:root{
  --bg:#0b0d12; --panel:#141821; --line:#232a36; --txt:#eef2f7; --mut:#8b97a8;
  --rojo:#ff3b3b; --naranja:#ff9f0a; --verde:#2ecc71; --negro:#555c6b; --azul:#3a86ff;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%;background:var(--bg);color:var(--txt);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
body{display:flex;flex-direction:column;height:100dvh;overflow:hidden}

/* ---- Pantalla de entrada ---- */
.intro{position:fixed;inset:0;z-index:5000;background:radial-gradient(circle at 50% 0%,#161b26,#0b0d12);
  display:flex;align-items:center;justify-content:center;padding:22px;overflow-y:auto}
.intro.oculto{display:none}
.intro-box{width:100%;max-width:440px;text-align:center}
.intro-logo{font-size:54px;line-height:1}
.intro-box h1{margin:6px 0 2px;font-size:26px;background:linear-gradient(90deg,#ffd166,#ff3b3b);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.intro-sub{margin:0 0 8px;color:var(--mut);font-size:13px}
.intro-ctx{margin:0 0 20px;color:#aeb8c6;font-size:12.5px;line-height:1.5}
.intro-contacto{display:block;margin-top:12px;color:#7ef0ad;text-decoration:none;font-size:13px;
  background:#0c2b1d;border:1px solid #1e5a3c;border-radius:11px;padding:11px}
.intro-btn{display:block;width:100%;text-align:left;border:none;border-radius:14px;padding:16px 18px;
  margin-bottom:12px;color:#fff;font-size:18px;font-weight:800;line-height:1.2}
.intro-btn small{display:block;font-weight:500;font-size:12.5px;opacity:.92;margin-top:4px}
.intro-btn.rojo{background:linear-gradient(135deg,#ff3b3b,#c81e1e)}
.intro-btn.azul{background:linear-gradient(135deg,#3a86ff,#1f5fd1)}
.intro-btn.morado{background:linear-gradient(135deg,#a855f7,#7c3aed)}
.intro-btn.verde{background:linear-gradient(135deg,#2ecc71,#1ea65a);display:block;text-decoration:none}
.intro-btn.negro{background:#1c2330;border:1px solid var(--line)}
.intro-btn:active{transform:scale(.985)}
.intro-aviso{margin-top:14px;color:var(--mut);font-size:11.5px}

#topbar{display:flex;align-items:center;gap:10px;padding:9px 12px;background:#0e1117;border-bottom:1px solid var(--line)}
.home{background:#1c2330;border:1px solid var(--line);color:var(--txt);font-size:13px;font-weight:700;border-radius:9px;padding:7px 11px}
.sel-sector{width:100%;margin-top:10px;padding:12px;background:#1a1f29;border:1px solid var(--line);
  border-radius:10px;color:var(--txt);font-size:14px}
.brand{font-weight:800;font-size:16px;flex:1}
.brand span{background:linear-gradient(90deg,#ffd166,#ff3b3b);-webkit-background-clip:text;background-clip:text;color:transparent}
.stats{display:flex;gap:8px;font-size:13px;color:var(--mut)}
.stats b{color:var(--txt)} .stats .s-atr b{color:var(--rojo)}

#tabs{display:flex;background:#0e1117;border-bottom:1px solid var(--line)}
.tab{flex:1;padding:11px 4px;background:none;border:none;color:var(--mut);font-size:13.5px;font-weight:600}
.tab.active{color:var(--txt);box-shadow:inset 0 -3px 0 var(--rojo)}

main{position:relative;flex:1;overflow:hidden}
.panel{position:absolute;inset:0;display:none}
.panel.active{display:block}
#map{width:100%;height:100%;background:#1a1f29}
.buscador{position:absolute;top:10px;left:10px;right:10px;z-index:1100;display:none;gap:7px}
.buscador.on{display:flex}
.buscador input{flex:1;padding:11px 13px;background:rgba(20,24,33,.96);border:1px solid var(--line);
  border-radius:10px;color:var(--txt);font-size:14px;box-shadow:0 3px 12px rgba(0,0,0,.45)}
.buscador button{background:var(--azul);color:#fff;border:none;border-radius:10px;padding:0 15px;font-weight:700;font-size:13px;box-shadow:0 3px 12px rgba(0,0,0,.45)}
#lista,#emergencias{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px}
#lista.active,#emergencias.active{display:block}
.lista-head h2{margin:0 0 2px;font-size:18px}
.lista-head p{margin:0 0 14px;color:var(--mut);font-size:13px}
.busca-lista{width:100%;margin-bottom:10px;padding:12px;background:#1a1f29;border:1px solid var(--line);border-radius:10px;color:var(--txt);font-size:14px}

/* ---- tarjetas dashboard ---- */
.item{background:var(--panel);border:1px solid var(--line);border-left-width:5px;border-radius:12px;
  padding:12px 14px;margin-bottom:10px}
.item.t-atrapados{border-left-color:var(--rojo)}
.item.t-recurso{border-left-color:var(--naranja)}
.item.t-peligro{border-left-color:var(--negro)}
.item.t-albergue{border-left-color:var(--verde)}
.item.t-acopio{border-left-color:#a855f7}

/* filtros del dashboard */
.filtros{display:flex;gap:7px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:10px;margin-bottom:4px}
.filtro{white-space:nowrap;background:#1a1f29;border:1.5px solid var(--line);color:var(--mut);
  border-radius:20px;padding:7px 13px;font-size:12.5px;font-weight:600;flex:0 0 auto}
.filtro.sel{border-color:var(--azul);color:#fff;background:#15243a}
.it-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.it-zona{font-weight:700;font-size:15px}
.it-time{font-size:11px;color:var(--mut);white-space:nowrap}
.badge-of{font-size:10px;background:#2a2113;color:#ffd9a0;border:1px solid #5a4a1e;border-radius:8px;padding:1px 6px;font-weight:600;vertical-align:middle}
.it-pers{color:var(--rojo);font-weight:700;font-size:13px;margin:4px 0}
.it-needs{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.it-needs span{background:#1d2430;border:1px solid var(--line);border-radius:20px;padding:3px 9px;font-size:12px}
.it-nota{color:var(--mut);font-size:12.5px;margin-top:6px}
.it-meta{font-size:11.5px;color:#9cc4ff;margin-top:6px}
.it-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}
.it-conf{font-size:11.5px;color:var(--verde)}
.it-apoyos{color:#9cc4ff;margin-left:6px}
.it-acts{display:flex;gap:7px}
.mini-apoyo{background:#163a26;color:#7ef0ad;border:none;border-radius:9px;padding:8px 11px;font-size:12.5px;font-weight:700}
.mini-mapa{background:#15243a;color:#9cc4ff;border:none;border-radius:9px;padding:8px 11px;font-size:12.5px;font-weight:700}

/* ---- resumen / dashboard ---- */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:6px}
.tile{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px}
.tile b{display:block;font-size:26px;line-height:1.1}
.tile span{font-size:12px;color:var(--mut)}
.tile.t-r b{color:var(--rojo)}
.res-h{font-size:15px;margin:20px 0 10px}
.needs-rank{display:flex;flex-direction:column;gap:8px}
.need-row{display:flex;align-items:center;gap:10px}
.need-nom{flex:0 0 42%;font-size:13px}
.need-bar{flex:1;height:10px;background:#1a1f29;border-radius:6px;overflow:hidden}
.need-bar i{display:block;height:100%;background:linear-gradient(90deg,#ff9f0a,#ff3b3b);border-radius:6px}
.need-num{flex:0 0 auto;font-weight:800;font-size:14px;min-width:24px;text-align:right}
.zonas{display:flex;flex-direction:column;gap:9px}
.zona-card{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--rojo);border-radius:11px;padding:11px 13px}
.zona-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;flex-wrap:wrap}
.zona-top b{font-size:14px}
.zona-top span{font-size:12px;color:var(--mut)}
.zona-needs{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px}
.zona-needs span{background:#1d2430;border:1px solid var(--line);border-radius:18px;padding:2px 8px;font-size:11.5px}
.res-tip{font-size:12.5px;color:var(--mut);background:#161b26;border:1px solid var(--line);border-radius:11px;padding:11px;margin-top:18px}
.res-link{display:block;text-align:center;background:#15243a;border:1px solid var(--azul);color:#cfe0ff;
  text-decoration:none;font-weight:700;font-size:13.5px;padding:12px;border-radius:11px;margin-bottom:14px}

/* ---- directorio emergencias ---- */
.dir-grupo{font-size:12px;color:var(--mut);font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin:16px 0 7px}
.dir-item{display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--panel);
  border:1px solid var(--line);border-radius:11px;padding:13px 14px;margin-bottom:8px;text-decoration:none;color:var(--txt)}
.dir-item:active{background:#1c2330}
.dir-item span:first-child{font-size:14px;font-weight:600}
.dir-tel{color:#7ef0ad;font-size:13px;font-weight:700;white-space:nowrap}

.fab{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:1200;background:var(--rojo);color:#fff;
  border:none;font-size:16px;font-weight:800;padding:14px 26px;border-radius:40px;box-shadow:0 6px 24px rgba(255,59,59,.45)}
.fab:active{transform:translateX(-50%) scale(.97)}

/* ---- modal ---- */
.modal-bg{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.6);display:none;align-items:flex-end;justify-content:center}
.modal-bg:not([hidden]){display:flex}
.modal{background:var(--panel);width:100%;max-width:520px;max-height:92dvh;overflow-y:auto;border-radius:18px 18px 0 0;padding:16px 16px 28px;border:1px solid var(--line)}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.modal-head h2{margin:0;font-size:18px}
.x{background:#1c2330;border:1px solid var(--line);color:var(--txt);font-size:14px;font-weight:700;line-height:1;padding:9px 13px;border-radius:9px}
.lbl{display:block;font-size:13px;color:var(--mut);margin:14px 0 7px;font-weight:600}
.tipos{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.tipo{padding:11px 8px;background:#1a1f29;border:1.5px solid var(--line);border-radius:10px;color:var(--txt);font-size:13px;font-weight:600;text-align:left}
.tipo.sel{border-color:var(--rojo);background:#2a161a}
.ubic{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.btn-sec{background:#1a2233;border:1px solid var(--azul);color:#cfe0ff;border-radius:10px;padding:11px 14px;font-size:13px;font-weight:700;flex:1;min-width:140px}
.ubic-txt{font-size:12.5px;color:var(--mut);margin-top:8px}
.ubic-txt.ok{color:var(--verde);font-size:14px}
input{width:100%;padding:12px;background:#1a1f29;border:1px solid var(--line);border-radius:10px;color:var(--txt);font-size:15px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:9px 12px;background:#1a1f29;border:1.5px solid var(--line);border-radius:22px;color:var(--txt);font-size:13px}
.chip.sel{border-color:var(--naranja);background:#2a2113;color:#ffd9a0}
.btn-enviar{width:100%;margin-top:18px;padding:15px;background:var(--rojo);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:800}
.btn-enviar:disabled{opacity:.5}
.aviso{font-size:12px;color:var(--mut);text-align:center;margin:12px 0 0}

.toast{position:fixed;left:50%;bottom:84px;transform:translateX(-50%);z-index:3000;background:#1d2430;border:1px solid var(--line);
  color:var(--txt);padding:12px 18px;border-radius:12px;font-size:14px;max-width:90%;text-align:center;box-shadow:0 6px 20px rgba(0,0,0,.4)}

/* ---- ESCRITORIO: el formulario va a un panel lateral y el mapa queda visible ---- */
@media(min-width:760px){
  #tabs .tab{font-size:15px;padding:13px}
  .fab{left:auto;right:26px;bottom:26px;transform:none}
  .fab:active{transform:scale(.97)}
  .modal-bg{justify-content:flex-end;align-items:stretch;background:rgba(0,0,0,.22)}
  .modal{width:440px;max-width:440px;height:100dvh;max-height:100dvh;border-radius:0;border-left:1px solid var(--line);
    box-shadow:-10px 0 40px rgba(0,0,0,.5)}
  .intro-box{max-width:560px}
  .intro-btn{font-size:19px}
}
@media(min-width:1100px){
  body{max-width:none}
}

/* ---- popups ---- */
.leaflet-popup-content-wrapper{background:var(--panel);color:var(--txt);border-radius:12px}
.leaflet-popup-tip{background:var(--panel)}
.leaflet-popup-content{margin:12px 14px;font-size:13.5px;line-height:1.45}
.pop-zona{font-weight:700;font-size:15px;margin-bottom:4px}
.sello-of{font-size:11px;color:#ffd9a0;background:#2a2113;border:1px solid #5a4a1e;border-radius:8px;padding:5px 8px;margin-bottom:6px}
.pop-pers{color:var(--rojo);font-weight:700}
.pop-apoyos{color:#9cc4ff;font-size:12.5px;margin-top:4px;font-weight:600}
.pop-needs{display:flex;flex-wrap:wrap;gap:5px;margin:7px 0}
.pop-needs span{background:#1d2430;border:1px solid var(--line);border-radius:18px;padding:2px 8px;font-size:11.5px}
.pop-actions{display:flex;gap:6px;margin-top:9px;flex-wrap:wrap}
.pop-actions button{flex:1;min-width:78px;padding:9px 6px;border:none;border-radius:9px;font-size:12px;font-weight:700}
.pa-apoyo{background:#163a26;color:#7ef0ad;flex-basis:100%!important}
.pa-conf{background:#1d2c1f;color:#a9e7c1}
.pa-res{background:#15243a;color:#9cc4ff}
.pa-flag{background:#2a1a1a;color:#ff9a9a;flex:0 0 auto;min-width:auto;padding:9px 11px}
.pop-wa{display:block;margin-top:8px;background:#0c3d24;color:#7ef0ad;text-align:center;padding:9px;border-radius:9px;text-decoration:none;font-weight:700;font-size:13px}
