/* ==========================================================================
   HOMEUPDATE — light design system for service + partner pages
   Mirrors index.html (Aroundhome-style): white header, category strip,
   light-grey hero, Fraunces serif headlines, mint step cards, green CTA
   band, dark-green footer. Includes funnel calculator, before/after,
   service-content and mobile-bar components.
   ========================================================================== */
:root{
  /* homepage tokens */
  --green:#5C8974; --green-deep:#3E5C4B; --green-dark:#2B3A2E; --mint:#E7EFE9; --mint-2:#D6E4DB;
  --grey:#EEF1EC; --ink:#1C1D16; --ink-soft:#4a5142; --ink-faint:#8a907d; --line:#E4E7DE;
  --yellow:#EEDD97; --yellow-deep:#E4C86A; --white:#fff; --sage:#729693;
  --disp:'Poppins',system-ui,sans-serif; --body:'Poppins',system-ui,sans-serif; --serif:'Fraunces',Georgia,serif;
  --ease:cubic-bezier(0.16,1,0.3,1); --radius:16px;
  /* aliases used by shared components (calc, ba, svc blocks) */
  --bg:#fff; --surface:var(--mint); --hairline:var(--line); --green-soft:var(--mint-2);
  --anthracite:var(--green-dark); --gold:var(--yellow);
  --display:'Poppins',system-ui,sans-serif; --serif-italic:'Fraunces',Georgia,serif;
  --ease-out:cubic-bezier(0.16,1,0.3,1);
}
*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
html{scroll-behavior:smooth}
body{margin:0;background:var(--white);color:var(--ink);font-family:var(--body);font-size:16px;line-height:1.55}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin-inline:auto;padding-inline:clamp(1rem,3vw,2rem)}
.skip{position:absolute;left:0;top:0;background:var(--ink);color:#fff;padding:.7rem 1.2rem;transform:translateY(-120%);transition:transform .18s;z-index:200;border-radius:0 0 6px 0}
.skip:focus{transform:translateY(0)}
:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:4px}
h1,h2,h3{font-family:var(--disp);letter-spacing:-0.02em;color:var(--ink)}
.hero h1,.sec-h h2,.why h2,.rail-head h2,.advisor h2{font-family:var(--serif);font-weight:400;letter-spacing:-0.01em}
.em-y{color:var(--green);font-style:italic;font-family:var(--serif)}

/* HEADER (same as homepage) */
.hdr{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:100}
.hdr-in{display:flex;align-items:center;gap:1rem;padding:.8rem 0}
.brand{display:flex;align-items:center;gap:.6rem}
.brand-mark{width:40px;height:40px;border-radius:11px;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center}
.brand-mark svg{width:22px;height:22px}
.brand-txt .nm{font-family:var(--disp);font-weight:800;font-size:1.25rem;line-height:1;color:var(--green-deep);letter-spacing:-0.02em}
.brand-txt .tg{font-size:.7rem;color:var(--ink-faint)}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:1.1rem}
.hdr-phone{display:flex;align-items:center;gap:.45rem;font-family:var(--disp);font-weight:700;color:var(--ink);font-size:.95rem}
.hdr-phone svg{width:16px;height:16px;color:var(--green)}
.hdr-login{display:flex;align-items:center;gap:.4rem;color:var(--ink-soft);font-size:.9rem;font-weight:500}
.hdr-login svg{width:18px;height:18px}
.btn{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--disp);font-weight:700;border-radius:9999px;cursor:pointer;border:0;transition:background .2s var(--ease),transform .2s var(--ease),box-shadow .2s}
.btn-green{background:var(--green);color:#fff;padding:.7rem 1.3rem;font-size:.95rem}
.btn-green:hover{background:var(--green-deep);transform:translateY(-1px)}
.btn-outline{background:var(--mint);color:var(--green-deep);padding:.6rem 1.15rem;font-size:.9rem;border:1px solid var(--mint-2)}
.btn-outline:hover{background:var(--mint-2)}
.btn-yellow{background:var(--yellow);color:#16110c;padding:.85rem 1.5rem;font-size:1rem}
.btn-yellow:hover{background:var(--yellow-deep);transform:translateY(-1px)}
@media(max-width:760px){.hdr-phone .num,.hdr-login span,.brand-txt .tg{display:none}}
@media(max-width:520px){.hdr-in{gap:.5rem}.hdr-right{gap:.55rem}.hdr-login{display:none}.brand-mark{width:34px;height:34px}.brand-txt .nm{font-size:1rem}.btn-outline{padding:.45rem .7rem;font-size:.74rem}}
html,body{max-width:100%;overflow-x:clip}

/* CATEGORY STRIP (same as homepage; .on = current page) */
.cats{background:var(--white);border-bottom:1px solid var(--line)}
.cats-in{display:flex;gap:.4rem;overflow-x:auto;padding:.7rem 0;scrollbar-width:none}
.cats-in::-webkit-scrollbar{display:none}
.cat{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:.45rem;width:92px;padding:.5rem .3rem;border-radius:12px;color:var(--ink-soft);transition:background .16s,color .16s}
.cat:hover{background:var(--mint);color:var(--green-deep)}
.cat.on{background:var(--mint);color:var(--green-deep);font-weight:700}
.cat-ic{width:30px;height:30px;color:var(--green)}
.cat:hover .cat-ic,.cat.on .cat-ic{color:var(--green-deep)}
.cat span{font-size:.72rem;font-weight:600;text-align:center;line-height:1.15}

/* HERO (light, copy left + calculator right) */
.hero{background:var(--grey)}
.hero-in{display:grid;grid-template-columns:1fr;gap:2rem;padding:clamp(2rem,4vw,3.5rem) 0;align-items:start}
@media(min-width:980px){.hero-in{grid-template-columns:1.05fr .95fr;gap:3rem}}
.hero h1{font-size:clamp(1.9rem,1.3rem+2.8vw,3.1rem);font-weight:800;line-height:1.08;margin:.4rem 0 1rem}
.hero-eyebrow{font-family:var(--disp);font-weight:700;color:var(--green);font-size:.82rem;letter-spacing:.02em;margin:0}
.hero-sub{color:var(--ink-soft);font-size:1.02rem;line-height:1.6;max-width:52ch;margin:0 0 1.1rem}
.hero-sub strong{color:var(--ink);font-weight:600}
.byline{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem;font-size:.78rem;color:var(--ink-faint);margin:.2rem 0 0}
.byline .dot-sep{opacity:.5}
.byline strong{color:var(--ink-soft);font-weight:600}
.hero-badges{display:flex;flex-wrap:wrap;gap:.7rem 1.2rem;margin-top:1.2rem;align-items:center}
.hb{display:inline-flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--ink-soft);font-weight:600}
.hb .stars{color:var(--yellow-deep);letter-spacing:.04em}
.hb-badge{background:#fff;border:1px solid var(--line);border-radius:8px;padding:.35rem .6rem;font-size:.72rem;font-weight:700;color:var(--ink-soft)}
.hero-stats{display:flex;flex-wrap:wrap;gap:0;margin-top:1.4rem}
.hero-stat{padding-inline:1.4rem;border-right:1px solid var(--line)}
.hero-stat:first-child{padding-left:0}
.hero-stat:last-child{border-right:0}
.hero-stat .num{font-family:var(--disp);font-weight:800;font-size:1.45rem;color:var(--green-deep);line-height:1;letter-spacing:-0.02em}
.hero-stat .label{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:.35rem}

/* SECTION shells (same as homepage) */
.sec{padding:clamp(3rem,5vw,5.5rem) 0}
.bg-grey{background:var(--grey)}
.sec-h{text-align:center;margin-bottom:2.5rem}
.eyebrow{font-family:var(--disp);font-weight:700;color:var(--green);font-size:.82rem;letter-spacing:.02em;margin:0 0 .5rem}
.sec-h h2{font-size:clamp(1.6rem,1.2rem+1.6vw,2.4rem);font-weight:800;margin:0}
.sec-h h2 .em-y{font-style:italic}
.sec-h p{color:var(--ink-soft);max-width:54ch;margin:.7rem auto 0}

/* STEPS (mint cards — used for benefits AND how-it-works) */
.steps{display:grid;grid-template-columns:1fr;gap:1.2rem}
@media(min-width:780px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{background:var(--mint);border-radius:var(--radius);padding:2rem 1.6rem;text-align:center;position:relative}
.step-pill{display:inline-block;background:var(--green);color:#fff;font-family:var(--disp);font-weight:700;font-size:.72rem;padding:.25rem .7rem;border-radius:9999px;margin-bottom:1.1rem}
.step-ic{width:48px;height:48px;margin:0 auto 1rem;color:var(--green-deep)}
.step h3{font-size:1.15rem;font-weight:700;margin:0 0 .5rem}
.step p{color:var(--ink-soft);font-size:.92rem;margin:0}

/* BENEFIT grid (white cards on grey, homepage .art vibe) */
.bens{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.bens{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.bens{grid-template-columns:repeat(3,1fr)}}
.ben{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.5rem 1.4rem}
.ben-ic{width:42px;height:42px;border-radius:10px;background:var(--mint);color:var(--green-deep);display:flex;align-items:center;justify-content:center;margin-bottom:.9rem}
.ben-ic svg{width:20px;height:20px}
.ben h3{font-size:1.02rem;font-weight:700;margin:0 0 .4rem}
.ben p{font-size:.9rem;color:var(--ink-soft);line-height:1.55;margin:0}

/* SERVICE CONTENT (pros / cost / primes) */
.svc-pros-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:2rem}
@media(min-width:780px){.svc-pros-grid{grid-template-columns:repeat(2,1fr)}}
.svc-pro{display:flex;gap:.9rem;background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.2rem 1.3rem}
.svc-pro .num{font-family:var(--serif);font-style:italic;font-size:1.6rem;color:var(--green);line-height:1;flex-shrink:0;min-width:2.2rem}
.svc-pro h3{font-family:var(--disp);font-weight:700;font-size:1rem;margin:0 0 .3rem;color:var(--ink)}
.svc-pro p{font-size:.88rem;color:var(--ink-soft);line-height:1.55;margin:0}
.svc-sub{font-family:var(--disp);font-weight:700;font-size:1.2rem;margin:3rem 0 0}
.cost-table{margin-top:1.4rem;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;max-width:720px}
.cost-row{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;padding:.9rem 1.4rem;border-bottom:1px solid var(--line)}
.cost-row:last-child{border-bottom:0}
.cost-row.head{background:var(--mint);font-family:var(--disp);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.cost-name{font-size:.95rem;color:var(--ink)}
.cost-name small{display:block;color:var(--ink-faint);font-size:.78rem;margin-top:.1rem}
.cost-val{font-family:var(--disp);font-weight:700;font-size:1rem;color:var(--green-deep);white-space:nowrap}
.cost-foot{font-size:.78rem;color:var(--ink-faint);margin-top:.8rem;max-width:720px}
.prime-list{list-style:none;margin:1.4rem 0 0;padding:0;max-width:720px}
.prime-list li{display:flex;gap:.8rem;padding:.85rem 0;border-top:1px solid var(--line)}
.prime-list li:first-child{border-top:0}
.prime-list .pi{width:26px;height:26px;flex-shrink:0;border-radius:50%;background:var(--mint);color:var(--green-deep);display:flex;align-items:center;justify-content:center;margin-top:1px;font-size:.8rem;font-weight:700}
.prime-list h4{font-family:var(--disp);font-weight:700;font-size:.95rem;margin:0 0 .2rem;color:var(--ink)}
.prime-list p{font-size:.86rem;color:var(--ink-soft);margin:0;line-height:1.5}
.prime-bridge{margin-top:1.4rem;font-size:.95rem;color:var(--ink);max-width:720px}
.prime-bridge strong{color:var(--green-deep)}

/* GREEN CTA BAND (homepage style, funnel jump) */
.cta-band{background:var(--green-deep);color:#fff;border-radius:22px;overflow:hidden;display:grid;grid-template-columns:1fr;align-items:center}
@media(min-width:820px){.cta-band{grid-template-columns:240px 1fr}}
.cta-band-img{height:100%;min-height:170px;background-size:cover;background-position:center}
.cta-band-body{padding:1.8rem 1.8rem 2rem;position:relative}
.cta-band-body h2{color:#fff;font-size:clamp(1.3rem,1.1rem+1vw,1.8rem);font-weight:800;margin:0 0 .5rem;max-width:30ch}
.cta-band-body p{color:rgba(255,255,255,.85);margin:0 0 1.2rem;font-size:.95rem;max-width:52ch}
.cta-badge{position:absolute;top:-26px;right:22px;width:84px;height:84px;border-radius:50%;background:var(--yellow);color:#16110c;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--disp);font-weight:800;font-size:.72rem;line-height:1.05;padding:.4rem;transform:rotate(-8deg)}
@media(max-width:820px){.cta-badge{display:none}}

/* BEFORE/AFTER (light cards) */
.ba-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:2.5rem}
@media(min-width:768px){.ba-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.ba-grid{grid-template-columns:repeat(3,1fr)}}
.ba-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.ba-slider{position:relative;aspect-ratio:16/10;overflow:hidden;cursor:ew-resize;user-select:none;touch-action:pan-y}
.ba-after,.ba-before{position:absolute;inset:0}
.ba-after img,.ba-before img{width:100%;height:100%;object-fit:cover;display:block}
.ba-before{clip-path:inset(0 50% 0 0)}
.ba-label{position:absolute;top:12px;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.6);padding:.25rem .55rem;border-radius:3px;z-index:3;font-weight:600}
.ba-label-before{left:12px}
.ba-label-after{right:12px}
.ba-divider{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;transform:translateX(-1px);z-index:4;pointer-events:none;box-shadow:0 0 12px rgba(0,0,0,.35)}
.ba-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;background:#fff;color:var(--ink);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;box-shadow:0 4px 14px rgba(0,0,0,.4);pointer-events:none}
.ba-meta{padding:1rem 1.2rem 1.15rem}
.ba-title{font-family:var(--disp);font-weight:700;font-size:1rem;color:var(--ink);margin:0}
.ba-spec{font-size:.83rem;color:var(--ink-soft);margin:.35rem 0 0;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.ba-spec .pin{color:var(--green)}
.ba-spec .via{color:var(--green-deep);font-weight:500}

/* CALCULATOR (light card, funnel) */
.calc{background:#fff;border-radius:14px;padding:1.7rem 1.6rem 1.5rem;box-shadow:0 18px 40px -22px rgba(0,0,0,.35);position:relative}
.calc-header{font-family:var(--disp);font-weight:700;font-size:1.18rem;color:var(--ink);margin:0;line-height:1.2}
.calc-sub{font-size:.82rem;color:var(--ink-soft);margin:.3rem 0 1.2rem}
.calc-progress{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:1.3rem}
.calc-progress-seg{height:4px;border-radius:2px;background:var(--line);transition:background 250ms var(--ease)}
.calc-progress-seg.active{background:var(--green)}
.calc-step-label{font-family:var(--disp);font-weight:700;font-size:1rem;color:var(--ink);margin:0 0 1rem}
.calc-chips{display:grid;grid-template-columns:repeat(2,1fr);gap:.55rem;margin-bottom:1.3rem}
.calc-chip{background:#fff;border:1px solid var(--line);padding:.75rem .9rem;border-radius:10px;font-family:var(--body);font-size:.86rem;color:var(--ink);cursor:pointer;text-align:left;transition:border-color 180ms var(--ease),background 180ms var(--ease);display:flex;align-items:center;gap:.55rem}
.calc-chip:hover{border-color:var(--green);background:var(--mint)}
.calc-chip.selected{border-color:var(--green-deep);background:var(--mint-2)}
.calc-chip .chip-icon{width:18px;height:18px;flex-shrink:0;color:var(--green)}
.calc-input{width:100%;padding:.75rem .9rem;border-radius:10px;border:1px solid var(--line);background:#fff;font-family:var(--body);font-size:.95rem;color:var(--ink);margin-bottom:.5rem}
.calc-input:focus-visible{outline:2px solid var(--green);outline-offset:1px;border-color:var(--green)}
.calc-label{font-size:.82rem;color:var(--ink-soft);margin:.7rem 0 .4rem;display:block}
.calc-helper{font-size:.76rem;color:var(--ink-faint);margin-top:.25rem;line-height:1.4}
.calc-buttons{display:flex;gap:.6rem;align-items:center;margin-top:.4rem}
.calc-back{font-size:.85rem;color:var(--ink-soft);background:transparent;border:0;cursor:pointer;padding:.5rem .4rem}
.calc-back:hover{color:var(--ink)}
.calc-next{background:var(--green);color:#fff;flex:1;padding:.85rem 1rem;border-radius:10px;font-family:var(--disp);font-weight:700;font-size:.95rem;border:0;cursor:pointer;transition:background 200ms var(--ease)}
.calc-next:hover:not(:disabled){background:var(--green-deep)}
.calc-next:disabled{opacity:.4;cursor:not-allowed}
.calc-phone-fallback{text-align:center;font-size:.82rem;color:var(--ink-soft);margin:1rem 0 0;padding-top:.9rem;border-top:1px solid var(--line)}
.calc-phone-fallback strong{color:var(--ink);font-weight:600}
.calc-success{text-align:center;padding:1rem .5rem}
.calc-success-icon{width:64px;height:64px;border-radius:50%;background:var(--mint);color:var(--green-deep);display:inline-flex;align-items:center;justify-content:center;margin-bottom:1rem}
.calc-success h3{font-family:var(--disp);font-weight:700;font-size:1.15rem;margin:0 0 .5rem;color:var(--ink)}
.calc-success ol{text-align:left;margin:1.2rem 0 0;padding:0;list-style:none}
.calc-success li{font-size:.88rem;color:var(--ink-soft);padding:.5rem 0;border-top:1px solid var(--line)}
.calc-success li:first-child{border-top:0}
.calc-success li strong{color:var(--ink);font-family:var(--disp);font-weight:600}

/* FAQ (homepage style) */
.faq{max-width:880px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:1.25rem .3rem;display:flex;justify-content:space-between;gap:1rem;font-family:var(--disp);font-weight:700;font-size:1.05rem}
.faq summary::-webkit-details-marker{display:none}
.faq .q-i{width:24px;height:24px;flex-shrink:0;color:var(--green);transition:transform .25s}
.faq details[open] .q-i{transform:rotate(180deg)}
.faq p{color:var(--ink-soft);margin:0 .3rem 1.25rem;max-width:72ch}

/* ADVISOR (homepage style) */
.advisor{display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap;background:var(--mint);border-radius:22px;padding:1.8rem 2rem}
.advisor img{width:96px;height:96px;border-radius:50%;object-fit:cover;flex-shrink:0}
.advisor h2{font-size:1.4rem;font-weight:800;margin:0 0 .4rem}
.advisor p{color:var(--ink-soft);margin:0 0 1rem;max-width:52ch}
.advisor-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.advisor .mail{color:var(--green-deep);font-weight:700}

/* FOOTER (homepage dark green) */
footer.ft{background:var(--green-dark);color:rgba(255,255,255,.78);padding:3.5rem 0 1.8rem}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem}
@media(max-width:820px){.ft-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ft-grid{grid-template-columns:1fr}}
.ft .wordmark{display:flex;align-items:center;gap:.55rem;font-family:var(--disp);font-weight:800;font-size:1.3rem;color:#fff;margin-bottom:.9rem}
.ft .wordmark .m{width:32px;height:32px;border-radius:9px;background:#fff;color:var(--green-deep);display:flex;align-items:center;justify-content:center}
.ft .wordmark .m svg{width:18px;height:18px}
.ft p.tag{font-size:.88rem;line-height:1.55;color:rgba(255,255,255,.66);max-width:34ch}
.ft h4{font-family:var(--disp);font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin:0 0 .9rem}
.ft ul{list-style:none;margin:0;padding:0}
.ft li{margin:.45rem 0}
.ft a:hover{color:#fff}
.ft-partner{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:1rem 1.1rem;margin-top:.4rem}
.ft-partner a{display:block;color:#fff;font-weight:600;margin:.3rem 0;font-size:.92rem}
.ft-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.5rem;padding-top:1.4rem;display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;font-size:.78rem;color:rgba(255,255,255,.5)}

/* MOBILE STICKY BAR (dark green, matches footer) */
.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--green-dark);border-top:1px solid rgba(255,255,255,.15);padding:.6rem .5rem calc(.6rem + env(safe-area-inset-bottom));transition:transform 220ms var(--ease)}
.mobile-bar.hide-on-input{transform:translateY(120%)}
@media(max-width:900px){.mobile-bar{display:flex;gap:.4rem}main{padding-bottom:84px}}
.mb-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.65rem .4rem;border-radius:8px;color:rgba(255,255,255,.85);font-size:.7rem;letter-spacing:.04em;transition:background 180ms var(--ease)}
.mb-btn:hover{background:rgba(255,255,255,.08);color:#fff}
.mb-btn.primary{background:var(--green);color:#fff}
.mb-btn.primary:hover{background:var(--green-deep)}

/* REVEAL */
.reveal,.rv{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in,.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal,.rv{opacity:1;transform:none}}

/* ==========================================================================
   AROUNDHOME-STYLE SERVICE PAGE — funnel band on top + article + sidebar
   ========================================================================== */
/* Breadcrumb */
.crumbs{font-size:.85rem;color:var(--ink-faint);padding:1.1rem 0 .2rem}
.crumbs a{color:var(--green-deep);font-weight:600}
.crumbs .sep{margin:0 .45rem;opacity:.6}

/* Funnel band (grey, full width) */
.fband{background:var(--grey);padding:.4rem 0 0;border-bottom:1px solid var(--line)}
.fband-in{max-width:1200px;margin-inline:auto;padding-inline:clamp(1rem,3vw,2rem)}
.fband-intro{text-align:center;color:var(--ink-soft);font-size:1.02rem;margin:1.1rem 0 1.2rem}
.fband #calc-body{max-width:1040px;margin-inline:auto;padding-bottom:2.2rem}
.q-pill{display:table;margin:0 auto 1.4rem;background:#fff;border-radius:12px;box-shadow:0 6px 18px -10px rgba(0,0,0,.18);padding:.75rem 1.4rem;font-family:var(--disp);font-weight:700;font-size:1.08rem;color:var(--ink);text-align:center}
.band-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem;max-width:1040px;margin-inline:auto}
@media(min-width:860px){.band-tiles{grid-template-columns:repeat(4,1fr)}}
.fband .band-tiles .calc-chip,.fpage-main .band-tiles .calc-chip{flex-direction:column;justify-content:center;align-items:center;gap:.8rem;background:#fff;border:1px solid var(--green-deep);border-radius:10px;min-height:132px;padding:1.2rem .8rem;font-family:var(--disp);font-weight:700;font-size:.95rem;color:var(--ink);text-align:center;transition:box-shadow .18s var(--ease),transform .18s var(--ease),background .18s}
.fband .band-tiles .calc-chip:hover,.fpage-main .band-tiles .calc-chip:hover{box-shadow:0 12px 26px -14px rgba(0,0,0,.3);transform:translateY(-2px);background:#fff}
.fband .band-tiles .calc-chip.selected,.fpage-main .band-tiles .calc-chip.selected{background:var(--mint);border-color:var(--green-deep)}
.fband .band-tiles .calc-chip .chip-icon,.fpage-main .band-tiles .calc-chip .chip-icon{width:44px;height:44px;color:var(--green-deep);stroke-width:1.4}
/* progress line under band */
.fband .calc-progress{grid-template-columns:repeat(4,1fr);gap:4px;margin:0;padding:0 0 .1rem;max-width:none}
.fband .calc-progress-seg{height:6px;border-radius:3px;background:#c9cec4}
.fband .calc-progress-seg.active{background:var(--yellow-deep)}
/* later steps rendered in the band: centered column */
.fband .calc-label{max-width:420px;margin-inline:auto;text-align:left}
.fband .calc-input{max-width:420px;display:block;margin-inline:auto}
.fband .calc-helper{max-width:420px;margin-inline:auto;text-align:center}
.fband .calc-buttons{max-width:420px;margin-inline:auto}
.fband .calc-step-label{text-align:center;font-size:1.08rem}
.fband .calc-success{max-width:520px;margin-inline:auto;background:#fff;border-radius:14px;padding:1.6rem 1.4rem;box-shadow:0 12px 30px -18px rgba(0,0,0,.25);margin-bottom:.6rem}

/* Article layout with sticky sidebar */
.article-wrap{display:grid;grid-template-columns:1fr;gap:2.2rem;padding-block:clamp(2rem,4vw,3.2rem);align-items:start}
@media(min-width:960px){.article-wrap{grid-template-columns:320px 1fr;gap:3rem}}
.side-col{order:2}
@media(min-width:960px){.side-col{order:0;position:sticky;top:88px}}
.side-card{background:var(--green-deep);color:#fff;border-radius:16px;padding:1.6rem 1.5rem}
.side-card h3{color:#fff;font-size:1.25rem;font-weight:800;line-height:1.25;margin:0 0 1.1rem;font-family:var(--disp)}
.side-row{display:flex;background:#fff;border-radius:12px;padding:.35rem;gap:.35rem}
.side-row input{flex:1;min-width:0;border:0;outline:none;font-family:var(--body);font-size:.95rem;padding:.55rem .7rem;border-radius:9px;color:var(--ink)}
.side-row .btn-yellow{padding:.65rem 1.1rem;font-size:.92rem;white-space:nowrap}
.side-count{display:flex;align-items:flex-start;gap:.5rem;font-size:.88rem;color:rgba(255,255,255,.92);margin-top:1rem;line-height:1.4}
.side-count svg{width:15px;height:15px;flex-shrink:0;margin-top:2px;color:var(--yellow)}
.side-count strong{color:var(--yellow)}
.side-note{font-size:.78rem;color:rgba(255,255,255,.65);margin:.9rem 0 0}

/* Article typography (Aroundhome bold sans) */
.art h1{font-family:var(--disp);font-weight:800;font-size:clamp(1.7rem,1.3rem+2vw,2.6rem);line-height:1.15;letter-spacing:-0.02em;margin:0 0 1rem}
.art .byline{margin:0 0 1.2rem}
.art .lead{font-size:1.05rem;color:var(--ink-soft);line-height:1.65;margin:0 0 .6rem;max-width:70ch}
.art h2{font-family:var(--disp);font-weight:800;font-size:clamp(1.3rem,1.1rem+1vw,1.8rem);letter-spacing:-0.02em;margin:3rem 0 1rem}
.art p{color:var(--ink-soft);line-height:1.65;max-width:70ch}
.art .svc-pros-grid{margin-top:1.4rem}
.art .cost-table,.art .prime-list{margin-top:1.2rem}
.art .steps{margin-top:1.4rem}
.art .faq{margin:1rem 0 0;max-width:none}
.art .ba-grid{margin-top:1.4rem}
@media(min-width:1024px){.art .ba-grid{grid-template-columns:repeat(2,1fr)}}
/* mid-article CTA card */
.mid-cta{display:grid;grid-template-columns:1fr;gap:1rem;align-items:center;background:var(--mint);border:1px solid var(--mint-2);border-radius:16px;padding:1.4rem 1.5rem;margin:2.4rem 0}
@media(min-width:720px){.mid-cta{grid-template-columns:1fr auto}}
.mid-cta h3{font-family:var(--disp);font-weight:800;font-size:1.15rem;margin:0 0 .25rem}
.mid-cta p{margin:0;font-size:.92rem;color:var(--ink-soft);max-width:none}
.mid-cta .btn-green{justify-self:start}
@media(min-width:720px){.mid-cta .btn-green{justify-self:end}}
@media(max-width:480px){.hdr{outline:6px solid red}}
.band-back-row{text-align:center;margin-top:1rem}
.band-back-row .calc-back{font-size:.88rem}

/* ==========================================================================
   FULL-SCREEN FUNNEL (funnel.html) — Perspective-style, one question per view
   ========================================================================== */
body.fpage{background:var(--grey);min-height:100vh;display:flex;flex-direction:column}
.fpage-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem clamp(1rem,3vw,2rem);background:#fff;border-bottom:1px solid var(--line)}
.fp-close{display:inline-flex;align-items:center;gap:.3rem;color:var(--ink-soft);font-size:.88rem;font-weight:500}
.fp-close:hover{color:var(--ink)}
.fp-tag{font-size:.78rem;font-weight:600;color:var(--green-deep);background:var(--mint);border:1px solid var(--mint-2);border-radius:9999px;padding:.35rem .8rem;white-space:nowrap}
@media(max-width:520px){.fp-tag{display:none}.fpage-bar .brand-txt .nm{font-size:1rem}}
.fpage-progress{grid-template-columns:repeat(4,1fr);gap:4px;margin:0}
.fpage-progress .calc-progress-seg{height:6px;border-radius:0;background:#dfe3da}
.fpage-progress .calc-progress-seg.active{background:var(--yellow-deep)}
.fpage-main{flex:1;width:100%;max-width:820px;margin-inline:auto;padding:clamp(1.6rem,4vw,3rem) clamp(1rem,3vw,2rem) 3rem}
.fp-service{text-align:center;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin:0 0 1.2rem}
.fpage-main .q-pill{background:transparent;box-shadow:none;padding:0;margin-bottom:1.6rem;font-size:clamp(1.25rem,1.1rem+1vw,1.7rem);font-weight:800;letter-spacing:-0.02em;display:block;text-align:center}
.fpage-main .band-tiles{grid-template-columns:repeat(2,1fr);gap:.8rem;max-width:640px}
@media(min-width:720px){.fpage-main .band-tiles{grid-template-columns:repeat(2,1fr)}}
.fpage-main .band-tiles .calc-chip{min-height:120px;background:#fff;box-shadow:0 10px 24px -18px rgba(0,0,0,.25)}
.fpage-main .calc-input,.fpage-main .calc-label,.fpage-main .calc-helper,.fpage-main .calc-buttons{max-width:440px;margin-inline:auto}
.fpage-main .calc-label{display:block;text-align:left}
.fpage-main .calc-input{display:block}
.fpage-main .calc-step-label{text-align:center;font-size:1.2rem;font-weight:800}
.fpage-main .calc-success{max-width:520px;margin-inline:auto;background:#fff;border-radius:16px;padding:1.8rem 1.6rem;box-shadow:0 18px 40px -22px rgba(0,0,0,.25)}
.fpage-foot{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1rem;padding:1rem;font-size:.8rem;color:var(--ink-faint);background:transparent}
