:root{
  --navy:#14274a;--navy-2:#0e1c38;--blue:#1f6fd4;--blue-2:#1657ad;--blue-tint:#eaf2fc;
  --ink:#172033;--muted:#54607a;
  --line:rgba(20,39,74,.10);--bg:#ffffff;--bg-soft:#f6f8fc;--white:#fff;
  --r-card:16px;--r-btn:11px;--r-pill:999px;
  --sh-sm:0 1px 2px rgba(20,39,74,.06),0 4px 12px rgba(20,39,74,.06);
  --sh-md:0 2px 4px rgba(20,39,74,.05),0 14px 34px -12px rgba(20,39,74,.16);
  --sh-lg:0 30px 60px -20px rgba(20,39,74,.28);
  --pad-y:clamp(60px,8vw,108px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;font-size:clamp(1rem,.97rem+.2vw,1.08rem);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
h1,h2,h3,h4{font-family:"Sora","Inter",sans-serif;color:var(--navy);font-weight:700;line-height:1.12;letter-spacing:-.02em}
h2{font-size:clamp(1.65rem,1.3rem+1.6vw,2.5rem)}
h3{font-size:1.18rem}
p{max-width:64ch}
.wrap{width:100%;max-width:1140px;margin:0 auto;padding:0 22px}
.wrap-narrow{max-width:820px}
section{padding:var(--pad-y) 0}
.eyebrow{font-family:"Sora",sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue)}
.center{text-align:center}
.lead{color:#54607a;font-size:1.08rem;max-width:60ch}
.lead.center{margin-inline:auto}
.icon{width:1.3em;height:1.3em;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round;flex:none}
.mt-s{margin-top:8px}.mt-m{margin-top:18px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;font-family:"Sora",sans-serif;font-weight:700;font-size:1.02rem;padding:15px 26px;border-radius:var(--r-btn);border:none;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;min-height:52px}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 8px 20px -6px rgba(31,111,212,.55),inset 0 1px 0 rgba(255,255,255,.25)}
.btn-primary:hover{background:var(--blue-2);transform:translateY(-2px);box-shadow:0 14px 28px -8px rgba(31,111,212,.6)}
.btn-ghost{background:transparent;border:1.5px solid rgba(255,255,255,.45);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-outline{background:#fff;border:1.5px solid #d3dbe8;color:var(--navy)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Sora",sans-serif;font-weight:800;color:var(--navy);font-size:1.04rem;letter-spacing:-.01em}
.brand .mark{width:34px;height:34px;border-radius:9px;background:var(--navy);color:#fff;display:grid;place-items:center}
.brand .mark .icon{width:20px;height:20px;stroke-width:2}
.nav-links{display:none;gap:28px;font-family:"Sora",sans-serif;font-weight:600;font-size:.93rem}
.nav-links a{color:var(--ink)}.nav-links a:hover,.nav-links a[aria-current]{color:var(--blue)}
@media(min-width:960px){.nav-links{display:flex}}
.nav .btn{padding:11px 18px;min-height:44px;font-size:.95rem}
.nav-phone .icon{width:18px;height:18px}

/* Hero (home) */
.hero{position:relative;color:#fff;overflow:hidden;isolation:isolate}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;background:url("/assets/img/hero-house.webp") center/cover no-repeat}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(115deg,rgba(14,28,56,.95) 0%,rgba(16,30,60,.88) 42%,rgba(20,39,74,.66) 72%,rgba(20,39,74,.40) 100%)}
@media(max-width:899px){.hero::after{background:linear-gradient(160deg,rgba(14,28,56,.93) 0%,rgba(16,30,60,.88) 55%,rgba(20,39,74,.66) 100%)}}
.grain{position:absolute;inset:0;z-index:-1;opacity:.05;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero-inner{padding:clamp(40px,7vw,84px) 0 clamp(52px,7vw,92px)}
.availpill{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);color:#dce7f7;font-weight:600;font-size:.86rem;padding:7px 15px;border-radius:var(--r-pill);margin-bottom:22px}
.dot{width:9px;height:9px;border-radius:50%;background:#36d07a;box-shadow:0 0 0 0 rgba(54,208,122,.7);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(54,208,122,.6)}70%{box-shadow:0 0 0 9px rgba(54,208,122,0)}100%{box-shadow:0 0 0 0 rgba(54,208,122,0)}}
@media(prefers-reduced-motion:reduce){.dot{animation:none}}
.hero h1{color:#fff;font-size:clamp(2.05rem,1.4rem+4vw,3.55rem);font-weight:800;max-width:16ch;margin-bottom:.5em}
.hero h1 .hl{color:#6fa6ec}
.hero .sub{color:#cdd9ec;font-size:1.14rem;max-width:46ch;margin-bottom:1.7em}
.hero-cta{display:flex;flex-wrap:wrap;gap:13px;margin-bottom:1.4em}
.risk{display:flex;flex-wrap:wrap;gap:7px 20px;color:#aebfd8;font-weight:600;font-size:.9rem}
.risk span{display:flex;align-items:center;gap:7px}.risk .icon{width:17px;height:17px;stroke:#6fa6ec}
@media(min-width:900px){.hero-inner{max-width:62%}}

/* Page hero (inner pages) */
.phero{position:relative;color:#fff;background:linear-gradient(125deg,var(--navy-2),var(--navy));overflow:hidden;isolation:isolate}
.phero .grain{opacity:.06}
.phero-inner{padding:clamp(30px,5vw,52px) 0 clamp(40px,6vw,68px)}
.crumb{display:flex;flex-wrap:wrap;gap:7px;align-items:center;color:#9fb2d0;font-size:.85rem;margin-bottom:16px;font-family:"Sora",sans-serif}
.crumb a{color:#9fb2d0}.crumb a:hover{color:#fff}.crumb .sep{opacity:.5}
.phero h1{color:#fff;font-size:clamp(1.9rem,1.3rem+3vw,3rem);font-weight:800;max-width:18ch;margin-bottom:.4em}
.phero .sub{color:#cdd9ec;font-size:1.1rem;max-width:54ch;margin-bottom:1.4em}
.phero-cta{display:flex;flex-wrap:wrap;gap:12px}

/* Trust strip */
.strip{background:var(--navy-2);color:#cdd9ec}
.strip-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px 14px;padding:26px 0}
@media(min-width:760px){.strip-grid{grid-template-columns:repeat(4,1fr)}}
.strip-item{display:flex;align-items:center;gap:12px;justify-content:center;text-align:left}
.strip-item .icon{width:26px;height:26px;stroke:#6fa6ec}
.strip-item b{display:block;color:#fff;font-family:"Sora",sans-serif;font-size:.98rem;line-height:1.2}
.strip-item small{font-size:.8rem;color:#9fb2d0}

/* Chips */
.chip{width:52px;height:52px;border-radius:13px;background:var(--blue-tint);color:var(--blue);display:grid;place-items:center;margin-bottom:15px}
.chip .icon{width:26px;height:26px}

/* Services grid */
.svc-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-top:36px}
@media(min-width:620px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.svc-grid{grid-template-columns:repeat(3,1fr)}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);padding:28px;box-shadow:var(--sh-sm);transition:transform .22s ease,box-shadow .22s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.card h3{margin-bottom:7px}.card p{color:#5d6a82;font-size:.96rem}
a.card{color:inherit}
.card .more{margin-top:auto;padding-top:14px;font-family:"Sora",sans-serif;font-weight:700;font-size:.9rem;color:var(--blue);display:inline-flex;align-items:center;gap:6px}
.card .more .icon{width:16px;height:16px;transition:transform .2s ease}
a.card:hover .more .icon{transform:translateX(3px)}
.card.dark{background:var(--navy);border:none;color:#cdd9ec}
.card.dark h3{color:#fff}.card.dark .chip{background:rgba(255,255,255,.12);color:#fff}

.soft{background:var(--bg-soft)}

/* Owner / trust */
.owner{display:grid;grid-template-columns:1fr;gap:34px;align-items:center}
@media(min-width:860px){.owner{grid-template-columns:.85fr 1.15fr}}
.owner-photo{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--sh-lg);aspect-ratio:4/5}
.owner-photo img{width:100%;height:100%;object-fit:cover}
.sample{position:absolute;top:12px;left:12px;z-index:2;background:rgba(14,28,56,.82);color:#fff;font-family:"Sora",sans-serif;font-weight:600;font-size:.72rem;letter-spacing:.04em;padding:5px 11px;border-radius:var(--r-pill);backdrop-filter:blur(4px)}
.sig{font-family:"Sora",sans-serif;font-weight:800;color:var(--navy);font-size:1.25rem;margin-top:14px}
.guarantee{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:12px;padding:18px 20px;margin-top:22px;box-shadow:var(--sh-sm)}
.guarantee .icon{width:30px;height:30px;stroke:var(--blue);flex:none;margin-top:2px}
.guarantee b{font-family:"Sora",sans-serif;color:var(--navy)}

/* Before/After slider */
.ba{position:relative;max-width:760px;margin:30px auto 0;border-radius:18px;overflow:hidden;box-shadow:var(--sh-md);aspect-ratio:3/2;background:#0e1c38;touch-action:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;user-select:none;-webkit-user-drag:none}
.ba .after{clip-path:inset(0 0 0 50%)}
.ba .tag{position:absolute;bottom:14px;z-index:3;background:rgba(14,28,56,.82);color:#fff;font-family:"Sora",sans-serif;font-weight:600;font-size:.78rem;padding:6px 12px;border-radius:var(--r-pill);backdrop-filter:blur(4px)}
.ba .tag.l{left:14px}.ba .tag.r{right:14px}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;z-index:4;transform:translateX(-1.5px);box-shadow:0 0 0 1px rgba(20,39,74,.15)}
.ba .knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;z-index:5;display:grid;place-items:center;box-shadow:var(--sh-md);color:var(--navy)}
.ba .knob .icon{width:24px;height:24px;stroke-width:2.4}
.ba input[type=range]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:6;margin:0}
.ba-cap{text-align:center;color:#5d6a82;font-size:.92rem;margin-top:14px}

/* Why grid */
.why-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:34px}
@media(min-width:760px){.why-grid{grid-template-columns:repeat(2,1fr)}}
.why{display:flex;gap:15px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:var(--sh-sm)}
.why .chip{margin:0;width:46px;height:46px;border-radius:11px}.why .chip .icon{width:23px;height:23px}
.why h3{font-size:1.05rem;margin-bottom:3px}.why p{color:#5d6a82;font-size:.93rem}

/* Split image + text (service pages) */
.split{display:grid;grid-template-columns:1fr;gap:36px;align-items:center}
@media(min-width:860px){.split{grid-template-columns:1fr 1fr}.split.rev .split-media{order:2}}
.split-media{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--sh-md);aspect-ratio:3/2}
.split-media img{width:100%;height:100%;object-fit:cover}
.prose p{color:#465067;margin-bottom:14px}
.prose p:last-child{margin-bottom:0}

/* Checklist (includes) */
.checklist{list-style:none;display:grid;grid-template-columns:1fr;gap:12px;margin-top:8px}
@media(min-width:620px){.checklist{grid-template-columns:repeat(2,1fr)}}
.checklist li{display:flex;gap:11px;align-items:flex-start;color:#3a4357;font-weight:500}
.checklist .ic{flex:none;width:24px;height:24px;border-radius:50%;background:var(--blue-tint);color:var(--blue);display:grid;place-items:center}
.checklist .ic .icon{width:15px;height:15px;stroke-width:2.6}

/* Steps */
.steps{display:grid;grid-template-columns:1fr;gap:18px;margin-top:34px;counter-reset:step}
@media(min-width:760px){.steps{grid-template-columns:repeat(4,1fr)}}
.step{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;box-shadow:var(--sh-sm);position:relative}
.step::before{counter-increment:step;content:counter(step);display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--navy);color:#fff;font-family:"Sora",sans-serif;font-weight:800;margin-bottom:14px}
.step h3{font-size:1.05rem;margin-bottom:5px}.step p{color:#5d6a82;font-size:.92rem}

/* Areas */
.area-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:26px}
.area-tags span,.area-tags a{background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:9px 19px;font-family:"Sora",sans-serif;font-weight:600;color:var(--navy);font-size:.9rem;box-shadow:var(--sh-sm)}
.area-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:36px}
@media(min-width:620px){.area-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.area-grid{grid-template-columns:repeat(3,1fr)}}
.area-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:var(--sh-sm)}
.area-card h3{display:flex;align-items:center;gap:9px;font-size:1.08rem;margin-bottom:6px}
.area-card h3 .icon{width:20px;height:20px;stroke:var(--blue)}
.area-card p{color:#5d6a82;font-size:.93rem}

/* Quote form */
.quote{display:grid;grid-template-columns:1fr;gap:34px;align-items:start}
@media(min-width:860px){.quote{grid-template-columns:1.05fr .95fr}}
.form-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--sh-md)}
.form-card h3{font-size:1.3rem;margin-bottom:4px}
.form-card .fineprint{color:#6b7790;font-size:.86rem;margin:4px 0 18px}
.field{margin-bottom:14px}
.field label{display:block;font-family:"Sora",sans-serif;font-weight:600;font-size:.86rem;color:var(--navy);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1px solid #d3dbe8;border-radius:10px;font:inherit;font-size:1rem;background:#fff;color:var(--ink);min-height:48px;transition:border-color .15s,box-shadow .15s}
.field textarea{min-height:96px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,111,212,.16)}
.form-card .btn{width:100%}
.or{text-align:center;color:#8a96ad;font-size:.9rem;margin:14px 0 6px}
.callrow{display:flex;flex-wrap:wrap;gap:10px}
.callrow .btn{flex:1}
.contact-list{list-style:none;margin-top:22px}
.contact-list li{display:flex;gap:13px;align-items:flex-start;margin-bottom:16px}
.contact-list .ic{flex:none;width:42px;height:42px;border-radius:11px;background:var(--blue-tint);color:var(--blue);display:grid;place-items:center}
.contact-list .ic .icon{width:21px;height:21px}
.contact-list b{font-family:"Sora",sans-serif;color:var(--navy);display:block;font-size:.95rem}
.contact-list span{color:#5d6a82;font-size:.95rem}

/* CTA band */
.cta-band{position:relative;background:linear-gradient(130deg,var(--blue) 0%,var(--blue-2) 100%);color:#fff;text-align:center;overflow:hidden;isolation:isolate}
.cta-band .grain{opacity:.06}
.cta-band h2{color:#fff}.cta-band p{color:#e6eefb;margin:0 auto 1.3em}
.cta-phone{display:inline-flex;align-items:center;gap:12px;font-family:"Sora",sans-serif;font-size:clamp(1.7rem,5vw,2.5rem);font-weight:800;color:#fff;margin-top:.2em}
.cta-phone .icon{width:1em;height:1em;stroke-width:2.2}

/* FAQ */
.faq{max-width:780px;margin:30px auto 0}
details{background:#fff;border:1px solid var(--line);border-radius:13px;padding:0 22px;margin-bottom:12px;box-shadow:var(--sh-sm)}
summary{cursor:pointer;font-family:"Sora",sans-serif;font-weight:700;color:var(--navy);padding:19px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
summary::-webkit-details-marker{display:none}
summary .icon{width:20px;height:20px;stroke:var(--blue);transition:transform .2s ease}
details[open] summary .icon{transform:rotate(45deg)}
details p{padding:0 0 19px;color:#5d6a82;max-width:none}

/* Footer */
footer{background:var(--navy-2);color:#aebfd8;padding:56px 0 26px;font-size:.93rem}
.foot-grid{display:grid;grid-template-columns:1fr;gap:30px;margin-bottom:30px}
@media(min-width:760px){.foot-grid{grid-template-columns:2fr 1fr 1.2fr}}
footer h4{font-family:"Sora",sans-serif;color:#fff;font-size:1rem;margin-bottom:13px}
footer a{color:#aebfd8}footer a:hover{color:#fff}
footer ul{list-style:none}footer li{margin-bottom:8px;display:flex;gap:9px;align-items:center}
footer .fa li{align-items:center}
footer .icon{width:17px;height:17px;stroke:#6fa6ec;flex:none}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;text-align:center;font-size:.83rem;color:#8095b6}

/* Sticky mobile action bar */
.actionbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;gap:1px;background:var(--line);box-shadow:0 -6px 20px rgba(0,0,0,.16)}
.actionbar a{flex:1;display:flex;align-items:center;justify-content:center;gap:9px;padding:15px 8px;font-family:"Sora",sans-serif;font-weight:700;font-size:1.02rem}
.actionbar .call{background:var(--blue);color:#fff;flex:1.6}
.actionbar .sms{background:var(--navy);color:#fff}
.actionbar .icon{width:20px;height:20px;stroke-width:2.2}
@media(min-width:900px){.actionbar{display:none}}
body{padding-bottom:58px}@media(min-width:900px){body{padding-bottom:0}}

/* Scroll reveal — only hidden when JS is on AND motion allowed (no-JS = visible) */
@media(prefers-reduced-motion:no-preference){
  .js .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease;will-change:opacity,transform}
  .js .reveal.in{opacity:1;transform:none}
}

/* Thank-you */
.ty{min-height:60vh;display:grid;place-items:center;text-align:center}
.ty .badge{width:84px;height:84px;border-radius:50%;background:var(--blue-tint);color:var(--blue);display:grid;place-items:center;margin:0 auto 22px}
.ty .badge .icon{width:44px;height:44px;stroke-width:2.4}
