/* SOS — Estilos de la PWA (offline-first, español)
   ================================================
   Diseño sobrio, alto contraste, legible en pantallas pequeñas y con poca luz.
   Sin dependencias externas: todo local desde 'self' (CSP estricta). */

:root {
  --rojo: #b91c1c;
  --rojo-osc: #7f1313;
  --fondo: #0b1220;
  --panel: #131c2e;
  --panel-2: #1b2740;
  --borde: #2a3a5c;
  --texto: #e8edf6;
  --texto-tenue: #9fb0cc;
  --verde: #16a34a;
  --ambar: #d97706;
  --gris: #64748b;
  --azul: #2563eb;
  --radio: 12px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--fondo);
  color: var(--texto);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.45;
  -webkit-text-size-adjust: 100%;
}

h1 { font-size: 1.35rem; margin: 0.2em 0 0.4em; }
h2 { font-size: 1.1rem; margin: 0 0 0.5em; }

/* ---- Barra superior ---- */
.barra {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 10px 14px;
  background: var(--rojo); color: #fff;
  position: sticky; top: 0; z-index: 1000;
  padding-top: calc(10px + env(safe-area-inset-top));
}
.marca { display: flex; align-items: baseline; gap: 10px; }
.logo { font-weight: 800; letter-spacing: 1px; font-size: 1.3rem; }
.lema { font-size: 0.85rem; opacity: 0.92; }

.estado { display: flex; align-items: center; gap: 7px; font-size: 0.82rem; }
.punto {
  width: 11px; height: 11px; border-radius: 50%;
  background: var(--gris); box-shadow: 0 0 0 2px rgba(255,255,255,0.25);
}
.estado.en-linea .punto { background: var(--verde); }
.estado.sin-linea .punto { background: var(--ambar); }

/* ---- Pestañas ---- */
.pestanas {
  display: flex; gap: 2px; background: var(--panel);
  border-bottom: 1px solid var(--borde);
  position: sticky; top: 52px; z-index: 900;
}
.pestana {
  flex: 1; padding: 12px 6px; background: transparent; color: var(--texto-tenue);
  border: none; border-bottom: 3px solid transparent;
  font-size: 0.92rem; cursor: pointer;
}
.pestana.activa { color: var(--texto); border-bottom-color: var(--rojo); font-weight: 600; }
.pestana:focus-visible { outline: 2px solid var(--azul); outline-offset: -2px; }

main { padding: 14px; max-width: 760px; margin: 0 auto; }
.vista { display: none; }
.vista.activa { display: block; }
.oculto { display: none !important; }

.ayuda { color: var(--texto-tenue); font-size: 0.9rem; margin: 0.3em 0 1em; }

/* ---- Botones de tipo de reporte ---- */
.tipos { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.tipo {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 18px 10px; background: var(--panel); color: var(--texto);
  border: 1px solid var(--borde); border-radius: var(--radio);
  cursor: pointer; text-align: center; min-height: 96px;
}
.tipo:hover { background: var(--panel-2); }
.tipo:focus-visible { outline: 2px solid var(--azul); }
.tipo.elegido { border-color: var(--rojo); box-shadow: 0 0 0 2px var(--rojo); }
.tipo .emoji { font-size: 1.8rem; }
.tipo .rotulo { font-size: 0.9rem; line-height: 1.2; }

/* ---- Formulario ---- */
form { margin-top: 16px; }
.campo { display: block; margin: 12px 0; }
.campo > span, .campo label > span { display: block; margin-bottom: 5px; font-size: 0.9rem; color: var(--texto-tenue); }
.campo.doble { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }

input[type=text], input[type=number], input[type=search],
textarea, select {
  width: 100%; padding: 11px 12px; font-size: 1rem;
  background: var(--panel); color: var(--texto);
  border: 1px solid var(--borde); border-radius: 10px;
}
textarea { resize: vertical; }
input:focus, textarea:focus, select:focus { outline: 2px solid var(--azul); border-color: var(--azul); }

.ubicacion {
  margin: 14px 0; padding: 12px; border: 1px solid var(--borde);
  border-radius: var(--radio); background: var(--panel);
}
.ubicacion legend { padding: 0 6px; color: var(--texto-tenue); font-size: 0.9rem; }
.ubic-fila { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ubic-texto { font-size: 0.88rem; color: var(--texto-tenue); }
.ubic-texto.ok { color: var(--verde); }
.check { display: flex; gap: 8px; align-items: flex-start; margin-top: 10px; font-size: 0.85rem; color: var(--texto-tenue); }
.check input { width: auto; margin-top: 3px; }

.acciones { display: flex; gap: 10px; margin-top: 16px; }
button.primario, button.secundario {
  padding: 12px 18px; font-size: 1rem; border-radius: 10px; cursor: pointer; border: none;
}
button.primario { background: var(--rojo); color: #fff; font-weight: 600; }
button.primario:hover { background: var(--rojo-osc); }
button.secundario { background: var(--panel-2); color: var(--texto); border: 1px solid var(--borde); }
button:disabled { opacity: 0.55; cursor: not-allowed; }

.aviso { margin-top: 12px; font-size: 0.92rem; min-height: 1.2em; }
.aviso.ok { color: var(--verde); }
.aviso.error { color: #f87171; }

/* ---- Mapa ---- */
.mapa { height: 60vh; min-height: 320px; border-radius: var(--radio); overflow: hidden; border: 1px solid var(--borde); }
.mapa-controles { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 10px; }
.mapa-controles select { width: auto; }
.conteo { color: var(--texto-tenue); font-size: 0.88rem; }
.nota-privacidad { color: var(--texto-tenue); font-size: 0.82rem; margin-top: 8px; }
/* Forzar legibilidad de controles Leaflet sobre fondo oscuro */
.leaflet-container { background: #0e1626; }

/* ---- Buscar / listas ---- */
.buscar-fila { display: flex; gap: 10px; }
.buscar-fila input { flex: 1; }
.resultados { list-style: none; padding: 0; margin: 14px 0; }
.resultados li {
  background: var(--panel); border: 1px solid var(--borde); border-radius: var(--radio);
  padding: 12px 14px; margin-bottom: 10px;
}
.res-titulo { font-weight: 600; }
.res-meta { color: var(--texto-tenue); font-size: 0.85rem; margin-top: 4px; }

/* Insignia de moderación del buscador (C-moderacion). */
.insignia-mod {
  display: inline-block; padding: 2px 9px; border-radius: 999px;
  font-size: 0.74rem; font-weight: 700; vertical-align: middle;
}
.insignia-mod.verificado { background: #0a2e1a; color: #4ade80; }
/* 'pendiente' = NO verificado: color de ADVERTENCIA (ámbar). */
.insignia-mod.pendiente { background: #3a2a08; color: #fbbf24; }

/* ---- Estados de la cola ---- */
.cola-acciones { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.insignia {
  display: inline-block; padding: 2px 9px; border-radius: 999px;
  font-size: 0.76rem; font-weight: 600; vertical-align: middle;
}
.insignia.encolado { background: #3a2a08; color: #fbbf24; }
.insignia.enviando { background: #0a2a3a; color: #38bdf8; }
.insignia.sellado  { background: #0a2e1a; color: #4ade80; }
.insignia.error    { background: #3a0a0a; color: #f87171; }
.identidad { word-break: break-all; font-family: ui-monospace, monospace; font-size: 0.74rem; }

@media (max-width: 420px) {
  .tipos { grid-template-columns: 1fr; }
  .lema { display: none; }
}
