/* ============ 303 PEST CONTROL — 2026 build ============ */
:root{
  --green-900:#0f3b2e;
  --green-700:#176b4c;
  --green-500:#1f8f63;
  --green-400:#37c98a;
  --sand-50:#faf6ee;
  --sand-100:#f4ede0;
  --sand-200:#e8dcc6;
  --ink:#15211c;
  --ink-soft:#4d5c54;
  --white:#ffffff;
  --blue-303:#2bb7ef; /* native to the client's photos/icons */
  --radius:20px;
  --radius-sm:14px;
  --shadow:0 18px 50px -22px rgba(15,59,46,.45);
  --shadow-sm:0 8px 24px -14px rgba(15,59,46,.4);
  --maxw:1160px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--sand-50);line-height:1.6;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{line-height:1.06;letter-spacing:-.02em;margin:0;font-weight:800}
p{margin:0}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:20px}
.section{padding-block:clamp(56px,9vw,116px)}

.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--green-900);color:#fff;padding:12px 18px;border-radius:0 0 12px 0}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--green-400);outline-offset:3px;border-radius:6px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  min-height:48px;padding:14px 26px;border-radius:999px;font-weight:700;font-size:1rem;
  cursor:pointer;border:0;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  will-change:transform;text-align:center;
}
.btn:active{transform:scale(.96)}
.btn-primary{background:linear-gradient(135deg,var(--green-500),var(--green-700));color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 34px -16px rgba(23,107,76,.7)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.22)}
.btn-sm{min-height:44px;padding:11px 20px;font-size:.95rem}
.btn-block{width:100%}
.btn-call{background:var(--green-400);color:var(--green-900);font-weight:800}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:90;
  background:rgba(250,246,238,.72);backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid transparent;transition:padding .3s var(--ease),background .3s,border-color .3s,box-shadow .3s;
}
.site-header.shrink{padding-block:0;background:rgba(250,246,238,.92);border-color:var(--sand-200);box-shadow:0 6px 20px -16px rgba(15,59,46,.5)}
.header-inner{display:flex;align-items:center;gap:14px;padding-block:14px;transition:padding .3s var(--ease)}
.site-header.shrink .header-inner{padding-block:8px}
.brand{display:inline-flex;align-items:center;transition:transform .25s var(--ease)}
.brand:hover{transform:scale(1.04)}
.brand-logo{height:44px;width:auto;transition:height .3s var(--ease)}
.site-header.shrink .brand-logo{height:36px}
.main-nav{display:none;margin-left:auto;gap:26px;font-weight:600;font-size:.97rem}
.main-nav a{position:relative;color:var(--ink-soft);transition:color .2s}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--green-500);transition:width .25s var(--ease)}
.main-nav a:hover{color:var(--green-700)}.main-nav a:hover::after{width:100%}
.header-call{margin-left:auto;font-size:.92rem;padding:10px 16px;min-height:44px}
.header-call .dot{width:8px;height:8px;border-radius:50%;background:var(--green-900);box-shadow:0 0 0 0 rgba(15,59,46,.5);animation:ring 2s infinite}
@keyframes ring{0%{box-shadow:0 0 0 0 rgba(15,59,46,.5)}70%{box-shadow:0 0 0 8px rgba(15,59,46,0)}100%{box-shadow:0 0 0 0 rgba(15,59,46,0)}}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(165deg,var(--green-900) 0%,var(--green-700) 55%,#14543b 100%);color:#fff;padding-block:clamp(40px,9vw,90px) clamp(60px,11vw,120px)}
.hero-art{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.sun{position:absolute;top:-10%;right:-8%;width:min(58vw,420px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 50% 50%,#ffd884 0%,#ff9d4d 38%,rgba(255,138,61,0) 70%);
  filter:blur(2px);animation:sunDrift 14s ease-in-out infinite alternate}
@keyframes sunDrift{from{transform:translate(0,0) scale(1)}to{transform:translate(-26px,28px) scale(1.08)}}
.shimmer{position:absolute;inset:0;background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.06) 50%,transparent 60%);background-size:300% 100%;animation:shim 7s linear infinite;mix-blend-mode:overlay}
@keyframes shim{from{background-position:120% 0}to{background-position:-120% 0}}
.dune{position:absolute;left:-5%;right:-5%;border-radius:50% 50% 0 0;opacity:.5}
.dune-1{bottom:-40%;height:60%;background:radial-gradient(120% 80% at 50% 0,rgba(31,143,99,.55),transparent 70%);animation:duneFloat 9s ease-in-out infinite alternate}
.dune-2{bottom:-46%;height:62%;background:radial-gradient(120% 80% at 40% 0,rgba(15,59,46,.7),transparent 72%);animation:duneFloat 11s ease-in-out infinite alternate-reverse}
@keyframes duneFloat{from{transform:translateX(0)}to{transform:translateX(20px)}}
.grain{position:absolute;inset:0;opacity:.05;background-image:radial-gradient(rgba(255,255,255,.8) 1px,transparent 1px);background-size:4px 4px}

.hero-inner{position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.82rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#d6f4e6;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:7px 14px;border-radius:999px;margin-bottom:22px}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--green-400);animation:ring2 1.8s infinite}
@keyframes ring2{0%{box-shadow:0 0 0 0 rgba(55,201,138,.6)}70%{box-shadow:0 0 0 7px rgba(55,201,138,0)}100%{box-shadow:0 0 0 0 rgba(55,201,138,0)}}
.hero h1{font-size:clamp(2.6rem,9.5vw,5.2rem);font-weight:800;margin-bottom:18px}
.hero h1 .accent{background:linear-gradient(120deg,var(--green-400),#bff3da);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:clamp(1.02rem,3.4vw,1.28rem);color:#dcefe2;max-width:42ch;margin-bottom:28px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}
.hero-cta .btn{flex:1 1 auto;min-width:170px}
.hero-trust{list-style:none;display:flex;flex-wrap:wrap;gap:10px 20px;margin:0 0 36px;padding:0;font-size:.9rem;color:#cdeede;font-weight:600}
.hero-trust li{display:flex;align-items:center;gap:7px}
.hero-trust li::before{content:"✓";color:var(--green-400);font-weight:900}
.hero-photo{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative;border:1px solid rgba(255,255,255,.14)}
.hero-photo img{width:100%;height:auto;object-fit:cover}
.hero-photo figcaption{position:absolute;left:0;bottom:0;right:0;padding:14px 16px;font-size:.82rem;color:#fff;background:linear-gradient(transparent,rgba(15,59,46,.78));font-weight:600}

.scroll-hint{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);z-index:3;width:26px;height:42px;border:2px solid rgba(255,255,255,.5);border-radius:14px;display:flex;justify-content:center;padding-top:7px}
.scroll-hint span{width:4px;height:8px;border-radius:2px;background:#fff;animation:scrolly 1.6s infinite}
@keyframes scrolly{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}100%{opacity:0;transform:translateY(10px)}}

/* ---------- marquee ---------- */
.marquee{background:var(--green-900);color:#fff;overflow:hidden;padding-block:16px;border-block:1px solid rgba(255,255,255,.08)}
.marquee-track{display:flex;align-items:center;gap:26px;width:max-content;animation:marq 26s linear infinite;font-weight:800;font-size:clamp(1rem,3.6vw,1.4rem);text-transform:uppercase;letter-spacing:.02em}
.marquee-track span:nth-child(even){color:var(--green-400)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- stats ---------- */
.stats{background:var(--white);border-bottom:1px solid var(--sand-200)}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 16px;padding-block:clamp(36px,7vw,60px)}
.stat{text-align:center;padding:14px 8px}
.stat-num{display:block;font-size:clamp(2.1rem,8vw,3.3rem);font-weight:800;line-height:1;color:var(--green-700);letter-spacing:-.03em}
.stat-label{display:block;margin-top:8px;font-size:.86rem;color:var(--ink-soft);font-weight:600}

/* ---------- section heads ---------- */
.section-head{max-width:60ch;margin-bottom:clamp(30px,5vw,52px)}
.kicker,.eyebrow.kicker{font-size:.8rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--green-500);margin-bottom:12px}
.kicker{display:block}
.section-head h2{font-size:clamp(1.9rem,6.6vw,3.2rem)}
.section-lede{margin-top:14px;color:var(--ink-soft);font-size:clamp(1rem,3vw,1.14rem)}

/* ---------- services ---------- */
.services{background:var(--sand-50)}
.service-grid{display:grid;grid-template-columns:1fr;gap:16px}
.card{background:var(--white);border:1px solid var(--sand-200);border-radius:var(--radius);padding:26px 22px;position:relative;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;overflow:hidden}
.card::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 100% 0,rgba(43,183,239,.08),transparent 60%);opacity:0;transition:opacity .35s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--green-400)}
.card:hover::before{opacity:1}
.card-icon{width:72px;height:72px;border-radius:50%;margin-bottom:16px;background:var(--sand-100);padding:4px;transition:transform .35s var(--ease)}
.card:hover .card-icon{transform:scale(1.08) rotate(-4deg)}
.card h3{font-size:1.34rem;margin-bottom:8px}
.card p{color:var(--ink-soft);font-size:.98rem;margin-bottom:16px}
.card-link{font-weight:800;color:var(--green-700);transition:gap .2s}
.card-link:hover{color:var(--green-500)}
.card-feature{background:linear-gradient(160deg,var(--green-900),var(--green-700));color:#fff;border-color:transparent}
.card-feature p{color:#cdeede}.card-feature .card-link{color:var(--green-400)}
.card-feature .card-icon{background:rgba(255,255,255,.92)}
.card-badge{position:absolute;top:16px;right:16px;background:var(--green-400);color:var(--green-900);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:5px 11px;border-radius:999px}
.card-cta{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;background:var(--sand-100);border-style:dashed}

/* ---------- why ---------- */
.why{background:var(--white)}
.why-grid{display:grid;grid-template-columns:1fr;gap:14px}
.why-item{background:var(--sand-50);border:1px solid var(--sand-200);border-radius:var(--radius-sm);padding:24px 22px;transition:transform .3s var(--ease),box-shadow .3s}
.why-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.why-ico{font-size:1.9rem;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--white);border-radius:14px;box-shadow:var(--shadow-sm);margin-bottom:14px}
.why-item h3{font-size:1.18rem;margin-bottom:7px}
.why-item p{color:var(--ink-soft);font-size:.96rem}

/* ---------- about ---------- */
.about{background:var(--sand-100)}
.about-inner{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.about-photo{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.about-copy h2{font-size:clamp(1.8rem,6vw,2.8rem);margin-block:8px 16px}
.about-copy p{color:var(--ink-soft);margin-bottom:14px}
.about-points{list-style:none;padding:0;margin:0 0 26px;display:grid;gap:10px}
.about-points li{padding-left:30px;position:relative;font-weight:600}
.about-points li::before{content:"✓";position:absolute;left:0;top:0;width:21px;height:21px;background:var(--green-500);color:#fff;border-radius:50%;font-size:.72rem;display:flex;align-items:center;justify-content:center}

/* ---------- reviews ---------- */
.reviews{background:var(--green-900);color:#fff}
.reviews .kicker{color:var(--green-400)}
.reviews .section-lede{color:#cdeede}
.review-grid{display:grid;grid-template-columns:1fr;gap:16px}
.review{margin:0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:26px 24px;backdrop-filter:blur(4px)}
.review .stars{color:#ffce54;font-size:1.15rem;letter-spacing:2px;margin-bottom:12px}
.review p{font-size:1.04rem;margin-bottom:16px}
.review cite{font-style:normal;font-size:.85rem;color:#a9d6c2;font-weight:600}
.review-note{margin-top:22px;font-size:.8rem;color:#9fc3b3;max-width:60ch}

/* ---------- service area ---------- */
.area{background:var(--sand-50)}
.area-inner{display:grid;grid-template-columns:1fr;gap:32px;align-items:center}
.area-copy h2{font-size:clamp(1.8rem,6vw,2.8rem);margin-block:8px 14px}
.area-copy p{color:var(--ink-soft);margin-bottom:18px}
.area-list{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-wrap:wrap;gap:8px}
.area-list li{background:var(--white);border:1px solid var(--sand-200);border-radius:999px;padding:7px 14px;font-size:.86rem;font-weight:600;color:var(--green-700)}
.area-map{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:var(--sand-100);border:1px solid var(--sand-200)}
.area-map svg{width:100%;height:auto;display:block}
.area-map figcaption{padding:13px 16px;font-size:.84rem;color:var(--ink-soft);font-weight:600;text-align:center;background:var(--white);border-top:1px solid var(--sand-200)}
.pulse-ring{opacity:0}

/* ---------- faq ---------- */
.faq{background:var(--white)}
.faq-list{display:grid;gap:12px;max-width:780px}
.faq-item{background:var(--sand-50);border:1px solid var(--sand-200);border-radius:var(--radius-sm);padding:4px 22px;transition:box-shadow .3s,border-color .3s}
.faq-item[open]{box-shadow:var(--shadow-sm);border-color:var(--green-400)}
.faq-item summary{list-style:none;cursor:pointer;font-weight:700;font-size:1.06rem;padding:18px 36px 18px 0;position:relative}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:1.5rem;font-weight:400;color:var(--green-500);transition:transform .3s var(--ease)}
.faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq-item p{color:var(--ink-soft);padding-bottom:20px;font-size:.98rem}

/* ---------- contact ---------- */
.contact{background:linear-gradient(165deg,var(--green-700),var(--green-900));color:#fff}
.contact .kicker{color:var(--green-400)}
.contact-inner{display:grid;grid-template-columns:1fr;gap:34px}
.contact-copy h2{font-size:clamp(1.9rem,6.4vw,3rem);margin-block:8px 14px}
.contact-copy>p{color:#dcefe2;margin-bottom:24px}
.contact-details{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.contact-details li{display:flex;flex-direction:column;gap:2px}
.contact-details strong{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--green-400)}
.contact-details a{font-weight:700}
.quote-form{background:var(--white);color:var(--ink);border-radius:var(--radius);padding:24px 22px;display:grid;grid-template-columns:1fr 1fr;gap:14px;box-shadow:var(--shadow)}
.field{display:flex;flex-direction:column;gap:6px}
.field-full{grid-column:1/-1}
.field label{font-size:.84rem;font-weight:700;color:var(--ink-soft)}
.field input,.field select,.field textarea{font:inherit;padding:13px 14px;border:1.5px solid var(--sand-200);border-radius:12px;background:var(--sand-50);color:var(--ink);min-height:48px;transition:border-color .2s,box-shadow .2s}
.field textarea{min-height:auto;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green-500);box-shadow:0 0 0 3px rgba(31,143,99,.18)}
.quote-form .btn-block{grid-column:1/-1}
.form-status{grid-column:1/-1;margin:0;font-size:.9rem;font-weight:700;color:var(--green-700);min-height:1.2em}

/* ---------- footer ---------- */
.site-footer{background:#0b2c22;color:#cdeede;padding-top:clamp(40px,7vw,64px)}
.footer-inner{display:grid;grid-template-columns:1fr;gap:30px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand img{margin-bottom:14px}
.footer-brand p{font-size:.92rem;max-width:36ch}
.footer-col h3{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--green-400);margin-bottom:14px}
.footer-col a,.footer-col span{display:block;margin-bottom:10px;font-size:.94rem;color:#cdeede;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding-block:20px;font-size:.84rem;color:#8fb4a4}
.footer-bottom a:hover{color:#fff}

/* ---------- sticky mobile call bar ---------- */
.mobile-callbar{position:fixed;left:12px;right:12px;bottom:12px;z-index:80;display:flex;align-items:center;gap:13px;
  background:linear-gradient(135deg,var(--green-500),var(--green-700));color:#fff;border-radius:16px;padding:12px 16px;
  box-shadow:0 14px 36px -10px rgba(15,59,46,.6);transition:transform .35s var(--ease),opacity .35s;min-height:60px}
.mobile-callbar.hide{transform:translateY(130%);opacity:0;pointer-events:none}
.cb-ico{font-size:1.4rem;animation:wiggle 2.6s ease-in-out infinite}
@keyframes wiggle{0%,88%,100%{transform:rotate(0)}90%{transform:rotate(-12deg)}94%{transform:rotate(12deg)}}
.cb-text{display:flex;flex-direction:column;line-height:1.2;flex:1}
.cb-text strong{font-size:.95rem}.cb-text span{font-size:.84rem;opacity:.92}
.cb-go{font-size:1.3rem;font-weight:800}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============ DESKTOP ============ */
@media(min-width:640px){
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .review-grid{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:860px){
  .main-nav{display:flex}
  .header-call{margin-left:0}
  .service-grid{grid-template-columns:repeat(3,1fr)}
  .card-feature{grid-row:span 2}
  .why-grid{grid-template-columns:repeat(4,1fr)}
  .about-inner{grid-template-columns:1.05fr 1fr}
  .about-inner .about-photo{order:2}
  .area-inner{grid-template-columns:1fr 1.1fr}
  .contact-inner{grid-template-columns:.9fr 1.1fr}
  .mobile-callbar{display:none}
  .hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
  .hero-photo{grid-row:1/span 6;grid-column:2}
  .hero .eyebrow,.hero h1,.hero-sub,.hero-cta,.hero-trust{grid-column:1}
}
@media(min-width:1024px){
  .hero h1{font-size:clamp(3.4rem,5.6vw,5.4rem)}
}

/* ============ REDUCED MOTION ============ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
  .marquee-track{animation:none}
  .sun,.shimmer,.dune,.cb-ico,.header-call .dot,.pulse-dot,.scroll-hint span{animation:none}
  .pulse-ring{opacity:0}
  #scorpion{opacity:0}#shield{opacity:1}
}
