/* =====================================================================
   SEAMAN'S NECK AUTO CARE — "The Garage of the Future"
   style.css · cinematic scene-based experience
   ===================================================================== */

:root{
  --bg:#050507; --bg-2:#0a0b0f; --panel:#101218;
  --line:rgba(255,255,255,.08); --line-soft:rgba(255,255,255,.05);
  --ink:#f4f5f7; --muted:#9aa0ad; --faint:#5a606e;
  --red:#ff2a2a; --red-deep:#c20512; --red-glow:rgba(255,42,42,.55); --blue:#38d0ff;
  --glass:rgba(255,255,255,.045); --glass-brd:rgba(255,255,255,.10);
  --font-display:"Saira Condensed",sans-serif; --font-hud:"Chakra Petch",monospace; --font-body:"Manrope",sans-serif;
  --ease:cubic-bezier(.22,1,.36,1); --ease-io:cubic-bezier(.65,.05,.36,1); --maxw:1320px;
}
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{ background:var(--bg); color:var(--ink); font-family:var(--font-body); line-height:1.6; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
body.is-loading{ overflow:hidden; height:100vh; }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
.accent{ color:var(--red); }
::selection{ background:var(--red); color:#fff; }

body::after{ content:""; position:fixed; inset:0; z-index:9998; pointer-events:none; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* shared */
.section-tag{ font-family:var(--font-hud); font-size:.74rem; letter-spacing:.32em; color:var(--red); display:inline-block; margin-bottom:14px; }
.section-title{ font-family:var(--font-display); font-weight:800; font-size:clamp(2.3rem,6vw,5rem); line-height:.96; text-transform:uppercase; }
.section-head{ max-width:var(--maxw); margin:0 auto clamp(36px,5vw,70px); }
.btn{ position:relative; display:inline-flex; align-items:center; justify-content:center; gap:.5em; padding:.95em 1.9em; border-radius:2px;
  font-family:var(--font-hud); font-weight:600; font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; white-space:nowrap;
  transition:transform .4s var(--ease),background .35s,color .35s,box-shadow .35s; will-change:transform; overflow:hidden; }
.btn--red{ background:var(--red); color:#fff; } .btn--red:hover{ box-shadow:0 10px 40px -8px var(--red-glow); }
.btn--ghost{ border:1px solid var(--glass-brd); color:var(--ink); background:rgba(255,255,255,.02); } .btn--ghost:hover{ border-color:var(--red); }
.btn::before{ content:""; position:absolute; inset:0; background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.25),transparent 70%); transform:translateX(-130%); transition:transform .7s var(--ease); }
.btn:hover::before{ transform:translateX(130%); }
.btn:disabled{ opacity:.35; pointer-events:none; }
.glass{ background:var(--glass); border:1px solid var(--glass-brd); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-radius:14px; }

/* split-text spans */
.char,.word{ display:inline-block; will-change:transform; }
.mask{ display:inline-block; overflow:hidden; vertical-align:top; }

/* ---------- PRELOADER ---------- */
.preloader{ position:fixed; inset:0; z-index:10000; background:var(--bg); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.preloader__inner{ text-align:center; z-index:2; }
.preloader__badge{ font-family:var(--font-hud); font-size:.66rem; letter-spacing:.34em; color:var(--faint); margin-bottom:22px; }
.preloader__bar{ width:min(320px,70vw); height:2px; background:rgba(255,255,255,.12); position:relative; overflow:hidden; }
.preloader__fill{ position:absolute; inset:0 100% 0 0; background:var(--red); box-shadow:0 0 18px var(--red-glow); }
.preloader__meta{ display:flex; justify-content:space-between; width:min(320px,70vw); margin:14px auto 0; font-family:var(--font-hud); font-size:.66rem; letter-spacing:.2em; color:var(--muted); }
.preloader__smoke{ position:absolute; inset:0; background:radial-gradient(60% 60% at 50% 90%,rgba(255,42,42,.10),transparent 70%); }

/* ---------- CURSOR ---------- */
.cursor,.cursor-dot{ position:fixed; top:0; left:0; z-index:9999; pointer-events:none; border-radius:50%; transform:translate(-50%,-50%); }
.cursor{ width:38px; height:38px; border:1px solid var(--red); transition:width .3s,height .3s,background .3s,border-color .3s; }
.cursor.is-active{ width:64px; height:64px; background:var(--red-glow); border-color:transparent; }
.cursor-dot{ width:5px; height:5px; background:var(--red); }
.ambient-light{ position:fixed; width:600px; height:600px; border-radius:50%; z-index:1; pointer-events:none;
  background:radial-gradient(circle,rgba(255,42,42,.12),transparent 60%); transform:translate(-50%,-50%); filter:blur(30px); opacity:0; transition:opacity .6s; }

/* ---------- scroll rail ---------- */
.scroll-rail{ position:fixed; top:0; left:0; width:3px; height:100%; z-index:950; background:rgba(255,255,255,.05); }
.scroll-rail span{ display:block; width:100%; height:0; background:linear-gradient(var(--red),var(--red-deep)); box-shadow:0 0 12px var(--red-glow); }

/* ---------- NAV ---------- */
.nav{ position:fixed; top:0; left:0; width:100%; z-index:900; display:flex; align-items:center; justify-content:space-between;
  padding:18px clamp(20px,5vw,60px); transition:background .4s,padding .4s,border-color .4s; border-bottom:1px solid transparent; }
.nav.is-scrolled{ background:rgba(5,5,7,.78); backdrop-filter:blur(16px); border-color:var(--line); padding-top:12px; padding-bottom:12px; }
.nav__brand{ display:flex; align-items:center; gap:12px; }
.nav__mark{ display:grid; place-items:center; width:42px; height:42px; flex:none; border:1px solid var(--red); color:var(--red);
  font-family:var(--font-display); font-weight:800; font-size:1.05rem; box-shadow:inset 0 0 18px rgba(255,42,42,.25); }
.nav__name{ font-family:var(--font-display); font-weight:700; letter-spacing:.14em; font-size:.92rem; line-height:1; }
.nav__name small{ display:block; color:var(--muted); font-size:.62rem; letter-spacing:.3em; margin-top:3px; }
.nav__links{ display:flex; gap:34px; }
.nav__links a{ font-family:var(--font-hud); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); position:relative; padding:4px 0; transition:color .3s; }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--red); transition:width .35s var(--ease); }
.nav__links a:hover{ color:var(--ink); } .nav__links a:hover::after{ width:100%; }
.nav__burger{ display:none; flex-direction:column; gap:6px; padding:8px; }
.nav__burger span{ width:26px; height:2px; background:var(--ink); transition:.35s var(--ease); }
.nav.is-open .nav__burger span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav.is-open .nav__burger span:nth-child(2){ transform:translateY(0) rotate(-45deg); }

/* =====================================================================
   1 · CINEMATIC INTRO
   ===================================================================== */
.intro{ height:300vh; position:relative; }            /* scroll length for the pin */
.intro__pin{ position:sticky; top:0; height:100vh; overflow:hidden; display:grid; place-items:center; background:#020203; }
.intro__canvas{ position:absolute; inset:0; width:100%; height:100%; }
.intro__center{ position:relative; z-index:3; text-align:center; padding:20px; will-change:transform,filter; }
.intro__kicker{ font-family:var(--font-hud); font-size:.8rem; letter-spacing:.4em; text-transform:uppercase; color:var(--red); margin-bottom:24px; }
.intro__title{ font-family:var(--font-display); font-weight:900; text-transform:uppercase; line-height:.86; letter-spacing:-.01em; font-size:clamp(3rem,13vw,11rem); }
.intro__title .ln{ display:block; overflow:hidden; }
.intro__title .accent{ color:var(--red); text-shadow:0 0 60px var(--red-glow); }
.streak{ position:absolute; top:50%; height:2px; width:60%; filter:blur(2px); opacity:0; z-index:2;
  background:linear-gradient(90deg,transparent,var(--red),#fff,var(--red),transparent); }
.streak--1{ left:-60%; transform:translateY(-90px); }
.streak--2{ right:-60%; transform:translateY(120px); }
.intro__scrollcue{ position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:var(--font-hud); font-size:.62rem; letter-spacing:.3em; color:var(--muted); }
.intro__scrollcue i{ width:1px; height:40px; background:linear-gradient(var(--red),transparent); animation:pulse 1.8s var(--ease) infinite; }
@keyframes pulse{ 0%,100%{ transform:scaleY(.4); opacity:.3; } 50%{ transform:scaleY(1); opacity:1; } }

/* =====================================================================
   2 · HERO
   ===================================================================== */
.hero{ position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden;
  background:radial-gradient(80% 60% at 50% 40%,#0c0d12,#050507); }
.hero__vignette{ position:absolute; inset:0; z-index:2; pointer-events:none; background:radial-gradient(120% 80% at 50% 35%,transparent 40%,rgba(0,0,0,.75)); }
.hud{ position:absolute; inset:0; z-index:5; pointer-events:none; font-family:var(--font-hud); font-size:.66rem; letter-spacing:.24em; color:var(--muted); }
.hud__c{ position:absolute; padding:26px clamp(20px,5vw,60px); opacity:.7; } .hud__c b{ color:var(--red); }
.hud__c--tl{ top:64px; left:0; } .hud__c--tr{ top:64px; right:0; } .hud__c--bl{ bottom:0; left:0; } .hud__c--br{ bottom:0; right:0; }
.hero__content{ position:relative; z-index:6; max-width:var(--maxw); width:100%; margin:0 auto; padding:0 clamp(20px,5vw,60px); }
.hero__eyebrow{ font-family:var(--font-hud); letter-spacing:.34em; text-transform:uppercase; font-size:.78rem; color:var(--red); margin-bottom:18px; }
.hero__title{ font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(3rem,11vw,8.5rem); line-height:.86; }
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line.accent span{ color:var(--red); text-shadow:0 0 40px var(--red-glow); }
.hero__sub{ margin:26px 0 34px; max-width:440px; color:var(--muted); font-size:1.05rem; }
.hero__cta{ display:flex; gap:16px; flex-wrap:wrap; }
[data-rise]{ opacity:0; transform:translateY(40px); }
.hero__stage{ position:absolute; z-index:4; right:-2%; bottom:8%; width:min(60vw,820px); }
.car{ position:relative; transition:transform .6s var(--ease); }
.car__img{ width:100%; filter:saturate(1.05) contrast(1.05) drop-shadow(0 40px 60px rgba(0,0,0,.7)); border-radius:6px; }
.car__glow{ position:absolute; inset:-10% -6% -20% -6%; z-index:-1; border-radius:50%; background:radial-gradient(closest-side,rgba(255,42,42,0),transparent); filter:blur(40px); transition:background .5s; }
.car.is-lit .car__glow{ background:radial-gradient(closest-side,rgba(255,42,42,.45),transparent); }
.car__headlights{ position:absolute; inset:0; border-radius:6px; opacity:0; transition:opacity .4s; background:radial-gradient(40% 12% at 20% 62%,rgba(255,250,220,.8),transparent 70%); mix-blend-mode:screen; }
.car.is-lit .car__headlights{ opacity:.9; }
.car__floor{ position:absolute; left:-10%; right:-10%; bottom:-4%; height:40px; z-index:-2; background:radial-gradient(closest-side,rgba(0,0,0,.85),transparent); filter:blur(8px); }

/* =====================================================================
   3 · PINNED 3D TURNTABLE
   ===================================================================== */
.turntable{ height:420vh; position:relative; }
.tt__pin{ position:sticky; top:0; height:100vh; overflow:hidden; display:grid; place-items:center; background:#030304; perspective:1400px; }
.tt__bg{ position:absolute; inset:0; background:radial-gradient(60% 50% at 50% 60%,rgba(255,42,42,.10),transparent 70%); }
.tt__words{ position:absolute; inset:0; display:grid; place-items:center; z-index:1; }
.tt__word{ position:absolute; font-family:var(--font-display); font-weight:900; text-transform:uppercase;
  font-size:clamp(3rem,16vw,15rem); color:rgba(255,255,255,.04); letter-spacing:.02em; opacity:0; transform:scale(1.1); transition:opacity .5s,transform .5s; }
.tt__word.is-on{ opacity:1; transform:scale(1); }
.tt__stage{ position:relative; z-index:2; transform-style:preserve-3d; }
.tt__turn{ position:relative; width:min(70vw,760px); aspect-ratio:16/10; transform-style:preserve-3d; will-change:transform; }
.tt__car{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:10px; opacity:0; transition:opacity .45s var(--ease);
  filter:saturate(1.05) contrast(1.05) drop-shadow(0 50px 70px rgba(0,0,0,.8)); backface-visibility:hidden; }
.tt__car.is-on{ opacity:1; }
.tt__floor{ position:absolute; left:50%; bottom:-40px; transform:translateX(-50%); width:80%; height:60px; background:radial-gradient(closest-side,rgba(255,42,42,.25),transparent); filter:blur(20px); }
.tt__angle{ position:absolute; top:18%; left:50%; transform:translateX(-50%); z-index:3; font-family:var(--font-hud); letter-spacing:.4em; font-size:.8rem; color:var(--red); }
.tt__progress{ position:absolute; bottom:8%; left:50%; transform:translateX(-50%); width:min(40vw,320px); height:2px; background:rgba(255,255,255,.1); z-index:3; }
.tt__progress span{ display:block; height:100%; width:0; background:var(--red); box-shadow:0 0 12px var(--red-glow); }

/* =====================================================================
   4 · SCROLL STORYTELLING
   ===================================================================== */
.story{ height:500vh; position:relative; }
.story__pin{ position:sticky; top:0; height:100vh; overflow:hidden; }
.scene{ position:absolute; inset:0; opacity:0; }
.scene::before{ content:""; position:absolute; inset:0; background-image:var(--img); background-size:cover; background-position:center;
  transform:scale(1.15); will-change:transform,filter; filter:saturate(.6) brightness(.5); }
.scene.is-on{ opacity:1; }
.scene__overlay{ position:absolute; inset:0; background:linear-gradient(90deg,rgba(3,3,5,.85),transparent 60%),linear-gradient(0deg,rgba(3,3,5,.9),transparent 50%); }
.scene__content{ position:absolute; left:clamp(20px,6vw,90px); bottom:18vh; z-index:2; max-width:760px; }
.scene__no{ font-family:var(--font-hud); color:var(--red); letter-spacing:.4em; font-size:.9rem; }
.scene__title{ font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(2.6rem,9vw,8rem); line-height:.9; margin:10px 0 16px; }
.scene__desc{ color:var(--muted); font-size:1.1rem; max-width:520px; }
.story__dots{ position:absolute; right:40px; top:50%; transform:translateY(-50%); z-index:5; display:flex; flex-direction:column; gap:14px; }
.story__dots button{ width:9px; height:9px; border-radius:50%; background:rgba(255,255,255,.2); transition:.3s; }
.story__dots button.is-on{ background:var(--red); height:26px; border-radius:5px; }

/* =====================================================================
   5 · PARALLAX SHOWROOM
   ===================================================================== */
.showroom{ position:relative; min-height:100vh; overflow:hidden; display:grid; place-items:center;
  background:radial-gradient(70% 60% at 50% 30%,#0e0f15,#040405); }
.show__lights{ position:absolute; inset:-10%; background:
  radial-gradient(30% 50% at 20% 30%,rgba(255,42,42,.18),transparent 60%),
  radial-gradient(30% 50% at 80% 40%,rgba(56,208,255,.12),transparent 60%); will-change:transform; }
.show__particles{ position:absolute; inset:0; width:100%; height:100%; z-index:1; }
.show__content{ position:relative; z-index:3; text-align:center; }
.show__title{ font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(2.5rem,8vw,7rem); line-height:.9; }
.show__car{ position:absolute; bottom:0; width:min(70vw,900px); z-index:2; will-change:transform; }
.show__car img{ width:100%; filter:drop-shadow(0 40px 80px rgba(0,0,0,.8)); }

/* =====================================================================
   6 · PERFORMANCE MODE
   ===================================================================== */
.perf{ height:200vh; position:relative; }
.perf__pin{ position:sticky; top:0; height:100vh; overflow:hidden; display:grid; place-items:center; background:#050507; }
.perf__bg{ position:absolute; inset:0; opacity:0; transition:opacity .6s;
  background:radial-gradient(70% 60% at 50% 50%,rgba(255,42,42,.22),transparent 70%),repeating-linear-gradient(115deg,rgba(255,42,42,.04) 0 10px,transparent 10px 30px); }
.perf.is-sport .perf__bg{ opacity:1; }
.perf__hud{ position:absolute; top:16vh; text-align:center; z-index:3; opacity:0; transform:translateY(30px); transition:.6s var(--ease); }
.perf.is-sport .perf__hud{ opacity:1; transform:none; }
.perf__title{ font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(2.2rem,7vw,6rem); line-height:.9; }
.perf__cluster{ position:relative; z-index:2; display:grid; place-items:center; }
.speedo{ width:min(70vw,420px); }
.speedo__track{ fill:none; stroke:rgba(255,255,255,.08); stroke-width:6; stroke-dasharray:660 880; stroke-dashoffset:0; transform:rotate(135deg); transform-origin:center; }
.speedo__fill{ fill:none; stroke:var(--red); stroke-width:6; stroke-linecap:round; stroke-dasharray:660 880; stroke-dashoffset:660; transform:rotate(135deg); transform-origin:center; filter:drop-shadow(0 0 6px var(--red-glow)); }
.speedo__needle{ stroke:var(--red); stroke-width:3; stroke-linecap:round; transform-origin:160px 160px; transform:rotate(-130deg); filter:drop-shadow(0 0 6px var(--red-glow)); }
.speedo__hub{ fill:var(--red); }
.speedo__read{ position:absolute; text-align:center; font-family:var(--font-hud); }
.speedo__read b{ font-size:3.4rem; display:block; line-height:1; } .speedo__read span{ color:var(--muted); letter-spacing:.3em; font-size:.8rem; }
.perf__stats{ position:absolute; bottom:14vh; z-index:3; display:flex; gap:clamp(24px,6vw,80px); font-family:var(--font-hud); text-align:center; }
.pstat b{ font-size:clamp(1.8rem,4vw,3rem); color:var(--red); display:block; } .pstat span{ color:var(--muted); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; }

/* =====================================================================
   HORIZONTAL SCROLL shared
   ===================================================================== */
.hscroll{ position:relative; height:100vh; overflow:hidden; }
.hscroll__track{ position:absolute; top:0; left:0; height:100%; display:flex; will-change:transform; }

/* 7 · SERVICES scenes */
.services{ position:relative; }
.svc{ position:relative; width:100vw; height:100vh; flex:none; display:flex; flex-direction:column; justify-content:center; padding:0 clamp(24px,8vw,120px); overflow:hidden; }
.svc::before{ content:""; position:absolute; inset:0; background-image:var(--img); background-size:cover; background-position:center; filter:saturate(.7) brightness(.4); transform:scale(1.1); }
.svc::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(3,3,5,.9),transparent 70%); }
.svc__no{ position:relative; z-index:2; font-family:var(--font-hud); color:var(--red); letter-spacing:.4em; }
.svc__title{ position:relative; z-index:2; font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(3rem,10vw,9rem); line-height:.9; margin:8px 0 14px; }
.svc__desc{ position:relative; z-index:2; color:var(--muted); font-size:1.2rem; max-width:480px; }

/* 8 · TIMELINE */
.timeline{ background:var(--bg-2); }
.tl__head{ max-width:var(--maxw); margin:0 auto; padding:clamp(60px,8vw,120px) clamp(20px,5vw,60px) 0; }
.tl__track{ align-items:center; padding:0 12vw; gap:14vw; position:relative; }
.tl__rail{ position:absolute; left:0; top:50%; height:2px; width:100%; background:rgba(255,255,255,.1); }
.tl__progress{ position:absolute; left:0; top:0; height:100%; width:0; background:var(--red); box-shadow:0 0 14px var(--red-glow); }
.tl__car{ position:absolute; top:50%; left:0; transform:translate(-50%,-50%); font-size:2.4rem; z-index:3; filter:drop-shadow(0 0 14px var(--red-glow)); }
.tl__stop{ position:relative; flex:none; text-align:center; }
.tl__stop::before{ content:""; position:absolute; left:50%; top:-46px; transform:translateX(-50%); width:14px; height:14px; border-radius:50%; background:var(--bg); border:2px solid var(--red); box-shadow:0 0 14px var(--red-glow); }
.tl__stop b{ font-family:var(--font-display); text-transform:uppercase; font-size:1.8rem; display:block; }
.tl__stop span{ color:var(--muted); font-size:.86rem; }

/* =====================================================================
   9 · VIDEO SHOWCASE
   ===================================================================== */
.video{ position:relative; height:100vh; overflow:hidden; display:grid; place-items:center; }
.video__bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.video__grade{ position:absolute; inset:0; background:linear-gradient(0deg,rgba(3,3,5,.9),rgba(3,3,5,.4)),radial-gradient(60% 60% at 50% 50%,transparent,rgba(3,3,5,.7)); }
.video__content{ position:relative; z-index:2; text-align:center; padding:20px; }
.video__title{ font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(2.6rem,9vw,8rem); line-height:.9; }
.video__desc{ color:var(--muted); font-size:1.1rem; margin-top:14px; }

/* =====================================================================
   10 · BEFORE / AFTER REVEAL
   ===================================================================== */
.reveal{ height:240vh; position:relative; }
.rev__pin{ position:sticky; top:0; height:100vh; overflow:hidden; display:grid; place-items:center; background:#000; }
.rev__layer{ position:absolute; inset:0; } .rev__layer img{ width:100%; height:100%; object-fit:cover; }
.rev__before img{ filter:saturate(.4) brightness(.55) contrast(.9); }
.rev__after{ clip-path:inset(0 100% 0 0); } .rev__after img{ filter:saturate(1.15) brightness(1.05) contrast(1.1); }
.rev__line{ position:absolute; top:0; bottom:0; left:0; width:3px; background:var(--red); box-shadow:0 0 20px var(--red-glow); z-index:3; }
.rev__tag{ position:absolute; top:24px; left:24px; z-index:4; font-family:var(--font-hud); font-size:.7rem; letter-spacing:.22em; padding:6px 10px; background:rgba(0,0,0,.6); border:1px solid var(--line); }
.rev__tag--r{ left:auto; right:24px; }
.rev__title{ position:absolute; z-index:5; font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(2.5rem,8vw,7rem); mix-blend-mode:difference; }

/* =====================================================================
   11 · PREMIUM CTA
   ===================================================================== */
.cta{ position:relative; min-height:100vh; display:grid; place-items:center; text-align:center; overflow:hidden; background:#050507; }
.cta__glow{ position:absolute; inset:0; background:radial-gradient(50% 50% at 50% 60%,rgba(255,42,42,.25),transparent 70%); }
.cta__car{ position:absolute; bottom:0; width:min(80vw,1000px); opacity:.5; filter:drop-shadow(0 40px 80px #000); z-index:1; }
.cta__title{ position:relative; z-index:2; font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(2.6rem,9vw,8rem); line-height:.88; }
.cta__title .ln{ display:block; overflow:hidden; } .cta__title .accent{ color:var(--red); text-shadow:0 0 50px var(--red-glow); }
.cta__btn{ position:relative; z-index:2; margin-top:34px; padding:1.2em 2.6em; font-size:.9rem; }

/* =====================================================================
   BOOKING / SELL / FAQ / FOOTER  (functional)
   ===================================================================== */
.booking,.sell,.faq{ padding:clamp(70px,9vw,150px) clamp(20px,5vw,80px); }
.booking__panel{ max-width:760px; margin:0 auto; padding:clamp(26px,4vw,46px); overflow:hidden; }
.booking__progress{ height:3px; background:rgba(255,255,255,.08); border-radius:3px; margin-bottom:34px; }
.booking__progress span{ display:block; height:100%; width:16.6%; background:var(--red); box-shadow:0 0 12px var(--red-glow); border-radius:3px; transition:width .5s var(--ease); }
.booking__steps{ position:relative; min-height:230px; }
.bstep{ position:absolute; inset:0; opacity:0; transform:translateX(40px); pointer-events:none; transition:.5s var(--ease); }
.bstep.is-active{ opacity:1; transform:none; pointer-events:auto; position:relative; }
.bstep__title{ font-family:var(--font-hud); letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-size:.86rem; margin-bottom:22px; }
.choices{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; } .choices--3{ grid-template-columns:repeat(3,1fr); }
.choice{ padding:20px 12px; border:1px solid var(--line); border-radius:10px; text-align:center; font-family:var(--font-hud); font-size:.82rem; display:flex; flex-direction:column; gap:8px; align-items:center; transition:.3s var(--ease); }
.choice:hover{ border-color:rgba(255,42,42,.5); transform:translateY(-3px); }
.choice.is-selected{ border-color:var(--red); background:rgba(255,42,42,.08); box-shadow:0 0 22px -6px var(--red-glow); }
.field{ width:100%; padding:15px 16px; background:rgba(255,255,255,.03); border:1px solid var(--line); border-radius:8px; color:var(--ink); font-family:var(--font-body); margin-bottom:14px; transition:border-color .3s; }
.field:focus{ outline:none; border-color:var(--red); } .field::placeholder{ color:var(--faint); } .field--area{ min-height:90px; resize:vertical; }
.summary{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.summary li{ display:flex; justify-content:space-between; padding:12px 16px; border:1px solid var(--line); border-radius:8px; font-family:var(--font-hud); font-size:.86rem; } .summary li b{ color:var(--red); }
.booking__nav{ display:flex; align-items:center; justify-content:space-between; margin-top:30px; gap:16px; }
.booking__count{ font-family:var(--font-hud); color:var(--muted); font-size:.84rem; } .booking__count b{ color:var(--ink); }
.booking__err{ color:var(--red); font-family:var(--font-hud); font-size:.8rem; margin-top:14px; min-height:1em; }

.sell__panel{ max-width:var(--maxw); margin:0 auto; padding:clamp(26px,4vw,46px); display:grid; grid-template-columns:1fr 1fr; gap:34px; }
.sell__fields{ display:grid; grid-template-columns:1fr 1fr; gap:0 14px; } .sell__fields #sNotes{ grid-column:1/-1; }
.dropzone{ border:1.5px dashed var(--line); border-radius:14px; padding:38px 20px; text-align:center; transition:.3s var(--ease); cursor:pointer; }
.dropzone:hover,.dropzone.is-drag{ border-color:var(--red); background:rgba(255,42,42,.04); }
.dropzone__icon{ font-size:2rem; color:var(--red); display:block; margin-bottom:12px; }
.dropzone p{ color:var(--muted); font-size:.9rem; } .dropzone small{ color:var(--faint); }
.previews{ display:flex; flex-wrap:wrap; gap:10px; margin:16px 0; }
.previews img{ width:72px; height:72px; object-fit:cover; border-radius:8px; border:1px solid var(--line); }
.sell__submit{ width:100%; margin-top:6px; }

.accordion{ max-width:840px; margin:0 auto; }
.acc{ border-bottom:1px solid var(--line); }
.acc__q{ width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center; padding:26px 0; font-family:var(--font-display); font-weight:600; text-transform:uppercase; font-size:clamp(1.2rem,2.4vw,1.7rem); transition:color .3s; }
.acc__q:hover{ color:var(--red); }
.acc__q i{ position:relative; width:18px; height:18px; flex:none; }
.acc__q i::before,.acc__q i::after{ content:""; position:absolute; background:var(--red); transition:.35s var(--ease); }
.acc__q i::before{ top:50%; left:0; right:0; height:2px; transform:translateY(-50%); }
.acc__q i::after{ left:50%; top:0; bottom:0; width:2px; transform:translateX(-50%); }
.acc.is-open .acc__q i::after{ transform:translateX(-50%) scaleY(0); }
.acc__a{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease); }
.acc__a p{ padding:0 0 26px; color:var(--muted); max-width:680px; }

.footer{ background:#030304; border-top:1px solid var(--line); padding:clamp(50px,6vw,90px) clamp(20px,5vw,60px) 30px; }
.footer__top{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.6fr 1fr 1fr 1.4fr; gap:40px; }
.footer__brand h3{ font-family:var(--font-display); text-transform:uppercase; font-size:1.5rem; line-height:1; margin:16px 0 10px; }
.footer__owner{ font-family:var(--font-hud); color:var(--red); letter-spacing:.06em; font-size:.86rem; }
.footer__tag{ color:var(--muted); font-size:.9rem; margin-top:8px; max-width:300px; }
.footer__social{ display:flex; gap:10px; margin-top:20px; }
.footer__social a{ width:40px; height:40px; display:grid; place-items:center; border:1px solid var(--line); border-radius:50%; font-family:var(--font-hud); font-size:.72rem; transition:.3s; }
.footer__social a:hover{ border-color:var(--red); color:var(--red); }
.footer__col h4{ font-family:var(--font-hud); letter-spacing:.16em; text-transform:uppercase; font-size:.82rem; margin-bottom:18px; }
.footer__col a,.footer__col p{ display:block; color:var(--muted); font-size:.92rem; margin-bottom:10px; transition:color .3s; }
.footer__col a:hover{ color:var(--red); }
.footer__form{ display:flex; gap:8px; margin-bottom:18px; } .footer__form .field{ margin:0; }
.footer__map{ height:90px; border:1px dashed var(--line); border-radius:10px; display:grid; place-items:center; font-family:var(--font-hud); font-size:.7rem; letter-spacing:.16em; color:var(--faint); text-align:center; }
.footer__bottom{ max-width:var(--maxw); margin:40px auto 0; padding-top:24px; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-family:var(--font-hud); font-size:.72rem; letter-spacing:.1em; color:var(--faint); }
.wa-float{ position:fixed; right:24px; bottom:24px; z-index:880; background:var(--red); color:#fff; padding:14px 20px; border-radius:40px; font-family:var(--font-hud); font-size:.8rem; letter-spacing:.1em; box-shadow:0 10px 30px -6px var(--red-glow); transition:transform .4s var(--ease); }
.wa-float:hover{ transform:translateY(-4px); }

[data-reveal]{ opacity:0; transform:translateY(48px); transition:opacity .8s var(--ease),transform .8s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }

/* =====================================================================
   RESPONSIVE  —  collapse pins into normal stacked scenes
   ===================================================================== */
@media (max-width:1080px){
  .footer__top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .nav__links{ position:fixed; inset:0 0 0 auto; width:78%; max-width:340px; flex-direction:column; justify-content:center; gap:26px; padding:40px; background:rgba(8,8,11,.97); backdrop-filter:blur(20px); transform:translateX(100%); transition:transform .5s var(--ease); border-left:1px solid var(--line); }
  .nav.is-open .nav__links{ transform:none; } .nav__links a{ font-size:1.1rem; }
  .nav__burger{ display:flex; z-index:10; } .nav__cta{ display:none; }
  .cursor,.cursor-dot,.ambient-light,.scroll-rail{ display:none; }

  /* kill pins: each tall section becomes one screen */
  .intro,.turntable,.story,.perf,.reveal{ height:auto !important; }
  .intro__pin,.tt__pin,.story__pin,.perf__pin,.rev__pin{ position:relative !important; height:100vh; }

  /* turntable -> show side image only */
  .tt__turn{ width:88vw; } .tt__car--side{ opacity:1 !important; } .tt__car{ opacity:0; }
  .tt__car--side{ position:relative; }

  /* storytelling -> stacked full-screen scenes */
  .story__pin{ height:auto; } .scene{ position:relative; height:100vh; opacity:1 !important; }
  .scene::before{ transform:none; } .story__dots{ display:none; }

  /* performance -> static sport view */
  .perf.is-sport .perf__bg,.perf__bg{ opacity:1; } .perf__hud{ opacity:1; transform:none; position:relative; top:auto; margin-bottom:30px; }
  .perf__pin{ display:flex; flex-direction:column; justify-content:center; gap:20px; } .perf__stats{ position:relative; bottom:auto; flex-wrap:wrap; justify-content:center; }

  /* horizontal -> vertical stacks */
  .hscroll{ height:auto; } .hscroll__track{ position:relative; flex-direction:column; height:auto; transform:none !important; }
  .svc{ height:80vh; } .tl__track{ flex-direction:column; padding:40px 24px; gap:40px; }
  .tl__rail{ left:30px; top:0; bottom:0; width:2px; height:100%; } .tl__progress{ width:100%; height:0; }
  .tl__car{ display:none; } .tl__stop{ text-align:left; padding-left:50px; } .tl__stop::before{ left:24px; top:50%; }

  .booking,.sell{ padding:70px 20px; } .sell__panel{ grid-template-columns:1fr; } .sell__fields{ grid-template-columns:1fr; }
  .choices,.choices--3{ grid-template-columns:1fr 1fr; }
  .footer__top{ grid-template-columns:1fr; } .footer__bottom{ flex-direction:column; }
  .hero__stage{ position:relative; right:auto; bottom:auto; width:118%; left:-9%; margin-top:30px; }
  .hero{ padding-top:120px; } .hud__c--tr,.hud__c--br{ display:none; }
}
@media (prefers-reduced-motion:reduce){
  .intro,.turntable,.story,.perf,.reveal{ height:auto !important; }
  .intro__pin,.tt__pin,.story__pin,.perf__pin,.rev__pin{ position:relative !important; }
  .scene,.tt__car--side,.tt__word.is-on{ opacity:1 !important; }
  *{ animation-duration:.001ms !important; transition-duration:.01ms !important; }
}