/* ============================================
   ScAI Console · estilos armonizados con el design system de SMI.
   TODOS los selectores prefijados con #view-scai. Adapta la paleta oscura del
   prototipo a la paleta clara (--tds-* / --neutral-* / --font-sans).
   ============================================ */
#view-scai .scai-wrap { max-width: 1480px; margin: 0 auto; padding: 8px 4px 40px; font-variant-numeric: tabular-nums; }

/* Cabecera */
#view-scai .scai-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px dashed var(--neutral-200); }
#view-scai .scai-head h2 { font-size: 20px; font-weight: 800; letter-spacing: -.02em; color: var(--neutral-900); margin: 0; }
#view-scai .scai-head h2 em { font-style: normal; color: var(--tds-blue-400); }
#view-scai .scai-head .caption { font: 600 10.5px/1 var(--font-mono); letter-spacing: .16em; color: var(--neutral-400); text-transform: uppercase; }
#view-scai .scai-meta { display: flex; gap: 22px; align-items: center; font: 500 11px/1 var(--font-mono); color: var(--neutral-500); letter-spacing: .06em; }
#view-scai .scai-meta b { color: var(--neutral-800); font-weight: 700; }
#view-scai .live-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--tds-green-500); box-shadow: 0 0 0 0 var(--tds-green-500); animation: scai-pulse 2s infinite; margin-right: 6px; vertical-align: 1px; }
@keyframes scai-pulse { 0% { box-shadow: 0 0 0 0 rgba(29,140,77,.45); } 70% { box-shadow: 0 0 0 7px rgba(29,140,77,0); } 100% { box-shadow: 0 0 0 0 rgba(29,140,77,0); } }

/* Filtros */
#view-scai .scai-filters { display: flex; gap: 6px; align-items: center; margin: 14px 0 22px; padding: 10px 14px; background: var(--tds-white); border: 1px solid var(--neutral-200); border-radius: var(--tds-radius-md); }
#view-scai .scai-filters .lbl { font: 700 10.5px/1 var(--font-mono); letter-spacing: .12em; color: var(--neutral-500); text-transform: uppercase; margin-right: 8px; }
#view-scai .scai-fbtn { background: transparent; color: var(--neutral-600); border: 1px solid var(--tds-border-strong); border-radius: var(--tds-radius-sm); padding: 7px 14px; font: 600 12px/1 var(--font-sans); cursor: pointer; transition: all var(--tx-fast); }
#view-scai .scai-fbtn:hover { background: var(--neutral-50); color: var(--neutral-900); }
#view-scai .scai-fbtn.active { background: var(--tds-blue-50); color: var(--tds-blue-700); border-color: var(--tds-blue-300); }
#view-scai .scai-filters .count { margin-left: auto; font: 500 11.5px/1 var(--font-mono); color: var(--neutral-500); letter-spacing: .04em; }

/* ===== KPI strip ===== */
#view-scai .scai-kpi-grid { display: grid; grid-template-columns: 1.05fr 1.05fr 1.05fr 1.55fr 2fr; gap: 12px; margin-bottom: 24px; }
#view-scai .scai-kpi { background: var(--tds-white); border: 1px solid var(--neutral-200); border-radius: var(--tds-radius-md); padding: 16px 18px; position: relative; box-shadow: var(--shadow-xs); }
#view-scai .scai-kpi .label { font: 700 10px/1 var(--font-mono); letter-spacing: .18em; text-transform: uppercase; color: var(--neutral-500); display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
#view-scai .scai-kpi .label .tag { font-size: 9px; padding: 2px 6px; border: 1px solid var(--neutral-200); border-radius: 3px; color: var(--neutral-500); letter-spacing: .08em; background: var(--neutral-50); }
#view-scai .scai-kpi .value { font: 800 32px/1 var(--font-sans); letter-spacing: -.02em; color: var(--neutral-900); }
#view-scai .scai-kpi .value small { font: 500 14px/1 var(--font-mono); color: var(--neutral-500); margin-left: 4px; }
#view-scai .scai-kpi .sub { margin-top: 8px; font: 500 11.5px/1 var(--font-mono); color: var(--neutral-500); display: flex; align-items: center; gap: 6px; }
#view-scai .scai-kpi .delta-up { color: var(--tds-green-500); font-weight: 700; }
#view-scai .scai-kpi .delta-down { color: var(--scania-brand-red); font-weight: 700; }

#view-scai .scai-progress { height: 5px; background: var(--neutral-100); margin-top: 12px; position: relative; overflow: hidden; border-radius: 3px; }
#view-scai .scai-progress > span { display: block; height: 100%; background: linear-gradient(90deg, var(--tds-blue-300), var(--tds-blue-400)); border-radius: 3px; }
#view-scai .scai-progress-lbl { display: flex; justify-content: space-between; font: 500 10px/1 var(--font-mono); color: var(--neutral-400); margin-top: 6px; letter-spacing: .08em; }

#view-scai .scai-kpi-feedback { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: end; }
#view-scai .scai-kpi-feedback .value { font-size: 26px !important; }
#view-scai .feedback-bars { display: grid; grid-template-columns: repeat(12, 1fr); gap: 3px; height: 56px; align-items: end; }
#view-scai .feedback-bars .bar-col { display: flex; flex-direction: column; gap: 2px; justify-content: end; height: 100%; }
#view-scai .feedback-bars .bar-pos { background: var(--tds-green-500); width: 100%; border-radius: 1px; }
#view-scai .feedback-bars .bar-neg { background: var(--scania-brand-red); width: 100%; opacity: .85; border-radius: 1px; }
#view-scai .scai-legend { display: flex; gap: 14px; margin-top: 8px; font: 600 10px/1 var(--font-mono); letter-spacing: .08em; color: var(--neutral-500); }
#view-scai .scai-legend .sw { display: inline-block; width: 8px; height: 8px; margin-right: 6px; vertical-align: middle; border-radius: 1px; }

#view-scai .scai-kpi-gpu .gpu-chart { width: 100%; height: 80px; display: block; }
#view-scai .scai-kpi-gpu .gpu-meta { display: flex; justify-content: space-between; font: 500 10px/1 var(--font-mono); color: var(--neutral-400); margin-top: 4px; letter-spacing: .08em; }

/* ===== Services rows ===== */
#view-scai .scai-section-head { display: flex; align-items: baseline; justify-content: space-between; margin: 8px 0 14px; padding-bottom: 10px; border-bottom: 1px dashed var(--neutral-200); }
#view-scai .scai-section-head h3 { font-size: 16px; font-weight: 800; color: var(--neutral-900); margin: 0; letter-spacing: -.01em; }

#view-scai .services { display: flex; flex-direction: column; gap: 8px; }
#view-scai .service {
  display: grid;
  grid-template-columns:
    minmax(220px, 1.6fr)
    100px
    minmax(160px, 1fr)
    90px
    minmax(180px, 1fr)
    auto
    auto;
  background: var(--tds-white);
  border: 1px solid var(--neutral-200);
  border-radius: var(--tds-radius-md);
  align-items: stretch;
  position: relative;
  overflow: hidden;
  transition: border-color var(--tx-fast), box-shadow var(--tx-fast);
}
#view-scai .service:hover { border-color: var(--tds-border-strong); box-shadow: var(--shadow-sm); }
#view-scai .service > .cell { padding: 14px 16px; border-right: 1px solid var(--neutral-100); display: flex; flex-direction: column; justify-content: center; gap: 5px; min-width: 0; }
#view-scai .service > .cell:last-child { border-right: none; }
#view-scai .service .cell-label { font: 700 9px/1 var(--font-mono); letter-spacing: .18em; text-transform: uppercase; color: var(--neutral-400); }

#view-scai .service::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--neutral-200); }
#view-scai .service[data-state="running"]::before { background: var(--tds-green-500); }
#view-scai .service[data-state="paused"]::before  { background: var(--tds-yellow-500); }
#view-scai .service[data-state="stopped"]::before { background: var(--neutral-300); }
#view-scai .service[data-state="error"]::before   { background: var(--scania-brand-red); }

#view-scai .name-cell { padding-left: 20px; }
#view-scai .name-line { display: flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 700; color: var(--neutral-900); letter-spacing: -.01em; }
#view-scai .name-line .status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--neutral-300); flex: none; }
#view-scai .service[data-state="running"] .status-dot { background: var(--tds-green-500); box-shadow: 0 0 0 0 var(--tds-green-500); animation: scai-pulse 2.2s infinite; }
#view-scai .service[data-state="paused"] .status-dot { background: var(--tds-yellow-500); }
#view-scai .service[data-state="error"] .status-dot { background: var(--scania-brand-red); animation: scai-blink 1.2s infinite; }
@keyframes scai-blink { 50% { opacity: 0.35; } }
#view-scai .name-sub { font: 500 11px/1 var(--font-mono); color: var(--neutral-500); letter-spacing: .01em; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-top: 4px; }
#view-scai .name-sub .pill { display: inline-flex; align-items: center; gap: 4px; padding: 2px 7px; border: 1px solid var(--neutral-200); border-radius: 3px; font-size: 10px; letter-spacing: .04em; color: var(--neutral-600); background: var(--neutral-50); }
#view-scai .name-sub .pill.kind-copilot { color: var(--accent-purple); border-color: #DDD0FB; background: #F4EEFE; }
#view-scai .name-sub .pill.kind-agent   { color: var(--tds-blue-500); border-color: var(--tds-blue-100); background: var(--tds-blue-50); }
#view-scai .state-text { font: 700 10px/1 var(--font-mono); letter-spacing: .14em; text-transform: uppercase; }
#view-scai .service[data-state="running"] .state-text { color: var(--tds-green-500); }
#view-scai .service[data-state="paused"]  .state-text { color: var(--tds-yellow-500); }
#view-scai .service[data-state="stopped"] .state-text { color: var(--neutral-400); }
#view-scai .service[data-state="error"]   .state-text { color: var(--scania-brand-red); }

#view-scai .uptime-val { font: 800 20px/1 var(--font-sans); color: var(--neutral-900); }
#view-scai .uptime-unit { font: 500 10px/1 var(--font-mono); color: var(--neutral-500); letter-spacing: .1em; }

/* Sparkline */
#view-scai .spark-cell { justify-content: space-between; }
#view-scai .spark { width: 100%; height: 36px; display: block; }
#view-scai .spark-val { display: flex; justify-content: space-between; align-items: baseline; font: 500 10px/1 var(--font-mono); color: var(--neutral-500); letter-spacing: .04em; }
#view-scai .spark-val b { color: var(--neutral-800); font-weight: 700; font-size: 11px; }

/* Alert */
#view-scai .alert-cell { justify-content: center; align-items: center; }
#view-scai .alert-icon { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; border: 1px solid var(--neutral-200); }
#view-scai .alert-icon svg { width: 13px; height: 13px; }
#view-scai .alert-ok   { color: var(--tds-green-500); border-color: #BFE6CF; background: var(--tds-green-100); }
#view-scai .alert-warn { color: var(--tds-yellow-500); border-color: #F2D29D; background: #FEF3DA; }
#view-scai .alert-err  { color: var(--scania-brand-red); border-color: #F3C9C4; background: var(--tds-red-100); }
#view-scai .alert-label { font: 700 9px/1 var(--font-mono); letter-spacing: .14em; color: var(--neutral-500); text-align: center; margin-top: 6px; text-transform: uppercase; }

/* Feedback */
#view-scai .fb-cell { gap: 6px; }
#view-scai .fb-counts { display: flex; justify-content: space-between; align-items: baseline; font: 500 11.5px/1 var(--font-mono); }
#view-scai .fb-counts .pos { color: var(--tds-green-500); font-weight: 700; }
#view-scai .fb-counts .neg { color: var(--scania-brand-red); font-weight: 700; }
#view-scai .fb-counts .ratio { color: var(--neutral-500); font-size: 10.5px; letter-spacing: .04em; }
#view-scai .fb-bar { height: 5px; background: var(--scania-brand-red); display: flex; overflow: hidden; border-radius: 3px; }
#view-scai .fb-bar .fill { height: 100%; background: var(--tds-green-500); border-radius: 3px 0 0 3px; }

/* Controls */
#view-scai .controls-cell { padding: 10px 12px; flex-direction: row; gap: 5px; align-items: center; justify-content: center; }
#view-scai .btn-ctrl { width: 32px; height: 32px; border: 1px solid var(--neutral-200); background: var(--tds-white); color: var(--neutral-500); cursor: pointer; display: grid; place-items: center; transition: all var(--tx-fast); padding: 0; border-radius: var(--tds-radius-sm); }
#view-scai .btn-ctrl svg { width: 12px; height: 12px; }
#view-scai .btn-ctrl:hover { color: var(--neutral-900); border-color: var(--tds-border-strong); background: var(--neutral-50); }
#view-scai .btn-ctrl.play.active  { border-color: var(--tds-green-500); color: var(--tds-green-500); background: var(--tds-green-100); }
#view-scai .btn-ctrl.pause.active { border-color: var(--tds-yellow-500); color: var(--tds-yellow-500); background: #FEF3DA; }
#view-scai .btn-ctrl.stop.active  { border-color: var(--scania-brand-red); color: var(--scania-brand-red); background: var(--tds-red-100); }

/* Details */
#view-scai .details-cell { padding: 10px 14px; justify-content: center; }
#view-scai .btn-details { border: 1px solid var(--neutral-200); background: transparent; color: var(--neutral-800); font: 700 10px/1 var(--font-mono); letter-spacing: .14em; padding: 9px 12px; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; text-transform: uppercase; transition: all var(--tx-fast); white-space: nowrap; border-radius: var(--tds-radius-sm); }
#view-scai .btn-details:hover { border-color: var(--tds-blue-300); color: var(--tds-blue-500); background: var(--tds-blue-50); }
#view-scai .btn-details svg { width: 11px; height: 11px; }

/* Modal de detalle */
#view-scai .scai-modal-backdrop { position: fixed; inset: 0; background: rgba(15,23,42,.55); backdrop-filter: blur(4px); display: none; z-index: 1000; align-items: center; justify-content: center; padding: 24px; }
#view-scai .scai-modal-backdrop.open { display: flex; }
#view-scai .scai-modal { background: var(--tds-white); border: 1px solid var(--neutral-200); border-radius: var(--tds-radius-lg); max-width: 640px; width: 100%; padding: 28px 32px; position: relative; box-shadow: var(--shadow-lg, 0 16px 48px rgba(15,23,42,.18)); }
#view-scai .scai-modal .cap { font: 800 10px/1 var(--font-mono); letter-spacing: .2em; color: var(--tds-blue-400); text-transform: uppercase; }
#view-scai .scai-modal h3 { font: 800 22px/1.2 var(--font-sans); margin: 6px 0 16px; letter-spacing: -.02em; color: var(--neutral-900); }
#view-scai .scai-modal .grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 28px; padding: 16px 0; border-top: 1px solid var(--neutral-100); border-bottom: 1px solid var(--neutral-100); }
#view-scai .scai-modal .grid > div > span { display: block; font: 700 10px/1 var(--font-mono); letter-spacing: .14em; text-transform: uppercase; color: var(--neutral-500); margin-bottom: 4px; }
#view-scai .scai-modal .grid > div > b { font: 700 16px/1.2 var(--font-sans); color: var(--neutral-900); }
#view-scai .scai-modal p { margin-top: 16px; color: var(--neutral-700); font-size: 13px; line-height: 1.5; }
#view-scai .scai-modal .close { position: absolute; top: 14px; right: 14px; width: 30px; height: 30px; background: transparent; border: 1px solid var(--neutral-200); color: var(--neutral-500); cursor: pointer; font-size: 14px; border-radius: var(--tds-radius-sm); }
#view-scai .scai-modal .close:hover { color: var(--neutral-900); border-color: var(--tds-border-strong); }

/* Foot */
#view-scai .scai-foot { margin-top: 28px; padding-top: 14px; border-top: 1px dashed var(--neutral-200); font: 500 10px/1 var(--font-mono); letter-spacing: .12em; color: var(--neutral-400); display: flex; justify-content: space-between; text-transform: uppercase; }

@media (max-width: 1200px) {
  #view-scai .scai-kpi-grid { grid-template-columns: 1fr 1fr 1fr; }
  #view-scai .scai-kpi-grid > .scai-kpi:nth-child(4),
  #view-scai .scai-kpi-grid > .scai-kpi:nth-child(5) { grid-column: span 3; }
}
@media (max-width: 900px) {
  #view-scai .scai-kpi-grid { grid-template-columns: 1fr 1fr; }
  #view-scai .scai-kpi-grid > .scai-kpi:nth-child(n) { grid-column: span 1; }
  #view-scai .service { grid-template-columns: 1fr 1fr; }
  #view-scai .service > .cell { border-right: none; border-bottom: 1px solid var(--neutral-100); }
  #view-scai .controls-cell, #view-scai .details-cell { grid-column: span 2; justify-content: flex-start; }
}
