/* ============================================================
   Home Inspector Lakeville MN — "Surveyor's Precision"
   Premium editorial trust. Light, bright, confident — refined
   minimalism with intention: characterful serif display
   (Spectral) + clean body (Mulish), atmospheric layered
   gradients, a faint precision-grid texture, oversized section
   numerals, a teal measurement-tick motif, asymmetric editorial
   tension, orchestrated staggered page-load reveals.
   Deliberately NOTHING like Rochester's dark blueprint/grain.
   ============================================================ */
:root{
  --paper:#fdfdfb;
  --mist:#f3f6f5;
  --cloud:#e9eeec;
  --navy:#13293d;        /* primary ink — deep, slightly cool */
  --navy-2:#1d3a55;
  --teal:#0e9488;        /* single bright trust accent */
  --teal-dk:#0a6f66;
  --teal-glow:rgba(14,148,136,.16);
  --ink:#2a343b;         /* warm slate body */
  --muted:#5d6a73;
  --line:#dde4e3;
  --line-2:#cbd5d3;
  --gold:#b88a3e;        /* whisper of warmth in fine rules only */
  --sh-sm:0 1px 2px rgba(19,41,61,.05),0 6px 18px rgba(19,41,61,.06);
  --sh:0 2px 6px rgba(19,41,61,.06),0 18px 44px rgba(19,41,61,.10);
  --sh-lg:0 4px 12px rgba(19,41,61,.08),0 34px 70px rgba(19,41,61,.16);
  --r:10px;
  --r-lg:20px;
  --wrap:1200px;
  --disp:"Spectral",Georgia,"Times New Roman",serif;
  --body:"Mulish",system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);background:var(--paper);color:var(--ink);
  font-size:17px;line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal-dk);text-decoration:none;transition:color .2s}
a:hover{color:var(--navy)}
h1,h2,h3,h4{font-family:var(--disp);color:var(--navy);
  line-height:1.08;letter-spacing:-.012em;font-weight:600}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 30px}
.mono{font-family:var(--body);font-weight:700;font-size:12px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.tbd{color:var(--teal-dk);font-style:italic;font-size:.88em;
  background:var(--teal-glow);padding:1px 8px;border-radius:5px;
  font-family:var(--body);font-weight:600}

/* Blank-gap guard: reveals hidden ONLY when JS active.
   Orchestrated staggered entrance via per-element delay. */
.js .reveal{opacity:0;transform:translateY(22px);
  transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.js .reveal.d2{transition-delay:.10s}
.js .reveal.d3{transition-delay:.20s}
.js .reveal.d4{transition-delay:.30s}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1!important;transform:none!important;
    transition:none!important}
  *{animation:none!important}
}

.skip{position:absolute;left:-999px;z-index:200}
.skip:focus{left:18px;top:18px;background:var(--teal);color:#fff;
  padding:12px 20px;border-radius:8px;font-family:var(--disp);
  font-weight:600}

/* ---------- Top meta bar ---------- */
.meta{background:var(--navy);color:#bcccd5;
  border-bottom:1px solid rgba(255,255,255,.06)}
.meta .wrap{display:flex;justify-content:space-between;
  align-items:center;height:40px;font-size:12.5px;flex-wrap:wrap;
  font-weight:600;letter-spacing:.01em}
.meta a{color:#fff}
.meta a:hover{color:var(--teal)}

/* ---------- Nav ---------- */
nav{position:sticky;top:0;z-index:90;
  background:rgba(253,253,251,.86);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line)}
nav .wrap{display:flex;align-items:center;justify-content:space-between;
  height:78px;gap:22px}
.brand{display:flex;align-items:center;gap:13px;color:var(--navy)}
.brand .glyph{width:44px;height:44px;display:grid;place-items:center;
  background:var(--navy);border-radius:11px;flex:none;position:relative;
  overflow:hidden}
.brand .glyph:after{content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 55%,
  rgba(14,148,136,.55) 130%)}
.brand .glyph svg{width:24px;height:24px;position:relative;z-index:1}
.brand .name{font-family:var(--disp);font-weight:700;font-size:20px;
  line-height:1;letter-spacing:-.02em}
.brand .name small{display:block;font-family:var(--body);
  font-weight:700;font-size:10.5px;color:var(--teal-dk);
  letter-spacing:.16em;text-transform:uppercase;margin-top:5px}
.navlinks{display:flex;gap:30px;margin-left:auto}
.navlinks a{color:var(--ink);font-weight:600;font-size:14.5px;
  position:relative;padding:8px 0;letter-spacing:.01em}
.navlinks a:before{content:"";position:absolute;left:0;top:50%;
  width:0;height:1px;background:var(--teal);opacity:0;
  transition:width .3s var(--ease),opacity .2s}
.navlinks a:hover{color:var(--navy)}
.navlinks a:hover:before{width:14px;opacity:1;
  transform:translateX(-19px)}
.book{background:var(--navy);color:#fff!important;
  padding:13px 22px;border-radius:8px;font-family:var(--disp);
  font-weight:600;font-size:14.5px;position:relative;overflow:hidden;
  transition:transform .25s var(--ease)}
.book:after{content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 40%,
  rgba(14,148,136,.65));opacity:0;transition:opacity .3s}
.book:hover{transform:translateY(-2px);color:#fff!important}
.book:hover:after{opacity:1}
.book span{position:relative;z-index:1}
.burger{display:none;width:46px;height:46px;background:none;
  border:0;cursor:pointer;flex-direction:column;gap:5px;
  align-items:center;justify-content:center}
.burger span{width:24px;height:2px;background:var(--navy);
  border-radius:2px;transition:.3s var(--ease)}
body.nav-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobnav{display:none}

/* ---------- Breadcrumb ---------- */
.crumb{background:var(--mist);border-bottom:1px solid var(--line)}
.crumb .wrap{display:flex;flex-wrap:wrap;gap:9px;align-items:center;
  height:48px;font-size:13px;color:var(--muted);font-weight:600}
.crumb a{color:var(--teal-dk)}
.crumb b{color:var(--navy);font-weight:700}
.crumb span{color:var(--line-2)}

/* ---------- Hero ---------- */
/* ---- Full-bleed background hero ---- */
.hero{position:relative;isolation:isolate;border-bottom:1px solid var(--line)}
.hero-full{min-height:clamp(560px,82vh,820px);display:flex;
  flex-direction:column;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center 62%;z-index:-2}
.hero-scrim{position:absolute;inset:0;z-index:-1;
  background:
   linear-gradient(100deg,rgba(10,22,33,.86) 0%,
     rgba(12,28,42,.72) 38%,rgba(14,32,48,.30) 68%,
     rgba(14,32,48,.12) 100%),
   linear-gradient(0deg,rgba(10,22,33,.55),transparent 38%)}
.hero-full .hero-inner{display:block;position:relative;
  padding:64px 0 26px}
.hero-full .htext{max-width:40em}
.hero-full .eyebrow{color:#7fd8cf}
.hero-full .eyebrow .tick,
.hero-full .eyebrow .tick:before,
.hero-full .eyebrow .tick:after{background:#7fd8cf}
.hero-full .hero-h1{color:#fff;
  text-shadow:0 2px 24px rgba(0,0,0,.35)}
.hero-full .hero-h1 .em{color:#7fd8cf}
.hero-full .lead{color:#d6e2e8;max-width:32em;
  text-shadow:0 1px 12px rgba(0,0,0,.4)}
.hero-full .secondary{background:rgba(255,255,255,.10);
  color:#fff;border-color:rgba(255,255,255,.34);
  backdrop-filter:blur(4px)}
.hero-full .secondary svg{stroke:#7fd8cf}
.hero-full .secondary:hover{background:rgba(255,255,255,.18);
  border-color:#fff;color:#fff}
/* slim trust strip pinned to hero base */
.hero-trust{position:relative;z-index:1;
  border-top:1px solid rgba(255,255,255,.14);
  background:rgba(8,18,28,.42);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.hero-trust .wrap{display:flex;flex-wrap:wrap;gap:14px 40px;
  padding:18px 30px}
.hero-trust span{color:#c4d3da;font-size:13.5px;font-weight:600;
  letter-spacing:.01em}
.hero-trust b{font-family:var(--disp);color:#fff;font-weight:600;
  margin-right:4px}
.hero-inner{position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:11px;
  color:var(--teal-dk);font-family:var(--body);font-weight:700;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:26px}
.eyebrow .tick{width:34px;height:2px;background:var(--teal);
  position:relative;flex:none}
.eyebrow .tick:before,.eyebrow .tick:after{content:"";
  position:absolute;top:-3px;width:2px;height:8px;background:var(--teal)}
.eyebrow .tick:before{left:0}.eyebrow .tick:after{right:0}
.hero h1,.hero-h1{font-size:clamp(40px,5.6vw,68px);
  margin-bottom:22px;font-weight:600;letter-spacing:-.02em}
.hero h1 .em,.hero-h1 .em{color:var(--teal-dk);font-style:italic;
  font-weight:500}
.hero .lead{font-size:19.5px;color:var(--muted);max-width:33em;
  margin-bottom:34px;line-height:1.72}
.actions{display:flex;gap:15px;flex-wrap:wrap;margin-bottom:42px}
.primary,.secondary{display:inline-flex;align-items:center;gap:11px;
  font-family:var(--disp);font-weight:600;font-size:16px;
  padding:16px 28px;border-radius:9px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),
  background .25s,border-color .25s}
.primary{background:var(--teal);color:#fff;position:relative;
  overflow:hidden;box-shadow:0 10px 26px rgba(14,148,136,.30)}
.primary:after{content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 45%,
  rgba(255,255,255,.22));transform:translateX(-100%);
  transition:transform .55s var(--ease)}
.primary:hover{background:var(--teal-dk);color:#fff;
  transform:translateY(-3px);box-shadow:0 16px 34px rgba(14,148,136,.40)}
.primary:hover:after{transform:translateX(100%)}
.primary svg{width:18px;height:18px;stroke:#fff;stroke-width:2.4;
  fill:none;position:relative;z-index:1}
.primary span{position:relative;z-index:1}
.secondary{background:#fff;color:var(--navy);
  border:1.5px solid var(--line-2)}
.secondary svg{width:17px;height:17px;stroke:var(--teal-dk);
  stroke-width:1.8;fill:none}
.secondary:hover{border-color:var(--navy);color:var(--navy);
  transform:translateY(-3px);box-shadow:var(--sh-sm)}
.hstats{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.hstats span{display:flex;flex-direction:column;font-size:13px;
  color:var(--muted);font-weight:600;letter-spacing:.02em}
.hstats b{font-family:var(--disp);font-size:30px;color:var(--navy);
  font-weight:600;line-height:1;margin-bottom:3px}
.hstats b i{font-size:16px;font-style:normal;color:var(--teal-dk);
  margin-left:2px}
.hstats .div{width:1px;height:34px;background:var(--line-2);
  align-self:center}
.hpanel{position:relative}
.hphoto{position:relative;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-lg);aspect-ratio:4/3.05;background:var(--cloud)}
.hphoto img{width:100%;height:100%;object-fit:cover;
  transform:scale(1.02)}
.hphoto-frame{position:absolute;inset:14px;
  border:1px solid rgba(255,255,255,.5);border-radius:12px;
  z-index:1;pointer-events:none}
.hphoto-frame:before,.hphoto-frame:after{content:"";position:absolute;
  width:22px;height:22px;border-color:#fff;border-style:solid}
.hphoto-frame:before{top:-1px;left:-1px;border-width:2px 0 0 2px}
.hphoto-frame:after{bottom:-1px;right:-1px;border-width:0 2px 2px 0}
.hbadge{position:absolute;background:#fff;border-radius:13px;
  padding:15px 18px;box-shadow:var(--sh-lg);display:flex;
  align-items:center;gap:13px;max-width:266px;
  border:1px solid var(--line)}
.hbadge:first-of-type{left:-26px;bottom:64px}
.hbadge-2{right:-22px;top:48px;max-width:248px}
.hbadge .ic{width:42px;height:42px;border-radius:10px;
  background:var(--teal-glow);display:grid;place-items:center;
  flex:none}
.hbadge .ic svg{width:21px;height:21px;stroke:var(--teal-dk);
  stroke-width:1.9;fill:none;stroke-linecap:round}
.hbadge b{font-family:var(--disp);font-size:15px;color:var(--navy);
  display:block;font-weight:600}
.hbadge span{font-size:11.5px;color:var(--muted);line-height:1.4;
  display:block;margin-top:2px}

/* ---------- Section primitives ---------- */
.blk{padding:96px 0;position:relative}
.blk.alt{background:var(--mist);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.shead{display:grid;grid-template-columns:auto 1fr;gap:28px;
  align-items:start;margin-bottom:54px;max-width:62em}
.shead .idx{font-family:var(--disp);font-weight:600;
  font-size:15px;color:var(--teal-dk);padding-top:9px;
  position:relative;white-space:nowrap;letter-spacing:.06em}
.shead .idx:before{content:"";display:block;width:40px;height:2px;
  background:var(--teal);margin-bottom:14px}
.shead h2{font-size:clamp(30px,4vw,46px);margin-bottom:12px;
  font-weight:600;letter-spacing:-.02em}
.shead h2 i{color:var(--teal-dk);font-style:italic;font-weight:500}
.shead .sub{color:var(--muted);font-size:17px;max-width:42em;
  line-height:1.6}

/* ---------- Service / link cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cards a{background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:32px 30px;display:block;
  position:relative;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),
  border-color .35s}
.cards a:before{content:"";position:absolute;left:0;top:0;
  width:100%;height:2px;background:var(--teal);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease)}
.cards a:hover{transform:translateY(-6px);box-shadow:var(--sh-lg);
  border-color:transparent}
.cards a:hover:before{transform:scaleX(1)}
.glyphbox{width:52px;height:52px;border-radius:12px;
  background:linear-gradient(150deg,var(--navy),var(--navy-2));
  display:grid;place-items:center;margin-bottom:22px;
  position:relative;overflow:hidden}
.glyphbox:after{content:"";position:absolute;inset:0;
  background:linear-gradient(150deg,transparent 50%,var(--teal-glow))}
.glyphbox svg{width:26px;height:26px;stroke:#fff;stroke-width:1.6;
  fill:none;stroke-linecap:round;stroke-linejoin:round;
  position:relative;z-index:1}
.cards h3{font-size:21px;margin-bottom:10px;font-weight:600}
.cards .desc{color:var(--muted);font-size:14.5px;line-height:1.62;
  margin-bottom:20px}
.cards .arrow{font-family:var(--disp);font-weight:600;font-size:14px;
  color:var(--teal-dk);display:inline-flex;align-items:center;gap:7px}
.cards .arrow:after{content:"\2192";transition:transform .25s var(--ease)}
.cards a:hover .arrow:after{transform:translateX(5px)}
.cards .no{display:inline-block;font-family:var(--disp);
  font-weight:600;font-size:13px;color:var(--teal-dk);
  letter-spacing:.08em;margin-bottom:18px;
  padding-bottom:6px;border-bottom:1px solid var(--line-2)}

/* ---------- Coverage / link grid ---------- */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cell{background:#fff;border:1px solid var(--line);
  border-radius:9px;padding:20px 22px;position:relative;
  transition:border-color .25s,transform .25s var(--ease),
  box-shadow .25s}
.cell:hover{border-color:var(--teal);transform:translateY(-3px);
  box-shadow:var(--sh-sm)}
.cell .mono{display:block;margin-bottom:8px;color:var(--teal-dk);
  font-size:11px}
.cell b{font-family:var(--disp);font-size:16.5px;display:block;
  margin-bottom:4px;font-weight:600}
.cell b a{color:var(--navy)}
.cell span{font-size:12.5px;color:var(--muted)}

/* ---------- AEO answer block ---------- */
.aeo{background:var(--navy);color:#dfe8ec;position:relative;
  overflow:hidden;border-bottom:1px solid var(--line)}
.aeo:before{content:"";position:absolute;inset:0;
  background:radial-gradient(80% 120% at 12% -10%,
  rgba(14,148,136,.20),transparent 55%)}
.aeo .wrap{padding:58px 30px;position:relative}
.aeo-answer{font-size:22px;line-height:1.62;color:#fff;
  font-family:var(--disp);font-weight:400;max-width:44em;
  letter-spacing:-.005em}
.aeo-answer:before{content:"";display:block;width:42px;height:2px;
  background:var(--teal);margin-bottom:24px}

/* ---------- Feature band ---------- */
.fband .fbgrid{display:grid;grid-template-columns:1fr 1.06fr;
  gap:64px;align-items:center}
.fbtext .eyebrow{margin-bottom:22px}
.fbtext h2{font-size:clamp(28px,3.6vw,42px);margin-bottom:18px;
  font-weight:600}
.fbtext h2 i{color:var(--teal-dk);font-style:italic;font-weight:500}
.fbtext p{color:var(--muted);font-size:17px;line-height:1.72;
  margin-bottom:28px}
.fbimg{position:relative;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-lg);aspect-ratio:16/10.4;background:var(--cloud)}
.fbimg:after{content:"";position:absolute;inset:13px;
  border:1px solid rgba(255,255,255,.4);border-radius:12px}
.fbimg img{width:100%;height:100%;object-fit:cover}

/* ---------- Gallery ---------- */
.ggrid{display:grid;grid-template-columns:repeat(3,1fr);
  grid-auto-rows:1fr;gap:20px}
.gcell{border-radius:var(--r);overflow:hidden;position:relative;
  box-shadow:var(--sh-sm);background:var(--cloud);aspect-ratio:3/2}
.gcell:nth-child(1),.gcell:nth-child(8){grid-row:span 1}
.gcell img{width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease)}
.gcell:hover img{transform:scale(1.07)}
.gcell figcaption{position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(0deg,rgba(19,41,61,.86),
  rgba(19,41,61,.30) 55%,transparent);
  color:#fff;font-family:var(--disp);font-weight:600;font-size:14.5px;
  padding:34px 18px 16px;letter-spacing:-.01em}
.gcell figcaption:before{content:"";display:block;width:22px;
  height:2px;background:var(--teal);margin-bottom:9px}

/* ---------- Before / after ---------- */
.ba{max-width:800px;margin:0 auto}
.ba-stage{position:relative;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--sh-lg);aspect-ratio:3/2;
  background:var(--cloud);user-select:none}
.ba-stage img{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover}
.ba-after{clip-path:inset(0 0 0 50%)}
.ba-tag{position:absolute;top:16px;font-family:var(--disp);
  font-weight:600;font-size:12px;color:#fff;
  background:rgba(19,41,61,.82);padding:7px 13px;border-radius:7px;
  letter-spacing:.04em}
.ba-tag.l{left:16px}.ba-tag.r{right:16px}
.ba-handle{position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);width:44px;height:44px;
  border-radius:50%;background:#fff;color:var(--navy);
  display:grid;place-items:center;box-shadow:var(--sh-lg);
  font-size:14px;pointer-events:none}
.ba-stage input[type=range]{position:absolute;inset:auto 0 0 0;
  width:100%;bottom:50%;margin:0;-webkit-appearance:none;
  background:transparent;cursor:ew-resize;height:44px}
.ba-stage input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:44px;height:44px;opacity:0;
  cursor:ew-resize}

/* ---------- FAQ ---------- */
.faqx{max-width:800px;margin:0 auto}
.faqx input[type=search]{width:100%;padding:17px 22px;font-size:16px;
  font-family:var(--body);border:1.5px solid var(--line-2);
  border-radius:10px;margin-bottom:20px;color:var(--ink);
  background:#fff;transition:border-color .2s,box-shadow .2s}
.faqx input[type=search]:focus{outline:none;border-color:var(--teal);
  box-shadow:0 0 0 4px var(--teal-glow)}
.fitem{background:#fff;border:1px solid var(--line);
  border-radius:10px;margin-bottom:13px;overflow:hidden;
  transition:border-color .25s,box-shadow .25s}
.fitem.open{border-color:var(--line-2);box-shadow:var(--sh-sm)}
.fq{font-family:var(--disp);font-weight:600;font-size:17px;
  color:var(--navy);padding:20px 24px;cursor:pointer;
  display:flex;justify-content:space-between;gap:18px;
  align-items:center}
.fq:after{content:"";width:14px;height:14px;flex:none;
  background:
   linear-gradient(var(--teal-dk),var(--teal-dk)) center/14px 2px no-repeat,
   linear-gradient(var(--teal-dk),var(--teal-dk)) center/2px 14px no-repeat;
  transition:transform .3s var(--ease)}
.fitem.open .fq:after{transform:rotate(135deg)}
.fa{max-height:0;overflow:hidden;transition:max-height .35s var(--ease),
  padding .35s var(--ease);color:var(--muted);font-size:15.5px;
  line-height:1.72;padding:0 24px}
.fitem.open .fa{max-height:360px;padding:0 24px 22px}
.nomatch{color:var(--muted);text-align:center;padding:22px}

/* ---------- Marquee ---------- */
.marq{background:var(--navy);overflow:hidden;padding:18px 0;
  position:relative}
.marq:before,.marq:after{content:"";position:absolute;top:0;
  bottom:0;width:90px;z-index:1;pointer-events:none}
.marq:before{left:0;background:linear-gradient(90deg,var(--navy),
  transparent)}
.marq:after{right:0;background:linear-gradient(270deg,var(--navy),
  transparent)}
.marq .track{display:flex;gap:54px;width:max-content;
  animation:marq 38s linear infinite}
.marq .item{font-family:var(--disp);font-weight:500;font-size:16px;
  color:#90a6b1;white-space:nowrap;display:flex;align-items:center;
  gap:54px;font-style:italic}
.marq .item:after{content:"";width:5px;height:5px;
  background:var(--teal);border-radius:50%;font-style:normal}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- Long-form prose ---------- */
.prose{max-width:50em}
.prose h2{font-size:clamp(25px,3vw,34px);margin:40px 0 16px;
  font-weight:600}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:20px;margin:30px 0 11px;color:var(--navy-2);
  font-weight:600}
.prose p{color:var(--ink);font-size:17px;line-height:1.8;
  margin-bottom:17px}
.prose ul{padding-left:0;margin-bottom:17px;list-style:none}
.prose li{color:var(--ink);font-size:17px;line-height:1.7;
  margin-bottom:11px;padding-left:26px;position:relative}
.prose li:before{content:"";position:absolute;left:0;top:11px;
  width:11px;height:2px;background:var(--teal)}
.prose a{color:var(--teal-dk);font-weight:600;
  text-decoration:underline;text-underline-offset:3px;
  text-decoration-color:var(--line-2)}
.prose a:hover{text-decoration-color:var(--teal)}
.prose .lead{font-size:21px;color:var(--navy);line-height:1.6;
  margin-bottom:26px;font-family:var(--disp);font-weight:400}
.mapwrap{margin-top:46px;border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden}
.mapwrap iframe{display:block;width:100%;height:360px;border:0;
  filter:saturate(.8) contrast(1.02)}

/* ---------- Reviews ---------- */
.rev{background:var(--mist);border-top:1px solid var(--line)}
.revhead{display:flex;align-items:baseline;gap:20px;flex-wrap:wrap;
  margin-bottom:30px}
.revhead .big{font-family:var(--disp);font-size:56px;
  color:var(--teal-dk);line-height:1;font-weight:600}
.stars{color:var(--teal);letter-spacing:3px}
.rev figure{background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:30px}
.rev blockquote{color:var(--ink);font-size:16px;line-height:1.72;
  margin:14px 0 18px;font-family:var(--disp);font-style:italic;
  font-weight:400}
.rev figcaption{font-size:13.5px;color:var(--muted)}
.rev figcaption b{font-family:var(--disp);color:var(--navy);
  font-style:normal;font-weight:600}
.revtbd{background:#fff;border:1px solid var(--line);
  border-left:3px solid var(--teal);
  border-radius:var(--r);padding:34px 38px;
  color:var(--muted);font-size:15.5px;line-height:1.72;
  max-width:680px;margin:0 auto}

/* ---------- Instant Quote close ---------- */
/* CRITICAL: never inside .reveal, never lazy, tall + eager. */
.close{position:relative;isolation:isolate;overflow:hidden;
  background:linear-gradient(165deg,var(--navy),#0e2233);
  padding:90px 0 100px;color:#fff;text-align:center}
/* top placement: same full widget, just less vertical padding */
.close-top{padding:64px 0 70px;
  border-bottom:1px solid rgba(255,255,255,.08)}
.close-top h2{font-size:clamp(28px,3.8vw,44px)}
.close:before{content:"";position:absolute;inset:0;z-index:-1;
  opacity:.4;background-image:
   linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
   linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:58px 58px;
  -webkit-mask-image:radial-gradient(70% 80% at 50% 0%,#000,transparent 70%);
  mask-image:radial-gradient(70% 80% at 50% 0%,#000,transparent 70%)}
.close:after{content:"";position:absolute;z-index:-1;
  width:540px;height:540px;border-radius:50%;left:50%;top:-280px;
  transform:translateX(-50%);
  background:radial-gradient(circle,var(--teal-glow),transparent 65%)}
.close h2{color:#fff;font-size:clamp(30px,4.4vw,52px);
  margin:16px 0 14px;font-weight:600}
.close h2 i{color:var(--teal);font-style:italic;font-weight:500}
.close .eyebrow{color:#7fd8cf;justify-content:center}
.close .eyebrow .tick,.close .eyebrow .tick:before,
.close .eyebrow .tick:after{background:#7fd8cf}
.close>.wrap>p{color:#aebfc9;font-size:17px;margin-bottom:36px}
.quotebox{background:#fff;border-radius:var(--r-lg);
  box-shadow:0 40px 90px rgba(0,0,0,.40);overflow:hidden;
  max-width:940px;margin:0 auto;text-align:left}
.quotecap{display:flex;justify-content:space-between;
  padding:18px 24px;background:var(--mist);
  border-bottom:1px solid var(--line);font-family:var(--disp);
  font-weight:600;font-size:14px;color:var(--navy);flex-wrap:wrap;
  gap:8px}
.quotecap span:last-child{color:var(--muted);font-weight:600}
.quotebox iframe{display:block;width:100%;min-height:900px;
  border:0;background:#fff}
.quote-fallback{background:#fff;border-radius:var(--r-lg);
  box-shadow:0 40px 90px rgba(0,0,0,.40);max-width:680px;
  margin:0 auto;padding:54px 40px;text-align:center}
.quote-fallback h3{font-size:25px;margin-bottom:13px;font-weight:600}
.quote-fallback p{color:var(--muted);margin-bottom:26px;
  font-size:16px}

/* ---------- Footer ---------- */
footer{background:var(--navy);color:#9fb2bc;padding:60px 0 54px;
  font-size:14px;border-top:3px solid var(--teal)}
footer .wrap{display:flex;flex-direction:column;gap:11px}
.fbrand{font-family:var(--disp);font-weight:600;font-size:22px;
  color:#fff;margin-bottom:4px}
footer a{color:#c6d6df;font-weight:600}
footer a:hover{color:var(--teal)}
.flink a{color:var(--teal)}
footer .mono{color:#6f8492;font-size:11.5px;margin-top:10px}

/* ---------- Sticky mobile bar ---------- */
.stickybar{position:fixed;left:0;right:0;bottom:0;z-index:80;
  display:none;gap:1px;background:var(--line-2);
  box-shadow:0 -6px 26px rgba(19,41,61,.18);
  transform:translateY(110%);transition:transform .35s var(--ease)}
.stickybar.show{transform:translateY(0)}
.stickybar a{flex:1;text-align:center;padding:16px;
  font-family:var(--disp);font-weight:600;font-size:15px}
.stickybar .call{background:#fff;color:var(--navy)}
.stickybar .quote{background:var(--teal);color:#fff}

/* ---------- Responsive: 1024 / 820 / 600 / 380 ---------- */
@media(max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .grid{grid-template-columns:repeat(3,1fr)}
  .ggrid{grid-template-columns:repeat(2,1fr)}
  .hero-inner{grid-template-columns:1fr;gap:46px}
  .hpanel{order:-1}
  .hbadge:first-of-type{left:0;bottom:18px}
  .hbadge-2{right:0;top:18px}
  .fband .fbgrid{grid-template-columns:1fr;gap:36px}
  .fband .fbimg{order:-1}
  .shead{gap:22px}
}
@media(max-width:820px){
  .navlinks,.book{display:none}
  .burger{display:flex}
  .mobnav{display:block;position:fixed;inset:78px 0 auto 0;
    background:#fff;border-bottom:1px solid var(--line);
    padding:16px 0;transform:translateY(-135%);
    transition:transform .35s var(--ease);z-index:85;
    box-shadow:var(--sh-lg)}
  body.nav-open .mobnav{transform:translateY(0)}
  .mobnav a{display:block;padding:15px 30px;font-family:var(--disp);
    font-weight:600;color:var(--navy);font-size:16px;
    border-bottom:1px solid var(--mist)}
  .stickybar{display:flex}
  body{padding-bottom:56px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .blk{padding:64px 0}
  .shead{grid-template-columns:1fr;gap:14px}
  .shead .idx:before{margin-bottom:10px}
  .hbadge:first-of-type,.hbadge-2{position:relative;left:0;right:0;
    top:0;bottom:0;margin-top:14px;max-width:100%}
  .hpanel{display:flex;flex-direction:column}
}
@media(max-width:600px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  .cards,.grid,.ggrid{grid-template-columns:1fr}
  .hero{padding:52px 0 64px}
  .hstats{gap:16px}
  .hstats .div{display:none}
  .actions{flex-direction:column}
  .primary,.secondary{width:100%;justify-content:center}
  .quotebox iframe{min-height:1100px}      /* uncut on mobile */
  .meta .wrap{justify-content:center;gap:16px;height:auto;
    padding:9px 20px}
  .aeo-answer{font-size:19px}
}
@media(max-width:380px){
  .hero h1,.hero-h1{font-size:33px}
  .brand .name{font-size:18px}
  .shead h2{font-size:25px}
}
/* All interactive targets >= 44px */
a.primary,a.secondary,.book,.fq,.stickybar a,.burger,
.navlinks a,.mobnav a{min-height:44px}
