/* ==========================================================================
   Watertech Heating — underfloor heating LP (Summit demo, noindex)
   DESIGN LANGUAGE: high-fidelity replication of the Nu-Heat UFH hub
   (square photography, squared UPPERCASE buttons, huge confident centred
   headlines, airy white bands), reskinned to Watertech's brand
   (navy #1B2646 + brand blue #005BAC + cyan #38B7EA waves) and to UFH content.
   Brand hex sampled exact from assets-company/watertech_logo.jpg.
   Engineering (modal funnel, attribution, carousel, map, drawer) preserved.
   ========================================================================== */
@font-face{font-family:"Geist";src:url("assets/fonts/geist-latin.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/inter-latin.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}

:root{
  /* Watertech brand (sampled from the logo) */
  --navy:#1B2646; --navy-2:#222F52; --navy-line:#34406A;
  --blue:#005BAC;            /* primary CTA / links — 6.8:1 on white (AA) */
  --blue-deep:#004986;       /* hover */
  --blue-press:#003C70;
  --cyan:#38B7EA;            /* light accent — DARK grounds only (fails AA on white) */
  --teal:#136891;            /* deep secondary accent */

  /* Ink — warm charcoal body per the Nu-Heat spec (premium warm neutral) */
  --ink:#3E3B39;             /* body */
  --ink-soft:#5C5854;        /* muted body */
  --ink-mute:#6E6B66;        /* meta / captions — AA (≥4.5:1 on white & mist) */
  --head:#1B2646;            /* headings = brand navy (Nu-Heat puts brand colour on heads) */

  /* Grounds — mostly white; rhythm from bands + spacing, not coloured walls */
  --paper:#fff;
  --mist:#F5F6F8;            /* faint cool-grey alternate band */
  --warm:#F7F5F2;            /* faint warm alternate band */
  --line:#E5E4E1;            /* warm hairline */
  --line-2:#D6D5D1;

  --r:3px;                   /* squared corners — the signature */
  --r-img:0px;               /* photography is square-cornered */
  --wrap:1180px;
  --pad:clamp(20px,4vw,40px);
  --gap:clamp(18px,2.4vw,30px);
  --sec:clamp(60px,8vw,108px); /* generous, airy band rhythm */
  --shadow-card:0 1px 2px rgba(27,38,70,.05),0 8px 26px rgba(27,38,70,.07);
  --shadow-lift:0 10px 30px rgba(27,38,70,.13),0 3px 10px rgba(27,38,70,.07);
  --font:"Geist","Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--paper);overflow-x:clip;
  font-size:1.0625rem;line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;color:var(--head);font-weight:700;line-height:1.08;letter-spacing:-.02em}
p{margin:0}
ul,ol{margin:0;padding:0;list-style:none}
button{font:inherit}
:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:2px}
.container{max-width:var(--wrap);margin:0 auto;padding-inline:var(--pad)}
.container--wide{max-width:1320px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:fixed;left:12px;top:-60px;z-index:200;background:var(--blue);color:#fff;padding:10px 16px;border-radius:var(--r);font-weight:700;transition:top .15s}
.skip-link:focus{top:12px}
.hl{color:var(--blue)}            /* headline highlight on light grounds */
.hl--bright{color:var(--cyan)}    /* headline highlight on dark grounds */

/* ---------- Buttons: squared, UPPERCASE, letter-spaced (the Nu-Heat signature) ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  padding:1rem 1.9rem;border-radius:var(--r);border:1.6px solid transparent;
  font-weight:700;font-size:.82rem;letter-spacing:.07em;text-transform:uppercase;
  cursor:pointer;line-height:1.1;white-space:nowrap;
  transition:background .16s,border-color .16s,color .16s,transform .1s,box-shadow .16s}
.btn svg{flex:none;transition:transform .16s}
.btn:hover svg[aria-hidden]{transform:translateX(3px)}
.btn--sm{padding:.7rem 1.2rem;font-size:.75rem}
.btn--lg{padding:1.15rem 2.3rem;font-size:.86rem}
.btn--primary{background:var(--blue);color:#fff}
.btn--primary:hover{background:var(--blue-deep)}
.btn--primary:active{background:var(--blue-press);transform:translateY(1px)}
.btn--outline{background:transparent;border-color:var(--blue);color:var(--blue)}
.btn--outline:hover{background:var(--blue);color:#fff}
.btn--dark{background:var(--navy);color:#fff}
.btn--dark:hover{background:#10182E}
/* On dark/photo grounds: white solid + brand-blue text (per spec) */
.btn--light{background:#fff;color:var(--blue)}
.btn--light:hover{background:#EAF2FA}
.btn--ghost-light{background:transparent;border-color:rgba(255,255,255,.65);color:#fff}
.btn--ghost-light:hover{background:rgba(255,255,255,.12);border-color:#fff}
/* Plain uppercase text-link with arrow */
.btn--text{background:none;border:none;color:var(--blue);font-weight:700;font-size:.78rem;
  letter-spacing:.07em;text-transform:uppercase;padding:.5em 0;gap:.45em}
.btn--text:hover{color:var(--blue-deep)}
.btn--google{background:#fff;border-color:var(--line-2);color:var(--ink);text-transform:none;letter-spacing:.01em;font-size:.92rem;gap:.55rem}
.btn--google:hover{border-color:var(--blue);color:var(--blue)}
.btn--google img{flex:none}

/* ---------- Section heads (centred, Nu-Heat style) ---------- */
.section{padding-block:var(--sec)}
.section--mist{background:var(--mist)}
.section--warm{background:var(--warm)}
.section-head{max-width:760px;margin:0 auto clamp(34px,4.6vw,56px);text-align:center}
.section-head--left{margin-inline:0;text-align:left}
.eyebrow{display:inline-block;color:var(--blue);font-weight:700;font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;margin-bottom:.9rem}
.eyebrow--light{color:var(--cyan)}
h2{font-size:clamp(2rem,3.8vw,3rem)}
.section-head h2{font-size:clamp(2rem,3.8vw,3rem)}
.section-sub{margin-top:1.1rem;color:var(--ink-soft);font-size:clamp(1.05rem,1.4vw,1.2rem);line-height:1.6}
.section-head .section-sub{max-width:62ch;margin-inline:auto}

/* ==========================================================================
   STICKY TOP — slim navy reviews bar + clean white header (no jump-nav)
   ========================================================================== */
.site-top{position:sticky;top:0;z-index:100}
.topbar{background:var(--navy);color:#CFD9EC}
.topbar__row{display:flex;align-items:center;justify-content:center;gap:.55rem;min-height:34px;
  padding-block:6px;font-size:.84rem;font-weight:600;flex-wrap:wrap}
.topbar__g{flex:none;background:#fff;border-radius:50%;padding:2px}
.topbar__stars{display:inline-flex;color:#F6B01E}
.topbar__txt b{color:#fff;font-weight:700}
.topbar__txt--muted{color:#93A2C2}
.topbar__sep{color:#3C4A6E}
.site-header{background:rgba(255,255,255,.96);backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--line);transition:box-shadow .2s,background .2s}
.site-header.scrolled{box-shadow:0 4px 18px rgba(27,38,70,.08);background:rgba(255,255,255,.99)}
.site-header__row{display:flex;align-items:center;gap:1.1rem;min-height:74px}
.brand{display:flex;align-items:center}
/* Logo is a white-on-navy lockup → present as a navy chip on the light header */
.brand__logo{height:52px;width:auto;background:var(--navy);border-radius:var(--r);padding:7px 11px}
.nav{display:flex;gap:.1rem;margin-left:1.4rem}
.nav a{padding:.5rem .8rem;border-radius:var(--r);font-weight:600;color:var(--ink);font-size:.95rem;transition:color .15s,background .15s}
.nav a:hover{color:var(--blue);background:var(--mist)}
.site-header__actions{margin-left:auto;display:flex;align-items:center;gap:1rem}
.header-call{display:inline-flex;align-items:center;gap:.5rem;color:var(--head);font-weight:700}
.header-call svg{color:var(--blue);flex:none}
.header-call span{display:flex;flex-direction:column;line-height:1.05;font-size:1.02rem}
.header-call small{font-weight:600;color:var(--ink-mute);font-size:.66rem;letter-spacing:.03em;text-transform:uppercase}
.header-quote{display:none}
.menu-btn{display:none;align-items:center;gap:.5rem;background:#fff;color:var(--head);
  border:1.6px solid var(--line-2);border-radius:var(--r);padding:.55rem .85rem;
  font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;
  transition:border-color .15s,background .15s,color .15s}
.menu-btn:hover{border-color:var(--blue);color:var(--blue)}
.menu-btn__bars{position:relative;width:18px;height:12px;flex:none}
.menu-btn__bars::before,.menu-btn__bars::after,.menu-btn__bars{content:""}
.menu-btn__bars{background:linear-gradient(currentColor,currentColor) left center/18px 2px no-repeat}
.menu-btn__bars::before,.menu-btn__bars::after{content:"";position:absolute;left:0;width:18px;height:2px;background:currentColor;border-radius:2px}
.menu-btn__bars::before{top:0}.menu-btn__bars::after{bottom:0}

/* ---------- Nav drawer (mobile / tablet) ---------- */
.navdrawer{position:fixed;inset:0;z-index:150;visibility:hidden;transition:visibility 0s linear .3s}
.navdrawer.is-open{visibility:visible;transition:visibility 0s}
.navdrawer__backdrop{position:absolute;inset:0;background:rgba(11,16,30,.55);opacity:0;transition:opacity .3s ease}
.navdrawer.is-open .navdrawer__backdrop{opacity:1}
.navdrawer__panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,340px);background:#fff;
  box-shadow:-14px 0 44px rgba(11,16,30,.24);display:flex;flex-direction:column;overflow-y:auto;
  padding:16px 20px calc(22px + env(safe-area-inset-bottom));
  transform:translateX(100%);transition:transform .3s cubic-bezier(.22,1,.36,1)}
.navdrawer.is-open .navdrawer__panel{transform:translateX(0)}
.navdrawer__head{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px;margin-bottom:6px;border-bottom:1px solid var(--line)}
.navdrawer__title{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute)}
.navdrawer__close{display:grid;place-items:center;background:none;border:none;cursor:pointer;color:var(--head);width:40px;height:40px;margin:-8px -8px -8px 0;border-radius:var(--r);transition:background .15s,color .15s}
.navdrawer__close:hover{background:var(--mist);color:var(--blue)}
.navdrawer__links{display:flex;flex-direction:column;margin:4px 0 auto}
.navdrawer__links a{display:block;padding:.95rem .3rem;font-weight:700;font-size:1.1rem;color:var(--head);
  letter-spacing:-.01em;border-bottom:1px solid var(--line);transition:color .15s}
.navdrawer__links a:hover{color:var(--blue)}
.navdrawer__cta{display:flex;flex-direction:column;gap:12px;margin-top:22px}
.navdrawer__cta .btn{width:100%}
.navdrawer__call{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:700;color:var(--head);padding:.55rem}
.navdrawer__call svg{color:var(--blue);flex:none}

/* ==========================================================================
   HERO — full-bleed genuine UFH photo, huge centred Geist headline
   ========================================================================== */
.hero{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;
  background:var(--navy);min-height:clamp(600px,90vh,860px);text-align:center}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 42%}
.hero__scrim{position:absolute;inset:0;pointer-events:none;background:
  linear-gradient(180deg,rgba(9,13,28,.66) 0%,rgba(9,13,28,.50) 28%,rgba(9,13,28,.58) 62%,rgba(9,13,28,.82) 100%),
  radial-gradient(86% 72% at 50% 46%,rgba(9,13,28,.58) 0%,rgba(9,13,28,.20) 64%,transparent 100%)}
.hero__inner{position:relative;z-index:2;width:100%;padding-block:clamp(56px,9vw,112px)}
.hero__content{max-width:920px;margin:0 auto;color:#fff;padding-inline:var(--pad)}
.hero__title{font-size:clamp(2.7rem,7vw,5.4rem);line-height:1.02;letter-spacing:-.022em;color:#fff;
  text-shadow:0 2px 10px rgba(0,0,0,.45),0 4px 36px rgba(0,0,0,.4)}
.hero__title .hl{color:var(--cyan)}
.hero__sub{margin:1.85rem auto 0;font-size:clamp(1.12rem,1.5vw,1.4rem);line-height:1.55;color:#EEF1F7;
  max-width:34ch;text-shadow:0 1px 3px rgba(0,0,0,.55),0 2px 18px rgba(0,0,0,.45)}
.hero__cta{margin-top:2.5rem;display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center}
.hero__cta .btn--light{box-shadow:0 12px 30px rgba(0,0,0,.3)}

/* ==========================================================================
   ALTERNATING TEXT ↔ SQUARE IMAGE BANDS
   ========================================================================== */
.band{padding-block:var(--sec)}
.band__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,72px);align-items:center}
.band--rev .band__media{order:-1}
.band__copy .eyebrow{margin-bottom:.8rem}
.band__copy h2{font-size:clamp(1.9rem,3.3vw,2.7rem)}
.band__copy>p{margin-top:1.2rem;color:var(--ink-soft);font-size:1.08rem;line-height:1.66;max-width:42em}
.band__copy>p b{color:var(--ink)}
.band__points{margin-top:1.5rem;display:flex;flex-direction:column;gap:.95rem}
.band__points li{display:flex;align-items:flex-start;gap:.7rem;font-size:1.02rem;color:var(--ink-soft)}
.band__points b{color:var(--ink)}
.band__points svg{color:#fff;background:var(--blue);border-radius:50%;padding:4px;flex:none;margin-top:2px}
.band__cta{margin-top:1.9rem;display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}
/* Square photography */
.band__media{position:relative;overflow:hidden;border-radius:var(--r-img);align-self:stretch;min-height:340px}
.band__media img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/3}
.band__cap{position:absolute;left:0;bottom:0;right:0;padding:18px 22px;color:#fff;font-weight:700;font-size:1rem;
  background:linear-gradient(0deg,rgba(11,18,40,.86),transparent)}
.band__cap .eyebrow{display:block;color:var(--cyan);margin-bottom:.2rem}

/* ==========================================================================
   CARD GRIDS — square "media block + caption" cards (honest, no stock)
   Media block uses a brand navy→blue panel with a large monoline icon,
   matching Nu-Heat's photo-card geometry without inventing imagery.
   ========================================================================== */
.cards{display:grid;gap:var(--gap)}
.cards--4{grid-template-columns:repeat(4,1fr)}
.cards--3{grid-template-columns:repeat(3,1fr)}
.card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;transition:box-shadow .18s,transform .18s,border-color .18s}
.card:hover{box-shadow:var(--shadow-lift);transform:translateY(-3px);border-color:var(--line-2)}
.card__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--navy)}
.card__media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.22,1,.36,1)}
.card:hover .card__media img{transform:scale(1.045)}
.card__tag{position:absolute;z-index:2;top:12px;left:12px;background:var(--cyan);color:#07243A;
  font-size:.64rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:.3rem .55rem;border-radius:2px;
  box-shadow:0 2px 8px rgba(0,0,0,.28)}
.card__num{position:absolute;z-index:2;top:12px;left:12px;width:44px;height:44px;border-radius:50%;
  background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:700;font-size:1.2rem;
  border:3px solid #fff;box-shadow:0 4px 14px rgba(9,13,28,.3)}
.card__body{display:flex;flex-direction:column;flex:1;padding:22px 22px 24px}
.card__body h3{font-size:1.35rem;line-height:1.15}
.card__kicker{font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);margin-top:.45rem}
.card__body p{margin-top:.6rem;color:var(--ink-soft);font-size:.98rem;line-height:1.55;flex:1}
.card__specs{margin-top:1rem;display:flex;flex-direction:column;gap:.45rem}
.card__specs li{display:flex;align-items:flex-start;gap:.5rem;font-size:.9rem;color:var(--ink-soft)}
.card__specs svg{color:var(--teal);flex:none;margin-top:2px}
.card__link{margin-top:1.1rem}

/* small note + secondary line under the systems grid */
.note{margin-top:clamp(24px,3vw,34px);text-align:center;font-size:1.02rem;color:var(--ink-soft)}
.note b{color:var(--head)}
.also{margin-top:clamp(18px,2.2vw,26px);display:flex;align-items:center;justify-content:center;gap:.7rem;flex-wrap:wrap;
  font-size:.96rem;color:var(--ink-mute);text-align:center}
.also b{color:var(--ink)}
.also svg{color:var(--blue);flex:none}

/* ==========================================================================
   CTA BAND (navy anchor)
   ========================================================================== */
.ctaband{background:var(--navy);position:relative;overflow:hidden}
.ctaband::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(56,183,234,.18),transparent 70%);pointer-events:none}
.ctaband__inner{position:relative;z-index:1;padding-block:clamp(46px,6vw,80px);text-align:center;display:flex;flex-direction:column;align-items:center}
.ctaband .eyebrow{color:var(--cyan)}
.ctaband h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.8rem);max-width:18ch}
.ctaband p{margin-top:1rem;color:#D3DBEC;font-size:1.1rem;max-width:54ch}
.ctaband__btns{margin-top:2rem;display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center}

/* ==========================================================================
   PROCESS — photo-backed numbered step cards
   ========================================================================== */
.proccards .card__media{background:var(--navy)}
.journey__cta{margin-top:clamp(36px,4.4vw,52px);display:flex;justify-content:center;gap:.9rem;flex-wrap:wrap}

/* ==========================================================================
   REVIEWS — real Google rating + carousel (engineering preserved)
   ========================================================================== */
.reviews__head{display:grid;grid-template-columns:1fr auto;gap:clamp(22px,3vw,44px);align-items:center;margin-bottom:clamp(28px,3.6vw,44px)}
.reviews__head .eyebrow{margin-bottom:.7rem}
.reviews__head h2{font-size:clamp(1.9rem,3.2vw,2.7rem)}
.reviews__head .section-sub{margin-top:.8rem;max-width:42em}
.reviews__badge{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px 24px;text-align:center;min-width:196px}
.reviews__badge img{height:30px;width:auto;margin:0 auto .5rem}
.reviews__stars{display:flex;justify-content:center;color:#F6B01E;gap:1px}
.reviews__score{margin-top:.4rem;font-size:.92rem;color:var(--ink-mute);font-weight:600}
.reviews__score b{color:var(--head);font-size:1.06rem;font-weight:700}
.rcarousel{position:relative;display:flex;align-items:stretch;gap:12px}
.rcarousel__track{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:4px 2px 14px;flex:1;scrollbar-width:none}
.rcarousel__track::-webkit-scrollbar{display:none}
.rcard{scroll-snap-align:start;flex:0 0 clamp(280px,33%,360px);background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:26px 24px 22px;display:flex;flex-direction:column;position:relative}
.rcard--featured{flex-basis:clamp(300px,44%,470px);background:var(--navy);border-color:transparent;color:#fff}
.rcard__quote{position:absolute;top:18px;right:20px;color:var(--line-2)}
.rcard--featured .rcard__quote{color:var(--navy-line)}
.rcard__stars{display:inline-flex;color:#F6B01E;margin-bottom:.8rem}
.rcard__text{font-size:.99rem;color:var(--ink);line-height:1.55;flex:1}
.rcard--featured .rcard__text{font-size:1.14rem;color:#EAEEF6;font-weight:500;line-height:1.5}
.rcard__by{margin-top:1.2rem;display:flex;align-items:center;gap:.7rem;font-size:.84rem;color:var(--ink-mute)}
.rcard__by>span:nth-child(2){display:flex;flex-direction:column;line-height:1.25;flex:1}
.rcard__by b{color:var(--head);font-size:.96rem;font-weight:700}
.rcard--featured .rcard__by{color:#A7B2C8}
.rcard--featured .rcard__by b{color:#fff}
.rcard__avatar{flex:none;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:var(--mist);color:var(--blue);font-weight:700;font-size:.92rem;border:1px solid var(--line)}
.rcard--featured .rcard__avatar{background:var(--navy-2);color:#fff;border-color:var(--navy-line)}
.rcard__g{flex:none}
.rcarousel__btn{flex:none;align-self:center;width:48px;height:48px;border-radius:50%;background:#fff;border:1.6px solid var(--line-2);
  display:grid;place-items:center;color:var(--head);cursor:pointer;transition:.15s}
.rcarousel__btn:hover{border-color:var(--blue);color:var(--blue)}
.rcarousel__btn--prev svg{transform:rotate(90deg)}
.rcarousel__btn--next svg{transform:rotate(-90deg)}
.rcarousel__hint{display:none;align-items:center;justify-content:center;gap:.5rem;margin-top:18px;color:var(--ink-mute);font-size:.9rem;font-weight:600}
.rcarousel__hint svg{color:var(--blue);flex:none;animation:swipe-nudge 1.8s ease-in-out infinite}
@keyframes swipe-nudge{0%,100%{transform:translateX(-3px)}50%{transform:translateX(3px)}}
.reviews__foot{margin-top:clamp(18px,2.2vw,26px);display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}

/* ==========================================================================
   FAQ — clean flat accordion (hairline rows, + toggle)
   ========================================================================== */
.faq__grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(32px,5vw,64px);align-items:start}
.faq__head{position:sticky;top:130px}
.faq__head h2{font-size:clamp(1.9rem,3vw,2.6rem)}
.faq__head .section-sub{margin-top:1rem}
.faq__head .btn{margin-top:1.6rem}
.faq__list{display:flex;flex-direction:column}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item summary{display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer;
  padding:20px 4px;font-weight:700;font-size:1.08rem;color:var(--head);list-style:none}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary svg{color:var(--blue);flex:none;transition:transform .2s}
.faq__item[open] summary svg{transform:rotate(180deg)}
.faq__a{padding:0 4px 20px}
.faq__a p{color:var(--ink-soft);max-width:60ch}

/* ==========================================================================
   AREAS + MAP
   ========================================================================== */
.areas__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(32px,4.6vw,64px);align-items:center}
.areas__copy h2{font-size:clamp(1.9rem,3vw,2.6rem)}
.areas__copy>p{margin-top:1.1rem;color:var(--ink-soft);font-size:1.08rem;max-width:34em}
.areas__chips{display:grid;grid-template-columns:1fr 1fr;gap:0 30px;margin-top:1.5rem;border-top:1px solid var(--line)}
.areas__chips li{display:flex;align-items:center;gap:.55rem;padding:.7rem .1rem;font-size:.96rem;font-weight:600;color:var(--ink);border-bottom:1px solid var(--line)}
.areas__chips svg{color:var(--blue);flex:none}
.areas__out{margin-top:1.4rem;color:var(--ink-soft)}
.areas__out a{color:var(--blue);font-weight:700}
.areas__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:1.7rem}
.areas__stats li{background:var(--mist);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px}
.areas__stats b{display:block;font-size:1.35rem;font-weight:700;color:var(--blue);letter-spacing:-.02em}
.areas__stats span{font-size:.82rem;color:var(--ink-mute)}
.mapframe{position:relative;border-radius:var(--r-img);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/12;width:100%;background:#E8EEF4}
.mapframe iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.map-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--blue);
  background:repeating-linear-gradient(0deg,transparent,transparent 28px,rgba(0,91,172,.05) 29px),repeating-linear-gradient(90deg,transparent,transparent 28px,rgba(0,91,172,.05) 29px),#E8EEF4}
.map-ph p{font-weight:700;color:var(--blue-deep)}

/* ==========================================================================
   QUOTE MODAL + MULTI-STEP FUNNEL (engineering preserved; restyled)
   ========================================================================== */
.quotemodal{position:fixed;inset:0;z-index:160;visibility:hidden;transition:visibility 0s linear .3s}
.quotemodal.is-open{visibility:visible;transition:visibility 0s}
.quotemodal__backdrop{position:absolute;inset:0;background:rgba(11,16,30,.6);opacity:0;transition:opacity .3s ease}
.quotemodal.is-open .quotemodal__backdrop{opacity:1}
.quotemodal__dialog{position:absolute;left:50%;top:50%;transform:translate(-50%,-46%) scale(.985);
  width:min(560px,calc(100vw - 28px));max-height:calc(100svh - 40px);display:flex;flex-direction:column;
  background:#fff;border-radius:var(--r);box-shadow:var(--shadow-lift);overflow:hidden;opacity:0;
  transition:opacity .3s ease,transform .3s cubic-bezier(.22,1,.36,1)}
.quotemodal.is-open .quotemodal__dialog{opacity:1;transform:translate(-50%,-50%) scale(1)}
.quotemodal__bar{flex:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--navy)}
.quotemodal__eyebrow{font-size:.98rem;font-weight:700;color:#fff}
.quotemodal__desc{font-size:.82rem;color:#AEB9D2;font-weight:600;margin-top:1px}
.quotemodal__close{flex:none;display:grid;place-items:center;width:40px;height:40px;margin:-4px -6px -4px 0;background:none;border:none;cursor:pointer;color:#C7D0E2;border-radius:var(--r);transition:background .15s,color .15s}
.quotemodal__close:hover{background:var(--navy-2);color:#fff}
.quote__card{background:#fff;padding:clamp(20px,3vw,32px);overflow-y:auto}
.qform__head{margin-bottom:1.5rem}
.qprogress{height:6px;border-radius:3px;background:var(--mist);overflow:hidden}
.qprogress span{display:block;height:100%;width:12%;border-radius:3px;background:linear-gradient(90deg,var(--blue),var(--cyan));transition:width .4s cubic-bezier(.4,0,.2,1)}
.qform__meta{margin-top:.6rem;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute)}
.qstep{display:none;border:0;padding:0;margin:0;min-inline-size:0}
.qstep.is-active{display:block;animation:qin .32s ease}
@keyframes qin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.q-legend{font-size:clamp(1.3rem,2vw,1.55rem);font-weight:700;letter-spacing:-.02em;padding:0;color:var(--head)}
.q-why{margin-top:.45rem;color:var(--ink-mute);font-size:.94rem}
.choices{margin-top:1.3rem;display:flex;flex-direction:column;gap:.55rem}
.choice{position:relative;display:flex;align-items:center;gap:.8rem;cursor:pointer;border:1.6px solid var(--line-2);border-radius:var(--r);padding:.92rem 1.1rem;font-weight:600;transition:border-color .14s,background .14s,box-shadow .14s}
.choice input{position:absolute;opacity:0;width:0;height:0}
.choice span{flex:1}
.choice::before{content:"";width:21px;height:21px;border-radius:50%;border:2px solid var(--line-2);flex:none;transition:.14s}
.choice:hover{border-color:var(--blue);background:#F2F7FC}
.choice:has(input:checked){border-color:var(--blue);background:#EAF2FA;box-shadow:0 0 0 3px rgba(0,91,172,.12)}
.choice:has(input:checked)::before{border-color:var(--blue);background:radial-gradient(circle,#fff 33%,var(--blue) 38%)}
.choice input:focus-visible+span{text-decoration:underline}
.field{margin-bottom:1rem}
.field label{display:block;font-weight:700;margin-bottom:.4rem;font-size:.95rem;color:var(--head)}
.field .opt{color:var(--ink-mute);font-weight:500}
.field input,.qform textarea{width:100%;border:1.6px solid var(--line-2);border-radius:var(--r);padding:.85rem 1rem;font:inherit;font-size:1rem;background:var(--mist);color:var(--ink)}
.qform textarea{resize:vertical;min-height:84px}
.field input:focus,.qform textarea:focus{background:#fff;border-color:var(--blue);outline:none;box-shadow:0 0 0 3px rgba(0,91,172,.15)}
.field input[aria-invalid]{border-color:#C24A2E;background:#FCF1EE}
.err{color:#B23A1E;font-size:.85rem;margin-top:.35rem;font-weight:600}
.err:empty{display:none}
.coverage{margin-top:.55rem;font-size:.9rem;font-weight:700}
.coverage:empty{display:none}
.coverage.ok{color:#16794A}.coverage.maybe{color:#9A6510}
.consent{display:flex;align-items:flex-start;gap:.65rem;font-size:.94rem;color:var(--ink-soft);cursor:pointer;margin-top:.3rem}
.consent input{margin-top:.2rem;width:19px;height:19px;accent-color:var(--blue);flex:none}
.filedrop{display:flex;align-items:center;gap:.6rem;border:1.6px dashed var(--line-2);border-radius:var(--r);padding:.85rem 1rem;cursor:pointer;color:var(--ink-mute);font-weight:600;font-size:.95rem;transition:border-color .15s,background .15s,color .15s}
.filedrop:hover{border-color:var(--blue);color:var(--blue);background:#F2F7FC}
.filedrop svg{color:var(--blue);flex:none}
.filedrop.has-file{border-style:solid;border-color:var(--blue);color:var(--ink);background:#EAF2FA}
.filedrop__label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.qform__nav{display:flex;align-items:center;gap:.6rem;margin-top:1.7rem}
.qform__adv{margin-left:auto}
.qform__foot{margin-top:1rem;font-size:.79rem;color:var(--ink-mute);text-align:center}
.qform__foot .muted{color:#A39F9A}
.qsuccess{text-align:center;padding:clamp(20px,4vw,46px) 1rem}
.qsuccess__tick{display:inline-flex;margin-bottom:.4rem}
.qsuccess h3{font-size:1.5rem;margin-bottom:.5rem}
.qsuccess p{color:var(--ink-soft)}
.qsuccess__meta{margin-top:1rem;font-size:.95rem}
.qsuccess__meta a{color:var(--blue);font-weight:700}
@media (max-width:560px){
  .quotemodal__dialog{inset:0;left:0;top:0;width:100%;max-width:none;height:100svh;max-height:100svh;border-radius:0;transform:translateY(14px)}
  .quotemodal.is-open .quotemodal__dialog{transform:translateY(0)}
}
/* No-JS fallback: render the form inline */
.no-js .quotemodal{position:static;visibility:visible;z-index:auto}
.no-js .quotemodal__backdrop,.no-js .quotemodal__bar{display:none}
.no-js .quotemodal__dialog{position:static;transform:none;opacity:1;width:auto;max-width:640px;margin:0 auto;max-height:none;border-radius:0;box-shadow:none}
.no-js .qstep{display:block;border-top:1px solid var(--line);padding-top:18px;margin-top:18px}
.no-js .qform__nav,.no-js .qform__head{display:none}

/* ==========================================================================
   CLOSING CTA already covered by .ctaband (navy anchor)
   FOOTER
   ========================================================================== */
.site-footer{background:var(--navy);color:#A9B5CF;padding-top:clamp(46px,5vw,66px)}
.site-footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;padding-bottom:38px;border-bottom:1px solid var(--navy-line)}
.site-footer__grid>*{min-width:0}
.site-footer__col a,.site-footer__col li,.site-footer__blurb{overflow-wrap:anywhere}
.footmark{height:42px;width:auto;margin-bottom:1.1rem}
.site-footer__blurb{font-size:.94rem;max-width:34em;color:#94A2C0;line-height:1.6}
.site-footer__trust{margin-top:1.2rem;display:flex;flex-wrap:wrap;gap:8px 16px}
.site-footer__trust li{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:700;color:#BAC7E0}
.site-footer__trust svg{color:var(--cyan)}
.site-footer__col h3{color:#fff;font-size:.86rem;letter-spacing:.08em;margin-bottom:1rem;text-transform:uppercase;font-weight:700}
.site-footer__col ul{display:flex;flex-direction:column;gap:.55rem;font-size:.94rem}
.site-footer__col a:hover{color:#fff}
.site-footer__legal{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;padding-block:24px;font-size:.82rem;color:#93A2C0}
.site-footer__demo{color:#97A4C2;max-width:54em}

/* ---------- Mobile sticky bar ---------- */
.stickybar{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;gap:10px;padding:9px 14px;
  background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-top:1px solid var(--line);box-shadow:0 -6px 18px rgba(27,38,70,.1)}
.stickybar__call{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;flex:0 0 42%;white-space:nowrap;
  border:1.6px solid var(--line-2);border-radius:var(--r);font-weight:700;font-size:1rem;color:var(--head)}
.stickybar__call svg{color:var(--blue)}
.stickybar__quote{flex:1}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:1080px){
  .reviews__head{grid-template-columns:1fr}
  .reviews__badge{justify-self:start;display:flex;align-items:center;gap:14px;text-align:left;min-width:0}
  .reviews__badge img{margin:0}
  .reviews__stars{justify-content:flex-start}
}
@media (max-width:1000px){
  .band__grid,.areas__grid,.faq__grid{grid-template-columns:1fr;gap:clamp(26px,5vw,40px)}
  .band--rev .band__media{order:0}
  .faq__head{position:static}
  .cards--4{grid-template-columns:repeat(2,1fr)}
  .cards--3{grid-template-columns:repeat(3,1fr)}
  .rcard{flex-basis:clamp(260px,70%,360px)}
  .rcard--featured{flex-basis:clamp(280px,80%,440px)}
  .band__media{min-height:300px}
}
@media (max-width:860px){
  .nav,.header-call{display:none}
  .menu-btn{display:inline-flex}
  .cards--3{grid-template-columns:1fr}
  .rcarousel__btn{display:none}
  .rcarousel__hint{display:flex}
}
@media (max-width:680px){
  :root{--sec:clamp(48px,11vw,66px)}
  .topbar__txt--muted,.topbar__sep{display:none}
  .site-header__row{min-height:64px}
  .brand__logo{height:44px;padding:6px 9px}
  .hero{min-height:clamp(500px,calc(100svh - 96px),680px)}
  .hero__title{font-size:clamp(2.3rem,9vw,3.1rem)}
  .hero__cta{flex-direction:column;width:100%;max-width:340px;margin-inline:auto}
  .hero__cta .btn{width:100%}
  .cards--4{grid-template-columns:1fr}
  .reviews__foot{flex-direction:column;align-items:stretch}
  .reviews__foot .btn{width:100%}
  .areas__stats{grid-template-columns:1fr 1fr 1fr}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .site-footer__brand{grid-column:1/-1}
  .stickybar{display:flex}
  body{padding-bottom:72px}
  .ctaband__btns{flex-direction:column;width:100%;max-width:340px}
  .ctaband__btns .btn{width:100%}
}
@media (max-width:430px){
  .areas__chips{grid-template-columns:1fr}
  .areas__stats{grid-template-columns:1fr}
  .areas__stats li{display:flex;align-items:baseline;gap:.5rem}
}

/* Anchor offset for the sticky top (topbar + header) */
section[id]{scroll-margin-top:118px}
@media (max-width:680px){section[id]{scroll-margin-top:104px}}

/* ---------- Motion / reduced-motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .rcarousel__track{scroll-behavior:auto}
}
