/* tab-salud.css — Estilos globales Tab Salud Infraestructura
   Movido de TabSaludInfraestructura.razor.css para evitar problemas de scoped CSS
   con render-mode="ServerPrerendered" en Blazor Server.
   Paleta: tokens var(--ircnl-*) — NUNCA hex hardcodeado */

/* ─── Encabezado del tab ─────────────────────────────────────────────────── */
.tab-header {
    border-bottom: 3px solid var(--ircnl-orange);
    padding-bottom: 10px;
    margin-bottom: 18px;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
}

.tab-titulo {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--ircnl-primary);
    letter-spacing: -0.3px;
}

.tab-subtitulo {
    font-size: 0.9375rem;
    color: var(--ircnl-text-muted);
    margin-top: 2px;
}

.refresh-badge {
    font-size: 0.8125rem;
    color: var(--ircnl-text-muted);
    background: var(--ircnl-white);
    border: 0.5px solid var(--ircnl-border);
    border-radius: 20px;
    padding: 3px 10px;
}

/* ─── Grid de tarjetas de nodos ──────────────────────────────────────────── */
.infra-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 14px;
    margin-bottom: 20px;
}

/* ─── Tarjeta de nodo ────────────────────────────────────────────────────── */
.nodo-card {
    background: var(--ircnl-bg-card);
    border: 0.5px solid var(--ircnl-border);
    border-radius: var(--radius-md);
    padding: 16px;
    cursor: pointer;
    transition: border-color var(--transition-fast);
    border-left: 3px solid transparent;
}

.nodo-card:hover {
    border-color: var(--ircnl-accent);
}

.nodo-card.seleccionado {
    border: 2px solid var(--ircnl-primary);
    border-top: 4px solid var(--ircnl-orange);
}

.nodo-critico  { border-left-color: var(--ircnl-danger); }
.nodo-alto     { border-left-color: var(--ircnl-warning); }
.nodo-ok       { border-left-color: var(--ircnl-success); }

.nc-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 10px;
}

.nc-hostname {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    color: var(--ircnl-primary);
}

.nc-ip {
    font-size: 0.8125rem;
    color: var(--ircnl-text-muted);
    margin-top: 2px;
    font-family: monospace;
}

.badge-eol {
    font-size: 0.75rem;
    font-weight: 600;
    background: var(--ircnl-orange-bg);
    color: var(--ircnl-orange-hover);
    border: 0.5px solid var(--ircnl-warning);
    border-radius: var(--radius-sm);
    padding: 2px 6px;
    white-space: nowrap;
}

.score-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 0.5px solid var(--ircnl-border);
}

.score-big {
    font-family: var(--font-display);
    font-size: 2.125rem;
    font-weight: 700;
    line-height: 1;
}

.score-big .score-max {
    font-size: 1rem;
    font-weight: 400;
    color: var(--ircnl-primary-light);
}

.score-meta {
    font-size: 0.8125rem;
    color: var(--ircnl-text-muted);
    line-height: 1.4;
}

.score-base-hint {
    font-size: 0.75rem;
    opacity: 0.7;
}

.score-critico     { color: var(--ircnl-danger); }
.score-advertencia { color: var(--ircnl-warning); }
.score-ok          { color: var(--ircnl-success); }

.metricas-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    margin-bottom: 12px;
}

.m-item {
    background: var(--ircnl-bg);
    border-radius: var(--radius-sm);
    padding: 7px 10px;
}

.m-lbl {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--ircnl-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 2px;
}

.m-val {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--ircnl-primary);
}

.critico     { color: var(--ircnl-danger); }
.advertencia { color: var(--ircnl-warning); }
.ok          { color: var(--ircnl-success); }

.m-cap {
    display: block;
    font-size: 0.72rem;
    color: var(--ircnl-text-muted);
    margin-top: 1px;
    font-family: monospace;
}

.nc-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.8125rem;
}

.freshness       { color: var(--ircnl-text-muted); }
.freshness.stale { color: var(--ircnl-danger); }

.hallazgos-mini { display: flex; gap: 4px; }

.hm-pill {
    font-size: 0.75rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
}

.hm-pill.crit { background: #FCEBEB; color: #A32D2D; }
.hm-pill.alto { background: var(--ircnl-orange-bg); color: var(--ircnl-orange-hover); }
.hm-pill.ok   { background: #EAF3DE; color: #3B6D11; }

/* ─── Panel de detalle ───────────────────────────────────────────────────── */
.detalle-panel {
    background: var(--ircnl-bg-card);
    border: 0.5px solid var(--ircnl-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.dp-header {
    background: var(--ircnl-primary);
    padding: 16px 20px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    flex-wrap: wrap;
}

.dp-hostname {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--ircnl-text-light);
}

.dp-ip {
    font-size: 0.875rem;
    color: var(--ircnl-primary-light);
    margin-top: 3px;
    font-family: monospace;
}

.dp-rol {
    font-size: 0.875rem;
    color: var(--ircnl-accent);
    margin-top: 4px;
}

.scores-bloque {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.score-box {
    text-align: center;
    padding: 8px 14px;
    border-radius: var(--radius-sm);
}

.score-box.pre  { background: rgba(255, 68, 56, 0.20); }
.score-box.post { background: rgba(0, 188, 112, 0.20); }

.score-box .sn {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    display: block;
}

.score-box.pre .sn  { color: #FF8070; }
.score-box.post .sn { color: #5DFFB4; }

.score-box .sl { font-size: 0.75rem; color: var(--ircnl-primary-light); }

.score-arrow { color: var(--ircnl-accent); font-size: 1rem; }
.score-denom { font-size: 0.8125rem; color: var(--ircnl-accent); }

.dp-body { padding: 18px 20px; }

.section-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--ircnl-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 10px;
}

/* ─── Sparkline CPU ──────────────────────────────────────────────────────── */
.sparkline-section { margin-bottom: 20px; }

.sparkline {
    display: flex;
    align-items: flex-end;
    gap: 2px;
    height: 56px;
    background: var(--ircnl-bg);
    border-radius: var(--radius-sm);
    padding: 4px 6px;
}

.spark-bar {
    border-radius: 2px 2px 0 0;
    min-width: 5px;
    flex: 1;
    transition: opacity var(--transition-fast);
}

.spark-bar:hover { opacity: 0.7; }

.spark-bar.ok          { background: var(--ircnl-primary-light); }
.spark-bar.advertencia { background: var(--ircnl-warning); }
.spark-bar.critico     { background: var(--ircnl-danger); }

.spark-label-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.75rem;
    color: var(--ircnl-primary-light);
    margin-top: 4px;
}

/* ─── Volúmenes de disco ─────────────────────────────────────────────────── */
.volumenes-section { margin-bottom: 20px; }

.volumenes-grid { display: flex; flex-direction: column; gap: 5px; }

.vol-item {
    display: grid;
    grid-template-columns: minmax(120px, 160px) 1fr 130px;
    gap: 10px;
    align-items: center;
    padding: 5px 6px;
    border-radius: var(--radius-sm);
}

.vol-item:hover { background: var(--ircnl-bg); }

.vol-ruta {
    font-family: monospace;
    font-size: 0.8125rem;
    color: var(--ircnl-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vol-bar-wrap {
    height: 8px;
    background: var(--ircnl-bg);
    border-radius: 4px;
    overflow: hidden;
}

.vol-bar-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.3s ease;
}

.vol-bar-fill.ok          { background: var(--ircnl-success); }
.vol-bar-fill.advertencia { background: var(--ircnl-warning); }
.vol-bar-fill.critico     { background: var(--ircnl-danger); }

.vol-meta {
    font-size: 0.8125rem;
    color: var(--ircnl-text-muted);
    text-align: right;
    white-space: nowrap;
}

/* ─── Sistema en vivo ────────────────────────────────────────────────────── */
.sistema-vivo-section { margin-bottom: 20px; }

.sv-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 8px;
}

.sv-chip {
    background: var(--ircnl-bg);
    border: 0.5px solid var(--ircnl-border);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
}

.sv-chip.sv-alerta {
    border-color: var(--ircnl-danger);
    background: #FCEBEB;
}

.sv-lbl {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--ircnl-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 4px;
}

.sv-val {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    color: var(--ircnl-primary);
}

.sv-chip-expandido {
    grid-column: 1 / -1;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}

/* ─── Top procesos ───────────────────────────────────────────────────────── */
.procesos-section { margin-bottom: 20px; }

.tabla-procesos {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.tabla-procesos th {
    background: var(--ircnl-bg);
    padding: 7px 10px;
    text-align: left;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ircnl-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 0.5px solid var(--ircnl-border);
}

.tabla-procesos td {
    padding: 7px 10px;
    border-bottom: 0.5px solid var(--ircnl-bg);
    vertical-align: middle;
    color: var(--ircnl-text);
}

.tabla-procesos tr:hover td { background: var(--ircnl-bg); }

.pid-col      { font-family: monospace; font-size: 0.8125rem; color: var(--ircnl-text-muted); }
.proceso-nombre {
    font-family: monospace;
    font-size: 0.875rem;
    color: var(--ircnl-primary);
    max-width: 260px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.usuario-col  { font-size: 0.8125rem; color: var(--ircnl-text-muted); }
.pct-col      { font-family: var(--font-display); font-weight: 700; text-align: right; }

/* ─── Eventos auth ───────────────────────────────────────────────────────── */
.auth-section { margin-bottom: 20px; }

.tabla-auth {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.tabla-auth th {
    background: var(--ircnl-bg);
    padding: 7px 10px;
    text-align: left;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ircnl-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 0.5px solid var(--ircnl-border);
}

.tabla-auth td {
    padding: 6px 10px;
    border-bottom: 0.5px solid var(--ircnl-bg);
    vertical-align: middle;
}

.tabla-auth tr:hover td { background: var(--ircnl-bg); }

.auth-ts      { font-family: monospace; font-size: 0.8125rem; color: var(--ircnl-text-muted); white-space: nowrap; }
.auth-usuario { font-family: monospace; font-size: 0.875rem; color: var(--ircnl-primary); }
.auth-ip      { font-family: monospace; font-size: 0.8125rem; color: var(--ircnl-text-muted); }

.badge-tipo { font-size: 0.75rem; font-weight: 600; padding: 2px 8px; border-radius: 10px; white-space: nowrap; }
.badge-tipo.failed   { background: #FCEBEB; color: #A32D2D; }
.badge-tipo.accepted { background: #EAF3DE; color: #3B6D11; }
.badge-tipo.invalid  { background: var(--ircnl-orange-bg); color: var(--ircnl-orange-hover); }

/* ─── Tabla de hallazgos ─────────────────────────────────────────────────── */
.tabla-hallazgos {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.tabla-hallazgos th {
    background: var(--ircnl-bg);
    padding: 8px 12px;
    text-align: left;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ircnl-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 0.5px solid var(--ircnl-border);
}

.tabla-hallazgos td {
    padding: 10px 12px;
    border-bottom: 0.5px solid var(--ircnl-bg);
    vertical-align: middle;
    color: var(--ircnl-text);
}

.tabla-hallazgos tr:hover td { background: var(--ircnl-bg); }

.hallazgo-row.cerrado td { opacity: 0.45; text-decoration: line-through; }

.clave-tag {
    font-family: monospace;
    font-size: 0.8125rem;
    background: var(--ircnl-bg);
    border: 0.5px solid var(--ircnl-border);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    color: var(--ircnl-primary);
    font-weight: 600;
    white-space: nowrap;
}

.badge-prioridad { font-size: 0.75rem; font-weight: 600; padding: 2px 8px; border-radius: 10px; white-space: nowrap; }
.badge-prioridad.critica   { background: #FCEBEB; color: #A32D2D; }
.badge-prioridad.alta      { background: var(--ircnl-orange-bg); color: var(--ircnl-orange-hover); }
.badge-prioridad.media     { background: #E6F1FB; color: #185FA5; }
.badge-prioridad.baja      { background: #EAF3DE; color: #3B6D11; }
.badge-prioridad.en_proceso { background: #E6F1FB; color: #185FA5; }
.badge-prioridad.pendiente  { background: var(--ircnl-orange-bg); color: var(--ircnl-orange-hover); }
.badge-prioridad.mitigado   { background: #EAF3DE; color: #3B6D11; }
.badge-prioridad.cerrado    { background: var(--ircnl-bg); color: var(--ircnl-text-muted); }

.estado-select {
    font-size: 0.8125rem;
    padding: 3px 6px;
    border: 0.5px solid var(--ircnl-border);
    border-radius: var(--radius-sm);
    background: var(--ircnl-bg-card);
    color: var(--ircnl-text);
    cursor: pointer;
    transition: border-color var(--transition-fast);
}
.estado-select:focus { outline: none; border-color: var(--ircnl-primary); }

.resp-col { font-size: 0.875rem; color: var(--ircnl-text-muted); }
.eta-col  { font-size: 0.8125rem; color: var(--ircnl-text-muted); }

/* ─── Tabla sesiones SSH ─────────────────────────────────────────────────── */
.sv-tabla-ssh { width: 100%; border-collapse: collapse; font-size: 0.8125rem; margin-top: 4px; }
.sv-tabla-ssh th {
    color: var(--ircnl-text-muted);
    font-weight: 600;
    text-align: left;
    padding: 3px 8px 3px 0;
    border-bottom: 1px solid var(--ircnl-border);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.sv-tabla-ssh td { padding: 4px 8px 4px 0; }
.ssh-usuario  { font-weight: 600; color: var(--ircnl-text); }
.ssh-terminal { font-family: monospace; color: var(--ircnl-text-muted); font-size: 0.8rem; }
.ssh-desde    { color: var(--ircnl-primary); font-size: 0.8rem; }
.ssh-hora     { color: var(--ircnl-text-muted); font-size: 0.8rem; white-space: nowrap; }

/* ─── Panel TCP desglose ─────────────────────────────────────────────────── */
.tcp-detalle-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    width: 100%;
    margin-top: 4px;
}
.tcp-col-titulo { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ircnl-text-muted); margin-bottom: 6px; }
.tcp-row { display: flex; align-items: center; gap: 6px; margin-bottom: 5px; }
.tcp-label { font-size: 0.78rem; min-width: 120px; font-weight: 500; white-space: nowrap; }
.tcp-bar-wrap { flex: 1; height: 8px; background: var(--ircnl-border); border-radius: 4px; overflow: hidden; }
.tcp-bar { height: 100%; border-radius: 4px; min-width: 2px; transition: width 0.4s ease; }
.tcp-count { font-size: 0.8rem; font-weight: 700; color: var(--ircnl-text); min-width: 24px; text-align: right; }
.tcp-srv     { color: var(--ircnl-text); }
.tcp-bar-srv { background: var(--ircnl-primary); opacity: 0.7; }

.tcp-internet { color: #b91c1c; }
.tcp-atlas    { color: var(--ircnl-primary); }
.tcp-prod     { color: #0369a1; }
.tcp-nas      { color: #7c3aed; }
.tcp-vpn      { color: #d97706; }
.tcp-local    { color: var(--ircnl-text-muted); }
.tcp-otro     { color: var(--ircnl-text-muted); }

.tcp-internet ~ .tcp-bar-wrap > .tcp-bar { background: #ef4444; }
.tcp-atlas    ~ .tcp-bar-wrap > .tcp-bar { background: var(--ircnl-primary); }
.tcp-prod     ~ .tcp-bar-wrap > .tcp-bar { background: #0ea5e9; }
.tcp-nas      ~ .tcp-bar-wrap > .tcp-bar { background: #7c3aed; }
.tcp-vpn      ~ .tcp-bar-wrap > .tcp-bar { background: #f59e0b; }
.tcp-local    ~ .tcp-bar-wrap > .tcp-bar { background: var(--ircnl-border); }
.tcp-otro     ~ .tcp-bar-wrap > .tcp-bar { background: var(--ircnl-text-muted); }

/* ─── Estado "sin datos" ─────────────────────────────────────────────────── */
.sin-datos {
    background: var(--ircnl-bg);
    border: 0.5px dashed var(--ircnl-border);
    border-radius: var(--radius-md);
    padding: 2rem;
    text-align: center;
    color: var(--ircnl-text-muted);
    font-size: 1rem;
}

.alerta-error {
    background: #FCEBEB;
    border: 0.5px solid var(--ircnl-danger);
    border-left: 3px solid var(--ircnl-danger);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    color: #A32D2D;
    font-size: 0.9375rem;
    margin-bottom: 12px;
}

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 992px) {
    .infra-grid { grid-template-columns: repeat(2, 1fr); }
    .dp-header  { flex-direction: column; }
}
@media (max-width: 640px) {
    .infra-grid { grid-template-columns: 1fr; }
    .metricas-row { grid-template-columns: 1fr 1fr; }
    .tcp-detalle-grid { grid-template-columns: 1fr; }
    .tcp-label { min-width: 100px; }
}
