*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Segoe UI',Arial,sans-serif;color:#1a1f36;background:#fff;line-height:1.65}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
h1,h2,h3,h4{line-height:1.25}
:root{
  --blue:#1a4fa0;--blue-dark:#112f6a;--blue-mid:#2358b5;--blue-pale:#e8eef8;
  --accent:#e84118;--accent-dark:#c2320e;--white:#fff;--gray:#f4f7fc;
  --border:#d8e4f0;--text:#1a1f36;--text-mid:#4a5878;--text-light:#6a7898;--r:10px;
}
.topbar{background:#b53010;text-align:center;padding:8px 16px;font-size:13px;color:#fff;font-weight:700}
.topbar a{color:#fff;font-weight:800}
header{background:var(--blue-dark);position:sticky;top:0;z-index:200;box-shadow:0 2px 16px rgba(0,0,0,.3)}
nav{max-width:1160px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:68px}
.logo img{height:48px;width:auto}
.nav-menu{display:flex;align-items:center;gap:2px}
.nav-menu>a,.nav-menu>.drop-wrap>a{color:rgba(255,255,255,.85);font-size:14px;font-weight:500;padding:8px 13px;border-radius:6px;display:block;transition:background .2s,color .2s;white-space:nowrap}
.nav-menu>a:hover,.nav-menu>.drop-wrap:hover>a,.nav-menu>a.active{color:#fff;background:rgba(255,255,255,.12)}
.drop-wrap{position:relative}
.dropdown{display:none;position:absolute;top:calc(100% + 2px);left:0;background:var(--blue-dark);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);min-width:220px;padding:6px;z-index:300;box-shadow:0 8px 24px rgba(0,0,0,.35)}
/* dropdown open state controlled by JS only — no CSS :hover so gap doesn't kill it */
.dropdown a{display:block;color:rgba(255,255,255,.8);font-size:13px;padding:9px 14px;border-radius:6px;transition:background .2s,color .2s}
.dropdown a:hover{background:rgba(255,255,255,.1);color:#fff}
.dropdown.wide{columns:2;min-width:380px}
.nav-cta{color:#fff!important;font-weight:700!important;border-radius:6px!important;white-space:nowrap;padding:8px 16px!important;font-size:14px!important;line-height:1.4;display:inline-flex!important;align-items:center;gap:6px}
a.nav-cta{background:#70ad4a!important}
a.nav-cta:hover{background:#5a9438!important}
button.nav-cta{background:var(--accent)!important}
button.nav-cta:hover{background:var(--accent-dark)!important}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;width:40px;height:40px}
.hamburger span{display:block;height:2px;background:#fff;border-radius:2px;transition:.3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.hero{position:relative;background:var(--blue-dark);overflow:hidden;padding:72px 20px 60px;text-align:center}
.hero-bg{position:absolute;inset:0;background-image:url('images/hero.webp');background-size:cover;background-position:center;opacity:.15}
.hero-inner{position:relative;z-index:1;max-width:760px;margin:0 auto}
.badge{display:inline-block;background:rgba(232,65,24,.2);color:#ffb8a8;font-size:12px;font-weight:700;letter-spacing:.07em;padding:5px 16px;border-radius:20px;border:1px solid rgba(232,65,24,.4);margin-bottom:20px;text-transform:uppercase}
.hero h1{color:#fff;font-size:clamp(28px,4.5vw,48px);font-weight:800;margin-bottom:16px}
.hero h1 span{color:#7ab4ff}
.hero-desc{color:#b8ccec;font-size:17px;line-height:1.75;margin-bottom:28px}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:9px;background:#b53010;color:#fff;font-size:16px;font-weight:700;padding:14px 28px;border-radius:7px;transition:background .2s;white-space:nowrap}
.btn-primary:hover{background:#8c2209}
.btn-outline{display:inline-flex;align-items:center;gap:6px;border:2px solid rgba(122,180,255,.5);color:#7ab4ff;font-size:16px;font-weight:700;padding:14px 28px;border-radius:7px;transition:background .2s}
.btn-outline:hover{background:rgba(122,180,255,.1)}
.trust-row{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.trust-item{color:#b8ccec;font-size:13px;font-weight:500;display:flex;align-items:center;gap:7px}
.trust-item svg{color:#7ab4ff;flex-shrink:0;width:16px;height:16px}
.area-strip{background:var(--blue);padding:11px 20px;text-align:center;font-size:13px;color:#fff;font-weight:600}
.page-hero{background:var(--blue-dark);padding:52px 20px 48px;text-align:center}
.breadcrumb{font-size:13px;color:rgba(255,255,255,.6);margin-bottom:14px}
.breadcrumb a{color:rgba(255,255,255,.6);transition:color .2s}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:#7ab4ff}
.page-hero h1{color:#fff;font-size:clamp(24px,3.5vw,40px);font-weight:800;margin-bottom:10px}
.page-hero p{color:#b8ccec;font-size:16px;max-width:640px;margin:0 auto}
.section{padding:68px 20px}
.section-alt{padding:68px 20px;background:var(--gray)}
.container{max-width:1160px;margin:0 auto}
.section-tag{display:inline-block;background:var(--blue-pale);color:#1a4fa0;font-size:11.5px;font-weight:700;padding:4px 14px;border-radius:20px;letter-spacing:.07em;text-transform:uppercase;margin-bottom:12px}
.section-header{text-align:center;margin-bottom:48px}
.section-header h2{font-size:clamp(22px,3vw,34px);font-weight:800;color:var(--text);margin-bottom:10px}
.section-header p{font-size:15.5px;color:var(--text-mid);max-width:600px;margin:0 auto;line-height:1.7}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc-card{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s}
.svc-card:hover{border-color:var(--blue);box-shadow:0 4px 20px rgba(26,79,160,.13)}
.svc-img{aspect-ratio:16/9;overflow:hidden;background:var(--gray)}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.svc-card:hover .svc-img img{transform:scale(1.04)}
.svc-body{padding:22px 20px 24px;flex:1;display:flex;flex-direction:column}
.svc-icon{width:50px;height:50px;background:var(--blue-pale);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex-shrink:0}
.svc-icon svg{width:26px;height:26px;color:var(--blue)}
.svc-body h3{font-size:17px;font-weight:700;margin-bottom:9px}
.svc-body p{font-size:14px;color:var(--text-mid);line-height:1.7;flex:1;margin-bottom:16px}
.svc-link{font-size:13.5px;color:#b53010;font-weight:700;display:inline-flex;align-items:center;gap:4px;margin-top:auto}
.svc-link:hover{text-decoration:underline}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.why-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:26px 18px;text-align:center}
.why-icon{width:58px;height:58px;background:var(--blue-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.why-icon svg{width:27px;height:27px;color:#7ab4ff}
.why-stat{font-size:28px;font-weight:800;color:var(--blue);margin-bottom:5px}
.why-card h3,.why-card h4{font-size:15px;font-weight:700;margin-bottom:6px}
.why-card p{font-size:13px;color:var(--text-mid);line-height:1.6}
.brands-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.brand-chip{display:flex;align-items:center;justify-content:center;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:13.5px;font-weight:600;color:var(--text-mid);text-align:center;background:#fff;transition:all .15s}
.brand-chip:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-pale)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:22px}
.stars{color:#f4b400;font-size:16px;letter-spacing:3px;margin-bottom:10px}
.review-card p{font-size:14px;color:var(--text-mid);line-height:1.75;margin-bottom:12px;font-style:italic}
.reviewer-name{font-size:13.5px;font-weight:700}
.reviewer-loc{font-size:12px;color:#4a5878}
.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.city-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:18px 12px;text-align:center;transition:border-color .2s,box-shadow .2s;display:block}
.city-card:hover{border-color:var(--blue);box-shadow:0 4px 14px rgba(26,79,160,.1)}
.city-icon{width:42px;height:42px;background:var(--blue-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.city-icon svg{width:20px;height:20px;color:#7ab4ff}
.city-card h3,.city-card h4{font-size:13.5px;font-weight:700}
.city-card p{font-size:11.5px;color:#4a5878;margin-top:3px}
.seo-block{background:#fff;padding:56px 20px}
.seo-block .container{max-width:940px}
.seo-block h2{font-size:26px;font-weight:800;margin-bottom:16px;color:var(--text)}
.seo-block h3{font-size:20px;font-weight:700;margin:28px 0 10px;color:var(--text)}
.seo-block p{font-size:15px;color:var(--text-mid);line-height:1.85;margin-bottom:14px}
.seo-block ul{margin:12px 0 16px;padding-left:0}
.seo-block ul li{font-size:15px;color:var(--text-mid);line-height:1.75;padding:5px 0 5px 26px;position:relative}
.seo-block ul li::before{content:"✓";position:absolute;left:0;color:var(--blue);font-weight:700}
.seo-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.info-box{background:var(--blue-pale);border-left:4px solid var(--blue);border-radius:0 8px 8px 0;padding:14px 16px;font-size:14px;color:#0a2f6b;line-height:1.7;margin:16px 0}
.detail-grid{display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start;max-width:1100px;margin:0 auto}
.detail-content h2{font-size:22px;font-weight:800;margin:28px 0 10px;color:var(--blue)}
.detail-content h2:first-child{margin-top:0}
.detail-content p{font-size:15px;color:var(--text-mid);line-height:1.85;margin-bottom:14px}
.detail-content ul{list-style:none;margin:14px 0 20px}
.detail-content ul li{font-size:15px;color:var(--text-mid);padding:8px 0 8px 28px;position:relative;border-bottom:1px solid var(--border)}
.detail-content ul li:last-child{border-bottom:none}
.detail-content ul li::before{content:"✓";position:absolute;left:0;color:var(--blue);font-weight:700}
.detail-sidebar .call-box{background:var(--blue-dark);border-radius:14px;padding:28px;text-align:center;margin-bottom:16px}
.call-box p{color:#b8ccec;font-size:14px;margin-bottom:8px}
.call-box .phone{font-size:24px;font-weight:800;color:#7ab4ff;display:block;margin-bottom:16px}
.call-box .book-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;font-weight:700;font-size:15px;padding:12px 20px;border-radius:7px;width:100%;transition:background .2s}
.call-box .book-btn:hover{background:var(--accent-dark)}
.sidebar-links{background:#fff;border:1px solid var(--border);border-radius:12px;padding:20px;margin-top:16px}
.sidebar-links h4{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-mid);margin-bottom:12px}
.sidebar-links a{display:block;padding:9px 0;font-size:14px;color:var(--text-mid);border-bottom:1px solid var(--border);transition:color .15s}
.sidebar-links a:last-child{border-bottom:none}
.sidebar-links a:hover{color:var(--blue)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.post-card{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s}
.post-card:hover{border-color:var(--blue);box-shadow:0 4px 20px rgba(26,79,160,.12)}
.post-img{aspect-ratio:16/9;overflow:hidden;background:var(--gray)}
.post-img img{width:100%;height:100%;object-fit:cover}
.post-body{padding:20px;flex:1;display:flex;flex-direction:column}
.post-date{font-size:12px;color:#4a5878;margin-bottom:8px}
.post-body h3{font-size:16px;font-weight:700;margin-bottom:8px;line-height:1.4}
.post-body p{font-size:13.5px;color:var(--text-mid);line-height:1.7;flex:1;margin-bottom:14px}
.post-link{font-size:13px;color:var(--blue);font-weight:700;margin-top:auto}
.post-link:hover{text-decoration:underline}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;max-width:1100px;margin:0 auto}
.contact-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px}
.contact-icon{width:48px;height:48px;background:var(--blue-dark);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-icon svg{width:22px;height:22px;color:#7ab4ff}
.contact-item h4{font-size:14px;font-weight:700;margin-bottom:4px}
.contact-item p,.contact-item a{font-size:15px;color:var(--text-mid);line-height:1.75}
.contact-item a:hover{color:var(--blue)}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:5px;color:var(--text)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:8px;font:inherit;font-size:14px;color:var(--text);transition:border-color .15s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--blue)}
.form-group textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.submit-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;font-size:16px;font-weight:700;padding:13px 28px;border-radius:7px;border:none;cursor:pointer;transition:background .2s;width:100%}
.submit-btn:hover{background:var(--accent-dark)}
.cta-band{background:var(--blue-dark);padding:68px 20px;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(22px,3vw,36px);font-weight:800;margin-bottom:10px}
.cta-band p{color:#b8ccec;font-size:16px;margin-bottom:28px}
.cta-phone{display:inline-flex;align-items:center;gap:14px;background:#b53010;color:#fff;font-size:26px;font-weight:800;padding:16px 36px;border-radius:8px;transition:background .2s}
.cta-phone:hover{background:#8c2209}
.cta-phone svg{width:28px;height:28px;flex-shrink:0}
.cta-sub{font-size:13px;font-weight:700;color:#fff;display:block;text-align:left;margin-bottom:3px;opacity:1}
footer{background:#0d2040;padding:56px 20px 20px}
.footer-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand img{height:46px;margin-bottom:14px;filter:brightness(0) invert(1)}
.footer-brand p{color:#b0bcd4;font-size:14px;line-height:1.8}
.footer-col h4,.footer-col .footer-heading{color:#7ab4ff;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;margin-bottom:14px}
.footer-col a,.footer-col p{display:block;color:#b0bcd4;font-size:14px;margin-bottom:8px;line-height:1.7;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{max-width:1160px;margin:20px auto 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-bottom p,.footer-bottom a{color:#b0bcd4;font-size:13px}
.footer-bottom a{margin-left:16px}
.footer-bottom a:hover{color:#fff}
@media(max-width:900px){
  .hamburger{display:flex}
  .nav-menu{display:none;position:fixed;top:68px;left:0;right:0;bottom:0;background:var(--blue-dark);flex-direction:column;align-items:stretch;padding:16px;overflow-y:auto;gap:0}
  .nav-menu.open{display:flex}
  .nav-menu>a,.nav-menu>.drop-wrap>a{padding:14px 16px;font-size:15px;border-radius:8px}
  .dropdown{display:none;position:static;background:rgba(255,255,255,.05);border:none;border-radius:8px;padding:4px 0 4px 16px;margin:4px 0;box-shadow:none;columns:1;min-width:unset}
  .dropdown.mob-open{display:block}
  .drop-wrap>a::after{content:" +";font-size:16px;font-weight:700;opacity:.8;float:right}
  .drop-wrap.mob-active>a::after{content:" −";font-size:18px;font-weight:700;opacity:.8;float:right}
  .services-grid,.why-grid,.reviews-grid,.contact-grid,.seo-grid,.detail-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  /* Mobile nav buttons — full width, stacked, no gap */
  .nav-menu a.nav-cta,
  .nav-menu button.nav-cta,
  .nav-menu .hcp-button.nav-cta{
    display:flex!important;
    width:100%;
    justify-content:center;
    margin:4px 0 0 0;
    padding:14px 16px!important;
    font-size:15px!important;
    border-radius:8px!important;
    box-sizing:border-box;
  }
}
@media(max-width:480px){
  .hero h1{font-size:26px}
  .hero-btns{flex-direction:column;align-items:stretch}
  .btn-primary,.btn-outline{justify-content:center}
  .brands-grid{grid-template-columns:repeat(2,1fr)}
  .cities-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .cta-phone{font-size:20px;padding:14px 20px}
}

/* ── HousecallPro booking button ── */
.hcp-button{font-family:'Segoe UI',Arial,sans-serif;font-size:inherit;border:none;cursor:pointer}
.nav-menu .hcp-button.nav-cta{background:var(--accent)!important;color:#fff;font-weight:700;border-radius:6px;padding:8px 16px;font-size:14px;white-space:nowrap;transition:background .2s;line-height:1.4}
.nav-menu .hcp-button.nav-cta:hover{background:var(--accent-dark)!important}
