*{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{margin:0;font-family:Arial,Helvetica,sans-serif;font-size:16px;line-height:1.6;color:#0B1F33;background:#fff;padding-bottom:56px}img,svg{display:block;max-width:100%;height:auto}a{color:#0077B6;text-decoration:none}a:hover,a:focus{text-decoration:underline}h1,h2,h3{margin:0 0 .75rem;line-height:1.12;color:#0B1F33}h1{font-size:clamp(2rem,7vw,4rem);letter-spacing:-.04em}h2{font-size:clamp(1.6rem,5vw,2.45rem);letter-spacing:-.03em}h3{font-size:1.15rem}p,ul,ol{margin-top:0}section{padding:3.5rem 0}button,input,select,textarea{font:inherit}.container{width:min(1120px,calc(100% - 2rem));margin:0 auto}.skip-link{position:absolute;left:-999px;top:1rem;z-index:9999;background:#FF7A00;color:#0B1F33;padding:.75rem 1rem;border-radius:.5rem}.skip-link:focus{left:1rem}.eyebrow{display:inline-flex;margin-bottom:.9rem;font-size:.8rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#0077B6}.section-heading{max-width:760px;margin-bottom:2rem}.section-heading p,.hero-intro{font-size:1.08rem;color:#40556B}.btn,.header-ctas a,.mobile-sticky-cta a,button.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:.85rem 1.15rem;border-radius:.65rem;border:2px solid transparent;font-weight:900;line-height:1;text-align:center;cursor:pointer;text-decoration:none}.btn:hover,.btn:focus,.header-ctas a:hover,.header-ctas a:focus,.mobile-sticky-cta a:hover,.mobile-sticky-cta a:focus{text-decoration:none}.btn-primary,.btn-phone{background:#FF7A00;color:#0B1F33;border-color:#FF7A00}.btn-primary:hover,.btn-phone:hover,.btn-primary:focus,.btn-phone:focus{background:#e86d00;border-color:#e86d00}.btn-secondary{background:#fff;color:#0B1F33;border-color:#d7e2ea}.btn-secondary:hover,.btn-secondary:focus{border-color:#0077B6;color:#0077B6}.section-ctas,.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.4rem}.site-header{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid #e4ecf2}.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:76px;gap:1rem}.site-logo{display:inline-flex;align-items:center;flex:0 0 auto;max-width:230px}.site-logo img{max-height:58px}.main-nav{display:none;position:absolute;left:0;right:0;top:100%;background:#fff;border-bottom:1px solid #e4ecf2;box-shadow:0 16px 30px rgba(11,31,51,.1)}.main-nav.is-open{display:block}.main-nav ul,.footer-nav ul{list-style:none;margin:0;padding:0}.main-nav li{border-top:1px solid #eef3f7}.main-nav a{display:block;padding:1rem;color:#0B1F33;font-weight:800}.menu-toggle{display:grid;gap:4px;width:44px;height:44px;padding:10px;border:1px solid #d7e2ea;border-radius:.55rem;background:#fff}.menu-toggle span{display:block;height:3px;background:#0B1F33;border-radius:999px}.header-ctas{display:flex;align-items:center;gap:.5rem}.header-ctas .btn-secondary{display:none}.mobile-sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:1001;display:grid;grid-template-columns:1fr 1fr;background:#0B1F33}.mobile-sticky-cta a{border-radius:0;min-height:56px}.mobile-sticky-cta a:first-child{background:#FF7A00;color:#0B1F33}.mobile-sticky-cta a:last-child{background:#0077B6;color:#fff}.hero,.service-hero,.services-hero,.contact-hero{background:linear-gradient(135deg,rgba(11,31,51,.96),rgba(0,119,182,.9)),#0B1F33;color:#fff;padding:4rem 0}.hero h1,.hero h2,.service-hero h1,.service-hero h2,.services-hero h1,.contact-hero h1{color:#fff}.hero p,.service-hero p,.services-hero p,.contact-hero p{color:#e8f2f8}.hero-inner,.service-hero-inner,.final-contact-inner,.contact-form-inner{display:grid;gap:2rem}.hero-content,.service-hero-content{max-width:700px}.hero-trust-list{display:grid;gap:.5rem;margin:1.2rem 0 0;padding:0;list-style:none}.hero-trust-list li{position:relative;padding-left:1.35rem;color:#fff;font-weight:800}.hero-trust-list li:before{content:'✓';position:absolute;left:0;color:#FF7A00}.hero-form-card,.contact-form-card,.callback-form-section form{background:#fff;color:#0B1F33;border-radius:1rem;padding:1.25rem;box-shadow:0 18px 45px rgba(11,31,51,.18)}.hero-form-card p,.contact-form-card p{color:#40556B}form{display:grid;gap:.85rem}label{font-weight:900;font-size:.92rem;color:#0B1F33}input,textarea,select{width:100%;border:1px solid #c9d8e2;border-radius:.55rem;padding:.8rem .85rem;background:#fff;color:#0B1F33}input:focus,textarea:focus,select:focus{outline:3px solid rgba(0,119,182,.22);border-color:#0077B6}.emergency-strip,.service-cta-band,.mid-cta-section,.phone-cta-section,.final-cta-section,.final-contact-cta{background:#0B1F33;color:#fff}.emergency-strip h2,.service-cta-band h2,.mid-cta-section h2,.phone-cta-section h2,.final-cta-section h2,.final-contact-cta h2{color:#fff}.emergency-strip p,.service-cta-band p,.mid-cta-section p,.phone-cta-section p,.final-cta-section p,.final-contact-cta p{color:#e8f2f8}.emergency-strip-inner{display:grid;gap:1rem;align-items:center}.trust-strip,.problems-section,.local-area-section,.final-contact-section,.local-area-note{background:#F5F8FA}.trust-strip{padding:1.5rem 0}.trust-strip-list{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin:0 0 1rem;padding:0;list-style:none}.trust-strip-list li{background:#fff;border:1px solid #e4ecf2;border-radius:.75rem;padding:.8rem;font-weight:900;text-align:center}.trust-strip p{text-align:center;color:#40556B;margin:0}.services-grid,.why-grid{display:grid;gap:1rem}.service-card,.why-grid article,.process-steps li{background:#fff;border:1px solid #e4ecf2;border-radius:1rem;padding:1.25rem;box-shadow:0 10px 25px rgba(11,31,51,.06)}.service-card p,.why-grid p,.process-steps p,.local-area-section p,.local-coverage-section p,.final-contact-section p{color:#40556B}.service-card a{display:inline-flex;margin-top:.5rem;font-weight:900}.problem-list,.signs-list{display:grid;gap:.65rem;margin:0 0 1.5rem;padding:0;list-style:none}.problem-list li,.signs-list li{position:relative;background:#fff;border:1px solid #e4ecf2;border-radius:.75rem;padding:.8rem .8rem .8rem 2.2rem;font-weight:800}.problem-list li:before,.signs-list li:before{content:'✓';position:absolute;left:.85rem;color:#0077B6;font-weight:900}.process-steps{display:grid;gap:1rem;margin:0;padding:0;list-style:none;counter-reset:process}.process-steps li{position:relative;padding-left:4rem;counter-increment:process}.process-steps li:before{content:counter(process);position:absolute;top:1.2rem;left:1.2rem;width:2rem;height:2rem;border-radius:999px;display:grid;place-items:center;background:#FF7A00;color:#0B1F33;font-weight:900}.faq-list{display:grid;gap:.8rem;margin-bottom:1.5rem}details{background:#fff;border:1px solid #d7e2ea;border-radius:.85rem;padding:1rem}summary{cursor:pointer;font-weight:900;color:#0B1F33}summary::marker{color:#0077B6}details p{margin:.75rem 0 0;color:#40556B}.legal-page .container{max-width:860px}.legal-page h2{font-size:1.35rem;margin-top:2rem}.legal-page p{color:#40556B}.thank-you-page,.error-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,rgba(11,31,51,.96),rgba(0,119,182,.88)),#0B1F33;color:#fff;text-align:center;padding:2rem 0}.thank-you-page h1,.error-page h1{color:#fff}.thank-you-page p,.error-page p{color:#e8f2f8;max-width:620px;margin-left:auto;margin-right:auto}.thanks-logo{max-width:420px;margin:0 auto 2rem}.site-footer{background:#081827;color:#DDEAF2;padding:3rem 0}.footer-inner{display:grid;gap:2rem}.footer-brand img{max-height:78px;margin-bottom:1rem}.footer-brand p,.footer-legal p{color:#DDEAF2}.footer-brand a,.footer-nav a,.footer-legal a{color:#fff}.footer-phone{display:inline-flex;margin-top:.5rem;font-weight:900}.footer-nav h2{color:#fff;font-size:1.1rem}.footer-nav li+li{margin-top:.5rem}.footer-legal{border-top:1px solid rgba(255,255,255,.12);padding-top:1rem}.whatsapp-float{position:fixed;right:1rem;bottom:4.75rem;z-index:1002;width:58px;height:58px;border-radius:999px;background:#25D366;color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(11,31,51,.25);text-decoration:none;border:3px solid #fff}.whatsapp-float svg{width:32px;height:32px;fill:#fff}.whatsapp-float:hover,.whatsapp-float:focus{background:#1ebe5d;text-decoration:none;outline:3px solid rgba(37,211,102,.35);outline-offset:3px}@media(min-width:640px){.trust-strip-list,.problem-list,.signs-list{grid-template-columns:repeat(2,1fr)}.services-grid,.why-grid{grid-template-columns:repeat(2,1fr)}.process-steps{grid-template-columns:repeat(2,1fr)}}@media(min-width:900px){body{padding-bottom:0}section{padding:5rem 0}.menu-toggle{display:none}.main-nav{display:block;position:static;border:0;box-shadow:none}.main-nav ul{display:flex;align-items:center;gap:1.25rem}.main-nav li{border:0}.main-nav a{padding:0;font-size:.95rem}.header-ctas .btn-secondary{display:inline-flex}.mobile-sticky-cta{display:none}.hero-inner,.service-hero-inner,.final-contact-inner,.contact-form-inner{grid-template-columns:minmax(0,1.05fr) minmax(360px,.75fr);align-items:center}.emergency-strip-inner{grid-template-columns:1fr auto}.trust-strip-list{grid-template-columns:repeat(4,1fr)}.services-grid{grid-template-columns:repeat(3,1fr)}.why-grid{grid-template-columns:repeat(4,1fr)}.process-steps{grid-template-columns:repeat(4,1fr)}.problem-list,.signs-list{grid-template-columns:repeat(4,1fr)}.footer-inner{grid-template-columns:1.25fr .8fr .8fr 1fr}.footer-legal{border-top:0;padding-top:0}.whatsapp-float{bottom:1.25rem;right:1.25rem}}@media(max-width:899px){.header-inner{min-height:68px}.site-logo{max-width:168px}.header-ctas .btn-phone{min-height:42px;padding:.7rem .8rem;font-size:.9rem}.hero,.service-hero,.services-hero,.contact-hero{padding:3rem 0}.hero-ctas .btn,.section-ctas .btn,form .btn{width:100%}.hero-form-card,.contact-form-card,.callback-form-section form{padding:1rem}}@media(max-width:420px){.container{width:min(100% - 1.25rem,1120px)}.header-ctas .btn-phone{font-size:.8rem;padding-inline:.6rem}.site-logo{max-width:138px}.trust-strip-list{grid-template-columns:1fr}}

.form-honeypot{display:none!important;}


/* Mobile header layout fix: logo left, burger menu right, no phone CTA in header */
@media (max-width: 899px) {
  .header-inner {
    justify-content: space-between;
    gap: 0.75rem;
  }

  .site-logo {
    flex: 1 1 auto;
    max-width: min(230px, calc(100% - 64px));
  }

  .site-logo img {
    max-height: 54px;
    width: auto;
  }

  .menu-toggle {
    flex: 0 0 44px;
    margin-left: auto;
    order: 2;
  }

  .header-ctas {
    display: none;
  }
}

@media (max-width: 420px) {
  .site-logo {
    max-width: min(200px, calc(100% - 58px));
  }
}

/* SYNCED MASTER VISUAL IMPROVEMENTS */
/* PPC hero image layout fix
   Keeps the van/drainage image visible without placing text over the van branding. */
.ppc-hero-media {
  display: block;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 18px 45px rgba(11,31,51,.22);
  border: 1px solid rgba(255,255,255,.18);
  background: #0B1F33;
  min-height: 220px;
}

.ppc-hero-media img {
  width: 100%;
  height: 100%;
  min-height: 220px;
  object-fit: cover;
  object-position: 58% center;
}

@media (min-width: 900px) {
  .hero-inner {
    grid-template-columns: minmax(0, .82fr) minmax(340px, .72fr) minmax(360px, .72fr);
    align-items: center;
  }

  .hero-content {
    position: relative;
    z-index: 2;
  }

  .ppc-hero-media {
    min-height: 440px;
  }

  .ppc-hero-media img {
    min-height: 440px;
    object-position: 62% center;
  }
}

@media (max-width: 899px) {
  .hero-inner {
    grid-template-columns: 1fr;
  }

  .ppc-hero-media {
    order: 2;
    min-height: 230px;
  }

  .ppc-hero-media img {
    min-height: 230px;
    object-position: 70% center;
  }

  .hero-form-card {
    order: 3;
  }
}

@media (max-width: 520px) {
  .ppc-hero-media {
    min-height: 190px;
  }

  .ppc-hero-media img {
    min-height: 190px;
    object-position: 72% center;
  }
}

/* PPC hero layout refinement
   Focuses visual on branded van / engineers / drainage work while keeping text and form clean. */
.hero .hero-content {
  max-width: 600px;
}

.hero .hero-content h1 {
  max-width: 10.5ch;
}

.hero .hero-intro {
  max-width: 560px;
}

.ppc-hero-media {
  position: relative;
  min-height: 260px;
  border-radius: 1rem;
  overflow: hidden;
  background: #0B1F33;
}

.ppc-hero-media::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(11,31,51,0.04), rgba(11,31,51,0.14));
}

.ppc-hero-media img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
  object-position: 55% center;
}

@media (min-width: 900px) {
  .hero-inner {
    grid-template-columns: minmax(0, .72fr) minmax(380px, .86fr) minmax(350px, .68fr);
    gap: 1.5rem;
  }

  .hero .hero-content {
    max-width: 560px;
  }

  .ppc-hero-media {
    min-height: 460px;
  }

  .ppc-hero-media img {
    min-height: 460px;
    object-position: 58% center;
  }
}

@media (max-width: 899px) {
  .hero .hero-content {
    max-width: 100%;
  }

  .hero .hero-content h1 {
    max-width: 100%;
  }

  .ppc-hero-media {
    order: 2;
    min-height: 240px;
  }

  .ppc-hero-media img {
    min-height: 240px;
    object-position: 60% center;
  }

  .hero-form-card {
    order: 3;
  }
}

@media (max-width: 520px) {
  .hero {
    padding-top: 2.5rem;
  }

  .ppc-hero-media {
    min-height: 205px;
  }

  .ppc-hero-media img {
    min-height: 205px;
    object-position: 58% center;
  }
}

/* Final PPC spacing/header fixes */
.site-header {
  overflow: visible;
}

.header-inner {
  width: min(1240px, calc(100% - 2rem));
  margin: 0 auto;
  gap: 1.25rem;
}

.site-logo {
  max-width: 250px;
  flex-shrink: 0;
}

.main-nav {
  min-width: 0;
}

.main-nav ul {
  flex-wrap: wrap;
  justify-content: center;
  row-gap: .5rem;
}

.header-ctas {
  flex-shrink: 0;
  white-space: nowrap;
}

.hero {
  overflow: hidden;
}

.hero .container.hero-inner {
  width: min(1240px, calc(100% - 2rem));
  margin: 0 auto;
}

.hero .hero-content {
  padding-left: 0;
  max-width: 560px;
}

.hero .hero-content h1,
.hero .hero-content p,
.hero .hero-ctas,
.hero .hero-trust-list {
  max-width: 100%;
}

@media (min-width: 900px) {
  .hero .container.hero-inner {
    grid-template-columns: minmax(360px, .72fr) minmax(390px, .88fr) minmax(350px, .68fr);
    gap: 1.75rem;
    padding-left: .75rem;
    padding-right: .75rem;
  }

  .hero .hero-content h1 {
    max-width: 11ch;
    font-size: clamp(2.6rem, 4.5vw, 4rem);
  }

  .hero .hero-intro {
    max-width: 530px;
  }

  .ppc-hero-media {
    min-height: 455px;
  }

  .ppc-hero-media img {
    min-height: 455px;
    object-position: 58% center;
  }
}

@media (max-width: 1100px) and (min-width: 900px) {
  .header-inner {
    width: min(100% - 1.25rem, 1180px);
    gap: .75rem;
  }

  .site-logo {
    max-width: 200px;
  }

  .main-nav a {
    font-size: .9rem;
  }

  .header-ctas .btn,
  .header-ctas a {
    padding-left: .85rem;
    padding-right: .85rem;
    font-size: .9rem;
  }

  .hero .container.hero-inner {
    grid-template-columns: minmax(310px, .8fr) minmax(330px, .85fr) minmax(330px, .75fr);
    gap: 1rem;
  }
}

@media (max-width: 899px) {
  .header-inner,
  .hero .container.hero-inner {
    width: min(100% - 1.25rem, 1120px);
  }

  .header-inner {
    display: flex;
    justify-content: space-between;
  }

  .site-logo {
    max-width: 170px;
  }

  .header-ctas {
    display: none;
  }

  .hero {
    padding-top: 2.5rem;
  }

  .hero .hero-content {
    padding-left: 0;
  }

  .hero .hero-content h1 {
    max-width: 100%;
    font-size: clamp(2rem, 10vw, 3rem);
  }

  .hero-ctas .btn {
    width: 100%;
  }

  .ppc-hero-media {
    min-height: 220px;
  }

  .ppc-hero-media img {
    min-height: 220px;
    object-position: 58% center;
  }
}

@media (max-width: 520px) {
  .hero .container.hero-inner,
  .header-inner {
    width: min(100% - 1rem, 1120px);
  }

  .ppc-hero-media {
    min-height: 190px;
  }

  .ppc-hero-media img {
    min-height: 190px;
    object-position: 56% center;
  }
}

/* Final hero image focal fix
   Prioritises the branded van while keeping the current hero card layout. */
@media (min-width: 900px) {
  .hero .container.hero-inner {
    grid-template-columns: minmax(330px, .66fr) minmax(460px, 1fr) minmax(350px, .68fr);
    gap: 1.5rem;
  }

  .ppc-hero-media {
    min-height: 455px;
  }

  .ppc-hero-media img {
    min-height: 455px;
    object-fit: cover;
    object-position: 18% center;
  }
}

@media (max-width: 899px) {
  .ppc-hero-media img {
    object-position: 18% center;
  }
}

@media (max-width: 520px) {
  .ppc-hero-media img {
    object-position: 16% center;
  }
}


/* Strategic drainage imagery section */
.work-proof-section {
  background: #F5F8FA;
}

.work-proof-grid {
  display: grid;
  gap: 1rem;
}

.work-proof-card {
  overflow: hidden;
  border-radius: 1rem;
  background: #FFFFFF;
  border: 1px solid #E4ECF2;
  box-shadow: 0 10px 25px rgba(11,31,51,.08);
}

.work-proof-card img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: center;
}

.work-proof-card-large img {
  object-position: 48% center;
}

.work-proof-card div {
  padding: 1.15rem;
}

.work-proof-card h3 {
  margin-bottom: .45rem;
}

.work-proof-card p {
  color: #40556B;
  margin-bottom: 0;
}

@media (min-width: 760px) {
  .work-proof-grid {
    grid-template-columns: 1.2fr .8fr;
    align-items: stretch;
  }

  .work-proof-card-large {
    grid-row: span 2;
  }

  .work-proof-card-large img {
    aspect-ratio: 16 / 13;
    height: 100%;
    min-height: 430px;
  }

  .work-proof-card:not(.work-proof-card-large) img {
    aspect-ratio: 16 / 8.5;
  }
}

@media (max-width: 520px) {
  .work-proof-card img {
    aspect-ratio: 16 / 9;
  }
}

/* Hero van focus override
   Keep the uploaded excavation image but bias the crop toward the branded van. */
.ppc-hero-media {
  background: #0B1F33;
}

.ppc-hero-media img {
  object-position: 22% center !important;
}

@media (min-width: 900px) {
  .ppc-hero-media img {
    object-position: 20% center !important;
  }
}

@media (max-width: 899px) {
  .ppc-hero-media img {
    object-position: 28% center !important;
  }
}

@media (max-width: 520px) {
  .ppc-hero-media img {
    object-position: 24% center !important;
  }
}


/* Form card heading contrast fix
   Keeps headings inside white hero form cards dark/readable. */
.hero .hero-form-card h2,
.hero .hero-form-card h3,
.hero .contact-form-card h2,
.hero .contact-form-card h3,
.hero-form-card h2,
.hero-form-card h3,
.contact-form-card h2,
.contact-form-card h3 {
  color: #0B1F33 !important;
}

.hero .hero-form-card p,
.hero .contact-form-card p {
  color: #40556B !important;
}
