:root{
  --navy:#0B3D5C; --blue:#127AC2; --teal:#0E8F8F; --ink:#1d2b36; --grey:#54616b;
  --line:#e3eaf0; --bg:#ffffff; --soft:#f3f8fb; --gold:#f4b400; --white:#fff;
  --radius:14px; --maxw:1140px; --shadow:0 8px 30px rgba(11,61,92,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);line-height:1.6;background:var(--bg);-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.btn{display:inline-block;background:var(--blue);color:#fff;padding:13px 24px;border-radius:999px;
  font-weight:700;border:0;cursor:pointer;transition:.15s;text-align:center}
.btn:hover{background:#0e63a0;text-decoration:none}
.btn.ghost{background:transparent;color:var(--navy);border:2px solid var(--navy)}
.btn.ghost:hover{background:var(--navy);color:#fff}
.btn.teal{background:var(--teal)}.btn.teal:hover{background:#0b7676}
/* top bar */
.topbar{background:var(--navy);color:#cfe3f1;font-size:.85rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:7px 20px;flex-wrap:wrap}
.topbar a{color:#fff;font-weight:600}
/* header */
header.site{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;color:var(--navy);font-size:1.25rem;letter-spacing:.2px}
.brand:hover{text-decoration:none}
.brand .logo{height:46px;width:auto;display:block}
nav.main{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
nav.main a{color:var(--ink);font-weight:600;font-size:.95rem}
nav.main a:hover{color:var(--blue);text-decoration:none}
.nav-cta{display:flex;align-items:center;gap:12px}
.phone{font-weight:800;color:var(--navy);white-space:nowrap}
/* hero */
.hero{background:linear-gradient(180deg,var(--soft),#fff)}
.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:54px 20px}
.hero h1{font-size:2.6rem;line-height:1.12;margin:0 0 14px;color:var(--navy)}
.hero p.lead{font-size:1.15rem;color:var(--grey);margin:0 0 22px}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero .pool{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/3;
  background:linear-gradient(135deg,#1a90c9,#0E8F8F 70%);position:relative;overflow:hidden}
.hero .pool::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120px 80px at 30% 30%,rgba(255,255,255,.35),transparent),
  repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 14px,transparent 14px 28px)}
.badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.badge{background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-weight:700;
  font-size:.85rem;color:var(--navy);box-shadow:0 2px 8px rgba(11,61,92,.05)}
/* sections */
section{padding:46px 0}
section.alt{background:var(--soft)}
h2{font-size:1.8rem;color:var(--navy);margin:0 0 8px}
.sub{color:var(--grey);margin:0 0 26px;max-width:760px}
.grid{display:grid;gap:20px}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:0 2px 10px rgba(11,61,92,.04)}
.card h3{margin:0 0 8px;color:var(--navy);font-size:1.15rem}
.card p{margin:0;color:var(--grey)}
.check{list-style:none;margin:0;padding:0}
.check li{padding:6px 0 6px 28px;position:relative;color:var(--ink)}
.check li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:800}
.hoods{columns:3;column-gap:24px}
.hoods span{display:block;padding:5px 0;color:var(--ink);break-inside:avoid}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:4px 18px;margin-bottom:10px}
.faq summary{cursor:pointer;font-weight:700;color:var(--navy);padding:12px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--teal);font-weight:800}
.faq details[open] summary::after{content:"–"}
.faq p{margin:0 0 14px;color:var(--grey)}
.cta-band{background:var(--navy);color:#fff;text-align:center}
.cta-band h2{color:#fff}.cta-band .sub{color:#bcd6e8;margin:0 auto 22px}
.cta-band a.btn.ghost{color:#fff;border-color:#fff}
.cta-band a.btn.ghost:hover{background:#fff;color:var(--navy)}
.ribbon{background:var(--teal);color:#fff;text-align:center;font-weight:700;padding:10px;letter-spacing:.3px;font-size:.9rem}
/* footer */
footer.site{background:var(--navy);color:#cfe0ee;padding:40px 0 20px;font-size:.92rem}
footer.site a{color:#fff}
footer.site h4{color:#fff;margin:0 0 10px;font-size:1rem}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:30px;margin-bottom:24px}
.areas span{color:#cfe0ee}
.social{display:flex;gap:12px;margin-top:8px}
.social a{display:inline-flex;width:36px;height:36px;border:1px solid #2a5a7c;border-radius:8px;align-items:center;justify-content:center;font-weight:700}
.copy{border-top:1px solid #1d4a68;padding-top:16px;color:#9fc0d8;font-size:.82rem}
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr;padding:34px 20px}
  .hero h1{font-size:2.1rem}.g3,.g4{grid-template-columns:1fr 1fr}.g2{grid-template-columns:1fr}
  .hoods{columns:2}.fgrid{grid-template-columns:1fr}nav.main{display:none}
}
@media(max-width:560px){.g3,.g4{grid-template-columns:1fr}.hoods{columns:1}}
/* estimate form */
.formcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);max-width:680px}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:5px}
.field.full{grid-column:1 / -1}
.field label{font-weight:700;color:var(--navy);font-size:.88rem}
.field .req{color:#c0392b}
.field input,.field select,.field textarea{
  padding:11px 12px;border:1.5px solid var(--line);border-radius:10px;font:inherit;font-size:.95rem;
  color:var(--ink);background:#fff;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(18,122,194,.15)}
.field textarea{min-height:84px;resize:vertical}
.form-note{background:var(--soft);border-left:4px solid var(--teal);border-radius:0 10px 10px 0;
  padding:12px 16px;color:var(--navy);font-weight:600;font-size:.9rem;margin:0 0 20px}
.form-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:8px}
.btn.big{padding:15px 28px;font-size:1.02rem}
.hp{position:absolute;left:-9999px;opacity:0}
@media(max-width:560px){.formgrid{grid-template-columns:1fr}}
/* ===== mobile-first hardening + hamburger ===== */
html,body{overflow-x:hidden;max-width:100%}
*{min-width:0}
.menu-toggle{display:none;background:none;border:0;font-size:1.9rem;line-height:1;color:var(--navy);cursor:pointer;padding:2px 6px}
.navphone,.navquote{display:none}
@media(max-width:900px){
  header.site .wrap{position:relative;flex-wrap:nowrap}
  .menu-toggle{display:block}
  nav.main{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;
    align-items:stretch;gap:0;padding:6px 20px 14px;border-bottom:1px solid var(--line);
    box-shadow:0 14px 26px rgba(11,61,92,.14);z-index:60}
  body.nav-open nav.main{display:flex}
  nav.main a{padding:13px 2px;border-bottom:1px solid #eef3f7;font-size:1.02rem;width:100%}
  .navphone{display:block;color:var(--navy);font-weight:800}
  .navquote{display:block;border-bottom:0;margin-top:12px;text-align:center;color:#fff}
  .nav-cta{display:none}
  .brand{font-size:1.15rem}.brand .logo{height:34px;width:auto}
  .topbar{font-size:.78rem}
  .hero h1{font-size:2rem;word-break:break-word}
  section{padding:30px 0}
  .cta-band a.btn{display:inline-block;margin:6px 4px}
}
@media(max-width:560px){
  .hero h1{font-size:1.7rem}
  h2{font-size:1.45rem}
  .hero .cta{flex-direction:column;align-items:stretch}
  .hero .cta .btn{text-align:center}
  .wrap{padding:0 16px}
}

/* ===== real images ===== */
img.pool{object-fit:cover;width:100%;display:block;background:#cfe6f2}
.imgcard{padding:0;overflow:hidden}
.imgcard>img{width:100%;height:172px;object-fit:cover;display:block}
.imgcard .cardbody{padding:16px 20px}
.ba{margin:0;position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.ba img{width:100%;height:240px;object-fit:cover;display:block}
.ba figcaption{position:absolute;top:10px;left:10px;background:rgba(11,61,92,.88);color:#fff;font-weight:700;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;padding:4px 11px;border-radius:999px}
.brand{gap:0}
@media(max-width:560px){.ba img{height:200px}.imgcard>img{height:150px}}
