/* ============================================================
   HUNTERS SERVICES — Brand Design System
   Navy-forward (60/30/10), eco-credible, conversion-first
   ============================================================ */

:root{
  --navy:#0B2545;
  --navy-2:#0E2E55;
  --navy-3:#103a6b;
  --steel:#7CB8E4;
  --blue:#1A75D2;
  --blue-bright:#00BFFF;
  --green:#00E64D;
  --orange:#E87722;
  --white:#FFFFFF;
  --gray-50:#F0F4F8;
  --gray-100:#e2ebf3;
  --gray-300:#c3d2e0;
  --gray-500:#555555;
  --charcoal:#1A1A1A;

  --maxw:1200px;
  --radius:16px;
  --radius-sm:10px;
  --shadow-sm:0 2px 10px rgba(11,37,69,.07);
  --shadow:0 18px 50px -18px rgba(11,37,69,.35);
  --shadow-lg:0 40px 90px -30px rgba(11,37,69,.45);
  --ring:0 0 0 4px rgba(124,184,228,.35);

  --display:"Barlow",-apple-system,sans-serif;
  --cond:"Barlow Condensed",sans-serif;
  --body:"Open Sans",-apple-system,Segoe UI,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  color:var(--charcoal);
  background:var(--white);
  line-height:1.65;
  font-size:17px;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);line-height:1.05;letter-spacing:-.01em;color:var(--navy);font-weight:800}
h1{font-size:clamp(2.4rem,5.4vw,4.4rem);font-weight:900}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
p{margin-bottom:1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}

/* ---------- Utility ---------- */
.eyebrow{
  font-family:var(--display);font-weight:800;text-transform:uppercase;
  letter-spacing:.16em;font-size:.78rem;color:var(--blue);
  display:inline-flex;align-items:center;gap:.55rem;margin-bottom:1rem;
}
.eyebrow::before{content:"";width:26px;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--blue),var(--green))}
.eyebrow.light{color:var(--steel)}
.eyebrow.center{justify-content:center}
.lead{font-size:1.2rem;color:var(--gray-500)}
.center{text-align:center}
.mw-680{max-width:680px}
.mw-720{max-width:720px}
.mx-auto{margin-left:auto;margin-right:auto}
.green{color:var(--green)}
.steel{color:var(--steel)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--display);font-weight:800;font-size:1.02rem;
  padding:.95rem 1.7rem;border-radius:999px;border:0;cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  text-transform:none;letter-spacing:.01em;white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 12px 26px -10px rgba(232,119,34,.7)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 34px -10px rgba(232,119,34,.85)}
.btn-blue{background:linear-gradient(135deg,var(--blue),var(--blue-bright));color:#fff;box-shadow:0 12px 26px -10px rgba(26,117,210,.7)}
.btn-blue:hover{transform:translateY(-3px)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.35);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.16);transform:translateY(-3px)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-3);transform:translateY(-3px)}
.btn-lg{padding:1.15rem 2.1rem;font-size:1.12rem}
.btn-block{width:100%}

/* ---------- Top bar ---------- */
.topbar{
  background:linear-gradient(90deg,var(--navy),var(--navy-3));
  color:#dfeaf5;font-size:.86rem;border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:40px;gap:1rem}
.topbar a{color:#dfeaf5;transition:color .2s}
.topbar a:hover{color:var(--green)}
.topbar .tb-left{display:flex;gap:1.4rem;align-items:center}
.topbar .tb-right{display:flex;gap:1.2rem;align-items:center}
.topbar .pill{display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap}
.topbar svg{width:15px;height:15px;flex:none}
.topbar .tb-stars{color:var(--green);letter-spacing:1px}
@media(max-width:860px){.topbar .tb-left{display:none}.topbar .container{justify-content:center}}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:1000;background:var(--navy);box-shadow:0 6px 24px -12px rgba(0,0,0,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.brand img{height:46px;width:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
.nav-links{display:flex;align-items:center;gap:.3rem;list-style:none}
.nav-links>li{position:relative}
.nav-links>li>a{
  display:block;padding:.7rem .95rem;color:#eaf2fb;font-weight:600;font-size:.97rem;
  border-radius:8px;transition:color .2s,background .2s;
}
.nav-links>li>a:hover,.nav-links>li.active>a{color:#fff;background:rgba(124,184,228,.15)}
.nav-links>li>a.has-caret::after{content:"";display:inline-block;width:6px;height:6px;border-right:2px solid var(--steel);border-bottom:2px solid var(--steel);transform:rotate(45deg);margin-left:.45rem;vertical-align:middle;margin-top:-3px}
.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;min-width:250px;background:#fff;border-radius:14px;
  box-shadow:var(--shadow);padding:.5rem;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:.22s var(--ease);border:1px solid var(--gray-100);
}
.nav-links>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:flex;align-items:center;gap:.6rem;padding:.65rem .8rem;border-radius:9px;color:var(--navy);font-weight:600;font-size:.93rem;transition:background .18s,color .18s}
.dropdown a:hover{background:var(--gray-50);color:var(--blue)}
.dropdown a .dot{width:8px;height:8px;border-radius:50%;background:var(--steel);flex-shrink:0}
.nav-cta{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.nav-phone{display:flex;flex-direction:column;line-height:1.05;color:#fff;font-weight:700}
.nav-phone small{font-size:.66rem;font-weight:600;color:var(--steel);letter-spacing:.08em;text-transform:uppercase}
.nav-phone span{font-family:var(--display);font-size:1.12rem;font-weight:800}
.hamburger{display:none;background:rgba(255,255,255,.1);border:0;width:46px;height:46px;border-radius:10px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.hamburger span{width:22px;height:2.5px;background:#fff;border-radius:3px;transition:.25s}
.hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media(max-width:1040px){
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(360px,86vw);background:var(--navy-2);
    flex-direction:column;align-items:stretch;gap:.15rem;padding:90px 18px 30px;
    transform:translateX(102%);transition:transform .32s var(--ease);overflow-y:auto;
    box-shadow:-20px 0 60px rgba(0,0,0,.4);z-index:1001;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links>li>a{padding:.95rem 1rem;font-size:1.05rem}
  .nav-links>li>a.has-caret::after{float:right;margin-top:6px}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;background:rgba(255,255,255,.05);margin:.2rem 0 .5rem;border:0;display:none}
  .dropdown.open{display:block}
  .dropdown a{color:#dfeaf5}
  .dropdown a:hover{background:rgba(255,255,255,.08);color:#fff}
  .hamburger{display:flex}
  .nav-phone{display:none}
  .scrim{position:fixed;inset:0;background:rgba(7,20,38,.55);opacity:0;visibility:hidden;transition:.3s;z-index:1000;backdrop-filter:blur(2px)}
  .scrim.open{opacity:1;visibility:visible}
}
@media(min-width:1041px){.scrim{display:none}}

/* ---------- Hero ---------- */
.hero{
  position:relative;color:#fff;overflow:hidden;
  background:
    radial-gradient(1100px 600px at 78% -10%,rgba(26,117,210,.55),transparent 60%),
    radial-gradient(900px 500px at 10% 110%,rgba(0,230,77,.16),transparent 55%),
    linear-gradient(160deg,var(--navy) 0%,#081d38 100%);
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 26%;display:block}
.hero::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(95deg,rgba(6,18,35,.9) 0%,rgba(8,24,46,.78) 30%,rgba(11,37,69,.55) 47%,rgba(11,37,69,.18) 60%,rgba(11,37,69,0) 75%),
    linear-gradient(to top,rgba(7,20,40,.4) 0%,transparent 24%);
}
.hero .container{position:relative;z-index:2;padding-top:80px;padding-bottom:92px}
.hero-copy{max-width:600px}
.hero-rating{display:inline-flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:.5rem .95rem;border-radius:999px;font-size:.88rem;margin-bottom:1.4rem;backdrop-filter:blur(6px)}
.hero-rating .stars{color:#ffc400;letter-spacing:1px;font-size:.95rem}
.hero-rating b{font-weight:800}
.hero h1{color:#fff;margin-bottom:1.1rem}
.hero h1 .hl{background:linear-gradient(120deg,var(--steel),var(--blue-bright));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.sub{font-size:1.18rem;color:#cfe0f1;max-width:560px;margin-bottom:1.8rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:1.8rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;font-size:.92rem;color:#bcd2e8}
.hero-trust span{display:inline-flex;align-items:center;gap:.5rem}
.hero-trust svg{width:18px;height:18px;color:var(--green);flex-shrink:0}
.hero-visual{position:relative;display:flex;justify-content:center;align-items:flex-end}
.hero-visual .tech{max-height:600px;width:auto;max-width:100%;display:block;border-radius:18px;-webkit-mask-image:radial-gradient(125% 100% at 52% 42%, #000 54%, rgba(0,0,0,0) 100%);mask-image:radial-gradient(125% 100% at 52% 42%, #000 54%, rgba(0,0,0,0) 100%)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.eco-badge{
  position:absolute;bottom:96px;right:40px;z-index:3;background:#fff;color:var(--navy);border-radius:50%;
  width:118px;height:118px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;box-shadow:var(--shadow);border:4px solid var(--green);transform:rotate(-8deg);
}
.eco-badge .leaf{font-size:1.6rem;line-height:1}
.eco-badge b{font-family:var(--display);font-weight:900;font-size:1.05rem;text-transform:uppercase;line-height:1;margin-top:3px}
.eco-badge small{font-size:.6rem;font-weight:700;letter-spacing:.12em;color:var(--blue);text-transform:uppercase}
.hero-wave{position:absolute;bottom:-1px;left:0;width:100%;line-height:0;z-index:2}
.hero-wave svg{width:100%;height:70px;display:block}
@media(max-width:980px){
  .hero .container{text-align:center;padding-top:clamp(210px,54vw,340px);padding-bottom:54px}
  .hero-copy{max-width:none}
  .hero p.sub{margin-left:auto;margin-right:auto}
  .hero-actions,.hero-trust,.eyebrow{justify-content:center}
  .hero-bg img{object-position:center 12%}
  .hero::after{background:linear-gradient(to bottom,rgba(7,20,40,.12) 0%,rgba(7,20,40,.28) 34%,rgba(8,22,44,.78) 58%,rgba(6,17,33,.95) 100%)}
  .eco-badge{display:none}
}

/* ---------- Trust strip ---------- */
.trust-strip{background:var(--white);border-bottom:1px solid var(--gray-100)}
.trust-strip .container{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;padding:30px 24px}
.trust-item{text-align:center;padding:.4rem}
.trust-item .num{font-family:var(--display);font-weight:900;font-size:2.1rem;color:var(--navy);line-height:1}
.trust-item .lbl{font-size:.84rem;color:var(--gray-500);font-weight:600;margin-top:.3rem;text-transform:uppercase;letter-spacing:.04em}
.trust-item .num .green{color:var(--green)}
@media(max-width:760px){.trust-strip .container{grid-template-columns:repeat(2,1fr);gap:1.4rem 1rem}.trust-item:last-child{grid-column:1/-1}}

/* ---------- Sections ---------- */
.sec{padding:90px 0}
.sec-sm{padding:64px 0}
.bg-gray{background:var(--gray-50)}
.bg-navy{background:linear-gradient(165deg,var(--navy),#081d38);color:#fff}
.bg-navy h1,.bg-navy h2,.bg-navy h3{color:#fff}
.sec-head{max-width:680px;margin-bottom:48px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head p{color:var(--gray-500);font-size:1.12rem;margin-bottom:0}
.bg-navy .sec-head p{color:#cfe0f1}

/* ---------- Service cards ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:900px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.svc-grid{grid-template-columns:1fr}}
.svc-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-100);
  box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
  display:flex;flex-direction:column;position:relative;
}
.svc-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--steel)}
.svc-card .ph{height:172px;position:relative;overflow:visible;display:flex;align-items:center;justify-content:center}
.svc-card .ph picture{position:absolute;inset:0;overflow:hidden;display:block}
.svc-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.svc-card:hover .ph img{transform:scale(1.07)}
.svc-card .ico{
  position:absolute;left:16px;bottom:-22px;width:54px;height:54px;border-radius:14px;
  background:#fff;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;
  border:1px solid var(--gray-100);z-index:2;
}
.svc-card .ico svg{width:28px;height:28px;color:var(--blue)}
.svc-card .body{padding:34px 24px 26px;flex:1;display:flex;flex-direction:column}
.svc-card h3{margin-bottom:.5rem;font-size:1.28rem}
.svc-card p{color:var(--gray-500);font-size:.97rem;margin-bottom:1.2rem;flex:1}
.svc-card .more{font-family:var(--display);font-weight:800;color:var(--blue);display:inline-flex;align-items:center;gap:.4rem;font-size:.96rem}
.svc-card .more svg{width:16px;height:16px;transition:transform .25s}
.svc-card:hover .more svg{transform:translateX(5px)}
.svc-card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(11,37,69,.45),transparent 55%)}

/* ---------- Why / feature columns ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:900px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.feat-grid{grid-template-columns:1fr}}
.feat{background:#fff;padding:30px 26px;border-radius:var(--radius);border:1px solid var(--gray-100);transition:transform .3s var(--ease),box-shadow .3s}
.feat:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.feat .ic{width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(26,117,210,.12),rgba(0,230,77,.12));margin-bottom:1.1rem}
.feat .ic svg{width:30px;height:30px;color:var(--blue)}
.feat h3{font-size:1.18rem;margin-bottom:.5rem}
.feat p{color:var(--gray-500);font-size:.96rem;margin:0}

/* ---------- Split / about ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.rev .split-media{order:2}
@media(max-width:920px){.split{grid-template-columns:1fr;gap:36px}.split.rev .split-media{order:0}}
.split-media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.split-media img{width:100%;height:100%;object-fit:cover;min-height:340px}
.split-media.framed{background:linear-gradient(135deg,var(--navy),var(--navy-3));padding:34px;display:flex;align-items:center;justify-content:center}
.split-media.framed img{min-height:auto;filter:drop-shadow(0 20px 30px rgba(0,0,0,.4))}
.checks{list-style:none;margin:1.3rem 0}
.checks li{display:flex;gap:.8rem;align-items:flex-start;margin-bottom:.85rem;font-size:1.02rem}
.checks li svg{width:24px;height:24px;flex-shrink:0;color:var(--green);margin-top:2px}
.bg-navy .checks li{color:#dceaf7}

.stat-card{position:absolute;bottom:22px;left:22px;background:#fff;border-radius:14px;padding:16px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}
.stat-card .big{font-family:var(--display);font-weight:900;font-size:2.4rem;color:var(--navy);line-height:1}
.stat-card .small{font-size:.82rem;color:var(--gray-500);font-weight:600;line-height:1.2}

/* ---------- Reviews ---------- */
.rev-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;margin-bottom:42px}
.google-badge{display:inline-flex;align-items:center;gap:.8rem;background:#fff;border:1px solid var(--gray-100);border-radius:14px;padding:.8rem 1.2rem;box-shadow:var(--shadow-sm)}
.google-badge .g{font-family:var(--display);font-weight:800;font-size:1.05rem}
.google-badge .g b:nth-child(1){color:#4285F4}.google-badge .g b:nth-child(2){color:#EA4335}.google-badge .g b:nth-child(3){color:#FBBC05}.google-badge .g b:nth-child(4){color:#4285F4}.google-badge .g b:nth-child(5){color:#34A853}.google-badge .g b:nth-child(6){color:#EA4335}
.google-badge .score{font-family:var(--display);font-weight:900;font-size:1.7rem;color:var(--navy);line-height:1}
.google-badge .stars{color:#ffc400;letter-spacing:1px}
.google-badge .meta{font-size:.78rem;color:var(--gray-500)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.rev-grid{grid-template-columns:1fr}}
.rev-card{background:#fff;border-radius:var(--radius);padding:28px;border:1px solid var(--gray-100);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s}
.rev-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.rev-card .stars{color:#ffc400;letter-spacing:1px;margin-bottom:.7rem;font-size:1.05rem}
.rev-card .txt{color:var(--charcoal);font-size:1rem;flex:1;margin-bottom:1.2rem}
.rev-card .who{display:flex;align-items:center;gap:.8rem}
.rev-card .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--steel));color:#fff;font-family:var(--display);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:1.05rem}
.rev-card .who b{display:block;font-size:.97rem;color:var(--navy);font-family:var(--display);font-weight:800}
.rev-card .who small{color:var(--gray-500);font-size:.8rem}
.rev-card .gicon{margin-left:auto;width:22px;height:22px;opacity:.9}

/* ---------- Areas ---------- */
.area-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
@media(max-width:900px){.area-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.area-grid{grid-template-columns:repeat(2,1fr)}}
.area-chip{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:14px;
  padding:20px 16px;text-align:center;transition:.28s var(--ease);color:#fff;
}
.area-chip:hover{background:rgba(124,184,228,.18);border-color:var(--steel);transform:translateY(-5px)}
.area-chip svg{width:26px;height:26px;color:var(--green);margin:0 auto .55rem}
.area-chip b{font-family:var(--display);font-weight:800;font-size:1.05rem;display:block}
.area-chip small{font-size:.76rem;color:#9fbcd8}
.area-chip.plain{cursor:default}
.area-chip.plain:hover{transform:none;background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--blue),var(--navy));color:#fff;border-radius:var(--radius);padding:56px 50px}
.cta-band::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1px);background-size:20px 20px;opacity:.6}
.cta-band .inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.cta-band h2{color:#fff;margin-bottom:.4rem}
.cta-band p{color:#d6e6f7;margin:0;font-size:1.1rem}
.cta-band .acts{display:flex;gap:.9rem;flex-wrap:wrap}
@media(max-width:760px){.cta-band{padding:40px 26px}.cta-band .inner{flex-direction:column;align-items:flex-start}}

/* ---------- Form ---------- */
.lead-form{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:34px;border:1px solid var(--gray-100)}
.lead-form .ttl{font-family:var(--display);font-weight:900;font-size:1.5rem;color:var(--navy);margin-bottom:.3rem}
.lead-form .sub{color:var(--gray-500);font-size:.94rem;margin-bottom:1.4rem}
.field{margin-bottom:1rem}
.field label{display:block;font-weight:700;font-size:.85rem;color:var(--navy);margin-bottom:.4rem;font-family:var(--display)}
.field input,.field select,.field textarea{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--gray-100);border-radius:10px;font-family:var(--body);
  font-size:.98rem;color:var(--charcoal);background:var(--gray-50);transition:border .2s,box-shadow .2s,background .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--steel);box-shadow:var(--ring);background:#fff}
.field textarea{resize:vertical;min-height:96px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:520px){.field-row{grid-template-columns:1fr}}
.form-note{font-size:.78rem;color:var(--gray-500);text-align:center;margin-top:.9rem}
.form-success{display:none;background:rgba(0,230,77,.1);border:1px solid var(--green);border-radius:12px;padding:1rem;color:var(--navy);font-weight:600;text-align:center;margin-top:1rem}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;color:#fff;background:linear-gradient(160deg,var(--navy),#081d38);overflow:hidden;padding:64px 0 56px}
.page-hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:22px 22px;mask-image:linear-gradient(to bottom,#000,transparent)}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;margin-bottom:1rem;max-width:760px}
.page-hero p{color:#cfe0f1;font-size:1.18rem;max-width:620px;margin-bottom:0}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.85rem;color:#9fbcd8;margin-bottom:1.4rem;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--steel)}
.breadcrumb span{opacity:.5}
.page-hero .ph-badges{display:flex;gap:.6rem 1.3rem;flex-wrap:wrap;margin-top:1.6rem;font-size:.92rem;color:#bcd2e8}
.page-hero .ph-badges span{display:inline-flex;align-items:center;gap:.45rem}
.page-hero .ph-badges svg{width:17px;height:17px;color:var(--green)}

/* ---------- Content layout (service/city) ---------- */
.content-wrap{display:grid;grid-template-columns:1fr 380px;gap:54px;align-items:start}
@media(max-width:980px){.content-wrap{grid-template-columns:1fr;gap:40px}}
.prose h2{margin:2.2rem 0 1rem}
.prose h2:first-child{margin-top:0}
.prose h3{margin:1.6rem 0 .7rem;color:var(--blue)}
.prose p{color:#3a4654;font-size:1.05rem}
.prose ul{margin:0 0 1.3rem;padding-left:0;list-style:none}
.prose ul li{position:relative;padding-left:2rem;margin-bottom:.7rem;color:#3a4654}
.prose ul li::before{content:"";position:absolute;left:0;top:7px;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--blue));mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.callout{background:var(--gray-50);border-left:4px solid var(--steel);border-radius:10px;padding:20px 24px;margin:1.6rem 0}
.callout.eco{border-color:var(--green);background:rgba(0,230,77,.06)}
.callout p{margin:0;font-size:1rem;color:#3a4654}
.callout b{color:var(--navy)}

.sidebar-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--gray-100);overflow:hidden;position:sticky;top:96px}
.sidebar-card .top{background:linear-gradient(135deg,var(--navy),var(--navy-3));color:#fff;padding:24px 26px}
.sidebar-card .top h3{color:#fff;font-size:1.3rem;margin-bottom:.3rem}
.sidebar-card .top p{color:#cfe0f1;font-size:.9rem;margin:0}
.sidebar-card .body{padding:24px 26px}
.sidebar-list{list-style:none;margin-bottom:1rem}
.sidebar-list li a{display:flex;align-items:center;gap:.6rem;padding:.6rem .2rem;border-bottom:1px solid var(--gray-50);font-weight:600;color:var(--navy);font-size:.95rem;transition:color .2s,padding .2s}
.sidebar-list li a:hover{color:var(--blue);padding-left:.5rem}
.sidebar-list li a svg{width:16px;height:16px;color:var(--green)}
.sidebar-phone{text-align:center;padding:18px;background:var(--gray-50);border-radius:12px;margin-top:.4rem}
.sidebar-phone small{display:block;font-size:.74rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.sidebar-phone b{font-family:var(--display);font-size:1.6rem;color:var(--navy);display:block;margin:.2rem 0 .6rem}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--gray-100);border-radius:12px;margin-bottom:14px;overflow:hidden;transition:box-shadow .25s}
.faq-item:hover{box-shadow:var(--shadow-sm)}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:20px 24px;font-family:var(--display);font-weight:800;font-size:1.08rem;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-q .pm{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--gray-50);position:relative;transition:.25s}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--blue);border-radius:2px;top:50%;left:50%;transition:.25s}
.faq-q .pm::before{width:12px;height:2.5px;transform:translate(-50%,-50%)}
.faq-q .pm::after{width:2.5px;height:12px;transform:translate(-50%,-50%)}
.faq-item.open .pm{background:var(--blue)}
.faq-item.open .pm::before,.faq-item.open .pm::after{background:#fff}
.faq-item.open .pm::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .32s var(--ease)}
.faq-a div{padding:0 24px 22px;color:var(--gray-500);font-size:1rem}

/* ---------- Footer ---------- */
.site-footer{background:#071831;color:#b9cde1;padding:64px 0 0;font-size:.95rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:48px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
.site-footer img.flogo{height:54px;width:auto;margin-bottom:1.2rem}
.site-footer h4{color:#fff;font-size:1.05rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1.2rem;font-family:var(--display);font-weight:800}
.site-footer ul{list-style:none}
.site-footer ul li{margin-bottom:.6rem}
.site-footer ul li a{transition:color .2s}
.site-footer ul li a:hover{color:var(--green)}
.foot-contact li{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:.9rem}
.foot-contact svg{width:18px;height:18px;color:var(--steel);flex-shrink:0;margin-top:3px}
.foot-social{display:flex;gap:.7rem;margin-top:1.2rem}
.foot-social a{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;transition:.25s}
.foot-social a:hover{background:var(--blue);transform:translateY(-3px)}
.foot-social svg{width:20px;height:20px;color:#fff}
.foot-eco{display:inline-flex;align-items:center;gap:.5rem;background:rgba(0,230,77,.12);border:1px solid rgba(0,230,77,.3);color:#9affc0;padding:.45rem .9rem;border-radius:999px;font-size:.8rem;font-weight:700;margin-top:1.2rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.84rem;color:#7f9bba}
.footer-bottom a:hover{color:var(--green)}

/* ---------- Floating mobile call ---------- */
.float-call{position:fixed;bottom:18px;right:18px;z-index:900;display:none;align-items:center;gap:.5rem;background:var(--orange);color:#fff;font-family:var(--display);font-weight:800;padding:.95rem 1.4rem;border-radius:999px;box-shadow:0 14px 30px -8px rgba(232,119,34,.7);animation:pulse 2.4s infinite}
.float-call svg{width:20px;height:20px}
@keyframes pulse{0%,100%{box-shadow:0 14px 30px -8px rgba(232,119,34,.7)}50%{box-shadow:0 14px 30px -8px rgba(232,119,34,.95),0 0 0 8px rgba(232,119,34,.12)}}
@media(max-width:1040px){.float-call{display:inline-flex}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}.hero-visual .tech{animation:none}}

/* pest emoji marker for area pages map */
.mini-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--gray-100);min-height:320px}
.mini-map iframe{width:100%;height:100%;min-height:320px;border:0;display:block}

/* ---------- Form states (error, honeypot, loading) ---------- */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden}
.form-error{display:none;background:rgba(232,119,34,.12);border:1px solid var(--orange);border-radius:12px;padding:.85rem 1rem;color:#7a3a00;font-weight:600;font-size:.92rem;text-align:center;margin-top:1rem}
.form-error a{color:#7a3a00;text-decoration:underline}
.btn[disabled]{opacity:.6;cursor:not-allowed;pointer-events:none}
.btn[data-loading]{position:relative}

/* ---------- Accessibility: keyboard focus ---------- */
a:focus-visible,button:focus-visible,.btn:focus-visible,.faq-q:focus-visible,.hamburger:focus-visible{outline:3px solid var(--steel);outline-offset:2px;border-radius:6px}
@media(prefers-reduced-motion:reduce){.float-call{animation:none}*{scroll-behavior:auto!important}}

/* (Hero is now a full-bleed background photo with a navy scrim — see .hero-bg / .hero::after) */

/* ---------- Key facts block (service & area pages) ---------- */
.keyfacts{background:var(--gray-50);border:1px solid var(--gray-100);border-left:4px solid var(--blue);border-radius:12px;padding:1.1rem 1.3rem;margin:1.6rem 0}
.keyfacts .kf-h{display:block;font-family:var(--display);font-weight:800;color:var(--navy);margin-bottom:.7rem;font-size:1.08rem}
.keyfacts ul{list-style:none;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:.45rem 1.4rem}
.keyfacts li{font-size:.95rem;color:var(--charcoal);position:relative;padding-left:1.4rem;line-height:1.4}
.keyfacts li::before{content:"✓";position:absolute;left:0;color:var(--blue);font-weight:800}
@media(max-width:560px){.keyfacts ul{grid-template-columns:1fr}}

/* ---------- Blog ---------- */
.prose ol{margin:0 0 1.3rem;padding-left:1.4rem;list-style:decimal}
.prose ol li{color:#3a4654;margin-bottom:.6rem;padding-left:.3rem}
.prose img{max-width:100%;height:auto;border-radius:14px;margin:1.4rem 0;display:block}
.prose blockquote{border-left:4px solid var(--steel);background:var(--gray-50);margin:1.4rem 0;padding:1rem 1.3rem;border-radius:0 12px 12px 0;color:var(--navy)}
.post-wrap{max-width:820px;margin:0 auto}
.page-hero .post-meta{color:#bcd2e8;font-weight:600;font-size:.95rem;margin-top:.7rem}
.post-hero{margin:0 0 1.8rem!important}
.post-hero img{width:100%;height:auto;border-radius:var(--radius);box-shadow:var(--shadow);margin:0}
.post-back{margin-top:2.4rem;border-top:1px solid var(--gray-100);padding-top:1.4rem}
.post-back a{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--display);font-weight:800;color:var(--blue)}
.post-back svg{width:18px;height:18px;transform:rotate(180deg)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
.blog-card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-100);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.blog-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--steel)}
.blog-card .bc-media{height:200px;overflow:hidden;background:linear-gradient(135deg,var(--navy),var(--navy-3))}
.blog-card .bc-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.blog-card:hover .bc-media img{transform:scale(1.07)}
.blog-card .bc-body{padding:22px 22px 24px;flex:1;display:flex;flex-direction:column}
.blog-card .bc-date{font-size:.8rem;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}
.blog-card h3{font-size:1.18rem;line-height:1.3;margin-bottom:.6rem;color:var(--navy)}
.blog-card p{color:var(--gray-500);font-size:.95rem;flex:1;margin-bottom:1rem}
.blog-card .more{font-family:var(--display);font-weight:800;color:var(--blue);display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem}
.blog-card .more svg{width:16px;height:16px;transition:transform .25s}
.blog-card:hover .more svg{transform:translateX(5px)}
