/* ============================================================
   911 Roofer — home.css  ·  bespoke section craft on top of styles.css tokens
   "Storm Watch" — midnight steel + ember/amber signal. Emergency roofing.
   ============================================================ */

/* ---- shared editorial primitives ---- */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-size:.74rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--accent)}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,var(--primary),transparent)}
.section-head{max-width:760px;margin:0 auto 56px;text-align:center}
.section-head.left{margin-inline:0;text-align:left}
.section-head h2{margin-top:18px}
.section-head p{font-size:clamp(1.02rem,1.4vw,1.18rem);opacity:.78}
.display{font-family:var(--font-head);font-weight:800;letter-spacing:-.03em;line-height:.98}
.text-grad{background:linear-gradient(100deg,var(--primary),var(--accent) 70%);-webkit-background-clip:text;background-clip:text;color:transparent}
.watermark{position:absolute;font-family:var(--font-head);font-weight:800;letter-spacing:-.04em;line-height:.8;color:transparent;-webkit-text-stroke:1px color-mix(in srgb,var(--foreground) 7%,transparent);font-size:clamp(7rem,22vw,20rem);user-select:none;pointer-events:none;z-index:0;white-space:nowrap}
.rule-stat{display:flex;align-items:baseline;gap:14px}
.rule-stat b{font-family:var(--font-head);font-weight:800;font-size:clamp(2rem,4vw,3rem);color:var(--foreground);line-height:1}
.hairline{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);border:0;margin:0}

/* ============================================================
   HEADER additions — call button + 24/7 badge
   ============================================================ */
.brand{display:inline-flex;align-items:center;gap:11px;letter-spacing:-.01em}
.brand__mark{width:34px;height:34px;flex:none}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__txt small{font-family:var(--font-body);font-weight:600;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);opacity:.9;margin-top:3px}
.nav-desktop{gap:26px}
.header-cta{display:flex;align-items:center;gap:18px}
.badge-247{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:700;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--foreground);padding:7px 13px;border:1px solid var(--border);border-radius:var(--radius-pill);background:color-mix(in srgb,var(--surface) 60%,transparent)}
.badge-247 .pulse{width:9px;height:9px;border-radius:50%;background:#2ec27a;box-shadow:0 0 0 0 rgba(46,194,122,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(46,194,122,.55)}70%{box-shadow:0 0 0 9px rgba(46,194,122,0)}100%{box-shadow:0 0 0 0 rgba(46,194,122,0)}}
@media (prefers-reduced-motion:reduce){.badge-247 .pulse{animation:none}}
.btn--call{background:var(--primary);color:#fff;padding:11px 20px;font-size:.92rem}
.btn--call svg{width:16px;height:16px}
.btn--call:hover{transform:translateY(-2px);box-shadow:0 10px 30px -8px var(--primary)}
@media (max-width:1080px){.badge-247{display:none}}
@media (max-width:880px){.header-cta .btn--call span{display:none}.header-cta .btn--call{padding:11px 13px}}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100svh;padding-top:64px}
.hero__poster{background:#0d0f12 center/cover no-repeat}
.hero__poster::after{content:"";position:absolute;inset:0;background:
   linear-gradient(180deg,rgba(13,15,18,.55) 0%,rgba(13,15,18,.35) 40%,rgba(13,15,18,.86) 100%),
   radial-gradient(120% 90% at 78% 8%,color-mix(in srgb,var(--primary) 26%,transparent),transparent 55%)}
#hero-gl{opacity:.5;mix-blend-mode:screen}
.hero__content{max-width:none;display:grid;grid-template-columns:minmax(0,1.32fr) minmax(0,.85fr);gap:48px;align-items:end;width:100%}
.hero__lead{max-width:680px}
.hero .kicker,.hero__kick{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-head);font-weight:700;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:22px}
.hero__kick .dot{width:10px;height:10px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 0 color-mix(in srgb,var(--primary) 70%,transparent);animation:pulse-red 1.8s infinite}
@keyframes pulse-red{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--primary) 60%,transparent)}70%{box-shadow:0 0 0 11px transparent}100%{box-shadow:0 0 0 0 transparent}}
@media (prefers-reduced-motion:reduce){.hero__kick .dot{animation:none}}
.hero h1{font-size:clamp(2.6rem,6.4vw,5.2rem);font-weight:800;letter-spacing:-.035em;line-height:.98;margin-bottom:22px}
.hero h1 em{font-style:normal;color:transparent;background:linear-gradient(100deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text}
.hero .lede{font-size:clamp(1.08rem,1.7vw,1.32rem);max-width:54ch;opacity:.92}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero__cta .btn{padding:16px 30px;font-size:1.02rem}
.btn--xl{background:var(--primary);color:#fff}
.btn--xl .ph{font-size:1.12rem;letter-spacing:.01em}
.hero__trust{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}
.tchip{display:flex;align-items:center;gap:10px;padding:10px 15px;border:1px solid var(--border);border-radius:var(--radius-pill);background:color-mix(in srgb,var(--surface) 55%,transparent);backdrop-filter:blur(6px);font-size:.86rem}
.tchip svg{width:18px;height:18px;color:var(--accent);flex:none}
.tchip b{font-family:var(--font-head)}
/* hero side — emergency card */
.hero__card{align-self:end;background:color-mix(in srgb,var(--surface) 78%,transparent);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.hero__card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent))}
.hero__card h3{font-size:1.15rem;margin-bottom:6px}
.hero__card .ph-phone{display:block;font-family:var(--font-head);font-weight:800;font-size:clamp(1.6rem,2.6vw,2.1rem);color:var(--foreground);letter-spacing:-.02em;margin:8px 0 4px}
.hero__card .sub{font-size:.85rem;opacity:.7;margin-bottom:18px}
.hero__card ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.hero__card li{display:flex;gap:11px;font-size:.92rem;align-items:flex-start}
.hero__card li svg{width:18px;height:18px;color:#2ec27a;flex:none;margin-top:1px}
.scroll-cue{position:absolute;left:50%;bottom:22px;translate:-50% 0;display:flex;flex-direction:column;align-items:center;gap:7px;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;opacity:.5;z-index:3}
.scroll-cue span{width:1px;height:34px;background:linear-gradient(var(--accent),transparent);animation:cue 2s var(--ease-premium) infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}
@media (max-width:980px){.hero__content{grid-template-columns:1fr;gap:34px}.hero__card{max-width:460px}}

/* ============================================================
   ALERT STRIP
   ============================================================ */
.alert-strip{background:linear-gradient(90deg,var(--primary),#c5481f);color:#fff;position:relative;overflow:hidden}
.alert-strip .container{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;padding-block:18px;text-align:center}
.alert-strip svg{width:26px;height:26px;flex:none}
.alert-strip p{margin:0;font-family:var(--font-head);font-weight:700;font-size:clamp(1rem,2vw,1.32rem);letter-spacing:-.01em}
.alert-strip a{color:#fff;text-decoration:underline;text-underline-offset:3px}
.alert-strip .marquee-track{position:absolute;inset:0;opacity:.12;display:flex;align-items:center;font-family:var(--font-head);font-weight:800;font-size:3rem;white-space:nowrap;gap:40px;animation:marq 28s linear infinite}
@keyframes marq{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.alert-strip .marquee-track{animation:none}}

/* ============================================================
   SERVICES
   ============================================================ */
.services{position:relative;overflow:hidden}
.services .watermark{top:-2vw;right:-3vw}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;z-index:1}
.svc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:26px 24px 28px;position:relative;overflow:hidden;transition:transform .4s var(--ease-premium),border-color .4s,background .4s;display:flex;flex-direction:column;min-height:230px}
.svc::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 0%,color-mix(in srgb,var(--primary) 14%,transparent),transparent 60%);opacity:0;transition:opacity .4s}
.svc:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--primary) 45%,var(--border))}
.svc:hover::after{opacity:1}
.svc__ico{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;background:color-mix(in srgb,var(--primary) 14%,var(--muted));border:1px solid color-mix(in srgb,var(--primary) 30%,var(--border));margin-bottom:18px;position:relative;z-index:1}
.svc__ico svg{width:27px;height:27px;color:var(--accent)}
.svc h3{font-size:1.12rem;margin-bottom:8px;position:relative;z-index:1}
.svc p{font-size:.9rem;opacity:.74;margin:0;position:relative;z-index:1}
.svc__more{margin-top:auto;padding-top:14px;font-family:var(--font-head);font-weight:600;font-size:.82rem;color:var(--accent);display:inline-flex;align-items:center;gap:7px;position:relative;z-index:1}
.svc__more svg{width:14px;height:14px;transition:transform .3s}
.svc:hover .svc__more svg{transform:translateX(4px)}
.svc--wide{grid-column:span 2;flex-direction:row;align-items:center;gap:22px;background:linear-gradient(120deg,color-mix(in srgb,var(--primary) 18%,var(--surface)),var(--surface))}
.svc--wide .svc__ico{margin-bottom:0;width:60px;height:60px}
@media (max-width:1040px){.svc-grid{grid-template-columns:repeat(2,1fr)}.svc--wide{grid-column:span 2}}
@media (max-width:560px){.svc-grid{grid-template-columns:1fr}.svc--wide{flex-direction:column;align-items:flex-start}}

/* ============================================================
   SIGNATURE — metric console + before/after
   ============================================================ */
.signature{background:linear-gradient(180deg,var(--background),var(--muted));position:relative;overflow:hidden}
.sig-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:center}
.metric-console{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.metric{background:var(--surface);padding:30px 26px;position:relative}
.metric::before{content:"";position:absolute;top:0;left:0;width:38px;height:2px;background:var(--primary)}
.metric .num{font-family:var(--font-head);font-weight:800;font-size:clamp(2.4rem,4.6vw,3.7rem);line-height:.9;letter-spacing:-.03em;color:var(--foreground)}
.metric .num .suf{color:var(--primary)}
.metric .lbl{margin-top:10px;font-size:.84rem;letter-spacing:.04em;opacity:.72}
.metric .ico{position:absolute;top:24px;right:22px;width:22px;height:22px;color:var(--accent);opacity:.5}
/* before/after */
.ba{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);aspect-ratio:4/3;user-select:none;box-shadow:var(--shadow);touch-action:pan-y}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba__after{clip-path:inset(0 0 0 var(--split,50%))}
.ba__before-tag,.ba__after-tag{position:absolute;top:14px;font-family:var(--font-head);font-weight:700;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:5px 11px;border-radius:var(--radius-pill);background:rgba(13,15,18,.7);backdrop-filter:blur(4px);z-index:3}
.ba__before-tag{left:14px;color:var(--primary)}
.ba__after-tag{right:14px;color:#2ec27a}
.ba__handle{position:absolute;top:0;bottom:0;left:var(--split,50%);width:2px;background:var(--accent);z-index:4;cursor:ew-resize}
.ba__handle::before{content:"";position:absolute;top:50%;left:50%;translate:-50% -50%;width:46px;height:46px;border-radius:50%;background:var(--accent);box-shadow:0 6px 20px rgba(0,0,0,.5)}
.ba__handle svg{position:absolute;top:50%;left:50%;translate:-50% -50%;width:24px;height:24px;color:#15171A;z-index:1}
.ba__range{position:absolute;inset:0;width:100%;opacity:0;cursor:ew-resize;z-index:5;margin:0}
@media (max-width:920px){.sig-grid{grid-template-columns:1fr;gap:38px}}

/* ============================================================
   WHY US
   ============================================================ */
.why{position:relative;overflow:hidden}
.why-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center}
.why__media{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:5/4;border:1px solid var(--border)}
.why__media img{width:100%;height:100%;object-fit:cover}
.why__media .badge{position:absolute;left:20px;bottom:20px;background:color-mix(in srgb,var(--surface) 88%,transparent);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px;display:flex;align-items:center;gap:14px}
.why__media .badge .n{font-family:var(--font-head);font-weight:800;font-size:2.1rem;line-height:1;color:var(--primary)}
.why__media .badge small{font-size:.74rem;letter-spacing:.05em;opacity:.78;display:block;max-width:13ch}
.why-list{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:20px}
.why-list li{display:grid;grid-template-columns:46px 1fr;gap:16px;align-items:start}
.why-list .wi{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--primary) 13%,var(--muted));border:1px solid color-mix(in srgb,var(--primary) 28%,var(--border))}
.why-list .wi svg{width:23px;height:23px;color:var(--accent)}
.why-list h4{font-family:var(--font-head);font-size:1.05rem;margin:2px 0 5px}
.why-list p{margin:0;font-size:.92rem;opacity:.76}
@media (max-width:920px){.why-grid{grid-template-columns:1fr;gap:40px}}

/* ============================================================
   PROCESS
   ============================================================ */
.process{background:var(--muted);position:relative;overflow:hidden}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.proc{position:relative;padding:30px 24px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden}
.proc__n{font-family:var(--font-head);font-weight:800;font-size:3.2rem;line-height:1;color:transparent;-webkit-text-stroke:1.4px color-mix(in srgb,var(--primary) 55%,transparent);margin-bottom:14px}
.proc__ico{width:44px;height:44px;color:var(--accent);margin-bottom:14px}
.proc__ico svg{width:44px;height:44px}
.proc h4{font-size:1.08rem;margin-bottom:8px}
.proc p{font-size:.9rem;opacity:.75;margin:0}
.proc__line{display:none}
@media (min-width:861px){.proc:not(:last-child)::after{content:"";position:absolute;top:48px;right:-13px;width:26px;height:2px;background:linear-gradient(90deg,var(--primary),transparent);z-index:2}}
@media (max-width:860px){.proc-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.proc-grid{grid-template-columns:1fr}}

/* ============================================================
   AREAS
   ============================================================ */
.areas{position:relative;overflow:hidden}
.areas-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:54px;align-items:center}
.areas__map{position:relative}
.areas__map svg{width:100%;height:auto;filter:drop-shadow(0 20px 40px rgba(0,0,0,.4))}
.town-cloud{display:flex;flex-wrap:wrap;gap:11px;margin-top:24px}
.town{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface);font-size:.9rem;transition:border-color .3s,transform .3s,color .3s}
.town svg{width:14px;height:14px;color:var(--primary)}
.town:hover{border-color:var(--primary);transform:translateY(-2px);color:var(--foreground)}
.town--home{background:linear-gradient(120deg,color-mix(in srgb,var(--primary) 22%,var(--surface)),var(--surface));border-color:color-mix(in srgb,var(--primary) 45%,var(--border));font-weight:600}
@media (max-width:920px){.areas-grid{grid-template-columns:1fr;gap:34px}}

/* ============================================================
   FAQ
   ============================================================ */
.faq{position:relative}
.faq-wrap{max-width:840px;margin-inline:auto;display:grid;gap:12px}
.faq details{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .3s}
.faq details[open]{border-color:color-mix(in srgb,var(--primary) 40%,var(--border))}
.faq summary{cursor:pointer;list-style:none;padding:20px 24px;font-family:var(--font-head);font-weight:600;font-size:1.04rem;display:flex;align-items:center;justify-content:space-between;gap:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{width:24px;height:24px;flex:none;position:relative;transition:transform .3s}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;top:50%;left:50%;translate:-50% -50%;background:var(--accent)}
.faq summary .pm::before{width:14px;height:2px}.faq summary .pm::after{width:2px;height:14px;transition:transform .3s}
.faq details[open] summary .pm::after{transform:translate(-50%,-50%) scaleY(0)}
.faq details p{padding:0 24px 22px;margin:0;opacity:.82;font-size:.96rem;max-width:70ch}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:linear-gradient(180deg,var(--muted),var(--background));position:relative;overflow:hidden}
.contact .watermark{bottom:-4vw;left:-2vw}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:start;position:relative;z-index:1}
.contact__info h2{margin-bottom:18px}
.contact__rows{display:grid;gap:18px;margin-top:28px}
.crow{display:grid;grid-template-columns:48px 1fr;gap:16px;align-items:start}
.crow .ci{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--primary) 13%,var(--muted));border:1px solid color-mix(in srgb,var(--primary) 28%,var(--border))}
.crow .ci svg{width:23px;height:23px;color:var(--accent)}
.crow b{font-family:var(--font-head);font-size:1.02rem}
.crow a{color:var(--foreground)}.crow a:hover{color:var(--primary)}
.crow small{display:block;opacity:.66;font-size:.84rem;margin-top:2px}
.contact__form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;position:relative;overflow:hidden}
.contact__form::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent))}
.contact__form h3{font-size:1.3rem;margin-bottom:6px}
.contact__form .muted{opacity:.7;font-size:.9rem;margin-bottom:22px}
.contact__form .grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact__form select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--foreground);font:inherit;width:100%}
.contact__form .btn{width:100%;justify-content:center;margin-top:6px}
@media (max-width:920px){.contact-grid{grid-template-columns:1fr;gap:38px}.contact__form .grid2{grid-template-columns:1fr}}

/* ============================================================
   FOOTER additions
   ============================================================ */
.site-footer{background:var(--background)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;width:100%}
.foot-grid h5{font-family:var(--font-head);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin:0 0 16px}
.foot-grid ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.foot-grid a{opacity:.74;font-size:.92rem}.foot-grid a:hover{opacity:1;color:var(--primary)}
.foot-brand p{opacity:.7;font-size:.9rem;max-width:34ch;margin:16px 0 0}
.foot-call{display:inline-flex;align-items:center;gap:10px;margin-top:18px;font-family:var(--font-head);font-weight:800;font-size:1.3rem;color:var(--foreground)}
.foot-call svg{width:20px;height:20px;color:var(--primary)}
.foot-bottom{border-top:1px solid var(--border);margin-top:8px;padding-top:26px;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;font-size:.82rem;opacity:.6;width:100%}
@media (max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.foot-grid{grid-template-columns:1fr}}

/* keep button labels on one line + constrain icon size (shared SVG has no width attr) */
.btn{white-space:nowrap}
.btn svg{width:18px;height:18px;flex:none}

/* reveal helpers */
[data-reveal],[data-reveal-group]>*{will-change:transform,opacity}

/* generic inner page hero (used by generate.mjs pages) */
.page-hero{position:relative;padding:clamp(120px,16vh,180px) 0 clamp(48px,7vw,80px);overflow:hidden;border-bottom:1px solid var(--border)}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(110% 120% at 80% 0%,color-mix(in srgb,var(--primary) 20%,var(--background)),var(--background) 58%);z-index:-1}
.page-hero .watermark{top:10%;right:-2vw}
.breadcrumbs{font-size:.82rem;opacity:.6;margin-bottom:18px;display:flex;gap:8px;flex-wrap:wrap}
.breadcrumbs a{color:var(--accent)}
.quick-answer{background:var(--surface);border:1px solid color-mix(in srgb,var(--primary) 32%,var(--border));border-left:3px solid var(--primary);border-radius:var(--radius-sm);padding:22px 26px;margin:0 0 32px;max-width:780px}
.quick-answer .qa-tag{font-family:var(--font-head);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:8px}
.quick-answer p{margin:0;font-size:1.06rem;line-height:1.6}
.kv-table{width:100%;border-collapse:collapse;margin:8px 0 30px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.kv-table th,.kv-table td{text-align:left;padding:13px 18px;border-bottom:1px solid var(--border);font-size:.94rem}
.kv-table th{background:var(--muted);font-family:var(--font-head);font-weight:600;width:38%;color:var(--foreground)}
.kv-table tr:last-child th,.kv-table tr:last-child td{border-bottom:0}
.prose{max-width:760px}
.prose h2{margin-top:48px}.prose h3{margin-top:32px}
.prose ul{padding-left:0;list-style:none;display:grid;gap:12px;margin:20px 0}
.prose ul li{display:grid;grid-template-columns:24px 1fr;gap:12px;align-items:start}
.prose ul li svg{width:22px;height:22px;color:var(--accent);margin-top:2px}
.cta-band{background:linear-gradient(120deg,color-mix(in srgb,var(--primary) 20%,var(--surface)),var(--surface));border:1px solid var(--border);border-radius:var(--radius);padding:clamp(32px,5vw,56px);text-align:center;margin:56px auto 0;max-width:900px}
.cta-band h2{margin-bottom:12px}
.cta-band .btn{margin-top:18px}
.svc-mini{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:14px}
.svc-mini a{display:block;padding:20px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);transition:border-color .3s,transform .3s}
.svc-mini a:hover{border-color:var(--primary);transform:translateY(-3px)}
.svc-mini b{font-family:var(--font-head);color:var(--foreground);display:block;margin-bottom:4px}
.svc-mini span{font-size:.86rem;opacity:.7}
