/* OPOD · estética de expediente clasificado. Negro / amarillo / blanco. Sin rojo. */
:root {
  --bg: #000000;
  --op: #febe04;          /* color operativo */
  --fg: #ffffff;
  --line: rgba(255, 255, 255, .22);
  --line-soft: rgba(255, 255, 255, .10);
  --mono: 'IBM Plex Mono', 'Share Tech Mono', 'Courier Prime', 'Space Mono', monospace;
  --head: 'Teko', 'Bebas Neue', 'Oswald', 'Anton', sans-serif;
  --nav-h: 60px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--mono);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  padding-bottom: calc(var(--nav-h) + env(safe-area-inset-bottom));
}
body.is-bare { padding-bottom: 0; }

.screen { max-width: 720px; margin: 0 auto; padding: 18px 16px 28px; }

a { color: var(--op); text-decoration: none; }
strong { color: var(--op); }
.muted { color: rgba(255,255,255,.6); }
.small { font-size: 13px; }
.center { text-align: center; }

/* ── Cabeceras / títulos ───────────────────────────────────────────────── */
.op-head { text-align: center; margin: 8px 0 22px; }
.op-head.compact { margin: 4px 0 16px; }
.op-kicker { font-family: var(--mono); font-weight: 500; letter-spacing: .22em; font-size: 11px; color: rgba(255,255,255,.65); text-transform: uppercase; }
.op-line { font-family: var(--head); font-weight: 600; letter-spacing: .3em; color: var(--op); margin-top: 12px; font-size: 18px; line-height: 1; }
.op-title { font-family: var(--head); font-weight: 700; letter-spacing: .04em; font-size: clamp(2rem, 10.5vw, 54px); line-height: .9; margin: 0; overflow-wrap: break-word; }
.op-title.sm { font-size: clamp(1.6rem, 7vw, 34px); letter-spacing: .05em; }
.brand { font-family: var(--head); font-weight: 700; letter-spacing: .1em; font-size: 76px; line-height: .85; margin: 8px 0 0; color: var(--op); }
.subtitle { font-family: var(--mono); color: rgba(255,255,255,.65); font-size: 13px; margin: 6px 0 0; }

.logo { display: block; width: 210px; max-width: 62%; height: auto; margin: 18px auto 0; }
.logo.sm { width: 150px; }

/* ── Paneles tipo expediente ───────────────────────────────────────────── */
.panel {
  border: 1px solid var(--line);
  background: #000;
  padding: 16px;
  margin: 0 0 16px;
}
.panel-h { font-family: var(--head); font-weight: 600; letter-spacing: .06em; color: var(--op); margin: 0 0 10px; font-size: 22px; line-height: 1; }
.blk-h { font-family: var(--head); font-weight: 600; letter-spacing: .06em; color: var(--op); font-size: 19px; line-height: 1; margin: 16px 0 6px; }
.briefing p { margin: 0 0 10px; }

/* ── Pares clave/valor ─────────────────────────────────────────────────── */
.kv { margin: 0; display: grid; grid-template-columns: 1fr; gap: 2px 0; }
.kv dt { font-family: var(--mono); font-weight: 500; letter-spacing: .08em; color: rgba(255,255,255,.6); font-size: 11px; text-transform: uppercase; margin-top: 10px; }
.kv dd { margin: 0; }
.kv.tight dt { margin-top: 6px; }

/* ── Censura ───────────────────────────────────────────────────────────── */
.classified { color: var(--fg); letter-spacing: 0; word-break: break-all; }
.pre { white-space: pre-line; margin: 4px 0 0; }
/* Bloque ofuscado (introducción/objetivo del sujeto): barras de redacción blancas
   como el resto de censuras, ocupando varias líneas. El texto real nunca llega al
   cliente; lo que se sirve es relleno ("chupamelapijagil") con color transparente,
   por lo que en pantalla solo se ven las barras pero sigue en el DOM (inspeccionable). */
.pre.classified { line-height: 2; letter-spacing: 1px; word-break: break-all; user-select: none; }
.pre.classified span {
  color: transparent;
  background: var(--fg);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

/* ── Sellos / etiquetas ────────────────────────────────────────────────── */
.stamp {
  display: inline-block; font-family: var(--mono); font-weight: 600;
  letter-spacing: .08em; padding: 3px 8px; border: 1px solid var(--op);
  color: var(--op); font-size: 12px; text-transform: uppercase;
}
.stamp.big { font-size: 16px; padding: 8px 14px; }
.stamp.center { display: block; text-align: center; margin: 18px auto; max-width: 340px; }
.st-exito { background: var(--op); color: #000; border-color: var(--op); }
.st-fracaso { color: var(--op); border-color: var(--op); border-style: dashed; }
.st-pendiente { color: var(--fg); border-color: var(--line); }
.st-clasificada { color: var(--fg); border-color: var(--line); }

/* ── T-MINUS ───────────────────────────────────────────────────────────── */
.tminus { text-align: center; border: 1px solid var(--op); padding: 14px; margin: 16px 0 16px; }
.tminus-label { font-family: var(--mono); font-weight: 500; letter-spacing: .3em; color: rgba(255,255,255,.65); font-size: 12px; }
.tminus-clock { font-family: var(--mono); font-weight: 600; font-variant-numeric: tabular-nums; font-size: 26px; color: var(--op); margin-top: 6px; letter-spacing: .04em; }
.tminus-live { font-family: var(--head); font-weight: 700; letter-spacing: .08em; color: var(--op); font-size: 30px; line-height: 1; }
.tminus-tz { font-family: var(--mono); font-weight: 500; letter-spacing: .12em; color: rgba(255,255,255,.6); font-size: 11px; margin-top: 8px; }

/* ── Login ─────────────────────────────────────────────────────────────── */
.login { min-height: 88vh; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; }
.login-form { width: 100%; max-width: 320px; margin: 22px 0 0; }
.login-form label { display: block; font-family: var(--head); letter-spacing: .16em; font-size: 13px; color: rgba(255,255,255,.75); margin-bottom: 8px; }
input[type="password"], input[type="text"] {
  width: 100%; background: #000; border: 1px solid var(--line); color: var(--fg);
  font-family: var(--mono); font-size: 18px; padding: 12px; text-align: center; letter-spacing: .15em;
}
input:focus { outline: none; border-color: var(--op); }
.fineprint { color: rgba(255,255,255,.5); font-size: 12px; margin-top: 26px; }

/* ── Botones ───────────────────────────────────────────────────────────── */
button, .btn-link {
  font-family: var(--mono); font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  background: #000; color: var(--op); border: 1px solid var(--op);
  padding: 12px 16px; font-size: 14px; cursor: pointer; display: inline-block;
}
button:active { background: var(--op); color: #000; }
button:disabled { opacity: .3; cursor: not-allowed; }
button:disabled:active { background: #000; color: var(--op); }
.login-form button { width: 100%; margin-top: 16px; }
.btn-assume { width: 100%; margin-bottom: 8px; background: var(--op); color: #000; }
.btn-ghost { color: rgba(255,255,255,.7); border-color: var(--line); }
/* Colores semánticos SOLO en los controles de Mando (team, funcional). */
.btn-exito { color: #34c759; border-color: #34c759; }                 /* éxito: verde + ✓ */
.btn-exito:active { background: #34c759; color: #000; }
.btn-fracaso { color: #ff3b30; border-color: #ff3b30; border-style: dashed; }  /* fracaso: líneas discontinuas rojas + ✕ */
.btn-fracaso:active { background: #ff3b30; color: #000; }
.btn-danger {                                                         /* reset destructivo: gris */
  width: 100%; margin-top: 8px;
  color: rgba(255,255,255,.6); border-color: rgba(255,255,255,.3); letter-spacing: .14em;
}
.btn-danger:active { background: rgba(255,255,255,.6); color: #000; }
.cmd-actions { margin-top: 10px; }
.cmd-row { display: flex; gap: 8px; }
.cmd-row button { flex: 1; }
.logout-row, .center { text-align: center; }
.logout-row { margin-top: 20px; }

/* ── Flash (confirmaciones / avisos, arriba) ───────────────────────────── */
.flash {
  font-family: var(--mono); font-size: 13px; letter-spacing: .03em;
  padding: 12px 14px; margin: 0 0 16px; border: 1px solid var(--op);
}
.flash-ok    { color: #34c759; border-color: #34c759; }
.flash-error { color: #ff3b30; border-color: #ff3b30; border-style: dashed; }

/* ── Manifiesto de equipamiento ────────────────────────────────────────── */
.manifest { list-style: none; margin: 0; padding: 0; }
.manifest li { border-bottom: 1px solid var(--line-soft); }
.manifest label { display: flex; align-items: center; gap: 12px; padding: 12px 2px; cursor: pointer; }
.manifest input { width: 20px; height: 20px; accent-color: var(--op); flex: 0 0 auto; }
.manifest input:checked + span { color: rgba(255,255,255,.45); }
.microcopy { color: rgba(255,255,255,.6); font-size: 13px; border-left: 2px solid var(--op); padding-left: 12px; }

/* ── Tabs tipo carpeta ─────────────────────────────────────────────────── */
.folders { display: flex; gap: 4px; margin: 0 0 -1px; position: relative; z-index: 2; }
.folder {
  font-family: var(--mono); font-weight: 500; letter-spacing: .04em; font-size: 12px;
  padding: 11px 8px; border: 1px solid var(--line); border-bottom: none;
  background: #0a0a0a; color: rgba(255,255,255,.7); flex: 1; text-align: center;
}
.folder.on { background: #000; color: var(--op); border-color: var(--op); position: relative; top: 0; }
.folder-body { border-top-color: var(--op); }

/* ── Misiones (acordeón) ───────────────────────────────────────────────── */
.intro-blocks p { margin: 0 0 12px; color: rgba(255,255,255,.8); }
.mission { border: 1px solid var(--line); margin-bottom: 10px; }
.mission summary {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 12px; cursor: pointer; list-style: none;
}
.mission summary::-webkit-details-marker { display: none; }
.m-code { font-family: var(--mono); font-weight: 600; letter-spacing: .03em; font-size: 14px; color: var(--op); }
.m-body { padding: 0 12px 14px; border-top: 1px solid var(--line-soft); }

/* ── Mando ─────────────────────────────────────────────────────────────── */
.counts { margin: 0 0 6px; }
.cmd-card .m-code { margin-bottom: 6px; }

/* ── Informe ───────────────────────────────────────────────────────────── */
.timeline { list-style: none; margin: 0; padding: 0; }
.timeline li { border-left: 2px solid var(--op); padding: 8px 0 8px 12px; margin-bottom: 12px; }
.tl-when { color: rgba(255,255,255,.6); font-size: 13px; }
.tl-code { font-family: var(--mono); font-weight: 600; letter-spacing: .03em; margin: 2px 0; color: var(--op); }

/* ── Contrainteligencia ────────────────────────────────────────────────── */
.quiz { padding-left: 20px; }
.quiz-item { margin-bottom: 18px; border-bottom: 1px solid var(--line-soft); padding-bottom: 14px; }
.quiz-q { font-weight: 700; color: var(--fg); margin: 0 0 6px; }
.quiz-opts { list-style: none; padding: 0; margin: 0 0 8px; color: rgba(255,255,255,.8); }
.quiz-opts li { padding: 2px 0; }
.quiz-a { color: var(--op); margin: 0; }

/* ── Restringido ───────────────────────────────────────────────────────── */
.restringido { text-align: center; margin-top: 18vh; }

/* ── Navegación inferior sticky ────────────────────────────────────────── */
.botnav {
  position: fixed; left: 0; right: 0; bottom: 0; height: var(--nav-h);
  display: flex; background: #000; border-top: 1px solid var(--op);
  padding-bottom: env(safe-area-inset-bottom);
}
.botnav a {
  flex: 1; display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-weight: 500; letter-spacing: .04em; font-size: 11px;
  color: rgba(255,255,255,.7); border-right: 1px solid var(--line-soft);
}
.botnav a:last-child { border-right: none; }
.botnav a.on { color: var(--op); box-shadow: inset 0 3px 0 var(--op); }
.botnav .short { display: none; }
@media (max-width: 380px) {
  .botnav .full { display: none; }
  .botnav .short { display: inline; }
}
