/* ==========================================================================
   Offer / CTA
   ========================================================================== */

.offer {
	padding-inline: 7.5rem;


}

.offer.section:has(+ section.blog) {
	padding-bottom: 0;
}

.offer__inner {
	background-color: var(--color-accent);
	border-radius: 2.5rem 2.5rem 0 2.5rem;
	padding: 5rem 6rem;
	color: var(--color-text-light);
	position: relative;

	&::after {
		content: "";
        position: absolute;
        inset: 0;
        pointer-events: none;
        z-index: 0;
        height: 60%;
        width: 50%;
        background-color: var(--color-accent);
        top: 100%;
        border-radius: 0 0 2.5rem 0;
        margin-left: auto;
	}
}

.offer .module-title {
	text-align: left;
	margin-bottom: 0.5rem;
}

.offer__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 5rem;
	align-items: start;
}

.offer__heading {
	font-family: var(--font-primary);
	font-size: 4.5rem;
	font-weight: 800;
	line-height: 1.125;
	color: var(--color-text-light);
	margin: 0 0 2.5rem;
}

.offer__desc {
	font-family: var(--font-primary);
	font-size: 1.375rem;
	font-weight: 400;
	line-height: 1.25;
	color: var(--color-text-light);
	text-align: justify;
	margin: 0 0 2.5rem;
}

.offer__form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.offer__field input {
	width: 100%;
	background: transparent;
	border: none;
	border-bottom: 1px solid var(--color-text-light);
	padding: 0.5rem 0;
	font-family: var(--font-primary);
	font-size: 1.75rem;
	font-weight: 400;
	line-height: 1.1;
	color: var(--color-text-light);
	outline: none;
}

.offer__field input::placeholder {
	color: var(--color-text-light);
}

/* ==========================================================================
   Offer – Responsive
   ========================================================================== */

@media (max-width: 1024px) {
	.offer {
		padding-inline: var(--container-padding);
	}

	.offer__inner {
		padding: 3.75rem;
	}

	.offer__heading {
		font-size: 3rem;
		line-height: 1.2;
	}

	.offer__grid {
		gap: 3rem;
	}
}

@media (max-width: 768px) {
	.offer {
		padding-inline: var(--container-padding);
	}

	.offer__inner {
		padding: 2.5rem 1.5rem;
		border-radius: 1.5rem;
	}

	.offer__inner::after {
		display: none;
	}

	.offer__grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.offer .module-title {
		text-align: center;
	}

	.offer__heading {
		font-size: 2rem;
		line-height: 1.25;
		text-align: center;
		margin-bottom: 1.5rem;
	}

	.offer__left {
		text-align: center;
	}

	.offer__desc {
		font-size: 1.125rem;
		line-height: 1.375;
		text-align: left;
	}

	.offer__field input {
		font-size: 1.25rem;
		line-height: 1.2;
	}
}
