/* ══════════════════════════════════════════
   oXben Disaster – Neon Green Dark Theme
   ══════════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#080810;
  --bg2:#0e0e1a;
  --bg3:#141422;
  --bg4:#1a1a2e;
  --accent:#39ff14;
  --accent-dim:#39ff1466;
  --accent-glow:0 0 12px #39ff1444,0 0 40px #39ff1418;
  --danger:#ff4444;
  --fire:#ff8c00;
  --storm:#00d4ff;
  --volcano:#ff44ff;
  --flood:#4488ff;
  --other:#ffcc00;
  --text:#e0e8e0;
  --text-dim:#7a8a7a;
  --text-muted:#4a5a4a;
  --border:#1e2e1e;
  --border-bright:#2a3e2a;
  --radius:10px;
  --font:-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

html,body{
  width:100%;height:100%;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  line-height:1.5;
}

a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--accent-dim);border-radius:3px}

/* ── App Wrapper ── */
.app-wrapper{
  max-width:1100px;
  margin:0 auto;
  padding:0 20px 30px;
}

/* ── Sidebar Ads ── */
.ad-sidebar{
  position:fixed;top:50%;transform:translateY(-50%);
  width:160px;height:600px;z-index:50;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg2);border:1px dashed var(--border);
  font-size:10px;color:var(--text-muted);border-radius:var(--radius);
}
.ad-sidebar-left{left:10px}
.ad-sidebar-right{right:10px}
@media(max-width:1440px){.ad-sidebar{display:none}}

/* ── Ad Slots ── */
.ad-center,.ad-bottom-full{
  margin:20px auto;padding:10px;
  background:var(--bg2);border:1px dashed var(--border);
  border-radius:var(--radius);text-align:center;
  font-size:10px;color:var(--text-muted);
}

/* ── Header ── */
.site-header{
  padding:18px 0 14px;
  border-bottom:1px solid var(--border);
  margin-bottom:16px;
}
.header-inner{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
}
.header-logo{
  display:flex;align-items:center;gap:8px;
  font-size:1.3em;font-weight:700;
  color:var(--text);text-decoration:none;
}
.header-logo svg{flex-shrink:0}
.brand-accent{color:var(--accent);text-shadow:var(--accent-glow)}
.header-tagline{
  font-size:.78em;color:var(--text-dim);
  letter-spacing:1px;text-transform:uppercase;
}
.header-home{
  margin-left:auto;font-size:.75em;
  color:var(--text-muted);opacity:.7;
}
.header-home:hover{color:var(--accent);opacity:1}

/* ── Stats Bar ── */
.stats-bar{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:10px;
  margin-bottom:16px;
}
.stat-card{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:12px 8px;
  text-align:center;
  transition:border-color .2s;
}
.stat-card:hover{border-color:var(--accent)}
.stat-value{
  display:block;
  font-size:1.6em;font-weight:700;
  color:var(--accent);
  text-shadow:0 0 8px #39ff1433;
}
.stat-label{
  display:block;
  font-size:.7em;
  color:var(--text-dim);
  text-transform:uppercase;
  letter-spacing:.5px;
  margin-top:2px;
}

/* ── Filter Bar ── */
.filter-bar{
  display:flex;align-items:center;gap:8px;
  flex-wrap:wrap;
  margin-bottom:16px;
  padding:10px 14px;
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
}
.filter-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:7px 14px;
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:20px;
  color:var(--text-dim);
  font-size:.8em;font-weight:500;
  cursor:pointer;
  transition:all .2s;
}
.filter-btn:hover{border-color:var(--accent);color:var(--text)}
.filter-btn.active{
  background:var(--accent);
  color:#080810;
  border-color:var(--accent);
  font-weight:700;
  box-shadow:0 0 12px #39ff1444;
}
.filter-icon{font-size:1em}
.filter-search{margin-left:auto}
.filter-search input{
  padding:7px 14px;
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:20px;
  color:var(--text);
  font-size:.8em;
  outline:none;
  width:180px;
  transition:border-color .2s;
}
.filter-search input:focus{border-color:var(--accent)}
.filter-search input::placeholder{color:var(--text-muted)}

/* ── Main Content ── */
.main-content{
  display:grid;
  grid-template-columns:1fr 340px;
  gap:16px;
  margin-bottom:16px;
}

/* ── Map ── */
.map-container{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border);
  min-height:500px;
}
#map{width:100%;height:100%;min-height:500px;background:var(--bg2)}

/* dark tiles - native dark from CARTO */
.leaflet-control-zoom a{
  background:var(--bg3)!important;
  color:var(--accent)!important;
  border-color:var(--border)!important;
}
.leaflet-control-attribution{
  background:rgba(8,8,16,.8)!important;
  color:var(--text-muted)!important;
  font-size:9px!important;
}
.leaflet-control-attribution a{color:var(--text-dim)!important}
.leaflet-popup-content-wrapper{
  background:var(--bg3)!important;
  color:var(--text)!important;
  border:1px solid var(--border)!important;
  border-radius:8px!important;
  box-shadow:0 4px 20px rgba(0,0,0,.5)!important;
}
.leaflet-popup-tip{background:var(--bg3)!important}
.leaflet-popup-close-button{color:var(--text-dim)!important}

.map-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:rgba(8,8,16,.85);
  z-index:500;
  transition:opacity .4s;
}
.map-overlay.hidden{opacity:0;pointer-events:none}
.map-overlay p{color:var(--text-dim);margin-top:12px;font-size:.85em}

/* Spinner */
.spinner{
  width:36px;height:36px;
  border:3px solid var(--border);
  border-top-color:var(--accent);
  border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Event Panel ── */
.event-panel{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  display:flex;flex-direction:column;
  max-height:540px;
}
.panel-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;
  border-bottom:1px solid var(--border);
}
.panel-header h2{font-size:.95em;color:var(--text);font-weight:600}
.event-count{
  background:var(--accent);
  color:#080810;
  font-size:.7em;font-weight:700;
  padding:2px 10px;
  border-radius:12px;
}
.event-list{
  overflow-y:auto;
  flex:1;
  padding:6px;
}

/* Event Card */
.event-card{
  display:flex;gap:10px;align-items:flex-start;
  padding:10px 12px;
  border-radius:8px;
  cursor:pointer;
  transition:background .15s;
  border-bottom:1px solid var(--border);
}
.event-card:last-child{border-bottom:none}
.event-card:hover{background:var(--bg3)}
.event-dot{
  width:10px;height:10px;min-width:10px;
  border-radius:50%;
  margin-top:5px;
}
.event-dot.earthquake{background:var(--danger);box-shadow:0 0 6px var(--danger)}
.event-dot.wildfire{background:var(--fire);box-shadow:0 0 6px var(--fire)}
.event-dot.storm{background:var(--storm);box-shadow:0 0 6px var(--storm)}
.event-dot.volcano{background:var(--volcano);box-shadow:0 0 6px var(--volcano)}
.event-dot.flood{background:var(--flood);box-shadow:0 0 6px var(--flood)}
.event-dot.other{background:var(--other);box-shadow:0 0 6px var(--other)}
.event-info{flex:1;min-width:0}
.event-title{
  font-size:.8em;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.event-meta{
  font-size:.68em;color:var(--text-dim);margin-top:2px;
  display:flex;gap:8px;flex-wrap:wrap;
}
.event-badge{
  display:inline-block;
  padding:1px 7px;
  border-radius:8px;
  font-size:.65em;font-weight:600;
  text-transform:uppercase;
  letter-spacing:.3px;
}
.event-badge.earthquake{background:#ff444433;color:#ff6666}
.event-badge.wildfire{background:#ff8c0033;color:#ffaa44}
.event-badge.storm{background:#00d4ff33;color:#44ddff}
.event-badge.volcano{background:#ff44ff33;color:#ff77ff}
.event-badge.flood{background:#4488ff33;color:#6699ff}
.event-badge.other{background:#ffcc0033;color:#ffdd44}

.event-card.major .event-title{color:var(--danger)}

/* No results */
.no-results{
  text-align:center;padding:40px 20px;
  color:var(--text-muted);font-size:.85em;
}

/* ── FAQ ── */
.faq-section{margin:30px 0}
.faq-section h2{
  text-align:center;font-size:1.4em;
  color:var(--accent);margin-bottom:20px;
}
.faq-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
}
.faq-item{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px 18px;
  transition:border-color .2s;
}
.faq-item[open]{border-color:var(--accent-dim)}
.faq-item summary{
  font-weight:600;font-size:.88em;
  cursor:pointer;color:var(--text);
  list-style:none;
  display:flex;align-items:center;gap:8px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{
  content:'▸';color:var(--accent);transition:transform .2s;
}
.faq-item[open] summary::before{transform:rotate(90deg)}
.faq-item p{
  margin-top:10px;font-size:.82em;
  color:var(--text-dim);line-height:1.6;
}

/* ── Footer ── */
.site-footer{
  text-align:center;
  padding:20px;
  border-top:1px solid var(--border);
  color:var(--text-muted);
  font-size:.75em;
}
.site-footer a{color:var(--text-dim)}
.site-footer a:hover{color:var(--accent)}

/* ══════════════════
   Responsive
   ══════════════════ */

@media(max-width:900px){
  .stats-bar{grid-template-columns:repeat(3,1fr)}
  .main-content{grid-template-columns:1fr}
  .event-panel{max-height:350px}
  .faq-grid{grid-template-columns:1fr}
  .map-container{min-height:400px}
  #map{min-height:400px}
}

@media(max-width:640px){
  .app-wrapper{padding:0 10px 20px}
  .header-inner{gap:8px}
  .header-logo{font-size:1.1em}
  .header-tagline{display:none}
  .stats-bar{grid-template-columns:repeat(3,1fr);gap:6px}
  .stat-value{font-size:1.2em}
  .stat-label{font-size:.6em}
  .filter-bar{gap:5px;padding:8px 10px}
  .filter-btn{padding:5px 10px;font-size:.72em}
  .filter-search{width:100%;margin-left:0;margin-top:4px}
  .filter-search input{width:100%}
  .map-container{min-height:300px}
  #map{min-height:300px}
  .event-panel{max-height:280px}
  .faq-section h2{font-size:1.1em}
}

@media(max-width:380px){
  .stats-bar{grid-template-columns:repeat(2,1fr)}
  .stat-card{padding:8px 4px}
}

/* ── Pulse animation for live dot ── */
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.6;transform:scale(1.3)}
}
.live-pulse{animation:pulse 2s ease-in-out infinite}
