/* =====================================================================
   Tiptree & District Business Directory — styled to match Pulsar Web Works
   ===================================================================== */
:root{
  --brand:#4f80ff; --brand-2:#1085fa; --violet:#605be5; --cyan:#22d3ee;
  --ink:#1d2540; --slate:#343f5a; --muted:#6b769a;
  --bg:#ffffff; --bg-soft:#f5f8ff; --bg-line:#e6ecfb; --cosmic:#0b1020; --cosmic-2:#121a33;
  --grad:linear-gradient(135deg,var(--brand),var(--violet));
  --grad-bright:linear-gradient(135deg,var(--cyan),var(--brand));
  --glow:0 0 40px rgba(79,128,255,.35);
  --shadow:0 10px 30px rgba(29,37,64,.08); --shadow-lg:0 24px 60px rgba(29,37,64,.14);
  --radius:18px; --maxw:1140px;
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;}
body{margin:0;font-family:var(--font);color:var(--slate);background:var(--bg);line-height:1.6;font-size:16.5px;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:var(--brand-2);text-decoration:none;}
h1,h2,h3{color:var(--ink);line-height:1.15;margin:0 0 .4em;font-weight:800;letter-spacing:-.02em;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px;}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;border-radius:999px;font-weight:700;font-size:15.5px;cursor:pointer;border:1px solid transparent;transition:transform .18s ease,box-shadow .18s ease;text-decoration:none;white-space:nowrap;}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--glow);}
.btn-light{background:#fff;color:var(--brand);border-color:var(--bg-line);box-shadow:var(--shadow);}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28);}
.dot{width:12px;height:12px;border-radius:50%;flex:none;background:radial-gradient(circle at 30% 30%,#fff,var(--cyan) 38%,var(--brand) 78%);box-shadow:0 0 12px rgba(34,211,238,.8);}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(11,16,32,.72);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.08);}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px;}
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:#fff;letter-spacing:-.01em;}
.brand .dot{width:16px;height:16px;}
.brand small{display:block;font-size:11px;font-weight:600;color:#9fb0dd;letter-spacing:.02em;}
.brand b{font-weight:800;}
.cta-sm{display:none;}

/* Hero (cosmic) */
.hero{position:relative;overflow:hidden;color:#fff;
  background:radial-gradient(900px 480px at 80% -10%,rgba(34,211,238,.16),transparent 60%),
             radial-gradient(800px 480px at 4% 0%,rgba(96,91,229,.30),transparent 55%),var(--cosmic);}
.hero::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:radial-gradient(1.4px 1.4px at 18% 30%,#fff,transparent),radial-gradient(1.2px 1.2px at 72% 22%,#cfe0ff,transparent),radial-gradient(1.5px 1.5px at 42% 66%,#fff,transparent),radial-gradient(1.1px 1.1px at 86% 58%,#bcd2ff,transparent),radial-gradient(1.2px 1.2px at 56% 44%,#fff,transparent);}
.hero-glow{position:absolute;right:-160px;top:30%;width:480px;height:480px;border-radius:50%;z-index:1;pointer-events:none;
  background:radial-gradient(circle,rgba(79,128,255,.4),rgba(96,91,229,.18) 45%,transparent 70%);filter:blur(22px);}
.hero-inner{position:relative;z-index:2;padding:64px 0 14px;text-align:center;max-width:760px;margin:0 auto;}
.pill{display:inline-flex;align-items:center;gap:8px;padding:7px 15px;border-radius:999px;font-size:13px;font-weight:700;letter-spacing:.04em;background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.22);}
.hero-inner h1{color:#fff;font-size:clamp(30px,5vw,46px);margin:16px 0 8px;}
.hero-inner .tagline{color:#c9d4f5;font-size:19px;margin:0;}
.hero-inner .stats{color:#aab6dc;font-size:14px;margin-top:12px;}

/* Controls */
.controls{position:relative;z-index:2;padding:8px 0 0;display:flex;justify-content:center;}
.search{flex:1;max-width:460px;display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.95);border-radius:999px;padding:12px 18px;box-shadow:var(--shadow-lg);}
.search input{flex:1;background:transparent;border:0;color:var(--ink);font-size:15px;outline:none;font-family:inherit;}
.filters{position:relative;z-index:2;display:flex;gap:8px;flex-wrap:wrap;justify-content:center;padding:22px 0 4px;}
.chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);color:#dbe4ff;border-radius:999px;padding:8px 15px;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:inherit;}
.chip:hover{background:rgba(255,255,255,.16);color:#fff;}
.chip.active{color:#04122e;background:linear-gradient(180deg,var(--cyan),var(--brand));border-color:transparent;}
.count{position:relative;z-index:2;text-align:center;color:#aab6dc;font-size:13px;padding:16px 0 56px;margin:0;}

/* Listings */
main{padding:54px 0;}
.category{margin-bottom:38px;}
.category h2{font-size:19px;display:flex;align-items:center;gap:10px;margin:0 0 16px;}
.category h2 .ico{font-size:22px;}
.category h2 .n{color:var(--muted);font-weight:600;font-size:14px;}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;}
.card{background:#fff;border:1px solid var(--bg-line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(79,128,255,.4);}
.card .town{font-size:11.5px;letter-spacing:.05em;color:var(--brand);text-transform:uppercase;font-weight:700;}
.card h3{margin:5px 0 7px;font-size:18px;}
.card h3 a{color:var(--ink);} .card h3 a:hover{color:var(--brand);}
.card p{margin:0 0 16px;color:var(--muted);font-size:14.5px;}
.card .visit{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:700;color:var(--brand);}
.card .visit:hover{gap:9px;}
.card-ph{background:transparent;border:2px dashed var(--bg-line);box-shadow:none;opacity:.7;}
.card-ph:hover{transform:none;box-shadow:none;border-color:var(--brand);opacity:1;}
.card-ph h3{color:var(--muted);}
.card-ph p{color:var(--muted);}
.empty{text-align:center;color:var(--muted);padding:50px 0;}

/* Join CTA */
.join{margin:20px 0 0;background:radial-gradient(700px 360px at 50% 120%,rgba(34,211,238,.18),transparent 60%),var(--grad);
  border-radius:24px;padding:48px 32px;text-align:center;color:#fff;}
.join h2{color:#fff;font-size:28px;}
.join p{color:rgba(255,255,255,.92);max-width:560px;margin:0 auto 22px;font-size:17px;}
.join .how{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;margin-top:26px;color:rgba(255,255,255,.9);font-size:14px;}
.join .how b{color:#fff;}

/* Footer */
.site-footer{background:var(--cosmic);color:#aab6dc;padding:40px 0;text-align:center;font-size:14.5px;border-top:1px solid rgba(255,255,255,.08);}
.site-footer a{color:#fff;font-weight:700;}
.pww{display:inline-flex;align-items:center;gap:8px;}

@media (max-width:560px){
  .hero-inner{padding:48px 0 12px;}
  .join{padding:38px 22px;border-radius:18px;}
  .nav{height:62px;}
  .site-header .btn{padding:11px 18px;font-size:14px;}
  .cta-lg{display:none;}
  .cta-sm{display:inline;}
}
