*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Open Sans',sans-serif;color:#2C3E50;background:#fff;line-height:1.6}
:root{
  --green:#2E7D32;--green-dark:#1B5E20;--green-mid:#388E3C;--green-bright:#43A047;
  --green-light:#E8F5E9;--orange:#E65100;--orange-h:#BF360C;
  --dark:#1A2A1A;--mid:#546E7A;--light:#F7FAF7;--border:#D8E4D8;
  --white:#fff;--shadow:0 4px 24px rgba(0,0,0,.10);--r:10px;--rl:18px;--mw:1200px
}
.wrap{max-width:var(--mw);margin:0 auto;padding:0 24px}
.page{display:none}.page.active{display:block}
sec{padding:80px 0}.sec.alt{background:var(--light)}.sec.compact{padding:50px 0}

/* Type */
h1,h2,h3,h4{font-family:'Montserrat',sans-serif;line-height:1.15}
h1{font-size:clamp(30px,5vw,54px);font-weight:900}
h2{font-size:clamp(24px,4vw,38px);font-weight:800}
h3{font-size:clamp(17px,2.5vw,22px);font-weight:700}
h4{font-size:17px;font-weight:700}
p{font-size:16px;line-height:1.75;color:var(--mid)}

/* Announcement bar */
.ann{background:var(--green-dark);color:#fff;text-align:center;padding:10px 24px;font-size:13px;font-weight:600;font-family:'Montserrat',sans-serif}
.ann a{color:#FFF176;text-decoration:none;font-weight:800}

/* Nav */
nav{position:sticky;top:0;background:#fff;box-shadow:0 2px 20px rgba(0,0,0,.12);z-index:999;padding:0 24px}
.nav-i{max-width:var(--mw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.logo{cursor:pointer;flex-shrink:0}.logo img{height:54px;width:auto}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center}
.nav-links li button,.nav-links li a{font-family:'Montserrat',sans-serif;font-weight:600;font-size:14px;color:var(--dark);background:none;border:none;cursor:pointer;text-decoration:none;transition:color .2s}
.nav-links li button:hover,.nav-links li a:hover{color:var(--green)}
.drop{position:relative}
.drop-menu{display:none;position:absolute;top:calc(100% + 10px);left:0;background:#fff;box-shadow:0 8px 32px rgba(0,0,0,.14);border-radius:var(--r);min-width:230px;padding:8px 0;z-index:1000;border-top:3px solid var(--green);border:1px solid var(--border);border-top:3px solid var(--green)}
.drop.open .drop-menu{display:block;animation:dropSlide .22s cubic-bezier(.25,.46,.45,.94)}
@keyframes dropSlide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.drop-menu button{display:block;width:100%;text-align:left;padding:12px 20px;font-family:'Montserrat',sans-serif;font-weight:600;font-size:13px;color:var(--dark);background:none;border:none;cursor:pointer;transition:background .15s,color .15s;border-radius:0}
.drop-menu button:hover{background:var(--green-light);color:var(--green);padding-left:26px}
.drop-arr{display:inline-block;font-size:10px;margin-left:5px;transition:transform .25s;line-height:1}
.drop.open .drop-arr{transform:rotate(180deg)}
/* Active state on the trigger button */
.drop>button{padding:4px 0;border-radius:4px}
.drop.open>button{color:var(--green)}
.nav-phone{display:flex;align-items:center;gap:8px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:14px;padding:10px 20px;border-radius:999px;text-decoration:none;white-space:nowrap;transition:background .2s}
.nav-phone:hover{background:var(--orange-h)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px}
.burger span{display:block;width:24px;height:2px;background:var(--dark);border-radius:2px;transition:all .3s}
@media(max-width:960px){
  .burger{display:flex}
  .nav-links{display:none;position:fixed;inset:0;background:#fff;flex-direction:column;align-items:center;justify-content:center;gap:28px;z-index:998;overflow-y:auto}
  .nav-links.open{display:flex}
  .drop-menu{position:static;box-shadow:none;border-top:none;text-align:center;padding:8px 0}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--r);font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;text-decoration:none;border:none;cursor:pointer;transition:all .2s}
.btn-o{background:var(--orange);color:#fff}.btn-o:hover{background:var(--orange-h)}
.btn-g{background:var(--green);color:#fff}.btn-g:hover{background:var(--green-dark)}
.btn-w{background:#fff;color:var(--green)}.btn-w:hover{background:var(--green-light)}
.btn-ow{background:transparent;color:#fff;border:2px solid #fff}.btn-ow:hover{background:rgba(255,255,255,.1)}
.btn-lg{padding:16px 34px;font-size:17px}
.btn-xl{padding:18px 40px;font-size:19px;border-radius:12px}

/* HERO */
.hero{min-height:92vh;display:flex;align-items:center;position:relative;overflow:hidden;background-size:cover;background-position:center}
.hero-ov{position:absolute;inset:0;background:linear-gradient(110deg,rgba(27,94,32,.94) 0%,rgba(27,94,32,.80) 50%,rgba(0,0,0,.45) 100%)}
.hero-c{position:relative;z-index:2;max-width:var(--mw);margin:0 auto;padding:70px 24px;display:grid;grid-template-columns:1fr 480px;gap:60px;align-items:center;width:100%}
.hero-l{color:#fff}
.eyebrow{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:#A5D6A7;margin-bottom:14px}
.hero-l h1{color:#fff;margin-bottom:18px}
.hero-l .lead{color:rgba(255,255,255,.90);font-size:17px;margin-bottom:28px;max-width:480px}
.hero-ph{font-family:'Montserrat',sans-serif;font-size:30px;font-weight:900;color:#FFF176;display:block;margin-bottom:22px;text-decoration:none}
.hero-ph:hover{text-decoration:underline}
.hero-btns{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:28px}
.ubadges{display:flex;flex-wrap:wrap;gap:8px}
.ubadge{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.30);color:#fff;font-size:11px;font-family:'Montserrat',sans-serif;font-weight:600;padding:6px 14px;border-radius:999px}

/* Quote form */
.qform{background:#fff;border-radius:var(--rl);padding:34px;box-shadow:0 24px 60px rgba(0,0,0,.30)}
.qform h3{color:var(--green-dark);font-size:19px;margin-bottom:4px}
.qform .fsub{color:var(--mid);font-size:13px;margin-bottom:20px}
.fg{margin-bottom:14px}
.fg label{display:block;font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;color:var(--dark);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.fg input,.fg select,.fg textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--r);font-family:'Open Sans',sans-serif;font-size:15px;color:var(--dark);transition:border-color .2s;background:#fff}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(46,125,50,.12)}
.fg textarea{resize:vertical;min-height:80px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn-submit{width:100%;padding:15px;font-size:16px;margin-top:6px;justify-content:center}
.fnote{text-align:center;font-size:11px;color:#999;margin-top:8px}

@media(max-width:960px){.hero-c{grid-template-columns:1fr}.hero{min-height:auto}
  .hero-ph{font-size:22px}}

/* Trust bar */
.tbar{background:var(--green-dark);padding:18px 0}
.tbar-i{max-width:var(--mw);margin:0 auto;padding:0 24px;display:flex;flex-wrap:wrap;justify-content:center;gap:20px 40px}
.ti{display:flex;align-items:center;gap:8px;color:#fff;font-family:'Montserrat',sans-serif;font-weight:600;font-size:13px}
.ti-icon{font-size:18px}

/* Section heads */
.sh{margin-bottom:48px}
.sh.center{text-align:center}.sh.center .sdesc{margin:0 auto}
.slabel{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--green);margin-bottom:10px}
.stitle{color:var(--dark);margin-bottom:14px}
.sdesc{color:var(--mid);font-size:17px;max-width:640px}
.divider{width:50px;height:4px;background:var(--green);border-radius:2px;margin:14px 0}
.divider.c{margin:14px auto}

/* Grids */
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media(max-width:900px){.g3,.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.g3,.g4,.g2{grid-template-columns:1fr}}

/* Service cards */
.svc-card{background:#fff;border-radius:var(--rl);overflow:hidden;box-shadow:var(--shadow);transition:transform .3s,box-shadow .3s}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.18)}
.svc-card img{height:210px;width:100%;object-fit:cover;display:block}
.svc-body{padding:26px}
.svc-body h3{color:var(--green-dark);margin-bottom:10px}
.svc-body p{font-size:14px;margin-bottom:18px}
.svc-list{list-style:none;margin-bottom:22px}
.svc-list li{font-size:13px;color:var(--mid);padding:5px 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.svc-list li::before{content:"✓";color:var(--green);font-weight:700;flex-shrink:0}

/* Why cards */
.why-card{text-align:center;padding:32px 20px}
.why-icon{width:68px;height:68px;border-radius:50%;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 18px}
.why-card h4{color:var(--dark);margin-bottom:10px}

/* Gallery */
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:700px){.gal-grid{grid-template-columns:repeat(2,1fr)}}
.gal-item{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gal-item:hover img{transform:scale(1.07)}
.gal-cap{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.70));color:#fff;font-family:'Montserrat',sans-serif;font-weight:600;font-size:12px;padding:24px 12px 10px}

/* Testimonials */
.testi-card{background:#fff;border-radius:var(--rl);padding:28px;box-shadow:var(--shadow);border-left:4px solid var(--green)}
.stars{color:#FFB300;font-size:16px;margin-bottom:12px;letter-spacing:2px}
.testi-text{font-size:14px;font-style:italic;color:var(--mid);margin-bottom:18px;line-height:1.75}
.testi-author{font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;color:var(--dark)}
.testi-loc{font-size:12px;color:var(--green);font-weight:600;margin-top:2px;font-family:'Montserrat',sans-serif}

/* Process */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
@media(max-width:900px){.steps{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.steps{grid-template-columns:1fr}}
.step{text-align:center;padding:18px 8px}
.step-n{width:54px;height:54px;border-radius:50%;background:var(--green);color:#fff;font-family:'Montserrat',sans-serif;font-weight:900;font-size:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.step h4{font-size:14px;color:var(--dark);margin-bottom:6px}
.step p{font-size:12px}

/* Emergency */
.emerg{background:linear-gradient(135deg,#E65100,#BF360C);color:#fff;padding:64px 0;text-align:center}
.emerg h2{color:#fff;margin-bottom:14px}
.emerg p{color:rgba(255,255,255,.92);font-size:17px;margin-bottom:28px;max-width:640px;margin-left:auto;margin-right:auto}
.emerg-ph{font-family:'Montserrat',sans-serif;font-size:44px;font-weight:900;color:#FFF176;display:block;margin-bottom:24px;text-decoration:none}
.emerg-ph:hover{text-decoration:underline}
@media(max-width:600px){.emerg-ph{font-size:30px}}

/* FAQ */
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:20px 0;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;color:var(--dark);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-q:hover{color:var(--green)}
.faq-arr{font-size:20px;transition:transform .3s;flex-shrink:0}
.faq-item.open .faq-arr{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a p{padding-bottom:18px;font-size:15px}

/* Areas */
.area-pills{display:flex;flex-wrap:wrap;gap:12px}
.area-pill{background:#fff;border:2px solid var(--green);color:var(--green);font-family:'Montserrat',sans-serif;font-weight:700;font-size:14px;padding:12px 24px;border-radius:999px;cursor:pointer;transition:all .2s;border:none;text-decoration:none}
.area-pill:hover{background:var(--green);color:#fff}

/* CTA section */
.cta-sec{background:var(--green);padding:80px 0;text-align:center;color:#fff}
.cta-sec h2{color:#fff;margin-bottom:14px}
.cta-sec p{color:rgba(255,255,255,.92);font-size:17px;margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
.cd{display:flex;gap:14px;align-items:flex-start;margin-bottom:22px}
.cd-icon{font-size:22px;flex-shrink:0}
.cd-t strong{font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;color:var(--dark);display:block;margin-bottom:2px}
.cd-t a{color:var(--green);text-decoration:none;font-size:15px;font-weight:600}.cd-t a:hover{text-decoration:underline}
.map-ph{height:280px;background:linear-gradient(135deg,var(--green-light),#C8E6C9);border-radius:var(--rl);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;color:var(--green-dark);font-family:'Montserrat',sans-serif;font-weight:700;margin-top:28px;border:2px dashed var(--green);font-size:15px}

/* Footer */
footer{background:var(--dark);color:rgba(255,255,255,.75);padding:60px 0 0}
.foot-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px}
@media(max-width:900px){.foot-inner{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.foot-inner{grid-template-columns:1fr}}
.foot-logo{margin-bottom:14px}.foot-logo img{height:52px;filter:brightness(0) invert(1)}
.foot-desc{font-size:13px;line-height:1.75;margin-bottom:18px}
footer h4{color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:14px;margin-bottom:14px}
.flinks{list-style:none}
.flinks li{margin-bottom:8px}
.flinks li button,.flinks li a{background:none;border:none;color:rgba(255,255,255,.65);font-size:13px;cursor:pointer;text-align:left;transition:color .2s;text-decoration:none;font-family:'Open Sans',sans-serif}
.flinks li button:hover,.flinks li a:hover{color:#A5D6A7}
.fbot{border-top:1px solid rgba(255,255,255,.10);padding:20px 0;text-align:center;font-size:12px;color:rgba(255,255,255,.45)}

/* Page hero (inner) */
.ph{background-size:cover;background-position:center;position:relative;overflow:hidden;padding:80px 0;text-align:center}
.ph-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(27,94,32,.93),rgba(0,0,0,.55))}
.ph-c{position:relative;z-index:2}
.ph h1{color:#fff;margin-bottom:14px}
.ph p.lead{color:rgba(255,255,255,.90);font-size:17px;max-width:640px;margin:0 auto 28px}
.bc{font-size:12px;color:rgba(255,255,255,.65);margin-bottom:14px;font-family:'Montserrat',sans-serif;font-weight:600}
.bc span{color:#A5D6A7}

/* Feature cards */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:600px){.feat-grid{grid-template-columns:1fr}}
.feat-card{background:var(--green-light);border-radius:var(--r);padding:22px;border-left:4px solid var(--green)}
.feat-card h4{color:var(--green-dark);margin-bottom:7px;font-size:15px}
.feat-card p{font-size:13px}

/* Split layout */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.split-img img{width:100%;border-radius:var(--rl);min-height:340px;object-fit:cover;display:block}

/* Before/After */
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:700px){.ba-grid{grid-template-columns:1fr}}
.ba-item{border-radius:var(--rl);overflow:hidden;position:relative}
.ba-item img{width:100%;height:270px;object-fit:cover;display:block}
.ba-label{position:absolute;top:14px;left:14px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:11px;padding:5px 14px;border-radius:999px;text-transform:uppercase;letter-spacing:1px;color:#fff}
.ba-before{background:var(--mid)}.ba-after{background:var(--green)}

/* Thank you */
.ty{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:60px 24px}
.ty-card{max-width:580px}
.ty-check{width:100px;height:100px;border-radius:50%;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:52px;margin:0 auto 28px}
.ty-card h1{color:var(--green-dark);margin-bottom:14px;font-size:38px}
.ty-phone{font-family:'Montserrat',sans-serif;font-size:32px;font-weight:900;color:var(--orange);display:block;margin:20px 0;text-decoration:none}
.ty-phone:hover{text-decoration:underline}

/* Area hero colour accent */
.area-hero-badge{display:inline-block;background:rgba(255,255,255,.20);color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;padding:7px 18px;border-radius:999px;margin-bottom:16px;letter-spacing:1px;text-transform:uppercase}

/* Sticky mobile call bar */
.mob-call{position:fixed;bottom:0;left:0;right:0;background:var(--orange);z-index:600;display:none;align-items:center;justify-content:center;gap:10px;padding:15px;text-decoration:none;color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:15px;box-shadow:0 -4px 20px rgba(0,0,0,.20)}
@media(max-width:768px){.mob-call{display:flex};body{padding-bottom:60px}}
.back-top{position:fixed;bottom:80px;right:20px;background:var(--green);color:#fff;border:none;border-radius:50%;width:44px;height:44px;font-size:18px;cursor:pointer;box-shadow:var(--shadow);z-index:500;display:none;align-items:center;justify-content:center}
.back-top.show{display:flex}

/* Utilities */
.text-center{text-align:center}
.text-white{color:#fff}
.text-green{color:var(--green)}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-48{margin-top:48px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-0{margin-bottom:0}
.fw-bold{font-weight:700;font-family:'Montserrat',sans-serif}
.bg-green{background:var(--green)}
ul.tick{list-style:none;padding:0}
ul.tick li{padding:7px 0;border-bottom:1px solid var(--border);font-size:15px;color:var(--mid);display:flex;align-items:center;gap:10px}
ul.tick li::before{content:"✓";color:var(--green);font-weight:700;flex-shrink:0}

/* ================================================================
   SPACING, BORDER & DETAIL REFINEMENTS
   ================================================================ */

/* Ensure custom <sec> element renders as block */
sec { display: block; }

/* ---- Section vertical rhythm ---- */
sec        { padding: 96px 0; }
sec.alt    { padding: 96px 0; }
sec.compact{ padding: 56px 0; }

/* ---- Announcement bar ---- */
.ann { padding: 12px 24px; font-size: 13px; letter-spacing: 0.3px;
       border-bottom: 1px solid rgba(255,255,255,0.15); }

/* ---- Nav ---- */
nav  { border-bottom: 1px solid rgba(0,0,0,0.07); }
.nav-i { height: 78px; }
.nav-links li button, .nav-links li a { font-size: 14px; letter-spacing: 0.2px; }

/* ---- Trust bar ---- */
.tbar   { padding: 22px 0; }
.tbar-i { gap: 16px 52px; }
.ti     { gap: 10px; font-size: 13px; }

/* ---- Section heads ---- */
.sh              { margin-bottom: 60px; }
.slabel          { font-size: 11px; letter-spacing: 2.5px; margin-bottom: 12px; }
.stitle          { margin-bottom: 18px; }
.sdesc           { font-size: 17px; line-height: 1.82; }
.divider         { width: 52px; height: 4px; margin: 20px 0; border-radius: 3px; }
.divider.c       { margin: 20px auto; }

/* ---- Why Choose Us cards ---- */
.why-card {
  background: #fff;
  border-radius: var(--rl);
  padding: 36px 28px 32px;
  border: 1px solid var(--border);
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
  transition: transform .25s, box-shadow .25s;
}
.why-card:hover { transform: translateY(-5px); box-shadow: 0 12px 36px rgba(0,0,0,0.12); }
.why-icon       { width: 72px; height: 72px; border-radius: 50%; font-size: 30px;
                  margin: 0 auto 22px; border: 2px solid var(--green-light); }
.why-card h4    { margin-bottom: 12px; font-size: 16px; }
.why-card p     { font-size: 14px; line-height: 1.75; }

/* ---- Service cards ---- */
.svc-card { border: 1px solid var(--border); }
.svc-card img { height: 220px; }
.svc-body { padding: 28px 28px 30px; }
.svc-body h3 { font-size: 20px; margin-bottom: 12px; }
.svc-body p  { font-size: 15px; margin-bottom: 22px; }
.svc-list    { border-top: 1px solid var(--border); margin-bottom: 24px; }
.svc-list li { padding: 8px 0; font-size: 14px; line-height: 1.5; gap: 10px; }

/* ---- Testimonials ---- */
.testi-card {
  padding: 32px 28px;
  border-left: 4px solid var(--green);
  border-top: 1px solid var(--border);
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  border-radius: 0 var(--rl) var(--rl) 0;
}
.stars       { font-size: 18px; letter-spacing: 3px; margin-bottom: 14px; }
.testi-text  { font-size: 15px; line-height: 1.82; margin-bottom: 20px; }
.testi-author{ font-size: 14px; }
.testi-loc   { font-size: 12px; margin-top: 4px; letter-spacing: 0.3px; }

/* ---- Process steps connector line ---- */
.steps { position: relative; }
.steps::before {
  content: ''; position: absolute; top: 28px; left: 9%; right: 9%;
  height: 2px;
  background: linear-gradient(90deg, var(--green-light), var(--green), var(--green-light));
  border-radius: 1px; z-index: 0;
}
@media(max-width:900px){ .steps::before { display: none; } }
.step   { padding: 22px 10px; position: relative; z-index: 1; }
.step-n { width: 56px; height: 56px; font-size: 22px; margin-bottom: 18px;
          border: 3px solid var(--green-dark); box-shadow: 0 4px 20px rgba(46,125,50,.30); }
.step h4{ font-size: 14px; margin-bottom: 8px; line-height: 1.3; }
.step p { font-size: 13px; line-height: 1.65; }

/* ---- FAQ ---- */
.faq-item:first-child  { border-top: 1px solid var(--border); }
.faq-q { padding: 22px 0; font-size: 16px; }
.faq-a p { padding-bottom: 22px; font-size: 15px; line-height: 1.8; }

/* ---- Emergency ---- */
.emerg   { padding: 80px 0; }
.emerg p { font-size: 18px; margin-bottom: 32px; }
.emerg-ph{ font-size: clamp(34px,5vw,52px); margin: 22px 0 32px; }

/* ---- CTA section ---- */
.cta-sec   { padding: 96px 0; }
.cta-sec h2{ margin-bottom: 18px; }
.cta-sec p { font-size: 18px; margin-bottom: 36px; }
.cta-btns  { gap: 16px; }

/* ---- Gallery ---- */
.gal-grid  { gap: 16px; }
.gal-cap   { padding: 32px 14px 12px; font-size: 12px; letter-spacing: 0.5px; }

/* ---- Area pills (fix double-border bug) ---- */
.area-pill {
  display: inline-flex; align-items: center; gap: 6px;
  background: #fff; border: 2px solid var(--green); color: var(--green);
  font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 14px;
  padding: 13px 26px; border-radius: 999px; cursor: pointer;
  transition: all .2s; text-decoration: none;
}
.area-pill:hover { background: var(--green); color: #fff; }
.area-pills { gap: 14px 16px; }

/* ---- Contact section ---- */
.cd { margin-bottom: 28px; padding-bottom: 28px; border-bottom: 1px solid var(--border); }
.cd:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.cd-icon { font-size: 24px; margin-top: 2px; }
.cd-t strong { font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px;
               color: var(--mid); margin-bottom: 5px; }
.cd-t a { font-size: 16px; font-weight: 600; }
.map-ph { height: 300px; font-size: 15px; }

/* ---- Quote form ---- */
.qform       { padding: 40px 38px; border-radius: 20px; }
.qform h3    { font-size: 22px; margin-bottom: 6px; }
.qform .fsub { font-size: 14px; margin-bottom: 26px; }
.fg          { margin-bottom: 16px; }
.fg label    { font-size: 11px; letter-spacing: 0.8px; margin-bottom: 6px; }
.fg input, .fg select, .fg textarea {
  padding: 13px 16px; border-radius: 8px;
  border: 1.5px solid #C8D8C8; font-size: 15px; background: #FAFCFA;
}
.fg input:focus, .fg select:focus, .fg textarea:focus {
  border-color: var(--green); background: #fff;
  box-shadow: 0 0 0 4px rgba(46,125,50,.10);
}
.fg textarea  { min-height: 95px; }
.fg-row       { gap: 14px; }
.btn-submit   { padding: 16px; font-size: 17px; margin-top: 10px;
                border-radius: var(--r); letter-spacing: 0.3px; }
.fnote        { font-size: 12px; margin-top: 12px; color: #aaa; letter-spacing: 0.2px; }

/* ---- Inner page hero ---- */
.ph      { padding: 100px 0; }
.ph h1   { margin-bottom: 18px; }
.ph p.lead { margin-bottom: 34px; font-size: 18px; }
.bc      { margin-bottom: 18px; }
.area-hero-badge { margin-bottom: 20px; padding: 8px 20px; font-size: 13px; letter-spacing: 1.2px; }

/* ---- Split layout ---- */
.split { gap: 64px; }
.split-img img { box-shadow: 0 20px 56px rgba(0,0,0,.15); }

/* ---- Feature cards ---- */
.feat-grid  { gap: 20px; }
.feat-card  {
  padding: 26px 24px;
  border-left: 4px solid var(--green);
  border-top: 1px solid rgba(46,125,50,.12);
  border-right: 1px solid rgba(46,125,50,.12);
  border-bottom: 1px solid rgba(46,125,50,.12);
  border-radius: 0 var(--r) var(--r) 0;
}
.feat-card h4 { font-size: 16px; margin-bottom: 9px; }
.feat-card p  { font-size: 14px; line-height: 1.72; }

/* ---- Tick list ---- */
ul.tick li { padding: 10px 0; font-size: 15px; line-height: 1.6; gap: 12px; }

/* ---- Before/After ---- */
.ba-grid { gap: 24px; }
.ba-item img { height: 290px; }
.ba-label { padding: 7px 16px; font-size: 12px; letter-spacing: 1.5px; }

/* ---- Footer ---- */
footer { padding: 80px 0 0; }
.foot-inner { gap: 50px; padding-bottom: 52px; }
.foot-logo  { margin-bottom: 20px; }
.foot-logo img {
  height: 68px; filter: none;
  background: #fff; border-radius: 12px; padding: 8px 12px;
}
.foot-desc  { font-size: 14px; line-height: 1.85; margin-bottom: 24px; }
footer h4   {
  font-size: 12px; text-transform: uppercase; letter-spacing: 1.2px;
  margin-bottom: 18px; color: rgba(255,255,255,.95);
  border-bottom: 1px solid rgba(255,255,255,.10); padding-bottom: 12px;
}
.flinks li  { margin-bottom: 10px; }
.flinks li button, .flinks li a { font-size: 14px; }
.fbot { border-top: 1px solid rgba(255,255,255,.08); padding: 24px 0; font-size: 13px; }

/* ---- Thank You ---- */
.ty { padding: 80px 24px; }
.ty-card h1 { font-size: clamp(28px,4vw,44px); margin-bottom: 18px; }
.ty-phone   { font-size: clamp(28px,4vw,38px); margin: 26px 0; }
.ty-check   { width: 110px; height: 110px; font-size: 56px; margin-bottom: 34px; }

/* ---- Responsive ---- */
@media(max-width:768px){
  .wrap          { padding: 0 20px; }
  sec, sec.alt   { padding: 64px 0; }
  .ph            { padding: 70px 0; }
  .cta-sec       { padding: 64px 0; }
  .emerg         { padding: 64px 0; }
  .sh            { margin-bottom: 42px; }
  .qform         { padding: 28px 22px; }
  .split         { gap: 36px; }
  .why-card      { padding: 28px 22px; }
  .svc-body      { padding: 22px; }
  .testi-card    { padding: 24px 20px; }
  .foot-inner    { gap: 32px; padding-bottom: 40px; }
  .mob-call      { padding: 16px; font-size: 16px; }
  body           { padding-bottom: 68px; }
  .g3            { gap: 20px; }
}
@media(max-width:480px){
  sec, sec.alt   { padding: 52px 0; }
  .ph            { padding: 56px 0; }
  .sh            { margin-bottom: 32px; }
  .gal-grid      { gap: 12px; }
  .wrap          { padding: 0 16px; }
  .step          { padding: 16px 6px; }
  .qform         { padding: 24px 16px; }
}


/* ============================================================
   WHATSAPP FLOAT BUTTON
   ============================================================ */
.wa-float {
  position: fixed;
  bottom: 90px;
  right: 20px;
  width: 54px;
  height: 54px;
  background: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,.45);
  z-index: 501;
  transition: transform .2s, box-shadow .2s;
  text-decoration: none;
}
.wa-float:hover { transform: scale(1.12); box-shadow: 0 8px 28px rgba(37,211,102,.55); }
.wa-float svg  { width: 30px; height: 30px; fill: #fff; }
@media(max-width:768px){ .wa-float { bottom: 80px; right: 16px; width: 50px; height: 50px; } }

/* ============================================================
   MOBILE NAV – COMPLETE FIX
   ============================================================ */

/* Burger visible on mobile */
.burger { display: none; flex-direction: column; gap: 5px; cursor: pointer;
          background: none; border: none; padding: 8px; }
.burger span { display: block; width: 24px; height: 2.5px; background: var(--dark);
               border-radius: 2px; transition: transform .3s, opacity .3s; transform-origin: center; }

/* Burger → X animation when menu open */
.burger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.active span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.burger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media(max-width:960px){
  .burger { display: flex; }

  /* Full-screen overlay */
  .nav-links {
    display: none;
    position: fixed;
    inset: 0;
    background: #fff;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 80px 24px 40px;
    gap: 0;
    z-index: 998;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .nav-links.open { display: flex; }

  /* Close button inside overlay */
  .nav-close-item {
    position: absolute;
    top: 18px;
    right: 18px;
  }
  .close-menu-btn {
    background: none;
    border: none;
    font-size: 26px;
    cursor: pointer;
    color: var(--dark);
    padding: 8px;
    line-height: 1;
    display: block !important;
  }

  /* Nav link items */
  .nav-links > li {
    width: 100%;
    border-bottom: 1px solid var(--border);
    list-style: none;
  }
  .nav-links > li:first-child { border-bottom: none; }
  .nav-links > li > button {
    width: 100%;
    text-align: center;
    padding: 16px 20px;
    font-size: 17px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    color: var(--dark);
    background: none;
    border: none;
    cursor: pointer;
    transition: color .2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
  }
  .nav-links > li > button:hover,
  .nav-links > li > button:active { color: var(--green); }

  /* Dropdowns inside mobile overlay – static, no animation */
  .drop-menu {
    position: static !important;
    box-shadow: none !important;
    border: none !important;
    border-radius: 0 !important;
    background: var(--green-light) !important;
    padding: 4px 0 8px !important;
    margin: 0 !important;
    animation: none !important;
    width: 100%;
  }
  .drop-menu button {
    width: 100%;
    text-align: center;
    padding: 14px 20px;
    font-size: 15px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    color: var(--green-dark);
    background: none;
    border: none;
    cursor: pointer;
    display: block;
  }
  .drop-menu button:hover,
  .drop-menu button:active { background: rgba(46,125,50,.12); }

  /* Drop arrow in mobile */
  .drop-arr { font-size: 11px; }
  .drop.open .drop-arr { transform: rotate(180deg); }

  /* Hide nav phone in mobile overlay (shown in sticky bar instead) */
  .nav-phone { display: none; }
}

/* Prevent background scroll when menu open */
body.menu-open { overflow: hidden; }

