/*
 * sections.css
 * Atmosphere · Hero · Work grid · Card internals.
 */


/* ── Page atmosphere ──────────────────────────────────────── */

.page-atmosphere {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: -1;
	overflow: hidden;
}

.page-atmosphere::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(
		ellipse 55% 40% at 105% 105%,
		rgba(59, 130, 246, 0.09) 0%,
		transparent 60%
	);
}

.page-atmosphere::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 60%, rgba(5, 8, 16, 0.45) 100%);
}

body > *:not(.page-atmosphere):not(.popup-backdrop) {
	position: relative;
}


/* ── Page wrapper ─────────────────────────────────────────── */

.page {
	padding-top: calc(var(--nav-offset) + 40px);
	padding-bottom: var(--space-10);
	min-height: 100vh;
}


/* ── Hero ─────────────────────────────────────────────────── */

.hero-layout {
	display: grid;
	grid-template-columns: 1fr minmax(220px, 280px);
	align-items: start;
	gap: var(--space-6);
	margin-bottom: var(--space-8);
}

.hero-heading {
	font-size: var(--text-hero);
	font-weight: var(--weight-black);
	line-height: 0.9;
	letter-spacing: var(--tracking-tighter);
	text-transform: uppercase;
	color: var(--color-text);
	animation: fade-up var(--duration-slower) var(--ease-out) 80ms both;
}

.hero-heading .filled { color: var(--color-primary); }

.hero-aside {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
	padding-bottom: var(--space-2);
	animation: fade-up var(--duration-slower) var(--ease-out) 220ms both;
}

.hero-badge { animation: float-y 4s ease-in-out 600ms infinite; }

.hero-desc {
	font-family: var(--font-mono);
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: var(--leading-loose);
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}


/* ── Nav brand wordmark ───────────────────────────────────── */

.nav-brand-wordmark {
	font-size: 1.5rem;
	font-weight: 900;
	letter-spacing: -0.015em;
	font-family: "Inter", sans-serif;
}

.nav-brand-unit { color: #ffffff; }
.nav-brand-tv   { color: var(--color-primary); }

.nav-drawer-cta-btn {
	width: 100%;
	justify-content: center;
}


/* ═══════════════════════════════════════════════════════════
   WORK GRID
   grid-cols-3 gap-6 auto-rows-[220px] max-w-7xl
   ═══════════════════════════════════════════════════════════ */

.work-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-auto-rows: 220px;
	gap: 24px;
	max-width: 1280px;
	margin-inline: auto;
}

/* Card positions
   [ A        ][ B      ][ C      ]   row 1
   [ A        ][ E             ←  ]   row 2
   [ D        ][ E             ←  ]   row 3
*/
.work-card--a { grid-column: 1;     grid-row: 1 / 3; }
.work-card--b { grid-column: 2;     grid-row: 1;     }
.work-card--c { grid-column: 3;     grid-row: 1;     }
.work-card--d { grid-column: 1;     grid-row: 3;     }
.work-card--e { grid-column: 2 / 4; grid-row: 2 / 4; }


/* ── Card base ────────────────────────────────────────────── */

.work-card {
	position: relative;
	border-radius: var(--radius-xl);
	border: 1px solid rgba(255, 255, 255, 0.11);
	overflow: hidden;
	cursor: pointer;
	background-size: cover;
	background-position: center;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
	transition:
		transform     var(--duration-base) var(--ease-out),
		border-color  var(--duration-base) var(--ease-out),
		box-shadow    var(--duration-base) var(--ease-out);
}

.work-card:hover {
	transform: translateY(-6px) scale(1.015);
	border-color: rgba(59, 130, 246, 0.4);
	box-shadow: 0 28px 72px rgba(0, 0, 0, 0.7), 0 0 0 1px rgba(59, 130, 246, 0.15);
}

.work-card > *:not(.card-label):not(.card-overlay) {
	transition: transform 500ms cubic-bezier(0.22, 1, 0.36, 1);
}

.work-card:hover > *:not(.card-label):not(.card-overlay) {
	transform: scale(1.02);
}

.card-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to top,
		rgba(0, 0, 0, 0.72) 0%,
		rgba(0, 0, 0, 0.18) 45%,
		transparent 100%
	);
	z-index: 1;
	pointer-events: none;
}


/* ── Card label ───────────────────────────────────────────── */

.card-label {
	position: absolute;
	inset-block-end: 0;
	inset-inline: 0;
	z-index: 2;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	padding: var(--space-5) var(--space-5) var(--space-4);
}

.card-label-text {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.card-title {
	font-size: var(--text-xl);
	font-weight: var(--weight-black);
	letter-spacing: var(--tracking-tight);
	color: var(--color-text);
	text-shadow: 0 1px 6px rgba(0, 0, 0, 0.6);
	line-height: 1;
	text-transform: uppercase;
}

.card-caption {
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	color: rgba(255, 255, 255, 0.65);
	letter-spacing: var(--tracking-wide);
}

.card-arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-full);
	background: #ffffff;
	color: #000000;
	flex-shrink: 0;
	margin-left: var(--space-3);
	transition:
		transform   var(--duration-base) var(--ease-spring),
		box-shadow  var(--duration-base) var(--ease-out),
		background  var(--duration-fast) var(--ease-out);
}

.card-arrow svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

.work-card:hover .card-arrow {
	transform: scale(1.1);
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.35);
}


/* ── Card backgrounds ─────────────────────────────────────── */

.work-card--a { background-color: #070e22; }
.work-card--b { background-color: #050f10; }
.work-card--c { background-color: #0b0618; }
.work-card--d { background-color: #120505; }
.work-card--e { background-color: #06091a; }


/* ── Card entrance animations ─────────────────────────────── */

.work-card--a { animation: scale-up var(--duration-slower) var(--ease-out) 260ms both; }
.work-card--b { animation: scale-up var(--duration-slower) var(--ease-out) 320ms both; }
.work-card--c { animation: scale-up var(--duration-slower) var(--ease-out) 380ms both; }
.work-card--d { animation: scale-up var(--duration-slower) var(--ease-out) 300ms both; }
.work-card--e { animation: scale-up var(--duration-slower) var(--ease-out) 440ms both; }


/* ── Shared card content centering ───────────────────────── */

.card-center-content {
	position: absolute;
	inset: 0;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding-bottom: 60px;
}


/* ── Card A: App icon ─────────────────────────────────────── */

.card-a-icon {
	width: 250px;
	height: 250px;
	object-fit: contain;
	opacity: 0.92;
}


/* ── Card B: Subscription tiers ──────────────────────────── */

.subscription-tiers {
	display: flex;
	align-items: flex-end;
	gap: 14px;
}

.sub-tier {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 7px;
}

.sub-tier-icon {
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.sub-tier-icon--basic {
	width: 38px;
	height: 38px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.14);
	gap: 8px;
}

.sub-tier-icon--pro {
	width: 50px;
	height: 50px;
	background: rgba(59, 130, 246, 0.18);
	border: 1px solid rgba(59, 130, 246, 0.5);
	box-shadow: 0 0 22px rgba(59, 130, 246, 0.3);
}

.sub-tier-icon--vip {
	width: 64px;
	height: 64px;
	background: rgba(245, 158, 11, 0.15);
	border: 1px solid rgba(245, 158, 11, 0.5);
	box-shadow: 0 0 32px rgba(245, 158, 11, 0.28);
}

.sub-tier-label {
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.sub-tier-label--basic { font-size: 0.58rem; color: rgba(255, 255, 255, 0.35); }
.sub-tier-label--pro   { color: #60a5fa; }
.sub-tier-label--vip   { font-size: 0.66rem; color: #fbbf24; }


/* ── Card C: Channel chips ────────────────────────────────── */

.card-chips-wrap {
	flex-wrap: wrap;
	align-content: center;
	gap: 7px;
	padding: 16px 16px 70px;
}

.channel-chip-brand {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 4px 10px;
	border-radius: 99px;
	font-size: 0.63rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	white-space: nowrap;
	border: 1px solid;
}

.chip-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	flex-shrink: 0;
}

.chip-netflix { background: rgba(229, 9, 20, 0.14);   border-color: rgba(229, 9, 20, 0.4);   color: #ff4d4d;  }
.chip-netflix .chip-dot { background: #e50914; }

.chip-sky     { background: rgba(0, 122, 195, 0.14);  border-color: rgba(0, 122, 195, 0.45); color: #5eb8ff; }
.chip-sky .chip-dot { background: #007ac3; }

.chip-disney  { background: rgba(17, 60, 207, 0.2);   border-color: rgba(17, 60, 207, 0.5);  color: #6e8fff;  }
.chip-disney .chip-dot { background: #113ccf; }

.chip-dazn    { background: rgba(0, 200, 160, 0.12);  border-color: rgba(0, 200, 160, 0.4);  color: #00e0b0;  }
.chip-dazn .chip-dot { background: #00c8a0; }

.chip-hbo     { background: rgba(91, 45, 142, 0.22);  border-color: rgba(91, 45, 142, 0.5);  color: #c084fc;  }
.chip-hbo .chip-dot { background: #6d28d9; }

.chip-prime   { background: rgba(0, 168, 224, 0.13);  border-color: rgba(0, 168, 224, 0.4);  color: #38bdf8;  }
.chip-prime .chip-dot { background: #00a8e0; }

.chip-bein    { background: rgba(140, 0, 40, 0.18);   border-color: rgba(200, 0, 60, 0.4);   color: #ff8096;  }
.chip-bein .chip-dot { background: #c00040; }

.chip-espn    { background: rgba(200, 0, 30, 0.14);   border-color: rgba(200, 0, 30, 0.38);  color: #ff6666;  }
.chip-espn .chip-dot { background: #c8001e; }

.chip-bt      { background: rgba(102, 0, 204, 0.18);  border-color: rgba(102, 0, 204, 0.42); color: #d8b4fe;  }
.chip-bt .chip-dot { background: #6600cc; }

.chip-rtp     { background: rgba(0, 154, 68, 0.14);   border-color: rgba(0, 154, 68, 0.4);   color: #4ade80;  }
.chip-rtp .chip-dot { background: #009a44; }


/* ── Card D: Reviews ──────────────────────────────────────── */

.card-review-wrap {
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	padding: 20px 20px 70px;
}

.review-content {
	transition: opacity 400ms ease, transform 400ms ease;
}

.review-stars {
	color: #fbbf24;
	font-size: 0.75rem;
	margin-bottom: 8px;
	letter-spacing: 0.1em;
}

.review-text {
	font-size: 0.78rem;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.6;
	margin-bottom: 10px;
	font-style: italic;
}

.review-author {
	font-size: 0.7rem;
	font-weight: 700;
	color: rgba(255, 255, 255, 0.5);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}


/* ── Card E: Offer ────────────────────────────────────────── */

.card-e-inner {
	position: absolute;
	inset: 0;
	z-index: 1;
	display: flex;
	align-items: stretch;
	padding: 24px 24px 72px;
	overflow: hidden;
}

.card-e-stats {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0;
	flex: 0 0 auto;
	width: 42%;
	padding-right: 20px;
}

.card-e-stat {
	text-align: center;
	padding: 12px 0;
}

.card-e-stat-divider {
	height: 1px;
	background: rgba(255, 255, 255, 0.07);
	margin: 0 16px;
}

.card-e-vdivider {
	width: 1px;
	background: rgba(255, 255, 255, 0.07);
	flex-shrink: 0;
	align-self: stretch;
}

.card-e-pills {
	flex: 1;
	min-width: 0;
	padding-left: 20px;
	display: flex;
	align-items: center;
	overflow: hidden;
}

.offer-pills-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 6px;
	width: 100%;
	overflow: hidden;
}

.offer-pill {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 5px 10px;
	border-radius: 99px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	font-size: clamp(0.52rem, 0.8vw, 0.62rem);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.7);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	min-width: 0;
	justify-content: center;
}

.offer-pill svg {
	width: 10px;
	height: 10px;
	color: #60a5fa;
	flex-shrink: 0;
}


/* ── Stat blocks ──────────────────────────────────────────── */

.stat-number {
	font-size: clamp(1.5rem, 3vw, 2.5rem);
	font-weight: 900;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1;
	margin-bottom: 6px;
}

.stat-label {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.45);
}


/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 1800px) {
	.hero-layout {
		grid-template-columns: 1fr;
		gap: var(--space-6);
	}

	.hero-heading {
		font-size: clamp(var(--text-5xl), 14vw, var(--text-7xl));
	}

	.work-grid {
		grid-template-columns: repeat(2, 1fr);
		grid-auto-rows: 200px;
	}

	.work-card--a { grid-column: 1 / 3; grid-row: 1;     }
	.work-card--b { grid-column: 1;     grid-row: 2;     }
	.work-card--c { grid-column: 2;     grid-row: 2;     }
	.work-card--d { grid-column: 1;     grid-row: 3 / 5; }
	.work-card--e { grid-column: 2;     grid-row: 3 / 5; }

	.card-e-stats { width: 34%; }

	.stat-number {
		font-size: clamp(1rem, 1.6vw, 1.5rem);
	}

	.stat-label { font-size: 0.58rem; }

	.offer-pill {
		padding: 4px 7px;
		font-size: 0.52rem;
		gap: 4px;
	}

	.offer-pill svg {
		width: 9px;
		height: 9px;
	}
}

@media (max-width: 960px) {
	.nav-links,
	.nav-actions { display: none; }
	.nav-toggle  { display: flex; }

	.work-grid {
		grid-template-columns: 1fr;
		grid-auto-rows: 220px;
	}

	.work-card--a,
	.work-card--b,
	.work-card--c,
	.work-card--d,
	.work-card--e {
		grid-column: 1 !important;
		grid-row: auto !important;
	}

	.offer-pill:nth-child(n+7) { display: none; }

	.offer-pill {
		padding: 4px 7px;
		font-size: 0.52rem;
		gap: 4px;
	}

	.offer-pill svg {
		width: 9px;
		height: 9px;
	}

	.card-e-stats { width: 36%; }

	.stat-number {
		font-size: clamp(0.9rem, 3.5vw, 1.4rem);
	}

	.stat-label { font-size: 0.55rem; }
}


/* ── Reduced motion ───────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
	.hero-heading,
	.hero-aside,
	.hero-badge,
	.work-card--a,
	.work-card--b,
	.work-card--c,
	.work-card--d,
	.work-card--e {
		animation: none !important;
		opacity: 1 !important;
		transform: none !important;
	}
}
