/* ============================================================
   D1NZ — National Drifting Championship · 3D scroll cinematic
   AUSX-style look: heavy condensed Anton headlines + Permanent
   Marker brush accents + Inter body, on ink black with red/ember.
   ============================================================ */
:root{
  --ink:#07060a;
  --ink-2:#0e0a0d;
  --panel:#150c11;
  --panel-2:#1c0e14;
  --line:rgba(255,255,255,.10);
  --red:#ff2a30;
  --red-bright:#ff4d4d;
  --crimson:#e00024;
  --ember:#ff6a1a;
  --text:#f5eef0;
  --dim:#9b8a8e;
  --grad:linear-gradient(100deg,var(--ember),var(--red) 50%,var(--crimson));
  --maxw:1200px;
  --ff-head:'Anton',Impact,sans-serif;
  --ff-alt:'Archivo','Arial Narrow',sans-serif;
  --ff-brush:'Permanent Marker',cursive;
  --ff-body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
body{
  background:var(--ink);color:var(--text);
  font-family:var(--ff-body);font-size:17px;line-height:1.62;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- Fixed HUD ---------- */
.hud{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:18px;padding:14px clamp(16px,4vw,40px);
  background:linear-gradient(to bottom,rgba(7,6,10,.9),rgba(7,6,10,0));
  backdrop-filter:blur(6px);
}
.hud-brand{display:flex;align-items:center}
.brand-logo{height:44px;width:auto;display:block;filter:drop-shadow(0 2px 10px rgba(0,0,0,.5))}
.hud-nav{display:flex;gap:26px}
.hud-nav a{font-family:var(--ff-alt);font-weight:700;font-size:13px;letter-spacing:.14em;
  text-transform:uppercase;color:#cdbfc4;transition:.25s}
.hud-nav a:hover{color:#fff}
.hud-cta{
  font-family:var(--ff-alt);font-size:13px;letter-spacing:.1em;font-weight:800;text-transform:uppercase;
  padding:11px 20px;border-radius:4px;color:#13060a;background:var(--grad);
  transition:.25s;white-space:nowrap;box-shadow:0 8px 30px -10px var(--red);
}
.hud-cta:hover{transform:translateY(-1px);filter:brightness(1.08);box-shadow:0 12px 36px -10px var(--red)}
.hud-nav a.active{color:#fff}
.hud-nav a.active::after,.hud-menu a.active{color:#fff}
.hud-cta-inline{display:none}
/* hamburger */
.hud-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:60}
.hud-burger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.25s}
.hud.open .hud-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hud.open .hud-burger span:nth-child(2){opacity:0}
.hud.open .hud-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* dropdown */
.hud-drop{position:relative}
.hud-drop-btn{font-family:var(--ff-alt);font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  color:#cdbfc4;background:none;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:.25s}
.hud-drop:hover .hud-drop-btn,.hud-drop-btn:hover{color:#fff}
.hud-drop .caret{font-size:9px;transition:transform .25s}
.hud-drop:hover .caret{transform:rotate(180deg)}
.hud-drop::after{content:"";position:absolute;top:100%;left:0;right:0;height:18px}
.hud-menu{position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%) translateY(8px);min-width:240px;
  background:rgba(12,8,11,.98);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:12px;padding:8px;
  display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transition:.22s;box-shadow:0 30px 70px -28px #000}
.hud-drop:hover .hud-menu,.hud-drop.open .hud-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.hud-menu a{font-family:var(--ff-alt);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:#cdbfc4;padding:12px 14px;border-radius:8px;transition:.18s;white-space:nowrap}
.hud-menu a:hover{color:#fff;background:rgba(255,42,48,.16)}
@media(max-width:900px){
  .brand-logo{height:36px}
  .hud-burger{display:flex}
  .hud-cta-top{display:none}
  .hud-nav{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:min(84vw,340px);transform:translateX(100%);
    flex-direction:column;align-items:stretch;gap:0;padding:80px 26px 28px;
    background:rgba(9,7,10,.99);backdrop-filter:blur(16px);border-left:1px solid var(--line);
    box-shadow:-30px 0 80px -30px #000;transition:transform .32s cubic-bezier(.4,0,.2,1);overflow-y:auto}
  .hud.open .hud-nav{transform:translateX(0)}
  .hud-nav>a{padding:15px 2px;border-bottom:1px solid rgba(255,255,255,.08);font-size:15px}
  .hud-drop{width:100%}
  .hud-drop-btn{width:100%;justify-content:space-between;padding:15px 2px;font-size:11px;color:#7d7480;border-bottom:1px solid rgba(255,255,255,.08);pointer-events:none}
  .hud-drop .caret{display:none}
  .hud-menu{position:static;transform:none;opacity:1;visibility:visible;background:none;border:0;padding:0;box-shadow:none;backdrop-filter:none;min-width:0}
  .hud-menu a{padding:15px 2px 15px 16px;font-size:14px;border-bottom:1px solid rgba(255,255,255,.08)}
  .hud-cta-inline{display:block;margin-top:20px;text-align:center}
}

/* ---------- Cinematic scrub stage ---------- */
.cinematic{position:relative;height:520vh;background:var(--ink)}
.cinematic .sticky{position:sticky;top:0;height:100vh;overflow:hidden}
.cinematic canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.grade{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(7,6,10,.45),rgba(7,6,10,0) 26%,rgba(7,6,10,0) 56%,rgba(7,6,10,.78))}
.tint{position:absolute;inset:0;pointer-events:none;mix-blend-mode:soft-light;
  background:radial-gradient(80% 70% at 70% 40%,rgba(255,42,48,.3),transparent 70%)}
.vignette{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 45%,rgba(0,0,0,0) 42%,rgba(0,0,0,.68) 100%)}

/* ---------- Overlay copy ---------- */
.overlay{position:absolute;inset:0;z-index:5;pointer-events:none;
  display:flex;flex-direction:column;justify-content:center;
  padding:0 clamp(20px,7vw,96px)}
.overlay-center{align-items:center;text-align:center}
.overlay-left{align-items:flex-start;text-align:left}
.overlay-hero{align-items:flex-start;text-align:left}
.reveal-line{opacity:0;will-change:opacity,transform}

.kicker{font-family:var(--ff-brush);font-size:clamp(15px,2vw,24px);
  letter-spacing:.01em;color:var(--red-bright);margin-bottom:.5rem;
  text-shadow:0 2px 18px rgba(255,42,48,.45)}
.mega{font-family:var(--ff-head);font-weight:400;line-height:.86;
  font-size:clamp(64px,15vw,210px);letter-spacing:.005em;text-transform:uppercase;
  text-shadow:0 6px 50px rgba(0,0,0,.6)}
.mega.accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 34px rgba(255,42,48,.5))}
.big{font-family:var(--ff-head);font-weight:400;line-height:.92;text-transform:uppercase;
  font-size:clamp(40px,8vw,108px);text-shadow:0 6px 40px rgba(0,0,0,.6)}
.big.accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.lede{font-size:clamp(16px,2vw,22px);color:#f0e3e6;max-width:34ch;margin-top:1.2rem;font-weight:500;
  text-shadow:0 2px 14px rgba(0,0,0,.8)}
.overlay-center .lede{margin-left:auto;margin-right:auto}

/* ---------- Telemetry ---------- */
.telemetry{position:absolute;z-index:6;font-family:var(--ff-alt);font-weight:700;
  font-size:10.5px;letter-spacing:.22em;color:var(--dim);padding:14px 18px;text-transform:uppercase}
.telemetry.tl{top:62px;left:0}.telemetry.tr{top:62px;right:0}
.telemetry.bl{bottom:14px;left:0}.telemetry.br{bottom:14px;right:0}
.telemetry b{color:var(--red-bright)}

/* ---------- Progress + hint ---------- */
.progress{position:absolute;left:0;right:0;bottom:0;height:3px;z-index:6;background:rgba(255,255,255,.07)}
.progress-fill{height:100%;width:0;background:var(--grad);box-shadow:0 0 16px var(--red)}
.scroll-hint{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:6;
  font-family:var(--ff-alt);font-weight:700;font-size:11px;letter-spacing:.35em;color:var(--dim);
  transition:opacity .4s;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,7px)}}

/* ---------- Generic content ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}
section.manifesto,section.calendar,section.feature-sec,section.experience,section.news,section.partners,section.signup{
  position:relative;padding:clamp(80px,12vh,150px) 0}
.manifesto{background:
  radial-gradient(80% 60% at 80% 0%,rgba(255,42,48,.12),transparent 60%),
  radial-gradient(70% 60% at 0% 100%,rgba(255,106,26,.08),transparent 60%),var(--ink)}
.eyebrow{font-family:var(--ff-brush);font-size:clamp(16px,2.2vw,24px);letter-spacing:.01em;
  color:var(--red-bright);margin-bottom:.8rem;text-shadow:0 2px 16px rgba(255,42,48,.35)}
.section-title,.manifesto h2,.calendar h2,.feature-sec h2,.experience h2,.news h2,.partners h2,.signup h2{
  font-family:var(--ff-head);font-weight:400;line-height:.92;text-transform:uppercase;
  font-size:clamp(40px,8vw,104px);letter-spacing:.005em}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.body{margin-top:1.4rem;max-width:60ch;font-size:clamp(16px,1.6vw,20px);color:#ddc9ce}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{background:var(--ink-2);padding:clamp(34px,6vw,64px) 22px;text-align:center}
.stat-num{font-family:var(--ff-head);font-weight:400;font-size:clamp(48px,8vw,96px);
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat-label{margin-top:.5rem;font-family:var(--ff-alt);font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
@media(max-width:720px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ---------- Calendar (AUSX-style big event blocks) ---------- */
.calendar{background:
  radial-gradient(70% 60% at 90% 10%,rgba(255,42,48,.08),transparent 60%),var(--ink)}
.cal-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:2.4rem}
.rounds{display:flex;flex-direction:column;gap:14px}
.round{position:relative;overflow:hidden;display:grid;
  grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(18px,3vw,46px);
  background:linear-gradient(110deg,var(--panel-2),var(--ink-2) 70%);
  border:1px solid var(--line);border-radius:16px;padding:clamp(22px,3vw,40px) clamp(24px,4vw,48px);
  transition:.35s}
.round::after{content:"";position:absolute;right:-40px;top:50%;transform:translateY(-50%);
  font:inherit;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,42,48,.18),transparent 70%);opacity:0;transition:.4s}
.round:hover{border-color:rgba(255,42,48,.6);transform:translateY(-3px);box-shadow:0 30px 70px -40px var(--red)}
.round:hover::after{opacity:1}
.round-no{font-family:var(--ff-brush);font-size:clamp(18px,2.4vw,28px);color:var(--red-bright);
  white-space:nowrap;text-shadow:0 2px 14px rgba(255,42,48,.4)}
.round-venue{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;
  font-size:clamp(28px,5vw,58px);line-height:.9;letter-spacing:.01em}
.round-loc{font-family:var(--ff-alt);font-weight:600;color:var(--dim);font-size:13px;
  letter-spacing:.16em;text-transform:uppercase;margin-top:8px}
.round-date{text-align:right;white-space:nowrap}
.rd-day{display:block;font-family:var(--ff-head);font-weight:400;font-size:clamp(22px,3vw,34px);line-height:1}
.rd-mon{display:block;font-family:var(--ff-alt);font-weight:700;font-size:12px;letter-spacing:.16em;color:var(--dim);margin-top:3px;text-transform:uppercase}
.round-cta{font-family:var(--ff-alt);font-weight:800;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:#13060a;background:var(--grad);padding:13px 22px;border-radius:4px;white-space:nowrap;transition:.25s;position:relative;z-index:2}
.round-cta:hover{transform:translateY(-1px);filter:brightness(1.08)}
.round.final{background:linear-gradient(110deg,rgba(255,42,48,.2),var(--panel-2) 65%);border-color:rgba(255,42,48,.45)}
@media(max-width:820px){
  .round{grid-template-columns:1fr;grid-template-areas:"no" "venue" "date";row-gap:10px;text-align:left}
  .round-no{grid-area:no}.round-body{grid-area:venue}
  .round-date{grid-area:date;text-align:left}
}

/* ---------- Nationwide NZ map ---------- */
.nationwide{display:grid;grid-template-columns:.82fr 1fr;gap:clamp(28px,5vw,68px);align-items:center;
  margin-top:clamp(44px,6vw,80px)}
.nz-map{position:relative;aspect-ratio:3/4;border-radius:20px;background-size:cover;background-position:center;
  border:1px solid rgba(255,42,48,.3);box-shadow:0 40px 100px -50px var(--red),inset 0 0 60px rgba(0,0,0,.5)}
.nz-tag{position:absolute;left:16px;bottom:16px;font-family:var(--ff-alt);font-weight:800;text-transform:uppercase;
  letter-spacing:.1em;font-size:12px;color:#fff;background:rgba(7,6,10,.6);border:1px solid rgba(255,42,48,.4);
  padding:8px 14px;border-radius:999px;backdrop-filter:blur(4px)}
.nationwide-copy h3{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;line-height:.92;
  font-size:clamp(34px,5vw,68px);margin-bottom:1rem}
.nationwide-copy p{color:#ddc9ce;font-size:clamp(16px,1.6vw,19px);max-width:46ch}
.nw-regions{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.6rem}
.nw-regions span{font-family:var(--ff-alt);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:12.5px;
  color:#e7dadd;border:1px solid var(--line);background:rgba(255,255,255,.03);padding:9px 15px;border-radius:999px}
@media(max-width:820px){.nationwide{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}}

/* ---------- Classes (two big cards) ---------- */
.feature-sec{background:var(--ink-2)}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:2.6rem}
.card{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--panel),var(--ink-2));
  border:1px solid var(--line);border-radius:18px;padding:38px 34px;transition:.3s}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--grad);transform:scaleY(0);transform-origin:top;transition:.35s}
.card:hover{border-color:rgba(255,42,48,.5);transform:translateY(-5px);box-shadow:0 28px 70px -38px var(--red)}
.card:hover::before{transform:scaleY(1)}
.card-num{font-family:var(--ff-brush);font-size:30px;color:var(--red-bright)}
.card h3{font-family:var(--ff-head);font-weight:400;font-size:clamp(26px,3vw,40px);margin:.4rem 0 .7rem;text-transform:uppercase;line-height:.95}
.card p{color:#cdbfc4;font-size:16px}
@media(max-width:820px){.cards{grid-template-columns:1fr}}

/* ---------- Experience (AUSX alternating image + text rows) ---------- */
.experience{background:var(--ink)}
.feature-rows{display:flex;flex-direction:column;gap:clamp(34px,6vw,84px);margin-top:3rem}
.feature-row{display:grid;grid-template-columns:1.05fr 1fr;align-items:center;gap:clamp(26px,5vw,70px)}
.feature-row:nth-child(even) .feature-media{order:2}
.feature-media{position:relative;aspect-ratio:4/3;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  background-size:cover;background-position:center;box-shadow:0 40px 90px -50px #000}
.feature-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(7,6,10,.5)),radial-gradient(120% 100% at 80% 20%,rgba(255,42,48,.18),transparent 60%)}
.feature-tag{font-family:var(--ff-brush);font-size:clamp(16px,2vw,22px);color:var(--red-bright)}
.feature-row h3{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;line-height:.92;
  font-size:clamp(30px,4.4vw,62px);margin:.5rem 0 .9rem}
.feature-row p{color:#cdbfc4;font-size:clamp(16px,1.6vw,19px);max-width:46ch}
@media(max-width:820px){
  .feature-row{grid-template-columns:1fr;gap:20px}
  .feature-row:nth-child(even) .feature-media{order:0}
}

/* ---------- News ---------- */
.news{background:var(--ink-2)}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:3rem}
.news-card{border:1px solid var(--line);border-radius:18px;overflow:hidden;
  background:var(--panel);transition:.3s}
.news-card:hover{transform:translateY(-5px);border-color:rgba(255,42,48,.5);box-shadow:0 24px 60px -36px var(--red)}
.news-img{height:200px;background-size:cover;background-position:center;position:relative}
.news-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(7,6,10,.85))}
.news-body{padding:24px 26px 30px}
.news-tag{font-family:var(--ff-brush);font-size:16px;color:var(--red-bright)}
.news-card h3{font-family:var(--ff-head);font-weight:400;font-size:22px;margin:.5rem 0 .6rem;line-height:.98;text-transform:uppercase}
.news-card p{color:#bdb1b5;font-size:15px;margin-bottom:1rem}
.news-link{font-family:var(--ff-alt);font-weight:800;font-size:12px;letter-spacing:.12em;color:var(--red-bright);text-transform:uppercase}
.news-link:hover{text-decoration:underline}
@media(max-width:900px){.news-grid{grid-template-columns:1fr}}

/* ---------- Newsletter ---------- */
.signup{background:
  radial-gradient(80% 80% at 50% 0%,rgba(255,42,48,.16),transparent 60%),var(--ink);text-align:center}
.signup .wrap{max-width:740px}
.signup-sub{color:#cdbfc4;margin:1.1rem auto 2rem;max-width:50ch;font-size:17px}
.signup-form{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.signup-form input{flex:1;min-width:260px;padding:16px 20px;border-radius:6px;
  background:var(--panel);border:1px solid var(--line);color:var(--text);font-family:var(--ff-body);font-size:16px}
.signup-form input:focus{outline:none;border-color:var(--red)}
.signup-msg{margin-top:1.1rem;color:var(--red-bright);font-family:var(--ff-alt);font-weight:700;letter-spacing:.04em}
.contact-line{margin-top:1.4rem;color:var(--dim);font-family:var(--ff-alt);font-weight:600;letter-spacing:.06em;font-size:14px;text-transform:uppercase}

/* ---------- Partnership tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:2.6rem 0 2.4rem;text-align:left}
.tier{position:relative;background:linear-gradient(180deg,var(--panel),var(--ink-2));
  border:1px solid var(--line);border-radius:18px;padding:32px 28px;transition:.3s}
.tier:hover{transform:translateY(-5px);border-color:rgba(255,42,48,.5)}
.tier.featured{border-color:transparent;
  background:linear-gradient(var(--panel),var(--panel)) padding-box,var(--grad) border-box;
  box-shadow:0 30px 80px -42px var(--red)}
.tier-flag{position:absolute;top:-12px;left:26px;font-family:var(--ff-alt);font-weight:800;font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;padding:6px 13px;border-radius:999px;background:var(--grad);color:#13060a}
.tier h3{font-family:var(--ff-head);font-weight:400;font-size:clamp(26px,3vw,34px);text-transform:uppercase;letter-spacing:.01em}
.tier-sub{color:var(--dim);font-family:var(--ff-alt);font-weight:600;font-size:13px;letter-spacing:.08em;margin:.1rem 0 1.1rem;text-transform:uppercase}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.tier li{padding-left:22px;position:relative;color:#d4c7cb;font-size:15.5px}
.tier li::before{content:"▸";position:absolute;left:0;color:var(--red-bright)}
@media(max-width:820px){.tiers{grid-template-columns:1fr}}

/* ---------- Partners (scrolling marquee) ---------- */
.partners{background:var(--ink-2);overflow:hidden}
.marquee{position:relative;width:100%;overflow:hidden;padding:12px 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee-row{margin-top:1.6rem}
.marquee-track{display:flex;align-items:stretch;gap:14px;width:max-content;
  animation:scrollx 46s linear infinite;will-change:transform}
.marquee-rev .marquee-track{animation-direction:reverse;animation-duration:54s}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo{flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:12px;padding:22px 30px;min-width:190px;
  font-family:var(--ff-alt);font-weight:800;letter-spacing:.08em;font-size:15px;
  color:#d8cace;background:rgba(255,255,255,.025);transition:.3s;text-align:center;white-space:nowrap;text-transform:uppercase}
.logo:hover{color:#fff;border-color:var(--red);background:rgba(255,42,48,.06);box-shadow:0 0 30px -10px var(--red)}
.fineprint{color:var(--dim);font-size:15px;letter-spacing:.02em;margin-top:2.4rem}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-family:var(--ff-alt);font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  font-size:14px;padding:18px 34px;border-radius:6px;color:#13060a;background:var(--grad);
  box-shadow:0 16px 50px -16px var(--red);transition:.25s}
.btn:hover{transform:translateY(-2px);box-shadow:0 22px 60px -16px var(--red);filter:brightness(1.06)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:2rem}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line);box-shadow:none}
.btn-ghost:hover{border-color:var(--red);color:var(--red-bright)}

/* ---------- Footer ---------- */
.foot{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  padding:30px clamp(20px,5vw,40px);border-top:1px solid var(--line);
  font-family:var(--ff-alt);font-weight:700;font-size:12px;letter-spacing:.16em;color:#d8cace;text-transform:uppercase}
.foot .dim{color:var(--dim)}

/* ---------- Audience & reach ---------- */
.reach{position:relative;padding:clamp(80px,12vh,150px) 0;background:var(--ink)}
.reach-sub{color:#cdbfc4;max-width:60ch;margin-top:1.2rem;font-size:clamp(16px,1.6vw,19px)}
.reach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:3rem}
.reach-tile{background:linear-gradient(180deg,var(--panel),var(--ink-2));border:1px solid var(--line);
  border-radius:16px;padding:30px 24px;transition:.3s}
.reach-tile:hover{border-color:rgba(255,42,48,.5);transform:translateY(-4px);box-shadow:0 24px 60px -38px var(--red)}
.reach-num{font-family:var(--ff-head);font-weight:400;font-size:clamp(34px,4.4vw,54px);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.reach-label{margin-top:.6rem;font-family:var(--ff-alt);font-weight:600;font-size:13px;letter-spacing:.08em;color:#cdbfc4;text-transform:uppercase}
.reach-foot{margin-top:2rem;color:var(--dim);font-size:14px;letter-spacing:.02em}
.reach-split{display:flex;flex-direction:column;gap:14px;margin-top:14px}
.reach-band{background:linear-gradient(110deg,rgba(255,42,48,.14),var(--panel-2) 60%);border:1px solid rgba(255,42,48,.3);
  border-radius:16px;padding:28px 30px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px 26px}
.reach-band .cell{display:flex;flex-direction:column;gap:5px;min-width:0}
.reach-band b{font-family:var(--ff-head);font-weight:400;font-size:clamp(26px,3vw,40px);color:#fff;line-height:1}
.reach-band span{font-family:var(--ff-alt);font-weight:600;letter-spacing:.05em;color:#cdbfc4;text-transform:uppercase;font-size:11.5px;line-height:1.3}
@media(max-width:760px){.reach-band{grid-template-columns:repeat(2,1fr)}}
@media(max-width:820px){.reach-grid{grid-template-columns:repeat(2,1fr)}.reach-split{grid-template-columns:1fr}}

/* ---------- Going global (2027) ---------- */
.global{position:relative;padding:clamp(80px,12vh,150px) 0;
  background:radial-gradient(80% 80% at 80% 0%,rgba(255,42,48,.14),transparent 60%),var(--ink-2)}
.global .body{max-width:52ch}
.global-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center}
.global-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:2.2rem}
.global-chip{font-family:var(--ff-alt);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:13px;
  color:#e7dadd;border:1px solid var(--line);background:rgba(255,255,255,.03);padding:13px 18px;border-radius:999px}
.global-chip b{color:var(--red-bright)}
@media(max-width:880px){.global-inner{grid-template-columns:1fr}}

/* ---- Global hub — beams converging into the glowing NZ map ---- */
.globe-stage{position:relative;width:min(520px,90vw);aspect-ratio:1;margin:0 auto;isolation:isolate}
.globe-glow{position:absolute;inset:12%;border-radius:50%;
  background:radial-gradient(circle at 50% 50%,rgba(255,42,48,.40),rgba(255,106,26,.14) 46%,transparent 68%);
  filter:blur(16px);animation:glowbreathe 4.5s ease-in-out infinite}
@keyframes glowbreathe{0%,100%{opacity:.6;transform:scale(.95)}50%{opacity:1;transform:scale(1.06)}}
.orbit-ring{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1;overflow:visible}
.orbit-ring circle{fill:none;stroke:rgba(255,90,40,.22);stroke-width:1.4;stroke-dasharray:2 13;
  transform-origin:300px 300px;animation:orbitspin 70s linear infinite}
@keyframes orbitspin{to{transform:rotate(360deg)}}
.globe-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;transform:scale(.84);z-index:2;
  animation:nzbreathe 5s ease-in-out infinite}
@keyframes nzbreathe{0%,100%{transform:scale(.84)}50%{transform:scale(.857)}}
.beams{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:3;overflow:visible}
.beams .arc{stroke-width:2.6;stroke-linecap:round;stroke-dasharray:18 218;filter:drop-shadow(0 0 8px rgba(255,42,48,.9))}
.beams .a1{animation:beamflow 2.4s linear infinite}
.beams .a2{animation:beamflow 2.4s linear infinite .3s}
.beams .a3{animation:beamflow 2.4s linear infinite .6s}
.beams .a4{animation:beamflow 2.4s linear infinite .9s}
.beams .a5{animation:beamflow 2.4s linear infinite 1.2s}
.beams .a6{animation:beamflow 2.4s linear infinite 1.5s}
@keyframes beamflow{from{stroke-dashoffset:236}to{stroke-dashoffset:0}}
.globe-net{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:4;overflow:visible}
.globe-net .node circle{fill:#ff5a3c;filter:drop-shadow(0 0 7px rgba(255,42,48,.9));transform-origin:center;
  transform-box:fill-box;animation:nodepulse 2.2s ease-in-out infinite}
.globe-net .n2 circle{animation-delay:.4s}.globe-net .n4 circle{animation-delay:.8s}.globe-net .n6 circle{animation-delay:1.2s}
@keyframes nodepulse{0%,100%{opacity:.6;transform:scale(.8)}50%{opacity:1;transform:scale(1.25)}}
.globe-net .glabel{fill:#f3e7ea;font-family:var(--ff-alt);font-weight:800;font-size:16px;letter-spacing:.08em}
.globe-net .nz-pulse{fill:none;stroke:#ffd28a;stroke-width:2;transform-origin:300px 300px;animation:nzpulse 2.6s ease-out infinite}
@keyframes nzpulse{0%{r:10;opacity:.85}100%{r:48;opacity:0}}
@media(prefers-reduced-motion:reduce){.globe-glow,.orbit-ring circle,.beams .arc,.globe-net .node circle,.globe-img,.globe-net .nz-pulse{animation:none}}

/* ---------- International drivers ---------- */
.drivers{position:relative;padding:clamp(80px,12vh,150px) 0;background:var(--ink);overflow:hidden}
.drivers-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.drivers-veil{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,var(--ink) 0%,rgba(7,6,10,.78) 22%,rgba(7,6,10,.74) 70%,var(--ink) 100%),
  radial-gradient(70% 60% at 25% 40%,rgba(7,6,10,.45),transparent 70%)}
.drivers>.wrap{position:relative;z-index:2}
.driver-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:3rem}
.driver-card{background:linear-gradient(180deg,var(--panel),var(--ink-2));border:1px solid var(--line);
  border-radius:16px;padding:24px 22px;transition:.3s}
.driver-card:hover{border-color:rgba(255,42,48,.5);transform:translateY(-4px)}
.driver-flag{font-family:var(--ff-alt);font-weight:800;font-size:11px;letter-spacing:.16em;color:var(--red-bright);text-transform:uppercase}
.driver-name{font-family:var(--ff-head);font-weight:400;font-size:clamp(20px,2.2vw,26px);margin:.35rem 0 .3rem;text-transform:uppercase;line-height:.98}
.driver-cred{color:#cdbfc4;font-size:13.5px;font-family:var(--ff-alt);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
@media(max-width:900px){.driver-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- Team (powered by people) ---------- */
.team{position:relative;padding:clamp(80px,12vh,150px) 0;background:var(--ink-2)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:3rem}
.team-card{background:linear-gradient(180deg,var(--panel),var(--ink-2));border:1px solid var(--line);
  border-radius:16px;padding:28px 26px;transition:.3s}
.team-card:hover{border-color:rgba(255,42,48,.45);transform:translateY(-4px)}
.team-name{font-family:var(--ff-head);font-weight:400;font-size:clamp(22px,2.4vw,28px);text-transform:uppercase;line-height:1}
.team-role{font-family:var(--ff-alt);font-weight:700;font-size:12px;letter-spacing:.12em;color:var(--red-bright);text-transform:uppercase;margin:.4rem 0 .7rem}
.team-card p{color:#cdbfc4;font-size:15px}
@media(max-width:820px){.team-grid{grid-template-columns:1fr}}

/* ---------- Logo band (real partner logos) ---------- */
.logo-band{margin:2.8rem auto 0;max-width:var(--maxw);padding:clamp(22px,3vw,40px);
  background:#2b2b2b;border:1px solid var(--line);border-radius:18px}
.logo-band img{width:100%;height:auto;display:block}

/* ---------- Contact cards ---------- */
.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:2.4rem 0 0;text-align:left}
.contact-card{background:linear-gradient(180deg,var(--panel),var(--ink-2));border:1px solid var(--line);
  border-radius:16px;padding:28px 30px}
.contact-card .cc-name{font-family:var(--ff-head);font-weight:400;font-size:26px;text-transform:uppercase;line-height:1}
.contact-card .cc-role{font-family:var(--ff-alt);font-weight:700;font-size:12px;letter-spacing:.1em;color:var(--red-bright);text-transform:uppercase;margin:.3rem 0 1rem}
.contact-card a{display:block;color:#e7dadd;font-size:15px;margin-top:.3rem}
.contact-card a:hover{color:var(--red-bright)}
@media(max-width:820px){.contact-cards{grid-template-columns:1fr}}

/* ---------- Sub-pages (HotPit, Economics) ---------- */
.subhero{position:relative;min-height:74vh;display:flex;align-items:flex-end;overflow:hidden;
  padding:0 0 clamp(40px,7vh,90px);background:#07060a}
.subhero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04)}
.subhero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,6,10,.55),rgba(7,6,10,.2) 35%,rgba(7,6,10,.95)),
             radial-gradient(90% 70% at 70% 30%,rgba(255,42,48,.22),transparent 60%)}
.subhero .wrap{position:relative;z-index:2}
.subhero h1{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;line-height:.9;
  font-size:clamp(44px,9vw,118px);letter-spacing:.005em;margin:.4rem 0}
.subhero .accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.subhero p{max-width:48ch;color:#f0e3e6;font-size:clamp(16px,1.8vw,21px);margin-top:1rem}
.backlink{font-family:var(--ff-alt);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:#cdbfc4}
.backlink:hover{color:var(--red-bright)}
.prose{max-width:64ch;margin-top:1.6rem}
.prose p{color:#ddc9ce;font-size:clamp(16px,1.6vw,19px);margin-bottom:1.1rem}
.prose strong{color:#fff}

/* quote blocks */
.quote{position:relative;background:linear-gradient(180deg,var(--panel),var(--ink-2));border:1px solid var(--line);
  border-left:3px solid var(--red);border-radius:14px;padding:28px 32px;margin:1.2rem 0}
.quote p{font-size:clamp(17px,1.8vw,21px);color:#f2e7ea;font-style:italic;line-height:1.5}
.quote cite{display:block;margin-top:.9rem;font-style:normal;font-family:var(--ff-alt);font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;font-size:12.5px;color:var(--red-bright)}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:1.4rem}
@media(max-width:820px){.quote-grid{grid-template-columns:1fr}}

/* placeholder tag */
.tbc{display:inline-block;font-family:var(--ff-alt);font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:#ffd166;border:1px dashed rgba(255,209,102,.5);border-radius:999px;padding:3px 10px;margin-left:8px;vertical-align:middle}

/* Vegas hero variant — bright & exciting */
.subhero-vegas{min-height:88vh}
.subhero-vegas .subhero-bg{transform:scale(1.06)}
.subhero-vegas .subhero-bg::after{
  background:linear-gradient(180deg,rgba(7,6,10,.2),rgba(7,6,10,.05) 38%,rgba(7,6,10,.78)),
             radial-gradient(70% 60% at 18% 60%,rgba(7,6,10,.55),transparent 60%)}
.subhero-vegas .wrap{max-width:var(--maxw)}
.subhero-copy{max-width:58%}
.dave-cut{position:absolute;right:1%;bottom:0;height:90%;max-height:720px;z-index:2;
  filter:drop-shadow(0 12px 40px rgba(0,0,0,.85)) drop-shadow(0 0 30px rgba(255,42,48,.25))}
.dave-glow{position:absolute;right:0;bottom:0;width:48%;height:92%;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse 60% 70% at 72% 78%,rgba(7,6,10,.85),rgba(7,6,10,.4) 55%,transparent 72%)}
.logo-lockup{display:flex;align-items:center;gap:20px;margin:0 0 1.2rem}
.logo-lockup img{height:clamp(34px,4.5vw,52px);width:auto;display:block}
.logo-lockup .x{font-family:var(--ff-head);color:var(--red-bright);font-size:clamp(20px,3vw,30px)}
/* Hotpit subhero lockup, 40% larger */
.subhero-vegas .logo-lockup img{height:clamp(48px,6.3vw,73px)}
.subhero-vegas .logo-lockup .x{font-size:clamp(28px,4.2vw,42px)}
.neon{color:#fff;text-shadow:0 0 4px rgba(255,255,255,.3),0 0 12px rgba(255,42,48,.4)}
@media(max-width:820px){.dave-cut,.dave-glow{display:none}.subhero-copy{max-width:100%}}

/* Vegas teaser slice (home page, slim) */
.vegas-slice{position:relative;display:flex;align-items:center;overflow:hidden;text-decoration:none;color:var(--text);
  min-height:clamp(360px,52vh,540px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#07060a}
.vegas-slice .subhero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);transition:transform .6s ease}
.vegas-slice:hover .subhero-bg{transform:scale(1.07)}
.vegas-slice .subhero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(7,6,10,.94),rgba(7,6,10,.6) 42%,rgba(7,6,10,.12) 72%),linear-gradient(180deg,rgba(7,6,10,.25),rgba(7,6,10,.55))}
.vegas-slice-inner{position:relative;z-index:2;width:100%}
.vegas-slice .subhero-copy{max-width:60%}
.vegas-slice .logo-lockup{margin-bottom:1rem}
.vegas-h{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;line-height:.9;
  font-size:clamp(32px,5.5vw,66px);margin:.4rem 0 .6rem}
.vegas-h .accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.vegas-p{max-width:44ch;color:#f0e3e6;font-size:clamp(15px,1.5vw,18px);margin-bottom:1.4rem}
.vegas-slice .dave-cut{height:96%;max-height:520px;bottom:0;right:1.5%}
@media(max-width:820px){.vegas-slice{min-height:0;padding:54px 0}.vegas-slice .subhero-copy{max-width:100%}
  .vegas-slice .dave-cut,.vegas-slice .dave-glow{display:none}}

/* highlight callout (Going Global → Vegas) */
.callout{margin-top:2rem;display:flex;gap:18px;align-items:center;flex-wrap:wrap;
  background:linear-gradient(110deg,rgba(255,42,48,.18),var(--panel-2) 60%);border:1px solid rgba(255,42,48,.4);
  border-radius:16px;padding:22px 26px}
.callout-txt{flex:1;min-width:220px}
.callout-k{font-family:var(--ff-brush);color:var(--red-bright);font-size:18px}
.callout-h{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;font-size:clamp(20px,2.4vw,30px);line-height:1;margin-top:.2rem}
.callout-p{color:#cdbfc4;font-size:14.5px;margin-top:.4rem}

/* ---------- VirtualD1 static car showcase ---------- */
.vd1-static{position:relative;overflow:hidden;display:flex;align-items:flex-end;
  min-height:clamp(520px,84vh,860px);background:#04080c;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.vd1-bg{position:absolute;inset:0;background-size:cover;background-position:center;will-change:transform,opacity}
/* crossfade between two crisp stills — front view ⇄ rear view, no rotation so logo never distorts */
.vd1-front{animation:vd1zoom 22s ease-in-out infinite alternate, vd1fadeF 13s ease-in-out infinite}
.vd1-rear {opacity:0;animation:vd1zoom 22s ease-in-out infinite alternate, vd1fadeR 13s ease-in-out infinite}
@keyframes vd1zoom{from{transform:scale(1.04)}to{transform:scale(1.1)}}
@keyframes vd1fadeF{0%,42%{opacity:1}50%,92%{opacity:0}100%{opacity:1}}
@keyframes vd1fadeR{0%,42%{opacity:0}50%,92%{opacity:1}100%{opacity:0}}
/* view label that switches with the crossfade */
.vd1-viewtag{position:absolute;left:clamp(18px,4vw,60px);top:clamp(78px,13vh,128px);z-index:6;height:1.4em}
.vd1-viewtag span{position:absolute;left:0;top:0;white-space:nowrap;font-family:var(--ff-head);font-weight:400;
  text-transform:uppercase;letter-spacing:.14em;font-size:clamp(13px,1.3vw,16px);color:#7df0e6;
  padding-left:18px;text-shadow:0 2px 18px rgba(0,210,255,.5)}
.vd1-viewtag span::before{content:"";position:absolute;left:0;top:.5em;width:8px;height:8px;border-radius:50%;
  background:#00e0ff;box-shadow:0 0 12px #00e0ff}
.vt-front{animation:vd1fadeF 13s ease-in-out infinite}
.vt-rear{animation:vd1fadeR 13s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.vd1-front,.vd1-rear,.vt-front,.vt-rear{animation:none}.vd1-rear{opacity:1}.vt-rear{opacity:0}}
/* sim-hologram scan layers (car stays a fixed still → logo never distorts) */
.vd1-static .vd1-lines{position:absolute;inset:0;z-index:3;pointer-events:none;mix-blend-mode:soft-light;opacity:.45;
  background:repeating-linear-gradient(0deg,rgba(120,240,255,.16) 0 1px,transparent 1px 5px);
  animation:vd1lines 7s linear infinite}
@keyframes vd1lines{from{background-position:0 0}to{background-position:0 240px}}
.vd1-static .vd1-scan{position:absolute;inset:0;z-index:4;pointer-events:none;mix-blend-mode:screen;
  background:linear-gradient(100deg,transparent 38%,rgba(0,210,255,.14) 47%,rgba(150,245,235,.42) 50%,rgba(0,210,255,.14) 53%,transparent 62%);
  background-size:260% 100%;animation:vd1sweep 6.5s ease-in-out infinite}
@keyframes vd1sweep{0%{background-position:150% 0}60%,100%{background-position:-50% 0}}
@media(prefers-reduced-motion:reduce){.vd1-static .vd1-lines,.vd1-static .vd1-scan{animation:none;opacity:.25}}
.vd1-grade{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(4,8,12,.55),rgba(4,8,12,.1) 30%,rgba(4,8,12,.2) 55%,rgba(4,8,12,.92)),
             radial-gradient(80% 70% at 25% 80%,rgba(0,210,255,.12),transparent 60%)}
.vd1-static-inner{position:relative;z-index:5;padding-bottom:clamp(40px,7vh,90px)}
.vd1-h{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;line-height:.88;
  font-size:clamp(48px,10vw,140px);margin:.4rem 0 .7rem;text-shadow:0 6px 40px rgba(0,0,0,.6)}
.vd1-h .accent{background:linear-gradient(100deg,#19a0ff,#00e0ff 55%,#7df0e6);
  -webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 4px 24px rgba(0,210,255,.5))}
.vd1-sub{max-width:48ch;color:#eaf6ff;font-size:clamp(16px,1.8vw,21px);margin-bottom:1.6rem;text-shadow:0 2px 14px rgba(0,0,0,.8)}
.vd1-static .kicker{color:#7df0e6;text-shadow:0 2px 18px rgba(0,210,255,.5)}
.vd1-static .telemetry b{color:#7df0e6}
@media(prefers-reduced-motion:reduce){.vd1-bg{animation:none}}

/* VirtualD1 full-car still (shows A90 front + A80 rear) */
.vd1-still{position:relative;margin:2.6rem 0 0;border-radius:18px;overflow:hidden;
  border:1px solid rgba(0,210,255,.25);box-shadow:0 30px 90px -50px #00e0ff}
.vd1-still img{width:100%;display:block}
.vd1-still-cap{position:absolute;left:18px;bottom:16px;font-family:var(--ff-alt);font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:#fff;
  background:rgba(4,8,12,.6);border:1px solid rgba(0,210,255,.4);padding:9px 15px;border-radius:999px;backdrop-filter:blur(4px)}

/* VirtualD1 official logo in the turntable overlay */
.vd1-logo-hero{width:min(440px,70vw);height:auto;display:block;margin:.3rem 0 1.1rem;
  filter:drop-shadow(0 6px 30px rgba(0,0,0,.7))}

/* ---------- VirtualD1 (cyan / virtual accent) ---------- */
.cinematic.vd1 .tint{background:radial-gradient(82% 72% at 52% 42%,rgba(0,210,255,.30),transparent 70%)}
.cinematic.vd1 .progress-fill{background:linear-gradient(100deg,#19a0ff,#00e0ff);box-shadow:0 0 16px #00e0ff}
.cinematic.vd1 .kicker{color:#7df0e6;text-shadow:0 2px 18px rgba(0,210,255,.5)}
.cinematic.vd1 .mega.accent,.cinematic.vd1 .big.accent{
  background:linear-gradient(100deg,#19a0ff,#00e0ff 55%,#7df0e6);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 30px rgba(0,210,255,.5))}
.cinematic.vd1 .telemetry b{color:#7df0e6}
.vd1-sec{background:
  radial-gradient(70% 60% at 12% 0%,rgba(0,210,255,.10),transparent 60%),var(--ink)}
.vd1-sec .eyebrow{color:#7df0e6;text-shadow:0 2px 16px rgba(0,210,255,.3)}
.vd1-sec .grad-text{background:linear-gradient(100deg,#19a0ff,#00e0ff 55%,#7df0e6);-webkit-background-clip:text;background-clip:text;color:transparent}
.vd1-sec .card::before{background:linear-gradient(180deg,#19a0ff,#00e0ff)}
.vd1-sec .card:hover{border-color:rgba(0,210,255,.5);box-shadow:0 28px 70px -38px #00e0ff}
.vd1-sec .card-num{color:#7df0e6}
.vd1-sec .btn-ghost:hover{border-color:#00e0ff;color:#7df0e6}

/* ---------- Auto reveals (play on load, not gated on scroll) ---------- */
.reveal{opacity:0;transform:translateY(24px);animation:autoreveal .85s cubic-bezier(.2,.7,.2,1) forwards}
.reveal.in{opacity:1;transform:none}
@keyframes autoreveal{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.reveal{animation:none;opacity:1;transform:none}}

/* ======================= Packages page ======================= */
/* Urgency banner */
.urgent{background:linear-gradient(100deg,rgba(255,42,48,.16),rgba(255,106,26,.10));border-top:1px solid rgba(255,42,48,.4);border-bottom:1px solid rgba(255,42,48,.4)}
.urgent-inner{display:flex;align-items:center;gap:18px;padding:18px 0;flex-wrap:wrap}
.urgent-inner p{flex:1;min-width:240px;margin:0;font-size:clamp(14px,1.5vw,16px);color:#ffe7e0}
.urgent-inner .btn{flex-shrink:0}
.urgent-dot{width:11px;height:11px;border-radius:50%;background:var(--red-bright);box-shadow:0 0 0 0 rgba(255,42,48,.6);animation:urgpulse 1.8s infinite}
@keyframes urgpulse{0%{box-shadow:0 0 0 0 rgba(255,42,48,.55)}70%{box-shadow:0 0 0 14px rgba(255,42,48,0)}100%{box-shadow:0 0 0 0 rgba(255,42,48,0)}}

/* Audience category grid */
.aud-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.aud-card{background:var(--ink-2);border:1px solid var(--line);border-radius:14px;padding:24px 26px;transition:.25s}
.aud-card:hover{border-color:rgba(255,42,48,.5);transform:translateY(-3px)}
.aud-card h4{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;letter-spacing:.02em;font-size:clamp(17px,1.9vw,21px);margin:0 0 .5rem;color:#fff}
.aud-card p{margin:0;color:var(--text);opacity:.82;font-size:14.5px;line-height:1.55}

/* ROI hero */
.roi-hero{display:flex;gap:clamp(20px,4vw,48px);align-items:center;flex-wrap:wrap;background:linear-gradient(110deg,var(--panel-2),var(--ink-2) 70%);border:1px solid rgba(255,42,48,.35);border-radius:18px;padding:clamp(26px,4vw,44px);margin-top:1.8rem}
.roi-big{text-align:center;flex-shrink:0}
.roi-num{font-family:var(--ff-head);font-weight:400;font-size:clamp(80px,13vw,150px);line-height:.86;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 6px 30px rgba(255,42,48,.45))}
.roi-cap{text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--red-bright);margin-top:.4rem}
.roi-says{flex:1;min-width:260px}
.roi-says p{margin:0 0 .8rem;font-size:clamp(15px,1.7vw,18px);line-height:1.6;color:#f3eef0}
.roi-foot{font-size:12px!important;opacity:.55}

/* Comparison table */
.cmp-wrap{overflow-x:auto;border-radius:14px;border:1px solid var(--line)}
.cmp{width:100%;border-collapse:collapse;min-width:560px;font-size:14.5px}
.cmp th{text-align:left;padding:14px 18px;background:var(--ink-2);font-family:var(--ff-head);font-weight:400;text-transform:uppercase;letter-spacing:.04em;color:#fff;font-size:13px;border-bottom:1px solid var(--line)}
.cmp td{padding:13px 18px;border-bottom:1px solid var(--line);color:var(--text);opacity:.9}
.cmp tr:last-child td{border-bottom:none}
.cmp-hi{color:#ffb3a0;font-weight:600;white-space:nowrap}
.cmp-us td{background:rgba(255,42,48,.08)}
.cmp-win{color:#7dffa8;font-weight:700;white-space:nowrap}

/* Package cards */
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;text-align:left;margin-top:1rem}
.pkg{position:relative;display:flex;flex-direction:column;background:linear-gradient(160deg,var(--panel-2),var(--ink-2));border:1px solid var(--line);border-radius:16px;padding:28px 26px;transition:.25s}
.pkg:hover{border-color:rgba(255,42,48,.6);transform:translateY(-4px);box-shadow:0 30px 70px -45px var(--red)}
.pkg.feat{border-color:rgba(255,42,48,.7);box-shadow:0 0 0 1px rgba(255,42,48,.3)}
.pkg.sold{opacity:.72}
.pkg-scarcity{align-self:flex-start;font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;padding:5px 11px;border-radius:30px;background:rgba(255,255,255,.08);color:#cfcdd6;margin-bottom:14px}
.pkg-scarcity.hot{background:rgba(255,42,48,.18);color:#ff9a8f}
.pkg-scarcity.gone{background:rgba(120,120,130,.2);color:#9a99a3}
.pkg-name{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;letter-spacing:.01em;font-size:clamp(21px,2.4vw,27px);margin:0 0 .25rem;color:#fff}
.pkg-tag{margin:0 0 1rem;color:var(--red-bright);font-size:13.5px}
.pkg-price{font-family:var(--ff-head);font-weight:400;font-size:clamp(32px,4vw,44px);color:#fff;line-height:1;margin-bottom:1.2rem;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.pkg-alt{font-family:var(--ff-body,inherit);font-size:13px;color:var(--text);opacity:.6;letter-spacing:0}
.pkg-list{list-style:none;padding:0;margin:0 0 1.6rem;flex:1}
.pkg-list li{position:relative;padding:7px 0 7px 22px;font-size:14px;color:var(--text);opacity:.88;border-bottom:1px solid rgba(255,255,255,.05)}
.pkg-list li::before{content:"›";position:absolute;left:4px;color:var(--red-bright);font-weight:700}
.pkg-cta{align-self:flex-start;margin-top:auto}
.pkg-note{margin-top:2.4rem;background:var(--ink-2);border:1px dashed rgba(255,255,255,.16);border-radius:14px;padding:22px 26px}
.pkg-note p{margin:0;color:var(--text);opacity:.85;font-size:15px;line-height:1.6}

/* Lead-capture form */
.book{background:linear-gradient(180deg,var(--ink-2),var(--ink))}
.lead-form{max-width:680px;margin:2rem auto 0;text-align:left}
.lf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.lf-row{grid-template-columns:1fr}}
.field{display:block;margin-bottom:16px}
.field span{display:block;font-size:12.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--red-bright);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;background:var(--ink-2);border:1px solid var(--line);border-radius:10px;padding:13px 15px;color:#fff;font-family:inherit;font-size:15px;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(255,42,48,.18)}
.field textarea{resize:vertical}
.lf-submit{margin-top:.6rem;width:100%;justify-content:center;font-size:16px}
.lf-fine{text-align:center;font-size:13px;opacity:.6;margin-top:1.2rem}
.lf-fine a{color:var(--red-bright)}
.hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* Hero CTA (needs pointer-events back on inside the click-through overlay) */
.hero-cta{display:flex;gap:14px;margin-top:1.7rem;pointer-events:auto;flex-wrap:wrap}

/* Video / sizzle-reel placeholder */
.reel-sec{background:var(--ink-2);padding:clamp(40px,7vw,90px) 0}
.reel{position:relative;display:block;max-width:1000px;margin:0 auto;border-radius:18px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9;background-size:cover;background-position:center;cursor:pointer;transition:.3s}
.reel:hover{border-color:rgba(255,42,48,.6);transform:translateY(-3px);box-shadow:0 40px 90px -50px var(--red)}
.reel::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,6,10,.25),rgba(7,6,10,.78))}
.reel-inner{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:20px}
.reel-play{width:84px;height:84px;border-radius:50%;background:rgba(255,42,48,.92);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 0 rgba(255,42,48,.55);animation:urgpulse 2s infinite}
.reel-play::before{content:"";margin-left:6px;border-style:solid;border-width:16px 0 16px 26px;border-color:transparent transparent transparent #fff}
.reel-h{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;font-size:clamp(22px,3vw,38px);color:#fff;letter-spacing:.01em;line-height:1}
.reel-badge{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#ffb3a0;background:rgba(255,42,48,.16);border:1px solid rgba(255,42,48,.4);padding:6px 14px;border-radius:30px}

/* Quote header photo + featured video */
.quote-header{margin:0 auto 1.8rem;border-radius:16px;overflow:hidden;border:1px solid var(--line);max-width:900px;box-shadow:0 30px 70px -45px var(--red)}
.quote-header img{display:block;width:100%;height:auto}
.video-feature{position:relative;max-width:960px;margin:1.8rem auto 0;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:#000;box-shadow:0 30px 80px -45px var(--red)}
.video-feature video{display:block;width:100%;height:auto;aspect-ratio:16/9;background:#000}
.video-badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--red);padding:6px 14px;border-radius:30px;margin-bottom:1rem}

/* Case-study bento galleries (one hero tile + two supporting) */
.case-bento{display:grid;grid-template-columns:1.9fr 1fr;grid-template-rows:repeat(2,1fr);gap:12px;margin-top:1.9rem;height:clamp(380px,48vw,540px)}
.case-tile{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:#0c0608}
.case-tile img,.case-tile video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.case-tile:hover img{transform:scale(1.05)}
.case-tile.big{grid-column:1;grid-row:1/3}
.case-bento.flip{grid-template-columns:1fr 1.9fr}
.case-bento.flip .case-tile.big{grid-column:2;grid-row:1/3}
.case-tile figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px 15px 12px;font-size:13px;color:#fff;background:linear-gradient(transparent,rgba(7,6,10,.92));font-weight:500;letter-spacing:.01em;z-index:2}
.case-tile .vtag{position:absolute;top:12px;left:12px;z-index:2;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(110,220,60,.85);padding:4px 9px;border-radius:20px;font-weight:700}
.case-tile .vtag.tier{background:var(--red);box-shadow:0 6px 18px -6px var(--red)}
.tier-line{display:inline-block;color:var(--red-bright);font-weight:600}
@media(max-width:640px){.case-bento,.case-bento.flip{grid-template-columns:1fr;grid-template-rows:none;height:auto}.case-tile{aspect-ratio:3/2}.case-tile.big{grid-column:1;grid-row:auto;aspect-ratio:16/10}}
.case-intro{max-width:60ch;color:var(--text);opacity:.9;font-size:clamp(16px,1.7vw,19px);line-height:1.65;margin-top:1rem}
.case-badge{display:inline-block;font-family:var(--ff-head);font-weight:400;text-transform:uppercase;letter-spacing:.04em;font-size:12px;color:#7dff5a;background:rgba(110,220,60,.14);border:1px solid rgba(110,220,60,.4);padding:6px 14px;border-radius:30px;margin-bottom:1rem}

/* Proof / testimonial feature */
.proof-feature{background:linear-gradient(110deg,var(--panel-2),var(--ink-2) 70%);border:1px solid rgba(255,42,48,.3);border-left:4px solid var(--red);border-radius:16px;padding:clamp(28px,4vw,46px);margin-top:1.6rem}
.proof-feature .pf-quote{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;line-height:1.05;font-size:clamp(24px,3.4vw,42px);color:#fff;margin:0 0 1rem}
.proof-feature .pf-quote em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.proof-feature .pf-cite{color:var(--red-bright);font-size:15px;letter-spacing:.02em}
.proof-feature .pf-sub{margin:1.2rem 0 0;color:var(--text);opacity:.85;font-size:15.5px;line-height:1.6}

/* ======================= VirtualD1 page ======================= */
.vd1hero{position:relative;min-height:94vh;display:flex;align-items:flex-end;overflow:hidden;background:#04080c;border-bottom:1px solid var(--line)}
.vd1hero-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.vd1hero-grade{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(4,8,12,.55),transparent 24%,rgba(4,8,12,.3) 55%,rgba(4,8,12,.96)),radial-gradient(80% 80% at 26% 72%,rgba(0,210,255,.13),transparent 62%)}
.vd1hero .wrap{position:relative;z-index:2;padding-bottom:clamp(50px,9vh,110px);width:100%}
.vd1hero-logo{width:min(300px,58vw);height:auto;display:block;margin-bottom:1.4rem;filter:drop-shadow(0 6px 26px rgba(0,0,0,.7))}
.vd1hero h1{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;line-height:.88;font-size:clamp(46px,8.5vw,118px);margin:0 0 1rem;text-shadow:0 6px 40px rgba(0,0,0,.6)}
.cy{background:linear-gradient(100deg,#19a0ff,#00e0ff 55%,#7df0e6);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 4px 22px rgba(0,210,255,.45))}
.vd1hero .lede{max-width:54ch;color:#eaf6ff;font-size:clamp(16px,1.9vw,22px);line-height:1.55;text-shadow:0 2px 14px rgba(0,0,0,.8)}
.vd1hero .btn-row{margin-top:1.7rem}
.vd1hero .btn:not(.btn-ghost){background:linear-gradient(100deg,#19a0ff,#00e0ff 60%,#7df0e6);color:#04141a;box-shadow:0 8px 30px -10px rgba(0,210,255,.6)}
.vd1hero .btn-ghost:hover{border-color:#00e0ff;color:#7df0e6}
.eyebrow.cy-eye{color:#7df0e6}
/* Naming-rights offer */
.vd1-offer{position:relative;background:linear-gradient(140deg,rgba(0,70,92,.4),var(--ink-2));border:1px solid rgba(0,210,255,.35);border-radius:20px;padding:clamp(28px,4vw,52px)}
.vd1-offer-flag{display:inline-block;font-family:var(--ff-alt);font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:#04141a;background:linear-gradient(100deg,#00e0ff,#7df0e6);padding:6px 14px;border-radius:30px;margin-bottom:1.2rem}
.vd1-offer h2{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;font-size:clamp(30px,4.4vw,52px);line-height:.95;margin:0 0 .8rem;color:#fff}
.vd1-offer p{color:#dff1ff;opacity:.92;font-size:clamp(15px,1.7vw,18px);line-height:1.6;max-width:62ch}
.vd1-price{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin:1.4rem 0 1.6rem}
.vd1-price b{font-family:var(--ff-head);font-weight:400;font-size:clamp(50px,8vw,90px);line-height:1;background:linear-gradient(100deg,#19a0ff,#00e0ff 55%,#7df0e6);-webkit-background-clip:text;background-clip:text;color:transparent}
.vd1-price span{color:#7df0e6;font-size:15px;letter-spacing:.04em;text-transform:uppercase}
.vd1-incl{list-style:none;padding:0;margin:0 0 1.9rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:8px 28px}
.vd1-incl li{position:relative;padding:9px 0 9px 26px;color:#eaf6ff;font-size:15px;border-bottom:1px solid rgba(255,255,255,.08)}
.vd1-incl li::before{content:"\2713";position:absolute;left:0;color:#00e0ff;font-weight:700}
.vd1-offer .btn{background:linear-gradient(100deg,#19a0ff,#00e0ff 60%,#7df0e6);color:#04141a}
/* Homepage VD1 teaser slice */
.vd1-teaser{position:relative;display:block;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);min-height:clamp(440px,62vh,660px);background:#04080c}
.vd1-teaser .tz-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transition:transform .9s ease}
.vd1-teaser:hover .tz-bg{transform:scale(1.05)}
.vd1-teaser .tz-grade{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(4,8,12,.95),rgba(4,8,12,.5) 58%,rgba(4,8,12,.82)),radial-gradient(70% 70% at 20% 60%,rgba(0,210,255,.16),transparent 62%)}
.vd1-teaser .wrap{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;min-height:inherit;padding-top:3rem;padding-bottom:3rem}
.vd1-teaser .tz-logo{width:min(240px,52vw);height:auto;margin-bottom:1.1rem;filter:drop-shadow(0 4px 20px rgba(0,0,0,.7))}
.vd1-teaser h2{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;line-height:.9;font-size:clamp(40px,6.5vw,84px);margin:0 0 .8rem;color:#fff}
.vd1-teaser p{max-width:48ch;color:#eaf6ff;font-size:clamp(15px,1.7vw,19px);margin-bottom:1.5rem;text-shadow:0 2px 12px rgba(0,0,0,.8)}
.vd1-teaser .btn{background:linear-gradient(100deg,#19a0ff,#00e0ff 60%,#7df0e6);color:#04141a;pointer-events:none;align-self:flex-start}

.vd1-teaser .tz-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}

/* VirtualD1 image fold (Darren on the sim) */
.vd1-fold{position:relative;overflow:hidden;min-height:clamp(420px,60vh,640px);display:flex;align-items:flex-end;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#04080c}
.vd1-fold-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:70% center;z-index:0}
.vd1-fold-grade{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(4,8,12,.94),rgba(4,8,12,.6) 52%,rgba(4,8,12,.25)),linear-gradient(180deg,rgba(4,8,12,.4),transparent 40%,rgba(4,8,12,.65)),radial-gradient(60% 70% at 18% 60%,rgba(0,210,255,.14),transparent 60%)}
.vd1-fold .wrap{position:relative;z-index:2;padding-top:3rem;padding-bottom:3rem}
.vd1-fold-h{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;line-height:.9;font-size:clamp(36px,6vw,78px);margin:0 0 .7rem;color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.6)}
.vd1-fold p{color:#eaf6ff;font-size:clamp(15px,1.8vw,20px);max-width:46ch;text-shadow:0 2px 12px rgba(0,0,0,.85);line-height:1.5}

/* Stats band with drift-battle background (front-page pop) */
.stats.stats-hero{position:relative;grid-template-columns:repeat(4,1fr);gap:0;background:#0a0608;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats.stats-hero::before{content:"";position:absolute;inset:0;background:url('img/drift-battle-red.jpg') center/cover;z-index:0}
.stats.stats-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(7,6,10,.62),rgba(7,6,10,.2) 45%,rgba(7,6,10,.72)),radial-gradient(130% 110% at 50% 50%,transparent 28%,rgba(7,6,10,.55))}
.stats.stats-hero .stat{position:relative;z-index:2;background:transparent;border-right:1px solid rgba(255,255,255,.09)}
.stats.stats-hero .stat:last-child{border-right:none}
.stats.stats-hero .stat-num{text-shadow:0 4px 26px rgba(0,0,0,.7),0 2px 8px rgba(0,0,0,.8)}
.stats.stats-hero .stat-label{color:#f3e7ea;text-shadow:0 2px 10px rgba(0,0,0,.85)}
@media(max-width:720px){.stats.stats-hero{grid-template-columns:repeat(2,1fr)}.stats.stats-hero .stat:nth-child(2){border-right:none}}

/* Proof section with drift-battle backdrop */
.reach.proof-hero{position:relative;overflow:hidden;background:#0a0608}
.reach.proof-hero::before{content:"";position:absolute;inset:0;background:url('img/proof-monster-red.jpg') center/cover;z-index:0;opacity:.85}
.reach.proof-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(7,6,10,.78),rgba(7,6,10,.42) 45%,rgba(7,6,10,.85)),radial-gradient(110% 90% at 72% 38%,transparent,rgba(7,6,10,.35))}
.reach.proof-hero .wrap{position:relative;z-index:2}

/* Brand case-study cards */
.brand-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:18px;margin-top:1.9rem}
.brand-card{background:linear-gradient(160deg,var(--panel-2),var(--ink-2));border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.25s}
.brand-card:hover{border-color:rgba(255,42,48,.55);transform:translateY(-4px);box-shadow:0 30px 70px -45px var(--red)}
.brand-shot{aspect-ratio:16/10;background-size:cover;background-position:center;border-bottom:1px solid var(--line)}
.brand-body{padding:22px 24px}
.brand-body h3{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;letter-spacing:.01em;font-size:clamp(20px,2.3vw,26px);margin:0 0 .2rem;color:#fff}
.brand-tag{margin:0 0 .8rem;color:var(--red-bright);font-size:13px;letter-spacing:.02em;text-transform:uppercase;font-weight:700}
.brand-body>p:last-child{margin:0;color:var(--text);opacity:.85;font-size:14.5px;line-height:1.55}

/* ---------- Manifesto: dark drift-battle backdrop ---------- */
.manifesto::before{content:"";position:absolute;inset:0;z-index:0;
  background:
    linear-gradient(90deg, var(--ink) 2%, rgba(8,7,8,.84) 42%, rgba(8,7,8,.5) 100%),
    linear-gradient(180deg, var(--ink), transparent 16%, transparent 80%, var(--ink)),
    url('img/drift-battle-red.jpg') center/cover no-repeat;
  pointer-events:none}
.manifesto>.wrap{position:relative;z-index:1}

/* ---------- Drift GP logo (Going global section) ---------- */
.driftgp-logo{display:block;width:min(440px,82%);height:auto;margin:0 0 1.3rem;
  filter:drop-shadow(0 6px 26px rgba(0,0,0,.55))}
@media(max-width:768px){.driftgp-logo{width:min(340px,88%);margin-bottom:1rem}}

/* ---------- Monster page hero: video backdrop + green grade ---------- */
.monster-hero::before{display:none}            /* drop the inherited red drift backdrop */
.monster-hero{overflow:hidden}
.manifesto-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.monster-veil{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(90deg, rgba(3,8,3,.93) 0%, rgba(5,14,5,.80) 46%, rgba(6,18,6,.48) 100%),
  radial-gradient(85% 80% at 84% 48%, rgba(99,190,20,.32), transparent 64%),
  linear-gradient(180deg, var(--ink), rgba(7,6,10,0) 16%, rgba(7,6,10,0) 82%, var(--ink))}
.monster-hero>.wrap{position:relative;z-index:2}

/* ---------- As Broadcast On (broadcaster logo strip) ---------- */
.broadcast-strip{margin:2rem 0 0;padding:20px 26px;border:1px solid var(--line);border-radius:16px;
  background:rgba(255,255,255,.03);display:flex;align-items:center;gap:30px;flex-wrap:wrap}
.bs-label{font-family:var(--ff-alt);font-weight:800;text-transform:uppercase;letter-spacing:.12em;
  font-size:12px;color:var(--red-bright);white-space:nowrap}
.bs-logos{display:flex;align-items:center;gap:40px;flex-wrap:wrap;flex:1}
.bs-logos img{height:30px;width:auto;opacity:.9;filter:drop-shadow(0 2px 8px rgba(0,0,0,.45))}
.bs-logos img[alt="Rebel Broadcast"]{height:38px}
@media(max-width:600px){.bs-logos{gap:26px}.bs-logos img{height:24px}.bs-logos img[alt="Rebel Broadcast"]{height:30px}}

/* ---------- Driver social icons ---------- */
.driver-social{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.driver-social a{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:8px;color:#fff;background:rgba(255,255,255,.05);
  transition:transform .18s,background .18s,border-color .18s}
.driver-social a:hover{background:var(--red);border-color:var(--red);transform:translateY(-2px)}
.dsi{width:15px;height:15px;fill:currentColor;display:block}

/* ---------- Economics "Bigger Picture" backdrop (overrides shared manifesto bg) ---------- */
.manifesto.econ-hero::before{background:
  linear-gradient(90deg, var(--ink) 2%, rgba(8,7,8,.82) 42%, rgba(8,7,8,.46) 100%),
  linear-gradient(180deg, var(--ink), transparent 16%, transparent 80%, var(--ink)),
  url('img/economics-bigpic.jpg') center/cover no-repeat}

/* ---------- Book a Catch-Up form backdrop (packages #book) ---------- */
.signup.book{overflow:hidden}
.signup.book::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:
  linear-gradient(180deg, var(--ink), transparent 20%, transparent 80%, var(--ink)),
  radial-gradient(120% 95% at 50% 42%, rgba(8,7,8,.5), rgba(8,7,8,.88) 78%),
  url('img/book-bg.jpg') center/cover no-repeat}
.signup.book .wrap{position:relative;z-index:1}

/* ---------- 2027 Showreel: hero ambient loop + click-to-play reel ---------- */
.hero-reel-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.reel-video{display:block;width:100%;max-width:1080px;margin:0 auto;border-radius:16px;
  border:1px solid var(--line);aspect-ratio:16/9;background:#000;
  box-shadow:0 40px 90px -45px rgba(255,42,48,.55)}

/* ---------- YouTube Content Program ---------- */
.shows-feat{display:grid;grid-template-columns:1.1fr .9fr;gap:0;margin-top:2.4rem;border:1px solid rgba(255,42,48,.5);
  border-radius:18px;overflow:hidden;background:linear-gradient(180deg,var(--panel),var(--ink-2));box-shadow:0 0 0 1px rgba(255,42,48,.2)}
.sf-body{padding:34px 36px}
.sf-body h3{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;letter-spacing:.01em;
  font-size:clamp(28px,3.6vw,40px);color:#fff;margin:.2rem 0 .7rem;line-height:.98}
.sf-body p{color:var(--text);opacity:.9;font-size:15.5px;line-height:1.6;margin:0;max-width:52ch}
.sf-img{background-size:cover;background-position:center;min-height:300px}
.shows-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:16px}
.show-card{background:linear-gradient(180deg,var(--panel),var(--ink-2));border:1px solid var(--line);
  border-radius:16px;padding:24px 24px 20px;display:flex;flex-direction:column}
.show-tag{font-family:var(--ff-alt);font-weight:800;text-transform:uppercase;letter-spacing:.1em;
  font-size:10.5px;color:var(--red-bright);margin-bottom:12px}
.show-card h3{font-family:var(--ff-head);font-weight:400;text-transform:uppercase;letter-spacing:.01em;
  font-size:clamp(19px,2.2vw,24px);color:#fff;margin:0 0 .5rem;line-height:1}
.show-card p{color:var(--text);opacity:.85;font-size:14px;line-height:1.55;margin:0 0 auto}
.show-angle{margin-top:16px;padding-top:12px;border-top:1px solid var(--line);font-family:var(--ff-alt);
  font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:10.5px;color:var(--dim)}
@media(max-width:980px){.shows-grid{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.shows-feat{grid-template-columns:1fr}.sf-img{min-height:200px;order:-1}}
@media(max-width:520px){.shows-grid{grid-template-columns:1fr}}

/* ---------- Footer social icons ---------- */
.foot-social{display:flex;gap:10px;align-items:center}
.foot-social a{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:8px;color:var(--text);background:rgba(255,255,255,.04);
  transition:transform .18s,background .18s,border-color .18s,color .18s}
.foot-social a:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-2px)}
.foot-social svg{width:16px;height:16px;fill:currentColor;display:block}
