:root{
  --bg:#0b1020; --panel:#ffffff; --text:#0f172a; --muted:#64748b;
  --accent:#22c55e; --accent2:#10b981; --border:#e5e7eb; --shadow:0 10px 30px rgba(2,8,23,.08)
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:linear-gradient(180deg,#0b1020,#0b1020 260px,#0f1a3a)}
.wrap{max-width:1100px;margin:0 auto;padding:0 14px}
header{position:sticky;top:0;color:#fff;padding:14px 0 18px;background:radial-gradient(900px 360px at 15% -10%,#1e3a8a,transparent),radial-gradient(700px 300px at 85% -30%,#10b981,transparent);z-index:50}
nav{display:flex;align-items:center;gap:14px}
.brand{font-weight:800;letter-spacing:.3px}
nav a{color:#e5e7eb;text-decoration:none;opacity:.9}
.grow{flex:1}
main{margin-top:10px}
.card{background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:14px;margin-bottom:14px}
.hero{color:#e2e8f0}
.hero .title{font-size:28px;margin:6px 0}
.toolbar{display:grid;grid-template-columns:1.1fr .5fr .5fr;gap:10px;align-items:end}
label small{display:block;color:var(--muted);font-size:12px;margin-bottom:4px}
input,select,button,textarea{font:inherit;border:1px solid var(--border);border-radius:10px;padding:10px}
button{background:#0f172a;color:#fff;cursor:pointer}
button.primary{background:linear-gradient(180deg,var(--accent),var(--accent2));color:#fff;border:none}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:#ecfdf5;color:#065f46;border:1px solid #bbf7d0;font-size:12px}
.note{font-size:12px;color:#64748b}
.map{height:440px;border-radius:14px;overflow:hidden}
.results{display:grid;gap:10px;margin-top:10px}
.item{background:#f8fafc;border:1px solid var(--border);border-left:4px solid #10b981;border-radius:10px;padding:12px}
.item h3{margin:0 0 4px 0}
.item .meta{color:#475569;font-size:13px}
.fav{float:right;background:#ef4444;border:none;border-radius:18px;padding:6px 10px;color:#fff;cursor:pointer}
.ads{margin-top:10px;border-top:1px dashed var(--border);padding-top:12px;text-align:center}
footer{color:#cbd5e1;padding:24px 0 40px}
.small{font-size:12px}
.age-gate{position:fixed;inset:0;background:rgba(15,23,42,.85);display:none;align-items:center;justify-content:center;z-index:100}
.age-card{background:#fff;max-width:420px;border-radius:16px;padding:20px;text-align:center}
@media(max-width: 900px){
  .toolbar{grid-template-columns:1fr}
}
