@font-face{font-family:'RankDisplay';src:url('/assets/fonts/display.woff2') format('woff2');font-weight:100 900;font-display:swap}@font-face{font-family:'RankSans';src:url('/assets/fonts/body.woff2') format('woff2');font-weight:100 900;font-display:swap}
:root{--ink:#150f11;--soft:#4d4748;--muted:#726c6e;--line:#e0dbdc;--bg:#ffffff;--bg2:#f9f5f6;--acc:#f6418a;--acc2:#ca0067;--accbg:#ffeff4;--grn:#337767;--grnbg:#e6f1ee;--ctaink:#150f11;--fdisp:'Bebas Neue',-apple-system,BlinkMacSystemFont,'Segoe UI Variable','Segoe UI',Roboto,Helvetica,Arial,sans-serif;--fbody:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI Variable','Segoe UI',Roboto,Helvetica,Arial,sans-serif;--rbtn:8px;--rcard:14px;--dweight:900;--dspace:0.02em;--dtransform:uppercase;--herograd:radial-gradient(1100px 380px at 83% -18%,#ffeff4,transparent 70%);--card-bg:var(--bg2);--card-border:1px solid var(--line);--card-shadow:var(--sh-sm);}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--fbody);color:var(--ink);line-height:1.62;font-size:17px;
-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background:var(--bg)}
img{max-width:100%;height:auto;display:block}
a{color:var(--acc2)}
h1,h2,h3{font-family:var(--fdisp);font-weight:var(--dweight);letter-spacing:var(--dspace);
text-transform:var(--dtransform)}
h1{font-size:clamp(2.1rem,1.3rem + 2.6vw,3.1rem);line-height:1.05;margin:.1em 0 .35em}
h2{font-size:clamp(1.5rem,1.2rem + 1vw,2.1rem);line-height:1.14;margin:0 0 .55em}
h3{font-size:1.16rem;margin:0 0 .35em;letter-spacing:0}
.lead{font-size:1.2rem;color:var(--soft);max-width:62ch}
.muted{color:var(--muted)}
.prose p{max-width:68ch}
/* ---- depth system: layered shadows + surface tints ---- */
:root{--sh-sm:0 1px 3px rgba(15,22,30,.06),0 4px 12px -4px rgba(15,22,30,.12);
--sh-md:0 2px 6px rgba(15,22,30,.06),0 12px 32px -10px rgba(15,22,30,.22),0 24px 48px -20px rgba(15,22,30,.14);
--sh-lg:0 3px 8px rgba(15,22,30,.05),0 20px 44px -16px rgba(15,22,30,.28),0 40px 80px -38px rgba(15,22,30,.18);
--ring:0 0 0 4px color-mix(in srgb,var(--acc) 18%,transparent)}
/* ---- header: backdrop-blur sticky ---- */
.hdr{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--bg) 85%,transparent);
-webkit-backdrop-filter:saturate(180%) blur(16px);backdrop-filter:saturate(180%) blur(16px);
border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent)}
.hdr-in{max-width:1120px;margin:0 auto;display:flex;align-items:center;gap:18px;padding:14px 22px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.08rem;
text-decoration:none;color:var(--ink);font-family:var(--fdisp);letter-spacing:-.01em}
.mono{border-radius:9px;flex:none}
.logo{height:40px;width:auto}
.nav{display:flex;gap:20px;margin-left:auto;flex-wrap:wrap;align-items:center}
.nav a{text-decoration:none;color:var(--soft);font-size:.93rem;font-weight:500;
transition:color .15s ease}
.nav a:hover{color:var(--acc2)}
/* ---- buttons: distinct hover/active states ---- */
.call-btn{background:var(--acc);color:#fff;text-decoration:none;font-weight:700;
padding:11px 19px;border-radius:var(--rbtn);white-space:nowrap;font-size:.95rem;
box-shadow:var(--sh-sm);transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}
.call-btn:hover{transform:translateY(-1px);box-shadow:var(--sh-md);filter:brightness(1.06)}
.call-btn:active{transform:translateY(0);box-shadow:var(--sh-sm);filter:brightness(.96)}
.call-btn.sm{display:inline-block;padding:9px 16px;font-size:.9rem}
/* ---- hero: generous spacing, layered composition ---- */
.hero{background:var(--herograd);border-bottom:1px solid var(--line);overflow:clip;position:relative}
.hero::before{content:"";position:absolute;z-index:-1;top:-30%;right:-14%;width:62%;height:160%;
background:radial-gradient(closest-side,var(--accbg),transparent 70%);filter:blur(12px);opacity:.85;pointer-events:none}
.hero.v-fullbleed::before{display:none}
.hero-in{max-width:1120px;margin:0 auto;padding:72px 22px 32px;display:grid;
grid-template-columns:1fr;gap:30px;align-items:center}
.hero.has-media .hero-in{grid-template-columns:1fr 1.04fr;gap:40px;align-items:stretch}
.hero h1{max-width:18ch;font-size:clamp(2.4rem,1rem + 4.5vw,4.5rem);letter-spacing:-.03em;line-height:1.0}
.hero.has-media h1{font-size:clamp(2rem,.8rem + 3.6vw,3.5rem)}
.sub{font-size:1.25rem;color:var(--soft);max-width:54ch}
.hero-eyebrow{display:inline-block;font-size:.76rem;font-weight:700;letter-spacing:.13em;
text-transform:uppercase;color:var(--acc2);background:var(--accbg);padding:6px 14px;border-radius:100px;margin-bottom:16px}
.hero.v-fullbleed .hero-eyebrow{background:rgba(255,255,255,.18);color:#fff}
/* floating stat/trust card in hero */
.hero-stat{display:inline-block;background:var(--bg);color:var(--acc2);font-weight:650;
padding:10px 18px;border-radius:var(--rcard);font-size:.92rem;
box-shadow:var(--sh-md);border:1px solid var(--line)}
.hero-media img{width:100%;height:auto;border-radius:var(--rcard);box-shadow:var(--sh-lg)}
.hero.has-media .hero-media{margin-right:calc(50% - 50vw);display:flex}
.hero.has-media .hero-media img{height:100%;min-height:420px;object-fit:cover;object-position:50% 32%;
width:100%;border-radius:20px 0 0 20px;box-shadow:var(--sh-lg)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;margin:24px 0 4px}
.cta-row.center{justify-content:center}
.cta{text-decoration:none;font-weight:700;padding:15px 26px;border-radius:var(--rbtn);font-size:1.02rem;
transition:transform .15s ease,box-shadow .15s ease,filter .15s ease,background .15s ease}
.cta.primary{background:var(--acc);color:#fff;
box-shadow:0 4px 14px -4px color-mix(in srgb,var(--acc) 50%,transparent),var(--sh-sm)}
.cta.primary:hover{transform:translateY(-2px);filter:brightness(1.06);
box-shadow:0 8px 24px -6px color-mix(in srgb,var(--acc) 45%,transparent),var(--sh-md)}
.cta.primary:active{transform:translateY(0);filter:brightness(.95);box-shadow:var(--sh-sm)}
.cta.soft{background:var(--bg);color:var(--acc2);border:1.5px solid color-mix(in srgb,var(--acc) 40%,var(--line))}
.cta.soft:hover{background:var(--accbg);transform:translateY(-1px);border-color:var(--acc)}
.cta.soft:active{transform:translateY(0);background:color-mix(in srgb,var(--accbg) 60%,var(--bg))}
.hero-form-wrap{max-width:1120px;margin:0 auto;padding:0 22px 56px}
/* ---- form: depth + polish ---- */
.quote{background:var(--bg);border:1px solid var(--line);border-radius:var(--rcard);padding:24px;
max-width:460px;box-shadow:var(--sh-lg)}
.quote h3{margin:0 0 4px}.form-ctx{color:var(--muted);font-size:.9rem;margin:0 0 14px}
.quote input,.quote textarea{width:100%;padding:13px 14px;margin:6px 0;border:1px solid var(--line);
border-radius:9px;font-size:1rem;font-family:inherit;background:var(--bg2);
transition:border-color .15s ease,box-shadow .15s ease}
.quote input:focus,.quote textarea:focus{outline:none;border-color:var(--acc);box-shadow:var(--ring)}
.quote button{width:100%;margin-top:10px;background:var(--acc);color:#fff;border:0;padding:15px;
border-radius:var(--rbtn);font-weight:700;font-size:1rem;cursor:pointer;
box-shadow:0 4px 14px -4px color-mix(in srgb,var(--acc) 40%,transparent);
transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}
.quote button:hover{transform:translateY(-1px);filter:brightness(1.06);box-shadow:var(--sh-md)}
.quote button:active{transform:translateY(0);filter:brightness(.95)}
/* ---- bands: generous section padding ---- */
.band{max-width:1120px;margin:0 auto;padding:72px 22px;border-bottom:1px solid var(--line)}
.trust-bar{background:var(--bg2);text-align:center;padding:16px 22px;font-size:.95rem;
color:var(--soft);border-bottom:1px solid var(--line);letter-spacing:.01em}
/* ---- cards: layered depth, never flat ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.card{display:block;text-decoration:none;color:var(--ink);border-radius:var(--rcard);
padding:22px 24px;background:var(--card-bg);border:var(--card-border);
box-shadow:var(--card-shadow,var(--sh-sm));overflow:hidden;
transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--acc) 40%,var(--line));
box-shadow:var(--sh-md)}
.card p{color:var(--soft);font-size:.95rem;margin:.35em 0}
.card .more{color:var(--acc2);font-weight:650;font-size:.9rem}
/* card media */
.card-media{display:block;margin:-22px -24px 16px;overflow:hidden;background:var(--bg2)}
.card-media img{width:100%;height:180px;object-fit:cover;display:block;transition:transform .35s ease}
.card:hover .card-media img{transform:scale(1.04)}
/* steps */
.steps{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.steps li{position:relative;padding:18px 20px 18px 58px;background:var(--bg2);border-radius:var(--rcard);
border:1px solid var(--line);transition:transform .15s ease,box-shadow .15s ease}
.steps li:hover{transform:translateY(-2px);box-shadow:var(--sh-sm)}
.step-n{position:absolute;left:16px;top:17px;width:30px;height:30px;border-radius:50%;
background:var(--acc);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.9rem;
box-shadow:0 2px 8px -2px color-mix(in srgb,var(--acc) 40%,transparent)}
.ticks{columns:2;gap:34px;padding-left:1.1em}.ticks li{margin:.35em 0}
/* gallery */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.shot{margin:0}.shot img{border-radius:var(--rcard);width:100%;height:auto;box-shadow:var(--sh-sm)}
.shot figcaption{color:var(--muted);font-size:.85rem;margin-top:6px}
/* reviews */
.reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.review{margin:0;border:1px solid var(--line);border-radius:var(--rcard);padding:22px;
background:var(--bg);box-shadow:var(--sh-sm);transition:box-shadow .2s ease}
.review:hover{box-shadow:var(--sh-md)}
.stars{color:#e8a317;letter-spacing:2px}
.review blockquote{margin:.6em 0;font-size:.99rem}
.review figcaption{color:var(--muted);font-size:.88rem;font-weight:650}
/* price table */
.price{width:100%;border-collapse:collapse}
.price td{padding:12px 14px;border-bottom:1px solid var(--line)}
.price td:last-child{text-align:right;font-weight:700}
/* misc */
.arealist{line-height:2.15}.arealist a{text-decoration:none;transition:color .12s ease}
.crumbs{max-width:1120px;margin:0 auto;padding:16px 22px 0;font-size:.85rem;color:var(--muted)}
.crumbs a{color:var(--muted);transition:color .12s ease}.up{font-weight:650}
/* FAQ */
.faq{border:1px solid var(--line);border-radius:var(--rcard);padding:2px 18px;margin:10px 0;
background:var(--bg);transition:box-shadow .2s ease}
.faq[open]{box-shadow:var(--sh-sm)}
.faq summary{cursor:pointer;font-weight:650;padding:14px 0;transition:color .12s ease}
.faq summary:hover{color:var(--acc2)}
.faq p{margin:0 0 14px;color:var(--soft)}
/* CTA band */
.cta-band{background:var(--ctaink);color:#fff;text-align:center;padding:80px 22px}
.cta-band h2{color:#fff;font-size:clamp(1.6rem,1.1rem + 1.5vw,2.4rem)}
.cta-band .cta.soft{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.cta-band .cta.soft:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.8)}
/* ---- footer: structured multi-column with brand block ---- */
.ftr{background:var(--bg2);border-top:1px solid var(--line);padding:56px 22px 0}
.ftr-cols{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
.brand-f{font-family:var(--fdisp);font-weight:var(--dweight);font-size:1.15rem;letter-spacing:-.01em}
.ftr .brand-desc{color:var(--soft);font-size:.9rem;margin:.6em 0 0;max-width:28ch;line-height:1.5}
.ftr h4{margin:0 0 12px;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700}
.ftr ul{list-style:none;padding:0;margin:0}.ftr li{margin:.4em 0}
.ftr a{text-decoration:none;color:var(--soft);transition:color .12s ease;font-size:.93rem}
.ftr a:hover{color:var(--acc2)}
.ftr-base{max-width:1120px;margin:32px auto 0;padding:20px 0;border-top:1px solid var(--line);
color:var(--muted);font-size:.85rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.sticky-call{display:none}
/* ---- icons: constrained 24-48px system ---- */
.ico-tile{width:48px;height:48px;border-radius:13px;background:var(--accbg);display:grid;
place-items:center;margin-bottom:14px;flex:none;border:1px solid color-mix(in srgb,var(--acc) 12%,transparent)}
.ico-tile .ico{width:24px;height:24px;color:var(--acc2)}
svg.ico{width:24px;height:24px;flex:none}
/* ---- layout variants ---- */
.hero.v-sideform .hero-in.two{grid-template-columns:1.05fr .95fr;align-items:start;padding-bottom:52px;min-height:auto}
.hero.v-sideform .hero-form-side .quote{margin-top:0}
.hero.v-centered .hero-in.center{text-align:center;justify-items:center}
.hero.v-centered .hero-copy{max-width:62ch}
.hero.v-centered .cta-row{justify-content:center}
.hero.v-centered .hero-stat{margin:0 auto}
.hero-media.wide{max-width:1120px;margin:0 auto;padding:0 22px}
.hero-media.wide img{width:100%;border-radius:var(--rcard);box-shadow:var(--sh-lg)}
.hero.v-fullbleed{position:relative;color:#fff;border-bottom:none;isolation:isolate;
min-height:min(80vh,640px);display:flex;flex-direction:column;justify-content:center}
.hero.v-fullbleed .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:-2}
.hero.v-fullbleed .hero-overlay{position:absolute;inset:0;z-index:-1;
background:linear-gradient(105deg,rgba(10,14,22,.93) 0%,rgba(10,14,22,.7) 40%,rgba(10,14,22,.35) 70%,rgba(10,14,22,.2))}
.hero.v-fullbleed.no-img{background:linear-gradient(135deg,var(--ctaink) 0%,color-mix(in srgb,var(--acc2) 80%,var(--ctaink)) 100%)}
.hero.v-fullbleed .hero-in{padding-top:72px;padding-bottom:28px}
.hero.v-fullbleed .hero-copy{max-width:42ch}
.hero.v-fullbleed h1,.hero.v-fullbleed .sub{color:#fff}
.hero.v-fullbleed .hl{color:color-mix(in srgb,var(--acc) 55%,#ffffff)}
.hero.v-fullbleed .hero-eyebrow{background:rgba(255,255,255,.15);color:#fff}
.hero.v-fullbleed .hero-stat{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.2);box-shadow:0 8px 32px rgba(0,0,0,.3)}
.hero.v-fullbleed .cta.soft{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.hero.v-fullbleed .cta.soft:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.8)}
.hero.v-fullbleed .hero-form-wrap{padding-bottom:48px}
/* card list + feature variants */
.cards.s-list{display:block}
.cards.s-list .card{display:flex;justify-content:space-between;align-items:center;gap:18px;margin:0 0 12px}
.cards.s-list .card p{margin:0;flex:1}
.cards.s-list .ico-tile{margin-bottom:0}
.cards.s-list .card-media{width:120px;min-width:120px;height:auto;margin:0;border-radius:10px;flex:none}
.cards.s-list .card-media img{height:100%;min-height:80px}
.cards.s-feature{grid-template-columns:1fr}
.cards.s-feature .card{display:grid;grid-template-columns:1fr auto;align-items:center;gap:14px;padding:24px 28px}
.cards.s-feature .card h3{font-size:1.3rem;margin:0}
.cards.s-feature .card .more{justify-self:end}
.cards.s-feature .card:has(.card-media){display:block}
.cards.s-feature .card-media{margin:-24px -28px 18px}
.cards.s-feature .card-media img{height:220px}
/* section kickers + accent headline */
.kicker{display:block;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
color:var(--acc2);margin-bottom:10px}
.hl{color:var(--acc)}
.card-price{display:inline-block;color:var(--acc2);font-weight:700;font-size:.92rem;margin:.1em 0 .4em}
.card-bul{list-style:none;padding:0;margin:.5em 0 0}
.card-bul li{padding:7px 0 7px 24px;position:relative;font-size:.9rem;color:var(--soft);border-top:1px solid var(--line)}
.card-bul li::before{content:"¹3";position:absolute;left:0;color:var(--acc);font-weight:800}
/* alternating band rhythm */
.alt-bands .band:nth-of-type(even){background:linear-gradient(180deg,var(--bg2),color-mix(in srgb,var(--accbg) 30%,var(--bg2)))}
/* niche-tailored bands */
.niche-band{background:var(--accbg);border-bottom:1px solid var(--line)}
.niche-band.emergency{background:var(--ctaink)}
.niche-band.emergency h2,.niche-band.emergency p{color:#fff}
.niche-band .nb-in{max-width:1120px;margin:0 auto;padding:40px 22px;display:flex;gap:24px;
align-items:center;justify-content:space-between;flex-wrap:wrap}
.niche-band .nb-in h2{margin:0 0 4px}.niche-band .nb-in p{margin:0;color:var(--soft)}
/* values grid */
.values{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:10px}
.value{border:1px solid var(--line);border-radius:var(--rcard);padding:20px 22px;background:var(--bg2);
box-shadow:var(--sh-sm);transition:transform .15s ease,box-shadow .15s ease}
.value:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.value h3{margin:.1em 0 .2em}
/* stat bar */
.statbar{background:linear-gradient(180deg,var(--bg2),var(--bg));border-bottom:1px solid var(--line)}
.statbar-in{max-width:1120px;margin:0 auto;padding:32px 22px;display:grid;
grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;text-align:center}
.stat-v{font-family:var(--fdisp);font-weight:820;font-size:2.2rem;letter-spacing:-.03em;color:var(--ink);line-height:1}
.stat-l{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:8px}
/* dark feature band */
.feature-band{background:var(--ctaink);color:#fff}
.fb-in{max-width:1120px;margin:0 auto;padding:80px 22px;display:grid;grid-template-columns:1.1fr .9fr;
gap:36px;align-items:center}
.feature-band h2{color:#fff;font-size:clamp(1.5rem,1rem + 1.5vw,2.2rem)}
.feature-band p{color:rgba(255,255,255,.82);max-width:46ch}
.feature-band .cta.primary{margin-top:8px}
.dark-points{list-style:none;padding:0;margin:0}
.dark-points li{padding:13px 2px;border-bottom:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.92);
display:flex;align-items:center;gap:10px}
.dark-points li::before{content:"¹3";color:var(--acc);font-weight:800}
/* ---- transitions ---- */
.nav a,.ftr a,.crumbs a,.arealist a{transition:color .12s ease}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
/* ---- mobile: 56px section padding ---- */
@media(max-width:780px){
.nav{display:none}
.hero-in{min-height:auto;padding:56px 22px 32px}
.hero.v-sideform .hero-in.two{grid-template-columns:1fr}
.cards.s-feature .card{grid-template-columns:1fr}
.cards.s-list .card{display:block}
.niche-band .nb-in{flex-direction:column;align-items:flex-start}
.fb-in{grid-template-columns:1fr;padding:56px 22px}
.hero-in,.hero.has-media .hero-in{grid-template-columns:1fr}
.hero.has-media .hero-media{margin-right:0}
.hero.has-media .hero-media img{height:260px;border-radius:var(--rcard)}
.hero h1,.hero.has-media h1{font-size:clamp(1.8rem,1.2rem + 2vw,2.4rem)}
.hero-media{order:-1}
.hero.v-fullbleed{min-height:70vh}
.band{padding:56px 22px}
.cta-band{padding:56px 22px}
.ftr{padding:40px 22px 0}
.ftr-cols{grid-template-columns:1fr 1fr;gap:24px}
.ticks{columns:1}
.sticky-call{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:50;justify-content:center;
align-items:center;gap:8px;background:var(--acc);color:#fff;text-decoration:none;font-weight:700;
padding:16px;font-size:1.05rem;box-shadow:0 -4px 20px -6px rgba(0,0,0,.35)}
main{padding-bottom:62px}
}
/* ---- P3.6 editorial scaffolding ---- */
/* numbered section kickers: "01 — OUR CRAFT" */
.kicker{position:relative;padding-bottom:14px}
.kicker::after{content:'';display:block;width:40px;height:1px;background:var(--line);margin-top:10px}
/* ghost-numeral process steps */
.steps-editorial{list-style:none;padding:0;display:grid;
grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px}
.steps-editorial li{position:relative;padding:48px 0 0;border-top:1px solid var(--line)}
.step-ghost{display:block;font-family:var(--fdisp);font-weight:900;font-size:3.5rem;
letter-spacing:-.02em;line-height:1;color:color-mix(in srgb,var(--line) 70%,transparent);margin-bottom:8px}
.steps-editorial h4{font-family:var(--fdisp);font-weight:800;font-size:.82rem;
text-transform:uppercase;letter-spacing:.1em;margin:0 0 6px}
.steps-editorial p{color:var(--soft);font-size:.9rem;margin:0}
/* stat strip: big numbers + hairline separators */
.statbar{background:var(--bg);border-bottom:1px solid var(--line);border-top:1px solid var(--line)}
.statbar-in{max-width:1120px;margin:0 auto;padding:36px 22px;display:flex;
justify-content:center;gap:0;text-align:center}
.stat{flex:1;padding:0 24px;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat-v{font-family:var(--fdisp);font-weight:900;font-size:clamp(2rem,1.2rem + 2.5vw,3rem);
letter-spacing:-.03em;color:var(--ink);line-height:1}
.stat-l{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;
margin-top:8px;font-weight:600}
/* neighborhood grid: table-like with hairline borders */
.area-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0;
border:1px solid var(--line);border-radius:var(--rcard)}
.area-cell{padding:14px 18px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);
font-size:.9rem}
.area-cell a{text-decoration:none;color:var(--ink);font-weight:600}
.area-cell .area-sub{color:var(--muted);font-size:.78rem;margin-top:2px}
/* dark pricing band with photo */
.price-band{background:var(--ctaink);color:#fff;position:relative;overflow:hidden}
.price-band .pb-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.25}
.price-band .pb-in{position:relative;z-index:1;max-width:1120px;margin:0 auto;padding:80px 22px;
display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.price-band h2{color:#fff;font-size:clamp(1.8rem,1rem + 2.5vw,3rem);line-height:1.05}
.price-band .price-hero{font-family:var(--fdisp);font-weight:900;
font-size:clamp(2.5rem,1.5rem + 3vw,4.5rem);color:rgba(255,255,255,.3);letter-spacing:-.02em;
margin-top:8px}
.price-band .price{border-collapse:collapse;width:100%}
.price-band .price td{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.85)}
.price-band .price td:last-child{text-align:right;color:#fff;font-weight:700}
/* photo-topped service cards with pricing badge */
.card .card-price-badge{display:inline-block;background:var(--acc);color:#fff;font-weight:700;
font-size:.82rem;padding:5px 12px;border-radius:100px;margin-bottom:8px}
/* editorial headline treatment */
.hero h1{text-wrap:balance}
.hero h1{font-size:clamp(2.4rem,1rem + 4.5vw,4.5rem);letter-spacing:-.02em}
/* voice flag: confident editorial */
.voice-editorial .hero h1{font-size:clamp(2.8rem,1rem + 5.5vw,5.5rem);line-height:.92;letter-spacing:.01em;max-width:14ch}
.voice-editorial h2{font-size:clamp(1.6rem,1rem + 2vw,2.8rem);letter-spacing:.01em}
.voice-editorial .kicker{font-family:var(--fbody);font-weight:600}
.voice-editorial .statbar{border-top:2px solid var(--ink);background:var(--bg)}
.voice-editorial .stat-v{font-size:clamp(2.5rem,1.5rem + 3vw,3.8rem)}
.voice-editorial .area-grid{border-radius:0}
.voice-editorial .step-ghost{font-size:clamp(3rem,2rem + 3vw,4.5rem);color:var(--line)}
@media(max-width:780px){
.statbar-in{flex-wrap:wrap;gap:16px}
.stat{flex:none;width:calc(50% - 12px);border-right:none;padding:12px 0;
border-bottom:1px solid var(--line)}
.stat:nth-last-child(-n+2){border-bottom:none}
.price-band .pb-in{grid-template-columns:1fr}
.steps-editorial{grid-template-columns:1fr 1fr}
.area-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
.ftr-cols{grid-template-columns:1fr}
.steps-editorial{grid-template-columns:1fr}
.area-grid{grid-template-columns:1fr}
}

.motif-grain{position:relative}.motif-grain::after{content:'';position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none;z-index:1}
.reveal-ready{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease}
.revealed{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){.reveal-ready{opacity:1;transform:none;transition:none}}
.qs-q{width:100%;padding:14px;margin:6px 0;border:1px solid var(--line);
border-radius:9px;font-size:1.05rem;font-family:inherit;background:var(--bg2)}
.qs-next{width:100%;margin-top:8px;background:var(--acc);color:#fff;border:0;padding:14px;
border-radius:var(--rbtn);font-weight:700;font-size:1rem;cursor:pointer}
.sticky-call{transform:translateY(100%);transition:transform .25s ease}
@media(prefers-reduced-motion:reduce){.sticky-call{transition:none}}
.ba-slider{position:relative;overflow:hidden;border-radius:var(--rcard)}
.ba-slider img{display:block;width:100%}
.ba-overlay{position:absolute;inset:0;clip-path:inset(0 50% 0 0)}
.ba-slider input[type=range]{position:absolute;bottom:12px;left:10%;width:80%;z-index:2;
accent-color:var(--acc)}
.lb{border:0;padding:0;background:transparent;max-width:92vw;max-height:92vh}
.lb::backdrop{background:rgba(0,0,0,.82)}
.lb-img{max-width:90vw;max-height:85vh;border-radius:8px;object-fit:contain}
.lb-close{position:absolute;top:8px;right:12px;background:rgba(0,0,0,.6);color:#fff;
border:0;font-size:1.6rem;width:36px;height:36px;border-radius:50%;cursor:pointer;z-index:2}
@view-transition{navigation:auto}
::view-transition-old(root),::view-transition-new(root){animation-duration:.2s}