/* ═══════════════════════════════════════════════════════════════
   SAVA — Super Agente Virtual Autónomo — Design System
   ═══════════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── Dark theme (default) ──────────────────────────────────── */
[data-theme="dark"]{
  --bg:            #09090b;
  --bg-s:          #111113;
  --bg-t:          #18181b;
  --bg-input:      #101014;
  --surface:       #1f1f23;
  --bg-panel:      #16161a;
  --surface-h:     #27272a;
  --border:        #27272a;
  --border-h:      #3f3f46;
  --text:          #fafafa;
  --text-s:        #a1a1aa;
  --text-m:        #71717a;
  --accent:        #6366f1;
  --accent-h:      #818cf8;
  --accent-sub:    rgba(99,102,241,.08);
  --accent-glow:   rgba(99,102,241,.15);
  --green:         #22c55e;
  --yellow:        #eab308;
  --red:           #ef4444;
  --blue:          #3b82f6;
  --user-bg:       #1e1b4b;
  --user-border:   rgba(129,140,248,.32);
  --user-text:     #eef2ff;
  --user-label:    rgba(255,255,255,.86);
  --user-shadow:   0 10px 24px rgba(79,70,229,.10);
  --sidebar-bg:    #0c0c0e;
  --overlay:       rgba(0,0,0,.6);
  --shadow:        0 8px 32px rgba(0,0,0,.4);
  --code-bg:       #0d1117;
  --hljs-theme:    github-dark;
}

/* ── Light theme ───────────────────────────────────────────── */
[data-theme="light"]{
  --bg:            #fafafa;
  --bg-s:          #f4f4f5;
  --bg-t:          #e4e4e7;
  --bg-input:      #ffffff;
  --surface:       #ffffff;
  --bg-panel:      #f7f7fb;
  --surface-h:     #f4f4f5;
  --border:        #d4d4d8;
  --border-h:      #a1a1aa;
  --text:          #18181b;
  --text-s:        #52525b;
  --text-m:        #71717a;
  --accent:        #4f46e5;
  --accent-h:      #6366f1;
  --accent-sub:    rgba(79,70,229,.06);
  --accent-glow:   rgba(79,70,229,.12);
  --green:         #16a34a;
  --yellow:        #ca8a04;
  --red:           #dc2626;
  --blue:          #2563eb;
  --user-bg:       #eef2ff;
  --user-border:   rgba(79,70,229,.24);
  --user-text:     #312e81;
  --user-label:    #4338ca;
  --user-shadow:   0 10px 24px rgba(79,70,229,.08);
  --sidebar-bg:    #f0f0f2;
  --overlay:       rgba(0,0,0,.3);
  --shadow:        0 8px 32px rgba(0,0,0,.1);
  --code-bg:       #f6f8fa;
  --hljs-theme:    github;
}

:root{
  --radius: 12px;
  --radius-s: 8px;
  --radius-xs: 6px;
  --chat-max-width: 1080px;
  --ease: 150ms cubic-bezier(.4,0,.2,1);
  --mono: 'SF Mono','Cascadia Code','Fira Code','Consolas',monospace;
}

html,body{height:100%;background:var(--bg);color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--border-h)}
a{color:var(--accent-h);text-decoration:none}
a:hover{text-decoration:underline}
.rich-inline-link{display:inline-block;vertical-align:top;max-width:100%}
.rich-inline-url{display:block;margin-top:2px;font-size:11px;line-height:1.35;color:var(--text-m);font-family:var(--mono);word-break:break-all}

/* ── Layout ────────────────────────────────────────────────── */
#app{display:flex;height:100vh;overflow:hidden}

/* ── Sidebar ───────────────────────────────────────────────── */
.sidebar{
  width:280px;min-width:280px;background:var(--sidebar-bg);
  border-right:1px solid var(--border);display:flex;flex-direction:column;
  transition:margin-left .25s ease,opacity .25s ease;z-index:20;
  overflow:hidden;
}
.sidebar.collapsed{margin-left:-280px;opacity:0;pointer-events:none}

.sidebar-header{
  padding:16px 16px 12px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
}
.sidebar-logo{display:flex;align-items:center;gap:8px}
.sidebar-logo .mark{
  width:28px;height:28px;border-radius:var(--radius-xs);overflow:hidden;flex-shrink:0;
}
.sidebar-logo .mark svg{width:100%;height:100%}
.sidebar-logo .mark img{width:100%;height:100%;object-fit:contain}
.sidebar-logo span{font-weight:700;font-size:15px;letter-spacing:-.3px}
.sidebar-close{
  background:none;border:none;color:var(--text-m);cursor:pointer;padding:4px;
  border-radius:4px;display:flex;align-items:center;transition:color var(--ease);
}
.sidebar-close:hover{color:var(--text)}
.sidebar-close svg{width:18px;height:18px}

.sidebar-body{flex:1;overflow-y:auto;padding:8px 0;min-height:0}

.sb-section{padding:0 12px;margin-bottom:16px}
.sb-section-tight{margin-bottom:8px}
.sb-section-footer{margin-top:auto;padding-top:8px;border-top:1px solid var(--border)}
.sb-label{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--text-m);padding:8px 4px 6px;
}

.sb-group{padding:0 12px;margin-bottom:2px}
.sb-group-toggle{
  display:flex;align-items:center;gap:6px;padding:7px 4px;width:100%;
  background:none;border:none;cursor:pointer;font-family:inherit;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--text-m);transition:color var(--ease);
}
.sb-group-toggle:hover{color:var(--text)}
.sb-group-toggle .sb-chevron{
  width:12px;height:12px;flex-shrink:0;transition:transform .2s ease;
  margin-left:auto;opacity:.5;
}
.sb-group.collapsed .sb-chevron{transform:rotate(-90deg)}
.sb-group.collapsed .sb-group-items{display:none}
.sb-group-items{padding:0 0 4px}

.manual-embed{max-width:860px;margin:0 auto;line-height:1.7;font-size:14.5px}
.manual-embed h2{font-size:22px;margin:32px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.manual-embed h3{font-size:17px;margin:24px 0 8px;color:var(--accent)}
.manual-embed h4{font-size:14px;margin:16px 0 4px;font-weight:600}
.manual-embed p,.manual-embed li{color:var(--text-s)}
.manual-embed ul,.manual-embed ol{padding-left:20px;margin:8px 0}
.manual-embed code{background:var(--code-bg);padding:2px 6px;border-radius:4px;font-size:13px}
.manual-embed pre{background:var(--code-bg);padding:14px;border-radius:var(--radius-xs);overflow-x:auto;margin:12px 0}
.manual-embed pre code{background:none;padding:0}
.manual-embed .manual-toc{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:24px}
.manual-embed .manual-toc a{color:var(--accent);text-decoration:none;display:block;padding:3px 0;font-size:13.5px}
.manual-embed .manual-toc a:hover{text-decoration:underline}
.manual-embed .manual-section{scroll-margin-top:16px}
.manual-embed kbd{display:inline-block;padding:2px 7px;border:1px solid var(--border);border-radius:4px;font-size:12px;background:var(--surface-1);font-family:inherit}

.sb-item{
  display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-xs);
  font-size:13px;color:var(--text-s);cursor:pointer;transition:all var(--ease);
  border:none;background:none;width:100%;text-align:left;font-family:inherit;
}
.sb-item:hover{background:var(--accent-sub);color:var(--text)}
.sb-item.active{background:var(--accent-sub);color:var(--accent-h);font-weight:600}
.sb-item svg{width:16px;height:16px;flex-shrink:0;opacity:.7}
.sb-item .badge{
  margin-left:auto;font-size:10px;min-width:18px;height:18px;display:flex;
  align-items:center;justify-content:center;background:var(--accent);color:#fff;
  border-radius:100px;padding:0 5px;font-weight:700;
}

.sb-workspace{
  padding:10px 12px;margin:0 12px 8px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-xs);
  transition:all var(--ease);overflow:hidden;
}
.sb-workspace:hover{border-color:var(--accent)}
.sb-workspace-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;cursor:pointer}
.sb-workspace-heading{flex:1;min-width:0;cursor:pointer}
.sb-workspace-label{font-size:10px;color:var(--text-m);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.sb-workspace-name{font-size:13px;color:var(--text);font-weight:600;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-workspace-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.sb-workspace-action{width:28px;height:28px;border:none;background:transparent;color:var(--text-m);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--ease)}
.sb-workspace-action:hover{background:var(--accent-sub);color:var(--text)}
.sb-workspace-action svg{width:16px;height:16px}
.sb-workspace-body{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);cursor:pointer}
.sb-workspace.collapsed .sb-workspace-body{display:none}
.sb-workspace-path{font-size:11px;color:var(--text-m);font-family:var(--mono);white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;line-height:1.45}
.sb-workspace-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.sb-workspace-chevron{transition:transform var(--ease)}
.sb-workspace.collapsed .sb-workspace-chevron{transform:rotate(-90deg)}
.sb-ws-badge{display:inline-block;font-size:9px;font-weight:700;text-transform:uppercase;padding:1px 6px;border-radius:100px;background:var(--accent-sub);color:var(--accent-h);letter-spacing:.03em;margin-top:0}

.sb-panel{display:none;padding:0 12px}
.sb-panel.active{display:block}

/* ── Main panels ───────────────────────────────────────────── */
.main-panel{display:none;flex:1;overflow-y:auto;padding:40px 24px;min-height:0}
.main-panel.active{display:block}
.mp-inner{max-width:680px;margin:0 auto}
.mp-header{margin-bottom:28px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.mp-header div{flex:1}
.mp-header h2{font-size:20px;font-weight:700;letter-spacing:-.3px;color:var(--text)}
.mp-header p{font-size:13px;color:var(--text-m);margin-top:4px}
.help-btn{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text-m);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;text-decoration:none;margin-top:2px}
.help-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);text-decoration:none}
.mp-section{margin-bottom:24px}
.mp-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-m);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.mp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-s);padding:16px 20px;margin-bottom:8px;transition:border-color var(--ease)}
.mp-card:hover{border-color:var(--border-h)}
.plugin-card-expanded{padding:20px 24px}
.plugin-tool-item{font-size:13px;padding:4px 0}
.plugin-skill-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);padding:12px 16px}
.plugin-skill-card:hover{border-color:var(--accent)}
.plugin-skill-card code{font-size:11px;background:var(--surface);padding:1px 5px;border-radius:3px;border:1px solid var(--border)}
.plugin-cap-badge{font-size:11px;padding:2px 10px;border-radius:100px;background:var(--accent-sub);color:var(--accent);border:1px solid var(--accent);white-space:nowrap}
.mp-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.mp-row:last-child{border-bottom:none}
.mp-row label{font-size:14px;color:var(--text-s)}
.mp-val{font-size:14px;font-family:var(--mono);color:var(--accent-h)}
.design-system-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.design-system-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.design-system-base-form{display:flex;flex-direction:column;gap:14px}
.design-system-base-form-head{gap:12px;align-items:flex-start;flex-wrap:wrap}
.design-system-form-field-wide{grid-column:1 / -1}
.design-system-editor{min-height:420px;font-family:var(--mono);line-height:1.6}
.design-system-preview{min-height:240px;overflow:auto}
.design-system-scaffold-card{display:flex;flex-direction:column;gap:10px}
.design-scaffold-select{max-width:260px;padding:5px 8px;font-size:12px}
.design-scaffold-editor-panel{margin-top:12px;border:1px solid var(--border-color,#e2e8f0);border-radius:8px;overflow:hidden}
.design-scaffold-editor-tabs{display:flex;align-items:center;gap:4px;padding:6px 10px;background:var(--bg-subtle,#f8fafc);border-bottom:1px solid var(--border-color,#e2e8f0);flex-wrap:wrap}
.design-scaffold-editor-tab{padding:4px 12px;border:1px solid transparent;border-radius:5px;font-size:12px;cursor:pointer;background:none;color:var(--text-muted,#64748b)}
.design-scaffold-editor-tab.is-active{background:var(--bg-card,#fff);border-color:var(--border-color,#e2e8f0);color:var(--text-primary,#0f172a);font-weight:600}
.scaffold-editor-actions{margin-left:auto}
.design-scaffold-code-editor{width:100%;min-height:280px;padding:12px;font-family:'Fira Code','Cascadia Code','Courier New',monospace;font-size:12px;line-height:1.6;resize:vertical;border:none;border-radius:0;outline:none;background:var(--bg-code,#1e293b);color:#e2e8f0;tab-size:2;white-space:pre;overflow-x:auto;display:block;box-sizing:border-box}
.design-scaffold-preview{
  min-height:240px;padding:12px;border:1px solid var(--border);
  border-radius:var(--radius-s);background:var(--bg);
}
.design-scaffold-frame{
  width:100%;min-height:560px;border:1px solid var(--border);
  border-radius:12px;background:#fff;
}
.design-motion-preview{
  min-height:360px;padding:12px;border:1px solid var(--border);
  border-radius:var(--radius-s);background:#050505;
}
.design-motion-frame{
  width:100%;min-height:560px;border:1px solid var(--border);
  border-radius:8px;background:#050505;
}
.design-motion-editor-panel{
  margin:10px 0 12px;padding:12px;border:1px solid var(--border);
  border-radius:var(--radius-s);background:var(--surface);
}
.design-motion-editor-grid,
.design-motion-scene-grid,
.design-motion-export-row{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;
}
.design-motion-editor-grid label,
.design-motion-scene-grid label,
.design-motion-export-row label{
  display:grid;gap:4px;font-size:11px;font-weight:700;color:var(--text-muted);
}
.design-motion-wide{grid-column:1 / -1}
.design-motion-subtitle{font-size:13px}
.design-motion-scenes-editor{display:grid;gap:10px;margin-top:10px}
.design-motion-scene-card{
  padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--bg-subtle,#f8fafc);
}
.design-motion-scene-head{
  display:grid;grid-template-columns:auto minmax(150px,1fr) 90px 90px;gap:8px;align-items:center;margin-bottom:10px;
}
.design-motion-scene-head strong{font-size:12px;color:var(--text-primary)}
.design-motion-nested-list{display:grid;gap:6px;margin-top:8px}
.design-motion-nested-row{display:grid;grid-template-columns:120px minmax(0,1fr) 44px;gap:8px;align-items:center}
.design-motion-nested-row:has([data-motion-card-field]){grid-template-columns:140px minmax(0,1fr)}
.design-motion-color-mini{min-width:44px;padding:2px}
.design-motion-export-row{
  align-items:end;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);
}
.design-motion-export-row .btn{align-self:end}

/* Task list in sidebar */
.task-card{padding:14px 18px;margin-bottom:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-s)}
.task-card-head{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.task-card-head .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.task-card-head .dot.on{background:var(--green)}
.task-card-head .dot.off{background:var(--text-m)}
.task-card-label{font-size:13px;font-weight:600;color:var(--text)}
.task-card-cron{font-size:11px;font-family:var(--mono);color:var(--text-m)}
.task-card-meta{font-size:11px;color:var(--text-m);margin-top:4px}

/* Config panel */
.cfg-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}
.cfg-row:last-child{border-bottom:none}
.cfg-row label{font-size:14px;color:var(--text-s)}
.cfg-val{font-size:14px;font-family:var(--mono);color:var(--accent-h)}
.config-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.config-tab-btn{
  border:1px solid var(--border);background:var(--surface);color:var(--text-m);
  border-radius:999px;padding:8px 14px;font-size:12px;font-weight:700;letter-spacing:.02em;
  cursor:pointer;transition:all var(--ease);font-family:inherit;
}
.config-tab-btn:hover{border-color:var(--border-h);color:var(--text);background:var(--surface-h)}
.config-tab-btn.active{border-color:rgba(59,130,246,.32);background:rgba(59,130,246,.1);color:var(--blue)}
.config-tab-panel{display:none}
.config-tab-panel.active{display:block}
.config-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.persona-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.config-actions-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.wa-connect-qr-wrap{display:flex;justify-content:center;padding:18px 0 10px}
.wa-connect-qr-img{width:min(320px,100%);height:auto;border-radius:16px;border:1px solid var(--border);background:#fff;padding:12px}

/* Model table */
.model-table{width:100%;border-collapse:collapse;font-size:13px}
.model-table th{text-align:left;padding:8px 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-m);border-bottom:2px solid var(--border);white-space:nowrap;cursor:default;-webkit-user-select:none;user-select:none}
.model-table td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text);white-space:nowrap;font-size:12px}
.model-table tbody tr:hover{background:var(--accent-sub)}
.model-table .tier-normal{color:var(--green);font-weight:600}
.model-table .tier-robust{color:var(--accent);font-weight:600}
.model-table .cost-free{color:var(--green);font-weight:700}
.model-table .cost-unknown{color:var(--yellow);font-weight:700}

/* Profile cards */
.prof-card{display:flex;align-items:center;gap:12px;padding:12px 14px;
  background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-s);
  margin-bottom:8px;transition:all var(--ease)}
.prof-card:not(.active){cursor:pointer}
.prof-card:not(.active):hover{border-color:var(--accent);background:var(--accent-sub);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.prof-card.active{border-color:var(--accent);background:var(--accent-sub)}
.prof-card .prof-name{font-size:14px;font-weight:600;color:var(--text)}
.prof-card .prof-detail{font-size:12px;color:var(--text-m);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prof-card .prof-badge{font-size:10px;font-weight:700;color:var(--accent);
  background:var(--accent-sub);padding:2px 8px;border-radius:100px;text-transform:uppercase;margin-left:8px}
.prof-card .prof-actions{display:flex;gap:6px}
.prof-card .prof-actions button{background:none;border:1px solid var(--border);
  color:var(--text-m);cursor:pointer;padding:4px 10px;border-radius:var(--radius-xs);
  font-size:11px;font-family:inherit;transition:all var(--ease)}
.prof-card .prof-actions button:hover{border-color:var(--accent);color:var(--text)}
.prof-card .prof-actions .prof-del:hover{border-color:var(--red);color:var(--red)}

/* Form elements */
.form-label{display:block;font-size:11px;font-weight:600;color:var(--text-m);
  text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}
.form-input{width:100%;padding:8px 10px;background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-xs);color:var(--text);font-size:13px;font-family:inherit;
  box-sizing:border-box;transition:border-color var(--ease)}
.form-input:focus{outline:none;border-color:var(--accent)}
select.form-input{cursor:pointer;appearance:auto}
.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-xs);
  font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;
  transition:opacity var(--ease)}
.btn-primary:hover{opacity:.85}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Inline-style cleanup utilities */
.is-hidden{display:none !important}
.text-muted-xs{font-size:11px;color:var(--text-m)}
.text-muted-sm{font-size:12px;color:var(--text-m)}
.text-muted-md{font-size:13px;color:var(--text-m)}
.text-muted-row{font-size:13px;color:var(--text-m);padding:8px 0}
.text-muted-center{color:var(--text-m);text-align:center}
.text-danger-sm{font-size:13px;color:var(--red)}
.text-secondary-sm{font-size:13px;color:var(--text-s)}
.text-accent-lg{font-size:24px;font-weight:700;color:var(--accent)}
.text-strong-lg{font-size:24px;font-weight:700;color:var(--text)}
.text-title-caps{font-size:11px;color:var(--text-m);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.mt-2{margin-top:2px}
.mt-4{margin-top:4px}
.mt-6{margin-top:6px}
.mt-8{margin-top:8px}
.mt-10{margin-top:10px}
.mt-12{margin-top:12px}
.mt-14{margin-top:14px}
.mb-2{margin-bottom:2px}
.mb-4{margin-bottom:4px}
.mb-8{margin-bottom:8px}
.mb-10{margin-bottom:10px}
.mb-12{margin-bottom:12px}
.mb-16{margin-bottom:16px}
.w-full{width:100%}
.w-auto{width:auto}
.max-w-panel{max-width:960px}
.nowrap{white-space:nowrap}
.flex-1{flex:1}
.grow-1{flex:1;min-width:0}
.minw-200{min-width:200px}
.minw-260{min-width:260px}
.flex-row-8{display:flex;gap:8px}
.flex-row-8-end{display:flex;gap:8px;align-items:flex-end}
.flex-row-8-center{display:flex;gap:8px;align-items:center}
.flex-row-8-wrap{display:flex;gap:8px;flex-wrap:wrap}
.flex-row-8-wrap-end{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}
.between-center{display:flex;align-items:center;justify-content:space-between}
.section-top-divider{margin-top:14px;border-top:1px solid var(--border);padding-top:12px}
.panel-loading{font-size:14px;color:var(--text-m)}
.empty-kpi{color:var(--text-m);font-size:13px;text-align:center;padding:20px}
.btn-compact{padding:8px 16px}
.btn-compact-sm{padding:4px 10px;font-size:12px}
.btn-block{width:100%;padding:10px}
.btn-block-lg{width:100%;margin-bottom:16px;padding:12px}
.toggle-inline-label{display:flex;align-items:center;gap:4px;cursor:pointer;white-space:nowrap;font-size:13px;color:var(--text-m)}
.toggle-inline-label-strong{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;color:var(--text-s);margin-bottom:8px}
.card-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.table-scroll{overflow-x:auto}
.ta-right{text-align:right}
.usage-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.usage-input-row{margin-top:8px;display:flex;gap:6px}
.usage-tabs{display:flex;gap:4px;margin-bottom:12px;border-bottom:1px solid var(--border);padding-bottom:6px}
.input-compact{font-size:12px;padding:4px 8px}
.subtitle-hero{color:var(--text-m);font-size:13px;margin-bottom:2px;font-weight:500}
.subtitle-version{color:var(--text-m);font-size:12px;margin-bottom:4px}
.fixed-basis-160{flex:0 0 160px}
.theme-card{display:flex;align-items:center;justify-content:space-between}
.grid-gap-8{display:grid;gap:8px}
.grid-auto-240{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.grid-auto-260{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.resize-vertical{resize:vertical}
.font-14{font-size:14px}
.font-13-inherit{font-size:13px;font-family:inherit}
.padding-10{padding:10px}
.padding-10-20{padding:10px 20px}
.btn-danger-text{color:#e55}
.text-center-pad-24{display:none;font-size:13px;color:var(--text-m);text-align:center;padding:24px}
.section-actions{display:flex;justify-content:space-between;align-items:center}
.inline-close-pre{white-space:pre-wrap;font-size:13px;line-height:1.6;background:var(--bg-panel);padding:12px;border-radius:8px;color:var(--text)}
.code-pre{position:relative;padding-top:14px}
.code-pre.with-lang{padding-top:28px}
.code-lang-badge{position:absolute;top:6px;left:12px;font-size:10px;color:var(--text-m);font-family:var(--mono);text-transform:uppercase;letter-spacing:.05em}
.modal-message{color:var(--text);font-size:14px;line-height:1.6;white-space:pre-line}
.att-size{color:var(--text-m);font-size:11px}
.pill-row{margin-top:6px;display:flex;flex-wrap:wrap;gap:4px}
.msg-av-muted{opacity:.5}
.msg-av-error{background:var(--red)}
.msg-name-error{color:var(--red)}
.msg-content-error{color:var(--text-s)}
.text-muted-10{font-size:10px;color:var(--text-m)}
.text-muted-11{font-size:11px;color:var(--text-m)}
.text-muted-12{font-size:12px;color:var(--text-m)}
.text-muted-pad-12{font-size:13px;color:var(--text-m);padding:12px 0}
.text-muted-center-16{font-size:13px;color:var(--text-m);text-align:center;padding:16px}
.text-danger-center-12{font-size:13px;color:var(--red);text-align:center;padding:12px}
.text-danger-center-20{font-size:13px;color:var(--red);text-align:center;padding:20px}
.text-danger-12{font-size:12px;color:var(--red)}
.mono-xs{font-family:var(--mono);font-size:11px}
.cell-mono-xs{font-family:var(--mono);font-size:11px}
.cell-right{text-align:right}
.cell-muted-xs{font-size:11px;color:var(--text-m)}
.nowrap-xs{white-space:nowrap;font-size:11px}
.cursor-pointer{cursor:pointer}
.outline-accent{outline:2px solid var(--accent)}
.ml-auto{margin-left:auto}
.card-compact{padding:8px 14px;margin-bottom:4px}
.flex-1-min0{flex:1;min-width:0}
.inline-name{font-size:13px;font-weight:600;color:var(--text)}
.inline-meta-mono{font-size:12px;color:var(--text-m);margin-left:8px;font-family:var(--mono)}
.btn-danger-outline{padding:4px 10px;font-size:12px;color:#e55;border-color:#e55}
.btn-danger-stop{color:#ff6b6b}
.btn-muted-icon{color:var(--text-m)}
.date-chip{font-size:11px;color:var(--text-m)}
.browse-empty{font-size:13px;color:var(--text-m);padding:12px 0}
.cal-date-num{font-size:11px;color:var(--text-m)}
.cal-empty-day{font-size:12px;color:var(--text-m);padding:4px 0}
.list-empty-row{font-size:13px;color:var(--text-m);text-align:center;padding:20px}
.entity-card{background:var(--bg-panel);border-radius:8px;padding:12px 14px;margin:6px 0;display:flex;justify-content:space-between;align-items:center;gap:8px}
.entity-card-compact{background:var(--bg-panel);border-radius:8px;padding:10px 14px;margin:6px 0;display:flex;justify-content:space-between;align-items:center;gap:8px}
.entity-main{flex:1;min-width:0}
.entity-main-click{flex:1;min-width:0;cursor:pointer}
.entity-title{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.entity-title-plain{font-weight:600;font-size:13px;color:var(--text)}
.entity-subtitle{font-size:11px;color:var(--text-m);margin-top:2px}
.entity-subtitle-clip{font-size:11px;color:var(--text-m);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.entity-caption{font-size:10px;color:var(--text-m);margin-top:1px}
.entity-arrow{width:14px;height:14px;flex-shrink:0;color:var(--text-m)}
.usage-empty{color:var(--text-m);font-size:13px}
.usage-empty-sm{color:var(--text-m);font-size:12px}
.headline-group{margin:8px 0}
.headline-title{font-weight:600;font-size:13px;color:var(--accent);margin-bottom:4px}
.headline-item{font-size:12px;color:var(--text);padding:2px 0 2px 8px;border-left:2px solid var(--accent)}
.headline-item-spaced{font-size:12px;color:var(--text);padding:3px 0 3px 8px;border-left:2px solid var(--accent)}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:12px}
.kpi-card{background:var(--bg-panel);border-radius:8px;padding:14px;text-align:center}
.kpi-panel{background:var(--bg-panel);border-radius:8px;padding:12px}
.kpi-panel + .kpi-panel{margin-top:10px}
.kpi-panel-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:6px}
.meter-row{margin:4px 0;display:flex;align-items:center;gap:8px}
.meter-row-habit{margin:6px 0;display:flex;align-items:center;gap:8px}
.meter-label{font-size:11px;color:var(--text-m);min-width:70px}
.meter-label-strong{font-size:12px;color:var(--text);min-width:100px;font-weight:500}
.meter-track{flex:1;height:8px;background:var(--bg-t);border-radius:4px;overflow:hidden}
.meter-fill{width:var(--fill);height:100%;background:var(--fill-color, var(--accent));border-radius:4px}
.meter-value{font-size:11px;color:var(--text);min-width:40px;text-align:right}
.meter-value-muted{font-size:11px;color:var(--text-m);min-width:80px;text-align:right}
.habit-meta{font-size:11px;color:var(--text-m);margin-left:8px}
.habit-streak{font-size:11px;margin-left:6px}
.reliability-hero{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(150px,.8fr);gap:14px;margin-bottom:12px;padding:18px 20px;border-radius:12px;border:1px solid var(--border);background:linear-gradient(135deg,var(--surface),var(--bg-panel))}
.reliability-hero.healthy{border-color:rgba(34,197,94,.28);background:linear-gradient(135deg,rgba(34,197,94,.12),rgba(22,163,74,.04))}
.reliability-hero.watch{border-color:rgba(234,179,8,.28);background:linear-gradient(135deg,rgba(234,179,8,.14),rgba(202,138,4,.05))}
.reliability-hero.critical{border-color:rgba(239,68,68,.28);background:linear-gradient(135deg,rgba(239,68,68,.14),rgba(220,38,38,.05))}
.reliability-hero.unknown{border-color:var(--border);background:linear-gradient(135deg,var(--surface),var(--bg-panel))}
.reliability-copy{min-width:0}
.reliability-eyebrow{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-m)}
.reliability-headline{font-size:24px;font-weight:700;letter-spacing:-.03em;color:var(--text);margin-top:4px}
.reliability-text{font-size:13px;color:var(--text-s);margin-top:6px}
.reliability-meta{font-size:11px;color:var(--text-m);margin-top:10px}
.reliability-score{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;text-align:right;gap:8px}
.reliability-score-value{font-size:34px;font-weight:700;line-height:1;color:var(--text)}
.health-chip{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;border:1px solid var(--border);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.health-chip.healthy{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.25);color:var(--green)}
.health-chip.watch{background:rgba(234,179,8,.14);border-color:rgba(234,179,8,.28);color:var(--yellow)}
.health-chip.critical{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.3);color:var(--red)}
.health-chip.unknown{background:var(--surface);border-color:var(--border);color:var(--text-m)}
.reliability-tool{padding:8px 0}
.reliability-tool + .reliability-tool{border-top:1px solid var(--border)}
.reliability-note{font-size:12px;color:var(--text-m);padding:5px 0}
.reliability-failure{padding:10px 0}
.reliability-failure + .reliability-failure{border-top:1px solid var(--border)}
.reliability-inline-metrics{display:flex;flex-wrap:wrap;gap:10px;color:var(--text-m);font-size:11px;margin-top:4px}
.checkin-actions{display:flex;gap:4px}
.checkin-input{width:60px;padding:4px 6px;font-size:12px}
.card-success{border-color:#4caf50}
.text-success-title{color:#4caf50}
.adaptive-hero{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(220px,.9fr);gap:12px;padding:18px 20px;border:1px solid var(--border);border-radius:12px;background:linear-gradient(135deg,var(--surface),var(--bg-panel))}
.adaptive-hero.ready{border-color:rgba(34,197,94,.28);background:linear-gradient(135deg,rgba(34,197,94,.12),rgba(22,163,74,.04))}
.adaptive-hero.waiting{border-color:rgba(234,179,8,.28);background:linear-gradient(135deg,rgba(234,179,8,.14),rgba(202,138,4,.05))}
.adaptive-title{font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--text)}
.adaptive-subtitle{font-size:13px;color:var(--text-s);margin-top:6px}
.adaptive-checklist{display:grid;gap:8px;margin-top:12px}
.adaptive-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-s)}
.adaptive-check::before{content:'•';font-size:16px;color:var(--text-m)}
.adaptive-check.done::before{content:'✓';color:var(--green)}
.adaptive-check.todo::before{content:'!';color:var(--yellow)}
.adaptive-metrics{display:grid;gap:8px}
.adaptive-metric{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:10px;padding:12px}
.adaptive-metric-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-m)}
.adaptive-metric-value{font-size:24px;font-weight:700;color:var(--text);margin-top:2px}
.adaptive-metric-note{font-size:11px;color:var(--text-m);margin-top:2px}
.status-chip{display:inline-flex;align-items:center;justify-content:center;padding:3px 10px;border-radius:999px;border:1px solid var(--border);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.status-chip.approved{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.28);color:var(--green)}
.status-chip.pending_review{background:rgba(234,179,8,.14);border-color:rgba(234,179,8,.28);color:var(--yellow)}
.status-chip.candidate{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.26);color:var(--blue)}
.status-chip.rejected{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.28);color:var(--red)}
.status-chip.connected,.status-chip.active{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.28);color:var(--green)}
.status-chip.attention{background:rgba(234,179,8,.14);border-color:rgba(234,179,8,.28);color:var(--yellow)}
.status-chip.disconnected{background:rgba(148,163,184,.12);border-color:rgba(148,163,184,.28);color:var(--text-m)}
.adaptive-fact{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:10px 0;border-top:1px solid var(--border)}
.adaptive-fact:first-child{border-top:none;padding-top:0}
.adaptive-fact-main{flex:1;min-width:0}
.adaptive-inline-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.adaptive-pill{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;background:var(--bg-t);border:1px solid var(--border);font-size:11px;color:var(--text-s)}
.adaptive-history-item{align-items:flex-start}
.adaptive-playbook-card{margin-bottom:10px}
.adaptive-playbook-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.adaptive-section-copy{font-size:12px;color:var(--text-s);line-height:1.6;margin-top:6px}
.adaptive-empty{font-size:13px;color:var(--text-m);text-align:center;padding:18px}
.task-empty{font-size:12px;color:var(--text-m);text-align:center;padding:12px 0}
.task-col-badge{border-radius:100px;padding:0 7px}
.file-results-summary{font-size:12px;color:var(--text-m);margin-bottom:8px}
.file-results-box{background:var(--bg-t);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.org-plan-text{font-size:12px;margin:4px 0}
.org-summary{font-size:12px;margin-bottom:8px;color:var(--text-m)}
.org-note{font-size:11px;color:var(--text-m);margin-top:4px}
.field-flex-1-120{flex:1;min-width:120px}
.field-flex-1-140{flex:1;min-width:140px}
.field-flex-1-100{flex:1;min-width:100px}
.field-flex-1-80-100{flex:1;min-width:80px;max-width:100px}
.field-flex-1-180{flex:2;min-width:180px}
.field-flex-2-200{flex:2;min-width:200px}
.field-flex-3-200{flex:3;min-width:200px}
.btn-flex-1{flex:1;padding:10px}
.mt-12-block{margin-top:12px}

/* Theme toggle */
.theme-toggle{
  display:flex;align-items:center;gap:6px;
  background:var(--surface);border:1px solid var(--border);border-radius:100px;
  padding:3px;cursor:pointer;
}

.guardrails-card {
  display: grid;
  gap: 12px;
}

.guardrails-grid {
  align-items: end;
}

.guardrails-summary {
  color: var(--text-m);
  font-size: 13px;
  line-height: 1.4;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface-1);
}

.guardrails-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 8px;
}

.guardrail-metric {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
}

.guardrail-metric span,
.guardrail-event span,
.guardrail-empty {
  color: var(--text-m);
  font-size: 12px;
}

.guardrails-events {
  display: grid;
  gap: 8px;
  max-height: 280px;
  overflow: auto;
}

.guardrail-event {
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface-1);
}

.guardrail-event div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.guardrail-event p {
  margin: 6px 0 0;
  color: var(--text-m);
  font-size: 12px;
  line-height: 1.4;
}
.theme-opt{
  padding:4px 10px;border-radius:100px;font-size:11px;font-weight:600;
  color:var(--text-m);transition:all var(--ease);border:none;background:none;
  cursor:pointer;font-family:inherit;
}
.theme-opt.active{background:var(--accent);color:#fff}

/* Toggle switch */
.toggle-sw{position:relative;width:36px;height:20px;flex-shrink:0}
.toggle-sw input{opacity:0;width:0;height:0}
.toggle-sw .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;
  background:var(--border);border-radius:20px;transition:all var(--ease)}
.toggle-sw .slider::before{content:'';position:absolute;height:14px;width:14px;
  left:3px;bottom:3px;background:#fff;border-radius:50%;transition:all var(--ease)}
.toggle-sw input:checked+.slider{background:var(--accent)}
.toggle-sw input:checked+.slider::before{transform:translateX(16px)}

/* Sidebar footer */
.sidebar-footer{
  padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;
}
.sidebar-footer .version{font-size:11px;color:var(--text-m)}

/* History list */
.hist-item{
  padding:14px 18px;margin-bottom:8px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-s);
  cursor:pointer;transition:all var(--ease);
}
.hist-item:hover{border-color:var(--accent);background:var(--accent-sub)}
.hist-item-title{font-size:14px;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hist-item-meta{font-size:12px;color:var(--text-m);margin-top:4px;
  display:flex;align-items:center;justify-content:space-between}
.hist-item .hist-del{
  background:none;border:none;color:var(--text-m);cursor:pointer;font-size:14px;
  padding:2px 4px;border-radius:4px;transition:color var(--ease);opacity:0;
}
.hist-item:hover .hist-del{opacity:1}
.hist-item .hist-del:hover{color:var(--red)}
.hist-item-snippet{font-size:12px;color:var(--text-s);line-height:1.55;margin-top:8px;white-space:pre-wrap;word-break:break-word}
.hist-item.important-item{cursor:default}
.hist-item.important-item:hover{border-color:var(--border-h);background:var(--surface)}
.hist-mini-btn{
  background:none;border:1px solid var(--border);color:var(--text-m);cursor:pointer;font-size:11px;
  padding:4px 8px;border-radius:999px;transition:all var(--ease);font-family:inherit;
}
.hist-mini-btn:hover{border-color:var(--accent);color:var(--text);background:var(--accent-sub)}
.repo-path-note{font-size:12px;color:var(--text-m);font-family:var(--mono);line-height:1.5;overflow-wrap:anywhere}
.important-repo-toolbar{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 10px}

/* Calendar */
.cal-nav{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.cal-nav-title{font-size:15px;font-weight:600;flex:1;text-align:center;color:var(--text)}
.cal-nav-btn{
  background:var(--surface);border:1px solid var(--border);color:var(--text-s);
  cursor:pointer;padding:6px 12px;border-radius:var(--radius-xs);font-size:16px;
  font-family:inherit;transition:all var(--ease);
}
.cal-nav-btn:hover{border-color:var(--accent);color:var(--text)}
.cal-grid{display:flex;flex-direction:column;gap:2px;font-size:13px}
.cal-row{display:flex;gap:1px}
.cal-header{font-weight:700;color:var(--text-m);text-transform:uppercase;font-size:10px}
.cal-cell{
  flex:1;min-width:0;padding:4px 3px;text-align:center;
  background:var(--surface);border-radius:2px;
}
.cal-cell.today{border:1px solid var(--accent);background:var(--accent-sub)}
.cal-cell.other-month{opacity:.3}
.cal-cell.has-task{position:relative}
.cal-cell .cal-day{font-weight:600;font-size:11px;margin-bottom:2px;color:var(--text)}
.cal-dot{
  width:5px;height:5px;border-radius:50%;background:var(--accent);
  margin:1px auto;
}
.cal-task-tip{
  font-size:10px;color:var(--accent-h);white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;
}

/* Day detail view */
.cal-day-detail{margin-top:10px;padding:8px 0;border-top:1px solid var(--border)}
.cal-day-detail h4{font-size:12px;font-weight:700;color:var(--text);margin-bottom:6px}
.cal-slot{
  display:flex;align-items:center;gap:6px;padding:5px 8px;margin-bottom:3px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xs);
  font-size:12px;
}
.cal-slot-time{font-family:var(--mono);color:var(--text-m);font-size:11px;min-width:42px}
.cal-slot-label{color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-slot-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.cal-slot-dot.on{background:var(--green)}
.cal-slot-dot.off{background:var(--text-m)}

/* ── Main area ─────────────────────────────────────────────── */
.main{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}

/* ── Top bar ───────────────────────────────────────────────── */
.topbar{
  display:flex;align-items:center;gap:8px;padding:10px 20px;
  border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg);
  min-height:52px;
}
.topbar-toggle{
  background:none;border:none;color:var(--text-m);cursor:pointer;padding:6px;
  border-radius:var(--radius-xs);display:flex;align-items:center;
  transition:color var(--ease),background var(--ease);
}
.topbar-toggle:hover{color:var(--text);background:var(--surface-h)}
.topbar-toggle svg{width:20px;height:20px}
.topbar-title{font-size:14px;font-weight:600;color:var(--text);flex:1}
.topbar-model{
  font-size:12px;font-family:var(--mono);color:var(--text-m);
  padding:4px 10px;background:var(--surface);border:1px solid var(--border);
  border-radius:100px;
}
.topbar-btn{
  background:none;border:1px solid var(--border);color:var(--text-s);
  padding:6px 12px;border-radius:var(--radius-xs);font-size:12px;
  cursor:pointer;transition:all var(--ease);font-family:inherit;
  display:flex;align-items:center;gap:4px;
}
.topbar-btn:hover{border-color:var(--border-h);color:var(--text);background:var(--surface-h)}

.topbar-runtime-alert{
  display:flex;align-items:center;gap:10px;padding:10px 20px;
  border-bottom:1px solid rgba(234,179,8,.2);
  background:linear-gradient(90deg,rgba(234,179,8,.14),rgba(234,179,8,.04));
}
.topbar-runtime-alert.is-hidden{display:none}
.chat-tabs{
  display:flex;align-items:center;gap:8px;padding:8px 20px;
  border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--surface),transparent);
}
.chat-tabs-list{
  display:flex;align-items:stretch;gap:6px;flex:1;min-width:0;overflow-x:auto;padding-bottom:2px;
}
.chat-tab{
  display:flex;align-items:stretch;min-width:208px;max-width:268px;
  border:1px solid var(--border);border-radius:12px;background:var(--bg-s);
  box-shadow:0 8px 18px rgba(0,0,0,.08);transition:border-color var(--ease),transform var(--ease),background var(--ease);
}
.chat-tab.active{border-color:var(--accent);background:var(--accent-sub)}
.chat-tab.is-locked{opacity:.8}
.chat-tab-main{
  flex:1;min-width:0;border:none;background:transparent;color:inherit;text-align:left;cursor:pointer;
  padding:8px 10px 8px 12px;font:inherit;
}
.chat-tab-main:disabled{cursor:not-allowed}
.chat-tab-title-row{display:flex;align-items:center;gap:8px;min-width:0}
.chat-tab-title{font-size:12px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-tab-preview{display:block;margin-top:2px;font-size:11px;color:var(--text-m);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-tab-badge{
  flex-shrink:0;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  padding:2px 8px;border-radius:999px;background:rgba(34,197,94,.12);color:var(--green);
}
.chat-tab-close{
  flex-shrink:0;width:32px;border:none;border-left:1px solid var(--border);background:transparent;color:var(--text-m);
  cursor:pointer;border-radius:0 12px 12px 0;font-size:18px;line-height:1;transition:background var(--ease),color var(--ease);
}
.chat-tab-close:hover{background:rgba(239,68,68,.08);color:var(--red)}
.chat-tab-close:disabled{cursor:not-allowed;opacity:.6}
.chat-tabs-add{
  flex-shrink:0;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--surface);
  color:var(--text);border-radius:999px;padding:9px 12px;font:inherit;font-size:12px;font-weight:700;cursor:pointer;
  transition:border-color var(--ease),background var(--ease),color var(--ease);
}
.chat-tabs-add:hover{border-color:var(--accent);background:var(--accent-sub);color:var(--accent-h)}
.chat-tabs-add:disabled{cursor:not-allowed;opacity:.6}
.topbar-runtime-badge{
  display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;
  border-radius:999px;border:1px solid rgba(234,179,8,.28);background:rgba(234,179,8,.16);
  color:var(--yellow);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  white-space:nowrap;flex-shrink:0;
}
.topbar-runtime-text{font-size:12px;color:var(--text-s);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.status-dot{
  display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--green);animation:pulse 2s ease-in-out infinite;
}
.status-dot.busy{background:var(--yellow);animation:pulse .8s ease-in-out infinite}
.status-dot.error{background:var(--red);animation:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* Timer / Step counter while busy */
.topbar-timer{
  font-size:12px;font-family:var(--mono);color:var(--yellow);
  padding:4px 10px;background:var(--surface);border:1px solid var(--border);
  border-radius:100px;display:none;align-items:center;justify-content:center;gap:5px;
  min-width:88px;
  animation:pulse 1.5s ease-in-out infinite;
}
.topbar-timer.visible{display:inline-flex}
.topbar-timer .timer-icon{font-size:10px}

/* Toast notification */
.toast{
  position:fixed;top:20px;right:20px;z-index:200;
  background:var(--accent);color:#fff;padding:14px 24px;
  border-radius:var(--radius);box-shadow:var(--shadow);
  font-size:14px;font-weight:600;display:flex;align-items:center;gap:10px;
  animation:toastIn .3s ease,toastOut .4s ease 4.6s forwards;
  max-width:400px;
}
@keyframes toastIn{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastOut{from{opacity:1}to{opacity:0;pointer-events:none}}

/* Log viewer panel */
.sb-log{max-height:300px;overflow-y:auto}
.sb-log pre{
  font-size:11px;font-family:var(--mono);color:var(--text-s);
  white-space:pre-wrap;word-break:break-all;line-height:1.4;
  padding:8px;background:var(--bg-t);border-radius:var(--radius-xs);
  border:1px solid var(--border);margin:4px 0;
}

/* ── Task cards (Mis Tareas) ──────────────────────────────── */
.task-col{background:var(--bg-t);border:1px solid var(--border);border-radius:var(--radius);padding:12px;min-height:80px}
.task-col-title{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-m);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xs);padding:10px;margin-bottom:8px;cursor:pointer;transition:border-color var(--ease)}
.task-card:hover{border-color:var(--accent)}
.task-card-title{font-size:13px;font-weight:600;margin-bottom:4px;line-height:1.3}
.task-card-meta{font-size:11px;color:var(--text-m);display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.task-pri{display:inline-block;padding:1px 6px;border-radius:100px;font-size:10px;font-weight:700}
.task-pri-alta{background:#ff4d4d22;color:#ff6b6b}
.task-pri-media{background:#ffd70022;color:#ffc107}
.task-pri-baja{background:#00c85322;color:#4caf50}
.task-timer{font-size:11px;font-family:var(--mono);color:var(--accent)}
.task-actions{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}
.task-actions .btn{padding:3px 8px;font-size:11px}

/* ── Note cards (Notas) ───────────────────────────────────── */
.note-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:8px;position:relative;transition:border-color var(--ease)}
.note-card:hover{border-color:var(--accent)}
.note-card.pinned{border-color:#ffd700;background:var(--accent-sub)}
.note-pin-badge{position:absolute;top:8px;right:8px;font-size:14px;cursor:pointer;opacity:.6;transition:opacity var(--ease)}
.note-pin-badge:hover{opacity:1}
.note-title{font-size:13px;font-weight:700;line-height:1.3;padding-right:20px}
.note-preview{font-size:12px;color:var(--text-m);line-height:1.5;white-space:pre-wrap;word-break:break-word;max-height:80px;overflow:hidden}
.note-tags{display:flex;flex-wrap:wrap;gap:4px}
.note-tag{background:var(--accent-sub);color:var(--accent);border-radius:100px;font-size:10px;padding:1px 7px;font-weight:600}
.note-meta{font-size:10px;color:var(--text-m)}
.note-actions{display:flex;gap:4px}
.note-actions .btn{padding:3px 8px;font-size:11px;flex:1}

/* ── File results (Archivos) ──────────────────────────────── */
.file-result-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-bottom:1px solid var(--border);font-size:12px}
.file-result-row:last-child{border-bottom:none}
.file-result-name{font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-result-size{color:var(--text-m);font-family:var(--mono);white-space:nowrap}
.file-result-path{color:var(--text-m);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:2}
.org-plan-category{background:var(--bg-t);border:1px solid var(--border);border-radius:var(--radius-xs);padding:8px 12px;margin-bottom:6px}
.org-plan-category h4{font-size:12px;font-weight:700;color:var(--accent);margin-bottom:4px}
.org-plan-category ul{font-size:11px;color:var(--text-m);padding-left:16px;margin:0;max-height:80px;overflow-y:auto}

/* ── Messages ──────────────────────────────────────────────── */
.messages{flex:1;overflow-y:auto;padding:24px clamp(16px,4vw,40px);scroll-behavior:smooth;min-height:0}
.messages > *{width:min(100%,var(--chat-max-width));margin-left:auto;margin-right:auto}

/* Empty state */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:60vh;text-align:center;padding:40px 20px}
.empty-logo{
  width:72px;height:72px;border-radius:14px;overflow:hidden;margin-bottom:20px;
  box-shadow:0 0 40px rgba(139,0,0,.3);
}
.empty-logo svg{width:100%;height:100%}
.empty-logo img{width:100%;height:100%;object-fit:contain}
.empty h2{font-size:22px;font-weight:700;margin-bottom:6px;letter-spacing:-.3px}
.empty p{color:var(--text-m);font-size:14px;margin-bottom:28px}
.suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:520px}
.sug{
  background:var(--surface);border:1px solid var(--border);color:var(--text-s);
  padding:9px 16px;border-radius:100px;font-size:13px;cursor:pointer;
  transition:all var(--ease);font-family:inherit;
}
.sug:hover{border-color:var(--accent);color:var(--text);background:var(--accent-sub)}
.sug-skill{border-color:var(--accent);color:var(--accent);background:transparent}
.sug-skill:hover{background:var(--accent);color:#fff}

/* Chat messages */
.msg{display:flex;width:min(100%,var(--chat-max-width));margin-bottom:20px;animation:msgIn .3s ease-out;max-width:100%}
.msg.user{justify-content:flex-end}
.msg.agent,.msg.info,.msg.error{justify-content:flex-start}
@keyframes msgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.msg-av{
  width:30px;height:30px;border-radius:var(--radius-xs);display:flex;align-items:center;
  justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;margin-top:2px;
}
.msg-av.user{background:var(--user-bg);color:#c7d2fe}
.msg-av.agent{background:linear-gradient(135deg,var(--accent),#a78bfa);color:#fff}
.msg-body{min-width:0;max-width:min(100%,860px);padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}
.msg.user .msg-body{margin-left:auto;max-width:min(100%,760px);background:var(--user-bg);border-color:var(--user-border);box-shadow:var(--user-shadow)}
.msg.agent .msg-body{width:100%;max-width:min(100%,880px);padding:0;border:none;border-radius:0;background:transparent;box-shadow:none}
.msg.agent.msg-live-status .msg-body{
  width:min(100%,760px);
  max-width:min(100%,760px);
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:linear-gradient(180deg,var(--surface),var(--bg-panel));
  box-shadow:0 10px 28px rgba(15,23,42,.08);
}
.msg-live-status .msg-name{display:flex;align-items:center;gap:8px}
.msg-live-status-badge{
  display:inline-flex;
  align-items:center;
  padding:2px 8px;
  border-radius:999px;
  background:var(--accent-sub);
  color:var(--accent-h);
  font-size:10px;
  font-weight:700;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.msg-live-status .msg-content{line-height:1.65}
.msg-live-status-meta{margin-top:8px;font-size:11px;color:var(--text-m)}
.msg.agent.streaming .streaming-content::after{content:'▍';animation:blink-cursor .6s step-end infinite;color:var(--accent,#6366f1);font-weight:700}
@keyframes blink-cursor{50%{opacity:0}}
.streaming-prelude{font-style:italic;opacity:.6;line-height:1.65;margin-bottom:10px;padding-bottom:8px;border-bottom:1px dashed var(--border,rgba(127,127,127,.25));color:var(--text-m,inherit)}
.streaming-prelude + .streaming-prelude{margin-top:6px;border-top:none}
.streaming-prelude p:first-child{margin-top:0}
.streaming-prelude p:last-child{margin-bottom:0}
.msg.info .msg-body{background:var(--surface)}
.msg.error .msg-body{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.06)}
.msg.user .msg-name{color:var(--user-label)}
.msg.user .msg-content{color:var(--user-text)}
.msg-name{font-size:12px;font-weight:600;color:var(--text-m);margin-bottom:3px}
.msg-content{color:var(--text);line-height:1.75;word-break:break-word}
.msg-content-plain{white-space:pre-wrap}
.msg-content p{margin-bottom:10px}
.msg-content p:last-child{margin-bottom:0}
.msg-content ul,.msg-content ol{margin:8px 0;padding-left:22px}
.msg-content li{margin-bottom:3px}
.msg-content strong{font-weight:600;color:var(--text)}
.msg-content em{font-style:italic;color:var(--text-s)}
.msg-content code{
  font-family:var(--mono);font-size:13px;background:var(--bg-t);
  padding:1.5px 5px;border-radius:4px;border:1px solid var(--border);
}
.msg-content pre{
  background:var(--code-bg);border:1px solid var(--border);border-radius:var(--radius-s);
  padding:14px 16px;margin:10px 0;overflow-x:auto;position:relative;
}
.msg-content pre code{
  background:none;border:none;padding:0;font-size:13px;line-height:1.5;
  color:var(--text);white-space:pre;
}
.msg-content blockquote{
  border-left:3px solid var(--accent);padding:8px 16px;margin:10px 0;
  color:var(--text-s);background:var(--accent-sub);border-radius:0 var(--radius-xs) var(--radius-xs) 0;
}
.msg-content h1,.msg-content h2,.msg-content h3,.msg-content h4{
  margin:16px 0 8px;font-weight:700;color:var(--text);
}
.msg-content h1{font-size:20px;border-bottom:1px solid var(--border);padding-bottom:6px}
.msg-content h2{font-size:17px}
.msg-content h3{font-size:15px}
.msg-content table{border-collapse:collapse;margin:10px 0;width:100%;font-size:13px}
.msg-content th,.msg-content td{border:1px solid var(--border);padding:7px 10px;text-align:left}
.msg-content th{background:var(--bg-t);font-weight:600}
.msg-content hr{border:none;border-top:1px solid var(--border);margin:16px 0}
.msg-content img{max-width:100%;border-radius:var(--radius-s);margin:8px 0}
.rich-block{margin:14px 0;padding:14px 16px;border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:linear-gradient(180deg,var(--surface),var(--bg-t));box-shadow:0 10px 26px rgba(15,23,42,.08)}
.rich-block-header{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.rich-block-kicker{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-h)}
.rich-block-title{margin:0;font-size:16px;font-weight:700;color:var(--text)}
.rich-block-subtitle{margin:0;font-size:12px;line-height:1.55;color:var(--text-m)}
.rich-chart-shell{overflow-x:auto;padding:8px 0 2px}
.rich-chart-svg{display:block;width:100%;min-width:560px;height:auto}
.rich-chart-grid{stroke:rgba(148,163,184,.22);stroke-width:1}
.rich-chart-axis{stroke:rgba(100,116,139,.5);stroke-width:1.5}
.rich-chart-axis-label{fill:var(--text-m);font-size:11px;font-family:var(--mono)}
.rich-chart-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.rich-chart-legend-item{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:11px;color:var(--text-s)}
.rich-chart-legend-dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0}
.rich-chart-auto{margin-top:12px;background:linear-gradient(180deg,var(--bg-t),var(--surface))}
.rich-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.rich-stat-card{padding:12px 13px;border-radius:var(--radius-s);border:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;gap:6px;min-height:110px}
.rich-stat-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-m)}
.rich-stat-value{font-size:24px;line-height:1.1;font-weight:800;color:var(--text)}
.rich-stat-trend{font-size:12px;font-weight:700;color:var(--accent-h)}
.rich-stat-note{font-size:12px;line-height:1.5;color:var(--text-s);margin-top:auto}
.rich-stat-good{border-color:rgba(34,197,94,.22);background:linear-gradient(180deg,rgba(34,197,94,.08),var(--surface))}
.rich-stat-warn{border-color:rgba(245,158,11,.24);background:linear-gradient(180deg,rgba(245,158,11,.08),var(--surface))}
.rich-stat-bad{border-color:rgba(239,68,68,.24);background:linear-gradient(180deg,rgba(239,68,68,.08),var(--surface))}
.rich-stat-neutral{border-color:var(--border)}
.assistant-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:nowrap;margin-top:14px;padding-top:10px;border-top:1px solid var(--border)}
.assistant-meta-group{display:flex;align-items:center;gap:8px;min-width:0;flex:1;overflow:hidden}
.assistant-timestamp{font-size:11px;color:var(--text-m);white-space:nowrap;flex-shrink:0}
.assistant-duration{display:inline-flex;align-items:center;min-width:58px;font-size:11px;color:var(--accent-h);white-space:nowrap;font-family:var(--mono);font-variant-numeric:tabular-nums;flex-shrink:0}
.assistant-inline-meta{display:flex;align-items:center;gap:6px;min-width:0;overflow-x:auto;white-space:nowrap}
.assistant-inline-meta::-webkit-scrollbar{display:none}
.assistant-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;border:1px solid var(--border);background:var(--bg-t);color:var(--text-m);font-size:11px;white-space:nowrap}
.assistant-actions{display:flex;align-items:center;gap:6px;justify-content:flex-end;flex-shrink:0;white-space:nowrap}
.assistant-action{
  background:transparent;border:1px solid var(--border);color:var(--text-m);cursor:pointer;
  padding:5px 9px;border-radius:999px;font-size:11px;font-weight:600;line-height:1;transition:all var(--ease);font-family:inherit;
}
.assistant-action-icon{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center}
.assistant-action svg{width:16px;height:16px}
.assistant-action:hover{border-color:var(--border-h);color:var(--text);background:var(--surface-h)}
.assistant-action.is-success{border-color:rgba(59,130,246,.28);color:var(--blue);background:rgba(59,130,246,.08)}
.assistant-action.is-saved{border-color:rgba(34,197,94,.28);color:var(--green);background:rgba(34,197,94,.08)}
.assistant-action.is-saved:hover{border-color:rgba(34,197,94,.4);color:var(--green);background:rgba(34,197,94,.12)}
.assistant-action.is-busy{opacity:.65;pointer-events:none}
.assistant-action.js-rate-up.is-active{border-color:rgba(34,197,94,.4);color:var(--green);background:rgba(34,197,94,.12)}
.assistant-action.js-rate-down.is-active{border-color:rgba(239,68,68,.4);color:#ef4444;background:rgba(239,68,68,.1)}

.media-output-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;margin-top:14px}
.media-output-card{padding:12px 13px;border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(180deg,var(--surface),var(--bg-t));box-shadow:0 10px 26px rgba(15,23,42,.08)}
.media-output-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}
.media-output-kicker{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-h)}
.media-output-delivery{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;background:var(--bg-t);border:1px solid var(--border);font-size:10px;font-weight:700;color:var(--text-m);white-space:nowrap}
.media-output-title{margin:0;font-size:14px;font-weight:700;color:var(--text)}
.media-output-detail{margin-top:6px;font-size:12px;line-height:1.6;color:var(--text-s)}
.media-output-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.media-output-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;background:var(--bg-t);border:1px solid var(--border);font-size:11px;color:var(--text-m)}
.media-output-preview{margin-top:10px}
.media-output-preview img,.media-output-preview video{display:block;width:100%;max-height:260px;object-fit:cover;border-radius:var(--radius-s);border:1px solid var(--border);background:var(--bg)}
.media-output-preview audio{width:100%;display:block}
.media-output-inline-note{padding:10px 12px;border:1px dashed var(--border);border-radius:var(--radius-s);background:var(--surface);font-size:12px;line-height:1.55;color:var(--text-s)}
.media-output-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.media-output-link{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:12px;font-weight:600;text-decoration:none;transition:all var(--ease)}
.media-output-link:hover{border-color:var(--border-h);background:var(--surface-h)}
.assistant-artifacts{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.assistant-artifact-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;border:1px solid var(--border);background:var(--bg-t);color:var(--text-s);font-size:12px;max-width:100%}
.assistant-artifact-pill-label{display:inline-block;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Copy button on code */
.copy-btn{
  position:absolute;top:6px;right:6px;background:var(--surface);border:1px solid var(--border);
  color:var(--text-m);padding:3px 8px;border-radius:4px;font-size:11px;cursor:pointer;
  opacity:0;transition:opacity var(--ease);font-family:inherit;
}
pre:hover .copy-btn{opacity:1}
.copy-btn:hover{color:var(--text);border-color:var(--border-h)}

/* Narration */
.narr{display:flex;align-items:flex-start;margin-bottom:12px;animation:msgIn .2s ease-out}
.narr-content{
  font-size:13px;color:var(--text-m);padding:10px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-xs);max-width:min(100%,820px);
}

/* Thinking dots */
.thinking{display:flex;align-items:flex-start;margin-bottom:12px;animation:msgIn .2s ease-out}
.thinking-wrap{display:flex;flex-direction:column;gap:6px}
.thinking-panel{width:min(100%,820px);padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-s)}
.thinking-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.thinking-header-main{display:flex;align-items:flex-start;gap:10px;min-width:0;flex:1}
.thinking-titleblock{display:flex;flex-direction:column;gap:4px;min-width:0}
.thinking-title{font-size:12px;font-weight:700;color:var(--text)}
.thinking-dots{display:flex;gap:4px;padding:10px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-xs)}
.thinking-dots span{width:5px;height:5px;border-radius:50%;background:var(--text-m);animation:dot 1.4s ease-in-out infinite}
.thinking-dots span:nth-child(2){animation-delay:.2s}
.thinking-dots span:nth-child(3){animation-delay:.4s}
.thinking-label{font-size:12px;line-height:1.4;color:var(--text-m);max-width:min(560px,calc(100vw - 140px))}
.thinking-elapsed{min-width:62px;text-align:right;font-size:12px;color:var(--accent-h);font-family:var(--mono);font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}
.thinking-log{display:flex;flex-direction:column;gap:6px;margin-top:10px}
.thinking-entry{display:flex;align-items:flex-start;gap:8px;font-size:12px;line-height:1.5;color:var(--text-s)}
.thinking-entry-kind{display:inline-flex;align-items:center;justify-content:center;min-width:54px;padding:2px 6px;border-radius:999px;border:1px solid var(--border);background:var(--bg-t);font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-m);flex-shrink:0}
.thinking-entry-narration .thinking-entry-kind{color:var(--accent-h);background:var(--accent-sub);border-color:rgba(99,102,241,.2)}
.thinking-entry-progress .thinking-entry-kind{color:var(--blue);background:rgba(59,130,246,.08);border-color:rgba(59,130,246,.2)}
.thinking-entry-text{min-width:0;word-break:break-word}
@keyframes dot{0%,80%,100%{transform:translateY(0);opacity:.3}40%{transform:translateY(-3px);opacity:1}}

/* Meta pills */
.msg-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.pill{
  display:inline-flex;align-items:center;gap:3px;padding:2px 8px;font-size:11px;
  background:var(--bg-t);border:1px solid var(--border);border-radius:100px;color:var(--text-m);
}

/* Attachments preview */
.attachments-bar{
  display:flex;flex-direction:column;gap:8px;padding:8px 10px;flex-wrap:nowrap;margin-bottom:8px;
  border:1px dashed rgba(99,102,241,.28);border-radius:var(--radius-s);background:linear-gradient(180deg,var(--accent-sub),rgba(255,255,255,.55));
}
.attachments-bar-title{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-h)}
.attachments-list{display:flex;gap:6px;flex-wrap:wrap}
.att-chip{
  display:flex;align-items:center;gap:5px;padding:4px 10px;background:var(--surface);
  border:1px solid var(--border);border-radius:100px;font-size:12px;color:var(--text-s);
  animation:msgIn .15s ease-out;
}
.att-chip .att-remove{
  background:none;border:none;color:var(--text-m);cursor:pointer;font-size:14px;
  line-height:1;padding:0 2px;transition:color var(--ease);
}
.att-chip .att-remove:hover{color:var(--red)}
.att-chip .att-thumb{
  width:36px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0;
}
.drop-highlight{outline:2px dashed var(--accent);outline-offset:-4px;background:var(--accent-sub) !important}

/* ── Voice IA inline button + popover ──────────────────────── */
.voice-ia-wrap{position:relative;display:flex;align-items:center}
.voice-ia-btn{
  position:relative;display:inline-flex;align-items:center;gap:8px;min-width:108px;
  padding:0 12px;border:1px solid rgba(37,99,235,.18);border-radius:12px;
  background:linear-gradient(180deg,rgba(37,99,235,.12),rgba(8,145,178,.06));
  color:var(--accent-h);font-weight:700;
}
.voice-ia-btn:hover{background:linear-gradient(180deg,rgba(37,99,235,.16),rgba(8,145,178,.09));color:var(--accent-h)}
.voice-ia-btn svg{width:18px;height:18px}
.voice-ia-btn-label{font-size:12px;line-height:1;white-space:nowrap;letter-spacing:.02em}
.voice-ia-btn.voice-active{color:var(--green);border-color:rgba(34,197,94,.28);background:linear-gradient(180deg,rgba(34,197,94,.14),rgba(8,145,178,.08));animation:voice-glow 1.6s infinite}
@keyframes voice-glow{0%,100%{filter:drop-shadow(0 0 0 transparent)}50%{filter:drop-shadow(0 0 6px rgba(34,197,94,.5))}}
.voice-ia-indicator{
  position:absolute;top:3px;right:3px;width:8px;height:8px;border-radius:50%;
  border:1.5px solid var(--surface);display:none;
}
.voice-ia-indicator.active{display:block;background:var(--green)}
.voice-ia-indicator.error{display:block;background:var(--red)}
.voice-popover{
  position:absolute;bottom:calc(100% + 8px);right:0;width:320px;max-height:400px;z-index:300;
  border-radius:var(--radius);border:1px solid var(--border);
  background:var(--surface);box-shadow:0 8px 32px rgba(0,0,0,.35);overflow:hidden;
  display:flex;flex-direction:column;
}
.voice-popover.is-hidden{display:none}
.voice-popover-head{
  display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border);
}
.voice-popover-title{font-size:13px;font-weight:700;color:var(--text);flex:1}
.voice-popover-close{
  background:none;border:none;color:var(--text-m);cursor:pointer;padding:4px;border-radius:4px;
  display:flex;align-items:center;
}
.voice-popover-close:hover{background:rgba(255,255,255,.08)}
.voice-popover-status{padding:8px 12px 0;font-size:11px;color:var(--text-s);line-height:1.4}
.voice-popover-meta{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px}
.voice-popover-actions{
  display:flex;align-items:center;gap:6px;padding:8px 12px 10px;border-top:1px solid var(--border);
}

.gemini-live-panel{
  margin-bottom:10px;border:1px solid var(--border);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(37,99,235,.06),rgba(8,145,178,.03));
  transition:background .2s ease;
}
.gemini-live-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.gemini-live-copy{min-width:0;flex:1}
.gemini-live-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.gemini-live-title{font-size:13px;font-weight:700;color:var(--text)}
.gemini-live-subtitle{margin-top:4px;font-size:11px;line-height:1.45;color:var(--text-s)}
.gemini-live-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}
.gemini-live-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.gemini-live-pill{
  display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;
  font-size:10px;font-weight:700;letter-spacing:.04em;border:1px solid rgba(125,211,252,.16);
  background:rgba(15,23,42,.26);color:var(--text-s)
}
.gemini-live-badge{
  display:inline-flex;align-items:center;padding:3px 9px;border-radius:999px;
  font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid transparent;
}
.gemini-live-badge-idle{background:rgba(113,113,122,.12);border-color:rgba(113,113,122,.18);color:var(--text-m)}
.gemini-live-badge-live{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.2);color:var(--green)}
.gemini-live-badge-busy{background:rgba(37,99,235,.12);border-color:rgba(37,99,235,.2);color:var(--blue)}
.gemini-live-badge-error{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.2);color:var(--red)}
.gemini-live-transcript{
  display:flex;flex-direction:column;gap:6px;max-height:160px;overflow:auto;
  padding:8px 12px;flex:1;min-height:0;
}
.gemini-live-empty{font-size:12px;color:var(--text-m)}
.gemini-live-line{
  display:flex;gap:10px;padding:8px 10px;border-radius:10px;background:rgba(0,0,0,.12);
  border:1px solid rgba(255,255,255,.05);
}
.gemini-live-line-user{background:rgba(30,27,75,.28);border-color:rgba(129,140,248,.18)}
.gemini-live-line-agent{background:rgba(17,24,39,.32);border-color:rgba(56,189,248,.16)}
.gemini-live-line-draft{opacity:.72}
.gemini-live-speaker{width:68px;flex-shrink:0;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-m)}
.gemini-live-line-user .gemini-live-speaker{color:#c4b5fd}
.gemini-live-line-agent .gemini-live-speaker{color:#7dd3fc}
.gemini-live-text{font-size:12px;line-height:1.5;color:var(--text-s);white-space:pre-wrap}

/* ── Sidebar channel status dots ───────────────────────────── */
.status-dot{
  width:7px;height:7px;border-radius:50%;display:inline-block;margin-left:auto;flex-shrink:0;
  background:var(--text-m);opacity:.4;
}
.status-dot.online{background:var(--green);opacity:1}
.status-dot.offline{background:var(--text-m);opacity:.4}

/* ── Input area ────────────────────────────────────────────── */
.input-area{padding:12px 20px 16px;border-top:1px solid var(--border);flex-shrink:0;background:var(--bg)}
.input-area > *{width:min(100%,var(--chat-max-width));margin-left:auto;margin-right:auto}
.input-wrap{
  display:flex;align-items:flex-end;gap:0;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:4px;transition:border-color var(--ease),box-shadow var(--ease);
}
.input-wrap.voice-chat-active{gap:6px}
.input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.input-actions{display:flex;align-items:center;gap:2px;padding:0 4px}
.input-icon{
  position:relative;background:none;border:none;color:var(--text-m);cursor:pointer;padding:8px;
  border-radius:var(--radius-xs);display:flex;align-items:center;
  transition:color var(--ease),background var(--ease);
}
.input-icon:hover{color:var(--text);background:var(--surface-h)}
.input-icon.has-attachments{color:var(--accent-h);background:var(--accent-sub)}
.input-icon.is-recording{color:#fff;background:var(--red)}
.input-icon.is-recording:hover{color:#fff;background:#f87171}
.input-icon.is-recording::after{
  content:'';position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:999px;
  background:rgba(255,255,255,.94);box-shadow:0 0 0 0 rgba(255,255,255,.5);animation:recordPulse 1.2s infinite;
}
.input-icon svg{width:18px;height:18px}
.input-icon-badge{position:absolute;top:1px;right:1px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--accent);color:#fff;font-size:10px;font-weight:800;line-height:16px;text-align:center;box-shadow:0 2px 8px rgba(79,70,229,.25)}
#input{
  flex:1;background:transparent;border:none;outline:none;color:var(--text);
  font-family:inherit;font-size:15px;line-height:1.5;resize:none;padding:8px 4px;
  max-height:180px;min-height:24px;
}
body.voice-chat-active #input{flex:0 1 320px;max-width:320px}
#input::placeholder{color:var(--text-m)}
#send{
  width:38px;height:38px;border:none;background:var(--accent);color:#fff;
  border-radius:var(--radius-s);cursor:pointer;display:flex;align-items:center;
  justify-content:center;transition:all var(--ease);flex-shrink:0;
}
#send:hover{background:var(--accent-h)}
#send:disabled{opacity:.35;cursor:not-allowed}
#send.is-stop{background:var(--red)}
#send.is-stop:hover{background:#f87171}
#send svg{width:16px;height:16px}
.composer-meta-row{display:flex;justify-content:center;margin-top:6px;min-height:18px}
.composer-meta-main{display:inline-flex;align-items:center;justify-content:center;gap:12px;max-width:100%;min-width:0;white-space:nowrap}
.composer-meta-separator{font-size:11px;color:var(--text-m);opacity:.4;flex-shrink:0}
.composer-mode-link{
  display:inline-flex;align-items:center;gap:4px;padding:0;border:none;background:none;
  color:var(--text-s);cursor:pointer;transition:color var(--ease);font:inherit;
  font-size:12px;line-height:1.2;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;
}
.composer-mode-link:hover{color:var(--accent-h)}
.composer-mode-link-label{color:var(--text-m)}
.composer-mode-link-value{font-weight:600;color:inherit;white-space:nowrap}
.composer-shortcuts{font-size:11px;color:var(--text-m);opacity:.68;overflow:hidden;text-overflow:ellipsis}
.input-hint{text-align:center;font-size:11px;color:var(--text-m);margin-top:6px;opacity:.5}
@keyframes recordPulse{0%{transform:scale(.9);box-shadow:0 0 0 0 rgba(255,255,255,.45)}70%{transform:scale(1);box-shadow:0 0 0 8px rgba(255,255,255,0)}100%{transform:scale(.95);box-shadow:0 0 0 0 rgba(255,255,255,0)}}

@media (max-width: 880px){
  .voice-ia-btn{min-width:0;padding:0 10px}
  body.voice-chat-active #input{flex:1 1 auto;max-width:none}
}

@media (max-width: 640px){
  .voice-ia-btn-label{display:none}
}

/* ── Modal ─────────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;background:var(--overlay);z-index:100;display:none;
  align-items:center;justify-content:center;animation:fadeIn .15s ease;
}
.modal-overlay.open{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  width:520px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;
  box-shadow:var(--shadow);animation:modalIn .2s ease;
}
.modal.modal-medium{width:620px;max-width:92vw;border-radius:10px}
@keyframes modalIn{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}
.modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px 12px;border-bottom:1px solid var(--border);
}
.modal-head h3{font-size:16px;font-weight:700}
.modal-close{
  background:none;border:none;color:var(--text-m);cursor:pointer;padding:4px;
  border-radius:4px;display:flex;align-items:center;transition:color var(--ease);
}
.modal-close:hover{color:var(--text)}
.modal-close svg{width:18px;height:18px}
.modal-body{flex:1;overflow-y:auto;padding:16px 20px}
.modal-foot{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}
.btn{
  padding:8px 16px;border-radius:var(--radius-xs);font-size:13px;font-weight:600;
  cursor:pointer;transition:all var(--ease);font-family:inherit;border:1px solid var(--border);
}
.btn-ghost{background:transparent;color:var(--text-s)}
.btn-ghost:hover{background:var(--surface-h);color:var(--text)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-h)}

/* Browse list */
.browse-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:10px}
.browse-path-input{flex:1;min-width:0}
.browse-crumb{
  font-size:12px;font-family:var(--mono);color:var(--text-m);padding:8px 0 12px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.browse-list{max-height:300px;overflow-y:auto}
.browse-item{
  display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-xs);
  font-size:13px;color:var(--text-s);cursor:pointer;transition:all var(--ease);
}
.browse-item:hover{background:var(--accent-sub);color:var(--text)}
.browse-item.selected{background:var(--accent-sub);color:var(--accent-h);font-weight:600;
  border:1px solid var(--accent)}
.browse-item svg{width:16px;height:16px;flex-shrink:0;color:var(--text-m)}
.browse-up{color:var(--accent-h);font-weight:600}
.op-mode-modal .modal-body{padding:18px 20px 16px}
.op-mode-modal-state{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px;color:var(--text-m);margin:14px 0 8px;padding:10px 12px;background:var(--bg-panel);border:1px solid var(--border);border-radius:10px}
.op-mode-modal-current{font-size:13px;line-height:1.45;color:var(--text);margin-bottom:14px;font-weight:600}
.op-mode-list{display:flex;flex-direction:column;gap:8px}

/* ── Mission Plan Panel ─────────────────────────────────────── */
.mission-plan-panel{
  margin:8px 0;border-radius:12px;border:1px solid var(--border);
  background:var(--bg-panel);overflow:hidden;font-size:13px;
  animation:mp-slideIn .3s ease;
}
.mission-plan-panel.is-finalized{border-color:rgba(16,185,129,.28);box-shadow:0 0 0 1px rgba(16,185,129,.08) inset}
.mission-plan-panel.is-finalized.is-failed{border-color:rgba(239,68,68,.28);box-shadow:0 0 0 1px rgba(239,68,68,.08) inset}
@keyframes mp-slideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.mp-header{cursor:pointer;padding:10px 14px 8px;-webkit-user-select:none;user-select:none}
.mp-title-row{display:flex;align-items:center;gap:8px}
.mp-title{font-weight:700;font-size:14px;color:var(--text)}
.mp-progress-badge{
  background:var(--accent);color:#fff;font-size:11px;font-weight:700;
  padding:2px 8px;border-radius:10px;min-width:36px;text-align:center;
}
.mp-status-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap}
.mp-status-done{background:#d1fae5;color:#065f46}
.mp-status-failed{background:#fee2e2;color:#991b1b}
.mp-toggle-icon{font-size:10px;color:var(--text-m);margin-left:auto}
.mp-progress-bar-wrap{
  height:4px;background:var(--bg-input);border-radius:2px;margin:6px 0 4px;overflow:hidden;
}
.mp-progress-bar{
  height:100%;background:linear-gradient(90deg,var(--accent),#10b981);
  border-radius:2px;transition:width .4s ease;
}
.mp-phases{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.mp-phase-chip{
  font-size:11px;padding:2px 8px;border-radius:8px;
  background:var(--bg-input);color:var(--text-m);white-space:nowrap;
}
.mp-phase-pending{opacity:.6}
.mp-phase-running{background:var(--accent-sub);color:var(--accent-h);font-weight:600}
.mp-phase-done{background:#d1fae5;color:#065f46}
.mp-phase-failed{background:#fee2e2;color:#991b1b}
.mp-body{padding:0 14px 10px}
.mp-summary{margin:8px 0 10px;padding:9px 10px;border-radius:8px;font-size:12px;line-height:1.45}
.mp-summary-done{background:#ecfdf5;color:#065f46;border:1px solid rgba(16,185,129,.18)}
.mp-summary-failed{background:#fef2f2;color:#991b1b;border:1px solid rgba(239,68,68,.18)}
.mp-plan-graph{
  margin:8px 0 12px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);
  background:linear-gradient(180deg,color-mix(in oklab, var(--bg-panel) 88%, white),var(--bg-panel));
}
.mp-vnext-shell{
  margin:8px 0 12px;padding:12px;border-radius:10px;border:1px solid color-mix(in oklab, var(--accent) 22%, var(--border));
  background:linear-gradient(135deg,color-mix(in oklab, var(--accent-sub) 72%, white),color-mix(in oklab, var(--bg-panel) 90%, white));
}
.mp-vnext-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-bottom:10px}
.mp-vnext-metric{padding:8px 10px;border-radius:8px;background:rgba(255,255,255,.55);border:1px solid color-mix(in oklab, var(--accent) 12%, var(--border));display:flex;flex-direction:column;gap:4px}
.mp-vnext-metric-label{font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-m);font-weight:700}
.mp-vnext-reorder{margin:0 0 10px;font-size:12px;line-height:1.5;color:var(--text)}
.mp-vnext-section + .mp-vnext-section{margin-top:10px}
.mp-vnext-section-title{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-m);margin-bottom:6px}
.mp-vnext-worker-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}
.mp-vnext-worker-card{padding:10px;border-radius:8px;background:rgba(255,255,255,.58);border:1px solid var(--border)}
.mp-vnext-worker-title{font-size:12px;font-weight:700;color:var(--text)}
.mp-vnext-worker-meta{margin-top:4px;font-size:11px;line-height:1.45;color:var(--text-m)}
.mp-vnext-worker-tiers{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.mp-vnext-wave-list{display:flex;flex-direction:column;gap:8px}
.mp-vnext-wave{padding:10px;border-radius:8px;background:rgba(255,255,255,.5);border:1px solid var(--border)}
.mp-vnext-wave.is-current{border-color:color-mix(in oklab, var(--accent) 30%, var(--border));box-shadow:0 0 0 1px color-mix(in oklab, var(--accent) 15%, transparent) inset}
.mp-vnext-wave-title{font-size:12px;font-weight:700;color:var(--text)}
.mp-vnext-wave-tasks,.mp-vnext-chiplist{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.mp-vnext-wave-agents{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.mp-vnext-chip,.mp-vnext-wave-agent{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600}
.mp-vnext-chip{background:rgba(255,255,255,.78);border:1px solid var(--border);color:var(--text)}
.mp-vnext-chip.is-blocked{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.mp-vnext-wave-agent{background:var(--accent-sub);color:var(--accent-h)}
.mp-plan-graph-title{
  font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:var(--text-m);margin-bottom:8px;
}
.mp-tree-root,.mp-tree-task-list{list-style:none;margin:0;padding:0}
.mp-tree-phase{position:relative}
.mp-tree-phase + .mp-tree-phase{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}
.mp-tree-phase-head{display:flex;align-items:flex-start;gap:10px}
.mp-tree-phase-node{
  width:28px;height:28px;border-radius:999px;border:1px solid var(--border);
  display:inline-flex;align-items:center;justify-content:center;background:var(--bg-input);flex-shrink:0;
}
.mp-tree-phase-body{flex:1;min-width:0}
.mp-tree-phase-title{font-size:12px;font-weight:700;color:var(--text)}
.mp-tree-phase-objective{font-size:11px;line-height:1.45;color:var(--text-m);margin-top:2px}
.mp-tree-task-list{margin:8px 0 0 38px;display:flex;flex-direction:column;gap:6px}
.mp-tree-task{display:flex;align-items:flex-start;gap:8px;position:relative}
.mp-tree-branch{position:relative;width:14px;flex-shrink:0;align-self:stretch}
.mp-tree-branch::before{
  content:'';position:absolute;left:6px;top:-8px;bottom:8px;width:1px;background:var(--border);
}
.mp-tree-branch::after{
  content:'';position:absolute;left:6px;top:11px;width:12px;height:1px;background:var(--border);
}
.mp-tree-task.is-last .mp-tree-branch::before{bottom:11px}
.mp-tree-task-icon{
  width:22px;height:22px;border-radius:999px;border:1px solid var(--border);
  display:inline-flex;align-items:center;justify-content:center;background:var(--surface);font-size:12px;flex-shrink:0;
}
.mp-tree-task-body{
  flex:1;min-width:0;padding:6px 8px;border-radius:8px;background:var(--bg-input);border:1px solid transparent;
}
.mp-tree-task-title{display:flex;gap:6px;flex-wrap:wrap;font-size:12px;line-height:1.4;color:var(--text)}
.mp-tree-task-index{font-weight:700;color:var(--accent)}
.mp-tree-task-meta{font-size:11px;color:var(--text-m);margin-top:2px}
.mp-tree-task.mp-task-running .mp-tree-task-body{border-color:var(--accent);background:var(--accent-sub)}
.mp-tree-task.mp-task-failed .mp-tree-task-body{border-color:#fca5a5;background:#fff1f2}
.mp-tree-task.mp-task-done .mp-tree-task-body{background:#f7fdf9}
.mp-task-row{
  display:flex;flex-direction:column;gap:2px;padding:8px 10px;
  border-radius:8px;margin:4px 0;transition:background .2s,border-color .2s;
  border:1px solid transparent;
}
.mp-task-row:hover{background:var(--bg-input)}
.mp-task-running{border-color:var(--accent);background:var(--accent-sub);animation:mp-pulse 2s infinite}
@keyframes mp-pulse{0%,100%{opacity:1}50%{opacity:.85}}
.mp-task-done{opacity:.85}
.mp-task-failed{border-color:#fca5a5;background:#fef2f2}
.mp-task-pending{opacity:.7}
.mp-task-main{display:flex;align-items:center;gap:6px}
.mp-task-icon{font-size:14px;flex-shrink:0}
.mp-task-emoji{font-size:14px;flex-shrink:0}
.mp-task-objective{flex:1;color:var(--text);line-height:1.4}
.mp-task-meta{display:flex;gap:8px;font-size:11px;color:var(--text-m);margin-left:32px}
.mp-task-agent{font-weight:600}
.mp-task-duration,.mp-task-steps{opacity:.8}
.mp-task-detail{font-size:11px;color:var(--text-m);margin-left:32px;font-style:italic}
.mp-task-report{font-size:11px;color:var(--text-m);margin-left:32px;max-height:60px;overflow:hidden;text-overflow:ellipsis}
.mp-inject-row{display:flex;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.mp-inject-input{
  flex:1;padding:6px 10px;border-radius:8px;border:1px solid var(--border);
  background:var(--bg-input);color:var(--text);font-size:12px;outline:none;
}
.mp-inject-input:focus{border-color:var(--accent)}
.mp-inject-btn{
  padding:6px 14px;border-radius:8px;border:none;
  background:var(--accent);color:#fff;font-size:12px;font-weight:600;
  cursor:pointer;white-space:nowrap;
}
.mp-inject-btn:hover{filter:brightness(1.1)}
/* ── Estados del composer compartido (Send / Stop / Inject) ── */
#send.is-inject{
  background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;
}
#send.is-inject:hover{filter:brightness(1.1)}
.input-area.is-injecting .input-wrap{
  border-color:#7c3aed;
  box-shadow:0 0 0 2px color-mix(in oklab, #7c3aed 25%, transparent);
}
.mp-task-parallel{
  font-size:10px;padding:1px 6px;border-radius:6px;
  background:linear-gradient(90deg,#dbeafe,#e0e7ff);color:#3730a3;
  font-weight:600;white-space:nowrap;
}
/* Per-task progress bar */
.mp-task-progress-wrap{
  display:flex;align-items:center;gap:6px;margin:2px 0 2px 32px;
}
.mp-task-progress-wrap .mp-task-progress-bar{
  height:3px;background:linear-gradient(90deg,var(--accent),#10b981);
  border-radius:2px;transition:width .3s ease;
}
.mp-task-progress-track{
  flex:1;height:3px;background:var(--bg-input);border-radius:2px;overflow:hidden;
}
.mp-task-progress-label{font-size:10px;color:var(--text-m);white-space:nowrap}
/* Expandable task detail */
.mp-task-expand{
  max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;
  margin-left:32px;font-size:11px;color:var(--text-m);
}
.mp-task-expand-open{max-height:300px;padding:6px 0 2px;overflow-y:auto}
.mp-expand-tools,.mp-expand-files{margin-bottom:3px}
.mp-expand-tools strong,.mp-expand-files strong{color:var(--text);font-weight:600}
.mp-expand-report{white-space:pre-wrap;word-break:break-word;margin-top:4px;padding:4px 8px;background:var(--bg-input);border-radius:6px;max-height:150px;overflow-y:auto}
.mp-expand-hint{color:var(--accent);font-weight:600;cursor:pointer}
.mp-task-report-preview{font-size:11px;color:var(--text-m);margin-left:32px;max-height:60px;overflow:hidden;text-overflow:ellipsis;cursor:pointer}
.mp-task-row{cursor:pointer}
/* Injection type selector & parallelism control */
.mp-inject-type{
  padding:4px 6px;border-radius:8px;border:1px solid var(--border);
  background:var(--bg-input);color:var(--text);font-size:11px;outline:none;
}
.mp-parallel-row{
  display:flex;align-items:center;gap:6px;margin-top:4px;font-size:11px;color:var(--text-m);
}
.mp-parallel-label{white-space:nowrap;font-weight:600}
.mp-parallel-select{
  padding:2px 6px;border-radius:6px;border:1px solid var(--border);
  background:var(--bg-input);color:var(--text);font-size:11px;outline:none;
}
.mp-readonly-note{margin-top:10px;padding-top:8px;border-top:1px solid var(--border);font-size:11px;color:var(--text-m)}
.op-mode-option{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;text-align:left;padding:12px 14px;
  border:1px solid var(--border);border-radius:10px;background:var(--surface);
  color:var(--text);cursor:pointer;transition:all var(--ease);font-family:inherit;
}
.op-mode-option:hover{border-color:var(--border-h);background:var(--surface-h)}
.op-mode-option.active{border-color:rgba(59,130,246,.36);background:rgba(59,130,246,.08);box-shadow:none}
.op-mode-option-body{display:flex;flex-direction:column;gap:6px;min-width:0}
.op-mode-option-title{font-size:13px;font-weight:700;color:var(--text)}
.op-mode-option-copy{font-size:12px;line-height:1.45;color:var(--text-m)}
.op-mode-option-example{opacity:.65;font-style:italic}
.op-mode-option-badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;border:1px solid var(--border);font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-m);flex-shrink:0}
.op-mode-option.active .op-mode-option-badge{border-color:rgba(59,130,246,.28);color:var(--blue);background:rgba(59,130,246,.08)}

/* ── Responsive ────────────────────────────────────────────── */
@media(max-width:768px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;z-index:50;
    box-shadow:var(--shadow)}
  .sidebar.collapsed{margin-left:-280px}
  .topbar{padding:10px 12px}
  .topbar-runtime-alert{padding:10px 12px;align-items:flex-start;flex-direction:column;gap:8px}
  .chat-tabs{padding:10px 12px;align-items:stretch;flex-direction:column}
  .chat-tabs-list{width:100%}
  .chat-tab{min-width:200px}
  .chat-tabs-add{width:100%;justify-content:center}
  .topbar-runtime-text{white-space:normal;overflow:visible;text-overflow:clip}
  .topbar-model{display:none}
  .messages{padding:16px 12px}
  .input-area{padding:10px 12px 14px}
  .gemini-live-head{flex-direction:column;align-items:stretch}
  .gemini-live-meta-row{justify-content:flex-start}
  .gemini-live-actions{justify-content:flex-start}
  .gemini-live-transcript{max-height:140px}
  .empty{min-height:50vh}
  .suggestions{flex-direction:column;align-items:center}
  .assistant-footer{gap:8px;align-items:center}
  .assistant-meta-group{gap:6px}
  .assistant-inline-meta{max-width:100%}
  .assistant-actions{justify-content:flex-end;gap:4px}
  .rich-block{padding:12px}
  .rich-chart-svg{min-width:520px}
  .rich-stats-grid{grid-template-columns:1fr}
  .thinking-panel{padding:11px 12px}
  .thinking-header{flex-direction:column;align-items:flex-start;gap:8px}
  .usage-grid{grid-template-columns:1fr}
  .reliability-hero{grid-template-columns:1fr}
  .reliability-score{align-items:flex-start;text-align:left}
  .config-tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:10px}
  .config-tab-btn{white-space:nowrap}
  .config-form-grid,.persona-grid{grid-template-columns:1fr}
  .config-actions-row{justify-content:flex-start}
  .config-actions-row .btn{width:100%}
  .composer-meta-row{justify-content:flex-start}
  .composer-meta-main{flex-wrap:wrap;justify-content:flex-start;gap:6px;width:100%;white-space:normal}
  .composer-meta-separator{display:none}
  .composer-shortcuts{width:100%;text-align:left}
  .composer-mode-link{width:100%;justify-content:flex-start}
}

