/* ============== TOKENS ============== */
:root{
  --ink:#141312;
  --ink-2:#23201d;
  --orange:#BF360C;        /* unified brand orange */
  --orange-ink:#BF360C;     /* same as --orange; both unified */
  --orange-deep:#E03C0C;
  --paper:#F6F2EA;
  --paper-2:#EDE7DB;
  --card:#FBF8F2;
  --muted:#5E564B;
  --muted-on-dark:#B6ADA0;
  --line:rgba(20,19,18,.12);
  --line-on-dark:rgba(246,242,234,.16);
  --font-display:"Bricolage Grotesque","Archivo Black",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --rad:14px;
  --maxw:1180px;
  --pad-section:clamp(56px,8vw,104px);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--font-body);font-size:1.0625rem;line-height:1.6;
  font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.04;letter-spacing:-.015em;margin:0}
p{margin:0}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:var(--pad-section) 0;position:relative}

/* eyebrow label (orange, with slash motif) */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--orange-ink);margin-bottom:18px;
}
.eyebrow::before{content:"";width:18px;height:11px;background:var(--orange);
  clip-path:polygon(28% 0,100% 0,72% 100%,0 100%);} /* shifted slash */
.dark .eyebrow{color:var(--paper)}

h2.head{font-size:clamp(2rem,4.4vw,3.1rem)}
.lead{font-size:clamp(1.06rem,1.6vw,1.2rem);color:var(--muted);max-width:60ch}
.dark .lead{color:var(--muted-on-dark)}

/* ============== BUTTONS ============== */
.btn{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:none;
  font-family:var(--font-display);font-weight:700;font-size:.95rem;letter-spacing:.01em;
  padding:15px 24px;border-radius:9px;transition:all .28s cubic-bezier(.2,.7,.3,1);
  white-space:nowrap;
}
.btn .arr{transition:transform .28s ease}
.btn:hover .arr{transform:translateX(5px)}
.btn--primary{background:var(--ink);color:var(--paper)}
.btn--primary:hover{background:var(--orange-ink);color:#fff}
.btn--orange{background:var(--orange-ink);color:#fff}
.btn--orange:hover{background:var(--ink)}
.btn--ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 2px var(--line)}
.btn--ghost:hover{box-shadow:inset 0 0 0 2px var(--ink);background:var(--ink);color:var(--paper)}
.dark .btn--ghost{color:var(--paper);box-shadow:inset 0 0 0 2px var(--line-on-dark)}
.dark .btn--ghost:hover{background:var(--paper);color:var(--ink);box-shadow:inset 0 0 0 2px var(--paper)}
.btn--block{width:100%;justify-content:center}

/* ============== HEADER ============== */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:80;background:rgba(246,242,234,.86);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid transparent;transition:.3s}
.site-header.scrolled{border-bottom:1px solid var(--line);box-shadow:0 6px 24px rgba(20,19,18,.06)}
.hdr-inner{display:flex;align-items:center;gap:24px;height:72px}
.brand{display:flex;align-items:center;gap:8px;flex-shrink:0}
.brand .mark{width:24px;height:24px;background:var(--orange);
  clip-path:polygon(26% 0,100% 0,74% 100%,0 100%)} /* shifted square mark */
.brand .word{font-family:var(--font-display);font-weight:800;font-size:1.42rem;letter-spacing:-.035em;color:var(--ink)}
.brand .sub{font-family:var(--font-display);font-weight:600;font-size:.62rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--muted);margin-left:1px}
nav.primary{margin-left:auto;display:flex;align-items:center;gap:30px}
nav.primary a{font-weight:600;font-size:.94rem;color:var(--ink);position:relative;padding:6px 0}
nav.primary a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--orange);transition:width .28s ease}
nav.primary a:hover::after{width:100%}
.hdr-cta{display:flex;align-items:center;gap:18px}
.hdr-phone{font-family:var(--font-display);font-weight:700;font-size:.94rem;color:var(--ink);display:flex;align-items:center;gap:7px}
.hdr-phone:hover{color:var(--orange-ink)}
.hdr-phone .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(191,54,12,.22);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(191,54,12,.4)}70%{box-shadow:0 0 0 8px rgba(191,54,12,0)}100%{box-shadow:0 0 0 0 rgba(191,54,12,0)}}
.menu-toggle{display:none;background:none;border:2px solid var(--line);width:42px;height:42px;border-radius:9px;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.menu-toggle span{width:18px;height:2px;background:var(--ink);transition:.3s}
.menu-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* mobile nav panel */
.mnav{position:fixed;inset:0 0 0 auto;width:min(86%,360px);background:var(--ink);z-index:90;
  transform:translateX(100%);transition:transform .34s cubic-bezier(.2,.7,.3,1);padding:90px 30px 30px;display:flex;flex-direction:column;gap:6px;overflow-y:auto}
.mnav.open{transform:translateX(0)}
.mnav a{color:var(--paper);font-family:var(--font-display);font-weight:600;font-size:1.18rem;padding:13px 0;border-bottom:1px solid var(--line-on-dark)}
.mnav a:hover{color:var(--orange-ink)}
.mnav .btn{margin-top:18px}
.scrim{position:fixed;inset:0;background:rgba(10,9,8,.5);z-index:85;opacity:0;visibility:hidden;transition:.3s}
.scrim.show{opacity:1;visibility:visible}

/* ============== HERO ============== */
.hero{padding-top:130px;padding-bottom:60px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;
  background-image:radial-gradient(var(--line) 1px,transparent 1px);background-size:26px 26px;opacity:.5;
  -webkit-mask-image:linear-gradient(to bottom,#000,transparent 75%);mask-image:linear-gradient(to bottom,#000,transparent 75%)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.9rem,6.6vw,5.1rem);font-weight:800;letter-spacing:-.03em}
.hero h1 .shift{color:var(--orange-ink)}
.hero .lead{margin-top:22px;font-size:clamp(1.08rem,1.7vw,1.28rem)}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.hero-trust{display:flex;align-items:center;gap:18px;margin-top:26px;flex-wrap:wrap;color:var(--muted);font-size:.9rem;font-weight:500}
.hero-trust .stars{color:var(--orange-ink);letter-spacing:2px;font-size:1rem}
.hero-trust .sep{width:5px;height:5px;border-radius:50%;background:var(--line)}

/* quote form card */
.quote-card{background:var(--card);border-radius:18px;box-shadow:0 24px 60px -22px rgba(20,19,18,.35);
  border:1px solid var(--line);overflow:hidden}
.quote-card .qhead{background:var(--ink);color:var(--paper);padding:20px 26px}
.quote-card .qhead .k{font-family:var(--font-display);font-weight:700;font-size:1.18rem}
.quote-card .qhead .s{font-size:.86rem;color:var(--muted-on-dark);margin-top:3px}
.qsteps{display:flex;gap:6px;margin-top:14px}
.qsteps i{height:4px;flex:1;border-radius:3px;background:var(--line-on-dark)}
.qsteps i.on{background:var(--orange)}
.qbody{padding:24px 26px 26px}
.qstep{display:none;flex-direction:column;gap:14px}
.qstep.active{display:flex;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.field label{display:block;font-family:var(--font-display);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px;color:var(--ink-2)}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;
  font-family:var(--font-body);font-size:.96rem;background:#fff;color:var(--ink);transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange-ink);box-shadow:0 0 0 3px rgba(191,54,12,.14)}
.field textarea{resize:vertical;min-height:80px}
.q-row{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-top:4px}
.q-back{background:none;border:none;color:var(--muted);font-family:var(--font-display);font-weight:600;cursor:pointer;font-size:.9rem;padding:0}
.q-back:hover{color:var(--ink)}
.q-note{font-size:.8rem;color:var(--muted);text-align:center;margin-top:12px}

/* ============== SOCIAL PROOF BAR ============== */
.proofbar{background:var(--ink);color:var(--paper)}
.proofbar .wrap{display:flex;align-items:center;justify-content:center;gap:38px;flex-wrap:wrap;padding:22px 22px}
.proof-item{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:600;font-size:.92rem}
.proof-item .stars{color:var(--orange-ink);letter-spacing:2px}
.proof-item .ico{color:var(--orange-ink);font-size:1.1rem}
.proof-divider{width:1px;height:26px;background:var(--line-on-dark)}
@media(max-width:760px){.proof-divider{display:none}}

/* ============== COMPANY PROMISE (dark) ============== */
.dark{background:var(--ink);color:var(--paper)}
.dark h2,.dark h3{color:var(--paper)}
.promise-top{max-width:760px}
.promise-top h2{margin-bottom:18px}
.promise-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:54px}
.promise-card{border-top:2px solid var(--line-on-dark);padding-top:22px}
.promise-card .glyph{font-size:1.7rem;color:var(--orange);line-height:1;margin-bottom:14px}
.promise-card h3{font-size:1.18rem;margin-bottom:9px}
.promise-card p{color:var(--muted-on-dark);font-size:.96rem}

/* ============== SERVICES GRID ============== */
.svc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:44px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--rad);
  padding:28px 26px;transition:.3s;position:relative;overflow:hidden}
.svc-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--orange);transition:width .3s ease}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 22px 44px -24px rgba(20,19,18,.4);border-color:transparent}
.svc-card:hover::before{width:100%}
.svc-tag{align-self:flex-start;font-family:var(--font-display);font-weight:600;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--orange-ink);background:rgba(191,54,12,.1);padding:5px 10px;border-radius:50px;margin-bottom:18px}
.svc-card h3{font-size:1.36rem;margin-bottom:10px}
.svc-card p{color:var(--muted);font-size:.97rem;margin-bottom:20px;flex:1}
.svc-link{font-family:var(--font-display);font-weight:700;font-size:.92rem;color:var(--ink);display:inline-flex;align-items:center;gap:7px}
.svc-card:hover .svc-link{color:var(--orange-ink)}
.svc-link .arr{transition:transform .28s}
.svc-card:hover .svc-link .arr{transform:translateX(5px)}

/* ============== PROCESS (numbered accordion) ============== */
.process{background:var(--paper-2)}
.proc-layout{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:start}
.proc-steps{display:flex;flex-direction:column}
.proc-step{border-bottom:1px solid var(--line);padding:22px 0;cursor:pointer}
.proc-step:first-child{border-top:1px solid var(--line)}
.proc-h{display:flex;align-items:center;gap:18px}
.proc-num{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--orange-ink);min-width:46px}
.proc-t{font-family:var(--font-display);font-weight:700;font-size:1.3rem;flex:1}
.proc-toggle{width:26px;height:26px;border-radius:50%;background:var(--ink);position:relative;flex-shrink:0;transition:.3s}
.proc-toggle::before,.proc-toggle::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--paper);transition:.3s}
.proc-toggle::before{width:11px;height:2px}
.proc-toggle::after{width:2px;height:11px}
.proc-step.open .proc-toggle{background:var(--orange)}
.proc-step.open .proc-toggle::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.proc-body{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;padding-left:64px}
.proc-step.open .proc-body{max-height:200px;padding-top:14px}
.proc-body p{color:var(--muted);font-size:1rem}
.proc-aside{background:var(--ink);color:var(--paper);border-radius:18px;padding:40px 36px;position:sticky;top:96px}
.proc-aside .eyebrow{margin-bottom:14px}
.proc-aside h3{font-size:1.75rem;margin-bottom:14px;line-height:1.1}
.proc-aside p{color:var(--muted-on-dark);margin-bottom:26px}

/* ============== ALTERNATING SERVICE DETAIL ============== */
.detail+.detail{padding-top:0}
.detail-row{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.detail:nth-of-type(even) .detail-media{order:2}
.detail-media{border-radius:18px;aspect-ratio:4/3;position:relative;overflow:hidden;
  box-shadow:0 24px 50px -28px rgba(20,19,18,.45)}
/* TODO: replace gradient placeholders with real photos */
.detail-media .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:#fff}
.detail-media .ph .pi{font-size:2.4rem;opacity:.92}
.detail-media .ph .pl{font-family:var(--font-display);font-weight:700;font-size:1rem;letter-spacing:.04em;opacity:.9}
.media-print{background:linear-gradient(135deg,#2a2724,#141312 60%,var(--orange))}
.media-wide{background:linear-gradient(135deg,var(--orange),#b8320a 70%,#141312)}
.media-vehicle{background:linear-gradient(135deg,#1c1a17,#3a352f 55%,var(--orange))}
.detail h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin-bottom:16px}
.detail .lead{margin-bottom:22px}
.detail-list{list-style:none;padding:0;margin:0 0 26px;display:grid;grid-template-columns:1fr 1fr;gap:18px 24px}
.detail-list li .dt{font-family:var(--font-display);font-weight:700;font-size:1.02rem;display:flex;align-items:center;gap:9px;margin-bottom:4px}
.detail-list li .dt::before{content:"";width:13px;height:8px;background:var(--orange);clip-path:polygon(28% 0,100% 0,72% 100%,0 100%);flex-shrink:0}
.detail-list li p{color:var(--muted);font-size:.92rem;line-height:1.45}

/* ============== WHY / WHAT SETS US APART ============== */
.why{background:var(--paper-2)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:48px}
.why-card{background:var(--card);border-radius:var(--rad);padding:28px 24px;border:1px solid var(--line)}
.why-card .n{font-family:var(--font-display);font-weight:800;font-size:.95rem;color:var(--orange-ink);margin-bottom:14px;letter-spacing:.04em}
.why-card h3{font-size:1.16rem;margin-bottom:8px}
.why-card p{color:var(--muted);font-size:.95rem}

/* ============== SERVICE AREA ============== */
.area-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:center}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.chip{font-family:var(--font-display);font-weight:600;font-size:.86rem;padding:9px 16px;border-radius:50px;
  background:var(--card);border:1px solid var(--line);transition:.25s}
.chip:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);transform:translateY(-2px)}
.chip.home{background:var(--orange-ink);color:#fff;border-color:var(--orange-ink)}

/* ============== REVIEWS ============== */
.reviews{background:var(--ink)}
.rev-head{text-align:center;max-width:640px;margin:0 auto 48px}
.rev-head .stars{color:var(--orange);font-size:1.5rem;letter-spacing:3px;margin-bottom:12px}
.rev-head h2{color:var(--paper)}
.rev-head .sub{color:var(--muted-on-dark);margin-top:10px}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev-card{background:var(--ink-2);border:1px solid var(--line-on-dark);border-radius:var(--rad);padding:28px 26px}
.rev-card .rstars{color:var(--orange);letter-spacing:2px;margin-bottom:14px}
.rev-card p{color:var(--paper);font-size:1rem;line-height:1.55;margin-bottom:20px}
.rev-card .who{display:flex;align-items:center;gap:12px}
.rev-card .av{width:42px;height:42px;border-radius:50%;background:var(--orange-ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800}
.rev-card .who .nm{font-family:var(--font-display);font-weight:700;font-size:.96rem;color:var(--paper)}
.rev-card .who .mt{font-size:.82rem;color:var(--muted-on-dark)}
.rev-cta{text-align:center;margin-top:40px}

/* ============== FAQ ============== */
.faq-layout{display:grid;grid-template-columns:.8fr 1.2fr;gap:54px;align-items:start}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;cursor:pointer;
  font-family:var(--font-display);font-weight:700;font-size:1.08rem}
.faq-icon{width:22px;height:22px;flex-shrink:0;position:relative}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--orange);transition:.3s}
.faq-icon::before{width:12px;height:2px}
.faq-icon::after{width:2px;height:12px}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:0 24px 22px;color:var(--muted)}

/* ============== CTA BANNER ============== */
.cta{background:var(--orange-ink);color:#fff;text-align:center}
.cta h2{color:#fff;font-size:clamp(2rem,4.6vw,3.2rem);margin-bottom:16px}
.cta p{color:rgba(255,255,255,.92);max-width:54ch;margin:0 auto 30px;font-size:1.12rem}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta .btn--primary{background:var(--ink);color:#fff}
.cta .btn--primary:hover{background:#fff;color:var(--ink)}
.cta .btn--ghost{box-shadow:inset 0 0 0 2px rgba(255,255,255,.55);color:#fff}
.cta .btn--ghost:hover{background:#fff;color:var(--orange-ink);box-shadow:inset 0 0 0 2px #fff}

/* ============== FOOTER ============== */
.site-footer{background:var(--ink);color:var(--paper);padding:70px 0 0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:50px}
.foot-brand .brand .word{color:var(--paper)}
.foot-brand p{color:var(--muted-on-dark);font-size:.95rem;margin:18px 0 22px;max-width:34ch}
.foot-col h3{font-family:var(--font-display);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper);margin-bottom:18px}
.foot-col a,.foot-col p{display:block;color:var(--muted-on-dark);font-size:.94rem;padding:5px 0}
.foot-col a:hover{color:var(--paper)}
.foot-contact .ci{font-family:var(--font-display);font-weight:700;color:var(--paper);font-size:.94rem}
.foot-bottom{border-top:1px solid var(--line-on-dark);padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.foot-bottom p,.foot-bottom a{color:var(--muted-on-dark);font-size:.85rem}
.foot-bottom a:hover{color:var(--paper)}

/* ============== REVEAL ANIM ============== */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{animation:none!important}}

/* ============== RESPONSIVE ============== */
@media(max-width:980px){
  nav.primary,.hdr-phone{display:none}
  .menu-toggle{display:flex}
  .hdr-cta{margin-left:auto}
  .hero-grid{grid-template-columns:1fr;gap:38px}
  .promise-grid,.svc-grid,.why-grid,.rev-grid{grid-template-columns:1fr 1fr}
  .proc-layout,.detail-row,.area-layout,.faq-layout{grid-template-columns:1fr;gap:36px}
  .proc-aside{position:static}
  .detail:nth-of-type(even) .detail-media{order:0}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .promise-grid,.svc-grid,.why-grid,.rev-grid,.detail-list,.foot-grid{grid-template-columns:1fr}
  .hdr-cta .btn{padding:12px 16px;font-size:.86rem}
}

/* ============== INNER PAGES ============== */
.page-hero{padding:128px 0 56px;position:relative;overflow:hidden;background:var(--paper)}
.page-hero::before{content:"";position:absolute;inset:0;z-index:0;background-image:radial-gradient(var(--line) 1px,transparent 1px);background-size:26px 26px;opacity:.45;-webkit-mask-image:linear-gradient(to bottom,#000,transparent 90%);mask-image:linear-gradient(to bottom,#000,transparent 90%)}
.page-hero .wrap{position:relative;z-index:1}
.page-hero.dark{background:var(--ink);color:var(--paper)}
.page-hero.dark h1{color:var(--paper)}
.breadcrumb{display:flex;gap:9px;align-items:center;font-size:.84rem;color:var(--muted);font-weight:500;margin-bottom:20px;flex-wrap:wrap}
.page-hero.dark .breadcrumb{color:var(--muted-on-dark)}
.breadcrumb a:hover{color:var(--orange-ink)}
.breadcrumb .sep{opacity:.45}
.page-hero h1{font-size:clamp(2.3rem,5vw,3.5rem);font-weight:800;letter-spacing:-.025em;max-width:18ch}
.page-hero h1 .accent{color:var(--orange-ink)}
.page-hero .lead{margin-top:18px}
.ph-cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.ph-meta{margin-top:24px;display:flex;gap:16px;flex-wrap:wrap;align-items:center;color:var(--muted);font-size:.9rem;font-weight:500}
.ph-meta .stars{color:var(--orange-ink);letter-spacing:1px}
.ph-meta .sep{width:5px;height:5px;border-radius:50%;background:var(--line)}

.section-head{max-width:720px;margin-bottom:46px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.reverse .split-media{order:2}

/* prose (privacy etc.) */
.prose{max-width:760px}
.prose h2{font-size:1.45rem;margin:38px 0 12px}
.prose h3{font-size:1.12rem;margin:24px 0 8px}
.prose p{color:var(--muted);margin-bottom:14px}
.prose ul{color:var(--muted);padding-left:20px;margin:0 0 16px}
.prose li{margin-bottom:7px}
.prose a{color:var(--orange-ink);font-weight:600}

/* location cards */
.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.loc-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--rad);padding:24px 24px;transition:.3s;position:relative;overflow:hidden}
.loc-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--orange);transition:width .3s}
.loc-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(20,19,18,.4);border-color:transparent}
.loc-card:hover::before{width:100%}
.loc-card .rg{font-family:var(--font-display);font-weight:600;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--orange-ink);margin-bottom:9px}
.loc-card h3{font-size:1.2rem;margin-bottom:6px}
.loc-card p{color:var(--muted);font-size:.91rem;margin-bottom:16px;flex:1}

/* contact */
.contact-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:start}
.contact-info{display:flex;flex-direction:column}
.ci-item{display:flex;gap:15px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.ci-item:first-child{border-top:1px solid var(--line)}
.ci-item .ico{width:40px;height:40px;border-radius:10px;background:rgba(191,54,12,.1);color:var(--orange-ink);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}
.ci-item .k{font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.ci-item .v{font-family:var(--font-display);font-weight:700;font-size:1.06rem;color:var(--ink)}
.ci-item a.v:hover{color:var(--orange-ink)}

/* feature list reused on service pages */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px 26px}
.feat-item .dt{font-family:var(--font-display);font-weight:700;font-size:1.06rem;display:flex;align-items:center;gap:10px;margin-bottom:6px}
.feat-item .dt::before{content:"";width:14px;height:9px;background:var(--orange);clip-path:polygon(28% 0,100% 0,72% 100%,0 100%);flex-shrink:0}
.feat-item p{color:var(--muted);font-size:.95rem;line-height:1.5}

.media-panel{border-radius:18px;aspect-ratio:4/3;position:relative;overflow:hidden;box-shadow:0 24px 50px -28px rgba(20,19,18,.45);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:#fff}
.media-panel .pi{font-size:2.6rem;opacity:.92}
.media-panel .pl{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.03em;opacity:.92}

@media(max-width:980px){
  .split,.contact-layout{grid-template-columns:1fr;gap:36px}
  .split.reverse .split-media{order:0}
  .loc-grid{grid-template-columns:1fr 1fr}
  .feat-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .loc-grid,.feat-grid{grid-template-columns:1fr}
}

/* ============== HEADER DROPDOWNS ============== */
.nav-dd{position:relative;display:flex;align-items:center;align-self:stretch}
.nav-dd .nav-top{display:inline-flex;align-items:center;gap:6px}
.caret{display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;opacity:.55;transition:transform .25s}
.nav-dd:hover .caret,.nav-dd:focus-within .caret{transform:rotate(180deg)}
.dd-menu{position:absolute;top:100%;left:-14px;min-width:240px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 54px -22px rgba(20,19,18,.34);padding:10px;display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease;z-index:120}
.nav-dd:hover .dd-menu,.nav-dd:focus-within .dd-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dd-menu a{display:block;padding:9px 13px;border-radius:9px;font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--ink);white-space:nowrap}
.dd-menu a::after{display:none}
.dd-menu a:hover{background:var(--paper-2);color:var(--orange-ink)}
.dd-menu--cols{display:grid;grid-template-columns:1fr 1fr;gap:2px 8px;min-width:420px;left:auto;right:-14px}

/* mobile dropdown groups */
.mnav{overflow-y:auto;-webkit-overflow-scrolling:touch}
.mnav-group{border-bottom:1px solid var(--line-on-dark)}
.mnav-top{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:0;cursor:pointer;color:var(--paper);font-family:var(--font-display);font-weight:600;font-size:1.18rem;padding:13px 0;text-align:left}
.mnav-group.open .mnav-top .caret{transform:rotate(180deg)}
.mnav-sub{display:none;padding:2px 0 12px 12px}
.mnav-group.open .mnav-sub{display:block}
.mnav-sub a{display:block;font-size:1rem;font-weight:500;padding:9px 0;border-bottom:none;color:var(--muted-on-dark)}
.mnav-sub a:hover{color:var(--orange-ink)}

@media(max-width:620px){.hdr-cta .btn{display:none}}

/* ===================== Resources & calculators ===================== */
.res-intro{max-width:760px}
.tool-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:920px){.tool-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.tool-grid{grid-template-columns:1fr}}
.tool-card{display:flex;flex-direction:column;align-items:flex-start;gap:11px;padding:26px;background:var(--card);border:1.5px solid var(--line);border-radius:var(--rad);text-decoration:none;color:var(--ink);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.tool-card:hover{transform:translateY(-3px);box-shadow:0 16px 38px rgba(20,19,18,.10);border-color:rgba(20,19,18,.22)}
.tool-card .tc-ico{width:44px;height:44px;border-radius:11px;background:rgba(191,54,12,.12);color:var(--orange-ink);display:grid;place-items:center;font-size:1.3rem;line-height:1}
.tc-ico svg,.ci-item .ico svg,.media-panel .pi svg,.detail-media .ph .pi svg,.promise-card .glyph svg,.proof-item .ico svg{display:block}
.tool-card .tc-ico svg{width:24px;height:24px}
.ci-item .ico svg{width:21px;height:21px}
.media-panel .pi svg{width:48px;height:48px}
.detail-media .ph .pi svg{width:46px;height:46px}
.promise-card .glyph svg{width:30px;height:30px}
.proof-item .ico svg{width:19px;height:19px}
.tool-card h3{font-family:var(--font-display);font-weight:800;font-size:1.12rem;letter-spacing:-.02em;margin:0;line-height:1.15}
.tool-card p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.55;flex:1}
.tool-card .tc-go{font-family:var(--font-display);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--orange-ink)}

.calc{background:var(--card);border:1.5px solid var(--line);border-radius:var(--rad);padding:clamp(20px,3vw,30px)}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}
@media(max-width:560px){.calc-grid{grid-template-columns:1fr}}
.cfield{display:flex;flex-direction:column}
.cfield.full{grid-column:1/-1}
.cfield label{font-family:var(--font-display);font-weight:600;font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px;color:var(--ink-2)}
.cfield input,.cfield select{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;font-family:var(--font-body);font-size:1rem;background:#fff;color:var(--ink)}
.cfield input:focus,.cfield select:focus{outline:none;border-color:var(--orange-ink);box-shadow:0 0 0 3px rgba(191,54,12,.14)}
.cfield .hint{font-size:.8rem;color:var(--muted);margin-top:6px;line-height:1.45}
.calc-out{margin-top:22px;border-top:1.5px solid var(--line);padding-top:22px}
.calc-out .placeholder{color:var(--muted);font-size:.95rem;margin:0}
.res-result{display:flex;flex-wrap:wrap;gap:13px}
.res-stat{flex:1;min-width:150px;background:var(--ink);color:#fff;border-radius:12px;padding:17px 20px}
.res-stat.accent{background:var(--orange-ink)}
.res-stat .v{font-family:var(--font-display);font-weight:800;font-size:1.65rem;letter-spacing:-.02em;line-height:1.05}
.res-stat .l{font-size:.74rem;color:rgba(255,255,255,.82);margin-top:5px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.res-note{margin:15px 0 0;color:var(--muted);font-size:.95rem;line-height:1.65}
.res-note strong{color:var(--ink)}
.res-note a{color:var(--orange-ink);font-weight:600}
.verdict{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:.78rem;padding:5px 12px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.verdict.good{background:rgba(29,122,64,.14);color:#1d7a40}
.verdict.ok{background:rgba(191,54,12,.14);color:var(--orange-ink)}
.verdict.low{background:rgba(179,45,45,.13);color:#b32d2d}
.res-disclaimer{margin:18px 2px 0;font-size:.9rem;color:var(--muted)}
.res-disclaimer a{color:var(--orange-ink);font-weight:600}
.res-links{margin-top:18px}
.bleed-diagram{margin-top:22px;display:flex;justify-content:center}
.bd-bleed{background:rgba(191,54,12,.16);padding:24px;border-radius:6px}
.bd-trim{background:var(--paper-2);padding:24px;border:1.5px dashed rgba(20,19,18,.5);border-radius:3px}
.bd-safe{background:#fff;border:1.5px dashed #1d7a40;width:160px;height:92px;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:#1d7a40}
.bd-legend{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:14px;font-size:.82rem;color:var(--muted)}
.bd-legend span{display:inline-flex;align-items:center;gap:7px}
.bd-legend .sw{width:14px;height:14px;border-radius:3px;display:inline-block}
.bd-legend .sw-bleed{background:rgba(191,54,12,.5)}
.bd-legend .sw-trim{background:var(--paper-2);border:1.5px dashed rgba(20,19,18,.5)}
.bd-legend .sw-safe{background:#fff;border:1.5px dashed #1d7a40}

/* ===== Accessibility: keyboard focus + skip link ===== */
a,button,input,select,textarea,[tabindex]{outline-color:var(--orange-ink)}
:focus-visible{outline:3px solid var(--orange-ink);outline-offset:2px;border-radius:4px}
.dark :focus-visible,.cta :focus-visible,.site-footer :focus-visible{outline-color:#fff}
.skip-link{position:absolute;left:8px;top:-60px;z-index:200;background:var(--ink);color:#fff;padding:11px 18px;border-radius:0 0 10px 10px;font-family:var(--font-display);font-weight:700;text-decoration:none;transition:top .2s ease}
.skip-link:focus{top:0}


/* ===== Quote form — honeypot + sent state ===== */
.qhoney{position:absolute!important;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.btn.is-loading{opacity:.72;pointer-events:none}
.qsent{padding:34px 26px 30px;text-align:center;animation:fade .35s ease}
.qsent-ic{width:54px;height:54px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;color:#fff;background:var(--orange-ink)}
.qsent-ic svg{width:26px;height:26px}
.qsent-k{font-family:var(--font-display);font-weight:700;font-size:1.32rem;color:var(--ink)}
.qsent-s{color:var(--muted);font-size:.98rem;line-height:1.6;margin:8px auto 18px;max-width:340px}


/* ============== REFINEMENT PASS ============== */
/* Brand selection + native control accent */
::selection{background:var(--orange);color:#fff}
html{accent-color:var(--orange-ink)}

/* Keep in-page anchor targets clear of the fixed header */
[id]{scroll-margin-top:90px}

/* Mobile-menu click-to-call (desktop uses .hdr-phone, hidden < 980px) */
.mnav a.mnav-call{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:14px;border:2px solid var(--line-on-dark);border-radius:9px;padding:13px;color:var(--paper);font-weight:700}
.mnav a.mnav-call:hover{border-color:var(--orange-ink);color:var(--orange-ink)}

/* Smoother, GPU-friendly card lift */
.svc-card,.loc-card,.tool-card,.chip,.btn{will-change:transform}

/* Media tiles: subtle texture + depth so the gradient panels read as
   intentional design rather than empty placeholders (no photos required) */
.detail-media::after,.media-panel::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;border-radius:inherit;
  background-image:
    radial-gradient(rgba(255,255,255,.14) 1px,transparent 1.6px),
    radial-gradient(120% 85% at 16% 10%,rgba(255,255,255,.14),transparent 55%);
  background-size:20px 20px,100% 100%;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.07),inset 0 -70px 90px -50px rgba(0,0,0,.45);
}
.detail-media .ph{z-index:2}
.media-panel>*{position:relative;z-index:2}

/* Slightly crisper elevation on the floating quote card */
.quote-card,.sqa-card{transition:box-shadow .3s ease,transform .3s ease}

/* Respect reduced-motion for the new will-change hints */
@media(prefers-reduced-motion:reduce){
  .svc-card,.loc-card,.tool-card,.chip,.btn{will-change:auto}
}
