*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #1a1a2e;--bg-secondary: #16213e;--bg-tertiary: #0f3460;--text: #e0e0e0;--text-muted: #8888aa;--accent: #e94560;--accent-dim: #c73652;--border: #2a2a4a;--msg-user: #1a2744;--msg-bot: #1e1e3a;--tool-bg: #12122a;--input-bg: #12122a;--scrollbar: #2a2a4a;--success: #4ade80;--warning: #fbbf24}html,body{height:100%;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:14px;background:var(--bg);color:var(--text)}#app{display:flex;height:100vh;height:100dvh}#sidebar{width:200px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:width .15s ease,opacity .15s ease;overflow:hidden}#sidebar.collapsed{width:40px}#sidebar.collapsed .sidebar-header h1,#sidebar.collapsed .nav-links .nav-btn span,#sidebar.collapsed .nav-links{display:none}#sidebar.collapsed .sidebar-header{justify-content:center;padding:12px 4px}.sidebar-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;padding:4px;margin-left:auto}.sidebar-toggle:hover{color:var(--text)}.sidebar-header{padding:16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}.sidebar-header h1{font-size:16px;font-weight:600}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.connected{background:var(--success)}.status-dot.disconnected{background:var(--accent)}.nav-links{display:flex;flex-direction:column;padding:8px;gap:2px}.nav-btn{background:none;border:none;color:var(--text-muted);text-align:left;padding:8px 12px;border-radius:6px;cursor:pointer;font-family:inherit;font-size:13px}.nav-btn:hover{background:var(--border);color:var(--text)}.nav-btn.active{background:var(--bg-tertiary);color:var(--text)}#main{flex:1;display:flex;flex-direction:column;min-width:0}#toolbar{padding:8px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0}#toolbar select{background:var(--input-bg);color:var(--text);border:1px solid var(--border);padding:4px 8px;border-radius:4px;font-family:inherit;font-size:12px}#toolbar label{font-size:12px;color:var(--text-muted)}.eval-group{display:flex;align-items:center;gap:6px;margin-left:auto}#eval-btn{background:var(--input-bg);color:var(--text);border:1px solid var(--border);padding:4px 10px;border-radius:4px;font-size:12px;cursor:pointer;font-family:inherit}#eval-btn:hover{border-color:var(--text-muted)}#eval-btn:disabled{opacity:.5;cursor:default}#eval-status{font-size:11px;font-weight:700}.eval-pass{color:#4caf50}.eval-fail{color:#f44336}.eval-running{color:var(--text-muted)}.eval-panel{display:flex;height:100%;gap:16px;padding:16px;overflow:hidden}.eval-config{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.eval-results{flex:1;overflow-y:auto;border-left:1px solid var(--border);padding-left:16px}.eval-results h3{margin:0 0 8px;color:var(--text);font-size:14px}.eval-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.eval-label{font-size:12px;color:var(--text-muted);margin-top:4px}.eval-hint{font-size:11px;opacity:.6}.eval-panel textarea{background:var(--input-bg);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:8px;font-family:inherit;font-size:12px;resize:vertical;width:100%;box-sizing:border-box}.eval-panel select{background:var(--input-bg);color:var(--text);border:1px solid var(--border);padding:4px 8px;border-radius:4px;font-family:inherit;font-size:12px}.eval-btn-sm{background:var(--input-bg);color:var(--text);border:1px solid var(--border);padding:4px 10px;border-radius:4px;font-size:12px;cursor:pointer;font-family:inherit}.eval-btn-sm:hover{border-color:var(--text-muted)}.eval-btn-primary{background:#2563eb;color:#fff;border:none;padding:8px 20px;border-radius:4px;font-size:13px;cursor:pointer;font-family:inherit;font-weight:600}.eval-btn-primary:hover{background:#1d4ed8}.eval-btn-primary:disabled{opacity:.5;cursor:default}.eval-actions{display:flex;align-items:center;gap:12px;margin-top:8px}.eval-tc{background:var(--input-bg);border:1px solid var(--border);border-radius:4px;padding:8px;margin-bottom:6px}.eval-tc-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.eval-tc-name{flex:1;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:3px;padding:3px 6px;font-size:12px;font-family:inherit}.eval-tc-type{font-size:11px}.eval-tc-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:0 4px}.eval-tc-remove:hover{color:#f44336}.eval-tc-input,.eval-tc-goals{width:100%;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:3px;padding:4px 6px;font-size:12px;font-family:inherit;margin-top:3px;box-sizing:border-box}.eval-result-item{border-left:3px solid var(--border);padding:6px 10px;margin-bottom:6px;font-size:12px}.eval-result-item.eval-pass{border-left-color:#4caf50}.eval-result-item.eval-fail{border-left-color:#f44336}.eval-result-header{display:flex;align-items:center;gap:6px}.eval-result-score{margin-left:auto;font-weight:700}.eval-result-detail{color:var(--text-muted);font-size:11px;margin-top:4px;white-space:pre-wrap}.eval-result-trace{color:var(--text-muted);font-size:11px;margin-top:4px;font-family:monospace}.eval-result-response{color:var(--text-muted);font-size:11px;margin-top:4px;white-space:pre-wrap;max-height:200px;overflow-y:auto}#eval-score-summary{margin-bottom:12px}#panel-container{flex:1;overflow:hidden;display:flex;flex-direction:column}.chat-panel{display:flex;flex-direction:column;height:100%}.messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.messages::-webkit-scrollbar{width:6px}.messages::-webkit-scrollbar-track{background:transparent}.messages::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:3px}.message{padding:12px 16px;border-radius:8px;max-width:90%;line-height:1.5;word-wrap:break-word}.message.user{background:var(--msg-user);align-self:flex-end;border:1px solid rgba(233,69,96,.15)}.message.assistant{background:var(--msg-bot);align-self:flex-start}.message .meta{font-size:11px;color:var(--text-muted);margin-top:8px}.message .content{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}.message .content p{margin:.5em 0}.message .content p:first-child{margin-top:0}.message .content p:last-child{margin-bottom:0}.message .content pre{background:#0d0d1a;padding:8px 12px;border-radius:4px;overflow-x:auto;margin:8px 0}.message .content code{background:#0d0d1a;padding:1px 4px;border-radius:3px;font-size:13px}.message .content pre code{background:none;padding:0}.tool-card{background:var(--tool-bg);border:1px solid var(--border);border-radius:6px;padding:8px 12px;margin:4px 0;font-size:12px}.tool-card .tool-name{color:var(--accent);font-weight:600}.tool-card .tool-args{color:var(--text-muted);margin-left:8px}.tool-card .tool-result{color:var(--success);font-size:11px;margin-top:4px}.tool-card.denied .tool-result{color:var(--warning)}.escalation-banner{background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:6px;padding:6px 12px;font-size:12px;color:var(--warning);text-align:center}.streaming-indicator{display:inline-block;width:6px;height:14px;background:var(--accent);animation:blink .8s infinite;vertical-align:text-bottom;margin-left:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.chat-input-area{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:8px}.chat-input-area textarea{flex:1;background:var(--input-bg);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px;resize:none;min-height:42px;max-height:200px;line-height:1.4}.chat-input-area textarea:focus{outline:none;border-color:var(--accent)}.chat-input-area button{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:0 16px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600}.chat-input-area button:hover{background:var(--accent-dim)}.chat-input-area button:disabled{opacity:.5;cursor:not-allowed}.agents-panel{padding:16px;overflow-y:auto;height:100%}.agent-list{display:flex;flex-direction:column;gap:8px}.agent-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:12px 16px}.agent-card h3{font-size:14px;margin-bottom:4px}.agent-card .desc{font-size:12px;color:var(--text-muted);margin-bottom:8px}.agent-card .agent-meta{font-size:11px;color:var(--text-muted)}.agent-run-area{margin-top:8px;display:flex;gap:8px}.agent-run-area input{flex:1;background:var(--input-bg);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-family:inherit;font-size:12px}.agent-run-area button{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:6px 12px;cursor:pointer;font-family:inherit;font-size:12px}.agent-output{margin-top:8px;background:var(--tool-bg);border:1px solid var(--border);border-radius:4px;padding:8px 12px;font-size:12px;white-space:pre-wrap;max-height:300px;overflow-y:auto}.settings-panel{padding:16px;overflow-y:auto;height:100%}.settings-section{margin-bottom:24px}.settings-section h2{font-size:14px;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--border)}.settings-list{display:flex;flex-direction:column;gap:4px}.settings-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px}.settings-item label{display:flex;align-items:center;gap:6px;cursor:pointer}.settings-item input[type=checkbox]{accent-color:var(--accent)}.key-item{font-size:13px;padding:4px 0;color:var(--text-muted)}.terminal-panel{display:flex;flex-direction:column;height:100%}.terminal-toolbar{padding:8px 12px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);flex-shrink:0}.terminal-toolbar button{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:6px 12px;cursor:pointer;font-family:inherit;font-size:12px}.terminal-toolbar button:hover{background:var(--accent-dim)}.terminal-toolbar button:disabled{opacity:.4;cursor:not-allowed}.terminal-toolbar .term-sep{width:1px;height:20px;background:var(--border)}.terminal-toolbar .term-key{background:var(--bg-tertiary);padding:4px 8px;font-size:11px;font-weight:700}.term-buffer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:200;display:flex;align-items:center;justify-content:center}.term-buffer-modal{background:var(--bg);border:1px solid var(--border);border-radius:8px;width:90vw;height:85vh;display:flex;flex-direction:column}.term-buffer-header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);font-weight:700}.term-buffer-header span{flex:1}.term-buffer-header button{background:var(--bg-tertiary);color:var(--text);border:none;border-radius:4px;padding:4px 10px;cursor:pointer;font-family:inherit;font-size:12px}.term-buffer-header button:hover{background:var(--accent)}.term-buffer-content{padding:14px;overflow:auto;flex:1 1 0;min-height:0;font-size:13px;line-height:1.4;white-space:pre;word-break:break-all;-webkit-user-select:text;user-select:text;-webkit-touch-callout:default;background:var(--bg);color:var(--text);border:none;font-family:inherit;resize:none;outline:none;width:100%}.terminal-fullscreen #sidebar,.terminal-fullscreen #toolbar{display:none!important}.terminal-fullscreen #main{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100}.terminal-tabs{display:flex;gap:0;background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto;min-height:0}.term-tab{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;color:var(--text-muted);border-right:1px solid var(--border);cursor:pointer;white-space:nowrap}.term-tab:hover{background:var(--surface)}.term-tab.active{background:var(--surface);color:var(--text);border-bottom:2px solid var(--accent)}.term-tab.exited{opacity:.5}.term-tab-close{font-size:14px;line-height:1;opacity:.5;cursor:pointer}.term-tab-close:hover{opacity:1;color:var(--accent)}#terminal-area{flex:1;position:relative;overflow:hidden;touch-action:none}.terminal-tab-content{position:absolute;top:0;right:0;bottom:0;left:0;padding:4px}/**
 * Copyright (c) 2014 The xterm.js authors. All rights reserved.
 * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
 * https://github.com/chjj/term.js
 * @license MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 *
 * Originally forked from (with the author's permission):
 *   Fabrice Bellard's javascript vt100 for jslinux:
 *   http://bellard.org/jslinux/
 *   Copyright (c) 2011 Fabrice Bellard
 *   The original design remains. The terminal itself
 *   has been extended to include xterm CSI codes, among
 *   other features.
 */.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .xterm-accessibility-tree:not(.debug) *::selection{color:transparent}.xterm .xterm-accessibility-tree{font-family:monospace;-webkit-user-select:text;user-select:text;white-space:pre}.xterm .xterm-accessibility-tree>div{transform-origin:left;width:fit-content}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{text-decoration:double underline}.xterm-underline-3{text-decoration:wavy underline}.xterm-underline-4{text-decoration:dotted underline}.xterm-underline-5{text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{text-decoration:overline double underline}.xterm-overline.xterm-underline-3{text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}.xterm .xterm-scrollable-element>.scrollbar{cursor:default}.xterm .xterm-scrollable-element>.scrollbar>.scra{cursor:pointer;font-size:11px!important}.xterm .xterm-scrollable-element>.visible{opacity:1;background:#0000;transition:opacity .1s linear;z-index:11}.xterm .xterm-scrollable-element>.invisible{opacity:0;pointer-events:none}.xterm .xterm-scrollable-element>.invisible.fade{transition:opacity .8s linear}.xterm .xterm-scrollable-element>.shadow{position:absolute;display:none}.xterm .xterm-scrollable-element>.shadow.top{display:block;top:0;left:3px;height:3px;width:100%;box-shadow:var(--vscode-scrollbar-shadow, #000) 0 6px 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.left{display:block;top:3px;left:0;height:100%;width:3px;box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.top-left-corner{display:block;top:0;left:0;height:3px;width:3px}.xterm .xterm-scrollable-element>.shadow.top.left{box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}
