/* ==========================================================================
   Gambit About Program Marquee
   Headline anchored top-left + auto-scrolling horizontal row of category cards.
   ========================================================================== */

.gambit-about-marquee {
	background-color: var(--deep-charcoal, #1A1A1E);
	color: var(--warm-white, #F7F5F2);
	padding: 64px 0 80px;
	overflow: hidden;
}

@media (min-width: 768px) {
	.gambit-about-marquee {
		padding: 96px 0 112px;
	}
}

@media (min-width: 1100px) {
	.gambit-about-marquee {
		padding: 128px 0 144px;
	}
}

.gambit-about-marquee__inner {
	display: flex;
	flex-direction: column;
	gap: 32px;
}

@media (min-width: 1100px) {
	.gambit-about-marquee__inner {
		flex-direction: row;
		align-items: stretch;
		gap: 0;
	}
}

/* ---------- Heading column ---------- */

.gambit-about-marquee__heading {
	padding: 0 24px;
}

@media (min-width: 768px) {
	.gambit-about-marquee__heading {
		padding: 0 40px;
	}
}

@media (min-width: 1100px) {
	.gambit-about-marquee__heading {
		flex: 0 0 auto;
		width: 32%;
		max-width: 460px;
		padding: 0 32px 0 clamp(40px, 6vw, 96px);
		display: flex;
		align-items: flex-end;   /* anchor headline to bottom of column */
	}
}

.gambit-about-marquee__headline {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(32px, 4.5vw, 60px);
	line-height: 1.05;
	letter-spacing: -0.02em;
	color: var(--warm-white, #F7F5F2);
	margin: 0;
	text-wrap: balance;
}

.gambit-about-marquee__headline em {
	color: var(--signal-red, #C43D2F);
	font-style: italic;
}

/* ---------- Marquee viewport + track ---------- */

/* ---------- Scroller wrap (viewport + arrows) ---------- */

.gambit-about-marquee__scroller {
	position: relative;
	flex: 1 1 auto;
	min-width: 0;
}

/* ---------- Arrow buttons ---------- */

.gambit-about-marquee__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 3;
	width: 48px;
	height: 48px;
	border-radius: 999px;
	border: 1px solid rgba(247, 245, 242, 0.25);
	background-color: rgba(247, 245, 242, 0.96);
	color: var(--deep-charcoal, #1A1A1E);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	padding: 0;
	box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.6);
	transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

@media (min-width: 1100px) {
	.gambit-about-marquee__arrow {
		width: 52px;
		height: 52px;
	}
}

.gambit-about-marquee__arrow:hover,
.gambit-about-marquee__arrow:focus-visible {
	background-color: var(--signal-red, #C43D2F);
	border-color: var(--signal-red, #C43D2F);
	color: var(--warm-white, #F7F5F2);
	outline: none;
}

.gambit-about-marquee__arrow:focus-visible {
	box-shadow: 0 0 0 3px rgba(196, 61, 47, 0.35);
}

.gambit-about-marquee__arrow:active {
	transform: translateY(-50%) scale(0.96);
}

.gambit-about-marquee__arrow--prev {
	left: 12px;
}

.gambit-about-marquee__arrow--next {
	right: 12px;
}

@media (min-width: 1100px) {
	.gambit-about-marquee__arrow--prev {
		left: 16px;
	}
	.gambit-about-marquee__arrow--next {
		right: 24px;
	}
}

.gambit-about-marquee__viewport {
	min-width: 0;
	overflow-x: auto;
	overflow-y: hidden;
	overscroll-behavior-x: contain;
	scrollbar-width: none;            /* Firefox */
	-ms-overflow-style: none;          /* IE/Edge legacy */
	cursor: grab;
	mask-image: linear-gradient(to right, transparent 0, #000 24px, #000 calc(100% - 64px), transparent 100%);
	-webkit-mask-image: linear-gradient(to right, transparent 0, #000 24px, #000 calc(100% - 64px), transparent 100%);
}

.gambit-about-marquee__viewport::-webkit-scrollbar {
	display: none;
}

.gambit-about-marquee__viewport.is-grabbing {
	cursor: grabbing;
}

@media (min-width: 1100px) {
	.gambit-about-marquee__viewport {
		mask-image: linear-gradient(to right, transparent 0, #000 48px, #000 100%);
		-webkit-mask-image: linear-gradient(to right, transparent 0, #000 48px, #000 100%);
	}
}

.gambit-about-marquee__track {
	display: flex;
	width: max-content;
}

.gambit-about-marquee__set {
	display: flex;
	flex-shrink: 0;
	gap: 20px;
	padding: 0 10px;
}

@media (min-width: 768px) {
	.gambit-about-marquee__set {
		gap: 24px;
		padding: 0 12px;
	}
}

/* ---------- Card ---------- */

.gambit-about-marquee__card {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	flex-shrink: 0;
	width: 260px;
	height: 380px;
	border-radius: 20px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	background-color: rgba(247, 245, 242, 0.04);
	transition: transform 0.4s ease, box-shadow 0.4s ease;
}

@media (min-width: 768px) {
	.gambit-about-marquee__card {
		width: 300px;
		height: 440px;
		border-radius: 24px;
	}
}

@media (min-width: 1100px) {
	.gambit-about-marquee__card {
		width: 340px;
		height: 500px;
	}
}

@media (min-width: 1400px) {
	.gambit-about-marquee__card {
		width: 360px;
		height: 540px;
	}
}

.gambit-about-marquee__card:hover,
.gambit-about-marquee__card:focus-visible {
	transform: translateY(-4px);
	box-shadow: 0 24px 48px -16px rgba(0, 0, 0, 0.55);
	outline: none;
}

.gambit-about-marquee__card:focus-visible {
	outline: 2px solid var(--signal-red, #C43D2F);
	outline-offset: 4px;
}

/* ---------- Image + overlay ---------- */

.gambit-about-marquee__image-wrap {
	position: absolute;
	inset: 0;
	display: block;
}

.gambit-about-marquee__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.gambit-about-marquee__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to top,
		rgba(0, 0, 0, 0.75) 0%,
		rgba(0, 0, 0, 0.45) 35%,
		rgba(0, 0, 0, 0.10) 65%,
		rgba(0, 0, 0, 0.00) 100%
	);
	pointer-events: none;
}

/* ---------- Card body (label + microcopy) ---------- */

.gambit-about-marquee__card-body {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 20px 22px 22px;
	color: var(--warm-white, #F7F5F2);
}

@media (min-width: 1100px) {
	.gambit-about-marquee__card-body {
		padding: 24px 28px 28px;
		gap: 10px;
	}
}

.gambit-about-marquee__card-label {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(20px, 1.7vw, 26px);
	line-height: 1.15;
	letter-spacing: -0.01em;
}

.gambit-about-marquee__card-micro {
	font-family: var(--font-body);
	font-size: clamp(14px, 1vw, 16px);
	line-height: 1.45;
	color: rgba(247, 245, 242, 0.88);
	text-wrap: pretty;
}

/* ---------- Tappable affordance: arrow pill in the top-right of every card.
   Used on both mobile and desktop — signals the whole card is clickable. */

.gambit-about-marquee__arrow-pill {
	position: absolute;
	top: 14px;
	right: 14px;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 999px;
	background-color: rgba(247, 245, 242, 0.92);
	color: var(--deep-charcoal, #1A1A1E);
	pointer-events: none;
	transition: transform 0.25s ease, background-color 0.25s ease, color 0.25s ease;
}

@media (min-width: 1100px) {
	.gambit-about-marquee__arrow-pill {
		top: 18px;
		right: 18px;
		width: 40px;
		height: 40px;
	}
}

.gambit-about-marquee__card:hover .gambit-about-marquee__arrow-pill,
.gambit-about-marquee__card:focus-visible .gambit-about-marquee__arrow-pill {
	background-color: var(--signal-red, #C43D2F);
	color: var(--warm-white, #F7F5F2);
	transform: translateX(3px);
}

/* ---------- NEW badge ---------- */

.gambit-about-marquee__badge {
	position: absolute;
	top: 16px;
	left: 16px;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	padding: 6px 10px;
	border-radius: 999px;
	background-color: var(--signal-red, #C43D2F);
	color: var(--warm-white, #F7F5F2);
	font-family: var(--font-heading);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

@media (min-width: 1100px) {
	.gambit-about-marquee__badge {
		top: 20px;
		left: 20px;
		padding: 7px 12px;
		font-size: 12px;
	}
}

/* ==========================================================================
   Mobile (≤1099px): stack programs vertically instead of scrolling.
   Maximus-style — every program visible without horizontal motion.
   ========================================================================== */

@media (max-width: 1099px) {
	/* Hide nav arrows — nothing to navigate when stacked. */
	.gambit-about-marquee__arrow {
		display: none;
	}

	/* Viewport: kill the horizontal scroll + edge-fade mask, allow vertical flow. */
	.gambit-about-marquee__viewport {
		overflow: visible;
		cursor: auto;
		mask-image: none;
		-webkit-mask-image: none;
	}

	/* Track + set: vertical column, full-width children. */
	.gambit-about-marquee__track {
		display: flex;
		flex-direction: column;
		width: 100%;
	}

	.gambit-about-marquee__set {
		display: flex;
		flex-direction: column;
		width: 100%;
		gap: 16px;
		padding: 0 24px;
		box-sizing: border-box;
	}

	/* Hide the duplicate set — only needed for the desktop infinite-loop trick. */
	.gambit-about-marquee__track .gambit-about-marquee__set + .gambit-about-marquee__set {
		display: none;
	}

	/* Add gap between sets just in case (only the first should render). */
	.gambit-about-marquee__track > * + * {
		margin-top: 16px;
	}

	/* Cards: full-width, shorter landscape-ish aspect so a stack of 5–7 isn't a
	   never-ending column. */
	.gambit-about-marquee__card {
		width: 100%;
		height: auto;
		aspect-ratio: 4 / 3;
		min-height: 280px;
	}
}

