/* ====================================================================
   SuperCar Garage — Visual48 design system
   Dual theme: LIGHT (default) + DARK via [data-theme="dark"]
   ==================================================================== */

/* ---- TOKENS ---- */
:root, :root[data-theme="light"]{
  --bg:#f5f3ed;
  --bg-raised:#ffffff;
  --bg-card:#ffffff;
  --bg-deep:#0f0f0d;
  --fg:#131312;
  --fg-dim:#524e46;
  --muted:#8a857c;
  --line:#e4dfd2;
  --line-bright:#c9c3b3;
  --accent:#a07c2a;
  --accent-hi:#c29a3c;
  --accent-lo:#6f5617;
  --red:#b91b00;
  --chip-bg:#fff;
  --chip-fg:#131312;
  --spec-bg:#faf8f1;
  --nav-scrolled-bg:rgba(245,243,237,.85);
  --usp-bg:#fff;
  --tier-featured-bg:linear-gradient(180deg,#fffaec 0%, #fff 100%);
}
:root[data-theme="dark"]{
  --bg:#0a0a0a;
  --bg-raised:#121212;
  --bg-card:#141414;
  --bg-deep:#0f0f0d;
  --fg:#f5f1e8;
  --fg-dim:#b8b3a8;
  --muted:#6b675f;
  --line:#1f1f1f;
  --line-bright:#2a2a2a;
  --accent:#C9A961;
  --accent-hi:#e2c47a;
  --accent-lo:#8e7840;
  --red:#c1272d;
  --chip-bg:rgba(10,10,10,.72);
  --chip-fg:#f5f1e8;
  --spec-bg:#0c0c0c;
  --nav-scrolled-bg:rgba(10,10,10,.72);
  --usp-bg:var(--bg);
  --tier-featured-bg:linear-gradient(180deg,#141209 0%, #0f0f0d 100%);
}

:root{
  --ease:cubic-bezier(.2,.7,.2,1);
  --font-display:"Syncopate", "Inter", system-ui, sans-serif;
  --font-body:"Inter", system-ui, -apple-system, sans-serif;
  --font-mono:"JetBrains Mono", ui-monospace, Menlo, monospace;
  --max:1440px;
  --gutter:clamp(20px, 4vw, 56px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  font-weight:400;
  overflow-x:hidden;
  min-height:100vh;
  transition:background .4s var(--ease), color .4s var(--ease);
  opacity:0;
}
/* No body transform — breaks position:fixed children. Pure opacity fade. */
body.page-ready{
  opacity:1;
  transition:opacity .6s var(--ease), background .4s var(--ease), color .4s var(--ease);
}
body.page-leaving{
  pointer-events:none;
}
@media (prefers-reduced-motion:reduce){
  body,body.page-ready,body.page-leaving{opacity:1;transition:none}
}
body.lock{overflow:hidden;height:100vh}

/* Page-transition veil: fade (no slide — prevents layout tear on mobile) */
.page-veil{
  position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100vh;height:100svh;z-index:95;pointer-events:none;
  background:#0f0f0d;
  opacity:0;
  transition:opacity .38s var(--ease);
  will-change:opacity;
  overflow:hidden;
}
.page-veil::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 50%, rgba(194,154,60,.18) 0%, transparent 55%);
  pointer-events:none;
}
.page-veil.in{opacity:1}
.page-veil.out{opacity:0;transition:opacity .5s var(--ease)}
.page-veil__mark{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:14px;
  font-family:var(--font-display);font-size:14px;letter-spacing:.3em;color:var(--accent-hi);text-transform:uppercase;
  opacity:0;transition:opacity .3s var(--ease) .1s;
}
.page-veil.in .page-veil__mark{opacity:.9}
.page-veil__mark::before,.page-veil__mark::after{content:"";width:26px;height:1px;background:var(--accent-hi)}
@media (prefers-reduced-motion:reduce){.page-veil{display:none}}

img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .3s var(--ease)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--accent);color:#fff}
[data-theme="dark"] ::selection{color:#0a0a0a}

/* ---------- Type ---------- */
.eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:500;
}
.h-display{
  font-family:var(--font-display);
  font-weight:700;
  line-height:.95;
  letter-spacing:-.01em;
  text-transform:uppercase;
  color:var(--fg);
}
h1.h-display{font-size:clamp(40px, 7vw, 104px);word-break:normal;hyphens:manual;overflow-wrap:normal}
@media (max-width:600px){h1.h-display{font-size:clamp(36px,10vw,60px)}}
h2.h-display{font-size:clamp(34px, 6vw, 84px)}
h3.h-display{font-size:clamp(22px, 3vw, 36px)}
.mono{font-family:var(--font-mono);letter-spacing:.02em}

/* ---------- Layout ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
section{padding:clamp(80px, 10vw, 160px) 0;position:relative}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:40;
  padding:22px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;
  transition:background .4s var(--ease), backdrop-filter .4s var(--ease), padding .3s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:var(--nav-scrolled-bg);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  padding-top:14px;padding-bottom:14px;
  border-bottom:1px solid var(--line);
}
/* Hero/page-head make nav text white over dark panel */
.nav--on-dark{color:#fff}
.nav--on-dark .nav__menu a{color:rgba(255,255,255,.78)}
.nav--on-dark .nav__menu a:hover,.nav--on-dark .nav__menu a.active{color:#fff}
.nav--on-dark.scrolled{color:var(--fg)}
.nav--on-dark.scrolled .nav__menu a{color:var(--fg-dim)}
.nav--on-dark.scrolled .nav__menu a:hover,.nav--on-dark.scrolled .nav__menu a.active{color:var(--fg)}
.nav--on-dark .nav__cta{color:#fff;border-color:rgba(255,255,255,.6)}
.nav--on-dark .nav__cta:hover{background:#fff;color:var(--fg);border-color:#fff}
.nav--on-dark.scrolled .nav__cta{color:var(--accent);border-color:var(--accent);background:transparent}
.nav--on-dark.scrolled .nav__cta:hover{background:var(--accent);color:#fff}
.nav--on-dark .nav__burger span{background:#fff}
.nav--on-dark.scrolled .nav__burger span{background:var(--fg)}

.nav__brand{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;display:flex;align-items:center;gap:12px;position:relative}
.nav__logo{height:28px;width:auto;display:block;transition:filter .4s var(--ease)}
/* Logo white asset — invert to dark on light bg, keep white on dark bg */
[data-theme="light"] .nav.scrolled .nav__logo,
[data-theme="light"] .nav:not(.nav--on-dark) .nav__logo,
[data-theme="light"] .nav--on-dark.scrolled .nav__logo{filter:invert(1) brightness(0)}
[data-theme="light"] .nav--on-dark:not(.scrolled) .nav__logo{filter:none}
[data-theme="dark"] .nav__logo{filter:none}
.nav__brand-text{display:inline-block}
@media (max-width:520px){.nav__brand-text{display:none}}
.nav__brand .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(160,124,42,.6);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(160,124,42,.55)}70%{box-shadow:0 0 0 12px rgba(160,124,42,0)}100%{box-shadow:0 0 0 0 rgba(160,124,42,0)}}
.nav__menu{display:flex;gap:30px;align-items:center}
.nav__menu a{font-size:13px;letter-spacing:.02em;color:var(--fg-dim);position:relative;padding:6px 0}
.nav__menu a:hover,.nav__menu a.active{color:var(--fg)}
.nav__menu a.active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--accent)}
.nav__cta{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;transition:all .3s var(--ease);background:transparent}
.nav__cta:hover{background:var(--accent);color:#fff}
.nav__burger{display:none;width:40px;height:40px;flex-direction:column;gap:6px;justify-content:center;align-items:center}
.nav__burger span{width:22px;height:1px;background:var(--fg);transition:.3s var(--ease)}
.nav.open .nav__burger span:nth-child(1){transform:translateY(3.5px) rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}

/* Theme toggle — minimal icon-style button */
.theme-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  border:1px solid var(--line-bright);
  color:var(--fg-dim);background:transparent;
  cursor:pointer;position:relative;overflow:hidden;
  transition:color .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease);
  margin-right:6px;flex-shrink:0;
}
.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}
.theme-toggle svg{width:18px;height:18px;transition:transform .5s var(--ease), opacity .3s var(--ease)}
.theme-toggle .sun{display:block}
.theme-toggle .moon{display:none;position:absolute;inset:0;margin:auto}
[data-theme="dark"] .theme-toggle .sun{display:none}
[data-theme="dark"] .theme-toggle .moon{display:block;position:static}
.theme-toggle:active svg{transform:scale(.85)}
.nav--on-dark:not(.scrolled) .theme-toggle{color:rgba(255,255,255,.75);border-color:rgba(255,255,255,.3)}
.nav--on-dark:not(.scrolled) .theme-toggle:hover{color:#fff;border-color:#fff;background:rgba(255,255,255,.08)}

.nav__close{display:none}
@media (max-width:900px){
  .nav__menu{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100vh;height:100svh;background:var(--bg);flex-direction:column;justify-content:center;gap:28px;padding:80px 40px;transform:translateY(-102%);transition:transform .55s var(--ease);z-index:39;overflow-y:auto}
  .nav__close{display:inline-flex;position:absolute;top:20px;right:20px;width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--line-bright);border-radius:50%;color:var(--fg);background:transparent;transition:color .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease)}
  .nav__close:hover,.nav__close:active{color:var(--accent);border-color:var(--accent);transform:rotate(90deg)}
  .nav__close svg{width:20px;height:20px}
  .nav.open .nav__menu{transform:translateY(0)}
  .nav__menu a,
  .nav--on-dark .nav__menu a{font-size:22px;font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;color:var(--fg)}
  .nav__menu a:hover,.nav__menu a.active,
  .nav--on-dark .nav__menu a:hover,.nav--on-dark .nav__menu a.active{color:var(--accent)}
  .nav__burger{display:flex}
  .nav__cta{display:none}
  .nav.open .nav__cta{display:inline-flex;margin-top:16px}
  /* Theme toggle: always visible as icon next to burger (grouped right) */
  .nav{gap:0}
  .nav__menu{flex:initial}
  .theme-toggle{width:44px;height:44px;margin-right:0;margin-left:auto;z-index:41;position:relative;order:10}
  .theme-toggle svg{width:20px;height:20px}
  .nav__burger{order:11;margin-left:6px}
}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:12px;padding:16px 26px;font-family:var(--font-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;border:1px solid var(--fg);background:var(--fg);color:var(--bg);transition:all .35s var(--ease);font-weight:500;position:relative;overflow:hidden}
.btn:hover{background:var(--accent);border-color:var(--accent);color:#fff;gap:18px}
.btn--ghost{background:transparent;color:var(--fg);border-color:var(--line-bright)}
.btn--ghost:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.btn--gold{background:var(--accent);border-color:var(--accent);color:#fff}
.btn--gold:hover{background:var(--accent-hi);border-color:var(--accent-hi);color:#fff}
.btn .arrow{transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Reveal ---------- */
.r{opacity:0;transform:translateY(32px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.r.show{opacity:1;transform:none}
.r.d1{transition-delay:.08s}.r.d2{transition-delay:.16s}.r.d3{transition-delay:.24s}.r.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.r{opacity:1;transform:none;transition:none}}

/* ---------- Hero (always dramatic dark panel with car bg — same on both themes) ---------- */
.hero{min-height:100vh;position:relative;padding:180px var(--gutter) 120px;display:flex;flex-direction:column;justify-content:center;overflow:hidden;background:#0f0f0d;color:#fff}
.hero__slides{position:absolute;inset:0;z-index:0}
.hero__slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.6s var(--ease);animation:kenburns 20s ease-in-out infinite alternate;animation-play-state:paused}
.hero__slide.active{opacity:.58;animation-play-state:running}
@keyframes kenburns{0%{transform:scale(1.06) translate(-1%, -1%)}100%{transform:scale(1.14) translate(1%, 1%)}}
.hero__slides::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg, rgba(15,15,13,.85) 0%, rgba(15,15,13,.35) 55%, rgba(15,15,13,.15) 100%),linear-gradient(180deg, rgba(15,15,13,.3) 0%, transparent 30%, rgba(15,15,13,.8) 100%)}
.hero__inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;width:100%}
.hero__eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.hero__eyebrow .line{height:1px;width:60px;background:var(--accent-hi)}
.hero__eyebrow .eyebrow{color:var(--accent-hi)}
.hero__title{margin-bottom:32px;max-width:15ch;color:#fff}
.hero__title em{font-style:italic;font-family:"Playfair Display",Georgia,serif;color:var(--accent-hi);font-weight:400;letter-spacing:-.02em}
.hero__sub{max-width:54ch;font-size:clamp(15px,1.1vw,18px);color:rgba(255,255,255,.82);margin-bottom:48px;line-height:1.65}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px}
.hero .btn{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.hero .btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.hero .btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.hero .btn--ghost:hover{background:#fff;color:#0f0f0d;border-color:#fff}
@media (hover:none){
  .hero .btn:active{background:var(--accent);color:#fff;border-color:var(--accent)}
  .hero .btn--ghost:active{background:#fff;color:#0f0f0d;border-color:#fff}
}
.hero__meta{position:absolute;bottom:40px;left:var(--gutter);right:var(--gutter);display:flex;justify-content:space-between;align-items:flex-end;gap:24px;font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.5);z-index:3}
.hero__meta .scroll{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.75)}
.hero__meta .scroll .bar{width:1px;height:40px;background:linear-gradient(180deg,var(--accent-hi) 0%,transparent 100%);animation:scroll-bar 2.4s var(--ease) infinite}
@keyframes scroll-bar{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.01%{transform-origin:bottom}100%{transform:scaleY(.2);transform-origin:bottom}}
.hero__dots{position:absolute;bottom:120px;left:var(--gutter);z-index:3;display:flex;gap:10px}
.hero__dots button{width:28px;height:2px;background:rgba(255,255,255,.25);transition:.4s var(--ease);border-radius:0}
.hero__dots button.active{background:var(--accent-hi);width:48px}
@media (max-width:900px){.hero__dots{display:none}}
@media (prefers-reduced-motion:reduce){.hero__slide{animation:none}}

/* ---------- USP row ---------- */
.usps{background:var(--usp-bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.usps__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.usp{padding:56px 40px;border-right:1px solid var(--line);position:relative;background:var(--usp-bg)}
.usp:last-child{border-right:none}
.usp__num{font-family:var(--font-mono);font-size:11px;color:var(--accent);letter-spacing:.2em;margin-bottom:18px}
.usp__t{font-family:var(--font-display);font-size:22px;text-transform:uppercase;letter-spacing:.01em;margin-bottom:12px;color:var(--fg)}
.usp__d{color:var(--fg-dim);font-size:14.5px;line-height:1.6;max-width:32ch}
@media (max-width:900px){.usps__grid{grid-template-columns:1fr}.usp{border-right:none;border-bottom:1px solid var(--line);padding:36px var(--gutter)}.usp:last-child{border-bottom:none}}

/* ---------- Section head ---------- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:56px;gap:40px;flex-wrap:wrap}
.sec-head__l{max-width:60%}
.sec-head__eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.sec-head__eyebrow .line{height:1px;width:40px;background:var(--accent)}
.sec-head__sub{color:var(--fg-dim);max-width:44ch;font-size:15px;margin-top:22px}

/* ---------- Fleet grid ---------- */
.fleet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media (max-width:1100px){.fleet-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.fleet-grid{grid-template-columns:1fr}}

.car{background:var(--bg-card);border:1px solid var(--line);overflow:hidden;position:relative;display:flex;flex-direction:column;transition:border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease)}
.car:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 18px 40px -20px rgba(20,16,8,.18)}
[data-theme="dark"] .car:hover{box-shadow:0 0 0 1px rgba(201,169,97,.2), 0 18px 40px -20px rgba(0,0,0,.8)}
.car__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--spec-bg)}
.car__media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease), filter .5s var(--ease)}
[data-theme="dark"] .car__media img{filter:saturate(.9) brightness(.92)}
.car:hover .car__media img{transform:scale(1.06);filter:saturate(1) brightness(1)}
.car__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.25) 100%)}
.car__tag{position:absolute;top:14px;left:14px;z-index:2;padding:6px 10px;background:var(--chip-bg);color:var(--chip-fg);backdrop-filter:blur(6px);font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--line)}
.car__price{position:absolute;top:14px;right:14px;z-index:2;padding:6px 10px;background:var(--accent);color:#fff;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em}
[data-theme="dark"] .car__price{color:#0a0a0a}
.car__body{padding:26px;display:flex;flex-direction:column;flex:1}
.car__brand{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;color:var(--muted);text-transform:uppercase;margin-bottom:8px}
.car__name{font-family:var(--font-display);font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:.01em;margin-bottom:20px;line-height:1.2;color:var(--fg)}
.car__specs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:22px}
.car__spec{background:var(--spec-bg);border:1px solid var(--line);padding:10px;text-align:center}
.car__spec__l{font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;margin-bottom:4px}
.car__spec__v{font-family:var(--font-mono);font-size:13px;color:var(--fg);font-weight:500}
.car__foot{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
.car__rate{font-family:var(--font-mono);font-size:13px}
.car__rate span{color:var(--muted);font-size:10px;letter-spacing:.15em;display:block;margin-bottom:2px}
.car__rate strong{font-weight:700;color:var(--fg);font-size:20px}
.car__rate em{color:var(--muted);font-style:normal;font-size:11px;margin-left:4px}
.car__cta{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);display:inline-flex;gap:8px;align-items:center;transition:gap .3s var(--ease)}
.car__cta:hover{gap:14px;color:var(--accent-hi)}

/* ---------- Filter bar ---------- */
.filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:40px;padding:6px;border:1px solid var(--line);align-self:flex-start;background:var(--bg-card)}
.filter-btn{padding:10px 20px;font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-dim);transition:.3s var(--ease)}
.filter-btn:hover{color:var(--fg)}
.filter-btn.active{background:var(--accent);color:#fff}
[data-theme="dark"] .filter-btn.active{color:#0a0a0a}

/* ---------- Split section ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:48px}}
.split__img{position:relative;aspect-ratio:4/5;overflow:hidden}
.split__img img{width:100%;height:100%;object-fit:cover}

/* ---------- Stats strip (always dark for drama) ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--bg-deep);color:#fff}
.stat{padding:60px 32px;border-right:1px solid rgba(255,255,255,.08);text-align:left}
.stat:last-child{border-right:none}
.stat__n{font-family:var(--font-display);font-size:clamp(40px,5vw,64px);font-weight:700;line-height:1;color:var(--accent-hi);margin-bottom:10px;letter-spacing:-.02em}
.stat__l{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6)}
@media (max-width:800px){.stats{grid-template-columns:1fr 1fr}.stat{border-bottom:1px solid rgba(255,255,255,.08);padding:36px 24px}.stat:nth-child(2n){border-right:none}.stat:nth-child(n+3){border-bottom:none}}

/* ---------- Gallery strip ---------- */
.strip{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.strip__item{aspect-ratio:3/4;overflow:hidden;position:relative;background:var(--spec-bg)}
.strip__item img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.strip__item:hover img{transform:scale(1.08)}
@media (max-width:900px){.strip{grid-template-columns:1fr 1fr}}

/* ---------- CTA block (always dark) ---------- */
.cta-block{background:var(--bg-deep);color:#fff;padding:clamp(48px,6vw,96px);display:grid;grid-template-columns:2fr 1fr;gap:64px;align-items:end;position:relative;overflow:hidden}
.cta-block::before{content:"";position:absolute;top:-40%;right:-10%;width:60%;height:180%;background:radial-gradient(ellipse at center, rgba(194,154,60,.22) 0%, transparent 70%);pointer-events:none}
.cta-block__t{font-family:var(--font-display);font-size:clamp(32px,5vw,68px);text-transform:uppercase;line-height:.95;letter-spacing:-.01em;color:#fff}
.cta-block__t em{font-style:italic;font-family:"Playfair Display",Georgia,serif;color:var(--accent-hi);font-weight:400}
.cta-block__actions{display:flex;flex-direction:column;gap:14px;align-items:flex-start;position:relative;z-index:1}
.cta-block .btn{background:#fff;color:#0f0f0d;border-color:#fff}
.cta-block .btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.cta-block .btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.cta-block .btn--ghost:hover{background:#fff;color:#0f0f0d;border-color:#fff}
.cta-block .btn--gold{background:var(--accent-hi);color:#0f0f0d;border-color:var(--accent-hi)}
.cta-block .btn--gold:hover{background:#fff;color:#0f0f0d;border-color:#fff}
@media (max-width:800px){.cta-block{grid-template-columns:1fr;gap:32px}}

/* ---------- Footer (always dark) ---------- */
.ft{background:var(--bg-deep);color:rgba(255,255,255,.7);padding:80px var(--gutter) 40px;position:relative;z-index:1;border-top:1px solid #1a1a17}
.ft__top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px}
@media (max-width:900px){.ft__top{grid-template-columns:1fr 1fr;gap:40px}}
@media (max-width:520px){.ft__top{grid-template-columns:1fr}}
.ft__brand{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:.08em;margin-bottom:20px;color:#fff}
.ft__about{color:rgba(255,255,255,.6);font-size:14px;max-width:40ch;line-height:1.6}
.ft h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-hi);margin-bottom:22px;font-weight:500}
.ft ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ft ul a{color:rgba(255,255,255,.7);font-size:14px}
.ft ul a:hover{color:var(--accent-hi)}
.ft__bottom{display:flex;justify-content:space-between;gap:24px;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:rgba(255,255,255,.4);text-transform:uppercase;flex-wrap:wrap}

/* ---------- Contact card ---------- */
.contact-info{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);background:var(--bg-card)}
@media (max-width:900px){.contact-info{grid-template-columns:1fr}}
.ci{padding:40px;border-right:1px solid var(--line)}
.ci:last-child{border-right:none}
@media (max-width:900px){.ci{border-right:none;border-bottom:1px solid var(--line)}.ci:last-child{border-bottom:none}}
.ci__l{font-family:var(--font-mono);font-size:10px;color:var(--accent);letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px}
.ci__v{font-family:var(--font-display);font-size:22px;text-transform:uppercase;letter-spacing:.02em;line-height:1.25;color:var(--fg)}
.ci__v a:hover{color:var(--accent)}
.ci__sub{color:var(--fg-dim);font-size:13px;margin-top:10px}

/* ---------- Intro animation (smooth cross-fade to hero) ---------- */
.intro{
  position:fixed;inset:0;z-index:100;background:#0f0f0d;
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:30px;
  overflow:hidden;pointer-events:all;
  transition:opacity 1.1s cubic-bezier(.4,0,.2,1), backdrop-filter 1.1s var(--ease);
}
.intro::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at 50% 50%, rgba(194,154,60,.12) 0%, transparent 60%);
  opacity:0;transition:opacity .8s var(--ease);
}
.intro.exiting::before{opacity:1}
.intro.exiting{opacity:0;pointer-events:none}
.intro__count{position:absolute;top:32px;right:32px;font-family:var(--font-mono);font-size:11px;letter-spacing:.24em;color:rgba(255,255,255,.4);opacity:0;animation:intro-count 2.2s var(--ease) .15s forwards;z-index:1}
.intro__corner{position:absolute;top:32px;left:32px;font-family:var(--font-mono);font-size:11px;letter-spacing:.24em;color:rgba(255,255,255,.4);opacity:0;animation:intro-count 2.2s var(--ease) .15s forwards;z-index:1}
@keyframes intro-count{0%{opacity:0}15%{opacity:.9}90%{opacity:.9}100%{opacity:0}}
.intro__line-wrap{display:flex;align-items:center;gap:18px;font-family:var(--font-mono);font-size:12px;letter-spacing:.2em;color:var(--accent-hi);text-transform:uppercase;opacity:0;animation:intro-sub 1.4s var(--ease) .1s forwards;z-index:1;position:relative;transition:opacity .6s var(--ease)}
.intro.exiting .intro__line-wrap{opacity:0!important;animation:none}
@keyframes intro-sub{0%{opacity:0;transform:translateY(8px)}40%{opacity:1;transform:none}85%{opacity:1}100%{opacity:0;transform:translateY(-6px)}}
.intro__line-wrap .hr{height:1px;width:0;background:var(--accent-hi);animation:intro-hr 1.6s var(--ease) .2s forwards}
@keyframes intro-hr{0%{width:0}100%{width:60px}}
.intro__title{
  font-family:var(--font-display);font-size:clamp(20px,7vw,96px);font-weight:700;
  text-transform:uppercase;letter-spacing:-.015em;line-height:.95;text-align:center;color:#fff;
  display:flex;flex-wrap:nowrap;justify-content:center;gap:.14em;
  max-width:94vw;
  z-index:1;position:relative;
  transition:opacity .9s cubic-bezier(.4,0,.2,1), transform 1.1s cubic-bezier(.4,0,.2,1), filter .9s var(--ease);
}
@media (max-width:640px){.intro__title{font-size:22px;gap:.1em}}
@media (max-width:380px){.intro__title{font-size:19px}}
.intro__title span{display:inline-block;opacity:0;transform:translateY(40px) rotateX(-60deg);animation:intro-letter 1s var(--ease) forwards;transform-origin:bottom}
.intro__title .em{color:var(--accent-hi);font-style:italic;font-family:"Playfair Display",Georgia,serif;font-weight:400}
@keyframes intro-letter{to{opacity:1;transform:none}}
.intro.exiting .intro__title{opacity:0;transform:scale(1.14) translateY(-24px);filter:blur(6px)}
.intro.exiting .intro__count,.intro.exiting .intro__corner{opacity:0;transition:opacity .5s var(--ease)}
@media (prefers-reduced-motion:reduce){.intro,.intro *{animation:none!important;transition:none!important}.intro{display:none}}

/* ---------- Price table ---------- */
.price-table{border:1px solid var(--line);overflow:hidden;background:var(--bg-card)}
.price-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;padding:20px 28px;border-bottom:1px solid var(--line);align-items:center;gap:16px;transition:background .3s var(--ease)}
.price-row:last-child{border-bottom:none}
.price-row:hover{background:var(--spec-bg)}
.price-row--head{background:var(--bg-deep);color:rgba(255,255,255,.6);font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;padding:14px 28px}
.price-row--head:hover{background:var(--bg-deep)}
.price-row strong{font-family:var(--font-display);font-size:15px;text-transform:uppercase;letter-spacing:.02em;color:var(--fg);font-weight:700}
.price-row .val{font-family:var(--font-mono);font-weight:500;color:var(--fg-dim)}
.price-row .val--gold{color:var(--accent);font-weight:700}
@media (max-width:720px){.price-row{grid-template-columns:1.5fr 1fr 1fr;font-size:13px;padding:16px 20px}.price-row .hide-s{display:none}.price-row--head{padding:12px 20px}}

/* ---------- Tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:900px){.tiers{grid-template-columns:1fr}}
.tier{background:var(--bg-card);border:1px solid var(--line);padding:36px 32px;display:flex;flex-direction:column;gap:16px;transition:border-color .3s var(--ease), box-shadow .3s var(--ease)}
.tier:hover{border-color:var(--accent);box-shadow:0 18px 40px -20px rgba(20,16,8,.14)}
.tier--featured{border-color:var(--accent);background:var(--tier-featured-bg);position:relative}
.tier--featured::before{content:"REKOMENDOWANE";position:absolute;top:0;right:24px;transform:translateY(-50%);background:var(--accent);color:#fff;font-family:var(--font-mono);font-size:9px;letter-spacing:.22em;padding:6px 12px;font-weight:600}
[data-theme="dark"] .tier--featured::before{color:#0a0a0a}

.tier__name{font-family:var(--font-display);font-size:22px;text-transform:uppercase;letter-spacing:.02em;color:var(--fg)}
.tier__price{font-family:var(--font-display);font-size:42px;color:var(--accent);font-weight:700;letter-spacing:-.01em}
.tier__price em{font-family:var(--font-mono);font-size:12px;color:var(--muted);font-style:normal;letter-spacing:.15em;text-transform:uppercase;margin-left:6px}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin:8px 0 20px;color:var(--fg-dim);font-size:14px}
.tier ul li{padding-left:24px;position:relative}
.tier ul li::before{content:"";position:absolute;left:0;top:8px;width:14px;height:1px;background:var(--accent)}

/* ---------- Page head (always dark panel with bg image) ---------- */
.page-head{padding:180px var(--gutter) 80px;position:relative;overflow:hidden;background:var(--bg-deep);color:#fff;border-bottom:1px solid var(--bg-deep)}
.page-head__bg{position:absolute;inset:0;z-index:0;opacity:.35}
.page-head__bg img{width:100%;height:100%;object-fit:cover}
.page-head__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,15,13,.85) 0%, rgba(15,15,13,.2) 100%)}
.page-head__inner{position:relative;z-index:1;max-width:var(--max);margin:0 auto}
.page-head__eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.page-head__eyebrow .line{height:1px;width:40px;background:var(--accent-hi)}
.page-head__eyebrow .eyebrow{color:var(--accent-hi)}
.page-head h1{margin-bottom:28px;max-width:18ch;color:#fff}
.page-head h1 em{color:var(--accent-hi);font-style:italic;font-family:"Playfair Display",Georgia,serif;font-weight:400}
.page-head__sub{max-width:58ch;color:rgba(255,255,255,.78);font-size:16px;line-height:1.65}

/* ---------- Car placeholder (for cars without real photo yet) ---------- */
.car__media--soon{background:
  radial-gradient(ellipse at 30% 20%, rgba(194,154,60,.14) 0%, transparent 60%),
  linear-gradient(135deg, #1a1a17 0%, #0f0f0d 100%);
  display:flex;align-items:center;justify-content:center;
}
.car__placeholder{text-align:center;display:flex;flex-direction:column;gap:10px;padding:24px}
.car__placeholder__mark{font-family:var(--font-display);font-size:36px;font-weight:700;letter-spacing:.1em;color:var(--accent-hi);line-height:1}
.car__placeholder__name{font-family:var(--font-display);font-size:15px;text-transform:uppercase;letter-spacing:.08em;color:#fff;margin-top:6px}
.car__placeholder__note{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:4px}

/* ---------- Smoother theme transition ---------- */
body,.car,.tier,.usp,.contact-info,.ci,.price-table,.filters,.filter-btn,.form input,.form select,.form textarea,.nav,.nav__cta,.btn,.theme-toggle{
  transition:background-color .5s var(--ease), color .4s var(--ease), border-color .4s var(--ease);
}
.nav,.nav__cta,.btn,.filter-btn,.theme-toggle,.car,.tier{will-change:auto}
/* Preserve fast hover transitions separately */
.btn{transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease), gap .35s var(--ease), transform .35s var(--ease)}
.car{transition:background-color .5s var(--ease), border-color .5s var(--ease), transform .5s var(--ease), box-shadow .5s var(--ease)}
.tier{transition:background-color .5s var(--ease), border-color .5s var(--ease), box-shadow .5s var(--ease)}

/* ---------- Typography polish ---------- */
body{font-weight:400;letter-spacing:-.002em}
.prose p{font-size:16.5px;line-height:1.7}
.hero__sub,.page-head__sub{font-weight:400;letter-spacing:-.003em}
h3.h-display,.usp__t,.car__name,.tier__name,.ci__v{letter-spacing:.015em}
/* Smaller heads use Inter, not Syncopate — better at small sizes */
.ci__v{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:.04em;line-height:1.3;text-transform:none}
.ci__v a{color:var(--fg)}

/* ---------- Mobile optimization (readability + tap targets) ---------- */
@media (max-width:900px){
  .nav__menu a{font-size:26px}
  .hero{padding:130px var(--gutter) 90px;min-height:100svh;justify-content:flex-start}
  .hero__title{margin-bottom:22px}
  .hero__sub{margin-bottom:28px;font-size:14.5px;line-height:1.6}
  .hero__actions{flex-direction:column;align-items:stretch;gap:10px}
  .hero__actions .btn{justify-content:center;width:100%}
  .hero__meta{position:static;margin-top:36px;font-size:10px;flex-direction:row;flex-wrap:wrap;align-items:center;gap:14px;padding:0;color:rgba(255,255,255,.55)}
  .hero__meta .scroll{display:none}
  .sec-head{margin-bottom:40px;gap:28px}
  .sec-head__l{max-width:100%}
  .sec-head .btn--ghost{align-self:flex-start}
  .car__body{padding:22px}
  .car__name{font-size:17px;letter-spacing:.02em}
  .car__specs{grid-template-columns:repeat(3,1fr);gap:6px}
  .car__spec{padding:8px 4px}
  .car__spec__v{font-size:12px}
  .car__rate strong{font-size:18px}
  .tier{padding:30px 24px}
  .tier__price{font-size:36px}
  .price-row{font-size:13.5px;padding:16px 18px;gap:12px}
  .ci{padding:32px 24px}
  .ci__v{font-size:18px}
  .cta-block{padding:48px 28px;gap:28px}
  .cta-block__t{font-size:clamp(30px,7vw,44px)}
  .ft{padding:60px var(--gutter) 30px}
  .ft__bottom{font-size:10px}
  .btn{padding:16px 22px;font-size:11px}
  .nav__cta{padding:12px 16px;font-size:10px}
  .filter-btn{padding:12px 18px;font-size:11px}
}
@media (max-width:640px){
  body{font-size:16px;line-height:1.6}
  .hero__title{max-width:100%}
  .hero__sub{font-size:15.5px;line-height:1.65}
  .strip{gap:2px}
  .strip__item{aspect-ratio:1/1}
  .car__tag,.car__price{font-size:9.5px;padding:5px 8px}
  .tier--featured::before{right:16px;font-size:8.5px;padding:5px 10px}
}
/* Bigger tap targets on touch devices */
@media (hover:none){
  .btn,.nav__cta,.filter-btn,.car__cta,.theme-toggle,.hero__dots button{min-height:44px;display:inline-flex;align-items:center}
  .hero__dots button{min-height:auto;padding:8px 0}
  .hero__dots button::after{content:"";position:absolute;inset:-14px}
  .hero__dots button{position:relative}
  .car__cta{min-height:44px}
}

/* ---------- Prose ---------- */
.prose{max-width:72ch;color:var(--fg-dim);font-size:16px;line-height:1.75}
.prose p{margin-bottom:22px}
.prose h3{font-family:var(--font-display);font-size:22px;text-transform:uppercase;letter-spacing:.02em;color:var(--fg);margin:40px 0 18px}
.prose strong{color:var(--fg)}
.prose ul{margin:18px 0 22px 20px;color:var(--fg-dim)}
.prose ul li{margin-bottom:10px}
