/* CRANK RACING TEAM — Design System v2.0 (Animated)
   Tokens, components, layout primitives + animation library. */

:root{
  /* === COLORS === */
  --carbon:#0a0a0c;
  --graphite:#141418;
  --gunmetal:#1d1f24;
  --steel:#2a2d33;
  --asphalt:#3a3e45;
  --silver:#8a8f99;
  --chrome:#c8ccd2;
  --pearl:#e8eaed;
  --red:#e10600;
  --red-deep:#a00400;
  --red-glow:rgba(225,6,0,.35);

  /* === SPACING === */
  --gutter:24px;
  --section-pad:120px;
  --container:1240px;

  /* === TRANSITIONS === */
  --t-fast:.15s ease;
  --t:.2s cubic-bezier(.4,0,.2,1);
  --t-slow:.5s cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--carbon);color:var(--pearl);font-family:'Inter',sans-serif;font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:0;background:transparent;color:inherit}

/* Custom selection */
::selection{background:var(--red);color:#fff}

/* Custom scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--carbon)}
::-webkit-scrollbar-thumb{background:var(--steel);border:2px solid var(--carbon)}
::-webkit-scrollbar-thumb:hover{background:var(--red)}

/* === SCROLL PROGRESS BAR === */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0%;background:linear-gradient(90deg,var(--red),#ff3a30,var(--red));z-index:200;transition:width .1s linear;box-shadow:0 0 12px var(--red-glow)}

/* === TYPOGRAPHY === */
h1,h2,h3,h4{font-family:'Oswald',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:-.005em;line-height:1}
.mono{font-family:'JetBrains Mono',monospace}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.28em;color:var(--silver);text-transform:uppercase;display:flex;align-items:center;gap:14px}
.eyebrow::before{content:'';width:32px;height:1px;background:var(--red);animation:eyebrow-pulse 2.4s ease-in-out infinite}

/* === LAYOUT === */
.container{max-width:var(--container);margin:0 auto;padding:0 32px}
section{padding:var(--section-pad) 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px;padding-bottom:24px;border-bottom:1px solid var(--steel);gap:32px}
.section-num{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--red);letter-spacing:.3em;margin-bottom:10px}
.section-title{font-size:46px;text-transform:uppercase}
.section-kicker{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--silver);letter-spacing:.22em;text-transform:uppercase;text-align:right;max-width:280px;line-height:1.6}

/* === NAV === */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(10,10,12,.85);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--steel);height:72px;
  transition:transform .35s cubic-bezier(.4,0,.2,1), background .25s ease;
}
.nav.hidden{transform:translateY(-100%)}
.nav.scrolled{background:rgba(10,10,12,.96);border-bottom-color:var(--asphalt)}
.nav-inner{max-width:var(--container);margin:0 auto;padding:0 32px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:32px}
.nav-logo{display:flex;align-items:center;gap:12px;font-family:'Oswald',sans-serif;font-size:18px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;transition:transform .2s ease}
.nav-logo:hover{transform:translateX(2px)}
.nav-logo .mark{width:36px;height:36px;background:var(--red);clip-path:polygon(20% 0,100% 0,80% 100%,0 100%);display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;position:relative;overflow:hidden}
.nav-logo .mark::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:mark-shine 3s ease-in-out infinite}
.nav-logo .red{color:var(--red)}
.nav-menu{display:flex;gap:4px;list-style:none}
.nav-menu a{padding:10px 16px;font-family:'Oswald',sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--chrome);transition:color var(--t-fast);position:relative}
.nav-menu a::before{content:'';position:absolute;left:16px;right:16px;bottom:6px;height:1px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s cubic-bezier(.4,0,.2,1)}
.nav-menu a:hover{color:var(--pearl)}
.nav-menu a:hover::before{transform:scaleX(1)}
.nav-menu a.active{color:var(--pearl)}
.nav-menu a.active::after{content:'';position:absolute;bottom:-26px;left:16px;right:16px;height:2px;background:var(--red)}
.nav-cta{display:flex;align-items:center;gap:14px}

/* === BUTTONS === */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--red);color:#fff;
  padding:14px 26px;font-family:'Oswald',sans-serif;font-size:13px;
  text-transform:uppercase;letter-spacing:.12em;font-weight:600;
  clip-path:polygon(0 0, 100% 0, 96% 100%, 4% 100%);
  transition:transform var(--t),background var(--t),box-shadow var(--t);
  position:relative;overflow:hidden;
}
.btn::after{content:'';position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transform:skewX(-20deg);transition:left .55s cubic-bezier(.4,0,.2,1)}
.btn:hover{background:var(--red-deep);transform:translateX(2px);box-shadow:0 8px 24px var(--red-glow)}
.btn:hover::after{left:140%}
.btn:active{transform:translateX(2px) scale(.98)}
.btn .arrow{font-family:'JetBrains Mono',monospace;font-size:12px;display:inline-block;transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(4px)}
.btn.ghost{background:transparent;border:1px solid var(--asphalt);color:var(--pearl);clip-path:none;padding:13px 25px}
.btn.ghost:hover{border-color:var(--red);color:var(--pearl);box-shadow:0 0 0 1px var(--red), 0 8px 24px var(--red-glow)}
.btn.sm{padding:10px 20px;font-size:11px}

/* === CARDS === */
.card{background:linear-gradient(160deg,var(--gunmetal),var(--graphite));border:1px solid var(--steel);padding:28px;position:relative;overflow:hidden;transition:transform var(--t),border-color var(--t),box-shadow var(--t)}
.card::before{content:'';position:absolute;top:0;left:0;width:0;height:2px;background:var(--red);transition:width .4s cubic-bezier(.4,0,.2,1)}
.card:hover{transform:translateY(-4px);border-color:var(--asphalt);box-shadow:0 16px 40px rgba(0,0,0,.5)}
.card:hover::before{width:100%}
.card.angled{clip-path:polygon(0 0, 100% 0, 100% 92%, 96% 100%, 0 100%)}
.corner-tag{position:absolute;top:0;right:0;background:var(--red);color:#fff;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;padding:6px 12px;text-transform:uppercase;z-index:2}

/* === PLACEHOLDER IMAGES === */
.placeholder{
  background:
    repeating-linear-gradient(115deg,var(--gunmetal) 0 14px,var(--graphite) 14px 28px);
  display:flex;align-items:center;justify-content:center;
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--silver);
  letter-spacing:.18em;text-transform:uppercase;text-align:center;padding:16px;
  position:relative;overflow:hidden;
}
.placeholder::before{
  content:attr(data-label);
  background:rgba(10,10,12,.7);padding:8px 14px;border:1px solid var(--steel);
  position:relative;z-index:2;
}
/* shimmer sweep on placeholders */
.placeholder::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 30%,rgba(225,6,0,.08) 50%,transparent 70%);
  transform:translateX(-100%);
  animation:placeholder-shimmer 4s ease-in-out infinite;
  pointer-events:none;
}
.placeholder.red-line{border-bottom:2px solid var(--red)}

/* === FOOTER === */
.footer{background:var(--graphite);border-top:2px solid var(--red);padding:80px 0 32px;margin-top:120px;position:relative;overflow:hidden}
.footer::before{content:'';position:absolute;top:-2px;left:-100%;width:30%;height:2px;background:linear-gradient(90deg,transparent,#fff,transparent);animation:footer-blip 6s linear infinite}
.footer-grid{max-width:var(--container);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:48px;position:relative}
.footer-col h5{font-family:'Oswald',sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:.18em;margin-bottom:20px;color:var(--pearl)}
.footer-col ul{list-style:none}
.footer-col li{padding:6px 0}
.footer-col a{color:var(--silver);font-size:13px;transition:color var(--t-fast),padding-left .2s ease;position:relative;display:inline-block}
.footer-col a:hover{color:var(--pearl);padding-left:8px}
.footer-col a:hover::before{opacity:1;transform:translateX(0)}
.footer-col a::before{content:'›';position:absolute;left:-2px;color:var(--red);opacity:0;transform:translateX(-6px);transition:all .2s ease}
.footer-tag{font-size:13px;color:var(--silver);max-width:280px;margin-top:12px;line-height:1.6}
.footer-bottom{max-width:var(--container);margin:48px auto 0;padding:24px 32px 0;border-top:1px solid var(--steel);display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--silver);letter-spacing:.2em;text-transform:uppercase}

/* === FORM === */
.form-row{margin-bottom:24px;position:relative}
.form-row label{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--silver);margin-bottom:8px;transition:color var(--t)}
.form-row input,.form-row textarea,.form-row select{
  width:100%;background:transparent;border:0;border-bottom:1px solid var(--asphalt);
  padding:10px 0;color:var(--pearl);font-family:inherit;font-size:15px;
  transition:border-color var(--t);outline:none;
}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{border-color:var(--red)}
.form-row input:focus + label, .form-row:focus-within label{color:var(--red)}
.form-row textarea{resize:vertical;min-height:120px}

/* === BREADCRUMB === */
.breadcrumb{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;color:var(--silver);text-transform:uppercase;padding:24px 0;display:flex;gap:10px}
.breadcrumb a{transition:color var(--t-fast)}
.breadcrumb a:hover{color:var(--red)}
.breadcrumb .sep{color:var(--asphalt)}

/* === GRID === */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* ========================================================
   ANIMATION LIBRARY
   ========================================================*/

/* === KEYFRAMES === */
@keyframes eyebrow-pulse{
  0%,100%{opacity:.6;width:32px}
  50%{opacity:1;width:48px}
}
@keyframes mark-shine{
  0%,100%{left:-100%}
  60%,100%{left:100%}
}
@keyframes placeholder-shimmer{
  0%{transform:translateX(-100%)}
  60%,100%{transform:translateX(100%)}
}
@keyframes footer-blip{
  0%{left:-30%}
  100%{left:130%}
}
@keyframes float-up{
  from{opacity:0;transform:translateY(40px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes float-left{
  from{opacity:0;transform:translateX(-40px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes float-right{
  from{opacity:0;transform:translateX(40px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes float-scale{
  from{opacity:0;transform:scale(.92)}
  to{opacity:1;transform:scale(1)}
}
@keyframes glitch-1{
  0%,100%{transform:translate(0)}
  20%{transform:translate(-2px,1px)}
  40%{transform:translate(2px,-1px)}
  60%{transform:translate(-1px,2px)}
  80%{transform:translate(1px,-2px)}
}
@keyframes glitch-2{
  0%,100%{transform:translate(0);opacity:.7}
  20%{transform:translate(2px,-1px);opacity:.9}
  40%{transform:translate(-2px,1px);opacity:.6}
  60%{transform:translate(1px,-2px);opacity:.8}
  80%{transform:translate(-1px,2px);opacity:.7}
}
@keyframes blink{
  0%,49%,100%{opacity:1}
  50%,99%{opacity:.2}
}
@keyframes pulse-red{
  0%,100%{box-shadow:0 0 0 0 var(--red-glow)}
  50%{box-shadow:0 0 0 12px transparent}
}
@keyframes spin-slow{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
@keyframes rev-counter{
  0%,100%{transform:rotate(-30deg)}
  50%{transform:rotate(150deg)}
}
@keyframes speed-line{
  0%{transform:translateX(-100vw) skewX(-20deg)}
  100%{transform:translateX(100vw) skewX(-20deg)}
}
@keyframes scan{
  0%{transform:translateY(-100%)}
  100%{transform:translateY(100vh)}
}
@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@keyframes ticker-flash{
  0%,100%{color:var(--red)}
  50%{color:#ff5a52}
}
@keyframes count-glow{
  0%,100%{text-shadow:0 0 0 transparent}
  50%{text-shadow:0 0 24px var(--red-glow)}
}
@keyframes hero-fade-in{
  from{opacity:0;filter:blur(10px);transform:translateY(20px)}
  to{opacity:1;filter:blur(0);transform:translateY(0)}
}
@keyframes nav-drop{
  from{opacity:0;transform:translateY(-100%)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes typing-bar{
  0%,100%{transform:scaleX(0)}
  50%{transform:scaleX(1)}
}

/* === SCROLL REVEAL === */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.left{transform:translateX(-30px)}
.reveal.left.in{transform:translateX(0)}
.reveal.right{transform:translateX(30px)}
.reveal.right.in{transform:translateX(0)}
.reveal.scale{transform:scale(.94)}
.reveal.scale.in{transform:scale(1)}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}
.reveal.delay-4{transition-delay:.32s}
.reveal.delay-5{transition-delay:.4s}
.reveal.delay-6{transition-delay:.48s}

/* Stagger children */
.stagger > *{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1)}
.stagger.in > *{opacity:1;transform:translateY(0)}
.stagger.in > *:nth-child(1){transition-delay:.04s}
.stagger.in > *:nth-child(2){transition-delay:.12s}
.stagger.in > *:nth-child(3){transition-delay:.20s}
.stagger.in > *:nth-child(4){transition-delay:.28s}
.stagger.in > *:nth-child(5){transition-delay:.36s}
.stagger.in > *:nth-child(6){transition-delay:.44s}
.stagger.in > *:nth-child(7){transition-delay:.52s}
.stagger.in > *:nth-child(8){transition-delay:.60s}

/* === VIDEO BACKGROUND === */
.video-bg{position:absolute;inset:0;width:100%;height:100%;overflow:hidden;z-index:0}
.video-bg video{position:absolute;top:50%;left:50%;width:100%;height:100%;min-width:100%;min-height:100%;object-fit:cover;transform:translate(-50%,-50%);filter:saturate(.85) contrast(1.05) brightness(.55)}
.video-bg::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,10,12,.75) 0%,rgba(20,20,24,.6) 50%,rgba(10,10,12,.85) 100%);z-index:1;pointer-events:none}
.video-bg::after{
  content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.012) 0px,rgba(255,255,255,.012) 1px,transparent 1px,transparent 3px);
  mix-blend-mode:overlay;
}
.video-bg.dim::before{background:linear-gradient(180deg,rgba(10,10,12,.55) 0%,rgba(10,10,12,.85) 100%)}
.video-bg-fallback{position:absolute;inset:0;background:linear-gradient(135deg,var(--graphite),var(--gunmetal) 50%,var(--carbon))}
.video-bg-fallback::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(115deg,transparent 0 60px,rgba(225,6,0,.05) 60px 62px),repeating-linear-gradient(115deg,transparent 0 140px,rgba(200,204,210,.03) 140px 142px)}

/* Speed lines overlay (decorative) */
.speed-lines{position:absolute;inset:0;pointer-events:none;z-index:2;overflow:hidden}
.speed-lines span{position:absolute;height:1px;background:linear-gradient(90deg,transparent,var(--red),transparent);opacity:.6}
.speed-lines span:nth-child(1){top:18%;left:0;width:120%;animation:speed-line 4.5s linear infinite;animation-delay:0s}
.speed-lines span:nth-child(2){top:34%;left:0;width:140%;height:2px;animation:speed-line 5.5s linear infinite;animation-delay:1.2s;opacity:.4}
.speed-lines span:nth-child(3){top:48%;left:0;width:100%;animation:speed-line 3.8s linear infinite;animation-delay:.4s}
.speed-lines span:nth-child(4){top:62%;left:0;width:130%;animation:speed-line 6s linear infinite;animation-delay:2.1s;opacity:.35}
.speed-lines span:nth-child(5){top:78%;left:0;width:110%;height:2px;animation:speed-line 5s linear infinite;animation-delay:.7s}
.speed-lines span:nth-child(6){top:88%;left:0;width:90%;animation:speed-line 4s linear infinite;animation-delay:1.8s;opacity:.5}

/* Scan line (CRT effect) */
.scan-line{position:absolute;inset:0;pointer-events:none;z-index:3;overflow:hidden}
.scan-line::before{content:'';position:absolute;left:0;right:0;height:200px;background:linear-gradient(180deg,transparent 0%,rgba(225,6,0,.04) 30%,rgba(225,6,0,.08) 50%,rgba(225,6,0,.04) 70%,transparent 100%);animation:scan 7s linear infinite}

/* Glitch heading */
.glitch{position:relative;display:inline-block}
.glitch::before,.glitch::after{
  content:attr(data-text);position:absolute;top:0;left:0;width:100%;height:100%;
  pointer-events:none;
}
.glitch::before{color:#1ad6ff;animation:glitch-1 4s infinite;mix-blend-mode:screen;clip-path:polygon(0 0,100% 0,100% 30%,0 30%)}
.glitch::after{color:var(--red);animation:glitch-2 3.2s infinite reverse;mix-blend-mode:screen;clip-path:polygon(0 70%,100% 70%,100% 100%,0 100%)}

/* ========================================================
   SCROLL-DRIVEN SCENES (home page)
   ========================================================*/

/* Scene container — full-viewport page-by-page */
[data-scene]{position:relative;height:100vh;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}

/* Scroll-snap: enabled only on home page via .home-snap on <html> */
html.home-snap{scroll-snap-type:y mandatory;scroll-behavior:smooth}
html.home-snap [data-scene]{scroll-snap-align:start;scroll-snap-stop:always}

/* Hero scene */
.scene-hero{background:var(--carbon)}
.scene-hero-inner{position:relative;z-index:5;max-width:var(--container);width:100%;padding:60px 32px;display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center}
.scene-hero-eyebrow{display:flex;align-items:center;gap:14px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.28em;color:var(--chrome);text-transform:uppercase;margin-bottom:16px}
.scene-hero-eyebrow::before{content:'';width:32px;height:1px;background:var(--red)}
.scene-hero h1{font-family:'Oswald',sans-serif;font-size:clamp(48px,7vw,96px);font-weight:700;line-height:.92;text-transform:uppercase;margin-bottom:24px}
.scene-hero h1 .h-line{display:block;overflow:hidden;line-height:.92}
.scene-hero h1 .h-word{display:inline-block;will-change:transform}
.scene-hero h1 .red{color:var(--red);font-style:italic}
.scene-hero-lede{font-size:18px;color:var(--chrome);max-width:520px;margin-bottom:28px;will-change:transform,opacity}
.scene-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.scene-hero-cta .btn{will-change:transform,opacity}
.scene-hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;padding-top:28px;border-top:1px solid var(--steel)}
.scene-hero-stat{will-change:transform,opacity}
.scene-hero-stat .num{font-family:'Oswald',sans-serif;font-size:clamp(32px,4vw,52px);font-weight:700;color:var(--pearl);line-height:1}
.scene-hero-stat .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;color:var(--silver);text-transform:uppercase;margin-top:8px}

.scene-hero-visual{position:relative;will-change:transform,opacity}
.scene-hero-logo{position:relative;aspect-ratio:1;background:radial-gradient(circle at 50%,#f4f4f4,#a8acb2);clip-path:polygon(0 8%,92% 0,100% 88%,8% 100%);padding:40px;display:flex;align-items:center;justify-content:center;box-shadow:0 30px 80px rgba(0,0,0,.5);will-change:transform,opacity,filter;transform-origin:center center}
.scene-hero-logo img{width:100%;height:100%;object-fit:contain}
.scene-hero-logo .tag{position:absolute;bottom:-14px;left:24px;background:var(--red);color:#fff;padding:8px 16px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;clip-path:polygon(0 0,100% 0,96% 100%,4% 100%);z-index:3}

/* Scene progress dots (right side) */
.scene-dots{position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:80;display:flex;flex-direction:column;gap:14px}
.scene-dots a{width:10px;height:10px;border:1px solid var(--silver);border-radius:50%;display:block;transition:all var(--t);cursor:pointer;position:relative}
.scene-dots a::after{content:attr(data-label);position:absolute;right:22px;top:50%;transform:translateY(-50%);font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;color:var(--silver);text-transform:uppercase;white-space:nowrap;opacity:0;transition:opacity var(--t)}
.scene-dots a:hover{border-color:var(--red);background:var(--red)}
.scene-dots a:hover::after{opacity:1;color:var(--pearl)}
.scene-dots a.active{background:var(--red);border-color:var(--red);transform:scale(1.4)}
@media(max-width:900px){.scene-dots{display:none}}

/* Stats scene */
.scene-stats{background:linear-gradient(180deg,var(--carbon),var(--graphite))}
.scene-stats-inner{max-width:var(--container);width:100%;padding:60px 32px;text-align:center;position:relative;z-index:5}
.scene-stats-bg{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-around;pointer-events:none;z-index:1}
.scene-stats-bg-line{height:1px;background:linear-gradient(90deg,transparent,var(--steel) 30%,var(--steel) 70%,transparent);transform-origin:left center}
.scene-stats-title{font-family:'Oswald',sans-serif;font-size:clamp(36px,6vw,72px);text-transform:uppercase;line-height:.95;margin-bottom:60px;will-change:transform,opacity}
.scene-stats-title .red{color:var(--red);font-style:italic}
.scene-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;max-width:1100px;margin:0 auto}
.scene-stat{padding:32px 20px;border:1px solid var(--steel);background:rgba(20,20,24,.6);will-change:transform,opacity}
.scene-stat .num{font-family:'Oswald',sans-serif;font-size:clamp(48px,7vw,96px);font-weight:700;color:var(--red);line-height:1}
.scene-stat .num small{font-size:.45em;color:var(--pearl);font-weight:400}
.scene-stat .lbl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:var(--silver);text-transform:uppercase;margin-top:14px}
.scene-stat .ev{font-size:13px;color:var(--chrome);margin-top:10px;line-height:1.4}

/* Calendar scene */
.scene-cal{background:var(--graphite);border-top:1px solid var(--steel);border-bottom:1px solid var(--steel)}
.scene-cal-inner{max-width:var(--container);width:100%;padding:60px 32px}
.scene-cal-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;border-bottom:1px solid var(--steel);padding-bottom:20px}
.scene-cal-title{font-family:'Oswald',sans-serif;font-size:clamp(36px,5vw,56px);text-transform:uppercase;will-change:transform,opacity}
.scene-cal-title .num{color:var(--red);font-family:'JetBrains Mono',monospace;font-size:.4em;letter-spacing:.3em;display:block;margin-bottom:6px}
.scene-cal-kicker{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--silver);letter-spacing:.22em;text-transform:uppercase;will-change:transform,opacity;text-align:right}
.scene-cal .calendar-list{border:1px solid var(--steel)}
.scene-cal .cal-row{display:grid;grid-template-columns:140px 100px 1fr 140px 120px;gap:24px;align-items:center;padding:18px 24px;border-bottom:1px solid var(--steel);will-change:transform,opacity;background:var(--carbon)}
.scene-cal .cal-row:last-child{border-bottom:0}
.scene-cal .cal-row.next{background:linear-gradient(90deg,rgba(225,6,0,.12),transparent 60%);border-left:3px solid var(--red);padding-left:21px}

/* Riders scene — 2 cards, equal height regardless of bio length */
.scene-riders{background:var(--carbon)}
.scene-riders-inner{max-width:1100px;width:100%;padding:60px 32px;text-align:center;position:relative}
.scene-riders-title{font-family:'Oswald',sans-serif;font-size:clamp(36px,6vw,72px);text-transform:uppercase;line-height:.95;margin-bottom:48px;will-change:transform,opacity}
.scene-riders-title .red{color:var(--red);font-style:italic}
.scene-riders-grid{display:grid;grid-template-columns:repeat(2,minmax(0,360px));justify-content:center;align-items:stretch;gap:32px}
.scene-rider{display:flex;flex-direction:column;background:var(--graphite);border:1px solid var(--steel);clip-path:polygon(0 0,100% 0,100% 92%,96% 100%,0 100%);will-change:transform,opacity;text-align:left;text-decoration:none;color:inherit;transition:transform var(--t),border-color var(--t),box-shadow var(--t)}
.scene-rider:hover{transform:translateY(-6px);border-color:var(--red);box-shadow:0 16px 40px rgba(0,0,0,.5)}
.scene-rider .photo{aspect-ratio:3/4;position:relative;overflow:hidden;background:repeating-linear-gradient(115deg,var(--gunmetal) 0 14px,var(--graphite) 14px 28px);flex-shrink:0}
.scene-rider .photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(10,10,12,.95) 100%)}
.scene-rider-number{position:absolute;top:20px;right:24px;font-family:'Oswald',sans-serif;font-size:140px;line-height:.8;font-weight:700;color:var(--red);opacity:.18;z-index:2;will-change:transform,opacity}
.scene-rider .body{padding:24px;position:relative;z-index:3;flex:1;display:flex;flex-direction:column;gap:8px;min-height:140px}
.scene-rider .role{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--red);letter-spacing:.22em;font-weight:700;margin:0}
.scene-rider h3{font-family:'Oswald',sans-serif;font-size:24px;text-transform:uppercase;line-height:1;margin:0}
.scene-rider .bio{font-size:13px;color:var(--silver);line-height:1.5;margin:0}
@media(max-width:900px){
  .scene-riders-grid{grid-template-columns:1fr;gap:16px;max-width:340px;margin:0 auto}
}

/* CTA scene */
.scene-cta{background:linear-gradient(135deg,var(--gunmetal),var(--graphite));position:relative;--cta-sweep:0%}
.scene-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(115deg,transparent 30%,rgba(225,6,0,.18) 50%,transparent 70%);transform:skewX(-20deg) translateX(calc(var(--cta-sweep) - 50%))}
.scene-cta-inner{position:relative;z-index:5;max-width:900px;padding:60px 32px;text-align:center}
.scene-cta-eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.28em;color:var(--silver);text-transform:uppercase;margin-bottom:24px;will-change:transform,opacity}
.scene-cta h2{font-family:'Oswald',sans-serif;font-size:clamp(48px,7vw,88px);font-weight:700;line-height:.95;margin-bottom:24px;text-transform:uppercase}
.scene-cta h2 .red{color:var(--red);font-style:italic}
.scene-cta h2 .cta-line{display:block;overflow:hidden;line-height:.95}
.scene-cta h2 .cta-word{display:inline-block;will-change:transform,opacity}
.scene-cta-lede{font-size:18px;color:var(--chrome);max-width:560px;margin:0 auto 36px;will-change:transform,opacity}
.scene-cta-btn{will-change:transform,opacity}

.scene-static{min-height:auto !important}
.scene-static *{transform:none !important;opacity:1 !important;animation:none !important}

.scene-news, .scene-gal{padding:120px 0}
.scene-news .news-card, .scene-gal .placeholder{will-change:transform,opacity}

@media(max-width:900px){
  .scene-hero-inner{grid-template-columns:1fr;text-align:center}
  .scene-hero-stats{grid-template-columns:repeat(2,1fr);gap:16px}
  .scene-stats-grid{grid-template-columns:repeat(2,1fr)}
  .scene-cal-head{flex-direction:column;align-items:flex-start;gap:12px}
  .scene-cal-kicker{text-align:left}
  .scene-cal .cal-row{grid-template-columns:1fr 1fr;gap:8px;font-size:12px}
}

/* Calendar series tags — SM (red) vs WMPP (chrome) */
.cal-round.sm{color:var(--red)}
.cal-round.wmpp{color:var(--chrome)}
.cal-round.sm::before, .cal-round.wmpp::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:8px;vertical-align:middle;transform:translateY(-2px)}
.cal-round.sm::before{background:var(--red)}
.cal-round.wmpp::before{background:var(--chrome)}

/* "TBA" placeholder for unassigned rider numbers — smaller than full-size number */
.scene-rider-number.tba, .number.tba{font-size:38px;letter-spacing:.18em;opacity:.32;color:var(--silver);font-weight:600;line-height:1}
