/* ──────────────────────────────────────────────────────────────────────
   agora-app · pulso.css
   "Pulso de Zona": overlay full-screen (mobile) / modal centrado
   (desktop) que lista qué barrios están vivos en las últimas 72h.

   Paleta heredada de style.css — fija al spec del proyecto:
     #0a0a0a  fondo principal
     #141414  superficie panel
     #e0e0e0  texto
     #c9a86a  ocre (acento)
     #6a9c5e  verde (positivo)
     #c9904a  ámbar (alerta)
   ────────────────────────────────────────────────────────────────────── */

/* ══════════════════════════════════════════════════════════════════════
   OVERLAY + PANEL
   ══════════════════════════════════════════════════════════════════════ */
.pulso-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(10, 10, 10, 0.96);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  /* Permite scroll si el contenido excede la altura */
  overflow-y: auto;
}

.pulso-panel {
  position: relative;
  width: 100%;
  max-width: 540px;
  background: #141414;
  border: 1px solid #222;
  border-radius: 8px;
  padding: 1.5rem;
  color: #e0e0e0;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6);
  /* Tipo base. Las cifras usarán monospace dentro. */
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 15px;
  line-height: 1.45;
}

.pulso-close {
  position: absolute;
  top: 0.7rem;
  right: 0.8rem;
  background: transparent;
  border: 1px solid #2a2a2a;
  color: #aaa;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  font-size: 1.2rem;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.pulso-close:hover {
  color: #c9a86a;
  border-color: #c9a86a;
  background: rgba(201, 168, 106, 0.06);
}

.pulso-content {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}

/* ══════════════════════════════════════════════════════════════════════
   CABECERA
   ══════════════════════════════════════════════════════════════════════ */
.pulso-head {
  border-bottom: 1px solid #222;
  padding-bottom: 0.8rem;
  padding-right: 2.5rem; /* deja sitio al botón × */
}

.pulso-title {
  margin: 0 0 0.3rem;
  font-size: 1.15rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #c9a86a;
}
.pulso-title-sub {
  color: #888;
  font-size: 0.8rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  font-family: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}

.pulso-summary {
  margin: 0;
  font-size: 0.88rem;
  color: #aaa;
}

/* Números — siempre monospace para alineación visual y carácter "dato". */
.pulso-num {
  font-family: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  color: #e0e0e0;
  font-weight: 500;
}

.pulso-empty {
  margin: 0;
  font-size: 0.88rem;
  color: #888;
  font-style: italic;
  text-align: center;
  padding: 1rem 0.5rem;
  border: 1px dashed #2a2a2a;
  border-radius: 4px;
}

/* ══════════════════════════════════════════════════════════════════════
   TU ZONA — bloque con acento visual fuerte (borde izquierdo ocre)
   ══════════════════════════════════════════════════════════════════════ */
.pulso-tuzona {
  border-left: 3px solid #c9a86a;
  padding: 0.7rem 1rem;
  background: rgba(201, 168, 106, 0.04);
  border-radius: 0 4px 4px 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.pulso-tuzona-label {
  margin: 0;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #c9a86a;
  font-weight: 500;
}

.pulso-tuzona-nombre {
  margin: 0;
  font-size: 1.05rem;
  color: #e0e0e0;
  font-weight: 500;
}

.pulso-tuzona-meta {
  margin: 0;
  font-size: 0.82rem;
  color: #aaa;
  font-family: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}
.pulso-tuzona-meta .pulso-rel { color: #888; }

.pulso-tuzona-invita {
  margin: 0;
  font-size: 0.85rem;
  color: #c9904a;
  font-style: italic;
}

/* ══════════════════════════════════════════════════════════════════════
   SECCIONES + LISTAS
   ══════════════════════════════════════════════════════════════════════ */
.pulso-seccion {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.pulso-subtitulo {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #aaa;
}
.pulso-subtitulo--dim { color: #555; }

.pulso-lista {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

/* ── Fila activa (con barra proporcional) ─────────────────────────── */
.pulso-fila {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.5rem 0.7rem;
  border-radius: 4px;
  cursor: pointer;
  transition: background 0.15s;
  /* La barra vive en una capa de fondo (z-index 0); el texto encima (z-index 1). */
}
.pulso-fila:hover,
.pulso-fila:focus-visible {
  background: rgba(255, 255, 255, 0.04);
  outline: none;
}
.pulso-fila:focus-visible {
  box-shadow: inset 0 0 0 1px #c9a86a;
}

.pulso-fila--activa {
  /* En las activas el grid es: [barra-overlay | nombre | meta | flecha] */
  grid-template-columns: 1fr auto 1rem;
}

/* Wrapper de la barra: ocupa toda la fila como fondo. */
.pulso-barra-wrap {
  position: absolute;
  inset: 0;
  border-radius: 4px;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
  background: transparent;
}
.pulso-barra {
  display: block;
  height: 100%;
  background: rgba(201, 168, 106, 0.18);
  border-right: 1px solid rgba(201, 168, 106, 0.4);
  transition: width 0.3s ease;
}

/* Texto siempre encima de la barra. */
.pulso-fila-nombre,
.pulso-fila-meta,
.pulso-fila-flecha,
.pulso-fila-punto {
  position: relative;
  z-index: 1;
}

.pulso-fila-nombre {
  color: #e0e0e0;
  font-size: 0.92rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pulso-fila-meta {
  font-family: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 0.75rem;
  color: #aaa;
  white-space: nowrap;
}

.pulso-fila-flecha {
  color: #c9a86a;
  font-size: 0.8rem;
  text-align: right;
  opacity: 0.6;
  transition: opacity 0.15s, transform 0.15s;
}
.pulso-fila:hover .pulso-fila-flecha {
  opacity: 1;
  transform: translateX(2px);
}

/* ── Fila silenciosa (gris, sin barra, con botón [activa]) ────────── */
.pulso-fila--silenciosa {
  grid-template-columns: auto 1fr auto;
  cursor: default;
  padding: 0.4rem 0.7rem;
}
.pulso-fila--silenciosa:hover {
  background: transparent;
}
.pulso-fila-punto {
  color: #555;
  font-size: 1rem;
  width: 0.6rem;
}
.pulso-fila--silenciosa .pulso-fila-nombre {
  color: #888;
  font-size: 0.88rem;
}

/* ══════════════════════════════════════════════════════════════════════
   BOTONES
   ══════════════════════════════════════════════════════════════════════ */
.pulso-btn {
  background: transparent;
  border: 1px solid #c9a86a;
  color: #c9a86a;
  font-family: inherit;
  font-size: 0.78rem;
  padding: 0.35em 0.85em;
  border-radius: 3px;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.pulso-btn:hover {
  background: #c9a86a;
  color: #0a0a0a;
}
.pulso-btn:focus-visible {
  outline: 2px solid rgba(201, 168, 106, 0.5);
  outline-offset: 2px;
}

.pulso-btn-mini {
  font-size: 0.7rem;
  padding: 0.2em 0.6em;
}

.pulso-btn-zona,
.pulso-btn-activar {
  align-self: flex-start;
  margin-top: 0.2rem;
}

/* ══════════════════════════════════════════════════════════════════════
   SIN-GEO — pie discreto, deliberadamente apartado del ranking
   ══════════════════════════════════════════════════════════════════════ */
.pulso-singeo {
  margin: 0;
  font-size: 0.78rem;
  color: #888;
  border-top: 1px solid #222;
  padding-top: 0.7rem;
}
.pulso-singeo-label {
  color: #555;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
}

/* ══════════════════════════════════════════════════════════════════════
   RESPONSIVE — mobile: full-screen sin padding del overlay
   ══════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
  .pulso-overlay {
    padding: 0;
    align-items: stretch;
    justify-content: stretch;
  }
  .pulso-panel {
    max-width: 100%;
    min-height: 100vh;
    border-radius: 0;
    border: none;
    padding: 1.2rem 1rem 2rem;
    box-shadow: none;
  }
  .pulso-close {
    top: 0.5rem;
    right: 0.5rem;
  }
  .pulso-head {
    padding-right: 3rem;
  }
}

/* Reduce motion — coherente con style.css */
@media (prefers-reduced-motion: reduce) {
  .pulso-barra,
  .pulso-fila-flecha,
  .pulso-close,
  .pulso-btn {
    transition: none;
  }
}
