/* ============================================================================
   GutterBox — home.css · bespoke homepage + page-hero craft layer
   "Steel & Rain" — deep steel blue, rain blue, copper. Built on styles.css tokens.
   ========================================================================== */

:root{
  --maxw: 1180px;
  --steel-grad: linear-gradient(135deg,#0C4A6E 0%,#0E5D86 55%,#117199 100%);
  --copper-grad: linear-gradient(120deg,#C2772E,#E0A45C);
  --rain-grad: linear-gradient(180deg,#38BDF8,#0C4A6E);
  --glass: color-mix(in srgb,#FFFFFF 72%,transparent);
  --glass-line: color-mix(in srgb,#FFFFFF 90%,transparent);
  --section-pad: clamp(72px,9vw,128px);
}

/* ---------- shared section furniture ---------- */
.section{padding-block:var(--section-pad);position:relative}
.section--tint{background:linear-gradient(180deg,var(--muted),var(--background))}
.section--steel{background:var(--steel-grad);color:#EaF4FA}
.section--steel .kicker{color:var(--secondary)}
.section--steel h2,.section--steel h3{color:#fff}
.eyebrow-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.rule{flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent);min-width:40px}
.section-head{max-width:760px}
.section-head .lede{margin-top:14px;color:var(--ink-60)}
.section--steel .section-head .lede{color:#BBD4E2}
.balance{text-wrap:balance}

/* gradient display word + watermark wordmark (premium kit) */
.grad-word{background:var(--copper-grad);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.grad-word--rain{background:var(--rain-grad);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.watermark{position:absolute;left:50%;translate:-50% 0;font-family:var(--font-head);font-weight:700;letter-spacing:-.03em;line-height:.8;font-size:clamp(7rem,26vw,22rem);color:transparent;-webkit-text-stroke:1px color-mix(in srgb,var(--primary) 14%,transparent);text-stroke:1px color-mix(in srgb,var(--primary) 14%,transparent);pointer-events:none;user-select:none;z-index:0;white-space:nowrap}
.watermark--btm{bottom:-.18em}
.section--steel .watermark{-webkit-text-stroke-color:rgba(255,255,255,.10)}

/* ============================================================================
   HERO — rain WebGL + content
   ========================================================================== */
.hero{min-height:clamp(640px,94vh,1000px);padding-top:clamp(40px,8vh,90px)}
.hero__poster{background:
   radial-gradient(120% 90% at 78% 8%,color-mix(in srgb,var(--secondary) 26%,var(--background)),transparent 55%),
   radial-gradient(140% 120% at 12% 100%,color-mix(in srgb,var(--primary) 22%,var(--background)),transparent 60%),
   var(--background)}
#hero-gl{opacity:.92}
.hero__veil{position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 40%,color-mix(in srgb,var(--background) 78%,transparent))}
.hero__content{max-width:none;width:min(var(--maxw),92vw)}
.hero__grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(28px,5vw,72px);align-items:end}
@media (max-width:920px){.hero__grid{grid-template-columns:1fr;gap:38px}}
.hero .kicker{margin-bottom:22px}
.hero h1{font-size:clamp(2.7rem,7.4vw,5.6rem);line-height:.98;margin-bottom:.32em}
.hero .lede{max-width:46ch;font-size:clamp(1.08rem,1.6vw,1.32rem);color:var(--ink-60)}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:30px;align-items:center}
.hero__phone{display:inline-flex;flex-direction:column;font-size:.82rem;color:var(--ink-40);font-weight:600;letter-spacing:.04em}
.hero__phone b{font-family:var(--font-head);font-size:1.18rem;color:var(--foreground);letter-spacing:0}
.hero__aside{display:flex;flex-direction:column;gap:16px}
.hero__card{background:var(--glass);backdrop-filter:blur(14px);border:1px solid var(--glass-line);border-radius:var(--radius);padding:22px 24px;box-shadow:0 20px 50px -28px rgba(12,74,110,.5)}
.hero__card h4{font-family:var(--font-head);font-size:1.02rem;margin:0 0 10px;display:flex;align-items:center;gap:10px}
.hero__card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.hero__card li{display:flex;align-items:flex-start;gap:10px;font-size:.94rem;color:var(--ink-60)}
.hero__card li svg{flex:none;margin-top:2px;color:var(--accent)}
.hero__trust{display:flex;gap:26px;flex-wrap:wrap;margin-top:34px;padding-top:24px;border-top:1px solid var(--border)}
.hero__trust div{display:flex;flex-direction:column}
.hero__trust b{font-family:var(--font-head);font-size:1.5rem;line-height:1}
.hero__trust span{font-size:.8rem;color:var(--ink-40);letter-spacing:.04em;text-transform:uppercase;margin-top:4px}
.hero__scroll{position:absolute;left:50%;bottom:22px;translate:-50% 0;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-40);z-index:2}
.hero__scroll i{width:1px;height:34px;background:linear-gradient(var(--accent),transparent);animation:scrolldrop 2.2s var(--ease-premium) infinite}
@keyframes scrolldrop{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}41%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media (prefers-reduced-motion:reduce){.hero__scroll i{animation:none}}

/* ============================================================================
   MARQUEE — editorial trust strip (premium kit)
   ========================================================================== */
.marquee{overflow:hidden;border-block:1px solid var(--border);background:var(--surface);padding-block:18px;position:relative}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--surface),transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,var(--surface),transparent)}
.marquee__track{display:flex;gap:54px;width:max-content;animation:marquee 32s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__item{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:600;font-size:1.02rem;color:var(--ink-60);white-space:nowrap}
.marquee__item svg{color:var(--accent);flex:none}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none;flex-wrap:wrap;justify-content:center}}

/* ============================================================================
   STATS band — animated counters
   ========================================================================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--surface);padding:34px 26px;position:relative}
.stat::after{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--copper-grad);opacity:0;transition:opacity .4s var(--ease-premium)}
.stat:hover::after{opacity:1}
.stat__num{font-family:var(--font-head);font-weight:700;font-size:clamp(2.2rem,4vw,3.2rem);line-height:1;display:flex;align-items:baseline;gap:4px}
.stat__num em{font-style:normal;color:var(--accent);font-size:.6em}
.stat__label{margin-top:10px;color:var(--ink-60);font-size:.95rem}

/* ============================================================================
   SERVICES — bespoke cards with SVG icons, hairline, tilt
   ========================================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px}
@media (max-width:920px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.svc-grid{grid-template-columns:1fr}}
.svc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:30px 28px 26px;position:relative;overflow:hidden;transition:transform .5s var(--ease-premium),box-shadow .5s var(--ease-premium),border-color .5s}
.svc::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 60%,transparent),transparent);opacity:0;transition:opacity .5s}
.svc::after{content:"";position:absolute;right:-40px;bottom:-40px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--secondary) 16%,transparent),transparent 70%);opacity:0;transition:opacity .6s var(--ease-premium)}
.svc:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(12,74,110,.45);border-color:color-mix(in srgb,var(--primary) 30%,var(--border))}
.svc:hover::before,.svc:hover::after{opacity:1}
.svc__ico{width:58px;height:58px;border-radius:14px;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--border);color:var(--primary);margin-bottom:20px;transition:background .5s,color .5s,transform .6s var(--ease-premium)}
.svc:hover .svc__ico{background:var(--steel-grad);color:#fff;transform:rotate(-6deg) scale(1.05)}
.svc h3{font-size:1.25rem;margin-bottom:8px}
.svc p{color:var(--ink-60);font-size:.96rem;margin-bottom:18px}
.svc__link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:600;font-size:.92rem;color:var(--primary)}
.svc__link svg{transition:transform .4s var(--ease-premium)}
.svc:hover .svc__link svg{transform:translateX(5px)}
.svc__tag{position:absolute;top:24px;right:24px;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:700}

/* ============================================================================
   ANATOMY — custom house cross-section SVG diagram (signature craft)
   ========================================================================== */
.anatomy{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,68px);align-items:center}
@media (max-width:920px){.anatomy{grid-template-columns:1fr}}
.anatomy__art{position:relative;border-radius:var(--radius);background:linear-gradient(180deg,#EAF4FB,#F5F7F8);border:1px solid var(--border);padding:18px;overflow:hidden}
.anatomy__art svg{width:100%;height:auto;display:block}
.anatomy__legend{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:16px}
.anatomy__legend li{display:flex;gap:14px;align-items:flex-start}
.anatomy__dot{flex:none;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;font-size:.85rem;color:#fff;background:var(--steel-grad)}
.anatomy__legend h4{font-family:var(--font-head);font-size:1.04rem;margin:0 0 3px}
.anatomy__legend p{margin:0;color:var(--ink-60);font-size:.92rem}
.flow-drop{animation:flowdrop 3s linear infinite}
@keyframes flowdrop{0%{transform:translateY(-6px);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(46px);opacity:0}}
@media (prefers-reduced-motion:reduce){.flow-drop{animation:none}}

/* ============================================================================
   PROCESS — numbered steps + connecting line (pinned-aware)
   ========================================================================== */
.process{position:relative;margin-top:50px}
.process__line{position:absolute;left:0;right:0;top:46px;height:2px;background:var(--border);overflow:hidden}
.process__line i{position:absolute;inset:0;background:var(--copper-grad);transform-origin:left;transform:scaleX(var(--p,0));transition:transform .2s linear}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
@media (max-width:860px){.steps{grid-template-columns:repeat(2,1fr);row-gap:40px}.process__line{display:none}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}
.step{position:relative}
.step__n{width:92px;height:92px;border-radius:50%;background:var(--surface);border:2px solid var(--border);display:grid;place-items:center;position:relative;z-index:1;margin-bottom:22px;transition:border-color .5s,transform .5s var(--ease-premium)}
.step:hover .step__n{border-color:var(--accent);transform:translateY(-4px)}
.step__n b{font-family:var(--font-head);font-size:1.5rem;color:var(--primary)}
.step__n svg{position:absolute;color:var(--accent)}
.step h3{font-size:1.18rem;margin-bottom:6px}
.step p{color:var(--ink-60);font-size:.94rem}

/* ============================================================================
   SIGNATURE — Gutter Health Matcher
   ========================================================================== */
.matcher{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;border:1px solid var(--border);border-radius:calc(var(--radius) + 6px);overflow:hidden;background:var(--surface);box-shadow:0 40px 90px -50px rgba(12,74,110,.55)}
@media (max-width:860px){.matcher{grid-template-columns:1fr}}
.matcher__panel{background:var(--steel-grad);color:#EAF4FA;padding:clamp(28px,4vw,46px);position:relative;overflow:hidden}
.matcher__panel .watermark{font-size:clamp(6rem,18vw,12rem)}
.matcher__panel h3{color:#fff;font-size:clamp(1.5rem,2.4vw,2rem);position:relative}
.matcher__panel p{color:#BBD4E2;position:relative}
.matcher__qs{display:flex;flex-direction:column;gap:10px;margin-top:26px;position:relative;z-index:1}
.q-opt{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);color:#EAF4FA;padding:15px 18px;border-radius:14px;cursor:pointer;font-family:var(--font-body);font-size:.98rem;transition:background .4s var(--ease-premium),border-color .4s,transform .4s var(--ease-premium)}
.q-opt:hover{background:rgba(255,255,255,.12);transform:translateX(4px)}
.q-opt.is-active{background:#fff;color:var(--primary);border-color:#fff;font-weight:600}
.q-opt .q-ico{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:rgba(255,255,255,.12);color:#fff;transition:background .4s,color .4s}
.q-opt.is-active .q-ico{background:var(--copper-grad);color:#fff}
.matcher__result{padding:clamp(28px,4vw,46px);display:flex;flex-direction:column;justify-content:center;min-height:340px}
.matcher__result .kicker{margin-bottom:14px}
.mr-card{opacity:0;transform:translateY(14px);transition:opacity .55s var(--ease-premium),transform .55s var(--ease-premium)}
.mr-card.is-in{opacity:1;transform:none}
.mr-card h4{font-family:var(--font-head);font-size:clamp(1.4rem,2.4vw,1.9rem);margin:0 0 10px}
.mr-card p{color:var(--ink-60)}
.mr-meta{display:flex;gap:22px;flex-wrap:wrap;margin:20px 0 26px}
.mr-meta div{display:flex;flex-direction:column;gap:2px}
.mr-meta b{font-family:var(--font-head);font-size:1.05rem;color:var(--foreground)}
.mr-meta span{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-40)}

/* ============================================================================
   SEAMLESS / why-us split with glass feature list
   ========================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
@media (max-width:860px){.split{grid-template-columns:1fr}}
.feat-list{display:grid;gap:18px;margin-top:30px}
.feat{display:flex;gap:16px;align-items:flex-start;padding:18px 20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:transform .5s var(--ease-premium),border-color .5s}
.feat:hover{transform:translateX(6px);border-color:color-mix(in srgb,var(--primary) 28%,var(--border))}
.feat__ico{flex:none;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--surface-2);color:var(--primary)}
.feat h4{font-family:var(--font-head);font-size:1.06rem;margin:0 0 4px}
.feat p{margin:0;color:var(--ink-60);font-size:.93rem}
.split__visual{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);aspect-ratio:4/5;background:var(--surface-2)}
.split__visual img{width:100%;height:100%;object-fit:cover}
.split__badge{position:absolute;left:20px;bottom:20px;background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--glass-line);border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow)}
.split__badge b{font-family:var(--font-head);font-size:1.4rem;line-height:1}
.split__badge span{font-size:.78rem;color:var(--ink-60)}

/* device / browser mockup (premium kit) */
.mockup{border-radius:14px;overflow:hidden;border:1px solid var(--border);background:var(--surface);box-shadow:0 30px 70px -40px rgba(12,74,110,.5)}
.mockup__bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:var(--surface-2);border-bottom:1px solid var(--border)}
.mockup__bar i{width:11px;height:11px;border-radius:50%;background:var(--border)}
.mockup__bar i:nth-child(1){background:#e0726a}.mockup__bar i:nth-child(2){background:#e6b357}.mockup__bar i:nth-child(3){background:#5fb98a}
.mockup__bar span{margin-left:10px;font-size:.74rem;color:var(--ink-40)}
.mockup__body{padding:24px}

/* ============================================================================
   SERVICE AREAS — map SVG + chips
   ========================================================================== */
.areas{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
@media (max-width:860px){.areas{grid-template-columns:1fr}}
.areas__map{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.04);padding:20px}
.areas__map svg{width:100%;height:auto}
.area-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.chip{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:var(--radius-pill);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);font-size:.9rem;font-weight:500;color:#EAF4FA;transition:background .4s var(--ease-premium),transform .4s}
.chip:hover{background:rgba(255,255,255,.15);transform:translateY(-2px)}
.chip svg{color:var(--secondary);flex:none}
.chip[data-ph]{outline-offset:3px}

/* ============================================================================
   TESTIMONIALS (placeholders — no real reviews yet)
   ========================================================================== */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
@media (max-width:860px){.quotes{grid-template-columns:1fr}}
.quote{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:30px 28px;position:relative}
.quote__mark{font-family:var(--font-head);font-size:4rem;line-height:.7;color:color-mix(in srgb,var(--accent) 40%,transparent);height:30px}
.quote p{color:var(--foreground);font-size:1rem}
.quote__who{display:flex;align-items:center;gap:12px;margin-top:18px}
.quote__av{width:42px;height:42px;border-radius:50%;background:var(--steel-grad);display:grid;place-items:center;color:#fff;font-family:var(--font-head);font-weight:700}
.quote__who b{font-family:var(--font-head);font-size:.96rem;display:block}
.quote__who span{font-size:.82rem;color:var(--ink-40)}
.quote__stars{display:flex;gap:2px;color:var(--accent);margin-top:12px}

/* ============================================================================
   FAQ
   ========================================================================== */
.faq{max-width:820px;margin-inline:auto}
.faq details{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);margin-bottom:14px;overflow:hidden;transition:border-color .4s,box-shadow .4s}
.faq details[open]{border-color:color-mix(in srgb,var(--primary) 30%,var(--border));box-shadow:0 20px 50px -36px rgba(12,74,110,.5)}
.faq summary{list-style:none;cursor:pointer;padding:22px 56px 22px 24px;font-family:var(--font-head);font-weight:600;font-size:1.08rem;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";position:absolute;right:24px;top:50%;width:13px;height:13px;border-right:2px solid var(--primary);border-bottom:2px solid var(--primary);translate:0 -65%;rotate:45deg;transition:rotate .4s var(--ease-premium)}
.faq details[open] summary::after{rotate:225deg}
.faq details p{padding:0 24px 24px;margin:0;color:var(--ink-60)}

/* ============================================================================
   CTA band + Contact
   ========================================================================== */
.cta-band{position:relative;overflow:hidden;border-radius:calc(var(--radius) + 8px);background:var(--steel-grad);color:#fff;padding:clamp(40px,6vw,76px);text-align:center}
.cta-band h2{color:#fff;font-size:clamp(2rem,4vw,3.2rem);max-width:18ch;margin-inline:auto}
.cta-band p{color:#BBD4E2;max-width:52ch;margin:14px auto 30px}
.cta-band .btn--primary{background:#fff;color:var(--primary)}
.cta-band .btn--ghost{color:#fff;border-color:rgba(255,255,255,.4)}
.cta-band .btn--ghost:hover{border-color:#fff;color:#fff}
.cta-band .watermark{-webkit-text-stroke-color:rgba(255,255,255,.12)}

.contact{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,64px);align-items:start}
@media (max-width:860px){.contact{grid-template-columns:1fr}}
.contact__info{display:grid;gap:18px}
.cinfo{display:flex;gap:14px;align-items:flex-start}
.cinfo__ico{flex:none;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--surface-2);color:var(--primary);border:1px solid var(--border)}
.cinfo h4{font-family:var(--font-head);font-size:1rem;margin:0 0 2px}
.cinfo p{margin:0;color:var(--ink-60);font-size:.95rem}
.contact__form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:clamp(24px,3vw,38px);box-shadow:0 30px 70px -44px rgba(12,74,110,.45)}
.contact__form .field input,.contact__form .field textarea,.contact__form .field select{width:100%}
.field select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--foreground);font:inherit}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:520px){.form-row{grid-template-columns:1fr}}

/* ============================================================================
   FOOTER (rich)
   ========================================================================== */
.site-footer{background:var(--foreground);color:#C4D2DC;border-top:0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;width:100%}
@media (max-width:860px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-brand .brand{color:#fff;font-size:1.4rem}
.foot-brand p{margin-top:14px;color:#8FA6B4;font-size:.92rem;max-width:34ch}
.foot-col h5{font-family:var(--font-head);font-size:.84rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin:0 0 16px}
.foot-col a{display:block;color:#A9BDC9;font-size:.93rem;margin-bottom:10px}
.foot-col a:hover{color:#fff}
.foot-bottom{width:100%;border-top:1px solid rgba(255,255,255,.1);margin-top:46px;padding-top:24px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.84rem;color:#7F95A4}
.site-footer .container{flex-direction:column;align-items:flex-start}

/* ============================================================================
   PAGE HERO (inner pages) + service page furniture
   ========================================================================== */
.page-hero{position:relative;padding-block:clamp(120px,16vh,180px) clamp(50px,7vw,84px);overflow:hidden;background:
   radial-gradient(120% 120% at 85% 0%,color-mix(in srgb,var(--secondary) 20%,var(--background)),transparent 55%),
   var(--muted);border-bottom:1px solid var(--border)}
.page-hero .watermark{font-size:clamp(6rem,20vw,16rem);opacity:.7}
.page-hero__inner{position:relative;z-index:1;max-width:760px}
.breadcrumbs{display:flex;gap:8px;align-items:center;font-size:.84rem;color:var(--ink-40);margin-bottom:18px}
.breadcrumbs a{color:var(--ink-60)}.breadcrumbs a:hover{color:var(--primary)}
.page-hero h1{font-size:clamp(2.3rem,5.5vw,3.8rem)}
.page-hero .lede{margin-top:14px;color:var(--ink-60);max-width:56ch}

.quick-answer{border-left:4px solid var(--accent);background:var(--surface);border-radius:0 var(--radius) var(--radius) 0;padding:24px 28px;margin:0 0 34px;box-shadow:0 20px 50px -40px rgba(12,74,110,.4)}
.quick-answer .kicker{margin-bottom:10px}
.quick-answer p{margin:0;font-size:1.06rem}
.facts-table{width:100%;border-collapse:collapse;margin:26px 0;font-size:.96rem}
.facts-table th,.facts-table td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--border)}
.facts-table th{font-family:var(--font-head);width:38%;color:var(--foreground);font-weight:600}
.facts-table td{color:var(--ink-60)}
.facts-table tr:hover td,.facts-table tr:hover th{background:var(--surface-2)}
.prose{max-width:760px}
.prose h2{margin-top:1.6em}
.prose ul{padding-left:0;list-style:none;display:grid;gap:12px;margin:1.2em 0}
.prose ul li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-60)}
.prose ul li svg{flex:none;margin-top:3px;color:var(--accent)}
.toc{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;margin-bottom:30px}
.toc h4{font-family:var(--font-head);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 12px;color:var(--ink-60)}
.toc a{display:block;padding:5px 0;font-size:.95rem}
.page-grid{display:grid;grid-template-columns:1fr 300px;gap:clamp(30px,5vw,60px);align-items:start}
@media (max-width:920px){.page-grid{grid-template-columns:1fr}}
.aside-card{position:sticky;top:100px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:0 24px 60px -44px rgba(12,74,110,.5)}
.aside-card h4{font-family:var(--font-head);margin:0 0 8px}
.aside-card p{color:var(--ink-60);font-size:.93rem}
.related{display:grid;gap:10px;margin-top:18px}
.related a{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border:1px solid var(--border);border-radius:12px;font-family:var(--font-head);font-weight:600;font-size:.92rem;transition:border-color .4s,transform .4s var(--ease-premium)}
.related a:hover{border-color:var(--primary);transform:translateX(4px)}

/* utility */
.center{text-align:center;margin-inline:auto}
.mt-l{margin-top:40px}
.divider-wave{display:block;width:100%;height:auto;color:var(--background)}
[hidden]{display:none!important}
