:root{--bg:linear-gradient(180deg,#020712 0%,#071229 100%);--surface:rgba(8,14,26,0.6);--muted:#8b94a6;--accent:#00e0ff;--accent-2:#7c5cff;--glass:rgba(255,255,255,0.04);--glass-border:rgba(120,180,255,0.06);--lower-banner-reserve:88px}
*{box-sizing:border-box}html{height:100%;overflow:hidden}body{height:100vh;height:100dvh;margin:0;overflow:hidden;font-family: 'Orbitron', Inter, system-ui, -apple-system, 'Segoe UI', Roboto, Arial; background:var(--bg); color:#dfe9ff}
[hidden]{display:none!important}
.login-body{height:auto;min-height:100vh;min-height:100dvh;overflow:auto;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 50% 22%,rgba(0,224,255,0.12),transparent 28%),var(--bg)}
.login-shell{width:min(420px,100%);border:1px solid rgba(255,255,255,0.08);background:linear-gradient(180deg,rgba(8,14,26,0.82),rgba(2,7,18,0.94));box-shadow:0 28px 80px rgba(0,0,0,0.46),0 0 42px rgba(0,224,255,0.055);border-radius:8px;overflow:hidden}
.login-panel{min-height:min(620px,calc(100vh - 48px));min-height:min(620px,calc(100dvh - 48px));padding:36px 30px;display:flex;flex-direction:column;background:rgba(0,0,0,0.13)}
.login-status-dot.error{background:#ff5f7a;box-shadow:0 0 12px rgba(255,95,122,0.65)}
.login-error-shell{grid-template-columns:1fr;width:min(520px,100%)}
.login-error-shell .login-panel{min-height:0}
.login-error-shell .login-actions{margin-top:0}
.login-brand{display:flex;flex-direction:column;gap:10px;align-items:center;text-align:center;margin:auto 0}
.login-mark{width:160px;height:160px;border-radius:8px;object-fit:cover;display:block;border:1px solid rgba(0,224,255,0.16);box-shadow:0 16px 36px rgba(0,224,255,0.14);background:rgba(0,0,0,0.22)}
.login-bob-mark{display:grid;place-items:center;overflow:hidden}
.login-bob-mark .login-bob-face{width:100%;height:100%}
.login-brand h1{margin:4px 0 0;font-size:30px;color:#f1f6ff;letter-spacing:0}
.login-brand p,.login-note{margin:0;color:#b9c6dd;font-size:15px;line-height:1.45}
.login-actions{display:grid;gap:11px;margin-top:auto}
.login-primary,.login-secondary,.login-privacy-trigger{min-height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;font-weight:700;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}
.login-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#00121a;box-shadow:0 10px 24px rgba(0,224,255,0.14)}
.login-secondary{border:1px solid rgba(0,224,255,0.22);background:rgba(0,224,255,0.05);color:var(--accent)}
.login-privacy-trigger{border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.025);color:#cdd8ec;font:inherit;font-size:13px;cursor:pointer}
.login-primary:hover,.login-secondary:hover,.login-privacy-trigger:hover{transform:translateY(-1px)}
.login-primary:hover{box-shadow:0 14px 30px rgba(0,224,255,0.18)}
.login-secondary:hover{border-color:rgba(0,224,255,0.36);background:rgba(0,224,255,0.085)}
.login-privacy-trigger:hover{border-color:rgba(0,224,255,0.24);background:rgba(0,224,255,0.055);color:#f1f6ff}
.login-privacy-list{display:grid;gap:8px;margin-top:14px}
.login-privacy-list span{min-height:34px;display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.025);color:#dfe9ff;font-size:12px}
.login-privacy-list .lucide{color:var(--accent);width:16px;height:16px}
.app{display:flex;width:100vw;height:100vh;height:100dvh;overflow:hidden;backdrop-filter: blur(6px);padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}
.sidebar{width:300px;background:linear-gradient(180deg, rgba(12,18,30,0.8), rgba(6,10,20,0.7));border-right:1px solid rgba(255,255,255,0.03);padding:20px;display:flex;flex-direction:column;box-shadow:inset 0 1px 0 rgba(255,255,255,0.02)}
.sidebar h2{margin:0 0 14px 0;color:var(--accent)}
.settings input{background:transparent;border:1px solid rgba(255,255,255,0.06);padding:8px;border-radius:6px;color:var(--muted);width:100%;margin-top:6px}
.footer{font-size:12px;color:var(--muted);margin-top:auto}
.main{flex:1;min-width:0;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding:20px;gap:14px;transition:margin-right 240ms ease}
.main.panel-open{margin-right:0}
.main-content{flex:1;min-height:0;min-width:0;display:flex;flex-direction:column}

/* Chat Container */
.chat-container{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden;gap:16px}
.chat-header{padding:16px 0;border-bottom:1px solid rgba(255,255,255,0.05)}
.chat-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}
.chat-header h1{margin:0;font-size:24px;background:linear-gradient(90deg, var(--accent), var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.chat-header .subtitle{margin:4px 0 0 0;color:var(--muted);font-size:13px}
.chat-clear-btn{width:48px;height:48px;border-radius:10px;border:1px solid rgba(255,95,122,0.16);background:rgba(255,95,122,0.05);color:#dfe9ff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 48px}
.chat-clear-btn:hover{border-color:rgba(255,95,122,0.4);background:rgba(255,95,122,0.12);color:#ff8ca0}
.hal-dialog-overlay{position:fixed;inset:0;z-index:30000;display:grid;place-items:center;padding:20px;background:rgba(2,7,18,0.68);backdrop-filter:blur(8px);opacity:0;transition:opacity 140ms ease}
.hal-dialog-overlay.open{opacity:1}
.hal-dialog{width:min(420px,100%);border:1px solid rgba(255,255,255,0.08);border-radius:8px;background:linear-gradient(180deg,rgba(8,14,26,0.96),rgba(2,7,18,0.98));box-shadow:0 24px 80px rgba(0,0,0,0.48),0 0 34px rgba(0,224,255,0.08);padding:18px;color:#dfe9ff;transform:translateY(8px);transition:transform 140ms ease}
.hal-dialog-overlay.open .hal-dialog{transform:translateY(0)}
.hal-dialog-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.hal-dialog-mark{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;border:1px solid rgba(0,224,255,0.18);background:rgba(0,224,255,0.06);color:var(--accent);flex:0 0 auto}
.hal-dialog h2{margin:0;color:#f1f6ff;font-size:16px;letter-spacing:0}
.hal-dialog p{margin:0;color:#cdd8ec;font-size:13px;line-height:1.5;white-space:pre-wrap;max-height:min(58vh,520px);overflow:auto}
.hal-dialog-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.hal-dialog-actions button{min-height:38px;padding:8px 13px;border-radius:8px;font:inherit;font-size:13px;cursor:pointer}
.hal-dialog-secondary{border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03);color:#dfe9ff}
.hal-dialog-secondary:hover{border-color:rgba(0,224,255,0.24);background:rgba(0,224,255,0.06);color:var(--accent)}
.hal-dialog-primary{border:1px solid rgba(0,224,255,0.28);background:rgba(0,224,255,0.1);color:#bff9ff;font-weight:700}
.hal-dialog-primary:hover{background:rgba(0,224,255,0.16);color:#f1fcff}
.hal-dialog-primary.danger{border-color:rgba(255,95,122,0.32);background:rgba(255,95,122,0.12);color:#ffd8df}
.hal-dialog-primary.danger:hover{background:rgba(255,95,122,0.2);color:#fff}
.bob-memory-overlay{position:fixed;inset:0;z-index:41000;display:grid;place-items:center;padding:24px;background:rgba(2,7,18,0.42);backdrop-filter:blur(6px)}
.bob-memory-dialog{width:min(1180px,calc(100vw - 48px));max-height:calc(100vh - 72px);display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:8px;border:1px solid rgba(0,224,255,0.24);background:#08111f;box-shadow:0 24px 80px rgba(0,0,0,0.54),0 0 34px rgba(0,224,255,0.08);opacity:.75;color:#dfe9ff}
.bob-memory-header{display:flex;align-items:center;gap:10px;min-height:34px}
.bob-memory-mark{width:32px;height:32px;border-radius:8px;border:1px solid rgba(0,224,255,0.2);background:rgba(0,224,255,0.07);color:#bff9ff;display:grid;place-items:center;flex:0 0 auto}
.bob-memory-header h2{margin:0 auto 0 0;color:#f1f6ff;font-size:16px}
.bob-memory-merge,.bob-memory-wipe{min-height:30px;padding:5px 9px;border-radius:8px;font:inherit;font-size:12px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;white-space:nowrap}
.bob-memory-merge{border:1px solid rgba(0,224,255,0.28);background:rgba(0,224,255,0.08);color:#c9fbff}
.bob-memory-merge:hover:not(:disabled){border-color:rgba(0,224,255,0.5);background:rgba(0,224,255,0.14);color:#fff}
.bob-memory-wipe{border:1px solid rgba(255,95,122,0.28);background:rgba(255,95,122,0.09);color:#ffd8df}
.bob-memory-wipe:hover:not(:disabled){border-color:rgba(255,95,122,0.5);background:rgba(255,95,122,0.16);color:#fff}
.bob-memory-merge:disabled,.bob-memory-wipe:disabled{opacity:.55;cursor:wait}
.bob-memory-close{width:30px;height:30px;border-radius:8px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.04);color:#dfe9ff;display:grid;place-items:center;cursor:pointer}
.bob-memory-close:hover{border-color:rgba(0,224,255,0.3);background:rgba(0,224,255,0.1);color:#bff9ff}
.bob-memory-grid{min-height:0;display:grid;grid-template-columns:minmax(0,1.45fr) minmax(0,1fr);grid-template-rows:minmax(190px,1fr) minmax(130px,.72fr) minmax(130px,.72fr);grid-template-areas:"chat facts" "short medium" "long long";gap:8px;overflow:hidden}
.bob-memory-section{min-width:0;min-height:0;display:flex;flex-direction:column;gap:7px;padding:9px;border-radius:8px;border:1px solid rgba(255,255,255,0.07);background:rgba(0,0,0,0.2)}
.bob-memory-section h3{margin:0;color:#bff9ff;font-size:12px;text-transform:uppercase}
.bob-memory-chat{grid-area:chat}
.bob-memory-facts{grid-area:facts}
.bob-memory-summary.short{grid-area:short}
.bob-memory-summary.medium{grid-area:medium}
.bob-memory-summary.long{grid-area:long}
.bob-memory-scroll{min-height:0;overflow:auto;display:flex;flex-direction:column;gap:5px}
.bob-memory-row,.bob-memory-factoid,.bob-memory-empty{min-width:0;padding:7px 8px;border-radius:8px;border:1px solid rgba(255,255,255,0.055);background:rgba(255,255,255,0.025)}
.bob-memory-row{display:grid;grid-template-columns:22px minmax(64px,.45fr) minmax(80px,.6fr) minmax(125px,.75fr) minmax(130px,.8fr) 34px minmax(0,2fr);gap:8px;align-items:center;border-left:3px solid rgba(0,224,255,0.42)}
.bob-memory-row.assistant{border-left-color:rgba(124,92,255,0.48)}
.bob-memory-row strong,.bob-memory-row span,.bob-memory-row time,.bob-memory-row p,.bob-memory-factoid strong,.bob-memory-factoid p,.bob-memory-factoid small{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bob-memory-row-merge{width:18px;height:18px;border-radius:999px;display:grid;place-items:center;color:#bff9ff;opacity:.22}
.bob-memory-row-merge.merged{border:1px solid rgba(0,224,255,0.35);background:rgba(0,224,255,0.1);box-shadow:0 0 10px rgba(0,224,255,0.18);opacity:1}
.bob-memory-row-merge svg{width:12px;height:12px}
.bob-memory-row-factoids{min-width:0;width:32px;height:20px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:3px;color:#ffcf9f;font-size:10px;font-weight:900;opacity:.28}
.bob-memory-row-factoids.has-factoids{border:1px solid rgba(255,154,90,0.34);background:rgba(255,154,90,0.09);opacity:1}
.bob-memory-row-factoids svg{width:11px;height:11px}
.bob-memory-row strong,.bob-memory-factoid strong{color:#f1f6ff;font-size:11px;text-transform:uppercase}
.bob-memory-row span,.bob-memory-row time,.bob-memory-factoid small{color:var(--muted);font-size:11px}
.bob-memory-row p,.bob-memory-factoid p{margin:0;color:#dfe9ff;font-size:12px}
.bob-memory-factoid{display:grid;grid-template-columns:minmax(84px,.55fr) minmax(0,1.6fr) minmax(150px,.9fr);gap:8px;align-items:center;border-left:3px solid rgba(255,154,90,0.44)}
.bob-memory-summary pre{min-height:0;flex:1;margin:0;padding:8px;border-radius:7px;border:1px solid rgba(255,255,255,0.06);background:rgba(0,0,0,0.22);color:#dfe9ff;font:12px/1.45 Consolas,'Courier New',monospace;white-space:pre-wrap;overflow:auto}
.bob-memory-summary small{color:var(--muted);font-size:11px}
.bob-memory-loading{min-height:180px;display:grid;place-items:center;color:var(--muted);font:13px/1.4 Consolas,'Courier New',monospace}
.entropy-overlay{position:fixed;inset:0;z-index:30010;display:grid;place-items:center;padding:18px;background:rgba(2,7,18,0.78);backdrop-filter:blur(10px);overscroll-behavior:contain;touch-action:none}
.entropy-dialog{width:min(520px,100%);border:1px solid rgba(0,224,255,0.16);border-radius:8px;background:linear-gradient(180deg,rgba(8,14,26,0.98),rgba(2,7,18,0.99));box-shadow:0 24px 80px rgba(0,0,0,0.52),0 0 34px rgba(0,224,255,0.09);padding:18px;color:#dfe9ff;display:grid;gap:13px}
.entropy-header{display:flex;align-items:center;gap:10px}
.entropy-header span{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;border:1px solid rgba(0,224,255,0.22);background:rgba(0,224,255,0.08);color:var(--accent)}
.entropy-header h2{margin:0;font-size:17px;color:#f1f6ff;letter-spacing:0}
.entropy-dialog p{margin:0;color:#cdd8ec;font-size:13px;line-height:1.5}
.entropy-pad{height:210px;border-radius:8px;border:1px solid rgba(0,224,255,0.2);background:linear-gradient(135deg,rgba(0,224,255,0.06),rgba(124,92,255,0.08)),rgba(0,0,0,0.24);position:relative;overflow:hidden;cursor:crosshair;outline:none;touch-action:none;overscroll-behavior:contain;user-select:none;-webkit-user-select:none}
.entropy-pad:focus{border-color:rgba(0,224,255,0.46);box-shadow:0 0 18px rgba(0,224,255,0.12)}
.entropy-trace{position:absolute;left:0;top:0;width:18px;height:18px;border-radius:50%;background:#00e0ff;box-shadow:0 0 18px rgba(0,224,255,0.72);transition:transform 80ms linear}
.entropy-meter{height:10px;border-radius:999px;background:rgba(255,255,255,0.06);overflow:hidden}
.entropy-meter span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width 120ms ease}
.entropy-dialog button{min-height:42px;border-radius:8px;border:1px solid rgba(0,224,255,0.22);background:rgba(0,224,255,0.08);color:#dfe9ff;font:inherit;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}
.entropy-dialog button:hover:not(:disabled){border-color:rgba(0,224,255,0.42);background:rgba(0,224,255,0.14);color:var(--accent)}
.entropy-dialog button:disabled{opacity:.5;cursor:not-allowed}

/* Messages Area */
.messages{flex:1;padding:16px;overflow:auto;background:transparent;display:flex;flex-direction:column;gap:12px}
.msg{position:relative;padding:14px 16px;border-radius:12px;max-width:72%;backdrop-filter:blur(4px);word-wrap:break-word;animation:slideIn 0.3s ease;display:flex;flex-direction:column;align-items:flex-start;gap:7px}
@keyframes slideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.msg.user{margin-left:auto;background:linear-gradient(135deg,#04213a,rgba(0,224,255,0.08));border:1px solid rgba(0,224,255,0.15);color:#bff9ff;border-radius:12px 2px 12px 12px}
.msg.bot{background:linear-gradient(135deg,rgba(124,92,255,0.08),rgba(0,0,0,0.02));border:1px solid rgba(124,92,255,0.12);color:#e8eaff;border-radius:2px 12px 12px 12px}
.msg.bot{cursor:pointer}
.msg.bot:hover,.msg.bot:focus-visible{border-color:rgba(183,167,255,0.34);background:linear-gradient(135deg,rgba(124,92,255,0.12),rgba(0,224,255,0.035));outline:none}
.msg.bot.memory-processed{border-color:rgba(155,164,180,0.52);background:linear-gradient(135deg,rgba(155,164,180,0.06),rgba(0,0,0,0.02));box-shadow:inset 0 0 0 1px rgba(155,164,180,0.08)}
.msg-body{white-space:pre-wrap;overflow-wrap:anywhere}
.msg-body a,.bob-chat-test-message a{color:#bff9ff;text-decoration:underline;text-underline-offset:2px}
.msg-body a:hover,.msg-body a:focus-visible,.bob-chat-test-message a:hover,.bob-chat-test-message a:focus-visible{color:#fff}
.skill-rail{position:absolute;left:12px;top:0;display:flex;gap:5px;max-width:calc(100% - 24px);transform:translateY(-50%);overflow:hidden}
.skill-pill{min-height:20px;max-width:100%;padding:3px 7px;border-radius:999px;border:1px solid rgba(0,224,255,0.22);background:rgba(0,224,255,0.075);color:#bff9ff;font:inherit;font-size:10px;font-weight:700;line-height:1.2;text-transform:uppercase;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
button.skill-pill{cursor:pointer}
button.skill-pill:hover{border-color:rgba(0,224,255,0.48);background:rgba(0,224,255,0.14);color:#fff}
.ollama-debug-rail{position:absolute;right:12px;bottom:0;display:flex;gap:5px;max-width:calc(100% - 24px);transform:translateY(50%);overflow:hidden}
.ollama-debug-pill{min-height:20px;max-width:100%;padding:3px 7px;border-radius:999px;border:1px solid rgba(255,154,90,0.3);background:rgba(255,154,90,0.085);color:#ffd8bd;font:inherit;font-size:10px;font-weight:700;line-height:1.2;text-transform:uppercase;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}
.ollama-debug-pill:hover{border-color:rgba(255,154,90,0.52);background:rgba(255,154,90,0.14);color:#fff}
.citation-rail{position:absolute;left:12px;bottom:0;display:flex;gap:5px;max-width:calc(100% - 24px);transform:translateY(50%);overflow:hidden}
.citation-pill{min-height:20px;max-width:100%;padding:3px 7px;border-radius:999px;border:1px solid rgba(126,231,135,0.28);background:rgba(126,231,135,0.085);color:#d8ffdc;font:inherit;font-size:10px;font-weight:700;line-height:1.2;text-transform:uppercase;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}
.citation-pill:hover{border-color:rgba(126,231,135,0.5);background:rgba(126,231,135,0.14);color:#fff}
.debug-copy-pill{border-color:rgba(183,167,255,0.34);background:rgba(183,167,255,0.1);color:#eee8ff}
.debug-copy-pill:hover{border-color:rgba(183,167,255,0.58);background:rgba(183,167,255,0.16)}

/* Voice Activity */
.voice-strip{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;align-items:stretch;padding:0 16px;flex:0 0 auto}
.voice-panel{height:158px;min-height:158px;max-height:158px;min-width:0;padding:10px;border:1px solid rgba(255,255,255,0.05);background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(0,0,0,0.02));display:flex;flex-direction:column;gap:8px;overflow:hidden}
.voice-panel.ai-voice{justify-self:stretch;width:100%;height:120px;min-height:120px;max-height:120px;border-radius:2px 12px 12px 12px;border-color:rgba(124,92,255,0.14);background:linear-gradient(135deg,rgba(124,92,255,0.08),rgba(0,0,0,0.02));display:grid;grid-template-columns:150px minmax(0,1fr);grid-template-rows:98px;column-gap:10px;row-gap:0;align-items:start}
.voice-panel.ai-voice.active{border-color:rgba(183,167,255,0.36);box-shadow:0 0 18px rgba(124,92,255,0.14)}
.voice-label{min-height:32px;display:flex;align-items:center;gap:7px;color:var(--muted);font-size:12px;text-transform:uppercase}
.voice-label-row{justify-content:space-between;gap:10px;min-width:0}
.voice-panel.ai-voice .voice-label-row{grid-column:1;grid-row:1;min-height:0;display:grid;grid-template-columns:minmax(0,98px) 42px;grid-template-rows:minmax(0,98px);align-items:center;justify-content:center;gap:8px}
.voice-label-row span{display:inline-flex;align-items:center;gap:7px;min-width:0}
.bob-voice-title{font-weight:700;color:#f2efff}
.voice-panel.ai-voice .bob-voice-title{position:relative;width:98px;height:98px;display:grid;place-items:stretch;overflow:hidden;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,0,0,0.2);box-shadow:0 0 18px rgba(0,224,255,0.14);line-height:1;color:transparent;grid-column:1;grid-row:1}
.voice-panel.ai-voice .bob-voice-title{cursor:pointer}
.voice-panel.ai-voice .bob-voice-title:focus-visible{outline:2px solid rgba(0,224,255,0.7);outline-offset:3px}
.voice-panel.ai-voice .bob-voice-title::after{content:'';position:absolute;inset:11px 43px;border-radius:999px;background:#ff5f7a;box-shadow:0 0 14px rgba(255,95,122,0.55);opacity:0;transform:rotate(-42deg) scaleY(0.2);transition:opacity 140ms ease,transform 140ms ease;pointer-events:none}
.bob-brain-btn{width:36px;height:36px;border-radius:8px;border:1px solid rgba(0,224,255,0.2);background:rgba(0,224,255,0.07);color:#dfe9ff;display:grid;place-items:center;cursor:pointer;flex:0 0 auto}
.bob-brain-btn:hover,.bob-brain-btn:focus-visible{outline:none;border-color:rgba(0,224,255,0.42);background:rgba(0,224,255,0.14);color:#bff9ff}
.bob-brain-btn.compact{width:30px;height:30px}
.bob-muted .voice-panel.ai-voice .bob-voice-title{border-color:rgba(255,95,122,0.42);box-shadow:0 0 18px rgba(255,95,122,0.18)}
.bob-muted .voice-panel.ai-voice .bob-voice-title::after{opacity:1;transform:rotate(-42deg) scaleY(1)}
.bob-muted .voice-panel.ai-voice .bob-face{opacity:.54}
.bob-muted .bob-face #bobMouth{stroke:#ffcfda!important;stroke-width:10!important;stroke-dasharray:8 10!important;stroke-linecap:round!important;filter:drop-shadow(0 0 5px rgba(255,95,122,0.62))}
.bob-face-shell{position:relative;width:32px;height:32px;border-radius:8px;display:inline-grid;place-items:center;flex:0 0 32px;box-shadow:0 0 16px rgba(0,224,255,0.16);background:rgba(0,0,0,0.18);opacity:var(--bob-glow,.78)}
.voice-panel.ai-voice .bob-face-shell{width:100%;height:100%;border-radius:0;box-shadow:none;background:transparent;opacity:var(--bob-glow,.78);flex:1 1 auto}
.bob-face{width:32px;height:32px;display:block;overflow:visible;transform-origin:50% 50%;transition:transform 180ms ease}
.voice-panel.ai-voice .bob-face{width:100%;height:100%}
.bob-face #bobHeadFront,.bob-face #bobHeadTop,.bob-face #bobHeadRight,.bob-face #bobHeadBottom,.bob-face #bobHeadLeft,.bob-face #bobHeadSide,.bob-face #bobFaceFeatures,.bob-face #bobLeftEye,.bob-face #bobRightEye,.bob-face #bobLeftEyeIcon,.bob-face #bobRightEyeIcon,.bob-face #bobMouth,.bob-face #bobBrow,.bob-face #bobForehead,.bob-face #bobLeftBrow,.bob-face #bobRightBrow,.bob-face #bobForeheadLine1,.bob-face #bobForeheadLine2{transition:transform 120ms ease,rx 120ms ease,ry 95ms ease,d 120ms ease,opacity 160ms ease}
.bob-face.bob-face-ready,.bob-face.bob-face-ready #bobHeadFront,.bob-face.bob-face-ready #bobHeadTop,.bob-face.bob-face-ready #bobHeadRight,.bob-face.bob-face-ready #bobHeadBottom,.bob-face.bob-face-ready #bobHeadLeft,.bob-face.bob-face-ready #bobHeadSide,.bob-face.bob-face-ready #bobFaceFeatures,.bob-face.bob-face-ready #bobEyes,.bob-face.bob-face-ready #bobBrow,.bob-face.bob-face-ready #bobForehead{transition:none}
.bob-memory-face-indicator{position:absolute;z-index:4;left:50%;top:7%;box-sizing:border-box;width:28px;height:28px;padding:0;border-radius:999px;border:1px solid rgba(0,224,255,0.52);background:rgba(2,12,26,0.88);color:#bff9ff;display:grid;place-items:center;line-height:0;box-shadow:0 0 18px rgba(0,224,255,0.34);opacity:0;transform:translate(-50%,-18%) scale(.72);pointer-events:none;transition:opacity 140ms ease,transform 140ms ease}
.bob-memory-face-indicator svg{display:block;width:17px;height:17px;margin:0}
.bob-memory-merging .bob-memory-face-indicator{opacity:1;transform:translate(-50%,-18%) scale(1);animation:bob-memory-pulse 1.25s ease-in-out infinite}
@keyframes bob-memory-pulse{0%,100%{box-shadow:0 0 14px rgba(0,224,255,0.25)}50%{box-shadow:0 0 28px rgba(0,224,255,0.58)}}
.bob-face[data-emotion="listening"] #bobBrow{opacity:.9}
.bob-face[data-emotion="thinking"] #bobBrow{opacity:.58}
.bob-face[data-emotion="concerned"] #bobLeftEye,.bob-face[data-emotion="concerned"] #bobRightEye{opacity:.72}
.bob-face[data-emotion="error"] #bobLeftEye,.bob-face[data-emotion="error"] #bobRightEye{fill:#ff5f7a}
.ai-card-controls{display:flex;align-items:center;gap:8px;min-width:0;flex:1;justify-content:flex-end}
.voice-panel.ai-voice .voice-label{color:#d7d0ff}
.voice-panel canvas{width:100%;height:48px;min-height:48px;max-height:48px;display:block;border-radius:6px;background:rgba(0,0,0,0.18);flex:0 0 48px}
.ai-waveform-stack{grid-column:2;grid-row:1;align-self:start;min-width:0;height:98px;min-height:98px;max-height:98px;overflow:hidden;display:flex;flex-direction:column;align-items:stretch;gap:6px}
.ai-waveform-stack #aiWaveform{width:100%;height:64px;min-height:0;max-height:none;flex:1 1 auto}
.ai-waveform-stack .playback-speed{align-self:flex-start;flex:0 0 28px}
.bob-context-widget{position:relative;min-width:0;width:42px;height:98px;padding:5px 4px;border-radius:8px;border:1px solid rgba(183,167,255,0.16);background:rgba(0,0,0,0.2);display:flex;flex-direction:column;align-items:center;gap:4px;grid-column:2;grid-row:1}
.bob-context-meta{position:static;z-index:2;width:auto;min-width:0;padding:0;border:0;background:transparent;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2px;transform:none;pointer-events:none;order:2}
.bob-context-meta span{color:#bff9ff;font-size:11px;font-weight:700;line-height:1;text-transform:uppercase}
.bob-context-meta small{color:var(--muted);font-size:10px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bob-context-meta.memory-due small{color:#ffcf9f}
.bob-context-meta.memory-updating small{color:#bff9ff}
.bob-context-widget canvas{display:block;width:100%;min-height:0;height:auto;max-height:none;flex:1;order:1}
.bob-context-widget .bob-brain-btn{order:3;width:28px;height:24px;min-height:24px}
.playback-speed{height:28px;display:inline-flex;align-items:center;gap:4px;border:1px solid rgba(183,167,255,0.22);border-radius:6px;overflow:hidden;background:rgba(0,0,0,0.18);flex:0 0 auto}
.playback-speed button{width:30px;height:26px;padding:0;border:0;background:transparent;color:#bfc0d8;display:flex;align-items:center;justify-content:center;cursor:pointer}
.playback-speed button:disabled{opacity:.35;cursor:not-allowed}
.playback-speed button:hover:not(:disabled){background:rgba(183,167,255,0.12);color:#f2efff}
.playback-speed span{min-width:42px;text-align:center;color:#f2efff;font-size:12px;line-height:26px}
.playback-speed .playback-stop{border-left:1px solid rgba(183,167,255,0.18);color:#ffcfda}
.playback-speed .playback-stop:hover:not(:disabled){background:rgba(255,95,122,0.14);color:#fff}

/* Input Section */
.lower-banner{position:relative;z-index:10001;flex:0 0 auto;display:grid;grid-template-columns:minmax(0,1fr) 106px;gap:10px;align-items:stretch;padding:10px;border:1px solid rgba(255,255,255,0.06);border-radius:14px;background:linear-gradient(180deg,rgba(8,14,26,0.82),rgba(2,7,18,0.92));box-shadow:0 -10px 30px rgba(0,0,0,0.24),inset 0 1px 0 rgba(255,255,255,0.03);overflow:visible}
.lower-banner-content{min-width:0;display:flex;align-items:stretch}
.lower-banner-actions{display:flex;align-items:stretch;justify-content:flex-end;gap:10px}
.page-banner-status{min-width:0;width:100%;min-height:48px;padding:8px 10px;border:1px solid rgba(255,255,255,0.05);border-radius:10px;background:rgba(255,255,255,0.025);display:flex;flex-direction:column;justify-content:center;gap:3px}
.page-banner-status span{color:#f1f6ff;font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.page-banner-status small{color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.input-section{width:100%;background:transparent;border:0;border-radius:0;padding:0;gap:12px;display:flex;flex-direction:column;box-shadow:none}
.btn-icon{width:30px;height:28px;padding:0;border-radius:6px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer}
.btn-icon:hover{color:var(--accent);border-color:rgba(0,224,255,0.22);background:rgba(0,224,255,0.06)}

/* Composer */
.composer{position:static;display:flex;flex-direction:column;gap:8px}
.composer-voice{position:absolute;left:10px;right:10px;bottom:calc(100% + 8px);z-index:2;display:grid;grid-template-columns:minmax(0,1fr) minmax(150px,28%);gap:8px;align-items:stretch;min-height:0;max-height:0;opacity:0;overflow:hidden;pointer-events:none;transform:translateY(12px);transition:max-height 180ms ease,opacity 180ms ease,transform 180ms ease}
.input-section.mic-active .composer-voice{max-height:64px;opacity:1;pointer-events:auto;transform:translateY(0)}
.composer-voice canvas{width:100%;height:48px;display:block;border-radius:8px;background:rgba(0,0,0,0.72);border:1px solid rgba(0,224,255,0.18);box-shadow:0 10px 26px rgba(0,0,0,0.26)}
.input-wrapper{display:flex;gap:10px;align-items:center}
.composer input{flex:1;order:1;min-width:0;padding:12px 16px;border-radius:10px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font-size:14px;transition:all 0.2s}
.composer input:focus{outline:none;border-color:var(--accent);background:rgba(0,224,255,0.02);box-shadow:0 0 12px rgba(0,224,255,0.1)}
.composer input.mic-live{border-color:rgba(255,154,90,0.36);background:rgba(255,154,90,0.06);color:#ffd8bd}
.btn-send{order:2;min-width:62px;padding:12px 22px;border-radius:10px;border:0;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#00121a;font-weight:700;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-send:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,224,255,0.2)}
.btn-send:active{transform:translateY(0)}

/* Composer Footer */
.btn-mic{order:3;width:46px;height:44px;min-width:46px;padding:0;border-radius:10px;border:1px solid rgba(0,224,255,0.2);background:rgba(0,224,255,0.05);color:var(--accent);font-size:13px;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;flex:0 0 46px}
.voice-label .btn-mic{text-transform:none}
.btn-mic:hover{background:rgba(0,224,255,0.12);border-color:rgba(0,224,255,0.4)}
.btn-mic.active{background:linear-gradient(135deg, rgba(255,95,122,0.2), rgba(255,154,90,0.1));border-color:rgba(255,95,122,0.4);color:#ff9a5a}
.vtt-output{background:rgba(0,20,30,0.78);padding:7px 10px;border-radius:8px;color:#bfefff;font-size:12px;line-height:14px;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;border:1px solid rgba(0,224,255,0.16);box-shadow:0 10px 26px rgba(0,0,0,0.22)}

/* Model Row */
.model-row{display:flex;justify-content:space-between;align-items:center;padding:8px;border-radius:8px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.02);margin-bottom:8px}
.model-name{color:#cfe9ff}
.model-actions button{background:transparent;border:1px solid rgba(255,255,255,0.04);padding:6px 8px;border-radius:6px;color:var(--muted)}
.available-model-row{display:flex;justify-content:space-between;align-items:center;padding:12px;border-radius:8px;background:rgba(124,92,255,0.05);border:1px solid rgba(124,92,255,0.08);margin-bottom:10px;gap:12px}
.model-info{flex:1}
.model-title{color:#bff9ff;font-weight:600;margin-bottom:4px}
.model-desc{color:var(--muted);font-size:12px;margin-bottom:6px}
.model-tags{display:flex;gap:4px;flex-wrap:wrap}
.tag{display:inline-block;padding:2px 8px;background:rgba(0,224,255,0.08);border:1px solid rgba(0,224,255,0.12);border-radius:4px;font-size:11px;color:#00e0ff}
.model-actions{display:flex;gap:6px;align-items:center}
.tag-select{background:transparent;border:1px solid rgba(255,255,255,0.04);padding:4px 6px;border-radius:4px;color:var(--muted);font-size:12px}
.btn-download{background:linear-gradient(90deg,var(--accent-2),var(--accent));border:0;padding:6px 12px;border-radius:6px;color:#00121a;font-weight:600;cursor:pointer}
.btn-download:disabled{opacity:.62;cursor:not-allowed}

/* Models Lists */
.models-list{max-height:260px;overflow:auto;padding-right:8px}
.ollama-config-grid{display:grid;grid-template-columns:minmax(180px,280px) auto;gap:10px;align-items:end;margin-bottom:8px}
.ollama-config-grid label{min-width:0;display:flex;flex-direction:column;gap:6px;color:var(--muted);font-size:12px;text-transform:uppercase}
.ollama-config-grid select,.ollama-config-grid input{min-width:0;height:36px;padding:0 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font:inherit;text-transform:none}
.ollama-config-actions button{min-height:36px;padding:8px 12px;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,224,255,0.06);color:#dfe9ff;cursor:pointer}
.ollama-config-actions button:hover{border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.1);color:var(--accent)}
.models-list .available-model-row{margin-bottom:10px}
.models-list::-webkit-scrollbar{width:10px;height:10px}
.models-list::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(124,92,255,0.18),rgba(0,224,255,0.12));border-radius:8px;border:2px solid transparent;background-clip:padding-box}
.models-list::-webkit-scrollbar-track{background:transparent}
.models-list{scrollbar-width:thin;scrollbar-color:rgba(124,92,255,0.18) transparent}

/* FAB Menu */
.fab-menu{width:48px;height:48px;border-radius:10px;border:1px solid rgba(0,224,255,0.18);background:linear-gradient(180deg,rgba(0,18,25,0.92),rgba(0,40,49,0.9));color:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,0.28),0 0 14px rgba(0,224,255,0.06);cursor:pointer;z-index:1000;transition:all 0.2s;flex:0 0 48px;order:3}
.fab-menu:hover{box-shadow:0 10px 28px rgba(0,224,255,0.14),0 0 20px rgba(0,224,255,0.1);border-color:rgba(0,224,255,0.32)}
.lucide{width:18px;height:18px;stroke-width:2;flex:0 0 auto}
.fab-menu .lucide{width:22px;height:22px}
.fab-menu .menu-glyph{font-size:26px;line-height:1;font-weight:700}
.fab-menu svg + .menu-glyph{display:none}
.fab-menu.open{border-color:rgba(124,92,255,0.42);background:linear-gradient(180deg,rgba(22,18,45,0.94),rgba(0,40,49,0.9))}

/* Slide Panel */
.slide-panel-backdrop{position:fixed;inset:0;z-index:19990;background:transparent;opacity:0;pointer-events:none;touch-action:none;overscroll-behavior:contain}
.slide-panel-backdrop.open{pointer-events:auto}
.slide-panel{position:fixed;right:0;bottom:var(--lower-banner-reserve);top:0;width:360px;background:linear-gradient(180deg, rgba(8,10,18,0.92), rgba(2,4,10,0.88));border-left:1px solid rgba(255,255,255,0.02);padding:16px;transform:translateX(100%);transition:transform 240ms ease;z-index:20000;display:flex;flex-direction:column;min-height:0}
.slide-panel.open{transform:translateX(0);box-shadow:-12px 0 32px rgba(2,6,23,0.45)}
.panel-header{display:grid;grid-template-columns:1fr 36px;gap:8px;align-items:center;color:var(--accent);min-height:40px}
.panel-header span{text-align:left;font-weight:700}
.panel-icon-btn{width:36px;height:36px;padding:0;border-radius:8px;border:1px solid rgba(255,255,255,0.04);background:rgba(255,255,255,0.02);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer}
.panel-icon-btn:hover{color:var(--accent);border-color:rgba(0,224,255,0.22);background:rgba(0,224,255,0.06)}
.panel-icon-btn[hidden]{visibility:hidden;display:flex}
.account-panel{display:grid;grid-template-columns:40px minmax(0,1fr) 36px;gap:10px;align-items:center;margin:10px 0 4px;padding:10px;border:1px solid rgba(255,255,255,0.06);border-radius:8px;background:linear-gradient(135deg,rgba(0,224,255,0.055),rgba(124,92,255,0.035))}
.account-avatar{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:rgba(0,224,255,0.08);border:1px solid rgba(0,224,255,0.14);color:var(--accent)}
.account-details{min-width:0;display:flex;flex-direction:column;gap:3px}
.account-details strong{font-size:13px;color:#f1f6ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.account-details span{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.account-panel .panel-icon-btn{color:#bfc0d8}
.account-panel .panel-icon-btn:disabled{opacity:.55;cursor:wait}
.panel-body{flex:1;min-height:0;overflow:auto;padding-top:12px}
.panel-body button{padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.03);background:transparent;color:var(--muted)}
.menu-slide-shell{position:relative;min-height:100%;display:grid;grid-template-columns:100% 100%;align-items:start;overflow-x:hidden;overflow-y:visible}
.menu-slide{transition:transform 220ms ease,opacity 220ms ease}
.menu-slide-shell .menu-slide-root{grid-column:1;grid-row:1;transform:translateX(0);opacity:1}
.menu-slide-shell .menu-slide-child{grid-column:2;grid-row:1;transform:translateX(0);opacity:.2;pointer-events:none}
.menu-slide-shell.show-child .menu-slide-root{transform:translateX(-100%);opacity:0;pointer-events:none}
.menu-slide-shell.show-child .menu-slide-child{transform:translateX(-100%);opacity:1;pointer-events:auto}
.menu-back{width:100%;min-height:42px;margin-bottom:10px;border-radius:8px;border:1px solid rgba(0,224,255,0.16);background:rgba(0,224,255,0.05);color:#dfe9ff;display:flex;align-items:center;gap:8px;text-align:left;cursor:pointer}
.menu-back:hover{border-color:rgba(0,224,255,0.3);background:rgba(0,224,255,0.09);color:var(--accent)}
.menu-landing{display:flex;flex-direction:column;gap:10px}
.menu-item{width:100%;min-height:76px;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:linear-gradient(135deg,rgba(255,255,255,0.035),rgba(0,0,0,0.02));color:#dfe9ff;display:grid;grid-template-columns:34px 1fr;gap:12px;align-items:center;text-align:left;cursor:pointer}
.menu-item:hover{border-color:rgba(0,224,255,0.24);background:linear-gradient(135deg,rgba(0,224,255,0.08),rgba(124,92,255,0.05));transform:translateY(-1px)}
.menu-item.active{border-color:rgba(0,224,255,0.36);background:linear-gradient(135deg,rgba(0,224,255,0.12),rgba(124,92,255,0.08))}
.menu-item .lucide{width:24px;height:24px;color:var(--accent)}
.menu-item span{display:flex;flex-direction:column;gap:4px;min-width:0}
.menu-item strong{font-size:14px;color:#f1f6ff}
.menu-item small{font-size:12px;color:var(--muted);line-height:1.35}
.menu-loading,.menu-error,.panel-copy{color:var(--muted)}
.install-row{display:flex;gap:8px}
.install-row input{min-width:0;flex:1;background:rgba(0,0,0,0.24);border:1px solid rgba(255,255,255,0.06);border-radius:8px;color:#dfe9ff;padding:10px}
.pull-jobs-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.pull-job{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px;border-radius:8px;background:rgba(255,255,255,0.035);border:1px solid rgba(255,255,255,0.07)}
.pull-job-title{font-weight:700;color:#dfe9ff}
.pull-job-detail{font-size:12px;color:var(--muted);margin-top:3px;overflow-wrap:anywhere}
.pull-job-state{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#00e0ff;white-space:nowrap}
.pull-job.succeeded .pull-job-state{color:#7dffb3}
.pull-job.failed .pull-job-state{color:#ff8fa3}
.model-status{min-height:24px;color:var(--muted);font-size:12px;margin-top:8px}
.main-menu-page{height:100%;overflow:auto}
.main-menu-page>.panel-view{height:100%;overflow:auto;padding:16px}
.main-menu-page>.panel-view h3:first-child{margin-top:0}
.panel-body .monitor-output { background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(0,0,0,0.02)); padding:8px; border-radius:8px; }
.monitor-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.monitor-toolbar button,.monitor-control-row button,.monitor-model-row button{min-height:34px;padding:7px 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.03);color:#dfe9ff;display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.monitor-toolbar button:hover,.monitor-control-row button:hover,.monitor-model-row button:hover{border-color:rgba(0,224,255,0.25);background:rgba(0,224,255,0.07);color:var(--accent)}
.monitor-toolbar .memory-wipe-btn{margin-left:auto;border-color:rgba(255,95,122,0.28);background:rgba(255,95,122,0.09);color:#ffd8df}
.monitor-toolbar .memory-wipe-btn:hover:not(:disabled){border-color:rgba(255,95,122,0.5);background:rgba(255,95,122,0.16);color:#fff}
.monitor-toolbar .memory-wipe-btn:disabled{opacity:.55;cursor:wait}
.monitor-toggle{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;text-transform:uppercase}
.monitor-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:12px}
.metric{min-width:0;padding:10px;border:1px solid rgba(255,255,255,0.05);background:rgba(255,255,255,0.025);border-radius:8px}
.metric span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;margin-bottom:5px}
.metric strong{display:block;color:#dfe9ff;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.monitor-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;margin-bottom:12px}
.monitor-card{min-width:0;border:1px solid rgba(255,255,255,0.05);background:linear-gradient(180deg,rgba(255,255,255,0.025),rgba(0,0,0,0.02));border-radius:8px;padding:12px}
.monitor-card h4{margin:0 0 10px;color:#bff9ff;font-size:13px}
.monitor-list{display:flex;flex-direction:column;gap:8px;min-height:40px}
.monitor-model-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px;border-radius:8px;background:rgba(0,0,0,0.18);border:1px solid rgba(255,255,255,0.04)}
.monitor-model-row div{min-width:0}
.monitor-model-row strong{display:block;color:#f1f6ff;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.monitor-model-row small{display:block;color:var(--muted);font-size:11px;margin-top:3px}
.monitor-control-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.monitor-control-row select{min-width:0;flex:1;height:34px;padding:0 8px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff}
.activity-dashboard .monitor-toolbar{align-items:center}
.activity-dashboard .monitor-toolbar h3{margin:0 auto 0 0}
.activity-chart-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;margin-bottom:12px}
.activity-chart-card{height:260px;display:flex;flex-direction:column}
.activity-chart-card.wide{grid-column:1 / -1;height:230px}
.activity-chart-card canvas{min-height:0;flex:1;width:100%}
.activity-table{display:flex;flex-direction:column;gap:8px;max-height:360px;overflow:auto}
.activity-row{min-width:0;padding:9px;border-radius:8px;border:1px solid rgba(255,255,255,0.04);background:rgba(0,0,0,0.18);display:grid;gap:4px}
.activity-row strong{font-size:13px;color:#f1f6ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.activity-row span{font-size:12px;color:#bff9ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.activity-row small{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.memory-manager{display:flex;flex-direction:column;gap:12px}
.memory-chat-card{min-height:320px;display:flex;flex-direction:column}
.memory-chat-card h4{flex:0 0 auto}
.memory-factoid-card{min-height:220px;display:flex;flex-direction:column}
.memory-factoid-card h4{margin-top:0}
.memory-factoid-list{display:flex;flex-direction:column;gap:8px;overflow:auto;min-height:0;flex:1}
.memory-message-list{display:flex;flex-direction:column;gap:5px;overflow:auto;min-height:0;flex:1}
.memory-message-row,.memory-factoid-row{padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.04);background:rgba(0,0,0,0.18)}
.memory-message-row{min-height:34px;padding:6px 8px;display:grid;grid-template-columns:minmax(72px,.65fr) minmax(110px,.9fr) minmax(90px,.7fr) minmax(170px,1.1fr) minmax(0,3fr) 32px;gap:9px;align-items:center}
.memory-message-row.user{border-left:3px solid rgba(0,224,255,0.45)}
.memory-message-row.assistant{border-left:3px solid rgba(124,92,255,0.45)}
.memory-message-role,.memory-message-model,.memory-message-time,.memory-message-emotion,.memory-message-content{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;line-height:1.25}
.memory-message-role{color:#f1f6ff;font-weight:800;text-transform:uppercase}
.memory-message-model,.memory-message-time,.memory-message-emotion{color:var(--muted)}
.memory-message-content{color:#cdd8ec}
.memory-factoid-row{border-left:3px solid rgba(255,154,90,0.45)}
.memory-row-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.memory-row-header strong{display:block;color:#f1f6ff;font-size:12px;text-transform:uppercase;margin:0 auto 0 0}
.memory-factoid-row p{margin:0;color:#cdd8ec;font-size:12px;line-height:1.45;white-space:pre-wrap}
.memory-factoid-row small{display:block;margin-top:6px;color:var(--muted);font-size:11px}
.memory-delete-btn{width:30px;height:30px;display:grid;place-items:center;border-radius:8px;border:1px solid rgba(255,95,122,0.16);background:rgba(255,95,122,0.05);color:#dfe9ff;cursor:pointer;flex:0 0 auto}
.memory-delete-btn:hover{border-color:rgba(255,95,122,0.4);background:rgba(255,95,122,0.12);color:#ff8ca0}
.memory-delete-btn .lucide{width:16px;height:16px}
.hal-dialog-mark.danger{border-color:rgba(255,95,122,0.28);background:rgba(255,95,122,0.1);color:#ff8ca0}
.memory-wipe-dialog p{color:#ffd8df}
.memory-wipe-confirm{display:flex;flex-direction:column;gap:7px;margin-top:14px;color:#cdd8ec;font-size:12px}
.memory-wipe-confirm input{height:38px;border-radius:8px;border:1px solid rgba(255,95,122,0.26);background:rgba(0,0,0,0.32);color:#f1f6ff;padding:0 10px;font:inherit;letter-spacing:0}
.memory-wipe-confirm input:focus{outline:none;border-color:rgba(255,95,122,0.58);box-shadow:0 0 14px rgba(255,95,122,0.12)}
.skills-view,.admin-view{display:flex;flex-direction:column;gap:12px}
.skills-grid,.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.skill-card,.admin-card{min-height:150px;padding:14px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:linear-gradient(180deg,rgba(255,255,255,0.025),rgba(0,0,0,0.02));color:#dfe9ff;display:grid;grid-template-columns:34px minmax(0,1fr);gap:12px;align-items:start;text-align:left;cursor:pointer}
.skill-card:hover,.admin-card:hover{border-color:rgba(0,224,255,0.25);background:rgba(0,224,255,0.07);color:var(--accent)}
.skill-card .lucide,.admin-card .lucide{width:24px;height:24px;color:var(--accent)}
.skill-card span,.admin-card span{min-width:0;display:flex;flex-direction:column;gap:7px}
.skill-card strong,.admin-card strong{color:#f1f6ff;font-size:14px}
.skill-card small,.admin-card small{color:var(--muted);font-size:12px;line-height:1.45}
.web-search-skill,.yahoo-skill,.memory-requirements{display:flex;flex-direction:column;gap:12px}
.requirement-card{display:grid;gap:10px}
.requirement-card h4{margin:0;color:#f1f6ff}
.requirement-card p,.requirement-card li,.requirement-card dd{color:#cdd8ec;font-size:13px;line-height:1.55}
.requirement-card ul{margin:0;padding-left:20px;display:grid;gap:7px}
.requirement-list{display:grid;gap:9px;margin:0}
.requirement-list div{display:grid;grid-template-columns:120px minmax(0,1fr);gap:10px}
.requirement-list dt{color:#bff9ff;font-size:12px;font-weight:700;text-transform:uppercase}
.requirement-list dd{margin:0}
.web-search-form textarea{width:100%;min-height:120px;resize:vertical;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font:inherit;line-height:1.45}
.web-search-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 12px rgba(0,224,255,0.1)}
.web-search-output{min-height:180px;white-space:pre-wrap;color:#dfe9ff;font-size:13px;line-height:1.55}
.web-search-source-list{display:flex;flex-direction:column;gap:8px}
.web-search-source{min-width:0;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.04);background:rgba(0,0,0,0.18);display:grid;gap:5px;color:inherit;text-decoration:none}
.web-search-source:hover{border-color:rgba(0,224,255,0.22);background:rgba(0,224,255,0.06)}
.web-search-source strong{font-size:13px;color:#f1f6ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.web-search-source span{font-size:11px;color:#bff9ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.web-search-source small{font-size:12px;color:var(--muted);line-height:1.4}
.yahoo-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.yahoo-actions button{min-height:34px;padding:7px 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.03);color:#dfe9ff;display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.yahoo-actions button:hover:not(:disabled){border-color:rgba(0,224,255,0.25);background:rgba(0,224,255,0.07);color:var(--accent)}
.yahoo-actions button.danger{border-color:rgba(255,95,122,0.22);background:rgba(255,95,122,0.08);color:#ffd8df}
.yahoo-actions button.danger:hover:not(:disabled){border-color:rgba(255,95,122,0.42);background:rgba(255,95,122,0.14);color:#fff}
.yahoo-actions button:disabled{opacity:.55;cursor:not-allowed}
.detail-list{display:grid;gap:8px;margin:0}
.detail-list div{display:grid;grid-template-columns:150px minmax(0,1fr);gap:10px;align-items:start}
.detail-list dt{color:var(--muted);font-size:12px}
.detail-list dd{margin:0;min-width:0;color:#dfe9ff;font-size:13px;overflow-wrap:anywhere}
.app-tester-view{display:flex;flex-direction:column;gap:12px}
.app-tester-grid{display:grid;grid-template-columns:minmax(220px,320px) minmax(0,1fr);gap:12px;align-items:stretch}
.tester-bob-card{min-width:0;min-height:360px;border:1px solid rgba(0,224,255,0.14);border-radius:8px;background:linear-gradient(180deg,rgba(0,224,255,0.045),rgba(0,0,0,0.06));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:16px;box-shadow:0 0 26px rgba(0,224,255,0.08)}
.tester-bob-card.active{border-color:rgba(183,167,255,0.36);box-shadow:0 0 28px rgba(124,92,255,0.16)}
.tester-bob-display{min-width:0;max-width:100%;display:flex;align-items:stretch;justify-content:center;gap:10px}
.tester-bob-face-shell{position:relative;width:min(220px,100%);aspect-ratio:1;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,0,0,0.22);box-shadow:0 0 24px rgba(0,224,255,0.12);display:grid;place-items:stretch;overflow:hidden}
.tester-bob-face{width:100%;height:100%}
.tester-bob-ctx{width:42px;min-height:120px;padding:6px 5px;border-radius:8px;border:1px solid rgba(183,167,255,0.16);background:rgba(0,0,0,0.2);display:flex;flex-direction:column;align-items:center;gap:5px}
.tester-bob-ctx canvas{width:100%;min-height:0;flex:1;display:block}
.tester-bob-ctx small{color:#bff9ff;font-size:10px;font-weight:900;line-height:1;text-transform:uppercase;white-space:nowrap}
.tester-bob-ctx .bob-brain-btn{width:30px;height:24px;min-height:24px;flex:0 0 24px}
.tester-bob-meta{display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center}
.tester-bob-title-row{display:flex;align-items:center;justify-content:center;gap:8px}
.tester-bob-meta strong{color:#f1f6ff;font-size:16px}
.tester-bob-meta small{color:var(--muted);font-size:12px;line-height:1.4}
.tester-speech-card,.tester-emotion-card{display:flex;flex-direction:column;gap:10px}
.tester-provider-control{display:grid;grid-template-columns:auto minmax(160px,260px);gap:10px;align-items:center;color:var(--muted);font-size:12px;text-transform:uppercase}
.tester-provider-control select{min-width:0;height:36px;padding:0 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font:inherit;text-transform:none}
.tester-provider-control select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 12px rgba(0,224,255,0.1)}
.tester-voice-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.tester-voice-options label{min-width:0;display:flex;flex-direction:column;gap:5px;color:var(--muted);font-size:11px;text-transform:uppercase}
.tester-voice-options input,.tester-voice-options select{min-width:0;height:34px;padding:0 9px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font:inherit;text-transform:none}
.tester-voice-options input:focus,.tester-voice-options select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 12px rgba(0,224,255,0.1)}
.tester-speech-card textarea{width:100%;min-height:150px;resize:vertical;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font:inherit;line-height:1.45}
.tester-speech-card textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 12px rgba(0,224,255,0.1)}
.tester-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;align-items:stretch}
.tester-action-group{min-width:0;display:flex;flex-direction:column;gap:6px;padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.025)}
.tester-action-group>span{color:var(--muted);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:0}
.tester-actions button,.tester-emotion-grid button{min-height:36px;padding:8px 11px;border-radius:8px;border:1px solid rgba(0,224,255,0.16);background:rgba(0,224,255,0.055);color:#dfe9ff;display:inline-flex;align-items:center;justify-content:center;gap:7px;cursor:pointer}
.tester-action-group button{width:100%;min-width:0}
.tester-actions button:hover:not(:disabled),.tester-emotion-grid button:hover{border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.1);color:var(--accent)}
.tester-actions button:disabled{opacity:.55;cursor:wait}
.bob-chat-test-rail .tester-actions{grid-area:actions;grid-template-columns:1fr;gap:5px;min-height:0;overflow:auto}
.bob-chat-test-rail .tester-action-group{padding:5px;gap:5px;display:grid;grid-template-columns:58px repeat(2,minmax(0,1fr));align-items:center}
.bob-chat-test-rail .tester-action-group>span{font-size:9px}
.bob-chat-test-rail .tester-actions button{min-height:26px;padding:4px 6px;font-size:10px;line-height:1.1}
.tester-speech-card canvas{width:100%;height:90px;display:block;border-radius:8px;border:1px solid rgba(183,167,255,0.14);background:rgba(0,0,0,0.2)}
.tester-emotion-card{grid-column:2}
.tester-orientation-control{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tester-look-pad{position:relative;width:126px;height:126px;border-radius:8px;border:1px solid rgba(0,224,255,0.2);background:linear-gradient(180deg,rgba(0,224,255,0.05),rgba(0,0,0,0.16));cursor:crosshair;touch-action:none;overflow:hidden}
.tester-look-pad:focus{outline:none;border-color:var(--accent);box-shadow:0 0 14px rgba(0,224,255,0.14)}
.tester-look-axis{position:absolute;background:rgba(223,233,255,0.22);pointer-events:none}
.tester-look-axis.horizontal{left:8px;right:8px;top:50%;height:1px}
.tester-look-axis.vertical{top:8px;bottom:8px;left:50%;width:1px}
.tester-look-dot{position:absolute;z-index:2;left:50%;top:50%;width:14px;height:14px;border-radius:50%;background:#ff2d4f;border:2px solid #ffd8df;box-shadow:0 0 14px rgba(255,45,79,0.55);opacity:0;transform:translate(-50%,-50%);pointer-events:none;transition:opacity 140ms ease}
.tester-look-pad.manual-look-active .tester-look-dot:not(.current){opacity:1}
.tester-look-dot.current{z-index:1;background:#8d96a8;border-color:#d7dce8;box-shadow:0 0 12px rgba(141,150,168,0.42);opacity:0.82;transition:left 120ms ease,top 120ms ease}
.tester-emotion-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
body.bob-chat-tester-route .main{padding:8px 20px 8px;gap:7px}
body.bob-chat-tester-route .main-content{flex:1 1 auto;height:auto;min-height:0;overflow:hidden}
body.bob-chat-tester-route .main-menu-page{height:100%;min-height:0;overflow:hidden;display:flex;flex-direction:column}
.main-menu-page>.bob-chat-tester-view{height:100%;overflow:hidden;padding:4px 8px 0}
.bob-chat-tester-view{display:flex;flex:1 1 auto;flex-direction:column;gap:5px;min-height:0}
.bob-chat-tester-view .monitor-toolbar{min-height:28px;margin:0;gap:8px}
.bob-chat-tester-view .monitor-toolbar h3{margin:0 auto 0 0;font-size:17px;line-height:1}
.bob-chat-tester-view .monitor-toolbar button,.bob-chat-tester-view .monitor-toolbar .stream-status,.bob-chat-tester-view .monitor-toolbar .bob-chat-contract-badge{min-height:28px}
.bob-chat-tester-grid{flex:1;display:grid;grid-template-columns:minmax(300px,430px) minmax(0,1fr) minmax(0,.72fr) minmax(0,1fr);grid-template-rows:minmax(138px,.72fr) minmax(310px,1.55fr);grid-template-areas:"modelstatus modelstatus live llm" "face runner runner runner";gap:7px;align-content:stretch;align-items:stretch;min-height:0;overflow:hidden}
.bob-chat-tester-view .monitor-card{padding:8px}
.bob-chat-runner{grid-area:runner;align-self:stretch;display:grid;grid-template-columns:minmax(420px,1fr) minmax(640px,36%);grid-template-areas:"runnerConversation runnerRail";gap:7px;min-height:0;height:100%;overflow:hidden}
.bob-chat-test-conversation{grid-area:runnerConversation;min-width:0;min-height:0;display:grid;grid-template-rows:minmax(0,1fr) 38px;gap:7px;overflow:hidden}
.bob-chat-test-rail{grid-area:runnerRail;min-width:0;min-height:0;display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);grid-template-rows:38px minmax(0,1fr);grid-template-areas:"model presets" "actions presets";gap:6px;overflow:hidden}
.bob-chat-test-controls{grid-area:model;display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:6px;align-items:end;min-width:0}
.bob-chat-test-controls label{min-width:0;display:flex;flex-direction:column;gap:5px;color:var(--muted);font-size:11px;text-transform:uppercase}
.bob-chat-test-controls select{min-width:0;height:34px;padding:0 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font:inherit;text-transform:none}
.bob-chat-test-controls button{width:34px;height:34px;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,224,255,0.06);color:#dfe9ff;display:grid;place-items:center;cursor:pointer}
.bob-chat-test-controls button:hover:not(:disabled){border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.1);color:var(--accent)}
.bob-chat-test-controls button:disabled{opacity:.55;cursor:wait}
.bob-chat-model-rules{border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.025);overflow:hidden}
.bob-chat-model-rules summary{min-height:34px;padding:8px 10px;cursor:pointer;color:#bff9ff;font-weight:700;font-size:12px}
.bob-chat-model-rules-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;border-top:1px solid rgba(255,255,255,0.06)}
.bob-chat-model-rules-grid label{display:flex;flex-direction:column;gap:5px;color:var(--muted);font-size:10px;text-transform:uppercase}
.bob-chat-model-rules-grid input{height:32px;min-width:0;padding:0 8px;border-radius:7px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.26);color:#dfe9ff;font:inherit}
.bob-chat-model-rules-grid input:focus{outline:none;border-color:rgba(0,224,255,0.36);box-shadow:0 0 12px rgba(0,224,255,0.08)}
.bob-chat-test-messages{min-height:0;overflow:auto;display:flex;flex-direction:column;gap:7px;padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,0.05);background:rgba(0,0,0,0.18)}
.bob-chat-test-message{max-width:90%;padding:10px 12px;border-radius:8px;color:#dfe9ff;font-size:13px;line-height:1.45;white-space:pre-wrap;overflow-wrap:anywhere}
.bob-chat-test-message.user{align-self:flex-end;border:1px solid rgba(0,224,255,0.16);background:rgba(0,224,255,0.08);color:#bff9ff}
.bob-chat-test-message.bot{align-self:flex-start;border:1px solid rgba(183,167,255,0.16);background:rgba(124,92,255,0.09);color:#eee8ff}
.bob-chat-test-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;min-height:0}
.bob-chat-test-form input{width:100%;min-width:0;height:38px;padding:0 12px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font:inherit;line-height:1.45}
.bob-chat-test-form input:focus,.bob-chat-test-controls select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 12px rgba(0,224,255,0.1)}
.bob-chat-test-form button{min-width:86px;height:38px;padding:0 12px;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,224,255,0.07);color:#dfe9ff;font:inherit;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;white-space:nowrap}
.bob-chat-test-form button:hover:not(:disabled){border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.12);color:var(--accent)}
.bob-chat-test-form button:disabled{opacity:.55;cursor:wait}
.bob-chat-preset-grid{grid-area:presets;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;min-height:0;overflow:auto}
.bob-chat-preset-grid button{min-height:32px;padding:6px 8px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.03);color:#dfe9ff;text-align:left;font:inherit;font-size:11px;line-height:1.2;cursor:pointer;overflow:hidden;text-overflow:ellipsis}
.bob-chat-preset-grid button:hover:not(:disabled){border-color:rgba(0,224,255,0.25);background:rgba(0,224,255,0.07);color:#bff9ff}
.bob-chat-model-status-card,.bob-chat-live-card,.bob-chat-llm-card{display:flex;flex-direction:column;gap:7px;min-height:0;overflow:hidden}
.bob-chat-face-card{grid-area:face;min-height:0}
.bob-chat-tester-view .bob-chat-face-card{min-height:0;height:100%;padding:8px;gap:7px;overflow:hidden}
.bob-chat-tester-view .bob-chat-face-card .tester-bob-display{height:min(190px,calc(100% - 52px));flex:0 1 auto}
.bob-chat-tester-view .bob-chat-face-card .tester-bob-face-shell{height:100%;width:auto;max-width:100%;aspect-ratio:1;flex:0 1 auto}
.bob-chat-tester-view .bob-chat-face-card .tester-bob-ctx{height:100%;flex:0 0 42px}
.bob-chat-tester-view .bob-chat-face-card .tester-bob-meta{flex:0 0 auto}
.bob-chat-model-status-card,.bob-chat-live-card,.bob-chat-llm-card{resize:vertical}
.bob-chat-model-status-card{grid-area:modelstatus;min-height:150px}
.bob-chat-live-card{grid-area:live;min-height:150px}
.bob-chat-llm-card{grid-area:llm;min-height:150px}
.bob-chat-llm-card h4{flex:0 0 auto}
.bob-chat-card-header{display:flex;align-items:center;gap:10px;min-width:0}
.bob-chat-card-header h4{margin:0 auto 0 0}
.bob-chat-model-status-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}
.bob-chat-model-status-summary .metric{min-height:34px;margin:0;padding:7px}
.bob-chat-model-status-list{min-height:0;overflow:auto;display:grid;gap:5px}
.bob-chat-model-status-row{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;padding:7px 8px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(0,0,0,0.18)}
.bob-chat-model-status-row.running{border-color:rgba(0,224,255,0.2);background:rgba(0,224,255,0.055)}
.bob-chat-model-status-row.background{border-color:rgba(255,204,102,0.18);background:rgba(255,204,102,0.045)}
.bob-chat-model-status-row.loaded{border-color:rgba(126,231,135,0.16);background:rgba(126,231,135,0.04)}
.bob-chat-model-status-row strong{display:block;min-width:0;color:#f1f6ff;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bob-chat-model-status-row small{display:flex;align-items:center;gap:6px;min-width:0;margin-top:3px;color:var(--muted);font-size:11px;line-height:1.35;white-space:nowrap;overflow:hidden}
.bob-chat-model-status-row small>span:last-child{min-width:0;overflow:hidden;text-overflow:ellipsis}
.bob-chat-model-processor{flex:0 0 auto;min-height:20px;padding:2px 6px;border-radius:999px;border:1px solid rgba(255,255,255,0.11);background:rgba(255,255,255,0.04);color:#dfe9ff;font-size:10px;font-weight:900;text-transform:uppercase}
.bob-chat-model-processor.gpu{border-color:rgba(126,231,135,0.26);background:rgba(126,231,135,0.09);color:#d8ffdc}
.bob-chat-model-processor.cpu{border-color:rgba(255,204,102,0.26);background:rgba(255,204,102,0.08);color:#ffe4a8}
.bob-chat-model-processor.unknown{border-color:rgba(155,164,180,0.22);background:rgba(155,164,180,0.06);color:#c9d3e5}
.bob-chat-model-countdown{color:#bff9ff}
.bob-chat-model-countdown.expired{color:#ffe4a8}
.bob-chat-model-actions{display:flex;align-items:center;gap:7px;min-width:max-content}
.bob-chat-model-state{display:inline-flex;align-items:center;justify-content:center;min-width:62px;min-height:24px;padding:3px 7px;border-radius:999px;border:1px solid rgba(255,255,255,0.11);background:rgba(255,255,255,0.04);color:var(--muted);font-size:10px;font-weight:800;text-transform:uppercase;white-space:nowrap}
.bob-chat-model-state.running{border-color:rgba(0,224,255,0.28);background:rgba(0,224,255,0.09);color:#bff9ff}
.bob-chat-model-state.background{border-color:rgba(255,204,102,0.24);background:rgba(255,204,102,0.07);color:#ffe4a8}
.bob-chat-model-state.loaded{border-color:rgba(126,231,135,0.24);background:rgba(126,231,135,0.08);color:#d8ffdc}
.bob-chat-model-unload{min-height:26px;padding:4px 8px;border-radius:999px;border:1px solid rgba(255,154,90,0.28);background:rgba(255,154,90,0.08);color:#ffd8bd;font:inherit;font-size:10px;font-weight:900;text-transform:uppercase;display:inline-flex;align-items:center;gap:5px;cursor:pointer;white-space:nowrap}
.bob-chat-model-unload .lucide{width:13px;height:13px}
.bob-chat-model-unload:hover:not(:disabled){border-color:rgba(255,154,90,0.48);background:rgba(255,154,90,0.14);color:#fff1e3}
.bob-chat-model-unload:disabled{opacity:.55;cursor:wait}
.bob-chat-model-status-empty{min-height:42px;display:flex;align-items:center;padding:8px 9px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(0,0,0,0.16);color:var(--muted);font-size:12px}
.bob-chat-live-output{min-height:0;flex:1;margin:0;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(0,0,0,0.22);color:#dfe9ff;font:12px/1.45 Consolas,'Courier New',monospace;white-space:pre-wrap;overflow:auto;overflow-wrap:anywhere}
.bob-chat-contract-header{display:flex;align-items:center;gap:10px}
.bob-chat-contract-header h4{margin:0 auto 0 0}
.bob-chat-debug-copy{min-height:28px;padding:5px 9px;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,224,255,0.06);color:#dfe9ff;font:inherit;font-size:12px;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;white-space:nowrap}
.bob-chat-debug-copy:hover:not(:disabled){border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.1);color:var(--accent)}
.bob-chat-debug-copy:disabled{opacity:.48;cursor:not-allowed}
.bob-chat-contract-badge{min-height:24px;padding:4px 8px;border-radius:6px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.035);color:var(--muted);font-size:11px;text-transform:uppercase;white-space:nowrap}
.bob-chat-contract-badge.pass{border-color:rgba(126,231,135,0.3);background:rgba(126,231,135,0.09);color:#d8ffdc}
.bob-chat-contract-badge.warn{border-color:rgba(255,204,102,0.28);background:rgba(255,204,102,0.07);color:#ffe4a8}
.bob-chat-contract-badge.fail{border-color:rgba(255,154,90,0.28);background:rgba(255,154,90,0.07);color:#ffd8bd}
.bob-chat-code-block{width:100%;min-height:0;margin:0;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(0,0,0,0.24);color:#dfe9ff;font:12px/1.45 Consolas,'Courier New',monospace;white-space:pre-wrap;overflow:auto;overflow-wrap:anywhere}
.bob-chat-contract-checks{display:block}
.bob-chat-contract-summary{border-radius:8px;border:1px solid rgba(255,255,255,0.07);background:rgba(255,255,255,0.025);overflow:hidden}
.bob-chat-contract-summary.fail{border-color:rgba(255,154,90,0.22);background:rgba(255,154,90,0.04)}
.bob-chat-contract-summary.warn{border-color:rgba(255,204,102,0.22);background:rgba(255,204,102,0.04)}
.bob-chat-contract-summary.pass{border-color:rgba(126,231,135,0.22);background:rgba(126,231,135,0.05)}
.bob-chat-contract-summary summary{min-height:34px;padding:8px 10px;display:flex;align-items:center;gap:8px;cursor:pointer;color:#dfe9ff}
.bob-chat-contract-summary summary span{margin-right:auto}
.bob-chat-contract-summary summary strong{font-size:11px;color:var(--muted);font-weight:700}
.bob-chat-contract-checks-body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;padding:8px;border-top:1px solid rgba(255,255,255,0.06)}
.bob-chat-contract-check{min-width:0;min-height:30px;padding:6px 8px;border-radius:6px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.018);display:flex;align-items:center;gap:7px;color:#dfe9ff;font-size:12px}
.bob-chat-contract-check.pass{border-color:rgba(126,231,135,0.18);background:rgba(126,231,135,0.045);color:#d8ffdc}
.bob-chat-contract-check.fail{border-color:rgba(255,154,90,0.2);background:rgba(255,154,90,0.045);color:#ffd8bd}
.bob-chat-contract-check span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bob-chat-llm-trace{overflow:auto;min-height:0;flex:1;border-radius:8px;border:1px solid rgba(255,255,255,0.06)}
.bob-chat-trace-list{display:grid;gap:7px;padding:8px;background:rgba(0,0,0,0.14)}
.bob-chat-trace-row{width:100%;min-width:0;min-height:38px;padding:7px 9px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.025);color:#dfe9ff;font:inherit;display:grid;grid-template-columns:minmax(120px,180px) minmax(0,1fr) auto;gap:10px;align-items:center;text-align:left;cursor:default}
.bob-chat-trace-row:hover,.bob-chat-trace-row:focus{outline:none;border-color:rgba(0,224,255,0.26);background:rgba(0,224,255,0.055)}
.bob-chat-trace-row.fail:hover,.bob-chat-trace-row.fail:focus{border-color:rgba(255,204,102,0.28);background:rgba(255,204,102,0.045)}
.bob-chat-trace-row-title{min-width:0;color:#f1f6ff;font-size:13px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bob-chat-trace-row-preview{min-width:0;color:var(--muted);font:12px/1.35 Consolas,'Courier New',monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bob-chat-trace-dialog{position:fixed;z-index:40000;left:50%;top:50%;transform:translate(-50%,-50%);width:min(920px,calc(100vw - 56px));max-height:calc(100vh - 120px);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;border-radius:8px;border:1px solid rgba(0,224,255,0.22);background:#08111f;box-shadow:0 18px 50px rgba(0,0,0,0.52);opacity:.75;pointer-events:none}
.bob-chat-trace-dialog.pinned{opacity:1;pointer-events:auto}
.bob-chat-trace-dialog.fail{border-color:rgba(255,204,102,0.28)}
.bob-chat-trace-dialog-title{grid-column:1/-1;min-height:28px;display:flex;align-items:center;gap:10px;color:#bff9ff;font-size:12px;font-weight:900;text-transform:uppercase}
.bob-chat-trace-dialog-title span{min-width:0;margin-right:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bob-chat-trace-dialog-close{display:none;width:28px;height:28px;border-radius:7px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.045);color:#dfe9ff;place-items:center;cursor:pointer}
.bob-chat-trace-dialog.pinned .bob-chat-trace-dialog-close{display:grid}
.bob-chat-trace-dialog-close:hover{border-color:rgba(0,224,255,0.3);background:rgba(0,224,255,0.09);color:#bff9ff}
.bob-chat-trace-dialog-section{min-width:0;display:flex;flex-direction:column;gap:5px}
.bob-chat-trace-dialog-section h5{margin:0;color:#f1f6ff;font-size:11px;text-transform:uppercase}
.bob-chat-trace-dialog-section pre{min-height:80px;max-height:220px;margin:0;padding:8px;border-radius:7px;border:1px solid rgba(255,255,255,0.07);background:rgba(0,0,0,0.28);color:#dfe9ff;font:11px/1.42 Consolas,'Courier New',monospace;white-space:pre-wrap;overflow:auto;overflow-wrap:anywhere}
.bob-stage-dialog{width:min(1120px,calc(100vw - 32px));max-height:calc(100vh - 40px);overflow:auto;display:flex;flex-direction:column;gap:10px}
.bob-stage-dialog .hal-dialog-header{margin-bottom:0}
.bob-stage-dialog .hal-dialog-header h2{min-width:0;margin-right:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bob-stage-close{width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.04);color:#dfe9ff;display:grid;place-items:center;cursor:pointer}
.bob-stage-close:hover{border-color:rgba(0,224,255,0.3);background:rgba(0,224,255,0.08);color:#bff9ff}
.bob-stage-status{min-height:30px;padding:8px 10px;border-radius:8px;border:1px solid rgba(0,224,255,0.12);background:rgba(0,224,255,0.035);color:#bff9ff;font-size:12px;line-height:1.35;overflow-wrap:anywhere}
.bob-stage-tags{display:flex;align-items:center;gap:8px;min-height:36px;padding:7px 8px;border-radius:8px;border:1px solid rgba(255,255,255,0.07);background:rgba(255,255,255,0.025);overflow:auto}
.bob-stage-tags span{color:#a9b6cc;font-size:11px;font-weight:900;text-transform:uppercase;white-space:nowrap}
.bob-stage-tags button{min-height:24px;padding:4px 8px;border-radius:999px;border:1px solid rgba(0,224,255,0.2);background:rgba(0,224,255,0.06);color:#bff9ff;font:12px/1.2 Consolas,'Courier New',monospace;white-space:nowrap;cursor:grab}
.bob-stage-tags button:hover,.bob-stage-tags button:focus{outline:none;border-color:rgba(0,224,255,0.38);background:rgba(0,224,255,0.11);color:#f1fcff}
.bob-stage-tags button:active{cursor:grabbing}
.bob-stage-chat-input{display:flex;flex-direction:column;gap:6px;color:#a9b6cc;font-size:11px;font-weight:800;text-transform:uppercase}
.bob-stage-chat-input textarea{width:100%;min-height:76px;resize:vertical;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.26);color:#dfe9ff;font:inherit;font-size:13px;line-height:1.45;text-transform:none}
.bob-stage-chat-input textarea:focus{outline:none;border-color:rgba(0,224,255,0.36);box-shadow:0 0 12px rgba(0,224,255,0.08)}
.bob-stage-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.bob-stage-grid label{min-width:0;display:flex;flex-direction:column;gap:6px;color:#a9b6cc;font-size:11px;font-weight:800;text-transform:uppercase}
.bob-stage-grid textarea{width:100%;min-height:260px;resize:vertical;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.28);color:#dfe9ff;font:12px/1.45 Consolas,'Courier New',monospace;white-space:pre;overflow:auto}
.bob-stage-grid textarea:focus{outline:none;border-color:rgba(0,224,255,0.36);box-shadow:0 0 12px rgba(0,224,255,0.08)}
.bob-stage-wide{grid-column:1/-1}
.bob-stage-wide textarea{min-height:130px;white-space:pre-wrap}
.bob-stage-actions{display:flex;justify-content:flex-end;gap:8px}
.bob-stage-actions button{min-height:36px;padding:8px 12px;border-radius:8px;border:1px solid rgba(0,224,255,0.2);background:rgba(0,224,255,0.07);color:#bff9ff;font:inherit;font-size:13px;font-weight:800;display:inline-flex;align-items:center;gap:7px;cursor:pointer}
.bob-stage-actions button:hover{border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.12);color:#f1fcff}
.bob-stage-preview{min-height:180px;max-height:300px;margin:0;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.07);background:rgba(0,0,0,0.3);color:#dfe9ff;font:12px/1.45 Consolas,'Courier New',monospace;white-space:pre-wrap;overflow:auto;overflow-wrap:anywhere}
.bob-chat-trace-table{width:100%;border-collapse:collapse;table-layout:fixed;background:rgba(0,0,0,0.14)}
.bob-chat-trace-table th{position:sticky;top:0;z-index:1;height:34px;padding:8px 10px;background:#07101f;color:#bff9ff;font-size:11px;text-transform:uppercase;text-align:left;border-bottom:1px solid rgba(255,255,255,0.08)}
.bob-chat-trace-table th:nth-child(1),.bob-chat-trace-table th:nth-child(2),.bob-chat-trace-table th:nth-child(3){width:30%}
.bob-chat-trace-table th:nth-child(4){width:10%;min-width:112px;text-align:center}
.bob-chat-trace-table td{vertical-align:top;padding:10px;border-bottom:1px solid rgba(255,255,255,0.06)}
.bob-chat-trace-table td+td{border-left:1px solid rgba(255,255,255,0.05)}
.bob-chat-trace-table tr:last-child td{border-bottom:0}
.bob-chat-trace-cell{display:flex;flex-direction:column;gap:7px;min-width:0}
.bob-chat-trace-cell-header{display:flex;align-items:center;gap:8px;color:#f1f6ff;font-weight:700;font-size:12px}
.bob-chat-trace-cell .bob-chat-code-block{max-height:220px;border-radius:6px;background:rgba(0,0,0,0.22)}
.bob-chat-trace-status-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}
.bob-chat-trace-status{display:inline-flex;align-items:center;justify-content:center;min-width:54px;min-height:24px;padding:3px 7px;border-radius:999px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.04);color:var(--muted);font-size:10px;font-weight:800;text-transform:uppercase;white-space:nowrap}
.bob-chat-trace-status.pass{border-color:rgba(126,231,135,0.24);background:rgba(126,231,135,0.08);color:#d8ffdc}
.bob-chat-trace-status.fail{border-color:rgba(255,204,102,0.24);background:rgba(255,204,102,0.07);color:#ffe4a8}
.bob-chat-trace-checks{width:100%;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.025);overflow:hidden}
.bob-chat-trace-checks.fail{border-color:rgba(255,154,90,0.2);background:rgba(255,154,90,0.04)}
.bob-chat-trace-checks.pass{border-color:rgba(126,231,135,0.2);background:rgba(126,231,135,0.045)}
.bob-chat-trace-checks summary{min-height:26px;padding:5px 7px;cursor:pointer;text-align:center;color:#dfe9ff;font-size:11px;font-weight:800}
.bob-chat-trace-check-list{display:grid;gap:6px;padding:7px;border-top:1px solid rgba(255,255,255,0.06)}
.stream-status[data-state="busy"]{border-color:rgba(255,154,90,0.28);background:rgba(255,154,90,0.08);color:#ffd8bd}
.stream-status[data-state="pass"]{border-color:rgba(126,231,135,0.3);background:rgba(126,231,135,0.09);color:#d8ffdc}
.stream-status[data-state="fail"]{border-color:rgba(255,95,122,0.34);background:rgba(255,95,122,0.1);color:#ffd8df}
.security-event{border-left:3px solid rgba(0,224,255,0.42)}
.security-event.severity-warn{border-left-color:#ff9a5a}
.security-event.severity-critical{border-left-color:#ff5f7a;background:rgba(255,95,122,0.08)}
.security-events-table{max-height:520px}
.users-dashboard .monitor-toolbar h3{margin:0 auto 0 0}
.users-card-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.users-card-header h4{margin:0 auto 0 0}
.users-card-header input{width:min(260px,45%);height:34px;padding:0 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff}
.users-card-header input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 12px rgba(0,224,255,0.1)}
.users-table{display:flex;flex-direction:column;gap:8px;max-height:620px;overflow:auto}
.users-row{min-width:0;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,1fr) auto;gap:12px;align-items:center;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.04);background:rgba(0,0,0,0.18)}
.users-identity{min-width:0;display:grid;grid-template-columns:12px minmax(0,1fr);gap:10px;align-items:center}
.users-presence{width:10px;height:10px;border-radius:999px;background:#5c6576;box-shadow:0 0 0 3px rgba(255,255,255,0.025)}
.users-presence.online{background:#00e0ff;box-shadow:0 0 12px rgba(0,224,255,0.5)}
.users-identity strong,.users-meta span{display:block;color:#f1f6ff;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.users-identity small,.users-meta small{display:block;margin-top:4px;color:var(--muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.users-meta{min-width:0}
.users-role-btn{min-height:34px;padding:7px 10px;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,224,255,0.06);color:#dfe9ff;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;white-space:nowrap}
.users-role-btn:hover:not(:disabled){border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.1);color:var(--accent)}
.users-role-btn.danger{border-color:rgba(255,95,122,0.22);background:rgba(255,95,122,0.08);color:#ffd8df}
.users-role-btn.danger:hover:not(:disabled){border-color:rgba(255,95,122,0.42);background:rgba(255,95,122,0.14);color:#fff}
.users-role-btn:disabled{opacity:.55;cursor:wait}
.user-chat-view{display:flex;flex-direction:column;gap:12px;min-height:100%}
.user-chat-grid{display:grid;grid-template-columns:minmax(220px,320px) minmax(0,1fr);gap:12px;min-height:0;flex:1}
.user-chat-people,.user-chat-thread{min-height:0;display:flex;flex-direction:column}
.user-chat-users,.user-chat-messages{min-height:0;overflow:auto;display:flex;flex-direction:column;gap:8px}
.user-chat-search{height:38px;margin:0 0 10px;display:grid;grid-template-columns:30px minmax(0,1fr);align-items:center;border:1px solid rgba(255,255,255,0.08);border-radius:8px;background:rgba(0,0,0,0.26);color:var(--muted)}
.user-chat-search .lucide{justify-self:center;width:16px;height:16px}
.user-chat-search input{min-width:0;height:100%;border:0;background:transparent;color:#dfe9ff;font:inherit;font-size:13px;outline:none;padding:0 10px 0 0}
.user-chat-search input::placeholder{color:var(--muted)}
.user-chat-search:focus-within{border-color:rgba(0,224,255,0.34);box-shadow:0 0 12px rgba(0,224,255,0.08)}
.user-chat-user{min-height:54px;padding:9px;border-radius:8px;border:1px solid rgba(255,255,255,0.05);background:rgba(0,0,0,0.18);color:#dfe9ff;display:grid;grid-template-columns:28px minmax(0,1fr);gap:9px;align-items:center;text-align:left;cursor:pointer}
.user-chat-user:hover:not(:disabled),.user-chat-user.active{border-color:rgba(0,224,255,0.28);background:rgba(0,224,255,0.07)}
.user-chat-user:disabled{opacity:.62;cursor:not-allowed}
.user-chat-user strong,.user-chat-user small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chat-user strong{font-size:13px;color:#f1f6ff}
.user-chat-user small{font-size:11px;color:var(--muted);margin-top:3px}
.user-chat-thread-header{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.user-chat-thread-header h4{margin:0;color:#f1f6ff}
.user-chat-thread-header small{color:var(--muted);font-size:12px;overflow-wrap:anywhere}
.user-chat-messages{flex:1;padding-right:4px}
.user-chat-message{max-width:78%;padding:10px 12px;border-radius:8px;border:1px solid rgba(255,255,255,0.05);background:rgba(0,0,0,0.2)}
.user-chat-message.sent{align-self:flex-end;border-color:rgba(0,224,255,0.18);background:rgba(0,224,255,0.065)}
.user-chat-message.received{align-self:flex-start;border-color:rgba(124,92,255,0.18);background:rgba(124,92,255,0.07)}
.user-chat-message p{margin:0;color:#dfe9ff;font-size:13px;line-height:1.45;white-space:pre-wrap;overflow-wrap:anywhere}
.user-chat-message small{display:block;margin-top:5px;color:var(--muted);font-size:10px}
.user-chat-form{display:grid;grid-template-columns:minmax(0,1fr) 42px;gap:8px;margin-top:10px}
.user-chat-form input{min-width:0;height:42px;padding:0 12px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font:inherit}
.user-chat-form input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 12px rgba(0,224,255,0.1)}
.user-chat-form button{height:42px;border-radius:8px;border:1px solid rgba(0,224,255,0.2);background:rgba(0,224,255,0.08);color:#dfe9ff;display:grid;place-items:center;cursor:pointer}
.user-chat-form button:hover:not(:disabled){border-color:rgba(0,224,255,0.38);background:rgba(0,224,255,0.13);color:var(--accent)}
.user-chat-form button:disabled{opacity:.5;cursor:not-allowed}
#softReboot{padding:10px;border-radius:8px;border:0;background:linear-gradient(90deg,#ff5f7a,#ff9a5a);color:white;margin-bottom:8px}
#rebootStatus{min-height:48px}
.log-row{padding:8px;border-bottom:1px solid rgba(255,255,255,0.02);font-family:monospace;color:var(--muted)}
.monitor-output{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.01));padding:10px;border-radius:8px;color:var(--muted);height:220px;overflow:auto}
.main-menu-page>.logging-view{display:flex;flex-direction:column;min-height:100%;overflow:hidden}
.logging-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex:0 0 auto}
.logging-toolbar h3{margin:0 auto 0 0}
.stream-status{min-height:24px;padding:4px 8px;border-radius:6px;border:1px solid rgba(0,224,255,0.14);background:rgba(0,224,255,0.05);color:#bff9ff;font-size:11px;text-transform:uppercase;display:inline-flex;align-items:center}
.logging-toolbar button{min-height:34px;padding:7px 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.03);color:#dfe9ff;display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.logging-toolbar button:hover{border-color:rgba(0,224,255,0.25);background:rgba(0,224,255,0.07);color:var(--accent)}
.logging-output{height:auto;flex:1 1 auto;min-height:0;width:100%;font-size:12px;line-height:1.45}
.settings-group{display:grid;gap:10px;max-width:420px}
.settings-group h4{margin:0;color:#bff9ff;font-size:13px}
.settings-group label{min-width:0;display:grid;gap:6px;color:var(--muted);font-size:12px;text-transform:uppercase}
.settings-group>label input{min-width:0;height:38px;padding:0 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font:inherit;text-transform:none}
.settings-action{min-height:42px;width:100%;padding:10px 12px;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,224,255,0.06);color:#dfe9ff;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}
.settings-action:hover{border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.1);color:var(--accent)}
.debug-setting-row{min-height:64px;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.025);display:grid;grid-template-columns:22px minmax(0,1fr);gap:12px;align-items:start;color:#dfe9ff}
.debug-setting-row input{width:18px;height:18px;margin-top:2px;accent-color:var(--accent)}
.debug-setting-row span{display:grid;gap:5px}
.debug-setting-row strong{color:#f1f6ff;font-size:13px}
.debug-setting-row small{color:var(--muted);font-size:12px;line-height:1.45}
.mic-services-group{max-width:760px}
.mic-services-status{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.mic-services-status>div{min-height:54px;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.18);display:grid;gap:5px;min-width:0}
.mic-services-status span{color:var(--muted);font-size:11px;text-transform:uppercase}
.mic-services-status strong{color:#dfe9ff;font-size:12px;line-height:1.35;overflow-wrap:anywhere}
.mic-services-status .mic-services-wide{grid-column:1/-1}
.mic-tester-view{display:flex;flex-direction:column;min-height:100%;overflow:hidden}
.mic-tester-grid{display:grid;grid-template-columns:minmax(260px,360px) minmax(0,1fr);gap:10px;min-height:0;flex:1;overflow:auto}
.mic-tester-card{padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.025);min-width:0}
.mic-tester-card h4{margin:0 0 10px;color:#bff9ff;font-size:13px}
.mic-tester-card-heading{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 0 10px}
.mic-tester-card-heading h4{margin:0}
.mic-renderer-toggle{display:flex;align-items:center;gap:4px;padding:3px;border-radius:8px;border:1px solid rgba(0,224,255,0.14);background:rgba(0,0,0,0.14)}
.mic-renderer-mode{min-height:28px;padding:0 8px;border-radius:6px;border:1px solid transparent;background:transparent;color:var(--muted);font:inherit;font-size:11px;font-weight:700;cursor:pointer}
.mic-renderer-mode:hover{color:#dffbff;border-color:rgba(0,224,255,0.18)}
.mic-renderer-mode.active{color:#03111f;background:linear-gradient(135deg,#1fd7ff,#7c5cff);border-color:rgba(255,255,255,0.22)}
.mic-tester-controls{display:grid;gap:10px}
.mic-tester-controls label{display:grid;gap:5px;color:var(--muted);font-size:11px;text-transform:uppercase}
.mic-tester-controls select{height:38px;min-width:0;padding:0 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:#060b16;color:#dfe9ff}
.mic-tester-controls .mic-tester-inline-toggle{min-height:34px;display:flex;align-items:center;gap:8px;padding:8px;border-radius:8px;border:1px solid rgba(0,224,255,0.12);background:rgba(0,224,255,0.035);color:#dfe9ff;font-size:12px;font-weight:700;text-transform:none;cursor:pointer}
.mic-tester-inline-toggle input{width:15px;height:15px;accent-color:var(--accent);flex:0 0 auto}
.mic-tester-process{min-height:38px;display:flex;align-items:center;padding:0 10px;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,224,255,0.055);color:#dfe9ff;font-weight:700}
.mic-tester-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mic-status-row{display:flex;align-items:center;gap:8px;margin:0 0 8px;color:#dfe9ff;font-size:12px}
.mic-status-light{width:12px;height:12px;border-radius:999px;display:inline-block;border:1px solid rgba(255,255,255,0.22);box-shadow:0 0 0 2px rgba(255,255,255,0.04)}
.mic-status-light-idle{background:#6f7b8d;box-shadow:0 0 0 2px rgba(255,255,255,0.04)}
.mic-status-light-good{background:#47f27a;box-shadow:0 0 12px rgba(71,242,122,0.72)}
.mic-status-light-bad{background:#ff4d61;box-shadow:0 0 12px rgba(255,77,97,0.72)}
.mic-diagnostic-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.mic-diagnostic-grid div{min-height:34px;display:flex;align-items:center;gap:8px;min-width:0;padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.14)}
.mic-diagnostic-grid strong{font-size:12px;color:#dfe9ff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.voice-pipeline-stage-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.voice-pipeline-path{display:grid;gap:8px}
.voice-pipeline-path span{min-height:34px;display:flex;align-items:center;padding:8px;border-radius:8px;border:1px solid rgba(0,224,255,0.12);background:rgba(0,224,255,0.035);color:#dfe9ff;font-size:12px;font-weight:700}
.voice-pipeline-path span::before{content:"";width:8px;height:8px;border-radius:999px;margin-right:8px;background:var(--accent);box-shadow:0 0 10px rgba(0,224,255,0.5)}
.mic-subsystem-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.mic-subsystem-grid label{min-height:34px;display:flex;align-items:center;gap:8px;min-width:0;padding:8px;border-radius:8px;border:1px solid rgba(0,224,255,0.12);background:rgba(0,224,255,0.035);color:#dfe9ff;font-size:12px;font-weight:700;cursor:pointer}
.mic-subsystem-grid input{width:15px;height:15px;accent-color:var(--accent);flex:0 0 auto}
.mic-subsystem-grid span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mic-tester-card canvas{width:100%;height:150px;border-radius:8px;border:1px solid rgba(0,224,255,0.12);background:rgba(0,0,0,0.2)}
.mic-tester-transcript{min-height:150px;padding:12px;border-radius:8px;border:1px solid rgba(124,92,255,0.16);background:rgba(124,92,255,0.055);color:#f1f6ff;line-height:1.45;white-space:pre-wrap;overflow:auto}
.mic-tester-log-card{grid-column:1/-1;min-height:220px}
.mic-tester-log-card .monitor-output{height:190px;font-size:12px;white-space:pre-wrap}
.model-default-toggle{min-height:30px;padding:5px 9px;border-radius:8px;border:1px solid rgba(0,224,255,0.16);background:rgba(0,224,255,0.05);color:#dfe9ff;display:inline-flex;align-items:center;gap:7px;font-size:12px;cursor:pointer;white-space:nowrap}
.model-default-toggle:hover{border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.1)}
.model-default-toggle input{width:15px;height:15px;accent-color:var(--accent)}
.model-default-toggle input:checked+span{color:#bff9ff;font-weight:700}

/* Scrollbar Styling */
.messages::-webkit-scrollbar{width:8px}
.messages::-webkit-scrollbar-thumb{background:linear-gradient(180deg, rgba(0,224,255,0.1), rgba(124,92,255,0.1));border-radius:4px;border:2px solid transparent;background-clip:padding-box}
.messages::-webkit-scrollbar-track{background:transparent}
.messages{scrollbar-width:thin;scrollbar-color:rgba(0,224,255,0.1) transparent}

/* Responsive */
@media (max-width: 768px) {
  :root{--lower-banner-reserve:72px}
  .main{padding:12px}
  .main.panel-open{margin-right:0}
  .slide-panel{width:min(360px, calc(100vw - 16px));max-width:calc(100vw - 16px);box-shadow:-16px 0 34px rgba(0,0,0,0.58)}
  .slide-panel.open{box-shadow:-16px 0 34px rgba(0,0,0,0.58)}
  .chat-header{padding:10px 0}
  .lower-banner{grid-template-columns:minmax(0,1fr) 96px;gap:8px;padding:8px;border-radius:12px}
  .page-banner-status{min-height:44px}
  .input-wrapper{gap:8px}
  .composer input{font-size:16px}
  .fab-menu{width:44px;height:44px;flex-basis:44px;border-radius:9px}
  .fab-menu .lucide{width:21px;height:21px}
  .chat-clear-btn{width:44px;height:44px;flex-basis:44px;border-radius:9px}
  .btn-send{width:58px;height:44px;min-width:58px;padding:0;justify-content:center;flex:0 0 58px}
  .btn-send .lucide{width:20px;height:20px}
  .login-body{padding:14px;place-items:start center}
  .login-shell{width:min(420px,100%)}
  .login-panel{min-height:calc(100vh - 28px);min-height:calc(100dvh - 28px);padding:30px 22px}
  .login-mark{width:140px;height:140px}
  .msg{max-width:85%}
  .voice-strip{grid-template-columns:minmax(0,1fr);padding:0;gap:8px;flex:0 0 auto}
  .voice-panel{height:auto;min-height:0;max-height:none;padding:8px;gap:6px;border-radius:8px}
  .voice-panel.ai-voice{width:100%;height:104px;min-height:104px;max-height:104px;justify-self:stretch;border-radius:8px;grid-template-columns:122px minmax(0,1fr);grid-template-rows:1fr;column-gap:8px;row-gap:0}
  .voice-label{min-height:26px;font-size:11px}
  .voice-label-row{gap:6px}
  .voice-panel.ai-voice .voice-label-row{grid-row:1;grid-template-columns:80px 34px;grid-template-rows:80px;align-items:center;justify-content:start;gap:6px}
  .voice-panel.ai-voice .bob-voice-title{width:80px;height:80px;aspect-ratio:auto}
  .ai-card-controls{flex-direction:row;align-items:center;gap:6px}
  .voice-panel canvas{height:auto;min-height:0;max-height:none;flex:1 1 auto}
  .ai-waveform-stack{grid-row:1;height:80px;min-height:80px;max-height:80px;gap:4px}
  .ai-waveform-stack #aiWaveform{height:52px;min-height:0;max-height:none}
  .bob-context-widget{width:34px;height:80px;padding:4px 3px}
  .bob-context-meta{width:auto;padding:0}
  .bob-context-meta small{font-size:9px}
  .bob-context-widget canvas{height:auto;min-height:0;max-height:none}
  .bob-context-widget .bob-brain-btn{width:24px;height:20px;min-height:20px}
  .playback-speed{height:24px}
  .playback-speed button{width:26px;height:24px}
  .playback-speed span{min-width:34px;font-size:11px;line-height:24px}
  .input-section{padding:0}
  .composer-voice{position:fixed;left:calc(12px + env(safe-area-inset-left));right:calc(12px + env(safe-area-inset-right));bottom:calc(84px + env(safe-area-inset-bottom));z-index:30005;grid-template-columns:minmax(0,1fr) minmax(106px,34%);gap:6px}
  .input-section.mic-active .composer-voice{max-height:54px}
  .composer-voice canvas{height:40px}
  .btn-mic{width:44px;height:44px;min-width:44px;flex-basis:44px;padding:0;border-radius:9px}
  .monitor-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .ollama-config-grid{grid-template-columns:1fr}
  .monitor-grid{grid-template-columns:1fr}
  .activity-chart-grid{grid-template-columns:1fr}
  .activity-chart-card,.activity-chart-card.wide{grid-column:auto;height:240px}
  .memory-message-row{grid-template-columns:minmax(0,1fr) 32px;gap:4px 8px}
  .memory-message-role,.memory-message-model,.memory-message-time,.memory-message-emotion{font-size:11px}
  .memory-message-model,.memory-message-time,.memory-message-emotion,.memory-message-content{grid-column:1}
  .memory-message-row .memory-delete-btn{grid-column:2;grid-row:1 / span 2}
  .skills-grid,.admin-grid{grid-template-columns:1fr}
  .mic-tester-grid{display:flex;flex-direction:column;overflow:auto}
  .mic-tester-actions{grid-template-columns:1fr}
  .mic-diagnostic-grid{grid-template-columns:1fr}
  .mic-subsystem-grid{grid-template-columns:1fr}
  .mic-services-status{grid-template-columns:minmax(0,1fr)}
  .mic-services-status .mic-services-wide{grid-column:auto}
  .app-tester-grid{grid-template-columns:1fr}
  .tester-bob-card{min-height:300px}
  .tester-emotion-card{grid-column:auto}
  .tester-emotion-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  body.bob-chat-tester-route .main{padding:8px;gap:8px;overflow:hidden}
  body.bob-chat-tester-route .main-content{width:100%;height:auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
  body.bob-chat-tester-route .main-menu-page{width:100%;height:auto;min-height:0;overflow-x:hidden;overflow-y:visible;display:block}
  .main-menu-page>.bob-chat-tester-view{width:100%;height:auto;min-height:0;overflow-x:hidden;overflow-y:visible;padding:0}
  .bob-chat-tester-view{width:100%;min-width:0;max-width:100%;display:flex;flex-direction:column;gap:8px;overflow-x:hidden;overflow-y:visible}
  .bob-chat-tester-view .monitor-toolbar{flex-wrap:wrap;align-items:center;gap:6px}
  .bob-chat-tester-view .monitor-toolbar h3{flex:1 1 100%;line-height:1.2}
  .bob-chat-tester-grid{width:100%;min-width:0;max-width:100%;flex:0 0 auto;display:flex;flex-direction:column;gap:8px;grid-template-columns:1fr;grid-template-rows:auto;grid-template-areas:"runner" "face" "modelstatus" "live" "llm";overflow-x:hidden;overflow-y:visible}
  .bob-chat-model-status-card{height:auto;max-height:none;resize:none}
  .bob-chat-model-status-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .bob-chat-runner{width:100%;min-width:0;max-width:100%;display:flex;flex-direction:column;gap:8px;height:auto;overflow:hidden}
  .bob-chat-test-conversation{width:100%;min-width:0;max-width:100%;display:flex;flex-direction:column;gap:8px;min-height:0;overflow:hidden}
  .bob-chat-test-rail{width:100%;min-width:0;max-width:100%;display:flex;flex-direction:column;gap:8px;overflow:hidden}
  .bob-chat-test-controls{display:grid;grid-template-columns:minmax(0,1fr) 34px}
  .tester-actions{grid-template-columns:1fr}
  .bob-chat-runner,.bob-chat-face-card,.bob-chat-live-card,.bob-chat-llm-card{grid-column:auto;grid-row:auto;min-width:0;max-width:100%;min-height:0;height:auto;overflow:hidden}
  .bob-chat-tester-view .bob-chat-face-card{height:auto;min-height:220px;overflow:hidden;justify-content:center}
  .bob-chat-tester-view .bob-chat-face-card .tester-bob-display{width:100%;height:auto;align-items:center;justify-content:center;flex:0 0 auto}
  .bob-chat-tester-view .bob-chat-face-card .tester-bob-face-shell{width:min(180px,calc(100vw - 128px));height:auto;max-width:100%;aspect-ratio:1;flex:0 0 auto}
  .bob-chat-tester-view .bob-chat-face-card .tester-bob-ctx{height:min(180px,calc(100vw - 128px));min-height:120px;flex:0 0 42px}
  .bob-chat-live-card,.bob-chat-llm-card{max-height:none;resize:none}
  .bob-chat-model-status-list,.bob-chat-live-output,.bob-chat-llm-trace,.bob-chat-preset-grid,.bob-chat-test-messages{max-width:100%;overflow:auto}
  .bob-chat-trace-row{grid-template-columns:minmax(0,1fr) auto}
  .bob-chat-trace-row-preview{grid-column:1/-1}
  .bob-chat-trace-dialog{left:50%;right:auto;top:50%;grid-template-columns:1fr;width:calc(100vw - 28px);max-height:calc(100vh - 100px)}
  .bob-memory-overlay{padding:14px}
  .bob-memory-dialog{width:calc(100vw - 28px);max-height:calc(100vh - 28px)}
  .bob-memory-grid{grid-template-columns:1fr;grid-template-rows:minmax(180px,1fr) minmax(160px,.8fr) minmax(130px,.6fr) minmax(130px,.6fr) minmax(130px,.6fr);grid-template-areas:"chat" "facts" "short" "medium" "long";overflow:auto}
  .bob-memory-row,.bob-memory-factoid{grid-template-columns:minmax(0,1fr);gap:4px}
  .bob-stage-dialog{width:calc(100vw - 28px);max-height:calc(100vh - 28px)}
  .bob-stage-grid{grid-template-columns:1fr}
  .bob-stage-grid textarea{min-height:220px}
  .bob-chat-trace-table{min-width:0}
  .bob-chat-test-messages{min-height:0;max-height:none}
  .bob-chat-test-form{grid-template-columns:minmax(0,1fr) auto}
  .bob-chat-preset-grid,.bob-chat-contract-checks{grid-template-columns:1fr}
  .tester-provider-control{grid-template-columns:1fr}
  .tester-voice-options{grid-template-columns:1fr}
  .monitor-control-row{flex-wrap:wrap}
  .users-card-header{align-items:stretch;flex-direction:column}
  .users-card-header input{width:100%}
  .users-row{grid-template-columns:1fr}
  .users-role-btn{width:100%}
  .user-chat-grid{grid-template-columns:1fr}
  .user-chat-people{max-height:none}
  .user-chat-message{max-width:88%}
  .entropy-overlay{padding:10px}
  .entropy-dialog{max-height:calc(100dvh - 20px);padding:14px;gap:10px}
  .entropy-pad{height:min(220px,34dvh)}
  .vtt-output{max-width:100%;min-height:40px;padding:5px 8px;font-size:11px;line-height:14px}
}
