/* ============================================================================
   car-sales — "Forecourt"
   Straight-talking, trust-led template family for used-car dealers, motor
   companies and van sales. Deep forecourt navy on a cool light paper, a strong
   grotesque display face (signage-confident, not flashy) over a clean civic
   body. The home page leads with the forecourt and the live stock grid; the
   only public action is "Book a viewing" (the form is baked onto /cars/ pages).
   LOCKED DESIGN — per-customer variation is brand tokens + blueprint data only.
   Theme/brand tokens are injected by the renderer in a :root rule AFTER this
   sheet, so every colour and the display face reference vars with fallbacks.
   ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700;800;900&family=Public+Sans:wght@400;500;600;700&display=swap');
@view-transition{navigation:auto}

:root{
  /* brand tokens — the renderer injects per-customer overrides after this sheet */
  --brand:#16324f;
  --brand-dark:#0e2238;
  --brand-soft:#dde6ee;
  /* family palette — cool, clean, trustworthy */
  --ink:#15212e;
  --ink-2:#566678;
  --paper:#f4f6f8;
  --paper-2:#eaeef3;
  --card:#ffffff;
  --line:#dde3ea;
  --steel:#7d8da0;
  --signal:#c8843a;          /* warm accent — a price tag / "checked" tick, used sparingly */
  --paper-on-dark:#f4f7fb;
  --muted-on-dark:rgba(244,247,251,.7);
  /* type — Archivo is a confident grotesque; Public Sans is a clean civic body */
  --display:'Archivo','Arial Narrow',sans-serif;
  --font-body:'Public Sans','Segoe UI',sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:1.0625rem;line-height:1.65;
  color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:var(--brand)}
::selection{background:var(--brand);color:var(--paper-on-dark)}

h1,h2,h3,h4{font-family:var(--display);line-height:1.04;font-weight:800;color:var(--ink);letter-spacing:-.015em}
h1{font-size:clamp(2.7rem,6.2vw,4.6rem);font-weight:900;text-transform:none}
h2{font-size:clamp(2rem,3.8vw,2.9rem);font-weight:800}
h3{font-size:1.32rem;font-weight:700}
.lead{font-size:1.16rem;color:var(--ink-2);max-width:60ch}
.lead--light{color:var(--muted-on-dark)}

.container{width:min(1180px,100% - 2.5rem);margin-inline:auto}

/* kicker — small caps eyebrow with a checked-tick dash */
.kicker{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--font-body);font-weight:700;font-size:.74rem;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--brand);margin-bottom:1rem;
}
.kicker::before{content:"";width:1.5rem;height:2px;background:var(--signal);border-radius:2px}
.kicker--light{color:var(--paper-on-dark)}
.kicker--light::before{background:var(--signal)}

/* buttons — crisp, squared-off, forecourt-signage confident */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--display);font-weight:700;letter-spacing:.005em;
  font-size:1rem;line-height:1;text-decoration:none;cursor:pointer;
  padding:1rem 1.8rem;border:2px solid transparent;border-radius:6px;
  transition:transform .14s ease,background .16s ease,color .16s ease,border-color .16s ease,box-shadow .16s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brand);color:var(--paper-on-dark);box-shadow:0 10px 26px -14px var(--brand-dark)}
.btn-primary:hover{background:var(--brand-dark);box-shadow:0 14px 30px -14px var(--brand-dark)}
.btn-outline{border-color:var(--line);color:var(--ink);background:var(--card)}
.btn-outline:hover{border-color:var(--brand);color:var(--brand)}
.btn-outline--light{border-color:rgba(244,247,251,.55);color:var(--paper-on-dark);background:transparent}
.btn-outline--light:hover{background:var(--paper-on-dark);color:var(--brand);border-color:var(--paper-on-dark)}
.btn-lg{padding:1.15rem 2.2rem;font-size:1.06rem}

/* ----- utility strip ----- */
.topstrip{
  background:var(--brand-dark);color:var(--muted-on-dark);
  font-size:.82rem;font-weight:600;
  display:flex;justify-content:space-between;align-items:center;gap:1.5rem;
  padding:.5rem 1.25rem;
}
.topstrip a{color:var(--paper-on-dark);text-decoration:none}
.topstrip__nap{display:flex;gap:1.5rem;align-items:center}
.topstrip__phone a{color:var(--paper-on-dark);font-weight:800}
@media(max-width:680px){.topstrip__nap span:nth-child(2){display:none}}

/* ----- nav ----- */
.nav{
  position:sticky;top:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 1.25rem;background:rgba(244,246,248,.93);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.nav__logo{
  font-family:var(--display);font-weight:900;font-size:1.5rem;
  letter-spacing:-.02em;color:var(--ink);text-decoration:none;
}
.nav__logo span{color:var(--signal)}
/* contained logo box: a captured brand logo is dropped in here and never exceeds the bar */
.nav__logo-img{display:block;max-height:46px;width:auto;object-fit:contain}
.nav__links{display:flex;align-items:center;gap:1.8rem;list-style:none}
.nav__links a{
  font-weight:700;font-size:.96rem;
  color:var(--ink-2);text-decoration:none;
  padding:.35rem 0;
}
.nav__links a:hover,.nav__links a[aria-current="page"]{color:var(--brand)}
.nav__links a[aria-current="page"]{box-shadow:0 2px 0 var(--signal)}
.nav__cta{color:var(--paper-on-dark) !important;box-shadow:none !important;padding:.6rem 1.2rem !important}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;min-width:44px;min-height:44px;justify-content:center;align-items:center}
.nav__toggle span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px}
.nav__mobile{
  display:none;position:fixed;inset:0;z-index:55;background:var(--paper);
  padding:6rem 2rem 2rem;flex-direction:column;gap:1.35rem;
}
.nav__mobile.open{display:flex}
.nav__mobile a{
  font-family:var(--display);font-weight:800;font-size:1.55rem;
  color:var(--ink);text-decoration:none;
}
@media(max-width:880px){
  .nav__links{display:none}
  .nav__toggle{display:flex}
}

/* ----- photo placeholders (replaced by the pipeline) ----- */
.photo-placeholder{
  display:flex;align-items:center;justify-content:center;text-align:center;
  width:100%;height:100%;min-height:120px;padding:1rem;
  background:
    linear-gradient(135deg,rgba(22,50,79,.06),transparent 60%),
    repeating-linear-gradient(45deg,var(--brand-soft),var(--brand-soft) 14px,var(--paper-2) 14px,var(--paper-2) 28px);
  color:var(--ink-2);font-size:.82rem;font-weight:700;letter-spacing:.02em;
}

/* ----- HOME: hero — full-bleed photo, dark overlay, copy low-left ----- */
.hero{position:relative;min-height:min(92vh,720px);display:flex;align-items:flex-end;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg .photo-placeholder{min-height:100%}
/* neutral-dark scrim leaning navy so light hero copy stays legible on any brand colour */
.hero__scrim{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(6deg,rgba(8,18,30,.94) 0%,rgba(10,22,36,.78) 44%,rgba(14,30,48,.42) 78%,rgba(16,34,52,.26) 100%);
}
.hero__inner{position:relative;z-index:2;padding:7rem 0 7rem;width:min(1180px,100% - 2.5rem);margin-inline:auto}
.hero__copy{max-width:46rem}
.hero__copy h1{color:var(--paper-on-dark)}
.hero__copy .lead{margin-top:1.2rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}

/* ----- generic section rhythm ----- */
.section{padding:5.5rem 0}
.section--tint{background:var(--paper-2)}
.section-head{margin-bottom:2.8rem;max-width:64ch}
.section-head--center{margin-inline:auto;text-align:center}
.section-head--row{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;max-width:none}
.section-head--row .lead{margin-top:.8rem}
.section-head .lead{margin-top:.8rem}
.stock-head__all{flex:none;white-space:nowrap}
@media(max-width:780px){.section-head--row{flex-direction:column;align-items:flex-start}.stock-head__all{display:none}}

/* ----- HOME: trust proof — numbered cards ----- */
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.trust-card{
  position:relative;background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:2.2rem 1.8rem 1.9rem;border-top:4px solid var(--brand);
  box-shadow:0 18px 40px -34px rgba(21,33,46,.6);
}
.trust-card__num{
  font-family:var(--display);font-weight:900;font-size:1rem;color:var(--signal);
  letter-spacing:.06em;display:block;margin-bottom:.9rem;
}
.trust-card h3{margin-bottom:.5rem}
.trust-card p{color:var(--ink-2);font-size:.98rem}
@media(max-width:900px){.trust-grid{grid-template-columns:1fr;max-width:520px;margin-inline:auto}}

/* ----- HOME/CARS: stock grid (cards rendered from stock.json, or baked server-side) ----- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.card{
  display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;text-decoration:none;color:var(--ink);
  box-shadow:0 20px 44px -36px rgba(21,33,46,.55);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
}
.card:hover{transform:translateY(-5px);border-color:var(--brand-soft);box-shadow:0 28px 52px -32px rgba(21,33,46,.5)}
.card__media{aspect-ratio:4/3;background:var(--brand-soft);position:relative;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover}
.card__ph{
  display:flex;align-items:center;justify-content:center;width:100%;height:100%;
  font-family:var(--display);font-weight:900;font-size:2rem;color:var(--steel);
  background:linear-gradient(135deg,var(--brand-soft),var(--paper-2));letter-spacing:.04em;
}
.card__body{padding:1.2rem 1.3rem 1.4rem;display:flex;flex-direction:column;gap:.5rem}
.card__title{font-family:var(--display);font-weight:700;font-size:1.1rem;line-height:1.2;color:var(--ink)}
.card__price{font-family:var(--display);font-weight:900;font-size:1.5rem;color:var(--brand)}
.card__chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.2rem}
.chip{
  font-family:var(--font-body);font-weight:600;font-size:.78rem;color:var(--ink-2);
  background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:.25rem .7rem;
}
.stock-empty{color:var(--ink-2);font-style:italic;grid-column:1/-1}
.stock-foot{margin-top:2.6rem;text-align:center}
@media(max-width:900px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.card-grid{grid-template-columns:1fr;max-width:420px;margin-inline:auto}}

/* ----- reviews — quotes on clean cards ----- */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.review-card{
  position:relative;background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:2rem 1.8rem 1.7rem;box-shadow:0 18px 40px -34px rgba(21,33,46,.5);
}
.review-card__stars{color:var(--signal);letter-spacing:.15em;font-size:.95rem}
.review-card__quote{margin:.8rem 0 1.1rem;color:var(--ink);font-size:1.04rem;line-height:1.55}
.review-card__name{font-family:var(--display);font-weight:800;font-size:.95rem;color:var(--brand)}
@media(max-width:900px){.reviews-grid{grid-template-columns:1fr;max-width:560px;margin-inline:auto}}

/* ----- find-us band ----- */
.find{padding:4.6rem 0;background:var(--paper-2)}
.find__grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.find__photo{aspect-ratio:4/3;border-radius:14px;overflow:hidden;background:var(--brand-soft);
  border:1px solid var(--line);box-shadow:0 20px 44px -32px rgba(21,33,46,.55)}
.find__photo img{width:100%;height:100%;object-fit:cover}
.find__photo .photo-placeholder{min-height:100%}
.find__hours{margin-top:1rem;color:var(--ink-2);font-size:1.05rem}
.find__rows{margin-top:1.4rem;display:flex;flex-direction:column;gap:.7rem}
.find__row{display:flex;gap:.7rem;align-items:baseline;font-size:1rem}
.find__row a{color:var(--brand);font-weight:800;text-decoration:none}
@media(max-width:880px){.find__grid{grid-template-columns:1fr;gap:2rem}}

/* ----- final CTA — deep navy panel ----- */
.cta-section{padding:5.5rem 0}
.cta-section .container{
  background:var(--brand-dark);border-radius:20px;
  padding:3.8rem 3.4rem;text-align:center;position:relative;overflow:hidden;
}
.cta-section .container::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(200,132,58,.22),transparent 62%);pointer-events:none}
.cta-section h2{color:var(--paper-on-dark);max-width:24ch;margin-inline:auto;position:relative}
.cta-section p{color:var(--muted-on-dark);max-width:56ch;margin:.9rem auto 1.8rem;position:relative}
.cta-section__actions{position:relative}
@media(max-width:680px){.cta-section .container{padding:2.8rem 1.6rem}}

/* ----- page hero (inner pages) ----- */
.page-hero{padding:4.4rem 0 3.4rem;background:linear-gradient(180deg,var(--paper-2) 0%,var(--paper) 100%)}
.page-hero h1{max-width:22ch}
.page-hero .lead{margin-top:1rem}
.breadcrumb{display:flex;align-items:center;gap:.55rem;font-size:.86rem;font-weight:700;margin-bottom:1.6rem;color:var(--ink-2)}
.breadcrumb a{color:var(--brand);text-decoration:none}
.breadcrumb__sep{color:var(--steel)}

/* ----- ABOUT page ----- */
.about-split{display:grid;grid-template-columns:1fr 1.05fr;gap:3.4rem;align-items:center;padding:4.5rem 0}
.about-split__img{aspect-ratio:4/5;border-radius:14px;overflow:hidden;background:var(--brand-soft);
  border:1px solid var(--line);box-shadow:0 22px 46px -30px rgba(21,33,46,.55)}
.about-split__img img{width:100%;height:100%;object-fit:cover}
.about-split__img .photo-placeholder{min-height:100%}
.about-split__copy p{color:var(--ink-2);margin-top:1rem}
.about-split__copy p:first-of-type{margin-top:0;color:var(--ink);font-size:1.12rem}
@media(max-width:880px){.about-split{grid-template-columns:1fr;gap:2rem;padding:3rem 0}}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.value-item{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:1.9rem 1.7rem;border-left:4px solid var(--signal)}
.value-item h3{font-size:1.16rem;margin-bottom:.45rem}
.value-item p{color:var(--ink-2);font-size:.97rem}
@media(max-width:880px){.values-grid{grid-template-columns:1fr}}

/* ----- CONTACT page ----- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:2rem 1.9rem;box-shadow:0 20px 44px -36px rgba(21,33,46,.5);margin-bottom:1.6rem}
.contact-card--accent{background:var(--brand);color:var(--paper-on-dark);border-color:var(--brand)}
.contact-card--accent h2{color:var(--paper-on-dark)}
.contact-card--accent p{color:var(--muted-on-dark)}
.contact-card h2,.contact-card h3{margin-bottom:.8rem}
.contact-card p{color:var(--ink-2)}
.contact-row{display:flex;gap:.85rem;align-items:flex-start;margin-top:1rem;font-size:1.02rem}
.contact-row a{color:var(--brand);font-weight:800;text-decoration:none}
.contact-icon{flex:none}

/* ----- BAKED vehicle pages (src/services/cars/bake.ts) ----- */
/* The forecourt grid header, a single vehicle's gallery/price/advert and the viewing form all
   ride this same sheet so the baked /cars/ pages match the family. */
.vehicle{max-width:840px;margin-inline:auto}
.crumb{font-size:.86rem;font-weight:700;color:var(--ink-2);margin-bottom:1.4rem}
.crumb a{color:var(--brand);text-decoration:none}
.vehicle__gallery{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}
.vehicle__gallery img{width:100%;border-radius:14px;border:1px solid var(--line);object-fit:cover}
.vehicle__gallery .card__ph{aspect-ratio:4/3;border-radius:14px;border:1px solid var(--line)}
.vehicle__head{margin-bottom:1.6rem}
.vehicle__price{font-family:var(--display);font-weight:900;font-size:2.2rem;color:var(--brand);margin:.4rem 0 .8rem}
.vehicle__chips{display:flex;flex-wrap:wrap;gap:.5rem}
.vehicle__advert{color:var(--ink-2);font-size:1.05rem;line-height:1.7;margin-bottom:2.6rem}
.vehicle__advert p{margin-bottom:1rem}
.vehicle__advert ul{margin:0 0 1rem 1.2rem}

/* ----- "Book a viewing" form (home: none; baked vehicle pages: present) ----- */
.book{background:var(--brand);color:var(--paper-on-dark);border-radius:18px;
  padding:2.4rem 2.2rem;box-shadow:0 30px 60px -38px rgba(8,18,30,.7)}
.book .section-head{margin-bottom:1.6rem;max-width:none}
.book h2{color:var(--paper-on-dark);font-size:1.8rem}
.book .lead{color:var(--muted-on-dark);font-size:1.02rem}
.book .form-group{margin-bottom:1.1rem}
.book label{display:block;font-family:var(--display);font-weight:700;font-size:.9rem;margin-bottom:.4rem;color:var(--paper-on-dark)}
.book input,.book textarea{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:var(--paper);border:1px solid transparent;border-radius:8px;padding:.85rem 1rem;
}
.book textarea{min-height:80px;resize:vertical}
.book input:focus,.book textarea:focus{outline:2px solid var(--signal);outline-offset:1px}
.slots{display:flex;flex-wrap:wrap;gap:.55rem;margin:.2rem 0 1.1rem}
.slot{
  font-family:var(--display);font-weight:700;font-size:.95rem;cursor:pointer;
  background:rgba(244,247,251,.1);border:1px solid rgba(244,247,251,.3);color:var(--paper-on-dark);
  border-radius:6px;padding:.55rem 1.05rem;transition:all .14s ease;
}
.slot:hover{border-color:var(--signal);color:var(--signal)}
.slot.on{background:var(--signal);border-color:var(--signal);color:var(--brand-dark)}
.booking-msg{font-size:.98rem;color:var(--paper-on-dark);font-weight:700;min-height:1.2rem;margin-top:.6rem}

/* ----- footer ----- */
.footer{background:var(--brand-dark);color:var(--muted-on-dark);padding:3.8rem 0 1.6rem;margin-top:2rem}
.footer a{color:var(--paper-on-dark);text-decoration:none}
.footer__inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem}
.footer__logo,.footer__brand{font-family:var(--display);font-weight:900;font-size:1.45rem;color:var(--paper-on-dark)}
.footer__logo span{color:var(--signal)}
.footer__desc{margin-top:.7rem;font-size:.95rem;max-width:34ch}
.footer__heading{font-family:var(--display);font-weight:700;color:var(--paper-on-dark);margin-bottom:.9rem}
.footer__links{list-style:none;display:flex;flex-direction:column;gap:.5rem;font-size:.95rem}
.footer__links a{display:flex;align-items:center;min-height:44px}
.footer__bottom{border-top:1px solid rgba(244,247,251,.16);margin-top:2.6rem;padding-top:1.4rem;font-size:.82rem}
@media(max-width:780px){.footer__inner{grid-template-columns:1fr;gap:1.8rem}}

/* ----- mobile sticky bar ----- */
.callbar{display:none}
@media(max-width:680px){
  .callbar{display:block;position:fixed;left:0;right:0;bottom:0;z-index:70;
    background:var(--brand);text-align:center;padding:.95rem 1rem;box-shadow:0 -6px 18px rgba(21,33,46,.25)}
  .callbar a{color:var(--paper-on-dark);font-family:var(--display);font-weight:800;font-size:1.05rem;text-decoration:none}
  body{padding-bottom:3.4rem}
}

/* ----- small-screen rhythm ----- */
@media(max-width:680px){
  .section,.find{padding:3.6rem 0}
  .hero__inner{padding:5.5rem 0 5rem}
  .section-head{margin-bottom:1.9rem}
  .hero__actions .btn{width:100%}
}

/* trust badges (accreditation marks + Google rating chip) — injected into [data-badges] */
.badges{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:1.4rem}
.badges:empty{display:none}
.badge{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);color:#fff;font-size:.8rem;font-weight:600;line-height:1}
.badge--google{background:#fff;color:#1a1a1a;border-color:rgba(0,0,0,.12)}
img.badge--img{height:42px;width:auto;display:block;background:#fff;border:1px solid rgba(0,0,0,.08);padding:6px 9px;border-radius:10px}
