/* ============================================================
   Service-detail page styles (white & orange)
   loaded after css/site.css
   ============================================================ */

/* section heading */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:clamp(34px,5vw,54px);flex-wrap:wrap}
.sec-head .lhs{max-width:640px}
.sec-head h2{font-size:clamp(28px,3.8vw,48px);margin:12px 0 0;font-weight:800;letter-spacing:-.02em;line-height:1.02}
.sec-head p{color:var(--t-mid);font-size:16.5px;margin-top:14px;max-width:500px}

/* hero ctas */
.svc-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

/* intro: body + sticky glance card */
.svc-intro{display:grid;grid-template-columns:1.3fr .7fr;gap:clamp(34px,5vw,60px);align-items:start}
.svc-body .section-num{display:block;margin-bottom:12px}
.svc-body h2{font-size:clamp(26px,3.4vw,42px);font-weight:800;letter-spacing:-.02em;line-height:1.04;margin-bottom:18px}
.svc-body p{color:var(--t-mid);font-size:16.5px;line-height:1.6;margin-bottom:16px}
.svc-body p strong{color:var(--t-hi);font-weight:700}

.glance{position:sticky;top:104px;display:flex;flex-direction:column;gap:16px}
.glance .gcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:26px}
.glance .gtitle{font-family:'Spline Sans Mono',monospace;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--t-low);margin-bottom:16px}
.glance .grow{display:flex;align-items:center;gap:12px;padding:13px 0;border-top:1px solid var(--line)}
.glance .grow:first-of-type{border-top:0;padding-top:0}
.glance .grow svg{width:20px;height:20px;stroke:var(--amber);fill:none;stroke-width:1.7;flex:none}
.glance .grow .gk{font-family:'Spline Sans Mono',monospace;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--t-low)}
.glance .grow .gv{font-size:15px;font-weight:700;color:var(--t-hi)}
.glance .gcard.dark{background:var(--chip);color:#fff;text-align:center}
.glance .gcard.dark .gtitle{color:var(--t-on-dark-mid)}
.glance .gcard.dark .gphone{font-family:'Anton',sans-serif;font-size:30px;color:#fff;display:inline-flex;align-items:center;gap:11px;letter-spacing:.01em}
.glance .gcard.dark .gphone svg{width:26px;height:26px;stroke:var(--amber-hi);fill:none;stroke-width:1.6}
.glance .gcard.dark .gsub{color:var(--t-on-dark-mid);font-size:13.5px;margin-top:12px}
.glance .gphoto{position:relative;aspect-ratio:4/3;border-radius:var(--r)}
.glance .gphoto .photo{position:absolute;inset:0;border-radius:var(--r)}
@media(max-width:880px){.svc-intro{grid-template-columns:1fr}.glance{position:static}}

/* included checklist */
.incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.incl{display:flex;align-items:flex-start;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:20px 22px}
.incl .ic{width:26px;height:26px;border-radius:50%;background:var(--amber-soft);display:flex;align-items:center;justify-content:center;flex:none;margin-top:1px}
.incl .ic svg{width:15px;height:15px;stroke:var(--amber-deep);fill:none;stroke-width:2.4}
.incl b{display:block;font-size:16px;font-weight:700;color:var(--t-hi);margin-bottom:3px}
.incl span{color:var(--t-mid);font-size:14px;line-height:1.45}
@media(max-width:620px){.incl-grid{grid-template-columns:1fr}}

/* process steps */
.pf-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,3vw,30px);counter-reset:ps}
.pf-step{position:relative;padding:30px 28px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden}
.pf-step::before{counter-increment:ps;content:"0" counter(ps);font-family:'Anton',sans-serif;position:absolute;right:16px;top:4px;font-size:70px;color:rgba(20,18,15,.05);line-height:1}
.pf-step .sk{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--amber-deep);text-transform:uppercase}
.pf-step h3{font-size:21px;font-weight:800;margin:12px 0 9px;letter-spacing:-.01em}
.pf-step p{color:var(--t-mid);font-size:14.5px}
@media(max-width:780px){.pf-steps{grid-template-columns:1fr}}

/* when to call list */
.when-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.when{display:flex;align-items:center;gap:13px;padding:16px 20px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;font-size:15.5px;font-weight:600;color:var(--t-hi)}
.when svg{width:19px;height:19px;stroke:var(--amber);fill:none;stroke-width:1.9;flex:none}
@media(max-width:620px){.when-grid{grid-template-columns:1fr}}

/* faq */
.faq{max-width:820px}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 0;font-size:18px;font-weight:700;color:var(--t-hi)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:none;width:26px;height:26px;border:1px solid var(--line-2);border-radius:50%;position:relative;transition:.2s}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--amber-deep);border-radius:2px;left:50%;top:50%;transform:translate(-50%,-50%)}
.faq summary .pm::before{width:11px;height:2px}
.faq summary .pm::after{width:2px;height:11px;transition:transform .2s}
.faq details[open] summary .pm{background:var(--amber-soft);border-color:transparent}
.faq details[open] summary .pm::after{transform:translate(-50%,-50%) scaleY(0)}
.faq details p{color:var(--t-mid);font-size:15.5px;line-height:1.6;padding:0 0 22px;max-width:680px}

/* related services */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rel{display:flex;align-items:center;gap:15px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:18px 20px;transition:border-color .2s,transform .2s var(--ease)}
.rel:hover{border-color:var(--amber);transform:translateY(-3px)}
.rel .ri{width:40px;height:40px;border:1px solid var(--line-2);border-radius:10px;display:flex;align-items:center;justify-content:center;flex:none}
.rel .ri svg{width:21px;height:21px;stroke:var(--amber);fill:none;stroke-width:1.5}
.rel b{font-size:15.5px;font-weight:700;color:var(--t-hi);display:block}
.rel span{font-family:'Spline Sans Mono',monospace;font-size:10.5px;letter-spacing:.06em;color:var(--t-low);text-transform:uppercase}
@media(max-width:820px){.related-grid{grid-template-columns:1fr}}

/* shared CTA band (service pages) */
.cta-band{position:relative;background:linear-gradient(135deg,var(--amber-hi),var(--amber-deep));color:#fff;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(0,0,0,.07) 0 16px,transparent 16px 44px)}
.cta-band .wrap{position:relative;text-align:center;padding:clamp(56px,8vw,92px) var(--gut)}
.cta-band .ek{font-family:'Spline Sans Mono',monospace;font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;color:#ffe6d3}
.cta-band h2{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;font-size:clamp(34px,5.5vw,68px);line-height:.92;margin:16px 0 10px;color:#fff}
.cta-band p{font-size:18px;font-weight:600;color:#fff3eb;max-width:520px;margin:0 auto 30px}
.cta-band .cphone{font-family:'Anton',sans-serif;font-size:clamp(32px,4.6vw,54px);color:#fff;display:inline-flex;align-items:center;gap:14px}

/* ============================================================
   SERVICE PAGE MOBILE OVERRIDES
   ============================================================ */

/* ── Section head: stack on narrow screens ── */
@media(max-width:620px){
  .sec-head{flex-direction:column;align-items:flex-start;gap:14px}
  .sec-head p{margin-top:0}
}

/* ── Svc body text: comfortable on mobile ── */
@media(max-width:600px){
  .svc-body h2{font-size:clamp(24px,7vw,40px)}
  .svc-body p{font-size:16px}
}

/* ── Glance card: full-width button & readable phone ── */
@media(max-width:880px){
  .glance .gcard .btn{width:100%;justify-content:center}
  .glance .gcard.dark .gphone{font-size:clamp(24px,6vw,30px)}
}

/* ── Incl checklist: compact on smallest screens ── */
@media(max-width:420px){
  .incl{padding:16px 16px}
  .incl b{font-size:15px}
  .incl span{font-size:13.5px}
}

/* ── Process steps: compact padding ── */
@media(max-width:500px){
  .pf-step{padding:22px 18px}
  .pf-step h3{font-size:19px}
}

/* ── When-to-call items: compact on smallest ── */
@media(max-width:420px){
  .when{padding:13px 14px;font-size:14.5px}
}

/* ── FAQ: comfortable tap targets ── */
@media(max-width:600px){
  .faq summary{font-size:16px;padding:18px 0;gap:12px}
  .faq details p{font-size:15px}
}

/* ── Related services: compact on mobile ── */
@media(max-width:520px){
  .rel{padding:16px}
  .rel b{font-size:15px}
}

/* ── CTA band phone: prevent overflow ── */
@media(max-width:500px){
  .cta-band .cphone{font-size:clamp(24px,6.5vw,54px);gap:10px}
}
@media(max-width:400px){
  .cta-band p{font-size:16px}
}
