/* Nova Sports Dome — shared stylesheet · dark cinematic */
:root {
  --bg: #0A0D0B;
  --bg-alt: #0F1310;
  --bg-card: #141A15;
  --panel: #10150F;          /* inverted feature sections (was --ink on light theme) */
  --ink: #F5F3EA;
  --ink-soft: #C9CDC4;
  --ink-mute: #8A9088;
  --line: rgba(245, 243, 234, 0.14);
  --line-soft: rgba(245, 243, 234, 0.08);
  --accent: #E8C15A;         /* warm gold — primary on dark */
  --accent-deep: #1E3D28;    /* deep pitch green */
  --accent-2: #6FBF8E;       /* lumen green */
  --accent-3: #E8C15A;       /* warm gold */
  --accent-warn: #D96C50;
  --display: 'Big Shoulders Display', 'Archivo Narrow', 'Helvetica Neue Condensed', Impact, sans-serif;
  --serif: 'Libre Caslon Text', 'EB Garamond', Georgia, serif;
  --sans: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', system-ui, sans-serif;
  --mono: 'JetBrains Mono', 'SF Mono', ui-monospace, monospace;
}
@import url('https://fonts.googleapis.com/css2?family=Big+Shoulders+Display:wght@500;600;700;800&family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=JetBrains+Mono:wght@400;500&display=swap');

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: var(--bg); color: var(--ink); font-family: var(--sans); font-size: 16px; line-height: 1.5; -webkit-font-smoothing: antialiased; }
body { min-height: 100vh; }
::selection { background: var(--accent); color: #0A0D0B; }

a { color: inherit; text-decoration: none; }
.inline-link { color: var(--accent); border-bottom: 1px solid currentColor; padding-bottom: 1px; }
.inline-link:hover { color: #fff; }

.container { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.container-wide { max-width: 1440px; margin: 0 auto; padding: 0 32px; }
.section { padding: 120px 0; }
.section-sm { padding: 64px 0; }

.mono { font-family: var(--mono); }
.tnum { font-variant-numeric: tabular-nums; }

.display-xl { font-family: var(--display); font-weight: 700; font-size: clamp(64px, 9.5vw, 148px); line-height: 0.92; letter-spacing: 0.005em; text-transform: uppercase; }
.display-lg { font-family: var(--display); font-weight: 700; font-size: clamp(50px, 7vw, 104px); line-height: 0.94; letter-spacing: 0.005em; text-transform: uppercase; }
.display-md { font-family: var(--display); font-weight: 700; font-size: clamp(40px, 5.5vw, 76px); line-height: 0.96; letter-spacing: 0.005em; text-transform: uppercase; }
.display-sm { font-family: var(--display); font-weight: 700; font-size: clamp(30px, 4vw, 52px); line-height: 1.0; letter-spacing: 0.005em; text-transform: uppercase; }
.italic-serif { font-family: var(--serif); font-style: italic; font-weight: 400; text-transform: none; letter-spacing: -0.01em; }
.display-xl .italic-serif, .display-lg .italic-serif, .display-md .italic-serif, .display-sm .italic-serif { font-size: 0.82em; }
.eyebrow { font-family: var(--sans); font-size: 12px; font-weight: 600; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-mute); }
.eyebrow::before { content: '✶'; color: var(--accent); margin-right: 10px; letter-spacing: 0; }
.eyebrow-accent { color: var(--accent); }
.star { color: var(--accent); font-style: normal; }

.body-lg { font-size: 19px; line-height: 1.55; color: var(--ink-soft); }
.body-md { font-size: 16px; line-height: 1.6; color: var(--ink-soft); }
.body-sm { font-size: 14px; line-height: 1.55; color: var(--ink-soft); }

.btn { display: inline-flex; align-items: center; gap: 10px; padding: 14px 22px; font-family: var(--sans); font-size: 14px; font-weight: 500; letter-spacing: 0.02em; border: 1px solid transparent; cursor: pointer; transition: all 0.18s; background: transparent; color: inherit; }
.btn-primary { background: var(--accent); color: #0A0D0B; }
.btn-primary:hover { background: #F4D27C; box-shadow: 0 0 32px rgba(232,193,90,0.25); }
.btn-outline { border-color: rgba(245,243,234,0.4); color: var(--ink); }
.btn-outline:hover { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.btn-lg { padding: 18px 28px; font-size: 15px; }
.arrow { display: inline-block; transition: transform 0.2s; }
.btn:hover .arrow { transform: translateX(3px); }

.hero-media { position: relative; overflow: hidden; background: #050706; }
.hero-media .img { position: absolute; inset: 0; background-size: cover; background-position: center; }
.hero-media video, .hero-media > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-media video.kenburns { animation: kenburns 26s ease-in-out infinite alternate; }
@keyframes kenburns { from { transform: scale(1); } to { transform: scale(1.07); } }
.hero-media .placeholder-hero { position: absolute; inset: 0; background: linear-gradient(135deg, var(--accent-deep), #0A0D0B); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.2); font-family: var(--mono); font-size: 14px; letter-spacing: 0.12em; }
.hero-media .scrim { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(5,7,6,0.25) 0%, rgba(5,7,6,0.45) 55%, rgba(10,13,11,0.92) 100%); }
.hero-media .content { position: relative; z-index: 2; }
.hero-media .page-chrome { position: absolute; top: 0; left: 0; right: 0; padding: 24px 32px; display: flex; justify-content: space-between; font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; color: rgba(255,255,255,0.72); text-transform: uppercase; z-index: 3; }

.placeholder { background: var(--bg-alt); display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; color: var(--ink-mute); text-transform: uppercase; border: 1px dashed var(--line); }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
@media (max-width: 920px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

.card { background: var(--bg-card); border: 1px solid var(--line); }
.badge { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-soft); padding: 6px 10px; background: rgba(245,243,234,0.04); border: 1px solid var(--line); }
.tick { color: var(--accent); }
.stat-num { font-family: var(--display); font-weight: 700; font-size: 80px; line-height: 0.95; letter-spacing: 0.01em; color: var(--ink); }

.marquee { overflow: hidden; position: relative; }
.marquee-track { display: flex; gap: 48px; white-space: nowrap; animation: marquee 45s linear infinite; font-family: var(--display); font-weight: 600; font-size: 34px; letter-spacing: 0.02em; padding: 12px 0; }
.marquee-item { color: var(--ink); text-transform: uppercase; }
.marquee-item.accent { font-style: italic; color: var(--accent); font-family: var(--serif); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* Scroll reveal — sections fade/rise as they enter the viewport */
.rv { opacity: 0; transform: translateY(28px); transition: opacity .8s cubic-bezier(.2,.6,.2,1), transform .8s cubic-bezier(.2,.6,.2,1); }
.rv.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .rv { opacity: 1; transform: none; transition: none; }
  .hero-media video.kenburns { animation: none; }
  .marquee-track { animation: none; }
}

/* Video feature cards */
.vid-card { position: relative; overflow: hidden; background: #050706; }
.vid-card video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.vid-card:hover video { transform: scale(1.04); }
.vid-card .vc-scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(5,7,6,0.85) 0%, rgba(5,7,6,0.05) 55%); }
.vid-card .vc-label { position: absolute; left: 24px; right: 24px; bottom: 20px; z-index: 2; }

/* Navbar — dark glass */
.navbar { position: sticky; top: 0; z-index: 100; background: rgba(10, 13, 11, 0.78); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); border-bottom: 1px solid var(--line-soft); }
.nav-inner { max-width: 1440px; margin: 0 auto; padding: 20px 32px; display: flex; align-items: center; justify-content: space-between; }
.nav-logo { display: flex; align-items: center; gap: 9px; font-family: var(--display); font-size: 20px; font-weight: 500; letter-spacing: -0.01em; }
.nav-logo-img { height: 42px; width: auto; display: block; }
.nav-logo .mark { width: 22px; height: 22px; border-radius: 50%; border: 1.5px solid var(--accent); position: relative; }
.nav-logo .mark::after { content: ''; position: absolute; inset: 4px; border-radius: 50%; background: var(--accent); }
.nav-logo .sub { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; color: var(--ink-mute); text-transform: uppercase; align-self: center; padding-left: 9px; border-left: 1px solid var(--line); }
.nav-links { display: flex; gap: 28px; font-size: 14px; }
.nav-links a { color: var(--ink-soft); padding: 6px 0; border-bottom: 1px solid transparent; transition: all 0.15s; }
.nav-links a:hover { color: var(--ink); }
.nav-links a.active { color: var(--accent); border-bottom-color: var(--accent); }
.nav-cta { display: flex; align-items: center; gap: 12px; }

/* Footer */
footer { background: #070907; color: var(--ink); padding: 80px 0 40px; border-top: 1px solid var(--line-soft); }
footer .foot-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; }
footer h4 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,253,246,0.55); margin-bottom: 20px; font-weight: 500; }
footer a { display: block; color: rgba(255,253,246,0.82); padding: 6px 0; font-size: 14px; }
footer a:hover { color: var(--accent-3); }
.footer-bottom { margin-top: 72px; padding-top: 28px; border-top: 1px solid rgba(255,253,246,0.15); display: flex; justify-content: space-between; font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; color: rgba(255,253,246,0.5); text-transform: uppercase; }

/* Form */
.field { display: block; width: 100%; padding: 14px 16px; font-family: var(--sans); font-size: 15px; border: 1px solid var(--line); background: var(--bg-card); color: var(--ink); transition: border-color 0.15s; }
.field::placeholder { color: var(--ink-mute); }
.field:focus { outline: none; border-color: var(--accent); }
.field-label { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 8px; }
.pill-group { display: flex; flex-wrap: wrap; gap: 8px; }
.pill { padding: 10px 16px; border: 1px solid var(--line); font-size: 13px; background: var(--bg-card); cursor: pointer; font-family: var(--sans); color: var(--ink-soft); transition: all 0.15s; }
.pill:hover { border-color: var(--ink-soft); }
.pill.on { background: var(--accent); color: #0A0D0B; border-color: var(--accent); }

/* Tweaks panel */
.tweaks-panel { position: fixed; bottom: 24px; right: 24px; width: 280px; background: var(--bg-card); border: 1px solid var(--line); box-shadow: 0 12px 40px rgba(0,0,0,0.55); padding: 20px; z-index: 500; font-size: 13px; }
.tweaks-panel h4 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 16px; }
.tweak-row { margin-bottom: 16px; }
.tweak-label { font-size: 11px; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 6px; }
.tweak-opts { display: flex; gap: 4px; flex-wrap: wrap; }
.tweak-opts button { padding: 6px 10px; font-size: 11px; border: 1px solid var(--line); background: var(--bg); cursor: pointer; font-family: var(--mono); letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-soft); }
.tweak-opts button.on { background: var(--accent); color: #0A0D0B; border-color: var(--accent); }

/* Blocked-time grid */
.sched-grid { display: grid; border: 1px solid var(--line); background: var(--line); gap: 1px; font-family: var(--mono); font-size: 10px; }
.sched-cell { background: var(--bg-card); padding: 4px 6px; min-height: 26px; letter-spacing: 0.04em; display: flex; align-items: center; justify-content: center; text-align: center; color: var(--ink-mute); }
.sched-cell.head { background: var(--bg-alt); font-weight: 500; color: var(--ink); letter-spacing: 0.1em; text-transform: uppercase; }
.sched-cell.booked { background: var(--accent); color: #0A0D0B; font-weight: 500; }
.sched-cell.partial { background: color-mix(in oklab, var(--accent) 35%, #10150F); color: var(--accent); }
.sched-cell.prime { background: var(--accent-3); color: #0A0D0B; }

/* Quote */
.quote-mark { font-family: var(--serif); font-size: 140px; line-height: 0.6; color: var(--accent); font-style: italic; }

/* Mobile nav toggle (hidden on desktop) */
.nav-toggle { display: none; align-items: center; justify-content: center; width: 44px; height: 44px; margin: -8px -6px -8px 0; background: transparent; border: none; cursor: pointer; }
.nav-toggle-bars { position: relative; width: 22px; height: 16px; }
.nav-toggle-bars i { position: absolute; left: 0; right: 0; height: 2px; background: var(--ink); border-radius: 2px; transition: transform .22s ease, opacity .18s ease, top .22s ease; }
.nav-toggle-bars i:nth-child(1) { top: 0; }
.nav-toggle-bars i:nth-child(2) { top: 7px; }
.nav-toggle-bars i:nth-child(3) { top: 14px; }
.nav-toggle-bars.open i:nth-child(1) { top: 7px; transform: rotate(45deg); }
.nav-toggle-bars.open i:nth-child(2) { opacity: 0; }
.nav-toggle-bars.open i:nth-child(3) { top: 7px; transform: rotate(-45deg); }
.nav-mobile { display: none; flex-direction: column; padding: 6px 20px 22px; border-top: 1px solid var(--line-soft); background: rgba(10,13,11,0.97); backdrop-filter: blur(18px); }
.nav-mobile a:not(.btn) { padding: 15px 2px; font-family: var(--display); font-size: 19px; font-weight: 500; color: var(--ink-soft); border-bottom: 1px solid var(--line-soft); }
.nav-mobile a.active { color: var(--accent); }

/* ============ Responsive / mobile ============ */
@media (max-width: 900px) {
  .section { padding: 72px 0; }
  .section-sm { padding: 44px 0; }
  .container, .container-wide { padding: 0 20px; }

  /* Nav → hamburger */
  .nav-links, .nav-cta { display: none; }
  .nav-toggle { display: inline-flex; }
  .nav-mobile.open { display: flex; }
  .nav-inner { padding: 13px 20px; }
  .nav-logo-img { height: 34px; }
  .nav-logo .sub { font-size: 9px; padding-left: 8px; }

  /* Type scale */
  .display-xl { font-size: clamp(40px, 12vw, 72px); }
  .stat-num { font-size: 52px; }
  .marquee-track { font-size: 24px; gap: 32px; }
  .quote-mark { font-size: 96px; }

  /* Footer */
  footer { padding: 56px 0 36px; }
  footer .foot-grid { grid-template-columns: 1fr 1fr; gap: 40px 24px; }
  .footer-bottom { flex-direction: column; gap: 10px; align-items: flex-start; margin-top: 48px; }

  /* Stack two-column inline (React) grids */
  [style*="grid-template-columns: minmax("],
  [style*="grid-template-columns: 0.8fr 1.2fr"],
  [style*="grid-template-columns: 1fr 2fr"],
  [style*="grid-template-columns: 1.2fr 1fr"],
  [style*="grid-template-columns: 1fr 1.2fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns: 1fr auto"] {
    grid-template-columns: 1fr !important;
  }
  /* 4-up → 2-up */
  [style*="grid-template-columns: repeat(4, 1fr)"] {
    grid-template-columns: 1fr 1fr !important;
  }
  /* Alternating image/text rows: image always on top */
  [style*="grid-template-columns: 1fr 1.2fr"] > div:first-child,
  [style*="grid-template-columns: 1.2fr 1fr"] > div:first-child { order: -1 !important; }
  [style*="grid-template-columns: 1fr 1.2fr"] > div[style*="min-height"],
  [style*="grid-template-columns: 1.2fr 1fr"] > div[style*="min-height"] { min-height: 240px !important; }

  /* Partner row (logo / name / status) → status drops to its own line */
  [style*="grid-template-columns: 64px 1fr 120px"] { grid-template-columns: 48px 1fr !important; gap: 16px !important; }
  [style*="grid-template-columns: 64px 1fr 120px"] > div:nth-child(3) { grid-column: 1 / -1 !important; text-align: left !important; }
  [style*="grid-template-columns: 64px 1fr 120px"] > div:first-child { width: 48px !important; height: 48px !important; }

  /* Rubric row (weight / category / detail) → detail drops to its own line */
  [style*="grid-template-columns: 80px 1fr 2fr"] { grid-template-columns: 64px 1fr !important; }
  [style*="grid-template-columns: 80px 1fr 2fr"] > div:nth-child(3) { grid-column: 1 / -1 !important; }

  /* Trim oversized inline paddings */
  [style*="padding: 56px"] { padding: 30px !important; }
  [style*="padding: 48px"] { padding: 26px !important; }
  [style*="padding: 40px"] { padding: 26px !important; }
  [style*="padding: 32px 40px"] { padding: 24px !important; }

  /* Oversized inline display numbers */
  [style*="font-size: 96px"] { font-size: 58px !important; }
  [style*="font-size: 88px"] { font-size: 56px !important; }
}

@media (max-width: 560px) {
  .section { padding: 56px 0; }
  .display-xl { font-size: clamp(34px, 11vw, 54px); }
  .stat-num { font-size: 44px; }
  footer .foot-grid { grid-template-columns: 1fr; gap: 32px; }
  .page-chrome span:last-child { display: none; }
  /* Heavy bordered card grids → single column on phones (stat grids stay 2-up) */
  [style*="grid-template-columns: repeat(4, 1fr)"][style*="gap: 1px"] { grid-template-columns: 1fr !important; }
}

/* Accent overrides via tweak — tuned for the dark theme */
[data-accent="green"] { --accent: #E8C15A; --accent-deep: #1E3D28; }
[data-accent="navy"] { --accent: #7FB6D9; --accent-deep: #14273F; }
[data-accent="rust"] { --accent: #E08A5E; --accent-deep: #4A2417; }
[data-accent="plum"] { --accent: #C9A8D9; --accent-deep: #3E263F; }
[data-accent="teal"] { --accent: #7FD4C4; --accent-deep: #163A38; }
