:root{--bg: #eef1f8;--bg-grad-top: #f7f9fc;--bg-grad-bottom: #e7ecf6;--panel: #ffffff;--panel-2: #f3f5fa;--text: #1b2436;--text-dim: #6b7689;--accent: #4f7cff;--accent-strong: #3b63e6;--accent-soft: #eaf0ff;--green: #16b364;--amber: #f59e0b;--red: #ef4444;--border: #e3e8f1;--border-strong: #d2dae8;--radius: 16px;--shadow-sm: 0 1px 2px rgba(20, 30, 55, .06), 0 1px 3px rgba(20, 30, 55, .05);--shadow-md: 0 4px 14px rgba(20, 30, 55, .08), 0 2px 6px rgba(20, 30, 55, .05);--shadow-lg: 0 18px 50px rgba(20, 30, 55, .18)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:linear-gradient(180deg,var(--bg-grad-top) 0%,var(--bg-grad-bottom) 100%);background-attachment:fixed;color:var(--text);font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}.app{height:100%;display:flex;flex-direction:column;max-width:1080px;margin:0 auto;padding:14px 16px;gap:12px}.topbar{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;box-shadow:var(--shadow-sm)}.brand{font-weight:700;font-size:18px;display:flex;align-items:center;gap:9px;letter-spacing:-.2px}.brand-dot{width:11px;height:11px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#9cc0ff,var(--accent));box-shadow:0 0 0 4px var(--accent-soft)}.topbar-actions{margin-left:auto;display:flex;gap:8px}.agent-select{background:var(--panel-2);color:var(--text);border:1px solid var(--border-strong);border-radius:10px;padding:10px 12px;font-size:15px;min-width:200px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.agent-select:hover{border-color:var(--accent)}.agent-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.banner{padding:11px 14px;border-radius:12px;font-size:14px;cursor:pointer;box-shadow:var(--shadow-sm)}.banner-error{background:#fef2f3;color:#b42318;border:1px solid #fbd5d5}.banner-warn{background:#fffaeb;color:#b25e09;border:1px solid #fce8b6}.stage{flex:1;display:flex;flex-direction:column;align-items:center;gap:12px;min-height:0}.agent-blurb{color:var(--text-dim);font-size:14px;text-align:center}.orb-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;padding-top:4px}.orb{position:relative;width:130px;height:130px}.orb-core{position:absolute;top:25%;right:25%;bottom:25%;left:25%;border-radius:50%;background:radial-gradient(circle at 35% 35%,#9cc0ff,var(--accent) 60%,#2f56c8);box-shadow:0 8px 24px #4f7cff59;transition:all .3s ease}.orb-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid var(--accent);opacity:.3}.orb-ring.r2{top:12%;right:12%;bottom:12%;left:12%;opacity:.45}.orb-label{color:var(--text-dim);font-size:15px;letter-spacing:.3px;font-weight:500}.orb-off .orb-core{background:radial-gradient(circle at 35% 35%,#dfe5ef,#c4cdde 60%,#aab6cc);box-shadow:none}.orb-off .orb-ring{border-color:#cbd4e3}.orb-connecting .orb-ring.r1{animation:spin 1.2s linear infinite;border-top-color:transparent;opacity:.85}.orb-standby .orb-core{background:radial-gradient(circle at 35% 35%,#ffd9a0,var(--amber) 60%,#c97f0a);box-shadow:0 8px 24px #f59e0b4d;animation:breathe 3.2s ease-in-out infinite}.orb-standby .orb-ring{border-color:var(--amber)}.orb-listening .orb-core{animation:breathe 2.2s ease-in-out infinite}.orb-listening .orb-ring.r1{animation:pulse 2.2s ease-out infinite}.orb-thinking .orb-ring.r1{animation:spin 1s linear infinite;border-top-color:transparent;opacity:.9}.orb-thinking .orb-ring.r2{animation:spin 1.6s linear infinite reverse;border-bottom-color:transparent;opacity:.6}.orb-speaking .orb-core{background:radial-gradient(circle at 35% 35%,#9af0bb,var(--green) 60%,#0f8a4c);box-shadow:0 8px 24px #16b36452;animation:talk .5s ease-in-out infinite}.orb-speaking .orb-ring{border-color:var(--green)}.orb-speaking .orb-ring.r1{animation:pulse .9s ease-out infinite}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes talk{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}@keyframes pulse{0%{transform:scale(.9);opacity:.55}to{transform:scale(1.25);opacity:0}}@keyframes spin{to{transform:rotate(360deg)}}.convo{flex:1;width:100%;min-height:0;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden}.convo-header{display:flex;align-items:center;gap:13px;padding:14px 16px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#fbfcfe 0%,var(--panel) 100%)}.convo-avatar{position:relative;width:46px;height:46px;flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);font-size:23px;transition:background .3s ease}.convo-avatar-emoji{line-height:1}.convo-avatar-ring{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid transparent}.convo-meta{flex:1;min-width:0}.convo-name{font-weight:700;font-size:16px;letter-spacing:-.2px}.convo-blurb{color:var(--text-dim);font-size:13px;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-pill{display:flex;align-items:center;gap:8px;flex-shrink:0;padding:6px 12px 6px 10px;border-radius:999px;font-size:13px;font-weight:600;background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);transition:background .3s ease,color .3s ease,border-color .3s ease}.status-text{white-space:nowrap}.convo-listening .convo-avatar{background:#e3f7ec}.convo-listening .convo-avatar-ring{border-color:var(--green);animation:ring-pulse 2s ease-out infinite}.convo-listening .status-pill{background:#e3f7ec;color:#0f8a4c;border-color:#bfedd2}.convo-speaking .convo-avatar{background:#e3f7ec}.convo-speaking .convo-avatar-ring{border-color:var(--green);box-shadow:0 0 0 4px #16b3641f}.convo-speaking .status-pill{background:#e3f7ec;color:#0f8a4c;border-color:#bfedd2}.convo-thinking .convo-avatar-ring{border-top-color:var(--accent);border-right-color:var(--accent);animation:spin .9s linear infinite}.convo-thinking .status-pill{background:var(--accent-soft);color:var(--accent-strong);border-color:#d3e0ff}.convo-connecting .convo-avatar-ring{border-top-color:var(--text-dim);animation:spin 1.2s linear infinite}.convo-standby .convo-avatar{background:#fdf3e0}.convo-standby .convo-avatar-ring{border-color:var(--amber);animation:ring-pulse 3s ease-out infinite}.convo-standby .status-pill{background:#fdf3e0;color:#b25e09;border-color:#f7e1b4}.convo-off .convo-avatar{background:#eef1f6;filter:grayscale(.4)}.convo-off .convo-avatar-ring{border-color:var(--border-strong)}@keyframes ring-pulse{0%{box-shadow:0 0 #16b36459}70%{box-shadow:0 0 0 9px #16b36400}to{box-shadow:0 0 #16b36400}}.glyph{display:inline-flex;align-items:center}.dot{width:8px;height:8px;border-radius:50%;background:currentColor}.dot-listening,.dot-standby{animation:dot-blink 1.4s ease-in-out infinite}@keyframes dot-blink{0%,to{opacity:1}50%{opacity:.3}}.eq{gap:2px;height:14px}.eq i{width:3px;border-radius:2px;background:currentColor;animation:eq-bounce .9s ease-in-out infinite}.eq i:nth-child(1){animation-delay:0s}.eq i:nth-child(2){animation-delay:.18s}.eq i:nth-child(3){animation-delay:.36s}.eq i:nth-child(4){animation-delay:.12s}@keyframes eq-bounce{0%,to{height:4px}50%{height:14px}}.dots{gap:3px}.dots i{width:5px;height:5px;border-radius:50%;background:currentColor;animation:dots-bounce 1.2s ease-in-out infinite}.dots i:nth-child(2){animation-delay:.16s}.dots i:nth-child(3){animation-delay:.32s}@keyframes dots-bounce{0%,to{transform:translateY(0);opacity:.5}50%{transform:translateY(-3px);opacity:1}}.convo-body{flex:1;min-height:120px;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth}.transcript-empty{color:var(--text-dim);text-align:center;margin:auto;font-size:14px;display:flex;flex-direction:column;align-items:center;gap:10px}.transcript-empty-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);font-size:24px}.msg{display:flex;align-items:flex-end;gap:9px;max-width:86%;animation:msg-in .22s ease}.msg-user{align-self:flex-end;flex-direction:row-reverse}.msg-bot{align-self:flex-start}.avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:var(--shadow-sm)}.avatar-bot{background:var(--accent-soft)}.avatar-user{background:#e9edf4}.bubble{padding:10px 14px;border-radius:16px;font-size:15px;line-height:1.5;display:flex;flex-direction:column;gap:3px;box-shadow:var(--shadow-sm)}.bubble-user{background:linear-gradient(180deg,var(--accent) 0%,var(--accent-strong) 100%);color:#fff;border-bottom-right-radius:5px}.bubble-bot{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:5px}.bubble-who{font-size:11px;opacity:.7;font-weight:600;text-transform:uppercase;letter-spacing:.6px}.bubble-user .bubble-who{color:#eaf0ff}.bubble-bot .bubble-who{color:var(--text-dim)}.bubble-pending{opacity:.85}@keyframes msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.controls{display:flex;gap:12px;padding-bottom:4px}.btn{background:var(--panel);color:var(--text);border:1px solid var(--border-strong);border-radius:12px;padding:10px 16px;font-size:15px;cursor:pointer;box-shadow:var(--shadow-sm);transition:background .15s ease,border-color .15s ease,transform .05s ease,box-shadow .15s ease}.btn:hover{background:var(--panel-2);border-color:var(--border-strong);box-shadow:var(--shadow-md)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:default;box-shadow:none}.btn-ghost{background:transparent;border-color:transparent;box-shadow:none}.btn-ghost:hover{background:var(--panel-2);border-color:var(--border);box-shadow:none}.btn-small{padding:6px 10px;font-size:13px}.btn-danger{border-color:#f4c4c4;color:#b42318;background:#fef5f5}.btn-danger:hover{background:#fdeaea}.btn-pill{padding:8px 14px;font-size:14px;font-weight:600;border-radius:999px;color:#fff;border:none;white-space:nowrap}.topbar-sep{width:1px;align-self:stretch;margin:2px 4px;background:var(--border)}.btn-big{flex:1;padding:17px;font-size:18px;font-weight:600;border-radius:16px;color:#fff;border:none}.btn-restart{background:linear-gradient(180deg,var(--accent) 0%,var(--accent-strong) 100%);box-shadow:0 6px 18px #4f7cff4d}.btn-restart:hover{background:linear-gradient(180deg,var(--accent-strong) 0%,#2f52cf 100%);box-shadow:0 8px 22px #4f7cff61}.btn-mute{background:linear-gradient(180deg,#1fbf72 0%,var(--green) 100%);box-shadow:0 6px 18px #16b36447}.btn-mute:hover{background:linear-gradient(180deg,var(--green) 0%,#0f9c55 100%);box-shadow:0 8px 22px #16b3645c}.btn-muted{background:linear-gradient(180deg,#f6b24a 0%,var(--amber) 100%);color:#4a2e00;box-shadow:0 6px 18px #f59e0b4d}.btn-muted:hover{background:linear-gradient(180deg,var(--amber) 0%,#d98708 100%)}.btn-camera{background:linear-gradient(180deg,#8b6ff0,#6d4fd6);box-shadow:0 6px 18px #6d4fd64d}.btn-camera:hover{background:linear-gradient(180deg,#6d4fd6,#5739bf);box-shadow:0 8px 22px #6d4fd661}.dock{display:flex;gap:12px;align-items:stretch;height:200px;flex:none}.system-log{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden}.system-log-title{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);padding:7px 8px 5px 14px}.log-clear{font-size:11px;letter-spacing:0;text-transform:none;color:#b42318;padding:4px 8px}.log-clear:hover{background:#fef2f3;border-color:#fbd5d5}.system-log-list{flex:1;overflow-y:auto;padding:0 14px 10px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12.5px;line-height:1.6}.log-row{display:flex;gap:9px}.log-time{color:var(--text-dim);flex:none;font-variant-numeric:tabular-nums}.log-msg{color:var(--text);white-space:pre-wrap;word-break:break-word}.log-empty{color:var(--text-dim);font-style:italic;padding-top:4px}.log-tokens .log-msg{color:var(--accent)}.log-face .log-msg{color:#0f9c55}.log-memory .log-msg{color:#6d4fd6}.dock .camera-preview{height:100%;width:auto}.camera-preview{position:relative;width:260px;aspect-ratio:4 / 3;border-radius:14px;overflow:hidden;background:#0b1020;box-shadow:var(--shadow-md);border:1px solid var(--border)}.camera-preview-video,.camera-preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.camera-preview-overlay{pointer-events:none}.camera-preview-tag{position:absolute;left:8px;bottom:8px;padding:3px 8px;font-size:12px;font-weight:600;color:#fff;background:#0000008c;border-radius:999px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#141e3759;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.modal{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px;width:100%;max-width:460px;max-height:88vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-lg)}.modal-wide{max-width:680px}.modal h2{margin:0 0 4px;font-size:19px;letter-spacing:-.2px}.modal label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--text-dim)}.modal label.row{flex-direction:row;align-items:center;gap:8px}.modal input,.modal select,.modal textarea{background:var(--panel);color:var(--text);border:1px solid var(--border-strong);border-radius:9px;padding:9px 11px;font-size:14px;font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease}.modal input:focus,.modal select:focus,.modal textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.modal textarea{resize:vertical}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.modal-head{display:flex;align-items:center;justify-content:space-between}.modal-head h2{margin:0}.btn-primary{background:linear-gradient(180deg,var(--accent) 0%,var(--accent-strong) 100%);color:#fff;border:none;box-shadow:0 4px 12px #4f7cff47}.btn-primary:hover{background:linear-gradient(180deg,var(--accent-strong) 0%,#2f52cf 100%);box-shadow:0 6px 16px #4f7cff5c}.tabs{display:flex;gap:4px;padding:4px;background:var(--panel-2);border:1px solid var(--border);border-radius:12px}.tab{flex:1;padding:8px 12px;border:none;background:transparent;color:var(--text-dim);font-size:14px;font-weight:600;border-radius:9px;cursor:pointer;transition:background .15s ease,color .15s ease}.tab:hover{color:var(--text)}.tab-active{background:var(--panel);color:var(--accent-strong);box-shadow:var(--shadow-sm)}.agent-admin-list{display:flex;flex-direction:column;gap:8px}.agent-admin-row{display:flex;align-items:center;gap:10px;background:var(--panel-2);border:1px solid var(--border);border-radius:11px;padding:10px 12px}.agent-admin-name{font-weight:600;white-space:nowrap}.agent-admin-desc{color:var(--text-dim);font-size:13px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agent-form{display:flex;flex-direction:column;gap:10px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.voice-badge{font-size:12px;font-weight:600;color:var(--accent-strong);background:var(--accent-soft);border-radius:999px;padding:3px 9px;white-space:nowrap}.voice-picker{display:flex;flex-direction:column;gap:9px;padding:12px;background:var(--panel-2);border:1px solid var(--border);border-radius:12px}.voice-picker-label{font-size:13px;color:var(--text-dim);font-weight:600}.segmented{display:flex;gap:4px;padding:4px;background:var(--panel);border:1px solid var(--border-strong);border-radius:10px}.seg{flex:1;padding:8px 12px;border:none;background:transparent;color:var(--text-dim);font-size:14px;font-weight:600;border-radius:7px;cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease}.seg:hover{color:var(--text)}.seg-active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #4f7cff4d}.keys-form{display:flex;flex-direction:column;gap:11px}.keys-section{margin:6px 0 0;font-size:14px;font-weight:700;color:var(--text);padding-bottom:4px;border-bottom:1px solid var(--border)}.key-row{display:flex;gap:8px;align-items:stretch}.key-row input{flex:1}.key-row .btn{white-space:nowrap}.saved-hint{color:var(--green);font-size:13px;font-weight:600;align-self:center;margin-right:auto}.badge{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;border-radius:999px;padding:2px 8px;margin-left:6px;vertical-align:middle}.badge-ok{background:#e3f7ec;color:#0f8a4c}.badge-env{background:var(--accent-soft);color:var(--accent-strong)}.badge-none{background:#f1f1f4;color:#8a8f9c}.muted-note{color:var(--text-dim);font-size:13px;margin:0;line-height:1.5}.empty-list{color:var(--text-dim);font-size:14px;text-align:center;padding:18px}.inline-note{font-size:12.5px;line-height:1.5;border-radius:9px;padding:8px 11px;font-weight:500}.inline-note-warn{background:#fffaeb;color:#b25e09;border:1px solid #fce8b6}.inline-note-info{background:var(--accent-soft);color:var(--accent-strong);border:1px solid #d3e0ff}.mono{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12px;background:#141e370f;padding:1px 5px;border-radius:5px}@media (max-width: 600px){.topbar{flex-wrap:wrap}.agent-select{min-width:0;flex:1}.form-grid{grid-template-columns:1fr}.msg{max-width:94%}}
