/* ===========================================================
   FLEET AUTOMOTIVE GROUP — design system v2
   Black & red. Photo-forward dealer-style cards, shop-by-brand.
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=IBM+Plex+Mono:wght@500&display=swap');

:root{
  --ink:        #0c0c0c;
  --ink-soft:   #57565c;
  --paper:      #d4d4d4;
  --mist:       #f3f3f4;
  --line:       rgba(12,12,12,0.12);
  --line-strong:rgba(12,12,12,0.45);

  --red:        #d11a2c;
  --red-dark:   #a3111f;
  --red-soft:   #d11a2c14;

  --serif: 'Oswald', 'Arial Narrow', sans-serif;   /* display face */
  --sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono:  'IBM Plex Mono', 'SFMono-Regular', monospace;

  --max: 1220px;
  --gutter: clamp(1.5rem, 5vw, 4rem);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; }
}

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.wrap{
  max-width:var(--max);
  margin:0 auto;
  padding-left:var(--gutter);
  padding-right:var(--gutter);
}

h1,h2,h3{
  font-family:var(--serif);
  font-weight:600;
  text-transform:uppercase;
  line-height:1.05;
  letter-spacing:0.01em;
  margin:0;
}

.eyebrow{
  font-family:var(--mono);
  font-size:0.72rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-soft);
  display:flex;
  align-items:center;
  gap:0.6em;
}
.eyebrow::before{
  content:'';
  width:10px; height:3px;
  background:var(--red);
  display:inline-block;
}

.lede{
  font-size:1.08rem;
  color:var(--ink-soft);
  max-width:48ch;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.5em;
  padding:0.9em 1.6em;
  font-family:var(--sans);
  font-weight:700;
  font-size:0.88rem;
  letter-spacing:0.02em;
  text-transform:uppercase;
  border:1.5px solid var(--ink);
  border-radius:3px;
  cursor:pointer;
  transition:background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
  white-space:nowrap;
}
.btn-primary{ background:var(--red); color:#fff; border-color:var(--red); }
.btn-primary:hover{ background:var(--red-dark); border-color:var(--red-dark); }
.btn-ghost{ background:transparent; color:var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:#fff; }
.btn-row{ display:flex; gap:0.85rem; flex-wrap:wrap; }

/* ---------- nav ---------- */
.site-nav{
  position:sticky; top:0; z-index:100;
  background:rgba(253,253,251,0.96);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-nav .wrap{
  display:flex; align-items:center; justify-content:space-between;
  height:78px; gap:1.5rem;
}
.brand{
  font-family:var(--serif);
  font-size:1.18rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.01em;
  display:flex; flex-direction:column; line-height:1.2;
  white-space:nowrap;
}
.brand span.dot{ color:var(--red); }
.brand small{
  font-family:var(--mono);
  font-size:0.6rem;
  font-weight:500;
  color:var(--ink-soft);
  letter-spacing:0.14em;
  text-transform:uppercase;
}
.nav-links{
  display:flex; align-items:center; gap:0.4rem;
  font-family:var(--sans);
  font-weight:600;
  font-size:0.92rem;
}
.nav-links > a{ position:relative; padding:0.7em 0.85em; }
.nav-links > a::after{
  content:''; position:absolute; left:0.85em; right:0.85em; bottom:0.3em; height:2px;
  background:var(--red); transform:scaleX(0); transform-origin:left;
  transition:transform 0.2s ease;
}
.nav-links > a:hover::after,
.nav-links > a[aria-current="page"]::after{ transform:scaleX(1); }

.nav-dropdown{ position:relative; }
.nav-dropdown-trigger{ display:inline-flex; align-items:center; gap:0.35em; padding:0.7em 0.85em; cursor:pointer; }
.nav-dropdown-trigger::after{
  content:''; position:absolute; left:0.85em; right:0.85em; bottom:0.3em; height:2px;
  background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform 0.2s ease;
}
.nav-dropdown:hover .nav-dropdown-trigger::after,
.nav-dropdown:focus-within .nav-dropdown-trigger::after{ transform:scaleX(1); }
button.nav-dropdown-trigger{
  background:none; border:none; font-family:var(--sans); font-size:0.92rem;
  font-weight:600; color:var(--ink); cursor:pointer;
}
button.nav-dropdown-trigger:focus{ outline:none; }
.caret{ font-size:0.65em; }

.nav-dropdown-menu{
  display:none;
  position:absolute; top:100%; left:0;
  background:#fff; border:1px solid var(--line); border-radius:4px;
  box-shadow:0 18px 40px rgba(12,12,12,0.14);
  padding:0.6rem;
  width:440px;
  grid-template-columns:repeat(2,1fr);
  gap:0.1rem;
  z-index:60;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu,
.nav-dropdown-menu.is-open{ display:grid; }
.nav-dropdown-menu a{
  padding:0.6rem 0.7rem; border-radius:3px; font-weight:500; font-size:0.9rem;
  display:block;
}
.nav-dropdown-menu a:hover{ background:var(--mist); color:var(--red); }
.nav-dropdown-menu .view-all{
  grid-column:1/-1; margin-top:0.3rem; padding-top:0.8rem; border-top:1px solid var(--line);
  font-family:var(--mono); font-size:0.74rem; text-transform:uppercase; letter-spacing:0.06em;
  color:var(--red); font-weight:500;
}

.nav-cta{ display:flex; align-items:center; gap:1rem; flex-shrink:0; }
.nav-phone{
  font-family:var(--mono); font-size:0.86rem; display:none; font-weight:500;
}
.nav-toggle{
  display:none; background:none; border:none; cursor:pointer;
  width:32px; height:22px; position:relative; flex-shrink:0;
}
.nav-toggle span{
  position:absolute; left:0; right:0; height:2px; background:var(--ink);
  transition:transform 0.25s ease, opacity 0.25s ease;
}
.nav-toggle span:nth-child(1){ top:0; }
.nav-toggle span:nth-child(2){ top:10px; }
.nav-toggle span:nth-child(3){ top:20px; }
.nav-open .nav-toggle span:nth-child(1){ transform:translateY(10px) rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2){ opacity:0; }
.nav-open .nav-toggle span:nth-child(3){ transform:translateY(-10px) rotate(-45deg); }

@media (min-width:760px){ .nav-phone{ display:inline-block; } }

@media (max-width:980px){
  .nav-links{
    position:fixed; top:78px; left:0; right:0;
    background:var(--ink);
    flex-direction:column; align-items:stretch; gap:0;
    padding:0;
    transform:translateY(-10px); opacity:0; pointer-events:none;
    transition:opacity 0.25s ease, transform 0.25s ease;
    border-top:3px solid var(--red);
    z-index:999;
    box-shadow:0 20px 40px rgba(0,0,0,0.4);
  }
  .nav-open .nav-links{
    opacity:1; transform:translateY(0); pointer-events:auto;
  }

  /* Each main nav link */
  .nav-links > a{
    display:block; width:100%;
    padding:1rem 1.5rem;
    color:#fff !important;
    font-size:1rem; font-weight:600;
    border-bottom:1px solid rgba(255,255,255,0.1);
    text-decoration:none;
  }
  .nav-links > a:hover{ background:rgba(255,255,255,0.08); color:#fff !important; }

  /* Brands section */
  .nav-dropdown{ border-bottom:1px solid rgba(255,255,255,0.1); }
  .nav-dropdown-trigger{
    display:flex; justify-content:space-between; align-items:center;
    width:100%; padding:1rem 1.5rem;
    font-size:1rem; font-weight:600; color:#fff;
    background:none; border:none;
    cursor:pointer;
  }
  .nav-dropdown-trigger:hover{ background:rgba(255,255,255,0.08); }

  /* Brand links grid — always visible, no tap needed */
  .nav-dropdown-menu{
    display:grid !important;
    position:static; box-shadow:none; border:none; border-radius:0;
    width:100%; padding:0.4rem 1rem 0.8rem 1rem;
    grid-template-columns:1fr 1fr;
    background:rgba(0,0,0,0.25);
    gap:0;
  }
  .nav-dropdown-menu a{
    padding:0.45rem 0.5rem;
    font-size:0.85rem; font-weight:500;
    color:rgba(255,255,255,0.7);
    border:none;
  }
  .nav-dropdown-menu a:hover{ color:#fff; }
  .nav-dropdown-menu .view-all{ display:none; }

  .nav-cta .btn-ghost{ display:none; }
  .nav-toggle{ display:block; }
  .nav-toggle span{ background:#0c0c0c; }
}

/* ---------- sections ---------- */
section{ padding:clamp(3.2rem,7vw,6.5rem) 0; }
.section-mist{ background:var(--mist); }
.section-border-t{ border-top:1px solid var(--line); }
.section-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:2rem; margin-bottom:clamp(2rem,5vw,3rem); flex-wrap:wrap;
}
.section-head h2{ font-size:clamp(1.7rem,3.4vw,2.3rem); margin-top:0.6rem; max-width:34ch; }

/* ---------- hero ---------- */
.hero{ padding-top:clamp(2.6rem,7vw,4.5rem); }
.hero-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.hero h1{
  font-size:clamp(2.5rem, 5.4vw, 4rem);
  margin:0.9rem 0 1.2rem;
}
.hero h1 .accent{ color:var(--red); }
.hero .btn-row{ margin-top:2rem; }
.hero-media{
  position:relative; border-radius:6px; overflow:hidden;
  border:1px solid var(--line);
}
.hero-media::before{
  content:''; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(12,12,12,0) 50%, rgba(12,12,12,0.55) 100%);
}
.hero-media img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }
.hero-media-tag{
  position:absolute; z-index:2; left:1.2rem; bottom:1.2rem; color:#fff;
  font-family:var(--mono); font-size:0.76rem; letter-spacing:0.06em; text-transform:uppercase;
}
@media (max-width:880px){ .hero-grid{ grid-template-columns:1fr; } .hero-media{ order:-1; } }

.hero-meta{
  margin-top:clamp(2.6rem,6vw,4rem);
  display:grid; grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.hero-meta div{ padding:1.3rem 1.6rem; border-left:1px solid var(--line); }
.hero-meta div:first-child{ border-left:none; padding-left:0; }
.hero-meta .num{ font-family:var(--serif); font-size:1.5rem; font-weight:600; display:block; }
.hero-meta .lbl{ font-family:var(--mono); font-size:0.68rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-soft); }
@media (max-width:680px){
  .hero-meta{ grid-template-columns:1fr; }
  .hero-meta div{ border-left:none; border-top:1px solid var(--line); padding-left:0; }
  .hero-meta div:first-child{ border-top:none; }
}

/* ---------- brand-page hero (no media) ---------- */
.brand-hero{ border-bottom:1px solid var(--line); padding-bottom:clamp(2.4rem,5vw,3.5rem); }
.brand-hero h1{ font-size:clamp(2.6rem,7vw,4.6rem); margin-top:0.7rem; }
.brand-hero .lede{ margin-top:1rem; max-width:60ch; }

/* ---------- shop-by-brand tiles ---------- */
.brand-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line);
}
.brand-tile{
  background:#fff; padding:1.8rem 1.4rem; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:0.5rem;
  transition:background 0.2s ease, color 0.2s ease;
}
.brand-tile:hover{ background:var(--ink); color:#fff; }
.bt-logo{
  width:72px; height:56px; object-fit:contain;
  filter:grayscale(100%);
  transition:filter 0.2s ease;
}
.brand-tile:hover .bt-logo{ filter:grayscale(100%) brightness(10); }
.brand-tile .bt-mark{
  font-family:var(--serif); font-size:1.5rem; font-weight:700;
  width:54px; height:54px; border-radius:50%;
  border:1.5px solid currentColor;
  align-items:center; justify-content:center;
}
.brand-tile .bt-name{ font-family:var(--sans); font-weight:600; font-size:0.94rem; }
.brand-tile .bt-count{ font-family:var(--mono); font-size:0.68rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--ink-soft); }
.brand-tile:hover .bt-count{ color:#cfcfcf; }
@media (max-width:880px){ .brand-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:600px){ .brand-grid{ grid-template-columns:repeat(2,1fr); } }

/* ---------- brand page hero logo ---------- */
.brand-hero-head{
  display:flex; align-items:center; gap:1.5rem; margin:1rem 0 1rem;
}
.brand-hero-logo{
  width:90px; height:70px; object-fit:contain;
  filter:grayscale(100%);
  flex-shrink:0;
}
@media (max-width:600px){
  .brand-hero-head{ flex-direction:column; align-items:flex-start; gap:0.8rem; }
  .brand-hero-logo{ width:64px; height:50px; }
}

/* ---------- car cards (the dealer-style device) ---------- */
.car-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.car-card{
  background:#fff; border:1px solid var(--line); border-radius:6px; overflow:hidden;
  display:flex; flex-direction:column;
  transition:box-shadow 0.25s ease, transform 0.25s ease;
}
.car-card:hover{ box-shadow:0 16px 34px rgba(12,12,12,0.14); transform:translateY(-3px); }
.car-card .media{ position:relative; aspect-ratio:4/3; background:#0c0c0c; overflow:hidden; }
.car-card .media img{ width:100%; height:100%; object-fit:cover; }
.car-card .badge{
  position:absolute; top:12px; left:12px; z-index:2;
  background:var(--red); color:#fff; font-family:var(--mono); font-size:0.68rem;
  padding:0.4em 0.75em; border-radius:3px; text-transform:uppercase; letter-spacing:0.06em;
}
.car-card .badge.demo{ background:var(--ink); }
.car-card .body{ padding:1.25rem 1.3rem 1.4rem; display:flex; flex-direction:column; gap:0.55rem; flex:1; }
.car-card h3{ font-size:1.18rem; font-weight:600; letter-spacing:0; }
.car-card .specs{ font-family:var(--sans); font-size:0.85rem; color:var(--ink-soft); }
.car-card .price-row{
  display:flex; align-items:baseline; justify-content:space-between;
  margin-top:auto; padding-top:0.75rem; border-top:1px solid var(--line);
}
.car-card .price{ font-family:var(--serif); font-size:1.55rem; font-weight:600; color:var(--red); }
.car-card .price .term{ display:block; font-family:var(--sans); font-size:0.7rem; font-weight:500; text-transform:none; letter-spacing:0; color:var(--ink-soft); margin-top:0.15rem; }
.car-card .ref{ font-family:var(--mono); font-size:0.68rem; color:var(--ink-soft); }
.car-card .actions{ display:flex; gap:0.6rem; margin-top:0.9rem; }
.car-card .actions .btn{ flex:1; padding:0.75em 1em; font-size:0.78rem; }

@media (max-width:980px){ .car-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .car-grid{ grid-template-columns:1fr; } }

/* ---------- steps ---------- */
.steps{ counter-reset:step; }
.step{
  display:grid; grid-template-columns:90px 1fr; gap:2rem;
  padding:2.2rem 0; border-bottom:1px solid var(--line);
}
.step:first-child{ border-top:1px solid var(--line); }
.step .step-num{
  font-family:var(--serif); font-size:2.4rem; color:var(--red);
  font-weight:700;
}
.step h3{ font-size:1.3rem; margin-bottom:0.5rem; text-transform:none; font-weight:600; }
.step p{ color:var(--ink-soft); max-width:54ch; margin:0; font-family:var(--sans); }
@media (max-width:600px){ .step{ grid-template-columns:1fr; gap:0.6rem; } }

/* ---------- feature grid ---------- */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.grid-3 > div{ background:var(--paper); padding:2.3rem; }
.grid-3 h3{ font-size:1.1rem; margin-bottom:0.7rem; text-transform:none; font-weight:600; }
.grid-3 p{ color:var(--ink-soft); font-size:0.94rem; margin:0; font-family:var(--sans); }
@media (max-width:760px){ .grid-3{ grid-template-columns:1fr; } }

/* ---------- quote / pull ---------- */
.pull{
  font-family:var(--serif); font-weight:500; text-transform:none;
  font-size:clamp(1.4rem,3.2vw,2rem);
  line-height:1.4; max-width:820px;
  color:var(--ink);
  border-left:4px solid var(--red); padding-left:1.4rem;
}

/* ---------- CTA band ---------- */
.cta-band{ background:var(--red); color:#fff; }
.cta-band h2{ color:#fff; font-size:clamp(1.9rem,4.2vw,2.8rem); max-width:640px; }
.cta-band .lede{ color:#ffe1e3; }
.cta-band .btn-primary{ background:#fff; color:var(--red); border-color:#fff; }
.cta-band .btn-primary:hover{ background:#f4f4f4; }
.cta-band .btn-ghost{ border-color:#fff; color:#fff; }
.cta-band .btn-ghost:hover{ background:#fff; color:var(--red); }
.cta-band .btn-row{ margin-top:1.8rem; }

/* ---------- footer ---------- */
footer{ border-top:1px solid var(--line); padding:3.5rem 0 2.5rem; background:var(--ink); color:#d8d8d6; }
.foot-grid{ display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:2.5rem; }
.foot-grid h4{
  font-family:var(--mono); font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase;
  color:#8d8c8a; margin:0 0 1rem;
}
.foot-grid a, .foot-grid p{ font-size:0.92rem; margin:0 0 0.55rem; color:#d8d8d6; }
.foot-grid a:hover{ color:var(--red); }
.foot-grid p{ color:#9b9a98; }
.foot-bottom{
  margin-top:3rem; padding-top:1.5rem; border-top:1px solid rgba(255,255,255,0.12);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  font-family:var(--mono); font-size:0.72rem; color:#8d8c8a;
}
@media (max-width:760px){ .foot-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .foot-grid{ grid-template-columns:1fr; } }

/* ---------- page header (interior pages) ---------- */
.page-head{ padding-top:clamp(2.6rem,7vw,4.5rem); padding-bottom:0; }
.page-head h1{ font-size:clamp(2.2rem,5vw,3.2rem); margin-top:1rem; }
.page-head .lede{ margin-top:1rem; }
.note{
  font-family:var(--mono); font-size:0.78rem; color:var(--ink-soft);
  border-left:2px solid var(--red); padding-left:1rem; max-width:60ch;
}

/* ---------- form ---------- */
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; }
.field{ display:flex; flex-direction:column; gap:0.5rem; }
.field.full{ grid-column:1 / -1; }
.field label{ font-family:var(--mono); font-size:0.72rem; letter-spacing:0.07em; text-transform:uppercase; color:var(--ink-soft); }
.field input, .field select, .field textarea{
  font-family:var(--sans); font-size:0.98rem; padding:0.85em 1em;
  border:1px solid var(--line-strong); border-radius:3px; background:var(--paper); color:var(--ink);
}
.field textarea{ resize:vertical; min-height:120px; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:2px solid var(--red); outline-offset:1px;
}
@media (max-width:640px){ .form-grid{ grid-template-columns:1fr; } }

/* ---------- contact strip ---------- */
.contact-strip{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.contact-strip > div{ background:var(--paper); padding:2.2rem; }
.contact-strip .eyebrow{ margin-bottom:0.8rem; }
.contact-strip a, .contact-strip span{ font-family:var(--serif); font-size:1.25rem; display:block; text-transform:none; font-weight:600; }
.contact-strip a:hover{ color:var(--red); }
@media (max-width:760px){ .contact-strip{ grid-template-columns:1fr; } }

/* ---------- reveal ---------- */
.reveal{ opacity:0; transform:translateY(14px); transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }

/* focus visibility */
a:focus-visible, button:focus-visible{ outline:2px solid var(--red); outline-offset:3px; }
