/* ============================================================================
   Clearwater Irrigation — home.css
   Bespoke section layouts for the hand-built homepage + page-heroes.
   Tokens live in styles.css :root. Water-blue + lawn-green, Fraunces/Figtree.
   ============================================================================ */

/* ---- shared display type + section furniture ------------------------------ */
.display{font-family:var(--font-head);font-weight:600;letter-spacing:-.025em;line-height:1.04;font-size:clamp(2.4rem,6vw,5.2rem)}
.display em{font-style:italic;font-weight:500;color:var(--water)}
.section-head{max-width:760px}
.section-head .kicker{margin-bottom:14px}
.section-lede{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--ink-60);max-width:60ch}
.eyebrow-line{display:flex;align-items:center;gap:16px;margin-bottom:22px}
.eyebrow-line::before{content:"";width:42px;height:2px;background:linear-gradient(90deg,var(--water),var(--lawn));border-radius:2px}
.eyebrow-line span{font-family:var(--font-head);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:.74rem;color:var(--primary)}
.watermark{position:absolute;font-family:var(--font-head);font-weight:700;letter-spacing:-.03em;line-height:.8;color:transparent;-webkit-text-stroke:1.5px color-mix(in srgb,var(--primary) 8%,transparent);text-stroke:1.5px color-mix(in srgb,var(--primary) 8%,transparent);pointer-events:none;user-select:none;z-index:0;white-space:nowrap}

/* gradient display type */
.grad-text{background:linear-gradient(100deg,var(--primary) 0%,var(--water) 55%,var(--lawn) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* editorial marquee */
.marquee{overflow:hidden;border-block:1px solid var(--border);background:var(--surface);padding:18px 0;position:relative;z-index:2}
.marquee__track{display:flex;gap:0;width:max-content;animation:marquee 28s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}
.marquee__item{display:inline-flex;align-items:center;gap:18px;padding:0 28px;font-family:var(--font-head);font-weight:600;font-size:clamp(1.1rem,2vw,1.6rem);color:var(--foreground);white-space:nowrap}
.marquee__item svg{width:18px;height:18px;color:var(--lawn)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* device mockup wrapper for the controller */
.device-mockup{position:relative}
.lift{display:block}

/* ============================================================================
   1. HERO — water-caustics WebGL + cinematic content
   ============================================================================ */
.hero{position:relative;isolation:isolate;min-height:100vh;display:flex;align-items:center;overflow:hidden;
  background:linear-gradient(160deg,#0E3A70 0%,#103e78 30%,#155e9e 70%,#1a78b8 100%)}
.hero__poster{position:absolute;inset:0;z-index:-2;background:
  radial-gradient(80% 70% at 75% 12%,rgba(95,203,230,.45),transparent 60%),
  radial-gradient(90% 80% at 12% 95%,rgba(116,180,60,.30),transparent 55%),
  linear-gradient(160deg,#0E3A70,#155e9e)}
#hero-gl{position:absolute;inset:0;width:100%;height:100%;z-index:-1;opacity:.9;mix-blend-mode:screen}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(8,30,58,.15),transparent 30%,transparent 60%,rgba(8,30,58,.55))}
.hero__content{position:relative;z-index:3;color:#fff;padding-block:clamp(120px,16vh,200px);width:100%}
.hero .kicker{color:var(--water-light)}
.hero__title{font-family:var(--font-head);font-weight:600;letter-spacing:-.03em;line-height:1.02;
  font-size:clamp(2.7rem,7.2vw,6rem);margin:0 0 .35em;color:#fff;max-width:16ch;text-wrap:balance}
.hero__title .drop{position:relative;white-space:nowrap}
.hero__title em{font-style:italic;font-weight:500;color:var(--water-light)}
.hero__lede{font-size:clamp(1.1rem,1.7vw,1.4rem);max-width:54ch;color:rgba(255,255,255,.85);margin-bottom:38px}
.hero__cta{display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.hero .btn--ghost{color:#fff;border-color:rgba(255,255,255,.32)}
.hero .btn--ghost:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.08)}
.hero__phone{display:inline-flex;align-items:center;gap:10px;color:#fff;font-family:var(--font-head);font-weight:600;font-size:1.05rem}
.hero__phone svg{width:20px;height:20px;color:var(--water-light)}
.hero__meta{display:flex;flex-wrap:wrap;gap:28px 40px;margin-top:54px;padding-top:30px;border-top:1px solid rgba(255,255,255,.16)}
.hero__meta-item{display:flex;flex-direction:column;gap:2px}
.hero__meta-item b{font-family:var(--font-head);font-size:1.7rem;font-weight:600;color:#fff;line-height:1}
.hero__meta-item span{font-size:.82rem;letter-spacing:.04em;color:rgba(255,255,255,.62)}
.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.6);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}
.hero__scroll i{width:1px;height:42px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:scrollPulse 2.2s var(--ease-premium) infinite}
@keyframes scrollPulse{0%{transform:scaleY(.3);transform-origin:top;opacity:0}40%{opacity:1}100%{transform:scaleY(1);transform-origin:top;opacity:0}}
@media (prefers-reduced-motion:reduce){.hero__scroll i{animation:none}}
.hero__drops{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5}
.hero__drops .drop-svg{position:absolute;color:var(--water-light);opacity:.5;animation:floatDrop 9s ease-in-out infinite}
@keyframes floatDrop{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-22px) rotate(8deg)}}
@media (prefers-reduced-motion:reduce){.hero__drops .drop-svg{animation:none}}

/* ============================================================================
   2. TRUST STRIP — area badges + brand truck + quick facts
   ============================================================================ */
.trust{background:var(--surface);border-bottom:1px solid var(--border);position:relative;z-index:4}
.trust .container{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,72px);align-items:center;padding-block:clamp(48px,7vw,84px)}
.trust__copy h2{font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:.4em}
.trust__areas{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.area-pill{display:inline-flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);padding:8px 16px;font-weight:500;font-size:.92rem;color:var(--primary-deep);transition:transform .3s var(--ease-premium),border-color .3s,background .3s}
.area-pill:hover{transform:translateY(-2px);border-color:var(--water);background:#fff}
.area-pill svg{width:15px;height:15px;color:var(--lawn)}
.trust__media{position:relative}
.trust__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;aspect-ratio:4/3;object-fit:cover}
.trust__media-badge{position:absolute;bottom:-22px;left:-22px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px;box-shadow:0 20px 40px -22px rgba(14,58,112,.4);display:flex;align-items:center;gap:14px}
.trust__media-badge svg{width:34px;height:34px;color:var(--lawn)}
.trust__media-badge b{font-family:var(--font-head);font-size:1.05rem;display:block;line-height:1.1}
.trust__media-badge span{font-size:.8rem;color:var(--ink-60)}
@media (max-width:820px){.trust .container{grid-template-columns:1fr}.trust__media{order:-1}}

/* ============================================================================
   3. SERVICES — asymmetric feature grid with hand-drawn SVG icons
   ============================================================================ */
.services{position:relative;overflow:hidden}
.services .watermark{top:-2vw;right:-1vw;font-size:clamp(8rem,22vw,20rem)}
.services__head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;margin-bottom:54px;position:relative;z-index:1}
.svc-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:22px;position:relative;z-index:1}
.svc{grid-column:span 2;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px 30px;position:relative;overflow:hidden;transition:transform .4s var(--ease-premium),box-shadow .4s var(--ease-premium),border-color .4s}
.svc::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 120% at 100% 0%,color-mix(in srgb,var(--water) 9%,transparent),transparent 50%);opacity:0;transition:opacity .4s}
.svc:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(14,58,112,.45);border-color:color-mix(in srgb,var(--water) 45%,var(--border))}
.svc:hover::before{opacity:1}
.svc:hover .svc__icon{background:var(--primary);color:#fff;transform:rotate(-6deg)}
.svc--wide{grid-column:span 3}
.svc--tall{grid-column:span 3}
.svc__icon{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;background:var(--surface-2);color:var(--primary);margin-bottom:22px;transition:background .4s var(--ease-premium),color .4s,transform .4s var(--ease-premium)}
.svc__icon svg{width:30px;height:30px}
.svc h3{font-size:1.32rem;margin-bottom:.45em}
.svc p{color:var(--ink-60);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{width:16px;height:16px;transition:transform .3s var(--ease-premium)}
.svc:hover .svc__link svg{transform:translateX(5px)}
.svc__tag{position:absolute;top:22px;right:22px;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--lawn-deep);background:color-mix(in srgb,var(--lawn) 14%,transparent);padding:5px 11px;border-radius:var(--radius-pill)}
@media (max-width:980px){.svc-grid{grid-template-columns:repeat(2,1fr)}.svc,.svc--wide,.svc--tall{grid-column:span 1}}
@media (max-width:560px){.svc-grid{grid-template-columns:1fr}}

/* ============================================================================
   4. SIGNATURE — "What does my lawn need?" service matcher
   ============================================================================ */
.matcher{background:linear-gradient(165deg,#0E3A70,#124b8b 55%,#0E3A70);color:#fff;position:relative;overflow:hidden}
.matcher::before{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 50% at 85% 8%,rgba(95,203,230,.22),transparent 60%),
  radial-gradient(50% 60% at 5% 100%,rgba(116,180,60,.18),transparent 60%);pointer-events:none}
.matcher .container{position:relative;z-index:1}
.matcher__head{text-align:center;max-width:640px;margin:0 auto 48px}
.matcher__head .kicker{color:var(--water-light);justify-content:center}
.matcher__head h2{color:#fff;font-size:clamp(2rem,4vw,3.2rem)}
.matcher__head p{color:rgba(255,255,255,.72)}
.matcher__panel{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);backdrop-filter:blur(14px);padding:clamp(26px,4vw,46px);max-width:920px;margin:0 auto}
.matcher__step{margin-bottom:30px}
.matcher__step-label{display:flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:600;font-size:1.05rem;margin-bottom:16px;color:#fff}
.matcher__step-label .num{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:var(--water);color:#fff;font-size:.85rem;flex:none}
.chip-row{display:flex;flex-wrap:wrap;gap:12px}
.chip{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);color:#fff;border-radius:var(--radius-pill);padding:11px 20px;font-family:var(--font-body);font-weight:500;font-size:.95rem;cursor:pointer;transition:background .3s var(--ease-premium),border-color .3s,transform .3s var(--ease-premium)}
.chip svg{width:18px;height:18px;color:var(--water-light);transition:color .3s}
.chip:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.4)}
.chip.is-active{background:#fff;color:var(--primary-deep);border-color:#fff}
.chip.is-active svg{color:var(--lawn-deep)}
.matcher__result{margin-top:34px;border-top:1px solid rgba(255,255,255,.14);padding-top:30px;display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;opacity:0;transform:translateY(14px);transition:opacity .5s var(--ease-premium),transform .5s var(--ease-premium)}
.matcher__result.is-shown{opacity:1;transform:none}
.matcher__result-icon{width:66px;height:66px;border-radius:18px;background:rgba(255,255,255,.1);display:grid;place-items:center;color:var(--water-light);flex:none}
.matcher__result-icon svg{width:34px;height:34px}
.matcher__result h3{color:#fff;font-size:1.5rem;margin-bottom:.25em}
.matcher__result p{color:rgba(255,255,255,.74);margin:0;max-width:48ch}
.matcher__result .btn{flex:none;white-space:nowrap}
.matcher__hint{text-align:center;color:rgba(255,255,255,.5);font-size:.9rem;margin-top:22px}
@media (max-width:720px){.matcher__result{grid-template-columns:1fr;text-align:center}.matcher__result-icon{margin:0 auto}.matcher__result p{margin-inline:auto}}

/* ============================================================================
   5. BEFORE / AFTER — dry → lush drag slider
   ============================================================================ */
.ba{position:relative;overflow:hidden}
.ba .container{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(32px,5vw,68px);align-items:center}
.ba__copy h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
.ba__list{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:14px}
.ba__list li{display:flex;gap:14px;align-items:flex-start;color:var(--ink-60)}
.ba__list svg{width:22px;height:22px;color:var(--lawn);flex:none;margin-top:2px}
.ba__list b{color:var(--foreground);font-weight:600}
.ba__slider{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:3/2;user-select:none;cursor:ew-resize;touch-action:none}
.ba__layer{position:absolute;inset:0;width:100%;height:100%}
.ba__layer img{width:100%;height:100%;object-fit:cover}
.ba__after{clip-path:inset(0 0 0 50%)}
.ba__label{position:absolute;top:16px;font-family:var(--font-head);font-weight:600;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(8,30,58,.55);backdrop-filter:blur(6px);padding:6px 13px;border-radius:var(--radius-pill);z-index:3}
.ba__label--before{left:16px}
.ba__label--after{right:16px;background:color-mix(in srgb,var(--lawn-deep) 85%,transparent)}
.ba__handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;z-index:4;transform:translateX(-50%);box-shadow:0 0 0 1px rgba(14,58,112,.1)}
.ba__grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:50%;background:#fff;display:grid;place-items:center;box-shadow:0 10px 26px -8px rgba(14,58,112,.6)}
.ba__grip svg{width:24px;height:24px;color:var(--primary)}
@media (max-width:820px){.ba .container{grid-template-columns:1fr}}

/* ============================================================================
   6. PROCESS — seasonal timeline
   ============================================================================ */
.process{background:var(--surface-2);position:relative;overflow:hidden}
.process .watermark{bottom:-3vw;left:-1vw;font-size:clamp(7rem,18vw,16rem)}
.process__head{text-align:center;max-width:620px;margin:0 auto 60px;position:relative;z-index:1}
.process__head .kicker{justify-content:center}
.timeline{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;z-index:1}
.timeline::before{content:"";position:absolute;top:38px;left:9%;right:9%;height:2px;background:linear-gradient(90deg,var(--lawn),var(--water),var(--primary),var(--water));border-radius:2px;z-index:0}
.tstep{position:relative;text-align:center;padding-top:0}
.tstep__dot{width:78px;height:78px;border-radius:50%;background:#fff;border:2px solid var(--border);display:grid;place-items:center;margin:0 auto 22px;position:relative;z-index:1;color:var(--primary);transition:transform .4s var(--ease-premium),border-color .4s,color .4s}
.tstep__dot svg{width:36px;height:36px}
.tstep:hover .tstep__dot{transform:translateY(-5px) scale(1.05);border-color:var(--water);color:var(--water)}
.tstep__season{font-family:var(--font-head);font-weight:600;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--lawn-deep);margin-bottom:8px}
.tstep h3{font-size:1.2rem;margin-bottom:.4em}
.tstep p{color:var(--ink-60);font-size:.95rem;max-width:26ch;margin-inline:auto}
@media (max-width:820px){.timeline{grid-template-columns:1fr 1fr}.timeline::before{display:none}}
@media (max-width:480px){.timeline{grid-template-columns:1fr}}

/* ============================================================================
   7. SMART TECH + FOUNDER authority
   ============================================================================ */
.tech{position:relative;overflow:hidden}
.tech .container{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:center}
.tech__visual{position:relative;border-radius:var(--radius);background:linear-gradient(160deg,#0E3A70,#155e9e);padding:clamp(30px,4vw,52px);color:#fff;overflow:hidden;box-shadow:var(--shadow)}
.tech__visual::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 60% at 90% 10%,rgba(95,203,230,.3),transparent 60%);pointer-events:none}
.controller{position:relative;z-index:1;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-sm);padding:24px;backdrop-filter:blur(8px)}
.controller__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.controller__top b{font-family:var(--font-head);font-weight:600;font-size:1.05rem}
.controller__status{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;color:var(--water-light)}
.controller__status i{width:8px;height:8px;border-radius:50%;background:var(--lawn);box-shadow:0 0 0 0 rgba(116,180,60,.6);animation:livePulse 2s infinite}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(116,180,60,.5)}70%{box-shadow:0 0 0 9px rgba(116,180,60,0)}100%{box-shadow:0 0 0 0 rgba(116,180,60,0)}}
@media (prefers-reduced-motion:reduce){.controller__status i{animation:none}}
.zone-row{display:flex;align-items:center;gap:14px;padding:13px 0;border-top:1px solid rgba(255,255,255,.1)}
.zone-row svg{width:20px;height:20px;color:var(--water-light);flex:none}
.zone-row span{flex:1;font-size:.92rem;color:rgba(255,255,255,.85)}
.zone-bar{width:84px;height:6px;border-radius:3px;background:rgba(255,255,255,.14);overflow:hidden}
.zone-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--water-light),var(--lawn));border-radius:3px}
.zone-row b{font-size:.82rem;color:var(--water-light);width:42px;text-align:right}
.tech__copy h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
.tech__feats{list-style:none;padding:0;margin:26px 0 0;display:flex;flex-direction:column;gap:18px}
.tech__feats li{display:flex;gap:16px;align-items:flex-start}
.tech__feats .ti{width:46px;height:46px;border-radius:13px;background:var(--surface-2);display:grid;place-items:center;color:var(--primary);flex:none}
.tech__feats .ti svg{width:24px;height:24px}
.tech__feats b{display:block;font-family:var(--font-head);font-weight:600;font-size:1.05rem}
.tech__feats span{color:var(--ink-60);font-size:.95rem}
@media (max-width:820px){.tech .container{grid-template-columns:1fr}}

/* founder block */
.founder{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:clamp(30px,4vw,50px);margin-top:clamp(40px,6vw,72px);display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,4vw,44px);align-items:center;position:relative;overflow:hidden}
.founder::before{content:"";position:absolute;top:0;left:0;width:5px;height:100%;background:linear-gradient(var(--water),var(--lawn))}
.founder__sig{width:120px;height:120px;border-radius:50%;background:linear-gradient(160deg,#0E3A70,#1FA9CE);display:grid;place-items:center;color:#fff;font-family:var(--font-head);font-weight:600;font-size:2.4rem;flex:none;box-shadow:0 18px 36px -16px rgba(14,58,112,.5)}
.founder__quote{font-family:var(--font-head);font-weight:500;font-size:clamp(1.2rem,2.2vw,1.7rem);line-height:1.4;letter-spacing:-.01em;color:var(--foreground);font-style:italic;margin:0 0 18px}
.founder__by b{font-family:var(--font-head);font-weight:600;display:block}
.founder__by span{color:var(--ink-60);font-size:.92rem}
@media (max-width:560px){.founder{grid-template-columns:1fr;text-align:center}.founder__sig{margin:0 auto}}

/* ============================================================================
   8. STATS band
   ============================================================================ */
.stats{background:linear-gradient(120deg,#0E3A70,#103e78);color:#fff;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 30h60M30 0v60' stroke='%23ffffff' stroke-opacity='.04' stroke-width='1'/%3E%3C/svg%3E");pointer-events:none}
.stats .container{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative;z-index:1;text-align:center}
.stat{position:relative;padding:10px}
.stat:not(:last-child)::after{content:"";position:absolute;right:-16px;top:18%;height:64%;width:1px;background:rgba(255,255,255,.14)}
.stat b{font-family:var(--font-head);font-weight:600;font-size:clamp(2.6rem,5vw,3.8rem);line-height:1;display:block;color:#fff}
.stat b .u{color:var(--water-light);font-size:.6em}
.stat span{font-size:.92rem;color:rgba(255,255,255,.66);margin-top:8px;display:block}
@media (max-width:720px){.stats .container{grid-template-columns:1fr 1fr;gap:36px 16px}.stat:nth-child(2)::after{display:none}}

/* ============================================================================
   9. TESTIMONIALS — real reviews
   ============================================================================ */
.reviews{position:relative;overflow:hidden}
.reviews .watermark{top:-1vw;left:-1vw;font-size:clamp(7rem,18vw,15rem)}
.reviews__head{text-align:center;max-width:620px;margin:0 auto 54px;position:relative;z-index:1}
.reviews__head .kicker{justify-content:center}
.review-grid{columns:3;column-gap:22px;position:relative;z-index:1}
.review{break-inside:avoid;margin-bottom:22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;position:relative;transition:transform .4s var(--ease-premium),box-shadow .4s}
.review:hover{transform:translateY(-4px);box-shadow:0 24px 50px -30px rgba(14,58,112,.4)}
.review__stars{display:flex;gap:3px;margin-bottom:14px;color:var(--lawn)}
.review__stars svg{width:18px;height:18px}
.review__quote{font-size:1.02rem;line-height:1.6;color:var(--foreground);margin:0 0 18px}
.review__by{display:flex;align-items:center;gap:12px}
.review__av{width:42px;height:42px;border-radius:50%;background:linear-gradient(150deg,var(--water),var(--primary));color:#fff;display:grid;place-items:center;font-family:var(--font-head);font-weight:600;flex:none}
.review__by b{display:block;font-family:var(--font-head);font-weight:600;font-size:.98rem;line-height:1.1}
.review__by span{font-size:.85rem;color:var(--ink-60)}
.review__svc{position:absolute;top:24px;right:24px;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--water);opacity:.8}
@media (max-width:900px){.review-grid{columns:2}}
@media (max-width:560px){.review-grid{columns:1}}

/* ============================================================================
   10. SERVICE AREAS
   ============================================================================ */
.areas{background:var(--surface-2);position:relative;overflow:hidden}
.areas .container{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,5vw,72px);align-items:center}
.areas__copy h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
.areas__map{position:relative;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:clamp(24px,3vw,40px);box-shadow:0 24px 60px -34px rgba(14,58,112,.4)}
.areas__map svg{width:100%;height:auto;display:block}
.region-dot{cursor:pointer}
.region-dot circle{transition:r .3s var(--ease-premium),fill .3s}
.region-dot:hover circle.pulse{r:18}
.areas__legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.areas__legend .area-pill{cursor:default}
@media (max-width:820px){.areas .container{grid-template-columns:1fr}}

/* ============================================================================
   11. FAQ
   ============================================================================ */
.faq{position:relative}
.faq .container{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(36px,5vw,72px);align-items:start}
.faq__aside{position:sticky;top:120px}
.faq__aside h2{font-size:clamp(1.9rem,3.6vw,2.8rem)}
.faq__aside p{color:var(--ink-60)}
.faq__aside .btn{margin-top:18px}
.faq-list details{border-bottom:1px solid var(--border);padding:6px 0}
.faq-list summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:22px 4px;font-family:var(--font-head);font-weight:600;font-size:1.12rem;color:var(--foreground);transition:color .3s}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary:hover{color:var(--primary)}
.faq-list summary .q-ico{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);display:grid;place-items:center;flex:none;transition:transform .4s var(--ease-premium),background .3s,border-color .3s,color .3s;color:var(--primary)}
.faq-list summary .q-ico svg{width:16px;height:16px}
.faq-list details[open] summary .q-ico{transform:rotate(45deg);background:var(--primary);border-color:var(--primary);color:#fff}
.faq-list details p{color:var(--ink-60);padding:0 4px 24px;margin:0;max-width:60ch;animation:faqIn .4s var(--ease-premium)}
@keyframes faqIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
@media (max-width:820px){.faq .container{grid-template-columns:1fr}.faq__aside{position:static}}

/* ============================================================================
   12. CONTACT / quote
   ============================================================================ */
.contact{background:linear-gradient(165deg,#0E3A70,#124b8b 60%,#0E3A70);color:#fff;position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 88% 6%,rgba(95,203,230,.2),transparent 60%),radial-gradient(50% 60% at 4% 100%,rgba(116,180,60,.16),transparent 60%);pointer-events:none}
.contact .container{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center;position:relative;z-index:1}
.contact__copy .kicker{color:var(--water-light)}
.contact__copy h2{color:#fff;font-size:clamp(2rem,4vw,3.2rem)}
.contact__copy p{color:rgba(255,255,255,.76);max-width:46ch}
.contact__lines{list-style:none;padding:0;margin:32px 0 0;display:flex;flex-direction:column;gap:18px}
.contact__lines li{display:flex;align-items:center;gap:16px}
.contact__lines .ci{width:48px;height:48px;border-radius:13px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);display:grid;place-items:center;color:var(--water-light);flex:none}
.contact__lines .ci svg{width:22px;height:22px}
.contact__lines b{display:block;font-family:var(--font-head);font-weight:600;font-size:1.05rem;color:#fff}
.contact__lines a{color:rgba(255,255,255,.85)}.contact__lines a:hover{color:#fff}
.contact__lines span{font-size:.86rem;color:rgba(255,255,255,.55)}
.quote-card{background:#fff;border-radius:var(--radius);padding:clamp(28px,4vw,44px);box-shadow:0 40px 80px -30px rgba(0,0,0,.5);color:var(--foreground)}
.quote-card h3{font-size:1.5rem;margin-bottom:.3em}
.quote-card>p{color:var(--ink-60);margin-bottom:24px}
.quote-card .field input,.quote-card .field textarea,.quote-card .field select{background:var(--surface-2);border-color:var(--border)}
.quote-card .field select{padding:12px 14px;border-radius:var(--radius-sm);font:inherit;color:var(--foreground);appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23134A8E' stroke-width='2'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.quote-card .btn{width:100%;justify-content:center;margin-top:6px}
.quote-card .form-note{font-size:.82rem;color:var(--ink-40);margin-top:14px;text-align:center}
@media (max-width:820px){.contact .container{grid-template-columns:1fr}}

/* ============================================================================
   Header brand logo / footer richness
   ============================================================================ */
.brand{display:inline-flex;align-items:center;gap:12px}
.brand img{height:38px;width:auto;display:block}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__txt b{font-family:var(--font-head);font-weight:600;font-size:1.05rem;color:var(--foreground)}
.brand__txt span{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-40)}
.header-cta{display:inline-flex;align-items:center;gap:9px;background:var(--primary);color:#fff !important;padding:10px 20px;border-radius:var(--radius-pill);font-family:var(--font-head);font-weight:600;font-size:.92rem;transition:transform .3s var(--ease-premium),box-shadow .3s}
.header-cta:hover{transform:translateY(-2px);box-shadow:0 10px 24px -8px var(--primary);color:#fff !important}
.header-cta svg{width:16px;height:16px}
.nav-desktop{display:flex;gap:26px;align-items:center}
@media (max-width:980px){.header-cta{display:none}}

.site-footer{background:#0B2A50;color:rgba(255,255,255,.7);border-top:0;padding-top:clamp(60px,8vw,90px)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;width:100%}
.footer-brand img{height:42px;margin-bottom:18px}
.footer-brand p{font-size:.92rem;color:rgba(255,255,255,.55);max-width:32ch}
.footer-social{display:flex;gap:12px;margin-top:20px}
.footer-social a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;color:rgba(255,255,255,.7);transition:background .3s,color .3s,border-color .3s,transform .3s}
.footer-social a:hover{background:var(--water);border-color:var(--water);color:#fff;transform:translateY(-2px)}
.footer-social svg{width:17px;height:17px}
.footer-col h4{font-family:var(--font-head);font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:18px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px}
.footer-col a{color:rgba(255,255,255,.62);font-size:.94rem}.footer-col a:hover{color:#fff}
.footer-contact b{color:#fff;font-family:var(--font-head);font-size:1.2rem}
.footer-bottom{width:100%;border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding-top:26px;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;font-size:.84rem;color:rgba(255,255,255,.45)}
.footer-bottom a{color:rgba(255,255,255,.55)}.footer-bottom a:hover{color:#fff}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ============================================================================
   Page-hero (inner pages) — lighter than homepage
   ============================================================================ */
.page-hero{position:relative;background:linear-gradient(160deg,#0E3A70,#155e9e);color:#fff;overflow:hidden;padding:clamp(120px,16vw,180px) 0 clamp(50px,7vw,80px)}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 80% at 80% 0%,rgba(95,203,230,.3),transparent 60%);pointer-events:none}
.page-hero__ripple{position:absolute;inset:0;opacity:.4;z-index:0}
.page-hero .container{position:relative;z-index:1}
.page-hero .kicker{color:var(--water-light)}
.page-hero h1{color:#fff;font-size:clamp(2.4rem,5.5vw,4rem);max-width:18ch}
.page-hero p{color:rgba(255,255,255,.8);max-width:56ch;font-size:clamp(1.05rem,1.5vw,1.25rem)}
.breadcrumbs{display:flex;gap:8px;align-items:center;font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:22px}
.breadcrumbs a{color:rgba(255,255,255,.78)}.breadcrumbs a:hover{color:#fff}
.breadcrumbs svg{width:13px;height:13px;opacity:.5}

/* inner content blocks */
.prose{max-width:72ch}
.prose h2{margin-top:1.6em}
.prose p{color:var(--ink-60)}
.prose ul{padding-left:0;list-style:none;display:flex;flex-direction:column;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{width:20px;height:20px;color:var(--lawn);flex:none;margin-top:3px}

/* quick-answer + key facts (AEO) */
.quick-answer{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--lawn);border-radius:var(--radius-sm);padding:24px 28px;margin-bottom:36px}
.quick-answer .qa-label{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:600;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--lawn-deep);margin-bottom:10px}
.quick-answer p{margin:0;font-size:1.08rem;color:var(--foreground)}
.keyfacts{width:100%;border-collapse:collapse;margin:28px 0;font-size:.96rem}
.keyfacts th,.keyfacts td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--border)}
.keyfacts th{font-family:var(--font-head);font-weight:600;color:var(--primary);width:38%;background:var(--surface-2)}
.keyfacts td{color:var(--ink-60)}

/* generic two-col content section */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover}
@media (max-width:820px){.split{grid-template-columns:1fr}}

/* service detail cards row */
.mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:32px}
.mini-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px}
.mini-card .svc__icon{margin-bottom:18px}
.mini-card h3{font-size:1.15rem;margin-bottom:.4em}
.mini-card p{color:var(--ink-60);font-size:.94rem;margin:0}

/* CTA band reusable */
.cta-band{background:linear-gradient(120deg,#0E3A70,#155e9e);color:#fff;border-radius:var(--radius);padding:clamp(36px,5vw,60px);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 80% 0%,rgba(95,203,230,.25),transparent 60%);pointer-events:none}
.cta-band h2{color:#fff;position:relative;z-index:1}
.cta-band p{color:rgba(255,255,255,.78);max-width:48ch;margin:0 auto 26px;position:relative;z-index:1}
.cta-band .hero__cta{justify-content:center;position:relative;z-index:1}
.cta-band .btn--ghost{color:#fff;border-color:rgba(255,255,255,.3)}
.cta-band .btn--ghost:hover{background:rgba(255,255,255,.1);border-color:#fff;color:#fff}

/* reveal helpers */
[data-reveal]{will-change:opacity,transform}
.btn--lawn{background:var(--lawn);color:#fff}
.btn--lawn:hover{background:var(--lawn-deep);transform:translateY(-2px);box-shadow:0 10px 30px -8px var(--lawn)}
.btn--white{background:#fff;color:var(--primary-deep)}
.btn--white:hover{transform:translateY(-2px);box-shadow:0 12px 30px -10px rgba(0,0,0,.4)}
