
:root{
  --blue:#082a66;
  --blue2:#0d63ce;
  --green:#56ae19;
  --text:#152348;
  --muted:#5f6d83;
  --bg:#f7f9fb;
  --card:#ffffff;
  --border:#dfe8f1;
  --shadow:0 18px 45px rgba(8,42,102,.09);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:#fff;overflow-x:hidden}
.container{width:min(1180px,calc(100% - 48px));margin:0 auto}
.site-header{background:#fff;border-bottom:1px solid #edf1f5;position:sticky;top:0;z-index:20}
.nav-wrap{height:82px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--blue);min-width:255px}
.brand img{width:58px;height:58px;object-fit:contain}
.logo-mark{width:58px;height:58px;border-radius:16px;background:linear-gradient(135deg,#0775a8,#5bb51e);display:grid;place-items:center;color:#fff;font-size:28px}
.brand strong{display:block;font-size:28px;line-height:.95}
.brand small{display:block;color:var(--green);text-transform:uppercase;font-size:17px;font-weight:800;letter-spacing:1px}
.desktop-nav{display:flex;align-items:center;gap:24px}
.desktop-nav a{text-decoration:none;color:#0d1837;font-weight:800;white-space:nowrap}
.header-phone{text-decoration:none;color:var(--blue);font-size:28px;font-weight:900;line-height:.9;white-space:nowrap}
.header-phone small{display:block;color:var(--green);font-size:14px;margin-top:8px}
.hero{background:var(--bg);padding:70px 0 56px}
.hero-grid{display:grid;grid-template-columns:1fr 430px;align-items:center;gap:56px}
.eyebrow,.section-kicker{text-transform:uppercase;color:var(--green);font-weight:900;letter-spacing:1.4px;margin:0 0 14px}
.hero h1{font-size:64px;line-height:1.04;letter-spacing:-2px;color:var(--blue);margin:0 0 22px;max-width:680px}
.hero-sub{font-size:20px;line-height:1.6;color:#21365c;margin:0 0 28px;max-width:650px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:17px 28px;border-radius:10px;font-weight:900;text-decoration:none;font-size:17px}
.btn-primary{background:#0c66d4;color:#fff}
.btn-outline{background:#fff;color:#0c66d4;border:2px solid #0c66d4}
.trust-pills{display:flex;flex-wrap:wrap;gap:10px}
.trust-pills span{background:#fff;border:1px solid var(--border);border-radius:999px;padding:10px 14px;font-weight:800;color:#10234a}
.quote-panel{background:#fff;border-radius:24px;padding:30px;box-shadow:var(--shadow);border:1px solid #e8eef5}
.quote-panel h2{margin:0 0 8px;color:var(--blue);font-size:30px}
.quote-panel p{margin:0 0 20px;color:var(--muted)}
.quote-form{display:grid;gap:12px}
.quote-form input,.quote-form select,.quote-form textarea{width:100%;padding:14px 15px;border:1px solid #ccd8e5;border-radius:10px;font-size:15px;font-family:inherit}
.quote-form textarea{min-height:94px;resize:vertical}
.quote-form button{border:0;border-radius:10px;padding:16px;background:var(--green);color:#fff;font-weight:900;font-size:17px;cursor:pointer}
.image-strip{background:#fff;padding:32px 0 0}
.image-strip img{width:100%;height:360px;object-fit:cover;border-radius:28px;display:block;box-shadow:none}
.quick-trust{padding:28px 0;background:#fff}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.trust-grid div,.service-grid article,.info-card,details{background:#fff;border:1px solid var(--border);border-radius:18px;padding:22px;box-shadow:0 10px 25px rgba(8,42,102,.05)}
.trust-grid strong{display:block;color:var(--blue);font-size:18px}
.trust-grid span{display:block;color:var(--muted);margin-top:6px}
.section{padding:70px 0}
.section h2{font-size:42px;line-height:1.1;color:var(--blue);margin:0 0 26px}
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.service-grid h3{color:var(--blue);margin:0 0 10px;font-size:20px}
.service-grid p{color:var(--muted);line-height:1.55;margin:0}
.split-section,.areas{background:var(--bg)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.split p,.areas p,.faq p{font-size:18px;line-height:1.65;color:var(--muted)}
.split li{margin:10px 0;font-weight:700}
.info-card{font-size:28px;font-weight:900;color:var(--blue);line-height:1.25}
details{margin-bottom:14px}
summary{font-weight:900;color:var(--blue);cursor:pointer;font-size:19px}
.cta-section{padding:60px 0;background:var(--blue)}
.cta-box{display:flex;align-items:center;justify-content:space-between;gap:24px;color:#fff}
.cta-box h2{margin:0 0 8px;font-size:36px}
.cta-box p{margin:0;color:#dce7f8}
footer{padding:28px 0;background:#061b43;color:#dce7f8}
.footer-inner{display:flex;justify-content:space-between;gap:20px}
.sticky-call{position:fixed;right:24px;bottom:24px;background:var(--green);color:#fff;text-decoration:none;font-weight:900;padding:15px 24px;border-radius:999px;box-shadow:0 10px 25px rgba(0,0,0,.18);z-index:50}
@media(max-width:960px){
  .container{width:min(100% - 32px,1180px)}
  .nav-wrap{height:76px}
  .desktop-nav{display:none}
  .brand strong{font-size:24px}.brand small{font-size:14px}
  .header-phone{font-size:22px}
  .hero{padding:36px 0 40px}
  .hero-grid{grid-template-columns:1fr;gap:24px}
  .quote-panel{order:2}
  .hero h1{font-size:42px;letter-spacing:-1px}
  .hero-sub{font-size:17px}
  .image-strip img{height:260px;border-radius:22px}
  .trust-grid,.service-grid,.split{grid-template-columns:1fr}
  .section{padding:48px 0}
  .section h2{font-size:32px}
  .cta-box,.footer-inner{flex-direction:column;align-items:flex-start}
}
@media(max-width:520px){
  .header-phone{display:none}
  .brand{min-width:0}
  .logo-mark,.brand img{width:52px;height:52px}
  .hero h1{font-size:36px}
  .btn{width:100%}
  .quote-panel{padding:22px;border-radius:18px}
  .sticky-call{left:16px;right:16px;text-align:center;justify-content:center}
}


/* Service icons added back */
.service-grid article{
  position:relative;
  padding-top:30px;
}
.service-icon{
  width:62px;
  height:62px;
  border-radius:18px;
  display:grid;
  place-items:center;
  font-size:30px;
  margin-bottom:18px;
  background:linear-gradient(135deg,#eaf5ff,#f2fff0);
  border:1px solid #d9e9f7;
  box-shadow:0 8px 20px rgba(8,42,102,.06);
}
.service-grid article:hover{
  transform:translateY(-3px);
  transition:.2s ease;
  box-shadow:0 14px 30px rgba(8,42,102,.08);
}
@media(max-width:960px){
  .service-icon{
    width:56px;
    height:56px;
    font-size:27px;
  }
}


/* FINAL MOBILE SERVICE GRID FIX
   Keeps the card boxes and shows 2 cards per row only on mobile */
@media (max-width: 600px){
  .section .service-grid{
    display:grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap:12px !important;
    align-items:stretch !important;
  }

  .section .service-grid article{
    display:block !important;
    background:#fff !important;
    border:1px solid #dfe8f1 !important;
    border-radius:18px !important;
    padding:16px 12px !important;
    min-height:205px !important;
    text-align:left !important;
    box-shadow:0 8px 22px rgba(8,42,102,.05) !important;
  }

  .section .service-grid .service-icon{
    width:44px !important;
    height:44px !important;
    min-width:44px !important;
    border-radius:14px !important;
    font-size:22px !important;
    margin:0 0 12px 0 !important;
    display:grid !important;
    place-items:center !important;
  }

  .section .service-grid article h3{
    font-size:17px !important;
    line-height:1.18 !important;
    margin:0 0 8px 0 !important;
    text-align:left !important;
  }

  .section .service-grid article p{
    font-size:13.5px !important;
    line-height:1.42 !important;
    margin:0 !important;
    text-align:left !important;
  }

  .quick-trust .trust-grid{
    display:grid !important;
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    gap:10px !important;
  }

  .quick-trust .trust-grid div{
    padding:14px 12px !important;
    border-radius:16px !important;
  }

  .quick-trust .trust-grid strong{
    display:block !important;
    font-size:14px !important;
    line-height:1.25 !important;
    margin-bottom:5px !important;
  }

  .quick-trust .trust-grid span{
    display:block !important;
    font-size:12.5px !important;
    line-height:1.35 !important;
  }
}

/* On very tiny phones, use one column so text does not break badly */
@media (max-width: 340px){
  .section .service-grid{
    grid-template-columns:1fr !important;
  }
}


/* ==========================================================
   FINAL DESKTOP GAP FIX - keep mobile service cards working
   ========================================================== */

@media (min-width: 961px){

  /* Reduce large blank areas in commercial/house split sections */
  #commercial.section,
  #house.section,
  .split-section{
    padding-top:56px !important;
    padding-bottom:56px !important;
    min-height:0 !important;
  }

  #commercial .container,
  #house .container,
  .split-section .container{
    max-width:1180px !important;
  }

  #commercial .split,
  #house .split,
  .split-section .split{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    align-items:center !important;
    gap:40px !important;
    min-height:0 !important;
  }

  #commercial h2,
  #house h2,
  .split-section h2{
    font-size:42px !important;
    line-height:1.12 !important;
    margin:0 0 18px !important;
  }

  #commercial p,
  #house p,
  .split-section p{
    margin:0 0 18px !important;
    line-height:1.55 !important;
  }

  #commercial ul,
  #house ul,
  .split-section ul{
    margin:14px 0 0 !important;
  }

  /* Replace empty-looking right cards with fuller stacked cards */
  .feature-stack{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:14px !important;
    align-self:center !important;
  }

  .mini-card{
    background:#fff !important;
    border:1px solid #dfe8f1 !important;
    border-radius:18px !important;
    padding:18px 22px !important;
    box-shadow:0 8px 24px rgba(8,42,102,.05) !important;
  }

  .mini-card strong{
    display:block !important;
    font-size:20px !important;
    line-height:1.25 !important;
    color:#082a66 !important;
    margin-bottom:6px !important;
  }

  .mini-card span{
    display:block !important;
    font-size:16px !important;
    line-height:1.45 !important;
    color:#5f6d83 !important;
  }

  /* If the old info-card still exists, make it compact */
  .info-card{
    padding:28px !important;
    font-size:28px !important;
    line-height:1.25 !important;
    min-height:0 !important;
  }
}

/* Make trust strip readable on mobile/desktop */
.quick-trust .trust-grid div{
  display:block !important;
}
.quick-trust .trust-grid strong,
.quick-trust .trust-grid span{
  display:block !important;
}

/* Keep service cards as real boxes on mobile, not loose text */
@media (max-width:600px){
  .service-grid{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:12px !important;
  }
  .service-grid article{
    background:#fff !important;
    border:1px solid #dfe8f1 !important;
    border-radius:18px !important;
    padding:16px 12px !important;
    min-height:205px !important;
    text-align:left !important;
    box-shadow:0 8px 22px rgba(8,42,102,.05) !important;
  }
  .service-icon{
    width:44px !important;
    height:44px !important;
    min-width:44px !important;
    border-radius:14px !important;
    font-size:22px !important;
    margin:0 0 12px 0 !important;
    display:grid !important;
    place-items:center !important;
  }
  .service-grid article h3{
    font-size:17px !important;
    line-height:1.18 !important;
    margin:0 0 8px !important;
    text-align:left !important;
  }
  .service-grid article p{
    font-size:13.5px !important;
    line-height:1.42 !important;
    margin:0 !important;
    text-align:left !important;
  }
}

/* === Final maximum optimisation additions === */
.hp-field{position:absolute!important;left:-9999px!important;opacity:0!important;height:0!important;width:0!important}
.review-grid,.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review-grid article,.gallery-card,.authority-box{background:#fff;border:1px solid var(--border,#dfe8f1);border-radius:18px;padding:24px;box-shadow:0 8px 24px rgba(8,42,102,.05)}
.stars{color:#ffb400;font-size:22px;letter-spacing:2px;margin-bottom:10px}
.gallery-grid{grid-template-columns:repeat(4,1fr)}
.gallery-card{min-height:180px;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(135deg,#f7fbff,#eff9ed)}
.gallery-card span{font-size:13px;color:#56ae19;font-weight:900;text-transform:uppercase;letter-spacing:1px}
.gallery-card strong{font-size:22px;color:#082a66;margin-top:8px}
.section-intro{max-width:760px;color:#5f6d83;font-size:18px;line-height:1.6}
.authority-section{background:#f7f9fb}
.authority-box{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}
.authority-list{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0;padding:0;list-style:none}
.authority-list li{background:#f7f9fb;border-radius:12px;padding:12px 14px;font-weight:800;color:#082a66}

/* Desktop section compactness and no empty gaps */
@media (min-width: 961px){
  #commercial.section,#house.section,.split-section{padding-top:54px!important;padding-bottom:54px!important;min-height:0!important}
  #commercial .split,#house .split,.split-section .split{align-items:center!important;gap:36px!important;min-height:0!important}
}

/* Stable mobile two-column service cards */
@media (max-width:600px){
  .service-grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important}
  .service-grid article{background:#fff!important;border:1px solid #dfe8f1!important;border-radius:18px!important;padding:16px 12px!important;min-height:205px!important;text-align:left!important;box-shadow:0 8px 22px rgba(8,42,102,.05)!important}
  .service-icon{width:44px!important;height:44px!important;min-width:44px!important;border-radius:14px!important;font-size:22px!important;margin:0 0 12px 0!important;display:grid!important;place-items:center!important}
  .service-grid article h3{font-size:17px!important;line-height:1.18!important;margin:0 0 8px!important;text-align:left!important}
  .service-grid article p{font-size:13.5px!important;line-height:1.42!important;margin:0!important;text-align:left!important}
  .review-grid,.gallery-grid,.authority-box,.authority-list{grid-template-columns:1fr!important}
}
@media (max-width:900px){
  .review-grid,.gallery-grid,.authority-box{grid-template-columns:1fr!important}
}


/* Visible before/after placeholder photos */
.photo-gallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.gallery-photo-card{
  background:#fff;
  border:1px solid var(--border,#dfe8f1);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(8,42,102,.06);
}
.gallery-photo-card img{
  width:100%;
  height:190px;
  object-fit:cover;
  display:block;
}
.gallery-photo-card div{
  padding:18px 20px;
}
.gallery-photo-card span{
  display:block;
  font-size:13px;
  color:#56ae19;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1px;
  margin-bottom:6px;
}
.gallery-photo-card strong{
  display:block;
  color:#082a66;
  font-size:21px;
  line-height:1.2;
}
@media(max-width:900px){
  .photo-gallery{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:520px){
  .photo-gallery{grid-template-columns:1fr;}
  .gallery-photo-card img{height:220px;}
}

/* === Dedicated landing pages for Google Ads === */
.service-hero{background:#f7f9fb;padding:76px 0}
.service-hero-grid{display:grid;grid-template-columns:1fr 430px;gap:56px;align-items:center}
.service-hero h1{font-size:62px;line-height:1.04;color:var(--blue,#082a66);letter-spacing:-1.8px;margin:0 0 22px}
.service-proof .service-image-card{background:#fff;border:1px solid var(--border,#dfe8f1);border-radius:24px;overflow:hidden;box-shadow:0 10px 30px rgba(8,42,102,.06)}
.service-image-card img{width:100%;height:360px;object-fit:cover;display:block}
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.related-grid a{display:block;background:#fff;border:1px solid var(--border,#dfe8f1);border-radius:16px;padding:18px;text-decoration:none;color:var(--blue,#082a66);font-weight:900;box-shadow:0 8px 24px rgba(8,42,102,.05)}
.photo-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gallery-photo-card{background:#fff;border:1px solid var(--border,#dfe8f1);border-radius:18px;overflow:hidden;box-shadow:0 8px 24px rgba(8,42,102,.06)}
.gallery-photo-card img{width:100%;height:190px;object-fit:cover;display:block}
.gallery-photo-card div{padding:18px 20px}
.gallery-photo-card span{display:block;font-size:13px;color:#56ae19;font-weight:900;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.gallery-photo-card strong{display:block;color:#082a66;font-size:21px;line-height:1.2}
@media(max-width:960px){
  .service-hero{padding:42px 0}
  .service-hero-grid{grid-template-columns:1fr;gap:24px}
  .service-hero h1{font-size:40px;letter-spacing:-1px}
  .related-grid{grid-template-columns:1fr 1fr}
  .photo-gallery{grid-template-columns:1fr}
}
@media(max-width:520px){
  .related-grid{grid-template-columns:1fr}
}


/* Mobile navigation menu */
.mobile-menu-btn{
  display:none;
  border:0;
  background:#082a66;
  color:#fff;
  width:48px;
  height:48px;
  border-radius:12px;
  font-size:26px;
  font-weight:900;
  cursor:pointer;
}
.mobile-nav{
  display:none;
}
@media(max-width:960px){
  .mobile-menu-btn{
    display:grid;
    place-items:center;
    flex:0 0 auto;
  }
  .desktop-nav{
    display:none!important;
  }
  .nav-wrap{
    gap:14px;
  }
  .mobile-nav{
    display:none;
    position:fixed;
    top:76px;
    left:16px;
    right:16px;
    background:#fff;
    z-index:9999;
    border:1px solid #dfe8f1;
    border-radius:18px;
    box-shadow:0 18px 45px rgba(8,42,102,.18);
    padding:14px;
  }
  body.menu-open .mobile-nav{
    display:grid;
    gap:8px;
  }
  .mobile-nav a{
    display:block;
    padding:13px 14px;
    border-radius:12px;
    text-decoration:none;
    color:#082a66;
    font-weight:900;
    background:#f7f9fb;
  }
  .mobile-nav a:last-child{
    background:#56ae19;
    color:#fff;
    text-align:center;
  }
}
