* { box-sizing: border-box; }
body {
  margin: 0; background: #10141a; color: #e8e8e8;
  font-family: -apple-system, "Segoe UI", Roboto, sans-serif;
  display: flex; flex-direction: column; min-height: 100vh;
}
header { padding: 10px 16px 4px; display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
h1 { font-size: 1.15rem; margin: 0; }
#actualizado { margin: 0; color: #8a95a5; font-size: .8rem; }

#bloques {
  display: grid; grid-template-columns: repeat(8, 1fr);
  gap: 6px; padding: 8px 16px;
}
@media (max-width: 640px) { #bloques { grid-template-columns: repeat(4, 1fr); } }

.bloque {
  border-radius: 8px; padding: 8px 6px; text-align: center;
  background: #1b222c; border-top: 4px solid #555;
}
.bloque .n { font-weight: 700; font-size: 1.05rem; }
.bloque .estado { font-size: .72rem; display: block; margin-top: 2px; }
.bloque .detalle { font-size: .66rem; color: #8a95a5; display: block; margin-top: 2px; }
.bloque.afectado { border-top-color: #e5484d; }
.bloque.afectado .estado { color: #ff8a8e; }
.bloque.restablecido { border-top-color: #46a758; }
.bloque.restablecido .estado { color: #7fd08c; }
.bloque.desconocido { border-top-color: #555; }
.bloque.desconocido .estado { color: #8a95a5; }

#mapa { flex: 1; min-height: 420px; background: #dfe8ef; }
.leaflet-container { background: #dfe8ef; }

footer { padding: 8px 16px; font-size: .7rem; color: #66707e; }
footer a { color: #8ab4f8; }

.popup h3 { margin: 0 0 4px; font-size: .95rem; }
.popup ul { margin: 4px 0 0; padding-left: 16px; max-height: 220px; overflow-y: auto; }
.popup li { margin-bottom: 5px; font-size: .78rem; }
.popup .hora { color: #666; }
.popup .rep { font-size: .75rem; color: #b06060; margin: 2px 0 0; }
.leaflet-popup-content-wrapper { background: #f5f5f5; color: #222; }

.leyenda {
  background: rgba(16, 20, 26, .85); color: #8a95a5;
  padding: 6px 10px; border-radius: 6px; font-size: .7rem; max-width: 230px;
}

#buscador { position: relative; flex: 1; min-width: 220px; max-width: 380px; margin-left: auto; }
#busqueda {
  width: 100%; padding: 6px 10px; border-radius: 8px; border: 1px solid #37414f;
  background: #1b222c; color: #e8e8e8; font-size: .85rem;
}
#resultados {
  position: absolute; top: 34px; left: 0; right: 0; z-index: 2000;
  background: #1b222c; border: 1px solid #37414f; border-radius: 8px;
  max-height: 260px; overflow-y: auto;
}
#resultados div { padding: 7px 10px; font-size: .82rem; cursor: pointer; }
#resultados div:hover { background: #26303d; }
#resultados .muni { color: #8a95a5; font-size: .72rem; }

.btn-reporte {
  display: inline-block; margin-top: 6px; padding: 6px 10px; border-radius: 6px;
  background: #e5484d; color: #fff; border: 0; cursor: pointer; font-size: .8rem;
}
.btn-reporte:disabled { background: #888; }
