/* ==========================================================================
   hero.css
   — Cover variant (.hero-cover) — front page only: background image + overlay
   — Data-Panel variant (.hero + .hero--data-panel) — inner pages: 60/40 mono stats
   ========================================================================== */

/* =========================== Cover hero (front) ====================== */
.hero-cover {
	position: relative;
	min-height: calc(100vh - var(--header-h));
	padding: calc(var(--header-h) + var(--s-80)) 0 var(--s-80);
	overflow: hidden;
	color: var(--c-white);
}

.hero-cover__bg {
	position: absolute;
	inset: 0;
	background-image: var(--hero-bg);
	background-size: cover;
	background-position: center;
	z-index: 0;
}

/* Dark overlay for editorial readability.
   NOT a box-shadow or gradient — plain solid-color layer with opacity. */
.hero-cover__overlay {
	position: absolute;
	inset: 0;
	background-color: rgba(11, 11, 13, 0.78);
	z-index: 1;
}

.hero-cover__inner {
	position: relative;
	z-index: 2;
	max-width: 760px;
	text-align: left;
}

.hero-cover__inner .kicker {
	color: var(--c-accent);
}

.hero-cover__h1 {
	font-family: var(--f-heading);
	font-weight: 500;
	font-size: clamp(2.25rem, 5.5vw, 3.75rem);
	line-height: 1.1;
	color: var(--c-white);
	margin-bottom: var(--s-24);
	max-width: 20ch;
}

.hero-cover__lead {
	font-family: var(--f-body);
	font-size: 1.125rem;
	line-height: 1.7;
	color: var(--c-text);
	margin-bottom: var(--s-40);
	max-width: 560px;
}

.hero-cover__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-16);
	align-items: center;
	margin-bottom: var(--s-48);
}

/* Secondary button contrast on overlaid background */
.btn-secondary--on-cover {
	border-color: var(--c-text);
	color: var(--c-white);
}
.btn-secondary--on-cover:hover,
.btn-secondary--on-cover:focus-visible {
	border-color: var(--c-accent);
	color: var(--c-accent);
}

/* Facts strip — horizontal mini mono row (replaces full data-panel) */
.hero-cover__facts {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	margin: 0;
	padding-top: var(--s-24);
	border-top: 1px solid rgba(232, 228, 216, 0.2);
	max-width: 720px;
}

.hero-cover__fact {
	flex: 1 1 auto;
	min-width: 140px;
	padding: var(--s-8) var(--s-24) var(--s-8) 0;
	margin: 0;
}

.hero-cover__fact + .hero-cover__fact {
	padding-left: var(--s-24);
	border-left: 1px solid rgba(232, 228, 216, 0.12);
}

.hero-cover__fact dt {
	font-family: var(--f-body);
	font-weight: 700;
	font-size: 0.6875rem;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--c-text-dim);
	margin: 0 0 var(--s-4);
}

.hero-cover__fact dd {
	font-family: var(--f-mono);
	font-size: 1rem;
	font-weight: 500;
	color: var(--c-white);
	margin: 0;
	font-variant-numeric: tabular-nums;
}

@media (max-width: 767px) {
	.hero-cover {
		min-height: auto;
		padding: calc(var(--header-h) + var(--s-48)) 0 var(--s-48);
	}
	.hero-cover__h1 {
		font-size: clamp(1.875rem, 8vw, 2.5rem);
	}
	.hero-cover__ctas .btn-primary,
	.hero-cover__ctas .btn-secondary,
	.hero-cover__ctas .btn-google-play {
		width: 100%;
		text-align: center;
	}
	.hero-cover__ctas .btn-google-play {
		display: flex;
		justify-content: center;
	}
	.hero-cover__fact {
		min-width: calc(50% - var(--s-12));
	}
	.hero-cover__fact + .hero-cover__fact {
		border-left: none;
		padding-left: 0;
	}
}

/* ======================== Data-panel hero (inner) ===================== */

.hero {
	background: var(--c-bg);
	padding: calc(var(--header-h) + var(--s-64)) 0 var(--s-80);
}

.hero--data-panel {
	display: grid;
	grid-template-columns: 60% 40%;
	gap: var(--s-64);
	min-height: calc(80vh - var(--header-h));
	align-items: center;
}

.hero--sm {
	padding: calc(var(--header-h) + var(--s-48)) 0 var(--s-48);
}

.hero--sm .hero--data-panel {
	min-height: auto;
}

/* --- Text column (left) --- */
.hero__text {
	max-width: 560px;
}

.hero__text .kicker {
	color: var(--c-accent);
	margin-bottom: var(--s-16);
}

.hero__text h1 {
	font-family: var(--f-heading);
	font-weight: 500;
	font-size: clamp(2rem, 4.5vw, 3.25rem);
	line-height: 1.15;
	margin-bottom: var(--s-24);
	color: var(--c-white);
}

.hero__lead {
	font-family: var(--f-body);
	font-size: 1.125rem;
	line-height: 1.7;
	color: var(--c-text-dim);
	margin-bottom: var(--s-32);
	max-width: 540px;
}

.hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-16);
	align-items: center;
	margin-bottom: var(--s-24);
}

/* Buttons inside hero should not inherit generic link styles */
.hero a:not(.btn-primary):not(.btn-secondary):not(.btn-google-play):not(.btn-tertiary) {
	color: var(--c-accent);
	text-decoration: underline;
	text-underline-offset: 4px;
}

/* --- Stats panel (right) --- */
.hero__stats {
	font-family: var(--f-mono);
	font-size: 0.875rem;
	border-top: 1px solid var(--c-border);
	align-self: stretch;
}

.hero__stat {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: var(--s-24);
	padding: var(--s-12) 0;
	border-bottom: 1px solid var(--c-border);
	align-items: baseline;
}

.hero__stat-label {
	color: var(--c-text-dim);
	text-transform: uppercase;
	letter-spacing: 1px;
	font-size: 0.75rem;
	font-weight: 400;
}

.hero__stat-value {
	color: var(--c-text);
	text-align: right;
	font-variant-numeric: tabular-nums;
	font-weight: 500;
}

.hero__stat-value--accent {
	color: var(--c-accent);
}

.hero__stat-value--moss {
	color: var(--c-accent-sec);
}

/* --- Hair-rule under CTAs (editorial detail) --- */
.hero__sep {
	border: 0;
	border-top: 1px solid var(--c-border);
	margin: var(--s-32) 0 0;
	max-width: 280px;
}

/* --- Responsive: stats-panel goes first on mobile --- */
@media (max-width: 1023px) {
	.hero--data-panel {
		grid-template-columns: 1fr;
		gap: var(--s-40);
		min-height: auto;
	}
	.hero__stats {
		order: -1;
	}
	.hero {
		padding: calc(var(--header-h) + var(--s-40)) 0 var(--s-48);
	}
	.hero--sm {
		padding: calc(var(--header-h) + var(--s-32)) 0 var(--s-32);
	}
	.hero__text {
		max-width: 100%;
	}
}

@media (max-width: 767px) {
	.hero__text h1 {
		font-size: clamp(1.75rem, 7vw, 2.25rem);
	}
	.hero__lead {
		font-size: 1rem;
	}
	.hero__ctas {
		width: 100%;
	}
	.hero__ctas .btn-secondary,
	.hero__ctas .btn-primary {
		width: 100%;
		text-align: center;
	}
}
