/* ============================================================
   MR. AUTO WRENCH — WEBSITE STYLESHEET  (mobile-first)
   Brand: Carbon · Ignition Orange · Steel · Chalk
   ============================================================ */

:root{
  --ignition:#E8340D;
  --ignition-bright:#FF3B14;
  --ignition-deep:#B82507;
  --carbon:#0A0A0B;
  --carbon-2:#141417;
  --carbon-3:#1D1E22;
  --carbon-line:#2A2B30;

  --ink:#16171C;          /* body text on light */
  --ink-2:#4B4D54;        /* secondary text on light */
  --paper:#FFFFFF;
  --paper-2:#F6F6F4;      /* off-white section */
  --paper-line:#E7E7E3;

  --steel:#9A9B9A;
  --chalk:#F2F2F1;
  --navy:#16263F;

  --metal:linear-gradient(160deg,#fff,#dcdcdc 18%,#9a9b9a 50%,#e6e6e6 62%,#76787a 86%,#cfcfcf);

  --f-display:'Anton',sans-serif;
  --f-cond:'Oswald',sans-serif;
  --f-body:'Barlow',sans-serif;

  --maxw:1200px;
  --r:14px;
  --shadow:0 18px 50px rgba(10,10,12,.10);
  --shadow-lg:0 30px 70px rgba(10,10,12,.18);
  --nav-h:72px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  -webkit-tap-highlight-color:transparent; /* remove grey flash on tap (iOS/Android) */
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---------- layout ---------- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.section.dark{background:var(--carbon);color:var(--chalk)}
.section.alt{background:var(--paper-2)}
.section.navy{background:var(--navy);color:#fff}
@media(min-width:780px){
  .section{padding:96px 0}
  .wrap{padding:0 32px}
}

/* ---------- type ---------- */
.eyebrow{
  font-family:var(--f-cond);font-weight:600;text-transform:uppercase;
  letter-spacing:.22em;font-size:13px;color:var(--ignition);
  display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--ignition)}
.eyebrow.center{justify-content:center}
.dark .eyebrow{color:var(--ignition-bright)}

h1,h2,h3,.display{font-family:var(--f-display);font-weight:400;text-transform:uppercase;line-height:1.04;letter-spacing:.01em}
.h1{font-size:clamp(38px,8vw,76px)}
.h2{font-size:clamp(30px,5.5vw,52px)}
.h3{font-size:clamp(22px,4vw,30px)}
.lead{font-size:clamp(17px,2.4vw,21px);color:var(--ink-2);line-height:1.6}
.dark .lead{color:#C8C8C6}
.muted{color:var(--ink-2)}
.dark .muted{color:#A9AAA8}
.center{text-align:center}
.orange{color:var(--ignition)}
.sec-head{max-width:62ch}
.sec-head.center{margin:0 auto}
.sec-head h2{margin:14px 0}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  font-size:15px;padding:15px 28px;border-radius:10px;border:2px solid transparent;
  transition:transform .15s ease,background .2s ease,border-color .2s,color .2s;
  white-space:nowrap;min-height:50px;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ignition);color:#fff}
.btn-primary:hover{background:var(--ignition-bright)}
.btn-dark{background:var(--carbon);color:#fff}
.btn-dark:hover{background:#000}
.btn-ghost{background:transparent;border-color:currentColor;color:var(--ink)}
.dark .btn-ghost,.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(0,0,0,.05)}
.dark .btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-block{width:100%}
.btn svg{width:18px;height:18px}

/* ---------- header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(10,10,11,.92);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--carbon-line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}
.nav .brand img{height:38px}
.nav-links{display:none}
.nav-links a{
  font-family:var(--f-cond);font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  font-size:14px;color:#C8C8C6;transition:color .2s;
}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a.active{color:var(--ignition-bright)}
.nav-cta{display:none}
.nav-toggle{
  display:flex;flex-direction:column;gap:5px;background:none;border:0;padding:8px;
}
.nav-toggle span{width:24px;height:2px;background:#fff;transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:var(--nav-h) 0 auto 0;background:var(--carbon);
  border-bottom:1px solid var(--carbon-line);
  transform:translateY(-120%);transition:transform .3s ease;z-index:99;
  padding:20px;display:flex;flex-direction:column;gap:4px;
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{
  font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.08em;
  font-size:18px;color:#E4E4E2;padding:14px 8px;border-bottom:1px solid var(--carbon-line);
}
.mobile-menu a.active{color:var(--ignition-bright)}
.mobile-menu .btn{margin-top:14px}

@media(min-width:900px){
  .nav-links{display:flex;gap:30px}
  .nav-cta{display:inline-flex}
  .nav-toggle{display:none}
}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--carbon);color:var(--chalk);overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 80% 0%,rgba(232,52,13,.18),transparent 55%);
}
.hero-streak{position:absolute;height:7px;border-radius:7px;background:linear-gradient(90deg,transparent,var(--ignition));opacity:.7}
.hero .wrap{position:relative;padding-top:56px;padding-bottom:64px}
.hero-grid{display:grid;gap:40px}
.hero h1{margin:18px 0 20px}
.hero .lead{max-width:48ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero-trust{display:flex;flex-wrap:wrap;gap:22px;margin-top:34px;padding-top:26px;border-top:1px solid var(--carbon-line)}
.hero-trust .item{display:flex;align-items:center;gap:10px;font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.05em;font-size:13px;color:#C8C8C6}
.hero-trust .item svg{width:20px;height:20px;color:var(--ignition-bright)}
.hero-card{
  background:linear-gradient(180deg,var(--carbon-2),var(--carbon));
  border:1px solid var(--carbon-line);border-radius:20px;padding:26px;box-shadow:var(--shadow-lg);
}
@media(min-width:900px){
  .hero-grid{grid-template-columns:1.15fr .85fr;align-items:center;gap:64px}
  .hero .wrap{padding-top:80px;padding-bottom:96px}
}

/* ---------- generic grid + cards ---------- */
.grid{display:grid;gap:20px}
.g2{grid-template-columns:1fr}
.g3{grid-template-columns:1fr}
.g4{grid-template-columns:1fr 1fr}
@media(min-width:680px){.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:1fr 1fr}}
@media(min-width:940px){.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}}

.card{
  background:var(--paper);border:1px solid var(--paper-line);border-radius:var(--r);
  padding:28px;transition:transform .18s ease,box-shadow .2s,border-color .2s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#d8d8d4}
.dark .card{background:var(--carbon-2);border-color:var(--carbon-line)}
.dark .card:hover{border-color:var(--carbon-line);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.card .ico{
  width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:rgba(232,52,13,.1);color:var(--ignition);margin-bottom:18px;
}
.card .ico svg{width:28px;height:28px}
.card h3{font-size:21px;margin-bottom:8px}
.card p{font-size:15.5px;color:var(--ink-2)}
.dark .card p{color:#A9AAA8}

/* ---------- steps ---------- */
.steps{display:grid;gap:16px;counter-reset:step}
@media(min-width:680px){.steps{grid-template-columns:repeat(5,1fr)}}
.step{position:relative;padding:26px 20px;border:1px solid var(--paper-line);border-radius:var(--r);background:var(--paper)}
.dark .step{background:var(--carbon-2);border-color:var(--carbon-line)}
.step .n{
  font-family:var(--f-display);font-size:40px;color:var(--ignition);line-height:1;display:block;margin-bottom:10px;
}
.step h4{font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:17px;margin-bottom:4px}
.step p{font-size:14px;color:var(--ink-2)}
.dark .step p{color:#A9AAA8}

/* ---------- pricing ---------- */
.price-table{border:1px solid var(--paper-line);border-radius:var(--r);overflow:hidden;background:var(--paper);box-shadow:var(--shadow)}
.price-group{padding:8px 0}
.price-group .ghead{
  font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  font-size:14px;color:#fff;background:var(--carbon);padding:14px 22px;display:flex;align-items:center;gap:10px;
}
.price-group .ghead svg{width:18px;height:18px;color:var(--ignition-bright)}
.price-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 22px;border-top:1px solid var(--paper-line)}
.price-row .name{font-weight:500;font-size:16px}
.price-row .name small{display:block;font-size:13px;color:var(--ink-2);font-weight:400}
.price-row .amt{font-family:var(--f-cond);font-weight:600;font-size:18px;color:var(--ignition-deep);white-space:nowrap}
.price-note{font-size:14px;color:var(--ink-2);margin-top:18px;text-align:center}

/* two-column (Non-Luxury / Luxury) price table */
.ptable{border:1px solid var(--paper-line);border-radius:var(--r);overflow:hidden;background:var(--paper);box-shadow:var(--shadow)}
.ptable .phead,.ptable .prow{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:10px;align-items:center;padding:14px 16px}
@media(min-width:600px){.ptable .phead,.ptable .prow{padding:15px 22px;gap:16px}}
.ptable .phead{background:var(--carbon);color:#fff;font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:12.5px}
.ptable .phead .c{text-align:right}
.ptable .phead .c .lux{color:var(--ignition-bright)}
.ptable .prow{border-top:1px solid var(--paper-line)}
.ptable .prow .name{font-weight:500;font-size:15px}
.ptable .prow .amt{text-align:right;font-family:var(--f-cond);font-weight:600;font-size:15px;color:var(--ink);white-space:nowrap}
.ptable .prow .amt.lux{color:var(--ignition-deep)}
.ptable .catrow{background:var(--paper-2);font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:var(--ink-2);padding:11px 16px;border-top:1px solid var(--paper-line);display:flex;align-items:center;gap:9px}
@media(min-width:600px){.ptable .catrow{padding:11px 22px}}
.ptable .catrow svg{width:16px;height:16px;color:var(--ignition)}

/* ---------- service area ---------- */
.area-grid{display:grid;gap:20px}
@media(min-width:780px){.area-grid{grid-template-columns:1fr 1fr;align-items:center;gap:48px}}
.area-list{display:grid;gap:14px}
.area-item{display:flex;align-items:center;gap:14px;font-family:var(--f-cond);font-weight:500;text-transform:uppercase;letter-spacing:.04em;font-size:19px}
.area-item .pin{width:42px;height:42px;border-radius:10px;background:rgba(232,52,13,.1);color:var(--ignition);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.area-item .pin svg{width:22px;height:22px}
.map-card{background:var(--carbon);border:1px solid var(--carbon-line);border-radius:18px;padding:14px;box-shadow:var(--shadow-lg)}
.map-card svg{width:100%;height:auto;display:block;border-radius:12px}

/* ---------- testimonials ---------- */
.quote{background:var(--paper);border:1px solid var(--paper-line);border-radius:var(--r);padding:28px;box-shadow:var(--shadow)}
.dark .quote{background:var(--carbon-2);border-color:var(--carbon-line)}
.quote .stars{color:var(--ignition);letter-spacing:3px;font-size:16px;margin-bottom:14px}
.quote p{font-size:16.5px;font-style:italic;color:var(--ink);margin-bottom:18px}
.dark .quote p{color:#E4E4E2}
.quote .who{display:flex;align-items:center;gap:12px}
.quote .who .av{width:42px;height:42px;border-radius:50%;background:var(--metal);flex-shrink:0}
.quote .who b{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.04em;font-size:15px}
.quote .who span{font-size:13px;color:var(--ink-2)}
.dark .quote .who span{color:#A9AAA8}

/* ---------- CTA band ---------- */
.cta-band{background:var(--carbon);color:var(--chalk);position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 120% at 90% 50%,rgba(232,52,13,.22),transparent 60%)}
.cta-band .wrap{position:relative;display:grid;gap:24px;align-items:center}
@media(min-width:820px){.cta-band .wrap{grid-template-columns:1.4fr .6fr}}
.cta-stripe{position:absolute;left:0;top:0;bottom:0;width:8px;background:repeating-linear-gradient(180deg,var(--ignition),var(--ignition) 22px,var(--carbon) 22px,var(--carbon) 38px)}

/* ---------- forms ---------- */
.form-card{background:var(--paper);border:1px solid var(--paper-line);border-radius:18px;box-shadow:var(--shadow);padding:26px}
@media(min-width:780px){.form-card{padding:40px}}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--f-cond);font-weight:500;text-transform:uppercase;letter-spacing:.05em;font-size:13px;color:var(--ink);margin-bottom:7px}
.field .req{color:var(--ignition)}
.input,.select,.textarea{
  width:100%;font-family:var(--f-body);font-size:16px;color:var(--ink);
  background:#fff;border:1.5px solid var(--paper-line);border-radius:10px;padding:13px 14px;transition:border-color .2s,box-shadow .2s;
}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--ignition);box-shadow:0 0 0 3px rgba(232,52,13,.12)}
.textarea{min-height:120px;resize:vertical}
.row2{display:grid;gap:18px}
@media(min-width:620px){.row2{grid-template-columns:1fr 1fr}}
.row3{display:grid;gap:18px}
@media(min-width:620px){.row3{grid-template-columns:1fr 1fr 1fr}}

/* stepper */
.stepper{display:flex;gap:6px;margin-bottom:30px;flex-wrap:wrap}
.stepper .s{flex:1;min-width:60px}
.stepper .s .bar{height:6px;border-radius:6px;background:var(--paper-line)}
.stepper .s.done .bar,.stepper .s.active .bar{background:var(--ignition)}
.stepper .s .lbl{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.04em;font-size:11px;color:var(--ink-2);margin-top:8px;display:block}
.stepper .s.active .lbl{color:var(--ignition)}
.form-step{display:none}
.form-step.active{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.form-nav{display:flex;justify-content:space-between;gap:14px;margin-top:26px}
.dropzone{border:2px dashed var(--paper-line);border-radius:12px;padding:30px;text-align:center;color:var(--ink-2);cursor:pointer;transition:.2s}
.dropzone:hover{border-color:var(--ignition);color:var(--ignition)}
.dropzone svg{width:34px;height:34px;margin:0 auto 10px}
.chip-select{display:flex;flex-wrap:wrap;gap:10px}
.chip-select label{position:relative;cursor:pointer}
.chip-select input{position:absolute;opacity:0}
.chip-select span{display:inline-block;padding:11px 18px;border:1.5px solid var(--paper-line);border-radius:100px;font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.04em;font-size:14px;transition:.18s}
.chip-select input:checked+span{background:var(--ignition);border-color:var(--ignition);color:#fff}

/* multi-select service checkboxes */
.check-grid{display:grid;gap:22px}
@media(min-width:560px){.check-grid{grid-template-columns:1fr 1fr}}
.cg-head{display:block;font-family:var(--f-cond);font-weight:500;text-transform:uppercase;letter-spacing:.06em;font-size:12px;color:var(--ink-2);margin-bottom:9px}
.check-item{display:flex;align-items:center;gap:11px;padding:11px 13px;border:1.5px solid var(--paper-line);border-radius:10px;cursor:pointer;margin-bottom:9px;background:#fff;transition:border-color .16s,background .16s}
.check-item:last-child{margin-bottom:0}
.check-item:hover{border-color:var(--steel)}
.check-item input{position:absolute;opacity:0;width:0;height:0}
.check-item .box{flex-shrink:0;width:22px;height:22px;border:2px solid var(--paper-line);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:.16s}
.check-item .box::after{content:"";width:11px;height:6px;border-left:2.5px solid #fff;border-bottom:2.5px solid #fff;transform:rotate(-45deg) scale(0);transition:transform .16s;margin-top:-3px}
.check-item .txt{font-size:15px;line-height:1.3}
.check-item input:checked~.box{background:var(--ignition);border-color:var(--ignition)}
.check-item input:checked~.box::after{transform:rotate(-45deg) scale(1)}
.check-item input:checked~.txt{font-weight:600}
.check-item:has(input:checked){border-color:var(--ignition);background:rgba(232,52,13,.04)}
.check-item input:focus-visible~.box{box-shadow:0 0 0 3px rgba(232,52,13,.12)}
.field-err{display:none;font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.04em;font-size:12px;color:var(--ignition);margin-top:12px}
.field-err.show{display:block}

/* VIN decode row */
.vin-row{display:flex;gap:10px;align-items:stretch}
.vin-row .input{flex:1;min-width:0}
.vin-row .btn{flex-shrink:0;white-space:nowrap;padding-left:18px;padding-right:18px}
.form-success{display:none;text-align:center;padding:30px 10px}
.form-success.show{display:block}
.form-success .check{width:72px;height:72px;border-radius:50%;background:rgba(232,52,13,.12);color:var(--ignition);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.form-success .check svg{width:38px;height:38px}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--paper-line)}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--f-cond);font-weight:500;text-transform:uppercase;letter-spacing:.03em;font-size:18px;color:var(--ink)}
.faq-q .pm{flex-shrink:0;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--paper-line);display:flex;align-items:center;justify-content:center;transition:.2s;position:relative}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--ignition);transition:.2s}
.faq-q .pm::before{width:12px;height:2px}
.faq-q .pm::after{width:2px;height:12px}
.faq-item.open .pm{background:var(--ignition);border-color:var(--ignition)}
.faq-item.open .pm::before,.faq-item.open .pm::after{background:#fff}
.faq-item.open .pm::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a .inner{padding:0 0 22px;color:var(--ink-2);font-size:16px;max-width:70ch}

/* ---------- safety ---------- */
.danger-card{border:1px solid #f1c9bf;background:#fff5f2;border-radius:var(--r);padding:26px}
.danger-card .ico{width:52px;height:52px;border-radius:12px;background:var(--ignition);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.danger-card .ico svg{width:28px;height:28px}
.danger-card h3{font-size:20px;margin-bottom:8px}
.danger-card p{font-size:15px;color:var(--ink-2)}

/* ---------- payment chips ---------- */
.pays{display:flex;flex-wrap:wrap;gap:12px}
.pay{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border:1px solid var(--paper-line);border-radius:10px;font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.04em;font-size:14px;background:#fff}
.dark .pay{background:var(--carbon-2);border-color:var(--carbon-line)}
.pay .dot{width:9px;height:9px;border-radius:50%;background:var(--ignition)}

/* ---------- page hero (interior) ---------- */
.page-hero{background:var(--carbon);color:var(--chalk);position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(100% 120% at 90% 0%,rgba(232,52,13,.16),transparent 55%)}
.page-hero .wrap{position:relative;padding:54px 20px}
@media(min-width:780px){.page-hero .wrap{padding:80px 32px}}
.page-hero h1{margin:16px 0 14px}
.crumbs{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:#A9AAA8}
.crumbs a:hover{color:#fff}

/* ---------- footer ---------- */
.site-footer{background:#060504;color:#C8C8C6;padding:56px 0 30px;border-top:3px solid var(--ignition)}
.foot-grid{display:grid;gap:34px}
@media(min-width:780px){.foot-grid{grid-template-columns:1.5fr 1fr 1fr 1.2fr}}
.foot-grid img{height:46px;margin-bottom:18px}
.foot-grid h5{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.1em;font-size:13px;color:#fff;margin-bottom:16px}
.foot-grid ul{list-style:none;display:grid;gap:10px}
.foot-grid a{font-size:14.5px;color:#B6B6B4;transition:color .2s}
.foot-grid a:hover{color:var(--ignition-bright)}
.foot-contact{display:grid;gap:10px;font-size:14.5px}
.foot-contact .row{display:flex;align-items:center;gap:10px}
.foot-contact svg{width:17px;height:17px;color:var(--ignition-bright);flex-shrink:0}
.foot-bottom{margin-top:40px;padding-top:24px;border-top:1px solid var(--carbon-line);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:13px;color:#85857F}
.foot-credit{flex-basis:100%;order:3;margin-top:12px;padding-top:14px;border-top:1px solid var(--carbon-line);font-size:12.5px;color:#75756F;letter-spacing:.02em}
.foot-credit b{color:#B6B6B4;font-weight:600}
.tagstamp{font-family:var(--f-display);text-transform:uppercase;letter-spacing:.16em;color:var(--ignition)}

/* ---------- misc ---------- */
.badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.06em;font-size:12px;padding:7px 13px;border-radius:100px;background:rgba(232,52,13,.12);color:var(--ignition)}
.split{display:grid;gap:36px}
@media(min-width:880px){.split{grid-template-columns:1fr 1fr;align-items:center;gap:56px}}
/* booking info column: only pin alongside the form in the 2-column layout.
   On phones (single column) sticky would float the box over the form fields. */
.book-aside{position:static}
@media(min-width:880px){.book-aside{position:sticky;top:96px;align-self:start}}
.list-check{list-style:none;display:grid;gap:14px}
.list-check li{display:flex;gap:12px;align-items:flex-start;font-size:16px}
.list-check svg{width:22px;height:22px;color:var(--ignition);flex-shrink:0;margin-top:2px}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- booking: AI quote / deposit / calendar ---------- */
.ai-msg{display:flex;gap:14px;margin-bottom:18px;opacity:0;transform:translateY(8px);animation:fade .4s ease forwards}
.ai-msg .av{width:42px;height:42px;border-radius:50%;background:var(--carbon);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-msg .av svg{width:24px;height:24px;color:var(--ignition-bright)}
.ai-msg .bubble{background:var(--paper-2);border:1px solid var(--paper-line);border-radius:4px 16px 16px 16px;padding:16px 18px;font-size:15.5px;color:var(--ink)}
.ai-msg .bubble b{color:var(--ink)}
.ai-typing{display:inline-flex;gap:5px;padding:4px 0}
.ai-typing i{width:8px;height:8px;border-radius:50%;background:var(--steel);animation:blink 1.2s infinite}
.ai-typing i:nth-child(2){animation-delay:.2s}.ai-typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.25}30%{opacity:1}}
.quote-box{background:var(--carbon);color:#fff;border-radius:16px;padding:26px;margin:6px 0 4px;text-align:center}
.quote-box .lbl{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.14em;font-size:13px;color:#A9AAA8}
.quote-box .amt{font-family:var(--f-display);font-size:clamp(40px,9vw,58px);color:var(--ignition-bright);line-height:1;margin:8px 0}
.quote-box .svc{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.05em;font-size:15px;color:#E4E4E2}
.quote-next{display:grid;gap:10px;margin-top:18px}
.quote-next .qn{display:flex;gap:12px;align-items:flex-start;font-size:15px;color:var(--ink-2)}
.quote-next .qn span.num{font-family:var(--f-display);color:var(--ignition);flex-shrink:0}

.deposit-card{border:1px solid var(--paper-line);border-radius:14px;padding:22px;background:var(--paper-2)}
.deposit-card.paid{border-color:#46c46a;background:#f1faf2}
.dep-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.dep-head .amt{font-family:var(--f-display);font-size:30px;color:var(--ink)}
.dep-head .tag{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.06em;font-size:12px;color:var(--ink-2)}
.card-row{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:520px){.card-row{grid-template-columns:1fr 90px 90px}}
.paid-stamp{display:none;align-items:center;gap:10px;color:#2e9e4f;font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.deposit-card.paid .paid-stamp{display:flex}
.deposit-card.paid .pay-fields{display:none}

.slots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(min-width:520px){.slots{grid-template-columns:repeat(4,1fr)}}
.slot{padding:12px 6px;text-align:center;border:1.5px solid var(--paper-line);border-radius:10px;font-family:var(--f-cond);font-size:14px;cursor:pointer;background:#fff;transition:.15s;user-select:none}
.slot:hover{border-color:var(--ignition)}
.slot.selected{background:var(--ignition);border-color:var(--ignition);color:#fff}

.summary{list-style:none;display:grid;gap:10px;text-align:left;max-width:380px;margin:22px auto 0;background:var(--paper-2);border:1px solid var(--paper-line);border-radius:12px;padding:18px 20px}
.summary li{display:flex;justify-content:space-between;gap:16px;font-size:14.5px;border-bottom:1px solid var(--paper-line);padding-bottom:9px}
.summary li:last-child{border-bottom:0;padding-bottom:0}
.summary li .k{color:var(--ink-2);font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.04em;font-size:12.5px}
.summary li .v{font-weight:600;text-align:right}
.ref-pill{display:inline-block;font-family:var(--f-display);letter-spacing:.1em;background:rgba(232,52,13,.12);color:var(--ignition-deep);padding:8px 18px;border-radius:8px;margin-top:6px}
.automation-feed{display:grid;gap:8px;max-width:380px;margin:18px auto 0;text-align:left}
.automation-feed .af{display:flex;gap:10px;align-items:center;font-size:13.5px;color:var(--ink-2);opacity:0;animation:fade .4s ease forwards}
.automation-feed .af svg{width:18px;height:18px;color:#46c46a;flex-shrink:0}
