/* Peters Twp. Mobile Detailing — shared styles for all pages */
:root{
  --asphalt:#0b0b0e;
  --panel:#141419;
  --panel-2:#1b1b22;
  --red:#e01b22;
  --red-bright:#fb2b32;
  --red-deep:#9e1016;
  --white:#f5f4f2;
  --steel:#9a9aa4;
  --line:rgba(255,255,255,.08);
  --display:'Saira Condensed',sans-serif;
  --body:'Barlow',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--asphalt);color:var(--white);font-family:var(--body);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
  /* leave room for the fixed bottom ribbon + iOS home-indicator safe area */
  padding-bottom:calc(34px + env(safe-area-inset-bottom))}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:2px}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

/* ---------- speed-line eyebrow ---------- */
/* eyebrow text uses a slightly brighter red (--red-bright) so 13px bold clears WCAG AA (4.5:1) on the dark background */
.eyebrow{display:flex;align-items:center;gap:14px;font-family:var(--body);font-weight:700;font-size:13px;letter-spacing:.28em;text-transform:uppercase;color:var(--red-bright)}
.eyebrow .lines{display:inline-block;width:46px;height:12px;background:
  linear-gradient(var(--red),var(--red)) 0 1px/46px 2px no-repeat,
  linear-gradient(var(--red),var(--red)) 6px 5px/40px 2px no-repeat,
  linear-gradient(var(--red),var(--red)) 14px 9px/32px 2px no-repeat}

/* ---------- top bar ---------- */
.topbar{background:#000;border-bottom:1px solid var(--line);font-size:13.5px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:16px}
.topbar span{color:var(--steel)}
.topbar strong{color:var(--white);font-weight:600}
.topbar a:hover strong{color:var(--red)}
.topbar .right{display:flex;gap:22px}
@media(max-width:640px){.topbar .right span:nth-child(2){display:none}}

/* ---------- nav ---------- */
header{position:sticky;top:0;z-index:50;background:rgba(11,11,14,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:76px;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:56px;width:auto}
.brand .name{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:.04em;text-transform:uppercase;line-height:1.05}
.brand .name em{font-style:normal;color:var(--red)}
.navlinks{display:flex;gap:8px;font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:.06em}
.navlinks a{padding:12px 14px;border-bottom:2px solid transparent;cursor:pointer}
.navlinks a:hover{color:var(--red)}
.navlinks a[aria-current="page"]{color:var(--red);border-bottom-color:var(--red)}
.btn{display:inline-block;font-family:var(--body);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:14.5px;padding:14px 28px;background:var(--red);color:#fff;border:none;cursor:pointer;clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);transition:background .18s}
.btn:hover{background:var(--red-deep)}
.btn.ghost{background:transparent;box-shadow:inset 0 0 0 2px var(--red)}
.btn.ghost:hover{background:rgba(224,27,34,.12)}
.menu-toggle{display:none;background:none;border:1px solid var(--line);color:var(--white);font-size:22px;line-height:1;padding:10px 14px;cursor:pointer}
@media(max-width:960px){
  .menu-toggle{display:block}
  .navlinks{display:none;position:absolute;top:100%;left:0;right:0;background:#0b0b0e;border-bottom:1px solid var(--line);flex-direction:column;padding:10px 24px 18px}
  .navlinks.open{display:flex}
  .navlinks a{padding:15px 6px;border-bottom:1px solid var(--line)}
  .nav .btn{display:none}
}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);display:flex;align-items:center;
  min-height:calc(100vh - 152px);
  background:url("/assets/hero.webp") center 68%/cover no-repeat #0b0b0e}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(11,11,14,.93) 0%, rgba(11,11,14,.78) 34%, rgba(11,11,14,.38) 62%, rgba(11,11,14,.18) 100%),
    linear-gradient(180deg, rgba(11,11,14,.55) 0%, transparent 30%, transparent 62%, rgba(11,11,14,.72) 100%)}
.hero .wrap{position:relative;width:100%;display:grid;grid-template-columns:minmax(0,720px) 1fr;gap:48px;align-items:center;padding-top:70px;padding-bottom:70px}
.hero h1{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(44px,6.4vw,84px);line-height:.95;letter-spacing:.01em;margin:18px 0 20px}
.hero h1 .red{color:var(--red)}
.hero p.lede{color:var(--steel);font-size:19px;max-width:52ch;margin-bottom:34px}
.hero p.lede strong{color:var(--white)}
.cta-row{display:flex;gap:16px;flex-wrap:wrap}
.contact-links{margin-top:22px;font-size:15.5px;font-weight:600;letter-spacing:.04em;color:var(--steel)}
.contact-links a{color:var(--white);border-bottom:2px solid var(--red);padding-bottom:2px}
.contact-links a:hover{color:var(--red)}
.contact-links span{margin:0 12px;color:var(--steel)}
@media(prefers-reduced-motion:no-preference){
  .hero .wrap > div{animation:settle .8s cubic-bezier(.2,.7,.2,1) both .1s}
  @keyframes settle{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
}
@media(max-width:900px){
  .hero{background-position:62% 68%}
  .hero::before{background:linear-gradient(180deg, rgba(11,11,14,.82) 0%, rgba(11,11,14,.6) 45%, rgba(11,11,14,.86) 100%)}
  .hero .wrap{grid-template-columns:1fr;text-align:center;padding-top:64px;padding-bottom:64px}
  .cta-row{justify-content:center}.eyebrow{justify-content:center}
}

/* ---------- ribbon (fixed to bottom of viewport) ---------- */
.ribbon{position:fixed;bottom:0;left:0;right:0;z-index:40;background:var(--red);color:#fff;overflow:hidden;border-top:2px solid #000;
  padding-bottom:env(safe-area-inset-bottom)}
.ribbon .track{display:flex;white-space:nowrap;font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:13px;padding:6px 0}
.ribbon .track span{padding:0 22px;flex:none}
.ribbon .track span::after{content:"◆";margin-left:44px;font-size:8px;vertical-align:2px;opacity:.75}
@media(prefers-reduced-motion:no-preference){
  .ribbon .track{animation:scroll 30s linear infinite}
  @keyframes scroll{to{transform:translateX(-50%)}}
}

/* ---------- sections ---------- */
section{padding:76px 0}
.sec-head{margin-bottom:44px}
.sec-head h1,.sec-head h2{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(32px,4vw,50px);line-height:1;margin-top:14px}
.sec-head p{color:var(--steel);max-width:64ch;margin-top:14px}

/* pricing (by vehicle class) */
.packages{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--panel);border:1px solid var(--line);padding:34px 30px;display:flex;flex-direction:column;position:relative}
.card:hover{border-color:rgba(224,27,34,.5)}
.card.feature{background:var(--panel-2);border-color:var(--red)}
.card .tag{position:absolute;top:-12px;left:30px;background:var(--red);color:#fff;font-size:11.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:4px 12px}
.card h2,.card h3{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:27px;letter-spacing:.02em;margin-bottom:6px}
.card .sub{color:var(--steel);font-size:14px;margin-bottom:18px}
.pricelist{list-style:none;margin:0 0 28px;flex:1}
.pricelist li{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:13px 0;border-bottom:1px solid var(--line);font-size:16px}
.pricelist li:last-child{border-bottom:none}
.pricelist .svc{font-weight:500}
.pricelist .amt{font-family:var(--display);font-weight:800;font-size:26px;color:var(--red);letter-spacing:.02em}
/* add-on rows (Car Seat Cleaning, Engine Bay Detail) */
.pricelist li.addon{font-size:14.5px}
.pricelist li.addon .svc{color:var(--steel)}
.pricelist li.addon .amt{font-size:19px}
.pricelist li.addon-divider{border-top:1px solid var(--line);margin-top:10px;padding-top:15px}
.pricelist li:has(+ .addon-divider){border-bottom:none}
.card .btn{text-align:center}
@media(max-width:900px){.packages{grid-template-columns:1fr;max-width:460px;margin:0 auto}}

.fineprint{margin-top:32px;display:flex;flex-wrap:wrap;gap:12px}
.fineprint .chip{border:1px solid var(--line);background:var(--panel);padding:10px 18px;font-size:14.5px;color:var(--steel)}
.fineprint .chip b{color:var(--white);font-weight:600}
.servicelinks{margin-top:28px;color:var(--steel);font-size:14.5px;line-height:2}
.servicelinks b{color:var(--white);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:12.5px}
.servicelinks a{color:var(--white);border-bottom:1px solid var(--red);padding-bottom:1px}
.servicelinks a:hover{color:var(--red)}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{padding:34px 30px;background:var(--panel);border:1px solid var(--line)}
.step .k{font-family:var(--display);font-weight:800;font-size:54px;color:transparent;-webkit-text-stroke:1.5px var(--red);line-height:1}
.step h2,.step h3{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:24px;margin:14px 0 8px}
.step p{color:var(--steel);font-size:15.5px}
@media(max-width:900px){.steps{grid-template-columns:1fr}}

/* proof / reviews */
.proof{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center}
.proof .stat{font-family:var(--display);font-weight:800;font-size:clamp(72px,9vw,120px);line-height:.9;color:var(--red)}
.proof .stat small{display:block;font-family:var(--body);font-weight:700;font-size:15px;letter-spacing:.22em;text-transform:uppercase;color:var(--white);margin-top:10px}
.proof .sub{color:var(--steel);font-size:14.5px;margin-top:10px}
.proof .asof{display:block;font-size:11.5px;font-weight:600;letter-spacing:.14em;color:var(--steel);margin-top:6px;text-transform:uppercase}
.quotes{display:grid;gap:16px}
.quote{background:var(--panel);border-left:3px solid var(--red);padding:22px 26px}
.quote p{font-size:16.5px}
.quote span{display:block;margin-top:10px;color:var(--steel);font-size:13.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:600}
@media(max-width:900px){.proof{grid-template-columns:1fr}}

/* service area */
.area{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:start}
.area h1,.area h2{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(32px,4vw,50px);line-height:1;margin-top:14px}
.arealist{list-style:none;margin-top:22px}
.arealist li{padding:16px 0 16px 26px;border-bottom:1px solid var(--line);font-size:16px;position:relative}
.arealist li:last-child{border-bottom:none}
.arealist li::before{content:"";position:absolute;left:0;top:24px;width:14px;height:8px;background:
  linear-gradient(var(--red),var(--red)) 0 0/14px 2px no-repeat,
  linear-gradient(var(--red),var(--red)) 3px 6px/11px 2px no-repeat}
.arealist b{color:var(--white);font-weight:700}
.arealist span{color:var(--steel)}
.notecard{background:var(--panel-2);border:1px solid var(--line);padding:34px 32px}
.notecard h2,.notecard h3{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:26px;margin-bottom:10px}
.notecard p{color:var(--steel);font-size:15.5px;margin-bottom:14px}
.notecard p b{color:var(--white)}
@media(max-width:900px){.area{grid-template-columns:1fr}}

footer{border-top:1px solid var(--line);padding:30px 0;font-size:14px;color:var(--steel)}
footer .wrap{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center}
footer nav{display:flex;gap:18px;flex-wrap:wrap}
footer a:hover{color:var(--red)}
/* sitewide "Services" dropdown — collapsed by default; links stay in the DOM
   (inside <details>) so they're crawlable for SEO without cluttering the footer */
.footer-services{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);font-size:13px;color:var(--steel)}
.footer-services summary{cursor:pointer;display:inline-flex;align-items:center;gap:8px;list-style:none;text-transform:uppercase;letter-spacing:.14em;font-weight:700;font-size:11.5px;color:var(--steel)}
.footer-services summary::-webkit-details-marker{display:none}
.footer-services summary::after{content:"▾";font-size:10px;transition:transform .2s}
.footer-services[open] summary::after{transform:rotate(180deg)}
.footer-services summary:hover{color:var(--red)}
.fs-links{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:14px}
.fs-links a{color:var(--steel)}
.fs-links a:hover{color:var(--red)}

/* service/vehicle page body copy */
.copy{max-width:70ch}
.copy h2{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:clamp(24px,3vw,32px);line-height:1.05;margin:34px 0 14px}
.copy p{color:var(--steel);margin-bottom:16px}
.copy ul{list-style:none;margin:0 0 18px}
.copy li{position:relative;padding:8px 0 8px 26px;color:var(--steel);border-bottom:1px solid var(--line)}
.copy li:last-child{border-bottom:none}
.copy li::before{content:"";position:absolute;left:0;top:16px;width:14px;height:8px;background:
  linear-gradient(var(--red),var(--red)) 0 0/14px 2px no-repeat,
  linear-gradient(var(--red),var(--red)) 3px 6px/11px 2px no-repeat}
.copy b{color:var(--white)}
.copy a{color:var(--white);border-bottom:1px solid var(--red);padding-bottom:1px}
.copy a:hover{color:var(--red)}
