/* ── Section ─────────────────────────────────────────────── */
.section-home-banner {
	background-color: var(--color-bg-light-50);
	background-blend-mode: multiply;	overflow-x: clip;
	position: relative;
	z-index: 1;
}

/* ── Container — positioning context for decorative shape ── */
.section-home-banner .container {
	position: relative;
	padding-block: var(--size-pad-sm) var(--size-v-pad-sm);
}

/* ── Green asterisk — bottom-left, overflows into next section ── */
.section-home-banner .shape-ast-green {
	position: absolute;
	left: -3vw;
	bottom: -45%;
	width: 42vh;
	pointer-events: none;
	z-index: 0;
	will-change: transform;
}

@media only screen and (max-width: 991.98px) {
	.section-home-banner .shape-ast-green {
		display: none;
	}
}

/* ── Yellow decorative shape — positioned relative to container ── */
.section-home-banner .shape-strike-yellow {
	position: absolute;
	left: 48%;
	top: -14vh;
	height: 105vh;
	max-height: 59rem;
	width: auto;
	z-index: 0;
	pointer-events: none;
	will-change: transform;
}

/* ── Grid ────────────────────────────────────────────────── */
.section-home-banner .g-13-11 {
	grid-template-columns: 1fr 1fr;
	column-gap: var(--size-pad-xl);
	row-gap: 0;
	position: relative;
	z-index: 1;
}

/* ── Override shared hero gap for precise spacing ──────── */
.section-home-banner .hero-col-text {
	gap: 0;
}

/* ── Title max-width ────────────────────────────────────── */
.section-home-banner .hero-title {
	max-width: 16ch;
}

/* ── Body text colour ───────────────────────────────────── */
.section-home-banner .hero-desc {
	color: var(--color-text-pri-dark);
	margin-top: var(--size-pad-xs);          /* 32px */
}

/* ── CTA buttons spacing ───────────────────────────────── */
.section-home-banner .hero-btns {
	margin-top: 1.75rem;                     /* 28px */
}

/* ── Right column ────────────────────────────────────────── */
.hb-visual {
	position: relative;
}

/* ── Stacked card viewport ───────────────────────────────── */
.hb-stack {
	position: relative;
	z-index: 1;
}

.hb-stack-viewport {
	position: relative;
	height: 68vh;
	max-height: 35rem;
	margin-left: auto;
	/* Front card fills viewport; stacked cards fan left */
	overflow: visible;
	list-style: none;
	padding-left: 0;
}

@media only screen and (min-width: 1400px) {
	.hb-stack-viewport {
		width: 80%;
	}
}

/* ── Individual card ─────────────────────────────────────── */
.hb-stack-card {
	position: absolute;
	inset: 0;
	border-radius: var(--radius-card);
	border: var(--size-border-card-border) solid var(--color-border-light-100);
	overflow: hidden;
	will-change: transform, opacity;
	transition:
		transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
		opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1);
	transform-origin: center bottom;
}

/* ── Intro: all cards stacked flat, then fan out ─────────── */
.hb-stack.is-intro .hb-stack-card {
	transform: translateX(0) scale(1) !important;
	opacity: 1 !important;
	transition: none !important;
}

/* Fan-out transition applied after intro removed */
.hb-stack-card.is-fanning {
	transition:
		transform 1.2s cubic-bezier(0.4, 0, 0.2, 1),
		opacity 1.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Stacking layers — set by JS via data-stack + --stack custom property */
.hb-stack-card[data-stack="0"] {
	z-index: 50;
	transform: translateX(0) scale(1);
	opacity: 1;
}

/* Hover — scale only (desktop pointer devices only) */
@media (hover: hover) {
    .hb-stack-card[data-stack="0"]:hover {
        transform: scale(1.015);
    }

    .hb-stack-card a.hb-stack-link:hover {
        opacity: 1;
    }
}

/* All cards behind the front one — fan left, each +1deg counter-clockwise */
.hb-stack-card:not([data-stack="0"]) {
	--tx: calc(var(--stack, 0) * -2.5vw);
	--ty: calc(var(--stack, 0) * -2.5rem);
	--sc: max(calc(1 - var(--stack, 0) * 0.1), 0.1);
	--rot: calc(var(--stack, 0) * -2.5deg);
	z-index: calc(50 - var(--stack, 0));
	transform: translate(var(--tx), var(--ty)) rotate(var(--rot)) scale(var(--sc));
	pointer-events: none;
}

/* Exiting card — next: scale-down + fade, sits between front and stack */
.hb-stack-card.is-exiting-next {
	z-index: 49;
	opacity: 0;
	transform: scale(0.92);
	transition:
		transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
		opacity 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Exiting card — prev: fade out */
.hb-stack-card.is-exiting-prev {
	z-index: 5;
	opacity: 0;
	transition: opacity 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Entering card — starts invisible */
.hb-stack-card.is-entering-next,
.hb-stack-card.is-entering-prev {
	z-index: 5;
	opacity: 0;
}

/* Card beyond the responsive depth limit — hidden but still in DOM */
.hb-stack-card.is-depth-hidden {
	opacity: 0;
	pointer-events: none;
}

.hb-slide-img {
	width: 100%;
	height: 100%;
}

.hb-slide-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Bottom info overlay */
.hb-slide-info {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 1.5rem 7rem 1.75rem 1.75rem;
	background: linear-gradient(to top, var(--color-overlay-dark-72) 0%, var(--color-overlay-dark-30) 70%, transparent 100%);
	color: var(--color-text-pri-light);
}

.hb-slide-label {
	display: block;
	font-size: var(--fs-body-s);
	font-weight: var(--fw-semibold);
	color: var(--color-text-pri-light);
	margin-bottom: 0.35rem;
}

.hb-slide-title {
	font-weight: var(--fw-semibold);
	margin: 0 0 1rem;
}

.hb-slide-stats {
	display: flex;
	flex-wrap: wrap;
}

.hb-stat {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	padding-inline: 1rem;
}

.hb-stat:first-child {
	padding-inline-start: 0;
}

.hb-stat + .hb-stat {
	border-left: var(--size-border-card-border) solid rgba(255,255,255,0.3);
}

.hb-stat-label {
	font-size: var(--fs-body-s);
	font-weight: var(--fw-semibold);
	color: var(--color-text-pri-light);
	margin-bottom: 0.35rem;
}

.hb-slide-label strong,
.hb-stat-label strong {
	font-weight: var(--fw-semibold);
}

/* ── Clickable card link ────────────────────────────────── */
.hb-stack-link {
	display: block;
	width: 100%;
	height: 100%;
	color: inherit;
	text-decoration: none;
}

/* ── Per-card CTA — hidden by default, shown on mobile ───── */
.hb-slide-cta {
	display: none;
}

/* ── Blurb — hidden by default, shown on mobile ─────────── */
.hb-slide-blurb {
	display: none;
}

/* ── No-stats modifier — remove bottom gap ──────────────── */
.hb-slide-info--no-stats .hb-slide-title {
	margin-bottom: 0;
}

.hb-stat-value {
	font-size: var(--fs-h4);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--ls-lg);
}

/* ── Nav buttons — fixed over viewport, not inside cards ── */
.hb-slide-nav {
	position: absolute;
	bottom: 1.75rem;
	right: 1.75rem;
	pointer-events: auto;
	display: flex;
	gap: 0.5rem;
	z-index: 60;
}

.hb-nav-btn {
	width: var(--size-icon-slider-btn);
	height: var(--size-icon-slider-btn);
	border-radius: var(--radius-btn);
	border: var(--size-border-card-border) solid var(--color-border-light-100);
	background-color: var(--color-bg-light-50);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: var(--transition-fast);
	padding: 0;
}

@media (hover: hover) {
.hb-nav-btn:hover {
	box-shadow: rgba(0, 0, 0, 0.06) 0px 0px 0px 100px inset;
}
}

.hb-nav-btn img {
	width: var(--size-icon-widget);
	height: var(--size-icon-widget);
	object-fit: contain;
}

.hb-stack-next img {
	transform: rotate(180deg);
}


/* ── prefers-reduced-motion ──────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
	.hb-stack-card {
		transition: none;
	}

	.hb-stack-card.is-exiting-next,
	.hb-stack-card.is-exiting-prev {
		transition: none;
	}
}

/* ── "Some of our work" — hidden on desktop ────────────── */
.hb-work-heading {
	display: none;
}

/* ── Responsive — early collapse for home banner ────────── */
/* Hero content collides on pre-tablet widths; stack at ≤1199px
   instead of the global 991px grid breakpoint. */
@media only screen and (max-width: 991.98px) {
	.section-home-banner .g-13-11 {
		grid-template-columns: 1fr;
		row-gap: var(--size-pad-xs);
	}

	/* Reorder: text (1) → visual/slides (2) → logos (3) */
	.section-home-banner .hero-col-visual {
		order: 2;
	}

	.section-home-banner .hero-logos {
		order: 3;
	}

	.hb-stack-viewport {
		height: auto;
		aspect-ratio: 4 / 3;
	}
}

@media only screen and (max-width: 991.98px) {
	.section-home-banner .shape-strike-yellow {
		display: none;
	}

	.section-home-banner .container {
		padding-block-start: var(--size-v-pad-xl);
		padding-block-end: var(--size-v-pad-md);
	}

	.section-home-banner .hero-desc {
		margin-top: var(--size-pad-2xs);
	}

	/* ── Strip section-content inline padding so slider can bleed ── */
	.section-home-banner .section-content {
		padding-inline: 0;
	}

	/* ── Restore padding on non-slider children ──────────────── */
	.section-home-banner .hero-col-text,
	.section-home-banner .hb-logos-static,
	.section-home-banner .banner-trust-row {
		padding-inline: var(--size-global-padding-h);
	}

	/* ── Contain horizontal scroll within grid column ────────── */
	.section-home-banner .hero-col-visual {
		min-width: 0;
	}

	/* ── Mobile wrap: transparent, no dark bg ────────────────── */
	.hb-mobile-wrap {
		position: relative;
		border-radius: 0;
		overflow: hidden;
		background-color: transparent;
		min-width: 0;
	}

	.hb-mobile-wrap::before {
		display: none;
	}

	/* ── Viewport: horizontal scroll-snap container ──────────── */
	.hb-stack-viewport {
		display: flex;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		scroll-padding-inline-start: var(--size-global-padding-h);
		gap: 0.75rem;
		padding-inline: var(--size-global-padding-h);
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		width: 100%;
		height: auto;
		max-height: none;
		aspect-ratio: auto;
		margin-left: 0;
		margin-bottom: 0;
	}

	.hb-stack-viewport::-webkit-scrollbar {
		display: none;
	}

	/* ── Card: inline scroll item ────────────────────────────── */
	.hb-stack-card {
		position: relative;
		inset: auto;
		flex: 0 0 93%;
		scroll-snap-align: start;
		border: none;
		border-radius: 0;
		overflow: visible;
	}

	/* ── Tablet: narrower cards so 2+ are visible ────────────── */
	@media (min-width: 576px) {
		.hb-stack-card {
			flex: 0 0 60%;
		}
	}

	/* ── Show ALL cards for scroll (override pre-JS + post-JS) ─ */
	.hb-stack-card,
	.hb-stack-card:not(:first-child),
	.hb-stack-card[data-stack="0"],
	.hb-stack-card[data-stack]:not([data-stack="0"]) {
		display: flex !important;
		opacity: 1 !important;
		transform: none !important;
		pointer-events: auto !important;
	}

	/* ── White overlay: suppress ─────────────────────────────── */
	.hb-stack-card::after {
		display: none;
	}

	/* ── Link: flex column — image then info then button ──────── */
	.hb-stack-link {
		display: flex;
		flex-direction: column;
		width: 100%;
	}

	/* ── Image: rounded top ──────────────────────────────────── */
	.hb-slide-img {
		flex: none;
		width: 100%;
		height: auto;
		position: relative;
		margin: 0;
		border-radius: var(--radius-card);
		overflow: hidden;
		aspect-ratio: 4 / 3;
	}

	/* ── Arrow: hide ─────────────────────────────────────────── */
	.slide-arrow-btn {
		display: none;
	}

	/* ── Info: dark text, below image ─────────────────────────── */
	.hb-slide-info {
		position: static;
		background: transparent;
		color: var(--color-text-pri-dark);
		padding: var(--size-pad-xxs) 0 0;
		flex-shrink: 0;
	}

	/* ── Hide "Client" label ─────────────────────────────────── */
	.hb-slide-label {
		display: none;
	}

	/* ── Title ────────────────────────────────────────────────── */
	.hb-slide-title {
		font-size: var(--fs-h3);
		color: var(--color-text-pri-dark);
		margin: 0 0 0.75rem;
	}

	/* ── Blurb: 3-line clamp ─────────────────────────────────── */
	.hb-slide-blurb {
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
		font-size: var(--fs-body-s);
		color: var(--color-text-sec-dark);
		line-height: var(--lh-base);
		margin: 0 0 0.75rem;
	}

	/* ── Stats: bordered tags in flex-wrap row ────────────────── */
	.hb-slide-stats {
		flex-direction: row;
		flex-wrap: wrap;
		gap: var(--metric-tag-row-gap);
		align-items: flex-start;
		margin-bottom: 0.25rem;
	}

	.hb-stat {
		flex-direction: row;
		gap: var(--metric-tag-gap);
		padding: var(--metric-tag-pad);
		border: 1px solid var(--color-border-light-100);
		border-radius: var(--radius-btn);
		width: auto;
		align-items: baseline;
	}

	.hb-stat:first-child {
		padding-inline-start: 0.6rem;
	}

	.hb-stat + .hb-stat {
		border-left: 1px solid var(--color-border-light-100);
	}

	.hb-stat-label {
		order: 2;
		color: var(--color-text-sec-dark);
		font-size: var(--metric-tag-fs);
		margin-bottom: 0;
	}

	.hb-stat-value {
		order: 1;
		font-size: var(--metric-tag-fs);
		font-weight: var(--fw-semibold);
		color: var(--color-text-pri-dark);
	}

	/* ── Per-card CTA button ─────────────────────────────────── */
	.hb-slide-cta {
		display: inline-flex;
		align-items: center;
		align-self: flex-start;
		margin-top: 0.75rem;
		border-radius: var(--radius-btn);
		padding-block: var(--btn-sm-pad-v);
		padding-inline: var(--btn-sm-pad-h);
		font-size: var(--fs-button);
		font-weight: var(--fw-semibold);
		line-height: 1;
		letter-spacing: var(--ls-md);
		border: var(--size-border-button-border) solid var(--color-border-button-pri);
		background-color: var(--color-bg-button-pri);
		color: var(--color-text-pri-light);
	}

	/* ── Nav: hide ───────────────────────────────────────────── */
	.hb-slide-nav {
		display: none;
	}

	/* ── Section grid: logos above slider, case studies below ── */
	.section-home-banner .hero-logos {
		display: contents;
	}

	/* ── Trust row: split children across grid ───────────────── */
	.section-home-banner .banner-trust-row {
		display: contents;
	}

	.section-home-banner .banner-trust-text {
		display: inline;
		order: 1;
		padding-inline: var(--size-global-padding-h);
		margin-bottom: -1rem;
	}

	.section-home-banner .banner-cs-link {
		order: 5;
		margin-inline: var(--size-global-padding-h);
	}

	.section-home-banner .hb-logos-static {
		order: 2;
		padding-block-start: 0;
	}

	.section-home-banner .hero-col-visual {
		order: 4;
	}

	/* ── "Some of our work" heading — between logos and slider ── */
	.hb-work-heading {
		display: block;
		order: 3;
		padding-inline: var(--size-global-padding-h);
		margin: 0;
		margin-bottom: -1rem;
		font-size: var(--fs-body-m);
		font-weight: var(--fw-semibold);
		line-height: var(--lh-base);
		letter-spacing: var(--ls-md);
	}

	/* ── Logo grid: 3 cols × 2 rows (6 logos) ────────────────── */
	.section-home-banner .hero-logos-grid {
		grid-template-columns: 1fr 1fr 1fr;
		min-width: 0;
	}

	.section-home-banner .hero-logo-item {
		min-width: 0;
	}

	.section-home-banner .hero-logo-item img {
		max-width: 100%;
		width: 100%;
	}

	.section-home-banner .hero-logo-item:nth-child(n+10) {
		display: none;
	}

	/* ── Case studies link → full-width secondary button ──────── */
	.section-home-banner .banner-cs-link {
		display: flex;
		width: auto;
		align-items: center;
		justify-content: center;
		border-radius: var(--radius-btn);
		padding-block: var(--btn-pad-v);
		padding-inline: var(--btn-pad-h);
		font-size: var(--fs-button);
		font-weight: var(--fw-semibold);
		line-height: 1;
		letter-spacing: var(--ls-md);
		text-decoration: none !important;
		border: var(--size-border-button-border) solid var(--color-border-button-sec);
		background-color: var(--color-bg-button-sec);
		color: var(--color-text-pri-dark);
	}

	/* ── Logo bar: tablet size ───────────────────────────────── */
	.logo-bar--marquee .marquee-logo {
		width: 8rem;
		height: 4rem;
		padding: 0;
	}
}


.section-home-banner .hero-logos {
	margin-top: -1rem;
}

/* ── §2.2.7 — Logo bar: show/hide by breakpoint ─────────── */

/* Default: show static (desktop), hide marquee */
.hb-logos-marquee {
	display: none;
}

/* Tablet + mobile (<992px): static 3-col grid (max 10 logos) */
@media (max-width: 991.98px) {
	.hb-logos-static {
		display: block;
		border: none;
		border-radius: 0;
		padding: 0;
		background-color: transparent;
	}

	.hb-logos-marquee {
		display: none;
	}

	.section-home-banner .hero-logos {
		min-width: 0;
	}

	.section-home-banner .hero-logos-grid {
		display: grid;
		grid-template-columns: 1fr 1fr 1fr;
		gap: 0.5rem;
		min-width: 0;
	}

	.section-home-banner .hero-logo-item {
		display: flex;
		align-items: center;
		justify-content: center;
		height: 3.5rem;
		overflow: hidden;
		border: 1px solid var(--color-border-light-100);
		border-radius: var(--radius-btn);
		min-width: 0;
	}

	.section-home-banner .hero-logo-item img {
		max-width: 100%;
		width: 100%;
		min-height: 3.3rem;
		object-fit: contain;
		padding-block: 0.5rem;
	}

	.section-home-banner .hero-logo-item:nth-child(n+10) {
		display: none;
	}
}

/* ── §2.2.8 — Marquee logo bar layout ───────────────────── */
.logo-bar--marquee {
	padding: 0.5rem 0;
	overflow: hidden;
	flex-direction: column;
	gap: 0.625rem;
}

/* Scoped logo sizing for home banner marquee (tablet + mobile) */
.logo-bar--marquee .marquee-logo {
	height: 4rem;
}

.logo-bar--marquee .marquee-logo img {
	height: 4rem;
}


/* ── §2.4 — Slide arrow button ──────────────────────────── */
.slide-arrow-btn {
	position: absolute;
	top: 1rem;
	right: 1rem;
	width: 2.3rem;
	height: 2.3rem;
	background-color: var(--color-bg-dark-200);
	border: var(--size-border-card-border) solid var(--color-border-dark-100);
	border-radius: var(--radius-btn);
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
	z-index: 2;
	text-decoration: none;
	opacity: 0;
	transition: opacity var(--duration-base) var(--ease-default);
}

@media (hover: hover) {
    .hb-stack-card:hover .slide-arrow-btn {
        opacity: 1;
    }
}

.slide-arrow-btn img {
	width: 1.1rem;
	height: 1.1rem;
	object-fit: contain;
}

/* ── §2.5 — White card fade overlay — keyed to data-stack ── */
.hb-stack-card::after {
	content: '';
	position: absolute;
	inset: 0;
	background: #fff;
	opacity: 0.7;
	pointer-events: none;
	border-radius: inherit;
	z-index: 1;
	transition: opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.hb-stack-card[data-stack="0"]::after  { opacity: 0; }
.hb-stack-card[data-stack="1"]::after  { opacity: 0.08; }
.hb-stack-card[data-stack="2"]::after  { opacity: 0.16; }
.hb-stack-card[data-stack="3"]::after  { opacity: 0.26; }
.hb-stack-card[data-stack="4"]::after  { opacity: 0.36; }
.hb-stack-card[data-stack="5"]::after  { opacity: 0.46; }
.hb-stack-card[data-stack="6"]::after  { opacity: 0.54; }
.hb-stack-card[data-stack="7"]::after  { opacity: 0.61; }
.hb-stack-card[data-stack="8"]::after  { opacity: 0.67; }
.hb-stack-card[data-stack="9"]::after  { opacity: 0.72; }
.hb-stack-card[data-stack="10"]::after { opacity: 0.76; }
.hb-stack-card[data-stack="11"]::after { opacity: 0.79; }
.hb-stack-card[data-stack="12"]::after { opacity: 0.82; }
.hb-stack-card[data-stack="13"]::after { opacity: 0.84; }
.hb-stack-card[data-stack="14"]::after { opacity: 0.86; }
