/* ---------- design tokens ---------- */
:root{
  --bg:#0a0c10;
  --panel:#10141a;
  --panel-2:#161b22;
  --line:#22272f;
  --line-2:#1a1f26;
  --ink:#e8edf2;
  --ink-2:#a8b2bc;
  --ink-3:#6b7480;
  --accent:#ff3838;
  --gold:#f5c542;
  --gold-glow:rgba(245,197,66,.55);
  --green:#3ddc84;
  --blue:#4aa7ff;
  --purple:#b487ff;
  --orange:#ff8a3d;

  --c-sp9-pro:#f5c542;
  --c-sp9-proam:#ff8a3d;
  --c-sp9-am:#ff6b6b;
  --c-sp-pro:#ff5454;
  --c-sp8:#4aa7ff;
  --c-sp10:#b487ff;
  --c-cup2:#c7ccd4;
  --c-cup3:#8a93a1;
  --c-tcr:#3ddc84;
  --c-at:#b487ff;
  --c-prod:#6b8aa0;

  --r:6px;
  --r-lg:10px;
  --gap:14px;
  --topbar-h:52px;

  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --sans:Inter,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body.app{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
}
h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em}
a{color:var(--blue);text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{
  position:absolute;left:8px;top:-40px;background:var(--gold);color:#000;padding:8px 12px;
  border-radius:var(--r);font-weight:600;z-index:9999;transition:top .15s
}
.skip-link:focus{top:8px}

/* ---------- topbar ---------- */
.topbar{
  height:var(--topbar-h);
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
  padding:0 16px;
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,#0e1218,#0a0c10);
  position:relative;
  z-index:5;
}
.brand{display:flex;align-items:center;gap:8px;color:var(--ink);font-weight:700;letter-spacing:.5px}
.brand-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(255,56,56,.55);animation:pulse 2.2s infinite}
.brand-text{font-size:14px}
.brand-mark{font-family:var(--mono);font-size:11px;color:var(--gold);margin-left:2px}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

.race-strip{display:flex;align-items:center;gap:14px;justify-content:center;flex-wrap:wrap}
.countdown-mini{display:inline-flex;align-items:baseline;gap:4px;font-family:var(--mono);font-size:13px;color:var(--ink-2)}
.countdown-mini .cd-label{color:var(--ink-3);text-transform:uppercase;letter-spacing:1px;font-size:10px;margin-right:6px}
.countdown-mini .cd-num{font-size:16px;color:var(--ink);font-weight:600;min-width:18px;text-align:right}
.countdown-mini .cd-num.small{font-size:12px;color:var(--ink-2);min-width:14px}
.countdown-mini .cd-sep{color:var(--ink-3);margin-right:6px;font-size:11px}

.race-phase{
  display:inline-flex;align-items:center;gap:8px;
  padding:4px 12px;border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:.5px;
  background:var(--panel);color:var(--ink-2);border:1px solid var(--line);
}
.race-phase::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ink-3)}
.race-phase.phase-pre::before{background:var(--green)}
.race-phase.phase-live{color:var(--accent);border-color:rgba(255,56,56,.35);background:rgba(255,56,56,.06)}
.race-phase.phase-live::before{background:var(--accent);box-shadow:0 0 8px rgba(255,56,56,.6)}
.race-phase.phase-night{color:var(--purple);border-color:rgba(180,135,255,.3)}
.race-phase.phase-night::before{background:var(--purple)}
.race-phase.phase-dawn{color:var(--orange);border-color:rgba(255,138,61,.3)}
.race-phase.phase-dawn::before{background:var(--orange)}
.race-phase.phase-finale{color:var(--gold);border-color:rgba(245,197,66,.4)}
.race-phase.phase-finale::before{background:var(--gold);box-shadow:0 0 8px var(--gold-glow)}
.race-phase.phase-post{color:var(--ink-3)}

.top-actions{display:flex;align-items:center;gap:10px}
.btn-link{color:var(--ink-2);font-size:13px;padding:6px 10px;border-radius:var(--r)}
.btn-link:hover{color:var(--ink);background:var(--panel)}
.btn-pill{
  font-size:12px;font-weight:600;padding:7px 12px;border-radius:999px;
  background:var(--gold);color:#0a0c10;
}
.btn-pill:hover{background:#ffd95f}

/* ---------- layout ---------- */
.layout{
  display:grid;
  grid-template-columns:280px 1fr 340px;
  height:calc(100vh - var(--topbar-h));
  gap:var(--gap);
  padding:var(--gap);
}
.layout aside{
  display:flex;flex-direction:column;gap:var(--gap);
  overflow-y:auto;min-height:0;
}
.stage{position:relative;background:#070a0d;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line)}
#map{position:absolute;inset:0}

@media (max-width:1100px){
  body.app{overflow:auto}
  .layout{grid-template-columns:1fr;height:auto;padding:10px;gap:10px}
  .stage{height:62vh;min-height:420px}
  .layout aside{max-height:none;overflow:visible}
}

/* ---------- cards ---------- */
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:14px;display:flex;flex-direction:column;gap:10px;
}
.card-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.card h3{font-size:11px;letter-spacing:1.4px;color:var(--ink-3);text-transform:uppercase;font-weight:600}
.card-meta{font-family:var(--mono);font-size:10px;color:var(--ink-3)}
.card-tag{font-family:var(--mono);font-size:10px;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase}
.empty-state{color:var(--ink-3);font-family:var(--mono);font-size:12px;text-align:center;padding:12px 0}

/* ---------- featured card ---------- */
.featured-card{
  background:linear-gradient(180deg,rgba(245,197,66,.08),var(--panel) 35%);
  border-color:rgba(245,197,66,.35);
  position:relative;
}
.featured-card::before{
  content:"";position:absolute;left:0;top:0;width:3px;bottom:0;background:var(--gold);
  border-radius:var(--r-lg) 0 0 var(--r-lg);
}
.featured-num{font-family:var(--mono);font-size:26px;font-weight:700;color:var(--gold);line-height:1;letter-spacing:-.5px}
.featured-name{font-size:15px;font-weight:600;color:var(--ink)}
.featured-team{font-size:12px;color:var(--ink-2);line-height:1.45}
.featured-team span{color:var(--ink-3);font-family:var(--mono);font-size:11px}
.featured-card img.car-photo{display:block;width:100%;border-radius:var(--r);margin-top:4px}
.kv-grid{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;margin:0;font-size:12px}
.kv-grid dt{color:var(--ink-3);font-family:var(--mono);text-transform:uppercase;font-size:10px;letter-spacing:1px}
.kv-grid dd{margin:0;color:var(--ink);font-family:var(--mono);font-size:12px;text-align:right}
.follow-btn{
  width:100%;padding:10px;border-radius:var(--r);
  background:var(--panel-2);color:var(--ink);border:1px solid var(--line);
  font-weight:600;font-size:13px;min-height:42px;
}
.follow-btn:hover{background:#1d242c;border-color:var(--ink-3)}
.follow-btn.active{background:rgba(245,197,66,.14);color:var(--gold);border-color:rgba(245,197,66,.45)}

/* ---------- class chips ---------- */
.chip-row{display:flex;flex-wrap:wrap;gap:5px}
.chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 9px;border-radius:999px;font-size:11px;font-family:var(--mono);
  background:var(--panel-2);color:var(--ink-2);border:1px solid var(--line);
  min-height:28px;
}
.chip:hover{background:#1d242c}
.chip.active{background:var(--ink-2);color:#0a0c10;border-color:var(--ink-2)}
.chip .swatch{width:7px;height:7px;border-radius:50%}
.chip.featured.active{background:var(--gold);color:#0a0c10;border-color:var(--gold)}
.chip.featured{color:var(--gold);border-color:rgba(245,197,66,.35)}

/* ---------- weather ---------- */
.weather-row{display:flex;align-items:center;gap:14px}
.weather-temp{font-family:var(--mono);font-size:32px;font-weight:700;color:var(--ink);line-height:1}
.weather-meta{font-size:12px;color:var(--ink-2);line-height:1.5}
.forecast{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin-top:2px}
.fc-cell{background:var(--panel-2);border:1px solid var(--line);border-radius:4px;padding:5px 2px;text-align:center;font-size:10px;font-family:var(--mono)}
.fc-h{color:var(--ink-3)}
.fc-t{color:var(--ink);font-weight:600;margin-top:1px}
.fc-r{color:var(--blue);margin-top:1px}

/* ---------- map overlays ---------- */
.map-status{
  position:absolute;left:14px;top:14px;
  display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;
  background:rgba(10,12,16,.86);backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:999px;
  padding:7px 14px;font-size:12px;color:var(--ink-2);
  font-family:var(--mono);max-width:calc(100% - 28px);
}
.map-status .dot{width:8px;height:8px;border-radius:50%;background:var(--ink-3)}
.map-status .sep{color:var(--ink-3)}
.map-meta{
  position:absolute;left:14px;bottom:14px;
  font-family:var(--mono);font-size:10px;color:var(--ink-3);
  background:rgba(10,12,16,.7);padding:4px 8px;border-radius:4px;border:1px solid var(--line-2);
}
.map-legend{
  position:absolute;right:14px;bottom:14px;
  background:rgba(10,12,16,.86);backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:var(--r);
  padding:9px 12px;font-size:11px;color:var(--ink-2);display:flex;flex-direction:column;gap:5px;
}
.map-legend .strk{display:inline-block;width:18px;height:2px;border-radius:1px;margin-right:7px;vertical-align:middle}
.map-legend .strk.red{background:var(--accent)}
.map-legend .strk.gold{background:var(--gold)}
.map-legend .dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;vertical-align:middle}
.map-legend .dot.gold{background:var(--gold)}
.map-legend .dot.pulse{animation:pulseGold 1.8s ease-in-out infinite}
@keyframes pulseGold{0%,100%{box-shadow:0 0 0 0 var(--gold-glow)}50%{box-shadow:0 0 0 10px transparent}}

/* ---------- leaderboard ---------- */
.lb{display:flex;flex-direction:column;gap:1px}
.lb-row{
  display:grid;grid-template-columns:22px 36px 1fr 64px;gap:8px;align-items:center;
  padding:6px 8px;border-radius:4px;font-size:12px;
}
.lb-row:nth-child(odd){background:rgba(255,255,255,.015)}
.lb-pos{color:var(--ink-3);font-family:var(--mono);font-size:11px;text-align:right}
.lb-num{font-family:var(--mono);color:var(--ink);font-weight:600;font-size:12px}
.lb-team{color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-gap{font-family:var(--mono);color:var(--ink-3);text-align:right;font-size:11px}
.lb-row.verstappen{background:rgba(245,197,66,.1);border-left:2px solid var(--gold);padding-left:6px}
.lb-row.verstappen .lb-team{color:var(--gold);font-weight:600}

/* ---------- drivers list ---------- */
.dl{display:flex;flex-direction:column;gap:8px;max-height:340px;overflow-y:auto}
.dl-group{padding-left:8px;border-left:2px solid var(--cls,var(--line));display:flex;flex-direction:column;gap:3px}
.dl-h{display:flex;align-items:center;justify-content:space-between;font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--ink-3);margin-bottom:3px}
.dl-count{font-family:var(--mono);color:var(--ink-2);background:var(--panel-2);border-radius:999px;padding:1px 6px;font-size:9px}
.dl-row{
  display:flex;align-items:center;gap:8px;width:100%;
  background:var(--panel-2);border:1px solid var(--line);border-radius:4px;
  padding:5px 8px;text-align:left;color:var(--ink);font-size:12px;min-height:30px;
}
.dl-row:hover{background:#1d242c}
.dl-row.featured{background:rgba(245,197,66,.1);border-color:rgba(245,197,66,.4)}
.dl-row.featured .dl-team{color:var(--gold)}
.dl-num{font-family:var(--mono);font-weight:600;color:var(--gold);min-width:34px;font-size:11px}
.dl-team{flex:1;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dl-team small{display:block;color:var(--ink-3);font-size:10px;font-family:var(--mono)}

/* ---------- popups (MapLibre) ---------- */
.maplibregl-popup{font-family:var(--sans)}
.maplibregl-popup-content{
  background:#11151b !important;color:var(--ink) !important;
  border:1px solid var(--line);border-radius:var(--r-lg);padding:14px !important;
  box-shadow:0 12px 40px rgba(0,0,0,.5);
}
.maplibregl-popup-close-button{color:var(--ink-3) !important;font-size:18px;padding:6px 10px !important}
.maplibregl-popup-tip{border-top-color:#11151b !important;border-bottom-color:#11151b !important}

/* ---------- about page ---------- */
.about-page{
  background:var(--bg);color:var(--ink);font-family:var(--sans);
  max-width:760px;margin:0 auto;padding:64px 24px 80px;line-height:1.6;
}
.about-page h1{font-size:32px;margin-bottom:24px;letter-spacing:-.02em}
.about-page h2{font-size:18px;color:var(--gold);margin:32px 0 12px;text-transform:uppercase;letter-spacing:1.5px;font-size:13px}
.about-page p{color:var(--ink-2);margin:0 0 14px}
.about-page a{color:var(--gold)}
.about-page .back{display:inline-block;margin-bottom:24px;color:var(--ink-2);font-size:13px}
.about-page table{width:100%;border-collapse:collapse;margin:8px 0 18px;font-size:13px}
.about-page th,.about-page td{padding:6px 10px;text-align:left;border-bottom:1px solid var(--line-2)}
.about-page th{color:var(--ink-3);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:1px}

/* ---------- /live full-bleed layout ---------- */
.live-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  height:calc(100vh - var(--topbar-h));
}
.live-layout .stage{
  position:relative;background:#070a0d;
  border-right:1px solid var(--line);
  border-radius:0;border-left:0;border-top:0;border-bottom:0;
}

.weather-overlay{
  position:absolute;right:14px;top:14px;
  background:rgba(10,12,16,.86);backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:var(--r);
  padding:8px 12px;display:flex;gap:10px;align-items:center;
}
.weather-overlay .w-temp{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--ink);line-height:1}
.weather-overlay .w-meta{font-size:11px;color:var(--ink-2);line-height:1.4;font-family:var(--mono)}

.rail{
  background:var(--panel);display:flex;flex-direction:column;min-height:0;
}
.rail-selected{
  border-bottom:1px solid var(--line);min-height:130px;padding:16px;
  display:flex;flex-direction:column;gap:8px;
}
.rail-selected .empty-hint{color:var(--ink-3);font-size:13px;line-height:1.5;margin:0;text-align:center;padding-top:16px}
.rail-selected.has-selection{padding:16px;gap:10px}

.sel-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.sel-num{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--cls,var(--gold));letter-spacing:-.5px}
.sel-class{font-family:var(--mono);font-size:10px;color:var(--ink-3);background:var(--panel-2);border:1px solid var(--line-2);padding:2px 7px;border-radius:999px;letter-spacing:1px}
.sel-star{color:var(--gold);font-size:11px;font-family:var(--mono)}
.sel-team{font-size:14px;font-weight:600;color:var(--ink);line-height:1.3}
.sel-car{font-size:12px;color:var(--ink-2);font-family:var(--mono)}
.sel-photo{width:100%;border-radius:var(--r);margin-top:2px;background:var(--panel-2)}
.sel-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:6px}
.sel-stat{background:var(--panel-2);border:1px solid var(--line-2);border-radius:var(--r);padding:6px 8px;text-align:center}
.sel-stat .l{font-size:9px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.8px}
.sel-stat .v{font-family:var(--mono);font-size:13px;color:var(--ink);font-weight:600;margin-top:2px}
.sel-drivers{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.sel-drivers div{background:var(--panel-2);border:1px solid var(--line-2);border-radius:4px;padding:5px 9px;font-size:12px;color:var(--ink-2)}
.sel-drivers div.current{border-color:rgba(245,197,66,.35);color:var(--gold)}
.sel-ctas{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.sel-ctas a{padding:6px 10px;border-radius:var(--r);font-size:11px;font-family:var(--mono);text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.sel-ctas a.cta-gold{background:var(--gold);color:#0a0c10}
.sel-ctas a.cta-ghost{background:var(--panel-2);color:var(--ink-2);border:1px solid var(--line)}

.rail-toolbar{
  padding:10px 12px;border-bottom:1px solid var(--line);
  display:flex;flex-direction:column;gap:8px;background:var(--panel);
}
.rail-search{
  width:100%;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r);
  color:var(--ink);padding:7px 10px;font:13px var(--sans);
}
.rail-search:focus{border-color:var(--gold);outline:none}

.rail-list{flex:1;overflow-y:auto;padding:6px 6px 14px;min-height:0}
.rail-list .empty-state{padding:24px;text-align:center;color:var(--ink-3);font-family:var(--mono);font-size:12px}
.car-row{
  display:grid;grid-template-columns:38px 1fr auto;gap:8px;align-items:center;
  padding:6px 8px;border-radius:4px;cursor:pointer;text-align:left;color:inherit;font:inherit;width:100%;
  border:1px solid transparent;background:transparent;
}
.car-row:hover{background:var(--panel-2)}
.car-row.active{background:rgba(245,197,66,.10);border-color:rgba(245,197,66,.35)}
.car-row.live::after{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px rgba(61,220,132,.7)}
.car-row .num{font-family:var(--mono);font-weight:700;color:var(--cls,var(--ink));font-size:13px;text-align:right}
.car-row .info{overflow:hidden}
.car-row .team{font-size:12px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.car-row .car{font-size:10px;color:var(--ink-3);font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.car-row.featured .num{color:var(--gold)}
.car-row.featured .team::before{content:"★ ";color:var(--gold)}

.rail-meta{padding:8px 14px;border-top:1px solid var(--line);color:var(--ink-3);font-family:var(--mono);font-size:10px}

@media (max-width:980px){
  body.app{overflow:auto}
  .live-layout{grid-template-columns:1fr;height:auto}
  .live-layout .stage{height:62vh;min-height:420px;border-right:0;border-bottom:1px solid var(--line)}
  .rail{height:auto}
  .rail-list{max-height:50vh}
}

/* ---------- content pages (home, classes, learn, drivers) ---------- */
body.content{overflow:auto;font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.6}
.content-nav{
  position:sticky;top:0;z-index:50;background:rgba(10,12,16,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{max-width:1280px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;justify-content:space-between;gap:20px;position:relative}
.nav-links{display:flex;gap:2px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links li{margin:0}
.nav-links a{color:var(--ink-2);padding:8px 12px;border-radius:var(--r);font-size:13px}
.nav-links a:hover{color:var(--ink);background:var(--panel)}
.nav-links a.active{color:var(--ink);background:var(--panel-2)}
.nav-links a.nav-cta{background:var(--gold);color:#0a0c10;font-weight:600;padding:8px 14px}
.nav-links a.nav-cta:hover{background:#ffd95f;color:#0a0c10}
.nav-toggle{display:none;background:transparent;border:1px solid var(--line);color:var(--ink);padding:7px 11px;border-radius:var(--r);font-size:13px}
@media (max-width:880px){
  .nav-toggle{display:inline-flex}
  .nav-links{position:absolute;left:0;right:0;top:100%;flex-direction:column;background:var(--bg);border-bottom:1px solid var(--line);padding:8px 14px;display:none}
  .nav-links.open{display:flex}
  .nav-links a, .nav-links a.nav-cta{width:100%;text-align:left}
}

.container{max-width:1280px;margin:0 auto;padding:0 22px}
.container-sm{max-width:820px;margin:0 auto;padding:0 22px}
.section{padding:56px 0}
.section-tight{padding:28px 0}

/* hero */
.hero{
  padding:72px 0 56px;border-bottom:1px solid var(--line);
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(245,197,66,.12), transparent 60%),
    radial-gradient(700px 420px at 10% 30%, rgba(255,56,56,.08), transparent 55%),
    linear-gradient(180deg,#0a0c10,#0d1117);
}
.hero-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:48px;align-items:center;max-width:1280px;margin:0 auto;padding:0 22px}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr;gap:28px}}
.hero h1{font-size:clamp(34px,5vw,56px);line-height:1.08;font-weight:700;letter-spacing:-.02em;margin-bottom:18px}
.hero h1 .accent{color:var(--accent)}
.hero .lede{color:var(--ink-2);font-size:17px;max-width:560px;margin-bottom:24px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;color:var(--gold);background:rgba(245,197,66,.08);border:1px solid rgba(245,197,66,.28);padding:5px 11px;border-radius:999px;margin-bottom:20px}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap}

.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--r);font-weight:600;font-size:14px;border:1px solid transparent;min-height:44px;cursor:pointer;text-decoration:none}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:#ff5454}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--panel)}
.btn-gold{background:var(--gold);color:#0a0c10}
.btn-gold:hover{background:#ffd95f}

/* hero countdown card */
.countdown-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;box-shadow:0 8px 24px rgba(0,0,0,.35)}
.countdown-card h4{margin-bottom:14px;font-size:11px;letter-spacing:1.4px;color:var(--ink-3);text-transform:uppercase;font-weight:600}
.countdown{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;font-family:var(--mono)}
.cd-cell{background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r);padding:12px 6px;text-align:center}
.cd-big{font-size:28px;font-weight:700;color:var(--gold);line-height:1}
.cd-lbl{font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:1.5px;margin-top:6px}
.cd-row{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:14px;border-top:1px solid var(--line-2);font-size:12px;color:var(--ink-3)}
.cd-row b{color:var(--ink);font-family:var(--mono)}
.race-status{display:inline-flex;align-items:center;gap:8px;padding:4px 11px;border-radius:999px;font-family:var(--mono);font-size:10px;letter-spacing:1px}
.race-status.countdown{background:rgba(61,220,132,.12);color:var(--green);border:1px solid rgba(61,220,132,.3)}
.race-status.live{background:rgba(255,56,56,.15);color:#ff6b6b;border:1px solid rgba(255,56,56,.4)}
.race-status.post{background:var(--panel);color:var(--ink-3);border:1px solid var(--line)}

/* generic content card */
h2.section-title{font-size:clamp(22px,3vw,30px);font-weight:600;letter-spacing:-.01em;margin-bottom:8px}
.lede{color:var(--ink-2);font-size:15px;max-width:760px}

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

.tile{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;transition:transform .15s,border-color .15s}
.tile h3{font-size:17px;margin-bottom:6px}
.tile p{color:var(--ink-2);font-size:14px;margin:0}
.tile .icon{font-size:22px;margin-bottom:8px}
a.tile{display:block;text-decoration:none;color:inherit}
a.tile:hover{transform:translateY(-2px);border-color:var(--ink-3);text-decoration:none}

/* class tile (left accent stripe) */
.cls-tile{position:relative;overflow:hidden;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;display:block;color:inherit;text-decoration:none;transition:transform .15s}
.cls-tile:hover{transform:translateY(-2px);text-decoration:none}
.cls-tile::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--cls,var(--accent))}
.cls-tile .tag{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:1px;color:var(--ink-3);background:var(--bg);padding:3px 9px;border-radius:999px;border:1px solid var(--line-2);margin-bottom:10px}
.cls-tile.featured .tag{color:var(--gold);border-color:rgba(245,197,66,.3);background:rgba(245,197,66,.08)}
.cls-tile h3{margin-bottom:4px;font-size:17px}
.cls-tile .meta{font-size:12px;color:var(--ink-3);margin-top:10px;font-family:var(--mono)}

/* stat row */
.stat-row{display:flex;gap:14px;flex-wrap:wrap}
.stat{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r);padding:13px 17px;flex:1;min-width:140px}
.stat .l{font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:1.2px}
.stat .n{font-size:22px;font-weight:700;color:var(--gold);font-family:var(--mono);margin-top:4px}

/* sched list */
.sched-list{list-style:none;padding:0;margin:0}
.sched-item{display:grid;grid-template-columns:200px 1fr auto;gap:14px;padding:13px 0;border-bottom:1px dashed var(--line-2);align-items:center}
.sched-item:last-child{border-bottom:none}
.sched-when{font-family:var(--mono);font-size:12px;color:var(--ink-3)}
.sched-what{font-weight:600}
.sched-tag{font-family:var(--mono);font-size:10px;padding:3px 8px;border-radius:999px;background:var(--panel-2);border:1px solid var(--line);color:var(--ink-3)}
.sched-tag.green{color:var(--green);border-color:rgba(61,220,132,.3);background:rgba(61,220,132,.08)}
.sched-tag.red{color:var(--accent);border-color:rgba(255,56,56,.3);background:rgba(255,56,56,.08)}
.sched-tag.gold{color:var(--gold);border-color:rgba(245,197,66,.3);background:rgba(245,197,66,.08)}
@media (max-width:640px){.sched-item{grid-template-columns:1fr;gap:4px}}

/* class hero (top of class detail pages) */
.cls-hero{padding:56px 0 36px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--cls-tint,rgba(255,56,56,.16)),transparent 80%),var(--bg)}
.cls-hero h1{font-size:clamp(28px,4vw,42px);margin-bottom:8px}
.cls-hero .summary{color:var(--ink-2);font-size:16px;max-width:720px}

/* entries list (for drivers + class pages) */
.entries{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-top:18px}
.entry-tile{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px;display:flex;flex-direction:column;gap:6px;text-decoration:none;color:inherit;transition:border-color .12s,transform .12s;text-align:left}
.entry-tile:hover{border-color:var(--ink-3);transform:translateY(-2px);text-decoration:none}
.entry-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.entry-num{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--cls,var(--ink))}
.entry-class{font-family:var(--mono);font-size:10px;color:var(--ink-3);background:var(--panel-2);border:1px solid var(--line-2);padding:2px 8px;border-radius:999px;letter-spacing:1px}
.entry-team{font-weight:600;color:var(--ink);font-size:14px;line-height:1.3}
.entry-car{color:var(--ink-2);font-size:12px;font-family:var(--mono)}
.entry-drivers{color:var(--ink-3);font-size:12px;line-height:1.45;margin-top:2px}
.entry-tile.featured{border-color:rgba(245,197,66,.5);background:linear-gradient(180deg,rgba(245,197,66,.06),var(--panel))}

/* search / filter bar */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;padding:14px 0}
.search-input{flex:1;min-width:200px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);color:var(--ink);padding:10px 14px;font:14px var(--sans)}
.search-input:focus{border-color:var(--gold);outline:none}
.filter-chips{display:flex;gap:6px;flex-wrap:wrap}
.toolbar .count{font-family:var(--mono);font-size:12px;color:var(--ink-3);margin-left:auto}

/* footer */
.site-footer{border-top:1px solid var(--line);padding:30px 0;color:var(--ink-3);font-size:13px;margin-top:60px}
.site-footer .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}
