/* ============================================================
   Webb's Complete Auto Care — heritage American garage
   Display: Zilla Slab · Body: Archivo · Mono: JetBrains Mono
   ============================================================ */

:root{
  --ink:#14233b;          /* deep navy (brand text)        */
  --ink-deep:#0e1a2d;     /* hero darkest                  */
  --ink-2:#1b2e4a;        /* raised navy panel             */
  --red:#b4332a;          /* barn red accent               */
  --red-bright:#cf3d31;   /* red hover                     */
  --cream:#f4ecdd;        /* paper background              */
  --cream-soft:#faf5ea;   /* raised card on cream          */
  --bone:#e7dcc6;         /* warm border on cream          */
  --line:#d7cbb2;         /* hairline on cream             */
  --steel:#54606d;        /* muted text on cream           */
  --steel-lt:#a7b6c8;     /* muted text on navy            */
  --line-navy:rgba(231,220,198,.16);

  --wrap:1180px;
  --pad:clamp(20px,5vw,40px);
  --font-d:"Zilla Slab",Georgia,serif;
  --font-b:"Archivo",system-ui,sans-serif;
  --font-m:"JetBrains Mono",ui-monospace,monospace;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
html,body{margin:0}
body{
  font-family:var(--font-b);
  background:var(--cream);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit}
h1,h2,h3{font-family:var(--font-d);font-weight:600;line-height:1.04;margin:0;letter-spacing:-.01em}
p{margin:0}
ul{margin:0;padding:0;list-style:none}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

.skip{position:absolute;left:-999px;top:0;z-index:200;background:var(--red);color:var(--cream);padding:10px 16px;font-weight:600}
.skip:focus{left:8px;top:8px}

/* ---------- shared bits ---------- */
.eyebrow{
  font-family:var(--font-m);
  font-size:12px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:var(--steel);display:flex;align-items:center;gap:.7em;margin:0 0 18px;
}
.eyebrow-light{color:var(--steel-lt)}
.tick{width:9px;height:9px;background:var(--red);flex:none;transform:rotate(0)}
.eyebrow-light .tick{background:var(--red-bright)}

.sec-title{font-size:clamp(2rem,4.6vw,3.4rem);color:var(--ink)}
.sec-title.light{color:var(--cream)}
.sec-head{max-width:680px;margin-bottom:clamp(36px,5vw,56px)}
.sec-lede{margin-top:18px;color:var(--steel);font-size:1.12rem;max-width:60ch}

/* ---------- brand mark ---------- */
.mk-gear{fill:var(--cream)}
.mk-gear-hole{fill:var(--ink)}
.mk-wr{fill:var(--red-bright)}
.mk-hub{fill:var(--cream)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-b);font-weight:600;font-size:.96rem;letter-spacing:.01em;
  padding:13px 22px;border:1.6px solid transparent;border-radius:0;cursor:pointer;
  text-decoration:none;transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
  white-space:nowrap;
}
.btn-lg{padding:16px 28px;font-size:1.02rem}
.btn-block{width:100%;padding:16px 24px;font-size:1.05rem}
.btn-red{background:var(--red);color:var(--cream)}
.btn-red:hover{background:var(--red-bright)}
.btn-line{border-color:rgba(244,236,221,.55);color:var(--cream);background:transparent}
.btn-line:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-ghost{color:var(--cream);background:transparent;border-color:transparent}
.btn-ghost:hover{color:var(--cream)}
.ph-ico{display:inline-flex;color:var(--red-bright)}
.btn-line .ph-ico,.btn-red .ph-ico{color:inherit}

/* ============ HEADER ============ */
.site-head{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
  border-bottom:1px solid transparent;
}
.site-head::before{ /* top scrim for legibility over hero */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,18,32,.55),rgba(10,18,32,0));
  opacity:1;transition:opacity .3s var(--ease);
}
.site-head.scrolled{background:var(--ink-deep);border-bottom-color:var(--line-navy);box-shadow:0 10px 30px -18px rgba(0,0,0,.7)}
.site-head.scrolled::before{opacity:0}
.head-inner{display:flex;align-items:center;gap:24px;height:74px;position:relative}

.brand{display:flex;align-items:center;gap:12px;text-decoration:none;flex:none}
.brand-mark{width:42px;height:42px;flex:none}
.brand-word{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--font-d);font-weight:700;font-size:1.34rem;color:var(--cream);letter-spacing:.005em}
.brand-sub{font-family:var(--font-m);font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--steel-lt);margin-top:3px}

.nav{display:flex;gap:30px;margin-left:auto}
.nav a{
  font-weight:500;font-size:.95rem;color:var(--cream);text-decoration:none;position:relative;padding:6px 0;
  transition:color .2s var(--ease);
}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--red-bright);transition:right .25s var(--ease)}
.nav a:hover::after,.nav a:focus-visible::after{right:0}

.head-cta{display:flex;align-items:center;gap:10px;flex:none}
.head-call{font-weight:600;font-size:.95rem}
.head-call:hover{color:var(--cream)}
.head-call .ph-ico{color:var(--red-bright)}

.menu-toggle{display:none;background:none;border:0;width:44px;height:44px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;margin-left:auto}
.menu-toggle span{display:block;height:2px;width:24px;background:var(--cream);margin:0 auto;transition:transform .25s var(--ease),opacity .25s var(--ease)}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile nav */
.mobile-nav{position:fixed;top:74px;left:0;right:0;z-index:99;background:var(--ink-deep);border-bottom:1px solid var(--line-navy);
  transform:translateY(-12px);opacity:0;transition:transform .25s var(--ease),opacity .25s var(--ease)}
.mobile-nav.open{transform:translateY(0);opacity:1}
.mobile-nav nav{display:flex;flex-direction:column;padding:8px var(--pad) 26px}
.mobile-nav a{color:var(--cream);text-decoration:none;font-weight:500;font-size:1.08rem;padding:15px 0;border-bottom:1px solid var(--line-navy)}
.mobile-nav .m-call{color:var(--red-bright);font-weight:600}
.mobile-nav .m-est{margin-top:18px;border:0}

/* ============ HERO ============ */
.hero{position:relative;background:var(--ink-deep);color:var(--cream);overflow:hidden;
  padding:clamp(140px,20vh,200px) 0 clamp(56px,8vh,90px)}
.hero-media{position:absolute;inset:0;background:url("../assets/img/hero.jpg") center right/cover no-repeat;}
.hero-scrim{position:absolute;inset:0;background:
  linear-gradient(90deg,var(--ink-deep) 0%,rgba(14,26,45,.92) 30%,rgba(14,26,45,.55) 62%,rgba(14,26,45,.35) 100%),
  linear-gradient(180deg,rgba(14,26,45,.5),rgba(14,26,45,0) 30%,rgba(14,26,45,.7))}
.hero-inner{position:relative;max-width:760px}
.hero-eyebrow{margin-bottom:24px}
.hero-h1{font-size:clamp(2.7rem,7vw,5rem);font-weight:700;letter-spacing:-.02em}
.hero-h1 .r1,.hero-h1 .r2{display:block}
.hero-h1 .r2{color:var(--cream)}
.hero-h1 .r1{color:var(--cream)}
.hero-h1 .r2{position:relative}
.hero-sub{margin-top:24px;font-size:clamp(1.05rem,1.7vw,1.28rem);color:#dfe6ef;max-width:54ch;line-height:1.55}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-trust{display:flex;flex-wrap:wrap;gap:0;margin-top:44px;border-top:1px solid var(--line-navy);padding-top:26px}
.hero-trust li{display:flex;flex-direction:column;padding-right:30px;margin-right:30px;border-right:1px solid var(--line-navy)}
.hero-trust li:last-child{border-right:0;margin-right:0;padding-right:0}
.hero-trust strong{font-family:var(--font-d);font-weight:600;font-size:1.35rem;color:var(--cream)}
.hero-trust span{font-size:.82rem;color:var(--steel-lt);margin-top:2px}

/* ============ STATS ============ */
.stats{background:var(--cream-soft);border-bottom:1px solid var(--bone)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:30px 24px;text-align:center;border-right:1px solid var(--bone);position:relative}
.stat::before{content:"";position:absolute;top:0;left:0;right:100%;height:3px;background:var(--red);transition:right .4s var(--ease)}
.stat:hover::before{right:0}
.stat:last-child{border-right:0}
.stat-num{display:block;font-family:var(--font-d);font-weight:700;font-size:clamp(2.2rem,4vw,3rem);color:var(--ink);line-height:1}
.stat-mf{letter-spacing:-.02em}
.stat-star{color:var(--red);font-size:.6em;vertical-align:.18em;margin-left:.05em}
.stat-label{display:block;margin-top:10px;font-size:.82rem;color:var(--steel);font-weight:500;letter-spacing:.01em}

/* ============ SERVICES ============ */
.services{padding:clamp(70px,9vw,120px) 0;background:var(--cream)}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.svc{padding:30px 26px 34px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;background:var(--cream);transition:background .25s var(--ease)}
.svc::before{content:"";position:absolute;left:0;top:26px;bottom:26px;width:3px;background:var(--red);transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease)}
.svc:hover{background:var(--cream-soft)}
.svc:hover::before{transform:scaleY(1)}
.svc-ico{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;color:var(--steel);margin-bottom:16px;transition:color .25s var(--ease)}
.svc-ico svg{width:30px;height:30px}
.svc:hover .svc-ico{color:var(--red)}
.svc h3{font-size:1.16rem;font-weight:600;letter-spacing:-.005em;transition:color .2s var(--ease)}
.svc:hover h3{color:var(--red)}
.svc p{margin-top:10px;font-size:.93rem;color:var(--steel);line-height:1.6}
.svc-foot{margin-top:30px;font-size:1.05rem;color:var(--ink)}
.svc-foot a{color:var(--red);font-weight:600;text-decoration:none;border-bottom:1.5px solid transparent;transition:border-color .2s}
.svc-foot a:hover{border-bottom-color:var(--red)}

/* ============ HONEST / THESIS ============ */
.honest{background:var(--ink);color:var(--cream);padding:clamp(72px,9vw,120px) 0;position:relative}
.honest-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(40px,6vw,84px);align-items:center}
.honest-lede{margin-top:20px;color:#d4ddea;font-size:1.12rem;max-width:54ch}
.sec-title.light br{display:block}
.promise{margin-top:40px;display:flex;flex-direction:column;gap:0}
.promise li{display:flex;gap:22px;padding:24px 0;border-top:1px solid var(--line-navy)}
.promise li:last-child{border-bottom:1px solid var(--line-navy)}
.promise-no{font-family:var(--font-m);font-size:.85rem;font-weight:700;color:var(--red-bright);padding-top:5px;flex:none;letter-spacing:.05em}
.promise h3{font-size:1.18rem;color:var(--cream);font-weight:600}
.promise p{margin-top:7px;color:var(--steel-lt);font-size:.97rem;line-height:1.6}

.honest-art{display:flex;flex-direction:column;align-items:center}
.blueprint{width:min(100%,320px);height:auto;color:var(--steel-lt)}
.blueprint .bp-line,.blueprint .bp-gear,.blueprint .bp-wr path,.blueprint .bp-hub{stroke:var(--steel-lt);fill:none}
.blueprint .bp-gear{stroke:var(--red-bright)}
.bp-anno{fill:var(--steel-lt);font-family:var(--font-m);font-size:9px;letter-spacing:.18em}
.honest-tag{margin-top:26px;font-family:var(--font-d);font-size:1.18rem;line-height:1.4;color:var(--cream);text-align:center;max-width:34ch;position:relative}
.honest-tag>span:first-child{color:var(--red-bright);font-size:1.6em;line-height:0;vertical-align:-.35em;margin-right:.1em}
.honest-tag-src{display:block;font-family:var(--font-m);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--steel-lt);margin-top:14px}

/* ============ REVIEWS ============ */
.reviews{background:var(--cream);padding:clamp(70px,9vw,118px) 0}
.rev-head{max-width:none;display:flex;flex-direction:column;align-items:flex-start}
.rev-rating{display:flex;align-items:center;gap:12px;margin-top:20px}
.rev-stars{color:var(--red);font-size:1.5rem;letter-spacing:.08em}
.rev-stars .half{background:linear-gradient(90deg,var(--red) 55%,var(--line) 55%);-webkit-background-clip:text;background-clip:text;color:transparent}
.rev-rating-txt{font-size:1rem;color:var(--steel)}
.rev-rating-txt strong{font-family:var(--font-d);font-size:1.3rem;color:var(--ink)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:14px}
.rev-card{background:var(--cream-soft);border:1px solid var(--bone);padding:30px 28px;display:flex;flex-direction:column;transition:border-color .25s var(--ease)}
.rev-card:hover{border-color:var(--red)}
.rev-card-stars{color:var(--red);font-size:1.05rem;letter-spacing:.12em;margin-bottom:16px}
.rev-card blockquote{margin:0;font-size:1.04rem;line-height:1.6;color:var(--ink);font-family:var(--font-d);font-weight:400}
.rev-card cite{margin-top:22px;font-style:normal;font-weight:700;font-size:.95rem;color:var(--ink);display:flex;flex-direction:column;gap:3px}
.rev-card cite span{font-family:var(--font-m);font-weight:400;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--steel)}
.rev-foot{margin-top:32px}
.rev-foot a{color:var(--red);font-weight:600;text-decoration:none;border-bottom:1.5px solid transparent;transition:border-color .2s}
.rev-foot a:hover{border-bottom-color:var(--red)}

/* ============ ESTIMATE (work order) ============ */
.estimate{background:var(--ink-deep);color:var(--cream);padding:clamp(72px,9vw,120px) 0}
.est-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:start}
.est-lede{margin-top:20px;color:#d4ddea;font-size:1.1rem;max-width:46ch}
.est-points{margin-top:28px;display:flex;flex-direction:column;gap:13px}
.est-points li{display:flex;align-items:center;gap:13px;color:var(--cream);font-size:1rem}
.ck{width:20px;height:20px;flex:none;border:1.5px solid var(--red-bright);position:relative}
.ck::after{content:"";position:absolute;left:5px;top:1px;width:6px;height:11px;border:solid var(--red-bright);border-width:0 2px 2px 0;transform:rotate(45deg)}
.est-call{display:inline-flex;align-items:center;gap:11px;margin-top:32px;font-family:var(--font-d);font-weight:700;font-size:1.5rem;color:var(--cream);text-decoration:none}
.est-call .ph-ico{color:var(--red-bright)}
.est-call:hover{color:var(--cream)}

/* ticket */
.ticket{background:var(--cream-soft);color:var(--ink);border:1px solid var(--ink);box-shadow:14px 14px 0 -2px rgba(180,51,42,.22);position:relative}
.ticket-top{display:flex;justify-content:space-between;align-items:center;padding:16px 26px;border-bottom:2px dashed var(--line);background:var(--cream)}
.ticket-title{font-family:var(--font-d);font-weight:700;font-size:1.1rem;letter-spacing:.02em}
.ticket-no{font-family:var(--font-m);font-size:.8rem;letter-spacing:.12em;color:var(--red)}
.ticket-form{padding:26px}
.t-row{display:flex;flex-direction:column;margin-bottom:18px}
.t-two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.t-row label{font-family:var(--font-m);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);margin-bottom:7px}
.t-opt{text-transform:none;letter-spacing:.02em;color:var(--steel)}
.t-row input,.t-row textarea{
  font-family:var(--font-b);font-size:1rem;color:var(--ink);background:var(--cream);
  border:1px solid var(--line);border-radius:0;padding:11px 13px;width:100%;transition:border-color .2s var(--ease),box-shadow .2s var(--ease);resize:vertical;
}
.t-row input:focus,.t-row textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(180,51,42,.16)}
.t-row.err input,.t-row.err textarea{border-color:var(--red);background:#fbeae8}
.t-err{font-size:.78rem;color:var(--red);margin-top:6px;min-height:0;font-weight:500}
.t-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.ticket-fine{margin-top:14px;font-size:.78rem;color:var(--steel);text-align:center}
.ticket-done{padding:54px 30px;text-align:center;position:relative}
.done-stamp{display:inline-block;font-family:var(--font-m);font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--red);border:2.5px solid var(--red);padding:7px 18px;transform:rotate(-7deg);font-size:.9rem;margin-bottom:22px;opacity:.9}
.ticket-done h3{font-size:1.6rem}
.ticket-done p{margin-top:12px;color:var(--steel);max-width:34ch;margin-inline:auto}
.ticket-done a{color:var(--red);font-weight:600;text-decoration:none}

/* ============ FAQ ============ */
.faq{background:var(--cream);padding:clamp(70px,9vw,118px) 0}
.faq-wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(36px,5vw,72px);align-items:start}
.faq-head{position:sticky;top:100px}
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;
  background:none;border:0;cursor:pointer;padding:22px 0;text-align:left;
  font-family:var(--font-d);font-weight:600;font-size:1.18rem;color:var(--ink);transition:color .2s var(--ease)}
.faq-q:hover{color:var(--red)}
.faq-sign{position:relative;width:16px;height:16px;flex:none}
.faq-sign::before,.faq-sign::after{content:"";position:absolute;background:var(--red);transition:transform .25s var(--ease)}
.faq-sign::before{left:0;top:7px;width:16px;height:2px}
.faq-sign::after{left:7px;top:0;width:2px;height:16px}
.faq-q[aria-expanded="true"] .faq-sign::after{transform:scaleY(0)}
.faq-a{overflow:hidden;max-height:0;transition:max-height .3s var(--ease)}
.faq-a p{padding:0 0 24px;color:var(--steel);font-size:1rem;line-height:1.65;max-width:56ch}

/* ============ VISIT ============ */
.visit{background:var(--cream-soft);padding:clamp(70px,9vw,118px) 0;border-top:1px solid var(--bone)}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,64px);align-items:stretch}
.visit-block{margin-top:26px}
.visit-block h3{font-family:var(--font-m);font-weight:500;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.visit-block p{color:var(--ink);font-size:1.06rem}
.hours{width:100%;max-width:380px;border-collapse:collapse}
.hours th,.hours td{text-align:left;padding:10px 0;border-bottom:1px solid var(--bone);font-weight:500}
.hours th{font-weight:500;color:var(--ink)}
.hours td{text-align:right;color:var(--steel);font-variant-numeric:tabular-nums}
.hours tr{transition:background .2s var(--ease)}
.hours tbody tr:hover{background:rgba(180,51,42,.05)}
.hours .closed td{color:var(--red)}
.visit-two{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.visit-link{display:inline-block;margin-top:10px;color:var(--red);font-weight:600;text-decoration:none;border-bottom:1.5px solid transparent;transition:border-color .2s}
.visit-link:hover{border-bottom-color:var(--red)}
.visit-note{font-size:.9rem;color:var(--steel);margin-top:10px}
.visit-info a[href^="tel"]{text-decoration:none;color:var(--ink)}

/* map panel (designed, not a live embed) */
.map-panel{position:relative;min-height:380px;background:var(--ink);border:1px solid var(--ink);overflow:hidden;text-decoration:none;display:block}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line-navy) 1px,transparent 1px),linear-gradient(90deg,var(--line-navy) 1px,transparent 1px);background-size:34px 34px}
.map-roads .road{position:absolute;background:rgba(231,220,198,.22)}
.road-75{top:0;bottom:0;left:26%;width:10px;background:rgba(180,51,42,.5)}
.road-emory{left:0;right:0;top:38%;height:6px}
.road-norman{left:26%;right:14%;top:62%;height:4px;transform:rotate(-8deg)}
.map-rd-label{position:absolute;font-family:var(--font-m);font-size:.62rem;letter-spacing:.16em;color:var(--steel-lt);text-transform:uppercase}
.lbl-75{top:14px;left:calc(26% + 16px)}
.lbl-emory{top:calc(38% - 18px);right:20px}
.map-pin{position:absolute;left:62%;top:60%;width:54px;height:54px;transform:translate(-50%,-50%);filter:drop-shadow(0 6px 10px rgba(0,0,0,.4))}
.map-pin .mk-gear{fill:var(--cream)}
.map-pin .mk-gear-hole{fill:var(--ink)}
.map-pin .mk-hub{fill:var(--red-bright)}
.map-cta{position:absolute;left:0;right:0;bottom:0;padding:16px 20px;background:linear-gradient(0deg,rgba(14,26,45,.95),transparent);
  color:var(--cream);font-weight:600;font-size:.95rem;transition:color .2s var(--ease)}
.map-panel:hover .map-cta{color:var(--red-bright)}

/* ============ FOOTER ============ */
.site-foot{background:var(--ink-deep);color:var(--cream);padding:clamp(54px,7vw,80px) 0 30px}
.foot-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start}
.foot-brand{display:flex;gap:16px;align-items:center}
.foot-mark{width:62px;height:62px;flex:none}
.foot-name{font-family:var(--font-d);font-weight:700;font-size:1.4rem;color:var(--cream)}
.foot-tag{font-family:var(--font-d);font-style:italic;color:var(--steel-lt);margin-top:2px}
.foot-nav{display:flex;flex-direction:column;gap:11px}
.foot-nav a{color:var(--steel-lt);text-decoration:none;font-size:.96rem;width:fit-content;transition:color .2s var(--ease)}
.foot-nav a:hover{color:var(--cream)}
.foot-contact{display:flex;flex-direction:column;gap:8px}
.foot-phone{font-family:var(--font-d);font-weight:700;font-size:1.5rem;color:var(--cream);text-decoration:none;transition:color .2s var(--ease)}
.foot-phone:hover{color:var(--red-bright)}
.foot-contact p{color:var(--steel-lt);font-size:.95rem;line-height:1.5}
.foot-hours{font-size:.88rem !important}
.foot-base{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:48px;padding-top:24px;border-top:1px solid var(--line-navy);flex-wrap:wrap}
.foot-base p{font-family:var(--font-m);font-size:.72rem;letter-spacing:.08em;color:var(--steel-lt);text-transform:uppercase}

/* ============ MOTION / REVEAL ============ */
body.js-ready .reveal{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
body.js-ready .reveal.in{opacity:1;transform:none}
body.js-ready .stagger>*{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
body.js-ready .stagger.in>*{opacity:1;transform:none}
body.js-ready .stagger.in>*{transition-delay:calc(var(--i,0) * 70ms)}

/* hero load orchestration */
body.js-ready .hero-eyebrow,body.js-ready .hero-h1 .r1,body.js-ready .hero-h1 .r2,
body.js-ready .hero-sub,body.js-ready .hero-actions,body.js-ready .hero-trust{
  opacity:0;transform:translateY(20px);animation:rise .85s var(--ease) forwards}
body.js-ready .hero-eyebrow{animation-delay:.1s}
body.js-ready .hero-h1 .r1{animation-delay:.22s}
body.js-ready .hero-h1 .r2{animation-delay:.34s}
body.js-ready .hero-sub{animation-delay:.5s}
body.js-ready .hero-actions{animation-delay:.62s}
body.js-ready .hero-trust{animation-delay:.74s}
@keyframes rise{to{opacity:1;transform:none}}

/* blueprint draw */
body.js-ready .blueprint .bp-line,body.js-ready .blueprint .bp-gear,
body.js-ready .blueprint .bp-wr path,body.js-ready .blueprint .bp-hub{
  stroke-dasharray:var(--len,900);stroke-dashoffset:var(--len,900);transition:stroke-dashoffset 1.6s var(--ease)}
body.js-ready .blueprint.drawn .bp-line,body.js-ready .blueprint.drawn .bp-gear,
body.js-ready .blueprint.drawn .bp-wr path,body.js-ready .blueprint.drawn .bp-hub{stroke-dashoffset:0}
body.js-ready .blueprint.drawn .bp-gear{transition-delay:.3s}
body.js-ready .blueprint.drawn .bp-wr path{transition-delay:.6s}

/* ============ RESPONSIVE ============ */
@media (max-width:1000px){
  .nav,.head-call{display:none}
  .menu-toggle{display:flex}
  .head-est{display:none}
  .honest-grid{grid-template-columns:1fr;gap:48px}
  .honest-art{order:-1}
  .est-grid,.visit-grid,.faq-wrap{grid-template-columns:1fr;gap:40px}
  .faq-head{position:static}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .rev-grid{grid-template-columns:1fr;gap:18px}
  .foot-inner{grid-template-columns:1fr 1fr;gap:34px}
  .foot-brand{grid-column:1/-1}
}
@media (max-width:680px){
  body{font-size:16px}
  .head-inner{height:64px}
  .mobile-nav{top:64px}
  .brand-sub{display:none}
  .hero{padding-top:120px}
  .hero-trust{gap:14px}
  .hero-trust li{padding-right:14px;margin-right:14px}
  .hero-trust li:nth-child(2){border-right:0;margin-right:0;padding-right:0}
  .hero-trust li:nth-child(3){border-top:1px solid var(--line-navy);padding-top:14px;width:100%}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat{border-bottom:1px solid var(--bone)}
  .stat:nth-child(2){border-right:0}
  .svc-grid{grid-template-columns:1fr}
  .t-two,.visit-two{grid-template-columns:1fr}
  .foot-inner{grid-template-columns:1fr}
  .foot-base{flex-direction:column;align-items:flex-start;gap:8px}
  .ticket{box-shadow:8px 8px 0 -2px rgba(180,51,42,.22)}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  body.js-ready .reveal,body.js-ready .stagger>*,
  body.js-ready .hero-eyebrow,body.js-ready .hero-h1 .r1,body.js-ready .hero-h1 .r2,
  body.js-ready .hero-sub,body.js-ready .hero-actions,body.js-ready .hero-trust{opacity:1;transform:none;animation:none}
  body.js-ready .blueprint .bp-line,body.js-ready .blueprint .bp-gear,
  body.js-ready .blueprint .bp-wr path,body.js-ready .blueprint .bp-hub{stroke-dashoffset:0}
}
