/* ============================================================
   aspam — panel. Consola moderna: lienzo claro + riel oscuro.
   IBM Plex Sans (UI) · IBM Plex Mono (datos). Orden, jerarquía,
   un acento azure. Pensado como herramienta de operación seria.
   ============================================================ */

@font-face { font-family:'Plex Sans'; src:url('/assets/fonts/ibm-plex-sans-400.woff2') format('woff2'); font-weight:400; font-display:swap; }
@font-face { font-family:'Plex Sans'; src:url('/assets/fonts/ibm-plex-sans-500.woff2') format('woff2'); font-weight:500; font-display:swap; }
@font-face { font-family:'Plex Sans'; src:url('/assets/fonts/ibm-plex-sans-600.woff2') format('woff2'); font-weight:600; font-display:swap; }
@font-face { font-family:'Plex Mono'; src:url('/assets/fonts/ibm-plex-mono-400.woff2') format('woff2'); font-weight:400; font-display:swap; }
@font-face { font-family:'Plex Mono'; src:url('/assets/fonts/ibm-plex-mono-500.woff2') format('woff2'); font-weight:500; font-display:swap; }

:root{
  /* lienzo claro (contenido) */
  --bg:#f3f4f6; --surface:#ffffff; --surface-2:#f4f5f7; --surface-3:#eceef1;
  --line:#e5e8ec; --line-soft:#eef0f3;
  --fg:#12151c; --fg-soft:#4a5260; --muted:#878e9b;
  /* acento azure (vivo) */
  --accent:#2f6bf6; --accent-strong:#1e54da; --accent-soft:#e8f0ff; --accent-line:#c6dcff;
  /* riel oscuro (sidebar) */
  --rail:#0f1117; --rail-2:#171a22; --rail-3:#1f232d; --rail-line:#272b36;
  --rail-fg:#d3d8e0; --rail-soft:#9aa1b0; --rail-muted:#697086; --rail-accent:#7ea6ff;
  /* semánticos vivos / alegres */
  --ok:#10a85a; --ok-soft:#e2f7ec;
  --warn:#e08a08; --warn-soft:#fdf0d6;
  --bad:#ef4444; --bad-soft:#fde7e7;
  --quar:#8b5cf6; --quar-soft:#f0eaff;
  --info:#2f6bf6; --info-soft:#e8f0ff;
  --edge:#64748b; --edge-soft:#eef1f5;  /* cortado en el borde, antes del motor */
  /* acentos alegres extra (para detalles/iconos) */
  --pop-teal:#0fb5a8; --pop-violet:#8b5cf6; --pop-amber:#f59e0b; --pop-pink:#ec4899;
  --sans:'Plex Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'Plex Mono',ui-monospace,'SFMono-Regular',Menlo,monospace;
  --r:11px; --r-sm:8px; --r-xs:6px; --pill:999px;
  --shadow-sm:0 1px 2px rgba(15,17,23,.04);
  --shadow:0 1px 2px rgba(15,17,23,.05),0 4px 14px rgba(15,17,23,.05);
  --shadow-lg:0 12px 40px rgba(15,17,23,.16);
  --ring:0 0 0 3px var(--accent-soft);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--sans);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-strong);text-decoration:underline}
h1,h2,h3{margin:0;font-weight:600;letter-spacing:-.012em;color:var(--fg)}
code,.mono,.num{font-family:var(--mono);font-feature-settings:"ss01","zero"}

/* ---------- App shell ---------- */
.app{display:grid;grid-template-columns:252px 1fr;min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,#10131b,var(--rail));
  border-right:1px solid var(--rail-line);display:flex;flex-direction:column;padding:1rem .7rem .8rem;overflow-y:auto;color:var(--rail-fg)}
.brand{display:flex;align-items:center;gap:.6rem;padding:.3rem .55rem 1.1rem;font-size:1.22rem;font-weight:600;color:#fff;letter-spacing:-.02em}
.brand .dot{width:10px;height:10px;border-radius:3px;background:var(--rail-accent);flex:none;box-shadow:0 0 0 4px rgba(122,162,255,.16)}
.brand img{height:26px;width:auto}

/* Búsqueda global en el riel: manda a /queue?any= (atajo de teclado: /) */
.rail-search{margin:0 .25rem .35rem}
.rail-search input{width:100%;background:var(--rail-2);border:1px solid var(--rail-line);border-radius:var(--r-sm);
  color:var(--rail-fg);font:inherit;font-size:.8rem;padding:.42rem .6rem;transition:border-color .12s,background .12s}
.rail-search input::placeholder{color:var(--rail-muted)}
.rail-search input:focus{outline:none;border-color:var(--rail-accent);background:var(--rail-3)}

.nav-group{margin-top:.7rem}
.nav-group+.nav-group{margin-top:.9rem}
.nav-group-label{font-size:.64rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--rail-muted);padding:.2rem .65rem .4rem}
.nav-item{position:relative;display:flex;align-items:center;gap:.6rem;padding:.5rem .65rem;border-radius:var(--r-sm);
  color:var(--rail-soft);font-weight:500;font-size:.89rem;transition:background .12s,color .12s}
.nav-item:hover{background:var(--rail-2);color:#fff;text-decoration:none}
.nav-item.active{background:var(--rail-3);color:#fff}
.nav-item.active::before{content:"";position:absolute;left:-.7rem;top:.45rem;bottom:.45rem;width:3px;border-radius:0 3px 3px 0;background:var(--rail-accent)}
.nav-item .ic{width:6px;height:6px;border-radius:2px;background:currentColor;opacity:.35;flex:none;transition:opacity .12s}
.nav-item:hover .ic,.nav-item.active .ic{opacity:.9}
.nav-item.active .ic{background:var(--rail-accent);opacity:1}

.sidebar-foot{margin-top:auto;padding-top:.9rem;border-top:1px solid var(--rail-line)}
.user-chip{display:flex;flex-direction:column;padding:.3rem .65rem;gap:.1rem}
.user-chip .who{font-weight:600;font-size:.83rem;color:#eef1f6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-chip .role{font-size:.71rem;color:var(--rail-muted)}
.btn-logout{display:inline-block;margin-top:.5rem;font-size:.8rem;color:var(--rail-muted);padding:.1rem .65rem}
.btn-logout:hover{color:#ff8d8d;text-decoration:none}

/* ---------- Main ---------- */
.main{min-width:0;display:flex;flex-direction:column}
.content{padding:2rem 2.4rem 3rem;max-width:1200px;width:100%}
@keyframes fadeUp{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
.spin{display:inline-block;animation:aspam-spin 1.1s linear infinite}
@keyframes aspam-spin{to{transform:rotate(360deg)}}
.page-title{font-size:1.55rem;font-weight:600;margin-bottom:.2rem;letter-spacing:-.022em}
.page-title small,.page-sub{font-weight:400;color:var(--muted);font-size:.9rem;letter-spacing:0}
.page-sub{margin:0 0 1.4rem}
.foot{margin-top:auto;padding:1.1rem 2.4rem;color:var(--muted);font-size:.76rem;border-top:1px solid var(--line-soft)}

/* ---------- Flash ---------- */
.flash{background:var(--surface);border:1px solid var(--accent-line);border-left:3px solid var(--accent);
  color:var(--fg);padding:.7rem 1rem;border-radius:var(--r-sm);margin-bottom:1.3rem;font-size:.88rem;font-weight:500;box-shadow:var(--shadow-sm)}

/* ---------- Cards ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.25rem 1.35rem;box-shadow:var(--shadow-sm)}
.card+.card{margin-top:1.1rem}
.card h3{font-size:.95rem;margin-bottom:1rem;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:.5rem}
.card-narrow{max-width:25rem;margin:0 auto}
/* Tarjeta de SOLO LECTURA (.card.ro): look de panel con cabecera gris.
   Regla del panel: .card = edición · .card.ro / .panel = visualización. */
.card.ro{padding:.85rem;border-radius:var(--r-sm)}
.card.ro>h3{margin:-.85rem -.85rem .8rem;padding:.5rem .85rem;background:var(--surface-2);
  border-bottom:1px solid var(--line);font-size:.78rem;border-radius:var(--r-sm) var(--r-sm) 0 0}

/* ---------- Tablas ---------- */
.grid{width:100%;border-collapse:collapse;font-size:.875rem}
.grid thead th{text-align:left;font-size:.66rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;
  color:var(--muted);padding:.55rem .7rem;border-bottom:1px solid var(--line);white-space:nowrap;
  position:sticky;top:0;background:var(--bg);z-index:2}
.card .grid thead th,.panel .grid thead th{background:var(--surface)}
.grid tbody td{padding:.62rem .7rem;border-bottom:1px solid var(--line-soft);vertical-align:middle}
/* evita que un valor largo sin espacios (cabeceras, firmas DKIM) desborde la tarjeta */
.grid tbody td:not(.nowrap):not(.ellip){overflow-wrap:anywhere}
.grid tbody tr:last-child td{border-bottom:0}
.grid tbody tr{transition:background .1s}
.grid tbody tr:hover{background:var(--surface-2)}
.num{text-align:right;font-variant-numeric:tabular-nums}
.nowrap{white-space:nowrap}
.ellip{max-width:22rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* tabla compacta (buscador de colas): más densa, menos ancho */
.grid.dense{font-size:.8rem}
.grid.dense thead th{padding:.4rem .5rem;font-size:.62rem}
.grid.dense tbody td{padding:.38rem .5rem}
.grid.dense .ellip{max-width:13rem}
.grid.dense .badge{padding:.1rem .45rem;font-size:.68rem}
.grid.dense .actions{gap:.5rem}

/* ---------- Badges (suaves, con punto de color) ---------- */
.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.16rem .55rem;border-radius:var(--pill);
  font-size:.72rem;font-weight:600;line-height:1.4;white-space:nowrap;background:var(--surface-2);color:var(--fg-soft);border:1px solid var(--line)}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex:none}
.badge.ok{color:var(--ok);background:var(--ok-soft);border-color:transparent}
.badge.warn{color:var(--warn);background:var(--warn-soft);border-color:transparent}
.badge.bad{color:var(--bad);background:var(--bad-soft);border-color:transparent}
.badge.quar{color:var(--quar);background:var(--quar-soft);border-color:transparent}
.badge.info{color:var(--info);background:var(--info-soft);border-color:transparent}

/* ---------- Botones ---------- */
.btn,button,input[type=submit]{font-family:var(--sans);font-size:.87rem;font-weight:500;cursor:pointer;
  border:1px solid var(--line);background:var(--surface);color:var(--fg);padding:.5rem .9rem;border-radius:var(--r-sm);
  transition:background .12s,border-color .12s,box-shadow .12s,transform .04s}
.btn:hover,button:hover{background:var(--surface-2);border-color:#d2d6db}
.btn:active,button:active{transform:translateY(1px)}
.btn.ok,.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 2px rgba(47,104,234,.25)}
.btn.ok:hover,.btn.primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}
.btn.bad{background:var(--bad);border-color:var(--bad);color:#fff}
.btn.bad:hover{filter:brightness(.96)}
.btn-ghost,.btn.ghost{background:transparent;border-color:var(--line);color:var(--fg-soft)}
.btn-ghost:hover{background:var(--surface-2)}
.back{display:inline-block;margin-top:1rem;color:var(--muted);font-size:.84rem}
.link-btn{background:none;border:0;padding:0;color:var(--accent);font-weight:500;font-size:.83rem;box-shadow:none}
.link-btn:hover{background:none;text-decoration:underline;transform:none}
.link-btn.ok{color:var(--ok)} .link-btn.bad{color:var(--bad)}
.actions{display:flex;flex-wrap:wrap;align-items:center;gap:.85rem}
.actions form{display:inline}

/* ---------- Inputs ---------- */
input[type=text],input[type=password],input[type=number],input[type=date],input[type=email],input[type=url],select,textarea{
  font-family:var(--sans);font-size:.87rem;color:var(--fg);background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:.5rem .6rem;transition:border-color .12s,box-shadow .12s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
input::placeholder{color:var(--muted)}
label{color:var(--fg-soft)}

/* ---------- Filtros ---------- */
.filters{display:flex;flex-wrap:wrap;align-items:center;gap:.55rem;margin-bottom:1.1rem}
.filters .chips{margin:0}
.inline{display:inline-flex;align-items:center;gap:.4rem;color:var(--fg-soft);font-size:.84rem}

/* ---------- Form config ---------- */
.cfgform{display:flex;flex-direction:column;gap:.15rem}
.cfgrow{display:grid;grid-template-columns:20rem 1fr;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--line-soft)}
.cfgrow:last-of-type{border-bottom:0}
.cfgrow label{font-size:.89rem;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;color:var(--fg)}
.cfgrow input,.cfgrow select{max-width:24rem}
.cfgrow input[type=number]{max-width:7rem}
.cfgform .actions{margin-top:.7rem}
.help{display:inline-flex;align-items:center;justify-content:center;width:1.05rem;height:1.05rem;border-radius:50%;
  font-size:.72rem;cursor:help;color:var(--muted);border:1px solid var(--line);user-select:none;transition:color .12s,border-color .12s}
.help:hover,.help:focus{color:var(--accent);border-color:var(--accent-line);outline:none}

/* ---------- Paginador ---------- */
.pager{display:flex;align-items:center;gap:1.1rem;margin-top:1.2rem;color:var(--muted);font-size:.84rem}
.pager2{flex-wrap:wrap}
.pager2 .pages{display:inline-flex;gap:.25rem;align-items:center}
.pager2 .pages a,.pager2 .pages .cur{min-width:1.7rem;height:1.7rem;display:inline-flex;align-items:center;
  justify-content:center;padding:0 .35rem;border:1px solid var(--line);border-radius:5px;text-decoration:none}
.pager2 .pages a:hover{background:var(--surface-2)}
.pager2 .pages .cur{background:var(--accent);color:#fff;border-color:transparent;font-weight:600}
.pager2 .perpage{margin-left:auto}
.pager2 .perpage a{margin:0 .15rem}
/* encabezado de tabla ordenable */
.sort-th{color:inherit;text-decoration:none;white-space:nowrap;cursor:pointer}
.sort-th:hover{color:var(--fg)}
/* affordance: las columnas ordenables muestran ↕ al pasar el cursor */
.sort-th:not(.on)::after{content:" ↕";opacity:0;transition:opacity .12s}
th:hover .sort-th:not(.on)::after{opacity:.5}
/* etiquetas rápidas (chips) del buscador de colas */
.chips{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin:0 0 .9rem}
.chip{display:inline-flex;align-items:center;gap:.3rem;padding:.22rem .7rem;border:1px solid var(--line);
  border-radius:999px;font-size:.8rem;text-decoration:none;color:var(--fg);background:var(--surface);white-space:nowrap;cursor:pointer}
.chip:hover{background:var(--surface-2)}
.chip.on{background:var(--accent);color:#fff;border-color:transparent;font-weight:600}
.chip.ghost{border-style:dashed;color:var(--muted)}
.chip.saved{padding-right:.3rem}
.chip.saved a{text-decoration:none;color:inherit}
.chip-x{border:0;background:none;color:var(--muted);cursor:pointer;font-size:1rem;line-height:1;padding:0 .1rem}
.chip-x:hover{color:var(--bad)}
.chip-sep{width:1px;height:1.3rem;background:var(--line);margin:0 .2rem}
/* Dominio clicable en las filas de la cola: filtra por ese dominio. */
.domlink{color:inherit;text-decoration:none;border-bottom:1px dotted var(--muted);cursor:pointer}
.domlink:hover{color:var(--accent);border-bottom-color:var(--accent)}
/* Chip de filtro de texto activo (dominio/from/to/asunto) con toggle de negación. */
.chip.filt .chip-x{color:rgba(255,255,255,.8)}
.chip.filt .chip-x:hover{color:#fff}
.chip .filt-neg{display:inline-flex;align-items:center;justify-content:center;min-width:1.1rem;height:1.1rem;
  border:1px solid currentColor;border-radius:50%;font-size:.72rem;line-height:1;text-decoration:none;color:inherit;opacity:.85}
.chip .filt-neg:hover{opacity:1;background:rgba(255,255,255,.18)}

/* ---------- Clave/valor ---------- */
.kv{display:grid;grid-template-columns:auto 1fr;gap:.55rem 1.3rem;margin:0}
.kv dt{color:var(--muted);font-size:.79rem;font-weight:500}
.kv dd{margin:0;font-family:var(--mono);font-size:.84rem;word-break:break-all}

/* ---------- .eml / .codebox (bloques de código oscuros, paleta única) ---------- */
.eml,.codebox{background:#0f1117;color:#cdd2dc;font-family:var(--mono);font-size:.79rem;line-height:1.55;padding:1rem 1.1rem;
  border:1px solid var(--rail-line);border-radius:var(--r-sm);overflow:auto;max-height:60vh;white-space:pre-wrap;word-break:break-word}
.codebox-sm{max-height:9rem}
.codebox-md{max-height:21rem}

/* ---------- Dashboard ---------- */
/* Cabecera + filtros */
.dash-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.dash-head .filters{margin:0}

/* Métricas compactas (strip estilo monitoreo) */
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(128px,1fr));gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;margin-bottom:1rem}
.metric{background:var(--surface);padding:.65rem .85rem .7rem;display:block;text-decoration:none;color:inherit;
  border-top:2px solid transparent;transition:background .12s}
.metric:hover,.metric:hover *{background:var(--surface-2);text-decoration:none}
.m-l{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--muted);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;line-height:1.15;min-height:2.3em;overflow:hidden}
.m-n{display:block;font-family:var(--mono);font-size:1.45rem;font-weight:500;letter-spacing:-.03em;color:var(--fg);line-height:1.2;margin-top:.05rem;font-variant-numeric:tabular-nums}
.m-s{display:block;color:var(--muted);font-size:.69rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.metric-lead{border-top-color:var(--accent)} .metric-lead .m-n{font-size:1.65rem}
.metric--ok{border-top-color:var(--ok)} .metric--warn{border-top-color:var(--warn)}
.metric--quar{border-top-color:var(--quar)} .metric--bad{border-top-color:var(--bad)} .metric--info{border-top-color:var(--info)}
.metric--edge{border-top-color:var(--edge)}

/* Paneles (Grafana-style) */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--shadow-sm)}
.panel-h{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.5rem .85rem;
  border-bottom:1px solid var(--line);background:var(--surface-2);font-size:.78rem;font-weight:600;color:var(--fg)}
.panel-b{padding:.85rem}
.panel-b.p0{padding:0}
.panel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(20rem,1fr));gap:1rem;margin-top:1rem}
.panel-wide{grid-column:1 / -1}
/* panel colapsable (details): gráficos secundarios cerrados por defecto */
details.panel>summary{list-style:none;cursor:pointer;user-select:none}
details.panel>summary::-webkit-details-marker{display:none}
details.panel>summary .chev{display:inline-block;color:var(--muted);font-size:.68rem;margin-right:.4rem;transition:transform .15s}
details.panel[open]>summary .chev{transform:rotate(90deg)}
details.panel:not([open])>summary.panel-h{border-bottom:0}

/* Gráfico */
.chart-legend{display:flex;gap:1.2rem;flex-wrap:wrap;font-size:.76rem;color:var(--fg-soft);margin-bottom:.5rem}
.chart-legend-wrap{gap:.4rem 1rem;font-size:.72rem}
.chart-legend-wrap span{white-space:nowrap}
.dot{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:.35rem;vertical-align:middle}
.dot-scan{background:var(--accent)} .dot-warn{background:var(--warn)} .dot-bad{background:var(--bad)} .dot-edge{background:var(--edge)}
.chart{width:100%;height:auto;display:block}
.chart .grid-l{stroke:var(--line-soft);stroke-width:1}
.chart .grid-axis{stroke:var(--line);stroke-width:1}
.chart .axis-t{fill:var(--muted);font-size:8px;font-family:var(--mono)}
.chart .ln{fill:none;stroke-width:1.6;stroke-linejoin:round;stroke-linecap:round}
.chart .ln-scan{stroke:var(--accent)} .chart .ln-warn{stroke:var(--warn)} .chart .ln-bad{stroke:var(--bad)}
.chart .mk{stroke:var(--surface);stroke-width:.8} .chart .mk-scan{fill:var(--accent)}
.chart .chart-hit{fill:transparent;stroke:none;pointer-events:all;cursor:crosshair}
.chart .chart-hit:hover{fill:var(--accent);fill-opacity:.06}
/* Tooltip de datos del gráfico (sigue al cursor; lo pinta app.js) */
.chart-tip{position:fixed;z-index:60;pointer-events:none;background:#10131b;color:var(--rail-fg);
  border:1px solid var(--rail-line);border-radius:var(--r-sm);padding:.5rem .65rem;font-size:.74rem;
  box-shadow:var(--shadow-lg);min-width:9rem;max-width:19rem}
.chart-tip .ct-d{font-family:var(--mono);font-size:.7rem;font-weight:600;color:#fff;margin-bottom:.3rem}
.chart-tip .ct-r{display:flex;align-items:center;gap:.45rem;line-height:1.55;white-space:nowrap}
.chart-tip .ct-dot{width:7px;height:7px;border-radius:2px;flex:none}
.chart-tip .ct-l{color:var(--rail-soft);overflow:hidden;text-overflow:ellipsis;max-width:12rem}
.chart-tip b{margin-left:auto;padding-left:.8rem;font-family:var(--mono);font-weight:600;color:#fff;font-variant-numeric:tabular-nums}

/* Tablas densas + barra-celda */
.dtable{width:100%;border-collapse:collapse;font-size:.8rem;table-layout:fixed}
.dtable th{text-align:left;font-size:.63rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);
  font-weight:600;padding:.4rem .85rem;border-bottom:1px solid var(--line);white-space:nowrap}
.dtable td{padding:.34rem .85rem;border-bottom:1px solid var(--line-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dtable tbody tr:last-child td{border-bottom:0}
.dtable tbody tr:hover td{background:var(--surface-2)}
.dtable .num,.dtable th.num{text-align:right;font-family:var(--mono);font-variant-numeric:tabular-nums}
.dtable .k{color:var(--fg-soft)}
.dtable .dim{color:var(--muted)}
.dtable .tone-warn{color:var(--warn)} .dtable .tone-quar{color:var(--quar)} .dtable .tone-bad{color:var(--bad)}
.barcell{background:linear-gradient(to left,var(--accent-soft) var(--p,0%),transparent var(--p,0%))}
/* Alertas de informe */
.rep-alert{padding:.7rem 1rem;border-radius:var(--r-sm);margin-bottom:1rem;font-size:.85rem;border:1px solid var(--line)}
.rep-alert-bad{background:var(--bad-soft);border-color:var(--bad);color:#7f1d1d}
.rep-alert-warn{background:var(--warn-soft);border-color:var(--warn);color:#7c4a03}
.rep-alert-ok{background:var(--ok-soft);border-color:var(--ok);color:#14532d}
.rep-actions{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin-bottom:1rem}
/* Mapa de configuración */
.seg-nav{display:inline-flex;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;margin-bottom:1.1rem}
.seg-link{padding:.4rem .9rem;font-size:.82rem;font-weight:500;color:var(--fg-soft);background:var(--surface);border-right:1px solid var(--line);text-decoration:none}
.seg-link:last-child{border-right:0}
.seg-link:hover{background:var(--surface-2);text-decoration:none}
.seg-link.active{background:var(--accent);color:#fff}
.badge-type{display:inline-block;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.08rem .4rem;border-radius:var(--r-xs);vertical-align:middle}
.bt-reseller{background:#ede9fe;color:#6d28d9} .bt-tenant{background:#dbeafe;color:#1e54da}
.bt-domain{background:#dcfce7;color:#15803d} .bt-user{background:var(--surface-3);color:var(--fg-soft)}
.bt-server{background:#fee2e2;color:#b91c1c}
/* Ocultar acciones según capacidad del rol (backstop visual; el router igual bloquea) */
.cap-no-quar form[action^="/quarantine/"],
.cap-no-quar form[action="/queue/report-spam"],
.cap-no-quar form[action="/queue/unreport"],
.cap-no-quar form[action="/queue/mark-fault"],
.cap-no-quar form[action="/queue/recover-evidence"],
.cap-no-quar form[action="/queue/list-add"],
.cap-no-quar form[action="/queue/whitelist-sender"],
.cap-no-quar form[action="/report/ip/block"]{display:none!important}
.cap-no-config form[action="/queue/delete"],
.cap-no-config form[action="/queue/purge"],
.cap-no-config form[action^="/dmarc/"]{display:none!important}
.cmap-node{padding:.2rem 0}
.cmap-node-h{display:flex;align-items:center;gap:.5rem;padding:.35rem 0}
.cmap-ovs{margin:.1rem 0 .5rem;background:var(--surface-2);border-radius:var(--r-xs)}
.cmap-ovs td{padding:.28rem .7rem;border-bottom:1px solid var(--line-soft)}
.cmap-matrix th{vertical-align:bottom;font-size:.62rem}
.cmap-matrix td:first-child{position:sticky;left:0;background:var(--surface)}
.cell-ov{background:var(--accent-soft)}

/* Jerarquía (árbol colapsable) */
.hier-howto{margin-bottom:1rem;padding:.7rem 1rem}
.hier-howto>summary{cursor:pointer;font-weight:600;font-size:.9rem;color:var(--fg)}
.hier-bar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.hier-totals{font-size:.86rem;color:var(--fg-soft)} .hier-totals b{color:var(--fg);font-family:var(--mono)}
.hier-search{flex:1;min-width:13rem;max-width:24rem;padding:.5rem .8rem;border:1px solid var(--line);border-radius:var(--r-sm);font:inherit;background:var(--surface)}
.hier-bar-r{display:flex;align-items:center;gap:.6rem;margin-left:auto}
.hier-newr{position:relative}
.hier-newr>summary{list-style:none;cursor:pointer}.hier-newr>summary::-webkit-details-marker{display:none}
.hier-newr[open]>form{position:absolute;right:0;top:2.6rem;z-index:20;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow-lg);padding:.8rem;min-width:18rem}
.htree{display:flex;flex-direction:column;gap:.55rem}
.hnode{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface)}
.hnode-r{box-shadow:var(--shadow-sm)}
.hnode-t{margin:.4rem .55rem;background:var(--surface-2);border-color:var(--line-soft)}
.hnode-t:first-of-type{margin-top:.2rem}
.hhead{display:flex;align-items:center;gap:.5rem;padding:.5rem .7rem .5rem .55rem}
.htoggle{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem;background:none;border:0;cursor:pointer;text-align:left;font:inherit;color:inherit;padding:.15rem 0}
.hchevron{transition:transform .15s;color:var(--muted);font-size:.7rem;flex:none}
.hnode:not(.collapsed)>.hhead .hchevron{transform:rotate(90deg)}
.hl-ico{flex:none}
.hname{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hsub{color:var(--muted);font-size:.78rem;flex:none}
.hcounts{margin-left:auto;color:var(--muted);font-size:.79rem;white-space:nowrap;flex:none;padding-left:.6rem}
.hcounts b{color:var(--fg);font-family:var(--mono)}
.hactions{display:flex;align-items:center;gap:.3rem;flex:none}
.ic-btn{display:inline-flex;align-items:center;justify-content:center;width:1.85rem;height:1.85rem;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);cursor:pointer;text-decoration:none;color:var(--fg-soft);font-size:.85rem}
.ic-btn:hover{background:var(--surface-2);text-decoration:none}
/* variante compacta para tablas densas + tonos semánticos */
.ic-btn.sm{width:1.55rem;height:1.55rem;font-size:.78rem;border-radius:var(--r-xs)}
.ic-btn.ok{color:var(--ok)} .ic-btn.ok:hover{border-color:var(--ok);background:var(--ok-soft)}
.ic-btn.bad{color:var(--bad)} .ic-btn.bad:hover{border-color:var(--bad);background:var(--bad-soft)}
.grid .actions{gap:.3rem;justify-content:flex-end;flex-wrap:nowrap}
/* badge de solo-icono (columna entrega): sin el punto ::before */
.badge.ic{padding:.14rem .4rem}
.badge.ic::before{content:none}
.grid th.ta-r{text-align:right}
/* zebra sutil en tablas densas (seguir la fila a lo ancho) */
.grid.dense tbody tr:nth-child(even)>td{background:#fafbfc}
.grid.dense tbody tr.edge-row>td{background:var(--surface-2)}
.grid.dense tbody tr:hover>td{background:var(--surface-2)}
/* Cuarentena simple (endusers): filas grandes con Liberar prominente */
.quar-simple{display:flex;flex-direction:column;gap:.6rem}
.qs-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r);padding:.95rem 1.15rem;box-shadow:var(--shadow-sm)}
.qs-main{flex:1;min-width:16rem}
.qs-subj{font-weight:600;font-size:.98rem;line-height:1.35;overflow-wrap:anywhere}
.qs-meta{color:var(--muted);font-size:.82rem;margin-top:.15rem}
.qs-meta b{color:var(--fg-soft);font-weight:500}
.qs-why{color:var(--fg-soft);font-size:.82rem;margin-top:.4rem;background:var(--surface-2);
  border-radius:var(--r-xs);padding:.35rem .6rem}
.qs-actions{display:flex;align-items:center;gap:.6rem;flex:none}
/* fecha relativa: el title trae la fecha completa */
time.ago{cursor:help}
.hmore{position:relative}
.hmenu{position:absolute;right:0;top:2.15rem;z-index:30;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow-lg);padding:.5rem;min-width:15rem;display:none}
.hmore.open .hmenu{display:block}
.hmenu-form{display:flex;flex-direction:column;gap:.3rem;padding:.35rem;border-bottom:1px solid var(--line-soft)}
.hmenu-lbl{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.hmenu-form input,.hmenu-form select{padding:.35rem .5rem;border:1px solid var(--line);border-radius:var(--r-xs);font:inherit}
.hmenu-del{padding:.4rem .35rem 0}
.hnode.collapsed>.hbody{display:none}
.hbody{padding:0 .55rem .4rem}
.hnode-t>.hbody{padding:0 .5rem .4rem}
.hdomtable{width:100%;border-collapse:collapse;font-size:.82rem;background:var(--surface);border-radius:var(--r-xs)}
.hdomtable td{padding:.32rem .7rem;border-bottom:1px solid var(--line-soft)}
.hdomtable tr:last-child td{border-bottom:0}
.hdomtable tr:hover td{background:var(--surface-2)}
.hdom-n{width:99%} .hdom-n a{color:var(--fg)}
.hadd-row{display:flex;gap:.6rem;flex-wrap:wrap;padding:.5rem .2rem 0;align-items:flex-start}
.bars{display:flex;align-items:flex-end;gap:.35rem;height:130px;padding-top:.5rem}
.bar{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:.35rem;height:100%;text-decoration:none}
.bar-f{display:block;width:100%;background:linear-gradient(180deg,var(--accent),#6f9bff);border-radius:4px 4px 0 0;min-height:3px;transition:height .4s ease}
.bar:hover .bar-f{filter:brightness(1.08)}
.bar-l,.bar-n{font-size:.67rem;color:var(--muted)}

/* ---------- Jerarquía ---------- */
.compact{font-size:.84rem;color:var(--fg-soft)}

/* leyenda conceptual */
.hier-legend{background:linear-gradient(180deg,var(--accent-soft),transparent 140%)}
.hier-levels{display:flex;align-items:stretch;gap:.5rem;flex-wrap:wrap}
.hl-step{flex:1 1 130px;min-width:120px;display:flex;flex-direction:column;gap:.15rem;
  padding:.7rem .8rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm)}
.hl-step .hl-ico{font-size:1.25rem;line-height:1}
.hl-step b{letter-spacing:-.01em}
.hl-arrow{display:flex;align-items:center;color:var(--muted);font-weight:700}
.hier-inherit{margin:.8rem 0 0}
@media(max-width:680px){.hl-arrow{display:none}}

/* bloques "agregar" colapsables */
.add-block>summary,.add-inline>summary{list-style:none;cursor:pointer;font-weight:600;
  color:var(--accent);font-size:.86rem;display:inline-flex;align-items:center;gap:.3rem}
.add-block>summary::-webkit-details-marker,.add-inline>summary::-webkit-details-marker{display:none}
.add-block{padding:.85rem 1rem}
.add-inline{margin-top:.7rem}

/* reseller / tenant: cabecera de 3 zonas (título · stats · acciones) */
.hier-reseller{padding:0;overflow:hidden}
.hier-head{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
  padding:1rem 1.1rem;background:linear-gradient(180deg,var(--accent-soft),transparent);
  border-bottom:1px solid var(--line)}
.hier-title{display:flex;align-items:center;gap:.7rem;min-width:0}
.hier-title .hl-ico{font-size:1.5rem;line-height:1;flex:none}
.hier-title h3{margin:0;letter-spacing:-.015em}
.hier-meta{display:flex;gap:.4rem;flex-wrap:wrap;margin-left:auto}
.tnode .hier-meta{margin-left:0;margin-top:.35rem}
.stat-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.18rem .55rem;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--pill);
  font-size:.76rem;color:var(--muted)}
.stat-chip b{color:var(--fg);font-size:.86rem}
.hier-actions{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}
.hier-actions form{margin:0}
.btn-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .6rem;border-radius:var(--pill);
  border:1px solid var(--line);background:var(--surface);color:var(--fg-soft);font-size:.8rem;
  font-weight:500;cursor:pointer;line-height:1.2;text-decoration:none}
.btn-chip:hover{border-color:var(--accent);color:var(--accent)}
.btn-chip.danger:hover{border-color:var(--bad);color:var(--bad)}

/* tenants dentro del reseller */
.tnode{padding:.9rem 1.1rem;border-bottom:1px solid var(--line-soft)}
.tnode:last-of-type{border-bottom:0}
.tnode-h{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.6rem}
.hier-sub-empty{margin:.2rem 0 .4rem}
.hier-reseller>.add-inline{padding:0 1.1rem 1rem}

/* grilla de dominios dentro del tenant */
.domgrid{margin:0}
.domgrid td{padding:.4rem .6rem}
.domgrid .domname a{font-weight:500}
.badge.muted-badge{color:var(--muted);background:var(--line-soft);border-color:transparent;opacity:.6}

.inline-edit{position:relative}
.inline-edit>summary{list-style:none;cursor:pointer}
.inline-edit>summary::-webkit-details-marker{display:none}
.inline-edit[open]>.filters{position:absolute;right:0;z-index:5;margin-top:.4rem;padding:.6rem;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow-lg)}

/* fila de evento de borde (cortado antes del motor): tenue */
.grid.dense tr.edge-row td{background:var(--surface-2)}
tr.edge-row td.muted{font-style:italic}

/* categorías dentro de Parámetros */
.cfg-cat{margin:1.4rem 0 .3rem;padding-bottom:.3rem;font-size:.78rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;color:var(--accent-strong);
  border-bottom:1px solid var(--line-soft)}
.cfg-cat:first-child{margin-top:0}
.hdr-var{display:inline-block;background:var(--accent-soft);color:var(--accent-strong);
  padding:.05rem .35rem;border-radius:5px;font-size:.78rem;margin:.1rem .1rem}

/* ---------- Login / páginas públicas (layout plain) ---------- */
.plain{background:linear-gradient(180deg,var(--accent-soft),var(--bg) 340px)}
.loginwrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.3rem;padding:2rem}
.brand-big{font-size:2rem;font-weight:600;display:flex;align-items:center;gap:.65rem;letter-spacing:-.025em;color:var(--fg)}
.brand-big .dot{width:13px;height:13px;border-radius:4px;background:var(--accent);box-shadow:0 0 0 5px var(--accent-soft)}
.logo-big{height:42px}
.tagline{color:var(--muted)}
.loginwrap .card{width:min(380px,100%);box-shadow:var(--shadow-lg)}
.form{display:flex;flex-direction:column;gap:.8rem}
.form label{display:flex;flex-direction:column;gap:.35rem;font-size:.84rem;color:var(--fg-soft)}
.form .btn{margin-top:.4rem}
.error{background:var(--bad-soft);border:1px solid var(--bad);color:var(--bad);padding:.6rem .8rem;border-radius:var(--r-sm);font-size:.84rem;margin-bottom:.8rem}

/* focus de teclado consistente */
.btn:focus-visible,button:focus-visible,.ic-btn:focus-visible,.chip:focus-visible,a.tablink:focus-visible{outline:none;box-shadow:var(--ring)}
/* iconos SVG inline: alineados al texto */
.ic-svg{vertical-align:-.18em;flex:none}
.nav-item .ic-svg{opacity:.55;transition:opacity .12s}
.nav-item:hover .ic-svg,.nav-item.active .ic-svg{opacity:1}
.nav-item.active .ic-svg{color:var(--rail-accent)}

.muted{color:var(--muted)}
.small{font-size:.8rem}
.spacer{flex:1}

/* ---------- Utilidades de homologación ----------
   .page-sub  : subtítulo bajo .page-title (reemplaza márgenes negativos inline)
   .sub       : título de sección (h2) dentro de una página
   .empty     : estado "sin datos" (único patrón en todo el panel)
   .w-sm/md/lg: anchos estándar de inputs
   .grid-3col : formulario en 3 columnas
   .card-md   : tarjeta centrada de ancho medio (páginas públicas/digest) */
.sub{font-size:1.02rem;font-weight:600;letter-spacing:-.012em;margin:1.6rem 0 .7rem}
.empty{color:var(--muted);font-size:.85rem;padding:.6rem .2rem;margin:0}
.w-sm{width:7rem}
.w-md{width:14rem}
.w-lg{width:20rem}
.f-inline{display:inline}
.th-min{width:1%;white-space:nowrap}
.mt-sm{margin-top:.6rem}
.mt-md{margin-top:1rem}
.ta-c{text-align:center}
.grid-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem 1rem}
@media (max-width:720px){.grid-3col{grid-template-columns:1fr}}
.card-md{max-width:35rem;margin-left:auto;margin-right:auto}

/* ---------- Barra de impersonación (layout) ---------- */
.imp-bar{background:#7a2e00;color:#ffd9b0;padding:.5rem .9rem;display:flex;align-items:center;gap:.8rem;
  font-size:.85rem;border-bottom:1px solid #a14a14}
.imp-bar .dim{opacity:.7}
.imp-bar form{margin:0 0 0 auto}
.imp-bar button{background:#ffd9b0;color:#7a2e00;border:0;border-radius:4px;padding:.25rem .7rem;font-weight:600;cursor:pointer}

/* ---------- Toggle segmentado (sí/no) — compacto tipo pill ---------- */
.seg{display:inline-flex;border:1px solid var(--line);border-radius:var(--pill);overflow:hidden;background:var(--surface-2);padding:2px}
.seg label{margin:0;display:block}
.seg input{position:absolute;opacity:0;pointer-events:none}
.seg span{display:block;padding:.16rem .62rem;font-size:.76rem;font-weight:500;color:var(--muted);cursor:pointer;border-radius:var(--pill);transition:background .12s,color .12s;user-select:none}
.seg input:checked+span{background:var(--accent);color:#fff;box-shadow:0 1px 2px rgba(47,107,246,.3)}
/* "No" activo en rojo suave para que se lea de un vistazo */
.seg label:last-child input:checked+span{background:var(--bad);box-shadow:0 1px 2px rgba(239,68,68,.3)}

/* ---------- Campo editable por modal (texto/select) ---------- */
.fieldchip{display:inline-flex;align-items:center;gap:.5rem;min-width:9rem;max-width:24rem;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-sm);padding:.36rem .6rem;font:inherit;color:var(--fg);cursor:pointer;text-align:left}
.fieldchip:hover{border-color:#d2d6db;background:var(--surface-2)}
.fieldchip .chip-val{font-family:var(--mono);font-size:.83rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fieldchip .chip-edit{margin-left:auto;color:var(--muted);font-size:.82rem}

/* ---------- Mini-modal ---------- */
.modal{position:fixed;inset:0;background:rgba(15,17,23,.5);display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem;backdrop-filter:blur(2px)}
.modal-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-lg);width:min(380px,100%);padding:1.2rem 1.3rem}
.modal-card h3{font-size:.95rem;margin-bottom:.8rem}
.modal-card.modal-wide{width:min(640px,100%)}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.6rem}
.modal-head h3{margin:0}
.modal-head .btn-ghost{padding:.2rem .5rem;line-height:1}
.modal-body{margin-bottom:1rem}
.confirm-detail{font-size:.84rem;color:var(--fg-soft);background:var(--surface-2);border-radius:var(--r-xs);padding:.5rem .7rem}
.modal-input{width:100%}
.modal-btns{display:flex;justify-content:flex-end;gap:.5rem}

/* ---------- Tabs por enlace (estado en la URL, sobreviven a F5) ----------
   Estructura: nav.tabnav > a.tablink; el servidor renderiza SOLO la pestaña
   activa (las pesadas, como listas, no viajan si no se piden). */
.tabnav{display:flex;gap:.15rem;border-bottom:1px solid var(--line);margin-bottom:1.3rem;flex-wrap:wrap}
.tabnav a.tablink{padding:.6rem .95rem;cursor:pointer;color:var(--muted);font-weight:500;font-size:.9rem;
  border-bottom:2px solid transparent;margin-bottom:-1px;text-decoration:none;transition:color .12s,border-color .12s}
.tabnav a.tablink:hover{color:var(--fg);text-decoration:none}
.tabnav a.tablink.active{color:var(--accent-strong);border-bottom-color:var(--accent)}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  /* columnas secundarias fuera; la tabla queda operable en el teléfono */
  .hide-sm{display:none!important}
  .filters input[type=text],.filters input[type=search]{flex:1;min-width:9rem}
  .rail-search{flex:1;min-width:10rem;margin:0}
  .grid.dense .ellip{max-width:34vw}
  .qs-row{padding:.8rem .9rem}
  .app{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;gap:.3rem;padding:.6rem .8rem}
  .sidebar .brand{padding:.2rem .4rem;width:100%}
  /* el nav fluye como chips (display:contents disuelve los grupos) */
  .sidebar nav{display:flex;flex-wrap:wrap;gap:.2rem;width:100%;order:3}
  .nav-group{display:contents;margin:0}
  .nav-group-label{display:none}
  .nav-item{padding:.4rem .6rem;border:1px solid var(--rail-line);border-radius:var(--pill);font-size:.82rem}
  .nav-item.active::before{display:none}
  .sidebar-foot{margin:0 0 0 auto;border:0;padding:0;display:flex;align-items:center;gap:.6rem;order:2}
  .rail-search{order:1}
  .user-chip{display:none}
  .content{padding:1.3rem 1.1rem 2rem}
  .cfgrow{grid-template-columns:1fr;gap:.35rem;align-items:start}
  .ellip{max-width:60vw}
}

/* ---------- Tabla visual de política de autenticación ----------
   Grid por fila con el MISMO template en encabezado y filas → columnas alineadas.
   Todas las celdas son selectores (sin inputs variables), así nada descuadra. */
.auth-tpl{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin:.3rem 0 1rem;padding:.55rem .7rem;background:var(--surface-2);border-radius:var(--r-sm)}
.auth-tpl form{display:flex;align-items:center;gap:.5rem;margin:0}
.auth-tpl-lbl{font-size:.82rem;color:var(--fg-soft);font-weight:600}
.quorum-form{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin:.2rem 0;padding:.55rem .7rem;background:var(--surface-2);border-radius:var(--r-sm)}
.quorum-form select{width:auto}
.quorum-form .btn{padding:.3rem .6rem}
.quorum-form .quorum-then{color:var(--fg-soft)}
.authgrid{display:flex;flex-direction:column;gap:.4rem;margin-top:.3rem}
.authrow{display:grid;grid-template-columns:2.4rem repeat(5,minmax(0,1fr)) minmax(0,1.5fr) auto;gap:.45rem;align-items:center}
.authrow > *{min-width:0}
.authrow select{width:100%}
.authhead{font-weight:600;font-size:.72rem;color:var(--fg-soft);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--line);padding-bottom:.4rem}
.authrow-id{font-size:.72rem;color:var(--muted);font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap}
.authrow-new{background:var(--accent-soft);border-radius:var(--r-sm);padding:.3rem 0}
.authrow-new .authrow-id{color:var(--accent);font-weight:600}
.authrow-sep{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-top:1px dashed var(--line);padding-top:.5rem;margin-top:.15rem}
.authrow-btns{display:flex;gap:.3rem;justify-content:flex-end;align-items:center}
.authrow-btns .btn{padding:.3rem .55rem}
select.authsel[data-v="fail"],select.authsel[data-v="hit"],select.authsel[data-v="missing"]{color:var(--bad);border-color:var(--bad);font-weight:600}
select.authsel[data-v="pass"],select.authsel[data-v="clean"],select.authsel[data-v="has"]{color:var(--ok);border-color:var(--ok);font-weight:600}
select.authsel[data-v="softfail"],select.authsel[data-v="neutral"]{color:var(--warn);border-color:var(--warn);font-weight:600}
select.actsel[data-a="reject"]{color:var(--bad);border-color:var(--bad);font-weight:600}
select.actsel[data-a="quarantine"]{color:var(--quar);border-color:var(--quar);font-weight:600}
select.actsel[data-a="tag"]{color:var(--warn);border-color:var(--warn);font-weight:600}
select.actsel[data-a="accept"]{color:var(--ok);border-color:var(--ok);font-weight:600}
select.actsel[data-a^="add_score"]{color:var(--accent);border-color:var(--accent);font-weight:600}

/* ---------- Matriz heredada (solo lectura coloreada + override) ---------- */
.authrow-inh{grid-template-columns:minmax(6rem,1.3fr) repeat(5,minmax(0,1fr)) minmax(0,1.5fr) auto}
.authrow-inh.is-overridden{opacity:.72}
.authrow-origin{font-size:.78rem;color:var(--fg-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.authval{display:block;width:100%;box-sizing:border-box;text-align:center;padding:.34rem .4rem;border:1px solid var(--line);border-radius:var(--r-sm);font-size:.82rem;background:var(--surface-2);color:var(--fg-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.authval.any{border-style:dashed;color:var(--muted)}
.authval[data-v="fail"],.authval[data-v="hit"],.authval[data-v="missing"]{color:var(--bad);border-color:var(--bad);font-weight:600}
.authval[data-v="pass"],.authval[data-v="clean"],.authval[data-v="has"]{color:var(--ok);border-color:var(--ok);font-weight:600}
.authval[data-v="softfail"],.authval[data-v="neutral"]{color:var(--warn);border-color:var(--warn);font-weight:600}

/* ---------- Breadcrumb de scope + etiqueta propio/heredado (/config) ---------- */
.scope-crumb{display:flex;flex-wrap:wrap;align-items:center;gap:.1rem;margin:.1rem 0 .3rem;font-size:.85rem}
.scope-crumb .crumb{color:var(--muted);text-decoration:none;padding:.15rem .45rem;border-radius:var(--r-xs)}
.scope-crumb .crumb:hover{background:var(--surface-2);color:var(--fg);text-decoration:none}
.scope-crumb .crumb.active{background:var(--accent-soft);color:var(--accent-strong);font-weight:600}
.scope-crumb .crumb-sep{color:var(--line);margin:0 .05rem}
.src-tag{display:inline-block;font-size:.64rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:.04rem .35rem;border-radius:var(--pill);margin-left:.35rem;vertical-align:middle}
.src-tag.own{background:var(--accent-soft);color:var(--accent-strong)}
.src-tag.inh{background:var(--surface-3);color:var(--muted)}
.src-tag.fac{background:transparent;color:var(--muted);border:1px dashed var(--line);font-weight:500}

@media (max-width:720px){
  .authrow{grid-template-columns:1fr 1fr}
  .authrow-inh{grid-template-columns:1fr 1fr}
  .authhead,.authrow-id{display:none}
}
