/* ============================================================
   ADAMS AUTO SCHOOL · design system "Street Legal" v2 FLAGSHIP
   Asphalt cinema + road-marking yellow + street-sign green
   Overpass (Highway Gothic DNA) · Public Sans · Overpass Mono
   ============================================================ */

:root{
  --black:#0C0E11;
  --asphalt:#14171C;
  --asphalt-2:#1C2027;
  --asphalt-3:#262B34;
  --concrete:#F1F1ED;
  --card:#FFFFFF;
  --line:#FFC216;
  --line-deep:#E0A800;
  --sign:#1E8A4E;
  --sign-deep:#136338;
  --ink:#1C2027;
  --ink-soft:#586068;
  --hairline:#DEDED7;
  --radius:14px;
  --maxw:1140px;
  --display:'Overpass',system-ui,sans-serif;
  --body:'Public Sans',system-ui,sans-serif;
  --mono:'Overpass Mono',ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{font-family:var(--body);color:var(--ink);background:var(--concrete);line-height:1.65;font-size:1.0625rem;-webkit-font-smoothing:antialiased}
img,svg{max-width:100%;display:block}
a{color:var(--sign-deep)}
a:focus-visible,button:focus-visible,input:focus-visible{outline:3px solid var(--line);outline-offset:3px}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);line-height:1.02;letter-spacing:-.015em}
h1{font-size:clamp(2.8rem,7.5vw,5.4rem);font-weight:900;text-transform:uppercase}
h2{font-size:clamp(1.9rem,4.2vw,3rem);font-weight:900;text-transform:uppercase;letter-spacing:-.01em}
h3{font-size:1.3rem;font-weight:800}
.eyebrow{font-family:var(--mono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sign-deep);font-weight:700;display:inline-flex;align-items:center;gap:.6rem;margin-bottom:.9rem}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--line)}
.on-dark .eyebrow{color:var(--line)}
.hl{color:var(--line)}
.hl-mark{background:var(--line);color:var(--black);padding:0 .18em;border-radius:.12em;display:inline-block;transform:rotate(-1deg)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.4rem}
section{padding:5.5rem 0}
.section-head{max-width:680px;margin-bottom:3rem}
.section-head p{color:var(--ink-soft);margin-top:1rem;font-size:1.1rem}
.divider{height:12px;border-top:3px solid var(--line);border-bottom:3px solid var(--line)}

/* ---------- header ---------- */
header.site{background:rgba(12,14,17,.92);backdrop-filter:blur(10px);color:#fff;position:sticky;top:0;z-index:50;border-bottom:3px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1.4rem;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:#fff}
.brand-mark{font-family:var(--mono);font-weight:700;background:var(--line);color:var(--black);padding:.22rem .55rem;border-radius:5px;font-size:1rem}
.brand-name{font-family:var(--display);font-weight:800;font-size:1.08rem}
nav.links{display:flex;gap:1.6rem;align-items:center}
nav.links a{color:#D8DBDF;text-decoration:none;font-size:.95rem;font-weight:600}
nav.links a:hover,nav.links a.active{color:var(--line)}
.nav-cta{background:var(--line);color:var(--black)!important;font-weight:800;padding:.6rem 1.15rem;border-radius:9px;text-decoration:none;font-family:var(--display)}
.nav-cta:hover{background:#ffd14f}
.menu-btn{display:none;background:none;border:2px solid #3A3F47;color:#fff;border-radius:8px;padding:.45rem .8rem;font-family:var(--display);font-weight:700;cursor:pointer}
@media (max-width:780px){
  nav.links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--black);flex-direction:column;align-items:flex-start;padding:1.2rem 1.4rem 1.4rem;gap:1.1rem;border-bottom:3px solid var(--line)}
  nav.links.open{display:flex}
  .menu-btn{display:block}
}

/* ---------- HERO: driving POV, animated lane ---------- */
.hero{background:radial-gradient(1200px 600px at 70% -10%,#222833 0%,var(--black) 55%);color:#fff;padding:6.5rem 0 0;position:relative;overflow:hidden;min-height:88vh;display:flex;flex-direction:column;justify-content:space-between}
.hero .wrap{position:relative;z-index:2}
.hero h1{max-width:14ch;margin-top:.4rem}
.hero .sub{color:#B9BEC6;max-width:52ch;margin:1.6rem 0 2.2rem;font-size:1.18rem}
.street-sign{display:inline-flex;align-items:center;gap:.55rem;background:var(--sign);color:#fff;border:2px solid #fff;border-radius:7px;padding:.4rem .95rem;font-family:var(--display);font-weight:800;letter-spacing:.08em;font-size:.88rem;text-transform:uppercase;box-shadow:0 3px 0 rgba(0,0,0,.45),0 10px 30px rgba(0,0,0,.35)}
.cta-row{display:flex;gap:1rem;flex-wrap:wrap;position:relative;z-index:2}
.btn{display:inline-block;font-family:var(--display);font-weight:800;text-decoration:none;padding:1.05rem 1.7rem;border-radius:12px;font-size:1.05rem;border:2px solid transparent;cursor:pointer;transition:transform .15s ease,background .15s ease}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--line);color:var(--black);box-shadow:0 8px 24px rgba(255,194,22,.25)}
.btn-primary:hover{background:#ffd14f}
.btn-ghost{border-color:#454B55;color:#fff}
.btn-ghost:hover{border-color:var(--line);color:var(--line)}
.btn-green{background:var(--sign);color:#fff}
.btn-green:hover{background:var(--sign-deep)}
.hero .reassure{margin-top:1.2rem;font-size:.92rem;color:#8A9098;font-family:var(--mono);position:relative;z-index:2}

/* perspective road floor */
.road{position:relative;height:30vh;min-height:220px;margin-top:2.5rem;perspective:420px;perspective-origin:50% 0%}
.road-plane{position:absolute;inset:-2% -40% 0;background:
  linear-gradient(90deg,transparent 0 12%, #20242B 12% 88%, transparent 88%),
  #14171C;
  transform:rotateX(55deg);transform-origin:top center;border-top:2px solid #2C313A}
.lane{position:absolute;top:0;bottom:0;left:50%;width:14px;margin-left:-7px;background:repeating-linear-gradient(180deg,var(--line) 0 90px,transparent 90px 200px);animation:drive 1.6s linear infinite;opacity:.95}
.lane.l2{left:24%;opacity:.5;animation-duration:1.6s}
.lane.l3{left:76%;opacity:.5;animation-duration:1.6s}
@keyframes drive{from{background-position-y:0}to{background-position-y:200px}}
.road-glow{position:absolute;left:0;right:0;top:-1px;height:120px;background:linear-gradient(180deg,rgba(255,194,22,.10),transparent)}
.hero-chips{position:absolute;right:6%;top:18%;display:flex;flex-direction:column;gap:.8rem;z-index:2}
.chip{background:rgba(28,32,39,.85);border:1px solid #343A44;backdrop-filter:blur(6px);color:#E6E8EB;border-radius:12px;padding:.7rem 1rem;font-size:.88rem;display:flex;align-items:center;gap:.6rem;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.chip .dot{width:10px;height:10px;border-radius:50%;background:var(--sign)}
.chip strong{font-family:var(--mono);color:var(--line)}
@media (max-width:900px){.hero-chips{display:none}.hero{min-height:auto;padding-top:5rem}}

/* ---------- stats band w/ count-up ---------- */
.stats{background:var(--black);color:#fff;padding:2.6rem 0;border-top:1px solid #20242B}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
@media (max-width:820px){.stats .wrap{grid-template-columns:repeat(2,1fr)}}
.stat .big{font-family:var(--display);font-weight:900;font-size:clamp(2rem,4vw,3rem);color:var(--line);line-height:1}
.stat .small{font-size:.8rem;color:#9AA0A8;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;margin-top:.4rem;display:block}

/* ---------- route: scroll-drawn road ---------- */
.route{position:relative;background:var(--concrete)}
.route-grid{display:grid;grid-template-columns:120px 1fr;gap:0;max-width:760px;margin:0 auto}
.route-svg-col{position:relative}
.route-path{position:sticky;top:120px}
.route-steps{display:flex;flex-direction:column;gap:4.2rem}
.step{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.step.seen{opacity:1;transform:none}
.step .marker{display:inline-flex;width:60px;height:60px;border-radius:50%;background:var(--black);color:var(--line);align-items:center;justify-content:center;font-family:var(--mono);font-weight:700;font-size:1.25rem;border:4px solid var(--line);margin-bottom:1rem;box-shadow:0 8px 20px rgba(0,0,0,.18)}
.step h3{font-size:1.5rem;margin-bottom:.4rem}
.step p{color:var(--ink-soft);max-width:50ch}
.step .micro{font-family:var(--mono);font-size:.82rem;color:var(--sign-deep);margin-top:.6rem;display:block}
@media (max-width:700px){.route-grid{grid-template-columns:54px 1fr}.route-path svg{width:40px}}

/* ---------- packages ---------- */
.grid{display:grid;gap:1.5rem}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:920px){.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);padding:1.9rem;box-shadow:0 1px 2px rgba(20,23,28,.05);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(20,23,28,.10)}
.card h3{margin-bottom:.45rem}
.card .from{font-family:var(--mono);color:var(--ink-soft);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase}
.card .price{font-family:var(--mono);font-weight:700;font-size:2.2rem;margin:.4rem 0 .3rem}
.card p{color:var(--ink-soft);font-size:.98rem}
.card .btn{margin-top:1.3rem;width:100%;text-align:center;padding:.85rem 1rem}
.badge{display:inline-block;background:var(--sign);color:#fff;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;border-radius:5px;padding:.2rem .6rem;margin-bottom:.7rem}
.pkg-dark{background:var(--asphalt);color:#fff;border-color:#2A2F38}
.pkg-dark p{color:#AEB3BB}
.pkg-dark .from{color:#8A9098}

/* ---------- BUILDER: interactive lesson picker ---------- */
.builder{background:var(--black);color:#fff;border-radius:20px;padding:2.6rem;border:1px solid #23272F;box-shadow:0 30px 80px rgba(0,0,0,.35);position:relative;overflow:hidden}
.builder::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:repeating-linear-gradient(90deg,var(--line) 0 42px,transparent 42px 84px)}
.builder h2{color:#fff}
.tabs{display:flex;gap:.6rem;flex-wrap:wrap;margin:1.8rem 0 2rem}
.tab{background:var(--asphalt-2);border:2px solid #2C313A;color:#C9CCD2;font-family:var(--display);font-weight:800;font-size:.95rem;padding:.7rem 1.2rem;border-radius:10px;cursor:pointer}
.tab[aria-pressed="true"]{background:var(--line);border-color:var(--line);color:var(--black)}
.slider-row{margin:1.4rem 0 .6rem}
.slider-row label{font-family:var(--mono);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:#9AA0A8}
.lesson-count{font-family:var(--display);font-weight:900;font-size:3.4rem;color:var(--line);line-height:1;margin:.3rem 0 .8rem}
.lesson-count span{font-size:1.1rem;color:#9AA0A8;font-family:var(--mono);font-weight:600}
input[type=range]{width:100%;accent-color:var(--line);height:34px;cursor:pointer}
.builder-out{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:end;margin-top:1.6rem;padding-top:1.6rem;border-top:1px dashed #343A44}
@media (max-width:640px){.builder-out{grid-template-columns:1fr}}
.b-price{font-family:var(--mono);font-weight:700;font-size:3rem;line-height:1}
.b-meta{font-family:var(--mono);color:#9AA0A8;font-size:.9rem;margin-top:.5rem}
.b-meta .save{color:var(--sign);font-weight:700}
.b-includes{color:#C9CCD2;font-size:.95rem;margin-top:.6rem}
.builder .btn-primary{width:100%;text-align:center;font-size:1.15rem}

/* ---------- pricing tables (kept for transparency / no-JS) ---------- */
.price-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);overflow:hidden}
.price-table caption{text-align:left;font-family:var(--display);font-weight:800;font-size:1.15rem;padding:1.1rem 1.3rem;background:var(--asphalt);color:#fff;border-bottom:3px solid var(--line);caption-side:top;border-radius:var(--radius) var(--radius) 0 0}
.price-table caption .cap-sub{display:block;font-family:var(--body);font-weight:400;font-size:.88rem;color:#B9BEC6;margin-top:.2rem}
.price-table th,.price-table td{padding:.8rem 1.3rem;text-align:left;border-bottom:1px solid var(--hairline);font-size:.97rem}
.price-table th{font-family:var(--mono);font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);background:#FAFAF6}
.price-table td.amount{font-family:var(--mono);font-weight:700}
.price-table td.per{color:var(--sign-deep);font-family:var(--mono);font-size:.85rem}
.price-table tr:last-child td{border-bottom:none}
.price-table .pay{display:inline-block;background:var(--line);color:var(--black);font-family:var(--display);font-weight:800;font-size:.85rem;padding:.42rem .95rem;border-radius:8px;text-decoration:none}
.price-table .pay:hover{background:#ffd14f}
.table-wrap{overflow-x:auto;margin-bottom:2.6rem;border-radius:var(--radius)}

/* ---------- reviews marquee ---------- */
.quotes{background:var(--black);color:#fff;overflow:hidden;padding:5.5rem 0}
.marquee{display:flex;gap:1.5rem;width:max-content;animation:scroll 38s linear infinite}
.marquee:hover{animation-play-state:paused}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.q-card{background:var(--asphalt-2);border:1px solid #2A2F38;border-radius:var(--radius);padding:1.7rem;width:380px;flex:0 0 auto;color:#D8DBDF}
.q-card .stars{color:var(--line);font-size:1rem;letter-spacing:.18em;margin-bottom:.8rem}
.q-card p{font-size:.98rem;color:#C9CCD2}
.q-card .who{font-family:var(--mono);color:var(--line);font-size:.85rem;margin-top:1.1rem;display:block}
@media (prefers-reduced-motion:reduce){.marquee{animation:none;flex-wrap:wrap;width:auto}}

/* ---------- nervous / calm ---------- */
.calm{background:#fff;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.calm .inner{display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:center}
@media (max-width:880px){.calm .inner{grid-template-columns:1fr}}
.calm ul{list-style:none;display:flex;flex-direction:column;gap:.9rem;margin-top:1.3rem}
.calm li{padding-left:1.9rem;position:relative;color:var(--ink-soft)}
.calm li::before{content:"";position:absolute;left:0;top:.42em;width:.9em;height:.9em;border-radius:50%;background:var(--sign)}
.permit-card{background:var(--concrete);border:1px solid var(--hairline);border-radius:var(--radius);padding:1.8rem}
.permit-card ol{margin:1rem 0 0 1.2rem;color:var(--ink-soft);display:flex;flex-direction:column;gap:.6rem}

/* ---------- FAQ ---------- */
details{background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);padding:1.05rem 1.4rem;margin-bottom:.85rem}
details summary{font-family:var(--display);font-weight:800;cursor:pointer;font-size:1.06rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
details summary::after{content:"+";font-family:var(--mono);color:var(--sign-deep);font-size:1.35rem}
details[open] summary::after{content:"–"}
details p{margin-top:.75rem;color:var(--ink-soft)}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr}}
.contact-card{background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);padding:2rem}
.contact-card dt{font-family:var(--mono);font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:1.2rem}
.contact-card dt:first-child{margin-top:0}
.contact-card dd{font-size:1.12rem;font-weight:600}
.contact-card dd a{text-decoration:none}

/* ---------- final CTA ---------- */
.final-cta{background:linear-gradient(135deg,var(--sign) 0%,var(--sign-deep) 100%);color:#fff;text-align:center;position:relative;overflow:hidden}
.final-cta::after{content:"";position:absolute;left:0;right:0;bottom:0;height:8px;background:repeating-linear-gradient(90deg,var(--line) 0 48px,transparent 48px 96px)}
.final-cta h2{color:#fff}
.final-cta p{color:#D7EAE0;max-width:54ch;margin:1rem auto 1.8rem}

/* ---------- footer ---------- */
footer.site{background:var(--black);color:#9AA0A8;padding:3.4rem 0 2.4rem;border-top:3px solid var(--line)}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem}
@media (max-width:760px){footer .cols{grid-template-columns:1fr}}
footer h4{color:#fff;font-size:1rem;margin-bottom:.8rem;font-family:var(--display)}
footer a{color:#C9CCD2;text-decoration:none;display:block;margin-bottom:.5rem;font-size:.95rem}
footer a:hover{color:var(--line)}
footer .fine{margin-top:2.4rem;padding-top:1.3rem;border-top:1px solid #20242B;font-size:.8rem;font-family:var(--mono)}

/* interior page hero */
.page-hero{background:radial-gradient(900px 420px at 80% -20%,#222833 0%,var(--black) 60%);color:#fff;padding:4.2rem 0 3.4rem;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:repeating-linear-gradient(90deg,var(--line) 0 48px,transparent 48px 96px);opacity:.7}
.page-hero h1{font-size:clamp(2.2rem,5.5vw,3.6rem)}
.page-hero p{color:#B9BEC6;max-width:60ch;margin-top:1rem}

.note{background:#FFF6DC;border:1px solid #EAD389;border-radius:var(--radius);padding:1.1rem 1.4rem;font-size:.96rem;color:#6B5A12;margin:1.6rem 0}

/* reveal helper */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.seen{opacity:1;transform:none}

/* ============================================================
   v3 SHOWPIECE LAYER — night drive
   ============================================================ */

/* film grain for depth on flat color */
.grain::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E")}

/* ---------- kinetic hero v3 ---------- */
.hero3{background:linear-gradient(180deg,#0A0D13 0%,#0E1118 46%,#12151C 100%);color:#fff;position:relative;overflow:hidden;padding:5.2rem 0 0}
.hero3 .wrap{position:relative;z-index:3}
.hero3 h1{max-width:16ch}
.hero3 h1 .w{display:inline-block;opacity:0;transform:translateY(.6em) rotate(2deg);animation:wordup .7s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes wordup{to{opacity:1;transform:none}}
.hero3 .sub{color:#AEB5BF;max-width:54ch;margin:1.6rem 0 2.3rem;font-size:1.18rem;opacity:0;animation:wordup .7s .55s cubic-bezier(.2,.8,.2,1) forwards}
.hero3 .cta-row,.hero3 .reassure{opacity:0;animation:wordup .7s .75s cubic-bezier(.2,.8,.2,1) forwards}
@media (prefers-reduced-motion:reduce){.hero3 h1 .w,.hero3 .sub,.hero3 .cta-row,.hero3 .reassure{opacity:1;animation:none;transform:none}}

/* illustrated night scene */
.scene{position:relative;margin-top:2.2rem;line-height:0}
.scene svg{width:100%;height:auto;display:block}
.skyline-back{animation:px 60s linear infinite alternate}
.skyline-front{animation:px 38s linear infinite alternate}
@keyframes px{from{transform:translateX(0)}to{transform:translateX(-40px)}}
.win{animation:flicker 5s steps(2) infinite}
.win:nth-child(3n){animation-delay:1.4s}.win:nth-child(4n){animation-delay:2.6s}
@keyframes flicker{0%,92%{opacity:.85}96%{opacity:.25}100%{opacity:.85}}
.scene .roadline-dash{stroke-dasharray:46 38;animation:dashmove 1.1s linear infinite}
@keyframes dashmove{to{stroke-dashoffset:-84}}
.car-bob{animation:bob 1.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.beam{animation:beam 3.4s ease-in-out infinite}
@keyframes beam{0%,100%{opacity:.5}50%{opacity:.8}}
.signal-r{animation:sig 6s steps(1) infinite}
.signal-y{animation:sig 6s steps(1) infinite;animation-delay:2s}
.signal-g{animation:sig 6s steps(1) infinite;animation-delay:4s}
@keyframes sig{0%{opacity:1}33%{opacity:.12}100%{opacity:.12}}
@media (prefers-reduced-motion:reduce){
  .skyline-back,.skyline-front,.win,.scene .roadline-dash,.car-bob,.beam,.signal-r,.signal-y,.signal-g{animation:none}
}

/* neighborhood ticker */
.ticker{background:var(--line);color:var(--black);overflow:hidden;padding:.7rem 0;border-top:3px solid var(--black);border-bottom:3px solid var(--black)}
.ticker-track{display:flex;gap:3rem;width:max-content;animation:scroll 30s linear infinite;font-family:var(--display);font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:1.05rem;white-space:nowrap}
.ticker-track span::after{content:"◆";margin-left:3rem;font-size:.7em;vertical-align:middle}
@media (prefers-reduced-motion:reduce){.ticker-track{animation:none;flex-wrap:wrap;width:auto}}

/* road-sign section eyebrows */
.sign-eyebrow{display:inline-flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.sign-eyebrow .diamond{width:34px;height:34px;background:var(--line);border:3px solid var(--black);transform:rotate(45deg);display:flex;align-items:center;justify-content:center;border-radius:5px;flex:0 0 auto}
.sign-eyebrow .diamond span{transform:rotate(-45deg);font-family:var(--mono);font-weight:700;font-size:.85rem;color:var(--black)}
.sign-eyebrow .txt{font-family:var(--mono);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--sign-deep)}
.on-dark .sign-eyebrow .txt{color:var(--line)}

/* ---------- JOURNEY: car drives the road as you scroll ---------- */
.journey{background:var(--black);color:#fff;position:relative}
.journey-grid{display:grid;grid-template-columns:200px 1fr;gap:2.5rem;max-width:860px;margin:0 auto}
.journey-road{position:relative}
.journey-sticky{position:sticky;top:90px;height:calc(100vh - 140px);min-height:480px}
.journey-sticky svg{height:100%;width:auto;display:block;margin:0 auto}
#jpath{stroke:#2A2F38;stroke-width:26;fill:none;stroke-linecap:round}
#jdash{stroke:var(--line);stroke-width:4;fill:none;stroke-dasharray:18 14;opacity:.9}
.mile{min-height:62vh;display:flex;flex-direction:column;justify-content:center;opacity:.25;transition:opacity .45s ease;padding:2rem 0}
.mile.active{opacity:1}
.mile .m-tag{font-family:var(--mono);color:var(--line);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:.7rem}
.mile h3{font-size:clamp(1.5rem,3vw,2.2rem);color:#fff;text-transform:uppercase}
.mile p{color:#AEB5BF;max-width:46ch;margin-top:.7rem}
.mile .m-cta{margin-top:1.1rem;display:inline-block;font-family:var(--mono);font-size:.88rem;color:var(--line);text-decoration:none;border-bottom:2px solid var(--line)}
@media (max-width:760px){
  .journey-grid{grid-template-columns:64px 1fr;gap:1.2rem}
  .journey-sticky{min-height:380px}
  .mile{min-height:46vh}
}

/* ---------- quiz: route check ---------- */
.quiz{background:#fff;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.quiz-box{background:var(--card);border:1px solid var(--hairline);border-radius:20px;padding:2.4rem;max-width:720px;margin:0 auto;box-shadow:0 24px 60px rgba(20,23,28,.08);position:relative;overflow:hidden}
.quiz-box::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:repeating-linear-gradient(90deg,var(--line) 0 42px,transparent 42px 84px)}
.q-step{display:none}
.q-step.on{display:block}
.q-q{font-family:var(--display);font-weight:900;font-size:clamp(1.3rem,2.6vw,1.8rem);margin-bottom:1.4rem;text-transform:uppercase}
.q-opts{display:flex;flex-direction:column;gap:.7rem}
.q-opt{background:var(--concrete);border:2px solid var(--hairline);border-radius:12px;padding:1rem 1.2rem;font-family:var(--body);font-weight:600;font-size:1.02rem;cursor:pointer;text-align:left;transition:border-color .15s,transform .15s}
.q-opt:hover{border-color:var(--line);transform:translateX(4px)}
.q-progress{font-family:var(--mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:1rem}
.q-result h3{font-size:clamp(1.4rem,3vw,2rem);text-transform:uppercase;margin-bottom:.6rem}
.q-result p{color:var(--ink-soft)}
.q-result .btn{margin-top:1.4rem}
.q-restart{background:none;border:none;font-family:var(--mono);font-size:.82rem;color:var(--ink-soft);cursor:pointer;margin-top:1.2rem;text-decoration:underline}

/* odometer stats */
.odo{display:inline-flex;gap:3px}
.odo b{background:#1C2027;border:1px solid #2C313A;border-radius:6px;padding:.05em .18em;font-family:var(--mono);color:var(--line);font-weight:700;min-width:1.15em;text-align:center;display:inline-block}

/* ============================================================
   v4 AWARD LAYER — ignition, cursor, odometer, kinetic type
   ============================================================ */

::selection{background:var(--line);color:var(--black)}

/* --- traffic signal: CORRECT cycle green -> yellow -> red --- */
@keyframes sigG2{0%,44%{opacity:1}46%,100%{opacity:.12}}
@keyframes sigY2{0%,45%{opacity:.12}46%,60%{opacity:1}62%,100%{opacity:.12}}
@keyframes sigR2{0%,61%{opacity:.12}62%,100%{opacity:1}}
.signal-g{animation:sigG2 7s linear infinite}
.signal-y{animation:sigY2 7s linear infinite;animation-delay:0s}
.signal-r{animation:sigR2 7s linear infinite;animation-delay:0s}
@media (prefers-reduced-motion:reduce){.signal-g,.signal-y,.signal-r{animation:none}}

/* --- ignition preloader --- */
#preloader{position:fixed;inset:0;background:#0A0D13;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.6rem;transition:transform .7s cubic-bezier(.7,0,.2,1),opacity .7s}
#preloader.done{transform:translateY(-100%);opacity:.4;pointer-events:none}
#preloader .pl-brand{font-family:var(--display);font-weight:900;color:#fff;font-size:1.2rem;letter-spacing:.3em;text-transform:uppercase}
#preloader .pl-brand b{color:var(--line)}
#preloader .pl-hint{font-family:var(--mono);font-size:.72rem;letter-spacing:.3em;color:#586068;text-transform:uppercase}
.gauge-needle{transform-origin:110px 110px;animation:rev 1.5s cubic-bezier(.6,0,.3,1.4) forwards}
@keyframes rev{0%{transform:rotate(-120deg)}55%{transform:rotate(55deg)}100%{transform:rotate(-12deg)}}
.gauge-arc{stroke-dasharray:300;stroke-dashoffset:300;animation:arcfill 1.1s ease-out forwards}
@keyframes arcfill{to{stroke-dashoffset:60}}
@media (prefers-reduced-motion:reduce){#preloader{display:none}}

/* --- custom headlight cursor (fine pointers only) --- */
@media (pointer:fine){
  body.cursor-on, body.cursor-on a, body.cursor-on button, body.cursor-on input, body.cursor-on summary{cursor:none}
  #cur-dot{position:fixed;top:0;left:0;width:8px;height:8px;border-radius:50%;background:var(--line);z-index:300;pointer-events:none;transform:translate(-50%,-50%);box-shadow:0 0 14px 3px rgba(255,194,22,.55)}
  #cur-ring{position:fixed;top:0;left:0;width:38px;height:38px;border-radius:50%;border:1.5px solid rgba(255,194,22,.6);z-index:299;pointer-events:none;transform:translate(-50%,-50%) scale(1);transition:transform .22s ease,border-color .22s,background .22s}
  #cur-ring.hot{transform:translate(-50%,-50%) scale(1.9);border-color:var(--line);background:rgba(255,194,22,.08)}
}
@media (pointer:coarse),(prefers-reduced-motion:reduce){#cur-dot,#cur-ring{display:none}}

/* --- scroll progress + odometer chip --- */
#progress{position:fixed;top:0;left:0;height:3px;background:var(--line);width:0;z-index:120}
#odo-chip{position:fixed;left:1rem;bottom:1rem;z-index:120;background:rgba(12,14,17,.88);border:1px solid #2A2F38;backdrop-filter:blur(8px);border-radius:10px;padding:.5rem .8rem;font-family:var(--mono);font-weight:700;color:var(--line);font-size:.85rem;letter-spacing:.08em;display:flex;align-items:center;gap:.55rem;box-shadow:0 10px 30px rgba(0,0,0,.4)}
#odo-chip .lbl{color:#586068;font-size:.62rem;letter-spacing:.22em}
@media (max-width:760px){#odo-chip{display:none}}
@media (prefers-reduced-motion:reduce){#odo-chip{display:none}}

/* --- giant kinetic type band --- */
.bigband{background:var(--black);overflow:hidden;padding:2.6rem 0;border-bottom:1px solid #1B2027}
.bigband-track{display:flex;gap:4rem;width:max-content;animation:scroll 26s linear infinite;white-space:nowrap;align-items:baseline}
.bigband-track span{font-family:var(--display);font-weight:900;font-size:clamp(3.4rem,9vw,7.5rem);text-transform:uppercase;letter-spacing:-.01em;color:transparent;-webkit-text-stroke:2px #333A45;line-height:1}
.bigband-track span.solid{color:var(--line);-webkit-text-stroke:0}
.bigband-track i{font-style:normal;color:var(--line);font-size:.4em;vertical-align:.55em}
@media (prefers-reduced-motion:reduce){.bigband-track{animation:none;flex-wrap:wrap;width:auto}}

/* --- hero car entrance --- */
#carEnter{animation:carIn 1.7s cubic-bezier(.2,.9,.25,1) both;animation-delay:.25s}
@keyframes carIn{from{transform:translateX(-46%)}to{transform:translateX(0)}}
@media (prefers-reduced-motion:reduce){#carEnter{animation:none}}

/* --- magnetic buttons get inline transforms from JS; keep transitions smooth --- */
.btn{will-change:transform}

/* --- journey road richer --- */
#jpath{stroke-width:30}
#jedgeL,#jedgeR{stroke:#3A4150;stroke-width:2;fill:none;opacity:.8}

/* hold hero choreography until ignition completes */
body:not(.go) .hero3 .w,
body:not(.go) .hero3 .sub,
body:not(.go) .hero3 .cta-row,
body:not(.go) .hero3 .reassure,
body:not(.go) #carEnter{animation-play-state:paused}

/* ============================================================
   v5 — scene atmosphere + correct motion physics
   ============================================================ */
.star{animation:tw 4.5s ease-in-out infinite}
@keyframes tw{0%,100%{opacity:.9}50%{opacity:.2}}
.neon{filter:drop-shadow(0 0 7px currentColor)}
.neon-pink{animation:neonf 8s steps(1) infinite}
.neon-teal{animation:neonf 11s steps(1) infinite;animation-delay:3s}
@keyframes neonf{0%,86%{opacity:1}87%,89%{opacity:.25}90%,92%{opacity:1}93%,94%{opacity:.4}95%,100%{opacity:1}}
.aas-glow{filter:drop-shadow(0 0 8px rgba(255,194,22,.75))}
@media (prefers-reduced-motion:reduce){.star,.neon-pink,.neon-teal{animation:none}}

/* ============================================================
   v6 THEME ENGINE — site-wide light / dark (all 5 pages)
   Default dark (set by inline head script). Light is a full theme.
   ============================================================ */
:root{ --surface-2:#FAFAF6; --note-bg:#FFF6DC; --note-bd:#EAD389; --note-ink:#6B5A12; }
html[data-theme="dark"]{
  --concrete:#0C0E11; --card:#171B22; --ink:#ECEEF1; --ink-soft:#A6ADB6; --hairline:#2A2F38;
  --surface-2:#1F242C; --note-bg:#241F0E; --note-bd:#5A4A12; --note-ink:#F1D98A;
}
body,.card,.price-table,.price-table th,.price-table td,.note,.permit-card,details,.contact-card,.quiz,.calm,.quiz-box,header.site{transition:background-color .45s ease,color .45s ease,border-color .45s ease}
.price-table th{background:var(--surface-2)}
.calm{background:var(--card)}
.quiz{background:var(--card)}
.permit-card{background:var(--surface-2)}
.note{background:var(--note-bg);border-color:var(--note-bd);color:var(--note-ink)}

/* hero text flips with theme (homepage + interior heads) */
.hero3 .reassure{color:#8A9098}
html[data-theme="light"] .hero3{background:linear-gradient(180deg,#9FC6E6 0%,#C7E0EF 52%,#DCEBF2 100%)}
html[data-theme="light"] .hero3 h1{color:#13202B}
html[data-theme="light"] .hero3 .sub{color:#34424F}
html[data-theme="light"] .hero3 .reassure{color:#5C6875}
html[data-theme="light"] .page-hero{background:radial-gradient(900px 420px at 80% -20%,#BBD6EA 0%,#DCEBF2 60%)}
html[data-theme="light"] .page-hero h1{color:#13202B}
html[data-theme="light"] .page-hero p{color:#44525F}
html[data-theme="light"] .on-dark .eyebrow,html[data-theme="light"] .page-hero .sign-eyebrow .txt{color:#136338}

/* hero scene: day/night cross-fade + color remap (light mode = day) */
.scene rect,.scene polygon,.scene line,.scene circle{transition:fill .55s ease}
.nightonly,.dayonly{transition:opacity .6s ease}
html[data-theme="light"] .nightonly{opacity:0}
html[data-theme="dark"] .dayonly{opacity:0}
html[data-theme="light"] .bfar,html[data-theme="light"] .bfar *{fill:#A9C0D0}
html[data-theme="light"] .skyline-back,html[data-theme="light"] .skyline-back *{fill:#BCCDD8}
html[data-theme="light"] .bfront,html[data-theme="light"] .bfront *{fill:#CBB084}
html[data-theme="light"] .bstoop,html[data-theme="light"] .bstoop *{fill:#B89F78}
html[data-theme="light"] .store-body{fill:#51637F}
html[data-theme="light"] .curb{fill:#A6AEB8}
html[data-theme="light"] .road{fill:#BCC2CA}
html[data-theme="light"] .neon{filter:none}

/* theme toggle (lives in dark header, visible both themes) */
.theme-toggle{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.08);border:1.5px solid #3A3F47;border-radius:999px;padding:5px 8px;cursor:pointer}
.theme-toggle svg{display:block}
html[data-theme="dark"] .theme-toggle .ic-sun{color:#6E7681}
html[data-theme="dark"] .theme-toggle .ic-moon{color:var(--line)}
html[data-theme="light"] .theme-toggle .ic-sun{color:#E0A800}
html[data-theme="light"] .theme-toggle .ic-moon{color:#9AA7B3}
.theme-toggle .knob{position:relative;width:38px;height:19px;border-radius:999px;background:rgba(255,255,255,.22);flex:0 0 auto}
.theme-toggle .knob::after{content:"";position:absolute;top:2px;left:2px;width:15px;height:15px;border-radius:50%;background:var(--line);transition:transform .35s cubic-bezier(.4,0,.2,1)}
html[data-theme="light"] .theme-toggle .knob::after{transform:translateX(19px)}
@media (prefers-reduced-motion:reduce){.theme-toggle .knob::after{transition:none}}
