
:root{--bg:#050b14;--panel:#081526;--panel2:#0e1d33;--line:rgba(126,169,221,.18);--text:#edf6ff;--muted:#94a9c2;--blue:#55aaff;--cyan:#72f5ff;--green:#62e699;--amber:#ffbd6b;--danger:#ff6b7a;--radius:18px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,Arial,sans-serif}button,input,select,textarea{font:inherit}.app-shell{min-height:100vh;display:grid;grid-template-columns:92px minmax(0,1fr)360px;grid-template-rows:58px minmax(0,1fr);background:radial-gradient(circle at 50% 0,rgba(36,118,210,.16),transparent 44%),#040a12}.topbar{grid-column:1/4;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:0 16px;border-bottom:1px solid var(--line);background:rgba(5,12,22,.92);backdrop-filter:blur(16px)}.brand{display:flex;align-items:center;gap:10px}.brand-mark{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,#9effff,#53a2ff);color:#04101f;font-weight:900}.brand span{display:block;color:var(--muted);font-size:11px}.top-metrics{display:flex;gap:10px}.top-metrics article{height:36px;min-width:120px;display:flex;align-items:center;gap:8px;padding:0 12px;border:1px solid var(--line);border-radius:10px;background:rgba(20,42,70,.62)}.top-metrics i{color:var(--cyan)}.top-metrics span{color:var(--muted);font-size:11px}.top-metrics b{font-size:13px}.logout,.primary{border:0;border-radius:12px;background:linear-gradient(135deg,#4f9cff,#316bf0);color:#fff;font-weight:800;cursor:pointer}.logout{height:34px;padding:0 12px;background:rgba(255,255,255,.06);border:1px solid var(--line)}.sidebar{grid-row:2;display:flex;flex-direction:column;gap:8px;padding:12px 8px;border-right:1px solid var(--line);background:rgba(5,13,24,.9)}.nav{border:1px solid transparent;border-radius:13px;min-height:58px;background:transparent;color:#aac0d8;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.nav.active,.nav:hover{border-color:rgba(85,170,255,.38);background:rgba(65,140,255,.14);color:#fff}.workspace{grid-column:2;grid-row:2;min-width:0;overflow:auto;padding:12px}.view{display:none}.workspace[data-view=center] .view-center,.workspace[data-view=agents] .view-agents,.workspace[data-view=dispatcher] .view-dispatcher,.workspace[data-view=tasks] .view-tasks,.workspace[data-view=files] .view-files,.workspace[data-view=reports] .view-reports,.workspace[data-view=settings] .view-settings{display:block}.stage-panel{height:100%}.command-stage{position:relative;max-width:100%;height:calc(100vh - 84px);min-height:620px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#000;box-shadow:0 24px 80px rgba(0,0,0,.45)}.command-stage img{width:100%;height:100%;object-fit:contain;display:block;background:#000}.stage-overlay{position:absolute;left:20px;top:20px;padding:12px 14px;border:1px solid rgba(114,245,255,.18);border-radius:14px;background:rgba(4,13,24,.58);backdrop-filter:blur(10px)}.stage-overlay span{display:block;color:var(--muted);font-size:12px;margin-top:4px}.hotspot{position:absolute;left:calc(var(--x)*1%);top:calc(var(--y)*1%);transform:translate(-50%,-50%);border:0;background:transparent;cursor:pointer}.hotspot .pulse{width:18px;height:18px;border-radius:50%;background:var(--cyan);box-shadow:0 0 0 6px rgba(114,245,255,.16),0 0 22px rgba(114,245,255,.7);display:block}.hotspot:hover .pulse,.hotspot.active .pulse{background:#fff;box-shadow:0 0 0 9px rgba(114,245,255,.22),0 0 34px rgba(114,245,255,.95)}.hotspot em{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);white-space:nowrap;border:1px solid var(--line);border-radius:10px;padding:5px 8px;background:rgba(4,13,24,.86);font-style:normal;font-size:11px;opacity:0;pointer-events:none}.hotspot:hover em,.hotspot.active em{opacity:1}.agent-panel{grid-column:3;grid-row:2;display:flex;flex-direction:column;gap:12px;margin:12px 12px 12px 0;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,rgba(12,27,48,.96),rgba(5,14,26,.96));min-width:0;overflow:hidden}.agent-head{display:flex;gap:12px;padding:16px;border-bottom:1px solid var(--line)}.agent-icon{width:48px;height:48px;border-radius:15px;display:grid;place-items:center;background:rgba(85,170,255,.14);color:#8bdcff;font-size:22px}.agent-head h2{margin:0;font-size:18px}.agent-head p{margin:5px 0;color:var(--muted);font-size:12px}.status-dot{color:var(--green);font-size:12px}.quick-actions{display:flex;flex-wrap:wrap;gap:7px;padding:0 14px}.quick-actions button{border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.04);color:#cce1f8;height:32px;padding:0 9px;cursor:pointer;font-size:12px}.chat-feed{flex:1;overflow:auto;padding:14px;display:flex;flex-direction:column;gap:10px}.empty-chat{border:1px dashed var(--line);border-radius:15px;min-height:120px;display:grid;place-items:center;color:var(--muted);text-align:center}.msg{max-width:92%;border-radius:16px;padding:12px 13px;font-size:13px;line-height:1.45}.msg.user{align-self:flex-end;background:linear-gradient(135deg,#3e86ff,#2f66d9)}.msg.bot{align-self:flex-start;background:rgba(255,255,255,.055);border:1px solid var(--line)}.msg pre{white-space:pre-wrap;font-family:inherit;margin:0}.artifact-link{display:inline-flex;align-items:center;gap:8px;margin-top:10px;border:1px solid rgba(114,245,255,.22);border-radius:12px;padding:9px 10px;color:#bdefff;text-decoration:none;background:rgba(114,245,255,.08)}.context-panel{margin:0 14px;border:1px solid var(--line);border-radius:14px;padding:10px;background:rgba(255,255,255,.035)}.selected-files{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.file-chip{display:inline-flex;gap:6px;align-items:center;border:1px solid var(--line);border-radius:999px;padding:6px 8px;background:rgba(85,170,255,.08);font-size:11px}.file-chip button{border:0;background:rgba(255,255,255,.1);color:#fff;border-radius:50%;cursor:pointer}.message-form{display:grid;grid-template-columns:1fr 48px;gap:8px;padding:14px;border-top:1px solid var(--line)}.message-form textarea{height:54px;resize:none;border:1px solid var(--line);border-radius:14px;background:#071425;color:var(--text);padding:12px;outline:none}.message-form button{border:0;border-radius:14px;background:linear-gradient(135deg,#56a5ff,#316bf0);color:#fff;font-size:18px}.module-head{margin-bottom:14px;border:1px solid var(--line);border-radius:var(--radius);padding:18px;background:rgba(255,255,255,.035)}.module-head span{color:var(--cyan);font-weight:900;font-size:11px;letter-spacing:.14em}.module-head h1{margin:8px 0 6px}.module-head p{margin:0;color:var(--muted)}.agents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.agent-card,.file-card,.task-card,.run-card,.settings-box{border:1px solid var(--line);border-radius:16px;padding:14px;background:rgba(255,255,255,.035)}.agent-card{cursor:pointer}.agent-card:hover,.agent-card.active{border-color:rgba(114,245,255,.38);box-shadow:0 0 28px rgba(114,245,255,.08)}.agent-card h3{margin:0 0 7px}.agent-card p{margin:0 0 10px;color:var(--muted);font-size:12px}.badge{display:inline-flex;border-radius:999px;padding:5px 8px;background:rgba(98,230,153,.1);color:#a8ffc7;font-size:11px}.badge.warn{background:rgba(255,189,107,.1);color:#ffd7a3}.primary{height:42px;padding:0 14px}.big-result{margin-top:14px}.task-form,.upload-form{display:flex;gap:10px;margin-bottom:14px}.task-form input,.task-form select,.upload-form input{height:42px;border:1px solid var(--line);border-radius:12px;background:#071425;color:var(--text);padding:0 12px;color-scheme:dark}.task-form input{flex:1}.task-board{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.task-column{border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.025);min-height:240px;padding:12px}.task-column h3{margin:0 0 10px;font-size:14px}.task-card{margin-bottom:10px}.task-card h4{margin:0 0 7px}.task-card small{color:var(--muted)}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.file-card button{margin-top:8px;border:1px solid var(--line);border-radius:10px;background:rgba(85,170,255,.1);color:#dcecff;height:32px;padding:0 10px;cursor:pointer}.runs-list{display:grid;gap:10px}.run-card a{color:#9eefff}.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 50% 0,rgba(65,140,255,.22),transparent 42%),#040a12}.login-card{width:min(420px,calc(100vw - 28px));border:1px solid var(--line);border-radius:24px;padding:26px;background:rgba(8,21,38,.92);box-shadow:0 28px 70px rgba(0,0,0,.4)}.login-card h1{margin:14px 0 6px}.login-card p{color:var(--muted)}.login-card label{display:block;margin:12px 0;color:#cfe1f6}.login-card input{width:100%;height:44px;margin-top:6px;border:1px solid var(--line);border-radius:12px;background:#071425;color:#fff;padding:0 12px}.login-card button{width:100%;height:44px;margin-top:12px;border:0;border-radius:12px;background:#428bff;color:#fff;font-weight:900}.login-card #loginError{margin-top:12px;color:#ff9aa7}@media(max-width:1300px){.app-shell{grid-template-columns:72px minmax(0,1fr);grid-template-rows:58px auto auto}.agent-panel{grid-column:2;grid-row:3;margin:0 12px 12px}.topbar{grid-column:1/3}.top-metrics{display:none}.task-board{grid-template-columns:1fr}.command-stage{height:auto;min-height:0}.command-stage img{height:auto}.agent-panel{min-height:520px}}


/* =========================================================
   VISUAL ALIGNMENT PATCH — situation center background
   =========================================================
   The background must remain the real command-center image.
   Do not stretch it to an arbitrary viewport height: hotspots are
   positioned in % over the actual image plane.
*/

.stage-panel {
  height: auto !important;
}

.command-stage {
  position: relative !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  aspect-ratio: 1672 / 941;
  overflow: hidden !important;
  background: #000 !important;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 24px 80px rgba(0,0,0,.45);
}

.command-stage img,
.command-stage .command-stage-bg {
  width: 100% !important;
  height: auto !important;
  max-width: none !important;
  display: block !important;
  object-fit: unset !important;
  object-position: center center !important;
  user-select: none;
  pointer-events: none;
  background: #000;
}

.hotspots {
  position: absolute !important;
  inset: 0 !important;
  z-index: 4 !important;
  pointer-events: none;
}

.hotspot {
  position: absolute !important;
  left: calc(var(--x) * 1%) !important;
  top: calc(var(--y) * 1%) !important;
  width: 34px;
  height: 34px;
  transform: translate(-50%, -50%) !important;
  border: 0 !important;
  background: transparent !important;
  cursor: pointer;
  display: grid;
  place-items: center;
  pointer-events: auto;
  padding: 0;
}

.hotspot .pulse {
  width: 13px !important;
  height: 13px !important;
  border-radius: 50%;
  background: var(--cyan);
  border: 2px solid rgba(255,255,255,.85);
  box-shadow:
    0 0 0 5px rgba(114,245,255,.14),
    0 0 18px rgba(114,245,255,.75),
    0 0 38px rgba(70,156,255,.45) !important;
  display: block;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.hotspot::before {
  content: "";
  position: absolute;
  inset: 2px;
  border-radius: 50%;
  border: 1px solid rgba(114,245,255,.38);
  background: radial-gradient(circle, rgba(114,245,255,.12), transparent 62%);
  opacity: .72;
  transform: scale(.9);
  transition: opacity .18s ease, transform .18s ease;
}

.hotspot:hover .pulse,
.hotspot.active .pulse {
  transform: scale(1.18);
  background: #ffffff;
  box-shadow:
    0 0 0 7px rgba(114,245,255,.22),
    0 0 30px rgba(114,245,255,.98),
    0 0 58px rgba(70,156,255,.62) !important;
}

.hotspot:hover::before,
.hotspot.active::before {
  opacity: 1;
  transform: scale(1.12);
}

.hotspot em {
  position: absolute;
  left: 50%;
  bottom: 35px !important;
  transform: translateX(-50%);
  white-space: nowrap;
  border: 1px solid rgba(114,245,255,.24);
  border-radius: 10px;
  padding: 5px 8px;
  background: rgba(4,13,24,.90);
  color: #eaf7ff;
  box-shadow: 0 12px 28px rgba(0,0,0,.28);
  font-style: normal;
  font-size: 11px;
  line-height: 1;
  opacity: 0;
  pointer-events: none;
  transition: opacity .16s ease, transform .16s ease;
}

.hotspot:hover em,
.hotspot.active em {
  opacity: 1;
  transform: translateX(-50%) translateY(-2px);
}

.stage-overlay {
  z-index: 5;
  max-width: min(380px, 42vw);
}

@media (max-width: 1280px) {
  .command-stage {
    min-width: 1180px;
  }

  .workspace {
    overflow: auto;
  }
}

@media (max-width: 980px) {
  .command-stage {
    min-width: 1060px;
  }

  .hotspot em {
    font-size: 10px;
  }
}
