/* ============================================================================
 * AI OPS COCKPIT — cafetele theme styling  (ai-ops.css)
 * Scoped to #obs-pane-aiops. Glass + indigo→pink→purple gradients + motion,
 * matching the lab's Protocol Observatory design language.
 * ==========================================================================*/
#obs-pane-aiops {
  --ai: #a855f7;            /* AI purple */
  --ai-2: #ec4899;          /* pink */
  --ai-ind: #ff0071;        /* indigo */
  --ai-grad: linear-gradient(120deg, #ff0071, #a855f7 55%, #ec4899);
  --glass: linear-gradient(180deg, rgba(244,244,246,.55), rgba(255,255,255,.55));
  --ok: #10b981; --warn: #f59e0b; --crit: #ef4444; --info: #64748b;
}

/* ---------- HERO ---------- */
.aiops-hero {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, rgba(255,0,113,.16), rgba(168,85,247,.10) 45%, rgba(236,72,153,.10));
  border: 1px solid rgba(168,85,247,.28);
  border-radius: 18px; padding: 20px 22px; margin-bottom: 16px;
  box-shadow: 0 18px 50px -28px rgba(168,85,247,.6), inset 0 1px 0 rgba(255,255,255,.05);
}
.aiops-hero::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(640px 160px at 12% -40%, rgba(168,85,247,.35), transparent 70%);
}
.aiops-hero-row { display:flex; align-items:center; gap:14px; flex-wrap:wrap; position:relative; z-index:1; }
.aiops-title {
  margin:0; font-size:20px; font-weight:800; letter-spacing:-.3px;
  background: var(--ai-grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.aiops-title i { -webkit-text-fill-color: initial; color:#c084fc; margin-right:6px; }
.aiops-badge {
  font-size:9px; font-weight:800; letter-spacing:.6px; color:#fff;
  background: var(--ai-grad); padding:3px 9px; border-radius:20px; vertical-align:middle;
  box-shadow:0 4px 14px -4px rgba(236,72,153,.6);
}
.aiops-sub { position:relative; z-index:1; color:var(--text-secondary); font-size:12.5px; margin-top:8px; line-height:1.55; }
.aiops-sub b { color:#cbd5e1; }

/* status pill with pulse glow */
.aiops-status {
  margin-left:auto; font-family:'JetBrains Mono',monospace; font-weight:800; font-size:14px;
  padding:8px 18px; border-radius:24px; border:1px solid; position:relative; white-space:nowrap;
}
.aiops-status::before {
  content:''; position:absolute; inset:-1px; border-radius:24px; opacity:.5;
  box-shadow:0 0 0 0 currentColor; animation: aiPulse 2s infinite;
}
@keyframes aiPulse { 0%{box-shadow:0 0 0 0 currentColor;} 70%{box-shadow:0 0 0 8px transparent;} 100%{box-shadow:0 0 0 0 transparent;} }

/* ---------- CONTROL BAR ---------- */
.aiops-controls { display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-top:16px; position:relative; z-index:1; }
.aiops-sep { width:1px; height:24px; background:rgba(255,255,255,.12); margin:0 4px; }
.aiops-demohint { color:var(--text-muted); font-size:11px; display:flex; align-items:center; gap:6px; }
.aiops-demohint i { color:var(--ai); }

/* themed buttons (extend obs-btn look) */
#obs-pane-aiops .obs-btn { border-radius:10px; font-weight:600; }
.aiops-btn-armed { background: var(--ai-grad) !important; box-shadow:0 6px 20px -6px rgba(168,85,247,.65) !important; }
.aiops-btn-kill { background:linear-gradient(120deg,#ef4444,#b91c1c) !important; }
.aiops-btn-kill.live { animation: killGlow 1.1s infinite; }
@keyframes killGlow { 0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.6);} 50%{box-shadow:0 0 0 7px rgba(239,68,68,0);} }

/* ---------- GRID LAYOUT ---------- */
.aiops-grid-top { display:grid; grid-template-columns: 300px 1fr; gap:14px; margin-bottom:14px; }
.aiops-grid-main { display:grid; grid-template-columns: 1fr 1fr; gap:14px; }
@media (max-width:1100px){ .aiops-grid-top, .aiops-grid-main { grid-template-columns:1fr; } }

.aiops-card {
  background: var(--glass);
  -webkit-backdrop-filter: blur(12px) saturate(140%); backdrop-filter: blur(12px) saturate(140%);
  border:1px solid rgba(255,0,113,.18); border-radius:16px; padding:16px;
  box-shadow:0 14px 40px -24px rgba(0,0,0,.75);
}
.aiops-card h4 {
  display:flex; align-items:center; gap:7px; margin:0 0 12px;
  font-size:11px; text-transform:uppercase; letter-spacing:.6px; color:var(--text-secondary); font-weight:700;
}
.aiops-card h4 i { color:var(--ai); }

/* ---------- MAPE-K RING ---------- */
.aiops-ringwrap { text-align:center; }
.aiops-ring { width:100%; max-width:240px; filter: drop-shadow(0 8px 24px rgba(168,85,247,.35)); }
.aiops-ring-label {
  font-family:'JetBrains Mono',monospace; font-size:12px; color:#e9d5ff; margin-top:2px; letter-spacing:.5px;
}
.aiops-phases { margin-top:12px; text-align:left; display:flex; flex-direction:column; gap:5px; }
.aiops-phase {
  display:flex; gap:8px; align-items:flex-start; font-size:11px; padding:5px 8px;
  background:rgba(255,255,255,.5); border:1px solid var(--border); border-radius:8px;
}
.aiops-phase b { color:#c084fc; min-width:54px; font-family:'JetBrains Mono',monospace; }
.aiops-phase span { color:var(--text-secondary); }

/* ---------- TELEMETRY STRIP ---------- */
.aiops-tele { display:flex; gap:18px; flex-wrap:wrap; align-items:center; }
.aiops-nfgrid { display:grid; grid-template-columns:repeat(12,1fr); gap:6px; flex:1; min-width:280px; }
@media (max-width:640px){ .aiops-nfgrid { grid-template-columns:repeat(6,1fr); } }
.aiops-nf {
  text-align:center; padding:7px 2px; border-radius:9px; background:rgba(255,255,255,.6);
  border:1px solid var(--border); transition:transform .15s, box-shadow .15s;
}
.aiops-nf:hover { transform:translateY(-2px); }
.aiops-nf-dot { width:9px; height:9px; border-radius:50%; margin:0 auto 4px; box-shadow:0 0 8px currentColor; }
.aiops-nf-dot.up { background:var(--ok); color:var(--ok); }
.aiops-nf-dot.down { background:var(--crit); color:var(--crit); animation:aiPulse 1.2s infinite; }
.aiops-nf-lbl { font-size:9px; font-family:'JetBrains Mono',monospace; color:var(--text-muted); }
.aiops-nf.down .aiops-nf-lbl { color:#fca5a5; }

.aiops-chips { display:flex; gap:8px; flex-wrap:wrap; }
.aiops-chip {
  display:flex; flex-direction:column; gap:1px; padding:7px 11px; border-radius:10px;
  background:rgba(255,255,255,.6); border:1px solid var(--border); min-width:78px;
}
.aiops-chip .k { font-size:9px; text-transform:uppercase; letter-spacing:.5px; color:var(--text-muted); }
.aiops-chip .v { font-size:15px; font-weight:700; font-family:'JetBrains Mono',monospace; color:var(--text-primary); }
.aiops-chip.ok .v { color:var(--ok);} .aiops-chip.warn .v { color:var(--warn);} .aiops-chip.crit .v { color:var(--crit);}

/* ---------- METRIC TILES ---------- */
.aiops-metrics { display:grid; grid-template-columns:repeat(auto-fill,minmax(118px,1fr)); gap:10px; }
.aiops-metric {
  position:relative; overflow:hidden; padding:12px 12px 11px; border-radius:12px;
  background:linear-gradient(180deg,rgba(255,0,113,.10),rgba(168,85,247,.04));
  border:1px solid var(--border); transition:transform .16s, box-shadow .16s, border-color .16s;
}
.aiops-metric:hover { transform:translateY(-2px); border-color:rgba(168,85,247,.4); box-shadow:0 14px 30px -18px rgba(168,85,247,.55); }
.aiops-metric::before { content:''; position:absolute; top:0; left:0; height:100%; width:3px; background:var(--ai); }
.aiops-metric .mk { font-size:10px; text-transform:uppercase; letter-spacing:.5px; color:var(--text-muted); display:flex; align-items:center; gap:5px; }
.aiops-metric .mv { font-size:22px; font-weight:800; font-family:'JetBrains Mono',monospace; margin-top:3px; }

/* ---------- REASONING STREAM ---------- */
.aiops-stream { max-height:440px; overflow:auto; display:flex; flex-direction:column; gap:7px; }
.aiops-cyc {
  border-left:3px solid var(--info); padding:8px 11px; border-radius:0 10px 10px 0;
  background:linear-gradient(90deg,rgba(255,255,255,.7),rgba(255,255,255,.4));
  animation: cycIn .35s cubic-bezier(.4,0,.2,1);
}
@keyframes cycIn { from{opacity:0; transform:translateX(-8px);} to{opacity:1; transform:none;} }
.aiops-cyc-head { display:flex; gap:8px; align-items:center; }
.aiops-cyc-n { font-family:'JetBrains Mono',monospace; font-weight:800; }
.aiops-flow { font-size:9px; color:var(--text-muted); letter-spacing:.5px; }
.aiops-outcome { margin-left:auto; font-size:9px; font-weight:800; text-transform:uppercase; padding:2px 7px; border-radius:8px; }
.aiops-cyc-body { margin-top:4px; font-size:12.5px; }
.aiops-cyc-detail { font-size:11px; color:#94a3b8; margin-top:2px; }
.aiops-heal {
  border-left:3px solid var(--ok); padding:8px 11px; border-radius:0 10px 10px 0;
  background:linear-gradient(90deg,rgba(236,253,245,.9),rgba(16,185,129,.06)); animation:cycIn .35s;
}

/* ---------- DIAGNOSIS ---------- */
.aiops-diag-head { display:flex; align-items:center; gap:8px; margin-bottom:9px; flex-wrap:wrap; }
.aiops-sev { border-radius:7px; padding:2px 9px; font-size:11px; font-weight:800; text-transform:uppercase; border:1px solid; }
.aiops-conf { margin-left:auto; font-family:'JetBrains Mono',monospace; font-size:12px; color:var(--text-secondary); }
.aiops-confbar { height:6px; background:rgba(255,255,255,.8); border-radius:4px; overflow:hidden; margin-bottom:11px; position:relative; }
.aiops-confbar > div { height:100%; background:var(--ai-grad); position:relative; }
.aiops-confbar > div::after {
  content:''; position:absolute; inset:0; background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  animation: shimmer 1.8s infinite;
}
@keyframes shimmer { from{transform:translateX(-100%);} to{transform:translateX(100%);} }
.aiops-sec { margin-bottom:9px; }
.aiops-sec .lbl { color:var(--text-muted); font-size:10px; text-transform:uppercase; letter-spacing:.5px; display:flex; gap:5px; align-items:center; }
.aiops-sec .lbl i { color:var(--ai); }
.aiops-sec .txt { color:#cbd5e1; font-size:12.5px; margin-top:2px; line-height:1.5; }
.aiops-ev { margin:4px 0 0 0; padding:0; list-style:none; }
.aiops-ev li { font-family:'JetBrains Mono',monospace; font-size:11px; color:#93c5fd; padding:2px 0 2px 14px; position:relative; }
.aiops-ev li::before { content:'▸'; position:absolute; left:0; color:var(--ai); }

/* callouts */
.aiops-callout { border-radius:10px; padding:9px 11px; margin-top:7px; font-size:12px; line-height:1.45; }
.aiops-callout.predict { background:rgba(168,85,247,.10); border-left:3px solid var(--ai); }
.aiops-callout.approve { background:rgba(245,158,11,.08); border:1px solid var(--border); margin-bottom:8px; }
.aiops-callout.escal { background:rgba(239,68,68,.07); border-left:3px solid var(--crit); margin-bottom:6px; }

/* intent */
.aiops-intent-row { display:flex; gap:8px; }
.aiops-input {
  flex:1; background:rgba(255,255,255,.8); color:var(--text-primary); border:1px solid var(--border);
  padding:10px 13px; border-radius:10px; font-size:12.5px; font-family:'Inter',sans-serif; transition:border-color .15s, box-shadow .15s;
}
.aiops-input:focus { outline:none; border-color:var(--ai); box-shadow:0 0 0 3px rgba(168,85,247,.18); }
.aiops-intent-out { font-size:12px; color:var(--text-secondary); margin-top:9px; line-height:1.5; }

/* empty / nominal */
.aiops-nominal { color:var(--ok); display:flex; gap:8px; align-items:flex-start; font-size:13px; line-height:1.5; }
.aiops-nominal i { margin-top:2px; }

/* audit */
.aiops-audit { display:none; font-family:'JetBrains Mono',monospace; font-size:11px; max-height:260px; overflow:auto; }
.aiops-audit .row { padding:4px 0; border-bottom:1px solid rgba(228,228,233,.6); display:flex; gap:9px; }
.aiops-audit .t { color:#64748b; } .aiops-audit .o { font-weight:700; } .aiops-audit .mt { color:#64748b; margin-left:auto; }

@media (prefers-reduced-motion: reduce) {
  .aiops-status::before, .aiops-nf-dot.down, .aiops-confbar > div::after, .aiops-btn-kill.live { animation:none; }
  .aiops-cyc, .aiops-heal { animation:none; }
}
