/**
 * Promo banners — pair of side-by-side banners with image, title, CTA.
 * Stacks vertically below 768px.
 */

.promo-banners {
	margin-block: 64px;
}

.promo-banners__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-4);
}

.promo-banner {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 360px;
	padding: var(--space-8);
	border-radius: 12px;
	overflow: hidden;
	isolation: isolate;
	color: var(--color-white);
}

.promo-banner__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
	transition: transform var(--transition-slow);
}

.promo-banner:hover .promo-banner__image {
	transform: scale(1.03);
}

.promo-banner__overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(
		126deg,
		rgba(54, 41, 37, 0.4) 18%,
		rgba(140, 129, 125, 0.4) 100%
	);
	pointer-events: none;
}

.promo-banner__content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
	align-items: flex-start;
}

.promo-banner__title {
	font-family: var(--font-heading);
	font-size: 2rem;            /* 32px */
	font-weight: var(--font-bold);
	line-height: var(--leading-normal);
	letter-spacing: -0.02em;
	color: var(--color-white);
	margin: 0;
}

/* === Responsive === */

@media (max-width: 768px) {
	.promo-banners__grid {
		grid-template-columns: 1fr;
	}

	.promo-banner {
        min-height: 360px;
        padding: var(--space-8);
    }

	.promo-banner__title {
		font-size: 2rem;
		line-height: 44px;
	}
	.promo-banners {
		margin-block: 42px;
	}
	.promo-banner .btn {
		padding: 10px 32px;
	}
}
