: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}
.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}
.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{padding:14px 16px;border-radius:12px;max-width:72%;backdrop-filter:blur(4px);word-wrap:break-word;animation:slideIn 0.3s ease}
@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}

/* 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:118px;min-height:118px;max-height:118px;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%;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:98px minmax(0,1fr);grid-template-rows:32px 58px;align-items:stretch}
.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{display:contents}
.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{grid-column:1;grid-row:1 / 3;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}
.bob-face-shell{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[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 .ai-card-controls{grid-column:2;grid-row:1;align-self:center}
.voice-panel.ai-voice .voice-label{color:#d7d0ff}
.voice-panel canvas{width:100%;height:58px;min-height:58px;max-height:58px;display:block;border-radius:6px;background:rgba(0,0,0,0.18);flex:0 0 58px}
.voice-panel.ai-voice canvas{grid-column:2;grid-row:2;min-width:0}
.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}

/* 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}
.model-picker{display:grid;grid-template-columns:auto minmax(120px,1fr) 30px;gap:6px;align-items:center;min-width:0;max-width:230px}
.model-picker label{color:var(--muted);font-size:12px;text-transform:uppercase}
.model-picker select{min-width:0;height:28px;padding:0 8px;border-radius:6px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3);color:#dfe9ff;font-size:12px}
.model-picker select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 12px rgba(0,224,255,0.1)}
.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{display:flex;flex-direction:column;gap:8px}
.composer-voice{position:absolute;left:0;right:0;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}

/* Models Lists */
.models-list{max-height:260px;overflow:auto;padding-right:8px}
.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{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}
.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-summary-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}
.memory-summary-card{min-height:210px;display:flex;flex-direction:column}
.memory-summary-card.wide{grid-column:1 / -1}
.memory-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.memory-card-header h4{margin:0 auto 0 0}
.memory-card-header button{min-height:32px;padding:6px 10px;border-radius:8px;border:1px solid rgba(0,224,255,0.18);background:rgba(0,224,255,0.06);color:#dfe9ff;cursor:pointer}
.memory-card-header button:hover:not(:disabled){border-color:rgba(0,224,255,0.34);background:rgba(0,224,255,0.1);color:var(--accent)}
.memory-card-header button:disabled{opacity:.55;cursor:wait}
.memory-summary-text{margin:0;white-space:pre-wrap;color:#dfe9ff;font-size:13px;line-height:1.55;flex:1}
.memory-summary-card small{display:block;margin-top:10px;color:var(--muted);font-size:11px}
.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:8px;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.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-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-message-row p,.memory-factoid-row p{margin:0;color:#cdd8ec;font-size:12px;line-height:1.45;white-space:pre-wrap}
.memory-message-row small,.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{display:flex;flex-direction:column;gap:12px}
.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-face-shell{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-meta{display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center}
.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{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{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:flex;gap:8px;align-items:center;flex-wrap:wrap}
.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-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}
.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}
.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-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)}

/* 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}
  .voice-panel{height:112px;min-height:112px;max-height:112px;padding:8px;gap:6px;border-radius:8px}
  .voice-panel.ai-voice{width:100%;justify-self:stretch;border-radius:8px;grid-template-columns:96px minmax(0,1fr);grid-template-rows:26px 36px}
  .voice-label{min-height:26px;font-size:11px}
  .voice-label-row{gap:6px}
  .voice-panel.ai-voice .voice-label-row{align-items:center}
  .voice-panel.ai-voice .bob-voice-title{width:96px;height:96px}
  .ai-card-controls{flex-direction:row;align-items:center;gap:6px}
  .voice-panel canvas{height:36px;min-height:36px;max-height:36px;flex-basis:36px}
  .playback-speed{height:26px}
  .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{left:0;right:0;bottom:calc(100% + 7px);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}
  .model-picker{grid-template-columns:auto minmax(0,1fr) 26px;width:min(100%,210px);max-width:210px;gap:4px}
  .model-picker label{font-size:10px}
  .model-picker select{height:26px;font-size:11px;padding:0 6px}
  .model-picker .btn-icon{width:26px;height:26px;border-radius:6px}
  .monitor-summary{grid-template-columns:repeat(2,minmax(0,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-summary-grid{grid-template-columns:1fr}
  .memory-summary-card.wide{grid-column:auto}
  .skills-grid,.admin-grid{grid-template-columns:1fr}
  .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))}
  .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:220px}
  .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}
}
