/* ==========================================================================
   High Tech Vermin Control — design tokens
   Palette pulled from brand logo: eggplant base, magenta→violet reticle gradient
   ========================================================================== */
:root {
  --bg-deep:      #220a3a;
  --bg-base:      #4c1a6f;
  --bg-base-2:    #3a1356;
  --card:         #34134d;
  --card-border:  rgba(199, 187, 209, 0.18);
  --accent-pink:  #ff6e8e;
  --accent-violet:#9b59f6;
  --lavender:     #c7bbd1;
  --text:         #f7f3fa;
  --text-dim:     #cdb9da;
  --mono:         'IBM Plex Mono', monospace;
  --display:      'Space Grotesk', sans-serif;
  --body:         'Inter', sans-serif;
  --radius:       14px;
  --gradient:     linear-gradient(120deg, var(--accent-pink), var(--accent-violet));
}

* { margin:0; padding:0; box-sizing:border-box; }

html { scroll-behavior: smooth; }

body {
  background: var(--bg-deep);
  color: var(--text);
  font-family: var(--body);
  line-height: 1.6;
  overflow-x: hidden;
}

img { max-width: 100%; display:block; }
a { color: inherit; text-decoration:none; }
ul { list-style:none; }

.wrap { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

h1,h2,h3 { font-family: var(--display); line-height:1.15; letter-spacing: -0.01em; }

.eyebrow {
  font-family: var(--mono);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-pink);
  display:flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before {
  content:"";
  width:8px; height:8px;
  border-radius:50%;
  background: var(--gradient);
  box-shadow: 0 0 10px var(--accent-pink);
}

.btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family: var(--display);
  font-weight:600;
  font-size: 0.95rem;
  padding: 14px 26px;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease;
}
.btn-primary {
  background: var(--gradient);
  color: #1c0830;
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(255,110,142,0.35); }
.btn-ghost {
  border-color: var(--card-border);
  color: var(--text);
}
.btn-ghost:hover { border-color: var(--accent-pink); }
.btn:focus-visible { outline: 2px solid var(--accent-pink); outline-offset: 3px; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top:0; z-index: 50;
  background: rgba(34,10,58,0.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--card-border);
}
.site-header .wrap { display:flex; align-items:center; justify-content:space-between; height:78px; }
.brand { display:flex; align-items:center; gap:12px; font-family: var(--display); font-weight:700; font-size:1.05rem; }
.brand img { width:42px; height:42px; object-fit:contain; }
.brand .sub { display:block; font-family: var(--mono); font-weight:400; font-size:0.62rem; letter-spacing:0.14em; color: var(--text-dim); text-transform:uppercase; }

.main-nav ul { display:flex; gap:30px; font-size:0.92rem; font-weight:500; }
.main-nav a { color: var(--text-dim); transition: color .15s; position:relative; }
.main-nav a:hover, .main-nav a.active { color: var(--text); }
.main-nav a.active::after {
  content:""; position:absolute; left:0; right:0; bottom:-22px; height:2px; background: var(--gradient);
}
.header-cta { display:flex; align-items:center; gap:18px; }
.phone-link { font-family: var(--mono); font-size:0.9rem; color: var(--accent-pink); }
.nav-toggle { display:none; background:none; border:0; color:var(--text); font-size:1.6rem; cursor:pointer; }

@media (max-width: 880px) {
  .main-nav { position:fixed; top:78px; right:0; bottom:0; left:0; height:calc(100vh - 78px); background: var(--bg-deep); padding: 30px 24px; transform: translateY(-110%); transition: transform .25s ease; pointer-events:none; z-index:40; overflow-y:auto; }
  .main-nav.open { transform: translateY(0); pointer-events:auto; }
  .header-cta { position:relative; z-index:60; }
  .main-nav ul { flex-direction:column; gap:22px; font-size:1.1rem; }
  .main-nav a.active::after { bottom:-8px; }
  .nav-toggle { display:block; }
  .phone-link { display:none; }
}

/* ---------- Hero with reticle motif ---------- */
.hero {
  position:relative;
  padding: 90px 0 110px;
  background:
    radial-gradient(circle at 80% 10%, rgba(255,110,142,0.18), transparent 50%),
    radial-gradient(circle at 10% 90%, rgba(155,89,246,0.18), transparent 50%),
    var(--bg-base);
  overflow:hidden;
}
.hero .wrap { display:grid; grid-template-columns: 1.1fr 0.9fr; gap:50px; align-items:center; position:relative; z-index:2; }
.hero h1 { font-size: clamp(2.2rem, 4.2vw, 3.4rem); margin: 18px 0 20px; }
.hero h1 span { background: var(--gradient); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero p.lede { font-size:1.08rem; color: var(--text-dim); max-width:480px; margin-bottom:32px; }
.hero .cta-row { display:flex; gap:16px; flex-wrap:wrap; }

.reticle-stage { position:relative; aspect-ratio:1; max-width:420px; margin:0 auto; }
.reticle-ring {
  position:absolute; inset:0; border:1.5px solid rgba(199,187,209,0.35); border-radius:50%;
}
.reticle-ring.r2 { inset: 14%; border-color: rgba(255,110,142,0.45); }
.reticle-ring.r3 { inset: 30%; border-color: rgba(155,89,246,0.55); }
.reticle-stage::before, .reticle-stage::after {
  content:""; position:absolute; background: rgba(199,187,209,0.35);
}
.reticle-stage::before { top:0; bottom:0; left:50%; width:1px; }
.reticle-stage::after { left:0; right:0; top:50%; height:1px; }
.reticle-sweep {
  position:absolute; inset:0; border-radius:50%;
  background: conic-gradient(from 0deg, rgba(255,110,142,0.55), transparent 28%);
  animation: sweep 4.5s linear infinite;
}
.reticle-core {
  position:absolute; top:50%; left:50%; width:64px; height:64px; margin:-32px 0 0 -32px;
  border-radius:50%; background: var(--gradient);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:0.62rem; letter-spacing:0.08em; text-align:center; color:#1c0830; font-weight:700;
  box-shadow: 0 0 36px rgba(255,110,142,0.5);
}
.reticle-tag {
  position:absolute; font-family:var(--mono); font-size:0.65rem; letter-spacing:0.1em; color: var(--text-dim);
  background: rgba(34,10,58,0.7); padding:4px 8px; border-radius:6px; border:1px solid var(--card-border);
}
.reticle-tag.t1 { top:6%; right:2%; }
.reticle-tag.t2 { bottom:10%; left:0%; }

@keyframes sweep { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .reticle-sweep { animation: none; } }

@media (max-width: 880px) {
  .hero .wrap { grid-template-columns:1fr; }
  .reticle-stage { max-width:280px; }
}

/* ---------- Stat strip ---------- */
.stat-strip { background: var(--bg-base-2); border-top:1px solid var(--card-border); border-bottom:1px solid var(--card-border); }
.stat-strip .wrap { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; padding:30px 24px; }
.stat { text-align:center; }
.stat .num { font-family:var(--mono); font-size:1.5rem; color: var(--accent-pink); }
.stat .lbl { font-size:0.78rem; color: var(--text-dim); text-transform:uppercase; letter-spacing:0.06em; margin-top:4px;}
@media (max-width:700px){ .stat-strip .wrap{ grid-template-columns: repeat(2,1fr);} }

/* ---------- Sections ---------- */
section { padding: 90px 0; }
.section-head { max-width:640px; margin-bottom:48px; }
.section-head h2 { font-size: clamp(1.7rem, 3vw, 2.3rem); margin-top:14px; }
.section-head p { color: var(--text-dim); margin-top:14px; }

/* Services grid - "target zones" */
.zones-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.zone-card {
  background: var(--card); border:1px solid var(--card-border); border-radius: var(--radius);
  padding: 28px; position:relative; overflow:hidden; transition: transform .2s ease, border-color .2s ease;
}
.zone-card:hover { transform: translateY(-4px); border-color: rgba(255,110,142,0.5); }
.zone-card .tag { font-family:var(--mono); font-size:0.7rem; color: var(--text-dim); letter-spacing:0.08em; }
.zone-card h3 { font-size:1.2rem; margin:12px 0 10px; }
.zone-card p { color: var(--text-dim); font-size:0.93rem; }
.zone-card .coord { position:absolute; top:18px; right:20px; font-family:var(--mono); font-size:0.68rem; color:rgba(255,110,142,0.5); }
@media (max-width:900px){ .zones-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:620px){ .zones-grid{ grid-template-columns:1fr;} }

/* Process / how-it-works */
.process { background: var(--bg-base-2); }
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:0; counter-reset: step; }
.step { padding:0 22px; position:relative; }
.step:not(:last-child)::after {
  content:""; position:absolute; top:18px; right:-2px; width:60%; height:1px;
  background: repeating-linear-gradient(90deg, var(--card-border) 0 6px, transparent 6px 12px);
}
.step .idx { font-family:var(--mono); color: var(--accent-pink); font-size:0.85rem; }
.step h3 { font-size:1.05rem; margin:10px 0 8px; }
.step p { color: var(--text-dim); font-size:0.9rem; }
@media (max-width:900px){ .process-steps{ grid-template-columns:1fr 1fr; gap:30px;} .step:not(:last-child)::after{display:none;} }
@media (max-width:600px){ .process-steps{ grid-template-columns:1fr;} }

/* Tech feature split */
.tech-split { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.tech-list li { display:flex; gap:14px; margin-bottom:20px; align-items:flex-start; }
.tech-list .dot { width:10px; height:10px; border-radius:50%; background:var(--gradient); margin-top:7px; flex-shrink:0; }
.tech-list h4 { font-size:1.02rem; margin-bottom:4px; }
.tech-list p { color:var(--text-dim); font-size:0.9rem; }
.readout {
  background: var(--bg-deep); border:1px solid var(--card-border); border-radius: var(--radius);
  padding:26px; font-family:var(--mono); font-size:0.85rem; color:var(--text-dim);
}
.readout .line { display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px dashed var(--card-border); }
.readout .line span:last-child { color: var(--accent-pink); }
@media (max-width:880px){ .tech-split{ grid-template-columns:1fr;} }

/* Areas covered */
.areas-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.area-pin {
  background: var(--card); border:1px solid var(--card-border); border-radius:10px;
  padding:14px; text-align:center; font-size:0.88rem;
}
@media (max-width:800px){ .areas-grid{ grid-template-columns:repeat(3,1fr);} }
@media (max-width:520px){ .areas-grid{ grid-template-columns:repeat(2,1fr);} }

/* Testimonials */
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.testi { background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius); padding:26px; }
.testi p { color:var(--text-dim); font-size:0.93rem; margin-bottom:16px; }
.testi .who { font-family:var(--mono); font-size:0.78rem; color: var(--accent-pink); }
@media (max-width:900px){ .testi-grid{ grid-template-columns:1fr;} }

/* CTA band */
.cta-band {
  background: var(--gradient); color:#1c0830; border-radius: 20px; padding:50px 40px;
  display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap;
}
.cta-band h2 { font-size:1.7rem; color:#1c0830; }
.cta-band .btn-ghost { border-color:#1c0830; color:#1c0830; }
.cta-band .btn-ghost:hover { background:#1c0830; color:#fff; }

/* Forms */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:50px; }
.field { margin-bottom:18px; }
.field label { display:block; font-size:0.82rem; color:var(--text-dim); margin-bottom:6px; font-family:var(--mono); letter-spacing:0.04em;}
.field input, .field select, .field textarea {
  width:100%; padding:12px 14px; border-radius:10px; border:1px solid var(--card-border);
  background: var(--bg-deep); color:var(--text); font-family:var(--body); font-size:0.95rem;
}
.field input:focus, .field select:focus, .field textarea:focus { outline:2px solid var(--accent-pink); }
.info-card { background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius); padding:26px; margin-bottom:16px; }
.info-card .eyebrow { margin-bottom:8px; }
@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr;} }

/* Footer */
.site-footer { background: var(--bg-deep); border-top:1px solid var(--card-border); padding:50px 0 30px; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px; margin-bottom:30px; }
.footer-grid h4 { font-size:0.85rem; margin-bottom:14px; color:var(--text); }
.footer-grid li { margin-bottom:9px; }
.footer-grid a { color:var(--text-dim); font-size:0.9rem; }
.footer-grid a:hover { color: var(--accent-pink); }
.footer-bottom { display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; border-top:1px solid var(--card-border); padding-top:20px; font-size:0.8rem; color:var(--text-dim); font-family:var(--mono); }
@media (max-width:800px){ .footer-grid{ grid-template-columns:1fr 1fr;} }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr;} }

.page-hero { padding:60px 0 50px; background: var(--bg-base); text-align:left; }
.page-hero h1 { font-size: clamp(1.9rem,3.6vw,2.6rem); margin-top:14px; }
.breadcrumb { font-family:var(--mono); font-size:0.78rem; color:var(--text-dim); }
.breadcrumb a:hover { color:var(--accent-pink); }
