/* ================================================================
   TERMINAL VELOCITY — Public Site  (v3 — Tactical Telemetry)
   ----------------------------------------------------------------
   Design language: dark CRT/telemetry + industrial brutalism.
     - Near-black substrate (#0B0C0E) with faint scanlines + grain
     - Phosphor off-white text, signal-blue (#6EC9FF) single accent
     - Monospace data labels, condensed display caps, 90deg corners
     - Hairline grids, HUD framing ([ TAG ], unit codes, ticks)
   Every class name + CSS variable name from the old build is kept
   so all Jinja/JS hooks keep working; only the look is rebuilt.
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Archivo:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  /* Semantic tokens (aligned to the live-chat widget palette) */
  --bg:        #0B0C0E;
  --bg-2:      #121418;
  --surface:   #1C1F25;
  --surface-2: #242830;
  --fg:        #ECEAE1;
  --fg-2:      #AEB4A4;
  --accent:    #6EC9FF;
  --accent-2:  #2E9FE0;
  --accent-soft: rgba(110,201,255,.10);
  --accent-line: rgba(110,201,255,.36);
  --red:       #FF4D3D;
  --green:     #6EC9FF;

  --r:      0px;
  --r-sm:   0px;
  --r-pill: 0px;
  --shadow-sm: none;
  --shadow:    0 0 0 1px var(--border);
  --shadow-lg: 10px 10px 0 0 rgba(0,0,0,.55);

  /* Legacy aliases — keep inline template styles resolving correctly */
  --ink:      #07080A;
  --ink-2:    #1C1F25;   /* card surface */
  --ink-3:    #242830;   /* image placeholder / subtle fill */
  --bone:     #ECEAE1;   /* primary text */
  --bone-2:   #AEB4A4;   /* secondary text */
  --muted:    #7C8174;
  --brass:    #6EC9FF;   /* accent */
  --brass-2:  #2E9FE0;
  --oxblood:  #FF4D3D;
  --border:   #34373D;
  --border-2: #474C56;

  --font-disp:  'Archivo', system-ui, sans-serif;
  --font-mega:  'Anton', 'Archivo', system-ui, sans-serif;
  --font-body:  'Archivo', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:  'JetBrains Mono', 'SFMono-Regular', Menlo, monospace;

  --maxw:   1280px;
  --gutter: clamp(18px, 4vw, 56px);
}

/* ─── Reset & base ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { overflow-x: hidden; }
body {
  margin: 0;
  font-family: var(--font-body);
  background-color: var(--bg);
  /* faint mechanical grain + horizontal scanlines baked into body so all
     clickable elements naturally sit above them (body::after scanlines removed) */
  background-image:
    repeating-linear-gradient(0deg,
      rgba(0,0,0,0) 0, rgba(0,0,0,0) 2px,
      rgba(0,0,0,.20) 3px, rgba(0,0,0,0) 4px),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-attachment: fixed;
  color: var(--fg);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; }
h1, h2, h3, h4, h5 { margin: 0; font-weight: 800; line-height: .98; letter-spacing: -0.02em; }
p { margin: 0 0 1em; }
::selection { background: var(--accent); color: #07080A; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ─── Image protection ──────────────────────────────────────────── */
img,
.det-gallery img, .inv-card-img img, .feat-card-img img {
  -webkit-user-select: none; -moz-user-select: none; user-select: none;
  -webkit-user-drag: none; -webkit-touch-callout: none; user-drag: none;
}

/* ─── Layout primitives ─────────────────────────────────────────── */
.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
.section { padding: clamp(58px, 9vw, 112px) 0; position: relative; }
.section--alt { background: var(--bg-2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }

/* ─── HUD utilities ─────────────────────────────────────────────── */
.eyebrow, .eyebrow-pill {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-soft);
  border: 1px solid var(--accent-line);
  padding: 7px 13px 6px;
  border-radius: 0;
  margin-bottom: 22px;
}
.eyebrow::before, .eyebrow-pill::before {
  content: '';
  width: 7px; height: 7px;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
  animation: tvBlink 1.6s steps(1) infinite;
}
@keyframes tvBlink { 0%,60%{opacity:1} 61%,100%{opacity:.25} }

.section-title {
  font-family: var(--font-disp);
  font-weight: 900;
  font-size: clamp(34px, 5.2vw, 68px);
  line-height: .94;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--fg);
}
.section-title small {
  display: block;
  margin-top: 18px;
  font-family: var(--font-body);
  font-weight: 400;
  font-size: clamp(15px, 1.4vw, 17px);
  line-height: 1.55;
  letter-spacing: 0;
  text-transform: none;
  color: var(--fg-2);
  max-width: 60ch;
}
.section-title-underline {
  display: block;
  width: 72px; height: 3px;
  margin: 20px auto 0;
  background: var(--accent);
  box-shadow: 0 0 14px var(--accent);
}

/* cursor-proximity headline spans: light-blue hover-glow */
.cursor-prox { transition: text-shadow .2s ease; }
.cursor-prox--ready { will-change: transform; }

/* ─── Header / topbar ───────────────────────────────────────────── */
.topbar {
  position: sticky; top: 0; z-index: 200;
  background: rgba(8,9,11,.86);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.topbar__row {
  display: flex; align-items: center; gap: 22px;
  height: 66px;
}
.brand {
  display: inline-flex; align-items: baseline; gap: 1px;
  font-family: var(--font-disp);
  font-weight: 900;
  font-size: 19px;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--fg);
  white-space: nowrap;
}
.brand img { height: 30px; width: auto; }
.brand__dot {
  display: inline-block;
  width: 9px; height: 18px;
  margin-left: 6px;
  background: var(--accent);
  box-shadow: 0 0 10px var(--accent);
  transform: translateY(2px);
  animation: tvBlink 1.1s steps(1) infinite;
}
.nav {
  display: flex; align-items: center; gap: 4px;
  margin-left: 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.nav a {
  padding: 11px 14px;
  color: var(--fg-2);
  border: 1px solid transparent;
  transition: color .15s ease, border-color .15s ease, background .15s ease;
}
.nav a:hover { color: var(--fg); }
.nav a.active { color: var(--accent); border-color: var(--accent-line); background: var(--accent-soft); }
.topbar__cta { display: flex; align-items: center; gap: 14px; margin-left: auto; }
.topbar__phone {
  font-family: var(--font-mono);
  font-size: 13px; font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--fg);
  padding: 12px 8px;
}
.topbar__phone:hover { color: var(--accent); }

/* burger */
.nav-toggle {
  display: none;
  margin-left: auto;
  width: 44px; height: 40px;
  background: transparent;
  border: 1px solid var(--border-2);
  position: relative;
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
  content: ''; position: absolute; left: 50%; top: 50%;
  width: 20px; height: 2px; background: var(--fg);
  transform: translate(-50%,-50%);
  transition: transform .2s ease, opacity .2s ease;
}
.nav-toggle span::before { transform: translate(-50%,-7px); }
.nav-toggle span::after  { transform: translate(-50%, 5px); }
.nav-toggle.is-active span { background: transparent; }
.nav-toggle.is-active span::before { transform: translate(-50%,-50%) rotate(45deg); top: 0; }
.nav-toggle.is-active span::after  { transform: translate(-50%,-50%) rotate(-45deg); top: 0; }

.nav-drawer {
  display: none;
  flex-direction: column;
  padding: 8px var(--gutter) 20px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-2);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 14px;
}
.nav-drawer.is-open { display: flex; }
.nav-drawer a { display: block; padding: 14px 16px; color: var(--fg-2); border-bottom: 1px solid var(--border); }
.nav-drawer a:hover { color: var(--accent); }
.nav-drawer a.btn { margin-top: 14px; border-bottom: none; color: #07080A; }

/* ─── Buttons ───────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--font-mono);
  font-size: 12.5px; font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 13px 22px;
  background: var(--accent);
  color: #07080A;
  border: 1px solid var(--accent);
  border-radius: 0;
  cursor: pointer;
  transition: background .15s ease, transform .08s ease, box-shadow .15s ease;
}
.btn:hover { background: var(--accent-2); box-shadow: 4px 4px 0 0 rgba(0,0,0,.5); transform: translate(-1px,-1px); }
.btn:active { transform: translate(0,0); box-shadow: none; }
.btn--ghost {
  background: transparent;
  color: var(--fg);
  border-color: var(--border-2);
}
.btn--ghost:hover { background: var(--accent-soft); color: var(--accent); border-color: var(--accent-line); box-shadow: none; transform: translateY(-1px); }
.btn--wide { width: 100%; }
.btn--sm { padding: 11px 16px; font-size: 11px; }

/* ─── Flash ─────────────────────────────────────────────────────── */
.flash {
  position: fixed; top: 78px; left: 50%; transform: translateX(-50%);
  z-index: 300;
  font-family: var(--font-mono); font-size: 13px; letter-spacing: .04em;
  background: var(--surface); color: var(--fg);
  border: 1px solid var(--accent-line); border-left: 4px solid var(--accent);
  padding: 13px 20px; max-width: 90vw;
}
.flash--error { border-color: var(--red); border-left-color: var(--red); color: var(--red); }

/* ─── HERO ──────────────────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: clamp(560px, 86vh, 820px);
  display: flex; align-items: center;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
.hero__bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: .50;
  filter: grayscale(0.2) contrast(1.05);
}
/* blueprint grid + vignette over hero */
.hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(110,201,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(110,201,255,.05) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(120% 90% at 20% 30%, #000 40%, transparent 100%);
}
.hero__inner { position: relative; z-index: 2; padding: clamp(60px,9vw,110px) 0; width: 100%; }
.hero__kicker {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent-line);
  background: var(--accent-soft);
  padding: 7px 14px 6px;
  margin-bottom: 28px;
}
.hero__kicker::before { content: '▸'; color: var(--accent); }
.hero__title {
  font-family: var(--font-mega);
  font-weight: 400;
  font-size: clamp(58px, 11vw, 168px);
  line-height: .86;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--fg);
  margin: 0 0 8px;
}
.hero__title span { display: block; }
.hero__title span:last-child { color: var(--accent); -webkit-text-stroke: 0; }
.hero__sub {
  margin: 26px 0 0;
  max-width: 56ch;
  font-size: clamp(15px, 1.5vw, 18px);
  line-height: 1.6;
  color: var(--fg-2);
}
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.hero__pills { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; }
.hero__pill {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 11.5px;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--fg-2);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.02);
  padding: 8px 13px;
}
.hero__pill svg { color: var(--accent); }

/* ─── Promise / spec band (full-width dark strip) ───────────────── */
.cta-bar {
  position: relative;
  display: flex; flex-wrap: wrap; align-items: center; gap: 26px;
  justify-content: space-between;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 4px solid var(--accent);
  padding: clamp(28px,4vw,48px);
  overflow: hidden;
}
.cta-bar::after {
  content: 'CH'; position: absolute; right: -6px; bottom: -34px;
  font-family: var(--font-mega); font-size: 150px; color: rgba(110,201,255,.05);
  pointer-events: none;
}
.cta-bar__text h3 {
  font-family: var(--font-disp); font-weight: 900;
  font-size: clamp(24px,3vw,34px); text-transform: uppercase; letter-spacing: -0.02em;
  color: var(--fg); margin-bottom: 10px;
}
.cta-bar__text p { color: var(--fg-2); max-width: 52ch; margin: 0; font-size: 15px; }
.cta-bar__actions { display: flex; flex-wrap: wrap; gap: 12px; position: relative; z-index: 1; }

/* ─── Feature / inventory cards ─────────────────────────────────── */
.feat, .inv-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}
.feat-card {
  position: relative;
  display: flex; flex-direction: column;
  background: var(--surface);
  color: var(--fg);
  transition: background .18s ease, transform .18s ease;
}
.feat-card:hover { background: var(--surface-2); }
.feat-card-img {
  position: relative; aspect-ratio: 4/3; overflow: hidden;
  background: var(--ink-3);
}
.feat-card-img img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.92); transition: transform .5s ease, opacity .3s ease; }
.feat-card:hover .feat-card-img img { transform: scale(1.05); }
.feat-card-img__hover { position: absolute; inset: 0; opacity: 0; }
.feat-card:hover .feat-card-img__hover { opacity: 1; }
.feat-card-img__year {
  position: absolute; top: 0; left: 0;
  font-family: var(--font-mono); font-size: 12px; font-weight: 700; letter-spacing: .1em;
  background: var(--accent); color: #07080A; padding: 5px 10px;
}
.feat-card-img__pending, .feat-card-img__sold, .feat-card-img__sold-large {
  position: absolute; top: 10px; right: 10px;
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  background: var(--red); color: #fff; padding: 5px 9px;
}
.feat-card-img__sold-large {
  top: 50%; left: 50%; right: auto; transform: translate(-50%,-50%) rotate(-7deg);
  font-size: clamp(22px,4vw,40px); letter-spacing: .2em; padding: 8px 22px;
  border: 2px solid #fff; background: rgba(255,77,61,.92);
}
.feat-card__body { padding: 18px 18px 20px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.feat-card__title {
  font-family: var(--font-disp); font-weight: 800; font-size: 19px;
  text-transform: uppercase; letter-spacing: -0.01em; color: var(--fg);
}
.feat-card__specs {
  display: flex; flex-wrap: wrap; gap: 6px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em; color: var(--fg-2);
}
.feat-card__specs span { border: 1px solid var(--border); padding: 3px 7px; }
.feat-card__price {
  margin-top: auto; font-family: var(--font-mono); font-weight: 700; font-size: 20px;
  color: var(--accent); letter-spacing: .01em;
}
.feat-card--sold { opacity: .72; }
.feat-card--sold .feat-card__price { color: var(--fg-2); }

/* ─── Inventory: 2-up grid + per-card image scroller ────────────── */
.inv-grid--2 { grid-template-columns: repeat(2, 1fr); }
.feat-card__body--link { color: var(--fg); text-decoration: none; }
.feat-card__foot { margin-top: auto; display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.feat-card__foot .feat-card__price { margin-top: 0; }
.feat-card__view {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--fg-2); opacity: 0; transform: translateX(-4px); transition: opacity .18s ease, transform .18s ease;
}
.feat-card:hover .feat-card__view { opacity: 1; transform: translateX(0); color: var(--accent); }

/* ── Inventory lead-conversion CTAs ─────────────────────────────── */
.inv-pitch {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px 24px; flex-wrap: wrap;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  padding: 16px 22px;
  margin: 14px 0 22px;
}
.inv-pitch__text { display: flex; flex-direction: column; gap: 9px; min-width: 0; }
.inv-pitch .eyebrow { margin-bottom: 0; align-self: flex-start; }
.inv-pitch__line {
  font-family: var(--font-disp); font-weight: 700;
  font-size: clamp(15px, 2.2vw, 19px); line-height: 1.25; color: var(--fg);
  max-width: 60ch;
}
.inv-pitch__cta { flex: 0 0 auto; }

.feat-card__price--ask { color: var(--muted); }

/* Explicit per-card action row sits below the linked body so the lead button is
   always visible (not hover-gated) and never nests a button inside the card link. */
.feat-card__actions { display: flex; gap: 8px; padding: 0 18px 18px; }
.feat-card__actions .feat-card__enquire { flex: 1 1 auto; }
.feat-card__actions .feat-card__details { flex: 0 0 auto; }

.inv-empty .eyebrow { margin-bottom: 16px; }
.inv-empty__cta { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-top: 24px; }

@media (max-width: 640px) {
  .inv-pitch { flex-direction: column; align-items: stretch; }
  .inv-pitch__cta { width: 100%; }
  .inv-empty__cta .btn { width: 100%; }
}

.feat-slider { /* extends .feat-card-img */ }
.feat-slider__track {
  display: flex; width: 100%; height: 100%;
  overflow-x: auto; scroll-snap-type: x mandatory;
  scrollbar-width: none; -ms-overflow-style: none;
}
.feat-slider__track::-webkit-scrollbar { display: none; }
.feat-slide { flex: 0 0 100%; scroll-snap-align: start; height: 100%; }
.feat-slide img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.92); }
.feat-card:hover .feat-slide img { transform: none; }
.feat-slider__arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px; display: flex; align-items: center; justify-content: center;
  background: rgba(7,8,10,.62); color: var(--bone, #E9E7DE); border: 1px solid rgba(255,255,255,.18);
  font-size: 22px; line-height: 1; cursor: pointer; z-index: 3;
  opacity: 0; transition: opacity .18s ease, background .15s ease;
}
.feat-card-img:hover .feat-slider__arrow { opacity: 1; }
.feat-slider__arrow:hover { background: var(--accent); color: #07080A; }
.feat-slider__arrow--prev { left: 8px; }
.feat-slider__arrow--next { right: 8px; }
.feat-slider__arrow.is-hidden { opacity: 0 !important; pointer-events: none; }
/* Touch devices have no hover — keep the photo-nav arrows visible so users
   know multiple photos exist and can tap through them. */
@media (hover: none) {
  .feat-slider__arrow { opacity: .85; }
}
.feat-slider__count {
  position: absolute; bottom: 8px; right: 8px; z-index: 3;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .08em;
  background: rgba(7,8,10,.62); color: var(--bone, #E9E7DE); padding: 3px 8px;
}

/* ─── Why grid ──────────────────────────────────────────────────── */
.why-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1px; background: var(--border); border: 1px solid var(--border);
}
.why-card { background: var(--surface); padding: 30px 26px 34px; position: relative; }
.why-card:hover { background: var(--surface-2); }
.why-card::before {
  counter-increment: why; content: '+';
  position: absolute; top: 14px; right: 16px; color: var(--accent); font-family: var(--font-mono); opacity: .5;
}
.why-card__icon {
  width: 48px; height: 48px; display: grid; place-items: center;
  border: 1px solid var(--accent-line); color: var(--accent);
  background: var(--accent-soft); margin-bottom: 22px;
}
.why-card h4 {
  font-family: var(--font-disp); font-weight: 800; font-size: 18px;
  text-transform: uppercase; letter-spacing: -0.01em; margin-bottom: 10px; color: var(--fg);
}
.why-card p { color: var(--fg-2); font-size: 14.5px; line-height: 1.6; margin: 0; }

/* ─── Steps ─────────────────────────────────────────────────────── */
.steps {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  gap: 1px; background: var(--border); border: 1px solid var(--border); margin-top: 44px;
}
.step { background: var(--surface); padding: 30px 26px 34px; position: relative; }
.step:hover { background: var(--surface-2); }
.step__num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 46px; height: 46px; margin-bottom: 20px;
  font-family: var(--font-mega); font-size: 26px; color: #07080A;
  background: var(--accent);
}
.step h4 { font-family: var(--font-disp); font-weight: 800; font-size: 18px; text-transform: uppercase; margin-bottom: 9px; color: var(--fg); }
.step p { color: var(--fg-2); font-size: 14.5px; line-height: 1.6; margin: 0; }

/* ─── Testimonials ──────────────────────────────────────────────── */
.testi-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  gap: 1px; background: var(--border); border: 1px solid var(--border); margin-top: 44px;
}
.testi { background: var(--surface); padding: 30px 26px; display: flex; flex-direction: column; gap: 14px; }
.testi .stars { color: var(--accent); letter-spacing: 4px; font-size: 14px; }
.testi__text { color: var(--fg); font-size: 15px; line-height: 1.6; margin: 0; }
.testi__name { font-family: var(--font-mono); font-weight: 700; font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); margin-top: auto; }
.testi__loc { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; color: var(--fg-2); }

/* ─── FAQ ───────────────────────────────────────────────────────── */
.faq { max-width: 860px; margin: 44px auto 0; border-top: 1px solid var(--border); }
.faq details { border-bottom: 1px solid var(--border); }
.faq summary {
  list-style: none; cursor: pointer; padding: 22px 40px 22px 0; position: relative;
  font-family: var(--font-disp); font-weight: 700; font-size: 17px;
  text-transform: uppercase; letter-spacing: -0.01em; color: var(--fg);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: '+'; position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  font-family: var(--font-mono); font-size: 22px; color: var(--accent);
}
.faq details[open] summary::after { content: '–'; }
.faq details > div { padding: 0 40px 24px 0; color: var(--fg-2); font-size: 15px; line-height: 1.65; }
.faq a { color: var(--accent); border-bottom: 1px solid var(--accent-line); }

/* ─── Split (about / financing / shipping intros) ──────────────── */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,5vw,64px); align-items: center; }
.split__img { border: 1px solid var(--border); overflow: hidden; aspect-ratio: 4/3; background: var(--ink-3); }
.split__img img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.25) saturate(.95); }
.split__body p { color: var(--fg-2); font-size: 15.5px; line-height: 1.7; }
.split__body strong { color: var(--fg); }

/* ─── Strip (about stat row) ────────────────────────────────────── */
.strip { background: var(--bg-2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: clamp(40px,6vw,72px) 0; }
.strip-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px,1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); }
.strip-item { background: var(--surface); padding: 28px 26px; }
.strip-item h4 { font-family: var(--font-disp); font-weight: 800; font-size: 17px; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
.strip-item p { color: var(--fg-2); font-size: 14px; margin: 0; line-height: 1.6; }

/* ─── Footer ────────────────────────────────────────────────────── */
.footer { background: var(--ink); border-top: 1px solid var(--border); padding: clamp(48px,6vw,80px) 0 28px; margin-top: 0; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 36px; }
.footer h5 { font-family: var(--font-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }
.footer p { color: var(--fg-2); font-size: 14px; line-height: 1.6; margin: 0 0 8px; word-break: break-word; }
.footer p a { display: inline-block; padding: 6px 0; }
.footer a:hover { color: var(--accent); }
.footer .brand { color: var(--fg); }
.footer-bottom {
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: 12px;
  margin-top: 44px; padding-top: 22px; border-top: 1px solid var(--border);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .06em; color: var(--muted);
  text-transform: uppercase;
}
.footer-legal { display: flex; gap: 18px; }
.footer-legal a { display: inline-block; padding: 6px 0; }
.footer-legal a:hover { color: var(--accent); }

/* ─── Reveal animations ─────────────────────────────────────────── */
/* Hidden state only applies when JS is running (html.js), so a JS failure
   or blocked script never leaves forms/content invisible and unusable. */
.js .reveal, .js .reveal-stagger .reveal-item { opacity: 0; transform: translateY(22px); }
.reveal.is-in, .reveal-stagger.is-in .reveal-item { opacity: 1; transform: none; transition: opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1); }
.reveal-stagger.is-in .reveal-item:nth-child(2){ transition-delay: .07s; }
.reveal-stagger.is-in .reveal-item:nth-child(3){ transition-delay: .14s; }
.reveal-stagger.is-in .reveal-item:nth-child(4){ transition-delay: .21s; }
.reveal-stagger.is-in .reveal-item:nth-child(5){ transition-delay: .28s; }
.reveal-stagger.is-in .reveal-item:nth-child(6){ transition-delay: .35s; }
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal-stagger .reveal-item { opacity: 1 !important; transform: none !important; }
  body::after { display: none; }
  .eyebrow::before, .eyebrow-pill::before, .brand__dot { animation: none; }
}

/* ════════════════════════════════════════════════════════════════
   INVENTORY
   ════════════════════════════════════════════════════════════════ */
.inv-bar { background: var(--surface); border: 1px solid var(--border); margin-bottom: 1px; }
.inv-bar__top { display: flex; align-items: flex-end; gap: 16px; flex-wrap: wrap; padding: 18px 22px; }
.inv-bar__search { flex: 1 1 320px; display: flex; flex-direction: column; gap: 8px; }
.inv-bar__go { flex: 0 0 auto; }
.inv-bar__more { flex: 0 0 auto; position: relative; }
.inv-bar__more > summary { list-style: none; cursor: pointer; }
.inv-bar__more > summary::-webkit-details-marker { display: none; }
.inv-bar__more[open] > summary { border-color: var(--accent); color: var(--accent); }
.inv-bar__drawer { display: flex; flex-wrap: wrap; gap: 18px; align-items: flex-end; width: 100%; margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--border); }
.inv-bar__drawer .inv-rail__group { flex: 1 1 220px; }
.inv-bar__reset { flex: 0 0 auto; justify-content: flex-end; }
.inv-rail__group { display: flex; flex-direction: column; gap: 8px; }
.inv-rail__label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
.inv-search, .inv-select {
  width: 100%; padding: 13px 13px; background: var(--bg); color: var(--fg);
  border: 1px solid var(--border-2); border-radius: 0; font-family: var(--font-mono); font-size: 16px;
}
.inv-search:focus, .inv-select:focus { border-color: var(--accent); outline: none; }
.inv-select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--accent) 50%), linear-gradient(135deg, var(--accent) 50%, transparent 50%); background-position: calc(100% - 18px) center, calc(100% - 13px) center; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; }
.inv-results { border: 1px solid var(--border); }
.inv-results-head { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; padding: 18px 22px; background: var(--surface); border-bottom: 1px solid var(--border); }
.inv-results-head__count { font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-2); }
.inv-results-head__count span { color: var(--accent); font-weight: 700; }
.inv-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.inv-chip { display: inline-flex; gap: 8px; align-items: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em; color: var(--fg); border: 1px solid var(--border-2); padding: 5px 10px; }
.inv-chip a { color: var(--red); font-weight: 700; display: inline-flex; align-items: center; justify-content: center; padding: 6px 8px; margin: -6px -8px -6px 0; min-width: 32px; min-height: 32px; }
.inv-grid { border: none; }
.inv-results .inv-grid { background: var(--border); }
.sold-section { opacity: .92; }
.empty { text-align: center; padding: 70px 20px; }
.empty h3 { font-family: var(--font-disp); font-weight: 900; font-size: 26px; text-transform: uppercase; color: var(--fg); margin-bottom: 10px; }
.empty p { color: var(--fg-2); }
.empty a { color: var(--accent); }

/* ════════════════════════════════════════════════════════════════
   CAR DETAIL
   ════════════════════════════════════════════════════════════════ */
.det { padding: 30px 0 96px; }
.det-breadcrumb { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-2); margin-bottom: 24px; }
.det-breadcrumb a { color: var(--accent); }
.det-cols { display: grid; grid-template-columns: 1fr minmax(300px, 380px); gap: 1px; background: var(--border); border: 1px solid var(--border); }
.det-gallery { background: var(--bg); padding: 0; }
.det-hero { position: relative; aspect-ratio: 16/10; overflow: hidden; background: var(--ink-3); border-bottom: 1px solid var(--border); cursor: zoom-in; }
.det-hero__img { width: 100%; height: 100%; object-fit: cover; }
.det-hero__placeholder { width: 100%; height: 100%; display: grid; place-items: center; font-family: var(--font-mono); letter-spacing: .2em; color: var(--muted); font-size: 12px; }
.det-gallery__nav {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 3;
  width: 46px; height: 46px; display: grid; place-items: center;
  background: rgba(8,9,11,.78); color: var(--accent); border: 1px solid var(--accent-line); font-size: 22px;
}
.det-gallery__nav--prev { left: 14px; } .det-gallery__nav--next { right: 14px; }
.det-gallery__nav:hover { background: var(--accent); color: #07080A; }
.det-gallery__count { position: absolute; bottom: 14px; right: 14px; z-index: 3; font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; background: rgba(8,9,11,.8); color: var(--accent); padding: 5px 10px; border: 1px solid var(--accent-line); }
.det-hero__scrim { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; padding: 26px 24px 20px; background: linear-gradient(0deg, rgba(7,8,10,.92) 5%, rgba(7,8,10,0) 100%); }
.det-year { font-family: var(--font-mono); font-size: 13px; letter-spacing: .14em; color: var(--accent); }
.det-title { font-family: var(--font-mega); font-weight: 400; font-size: clamp(30px,4.5vw,58px); text-transform: uppercase; line-height: .9; color: var(--fg); margin-top: 4px; }
.det-hero__aside { text-align: right; flex-shrink: 0; }
.det-price { font-family: var(--font-mono); font-weight: 700; font-size: clamp(22px,3vw,32px); color: var(--accent); }
.det-price small { display: block; font-weight: 500; font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--fg-2); margin-bottom: 4px; }
.det-hero__cta { margin-top: 12px; }
.det-gallery__thumbs { display: grid; grid-template-columns: repeat(auto-fill, minmax(86px,1fr)); gap: 1px; background: var(--border); padding: 1px; }
.det-gallery__thumb { aspect-ratio: 4/3; overflow: hidden; cursor: pointer; opacity: .5; border: 2px solid transparent; }
.det-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }
.det-gallery__thumb.is-active { opacity: 1; border-color: var(--accent); }
.det-side { background: var(--surface); display: flex; flex-direction: column; }
.det-card { padding: 24px 22px; border-bottom: 1px solid var(--border); }
.det-card h3 { font-family: var(--font-disp); font-weight: 800; font-size: 14px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); margin-bottom: 18px; }
.det-specs { display: flex; flex-direction: column; }
.det-spec { display: flex; justify-content: space-between; gap: 14px; padding: 9px 0; border-bottom: 1px solid var(--border); font-size: 14px; }
.det-spec:last-child { border-bottom: none; }
.det-spec__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-2); }
.det-spec__value { color: var(--fg); font-weight: 600; text-align: right; }
.det-desc { margin-top: 1px; background: var(--surface); border: 1px solid var(--border); padding: clamp(26px,4vw,44px); }
.det-desc h2 { font-family: var(--font-disp); font-weight: 900; font-size: 24px; text-transform: uppercase; color: var(--fg); margin-bottom: 18px; }
.det-desc p { color: var(--fg-2); line-height: 1.75; }
.det-cta-banner { margin-top: 1px; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 24px; background: var(--surface); border: 1px solid var(--border); border-left: 4px solid var(--accent); padding: clamp(26px,4vw,42px); }
.det-cta-banner h2 { font-family: var(--font-disp); font-weight: 900; font-size: clamp(22px,3vw,30px); text-transform: uppercase; color: var(--fg); margin-bottom: 8px; }
.det-cta-banner p { color: var(--fg-2); margin: 0; }
.det-cta-banner__actions { display: flex; flex-wrap: wrap; gap: 12px; }
.det-related { margin-top: clamp(48px,6vw,72px); }
.det-related h2 { font-family: var(--font-disp); font-weight: 900; font-size: 26px; text-transform: uppercase; color: var(--fg); margin-bottom: 22px; }

/* lightbox */
.det-lightbox { position: fixed; inset: 0; z-index: 500; display: none; align-items: center; justify-content: center; background: rgba(5,6,8,.95); }
.det-lightbox.is-open { display: flex; }
.det-lightbox__img { max-width: 92vw; max-height: 86vh; object-fit: contain; cursor: pointer; border: 1px solid var(--border-2); }
.det-lightbox__close { position: absolute; top: 20px; right: 24px; width: 46px; height: 46px; background: transparent; border: 1px solid var(--border-2); color: var(--fg); font-size: 26px; }
.det-lightbox__close:hover { border-color: var(--accent); color: var(--accent); }
.det-lightbox__nav { position: absolute; top: 50%; transform: translateY(-50%); width: 52px; height: 52px; background: rgba(8,9,11,.7); border: 1px solid var(--accent-line); color: var(--accent); font-size: 26px; }
.det-lightbox__nav--prev { left: 22px; } .det-lightbox__nav--next { right: 22px; }
.det-lightbox__count { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); font-family: var(--font-mono); font-size: 13px; letter-spacing: .12em; color: var(--accent); }

/* sticky inquiry bar */
.det-stickybar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 180; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 12px var(--gutter); padding-bottom: max(12px, env(safe-area-inset-bottom)); background: rgba(8,9,11,.95); border-top: 1px solid var(--accent-line); transform: translateY(110%); transition: transform .25s ease; pointer-events: none; }
.det-stickybar.is-visible { transform: translateY(0); pointer-events: auto; }
/* When the floating chat launcher is present it occupies the bottom-right corner
   above this bar (~84px in from the right edge). Reserve room so the bar's action
   buttons are never tucked underneath it. The car_detail script adds this class
   only when the launcher actually rendered, so pages without live chat keep the
   normal gutter. Two-class selector so it also wins over the mobile padding shorthand. */
.det-stickybar.det-stickybar--chat-clear { padding-right: 96px; }
.det-stickybar__info { min-width: 0; overflow: hidden; }
.det-stickybar__title { display: block; font-family: var(--font-disp); font-weight: 800; text-transform: uppercase; font-size: 15px; color: var(--fg); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.det-stickybar__price { display: block; font-family: var(--font-mono); font-size: 13px; color: var(--accent); }
.det-stickybar__actions { display: flex; gap: 10px; flex: 0 0 auto; }

/* ════════════════════════════════════════════════════════════════
   FORMS (shared)
   ════════════════════════════════════════════════════════════════ */
.det-form { display: flex; flex-direction: column; gap: 12px; }
.det-form input, .det-form select, .det-form textarea,
.quote-form input, .quote-form select, .quote-form textarea {
  width: 100%; padding: 13px 14px; background: var(--bg); color: var(--fg);
  border: 1px solid var(--border-2); border-radius: 0;
  font-family: var(--font-mono); font-size: 16px; letter-spacing: .01em;
}
.det-form textarea, .quote-form textarea { resize: vertical; min-height: 96px; font-family: var(--font-body); }
.det-form input::placeholder, .quote-form input::placeholder, .det-form textarea::placeholder, .quote-form textarea::placeholder { color: var(--muted); }
.det-form input:focus, .det-form select:focus, .det-form textarea:focus,
.quote-form input:focus, .quote-form select:focus, .quote-form textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }

/* ════════════════════════════════════════════════════════════════
   FINANCING
   ════════════════════════════════════════════════════════════════ */
.fin-hero .hero__inner { padding-top: clamp(48px,7vw,96px); }
.fin-hero__split { display: grid; grid-template-columns: 1fr minmax(340px, 440px); gap: clamp(28px,4vw,56px); align-items: start; }
.fin-hero__solo { max-width: 760px; }
.fin-hero__copy .hero__title { font-size: clamp(46px,7vw,104px); }
.calc { background: var(--surface); border: 1px solid var(--border); }
.calc--hero { box-shadow: var(--shadow-lg); }
.calc__head { padding: 18px 22px; border-bottom: 1px solid var(--border); }
.calc__controls { padding: 22px; display: flex; flex-direction: column; gap: 20px; }
.calc__field-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; }
.calc__field-head label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-2); }
.calc__val { font-family: var(--font-mono); font-weight: 700; font-size: 15px; color: var(--accent); }
.calc__hint { font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em; text-transform: uppercase; color: var(--muted); }
.calc__input { display: flex; align-items: center; gap: 6px; background: var(--ink); border: 1px solid var(--border-2); padding: 0 14px; transition: border-color .15s; }
.calc__input:focus-within { border-color: var(--accent); }
.calc__input input[type=number] { flex: 1 1 auto; width: 100%; min-width: 0; background: transparent; border: 0; outline: 0; color: var(--fg); font-family: var(--font-mono); font-weight: 700; font-size: 18px; padding: 12px 0; -moz-appearance: textfield; }
.calc__input input[type=number]::-webkit-outer-spin-button,
.calc__input input[type=number]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.calc__prefix, .calc__suffix { font-family: var(--font-mono); font-size: 14px; color: var(--accent); flex: 0 0 auto; }
.calc__scale { display: flex; justify-content: space-between; margin-top: 6px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em; color: var(--muted); }
.calc__result { background: var(--ink); border-top: 1px solid var(--accent-line); padding: 26px 22px; }
.calc__result-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--fg-2); }
.calc__payment { display: flex; align-items: baseline; gap: 2px; margin: 8px 0 18px; }
.calc__currency { font-family: var(--font-mono); font-size: 22px; color: var(--accent); }
.calc__payment > span#outMonthly { font-family: var(--font-mega); font-size: clamp(48px,8vw,72px); color: var(--fg); line-height: 1; }
.calc__per { font-family: var(--font-mono); font-size: 15px; color: var(--fg-2); margin-left: 6px; }
.calc__breakdown { display: flex; flex-direction: column; gap: 2px; }
.calc__brk { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 13px; color: var(--fg-2); }
.calc__brk strong { color: var(--fg); font-family: var(--font-mono); }
.calc__disclaimer { margin: 16px 0 0; font-size: 11px; line-height: 1.5; color: var(--muted); }

/* range sliders */
.calc input[type=range] { -webkit-appearance: none; appearance: none; width: 100%; height: 4px; background: linear-gradient(to right, var(--accent) 0%, var(--accent) var(--fill, 50%), var(--border-2) var(--fill, 50%), var(--border-2) 100%); cursor: pointer; }
.calc input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; width: 16px; height: 22px; background: var(--accent); border: none; box-shadow: 0 0 10px rgba(110,201,255,.5); cursor: grab; }
.calc input[type=range]::-moz-range-thumb { width: 16px; height: 22px; background: var(--accent); border: none; border-radius: 0; cursor: grab; }

.fin-stats { background: var(--bg-2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: clamp(36px,5vw,60px) 0; }
.fin-stats__grid { display: grid; grid-template-columns: 1fr 440px; gap: clamp(28px,4vw,56px); align-items: stretch; }
.fin-stats__col { display: flex; }
.fin-stats__row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); }
.fin-stats__row--2up { grid-template-columns: 1fr; grid-auto-rows: 1fr; flex: 1; }
.fin-stat { background: var(--surface); padding: 28px 24px; display: flex; flex-direction: column; justify-content: center; }
.fin-stat__num { font-family: var(--font-mega); font-size: clamp(40px,6vw,64px); color: var(--accent); line-height: 1; }
.fin-stat__num span { font-size: .4em; color: var(--fg-2); margin-left: 4px; }
.fin-stat__label { font-family: var(--font-mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--fg); margin-top: 12px; }
.fin-stat__label small { display: block; text-transform: none; letter-spacing: 0; color: var(--muted); font-size: 11px; margin-top: 4px; }

.rate-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); margin-top: 44px; }
.rate-card { background: var(--surface); padding: 30px 26px; display: flex; flex-direction: column; gap: 6px; position: relative; }
.rate-card--feature { background: var(--surface-2); border-top: 3px solid var(--accent); }
.rate-card__badge { position: absolute; top: 0; right: 0; font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; background: var(--accent); color: #07080A; padding: 4px 9px; }
.rate-card__term { font-family: var(--font-mega); font-size: 56px; color: var(--fg); line-height: 1; }
.rate-card__term small { font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-2); margin-left: 8px; }
.rate-card__apr { font-family: var(--font-mono); font-size: 13px; letter-spacing: .08em; color: var(--accent); }
.rate-card__pay { font-family: var(--font-disp); font-weight: 800; font-size: 30px; color: var(--fg); margin: 8px 0 4px; }
.rate-card__pay span { font-size: 14px; color: var(--fg-2); font-weight: 500; }
.rate-card__list { list-style: none; padding: 0; margin: 12px 0 22px; display: flex; flex-direction: column; gap: 9px; }
.rate-card__list li { position: relative; padding-left: 22px; font-size: 13.5px; color: var(--fg-2); }
.rate-card__list li::before { content: '✓'; position: absolute; left: 0; color: var(--accent); }
.rate-card a { margin-top: auto; }
.compare-note { text-align: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em; color: var(--muted); margin-top: 26px; }

.fin-reqs__title { font-family: var(--font-disp); font-weight: 800; font-size: 16px; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin: 30px 0 14px; }
.fin-reqs { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.fin-reqs li { position: relative; padding-left: 26px; color: var(--fg-2); font-size: 15px; }
.fin-reqs li::before { content: '▸'; position: absolute; left: 0; color: var(--accent); }
.fin-form-card { background: var(--surface); border: 1px solid var(--border); }
.fin-form-card h3 { font-family: var(--font-disp); font-weight: 800; font-size: 15px; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); }
.fin-form-card__sub { color: var(--fg-2); font-size: 14px; margin: 8px 0 18px; }
.fin-form-card__fine { font-size: 11px; color: var(--muted); margin: 14px 0 0; line-height: 1.5; }
.fin-form-card__fine a { color: var(--accent); }
.fin-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ════════════════════════════════════════════════════════════════
   SHIPPING
   ════════════════════════════════════════════════════════════════ */
.tx-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); margin-top: 44px; }
.tx-card { background: var(--surface); padding: 32px 28px; display: flex; flex-direction: column; }
.tx-card:hover { background: var(--surface-2); }
.tx-card__icon { width: 52px; height: 52px; display: grid; place-items: center; border: 1px solid var(--accent-line); background: var(--accent-soft); color: var(--accent); margin-bottom: 22px; }
.tx-card__icon svg { width: 26px; height: 26px; }
.tx-card h3 { font-family: var(--font-disp); font-weight: 800; font-size: 20px; text-transform: uppercase; color: var(--fg); margin-bottom: 10px; }
.tx-card > p { color: var(--fg-2); font-size: 14.5px; line-height: 1.6; }
.tx-card ul { list-style: none; padding: 0; margin: 14px 0 20px; display: flex; flex-direction: column; gap: 8px; }
.tx-card li { position: relative; padding-left: 22px; font-size: 13.5px; color: var(--fg-2); }
.tx-card li::before { content: '+'; position: absolute; left: 0; color: var(--accent); }
.tx-card__price { margin-top: auto; font-family: var(--font-mono); font-size: 13px; letter-spacing: .06em; text-transform: uppercase; color: var(--fg-2); border-top: 1px solid var(--border); padding-top: 16px; }
.tx-card__price strong { color: var(--accent); }

.compare-tbl { width: 100%; border-collapse: collapse; margin-top: 40px; border: 1px solid var(--border); font-size: 14px; }
.compare-tbl th { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; text-align: left; padding: 14px 16px; background: var(--ink); color: var(--accent); border-bottom: 1px solid var(--border); }
.compare-tbl td { padding: 16px; border-bottom: 1px solid var(--border); border-right: 1px solid var(--border); color: var(--fg-2); }
.compare-tbl tr:nth-child(even) td { background: rgba(255,255,255,.015); }
.row-label { font-family: var(--font-disp); font-weight: 700; text-transform: uppercase; color: var(--fg); font-size: 14px; }
.pop { display: inline-block; margin-left: 8px; font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em; background: var(--accent); color: #07080A; padding: 2px 6px; vertical-align: middle; }

.ship-quote .split__body p { color: var(--fg-2); }
.ship-quote__steps { list-style: none; counter-reset: sq; padding: 0; margin: 26px 0 0; display: flex; flex-direction: column; gap: 18px; }
.ship-quote__steps li { counter-increment: sq; position: relative; padding-left: 48px; color: var(--fg-2); font-size: 14px; }
.ship-quote__steps li::before { content: counter(sq,decimal-leading-zero); position: absolute; left: 0; top: -2px; font-family: var(--font-mono); font-weight: 700; color: var(--accent); border: 1px solid var(--accent-line); padding: 4px 7px; font-size: 12px; }
.ship-quote__steps strong { display: block; color: var(--fg); font-family: var(--font-disp); text-transform: uppercase; font-size: 14px; letter-spacing: .02em; margin-bottom: 3px; }
.quote-card { background: var(--surface); border: 1px solid var(--border); padding: 28px 26px; }
.quote-card__pills { display: flex; flex-wrap: wrap; gap: 10px; }
.quote-form { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.quote-form .full { grid-column: 1 / -1; }
.quote-form label { display: block; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-2); margin-bottom: 7px; }

.track-band { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px,4vw,48px); align-items: center; background: var(--surface); border: 1px solid var(--border); border-left: 4px solid var(--accent); padding: clamp(28px,4vw,44px); }
.track-band h3 { font-family: var(--font-disp); font-weight: 900; font-size: clamp(22px,3vw,30px); text-transform: uppercase; color: var(--fg); margin-bottom: 8px; }
.track-band p { color: var(--fg-2); margin: 0; }
.track-form, .track-search { display: flex; gap: 10px; flex-wrap: wrap; }
.track-form input, .track-search input { flex: 1 1 180px; padding: 13px 14px; background: var(--bg); color: var(--fg); border: 1px solid var(--border-2); font-family: var(--font-mono); font-size: 16px; letter-spacing: .08em; }
.track-form input:focus, .track-search input:focus { outline: none; border-color: var(--accent); }
.track-hint { font-size: 12px; color: var(--muted); }
.track-hint a { color: var(--accent); }

/* ════════════════════════════════════════════════════════════════
   CONTACT
   ════════════════════════════════════════════════════════════════ */
.contact-tiles { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); margin-bottom: clamp(36px,5vw,52px); }
.contact-info__item { background: var(--surface); padding: 26px 24px; }
.contact-info__item label { display: block; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin-bottom: 12px; }
.contact-info__item span { font-family: var(--font-disp); font-weight: 700; font-size: 20px; color: var(--fg); }
.contact-info__item a { color: var(--accent) !important; }
.contact-form-wrap { max-width: 720px; margin: 0 auto; }
.contact-form-wrap .det-card { background: var(--surface); border: 1px solid var(--border); padding: clamp(28px,4vw,40px); }
.contact-form-wrap h3 { font-family: var(--font-disp); font-weight: 800; font-size: 16px; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin-bottom: 18px; }
.contact-split-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ════════════════════════════════════════════════════════════════
   MERCH / SHOP
   ════════════════════════════════════════════════════════════════ */
.merch-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); }
.merch-card { background: var(--surface); display: flex; flex-direction: column; }
.merch-card:hover { background: var(--surface-2); }
.merch-card__img { aspect-ratio: 1; overflow: hidden; background: var(--ink-3); border-bottom: 1px solid var(--border); }
.merch-card__img img { width: 100%; height: 100%; object-fit: cover; }
.merch-card__noimg { width: 100%; height: 100%; display: grid; place-items: center; font-family: var(--font-mega); font-size: 64px; color: rgba(110,201,255,.18); }
.merch-card__body { padding: 18px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.merch-card__name { font-family: var(--font-disp); font-weight: 800; font-size: 17px; text-transform: uppercase; color: var(--fg); }
.merch-card__desc { color: var(--fg-2); font-size: 13.5px; line-height: 1.5; }
.merch-card__sizes { display: flex; flex-wrap: wrap; gap: 5px; }
.merch-card__sizes span { font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em; border: 1px solid var(--border-2); padding: 3px 7px; color: var(--fg-2); }
.merch-card__foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 10px; }
.merch-card__price { font-family: var(--font-mono); font-weight: 700; font-size: 17px; color: var(--accent); }
.merch-card__price--muted { color: var(--muted); }
.merch-empty { text-align: center; padding: 80px 20px; color: var(--fg-2); }
.merch-empty__mark { font-size: 40px; color: rgba(110,201,255,.3); margin-bottom: 16px; }
.merch-empty a { color: var(--accent); }
.merch-size__label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-2); margin: 6px 0 8px; }
.merch-size__pills { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.merch-size__pill { font-family: var(--font-mono); font-size: 12px; background: var(--bg); border: 1px solid var(--border-2); color: var(--fg); padding: 8px 13px; }
.merch-size__pill.is-sel { background: var(--accent); color: #07080A; border-color: var(--accent); }
.merch-modal__err { font-family: var(--font-mono); font-size: 12px; color: var(--red); border: 1px solid var(--red); padding: 9px 12px; }
.merch-done__mark { width: 56px; height: 56px; margin: 0 auto 16px; display: grid; place-items: center; font-size: 26px; color: #07080A; background: var(--accent); }

/* ════════════════════════════════════════════════════════════════
   MODAL  (lead modal + merch modal)
   ════════════════════════════════════════════════════════════════ */
.modal-bg { position: fixed; inset: 0; z-index: 400; display: none; align-items: center; justify-content: center; padding: 20px; background: rgba(5,6,8,.88); backdrop-filter: blur(4px); }
.modal-bg.is-open { display: flex; }
.modal { position: relative; width: 100%; max-width: 460px; max-height: 90vh; overflow-y: auto; background: var(--surface); border: 1px solid var(--accent-line); box-shadow: var(--shadow-lg); padding: 34px 30px; }
.modal__close { position: absolute; top: 12px; right: 14px; width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; background: transparent; border: 1px solid var(--border-2); color: var(--fg); font-size: 22px; }
.modal__close:hover { border-color: var(--accent); color: var(--accent); }
.modal h3 { font-family: var(--font-disp); font-weight: 900; font-size: 23px; text-transform: uppercase; color: var(--fg); margin-bottom: 8px; }
.modal > p, .modal p { color: var(--fg-2); font-size: 14px; margin-bottom: 18px; }
.modal form { display: flex; flex-direction: column; gap: 12px; }
.modal input, .modal textarea { width: 100%; padding: 13px 14px; background: var(--bg); color: var(--fg); border: 1px solid var(--border-2); font-family: var(--font-mono); font-size: 16px; }
.modal input:focus, .modal textarea:focus { outline: none; border-color: var(--accent); }
.modal textarea { font-family: var(--font-body); min-height: 90px; resize: vertical; }

/* ════════════════════════════════════════════════════════════════
   MISC  (head-row, cat, full, spec-band, status pages)
   ════════════════════════════════════════════════════════════════ */
.head-row { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 18px; margin-bottom: 30px; }
.head-row__lead { max-width: 60ch; }
.cat { font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
.full { grid-column: 1 / -1; }
.spec-band { background: var(--bg-2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.spec-band__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: 1px; background: var(--border); }
.spec-band__cell { background: var(--surface); padding: 26px 22px; }
.spec-band__h, .spec-band__k { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
.spec-band__p { font-family: var(--font-mega); font-size: clamp(30px,4vw,46px); color: var(--fg); line-height: 1; }
.quote-card__pills .hero__pill { background: rgba(255,255,255,.02); }

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════ */
@media (min-width: 1025px) and (max-width: 1280px) {
  /* two-column layout */
}
@media (max-width: 1024px) {
  .fin-hero__split { grid-template-columns: 1fr; }
  .fin-stats__grid { grid-template-columns: 1fr; align-items: start; }
  .fin-stats__row--2up { grid-auto-rows: auto; }
  .fin-hero__copy .hero__title { font-size: clamp(46px,11vw,84px); }
  .det-cols { grid-template-columns: 1fr; }
  .det-side { flex-direction: column; }
}
@media (max-width: 520px) {
  .fin-stats__row--2up { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .inv-bar__top { align-items: stretch; }
  .inv-bar__search { flex: 1 1 100%; }
  .inv-bar__go { flex: 1 1 auto; }
  .split { grid-template-columns: 1fr; }
  .track-band { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .nav, .topbar__cta { display: none; }
  .nav-toggle { display: block; }
  .quote-form { grid-template-columns: 1fr; }
  .fin-form-row, .contact-split-row { grid-template-columns: 1fr; }
  .cta-bar, .det-cta-banner { flex-direction: column; align-items: flex-start; }
  .compare-tbl { border: none; }
  .compare-tbl thead { display: none; }
  .compare-tbl tr { display: block; border: 1px solid var(--border); margin-bottom: 1px; background: var(--surface); }
  .compare-tbl td { display: flex; justify-content: space-between; gap: 16px; border-right: none; text-align: right; }
  .compare-tbl td::before { content: attr(data-label); font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); text-align: left; }
}
@media (max-width: 560px) {
  .footer-grid { grid-template-columns: 1fr; }
  .feat, .inv-grid, .inv-grid--2, .merch-grid { grid-template-columns: 1fr; }
  .det-stickybar { padding: 10px 16px; padding-bottom: max(10px, env(safe-area-inset-bottom)); }
  .det-stickybar__call { display: none; }
  /* Stack the car-detail hero overlay so title/price/CTA don't collide */
  .det-hero__scrim { flex-direction: column; align-items: flex-start; gap: 10px; padding: 20px 16px 16px; }
  .det-hero__aside { text-align: left; }
  .det-gallery__thumb { min-height: 44px; }
}

/* ════════════════════════════════════════════════════════════════
   HOME — v4 REBUILD  ("Command Console")
   Replaces the curved-loop marquee, the scroll-stack, and the
   cursor-proximity gradient headings with a static, grid-driven
   tactical layout. All classes prefixed .hx- so the shared
   component library (feat-card, why-card, steps, …) is untouched.
   ════════════════════════════════════════════════════════════════ */

/* ─── Hero: command console ─────────────────────────────────────── */
.hx-hero { position: relative; overflow: hidden; background: var(--bg); border-bottom: 1px solid var(--border); }
.hx-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: .45; filter: grayscale(0.3) contrast(1.05); }
.hx-hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 1;
  background-image:
    linear-gradient(rgba(110,201,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(110,201,255,.05) 1px, transparent 1px);
  background-size: 58px 58px;
  mask-image: radial-gradient(150% 110% at 85% 25%, #000 45%, transparent 100%);
}
.hx-hero__grid {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1.55fr .95fr;
  gap: clamp(26px, 4vw, 60px); align-items: stretch;
  padding-top: clamp(52px, 8vw, 104px); padding-bottom: clamp(40px, 6vw, 80px);
}
.hx-hero__main { align-self: center; min-width: 0; }
.hx-kicker {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .26em;
  text-transform: uppercase; color: var(--accent);
  border: 1px solid var(--accent-line); background: var(--accent-soft);
  padding: 7px 14px 6px; margin-bottom: 26px;
}
.hx-kicker::before { content: '▸'; }
.hx-hero__title {
  font-family: var(--font-mega); font-weight: 400;
  font-size: clamp(54px, 9.4vw, 156px); line-height: .82;
  letter-spacing: -.01em; text-transform: uppercase; color: var(--fg); margin: 0;
}
.hx-hero__title span { display: block; }
.hx-hero__title .accent { color: var(--accent); }
.hx-hero__sub { margin: 26px 0 0; max-width: 52ch; font-size: clamp(15px, 1.4vw, 18px); line-height: 1.6; color: var(--fg-2); }
.hx-hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }

/* HUD telemetry panel */
.hx-panel { align-self: center; border: 1px solid var(--border-2); background: rgba(15,16,18,.78); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
.hx-panel__top {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 16px; border-bottom: 1px solid var(--border);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--accent);
}
.hx-panel__top .hx-live { display: inline-flex; align-items: center; gap: 8px; color: var(--fg-2); }
.hx-panel__top .hx-live::before { content: ''; width: 7px; height: 7px; background: var(--accent); box-shadow: 0 0 8px var(--accent); animation: tvBlink 1.4s steps(1) infinite; }
.hx-row {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  padding: 15px 16px; border-bottom: 1px solid var(--border);
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .06em; text-transform: uppercase;
}
.hx-row__k { color: var(--fg-2); }
.hx-row__v { color: var(--fg); font-weight: 700; display: inline-flex; align-items: center; gap: 8px; }
.hx-row__v .ok { color: var(--accent); }
.hx-panel__foot { padding: 16px; display: flex; flex-direction: column; gap: 11px; }
.hx-check { display: flex; align-items: center; gap: 11px; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .04em; text-transform: uppercase; color: var(--fg-2); }
.hx-check::before { content: '✓'; color: var(--accent); font-weight: 700; }

/* static manifest strip — replaces the moving curved loop */
.hx-manifest {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: var(--border); border-top: 1px solid var(--border);
}
.hx-manifest__cell {
  background: var(--bg-2); padding: 16px clamp(14px, 2vw, 26px);
  font-family: var(--font-mono); font-size: clamp(11px, 1.05vw, 13px);
  letter-spacing: .12em; text-transform: uppercase; color: var(--fg);
  display: flex; align-items: center; gap: 11px;
}
.hx-manifest__cell::before { content: '//'; color: var(--accent); font-weight: 700; }

/* ─── Section head row ──────────────────────────────────────────── */
.hx-head { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 32px; }
.hx-head__title { font-family: var(--font-disp); font-weight: 900; font-size: clamp(30px, 4.6vw, 60px); line-height: .92; letter-spacing: -.03em; text-transform: uppercase; color: var(--fg); margin: 6px 0 0; }
.hx-head__lead { max-width: 54ch; color: var(--fg-2); }
.hx-link { font-family: var(--font-mono); font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); border-bottom: 1px solid var(--accent-line); padding-bottom: 3px; white-space: nowrap; }
.hx-link:hover { color: var(--accent-2); }

/* ─── Doctrine (reworked spec band) ─────────────────────────────── */
.hx-doctrine { display: grid; grid-template-columns: .92fr 1.08fr; gap: 1px; background: var(--border); border: 1px solid var(--border); }
.hx-doctrine__lead { background: var(--surface); padding: clamp(30px, 4vw, 48px); display: flex; flex-direction: column; justify-content: center; }
.hx-doctrine__eye { font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); margin-bottom: 18px; }
.hx-doctrine__big { font-family: var(--font-mega); font-weight: 400; font-size: clamp(38px, 5.2vw, 78px); line-height: .9; text-transform: uppercase; color: var(--fg); }
.hx-doctrine__big em { color: var(--accent); font-style: normal; }
.hx-doctrine__note { margin: 18px 0 0; color: var(--fg-2); font-size: 14px; line-height: 1.6; max-width: 38ch; }
.hx-doctrine__list { display: grid; gap: 1px; background: var(--border); }
.hx-rule { background: var(--surface); padding: 22px clamp(20px, 3vw, 32px); display: grid; grid-template-columns: auto 1fr; gap: 18px; align-items: start; }
.hx-rule:hover { background: var(--surface-2); }
.hx-rule__n { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--accent); border: 1px solid var(--accent-line); padding: 4px 8px; }
.hx-rule__h { font-family: var(--font-disp); font-weight: 800; text-transform: uppercase; font-size: 18px; letter-spacing: -.01em; color: var(--fg); margin: 1px 0 5px; }
.hx-rule__p { color: var(--fg-2); font-size: 14px; line-height: 1.55; margin: 0; }

/* ─── Bento (reworked "why" grid) ───────────────────────────────── */
.hx-bento { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); }
.hx-bento .why-card { margin: 0; height: 100%; }
.hx-bento__feature { grid-column: span 2; }
.hx-bento__feature.why-card { padding: clamp(30px, 3.4vw, 40px) clamp(26px, 3vw, 36px); }
.hx-bento__feature .why-card__icon { width: 54px; height: 54px; }
.hx-bento__feature h4 { font-size: clamp(22px, 2.5vw, 32px); margin-bottom: 12px; }
.hx-bento__feature p { font-size: 15.5px; max-width: 46ch; }
.hx-bento__stat { background: var(--surface); padding: 28px 26px; display: flex; flex-direction: column; gap: 6px; justify-content: center; position: relative; }
.hx-bento__stat::after { content: '+'; position: absolute; top: 12px; right: 14px; color: var(--accent); opacity: .5; font-family: var(--font-mono); }
.hx-bento__stat .k { font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
.hx-bento__stat .big { font-family: var(--font-mega); font-size: clamp(46px, 6vw, 74px); color: var(--fg); line-height: .95; }
.hx-bento__stat .sub { font-family: var(--font-mono); font-size: 11px; letter-spacing: .05em; color: var(--fg-2); line-height: 1.5; }

/* ─── Magic Bento — cursor glow / spotlight / particles / ripple ──────────
   Vanilla port of React Bits <MagicBento />, recolored to the site's light-blue accent
   (110,201,255). Applied to the home bento ([data-magic-bento], full effect)
   and the main card grids (.feat/.inv-grid/.rate-cards/.tx-cards/.merch-grid,
   glow + spotlight + ripple only). JS adds .mb-card to each child and drives
   the --mb-glow-* custom properties as the cursor moves. */
.hx-bento[data-magic-bento] { position: relative; }
.mb-card {
  position: relative;
  overflow: hidden;
  --mb-glow-x: 50%;
  --mb-glow-y: 50%;
  --mb-glow-intensity: 0;
  --mb-glow-radius: 320px;
}
/* tilt/magnetism only on the full-effect bento — keep other grids' own
   hover transitions intact. */
[data-magic-bento] .mb-card {
  transition: transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease;
  transform-style: preserve-3d;
}
[data-magic-bento] .mb-card:hover {
  box-shadow: 0 8px 28px rgba(0,0,0,.4), 0 0 30px rgba(110,201,255,.12);
}
/* cursor-tracking border glow (masked ring) */
.mb-card::after {
  content: '';
  position: absolute;
  inset: 0;
  padding: 2px;
  background: radial-gradient(
    var(--mb-glow-radius) circle at var(--mb-glow-x) var(--mb-glow-y),
    rgba(110,201,255, calc(var(--mb-glow-intensity) * 0.85)) 0%,
    rgba(110,201,255, calc(var(--mb-glow-intensity) * 0.4)) 30%,
    transparent 60%
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  pointer-events: none;
  transition: opacity .3s ease;
  z-index: 2;
}
/* particles spawned by JS */
.mb-particle {
  position: absolute;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: rgba(110,201,255,1);
  box-shadow: 0 0 6px rgba(110,201,255,.6);
  pointer-events: none;
  opacity: 0;
  transform: scale(0);
  transition: opacity 1.4s ease, transform 2.2s ease;
  z-index: 3;
}
/* click ripple */
.mb-ripple {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle,
    rgba(110,201,255,.4) 0%, rgba(110,201,255,.2) 30%, transparent 70%);
  pointer-events: none;
  transform: scale(0);
  opacity: 1;
  transition: transform .8s cubic-bezier(.2,.7,.2,1), opacity .8s ease;
  z-index: 4;
}
/* global pointer spotlight */
.mb-spotlight {
  position: fixed;
  width: 700px; height: 700px;
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, -50%);
  mix-blend-mode: screen;
  z-index: 50;
  transition: opacity .3s ease;
  background: radial-gradient(circle,
    rgba(110,201,255,.12) 0%,
    rgba(110,201,255,.07) 15%,
    rgba(110,201,255,.035) 25%,
    rgba(110,201,255,.018) 40%,
    rgba(110,201,255,.008) 65%,
    transparent 70%);
}
@media (prefers-reduced-motion: reduce) {
  .mb-card { transition: none; }
  .mb-card::after, .mb-spotlight { display: none; }
}

/* ─── Ledger (recent — replaces scroll-stack) ───────────────────── */
.hx-ledger { display: grid; gap: 1px; background: var(--border); border: 1px solid var(--border); }
.hx-roll { display: grid; grid-template-columns: 92px 1fr auto; gap: clamp(16px, 2.4vw, 28px); align-items: center; background: var(--surface); padding: 14px 18px; transition: background .15s ease; }
.hx-roll:hover { background: var(--surface-2); }
.hx-roll__img { width: 92px; height: 64px; object-fit: cover; background: var(--ink-3); border: 1px solid var(--border); }
.hx-roll__noimg { width: 92px; height: 64px; display: grid; place-items: center; background: var(--ink-3); border: 1px solid var(--border); font-family: var(--font-mono); font-size: 9px; letter-spacing: .14em; color: var(--muted); }
.hx-roll__main { min-width: 0; }
.hx-roll__name { font-family: var(--font-disp); font-weight: 800; text-transform: uppercase; font-size: clamp(15px, 1.6vw, 18px); letter-spacing: -.01em; color: var(--fg); }
.hx-roll__name .yr { color: var(--accent); }
.hx-roll__specs { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 7px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .04em; color: var(--fg-2); }
.hx-roll__specs span { border: 1px solid var(--border); padding: 2px 6px; }
.hx-roll__right { display: flex; align-items: center; gap: 16px; white-space: nowrap; }
.hx-roll__price { font-family: var(--font-mono); font-weight: 700; font-size: clamp(15px, 1.6vw, 18px); color: var(--accent); }
.hx-roll__price--muted { color: var(--muted); }
.hx-roll__arrow { font-family: var(--font-mono); color: var(--fg-2); transition: transform .15s ease, color .15s ease; }
.hx-roll:hover .hx-roll__arrow { color: var(--accent); transform: translateX(3px); }

/* ─── Home responsive ───────────────────────────────────────────── */
@media (max-width: 1024px) {
  .hx-hero__grid { grid-template-columns: 1fr; gap: 36px; }
  .hx-panel { max-width: 520px; }
  .hx-doctrine { grid-template-columns: 1fr; }
  .hx-bento { grid-template-columns: 1fr 1fr; }
  .hx-bento__feature { grid-column: span 2; }
}
@media (max-width: 720px) {
  .hx-manifest { grid-template-columns: 1fr 1fr; }
  .hx-bento { grid-template-columns: 1fr; }
  .hx-bento__feature { grid-column: span 1; }
  .hx-roll { grid-template-columns: 72px 1fr; }
  .hx-roll__right { grid-column: 1 / -1; justify-content: space-between; padding-top: 4px; border-top: 1px solid var(--border); }
}
@media (max-width: 480px) {
  .hx-manifest { grid-template-columns: 1fr; }
}

/* ─── Status / tracking pages (financing_status, shipping_track) ──── */
.track-search { max-width: 640px; margin-left: auto; margin-right: auto; }
.track-banner { max-width: 760px; margin: 24px auto 0; padding: 16px 20px; border: 1px solid var(--border-2); background: var(--surface); color: var(--fg); font-size: 15px; line-height: 1.55; border-radius: 2px; }
.track-banner--cancelled { background: rgba(255,77,61,.12); border-color: rgba(255,77,61,.5); color: #ff9c92; }
.track-banner--delayed { background: rgba(110,201,255,.1); border-color: var(--accent-line); color: var(--accent); }

.track-card { max-width: 760px; margin: 28px auto 0; border: 1px solid var(--border); background: var(--surface); padding: clamp(20px,3vw,30px); }
.track-card__main { display: flex; gap: 18px; align-items: flex-start; }
.track-card__icon { flex: 0 0 auto; width: 52px; height: 52px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--accent-line); background: var(--accent-soft); color: var(--accent); }
.track-card__body { min-width: 0; }
.track-card__code { font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-2); }
.track-card__title { font-family: var(--font-disp); font-weight: 800; text-transform: uppercase; font-size: clamp(20px,3vw,28px); color: var(--fg); margin: 6px 0 10px; }
.track-card__desc { color: var(--fg-2); font-size: 15px; line-height: 1.65; margin: 0; }
.track-card__illus { max-width: 96px; height: auto; display: block; margin-left: auto; flex: 0 0 auto; }

.track-steps { max-width: 760px; margin: 24px auto 0; display: flex; gap: 6px; }
.track-step { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; position: relative; }
.track-step::before { content: ''; position: absolute; top: 13px; left: -50%; width: 100%; height: 2px; background: var(--border-2); z-index: 0; }
.track-step:first-child::before { display: none; }
.track-step__dot { position: relative; z-index: 1; width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--border-2); background: var(--bg); display: flex; align-items: center; justify-content: center; color: var(--bg); }
.track-step__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em; color: var(--fg-2); line-height: 1.3; }
.track-step.is-done .track-step__dot { background: var(--accent); border-color: var(--accent); color: #07080A; }
.track-step.is-done::before { background: var(--accent); }
.track-step.is-current .track-step__dot { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); }
.track-step.is-current .track-step__label { color: var(--fg); }

.track-meta { max-width: 760px; margin: 24px auto 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); }
.track-meta__item { background: var(--surface); padding: 16px 18px; display: flex; flex-direction: column; gap: 6px; }
.track-meta__k { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-2); }
.track-meta__v { font-family: var(--font-mono); font-weight: 700; font-size: 16px; color: var(--fg); word-break: break-word; }
.track-arrow { color: var(--accent); }

.track-history { max-width: 760px; margin: 32px auto 0; }
.track-history__title { font-family: var(--font-disp); font-weight: 800; text-transform: uppercase; font-size: 15px; letter-spacing: .1em; color: var(--accent); margin-bottom: 16px; }
.track-events { list-style: none; margin: 0; padding: 0; }
.track-event { display: flex; gap: 14px; }
.track-event__rail { flex: 0 0 auto; display: flex; flex-direction: column; align-items: center; }
.track-event__node { width: 12px; height: 12px; border-radius: 50%; border: 2px solid var(--border-2); background: var(--bg); margin-top: 5px; }
.track-event.is-latest .track-event__node { background: var(--accent); border-color: var(--accent); }
.track-event__rail::after { content: ''; flex: 1; width: 2px; background: var(--border); margin: 4px 0; }
.track-event:last-child .track-event__rail::after { display: none; }
.track-event__content { padding-bottom: 22px; min-width: 0; }
.track-event__top { display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px 14px; }
.track-event__status { font-family: var(--font-disp); font-weight: 700; text-transform: uppercase; font-size: 14px; color: var(--fg); }
.track-event__time { font-family: var(--font-mono); font-size: 11px; letter-spacing: .06em; color: var(--muted); }
.track-event__loc { font-family: var(--font-mono); font-size: 12px; color: var(--fg-2); margin-top: 4px; }
.track-event__note { color: var(--fg-2); font-size: 14px; line-height: 1.55; margin-top: 5px; }

.track-empty { max-width: 620px; margin: 32px auto 0; text-align: center; padding: 40px 24px; border: 1px solid var(--border); background: var(--surface); }
.track-empty__icon { width: 64px; height: 64px; margin: 0 auto 18px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--border-2); color: var(--fg-2); border-radius: 50%; }
.track-empty h3 { font-family: var(--font-disp); font-weight: 800; text-transform: uppercase; font-size: 20px; color: var(--fg); margin-bottom: 12px; }
.track-empty p { color: var(--fg-2); font-size: 15px; line-height: 1.6; margin: 0 auto 22px; max-width: 44ch; }
.track-empty .btn { margin: 4px 6px 0; }

@media (max-width: 560px) {
  .track-card__main { flex-wrap: wrap; }
  .track-card__illus { display: none; }
  .track-steps { gap: 2px; }
  .track-step__label { font-size: 9.5px; }
}

/* ─── Legal pages (privacy, terms) ──────────────────────────────── */
.legal { max-width: 74ch; margin: 0 auto; }
.legal__updated { font-family: var(--font-mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin: 8px 0 28px; }
.legal h2 { font-family: var(--font-disp); font-weight: 800; text-transform: uppercase; font-size: clamp(18px,2.5vw,24px); color: var(--fg); margin: 36px 0 12px; letter-spacing: -.01em; }
.legal h3 { font-size: clamp(16px,2vw,19px); color: var(--fg); margin: 24px 0 10px; }
.legal p, .legal li { color: var(--fg-2); font-size: 15px; line-height: 1.75; }
.legal p { margin: 0 0 14px; }
.legal ul, .legal ol { padding-left: 22px; margin: 0 0 16px; }
.legal li { margin-bottom: 8px; }
.legal a { color: var(--accent); text-decoration: underline; }
.legal a[href^="tel:"], .legal a[href^="mailto:"] { display: inline-block; padding: 4px 0; text-decoration: none; }
.legal strong { color: var(--fg); }
