/* ============================================================
   Keep On Rolling Tires — racing-themed dark design system
   electric blue + asphalt black + yellow "call" CTA
   ============================================================ */

:root{
  --bg:#0a1320; --bg2:#0d1a2c; --panel:#11203552; --panel-solid:#0f1d31;
  --ink:#eef4fc; --muted:#9db1cd; --faint:#7186a3;
  --line:rgba(255,255,255,.10); --line2:rgba(255,255,255,.16);
  --blue:#1aa3ff; --blue-2:#0a84ff; --blue-deep:#0563c9;
  --blue-glow:rgba(26,163,255,.45);
  --yellow:#ffd21a; --yellow-2:#ffb800; --yellow-ink:#241900;
  --white:#fff;
  --maxw:1180px; --radius:14px; --radius-sm:10px;
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --head:'Oswald',Impact,system-ui,sans-serif;
  --body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; font-family:var(--body); color:var(--ink); background:var(--bg);
  line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden;
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(26,163,255,.14), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(10,132,255,.10), transparent 55%);
  background-attachment:fixed;
}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
h1,h2,h3,h4{font-family:var(--head);font-weight:700;line-height:1.04;margin:0;letter-spacing:.5px}
h1{font-size:clamp(2.3rem,6vw,4.4rem);text-transform:uppercase}
h2{font-size:clamp(1.8rem,4.2vw,3rem);text-transform:uppercase}
h3{font-size:1.3rem}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:20px}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:12px;top:12px;background:var(--yellow);color:#000;padding:10px 16px;border-radius:8px;z-index:200}
:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:6px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--head);font-weight:600;text-transform:uppercase;letter-spacing:.6px;
  font-size:1rem;padding:13px 22px;border-radius:var(--radius-sm);border:2px solid transparent;
  background:linear-gradient(180deg,var(--blue),var(--blue-2));color:#02101f;cursor:pointer;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease;white-space:nowrap;
  box-shadow:0 8px 22px rgba(10,132,255,.35);
}
.btn svg{width:1.15em;height:1.15em;flex:none}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(10,132,255,.5)}
.btn--call{background:linear-gradient(180deg,var(--yellow),var(--yellow-2));color:var(--yellow-ink);
  box-shadow:0 8px 22px rgba(255,184,0,.4)}
.btn--call:hover{box-shadow:0 12px 32px rgba(255,184,0,.6)}
.btn--ghost{background:transparent;border-color:var(--line2);color:var(--ink);box-shadow:none}
.btn--ghost:hover{border-color:var(--blue);color:#fff;background:rgba(26,163,255,.08)}
.btn--lg{font-size:1.18rem;padding:17px 30px}
.btn--block{width:100%}

/* ---------- top utility bar ---------- */
.topbar{background:#06101d;border-bottom:1px solid var(--line);font-size:.82rem;color:var(--muted)}
.topbar-in{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding-block:8px;min-height:38px}
.tb-item{display:inline-flex;align-items:center;gap:6px}
.tb-item svg{width:15px;height:15px;color:var(--blue)}
.tb-item strong{color:var(--ink)}
.tb-ic.star svg{color:var(--yellow)}
.tb-area{margin-left:auto;color:var(--faint)}
.tb-area svg{color:var(--faint)}
@media (max-width:760px){.tb-hide,.tb-area{display:none}.topbar-in{justify-content:center;gap:12px}}

/* ---------- header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(8,16,28,.86);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-header.scrolled{box-shadow:0 10px 30px rgba(0,0,0,.5);background:rgba(7,14,24,.96)}
.nav{display:flex;align-items:center;gap:20px;padding-block:10px}
.brand{display:flex;align-items:center;flex:none}
.brand img{height:52px;width:auto}
nav[aria-label="Primary"]{margin-left:auto}
.nav-links{list-style:none;display:flex;gap:6px;margin:0;padding:0}
.nav-links a{color:var(--ink);font-family:var(--head);font-weight:500;text-transform:uppercase;
  letter-spacing:.6px;font-size:.95rem;padding:9px 13px;border-radius:8px;display:block;transition:.15s}
.nav-links a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-links a[aria-current="page"]{color:var(--blue)}
.nav-links a[aria-current="page"]::after{content:"";display:block;height:2px;background:var(--blue);
  border-radius:2px;margin-top:4px;box-shadow:0 0 8px var(--blue-glow)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-cta .btn--call{padding:9px 16px}
.ncta-text{display:flex;flex-direction:column;line-height:1.05;text-align:left}
.ncta-word{font-size:.62rem;letter-spacing:1px;opacity:.8}
.ncta-num{font-size:1.02rem;font-weight:700}
.nav-toggle{display:none;background:transparent;border:1px solid var(--line2);border-radius:9px;
  width:46px;height:42px;color:var(--ink);align-items:center;justify-content:center;cursor:pointer}
.nav-toggle svg{width:24px;height:24px}

@media (max-width:920px){
  nav[aria-label="Primary"]{position:fixed;inset:0 0 auto auto;top:0;height:100%;width:min(80vw,330px);
    background:#0a1422;border-left:1px solid var(--line);transform:translateX(105%);
    transition:transform .25s ease;margin:0;padding:84px 18px 24px;z-index:120;box-shadow:var(--shadow)}
  body.nav-open nav[aria-label="Primary"]{transform:translateX(0)}
  .nav-links{flex-direction:column;gap:4px}
  .nav-links a{font-size:1.15rem;padding:13px 14px}
  .nav-toggle{display:inline-flex}
  body.nav-open::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:110}
  .ncta-word{display:none}.ncta-num{font-size:.95rem}
}
@media (max-width:430px){.nav-cta .ncta-text{display:none}.nav-cta .btn--call{padding:10px 12px}}

/* ---------- hero ---------- */
.hero{position:relative;display:flex;align-items:center;min-height:clamp(560px,84vh,820px);
  overflow:hidden;border-bottom:1px solid var(--line)}
.hero--sm{min-height:clamp(300px,42vh,420px)}
.hero--sm .hero-inner{padding-block:clamp(26px,4vw,44px)}
.hero--sm h1{font-size:clamp(2rem,4.6vw,3.2rem)}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-shade{position:absolute;inset:0;z-index:1;background:
  linear-gradient(100deg,rgba(5,10,18,.94) 0%,rgba(6,12,22,.82) 38%,rgba(6,12,22,.35) 75%,rgba(6,12,22,.55) 100%),
  linear-gradient(0deg,rgba(5,10,18,.9),transparent 45%)}
.hero-inner{position:relative;z-index:2;padding-block:clamp(40px,7vw,80px);max-width:760px}
.hero .eyebrow{color:var(--blue)}
.hero h1{margin:.2em 0 .35em;text-shadow:0 3px 24px rgba(0,0,0,.6)}
.hero h1 .hl{color:var(--blue);text-shadow:0 0 24px var(--blue-glow)}
.hero .lead{font-size:clamp(1.05rem,1.9vw,1.35rem);color:#dbe6f5;max-width:600px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin:26px 0 6px}
.hero-note{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.92rem;margin-top:14px}
.hero-note svg{width:18px;height:18px;color:var(--yellow)}

/* eyebrow + section heads */
.eyebrow{font-family:var(--head);text-transform:uppercase;letter-spacing:3px;font-weight:600;
  font-size:.85rem;color:var(--blue);margin:0 0 .5rem;display:inline-flex;align-items:center;gap:8px}
.section{padding-block:clamp(54px,8vw,96px);position:relative}
.section--alt{background:#0b1626}
.section--panel{background:#0c1829}
.section-head{max-width:720px;margin-bottom:38px}
.section-head.center{margin-inline:auto;text-align:center}
.section-head .lead{color:var(--muted);font-size:1.1rem;margin-top:.6rem}

/* checkered racing divider */
.checkers{height:10px;width:100%;
  background-image:linear-gradient(45deg,#e9eef6 25%,transparent 25%,transparent 75%,#e9eef6 75%),
    linear-gradient(45deg,#e9eef6 25%,#0a1320 25%,#0a1320 75%,#e9eef6 75%);
  background-size:18px 18px;background-position:0 0,9px 9px;opacity:.85;
  border-top:2px solid var(--blue);border-bottom:2px solid var(--blue)}

/* ---------- trust strip ---------- */
.trust-strip{background:#0b1726;border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.trust-cell{background:#0b1726;display:flex;align-items:center;gap:12px;padding:20px 18px}
.trust-cell svg{width:30px;height:30px;color:var(--blue);flex:none}
.trust-cell b{font-family:var(--head);text-transform:uppercase;letter-spacing:.5px;font-size:1.02rem;display:block}
.trust-cell span{color:var(--muted);font-size:.85rem}
@media (max-width:760px){.trust-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- service cards ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px}
.svc-card{background:linear-gradient(180deg,#0f1d31,#0c1729);border:1px solid var(--line);
  border-radius:var(--radius);padding:26px 22px;transition:transform .2s,border-color .2s,box-shadow .2s}
.svc-card:hover{transform:translateY(-5px);border-color:rgba(26,163,255,.5);box-shadow:0 16px 40px rgba(0,0,0,.4)}
.icon-badge{width:56px;height:56px;border-radius:13px;display:grid;place-items:center;margin-bottom:16px;
  background:linear-gradient(150deg,rgba(26,163,255,.22),rgba(10,132,255,.08));border:1px solid rgba(26,163,255,.4)}
.icon-badge svg{width:30px;height:30px;color:var(--blue)}
.icon-badge--y{background:linear-gradient(150deg,rgba(255,210,26,.25),rgba(255,184,0,.08));border-color:rgba(255,210,26,.45)}
.icon-badge--y svg{color:var(--yellow)}
.svc-card h3{font-size:1.18rem;text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}
.svc-card p{color:var(--muted);margin:0;font-size:.97rem}

/* ---------- chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;gap:8px;background:#0e1c2f;border:1px solid var(--line);
  border-radius:999px;padding:9px 15px;font-size:.92rem;color:var(--ink)}
.chip svg{width:17px;height:17px;color:var(--blue)}

/* ---------- vehicles we serve ---------- */
.veh-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.veh-card{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  aspect-ratio:4/3;background:#0c1729}
.veh-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.veh-card:hover img{transform:scale(1.06)}
.veh-card figcaption{position:absolute;inset:auto 0 0 0;padding:30px 16px 14px;
  background:linear-gradient(0deg,rgba(5,10,18,.92),transparent);
  font-family:var(--head);text-transform:uppercase;letter-spacing:.5px;font-size:1.02rem}
.veh-card figcaption small{display:block;font-family:var(--body);text-transform:none;letter-spacing:0;
  color:var(--muted);font-size:.82rem;font-weight:400;margin-top:2px}

/* ---------- why / feature list ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
@media (max-width:880px){.split{grid-template-columns:1fr;gap:30px}}
.media-frame{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line2);box-shadow:var(--shadow)}
.media-frame img{display:block;width:100%;height:100%;aspect-ratio:4/3;object-fit:cover}
.check-list{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:14px}
.check-list li{display:flex;gap:12px;align-items:flex-start}
.check-list svg{width:24px;height:24px;color:var(--blue);flex:none;margin-top:2px}
.check-list strong{color:#fff}
.check-list span{color:var(--muted)}

/* ---------- stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stat .n{font-family:var(--head);font-size:clamp(2rem,4vw,3rem);color:var(--blue);line-height:1}
.stat .l{color:var(--muted);font-size:.9rem;text-transform:uppercase;letter-spacing:1px;margin-top:6px}
@media (max-width:620px){.stats{grid-template-columns:repeat(2,1fr);gap:26px 18px}}

/* ---------- pricing ---------- */
.price-wrap{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media (max-width:820px){.price-wrap{grid-template-columns:1fr}}
.price-card{background:linear-gradient(180deg,#0f1d31,#0c1729);border:1px solid var(--line);
  border-radius:var(--radius);padding:26px}
.price-card h3{text-transform:uppercase;font-size:1.25rem;margin-bottom:6px}
.price-hero{display:flex;align-items:baseline;gap:10px;margin:6px 0 14px}
.price-hero .big{font-family:var(--head);font-size:3rem;color:var(--yellow);line-height:1}
.price-hero .u{color:var(--muted)}
.ptable{width:100%;border-collapse:collapse;font-size:1.02rem}
.ptable td{padding:12px 6px;border-bottom:1px solid var(--line)}
.ptable tr:last-child td{border-bottom:0}
.ptable .sz{font-weight:600;letter-spacing:.5px}
.ptable .pr{text-align:right;font-family:var(--head);color:var(--yellow);font-size:1.25rem}
.price-note{color:var(--faint);font-size:.86rem;margin-top:14px}

/* ---------- reviews ---------- */
.rev-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.rev-card{background:#0e1c2f;border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.stars{display:inline-flex;gap:2px;margin-bottom:10px}
.stars svg{width:19px;height:19px;color:var(--yellow)}
.rev-card p{font-size:1.02rem;color:#e6eef9}
.rev-by{color:var(--muted);font-size:.9rem;margin:0}
.rev-by b{color:#fff}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--blue-deep),var(--blue-2));
  border-radius:var(--radius);padding:clamp(30px,5vw,52px);text-align:center;box-shadow:var(--shadow)}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.16;
  background-image:linear-gradient(45deg,#fff 25%,transparent 25%,transparent 75%,#fff 75%),
    linear-gradient(45deg,#fff 25%,transparent 25%,transparent 75%,#fff 75%);
  background-size:26px 26px;background-position:0 0,13px 13px}
.cta-band>*{position:relative}
.cta-band h2{color:#fff}
.cta-band p{color:#eaf4ff;max-width:560px;margin-inline:auto}
.cta-band .btn--call{margin-top:8px}

/* ---------- gallery ---------- */
.gallery{columns:3;column-gap:14px}
@media (max-width:860px){.gallery{columns:2}}
@media (max-width:520px){.gallery{columns:1}}
.gallery figure{margin:0 0 14px;break-inside:avoid;border-radius:12px;overflow:hidden;
  border:1px solid var(--line);position:relative;cursor:zoom-in}
.gallery img{width:100%;transition:transform .4s}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figcaption{position:absolute;inset:auto 0 0 0;padding:24px 14px 12px;font-size:.88rem;
  background:linear-gradient(0deg,rgba(5,10,18,.9),transparent);color:#dbe6f5}
/* lightbox */
.lb{position:fixed;inset:0;background:rgba(4,8,15,.92);display:none;align-items:center;justify-content:center;
  z-index:300;padding:24px}
.lb.open{display:flex}
.lb img{max-width:94vw;max-height:90vh;border-radius:10px;box-shadow:var(--shadow)}
.lb-close{position:absolute;top:18px;right:22px;background:transparent;border:0;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1}

/* ---------- area page ---------- */
.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-top:8px}
.area-grid li{list-style:none;background:#0e1c2f;border:1px solid var(--line);border-radius:9px;
  padding:11px 14px;display:flex;align-items:center;gap:9px;color:var(--ink);font-size:.95rem}
.area-grid svg{width:16px;height:16px;color:var(--blue);flex:none}

/* ---------- contact + forms ---------- */
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:34px;align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:26px}}
.contact-line{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}
.contact-line svg{width:24px;height:24px;color:var(--blue);flex:none;margin-top:3px}
.contact-line a{color:#dbe6f5}
.contact-line strong{color:#fff;display:block}
.big-call{display:inline-flex;align-items:center;gap:12px;font-family:var(--head);font-size:clamp(1.6rem,4vw,2.3rem);
  color:var(--yellow);text-shadow:0 0 22px rgba(255,184,0,.3);margin:6px 0}
.big-call svg{width:1em;height:1em}
.form-card{background:linear-gradient(180deg,#0f1d31,#0c1729);border:1px solid var(--line2);
  border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.field{margin-bottom:15px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:560px){.field-row{grid-template-columns:1fr}}
label{display:block;font-size:.9rem;font-weight:600;margin-bottom:6px;color:#cdd9ec}
.req{color:var(--yellow)}
input,select,textarea{width:100%;background:#0a1626;border:1px solid var(--line2);border-radius:10px;
  color:var(--ink);padding:12px 14px;font:inherit;transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,163,255,.25)}
textarea{min-height:120px;resize:vertical}
.hp{position:absolute;left:-9999px}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:var(--muted);font-weight:400;margin:6px 0 16px}
.consent input{width:auto;margin-top:3px}
.form-success{display:flex;gap:12px;background:rgba(26,163,255,.12);border:1px solid rgba(26,163,255,.4);
  border-radius:12px;padding:16px;margin-bottom:18px}
.form-success svg{width:26px;height:26px;color:var(--blue);flex:none}
.btn-note{color:var(--faint);font-size:.82rem}

/* ---------- footer ---------- */
.site-footer{background:#070f1c;border-top:1px solid var(--line);margin-top:0;padding-top:54px}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px;padding-bottom:34px}
@media (max-width:880px){.f-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.f-grid{grid-template-columns:1fr}}
.f-brand img{height:62px;width:auto;margin-bottom:12px}
.f-tag{color:var(--muted);max-width:300px}
.f-hours{color:var(--faint);font-size:.86rem;display:flex;gap:8px;align-items:center;margin-top:12px}
.f-hours svg{width:16px;height:16px;color:var(--blue)}
.f-col h4{font-size:.95rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--blue);margin-bottom:14px}
.f-col ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.f-col a,.f-col span{color:var(--muted);font-size:.95rem;display:inline-flex;gap:8px;align-items:center}
.f-col a:hover{color:#fff}
.f-col svg{width:16px;height:16px;color:var(--faint);flex:none}
.f-bottom{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-block:18px;color:var(--faint);font-size:.84rem}
.f-bottom a{color:var(--muted)}

/* ---------- mobile call bar ---------- */
.callbar{display:none}
@media (max-width:760px){
  .callbar{display:grid;grid-template-columns:1fr 1fr;gap:0;position:fixed;inset:auto 0 0 0;z-index:90;
    border-top:1px solid rgba(255,255,255,.14)}
  .callbar-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;
    font-family:var(--head);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
  .callbar-btn svg{width:20px;height:20px}
  .cb-call{background:linear-gradient(180deg,var(--yellow),var(--yellow-2));color:var(--yellow-ink)}
  .cb-text{background:linear-gradient(180deg,var(--blue),var(--blue-2));color:#02101f}
  body{padding-bottom:56px}
}

/* ---------- utilities ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
.center{text-align:center}
.mt-s{margin-top:14px}.mt{margin-top:26px}.mt-l{margin-top:42px}
.lead{font-size:1.1rem;color:var(--muted)}
.wrap-narrow{max-width:760px;margin-inline:auto}
.badge-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
[id]{scroll-margin-top:96px}
.map-frame{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line2);box-shadow:var(--shadow);line-height:0}
.map-frame iframe{width:100%;height:420px;border:0;filter:grayscale(.2) contrast(1.05)}
