/* ============================================================
   Hawkhurst Taxis — design tokens
   Palette: deep racing-green + brass-gold, grounded in rural Kent
   ============================================================ */
:root{
  --green-950:#0e1d16;
  --green-900:#16291f;
  --green-800:#1f3a2e;
  --green-700:#2b4f3e;
  --gold-500:#c9a84c;
  --gold-400:#dcc278;
  --gold-100:#f3e9cd;
  --paper:#f7f4ec;
  --paper-warm:#efe9d8;
  --ink:#161a17;
  --ink-soft:#3c443e;
  --line:#d8d0b8;
  --white:#ffffff;
  --radius:2px;
  --shadow-sm:0 1px 2px rgba(14,29,22,.08);
  --shadow-md:0 8px 24px rgba(14,29,22,.12);
  --font-display:"Fraunces",Georgia,serif;
  --font-body:"Public Sans","Segoe UI",Arial,sans-serif;
  --maxw:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.12;
  margin:0 0 .4em;
  letter-spacing:-.01em;
  color:var(--green-950);
}
h1{font-size:clamp(2.4rem,5vw,4rem);font-weight:560}
h2{font-size:clamp(1.7rem,3vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em;color:var(--ink-soft)}
.eyebrow{
  font-family:var(--font-body);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.72rem;
  font-weight:700;
  color:var(--gold-500);
  display:inline-block;
  margin-bottom:.9em;
}
.lede{font-size:1.18rem;color:var(--ink-soft);max-width:60ch}

a.skip-link{position:absolute;left:-999px;top:0;background:var(--green-950);color:var(--gold-100);padding:.7em 1.2em;z-index:200}
a.skip-link:focus{left:12px;top:12px}

:focus-visible{outline:3px solid var(--gold-500);outline-offset:2px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-body);font-weight:700;font-size:.95rem;
  padding:.85em 1.6em;border-radius:var(--radius);
  text-decoration:none;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--gold-500);color:var(--green-950);box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--gold-400);box-shadow:var(--shadow-md)}
.btn-ghost{background:transparent;color:var(--paper);border-color:rgba(247,244,236,.35)}
.btn-ghost:hover{border-color:var(--gold-500);color:var(--gold-400)}
.btn-dark{background:var(--green-950);color:var(--gold-100)}
.btn-dark:hover{background:var(--green-800)}
.btn-block{width:100%;justify-content:center}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--green-950);
  border-bottom:1px solid rgba(201,168,76,.25);
}
.bar-top{
  background:var(--green-900);color:var(--gold-100);
  font-size:.82rem;text-align:center;padding:.5em 1em;
}
.bar-top a{color:var(--gold-400);font-weight:700;text-decoration:none}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.9em 0}
.brand{
  font-family:var(--font-display);font-size:1.4rem;font-weight:600;
  color:var(--gold-100);text-decoration:none;letter-spacing:-.01em;
}
.brand span{color:var(--gold-500)}
.nav-links{display:flex;gap:1.8em;list-style:none;margin:0;padding:0}
.nav-links a{
  color:var(--paper);text-decoration:none;font-size:.93rem;font-weight:600;
  opacity:.85;transition:opacity .15s, color .15s;
}
.nav-links a:hover{opacity:1;color:var(--gold-400)}
.nav-cta{display:flex;align-items:center;gap:.9em}
.nav-phone{color:var(--gold-400);font-weight:700;text-decoration:none;font-size:.95rem}
.nav-toggle{display:none;background:none;border:0;color:var(--paper);font-size:1.6rem;cursor:pointer}

@media (max-width:880px){
  .nav-links{
    position:fixed;inset:0 0 0 30%;background:var(--green-950);
    flex-direction:column;padding:5em 2em 2em;gap:1.4em;
    transform:translateX(100%);transition:transform .25s ease;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-toggle{display:block}
  .nav-phone{display:none}
}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(160deg,var(--green-950) 0%,var(--green-800) 100%);
  color:var(--paper);padding:5em 0 6em;position:relative;overflow:hidden;
}
.hero::after{
  content:"";position:absolute;inset:auto -10% -40% auto;width:60%;aspect-ratio:1;
  background:radial-gradient(circle,rgba(201,168,76,.18),transparent 70%);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3em;align-items:center;position:relative}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr}}
.hero h1{color:var(--paper)}
.hero .lede{color:rgba(247,244,236,.82)}
.hero-actions{display:flex;gap:1em;flex-wrap:wrap;margin-top:1.6em}
.hero-trust{display:flex;gap:1.6em;flex-wrap:wrap;margin-top:2.4em;font-size:.85rem;color:rgba(247,244,236,.7)}
.hero-trust strong{color:var(--gold-400);display:block;font-family:var(--font-display);font-size:1.5rem}

/* ---------- Route strip — the signature element ---------- */
.route-strip{
  background:var(--green-900);border:1px solid rgba(201,168,76,.3);
  border-radius:var(--radius);padding:1.8em 1.6em 1.6em;
}
.route-strip-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-400);font-weight:700;margin-bottom:1.2em}
.route-line{position:relative;height:2px;background:rgba(201,168,76,.3);margin:1.6em .4em 1.1em}
.route-node{
  position:absolute;top:50%;transform:translate(-50%,-50%);
  width:11px;height:11px;border-radius:50%;background:var(--gold-500);
  border:2px solid var(--green-900);
}
.route-node.end{width:15px;height:15px;background:var(--paper)}
.route-node-label{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  font-size:.72rem;color:rgba(247,244,236,.75);white-space:nowrap;
}
.route-strip-meta{display:flex;justify-content:space-between;margin-top:2.2em;gap:1em;flex-wrap:wrap}
.route-strip-meta div{font-size:.78rem;color:rgba(247,244,236,.6);text-transform:uppercase;letter-spacing:.08em}
.route-strip-meta strong{display:block;font-family:var(--font-display);font-size:1.7rem;color:var(--paper);text-transform:none;letter-spacing:0}

/* ---------- Sections ---------- */
section{padding:5em 0}
.section-paper{background:var(--paper)}
.section-warm{background:var(--paper-warm)}
.section-dark{background:var(--green-950);color:var(--paper)}
.section-dark h2,.section-dark h3{color:var(--paper)}
.section-dark p{color:rgba(247,244,236,.78)}
.section-head{max-width:62ch;margin-bottom:2.4em}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6em}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6em}
@media (max-width:880px){.grid-3,.grid-2{grid-template-columns:1fr}}

.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8em;
}
.card h3{margin-bottom:.5em}
.card .price{font-family:var(--font-display);font-size:1.6rem;color:var(--green-800)}

.price-table{width:100%;border-collapse:collapse;margin-top:1em}
.price-table th,.price-table td{text-align:left;padding:.9em 1em;border-bottom:1px solid var(--line)}
.price-table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.price-table td.amount{font-family:var(--font-display);font-size:1.15rem;color:var(--green-800);font-weight:600}
.price-table tr:hover{background:var(--paper-warm)}

.quote{
  border-left:3px solid var(--gold-500);padding:0 0 0 1.4em;margin:0;
}
.quote p{font-size:1.05rem;font-style:italic;color:var(--ink)}
.quote cite{font-style:normal;font-size:.85rem;color:var(--ink-soft);display:block;margin-top:.5em}

.faq-item{border-bottom:1px solid var(--line);padding:1.4em 0}
.faq-item summary{
  cursor:pointer;font-family:var(--font-display);font-size:1.08rem;font-weight:600;
  color:var(--green-900);list-style:none;display:flex;justify-content:space-between;gap:1em;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.4rem;color:var(--gold-500);flex-shrink:0}
.faq-item[open] summary::after{content:"–"}
.faq-item p{margin-top:.9em}

.chip-grid{display:flex;flex-wrap:wrap;gap:.6em}
.chip{
  background:var(--white);border:1px solid var(--line);border-radius:999px;
  padding:.45em 1.1em;font-size:.86rem;color:var(--ink-soft);text-decoration:none;
}
.chip:hover{border-color:var(--gold-500);color:var(--green-800)}

.cta-band{
  background:var(--green-800);color:var(--paper);border-radius:var(--radius);
  padding:3em;display:flex;justify-content:space-between;align-items:center;gap:2em;flex-wrap:wrap;
}
.cta-band h3{color:var(--paper);margin-bottom:.3em}
.cta-band p{color:rgba(247,244,236,.78);margin:0}

footer.site-footer{background:var(--green-950);color:rgba(247,244,236,.75);padding:4em 0 2em;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.4em}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
footer h4{color:var(--gold-400);font-family:var(--font-body);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1em}
footer ul{list-style:none;margin:0;padding:0}
footer li{margin-bottom:.6em}
footer a{text-decoration:none;color:inherit;opacity:.85}
footer a:hover{opacity:1;color:var(--gold-400)}
.footer-base{border-top:1px solid rgba(201,168,76,.18);margin-top:3em;padding-top:1.6em;font-size:.82rem;opacity:.65;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1em}

.breadcrumb{font-size:.82rem;color:var(--ink-soft);margin-bottom:1.4em}
.breadcrumb a{color:var(--green-700);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}

.sticky-call{
  position:fixed;bottom:18px;right:18px;z-index:90;display:flex;gap:.6em;
}
.sticky-call a{
  width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;box-shadow:var(--shadow-md);text-decoration:none;
}
.sticky-call .call{background:var(--gold-500);color:var(--green-950)}
.sticky-call .wa{background:#25D366;color:#fff}

@media (max-width:600px){
  section{padding:3.4em 0}
  .cta-band{padding:2em}
  .footer-grid{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
