/* ==========================================================================
   Fairmark Motors — Certified Showroom design system
   Showcase Build #4 — SimpliTechPro portfolio demo (fictional dealership)
   ========================================================================== */

:root{
  /* palette — the only LIGHT demo in the set */
  --paper:      #F7F8FA;   /* porcelain canvas */
  --white:      #FFFFFF;
  --ink:        #1A1D21;   /* graphite */
  --ink-2:      #3E444C;   /* secondary text — 9.2:1 on paper */
  --ink-3:      #5A626D;   /* tertiary text — 5.6:1 on white */
  --line:       #E4E8EE;   /* hairlines */
  --line-2:     #D2D8E0;   /* stronger lines / input borders */

  --cobalt:     #1F5FFF;   /* primary accent — buttons, links */
  --cobalt-deep:#1244C9;   /* small cobalt text on white (6.9:1) + hover */
  --cobalt-tint:#EBF1FF;   /* washes, chips */

  --green:      #12A150;   /* certified / available state (badges w/ dark text or ≥3:1 UI) */
  --green-deep: #0B7A3B;   /* small green text on white (4.8:1) */
  --green-tint: #E7F6EE;

  /* type — Tesla-style geometric sans (Gotham substitute) */
  --font-head: "Montserrat", sans-serif;
  --font-ui:   "Inter", sans-serif;

  --radius: 14px;
  --radius-lg: 20px;
  --shadow-1: 0 1px 2px rgba(20,25,35,.05), 0 4px 16px rgba(20,25,35,.06);
  --shadow-2: 0 2px 6px rgba(20,25,35,.07), 0 16px 40px rgba(20,25,35,.10);
  --ease: cubic-bezier(.22,.61,.36,1);
  --maxw: 1180px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-ui);
  font-size:16px; line-height:1.6;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{ font-family:var(--font-head); line-height:1.08; margin:0; letter-spacing:-.015em; }
p{ margin:0; }
a{ color:var(--cobalt-deep); text-decoration:none; }
img{ max-width:100%; display:block; }
::selection{ background:var(--cobalt); color:#fff; }
:focus-visible{ outline:2px solid var(--cobalt); outline-offset:2px; border-radius:4px; }

/* numerals: prices, payments, tables all align */
.num, .chip-price, .hero-proof strong{
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-ui); font-weight:600; font-size:15.5px; line-height:1;
  padding:15px 26px; border-radius:12px; border:1px solid transparent;
  cursor:pointer; transition:transform .18s var(--ease), box-shadow .18s var(--ease),
    background .18s var(--ease), border-color .18s var(--ease);
  white-space:nowrap;
}
.btn-primary{
  background:var(--cobalt); color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22), 0 2px 8px rgba(31,95,255,.28);
}
.btn-primary:hover{ background:var(--cobalt-deep); transform:translateY(-1px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22), 0 6px 18px rgba(31,95,255,.32); }
.btn-ghost{
  background:var(--white); color:var(--ink); border-color:var(--line-2);
  box-shadow:0 1px 2px rgba(20,25,35,.04);
}
.btn-ghost:hover{ border-color:var(--ink-3); transform:translateY(-1px); }
.btn-sm{ padding:11px 18px; font-size:14.5px; border-radius:10px; }

/* ==========================================================================
   NAV
   ========================================================================== */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 24px;
  height:72px; display:flex; align-items:center; gap:32px;
}
.brand{ display:flex; align-items:center; gap:10px; }
.brand-mark svg{ display:block; }
.brand-word{
  font-family:var(--font-head); font-weight:700; font-size:20px; color:var(--ink);
  letter-spacing:-.02em;
}
.brand-word em{ font-style:normal; font-weight:500; color:var(--ink-3); }
.nav-links{ display:flex; gap:26px; margin-left:8px; }
.nav-links a{
  font-size:15px; font-weight:500; color:var(--ink-2); padding:6px 2px;
  border-bottom:2px solid transparent; transition:color .15s var(--ease);
}
.nav-links a:hover{ color:var(--ink); border-bottom-color:var(--cobalt); }
.nav-cta{ margin-left:auto; display:flex; align-items:center; gap:18px; }
.nav-phone{ font-size:15px; font-weight:600; color:var(--ink-2); font-variant-numeric:tabular-nums; }
.nav-phone:hover{ color:var(--cobalt-deep); }
.nav-burger{ display:none; }
.nav-drawer{ display:none; }

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative;
  background:
    radial-gradient(1100px 520px at 78% -10%, #E7EEFC 0%, rgba(231,238,252,0) 60%),
    radial-gradient(900px 480px at 8% 110%, #EDF2FB 0%, rgba(237,242,251,0) 55%),
    var(--paper);
  padding:64px 24px 96px;
  overflow:hidden;
}
.hero::before{ /* full-height blueprint grid — dimmed behind the headline for readability */
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(90deg, rgba(31,95,255,.11) 1.5px, transparent 1.5px),
    linear-gradient(0deg,  rgba(31,95,255,.11) 1.5px, transparent 1.5px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(760px 460px at 24% 34%, rgba(0,0,0,.18) 0%, rgba(0,0,0,.55) 55%, #000 85%);
          mask-image:radial-gradient(760px 460px at 24% 34%, rgba(0,0,0,.18) 0%, rgba(0,0,0,.55) 55%, #000 85%);
}
.hero::after{ /* showroom floor — perspective grid converging low */
  content:""; position:absolute; left:-35%; right:-35%; bottom:-4%; height:52%;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(31,95,255,.20) 2px, transparent 2px),
    linear-gradient(0deg,  rgba(31,95,255,.20) 2px, transparent 2px);
  background-size:110px 110px;
  transform:perspective(600px) rotateX(48deg);
  transform-origin:50% 100%;
  -webkit-mask-image:linear-gradient(180deg, transparent 4%, rgba(0,0,0,.8) 42%, #000 70%, rgba(0,0,0,.5) 100%);
          mask-image:linear-gradient(180deg, transparent 4%, rgba(0,0,0,.8) 42%, #000 70%, rgba(0,0,0,.5) 100%);
}
.hero-visual::after{ /* showroom spotlight pooling under the display card */
  content:""; position:absolute; left:5%; right:5%; bottom:-26px; height:52px;
  background:radial-gradient(50% 100% at 50% 0%, rgba(20,25,35,.16) 0%, rgba(20,25,35,0) 72%);
  filter:blur(6px); pointer-events:none;
}
.hero-inner, .hero-search{ position:relative; z-index:1; }
.hero-inner{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns: 1.02fr .98fr; gap:48px; align-items:center;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:13.5px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-3); margin-bottom:22px;
}
.eyebrow .dot{
  width:8px; height:8px; border-radius:50%; background:var(--green);
  box-shadow:0 0 0 4px var(--green-tint);
}
.hero h1{
  font-size:clamp(40px, 5vw, 64px); font-weight:700; color:var(--ink);
  letter-spacing:-.025em;
}
.hero-sub{
  margin-top:22px; max-width:46ch;
  font-size:18px; line-height:1.65; color:var(--ink-2);
}
.hero-ctas{ display:flex; gap:14px; margin-top:32px; flex-wrap:wrap; }
.hero-proof{
  list-style:none; display:flex; gap:36px; padding:0; margin:42px 0 0;
}
.hero-proof li{ display:flex; flex-direction:column; gap:2px; }
.hero-proof strong{
  font-family:var(--font-head); font-size:26px; font-weight:700; color:var(--ink);
  letter-spacing:-.01em;
}
.hero-proof span{ font-size:13.5px; color:var(--ink-3); }

/* visual */
.hero-visual{ position:relative; }
.hero-sweep{
  position:relative;
  background:linear-gradient(180deg, #FFFFFF 0%, #EDF0F5 100%);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-1);
  padding:14px;
}
.hero-visual img{
  position:relative; width:100%; height:auto; aspect-ratio:16/9.5; object-fit:cover;
  object-position:92% 86%;
  border-radius:12px;
  filter:saturate(.9) contrast(1.03) brightness(1.04);
}
.hero-sweep::after{ /* soften the photo top into the card */
  content:""; position:absolute; inset:14px; border-radius:12px; pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.55) 0%, rgba(255,255,255,0) 34%);
}
.hero-chip{
  position:absolute; left:32px; bottom:34px; z-index:2;
  background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius); box-shadow:var(--shadow-2);
  padding:14px 18px; display:flex; flex-direction:column; gap:3px;
}
.chip-status{
  display:inline-flex; align-items:center; gap:7px;
  font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  color:var(--green-deep);
}
.chip-status i{
  width:7px; height:7px; border-radius:50%; background:var(--green); display:inline-block;
}
.chip-title{ font-weight:600; font-size:15px; color:var(--ink); }
.chip-price{ font-weight:700; font-size:17px; color:var(--ink); }
.chip-price em{ font-style:normal; font-weight:500; font-size:13.5px; color:var(--ink-3); }

/* quick search card */
.hero-search{
  max-width:var(--maxw); margin:60px auto 0;
  background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-2);
  padding:18px; display:grid;
  grid-template-columns: repeat(3, 1fr) auto; gap:14px; align-items:end;
}
.hs-field{ display:flex; flex-direction:column; gap:6px; }
.hs-field label{
  font-size:12.5px; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  color:var(--ink-3);
}
.hs-field select{
  font-family:var(--font-ui); font-size:15px; color:var(--ink);
  padding:13px 14px; border-radius:10px; border:1px solid var(--line-2);
  background:var(--white);
  appearance:none;
  background-image:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8"><path d="M1 1.5l5 5 5-5" fill="none" stroke="%235A626D" stroke-width="1.8" stroke-linecap="round"/></svg>');
  background-repeat:no-repeat; background-position:right 14px center;
}
.hs-field select:hover{ border-color:var(--ink-3); }
.hero-search .btn{ height:47px; }
.hs-count{ font-weight:500; opacity:.85; }

/* ---------- scrolling inventory row (homepage) ---------- */
.home-row{ position:relative; z-index:1; margin-top:56px; }
.hr-head{
  max-width:var(--maxw); margin:0 auto 16px; padding:0;
  display:flex; align-items:baseline; justify-content:space-between;
}
.hr-title{
  font-size:13.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-3);
}
.hr-all{ font-size:14px; font-weight:600; }
.hr-wrap{
  overflow:hidden; margin:0 -24px; padding:6px 0 14px;
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%);
          mask-image:linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%);
}
.hr-track{
  display:flex; width:max-content;
  animation:hr-scroll 70s linear infinite;
}
.hr-wrap:hover .hr-track{ animation-play-state:paused; }
@keyframes hr-scroll{ to{ transform:translateX(-50%); } }
.hr-card{
  flex:none; width:264px; margin-right:18px;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow-1); color:var(--ink);
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}
.hr-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-2); }
.hr-photo{ position:relative; aspect-ratio:16/9; background:#EEF1F6; }
.hr-photo img{ width:100%; height:100%; object-fit:cover; }
.hr-info{ padding:12px 14px 14px; }
.hr-name{ font-size:14.5px; font-weight:700; letter-spacing:-.01em; }
.hr-price{ font-size:14.5px; font-weight:700; margin-top:4px; }
.hr-price em{ font-style:normal; font-weight:500; font-size:12.5px; color:var(--ink-3); }
@media (prefers-reduced-motion: reduce){
  .hr-track{ animation:none; }
  .hr-wrap{ overflow-x:auto; }
}

/* ==========================================================================
   TRUST BAR
   ========================================================================== */
.trust{ background:var(--white); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.trust-inner{
  max-width:var(--maxw); margin:0 auto; padding:22px 24px;
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
}
.trust-item{
  display:flex; align-items:center; gap:10px;
  font-size:14px; font-weight:500; color:var(--ink-2);
}
.trust-item svg{ width:22px; height:22px; color:var(--cobalt); flex:none; }

/* ==========================================================================
   SHOP PAGE
   ========================================================================== */
.no-scroll{ overflow:hidden; }
.shop{ max-width:var(--maxw); margin:0 auto; padding:40px 24px 90px; }
.shop-head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:20px;
  margin-bottom:26px; flex-wrap:wrap;
}
.shop-head h1{ font-size:clamp(30px, 3.4vw, 42px); font-weight:700; letter-spacing:-.02em; }
.shop-sub{ color:var(--ink-3); font-size:15px; margin-top:6px; }
.shop-tools{ display:flex; align-items:center; gap:12px; }
.shop-filter-toggle{ display:none; }
.sort-label{ font-size:13px; font-weight:600; color:var(--ink-3); text-transform:uppercase; letter-spacing:.04em; }
.sort-select{
  font-family:var(--font-ui); font-size:14.5px; color:var(--ink);
  padding:10px 34px 10px 12px; border-radius:10px; border:1px solid var(--line-2); background:var(--white);
  appearance:none;
  background-image:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8"><path d="M1 1.5l5 5 5-5" fill="none" stroke="%235A626D" stroke-width="1.8" stroke-linecap="round"/></svg>');
  background-repeat:no-repeat; background-position:right 12px center;
}

.shop-body{ display:grid; grid-template-columns:264px 1fr; gap:32px; align-items:start; }

/* filter rail */
.filters{
  position:sticky; top:92px;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-1); padding:20px;
}
.f-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.f-head strong{ font-size:15px; }
.f-clear{
  background:none; border:none; padding:4px; cursor:pointer;
  font-family:var(--font-ui); font-size:13px; font-weight:600; color:var(--cobalt-deep);
}
.f-clear:hover{ text-decoration:underline; }
.f-close{ display:none; }
.f-group{ padding:14px 0; border-top:1px solid var(--line); }
.f-label{
  display:block; font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink-3); margin-bottom:9px;
}
.f-group input[type="search"]{
  width:100%; font-family:var(--font-ui); font-size:14.5px; color:var(--ink);
  padding:10px 12px; border-radius:10px; border:1px solid var(--line-2); background:var(--white);
}
.f-group select{
  width:100%; font-family:var(--font-ui); font-size:14.5px; color:var(--ink);
  padding:10px 12px; border-radius:10px; border:1px solid var(--line-2); background:var(--white);
  appearance:none;
  background-image:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8"><path d="M1 1.5l5 5 5-5" fill="none" stroke="%235A626D" stroke-width="1.8" stroke-linecap="round"/></svg>');
  background-repeat:no-repeat; background-position:right 12px center;
}
.f-checks{ display:flex; flex-direction:column; gap:8px; }
.f-check{
  display:flex; align-items:center; gap:9px; font-size:14.5px; color:var(--ink-2); cursor:pointer;
}
.f-check input{ width:17px; height:17px; accent-color:var(--cobalt); cursor:pointer; }
.f-range{ display:flex; justify-content:space-between; font-size:13.5px; font-weight:600; color:var(--ink-2); margin-bottom:8px; }
.dual-range{ position:relative; height:28px; }
.dual-range input[type="range"]{
  position:absolute; left:0; right:0; top:50%; transform:translateY(-50%);
  width:100%; margin:0; background:none; pointer-events:none;
  -webkit-appearance:none; appearance:none; height:4px;
}
.dual-range input[type="range"]::-webkit-slider-runnable-track{ height:4px; background:transparent; }
.dual-range{ background:linear-gradient(var(--line-2), var(--line-2)) center/100% 4px no-repeat; border-radius:4px; }
.dual-range input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none; appearance:none; pointer-events:auto;
  width:18px; height:18px; margin-top:-7px; border-radius:50%;
  background:var(--white); border:2.5px solid var(--cobalt);
  box-shadow:0 1px 4px rgba(20,25,35,.18); cursor:pointer;
}
.dual-range input[type="range"]::-moz-range-thumb{
  pointer-events:auto; width:15px; height:15px; border-radius:50%;
  background:var(--white); border:2.5px solid var(--cobalt);
  box-shadow:0 1px 4px rgba(20,25,35,.18); cursor:pointer;
}
.f-apply{ display:none; width:100%; margin-top:16px; }

/* results */
.results-count{ font-size:14.5px; color:var(--ink-3); margin-bottom:14px; }
.results-count strong{ color:var(--ink); font-weight:700; }
.veh-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(272px, 1fr)); gap:20px;
}
.v-card{
  display:block; background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:var(--shadow-1); color:var(--ink);
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease);
}
.v-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-2); border-color:var(--line-2); }
.v-photo{ position:relative; aspect-ratio:16/10; background:#EEF1F6; }
.v-photo img{ width:100%; height:100%; object-fit:cover; }
.v-badge{
  position:absolute; top:12px; left:12px;
  display:inline-flex; align-items:center; gap:5px;
  background:var(--white); color:var(--green-deep);
  font-size:11.5px; font-weight:700; letter-spacing:.04em; text-transform:uppercase;
  padding:5px 9px; border-radius:8px; box-shadow:0 1px 4px rgba(20,25,35,.14);
}
.v-badge svg{ color:var(--green); }
.v-pill{
  position:absolute; top:12px; right:12px;
  font-size:11.5px; font-weight:700; letter-spacing:.04em; text-transform:uppercase;
  padding:5px 9px; border-radius:8px; color:#fff;
}
.v-pill--reserved{ background:var(--ink); }
.v-pill--sold{ background:#B42318; }
.v-card.is-sold .v-photo img{ filter:grayscale(.85); opacity:.8; }
.v-info{ padding:16px 18px 18px; }
.v-title{ font-size:17px; font-weight:700; letter-spacing:-.01em; }
.v-trim{ font-size:13.5px; color:var(--ink-3); margin-top:2px; }
.v-price{ font-size:18px; font-weight:700; margin-top:10px; }
.v-price em{ font-style:normal; font-weight:500; font-size:13.5px; color:var(--ink-3); }
.v-specs{ font-size:13px; color:var(--ink-3); margin-top:6px; }

/* empty state */
.empty{
  text-align:center; padding:70px 20px; color:var(--ink-3);
  background:var(--white); border:1px dashed var(--line-2); border-radius:var(--radius-lg);
}
.empty h3{ margin-top:14px; color:var(--ink); font-size:19px; }
.empty p{ max-width:38ch; margin:8px auto 20px; font-size:14.5px; }

/* ==========================================================================
   VEHICLE DETAIL + FINANCING CALCULATOR
   ========================================================================== */
.veh{ max-width:var(--maxw); margin:0 auto; padding:28px 24px 90px; }
.crumbs{ margin-bottom:18px; }
.crumbs a{ font-size:14px; font-weight:600; color:var(--ink-3); }
.crumbs a:hover{ color:var(--cobalt-deep); }
.veh-loading{ text-align:center; padding:90px 20px; }
.veh-loading p{ color:var(--ink-3); margin:10px 0 24px; }

.veh-top{ display:grid; grid-template-columns:1.05fr .95fr; gap:36px; align-items:start; }
.veh-photo{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--shadow-1); background:#EEF1F6;
  position:sticky; top:96px;
}
.veh-photo img{ width:100%; aspect-ratio:16/11; object-fit:cover; }
.veh-summary h1{ font-size:clamp(26px, 3vw, 36px); font-weight:700; letter-spacing:-.02em; }
.veh-trim{ color:var(--ink-3); font-size:15px; margin-top:4px; }
.veh-price{ font-size:28px; font-weight:700; margin-top:16px; }
.veh-price em{ font-style:normal; font-weight:500; font-size:16px; color:var(--ink-3); }
.veh-price-note{ font-size:12.5px; color:var(--ink-3); margin-top:2px; }
.veh-actions{ display:flex; gap:12px; margin-top:20px; flex-wrap:wrap; }
.veh-assure{
  list-style:none; display:flex; gap:8px 18px; flex-wrap:wrap; padding:0; margin:18px 0 0;
}
.veh-assure li{
  font-size:13px; font-weight:600; color:var(--green-deep);
  display:flex; align-items:center; gap:6px;
}
.veh-assure li::before{ content:"✓"; font-weight:700; }
.veh-specs{
  display:grid; grid-template-columns:repeat(2, 1fr); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; margin-top:22px;
}
.spec{ background:var(--white); padding:12px 16px; display:flex; flex-direction:column; gap:2px; }
.spec-k{ font-size:11.5px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3); }
.spec-v{ font-size:14.5px; font-weight:600; color:var(--ink); }
.veh-features{
  list-style:none; display:flex; gap:8px; flex-wrap:wrap; padding:0; margin:18px 0 0;
}
.veh-features li{
  font-size:13px; font-weight:500; color:var(--ink-2);
  background:var(--white); border:1px solid var(--line-2); border-radius:999px;
  padding:6px 13px;
}

/* calculator */
.calc{
  margin-top:56px; background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-1); padding:34px;
}
.calc-head h2{ font-size:clamp(22px, 2.4vw, 28px); letter-spacing:-.02em; }
.calc-head p{ color:var(--ink-3); font-size:14.5px; margin-top:6px; }
.calc-demo{
  display:inline-block; margin-left:6px; font-size:11.5px; font-weight:700; letter-spacing:.05em;
  text-transform:uppercase; color:var(--cobalt-deep); background:var(--cobalt-tint);
  border-radius:6px; padding:3px 8px;
}
.calc-body{ display:grid; grid-template-columns:1fr 1.1fr; gap:40px; margin-top:26px; }
.calc-inputs{ display:grid; grid-template-columns:1fr 1fr; gap:16px; align-content:start; }
.c-field{ display:flex; flex-direction:column; gap:6px; }
.c-field:first-child{ grid-column:1 / -1; }
.c-field span{
  font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3);
}
.c-field input, .c-field select{
  font-family:var(--font-ui); font-size:16px; font-weight:600; color:var(--ink);
  padding:12px 14px; border-radius:10px; border:1px solid var(--line-2); background:var(--white);
  width:100%;
}
.c-field select{
  appearance:none;
  background-image:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8"><path d="M1 1.5l5 5 5-5" fill="none" stroke="%235A626D" stroke-width="1.8" stroke-linecap="round"/></svg>');
  background-repeat:no-repeat; background-position:right 12px center;
}
.c-field input:focus, .c-field select:focus{ border-color:var(--cobalt); outline:none; box-shadow:0 0 0 3px var(--cobalt-tint); }
.calc-out{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:26px 28px;
}
.co-label{
  font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3);
}
.co-monthly{ margin-top:4px; }
.co-monthly .num{
  font-family:var(--font-head); font-size:clamp(38px, 4vw, 52px); font-weight:700;
  letter-spacing:-.02em; color:var(--ink);
}
.co-monthly em{ font-style:normal; font-size:16px; color:var(--ink-3); margin-left:4px; }
.co-bar{
  display:flex; gap:2px; height:14px; margin-top:20px; border-radius:7px; overflow:hidden;
}
.co-seg{ height:100%; min-width:6px; transition:width .3s var(--ease); }
.co-seg--p{ background:var(--cobalt); border-radius:7px 0 0 7px; }
.co-seg--i{ background:#B45309; border-radius:0 7px 7px 0; }
.co-legend{ display:flex; gap:22px; flex-wrap:wrap; margin-top:12px; }
.co-key{ display:flex; align-items:center; gap:7px; font-size:13.5px; color:var(--ink-2); }
.co-key strong{ color:var(--ink); font-weight:700; }
.co-dot{ width:10px; height:10px; border-radius:3px; display:inline-block; }
.co-dot--p{ background:var(--cobalt); }
.co-dot--i{ background:#B45309; }
.co-rows{ margin-top:18px; border-top:1px solid var(--line); }
.co-row{
  display:flex; justify-content:space-between; padding:10px 0; font-size:14.5px;
  color:var(--ink-2); border-bottom:1px solid var(--line);
}
.co-row strong{ color:var(--ink); }

/* more from the showroom */
.more{ margin-top:56px; }
.more-head{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:18px; }
.more-head h2{ font-size:22px; letter-spacing:-.02em; }
.more-head a{ font-size:14px; font-weight:600; }

/* ==========================================================================
   WIZARD MODALS (demo flows)
   ========================================================================== */
.wz-overlay{
  position:fixed; inset:0; z-index:100; background:rgba(20,25,35,.46);
  display:flex; align-items:center; justify-content:center; padding:18px;
}
.wz{
  width:100%; max-width:480px; max-height:92vh; overflow-y:auto;
  background:var(--white); border-radius:var(--radius-lg); box-shadow:var(--shadow-2);
  display:flex; flex-direction:column;
}
.wz-top{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 22px; border-bottom:1px solid var(--line);
}
.wz-top strong{ font-family:var(--font-head); font-size:17px; letter-spacing:-.01em; }
.wz-x{
  background:none; border:none; font-size:26px; line-height:1; color:var(--ink-3);
  cursor:pointer; padding:2px 6px; border-radius:8px;
}
.wz-x:hover{ color:var(--ink); background:var(--paper); }
.wz-body{ padding:20px 22px 24px; }
.wz-body h3{ font-size:18px; margin:14px 0 12px; letter-spacing:-.01em; }
.wz-banner{
  margin-top:auto; padding:10px 22px; border-top:1px solid var(--line);
  background:var(--paper); font-size:11px; font-weight:700; letter-spacing:.06em;
  color:var(--ink-3); text-align:center; border-radius:0 0 var(--radius-lg) var(--radius-lg);
}
.wz-dots{ display:flex; gap:6px; margin-bottom:12px; }
.wz-dots i{ width:26px; height:4px; border-radius:2px; background:var(--line-2); }
.wz-dots i.on{ background:var(--cobalt); }
.wz-veh{
  display:flex; align-items:center; gap:12px;
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:10px 12px;
}
.wz-veh img{ width:74px; height:50px; object-fit:cover; border-radius:8px; }
.wz-veh strong{ display:block; font-size:14.5px; }
.wz-veh span{ font-size:13px; color:var(--ink-3); }
.wz-days{ display:flex; gap:8px; flex-wrap:wrap; }
.wz-times{ display:flex; gap:8px; flex-wrap:wrap; margin-top:12px; min-height:44px; }
.wz-hint{ font-size:13.5px; color:var(--ink-3); align-self:center; }
.slot{
  font-family:var(--font-ui); font-size:13.5px; font-weight:600; color:var(--ink-2);
  background:var(--white); border:1px solid var(--line-2); border-radius:10px;
  padding:9px 13px; cursor:pointer; transition:all .15s var(--ease);
}
.slot:hover:not([disabled]){ border-color:var(--cobalt); color:var(--cobalt-deep); }
.slot.sel{ background:var(--cobalt); border-color:var(--cobalt); color:#fff; }
.slot[disabled]{ opacity:.5; cursor:not-allowed; }
.slot em{ font-style:normal; font-size:11px; font-weight:700; text-transform:uppercase; margin-left:4px; }
.wz-next{ width:100%; margin-top:18px; }
.wz-fields{ display:flex; flex-direction:column; gap:12px; margin-top:4px; }
.wz-fields label{
  display:flex; flex-direction:column; gap:5px;
  font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3);
}
.wz-fields input, .wz-fields select{
  font-family:var(--font-ui); font-size:15.5px; font-weight:500; color:var(--ink);
  padding:11px 13px; border-radius:10px; border:1px solid var(--line-2); background:var(--white);
}
.wz-fields input:focus, .wz-fields select:focus{
  border-color:var(--cobalt); outline:none; box-shadow:0 0 0 3px var(--cobalt-tint);
}
.wz-half{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.wz-row{ display:flex; gap:10px; margin-top:18px; }
.wz-row .btn{ flex:1; }
.wz-err{ margin-top:12px; font-size:13.5px; font-weight:600; color:#B42318; }
.wz-fill{
  margin-top:10px; background:none; border:none; cursor:pointer; padding:2px;
  font-family:var(--font-ui); font-size:13px; font-weight:600; color:var(--cobalt-deep);
  text-decoration:underline;
}
.wz-test{
  display:inline-block; vertical-align:2px; font-size:10.5px; font-weight:800; letter-spacing:.07em;
  color:#92400E; background:#FEF3C7; border-radius:6px; padding:3px 7px;
}
.wz-qualify{
  text-align:center; background:var(--green-tint); border:1px solid #CDEBDA;
  border-radius:var(--radius); padding:18px; margin-bottom:14px;
}
.wz-amount{
  font-family:var(--font-head); font-size:38px; font-weight:700; letter-spacing:-.02em;
  color:var(--green-deep); margin-top:2px;
}
.wz-reserve{ margin-top:14px; font-size:14.5px; }
.wz-reserve p{ color:var(--ink-2); margin-top:4px; }
.wz-done{ text-align:center; padding:8px 0 4px; }
.wz-check{
  display:inline-flex; align-items:center; justify-content:center;
  width:60px; height:60px; border-radius:50%; background:var(--green-tint); color:var(--green-deep);
  margin-bottom:12px;
}
.wz-ref{ font-size:13.5px; font-weight:600; color:var(--ink-3); margin-top:4px; }
.wz-summary{
  margin:16px 0; border:1px solid var(--line); border-radius:var(--radius); text-align:left;
}
.wz-summary > div{
  display:flex; justify-content:space-between; gap:14px; padding:10px 14px;
  font-size:14px; border-bottom:1px solid var(--line);
}
.wz-summary > div:last-child{ border-bottom:none; }
.wz-summary span{ color:var(--ink-3); }
.wz-note{ font-size:13.5px; color:var(--ink-2); margin:12px 0 16px; }
.wz-done .btn{ width:100%; }
.wz-processing{ text-align:center; padding:46px 0; }
.wz-processing p{ margin-top:14px; color:var(--ink-2); font-weight:500; }
.wz-spin{
  display:inline-block; width:38px; height:38px; border-radius:50%;
  border:3.5px solid var(--line-2); border-top-color:var(--cobalt);
  animation:wz-rot .8s linear infinite;
}
@keyframes wz-rot{ to{ transform:rotate(360deg); } }
@media (prefers-reduced-motion: reduce){ .wz-spin{ animation-duration:2s; } }

/* toast */
.toast{
  position:fixed; left:50%; bottom:28px; transform:translate(-50%, 12px); z-index:120;
  background:var(--ink); color:#fff; font-size:14px; font-weight:500;
  padding:12px 20px; border-radius:12px; box-shadow:var(--shadow-2);
  opacity:0; transition:opacity .25s var(--ease), transform .25s var(--ease);
  max-width:88vw; text-align:center;
}
.toast.show{ opacity:1; transform:translate(-50%, 0); }

/* honesty footer (slim) */
.footer-lite{
  border-top:1px solid var(--line); background:var(--white);
  padding:26px 24px; text-align:center;
}
.footer-lite p{ max-width:640px; margin:0 auto; font-size:13.5px; color:var(--ink-3); }
.footer-lite a{ font-weight:600; }

/* ==========================================================================
   HOMEPAGE SECTIONS (M6)
   ========================================================================== */
.sec-head{ max-width:560px; margin-bottom:38px; }
.sec-head h2{ font-size:clamp(26px, 3vw, 38px); font-weight:700; letter-spacing:-.02em; }
.sec-head p{ color:var(--ink-3); font-size:16px; margin-top:10px; }

/* how it works */
.how{ background:var(--white); border-bottom:1px solid var(--line); }
.how-inner{ max-width:var(--maxw); margin:0 auto; padding:84px 24px; }
.how-steps{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(3, 1fr); gap:22px;
  counter-reset:step;
}
.how-step{
  position:relative; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:26px 26px 28px;
}
.how-n{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border-radius:12px;
  background:var(--cobalt); color:#fff;
  font-family:var(--font-head); font-size:18px; font-weight:700;
  box-shadow:0 2px 8px rgba(31,95,255,.28);
}
.how-step h3{ font-size:18px; margin-top:18px; letter-spacing:-.01em; }
.how-step p{ font-size:14.5px; color:var(--ink-2); line-height:1.6; margin-top:9px; }

/* financing teaser */
.fin{ background:var(--paper); }
.fin-inner{
  max-width:var(--maxw); margin:0 auto; padding:84px 24px;
  display:grid; grid-template-columns:.9fr 1.1fr; gap:52px; align-items:center;
}
.fin-copy h2{ font-size:clamp(26px, 3vw, 38px); font-weight:700; letter-spacing:-.02em; }
.fin-copy > p{ color:var(--ink-2); font-size:16px; line-height:1.65; margin-top:14px; max-width:44ch; }
.fin-points{ list-style:none; padding:0; margin:20px 0 26px; display:flex; flex-direction:column; gap:9px; }
.fin-points li{
  font-size:14.5px; font-weight:600; color:var(--ink-2);
  display:flex; align-items:center; gap:9px;
}
.fin-points li::before{ content:"✓"; color:var(--green-deep); font-weight:700; }
.fin-calc{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-2); padding:26px;
}
.fin-fields{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fin-out{
  margin-top:20px; padding-top:20px; border-top:1px solid var(--line);
}
.fin-out .co-monthly .num{ font-size:clamp(34px, 3.6vw, 46px); }
.fin-note{ font-size:12.5px; color:var(--ink-3); margin-top:10px; max-width:46ch; }

/* why fairmark */
.why{ background:var(--white); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.why-inner{ max-width:var(--maxw); margin:0 auto; padding:84px 24px; }
.why-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:20px; }
.why-card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:24px 24px 26px;
}
.why-card h3{ font-size:16.5px; letter-spacing:-.01em; }
.why-card p{ font-size:14px; color:var(--ink-2); line-height:1.6; margin-top:9px; }

/* sell / trade */
.sell{ background:var(--paper); }
.sell-inner{
  max-width:var(--maxw); margin:0 auto; padding:84px 24px;
  display:grid; grid-template-columns:.95fr 1.05fr; gap:52px; align-items:start;
}
.sell-copy h2{ font-size:clamp(26px, 3vw, 38px); font-weight:700; letter-spacing:-.02em; }
.sell-copy p{ color:var(--ink-2); font-size:16px; line-height:1.65; margin-top:14px; max-width:44ch; }
.sell-widget{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-1); padding:26px;
}
.sell-fields{ display:grid; grid-template-columns:1fr 1.2fr 1.4fr; gap:14px; margin-bottom:18px; }
.sell-widget .btn{ width:100%; }
.sell-result{ margin-top:20px; padding-top:20px; border-top:1px solid var(--line); }
.sell-result[hidden]{ display:none; }
.sell-range{
  font-family:var(--font-head); font-size:clamp(28px, 3vw, 38px); font-weight:700;
  letter-spacing:-.02em; margin-top:4px;
}

/* closing cta — confident cobalt block */
.closing{ background:linear-gradient(135deg, var(--cobalt-deep) 0%, var(--cobalt) 100%); }
.closing-inner{
  max-width:760px; margin:0 auto; padding:88px 24px; text-align:center; color:#fff;
}
.closing h2{ font-size:clamp(28px, 3.4vw, 44px); font-weight:700; letter-spacing:-.02em; color:#fff; }
.closing-inner > p{ font-size:17px; line-height:1.6; color:rgba(255,255,255,.95); margin-top:14px; } /* 4.73:1 on cobalt — AA */
.closing-ctas{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:30px; }
.closing .btn-primary{
  background:#fff; color:var(--cobalt-deep);
  box-shadow:0 2px 10px rgba(10,25,80,.25);
}
.closing .btn-primary:hover{ background:#F0F4FF; }
.closing .btn-ghost{
  background:transparent; color:#fff; border-color:rgba(255,255,255,.55);
}
.closing .btn-ghost:hover{ border-color:#fff; background:rgba(255,255,255,.08); }
.closing-note{ font-size:13px; color:rgba(255,255,255,.95); margin-top:20px; } /* 4.73:1 on cobalt — AA */

/* full footer */
.footer{ background:var(--white); border-top:1px solid var(--line); }
.footer-inner{
  max-width:var(--maxw); margin:0 auto; padding:60px 24px 44px;
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:36px;
}
.foot-brand p{ font-size:14px; color:var(--ink-3); line-height:1.6; margin-top:14px; max-width:34ch; }
.foot-col{ display:flex; flex-direction:column; gap:10px; }
.foot-col strong{
  font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-3); margin-bottom:4px;
}
.foot-col a, .foot-col span{ font-size:14.5px; color:var(--ink-2); }
.foot-col a:hover{ color:var(--cobalt-deep); }
.foot-legal{ border-top:1px solid var(--line); padding:20px 24px; }
.foot-legal p{
  max-width:var(--maxw); margin:0 auto; font-size:13px; color:var(--ink-3); line-height:1.6;
}
.foot-legal a{ font-weight:600; }

@media (max-width: 940px){
  .how-steps{ grid-template-columns:1fr; }
  .fin-inner, .sell-inner{ grid-template-columns:1fr; gap:34px; padding:64px 24px; }
  .why-grid{ grid-template-columns:1fr 1fr; }
  .how-inner, .why-inner{ padding:64px 24px; }
  .footer-inner{ grid-template-columns:1fr 1fr; gap:30px; }
}
@media (max-width: 560px){
  .why-grid{ grid-template-columns:1fr; }
  .sell-fields{ grid-template-columns:1fr; }
  .fin-fields{ grid-template-columns:1fr 1fr; }
  .footer-inner{ grid-template-columns:1fr; padding:48px 18px 36px; }
  .how-inner, .why-inner, .fin-inner, .sell-inner{ padding:56px 18px; }
  .closing-inner{ padding:68px 18px; }
}

/* ==========================================================================
   STAFF DASHBOARD (admin.html — demo back office)
   ========================================================================== */
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}
.adm-body{ background:var(--paper); }
/* the hidden attribute must beat the display rules below */
.adm-login[hidden], .adm-app[hidden], .adm-panel[hidden]{ display:none; }
.adm-top{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.9); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.adm-top-inner{
  max-width:1280px; margin:0 auto; padding:0 24px; height:64px;
  display:flex; align-items:center; gap:16px;
}
.adm-badge{
  font-size:11px; font-weight:800; letter-spacing:.07em; text-transform:uppercase;
  color:var(--cobalt-deep); background:var(--cobalt-tint);
  border-radius:6px; padding:4px 9px; white-space:nowrap;
}
.adm-top-right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.adm-back{ font-size:14px; font-weight:600; color:var(--ink-2); }
.adm-back:hover{ color:var(--cobalt-deep); }

/* login gate */
.adm-login{ min-height:calc(100vh - 210px); display:flex; align-items:center; justify-content:center; padding:48px 20px; }
.adm-login-card{
  width:100%; max-width:400px; background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-2); padding:32px 30px;
  display:flex; flex-direction:column; gap:14px;
}
.adm-login-card h1{ font-size:24px; letter-spacing:-.02em; }
.adm-login-sub{ font-size:14px; color:var(--ink-3); line-height:1.55; }
.adm-field{
  display:flex; flex-direction:column; gap:5px;
  font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3);
}
.adm-field input{
  font-family:var(--font-ui); font-size:15.5px; font-weight:500; color:var(--ink);
  padding:12px 13px; border-radius:10px; border:1px solid var(--line-2); background:var(--white);
}
.adm-field input:focus{ border-color:var(--cobalt); outline:none; box-shadow:0 0 0 3px var(--cobalt-tint); }
.adm-login-card .wz-fill{ margin-top:2px; align-self:center; }

/* console layout */
.adm-app{
  max-width:1280px; margin:0 auto; padding:28px 24px 90px;
  display:grid; grid-template-columns:216px 1fr; gap:28px; align-items:start;
}
.adm-side{
  position:sticky; top:88px; display:flex; flex-direction:column; gap:4px;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-1); padding:10px;
}
.adm-tab{
  display:flex; align-items:center; gap:10px; text-align:left;
  font-family:var(--font-ui); font-size:14.5px; font-weight:600; color:var(--ink-2);
  background:none; border:none; border-radius:10px; padding:11px 12px; cursor:pointer;
  transition:background .15s var(--ease), color .15s var(--ease);
}
.adm-tab svg{ width:19px; height:19px; flex:none; color:var(--ink-3); }
.adm-tab:hover{ background:var(--paper); color:var(--ink); }
.adm-tab.is-on{ background:var(--cobalt-tint); color:var(--cobalt-deep); }
.adm-tab.is-on svg{ color:var(--cobalt-deep); }
.adm-count{
  font-style:normal; margin-left:auto; font-size:12px; font-weight:700;
  color:var(--ink-3); background:var(--paper); border-radius:999px; padding:2px 8px;
  font-variant-numeric:tabular-nums;
}
.adm-tab.is-on .adm-count{ background:#fff; color:var(--cobalt-deep); }
.adm-tab--reset{ margin-top:8px; border-top:1px solid var(--line); border-radius:0 0 10px 10px; color:var(--ink-3); font-size:13.5px; }

.adm-main{ min-width:0; }
.adm-h1{ font-size:clamp(24px, 2.6vw, 32px); font-weight:700; letter-spacing:-.02em; }
.adm-sub{ color:var(--ink-3); font-size:14.5px; margin-top:5px; }
.adm-panel-head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap;
}

/* KPI tiles */
.kpis{ display:grid; grid-template-columns:repeat(4, 1fr); gap:16px; margin-top:22px; }
.kpi{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-1); padding:18px 20px; display:flex; flex-direction:column; gap:2px;
}
.kpi-label{ font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3); }
.kpi-value{ font-family:var(--font-head); font-size:34px; font-weight:700; letter-spacing:-.02em; color:var(--ink); }
.kpi-sub{ font-size:13px; color:var(--ink-3); }

.adm-duo{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:16px; }
.adm-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-1); padding:18px 20px;
}
.adm-card-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px;
}
.adm-card-head strong{ font-size:15px; }
.adm-chip-lite, .adm-chip-live{
  font-size:11px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  border-radius:6px; padding:3px 8px; white-space:nowrap;
}
.adm-chip-lite{ color:var(--ink-3); background:var(--paper); }
.adm-chip-live{ color:var(--cobalt-deep); background:var(--cobalt-tint); }
.adm-spark{ width:100%; height:auto; display:block; }
.adm-spark-lbl{ font:600 10px var(--font-ui); fill:var(--ink-3); }
.adm-spark-val{ font:700 11px var(--font-ui); fill:var(--ink); }
.adm-feed{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
.adm-feed li{
  font-size:14px; color:var(--ink-2); padding:10px 0; border-bottom:1px solid var(--line); line-height:1.5;
}
.adm-feed li:last-child{ border-bottom:none; }
.adm-feed-empty{ color:var(--ink-3); }

/* tables */
.adm-tablewrap{
  margin-top:20px; background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-1); overflow-x:auto;
}
.adm-table{ width:100%; border-collapse:collapse; min-width:680px; }
.adm-table th{
  font-size:11.5px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink-3); text-align:left; padding:13px 16px; border-bottom:1px solid var(--line);
  background:var(--paper); white-space:nowrap;
}
.adm-table th.num{ text-align:left; }
.adm-table td{
  font-size:14px; color:var(--ink-2); padding:12px 16px; border-bottom:1px solid var(--line);
  vertical-align:middle;
}
.adm-table tr:last-child td{ border-bottom:none; }
.adm-table td strong{ color:var(--ink); font-weight:600; }
.adm-row-live td{ background:#F4F8FF; }
.adm-veh{ display:flex; align-items:center; gap:12px; min-width:230px; }
.adm-veh img{ width:64px; height:42px; object-fit:cover; border-radius:8px; flex:none; background:#EEF1F6; }
.adm-veh span{ display:block; font-size:12.5px; color:var(--ink-3); }
.adm-actions-col{ width:1%; }
.adm-actions{ white-space:nowrap; text-align:right; }
.adm-act{
  font-family:var(--font-ui); font-size:13px; font-weight:600; color:var(--cobalt-deep);
  background:none; border:1px solid var(--line-2); border-radius:8px; padding:6px 11px;
  cursor:pointer; margin-left:6px; transition:all .15s var(--ease);
}
.adm-act:hover{ border-color:var(--cobalt); background:var(--cobalt-tint); }

/* status pills (state = status colors, labelled — never color-alone) */
.adm-pill{
  display:inline-block; font-size:11.5px; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; border-radius:999px; padding:4px 10px; white-space:nowrap;
}
.adm-pill--ok{ color:var(--green-deep); background:var(--green-tint); }
.adm-pill--hold{ color:#92400E; background:#FEF3C7; }
.adm-pill--sold{ color:#B42318; background:#FEECEA; }
.adm-pill--new{ color:var(--cobalt-deep); background:var(--cobalt-tint); }
.adm-pill--done{ color:var(--ink-2); background:var(--paper); border:1px solid var(--line); }
.adm-pill--type{ color:var(--ink-2); background:var(--paper); border:1px solid var(--line-2); }

/* demo banner */
.adm-banner{
  position:sticky; bottom:0; z-index:60;
  background:var(--ink); color:#fff; text-align:center;
  font-size:11px; font-weight:700; letter-spacing:.07em; padding:9px 16px;
}
.adm-footer{ border-top:none; }

@media (max-width: 560px){
  .adm-badge{ display:none; } /* the bottom demo banner still labels the page */
  .adm-top-inner{ gap:12px; padding:0 14px; }
  .adm-top .brand-word em{ display:none; } /* "Fairmark" alone on tiny screens */
  .adm-back{ white-space:nowrap; }
}
@media (max-width: 940px){
  .adm-app{ grid-template-columns:1fr; padding:20px 16px 80px; gap:18px; }
  .adm-side{
    position:static; flex-direction:row; overflow-x:auto; padding:8px;
  }
  .adm-tab{ flex:none; padding:10px 12px; }
  .adm-tab--reset{ margin-top:0; border-top:none; margin-left:auto; }
  .kpis{ grid-template-columns:repeat(2, 1fr); gap:12px; }
  .adm-duo{ grid-template-columns:1fr; }
  .kpi-value{ font-size:28px; }
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1020px){
  .hero-inner{ grid-template-columns:1fr; gap:40px; }
  .hero-visual{ max-width:640px; }
  .hero-search{ grid-template-columns:1fr 1fr; }
  .hero-search .btn{ grid-column:1 / -1; }
  .nav-links{ display:none; }
  .nav-cta .nav-phone{ display:none; }
  .nav-burger{
    display:flex; flex-direction:column; justify-content:center; gap:5px;
    width:44px; height:44px; padding:10px; margin-left:6px;
    background:none; border:1px solid var(--line-2); border-radius:10px; cursor:pointer;
  }
  .nav-burger span{ height:2px; background:var(--ink); border-radius:2px; transition:all .2s var(--ease); }
  .nav-burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
  .nav-burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .nav-drawer{
    display:none; flex-direction:column; gap:4px;
    padding:12px 24px 20px; border-top:1px solid var(--line); background:var(--white);
  }
  .nav-drawer.open{ display:flex; }
  .nav-drawer a{ padding:12px 4px; font-size:16px; font-weight:500; color:var(--ink); border-bottom:1px solid var(--line); }
  .nav-drawer a.btn{ margin-top:12px; border-bottom:none; color:#fff; }
}
@media (max-width: 900px){
  .veh-top{ grid-template-columns:1fr; gap:26px; }
  .veh-photo{ position:relative; top:auto; }
  .calc{ padding:24px 20px; }
  .calc-body{ grid-template-columns:1fr; gap:26px; }
  .shop-body{ grid-template-columns:1fr; }
  .shop-filter-toggle{ display:inline-flex; }
  .filters{
    position:fixed; inset:0 auto 0 0; width:min(84vw, 340px); z-index:80;
    border-radius:0; overflow-y:auto; transform:translateX(-102%);
    transition:transform .28s var(--ease); top:0;
  }
  .filters.open{ transform:translateX(0); }
  .f-close{
    display:block; background:none; border:none; font-size:26px; line-height:1;
    color:var(--ink-3); cursor:pointer; padding:2px 6px;
  }
  .f-apply{ display:block; }
  .filters-overlay{
    position:fixed; inset:0; background:rgba(20,25,35,.4); z-index:70;
  }
}
@media (max-width: 640px){
  .nav-inner{ gap:14px; padding:0 16px; }
  .nav-cta .btn{ display:none; } /* the drawer carries Browse inventory */
  .hr-wrap{ margin:0 -18px; } /* match the hero's mobile padding */
  .hero{ padding:44px 18px 72px; }
  .hero-sub{ font-size:16.5px; }
  .hero-proof{ gap:24px; }
  .hero-proof strong{ font-size:22px; }
  .hero-search{ grid-template-columns:1fr; margin-top:44px; }
  .hero-chip{ left:4%; padding:11px 14px; }
  .chip-title{ font-size:13.5px; }
  .chip-price{ font-size:15px; }
  .trust-inner{ flex-direction:column; gap:14px; padding:20px 18px; }
  .btn{ padding:14px 22px; }
}

/* ==========================================================================
   ADMIN PILL — persistent floating entry to the staff dashboard (demo)
   Sits below the filter drawer/overlay (70/80), wizard overlay (100), toast (120)
   ========================================================================== */
.admin-pill{
  position:fixed; right:18px; bottom:18px; z-index:60;
  display:inline-flex; align-items:center; gap:7px;
  padding:12px 19px; border-radius:999px;
  background:var(--cobalt); color:#fff;
  font-family:'Montserrat', sans-serif;
  font-size:14px; font-weight:700; letter-spacing:.01em;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 10px 26px rgba(20,25,35,.30);
  transition:background .18s var(--ease), transform .18s var(--ease), box-shadow .18s var(--ease);
}
.admin-pill:hover{
  background:var(--cobalt-deep); transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(20,25,35,.34);
}
@media (max-width: 640px){
  .admin-pill{ right:12px; bottom:12px; padding:10px 15px; font-size:13px; }
}
