/**
 * 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 .xterm-scroll-area{visibility:hidden}.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{-webkit-user-select:text;user-select:text;white-space:pre}.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}.terminal-panel{display:flex;flex-direction:column;height:100%;background:var(--term-bg);border-radius:var(--radius-m);overflow:hidden}.terminal-toolbar{display:flex;align-items:center;justify-content:space-between;height:34px;padding:0 var(--space-3);background:var(--surface-1);border-bottom:1px solid var(--border-default);flex-shrink:0}.terminal-toolbar-left,.terminal-toolbar-right{display:flex;align-items:center;gap:var(--space-2)}.toolbar-icon{color:var(--success)}.toolbar-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.toolbar-chip{font-size:var(--font-size-xs);padding:1px var(--space-2);border-radius:var(--radius-xs);background:var(--surface-3);color:var(--text-secondary)}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:var(--radius-xs);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.toolbar-btn:hover{background:var(--surface-3);color:var(--text-primary)}.toolbar-font-size{font-size:var(--font-size-xs);color:var(--text-tertiary);font-family:var(--font-mono);min-width:32px;text-align:center}.toolbar-divider{width:1px;height:16px;background:var(--border-default);margin:0 var(--space-1)}.terminal-search-bar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-2);border-bottom:1px solid var(--border-default);color:var(--text-secondary)}.terminal-search-bar input{flex:1;background:var(--surface-3);border:1px solid var(--border-default);border-radius:var(--radius-xs);padding:var(--space-1) var(--space-2);color:var(--text-primary);font-size:var(--font-size-sm);font-family:var(--font-sans);outline:none}.terminal-search-bar input:focus{border-color:var(--accent)}.terminal-search-bar button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:var(--radius-xs);background:transparent;color:var(--text-secondary);cursor:pointer}.terminal-search-bar button:hover{background:var(--surface-3);color:var(--text-primary)}.terminal-xterm{flex:1;padding:var(--space-2);overflow:hidden}.terminal-xterm .xterm{height:100%}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}.timeline-panel{display:flex;flex-direction:column;height:100%;background:var(--surface-0);border-radius:var(--radius-m);border:1px solid var(--border-default);overflow:hidden}.timeline-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-muted);flex-shrink:0}.timeline-live{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:var(--success);text-transform:uppercase;letter-spacing:.5px}.live-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse 1.2s ease-in-out infinite}.timeline-scroll{flex:1;overflow-y:auto;padding:var(--space-3)}.timeline-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);height:100%;color:var(--text-tertiary);font-size:var(--font-size-sm)}.timeline-empty-sub{font-size:10px;opacity:.6}.timeline-track{display:flex;flex-direction:column}.timeline-node{display:flex;gap:var(--space-2);position:relative;padding-bottom:var(--space-2);animation:fadeIn .15s ease}.timeline-connector{position:absolute;left:9px;top:20px;bottom:0;width:1px;background:var(--border-default)}.timeline-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1;border:2px solid var(--surface-0)}.dot-user,.dot-response{background:var(--accent);color:#fff}.dot-tool{background:#fbbf2426;color:var(--warning);border-color:var(--surface-0)}.dot-result{background:#22d39926;color:var(--success)}.dot-thought{background:#a855f726;color:#a855f7}.dot-error{background:#f8717126;color:var(--danger)}.dot-status{background:var(--surface-3);color:var(--text-tertiary)}.dot-working{background:var(--accent);color:#fff}.timeline-node-active .timeline-dot{animation:pulse 1.2s ease-in-out infinite}.timeline-content{flex:1;min-width:0;padding-top:1px}.tl-label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:2px}.tl-expand{font-size:9px;cursor:pointer;opacity:.5}.tl-text{font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.5}.tl-working{font-size:var(--font-size-sm);color:var(--accent);font-weight:500}.tl-status{font-size:var(--font-size-xs);color:var(--text-tertiary)}.tl-user .tl-label{color:var(--accent)}.tl-attachments{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.tl-attachment-chip{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:2px 5px;border-radius:var(--radius-xs);background:var(--surface-2);color:var(--text-secondary)}.tl-thumb{width:32px;height:20px;object-fit:cover;border-radius:2px}.tl-tool .tl-label{color:var(--warning)}.tl-tool-name{display:inline-block;font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--warning);background:#fbbf2414;padding:1px 5px;border-radius:3px;margin-right:var(--space-1)}.tl-tool-args{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);word-break:break-all}.tl-result{cursor:pointer}.tl-result .tl-label{color:var(--success)}.tl-output{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;max-height:150px;overflow-y:auto;margin:2px 0 0;background:var(--surface-1);padding:var(--space-2);border-radius:var(--radius-xs);border:1px solid var(--border-muted)}.tl-thought{cursor:pointer}.tl-thought .tl-label{color:#a855f7}.tl-thought-text{font-size:var(--font-size-xs);color:var(--text-secondary);font-style:italic;line-height:1.5;white-space:pre-wrap}.tl-error .tl-label,.tl-error .tl-text{color:var(--danger)}.tl-response .tl-label{color:var(--accent)}.tl-markdown{color:var(--text-primary);font-size:var(--font-size-sm)}.tl-markdown p{margin:0 0 var(--space-2)}.tl-markdown p:last-child{margin:0}.tl-markdown code{font-family:var(--font-mono);font-size:.9em;padding:1px 4px;border-radius:3px;background:var(--surface-3)}.tl-markdown pre{background:var(--surface-2);border:1px solid var(--border-muted);border-radius:var(--radius-s);padding:var(--space-2);overflow-x:auto;margin:var(--space-2) 0}.tl-markdown pre code{background:none;padding:0;font-size:11px}.tl-markdown ul,.tl-markdown ol{padding-left:var(--space-5);margin:var(--space-2) 0}.tl-markdown strong{color:var(--text-primary)}.vitals-panel{display:flex;flex-direction:column;height:100%;background:var(--surface-0);border-radius:var(--radius-m);border:1px solid var(--border-default);overflow:hidden}.vitals-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-muted);flex-shrink:0}.vitals-cores{font-size:10px;color:var(--text-tertiary);font-family:var(--font-mono)}.vitals-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:var(--font-size-sm)}.vitals-gauges{display:flex;justify-content:space-around;padding:var(--space-3) var(--space-2);flex:1}.arc-gauge{display:flex;flex-direction:column;align-items:center;position:relative}.arc-gauge svg{filter:drop-shadow(0 0 4px rgba(45,212,191,.08))}.arc-value{transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1)}.arc-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-55%);display:flex;align-items:baseline;gap:1px}.arc-number{font-size:18px;font-weight:700;font-family:var(--font-mono);line-height:1}.arc-unit{font-size:10px;color:var(--text-tertiary);font-weight:600}.arc-title{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;font-weight:600;margin-top:-4px}.vitals-details{display:flex;flex-direction:column;gap:2px;padding:0 var(--space-3) var(--space-2);flex-shrink:0}.vitals-row{display:flex;justify-content:space-between;font-size:10px;font-family:var(--font-mono)}.vitals-key{color:var(--text-tertiary)}.vitals-val{color:var(--text-secondary)}.alert-feed-panel{display:flex;flex-direction:column;height:100%;background:var(--surface-0);border-radius:var(--radius-m);border:1px solid var(--border-default);overflow:hidden}.alert-feed-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-muted);flex-shrink:0}.alert-feed-controls{display:flex;align-items:center;gap:var(--space-2)}.monitor-dot{width:7px;height:7px;border-radius:50%;background:var(--success)}.monitor-dot.warning{background:var(--warning);animation:pulse 1.5s ease-in-out infinite}.monitor-dot.critical{background:var(--danger);animation:pulse 1s ease-in-out infinite}.heal-toggle{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:2px 8px;border:1px solid var(--border-default);border-radius:var(--radius-full);background:var(--surface-2);color:var(--text-tertiary);cursor:pointer;font-family:var(--font-sans);transition:all var(--transition-fast)}.heal-toggle:hover{border-color:var(--border-accent);color:var(--text-secondary)}.heal-toggle.active{background:#22c55e1a;border-color:#22c55e4d;color:#22c55e}.alert-feed-list{flex:1;overflow-y:auto;padding:var(--space-2);display:flex;flex-direction:column;gap:3px}.alert-feed-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);color:var(--text-tertiary);font-size:var(--font-size-xs)}.feed-alert{display:flex;flex-direction:column;border-radius:var(--radius-xs);animation:fadeIn .2s ease}.feed-alert-main{display:flex;align-items:flex-start;gap:var(--space-2);padding:6px 8px}.feed-alert-dot{width:6px;height:6px;border-radius:50%;margin-top:4px;flex-shrink:0}.feed-alert-dot.critical{background:var(--danger)}.feed-alert-dot.warning{background:var(--warning)}.feed-alert-dot.info{background:var(--accent)}.feed-alert-critical{background:#ef44440d}.feed-alert-warning{background:#facc150a}.feed-alert-info{background:#2dd4bf0a}.feed-alert-body{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.feed-alert-title{font-size:11px;font-weight:600;color:var(--text-primary)}.feed-alert-detail{font-size:10px;color:var(--text-tertiary)}.feed-alert-resolved{border-left:2px solid rgb(34,197,94)}.feed-alert-dot.healed{background:#22c55e!important;box-shadow:0 0 4px #22c55e66}.feed-alert-healing{display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:700;color:var(--accent);margin-top:2px;animation:pulse 1.5s ease-in-out infinite}.feed-alert-healed-btn{display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:700;color:#22c55e;margin-top:3px;background:none;border:none;cursor:pointer;padding:2px 0;font-family:var(--font-sans);transition:color var(--transition-fast)}.feed-alert-healed-btn:hover{color:#4ade80}.feed-alert-response{padding:4px 8px 8px 20px;animation:fadeIn .2s ease}.feed-alert-response-header{display:flex;align-items:center;gap:4px;font-size:9px;font-weight:600;color:var(--text-tertiary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px}.feed-alert-response pre{font-family:var(--font-mono);font-size:9px;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;max-height:120px;overflow-y:auto;margin:0;padding:6px 8px;background:var(--surface-1);border-radius:var(--radius-xs);border:1px solid var(--border-muted);line-height:1.5}.feed-alert-fix{display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:2px 8px;margin-top:3px;border:1px solid var(--border-accent);border-radius:var(--radius-full);background:var(--accent-muted);color:var(--accent);cursor:pointer;font-family:var(--font-sans);transition:all var(--transition-fast)}.feed-alert-fix:hover:not(:disabled){background:var(--accent);color:var(--text-inverse)}.feed-alert-fix:disabled{opacity:.4;cursor:not-allowed}.feed-alert-dismiss{display:flex;align-items:center;justify-content:center;width:16px;height:16px;border:none;border-radius:50%;background:transparent;color:var(--text-tertiary);cursor:pointer;padding:0;opacity:0;transition:opacity var(--transition-fast)}.feed-alert:hover .feed-alert-dismiss{opacity:1}.feed-alert-dismiss:hover{background:var(--surface-3);color:var(--text-secondary)}.command-bar{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--surface-1);border-top:1px solid var(--border-default);flex-shrink:0;position:relative}.command-bar.drag-over{outline:2px dashed var(--accent);outline-offset:-2px}.cmd-status{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;font-family:var(--font-mono);padding:0 var(--space-1)}.status-orb{width:7px;height:7px;border-radius:50%;transition:background .3s ease}.cmd-status-idle{color:var(--text-tertiary)}.cmd-status-idle .status-orb{background:var(--text-tertiary)}.cmd-status-thinking{color:#a855f7}.cmd-status-thinking .status-orb{background:#a855f7;animation:pulse 1.2s ease-in-out infinite}.cmd-status-executing{color:var(--warning)}.cmd-status-executing .status-orb{background:var(--warning);animation:pulse .8s ease-in-out infinite}.cmd-status-monitoring{color:var(--success)}.cmd-status-monitoring .status-orb{background:var(--success);animation:breathing 3s ease-in-out infinite}.cmd-status-healing{color:var(--danger)}.cmd-status-healing .status-orb{background:var(--danger);animation:pulse .6s ease-in-out infinite}.cmd-attachments{display:flex;flex-wrap:wrap;gap:4px;padding:0 var(--space-1)}.cmd-att-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border:1px solid var(--border-default);border-radius:var(--radius-xs);background:var(--surface-2);font-size:10px;color:var(--text-secondary)}.cmd-att-thumb{width:24px;height:16px;object-fit:cover;border-radius:2px}.cmd-att-chip button{display:flex;align-items:center;border:none;background:none;color:var(--text-tertiary);cursor:pointer;padding:0}.cmd-att-chip button:hover{color:var(--danger)}.cmd-input-row{display:flex;align-items:flex-end;gap:var(--space-2)}.cmd-actions{display:flex;align-items:center;gap:1px;flex-shrink:0}.cmd-divider{width:1px;height:16px;background:var(--border-default);margin:0 4px}.cmd-action{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-xs);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);padding:0}.cmd-action:hover:not(:disabled){background:var(--surface-2);color:var(--text-secondary)}.cmd-action:disabled{opacity:.3;cursor:not-allowed}.cmd-action.recording{color:var(--danger);background:var(--danger-muted);animation:pulse 1.5s ease-in-out infinite}.cmd-thinking.active{color:#a855f7;background:#a855f71a}.cmd-input{flex:1;resize:none;border:1px solid var(--border-default);border-radius:var(--radius-s);background:var(--surface-0);color:var(--text-primary);padding:var(--space-2) var(--space-3);font-family:var(--font-sans);font-size:var(--font-size-sm);line-height:1.5;outline:none;transition:border-color var(--transition-fast);max-height:80px}.cmd-input:focus{border-color:var(--accent)}.cmd-input::placeholder{color:var(--text-tertiary)}.cmd-send{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;border-radius:var(--radius-s);background:var(--accent);color:#fff;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.cmd-send:hover:not(:disabled){background:var(--accent-hover)}.cmd-send:disabled{opacity:.4;cursor:not-allowed}.cmd-stop{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;border-radius:var(--radius-s);background:#ef4444;color:#fff;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast);animation:fadeIn .15s ease}.cmd-stop:hover{background:#dc3232}.cmd-drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:var(--space-2);background:#2dd4bf0f;border:2px dashed var(--accent);border-radius:var(--radius-s);color:var(--accent);font-size:var(--font-size-sm);font-weight:600;pointer-events:none}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);z-index:var(--z-overlay);display:flex;justify-content:center;align-items:flex-start;padding-top:60px;animation:fadeIn .15s ease}.drawer{width:480px;max-height:70vh;background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius-l);box-shadow:var(--shadow-overlay);display:flex;flex-direction:column;overflow:hidden}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--border-default)}.drawer-title{display:flex;align-items:center;gap:var(--space-2);font-weight:700;color:var(--text-primary)}.drawer-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-xs);background:transparent;color:var(--text-secondary);cursor:pointer}.drawer-close:hover{background:var(--surface-3)}.drawer-body{flex:1;overflow-y:auto;padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.drawer-empty{padding:var(--space-6);text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm)}.skill-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-s);background:var(--surface-2);transition:all var(--transition-fast)}.skill-card.active{border-color:var(--accent);background:var(--accent-subtle)}.skill-info{flex:1;min-width:0}.skill-name{font-weight:600;font-size:var(--font-size-sm);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-1)}.skill-active-icon{color:var(--accent)}.skill-desc{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:2px;line-height:1.4}.skill-toggle{flex-shrink:0;padding:var(--space-1) var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-xs);background:transparent;color:var(--text-secondary);font-size:var(--font-size-xs);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast)}.skill-toggle:hover{background:var(--surface-3)}.skill-toggle.on{background:var(--accent);color:#fff;border-color:var(--accent)}.toast-container{position:fixed;bottom:32px;right:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);z-index:var(--z-toast);pointer-events:none}.toast{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-s);background:var(--surface-2);border:1px solid var(--border-default);box-shadow:var(--shadow-md);font-size:var(--font-size-sm);color:var(--text-primary);pointer-events:auto;animation:slideUp .2s ease;max-width:360px}.toast-info .toast-icon{color:var(--info)}.toast-success .toast-icon{color:var(--success)}.toast-warning .toast-icon{color:var(--warning)}.toast-error .toast-icon{color:var(--danger)}.toast-msg{flex:1}.toast-close{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;border-radius:var(--radius-xs);background:transparent;color:var(--text-tertiary);cursor:pointer}.toast-close:hover{background:var(--surface-3);color:var(--text-primary)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=dark]{--surface-0: #111113;--surface-1: #18181b;--surface-2: #1f1f23;--surface-3: #27272b;--surface-4: #303036;--surface-overlay: rgba(0, 0, 0, .65);--border-default: #2c2c31;--border-muted: #232328;--border-accent: rgba(45, 212, 191, .2);--text-primary: #ececef;--text-secondary: #a0a0ab;--text-tertiary: #63636e;--text-link: #2dd4bf;--text-inverse: #111113;--accent: #2dd4bf;--accent-hover: #5eead4;--accent-muted: rgba(45, 212, 191, .1);--accent-subtle: rgba(45, 212, 191, .05);--success: #34d399;--success-muted: rgba(52, 211, 153, .1);--warning: #fbbf24;--warning-muted: rgba(251, 191, 36, .1);--danger: #f87171;--danger-muted: rgba(248, 113, 113, .08);--info: #60a5fa;--info-muted: rgba(96, 165, 250, .08);--chat-user-bg: rgba(45, 212, 191, .08);--chat-user-border: rgba(45, 212, 191, .15);--chat-ai-bg: #18181b;--chat-ai-border: #2c2c31;--term-bg: #111113;--term-fg: #d4d4d8;--term-cursor: #2dd4bf;--term-selection: rgba(45, 212, 191, .18);--term-black: #52525b;--term-red: #f87171;--term-green: #34d399;--term-yellow: #fbbf24;--term-blue: #60a5fa;--term-magenta: #c084fc;--term-cyan: #2dd4bf;--term-white: #d4d4d8;--term-bright-black: #71717a;--term-bright-red: #fca5a5;--term-bright-green: #6ee7b7;--term-bright-yellow: #fde68a;--term-bright-blue: #93c5fd;--term-bright-magenta: #d8b4fe;--term-bright-cyan: #5eead4;--term-bright-white: #fafafa;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--radius-xs: 4px;--radius-s: 6px;--radius-m: 10px;--radius-l: 14px;--radius-xl: 20px;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", "Cascadia Code", "Consolas", monospace;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-md: 13px;--font-size-lg: 14px;--font-size-xl: 16px;--font-size-2xl: 20px;--line-height: 1.55;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .4);--shadow-overlay: 0 24px 48px rgba(0, 0, 0, .5);--transition-fast: .12s ease;--transition-normal: .2s ease;--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--z-terminal: 1;--z-panel: 10;--z-header: 20;--z-overlay: 100;--z-toast: 200;--z-palette: 300}[data-theme=light]{--surface-0: #fafafa;--surface-1: #f4f4f5;--surface-2: #e4e4e7;--surface-3: #d4d4d8;--surface-4: #c4c4cc;--surface-overlay: rgba(9, 9, 11, .25);--border-default: #d4d4d8;--border-muted: #e4e4e7;--border-accent: rgba(13, 148, 136, .25);--text-primary: #09090b;--text-secondary: #52525b;--text-tertiary: #a1a1aa;--text-link: #0d9488;--text-inverse: #fafafa;--accent: #0d9488;--accent-hover: #0f766e;--accent-muted: rgba(13, 148, 136, .08);--accent-subtle: rgba(13, 148, 136, .04);--success: #059669;--success-muted: rgba(5, 150, 105, .08);--warning: #d97706;--warning-muted: rgba(217, 119, 6, .08);--danger: #dc2626;--danger-muted: rgba(220, 38, 38, .06);--info: #2563eb;--info-muted: rgba(37, 99, 235, .06);--chat-user-bg: rgba(13, 148, 136, .06);--chat-user-border: rgba(13, 148, 136, .12);--chat-ai-bg: #f4f4f5;--chat-ai-border: #d4d4d8;--term-bg: #18181b;--term-fg: #d4d4d8;--term-cursor: #2dd4bf;--term-selection: rgba(45, 212, 191, .25);--term-black: #52525b;--term-red: #f87171;--term-green: #34d399;--term-yellow: #fbbf24;--term-blue: #60a5fa;--term-magenta: #c084fc;--term-cyan: #2dd4bf;--term-white: #d4d4d8;--term-bright-black: #71717a;--term-bright-red: #fca5a5;--term-bright-green: #6ee7b7;--term-bright-yellow: #fde68a;--term-bright-blue: #93c5fd;--term-bright-magenta: #d8b4fe;--term-bright-cyan: #5eead4;--term-bright-white: #fafafa;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .08);--shadow-overlay: 0 24px 48px rgba(0, 0, 0, .12)}html,body,#root{height:100%;width:100%;overflow:hidden;background:var(--surface-0);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--font-size-md);line-height:var(--line-height);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::selection{background:var(--accent-muted);color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes breathing{0%,to{opacity:.6}50%{opacity:1}}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden;background:var(--surface-0);transition:box-shadow .5s ease}.glow-warn{box-shadow:inset 0 0 60px -20px #facc1514}.glow-danger{box-shadow:inset 0 0 80px -20px #ef44441a}.app-header{display:flex;align-items:center;justify-content:space-between;height:40px;padding:0 var(--space-4);background:var(--surface-1);border-bottom:1px solid var(--border-default);z-index:var(--z-header);flex-shrink:0}.header-left,.header-right{display:flex;align-items:center;gap:var(--space-3)}.header-logo{display:flex;align-items:center;gap:var(--space-2)}.logo-mark{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-s);background:var(--accent);color:#fff}.logo-text{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.connection-dot{width:7px;height:7px;border-radius:50%;background:var(--text-tertiary);transition:background var(--transition-normal)}.connection-dot.connected{background:var(--success)}.connection-dot.connecting{background:var(--warning);animation:pulse 1.5s infinite}.connection-dot.error,.connection-dot.disconnected{background:var(--danger)}.header-running{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-mono)}.header-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-s);background:var(--surface-2);color:var(--text-secondary);font-size:var(--font-size-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast)}.header-btn:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-accent)}.header-icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:var(--radius-s);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.header-icon-btn:hover{background:var(--surface-3);color:var(--text-primary)}.dashboard{display:grid;grid-template-columns:1fr 340px;gap:var(--space-2);flex:1;padding:var(--space-2);overflow:hidden;min-height:0}.tile{position:relative;overflow:hidden;border-radius:var(--radius-m)}.tile-terminal{min-height:0;border:1px solid var(--border-default);border-radius:var(--radius-m);overflow:hidden}.tile-column{display:flex;flex-direction:column;gap:var(--space-2);min-height:0;overflow:hidden}.tile-vitals{flex-shrink:0;height:210px}.tile-alerts{flex-shrink:0;height:160px}.tile-timeline{flex:1;min-height:0}.tile-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-tertiary)}.terminal-agent-overlay{position:absolute;top:var(--space-2);right:var(--space-2);display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);background:#2dd4bf14;border:1px solid rgba(45,212,191,.15);color:var(--accent);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-mono);z-index:5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;animation:fadeIn .2s ease}@media (max-width: 900px){.dashboard{grid-template-columns:1fr;grid-template-rows:1fr auto}.tile-column{flex-direction:row;height:180px}.tile-vitals,.tile-alerts,.tile-timeline{flex:1;height:100%}}
