/* =====================================================================
   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:420vh; 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; } }

/* =====================================================================
   1b · INTRO BMW CAR  (intro-section enhancement only — no other
        styles changed)
   ===================================================================== */

/*
 * Layout: the car wrapper lives inside .intro__center.
 * .intro__center already has: position:relative; z-index:3;
 *   text-align:center; will-change:transform,filter.
 * We only control the car and its children here.
 */

/* ── Car wrapper ──────────────────────────────────────────────── */
.intro__car{
  position:relative;
  display:inline-block;          /* shrink-wrap to image width      */
  width:min(66vw, 760px);
  margin-top:clamp(8px,2vh,24px);
  /*
   * transform-origin: the zoom target — BMW grille / headlight zone.
   * 50% horizontal = dead centre.
   * 56% vertical   = just below the BMW roundel, between the headlights.
   */
  transform-origin:50% 56%;
  will-change:transform;
}

/* ── BMW image ────────────────────────────────────────────────── */
.intro__car-img{
  display:block;
  width:100%;
  height:auto;
  /*
   * Drop-shadows:
   *   1st: blue halo matching the headlight rings
   *   2nd: deep shadow to ground the car on the black stage
   */
  filter:
    drop-shadow(0 0 30px rgba(56,208,255,.22))
    drop-shadow(0 24px 48px rgba(0,0,0,.85));
  /* No CSS transition — JS controls this directly for scrub accuracy */
  transform-origin:inherit;
  will-change:opacity;
  /* Prevent the image being dragged or selected */
  -webkit-user-drag:none;
  pointer-events:none;
}

/* ── Blue headlight halo blobs ───────────────────────────────── */
/*
 * Two positioned radial-gradient blobs that sit right on the
 * headlight rings. JS reads scroll progress and sets opacity.
 */
.intro__hl{
  position:absolute;
  /* vertical position: headlight band — approx 50-62% from top  */
  top:50%;
  width:20%;
  height:18%;
  border-radius:50%;
  pointer-events:none;
  opacity:0;                 /* starts invisible; JS drives 0→1  */
  will-change:opacity;
  mix-blend-mode:screen;
  background:radial-gradient(
    closest-side,
    rgba(56,208,255,.75)  0%,
    rgba(56,208,255,.30) 40%,
    rgba(0,100,220,.10)  70%,
    transparent          100%
  );
  filter:blur(clamp(10px,1.8vw,22px));
  transform:translateY(-50%);
}
/* Left headlight: BMW M4 left DRL is ~14% from left edge */
.intro__hl--l{ left:13%; }
/* Right headlight: mirrored */
.intro__hl--r{ right:13%; }

/* ── Floor reflection beneath the car ──────────────────────── */
.intro__floor-glow{
  position:absolute;
  bottom:-4%;
  left:15%; right:15%;
  height:clamp(18px,3vw,36px);
  background:radial-gradient(
    ellipse 80% 100% at 50% 0%,
    rgba(56,208,255,.22) 0%,
    rgba(20,80,180,.06)  50%,
    transparent          100%
  );
  filter:blur(clamp(8px,1.2vw,16px));
  opacity:0;            /* JS drives 0→0.8  */
  will-change:opacity;
  pointer-events:none;
}

/* ── White flash overlay — fills .intro__center on exit ──────── */
.intro__flash{
  position:fixed;       /* covers full viewport for seamless exit */
  inset:0;
  z-index:8;            /* above canvas (z:0) and car (z:3), below nav (z:900) */
  background:#fff;
  opacity:0;
  pointer-events:none;
  will-change:opacity;
}

/* ── Responsive ──────────────────────────────────────────────── */
@media(max-width:760px){
  .intro__car{ width:min(90vw,480px); }
  .intro__hl { filter:blur(8px); }
}
@media(prefers-reduced-motion:reduce){
  .intro__car-img{ filter:none; }
  .intro__flash  { display:none; }
}

/* =====================================================================
   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); }

/* =====================================================================
   2b · HERO GARAGE SHUTTER  (hero-section enhancement only)
   ===================================================================== */

/* Workshop atmosphere layer (sits behind car & content) */
.hero__workshop{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(ellipse 90% 55% at 50% 100%, rgba(255,42,42,.055) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 22% 60%, rgba(255,180,60,.04) 0%, transparent 50%),
    radial-gradient(ellipse 50% 40% at 78% 60%, rgba(255,180,60,.04) 0%, transparent 50%),
    linear-gradient(180deg,#06060a 0%,#0b0c12 100%);
}
/* Overhead ceiling strip */
.workshop__ceiling{
  position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,transparent 5%,rgba(255,200,120,.18) 30%,rgba(255,220,150,.22) 50%,rgba(255,200,120,.18) 70%,transparent 95%);
  filter:blur(4px);
}
/* Light cones from ceiling */
.workshop__beam{
  position:absolute; top:0; width:38vw; height:78vh; pointer-events:none;
  background:linear-gradient(180deg,rgba(255,200,100,.025) 0%,transparent 85%);
  clip-path:polygon(10% 0%,90% 0%,100% 100%,0% 100%);
}
.workshop__beam--l{ left:2%; }
.workshop__beam--r{ right:2%; }
/* Workshop floor grid */
.workshop__floor-grid{
  position:absolute; bottom:0; left:0; right:0; height:42%;
  background:
    linear-gradient(to bottom,#09090e 0%,#060609 100%),
    repeating-linear-gradient(90deg,transparent 0,transparent 99px,rgba(255,255,255,.025) 100px);
  border-top:1px solid rgba(255,255,255,.045);
}
.workshop__floor-grid::after{
  content:""; position:absolute; top:0; left:15%; right:15%; height:2px;
  background:linear-gradient(90deg,transparent,rgba(255,42,42,.22),transparent);
  filter:blur(3px);
}

/* ── Shutter container ───────────────────────────────────────────── */
.hero__shutter{
  position:absolute; inset:0; z-index:20; pointer-events:none; overflow:hidden;
}

/* ── Sliding door (contains slats) ─────────────────────────────── */
.shutter__door{
  position:absolute; top:0; left:0; right:0; height:105%; /* extra 5% hides edge */
  display:flex; flex-direction:column;
  will-change:transform; transform-origin:top center;
  overflow:visible;
}

/* ── Individual slats (injected by JS) ─────────────────────────── */
.shutter__slat{
  width:100%; flex:none;
  position:relative; overflow:hidden;
  background:linear-gradient(
    180deg,
    #232323 0%,#1c1c1c 20%,
    #171717 46%,
    #111 48%,
    #151515 50%,
    #1a1a1a 70%,#161616 100%
  );
  border-bottom:1px solid #2e2e2e;
}
/* Side-shadow insets on every slat */
.shutter__slat::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg,rgba(0,0,0,.65) 0%,transparent 7%,transparent 93%,rgba(0,0,0,.65) 100%);
}
/* Top-edge highlight */
.shutter__slat::after{
  content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.09),transparent);
}

/* ── Guide rails (stay fixed while door moves) ─────────────────── */
.shutter__rail{
  position:absolute; top:-20%; bottom:-5%; /* extend beyond clip edge */
  width:clamp(14px,2.2vw,26px); z-index:2; pointer-events:none;
}
.shutter__rail--l{
  left:0;
  background:linear-gradient(90deg,#161616,#242424,#1a1a1a);
  border-right:1px solid #363636;
  box-shadow:inset -3px 0 8px rgba(0,0,0,.6);
}
.shutter__rail--r{
  right:0;
  background:linear-gradient(90deg,#1a1a1a,#242424,#161616);
  border-left:1px solid #363636;
  box-shadow:inset 3px 0 8px rgba(0,0,0,.6);
}
/* Bolts on rails (injected by JS) */
.shutter__bolt{
  position:absolute; left:50%; transform:translateX(-50%);
  width:7px; height:7px; border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#555,#1c1c1c);
  border:1px solid #4a4a4a;
  box-shadow:0 1px 3px rgba(0,0,0,.8);
}

/* ── Brand watermark (moves with door) ─────────────────────────── */
.shutter__brand{
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  text-align:center; z-index:3; pointer-events:none;
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.shutter__brand-logo{
  display:grid; place-items:center;
  width:clamp(42px,6vw,72px); height:clamp(42px,6vw,72px);
  border:1px solid rgba(255,42,42,.12);
  color:rgba(255,42,42,.12); font-family:var(--font-display);
  font-weight:800; font-size:clamp(1rem,2vw,1.6rem);
  box-shadow:inset 0 0 20px rgba(255,42,42,.06);
}
.shutter__brand-name{
  display:block; font-family:var(--font-display);
  font-size:clamp(1.4rem,4vw,4.5rem); font-weight:900;
  letter-spacing:.3em; text-transform:uppercase;
  color:rgba(255,255,255,.035); line-height:1;
}
.shutter__brand-sub{
  display:block; font-family:var(--font-hud);
  font-size:clamp(.55rem,.9vw,.85rem);
  letter-spacing:.5em; text-transform:uppercase;
  color:rgba(255,255,255,.045);
}

/* ── Red accent stripes on the door ────────────────────────────── */
.shutter__stripe{
  position:absolute; left:clamp(14px,2.2vw,26px); right:clamp(14px,2.2vw,26px);
  height:2px; z-index:3;
  background:linear-gradient(90deg,transparent,rgba(255,42,42,.14),transparent);
}
.shutter__stripe--t{ top:28%; }
.shutter__stripe--b{ bottom:28%; }

/* ── Bottom rubber seal (moves with door) ───────────────────────── */
.shutter__seal{
  position:absolute; bottom:0; left:0; right:0;
  height:clamp(8px,1.2vh,14px);
  background:linear-gradient(180deg,#3a3a3a,#111);
  border-top:2px solid #555;
  z-index:4;
}

/* ── Scroll hint ────────────────────────────────────────────────── */
.shutter__hint{
  position:absolute; bottom:clamp(24px,4vh,44px); left:50%;
  transform:translateX(-50%); z-index:25;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  pointer-events:none;
}
.shutter__hint-text{
  font-family:var(--font-hud); font-size:.6rem;
  letter-spacing:.32em; text-transform:uppercase;
  color:rgba(255,255,255,.28);
}
.shutter__hint-mouse{
  width:20px; height:33px;
  border:1.5px solid rgba(255,255,255,.16); border-radius:10px;
  display:flex; justify-content:center; padding-top:5px;
}
.shutter__hint-wheel{
  width:3px; height:7px; border-radius:2px;
  background:var(--red);
  animation:shutterWheel 1.7s ease-in-out infinite;
}
@keyframes shutterWheel{
  0%  { transform:translateY(0);    opacity:1; }
  100%{ transform:translateY(10px); opacity:0; }
}

/* ── Responsive: disable shutter on small screens ──────────────── */
@media(max-width:760px){
  .hero__shutter{ display:none; }
  .hero__workshop{ display:none; }
}
@media(prefers-reduced-motion:reduce){
  .hero__shutter{ display:none; }
}

/* =====================================================================
   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; 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 — STACKED CARD DECK
   (replaces horizontal scroll — .hscroll / .tl rules below still used
    by the Timeline section)
   ===================================================================== */

/* Section height: 800vh  =  700vh scroll range  +  100vh viewport
   (700vh / 6 cards ≈ 116vh dismissal distance per card)              */
.services{ height:800vh; position:relative; background:var(--bg); }

/* Sticky viewport container */
.svc-pin{
  position:sticky; top:0; height:100vh; overflow:hidden;
  display:grid; grid-template-columns:1fr 1.1fr; align-items:center;
  gap:clamp(30px,4vw,70px); padding:0 clamp(24px,6vw,90px);
  background:var(--bg);
  background-image:radial-gradient(ellipse 60% 70% at 70% 50%,rgba(255,42,42,.055) 0%,transparent 65%);
}

/* ── Left info panel ─────────────────────────────────────────── */
.svc-left{ position:relative; z-index:2; padding-top:clamp(0px,2vh,30px); }
.svc-left__title{ font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(2.2rem,3.8vw,4.2rem); line-height:.9; margin:14px 0 20px; letter-spacing:-.01em; }
.svc-left__desc{ color:var(--muted); font-size:clamp(.88rem,1.1vw,1rem); line-height:1.72; max-width:380px; }
.svc-left__meta{ margin-top:clamp(28px,4vh,44px); }
.svc-left__counter{ display:flex; align-items:baseline; gap:8px; font-family:var(--font-hud); letter-spacing:.06em; line-height:1; }
.svc-left__cur{ font-size:clamp(2.2rem,4vw,3.4rem); font-weight:700; color:var(--red); will-change:contents; min-width:2ch; text-shadow:0 0 24px var(--red-glow); }
.svc-left__sep{ font-size:.9rem; color:var(--faint); margin:0 2px; }
.svc-left__tot{ font-size:.9rem; color:var(--faint); }
.svc-left__bar{ margin-top:14px; height:2px; width:min(220px,100%); background:rgba(255,255,255,.08); border-radius:2px; overflow:hidden; }
.svc-left__fill{ display:block; height:100%; width:0%; background:linear-gradient(90deg,var(--red-deep),var(--red)); box-shadow:0 0 10px var(--red-glow); border-radius:2px; will-change:width; }

/* ── Right card stack ─────────────────────────────────────────── */
.svc-right{ position:relative; height:min(500px,68vh); display:flex; align-items:center; justify-content:center; }
.svc-stack{ position:relative; width:min(100%,460px); height:min(410px,60vh); perspective:1200px; perspective-origin:50% 30%; }

/* ── Service cards ────────────────────────────────────────────── */
.svc-card{
  position:absolute; top:0; left:50%; width:100%;
  padding:clamp(22px,3vw,36px);
  background:rgba(7,7,11,.90);
  border:1px solid rgba(255,42,42,.14); border-radius:18px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    0 0 0 1px rgba(255,42,42,.06),
    0 0 40px rgba(255,42,42,.07),
    0 28px 70px rgba(0,0,0,.75);
  backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  will-change:transform,opacity;
  transform-origin:50% 105%;    /* rotate from just below card bottom */
  overflow:hidden; cursor:default;
}
/* Top sheen */
.svc-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent 5%,rgba(255,42,42,.3) 35%,rgba(255,255,255,.1) 50%,rgba(255,42,42,.3) 65%,transparent 95%); }
/* Left red accent bar */
.svc-card::after{ content:""; position:absolute; top:18%; left:0; bottom:18%; width:3px; border-radius:0 3px 3px 0; background:linear-gradient(180deg,transparent,var(--red) 30%,var(--red) 70%,transparent); opacity:.7; }

.svc-card__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:clamp(14px,2vw,22px); }
.svc-card__no{ font-family:var(--font-hud); font-size:.7rem; letter-spacing:.36em; color:var(--red); }
.svc-card__tag{ font-family:var(--font-hud); font-size:.58rem; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.22); border:1px solid rgba(255,255,255,.08); padding:4px 10px; border-radius:40px; }
.svc-card__title{ font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(1.8rem,3vw,2.5rem); line-height:.92; letter-spacing:-.01em; color:var(--ink); margin-bottom:clamp(10px,1.5vw,16px); }
.svc-card__desc{ color:var(--muted); font-size:clamp(.82rem,1vw,.94rem); line-height:1.68; }
.svc-card__rule{ margin-top:clamp(14px,2vw,22px); height:1px; background:linear-gradient(90deg,rgba(255,42,42,.35) 0%,rgba(255,42,42,.08) 50%,transparent 100%); }
.svc-card__cta{ display:inline-flex; align-items:center; gap:8px; margin-top:clamp(10px,1.5vw,16px); font-family:var(--font-hud); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--red); }
.svc-card__cta::after{ content:"→"; display:inline-block; transition:transform .3s var(--ease); }
.svc-card:hover .svc-card__cta::after{ transform:translateX(5px); }

/* ── Tablet ───────────────────────────────────────────────────── */
@media(max-width:960px){
  .svc-pin{ grid-template-columns:1fr; grid-template-rows:auto 1fr; padding-top:clamp(80px,10vh,120px); align-items:start; gap:20px; }
  .svc-left__title{ font-size:clamp(2rem,7vw,3rem); }
  .svc-left__desc{ display:none; }  /* save vertical space */
  .svc-right{ height:min(420px,52vh); width:100%; }
  .svc-stack{ width:min(100%,400px); margin:0 auto; }
}
/* ── Mobile: keep stacked-card pin, adapted heights ───────────── */
@media(max-width:760px){
  .services{ height:480vh; }
  .svc-pin{
    position:sticky; top:0;
    height:100vh; height:100dvh;
    grid-template-columns:1fr;
    grid-template-rows:auto 1fr;
    padding:clamp(70px,10vh,100px) 20px 20px;
    align-items:start;
    gap:16px;
    overflow:hidden;
    background-image:none;
  }
  .svc-left__title{ font-size:clamp(1.7rem,7vw,2.4rem); }
  .svc-left__desc{ display:none; }
  .svc-right{ height:min(400px,50vh); width:100%; }
  .svc-stack{ width:min(100%,360px); margin:0 auto; height:min(380px,48vh); }
  /* Cards are positioned by GSAP — do NOT override transform/opacity with !important */
  .svc-card{ max-width:360px; }
}

/* 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
   ===================================================================== */
@media (max-width:1080px){
  .footer__top{ grid-template-columns:1fr 1fr; }
}

/* =====================================================================
   MOBILE  —  cinematic animations preserved; values reduced for phones.
   Desktop layout and animations are completely untouched.
   ===================================================================== */
@media (max-width:760px){
  /* ── NAV ──────────────────────────────────────────────────────────── */
  .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; }

  /* ── MOBILE SECTION SCROLL HEIGHTS (shorter pins, not auto) ──────── */
  /* intro  : 200vh  → pin lives inside, scroll zoom still runs        */
  /* turntable: 250vh → rotateY 360 still runs                         */
  /* perf   : 160vh  → speedometer still runs                          */
  /* reveal : 180vh  → before/after wipe still runs                    */
  /* story + services + gallery have their own blocks below            */
  .intro     { height:200vh; }
  .turntable { height:250vh; }
  .perf      { height:160vh; }
  .reveal    { height:180vh; }

  /* ── dvh fix: iOS Safari 100vh includes browser chrome ───────────── */
  .intro__pin,
  .tt__pin,
  .perf__pin,
  .rev__pin { height:100vh; height:100dvh; }

  /* ── Turntable ────────────────────────────────────────────────────── */
  .tt__turn{ width:88vw; }
  .tt__word{ font-size:clamp(2rem,13vw,6rem); }

  /* ── Hero mobile layout ───────────────────────────────────────────── */
  /* ── HERO MOBILE: image-first column layout ───────────────────────
     Stage (garage image) sits above text thanks to order:-1.
     The fixed nav clears via padding-top on .hero.
  ─────────────────────────────────────────────────────────────────── */
  .hero{
    flex-direction: column;
    align-items: stretch;
    padding-top: clamp(58px,9vw,70px);
    min-height: 100svh;
    overflow: hidden;
  }
  /* Full-width image block — appears BEFORE hero__content */
  .hero__stage{
    position: relative;
    right: auto; bottom: auto; left: 0;
    width: 100%;
    height: clamp(260px, 70vw, 320px);
    overflow: hidden;
    order: -1;          /* pulls image above .hero__content in flex column */
    margin-top: 0;
    flex-shrink: 0;
    z-index: 4;
  }
  /* Car div fills the stage */
  .hero .car{ position:relative; width:100%; height:100%; }
  /* Image covers the stage — no horizontal overflow */
  .hero .car__img{
    width:100%; height:100%;
    object-fit:cover; object-position:center top;
    filter:saturate(1.05) contrast(1.05);
    border-radius:0;
  }
  /* Simplify overlays that don't suit object-fit:cover on mobile */
  .hero .car__floor{ display:none; }
  .hero .car__headlights{ display:none; }
  /* Hero text + buttons below the image */
  .hero__content{
    position:relative; z-index:6; max-width:100%;
    padding:22px clamp(18px,5vw,28px) clamp(28px,5vw,40px);
  }
  /* Hide all HUD labels — they overlap the image on mobile */
  .hud{ display:none; }

  /* ── Performance mobile ───────────────────────────────────────────── */
  .speedo{ width:min(78vw,260px); }
  .perf__hud{ position:absolute; top:7vh; }
  .perf__stats{ position:absolute; bottom:7vh; gap:clamp(14px,4vw,32px); flex-wrap:wrap; justify-content:center; }
  .pstat b{ font-size:clamp(1.4rem,5vw,2.2rem); }

  /* ── Timeline (horizontal scroll preserved on mobile) ────────────── */
  .tl__stop b{ font-size:1.3rem; }

  /* ── Booking / Sell / FAQ ─────────────────────────────────────────── */
  .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 ───────────────────────────────────────────────────────── */
  .footer__top{ grid-template-columns:1fr; } .footer__bottom{ flex-direction:column; }
}

/* =====================================================================
   REDUCED MOTION — collapse ALL pins to static (accessibility)
   ===================================================================== */
@media (prefers-reduced-motion:reduce){
  .intro,.turntable,.perf,.reveal{ height:auto !important; }
  .story{ height:auto !important; }
  .services{ height:auto !important; }
  .gallery{ height:auto !important; }
  .intro__pin,.tt__pin,.perf__pin,.rev__pin{ position:relative !important; height:auto !important; }
  .story__pin{ position:relative !important; height:auto !important; }
  .svc-pin{ position:relative !important; height:auto !important; }
  .gal-pin{ position:relative !important; height:auto !important; }
  .tt__car--side{ opacity:1 !important; }
  .tt__word.is-on{ opacity:1 !important; }
  .rev__after{ clip-path:inset(0 0 0 0) !important; }
  .perf__bg{ opacity:1 !important; }
  .perf__hud{ opacity:1 !important; transform:none !important; position:relative !important; top:auto !important; }
  *{ animation-duration:.001ms !important; transition-duration:.01ms !important; }
}
/* =========================================================
   TEXT RED VISIBILITY FIX — only active turntable word visible
   ========================================================= */
.tt__word{
  color: rgba(255, 42, 42, 0.44) !important;
  opacity: 0 !important;
  text-shadow:
    0 0 18px rgba(255, 42, 42, 0.45),
    0 0 55px rgba(255, 42, 42, 0.25) !important;
}

.tt__word.is-on{
  opacity: 1 !important;
  color: rgba(255, 42, 42, 0.46) !important;
}

.tt__angle{
  color: #ff2a2a !important;
  opacity: 1 !important;
  font-weight: 700 !important;
  text-shadow:
    0 0 12px rgba(255, 42, 42, 0.85),
    0 0 28px rgba(255, 42, 42, 0.45) !important;
}

/* Timeline delivery progress fix */
.tl__rail{
  left: 0;
  width: 100%;
}
.tl__progress{
  width: 0;
  max-width: 100%;
}


/* =====================================================================
   4 · PROCESS — STACKED CARD SCROLLER
   Matches the Services stacked-card scroll interaction.
   ===================================================================== */
.story{
  height:700vh;
  position:relative;
  background:var(--bg);
}
.story__pin.process-pin{
  position:sticky;
  top:0;
  height:100vh;
  overflow:hidden;
  display:grid;
  grid-template-columns:1fr 1.1fr;
  align-items:center;
  gap:clamp(30px,4vw,70px);
  padding:0 clamp(24px,6vw,90px);
  background:
    radial-gradient(ellipse 60% 70% at 72% 50%,rgba(255,42,42,.07) 0%,transparent 65%),
    radial-gradient(ellipse 40% 50% at 15% 50%,rgba(255,42,42,.045) 0%,transparent 70%),
    var(--bg);
}
.process-left{ position:relative; z-index:2; padding-top:clamp(0px,2vh,30px); }
.process-left::before{
  content:"";
  position:absolute;
  left:-26px;
  top:12%;
  width:3px;
  height:70%;
  background:linear-gradient(180deg,transparent,var(--red) 30%,var(--red) 70%,transparent);
  box-shadow:0 0 22px var(--red-glow);
}
.process-left__title{
  font-family:var(--font-display);
  font-weight:900;
  text-transform:uppercase;
  font-size:clamp(2.25rem,4vw,4.6rem);
  line-height:.9;
  margin:14px 0 20px;
  letter-spacing:-.01em;
}
.process-left__desc{ color:var(--muted); font-size:clamp(.88rem,1.1vw,1rem); line-height:1.72; max-width:390px; }
.process-left__meta{ margin-top:clamp(28px,4vh,44px); }
.process-left__counter{ display:flex; align-items:baseline; gap:8px; font-family:var(--font-hud); letter-spacing:.06em; line-height:1; }
.process-left__cur{ font-size:clamp(2.2rem,4vw,3.4rem); font-weight:700; color:var(--red); min-width:2ch; text-shadow:0 0 24px var(--red-glow); }
.process-left__sep{ font-size:.9rem; color:var(--faint); margin:0 2px; }
.process-left__tot{ font-size:.9rem; color:var(--faint); }
.process-left__bar{ margin-top:14px; height:2px; width:min(220px,100%); background:rgba(255,255,255,.08); border-radius:2px; overflow:hidden; }
.process-left__fill{ display:block; height:100%; width:0%; background:linear-gradient(90deg,var(--red-deep),var(--red)); box-shadow:0 0 10px var(--red-glow); border-radius:2px; }
.process-right{ position:relative; height:min(500px,68vh); display:flex; align-items:center; justify-content:center; }
.process-stack{ position:relative; width:min(100%,470px); height:min(420px,60vh); perspective:1200px; perspective-origin:50% 30%; }
.process-card{
  position:absolute;
  top:0;
  left:50%;
  width:100%;
  padding:clamp(22px,3vw,36px);
  background:rgba(7,7,11,.92);
  border:1px solid rgba(255,42,42,.16);
  border-radius:18px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 0 0 1px rgba(255,42,42,.07),0 0 45px rgba(255,42,42,.08),0 28px 70px rgba(0,0,0,.76);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  will-change:transform,opacity;
  transform-origin:50% 105%;
  overflow:hidden;
}
.process-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent 5%,rgba(255,42,42,.32) 35%,rgba(255,255,255,.1) 50%,rgba(255,42,42,.32) 65%,transparent 95%); }
.process-card::after{ content:""; position:absolute; top:18%; left:0; bottom:18%; width:3px; border-radius:0 3px 3px 0; background:linear-gradient(180deg,transparent,var(--red) 30%,var(--red) 70%,transparent); opacity:.72; }
.process-card__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:clamp(14px,2vw,22px); }
.process-card__no{ font-family:var(--font-hud); font-size:.7rem; letter-spacing:.36em; color:var(--red); }
.process-card__tag{ font-family:var(--font-hud); font-size:.58rem; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.24); border:1px solid rgba(255,255,255,.08); padding:4px 10px; border-radius:40px; }
.process-card__title{ font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:clamp(1.9rem,3.2vw,2.7rem); line-height:.92; letter-spacing:-.01em; color:var(--ink); margin-bottom:clamp(10px,1.5vw,16px); }
.process-card__desc{ color:var(--muted); font-size:clamp(.82rem,1vw,.94rem); line-height:1.68; }
.process-card__rule{ margin-top:clamp(14px,2vw,22px); height:1px; background:linear-gradient(90deg,rgba(255,42,42,.36) 0%,rgba(255,42,42,.08) 50%,transparent 100%); }
.process-card__cta{ display:inline-flex; align-items:center; gap:8px; margin-top:clamp(10px,1.5vw,16px); font-family:var(--font-hud); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--red); }
.process-card__cta::after{ content:"→"; display:inline-block; transition:transform .3s var(--ease); }
.process-card:hover .process-card__cta::after{ transform:translateX(5px); }
@media(max-width:960px){
  .story__pin.process-pin{ grid-template-columns:1fr; grid-template-rows:auto 1fr; padding-top:clamp(80px,10vh,120px); align-items:start; gap:20px; }
  .process-left__title{ font-size:clamp(2rem,7vw,3rem); }
  .process-left__desc{ display:none; }
  .process-right{ height:min(420px,52vh); width:100%; }
  .process-stack{ width:min(100%,400px); margin:0 auto; }
}
@media(max-width:760px){
  .story{ height:400vh; }
  .story__pin.process-pin{
    position:sticky; top:0;
    height:100vh; height:100dvh;
    grid-template-columns:1fr;
    grid-template-rows:auto 1fr;
    padding:clamp(70px,10vh,100px) 20px 20px;
    align-items:start;
    gap:16px;
    overflow:hidden;
    background-image:none;
  }
  .process-left__title{ font-size:clamp(1.7rem,7vw,2.4rem); }
  .process-left__desc{ display:none; }
  .process-right{ height:min(400px,50vh); width:100%; }
  .process-stack{ width:min(100%,360px); margin:0 auto; height:min(380px,48vh); }
  /* Cards positioned by GSAP — no !important override on transform/opacity */
  .process-card{ max-width:360px; }
  .process-left::before{ display:none; }
}

/* =====================================================================
   8 · GALLERY — CINEMATIC 3D COVERFLOW SHOWCASE
   Scroll-driven horizontal depth carousel.
   Active card: large, sharp, facing viewer.
   Adjacent cards: rotateY, scaled, darkened — receding into 3D space.
   Prefix: gal-   (no conflicts with svc- or process- namespaces)
   ===================================================================== */

/* ── Section container ───────────────────────────────────────────
   700vh total height → 600vh of scroll range for N-1=5 transitions.
   Each transition gets 120vh — smooth and cinematic.              */
.gallery{
  height:700vh;
  position:relative;
  background:#05050a;
}

/* Sticky full-viewport stage */
.gal-pin{
  position:sticky;
  top:0;
  height:100vh;
  overflow:hidden;
  background:#05050a;
}

/* ── Cinematic background ────────────────────────────────────────
   Two layers: vignette darkens edges, sweep is a red centre pulse. */
.gal-bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.gal-bg__vignette{
  position:absolute; inset:0;
  background:radial-gradient(ellipse 88% 88% at 50% 50%,
    transparent 36%, rgba(0,0,0,.55) 70%, rgba(0,0,0,.92) 100%);
}
.gal-bg__sweep{
  position:absolute; inset:0;
  background:radial-gradient(ellipse 52% 58% at 50% 50%,
    rgba(255,42,42,.06) 0%, transparent 62%);
}

/* ── 3D perspective stage ────────────────────────────────────────
   Wraps all cards. perspective here means ALL cards share the same
   vanishing point — this is exactly what gives the coverflow depth. */
.gal-stage{
  position:absolute; inset:0;
  perspective:1400px;
  perspective-origin:50% 50%;
  z-index:2;
}

/* ── Gallery cards ───────────────────────────────────────────────
   All cards stack at the same DOM position.
   GSAP sets x / z / rotateY / scale / opacity to position each one.
   top:50%; left:50% + GSAP xPercent:-50 yPercent:-50 → centred.    */
.gal-card{
  position:absolute;
  top:50%; left:50%;
  /* Card dimensions — active card fills this; others scale down */
  width:min(38vw, 480px);
  height:min(66vh, 560px);
  border-radius:16px;
  overflow:hidden;
  will-change:transform,opacity,filter;
  cursor:default;
}

/* Full-size frame inside each card */
.gal-card__frame{
  position:relative;
  width:100%; height:100%;
}

/* Full-bleed photography */
.gal-card__img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  /* Slight scale prevents white edge on rounded corners */
  transform:scale(1.03);
  transform-origin:center center;
  transition:none;
}

/* Bottom-to-top gradient: darkens lower half for text legibility */
.gal-card__grad{
  position:absolute; inset:0;
  background:
    linear-gradient(
      to top,
      rgba(0,0,0,.94)  0%,
      rgba(0,0,0,.60)  32%,
      rgba(0,0,0,.14)  58%,
      transparent      100%
    ),
    /* Red rim-light from the left — studio feel */
    linear-gradient(
      to right,
      rgba(255,42,42,.14) 0%,
      transparent         38%
    );
  pointer-events:none;
}

/* Red glow border — JS drives opacity (0 = inactive, 1 = active) */
.gal-card__glow{
  position:absolute; inset:0;
  border-radius:16px;
  border:1.5px solid rgba(255,42,42,.55);
  box-shadow:
    0 0 28px  rgba(255,42,42,.22),
    0 0 80px  rgba(255,42,42,.10),
    inset 0 0 60px rgba(255,42,42,.06);
  opacity:0;
  pointer-events:none;
  transition:none;   /* JS scrubs this — no CSS transition */
}

/* Text overlay in the lower portion of each card */
.gal-card__body{
  position:absolute;
  bottom:0; left:0; right:0;
  padding:clamp(18px,2.5vw,32px);
  /* Thin left red stripe */
  border-left:3px solid transparent;
  background:
    linear-gradient(to right, rgba(255,42,42,.6) 0px, transparent 3px)
    no-repeat left center / 3px 60%;
}

/* Number + category tag row */
.gal-card__head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:clamp(8px,1.2vw,14px);
}
.gal-card__no{
  font-family:var(--font-hud);
  font-size:.68rem; letter-spacing:.36em;
  color:var(--red); text-shadow:0 0 12px var(--red-glow);
}
.gal-card__tag{
  font-family:var(--font-hud); font-size:.55rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:rgba(255,255,255,.32);
  border:1px solid rgba(255,255,255,.1); padding:3px 9px; border-radius:40px;
}

/* Service title */
.gal-card__title{
  font-family:var(--font-display); font-weight:900; text-transform:uppercase;
  font-size:clamp(1.7rem,2.9vw,2.6rem); line-height:.88;
  letter-spacing:-.01em; color:var(--ink);
  margin-bottom:clamp(8px,1vw,12px);
}

/* Red separator */
.gal-card__rule{
  height:1px; margin-bottom:clamp(6px,1vw,10px);
  background:linear-gradient(90deg, var(--red) 0%, rgba(255,42,42,.08) 55%, transparent 100%);
  opacity:.7;
}

/* Short description */
.gal-card__desc{
  color:rgba(154,160,173,.82);
  font-size:clamp(.76rem,.9vw,.86rem); line-height:1.62;
}

/* ── Info overlay — bottom-left corner ──────────────────────────
   Static label + counter + progress bar. Sits above the stage.   */
.gal-info{
  position:absolute;
  bottom:clamp(28px,5vh,56px); left:clamp(24px,4vw,64px);
  z-index:10; pointer-events:none;
  max-width:min(30vw,340px);
}
.gal-info__title{
  font-family:var(--font-display); font-weight:900; text-transform:uppercase;
  font-size:clamp(1.9rem,3.2vw,3.8rem); line-height:.88; letter-spacing:-.01em;
  margin:10px 0 10px;
}
.gal-info__desc{
  color:var(--muted); font-size:clamp(.78rem,.95vw,.88rem);
  line-height:1.65; margin-bottom:clamp(14px,2.5vh,24px);
}
.gal-info__counter{
  display:flex; align-items:baseline; gap:6px;
  font-family:var(--font-hud); line-height:1; margin-bottom:10px;
}
.gal-info__cur{
  font-size:clamp(1.8rem,3vw,2.6rem); font-weight:700;
  color:var(--red); min-width:2ch; text-shadow:0 0 22px var(--red-glow);
  will-change:contents;
}
.gal-info__sep,.gal-info__tot{ font-size:.9rem; color:var(--faint); }
.gal-info__sep{ margin:0 3px; }
.gal-info__bar{
  height:2px; width:min(180px,100%);
  background:rgba(255,255,255,.08); border-radius:2px; overflow:hidden;
}
.gal-info__fill{
  display:block; height:100%; width:0%;
  background:linear-gradient(90deg,var(--red-deep),var(--red));
  box-shadow:0 0 10px var(--red-glow); border-radius:2px; will-change:width;
}

/* ── Dot navigation — bottom-right corner ───────────────────────*/
.gal-dots{
  position:absolute;
  bottom:clamp(28px,5vh,56px); right:clamp(24px,4vw,64px);
  z-index:10; display:flex; align-items:center; gap:10px;
}
.gal-dot{
  width:7px; height:7px; border-radius:50%;
  background:rgba(255,255,255,.18);
  transition:background .3s var(--ease), transform .3s var(--ease), box-shadow .3s;
  cursor:pointer; pointer-events:all;
}
.gal-dot.is-active{
  background:var(--red); transform:scale(1.45);
  box-shadow:0 0 10px var(--red-glow);
}

/* ── Responsive: tablet ─────────────────────────────────────────*/
@media(max-width:960px){
  .gal-card{ width:min(56vw,380px); height:min(64vh,480px); }
  .gal-info{ max-width:min(44vw,260px); }
  .gal-info__desc{ display:none; }
}

/* ── Responsive: mobile — cinematic 3D coverflow preserved ──── */
@media(max-width:760px){
  .gallery{ height:500vh; }
  .gal-pin{
    position:sticky; top:0;
    height:100vh; height:100dvh;
    overflow:hidden;
    background:#05050a;
  }
  /* Info panel repositioned for mobile */
  .gal-info{
    bottom:clamp(14px,3vh,26px);
    left:clamp(14px,4vw,28px);
    max-width:min(68vw,240px);
    pointer-events:none;
  }
  .gal-info__title{ font-size:clamp(1.3rem,5vw,1.9rem); }
  .gal-info__desc{ display:none; }
  /* Cards: adapted size — GSAP handles ALL 3D transforms */
  .gal-card{
    width:80vw;
    height:min(74vw,320px);
  }
  /* Keep dots visible on mobile */
  .gal-dots{
    bottom:clamp(14px,3vh,26px);
    right:clamp(12px,3vw,22px);
    gap:7px;
  }
  .gal-dot{ width:6px; height:6px; }
}

/* ── Reduced motion ─────────────────────────────────────────────*/
@media(prefers-reduced-motion:reduce){
  .gallery{ height:auto !important; }
  .gal-pin{ position:relative !important; height:auto !important; overflow:visible !important; padding:60px 20px; display:flex; flex-direction:column; gap:0; }
  .gal-info{ position:relative; bottom:auto; left:auto; max-width:100%; margin-bottom:30px; }
  .gal-stage{ position:relative; height:auto; perspective:none; display:flex; flex-direction:column; gap:18px; }
  .gal-card{ position:relative !important; top:auto !important; left:auto !important; width:100% !important; height:min(70vw,360px) !important; transform:none !important; opacity:1 !important; filter:none !important; }
  .gal-dots{ display:none; }
}

/* Custom vehicle input in booking step */
.custom-vehicle-box{ margin-top:18px; }
.custom-vehicle-box label{ display:block; margin-bottom:10px; font-family:var(--font-hud); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.custom-vehicle-box .field{ margin-bottom:0; border-color:rgba(255,42,42,.22); }
.custom-vehicle-box .field:focus{ border-color:var(--red); box-shadow:0 0 22px -10px var(--red-glow); }


/* Floating back-to-top button above WhatsApp */
.to-top-btn{
  position:fixed;
  right:24px;
  bottom:92px;
  z-index:881;
  width:54px;
  height:54px;
  display:grid;
  place-items:center;
  border-radius:50%;
  border:1px solid rgba(255,42,42,.75);
  background:rgba(5,5,7,.72);
  color:#fff;
  font-family:var(--font-hud);
  font-size:1.35rem;
  line-height:1;
  box-shadow:0 0 0 0 rgba(255,42,42,.35), 0 10px 28px -10px var(--red-glow), inset 0 0 20px rgba(255,42,42,.12);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  opacity:0;
  visibility:hidden;
  transform:translateY(14px) scale(.88);
  transition:opacity .35s var(--ease), visibility .35s, transform .35s var(--ease), background .35s, box-shadow .35s;
  animation:toTopPulse 2.2s ease-in-out infinite;
}
.to-top-btn.is-visible{
  opacity:1;
  visibility:visible;
  transform:translateY(0) scale(1);
}
.to-top-btn:hover{
  background:var(--red);
  transform:translateY(-4px) scale(1.04);
  box-shadow:0 0 0 8px rgba(255,42,42,.08), 0 16px 38px -10px var(--red-glow);
}
.to-top-btn__icon{
  display:block;
  transform:translateY(-1px);
  text-shadow:0 0 16px rgba(255,255,255,.45);
}
@keyframes toTopPulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(255,42,42,.28), 0 10px 28px -10px var(--red-glow), inset 0 0 20px rgba(255,42,42,.12); }
  50%{ box-shadow:0 0 0 9px rgba(255,42,42,0), 0 16px 36px -8px var(--red-glow), inset 0 0 26px rgba(255,42,42,.18); }
}
@media(max-width:760px){
  .to-top-btn{ right:18px; bottom:86px; width:48px; height:48px; font-size:1.2rem; }
}



/* ===== Uploaded logo layout-safe update ===== */
.nav__brand--logo{
  display:flex;
  align-items:center;
  min-width:240px;
  height:54px;
  overflow:visible;
  flex-shrink:0;
}

.site-logo{
  display:block;
  object-fit:contain;
  filter:drop-shadow(0 0 10px rgba(255,42,42,.18));
}

.site-logo--nav{
  width:270px;
  max-width:24vw;
  max-height:52px;
  height:auto;
}

.site-logo--footer{
  width:360px;
  max-width:100%;
  height:auto;
  margin-bottom:18px;
}

.footer__brand .site-logo--footer + .footer__owner{
  margin-top:4px;
}

@media (max-width:1080px){
  .nav__brand--logo{ min-width:205px; height:48px; }
  .site-logo--nav{ width:225px; max-width:30vw; max-height:46px; }
}

@media (max-width:760px){
  .nav__brand--logo{ min-width:0; height:44px; }
  .site-logo--nav{ width:205px; max-width:58vw; max-height:42px; }
  .site-logo--footer{ width:280px; }
}

@media (max-width:420px){
  .site-logo--nav{ width:178px; max-width:54vw; max-height:38px; }
}



/* ===== Sell Car condition dropdown fix ===== */
.sell select.field,
#sCond.field{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  cursor:pointer;
  color:var(--ink) !important;
  background:
    linear-gradient(45deg, transparent 50%, #ffffff 50%) calc(100% - 22px) 50%/6px 6px no-repeat,
    linear-gradient(135deg, #ffffff 50%, transparent 50%) calc(100% - 16px) 50%/6px 6px no-repeat,
    rgba(255,255,255,.035) !important;
  border:1px solid var(--line);
}

.sell select.field:focus,
#sCond.field:focus{
  border-color:var(--red) !important;
  box-shadow:0 0 0 1px rgba(255,42,42,.35), 0 0 18px rgba(255,42,42,.14);
}

.sell select.field option,
#sCond.field option{
  background:#121216 !important;
  color:#f4f5f7 !important;
}

.sell select.field option:checked,
#sCond.field option:checked{
  background:#ff2a2a !important;
  color:#ffffff !important;
}

/* =====================================================================
   MOBILE HERO SHUTTER  —  .hms
   Hidden on desktop (display:none base rule).
   Shown + animated only on ≤760px via GSAP MQ_M block.
   Lives inside .hero__stage which has overflow:hidden, so the door
   slides up and exits cleanly through the top of the image container.
   ===================================================================== */
.hms{ display:none; }           /* desktop: invisible */

@media(max-width:760px){
  /* Container — covers the entire .hero__stage */
  .hms{
    display:block;
    position:absolute; inset:0;
    z-index:10; overflow:hidden; pointer-events:none;
  }

  /* The sliding door panel */
  .hms__door{
    position:absolute; top:0; left:0; right:0; height:110%;
    will-change:transform;
    /* Slat-effect via repeating gradient */
    background:
      repeating-linear-gradient(
        180deg,
        transparent     0px,
        transparent     10px,
        rgba(0,0,0,.38) 10px,
        rgba(0,0,0,.38) 11px
      ),
      linear-gradient(180deg,#1e1e1e 0%,#161616 55%,#111 100%);
  }
  /* Side-shadow insets */
  .hms__door::before{
    content:""; position:absolute; inset:0;
    background:linear-gradient(90deg,rgba(0,0,0,.55) 0%,transparent 8%,transparent 92%,rgba(0,0,0,.55) 100%);
  }
  /* Faint red stripe */
  .hms__door::after{
    content:""; position:absolute; top:30%; left:10%; right:10%; height:2px;
    background:linear-gradient(90deg,transparent,rgba(255,42,42,.12),transparent);
  }

  /* Brand watermark centred on the door */
  .hms__brand{
    position:absolute; top:50%; left:50%;
    transform:translate(-50%,-50%);
    text-align:center;
    display:flex; flex-direction:column; align-items:center; gap:6px;
    pointer-events:none; user-select:none;
  }
  .hms__logo{
    display:grid; place-items:center;
    width:32px; height:32px;
    border:1px solid rgba(255,42,42,.10);
    color:rgba(255,42,42,.10);
    font-family:var(--font-display); font-weight:800; font-size:.8rem;
    box-shadow:inset 0 0 12px rgba(255,42,42,.05);
  }
  .hms__name{
    font-family:var(--font-display); font-weight:900;
    font-size:1.4rem; letter-spacing:.26em;
    text-transform:uppercase; color:rgba(255,255,255,.04); line-height:1;
  }

  /* Guide rails (stay fixed while door moves) */
  .hms__rail{
    position:absolute; top:0; bottom:0; width:clamp(8px,1.5vw,13px); z-index:2;
  }
  .hms__rail--l{
    left:0;
    background:linear-gradient(90deg,#131313,#1e1e1e,#171717);
    border-right:1px solid #2a2a2a;
    box-shadow:inset -2px 0 5px rgba(0,0,0,.5);
  }
  .hms__rail--r{
    right:0;
    background:linear-gradient(90deg,#171717,#1e1e1e,#131313);
    border-left:1px solid #2a2a2a;
    box-shadow:inset 2px 0 5px rgba(0,0,0,.5);
  }
}

/* Safety: never show on desktop regardless of specificity */
@media(min-width:761px){ .hms{ display:none !important; } }
