
:root{
  --shell:#FBF6EC; --shell-2:#F3EAD8; --card:#FFFFFF;
  --teal:#0E4D4A; --teal-2:#0A3B39; --teal-soft:#15625E;
  --seafoam:#2FA8A0; --seafoam-lt:#7FD3CB;
  --coral:#F0563A; --coral-d:#D2432A; --marigold:#E8B54B;
  --ink:#14312F; --muted:#5C726F; --line:#E4D8C4;
  --shadow:0 1px 0 rgba(14,77,74,.03),0 14px 34px -20px rgba(14,77,74,.35);
  --glow:0 10px 26px -10px rgba(240,86,58,.5);
  --maxw:1150px;
  --disp:"Fraunces",Georgia,serif; --body:"DM Sans",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--shell);color:var(--ink);font-family:var(--body);font-size:17px;line-height:1.68;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--disp);font-weight:600;line-height:1.1;letter-spacing:-.01em;color:var(--teal);margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5.4vw,3.7rem);font-weight:600}
h2{font-size:clamp(1.6rem,3.4vw,2.5rem)}
h3{font-size:clamp(1.2rem,2vw,1.45rem)}
p{margin:0 0 1rem}
a{color:var(--coral-d);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.label{font-family:var(--body);font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--seafoam)}
.kicker{font-family:var(--body);font-weight:700;font-size:.74rem;letter-spacing:.15em;text-transform:uppercase;color:var(--coral)}
/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--body);font-weight:700;font-size:1.08rem;background:var(--coral);color:#fff;padding:.9rem 1.5rem;border-radius:6px;box-shadow:var(--glow);border:0;cursor:pointer;transition:transform .12s,box-shadow .12s}
.btn:hover{transform:translateY(-2px);text-decoration:none;box-shadow:0 16px 30px -12px rgba(240,86,58,.62)}
.btn-lg{font-size:1.24rem;padding:1.1rem 1.9rem}
.btn-ghost{background:#fff;color:var(--teal);border:1.5px solid var(--line);box-shadow:none}
.btn-ghost:hover{border-color:var(--seafoam);box-shadow:none}
.btn-teal{background:var(--teal)}
/* rope divider */
.rope{height:8px;border:0;margin:0;background-image:repeating-linear-gradient(66deg,var(--seafoam) 0 6px,var(--marigold) 6px 12px,var(--seafoam) 12px 18px);opacity:.55;-webkit-mask:linear-gradient(#000,#000);mask-image:radial-gradient(circle,#000 40%,transparent 41%);mask-size:8px 8px;mask-repeat:repeat-x}
.rope-simple{height:3px;border:0;margin:0;background:repeating-linear-gradient(90deg,var(--seafoam) 0 10px,transparent 10px 16px)}
/* sections */
section{padding:clamp(3rem,6vw,5rem) 0}
.sec-teal{background:var(--teal);color:#dcefe c}
.sec-teal{color:#d7ece9}
.sec-teal h1,.sec-teal h2,.sec-teal h3{color:#fff}
.sec-alt{background:var(--shell-2)}
.lead{font-size:1.2rem;color:var(--muted);max-width:60ch}
.sec-teal .lead{color:#a9cfca}
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{font-family:var(--body);font-weight:600;font-size:.78rem;background:#fff;border:1px solid var(--line);color:var(--teal);padding:.4rem .75rem;border-radius:999px}
.sec-teal .chip{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18);color:#eaf5f3}
/* header - two tier */
.util{background:var(--teal);color:#bfe0dc;font-family:var(--body);font-size:.78rem}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;gap:1rem}
.util .r{display:flex;gap:1.2rem;align-items:center}
.util a{color:#eafaf7;font-weight:600}
.util .dot{color:var(--marigold)}
.hdr{position:sticky;top:0;z-index:60;background:rgba(251,246,236,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.hdr .row{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;height:70px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--disp);font-weight:600;font-size:1.4rem;color:var(--teal);white-space:nowrap;letter-spacing:-.01em}
.brand:hover{text-decoration:none}
.brand svg{width:38px;height:38px;flex:none}
.nav{display:flex;align-items:center;gap:1.2rem}
.nav>a,.nav .has>summary{color:var(--teal);font-weight:600;font-size:.94rem;white-space:nowrap}
.nav>a:hover{color:var(--coral);text-decoration:none}
.nav .has{position:relative}
.nav .has>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:.3rem}
.nav .has>summary::-webkit-details-marker{display:none}
.nav .has>summary::after{content:"";width:6px;height:6px;border-right:2px solid var(--seafoam);border-bottom:2px solid var(--seafoam);transform:rotate(45deg);margin-top:-3px}
.nav .menu{position:absolute;top:calc(100% + 14px);left:-14px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:.45rem;min-width:270px;display:flex;flex-direction:column;gap:.05rem}
.nav .menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.nav .menu a{padding:.58rem .75rem;border-radius:9px;font-weight:600;font-size:.9rem;color:var(--teal)}
.nav .menu a:hover{background:var(--shell-2);text-decoration:none;color:var(--coral)}
.call-pill{display:inline-flex;align-items:center;gap:.45rem;background:var(--coral);color:#fff;font-family:var(--body);font-weight:700;font-size:.95rem;padding:.55rem .95rem;border-radius:6px;box-shadow:var(--glow)}
.call-pill:hover{text-decoration:none;transform:translateY(-1px)}
.call-pill svg{width:15px;height:15px}
.hdr-mobile{display:none;align-items:center;gap:.55rem}
.mcall{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:var(--coral);color:#fff;box-shadow:var(--glow)}
.mcall:hover{text-decoration:none}
.mcall svg{width:20px;height:20px}
.menu-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--teal);font-size:1.4rem;cursor:pointer;padding:0}
#mnav{display:none}
/* hero */
.hero{background:linear-gradient(180deg,#fff 0,var(--shell) 60%)}
.hero .grid{display:grid;grid-template-columns:1.02fr .98fr;gap:2.6rem;align-items:center}
.hero h1 em{font-style:italic;color:var(--coral)}
.trust-row{display:flex;flex-wrap:wrap;gap:1.1rem;margin-top:1.2rem}
.trust-row .t{display:flex;align-items:center;gap:.45rem;font-size:.9rem;color:var(--teal);font-weight:600}
.trust-row svg{width:20px;height:20px;color:var(--seafoam)}
.cta-stack{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;margin:1.4rem 0 .3rem}
.callnote{font-family:var(--body);font-size:.82rem;color:var(--muted)}
/* island cross-section */
.island{background:var(--teal);border-radius:20px;padding:1.4rem;color:#fff;box-shadow:var(--shadow);position:relative;overflow:hidden}
.island h3{color:#fff;font-size:1.05rem;margin-bottom:.2rem}
.island .cap{font-size:.82rem;color:#a9cfca;margin-bottom:1rem}
.island svg{width:100%;height:auto;display:block;border-radius:12px}
.island .lg{display:grid;grid-template-columns:1fr 1fr;gap:.4rem .9rem;margin-top:.9rem;font-size:.8rem}
.island .lg div{display:flex;gap:.45rem;align-items:flex-start;color:#cfe6e3}
.island .lg b{color:#fff;font-weight:700}
.island .lg i{width:11px;height:11px;border-radius:3px;flex:none;margin-top:.28rem;font-style:normal}
/* field guide */
.guide{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.gcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.2rem;position:relative;overflow:hidden}
.gcard::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--seafoam)}
.gcard.warn::before{background:var(--coral)}
.gcard .bug{width:46px;height:46px;border-radius:50%;background:var(--shell-2);display:flex;align-items:center;justify-content:center;margin-bottom:.7rem;color:var(--teal)}
.gcard .bug svg{width:26px;height:26px}
.gcard h4{font-family:var(--disp);font-weight:600;font-size:1.08rem;color:var(--teal);margin:0 0 .3rem}
.gcard p{font-size:.86rem;color:var(--muted);margin:0}
.gcard .tag{font-family:var(--body);font-weight:700;font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--coral);display:block;margin-top:.5rem}
/* season ribbon */
.season{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.4rem;overflow-x:auto}
.season table{width:100%;border-collapse:collapse;min-width:640px}
.season th{font-family:var(--body);font-weight:700;font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);padding:.4rem .3rem;text-align:center}
.season td{padding:.3rem .25rem;text-align:center}
.season .pest{text-align:left;font-family:var(--disp);font-weight:600;color:var(--teal);font-size:.95rem;white-space:nowrap;padding-right:.8rem}
.season .b{height:14px;border-radius:7px;background:var(--shell-2)}
.season .b.on{background:var(--seafoam)}
.season .b.hi{background:var(--coral)}
/* cards / services */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1.4rem;box-shadow:var(--shadow)}
.card h3{margin-bottom:.35rem;font-size:1.2rem}
.card .ic{width:46px;height:46px;border-radius:12px;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:.85rem}
.card .ic svg{width:24px;height:24px}
.card .more{font-family:var(--body);font-weight:700;color:var(--coral-d);display:inline-block;margin-top:.5rem}
/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.steps .s{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:1.5rem 1.3rem}
.steps .s .no{font-family:var(--disp);font-style:italic;color:var(--marigold);font-size:1.5rem;font-weight:600}
.steps .s h3{margin:.3rem 0 .3rem}
/* cost */
.cost{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.cost .c{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.5rem;text-align:center}
.cost .c .amt{font-family:var(--disp);font-weight:600;font-size:2rem;color:var(--coral)}
.cost .c small{font-weight:600;font-size:.78rem;color:var(--muted)}
/* faq */
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:.7rem}
.faq summary{cursor:pointer;font-family:var(--disp);font-weight:600;font-size:1.08rem;color:var(--teal);padding:1rem 1.1rem;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--coral);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq p{padding:0 1.1rem 1.1rem;margin:0;color:var(--muted)}
/* areas */
.areas{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
.areas a{background:#fff;border:1px solid var(--line);border-radius:10px;padding:.8rem .9rem;font-weight:700;color:var(--teal);display:flex;align-items:center;justify-content:space-between}
.areas a:hover{border-color:var(--coral);text-decoration:none}
.areas a span{color:var(--coral)}
/* prose */
.prose{max-width:72ch}
.prose.full{max-width:820px;margin-left:auto;margin-right:auto}
.prose h2{margin-top:1.6rem}
.prose ul{padding-left:0;list-style:none;margin:1rem 0}
.prose ul li{padding:.35rem 0 .35rem 1.7rem;position:relative}
.prose ul li::before{content:"";position:absolute;left:0;top:.8rem;width:11px;height:11px;border-radius:50%;background:var(--seafoam)}
/* cta band */
.ctaband{background:var(--teal);border-radius:22px;padding:2.5rem;text-align:center;position:relative;overflow:hidden}
.ctaband::after{content:"";position:absolute;left:0;right:0;bottom:0;height:60px;background:radial-gradient(circle at 20% 0,var(--seafoam),transparent 60%);opacity:.3}
.ctaband h2{color:#fff;position:relative}
.ctaband .phone{font-family:var(--disp);font-weight:600;font-size:2.1rem;color:var(--marigold);position:relative;display:inline-block;margin:.4rem 0 1rem}
/* footer */
.ft{background:var(--teal);color:#a9cfca;border-top:6px solid var(--marigold)}
.ft .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:1.6rem;padding:3rem 0 1.4rem}
.ft h4{color:#fff;font-size:.8rem;font-family:var(--body);letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.ft a{color:#a9cfca;font-weight:500;font-size:.92rem;display:block;padding:.2rem 0}
.ft a:hover{color:#fff}
.ft .bigphone{font-family:var(--disp);font-weight:600;font-size:1.7rem;color:var(--marigold)}
.ft .disc{font-size:.76rem;color:#7fa8a3;border-top:1px solid rgba(255,255,255,.12);padding:1.2rem 0 5rem;line-height:1.6}
/* callbar */
.callbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:80;background:rgba(14,77,74,.97);backdrop-filter:blur(8px);border-top:3px solid var(--marigold);padding:.55rem .8rem calc(.55rem + env(safe-area-inset-bottom))}
.callbar .cbrow{display:flex;align-items:center;gap:.8rem;justify-content:space-between;max-width:560px;margin:0 auto}
.callbar .cbtext b{display:block;font-family:var(--disp);font-weight:600;font-size:.98rem;color:#fff}
.callbar .cbtext span{font-size:.66rem;letter-spacing:.04em;color:#8fbcb7;font-weight:600;text-transform:uppercase}
.callbar .cbbtn{display:inline-flex;align-items:center;gap:.45rem;background:var(--coral);color:#fff;font-family:var(--body);font-weight:700;font-size:1rem;padding:.7rem 1.15rem;border-radius:6px;white-space:nowrap}
.callbar .cbbtn:hover{text-decoration:none}
.callbar .cbbtn svg{width:17px;height:17px}
/* pagehead / crumbs */
.crumbs{font-family:var(--body);font-weight:600;font-size:.78rem;color:#8fbcb7;padding:0 0 .3rem}
.pagehead{background:var(--teal);color:#fff;padding:2.4rem 0 2.6rem;position:relative;overflow:hidden}
.pagehead::after{content:"";position:absolute;right:-40px;bottom:-50px;width:260px;height:120px;background:radial-gradient(circle at 30% 0,var(--seafoam),transparent 65%);opacity:.35}
.pagehead h1{color:#fff;position:relative}
.pagehead .lead{color:#a9cfca;position:relative}
.pagehead .crumbs,.pagehead .crumbs a{color:#8fbcb7}
/* responsive */
@media(max-width:1024px){
  .hero .grid{grid-template-columns:1fr;gap:1.6rem}
  .grid-3,.grid-4,.steps,.cost,.guide,.areas{grid-template-columns:1fr 1fr}
  .ft .cols{grid-template-columns:1fr 1fr}
  .nav,.util{display:none}
  .hdr-mobile{display:flex}
  .callbar{display:block}
  body{padding-bottom:78px}
  #mnav.open{display:block;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  #mnav a{display:block;padding:.85rem 20px;border-top:1px solid var(--line);color:var(--teal);font-weight:600}
  #mnav a:first-child{border-top:0}
}
@media(max-width:560px){
  .grid-3,.grid-4,.steps,.cost,.guide,.areas,.grid-2,.ft .cols{grid-template-columns:1fr}
  .hero .cta-stack .btn{width:100%;justify-content:center}
}
