/* ── CSS variable: updated by JS with the actual banner height ── */
:root {
	--ccs-banner-height: 0px;
	--ccs-banner-body-offset: 0px;
}

/* ── Push the fixed navbar down by the banner height ── */
.ccs-header {
	top: calc(20px + var(--ccs-banner-height)) !important;
	transition: top 0.3s ease;
}

@media (max-width: 991.98px) {
	.ccs-header {
		top: var(--ccs-banner-height) !important;
	}
}

/* ── Anti-flash: hide banner before JS runs if already dismissed ── */
html.ccs-banner-pre-hidden #ccs-promo-banner {
	display: none;
}

/* Banner dismissed → reset navbar offset immediately */
html.ccs-banner-pre-hidden {
	--ccs-banner-height: 0px;
}

/* Keep the homepage hero and its carousel controls inside the viewport. */
body.home .ccs-home-hero {
	min-height: calc(100vh - var(--ccs-banner-height));
}

body.home .ccs-home-hero .ccs-home-hero-section {
	height: calc(100vh - var(--ccs-banner-height));
}

/* ── Banner wrapper ── */
.ccs-promo-banner {
	background-color: var(--color-natural);
	width: 100%;
	position: sticky;
	top: 0;
	z-index: 100; /* below navbar z-index: 1000 */
	overflow: hidden;
	max-height: 10rem;
	opacity: 1;
	transform: translateY(0);
	margin-top: calc(-1 * var(--ccs-banner-body-offset));
	margin-bottom: var(--ccs-banner-body-offset);
	transition: max-height 0.3s ease, opacity 0.25s ease, padding 0.3s ease, transform 0.3s ease;
}

.ccs-promo-banner--scroll-hidden {
	pointer-events: none;
	transform: translateY(-100%);
}

.ccs-promo-banner--closing {
	max-height: 0 !important;
	opacity: 0;
	padding-top: 0;
	padding-bottom: 0;
}

@media (prefers-reduced-motion: reduce) {
	.ccs-header,
	.ccs-promo-banner {
		transition: none;
	}
}

/* ── Inner layout ── */
.ccs-promo-banner__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0.25rem;
	position: relative;
	gap: 0.5rem;
}

/* ── Content (text + CTA) ── */
.ccs-promo-banner__content {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-wrap: wrap;
	justify-content: center;
}

.ccs-promo-banner__text {
	font-size: 1rem;
	font-weight: 400;
	color: var(--color-navy);
	letter-spacing: -0.4px;
	line-height: 1.28;
}

/* ── CTA link ── */
.ccs-promo-banner__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	font-size: 1rem;
	font-weight: 500;
	color: var(--color-red);
	text-decoration: none;
	letter-spacing: -0.2px;
	line-height: 1.28;
	transition: opacity 0.2s ease;
	white-space: nowrap;
}

.ccs-promo-banner__cta:hover {
	opacity: 0.75;
	color: var(--color-red);
	text-decoration: none;
}

.ccs-promo-banner__cta svg {
	flex-shrink: 0;
}

/* ── Close button ── */
.ccs-promo-banner__close {
	position: absolute;
	right: 1.25rem;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.375rem;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-navy);
	opacity: 0.6;
	transition: opacity 0.2s ease;
	line-height: 0;
}

.ccs-promo-banner__close:hover {
	opacity: 1;
}

.ccs-promo-banner__close:focus-visible {
	outline: 2px solid var(--color-navy);
	outline-offset: 2px;
	border-radius: 4px;
	opacity: 1;
}

/* ── Responsive ── */
@media (max-width: 767.98px) {
	.ccs-promo-banner__inner {
		padding: 0.25rem;
		justify-content: flex-start;
	}

	.ccs-promo-banner__content {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.25rem;
	}

	.ccs-promo-banner__text,
	.ccs-promo-banner__cta {
		font-size: 1rem;
	}

	.ccs-promo-banner__close {
		right: 0.75rem;
	}
}
