/* NZ Pest Free - clinical / trust-led */
:root{
  --green:#1f5a43; --green-d:#143d2d; --green-l:#2f8f63;
  --charcoal:#22282a; --ink:#1d2422; --body:#46514c; --mut:#6d7a73;
  --mist:#f4f7f3; --sand:#eef3ee; --surface:#ffffff; --line:#e3eae4;
  --red:#b53a2c;
  --maxw:1140px; --r:14px; --r-sm:10px;
  --sh:0 1px 2px rgba(20,40,30,.05),0 8px 28px rgba(20,40,30,.06);
  --sh-lg:0 18px 50px rgba(20,40,30,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--body);background:var(--surface);line-height:1.65;-webkit-font-smoothing:antialiased;font-size:16.5px}
h1,h2,h3,h4{font-family:'Plus Jakarta Sans','Inter',sans-serif;color:var(--ink);line-height:1.18;font-weight:700;letter-spacing:-.01em}
img{max-width:100%;display:block}
a{color:var(--green);text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green-l)}
.sec{padding:76px 0}
.sec-sm{padding:52px 0}
.mist{background:var(--mist)}
.center{text-align:center}
.lead{font-size:1.12rem;color:var(--body);max-width:64ch}
.sec-head{max-width:60ch;margin-bottom:38px}
.sec-head.center{margin-left:auto;margin-right:auto}
.sec-head h2{font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:14px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.96rem;padding:14px 24px;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:.18s;white-space:nowrap}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-d);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-light{background:#fff;color:var(--green-d)}
.btn-light:hover{transform:translateY(-1px)}
.btn svg{width:18px;height:18px}

/* header */
header.nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:18px;height:72px;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:34px;height:34px;flex:none}
.brand b{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.12rem;font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1}
.brand span{display:block;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mut);font-weight:600;margin-top:2px}
.menu{display:flex;align-items:center;gap:26px}
.menu a.lnk{font-weight:600;font-size:.95rem;color:var(--charcoal)}
.menu a.lnk:hover{color:var(--green)}
.menu a.lnk.active{color:var(--green)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{display:inline-flex;align-items:center;gap:8px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;color:var(--ink);font-size:.98rem}
.nav-phone svg{width:17px;height:17px;color:var(--green)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* hero split */
.hero{display:grid;grid-template-columns:1.05fr .95fr;min-height:540px}
.hero-copy{background:linear-gradient(155deg,var(--green-d),var(--charcoal));color:#eaf1ec;padding:64px clamp(28px,5vw,72px);display:flex;flex-direction:column;justify-content:center}
.hero-copy .eyebrow{color:#86d6ab}
.hero-copy h1{color:#fff;font-size:clamp(2rem,4vw,2.85rem);margin:16px 0 16px;max-width:16ch}
.hero-copy p.sub{color:#cdded4;font-size:1.08rem;max-width:46ch;margin-bottom:26px}
.hero-cta{display:flex;flex-wrap:wrap;gap:13px;margin-bottom:28px}
.hero-chips{display:flex;flex-wrap:wrap;gap:8px 9px}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:.8rem;font-weight:600;color:#dcebe2;color:#d6e6dc;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);padding:6px 12px;border-radius:999px}
.chip svg{width:14px;height:14px;color:#86d6ab}
.hero-photo{position:relative;background:var(--green-d)}
.hero-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-photo .tag{position:absolute;left:18px;bottom:18px;background:rgba(29,36,34,.82);color:#eaf1ec;font-size:.74rem;font-weight:600;padding:7px 13px;border-radius:8px;backdrop-filter:blur(4px)}

/* trust bar */
.trustbar{background:var(--ink);color:#dfe9e2}
.trustbar .row{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;padding:22px 0}
.tb-item{display:flex;align-items:center;gap:11px;padding:6px 14px;border-left:1px solid rgba(255,255,255,.09)}
.tb-item:first-child{border-left:0}
.tb-item svg{width:24px;height:24px;color:#86d6ab;flex:none}
.tb-item b{font-family:'Plus Jakarta Sans',sans-serif;font-size:.92rem;color:#fff;display:block;font-weight:700;line-height:1.2}
.tb-item span{font-size:.76rem;color:#9fb3a8}

/* accordion (centrepiece) */
.pest-list{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.acc{border:1px solid var(--line);border-radius:var(--r);background:#fff;overflow:hidden;transition:.2s}
.acc.open{box-shadow:var(--sh);border-color:#cfe0d4}
.acc-head{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:18px 20px;font-family:'Plus Jakarta Sans',sans-serif}
.acc-ico{width:42px;height:42px;border-radius:10px;background:var(--sand);display:grid;place-items:center;flex:none}
.acc-ico svg{width:22px;height:22px;color:var(--green)}
.acc-head h3{font-size:1.05rem;flex:1}
.acc-head .plus{width:22px;height:22px;flex:none;position:relative}
.acc-head .plus:before,.acc-head .plus:after{content:"";position:absolute;background:var(--green);border-radius:2px;transition:.2s}
.acc-head .plus:before{top:10px;left:2px;width:18px;height:2px}
.acc-head .plus:after{left:10px;top:2px;width:2px;height:18px}
.acc.open .plus:after{transform:scaleY(0)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .32s ease}
.acc-inner{padding:0 20px 20px 76px}
.acc-inner .lab{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mut);margin:8px 0 4px}
.acc-inner p{font-size:.94rem;margin-bottom:8px}
.acc-inner a.more{font-weight:700;font-size:.9rem;display:inline-flex;align-items:center;gap:6px}

/* feature split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split .media{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);aspect-ratio:5/4;background:var(--mist)}
.split .media img{width:100%;height:100%;object-fit:cover}
.split h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:16px}
.ticks{list-style:none;margin-top:18px;display:grid;gap:11px}
.ticks li{display:flex;gap:11px;align-items:flex-start;font-size:.98rem}
.ticks svg{width:21px;height:21px;color:var(--green);flex:none;margin-top:2px}

/* cards / steps */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 22px}
.card .num{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;color:var(--green-l);font-size:.85rem;letter-spacing:.1em}
.card h3{font-size:1.1rem;margin:10px 0 7px}
.card p{font-size:.92rem}
.card .ci{width:44px;height:44px;border-radius:10px;background:var(--sand);display:grid;place-items:center;margin-bottom:14px}
.card .ci svg{width:23px;height:23px;color:var(--green)}

/* signs/treatment two-col on service pages */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:8px}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 26px}
.panel.warn{border-left:4px solid var(--red)}
.panel h3{font-size:1.15rem;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.panel h3 svg{width:22px;height:22px;color:var(--green)}
.panel.warn h3 svg{color:var(--red)}
.panel ul{list-style:none;display:grid;gap:10px}
.panel li{display:flex;gap:10px;font-size:.96rem}
.panel li svg{width:18px;height:18px;color:var(--green);flex:none;margin-top:3px}
.panel.warn li svg{color:var(--red)}

/* page hero (service/about/contact) */
.phead{background:linear-gradient(155deg,var(--green-d),var(--charcoal));color:#eaf1ec;padding:54px 0 50px}
.phead .eyebrow{color:#86d6ab}
.phead h1{color:#fff;font-size:clamp(1.9rem,3.6vw,2.6rem);margin:12px 0 12px;max-width:20ch}
.phead p{color:#cdded4;max-width:58ch;font-size:1.06rem}
.crumb{font-size:.8rem;color:#9fc3ae}
.crumb a{color:#9fc3ae}

/* safety note */
.note{display:flex;gap:14px;align-items:flex-start;background:var(--sand);border-radius:var(--r);padding:20px 22px;font-size:.95rem}
.note svg{width:24px;height:24px;color:var(--green);flex:none;margin-top:2px}

/* cta band */
.ctaband{background:linear-gradient(155deg,var(--green),var(--green-d));color:#fff}
.ctaband .in{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;padding:50px 0}
.ctaband h2{color:#fff;font-size:clamp(1.5rem,2.8vw,2rem);max-width:20ch}
.ctaband p{color:#cfe6d8;margin-top:6px}

/* form */
.formwrap{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
form.lead-form{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--sh)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.84rem;font-weight:600;color:var(--charcoal);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--r-sm);font:inherit;font-size:.95rem;background:var(--mist);color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--green-l);outline-offset:1px;background:#fff}
.field textarea{min-height:120px;resize:vertical}
.hp{position:absolute;left:-9999px}
.contact-aside .ci-item{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.contact-aside .ci-item svg{width:22px;height:22px;color:var(--green);flex:none;margin-top:3px}
.contact-aside .ci-item b{font-family:'Plus Jakarta Sans',sans-serif;color:var(--ink);display:block}
.contact-aside .ci-item a{color:var(--body)}

/* demo banner */
.demobar{background:var(--ink);color:#dfe9e2;font-size:.83rem;text-align:center;padding:9px 16px;line-height:1.5}
.demobar b{color:#86d6ab}

/* footer */
footer.site{background:var(--ink);color:#a9b8b0;padding:54px 0 26px;font-size:.9rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:34px}
footer.site h4{color:#fff;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
footer.site a{color:#a9b8b0;display:block;margin-bottom:8px}
footer.site a:hover{color:#86d6ab}
.foot-brand b{font-family:'Plus Jakarta Sans',sans-serif;color:#fff;font-size:1.1rem;font-weight:800}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;font-size:.82rem;color:#7e8e85}
.foot-bottom a{display:inline;color:#86d6ab}

@media(max-width:900px){
  .hero{grid-template-columns:1fr}
  .hero-photo{min-height:300px}
  .trustbar .row{grid-template-columns:repeat(2,1fr);gap:4px}
  .tb-item{border-left:0;border-top:1px solid rgba(255,255,255,.08);padding:12px 8px}
  .tb-item:nth-child(-n+2){border-top:0}
  .pest-list,.split,.formwrap{grid-template-columns:1fr}
  .split{gap:30px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .duo{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .menu{position:fixed;inset:72px 0 auto 0;background:#fff;flex-direction:column;align-items:flex-start;gap:0;padding:8px 22px 18px;border-bottom:1px solid var(--line);box-shadow:var(--sh-lg);transform:translateY(-130%);transition:.26s;z-index:55}
  .menu.show{transform:translateY(0)}
  .menu a.lnk{padding:13px 0;width:100%;border-bottom:1px solid var(--line)}
  .burger{display:flex}
  .nav-phone span{display:none}
  .ctaband .in{flex-direction:column;align-items:flex-start}
}
@media(max-width:520px){
  .cards{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .sec{padding:54px 0}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}
