/* ─────────────────────────────────────────────────────────────
   SentinelIQ — Socify
   Mapea las clases legacy de custom.css al sistema SOC.
   NO toca markup ni JS. Se carga DESPUÉS de custom.css para
   ganar especificidad y dar el look nuevo a páginas heredadas.

   Scope: todo dentro de body.soc (ver base.html → body class="soc").
   ───────────────────────────────────────────────────────────── */

/* ── Remapeo de variables legacy → tokens SOC (monocromo) ───
   custom.css define --bg-base, --bg-surface, --bg-card, --cyan,
   --purple, --text-primary, etc. en :root. Al re-declararlas
   dentro de .soc, todas las reglas legacy heredan los valores
   nuevos sin necesidad de tocar el markup. */
.soc {
    --bg-base:        #000000;
    --bg-surface:     #0a0a0a;
    --bg-card:        #0a0a0a;
    --bg-card-hover:  #141414;
    --bg-card-light:  #1c1c1c;
    --bg-elevated:    #141414;

    --border:         rgba(255,255,255,.10);
    --border-bright:  rgba(255,255,255,.18);

    --cyan:           #ffffff;   /* mono: acento = blanco */
    --cyan-dim:       rgba(255,255,255,.10);
    --purple:         #d4d4d4;   /* AI / púrpura legacy → gris claro */
    --purple-dim:     rgba(212,212,212,.10);

    --text-primary:   #ffffff;
    --text-secondary: #e5e5e5;
    --text-muted:     #a3a3a3;
    --text-faint:     #737373;

    /* Semánticos los conservamos para que comuniquen estado */
    --green:   #22c55e;  --green-dim: rgba(34,197,94,.16);
    --yellow:  #fbbf24;  --yellow-dim: rgba(251,191,36,.16);
    --red:     #ef4444;  --red-dim: rgba(239,68,68,.18);
    --orange:  #f97316;  --orange-dim: rgba(249,115,22,.16);
}

/* Cuerpo + main + page-content en negro puro */
.soc body,
.soc .app-layout,
.soc .main-content,
.soc .page-content { background: var(--bg) !important; }

/* ── Sidebar legacy (.sidebar / .nav-item / .nav-section) ─── */
.soc .sidebar {
    background: var(--surface) !important;
    border-right: 1px solid var(--border) !important;
}
.soc .sidebar-brand {
    background: transparent !important;
    color: var(--text) !important;
    border-bottom: 1px solid var(--border) !important;
    font-family: var(--font-display) !important;
    font-weight: 700 !important;
    letter-spacing: -0.01em !important;
}
.soc .sidebar-brand .logo-icon {
    background: linear-gradient(135deg, var(--accent), var(--ai)) !important;
    color: #000 !important;
}
.soc .nav-section {
    font-size: 9.5px !important;
    font-weight: 600 !important;
    letter-spacing: .1em !important;
    text-transform: uppercase !important;
    color: var(--muted-2) !important;
    padding: 12px 14px 4px !important;
    background: transparent !important;
}
.soc .nav-item {
    position: relative;
    display: flex !important; align-items: center !important; gap: 10px !important;
    padding: 6px 12px !important;
    border-radius: var(--r-md) !important;
    color: var(--text-2) !important;
    background: transparent !important;
    border: 0 !important;
    text-decoration: none !important;
    transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
    margin: 1px 8px !important;
    font-size: 12.5px !important;
    font-weight: 500 !important;
}
.soc .nav-item:hover {
    background: rgba(255,255,255,.04) !important;
    color: var(--text) !important;
    transform: none !important;
}
.soc .nav-item.active {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
}
.soc .nav-item.active::before {
    content: ""; position: absolute; left: -8px; top: 4px; bottom: 4px;
    width: 2px; border-radius: 0 2px 2px 0;
    background: var(--accent);
    box-shadow: 0 0 8px var(--accent);
}
.soc .nav-item .icon {
    color: var(--muted) !important;
    width: auto !important;
    background: transparent !important;
    font-size: 14px !important;
}
.soc .nav-item.active .icon { color: var(--accent) !important; }
.soc .nav-item:hover .icon  { color: var(--text) !important; }
.soc .nav-item .nav-text {
    flex: 1; font-size: 12.5px; font-weight: 500;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.soc .nav-item .badge {
    background: var(--crit) !important;
    color: #fff !important;
    font-size: 10px !important;
    padding: 1px 6px !important;
    border-radius: var(--r-pill) !important;
    border: 0 !important;
    font-weight: 700 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

/* Topbar legacy (.topbar dentro de layout antiguo) — limpiar */
.soc .topbar {
    background: var(--surface) !important;
    border-bottom: 1px solid var(--border) !important;
}
.soc .topbar-actions { display: flex; align-items: center; gap: 8px; }

/* ── Cards / paneles ──────────────────────────────────────── */
.soc .card,
.soc .stat-card {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--r-lg) !important;
    box-shadow: var(--sh-card) !important;
    transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.soc .card:hover,
.soc .stat-card:hover {
    border-color: var(--border-strong) !important;
    transform: none !important;        /* legacy translateY → off */
    background: var(--surface) !important;
}
.soc .card-header {
    border-bottom: 1px solid var(--border) !important;
    padding: 10px 14px !important;
}
.soc .card-title {
    font-family: var(--font-ui);
    font-size: var(--fs-h3) !important;
    font-weight: 600 !important;
    letter-spacing: -0.005em !important;
    color: var(--text) !important;
}

/* Stat card → variante KPI */
.soc .stat-card {
    position: relative;
    padding: 14px 16px 14px 18px !important;
    overflow: hidden;
}
.soc .stat-card::before {
    content: ""; position: absolute; top: 12px; bottom: 12px; left: 0;
    width: 3px; border-radius: 0 2px 2px 0;
    background: var(--accent);
}
.soc .stat-icon {
    color: var(--accent) !important;
    background: var(--accent-soft) !important;
}
.soc .stat-label {
    font-size: 10px !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    color: var(--muted) !important;
    font-weight: 500 !important;
}
.soc .stat-value {
    font-family: var(--font-display) !important;
    font-weight: 700 !important;
    font-size: var(--fs-kpi) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.025em !important;
    color: var(--text) !important;
    font-variant-numeric: tabular-nums;
}

.soc .metric-mini { background: rgba(255,255,255,.03); border: 1px solid var(--border); border-radius: var(--r-md); padding: 10px 12px; }
.soc .metric-mini-label { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; font-weight: 500; }
.soc .metric-mini-value { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--text); font-variant-numeric: tabular-nums; }

/* ── Botones ──────────────────────────────────────────────── */
.soc .btn,
.soc .btn-outline {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    height: 30px; padding: 0 12px !important;
    border-radius: var(--r-md) !important;
    font-size: 12px !important; font-weight: 500 !important;
    border: 1px solid var(--border-strong) !important;
    background: rgba(255,255,255,.04) !important;
    color: var(--text) !important;
    transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease) !important;
    font-family: inherit !important;
    text-transform: none !important;
    letter-spacing: -0.005em !important;
    box-shadow: none !important;
}
.soc .btn:hover,
.soc .btn-outline:hover {
    background: rgba(255,255,255,.08) !important;
    border-color: var(--border-strong) !important;
    transform: none !important;
}
.soc .btn-primary {
    background: var(--accent) !important;
    color: #051022 !important;
    border-color: transparent !important;
    font-weight: 600 !important;
}
.soc .btn-primary:hover { filter: brightness(1.08); background: var(--accent) !important; }
.soc .btn-purple {
    background: linear-gradient(180deg, color-mix(in oklab, var(--ai) 90%, white 0%), var(--ai)) !important;
    color: #fff !important; border-color: transparent !important; font-weight: 600 !important;
}
.soc .btn-success {
    background: var(--ok-soft) !important;
    border-color: color-mix(in oklab, var(--ok) 55%, transparent) !important;
    color: #86efac !important;
}
.soc .btn-danger {
    background: rgba(255,255,255,.08) !important;
    border-color: rgba(255,255,255,.35) !important;
    color: #ffffff !important;
}
.soc .btn-sm { height: 26px !important; padding: 0 10px !important; font-size: 11px !important; }
.soc .btn-lg { height: 38px !important; padding: 0 16px !important; font-size: 13px !important; }

/* ── Inputs / form ────────────────────────────────────────── */
.soc .form-control,
.soc .search-box input,
.soc input.field-input {
    width: 100%;
    height: 32px;
    padding: 0 10px !important;
    border-radius: var(--r-md) !important;
    background: rgba(255,255,255,.03) !important;
    border: 1px solid var(--border) !important;
    color: var(--text) !important;
    transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
    font-family: inherit !important;
    font-size: 12.5px !important;
}
.soc .form-control:focus,
.soc .search-box input:focus,
.soc input.field-input:focus {
    border-color: var(--border-focus) !important;
    background: rgba(255,255,255,.05) !important;
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent) !important;
    outline: 0 !important;
}
.soc .form-control::placeholder { color: var(--muted-2) !important; }
.soc textarea.form-control { height: auto; padding: 8px 10px !important; }
.soc select.form-control {
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M2 4l3 3 3-3' stroke='%2394a3b8' stroke-width='1.4' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") !important;
    background-repeat: no-repeat !important;
    background-position: right 10px center !important;
    padding-right: 26px !important;
}
.soc .form-group { margin-bottom: 14px; }
.soc .form-label {
    font-size: 11px !important;
    color: var(--muted) !important;
    font-weight: 500 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    margin-bottom: 5px !important;
    display: block;
}

/* ── Badges ──────────────────────────────────────────────── */
.soc .badge {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 2px 8px !important; border-radius: var(--r-pill) !important;
    font-size: 10.5px !important; font-weight: 500 !important;
    letter-spacing: .04em !important;
    background: rgba(255,255,255,.05) !important;
    border: 1px solid rgba(255,255,255,.1) !important;
    color: var(--text-2) !important;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    text-transform: none !important;
}
.soc .badge-success { background: var(--ok-soft)   !important; border-color: color-mix(in oklab, var(--ok)   55%, transparent) !important; color: #86efac !important; }
.soc .badge-warning { background: var(--warn-soft) !important; border-color: color-mix(in oklab, var(--warn) 55%, transparent) !important; color: #fcd34d !important; }
.soc .badge-danger  { background: rgba(255,255,255,.08) !important; border-color: rgba(255,255,255,.35) !important; color: #ffffff !important; }
.soc .badge-info    { background: var(--info-soft) !important; border-color: color-mix(in oklab, var(--info) 55%, transparent) !important; color: #67e8f9 !important; }
.soc .badge-purple  { background: var(--ai-soft)   !important; border-color: color-mix(in oklab, var(--ai)   55%, transparent) !important; color: #c4b5fd !important; }
.soc .badge-muted   { background: rgba(255,255,255,.05) !important; border-color: var(--border) !important; color: var(--muted) !important; }

/* ── Dots de estado ───────────────────────────────────────── */
.soc .dot {
    display: inline-block; width: 7px; height: 7px; border-radius: 50%;
    background: var(--muted); flex: none;
}
.soc .dot-green, .soc .dot.green   { background: var(--ok)   !important; box-shadow: 0 0 0 3px color-mix(in oklab, var(--ok)   40%, transparent); }
.soc .dot-red,   .soc .dot.red     { background: #ffffff !important; box-shadow: 0 0 0 3px rgba(255,255,255,.25); animation: dotpulse 1.2s ease-out infinite; }
.soc .dot-yellow,.soc .dot.yellow  { background: var(--warn) !important; box-shadow: 0 0 0 3px color-mix(in oklab, var(--warn) 35%, transparent); }
.soc .dot-grey,  .soc .dot.grey    { background: var(--muted)!important; }

/* ── Tabs ─────────────────────────────────────────────────── */
.soc .tabs {
    display: flex; gap: 0; padding: 0 6px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 14px;
    overflow-x: auto;
}
.soc .tab {
    position: relative;
    padding: 10px 14px !important; font-size: 12px !important; font-weight: 500 !important;
    color: var(--muted) !important; cursor: pointer; white-space: nowrap;
    background: transparent !important; border: 0 !important; border-radius: 0 !important;
    text-transform: none !important; letter-spacing: -0.005em !important;
    transition: color var(--t-fast) var(--ease);
}
.soc .tab:hover { color: var(--text-2) !important; }
.soc .tab.active {
    color: var(--text) !important;
    background: transparent !important;
}
.soc .tab.active::after {
    content: ""; position: absolute; left: 8px; right: 8px; bottom: -1px;
    height: 1.5px; background: var(--accent); border-radius: 1px;
    box-shadow: 0 0 6px var(--accent);
}

/* ── Alerts ───────────────────────────────────────────────── */
.soc .alert-box {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--border) !important;
    border-left: 3px solid var(--accent) !important;
    border-radius: var(--r-md) !important;
    padding: 10px 14px !important;
    font-size: 12.5px !important;
    color: var(--text-2) !important;
}
.soc .alert-success { background: var(--ok-soft)   !important; border-color: color-mix(in oklab, var(--ok)   45%, transparent) !important; border-left-color: var(--ok)   !important; color: #86efac !important; }
.soc .alert-warning { background: var(--warn-soft) !important; border-color: color-mix(in oklab, var(--warn) 45%, transparent) !important; border-left-color: var(--warn) !important; color: #fcd34d !important; }
.soc .alert-danger  { background: rgba(255,255,255,.05) !important; border-color: rgba(255,255,255,.25) !important; border-left-color: #ffffff !important; color: #ffffff !important; }
.soc .alert-info    { background: var(--info-soft) !important; border-color: color-mix(in oklab, var(--info) 45%, transparent) !important; border-left-color: var(--info) !important; color: #67e8f9 !important; }

/* ── Modals ───────────────────────────────────────────────── */
.soc .modal-overlay {
    background: rgba(8,13,26,.7) !important;
    backdrop-filter: blur(4px) !important;
}
.soc .modal {
    background: var(--surface) !important;
    border: 1px solid var(--border-strong) !important;
    border-radius: var(--r-lg) !important;
    box-shadow: var(--sh-pop) !important;
}

/* ── Tablas genéricas (table, table-wrap) ─────────────────── */
.soc .table-wrap { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: auto; }
.soc table.table,
.soc .table-wrap table {
    width: 100%; border-collapse: collapse;
    font-size: 12px;
    font-variant-numeric: tabular-nums;
}
.soc table.table th,
.soc .table-wrap th {
    text-align: left; font-weight: 500;
    color: var(--muted); font-size: 10.5px; letter-spacing: .04em;
    text-transform: uppercase;
    padding: 8px 12px;
    border-bottom: 1px solid var(--border);
    background: rgba(255,255,255,.015);
    white-space: nowrap;
}
.soc table.table td,
.soc .table-wrap td {
    padding: 8px 12px;
    border-bottom: 1px solid rgba(255,255,255,.04);
    color: var(--text-2);
}
.soc table.table tr:hover td,
.soc .table-wrap tr:hover td { background: rgba(255,255,255,.02); }

/* ── Code blocks ──────────────────────────────────────────── */
.soc .code-block {
    background: var(--code-bg) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--r-md) !important;
    padding: 10px 12px !important;
    font-family: var(--font-mono) !important;
    font-size: 11.5px !important;
    color: var(--text-2) !important;
}

/* ── Agent cards (módulo Agentes) ─────────────────────────── */
.soc .agent-card {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--r-lg) !important;
    box-shadow: var(--sh-card) !important;
}
.soc .agent-hostname { color: var(--text) !important; font-family: var(--font-mono) !important; font-weight: 600 !important; }
.soc .agent-ip       { color: var(--muted) !important; font-family: var(--font-mono) !important; }

/* ── Toasts ───────────────────────────────────────────────── */
.soc .toast {
    position: fixed; bottom: 20px; right: 20px; z-index: 99999;
    background: rgba(15,18,38,.96) !important;
    border: 1px solid var(--border-strong) !important;
    border-left: 3px solid var(--accent) !important;
    border-radius: var(--r-md) !important;
    color: var(--text) !important;
    padding: 10px 14px !important;
    font-size: 12.5px !important;
    box-shadow: var(--sh-pop) !important;
    backdrop-filter: blur(8px);
}
.soc .toast-success { border-left-color: var(--ok)   !important; }
.soc .toast-error   { border-left-color: #ffffff !important; }
.soc .toast-info    { border-left-color: var(--info) !important; }

/* ── Timeline (used in dashboard / runs) ──────────────────── */
.soc .timeline { position: relative; padding-left: 20px; }
.soc .timeline::before {
    content: ""; position: absolute; left: 6px; top: 6px; bottom: 6px;
    width: 1px; background: var(--border);
}
.soc .timeline-item { position: relative; padding: 8px 0; }
.soc .timeline-dot {
    position: absolute; left: -19px; top: 11px;
    width: 9px; height: 9px; border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-ring);
}

/* ── Search box (generic) ─────────────────────────────────── */
.soc .search-box {
    display: flex; align-items: center; gap: 8px;
    height: 32px; padding: 0 10px;
    background: rgba(255,255,255,.03);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
}
.soc .search-box input { height: 100% !important; border: 0 !important; box-shadow: none !important; background: transparent !important; }

/* ── Text helpers (alinear con tokens) ────────────────────── */
.soc .text-cyan   { color: var(--accent) !important; }
.soc .text-green  { color: var(--ok)     !important; }
.soc .text-red    { color: #ffffff !important; }
.soc .text-yellow { color: var(--warn)   !important; }
.soc .text-muted  { color: var(--muted)  !important; }
.soc .text-secondary { color: var(--text-2) !important; }
.soc .font-mono { font-family: var(--font-mono) !important; }

/* ── Página content padding consistent ────────────────────── */
.soc .page-content { padding: 20px 22px; }

/* ── Headings legacy mantienen jerarquía SOC ──────────────── */
.soc h1, .soc h2 { font-family: var(--font-display); letter-spacing: -0.015em; }
.soc h1 { font-size: var(--fs-h1); font-weight: 600; }
.soc h2 { font-size: var(--fs-h2); font-weight: 600; }

/* ── Progress bars ────────────────────────────────────────── */
.soc .progress-bar,
.soc .scan-progress-bar {
    background: rgba(255,255,255,.05) !important;
    border-radius: var(--r-pill);
    overflow: hidden;
    height: 6px;
}
.soc .progress-fill,
.soc .scan-progress-fill {
    background: linear-gradient(90deg, var(--accent), color-mix(in oklab, var(--accent) 70%, white 0%)) !important;
    border-radius: var(--r-pill);
}

/* ── Map legend (red map) ─────────────────────────────────── */
.soc .map-legend { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 10px 14px; }
.soc .map-legend-item { font-size: 11.5px; color: var(--text-2); }
.soc .legend-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }

/* ── Detail panels (SNMP device drawer, etc.) ─────────────── */
.soc .device-detail-panel {
    background: var(--surface) !important;
    border-left: 1px solid var(--border-strong) !important;
}
.soc .detail-row { display: grid; grid-template-columns: 130px 1fr; gap: 8px; padding: 6px 0; font-size: 12px; }
.soc .detail-label { color: var(--muted); }
.soc .detail-value { color: var(--text); word-break: break-word; }

/* ── Gauges (agent ring metrics) ──────────────────────────── */
.soc .gauge-ring { stroke: var(--accent); }
.soc .gauge-text { font-family: var(--font-display) !important; font-weight: 700 !important; }
.soc .gauge-sub { color: var(--muted) !important; font-size: 10px !important; text-transform: uppercase; letter-spacing: .08em; }

/* ── Task pills (cairn/ai studio) ─────────────────────────── */
.soc .task-pill {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,.05) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--r-pill) !important;
    padding: 2px 8px !important; font-size: 10.5px !important;
    color: var(--text-2) !important;
}

/* ═════════════════════════════════════════════════════════════
   Cairn — neutralizar paleta gold/amber/red a monocromo.
   La página tiene CSS inline con rgba(245,185,66,*), #fbbf24,
   #f97316, gradientes gold→orange→red. Se mapea a blanco/gris
   manteniendo crítico-rojo y warning-amber para semántica.
   ═════════════════════════════════════════════════════════════ */
.soc .cairn-hero {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
}
.soc .cairn-hero-iso {
    background: linear-gradient(135deg, var(--accent), var(--ai)) !important;
    box-shadow: 0 4px 16px rgba(255,255,255,.10), inset 0 1px 0 rgba(255,255,255,.20) !important;
}
.soc .cairn-hero-iso i { color: #000 !important; }
.soc .cairn-hero h2 {
    font-family: var(--font-display) !important;
    color: var(--text) !important;
}
.soc .cairn-hero p { color: var(--muted) !important; }

.soc .cairn-pill {
    background: rgba(255,255,255,.05) !important;
    color: var(--text-2) !important;
    border-color: var(--border) !important;
    font-family: var(--font-mono) !important;
}
.soc .cairn-pill.ok   { background: var(--ok-soft) !important;   color: #86efac !important; border-color: color-mix(in oklab, var(--ok)   55%, transparent) !important; }
.soc .cairn-pill.warn { background: var(--warn-soft) !important; color: #fcd34d !important; border-color: color-mix(in oklab, var(--warn) 55%, transparent) !important; }
.soc .cairn-pill.err  { background: rgba(255,255,255,.08) !important; color: #ffffff !important; border-color: rgba(255,255,255,.35) !important; }
.soc .cairn-pill.run  { background: var(--accent-soft) !important; color: var(--text) !important; border-color: var(--accent-ring) !important; }
.soc .cairn-pill .dot { background: currentColor; box-shadow: 0 0 6px currentColor; }

.soc .cairn-tabs { border-bottom: 1px solid var(--border) !important; }
.soc .cairn-tab {
    color: var(--muted) !important;
    text-transform: none !important;
    letter-spacing: -0.005em !important;
    font-size: 12.5px !important;
    font-weight: 500 !important;
    padding: 10px 16px !important;
}
.soc .cairn-tab:hover { color: var(--text-2) !important; }
.soc .cairn-tab.active {
    color: var(--text) !important;
    background: transparent !important;
    border-bottom-color: var(--accent) !important;
    font-weight: 600 !important;
}

.soc .cairn-tcard {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
    border-left: 3px solid var(--accent) !important;
}
.soc .cairn-tcard .label {
    font-size: 10px !important; letter-spacing: .08em !important;
    color: var(--muted) !important;
}
.soc .cairn-tcard .value {
    font-family: var(--font-display) !important;
    color: var(--text) !important;
    font-size: 22px !important; font-weight: 700 !important;
    letter-spacing: -0.02em !important;
}
.soc .cairn-tcard .unit { color: var(--muted) !important; }

.soc .cairn-not-cfg {
    background: var(--surface) !important;
    border: 1px dashed var(--border-strong) !important;
    color: var(--muted) !important;
}
.soc .cairn-not-cfg a { color: var(--accent) !important; border-bottom-color: var(--accent-ring) !important; }

.soc .cairn-task-pill {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-2) !important;
}
.soc .cairn-task-pill.active {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
    border-color: var(--accent-ring) !important;
    box-shadow: 0 0 0 1px var(--accent-ring), 0 0 12px rgba(255,255,255,.08) !important;
}

.soc .cairn-launch-btn {
    background: var(--accent) !important;
    color: #000 !important;
    text-transform: none !important;
    letter-spacing: -0.005em !important;
    box-shadow: 0 6px 20px rgba(255,255,255,.10), inset 0 1px 0 rgba(255,255,255,.30) !important;
    border: 0 !important; font-weight: 700 !important;
}
.soc .cairn-launch-btn:hover { filter: brightness(.95); }

.soc .cairn-bb-col.hints .cairn-bb-head { color: var(--text) !important; }
.soc .cairn-bb-col.hints .cairn-bb-head .badge {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
    border-color: var(--accent-ring) !important;
}

.soc .cairn-bb-item .label .sev.medium {
    background: var(--warn-soft) !important;
    color: #fcd34d !important;
}

.soc .cairn-hint-row button {
    background: rgba(255,255,255,.05) !important;
    border: 1px solid var(--border-strong) !important;
    color: var(--text) !important;
    text-transform: none !important;
    letter-spacing: -0.005em !important;
    font-weight: 600 !important;
}
.soc .cairn-hint-row button:hover { background: rgba(255,255,255,.10) !important; }

.soc .cairn-empty-detail i,
.soc .cairn-reason-empty i { color: var(--muted-2) !important; }

.soc .cairn-mapa-bar .toggle-pill {
    background: rgba(255,255,255,.03) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-2) !important;
}
.soc .cairn-mapa-bar .toggle-pill.active {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
    border-color: var(--accent-ring) !important;
}

.soc .cairn-mapa-side .raw-id,
.soc .cairn-mapa-side .call-row .phase {
    background: rgba(255,255,255,.06) !important;
    color: var(--text-2) !important;
    border: 1px solid var(--border) !important;
}

.soc .cairn-ooda-step {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
}
.soc .cairn-ooda-step.active {
    background: var(--accent-soft) !important;
    border-color: var(--accent-ring) !important;
    box-shadow: 0 0 24px rgba(255,255,255,.10) !important;
    transform: none !important;
}

.soc .cairn-rev.hint { border-left-color: var(--accent) !important; }
.soc .cairn-rev .rev-tag.hint {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
}
.soc .cairn-rev .rev-expand { color: var(--accent) !important; }

/* Cualquier residuo de #fbbf24 puro en inline-style — neutralizar texto.
   No usamos selector :has() para compat; en su lugar, hijos directos. */

/* ═════════════════════════════════════════════════════════════
   Network Map — neutralizar cyan (#22d3ee / rgba(34,211,238,*))
   ═════════════════════════════════════════════════════════════ */
.soc .cy-wrapper {
    border: 1px solid var(--border) !important;
    background: var(--surface) !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.03) !important;
}
.soc .cy-wrapper::before {
    background: var(--bg) !important;
}

/* Toolbar y controles del mapa */
.soc [class*="cy-"][class*="-control"],
.soc [class*="map-"][class*="-control"] {
    background: var(--surface) !important;
    border-color: var(--border) !important;
    color: var(--text-2) !important;
}

/* Cualquier color cyan hardcoded en clases del mapa */
.soc .map-legend,
.soc .map-controls,
.soc .map-info,
.soc .map-stats {
    background: var(--surface) !important;
    border-color: var(--border) !important;
    color: var(--text-2) !important;
}
.soc .map-legend-item .legend-dot.cyan,
.soc .map-legend-item .legend-dot.purple {
    background: var(--accent) !important;
}
.soc .map-legend-item .legend-dot.green { background: var(--ok) !important; }
.soc .map-legend-item .legend-dot.red   { background: var(--crit) !important; }
.soc .map-legend-item .legend-dot.yellow{ background: var(--warn) !important; }

/* Tooltips/popovers del mapa */
.soc .cy-tooltip,
.soc [class*="cy-popper"],
.soc .device-popup,
.soc .node-popover {
    background: var(--surface-2) !important;
    border: 1px solid var(--border-strong) !important;
    color: var(--text) !important;
    box-shadow: var(--sh-pop) !important;
}

/* Detalle SNMP / panel de dispositivo */
.soc .device-detail-panel {
    background: var(--surface) !important;
    border-color: var(--border) !important;
    color: var(--text) !important;
}
.soc .device-detail-panel h3,
.soc .device-detail-panel h4 { color: var(--text) !important; }

/* Stats SNMP / contadores del mapa */
.soc [class*="map-stat-"],
.soc .map-stat-card {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
    border-left: 3px solid var(--accent) !important;
}

/* Botones cyan del mapa */
.soc .cy-fit, .soc .cy-zoom-in, .soc .cy-zoom-out, .soc .cy-reset,
.soc button[class*="cy-"] {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--border-strong) !important;
    color: var(--text) !important;
}
.soc button[class*="cy-"]:hover { background: rgba(255,255,255,.08) !important; }

/* ── Network Map — neutralizar cyan/azul de TODOS los componentes inline ── */

/* Wrapper canvas Cytoscape */
.soc .cy-wrapper {
    border: 1px solid var(--border) !important;
    background:
        radial-gradient(ellipse at 0% 0%, rgba(255,255,255,.04), transparent 55%),
        radial-gradient(ellipse at 100% 100%, rgba(255,255,255,.03), transparent 55%),
        var(--bg) !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.02) !important;
}
.soc .cy-wrapper::before { background: var(--bg) !important; }

/* Toolbars / panels flotantes en el mapa */
.soc .map-controls,
.soc .map-legend,
.soc .live-feed {
    background: linear-gradient(180deg, var(--surface), var(--bg)) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-2) !important;
    box-shadow: var(--sh-pop) !important;
    backdrop-filter: blur(8px);
}

/* Filter buttons — base monocromo + cada tipo conserva su color SEMI-mutado */
.soc .filter-btn {
    background: rgba(255,255,255,.04) !important;
    color: var(--text-2) !important;
    border: 1px solid var(--border-strong) !important;
    font-family: var(--font-mono) !important;
    text-transform: none !important;
}
.soc .filter-btn:hover {
    background: rgba(255,255,255,.08) !important;
    border-color: var(--border-focus) !important;
    color: var(--text) !important;
}
/* "Todos" activo → acento blanco */
.soc .filter-btn[data-type="all"].active {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
    border-color: var(--accent-ring) !important;
    box-shadow: 0 0 12px rgba(255,255,255,.15) !important;
}
/* Tipos de dispositivo — el color del icono indica el tipo, pero el bg/border vuelven monocromo */
.soc .filter-btn[data-type="agent"].active,
.soc .filter-btn[data-type="router"].active,
.soc .filter-btn[data-type="switch"].active,
.soc .filter-btn[data-type="server_dev"].active,
.soc .filter-btn[data-type="workstation"].active,
.soc .filter-btn[data-type="printer"].active,
.soc .filter-btn[data-type="service"].active {
    background: rgba(255,255,255,.07) !important;
    border-color: var(--border-focus) !important;
    color: var(--text) !important;
    box-shadow: 0 0 12px rgba(255,255,255,.08) !important;
}
/* La marca de color se queda solo en el icono pequeño dentro del botón */
.soc .filter-btn[data-type="agent"]      .lf-dot,
.soc .filter-btn[data-type="agent"]      i { color: #86efac !important; }
.soc .filter-btn[data-type="router"]     i { color: #fcd34d !important; }
.soc .filter-btn[data-type="switch"]     i { color: #5eead4 !important; }
.soc .filter-btn[data-type="server_dev"] i { color: var(--text) !important; }
.soc .filter-btn[data-type="workstation"]i { color: var(--text-2) !important; }
.soc .filter-btn[data-type="printer"]    i { color: var(--muted) !important; }
.soc .filter-btn[data-type="service"]    i { color: #c4b5fd !important; }

/* Search del mapa */
.soc .map-search {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--border) !important;
    color: var(--text) !important;
}
.soc .map-search input {
    background: transparent !important;
    color: var(--text) !important;
    border: 0 !important;
    font-family: inherit !important;
}
.soc .map-search input:focus {
    border-color: var(--border-focus) !important;
    background: rgba(255,255,255,.06) !important;
}
.soc .map-search input::placeholder { color: var(--muted-2) !important; }

/* Live feed (panel derecho del mapa) */
.soc .live-feed-head {
    background: var(--surface) !important;
    border-bottom: 1px solid var(--border) !important;
    color: var(--text) !important;
}
.soc .lf-title {
    color: var(--text) !important;
    font-family: var(--font-display) !important;
    font-weight: 600 !important;
}
.soc .lf-count {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
    border: 1px solid var(--accent-ring) !important;
}
.soc .live-feed-body { background: var(--bg) !important; }
.soc .lf-item {
    background: rgba(255,255,255,.025) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-2) !important;
}
.soc .lf-item:hover {
    background: rgba(255,255,255,.05) !important;
    border-color: var(--border-strong) !important;
}
.soc .lf-empty { color: var(--muted) !important; }
.soc .lf-toggle {
    background: rgba(255,255,255,.05) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-2) !important;
}
.soc .lf-toggle:hover { background: rgba(255,255,255,.08) !important; color: var(--text) !important; }
.soc .lf-toggle.on {
    background: var(--accent-soft) !important;
    border-color: var(--accent-ring) !important;
    color: var(--text) !important;
}
.soc .lf-dot { box-shadow: 0 0 6px currentColor; }

/* Threat panels (ataques por país/tipo) */
.soc .threat-col-title {
    color: var(--text) !important;
    font-family: var(--font-display) !important;
    font-weight: 600 !important;
}
.soc .threat-country-row,
.soc .attack-type-row,
.soc .path-row {
    background: rgba(255,255,255,.025) !important;
    border: 1px solid var(--border) !important;
}
.soc .threat-country-row:hover,
.soc .attack-type-row:hover,
.soc .path-row:hover {
    background: rgba(255,255,255,.05) !important;
}
.soc .threat-count,
.soc .path-count { color: var(--text) !important; font-family: var(--font-mono) !important; font-weight: 700 !important; }
.soc .threat-empty { color: var(--muted) !important; }
.soc .threat-bar-wrap {
    background: rgba(255,255,255,.06) !important;
}
.soc .threat-bar-fill {
    background: linear-gradient(90deg, var(--accent), color-mix(in oklab, var(--accent) 70%, transparent)) !important;
}
.soc .attack-type-icon {
    background: rgba(255,255,255,.06) !important;
    border: 1px solid var(--border) !important;
    color: var(--text) !important;
}

/* Down alerts (popups esquina) */
.soc .down-alert {
    background: linear-gradient(180deg, var(--surface-2), var(--surface)) !important;
    border: 1px solid rgba(255,255,255,.30) !important;
    border-left: 3px solid #ffffff !important;
    color: var(--text) !important;
    box-shadow: var(--sh-pop), 0 0 24px rgba(255,255,255,.12) !important;
}
.soc .down-alert-icon { color: #ffffff !important; background: rgba(255,255,255,.08) !important; }
.soc .down-alert-title { color: var(--text) !important; font-family: var(--font-display) !important; font-weight: 700 !important; }
.soc .down-alert-name  { color: var(--text-2) !important; font-family: var(--font-mono) !important; }
.soc .down-alert-meta  { color: var(--muted) !important; }
.soc .down-alert-close { color: var(--muted) !important; }
.soc .down-alert-close:hover { color: var(--text) !important; }
.soc .down-alert-progress {
    background: rgba(255,255,255,.06) !important;
}
.soc .down-alert-progress::after {
    background: #ffffff !important;
}

/* Leyenda — formas geométricas */
.soc .map-legend .map-legend-item { color: var(--text-2) !important; }
.soc .leg-dot     { background: var(--accent) !important; box-shadow: 0 0 6px var(--accent-ring); }
.soc .leg-hex,
.soc .leg-rect,
.soc .leg-diamond { background: var(--text) !important; border: 1px solid var(--border-strong) !important; }
.soc .leg-sep     { background: var(--border) !important; }

/* Texto general dentro del mapa que estaba en cyan */
.soc .cy-wrapper ~ * [style*="color: #67e8f9"],
.soc .cy-wrapper ~ * [style*="color:#67e8f9"],
.soc .cy-wrapper ~ * [style*="color: rgba(103,232,249"] { color: var(--text-2) !important; }

/* Panel detalle de nodo seleccionado (gradiente cyan→ahora gris) */
.soc [class*="node-detail"],
.soc [class*="device-detail"],
.soc [class*="cy-panel"] {
    background: linear-gradient(180deg, var(--surface-2), var(--surface)) !important;
    border: 1px solid var(--border-strong) !important;
    color: var(--text) !important;
    box-shadow: var(--sh-pop) !important;
}

/* Badge de performance del mapa (perfBadge) */
.soc #perfBadge {
    background: linear-gradient(180deg, rgba(20,20,20,.92), rgba(10,10,10,.92)) !important;
    border: 1px solid var(--border-strong) !important;
    color: var(--text-2) !important;
    font-family: var(--font-mono) !important;
}

/* Tipos de filtro residual: hub-cyan tint */
.soc .filter-btn[data-type] {
    color: var(--text-2) !important;
}
.soc .filter-btn:not(.active) i { color: var(--muted) !important; }

/* Búsqueda del mapa con tint cyan en focus */
.soc .map-search input:focus {
    border-color: var(--border-focus) !important;
    background: rgba(255,255,255,.04) !important;
}

/* Botones cyan-pill que quedaron */
.soc [class*="lf-toggle"]:hover { color: var(--text) !important; border-color: var(--border-focus) !important; }


/* ═════════════════════════════════════════════════════════════
   Vulnerabilities — neutralizar paleta indigo/cyan/purple a mono.
   La página inline tiene rgba(99,102,241,*), rgba(0,212,255,*),
   rgba(124,58,237,*), rgba(168,85,247,*), #5b9bd5, etc.
   Mantiene los semánticos por SEVERIDAD CVSS (rojo/naranja/
   amarillo/verde/azul) que son funcionales.
   ═════════════════════════════════════════════════════════════ */

/* Hover de filas / fondos cyan-tint */
.soc .vuln-row:hover { background: rgba(255,255,255,.05) !important; }
.soc .stats-table tr:hover td { background: rgba(255,255,255,.04) !important; }
.soc .fr-finding:hover { background: rgba(255,255,255,.04) !important; }

/* Botones gradient indigo/purple → mono */
.soc .btn-gradient {
    background: var(--accent) !important;
    color: #000 !important;
    border: 0 !important;
    font-weight: 600 !important;
}
.soc .btn-gradient:hover { filter: brightness(.92); }
.soc .report-btn {
    background: var(--accent) !important;
    color: #000 !important;
    border: 0 !important;
}
.soc .report-btn:hover { filter: brightness(.92); }

/* Filter chips & focus rings */
.soc .filter-chip {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
    border-color: var(--accent-ring) !important;
}
.soc .filter-select:focus,
.soc .search-box:focus,
.soc .search-box input:focus {
    border-color: var(--border-focus) !important;
    box-shadow: 0 0 0 3px rgba(255,255,255,.12) !important;
}

/* Bulk action bar */
.soc .bulk-bar {
    background: var(--accent-soft) !important;
    border: 1px solid var(--accent-ring) !important;
    color: var(--text) !important;
}

/* False-positive buttons */
.soc .fp-reason-btn.selected {
    border-color: var(--accent) !important;
    color: var(--text) !important;
    background: var(--accent-soft) !important;
}

/* Checkbox accent */
.soc .vuln-chk { accent-color: #ffffff !important; }

/* Líneas de scan (background pattern indigo) */
.soc [class*="scan-overlay"],
.soc [style*="repeating-linear-gradient"][style*="0,212,255"] {
    background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(255,255,255,.012) 2px, rgba(255,255,255,.012) 4px) !important;
}

/* Attack-type tags — mantener verde/rojo/amarillo, neutralizar purple/cyan */
.soc .attack-bruteforce {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
}

/* KPI severity bar — KEEP semantic colors (crit/high/med/low/info funcional) */
/* (sin override aquí: los CVSS deben distinguirse por color) */

/* KPI tiles base — fondo gradient indigo → surface */
.soc .kpi-tile {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
}
.soc .kpi-tile.t-poc { --ac: var(--accent) !important; }

/* fr-tag: cve y categoría — púrpura → mono accent */
.soc .fr-tag.cve {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
    border-color: var(--accent-ring) !important;
}
.soc .fr-tag.cat {
    background: rgba(255,255,255,.04) !important;
    color: var(--text-2) !important;
    border-color: var(--border) !important;
}

/* Side panel: cabeceras / iconos cyan / labels */
.soc .vuln-side-label i { color: var(--accent) !important; }
.soc .vuln-side-copy {
    color: var(--muted) !important;
}
.soc .vuln-side-copy:hover {
    color: var(--accent) !important;
    background: var(--accent-soft) !important;
}
.soc .vuln-side-mini-btn,
.soc [class*="vuln-side"][class*="-btn"] {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
    border: 1px solid var(--accent-ring) !important;
}
.soc .vuln-side-mini-btn:hover { background: rgba(255,255,255,.12) !important; }

/* Headings con fondos gradient */
.soc [style*="background:linear-gradient(180deg,rgba(99,102,241"],
.soc [style*="background:linear-gradient(180deg, rgba(0,212,255"],
.soc [style*="background:linear-gradient(135deg,rgba(99,102,241"],
.soc [style*="background:linear-gradient(135deg, rgba(0,212,255"] {
    background: linear-gradient(180deg, var(--surface-2), var(--surface)) !important;
}

/* Scanning badge / ops counters indigo */
.soc [id="scanningBadge"],
.soc [class*="scanning-badge"] {
    background: var(--accent-soft) !important;
    color: var(--text) !important;
    border: 1px solid var(--accent-ring) !important;
}

/* Ops history rows */
.soc .ops-hist-row:hover {
    background: rgba(255,255,255,.04) !important;
    border-color: var(--border-strong) !important;
}
.soc .ops-source-menu button:hover {
    background: rgba(255,255,255,.06) !important;
    color: var(--text) !important;
}

/* Texto secundario indigo (#a5b4fc / #67e8f9 / #c084fc) que aparece en inline-styles */
.soc [style*="color:#a5b4fc"],
.soc [style*="color: #a5b4fc"],
.soc [style*="color:#67e8f9"],
.soc [style*="color: #67e8f9"],
.soc [style*="color:#c084fc"],
.soc [style*="color: #c084fc"],
.soc [style*="color:#5b9bd5"],
.soc [style*="color: #5b9bd5"] {
    color: var(--text-2) !important;
}

/* Bordes y backgrounds indigo (rgba(99,102,241,*)) → mono */
.soc [style*="background:rgba(99,102,241"],
.soc [style*="background: rgba(99,102,241"] {
    background: rgba(255,255,255,.04) !important;
}
.soc [style*="border:1px solid rgba(99,102,241"],
.soc [style*="border: 1px solid rgba(99,102,241"] {
    border-color: var(--border-strong) !important;
}
.soc [style*="background:rgba(0,212,255"],
.soc [style*="background: rgba(0,212,255"] {
    background: rgba(255,255,255,.06) !important;
}
.soc [style*="border:1px solid rgba(0,212,255"],
.soc [style*="border: 1px solid rgba(0,212,255"] {
    border-color: var(--accent-ring) !important;
}

/* Fondos de cards/paneles principales con indigo overlay */
.soc [style*="background:linear-gradient(180deg, rgba(0,212,255,.025), rgba(124,58,237"],
.soc [style*="background:linear-gradient(135deg, rgba(0,212,255,.07), rgba(124,58,237"] {
    background: linear-gradient(180deg, var(--surface-2), var(--surface)) !important;
}

/* Boxes con #111827 / #0d1320 — dark blue tint → black */
.soc [style*="background:linear-gradient(180deg,#111827,#0d1320"] {
    background: var(--surface) !important;
}
