:root{
  --bg:#0b0f17; --panel:#111726; --panel2:#0e1422; --line:#1e2941; --line2:#26324f;
  --text:#e8edf6; --muted:#8a97b1; --accent:#5b9cff; --accent2:#7c5cff;
  --good:#46d39a; --warn:#ffb547; --bad:#ff6b6b; --chip:#1b2742;
  --radius:14px; --mono:ui-monospace,SFMono-Regular,Menlo,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:15px;-webkit-font-smoothing:antialiased}
.hidden{display:none !important}
.muted{color:var(--muted);font-size:13px}
button{font-family:inherit;cursor:pointer}
input{font-family:inherit}

/* LOGIN */
.login{position:fixed;inset:0;display:grid;place-items:center;background:radial-gradient(1200px 600px at 50% -10%,#16203a,var(--bg))}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:34px 30px;width:min(360px,92vw);display:flex;flex-direction:column;gap:14px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.brand{font-weight:700;font-size:20px;letter-spacing:.3px;display:flex;align-items:center;gap:9px}
.logo{color:var(--accent);font-size:18px}
.login-card input{background:var(--panel2);border:1px solid var(--line2);color:var(--text);padding:12px 14px;border-radius:11px;font-size:15px}
.login-card button{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:0;padding:12px;border-radius:11px;font-weight:600}
.err{color:var(--bad);font-size:13px;min-height:16px}

/* APP SHELL */
.app{display:grid;grid-template-columns:260px 1fr;height:100dvh;overflow:hidden}
.sidebar{background:var(--panel2);border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:6px;overflow-y:auto}
.sidebar .brand{margin-bottom:10px;padding:0 6px}
.nav-section-label{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em;margin:16px 6px 6px}
.agent-list{display:flex;flex-direction:column;gap:3px}
.agent{display:flex;gap:11px;align-items:center;padding:9px 10px;border-radius:11px;border:1px solid transparent;text-align:left;background:none;color:var(--text);width:100%}
.agent:hover{background:var(--panel)}
.agent.active{background:var(--panel);border-color:var(--line2)}
.av{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff;flex:none}
.agent .meta{min-width:0}
.agent .nm{font-weight:600;font-size:14px;display:flex;align-items:center;gap:6px}
.agent .rl{color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tag-new{font-size:9px;background:var(--accent2);color:#fff;padding:1px 5px;border-radius:6px;letter-spacing:.04em}
.inbox-btn{background:none;border:0;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em;display:flex;align-items:center;gap:6px}
.badge{background:var(--bad);color:#fff;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700}
.ghost-btn{background:none;border:1px solid var(--line2);color:var(--muted);padding:9px;border-radius:10px;font-size:13px;margin-top:6px}
.ghost-btn:hover{color:var(--text);border-color:var(--accent)}
.logout{margin-top:auto}
.queue{color:var(--muted);font-size:11px;font-family:var(--mono);padding:8px 6px}
.urgent-mode{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;padding:4px 6px 10px}

/* MAIN */
.main{display:flex;flex-direction:column;min-width:0;min-height:0;height:100dvh}
.chat-header{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--line);background:var(--panel2)}
.hamburger{display:none;background:none;border:0;color:var(--text);font-size:20px}
.chat-title{flex:1;min-width:0}
.ct-name{font-weight:700;font-size:16px}
.ct-sub{color:var(--muted);font-size:12px}
.trust-chip{font-size:11px;padding:4px 8px;border-radius:20px;background:var(--chip);color:var(--accent);border:1px solid var(--line2);white-space:nowrap;display:flex;align-items:center;gap:5px}
.trust-chip .dial-ico{opacity:.7}
.trust-chip select{background:var(--panel2);color:var(--accent);border:0;font-size:11px;font-family:inherit;outline:none;cursor:pointer}
.group-entry .av{font-size:15px}

.messages{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px;display:flex;flex-direction:column;gap:16px}
.messages>*{flex:0 0 auto}  /* children keep natural height so the container scrolls (no flex-shrink compression) */
.empty{align-self:center;text-align:center;color:var(--text);margin-top:40px}

/* working banner (live agent status for the open agent) */
.work-banner{position:sticky;top:0;z-index:5;background:linear-gradient(90deg,rgba(91,156,255,.16),rgba(124,92,255,.10));border:1px solid var(--line2);border-radius:12px;padding:10px 14px;display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text)}
.work-banner .note{color:var(--accent)}
.work-banner .el{margin-left:auto;color:var(--muted);font-family:var(--mono);font-size:12px}
.spin{width:13px;height:13px;border:2px solid var(--line2);border-top-color:var(--accent);border-radius:50%;display:inline-block;animation:sp .8s linear infinite;flex:none}
@keyframes sp{to{transform:rotate(360deg)}}

/* thread card */
.thread{border:1px solid var(--line);border-radius:16px;background:var(--panel2);overflow:hidden}
.thread.flash{animation:fl 1.6s ease}
@keyframes fl{0%,100%{box-shadow:none}30%{box-shadow:0 0 0 2px var(--accent)}}
.thread.collapsed{background:var(--panel2)}
.thread.collapsed .thread-head{border-bottom:0}
.thread.archived{opacity:.6}
.thread-head{display:flex;align-items:center;gap:10px;padding:11px 15px;background:var(--panel);border-bottom:1px solid var(--line);cursor:pointer}
.thread-head:hover{background:#121a2b}
.chev{color:var(--muted);font-size:11px;width:12px;flex:none}
.ttitle{font-weight:600;font-size:14px;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.thead-actions{display:flex;gap:2px;flex:none}
.thead-actions button{background:none;border:0;font-size:13px;opacity:.45;padding:3px 5px;border-radius:7px;line-height:1}
.thead-actions button:hover{opacity:1;background:var(--chip)}
.preview{padding:9px 15px 12px 39px;color:var(--muted);font-size:12.5px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.preview:hover{color:var(--text)}
.arch-bar{align-self:center}
.arch-bar button{background:none;border:1px solid var(--line2);color:var(--muted);font-size:12px;padding:5px 12px;border-radius:18px}
.arch-bar button:hover{color:var(--text);border-color:var(--accent)}
.ttime{color:var(--muted);font-size:11px;font-family:var(--mono)}
.tstatus{font-size:11px;padding:3px 9px;border-radius:20px;display:flex;align-items:center;gap:6px}
.tstatus.run{background:rgba(91,156,255,.15);color:var(--accent)}
.tstatus.done{background:var(--chip);color:var(--muted)}
.link-back{background:none;border:0;color:var(--accent);font-size:12px}
.thread-body{padding:14px;display:flex;flex-direction:column;gap:12px}

/* delegation trace */
.trace{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);background:var(--panel);border:1px dashed var(--line2);border-radius:11px;padding:9px 12px}
.trace.active{border-color:var(--accent)}
.trace .tr-dot{width:8px;height:8px;border-radius:50%;flex:none}
.trace .tr-main{flex:1}.trace .tr-main b{color:var(--text)}
.trace .live-note{color:var(--accent)}
.peek{background:none;border:1px solid var(--line2);color:var(--accent);font-size:11px;padding:3px 9px;border-radius:8px;white-space:nowrap}
.peek:hover{border-color:var(--accent)}
.who .peek{margin-left:8px}

/* per-thread reply */
.reply-box{display:flex;gap:7px;padding:10px 14px;border-top:1px solid var(--line);background:var(--panel)}
.reply-box input{flex:1;background:var(--panel2);border:1px solid var(--line2);color:var(--text);padding:8px 12px;border-radius:9px;font-size:13px}
.reply-box button{background:var(--chip);border:1px solid var(--line2);color:var(--accent);border-radius:9px;width:36px;font-size:15px}

/* sidebar live run dot */
.run-dot{width:7px;height:7px;border-radius:50%;background:transparent;display:inline-block;margin-left:2px}
.run-dot.on{background:var(--accent);box-shadow:0 0 0 0 var(--accent);animation:pulse 1.3s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(91,156,255,.6)}70%{box-shadow:0 0 0 6px rgba(91,156,255,0)}100%{box-shadow:0 0 0 0 rgba(91,156,255,0)}}
.old-messages-gap{}
.msg{max-width:760px;width:fit-content;padding:12px 15px;border-radius:14px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}
.msg.user{align-self:flex-end;background:linear-gradient(135deg,#21407a,#2b2f6e);border:1px solid var(--line2)}
.msg.assistant{align-self:flex-start;background:var(--panel);border:1px solid var(--line)}
.msg.system{align-self:center;background:transparent;color:var(--muted);font-size:13px;border:1px dashed var(--line2)}
.msg.trace{align-self:flex-start;background:transparent;color:var(--accent);font-size:13px;border:1px dashed var(--line2);padding:7px 12px}
.msg .who{font-size:11px;color:var(--muted);margin-bottom:4px;display:flex;align-items:center;gap:7px}
.msg .who .dot{width:7px;height:7px;border-radius:50%}
.msg b,.msg strong{color:#fff}
.msg code{background:var(--panel2);padding:1px 5px;border-radius:5px;font-family:var(--mono);font-size:13px}
.typing{align-self:flex-start;color:var(--muted);font-size:13px;display:flex;gap:5px;align-items:center}
.typing .d{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:b 1.2s infinite}
.typing .d:nth-child(2){animation-delay:.2s}.typing .d:nth-child(3){animation-delay:.4s}
@keyframes b{0%,60%,100%{opacity:.25}30%{opacity:1}}

/* approval card */
.card{align-self:flex-start;max-width:760px;background:var(--panel);border:1px solid var(--warn);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.card .ch{font-weight:700;color:var(--warn);display:flex;align-items:center;gap:8px}
.card .cb{color:var(--text)}
.card .actions{display:flex;gap:8px;flex-wrap:wrap}
.card button{border:0;border-radius:9px;padding:8px 14px;font-weight:600;font-size:13px}
.btn-approve{background:var(--good);color:#06241a}
.btn-edit{background:var(--chip);color:var(--text);border:1px solid var(--line2) !important}
.btn-reject{background:transparent;color:var(--bad);border:1px solid var(--bad) !important}
.card.done{border-color:var(--line)}
.ob-field{margin:6px 0;font-size:13px}
.ob-field input,.ob-field textarea{width:100%;background:var(--panel2);border:1px solid var(--line2);color:var(--text);padding:7px 10px;border-radius:8px;font-size:13px;font-family:inherit;margin-top:3px}
.perm-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--line)}
.perm-label{flex:1;font-size:13px;display:flex;flex-direction:column;gap:2px}
.perm-inst{color:var(--muted);font-size:11px}
.perm-eff{color:var(--accent);font-size:11px;font-family:var(--mono)}
.lvl-sel{background:var(--panel2);color:var(--text);border:1px solid var(--line2);border-radius:8px;padding:5px 8px;font-size:12px;font-family:inherit}
.card .status{font-size:12px;font-weight:700}

/* composer */
.composer{display:flex;gap:10px;align-items:center;padding:14px 18px;border-top:1px solid var(--line);background:var(--panel2)}
.composer input[type=text]{flex:1;background:var(--panel);border:1px solid var(--line2);color:var(--text);padding:13px 15px;border-radius:12px;font-size:15px}
.composer .urgent{color:var(--muted);font-size:12px;display:flex;align-items:center;gap:5px;white-space:nowrap}
.composer #send{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:0;padding:13px 22px;border-radius:12px;font-weight:600}
.composer #send:disabled{opacity:.5}

/* drawer */
.drawer{position:fixed;top:0;right:0;height:100dvh;width:min(420px,100vw);background:var(--panel);border-left:1px solid var(--line);z-index:30;display:flex;flex-direction:column;box-shadow:-20px 0 60px rgba(0,0,0,.5)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line);font-weight:700}
.drawer-head button{background:none;border:0;color:var(--muted);font-size:18px}
.drawer-body{overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.notif{background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:11px 13px}
.notif.unread{border-color:var(--accent)}
.notif .nt{font-weight:600;font-size:14px}
.notif .nb{color:var(--muted);font-size:13px;margin-top:2px}
.notif .tm{color:var(--muted);font-size:11px;margin-top:5px}
.kind{font-size:10px;text-transform:uppercase;letter-spacing:.1em;padding:2px 7px;border-radius:6px;background:var(--chip)}

@media(max-width:760px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;height:100dvh;width:260px;z-index:40;transform:translateX(-105%);transition:transform .22s}
  .sidebar.open{transform:none}
  .hamburger{display:block}
  .msg{max-width:90%}
}
