/* TEJAT — Index page Stylesheet
   Hero · Section-head · Fleet · Car cards · Contact · Channels · Form · Bigtype
   Page-specific styles for index.html. Common patterns live in base.css. */

/* ---------------- HERO ---------------- */
.hero{
  min-height:100vh; /* fallback */
  min-height:100svh; /* iOS-stable: never changes with address-bar */
  position:relative;
  display:flex;flex-direction:column;justify-content:center;
  padding:var(--space-11) var(--space-7) var(--space-8);
  overflow:hidden;
  background:#050505;
  /* GPU-layer hint stabilises pinType:'transform' scrub on iOS */
  transform:translateZ(0);
  -webkit-transform:translateZ(0);
  will-change:transform;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
}
.hero-bg picture, .hero-bg img{
  display:block;width:100%;height:100%;
}
.hero-bg img{
  object-fit:cover;
  object-position:center center;
  filter:contrast(1.04) saturate(0.98);
}
.hero-bg canvas{
  position:absolute;inset:0;
  width:100%;height:100%;
  display:block;
}
html.hero-scrub-active .hero-bg img{display:none}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg, rgba(5,5,5,0.78) 0%, rgba(5,5,5,0.45) 28%, rgba(5,5,5,0.15) 55%, rgba(5,5,5,0) 80%);
}
.hero-overlay::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(5,5,5,0.35) 0%, transparent 20%, transparent 70%, rgba(5,5,5,0.85) 100%);
}
.hero-grid-bg{
  position:absolute;inset:0;z-index:1;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 90% 70% at 30% 50%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 30% 50%, #000 30%, transparent 80%);
  opacity:.3;
  pointer-events:none;
}
.hero-inner{
  max-width:var(--max);width:100%;margin:0 auto;
  position:relative;z-index:2;
}
.hero-eyebrow{
  margin-bottom:32px;
  opacity:0;transform:translateY(20px);
}
.hero-claim{
  font-size:var(--text-4xl);
  margin-bottom:var(--space-6);
  max-width:14ch;
}
.hero-claim em{
  font-style:italic;font-weight:300;
  color:var(--chrome-1);
}
/* The .line wrappers mask the "rise-up" entry animation. With line-height:0.95
   on .display + overflow:hidden, descenders (j, g, y, ł, p) would be clipped.
   padding-bottom + matching negative margin reclaims that clearance without
   changing the visual rhythm of the headline. */
.hero-claim .line{
  display:block;
  overflow:hidden;
  padding-bottom:0.18em;
  margin-bottom:-0.18em;
}
.hero-claim .line > span{display:inline-block}
.hero-sub{
  font-size:clamp(15px,1.15vw,18px);
  color:var(--fg-dim);
  max-width:46ch;
  margin-bottom:48px;
  line-height:1.6;
  opacity:0;transform:translateY(20px);
}
.hero-actions{
  display:flex;gap:16px;flex-wrap:wrap;
  opacity:0;transform:translateY(20px);
}

.hero-meta{
  position:absolute;bottom:32px;left:40px;right:40px;
  display:flex;justify-content:space-between;align-items:flex-end;
  z-index:2;font-size:11px;color:var(--fg-mute);
  letter-spacing:0.18em;text-transform:uppercase;
}
.hero-meta .scroll{
  display:flex;align-items:center;gap:14px;
}
.hero-meta .scroll-line{
  width:1px;height:36px;background:linear-gradient(to bottom, var(--fg-mute), transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{transform:scaleY(1);opacity:.6}
  50%{transform:scaleY(.5) translateY(8px);opacity:1}
}

/* ---------------- SECTIONS ---------------- */
section{padding:var(--space-11) var(--space-7);position:relative}
.section-head{
  display:grid;grid-template-columns:1fr 2fr;gap:var(--space-8);
  margin-bottom:var(--space-8);align-items:end;
}
.section-head h2{
  font-size:var(--text-3xl);
  max-width:14ch;
}
.section-head p{
  color:var(--fg-dim);max-width:50ch;font-size:16px;line-height:1.7;
}

/* ---------------- FLEET ---------------- */
.fleet{background:var(--bg)}
.fleet-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;background:var(--line);
  border:1px solid var(--line);
}
.car{
  --car-color: var(--accent);
  background:var(--bg);
  padding:var(--space-7);
  display:flex;flex-direction:column;
  position:relative;
  /* Cinematic-Reveal initial state — controlled via .is-revealed (set by ScrollTrigger
     in index.html inline JS, or by IO fallback in older browsers). GPU-friendly:
     transform + opacity only, no layout-shifting properties. */
  opacity:0;
  transform:translate3d(0, 32px, 0);
  transition:
    opacity .8s var(--ease-out-quart),
    transform .9s var(--ease-out-quart),
    background-color .35s var(--ease);
  transition-delay: calc(var(--car-idx, 0) * 70ms);
}
.car.is-revealed{
  opacity:1;
  transform:translate3d(0, 0, 0);
}
/* Top accent strip in per-car color — sweeps left→right with the reveal */
.car::before{
  content:"";
  position:absolute;top:0;left:0;right:0;
  height:3px;
  background:var(--car-color);
  opacity:.55;
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .9s var(--ease-out-quart), opacity .35s var(--ease);
  transition-delay: calc(var(--car-idx, 0) * 70ms + 220ms);
  will-change:transform;
}
.car.is-revealed::before{
  transform:scaleX(1);
}
@media (hover:hover){
  .car:hover{
    background:color-mix(in srgb, var(--car-color) 7%, #0F0F0F);
    transform:translate3d(0, -4px, 0);
    box-shadow:0 24px 60px -20px color-mix(in srgb, var(--car-color) 28%, transparent);
    transition-delay:0s;
  }
  .car:hover::before{opacity:1;transition-delay:0s}
}
.car-image{
  aspect-ratio: 16/10;
  margin-bottom:var(--space-6);
  position:relative;overflow:hidden;
  background:radial-gradient(ellipse 70% 60% at 50% 45%, #1f1f1f 0%, #0c0c0c 70%, #060606 100%);
  /* Clip-Path-Mask Wisch-Reveal — wisches from left→right when card enters viewport */
  clip-path:inset(0 100% 0 0);
  -webkit-clip-path:inset(0 100% 0 0);
  transition:clip-path .95s var(--ease-out-quart);
  transition-delay: calc(var(--car-idx, 0) * 70ms + 120ms);
}
.car.is-revealed .car-image{
  clip-path:inset(0 0 0 0);
  -webkit-clip-path:inset(0 0 0 0);
}
.car-image img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 55%;
  /* Image starts slightly zoomed + softly blurred for "coming into focus" on reveal.
     Parallax-drift is driven from inline JS via translate3d (see initFleetReveal). */
  transform:translate3d(0, -24px, 0) scale(1.08);
  filter:contrast(1.04) saturate(0.95) brightness(1) blur(3px);
  transition:transform 1s var(--ease-out-quart), filter .9s var(--ease-out-quart);
  transition-delay: calc(var(--car-idx, 0) * 70ms + 200ms);
}
.car.is-revealed .car-image img{
  transform:translate3d(0, 0, 0) scale(1);
  filter:contrast(1.04) saturate(0.95) brightness(1) blur(0);
}
@media (hover:hover){
  .car:hover .car-image img{
    /* Drive-in: image slides left and scales — feels like a car driving into the card */
    transform:translate3d(-22px, 0, 0) scale(1.06);
    filter:contrast(1.06) saturate(1.02) brightness(1.08) blur(0)
           drop-shadow(0 14px 24px rgba(0,0,0,0.55));
    transition-duration:.6s;
    transition-delay:0s;
  }
}
.car-image::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 40% at 50% 95%, rgba(0,0,0,0.55), transparent 70%),
    linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,0.25) 100%);
  pointer-events:none;
}
.car-image .seg-tag{
  position:absolute;top:16px;left:16px;
  z-index:2;
  font-family:var(--font-sans);
  font-size:10px;letter-spacing:0.22em;
  color:var(--fg);text-transform:uppercase;
  border:1px solid rgba(255,255,255,0.18);
  padding:6px 10px;
  background:rgba(0,0,0,0.55);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;gap:8px;
}
.car-image .seg-tag::before{
  content:"";width:5px;height:5px;background:var(--car-color, var(--accent));
}
.car-segment{
  display:flex;align-items:center;gap:10px;
  margin-bottom:14px;
}
.car-segment .seg-num{
  font-family:var(--font-sans);
  font-size:11px;color:var(--fg-mute);
  letter-spacing:0.18em;
}
.car-segment .seg-name{
  font-size:11px;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--car-color, var(--accent));
  font-weight:500;
}
.car-model{
  font-family:var(--font-serif);
  font-size:var(--text-2xl);
  font-weight:300;letter-spacing:-0.02em;
  margin-bottom:var(--space-2);
  line-height:1.1;
  font-optical-sizing:auto;
  font-variation-settings:"opsz" 96;
}
.car-tag{
  color:var(--fg-mute);font-size:13px;
  margin-bottom:28px;
  letter-spacing:0.04em;
}
.car-spec{
  display:flex;gap:24px;margin-bottom:28px;
  padding-top:24px;border-top:1px solid var(--line);
}
.car-spec .spec{flex:1}
.car-spec .spec-label{
  font-size:10px;color:var(--fg-mute);
  letter-spacing:0.18em;text-transform:uppercase;
  margin-bottom:6px;
}
.car-spec .spec-val{font-size:14px;color:var(--fg)}
.car-foot{
  margin-top:auto;
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:16px;
}
.car-price{display:flex;flex-direction:column}
.car-price .from{
  font-size:10px;color:var(--fg-mute);
  letter-spacing:0.2em;text-transform:uppercase;
  margin-bottom:4px;
}
.car-price .val{
  font-family:var(--font-serif);font-weight:300;
  font-size:32px;letter-spacing:-0.02em;line-height:1;
}
.car-price .val .pln{font-size:14px;color:var(--fg-dim);margin-left:2px}
.car-price .per{font-size:11px;color:var(--fg-mute);margin-top:6px;letter-spacing:0.08em}
.spec-tbd{
  font-family:var(--font-serif);font-weight:300;
  font-size:20px;letter-spacing:-0.01em;line-height:1.2;
  color:var(--fg-dim);
  font-style:italic;
  display:inline-block;
  padding-top:14px;
}
.car-cta{
  border-bottom:1px solid var(--fg-dim);
  padding:12px 0 6px;
  min-height:44px;
  font-size:11px;letter-spacing:0.22em;
  text-transform:uppercase;
  transition:all .3s var(--ease);
  white-space:nowrap;
  display:inline-flex;align-items:flex-end;
}
.car-cta:hover{
  color:var(--accent);
  border-color:var(--accent);
}

/* ---------------- CONTACT ---------------- */
.contact{background:var(--bg-3);padding:140px 0}
.contact-wrap{
  max-width:var(--max);margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:1fr 1fr;gap:100px;
}
.contact-aside h2{
  font-size:clamp(36px,4.5vw,64px);
  margin-bottom:28px;
}
.contact-aside p{
  color:var(--fg-dim);font-size:16px;line-height:1.7;
  margin-bottom:48px;max-width:38ch;
}
.contact-channels{
  display:flex;flex-direction:column;gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.channel{
  background:var(--bg-3);
  padding:22px 24px;
  min-height:44px;
  display:flex;align-items:center;gap:20px;
  transition:background .3s var(--ease);
}
.channel:hover{background:#181818}
.channel-icon{
  width:44px;height:44px;
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:all .3s var(--ease);
}
.channel:hover .channel-icon{border-color:var(--accent);color:var(--accent)}
.channel-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.5}
.channel-meta .channel-label{
  font-size:10px;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--fg-mute);
  margin-bottom:4px;
}
.channel-meta .channel-val{
  font-size:16px;color:var(--fg);font-weight:400;
}
.channel-arrow{
  margin-left:auto;color:var(--fg-mute);
  transition:transform .3s var(--ease), color .3s var(--ease);
}
.channel:hover .channel-arrow{color:var(--accent);transform:translateX(4px)}

/* ---------------- FORM ---------------- */
.form{display:flex;flex-direction:column;gap:0}
.field{
  border-bottom:1px solid var(--line-strong);
  padding:22px 0;
  position:relative;
  transition:border-color .3s var(--ease);
}
.field:focus-within{border-color:var(--fg)}
.field label{
  font-size:11px;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--fg-mute);
  margin-bottom:10px;display:block;
  transition:color .3s var(--ease);
}
.field:focus-within label{color:var(--accent)}
.field input,
.field textarea,
.field select{
  width:100%;
  background:transparent;
  border:none;outline:none;
  font-size:17px;color:var(--fg);
  font-family:var(--font-sans);
  padding:2px 0;
  min-height:32px;
}
.field textarea{resize:none;min-height:80px;line-height:1.5}
.field select{
  -webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1L6 6L11 1' stroke='%23A3A3A3' stroke-width='1.2'/></svg>");
  background-repeat:no-repeat;background-position:right center;
  padding-right:24px;cursor:pointer;
}
.field select option{background:var(--bg-2);color:var(--fg)}
.field .error{
  position:absolute;bottom:6px;right:0;
  font-size:11px;color:var(--accent-2);
  letter-spacing:0.05em;opacity:0;
  transition:opacity .25s var(--ease);
}
.field.invalid{border-color:var(--accent-2)}
.field.invalid .error{opacity:1}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.form-foot{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:36px;gap:24px;
}
.form-consent{
  font-size:12px;color:var(--fg-mute);max-width:42ch;line-height:1.5;
}
.form-submit{
  background:var(--accent);color:#fff;
  padding:20px 36px;
  min-height:44px;
  font-size:11px;letter-spacing:0.24em;
  text-transform:uppercase;font-weight:500;
  display:inline-flex;align-items:center;gap:14px;
  transition:background .3s var(--ease);
  white-space:nowrap;
}
.form-submit:hover{background:var(--accent-2)}
.form-submit .arrow{
  width:18px;height:1px;background:#fff;position:relative;transition:width .3s var(--ease);
}
.form-submit .arrow::after{
  content:"";position:absolute;right:0;top:-3px;
  width:7px;height:7px;border-top:1px solid #fff;border-right:1px solid #fff;
  transform:rotate(45deg);
}
.form-submit:hover .arrow{width:28px}

.form-success{
  margin-top:24px;padding:18px 22px;
  border:1px solid rgba(160,40,40,0.4);
  background:rgba(160,40,40,0.07);
  color:var(--fg);font-size:14px;
  display:none;align-items:center;gap:14px;
}
.form-success.show{display:flex}
.form-success::before{
  content:"";width:6px;height:6px;background:var(--accent);
}
.form-error{
  margin-top:24px;padding:18px 22px;
  border:1px solid rgba(201,48,44,0.5);
  background:rgba(201,48,44,0.08);
  color:var(--fg);font-size:14px;
  display:none;align-items:center;gap:14px;
}
.form-error.show{display:flex}
.form-error a{color:var(--accent-2);text-decoration:underline}

/* ---------------- HONEYPOT (visually hidden, accessible to bots) ---------------- */
.hp-field{
  position:absolute;left:-9999px;top:-9999px;
  width:1px;height:1px;overflow:hidden;
  opacity:0;pointer-events:none;
}

/* ---------------- CHECKBOX FIELDS ----------------
   NB: higher specificity selectors (.field-checkbox label.checkbox …)
   are required to override the parent .field label uppercase/eyebrow styles. */
.field-checkbox{
  border-bottom:none;
  padding:20px 0 6px;
}
.field-checkbox:first-of-type{
  border-top:1px solid var(--line-strong);
  margin-top:14px;
  padding-top:24px;
}
.field-checkbox + .field-checkbox{padding-top:10px}
.field-checkbox.invalid{border-color:transparent}
.field-checkbox .error{
  position:static;opacity:0;
  margin:8px 0 0 36px;
  display:block;
  font-size:12px;color:var(--accent-2);
  letter-spacing:0.05em;text-transform:none;
}
.field-checkbox.invalid .error{opacity:1}

.field-checkbox label.checkbox,
.field-checkbox .checkbox{
  display:flex !important;
  align-items:flex-start;
  gap:14px;
  cursor:pointer;
  font-size:14px !important;
  font-family:var(--font-sans);
  font-weight:400;
  line-height:1.6;
  letter-spacing:0 !important;
  text-transform:none !important;
  color:var(--fg-dim) !important;
  margin-bottom:0 !important;
  -webkit-user-select:none;user-select:none;
  min-height:44px;
}
.field-checkbox .checkbox input{
  position:absolute;opacity:0;width:0;height:0;pointer-events:none;
}
.field-checkbox .checkbox-box{
  flex:0 0 auto;
  width:24px;height:24px;
  border:2px solid var(--fg-mute);
  background:rgba(255,255,255,0.06);
  margin-top:0;
  position:relative;
  transition:border-color .2s var(--ease), background .2s var(--ease), transform .15s var(--ease);
  border-radius:4px;
  display:block;
}
.field-checkbox .checkbox input:focus-visible + .checkbox-box{
  outline:2px solid var(--accent);outline-offset:3px;
}
.field-checkbox .checkbox:hover .checkbox-box{
  border-color:var(--fg);
  background:rgba(255,255,255,0.12);
}
.field-checkbox .checkbox:active .checkbox-box{
  transform:scale(0.94);
}
.field-checkbox .checkbox input:checked + .checkbox-box{
  background:var(--accent);
  border-color:var(--accent);
}
.field-checkbox .checkbox input:checked + .checkbox-box::after{
  content:"";position:absolute;
  left:50%;top:48%;
  width:6px;height:12px;
  border:solid #fff;border-width:0 2.5px 2.5px 0;
  transform:translate(-50%, -55%) rotate(45deg);
  transform-origin:center;
}
.field-checkbox .checkbox-text{
  flex:1;
  padding-top:2px;
  font-size:14px;
  letter-spacing:0;
  text-transform:none;
  color:var(--fg-dim);
}
.field-checkbox .checkbox-text a{
  color:var(--fg);
  border-bottom:1px solid var(--fg-mute);
  transition:color .2s var(--ease), border-color .2s var(--ease);
  text-transform:none;
  letter-spacing:0;
}
.field-checkbox .checkbox-text a:hover{
  color:var(--accent);border-color:var(--accent);
}
.field-checkbox .checkbox-text em{
  color:var(--accent);font-style:normal;font-weight:600;
  margin-left:2px;
}
.field-checkbox.invalid .checkbox-box{
  border-color:var(--accent-2);
  background:rgba(201,48,44,0.10);
}

/* ---------------- SUBMIT — LOADING STATE ---------------- */
.form-submit[data-state="loading"]{
  opacity:0.65;cursor:wait;pointer-events:none;
}
.form-submit[data-state="loading"] .arrow{
  width:14px;height:14px;border:1.5px solid rgba(255,255,255,0.3);
  border-top-color:#fff;border-radius:50%;
  animation:spin .7s linear infinite;
  background:transparent;
}
.form-submit[data-state="loading"] .arrow::after{display:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------------- BIGTYPE ---------------- */
.bigtype{
  padding:var(--space-10) var(--space-7) var(--space-7);
  background:var(--bg);
  overflow:hidden;
  text-align:center;
  line-height:0.85;
  position:relative;
}
.bigtype-word{
  font-family:var(--font-serif);
  font-weight:300;
  font-size:clamp(120px,20vw,320px);
  letter-spacing:-0.04em;
  display:inline-block;
  line-height:1;
  position:relative;
  /* Variable optical-sizing — animated from 9 → 144 in inline JS for premium "swell" */
  font-optical-sizing:auto;
  font-variation-settings:"opsz" 9;
  /* GPU-promoted parallax handled via CSS var --bt-y set from inline JS */
  transform:translate3d(0, var(--bt-y, 0px), 0);
  will-change:transform;
  /* Outline-only effect via text-stroke. The shine sweep lives in .bigtype-shine */
  color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,0.10);
  text-stroke:1px rgba(255,255,255,0.10);
}
.bigtype-shine{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
  font-family:var(--font-serif);
  font-weight:300;
  font-size:clamp(120px,20vw,320px);
  letter-spacing:-0.04em;
  line-height:1;
  /* Chrome-shine: gradient text-clip travels across via background-position */
  background:linear-gradient(
    100deg,
    transparent 35%,
    rgba(255,255,255,0.65) 50%,
    transparent 65%
  );
  background-size:280% 100%;
  background-position:-180% 0;
  background-repeat:no-repeat;
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  transform:translate3d(0, var(--bt-y, 0px), 0);
}
.bigtype.is-sweep .bigtype-shine{
  animation:btShine 1.6s var(--ease-out-expo) forwards;
}
@keyframes btShine{
  to{ background-position:280% 0; }
}

/* ---------------- RESPONSIVE ---------------- */
@media (max-width: 960px){
  section{padding:64px 22px}
  .hero{
    padding:90px 22px 60px;
    padding-bottom:100vh;
    padding-bottom:100svh;
    min-height:auto;
    justify-content:flex-start;
    gap:36px;
    overflow:visible;
  }
  .hero-bg{
    position:sticky;top:0;inset:auto;
    width:calc(100% + 44px);
    margin:0 -22px;
    height:auto;
    aspect-ratio:3 / 2;
    z-index:0;
  }
  .hero-bg img{
    width:100%;height:100%;
    object-fit:cover;
    object-position:center 38%;
  }
  .hero-overlay{display:none}
  .hero-grid-bg{display:none}
  .hero-inner{
    position:relative;z-index:1;
    display:flex;flex-direction:column;
    width:100%;
  }
  .hero-sub{margin-top:0;margin-bottom:24px}
  .hero-actions{margin-top:0;margin-bottom:0}
  .hero-meta{
    position:static;left:auto;right:auto;bottom:auto;
    flex-direction:column;align-items:flex-start;gap:16px;
    margin-top:32px;
  }

  .section-head{grid-template-columns:1fr;gap:var(--space-5);margin-bottom:var(--space-8)}
  .fleet-grid{grid-template-columns:1fr}
  .car{
    padding:var(--space-6);
    /* Snappier reveal on mobile — shorter duration, smaller offset */
    transform:translate3d(0, 20px, 0);
    transition-duration:.5s, .55s, .35s;
    transition-delay: calc(var(--car-idx, 0) * 50ms);
  }
  .car-image{
    transition-duration:.6s;
    transition-delay: calc(var(--car-idx, 0) * 50ms + 80ms);
  }
  .car-image img{
    transform:translate3d(0, -16px, 0) scale(1.06);
    transition-duration:.6s, .55s;
    transition-delay: calc(var(--car-idx, 0) * 50ms + 140ms);
  }

  .contact-wrap{grid-template-columns:1fr;gap:60px;padding:0 22px}
  .form-row{grid-template-columns:1fr;gap:0}

  .bigtype{padding:80px 22px 20px}
}
@media (max-width:960px){
  /* Car CTA becomes a full-width primary button on mobile (conversion-stark) */
  .car-foot{flex-direction:column;align-items:stretch;gap:20px}
  .car-cta{
    background:var(--accent);color:#fff;
    border-bottom:none;
    width:100%;min-height:44px;
    padding:16px 20px;
    display:inline-flex;align-items:center;justify-content:center;gap:12px;
    font-weight:500;
  }
  .car-cta:hover,
  .car-cta:active{background:var(--accent-2);color:#fff;border-color:transparent}
}
@media (max-width:520px){
  .form-foot{flex-direction:column;align-items:stretch}
  .form-submit{justify-content:center}
  .hero-meta{display:none}
  .hero{padding-bottom:max(48px, env(safe-area-inset-bottom))}
}

/* ---------------- CAR LIGHTBOX ---------------- */
.car-image{cursor:zoom-in}

.car-lightbox{
  position:fixed;inset:0;z-index:1000;
  opacity:0;visibility:hidden;
  transition:opacity .35s var(--ease), visibility 0s linear .35s;
}
.car-lightbox.is-open{
  opacity:1;visibility:visible;
  transition:opacity .35s var(--ease), visibility 0s linear 0s;
}
.lb-backdrop{
  position:absolute;inset:0;
  background:rgba(5,5,5,0.88);
  backdrop-filter:blur(0) saturate(1);
  -webkit-backdrop-filter:blur(0) saturate(1);
  cursor:zoom-out;
  transition:backdrop-filter .45s var(--ease-out-expo), -webkit-backdrop-filter .45s var(--ease-out-expo);
}
.car-lightbox.is-open .lb-backdrop{
  backdrop-filter:blur(20px) saturate(1.2);
  -webkit-backdrop-filter:blur(20px) saturate(1.2);
}
.lb-panel{
  --lb-color: var(--accent);
  position:relative;
  max-width:1400px;
  width:calc(100% - 64px);
  height:calc(100vh - 64px);
  height:calc(100dvh - 64px);
  margin:32px auto;
  background:#0A0A0A;
  border:1px solid var(--line);
  display:grid;
  grid-template-columns:1.4fr 1fr;
  overflow:hidden;
  box-shadow:var(--shadow-xl);
  transform:scale(.94) translate3d(0, 20px, 0);
  opacity:0;
  transition:transform .55s var(--ease-out-expo), opacity .35s var(--ease);
}
.car-lightbox.is-open .lb-panel{
  transform:scale(1) translate3d(0, 0, 0);
  opacity:1;
}
.lb-strip{
  position:absolute;top:0;left:0;right:0;
  height:3px;
  background:var(--lb-color);
  z-index:4;
}
.lb-close{
  position:absolute;top:24px;right:24px;
  z-index:5;
  width:44px;height:44px;
  background:rgba(0,0,0,0.5);
  border:1px solid rgba(255,255,255,0.18);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:all .3s var(--ease);
  color:var(--fg);
}
.lb-close:hover{background:var(--accent);border-color:var(--accent)}
.lb-close svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.6;fill:none}
.lb-image-wrap{
  position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse 75% 60% at 50% 55%,
      color-mix(in srgb, var(--lb-color) 22%, #0a0a0a) 0%,
      #050505 75%);
  display:flex;align-items:center;justify-content:center;
  padding:60px 40px;
}
.lb-image-wrap::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:30%;
  background:radial-gradient(ellipse 70% 100% at 50% 100%, rgba(0,0,0,.55), transparent 70%);
  pointer-events:none;
}
.lb-image{
  position:relative;z-index:1;
  max-width:100%;max-height:100%;
  width:auto;height:auto;
  object-fit:contain;
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.65));
  transform:scale(.97) translate3d(0, 0, 0);
  opacity:.6;
  transition:transform .65s var(--ease-out-expo), opacity .45s var(--ease);
  transition-delay:.1s;
}
.car-lightbox.is-open .lb-image{transform:scale(1);opacity:1}
.lb-canvas{
  position:absolute;inset:0;
  width:100%;height:100%;
  padding:60px 40px;
  box-sizing:border-box;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.6));
  opacity:0;
  transition:opacity .35s var(--ease);
  pointer-events:none;
  z-index:2;
  touch-action:none;
}
.car-lightbox.is-open .lb-canvas.is-ready{opacity:1;pointer-events:auto;cursor:grab}
.car-lightbox.is-open .lb-canvas.is-ready.is-dragging{cursor:grabbing}

.lb-scrubber{
  position:absolute;
  left:50%;bottom:32px;
  transform:translateX(-50%);
  width:min(60%, 480px);
  z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  opacity:0;
  transition:opacity .4s var(--ease) .2s;
  pointer-events:none;
}
.car-lightbox.is-open .lb-scrubber.is-ready{opacity:1;pointer-events:auto}
.lb-scrub-hint{
  font-family:var(--font-sans);
  font-size:10px;letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.55);
  transition:opacity .35s var(--ease);
  order:-1;
}
.lb-scrubber.has-interacted .lb-scrub-hint{opacity:0}
.lb-scrub-range{
  appearance:none;-webkit-appearance:none;
  width:100%;height:2px;
  background:rgba(255,255,255,0.18);
  outline:none;cursor:pointer;
  margin:0;
}
.lb-scrub-range:disabled{opacity:.4;cursor:default}
.lb-scrub-range::-webkit-slider-thumb{
  appearance:none;-webkit-appearance:none;
  width:14px;height:14px;border-radius:50%;
  background:var(--lb-color, var(--accent));
  border:2px solid #fff;
  cursor:grab;
  transition:transform .2s var(--ease);
}
.lb-scrub-range:active::-webkit-slider-thumb{cursor:grabbing;transform:scale(1.15)}
.lb-scrub-range::-moz-range-thumb{
  width:14px;height:14px;border-radius:50%;
  background:var(--lb-color, var(--accent));
  border:2px solid #fff;
  cursor:grab;
}
.lb-scrub-range:active::-moz-range-thumb{cursor:grabbing;transform:scale(1.15)}
.lb-info{
  padding:80px 60px 48px;
  display:flex;flex-direction:column;
  background:var(--bg);
  overflow-y:auto;
}
.lb-info .lb-eyebrow{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-sans);
  font-size:11px;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--fg-mute);
  margin-bottom:24px;
}
.lb-seg{color:var(--lb-color);font-weight:500}
.lb-model{
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(36px, 3.6vw, 56px);
  letter-spacing:-0.02em;line-height:1.05;
  margin-bottom:14px;
}
.lb-tag{
  color:var(--fg-dim);font-size:15px;
  letter-spacing:0.04em;
  margin-bottom:40px;
}
.lb-specs{
  display:grid;grid-template-columns:1fr 1fr;
  gap:24px 36px;
  padding:32px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-bottom:36px;
}
.lb-specs .spec{display:flex;flex-direction:column}
.lb-specs .spec-label{
  font-size:10px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--fg-mute);
  margin-bottom:8px;
}
.lb-specs .spec-val{
  font-family:var(--font-serif);font-weight:300;
  font-size:20px;color:var(--fg);
  letter-spacing:-0.01em;
}
.lb-foot{
  margin-top:auto;
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:24px;flex-wrap:wrap;
}
.lb-price{display:flex;flex-direction:column}
.lb-price .from{
  font-size:10px;color:var(--fg-mute);
  letter-spacing:0.2em;text-transform:uppercase;
  margin-bottom:4px;
}
.lb-price .val{
  font-family:var(--font-serif);font-weight:300;
  font-size:40px;letter-spacing:-0.02em;line-height:1;
}
.lb-price .val .pln{font-size:16px;color:var(--fg-dim);margin-left:4px}
.lb-price .per{font-size:11px;color:var(--fg-mute);margin-top:6px;letter-spacing:0.08em}
.lb-price .spec-tbd{font-size:24px;padding-top:0}
.lb-cta{
  background:var(--accent);color:#fff;
  padding:18px 32px;min-height:54px;
  font-size:11px;letter-spacing:0.22em;
  text-transform:uppercase;font-weight:500;
  display:inline-flex;align-items:center;gap:14px;
  transition:background .3s var(--ease), transform .3s var(--ease);
  white-space:nowrap;
}
.lb-cta:hover{background:var(--accent-2);transform:translateX(4px)}
.lb-cta .arrow{
  display:inline-block;
  transition:transform .3s var(--ease);
}
.lb-cta:hover .arrow{transform:translateX(4px)}

body.lb-locked{overflow:hidden}

@media (max-width:900px){
  .lb-panel{
    grid-template-columns:1fr;
    grid-template-rows:auto 1fr;
    width:100%;height:100vh;height:100dvh;
    margin:0;border:0;
  }
  .lb-image-wrap{
    height:42vh;height:42dvh;
    padding:40px 24px 20px;
  }
  .lb-canvas{padding:40px 24px 20px}
  .lb-scrubber{width:80%;bottom:16px}
  .lb-info{padding:40px 28px 32px}
  .lb-close{top:16px;right:16px;width:40px;height:40px}
  .lb-model{font-size:clamp(28px,7vw,36px);margin-bottom:10px}
  .lb-tag{margin-bottom:24px;font-size:13px}
  .lb-specs{padding:20px 0;margin-bottom:24px;gap:18px 24px}
  .lb-specs .spec-val{font-size:17px}
  .lb-price .val{font-size:32px}
  .lb-foot{flex-direction:column;align-items:stretch;gap:16px}
  .lb-cta{width:100%;justify-content:center}
}
@media (max-width:520px){
  .lb-specs{grid-template-columns:1fr 1fr}
}

/* A11y · reduced-motion overrides (base.css handles the universal reset) */
@media (prefers-reduced-motion: reduce){
  .car-lightbox,.lb-panel,.lb-image{transition:opacity .2s linear !important;transform:none !important}
  .lb-canvas{transition:opacity .15s linear !important}
  .scroll-line{animation:none !important}
  .hero-eyebrow,.hero-sub,.hero-actions{opacity:1;transform:none}
  .bigtype-word,.bigtype-shine{transform:none !important;animation:none !important}
  .bigtype.is-sweep .bigtype-shine{animation:none !important}
  /* Fleet: instant fade only, no clip-path/translates/blur/scale */
  .car{
    opacity:1;transform:none;
    transition:opacity .2s linear, background-color .2s linear;
    transition-delay:0s;
  }
  .car::before{transform:scaleX(1);transition:none;transition-delay:0s}
  .car-image{
    clip-path:inset(0 0 0 0);-webkit-clip-path:inset(0 0 0 0);
    transition:none;transition-delay:0s;
  }
  .car-image img{
    transform:none;filter:contrast(1.04) saturate(0.95) brightness(1);
    transition:none;transition-delay:0s;
  }
  .car:hover{transform:none;box-shadow:none}
  .car:hover .car-image img{transform:none;filter:contrast(1.04) saturate(0.95) brightness(1)}
}
