:root{
  --bg:#f6f9ff; --card:#ffffff; --ink:#122233; --sub:#5b6b76;
  --accent:#2a7be4; --accent-2:#e8f0ff; --purple:#7a66ff; --line:#e6ebf2;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Poppins, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;color:var(--ink);background:var(--bg);line-height:1.6}
img{max-width:100%;height:auto;display:block}
.container{width:min(1100px,92%);margin-inline:auto}
.site-header{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.9);backdrop-filter:saturate(140%) blur(6px);border-bottom:1px solid var(--line)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit;font-weight:700}
.brand-mark{width:56px;height:56px;border-radius:10px;object-fit:contain;background:#fff;padding:6px;box-shadow:0 1px 2px rgba(0,0,0,.06)}
.brand-text{font-family:Montserrat, sans-serif;font-weight:800;letter-spacing:.2px;white-space:nowrap}
.main-nav ul{display:flex;align-items:center;gap:.75rem;list-style:none;margin:0;padding:0}
.main-nav a{color:inherit;text-decoration:none}
.main-nav .btn{margin-left:.25rem}
.hero{border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.hero.colorful{background: radial-gradient(1200px 600px at -10% -40%, var(--accent) 0%, transparent 40%), radial-gradient(1200px 600px at 120% -40%, var(--purple) 0%, transparent 40%), linear-gradient(180deg, var(--accent-2), #f6fbff 50%, transparent)}
.hero-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:center;padding:3rem 0 2rem}
.hero h1{font-family:Montserrat, sans-serif;font-size: clamp(2rem, 3.5vw, 3.2rem);margin:.2rem 0}
.hero .lede{color:var(--sub);font-size:1.1rem}
.cta-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.75rem}
.trust-row{display:flex;gap:1rem;flex-wrap:wrap;padding:0;margin:1rem 0 0;list-style:'✓ '}
.trust-row li{color:var(--sub)}
.hero-logo{width:min(360px,70vw);margin-inline:auto}
.under-logo{margin-top:.5rem;text-align:center;font-weight:700}
.hero-ribbon{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(90deg,var(--accent),var(--purple));color:#fff;font-weight:600;text-align:center;padding:.4rem .5rem}
.mosaic{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin:1.25rem 0}
.mosaic img{border-radius:14px;width:100%;height:180px;object-fit:cover;box-shadow:0 8px 16px rgba(0,0,0,.06)}
.page-header{padding:2rem 0 1rem;border-bottom:1px solid var(--line)}
.page-header h1{margin:0 0 .25rem}
.page-sub{color:var(--sub)}
.service-block{padding:1.25rem 0 1.5rem;border-bottom:1px dashed var(--line)}
.service-block h2{margin:0 0 .25rem}
.service-desc{color:var(--sub);margin:0 0 .8rem}
.ba-grid-static{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:.8rem}
.ba-static{margin:0;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 6px 20px rgba(42,123,228,.06)}
.ba-static img{width:80%;height:180px;object-fit:cover;margin:0 auto}
.ba-static figcaption{text-align:center;font-weight:600;color:#445; padding:.4rem .5rem;background:#f5f7fb}
.services-cta{display:flex;justify-content:center;margin:1.4rem 0 2rem}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;text-decoration:none;border-radius:999px;padding:.65rem 1.1rem;font-weight:700;border:1px solid transparent;cursor:pointer;transition:transform .04s ease, filter .18s ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(90deg,var(--accent),var(--purple));color:#fff}
.btn-primary:hover{filter:brightness(.95)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:#f2f6fb}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;padding:1.5rem 0}
.contact-card{background:var(--card);padding:1.25rem;border-radius:14px;border:1px solid var(--line)}
.quote-form{background:var(--card);margin:1.5rem 0 2.5rem;padding:1.25rem;border-radius:14px;border:1px solid var(--line)}
.form-row{display:flex;gap:1rem;flex-wrap:wrap}
.form-group{display:flex;flex-direction:column;gap:.4rem;flex:1 1 260px}
input[type="text"],input[type="tel"],textarea,select{padding:.75rem .8rem;border:1px solid var(--line);border-radius:10px;outline:none;font:inherit;background:#fff}
textarea{resize:vertical}
.note{color:var(--sub)}
.form-actions{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap;margin-top:1rem}
.form-message{margin-top:1rem;font-weight:600;color:var(--accent)}
.reviews-wrap{padding:1rem 0 2rem}
.review-form{background:var(--card);padding:1rem;border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 22px rgba(42,123,228,.06)}
.reviews-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.9rem;margin-top:1rem}
.review{background:linear-gradient(180deg,#fff,#f7faff);border:1px solid var(--line);border-radius:14px;padding:1rem;box-shadow:0 10px 28px rgba(42,123,228,.07)}
.review .name{font-weight:700}
.review .stars{color:#f5a623;font-size:1.05rem;letter-spacing:1px}
.review .text{margin:.35rem 0 0}
.site-footer{border-top:1px solid var(--line);margin-top:2rem;background:#fff}
.site-footer .container{padding:1.1rem 0}
.footer-grid{display:flex;align-items:center;gap:1rem}
.footer-brand{display:flex;align-items:center;gap:.6rem}
.footer-spacer{flex:1}
.social-box{align-self:flex-end; background:#fff;border:1px solid var(--line);border-radius:14px;padding:.75rem 1rem;box-shadow:0 6px 18px rgba(0,0,0,.06);min-width:260px;max-width:320px}
.social-box h4{margin:.1rem 0 .5rem;background:linear-gradient(90deg,var(--accent),var(--purple));-webkit-background-clip:text;color:transparent}
.social-item{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:inherit;padding:.35rem .25rem;border-radius:10px}
.social-item:hover{background:#f2f6ff}
.icon{width:20px;height:20px;fill:#1b2540}
.legal{color:var(--sub);margin-top:.4rem}
@media (max-width: 880px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-art{order:-1}
  .trust-row{justify-content:center}
  .footer-grid{flex-wrap:wrap}
  .social-box{align-self:stretch;margin-left:auto}
}


/* Service Area */
.service-area-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:1rem;padding:1.25rem 0}
.service-area-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1rem;box-shadow:0 8px 22px rgba(42,123,228,.06)}
.area-list{columns:2;gap:1rem;margin:.5rem 0 0;padding-left:1.1rem}
.service-area-teaser{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:center;margin:1rem 0 0}
.teaser-map{border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 6px 18px rgba(0,0,0,.06)}

@media (max-width: 880px){
  .service-area-grid{grid-template-columns:1fr}
  .area-list{columns:1}
  .service-area-teaser{grid-template-columns:1fr}
}

/* Theme Enhancements */

:root{ --brand-blue:#2a7be4; --brand-gray:#8ea0b3; --brand-purple:#7a66ff;
  --bg-gradient:linear-gradient(90deg, var(--brand-blue), var(--brand-gray), var(--brand-purple));
  --soft-gradient:linear-gradient(180deg, rgba(42,123,228,.08), rgba(122,102,255,.10));
}
.hero.colorful{
  background: radial-gradient(1200px 600px at -10% -20%, rgba(42,123,228,.16), transparent 60%),
              radial-gradient(900px 500px at 120% 0%, rgba(122,102,255,.18), transparent 60%),
              linear-gradient(180deg, var(--accent-2), #f6fbff 50%, transparent);
}
.hero-banners{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-top:.4rem}
.banner-pill{background:var(--bg-gradient);color:#fff;padding:.35rem .7rem;border-radius:999px;font-weight:700;box-shadow:0 6px 16px rgba(42,123,228,.25);white-space:nowrap}
.hero-art{position:relative}
.pressure-wash{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.pressure-wash .spray{position:absolute;top:38%;left:-60%;width:220%;height:110px;border-radius:90px;background:radial-gradient(closest-side, rgba(255,255,255,.95), rgba(255,255,255,0) 70%),var(--bg-gradient);mix-blend-mode:screen;filter:blur(6px) saturate(120%);opacity:.35;animation:wash 7s linear infinite}
@keyframes wash{0%{transform:translateX(-40%) rotate(-3deg)}50%{opacity:.5}100%{transform:translateX(10%) rotate(2deg)}}
.service-block{background:var(--soft-gradient);border:1px solid var(--line);border-radius:14px;padding:1.25rem 1rem 1.5rem;margin:1rem 0 1.5rem;box-shadow:0 10px 28px rgba(42,123,228,.06);position:relative}
.service-block::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;border-radius:14px 14px 0 0;background:var(--bg-gradient)}
.contact-card.colorful-soft{background:linear-gradient(180deg,#fff,#f7faff 60%);border:1px solid var(--line);box-shadow:0 10px 26px rgba(42,123,228,.08);position:relative}
.contact-card.colorful-soft::after{content:"";position:absolute;left:12px;right:12px;bottom:-1px;height:4px;border-radius:3px;background:var(--bg-gradient);opacity:.9}
.site-footer::before{content:"";display:block;height:4px;background:var(--bg-gradient)}
.social-box h4{display:inline-block;padding:.25rem .6rem;border-radius:999px;background:var(--bg-gradient);color:#fff}
.social-item{border-radius:10px;padding:.5rem;border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f7fbff)}
.social-item:hover{box-shadow:0 8px 20px rgba(42,123,228,.12)}
@media (max-width: 640px){.ba-grid-static{grid-template-columns:1fr}.ba-static img{width:80%}}
