/* ---- Tailwind preflight subset (matches what the CDN provided) ---- */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:currentColor}
html{-webkit-text-size-adjust:100%;line-height:1.5}
h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit;margin:0}
p,figure,blockquote{margin:0}
a{color:inherit;text-decoration:inherit}
button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}
button,select{text-transform:none}
button,[type='button'],[type='reset'],[type='submit']{-webkit-appearance:button;background-color:transparent;background-image:none}
button,[role="button"]{cursor:pointer}
:-moz-focusring{outline:auto}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}
input::placeholder,textarea::placeholder{opacity:1;color:#94a3b8}
[hidden]{display:none}

/* ---- Site base + custom animations / brand ---- */
body{font-family:'Heebo',sans-serif;background-color:#020617;color:#f1f5f9;margin:0;overflow-x:hidden}
section{position:relative;z-index:10}
.custom-font-impact{letter-spacing:-0.05em}
.brand-olive{color:#9ABF68}
.bg-brand-olive{background-color:#9ABF68}
.pest-instance{position:absolute;pointer-events:none;z-index:0;opacity:0.3}

@keyframes scuttle{0%{transform:translate(0,0) rotate(0deg)}25%{transform:translate(15px,-8px) rotate(15deg)}50%{transform:translate(30px,0px) rotate(0deg)}75%{transform:translate(15px,8px) rotate(-15deg)}100%{transform:translate(0,0) rotate(0deg)}}
@keyframes slither{0%,100%{transform:translateX(0) scaleY(1)}50%{transform:translateX(30px) scaleY(0.9)}}
@keyframes glow-pulse{0%,100%{transform:scale(1);box-shadow:0 0 15px 2px rgba(154,191,104,0.4)}50%{transform:scale(1.03);box-shadow:0 0 30px 8px rgba(154,191,104,0.6)}}
@keyframes flicker{0%,80%,100%{opacity:0;transform:scaleX(0)}85%,95%{opacity:1;transform:scaleX(1)}}
@keyframes swing{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}
.animate-scuttle{animation:scuttle 8s infinite linear}
.animate-slither{animation:slither 6s infinite ease-in-out}
.animate-glow-pulse{animation:glow-pulse 2.5s infinite ease-in-out}
.animate-flicker{animation:flicker 3s infinite;transform-origin:left center}

/* ---- space-y ---- */
.space-y-2 > :not([hidden]) ~ :not([hidden]){margin-top:0.5rem}
.space-y-6 > :not([hidden]) ~ :not([hidden]){margin-top:1.5rem}
/* ---- utilities ---- */
.block{display:block}
.inline-block{display:inline-block}
.inline-flex{display:inline-flex}
.flex{display:flex}
.grid{display:grid}
.hidden{display:none}
.flex-col{flex-direction:column}
.flex-1{flex:1 1 0%}
.flex-shrink-0{flex-shrink:0}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.justify-center{justify-content:center}
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.fixed{position:fixed}
.relative{position:relative}
.inset-0{top:0;right:0;bottom:0;left:0}
.bottom-6{bottom:1.5rem}
.left-4{left:1rem}
.right-4{right:1rem}
.z-10{z-index:10}
.z-50{z-index:50}
.z-\[5\]{z-index:5}
.overflow-hidden{overflow:hidden}
.pointer-events-none{pointer-events:none}
.mx-auto{margin-left:auto;margin-right:auto}
.max-w-2xl{max-width:42rem}
.max-w-4xl{max-width:56rem}
.max-w-6xl{max-width:72rem}
.w-12{width:3rem}
.w-16{width:4rem}
.w-full{width:100%}
.h-12{height:3rem}
.h-16{height:4rem}
.h-3{height:0.75rem}
.p-4{padding:1rem}
.p-5{padding:1.25rem}
.p-6{padding:1.5rem}
.p-8{padding:2rem}
.px-5{padding-left:1.25rem;padding-right:1.25rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.px-10{padding-left:2.5rem;padding-right:2.5rem}
.py-2{padding-top:0.5rem;padding-bottom:0.5rem}
.py-3{padding-top:0.75rem;padding-bottom:0.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-6{padding-top:1.5rem;padding-bottom:1.5rem}
.py-12{padding-top:3rem;padding-bottom:3rem}
.py-16{padding-top:4rem;padding-bottom:4rem}
.pt-4{padding-top:1rem}
.pt-6{padding-top:1.5rem}
.pt-10{padding-top:2.5rem}
.pb-4{padding-bottom:1rem}
.pb-12{padding-bottom:3rem}
.pb-16{padding-bottom:4rem}
.pb-32{padding-bottom:8rem}
.pr-2{padding-right:0.5rem}
.mb-1{margin-bottom:0.25rem}
.mb-3{margin-bottom:0.75rem}
.mb-4{margin-bottom:1rem}
.mb-6{margin-bottom:1.5rem}
.mb-8{margin-bottom:2rem}
.mb-10{margin-bottom:2.5rem}
.mb-12{margin-bottom:3rem}
.mt-2{margin-top:0.5rem}
.mt-4{margin-top:1rem}
.mt-6{margin-top:1.5rem}
.mt-12{margin-top:3rem}
.gap-1{gap:0.25rem}
.gap-2{gap:0.5rem}
.gap-3{gap:0.75rem}
.gap-4{gap:1rem}
.gap-6{gap:1.5rem}
.text-center{text-align:center}
.text-left{text-align:left}
.text-right{text-align:right}
.text-xs{font-size:0.75rem;line-height:1rem}
.text-sm{font-size:0.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.text-5xl{font-size:3rem;line-height:1}
.text-\[11px\]{font-size:11px}
.text-white{color:#fff}
.text-slate-300{color:#cbd5e1}
.text-slate-400{color:#94a3b8}
.text-slate-500{color:#64748b}
.text-slate-600{color:#475569}
.text-slate-900{color:#0f172a}
.font-medium{font-weight:500}
.font-bold{font-weight:700}
.font-black{font-weight:900}
.leading-tight{line-height:1.25}
.leading-relaxed{line-height:1.625}
.tracking-tighter{letter-spacing:-0.05em}
.tracking-wide{letter-spacing:0.025em}
.tracking-widest{letter-spacing:0.1em}
.tracking-\[0\.4em\]{letter-spacing:0.4em}
.italic{font-style:italic}
.uppercase{text-transform:uppercase}
.underline{text-decoration-line:underline}
.opacity-40{opacity:0.4}
.opacity-60{opacity:0.6}
.bg-slate-800{background-color:#1e293b}
.bg-slate-900{background-color:#0f172a}
.bg-slate-950{background-color:#020617}
.bg-slate-800\/50{background-color:rgba(30,41,59,0.5)}
.bg-slate-900\/30{background-color:rgba(15,23,42,0.3)}
.bg-slate-900\/50{background-color:rgba(15,23,42,0.5)}
.bg-slate-900\/70{background-color:rgba(15,23,42,0.7)}
.bg-slate-950\/40{background-color:rgba(2,6,23,0.4)}
.border{border-width:1px}
.border-t{border-top-width:1px}
.border-slate-700\/50{border-color:rgba(51,65,85,0.5)}
.border-slate-800{border-color:#1e293b}
.border-slate-900{border-color:#0f172a}
.border-white\/10{border-color:rgba(255,255,255,0.1)}
.border-white\/5{border-color:rgba(255,255,255,0.05)}
.rounded-xl{border-radius:0.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-3xl{border-radius:1.5rem}
.rounded-full{border-radius:9999px}
.rounded-\[2rem\]{border-radius:2rem}
.rounded-\[2\.5rem\]{border-radius:2.5rem}
.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -4px rgba(0,0,0,0.1)}
.shadow-xl{box-shadow:0 20px 25px -5px rgba(0,0,0,0.1),0 8px 10px -6px rgba(0,0,0,0.1)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgba(0,0,0,0.25)}
.shadow-inner{box-shadow:inset 0 2px 4px 0 rgba(0,0,0,0.05)}
.shadow-\[0_20px_40px_rgba\(0\,0\,0\,0\.6\)\]{box-shadow:0 20px 40px rgba(0,0,0,0.6)}
.bg-gradient-to-l{background-image:linear-gradient(to left,var(--tw-gradient-from,transparent),var(--tw-gradient-to,transparent))}
.from-\[\#9ABF68\]{--tw-gradient-from:#9ABF68}
.to-\[\#7da84e\]{--tw-gradient-to:#7da84e}
.transition-all{transition-property:all;transition-timing-function:cubic-bezier(0.4,0,0.2,1);transition-duration:150ms}
.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(0.4,0,0.2,1);transition-duration:150ms}
.backdrop-blur-lg{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.outline-none{outline:2px solid transparent;outline-offset:2px}
.focus\:ring-\[\#9ABF68\]{--tw-ring-color:#9ABF68}
.hover\:brightness-110:hover{filter:brightness(1.1)}
.hover\:scale-110:hover{transform:scale(1.1)}
.active\:scale-95:active{transform:scale(0.95)}
.focus\:ring-2:focus{box-shadow:0 0 0 2px var(--tw-ring-color,#9ABF68)}
/* ---- responsive: md (>=768px) ---- */
@media (min-width:768px){
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .md\:hidden{display:none}
  .md\:p-12{padding:3rem}
  .md\:pb-24{padding-bottom:6rem}
  .md\:rounded-\[4rem\]{border-radius:4rem}
  .md\:text-2xl{font-size:1.5rem;line-height:2rem}
  .md\:text-3xl{font-size:1.875rem;line-height:2.25rem}
  .md\:text-4xl{font-size:2.25rem;line-height:2.5rem}
  .md\:text-5xl{font-size:3rem;line-height:1}
  .md\:text-6xl{font-size:3.75rem;line-height:1}
  .md\:text-7xl{font-size:4.5rem;line-height:1}
  .md\:text-9xl{font-size:8rem;line-height:1}
  .md\:text-lg{font-size:1.125rem;line-height:1.75rem}
  .md\:text-xl{font-size:1.25rem;line-height:1.75rem}
  .md\:text-sm{font-size:0.875rem;line-height:1.25rem}
  .md\:text-right{text-align:right}
  .md\:text-left{text-align:left}
  .md\:w-auto{width:auto}
}
/* ---- responsive: lg (>=1024px) ---- */
@media (min-width:1024px){
  .lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
}
