:root{--primary-bg: #1a1a2e;--secondary-bg: #16213e;--accent: #0f3460;--text: #eaeaea;--text-muted: #a0a0a0;--recording: #ff4757;--playing: #2ed573;--idle: #747d8c;--border: #2a2a4a;--success: #2ed573;--warning: #ffa502}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--primary-bg);color:var(--text);height:100vh;max-height:100vh;overflow:hidden}html.is-overlay,html.is-overlay body{background:transparent!important}.app{display:flex;flex-direction:column;height:100vh;max-height:100vh;overflow:hidden}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--secondary-bg);border-bottom:1px solid var(--border)}.header h1{font-size:1.5rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.status-badge:before{content:"";width:8px;height:8px;border-radius:50%}.status-badge.idle{background:#747d8c33;color:var(--idle)}.status-badge.idle:before{background:var(--idle)}.status-badge.recording{background:#ff475733;color:var(--recording)}.status-badge.recording:before{background:var(--recording);animation:pulse 1s infinite}.status-badge.playing{background:#2ed57333;color:var(--playing)}.status-badge.playing:before{background:var(--playing);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.main{display:grid;grid-template-columns:1fr;gap:1rem;padding:1rem;flex:1;overflow:hidden;min-height:0}.debug-main{padding:1rem}.debug-layout{height:100%;min-height:0;display:grid;grid-template-rows:auto 1fr;gap:1rem}.debug-top{min-height:0}.debug-bottom{min-height:0;overflow:auto}.debug-panels{display:flex;flex-direction:column;gap:1rem;min-height:0}.panel{background:var(--secondary-bg);border-radius:12px;padding:1rem;border:1px solid var(--border)}.panel.avatar-panel{flex:1;height:clamp(360px,55vh,760px);display:flex;flex-direction:column;overflow:hidden;position:relative;clip-path:inset(0)}.avatar-3d-wrapper{flex:1;min-height:0;position:relative;overflow:hidden;isolation:isolate;contain:paint}.avatar-3d-wrapper canvas{position:absolute!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100%!important;height:100%!important;z-index:0!important;pointer-events:none}.avatar-row{display:grid;grid-template-columns:1fr 360px;gap:1rem;align-items:stretch;min-height:0;overflow:hidden}.tts-panel--side{display:flex;flex-direction:column;height:clamp(360px,55vh,760px);overflow:hidden}.tts-panel--side .queue-list{flex:1;overflow-y:auto;padding-right:.5rem}@media (max-width: 1024px){.avatar-row{grid-template-columns:1fr}.tts-panel--side{min-height:260px}}.panel h2{font-size:1rem;margin-bottom:1rem;color:var(--text)}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:.5rem;flex-wrap:wrap;min-width:0}.panel-header h2{margin-bottom:0;flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.panel-header>:not(h2){flex:0 0 auto}.panel-header select,.panel-header button{max-width:100%}.toggle{flex:0 0 auto}.avatar-row>*{min-width:0}.log-panel{display:flex;flex-direction:column;overflow:hidden}.log-list{flex:1;overflow-y:auto;padding-right:.5rem}.log-list::-webkit-scrollbar{width:6px}.log-list::-webkit-scrollbar-track{background:var(--primary-bg);border-radius:3px}.log-list::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}.log-entry{display:flex;gap:1rem;padding:.75rem;border-radius:8px;margin-bottom:.5rem;background:#ffffff08;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.log-time{color:var(--text-muted);font-size:.875rem;font-family:monospace;min-width:70px}.log-text{flex:1;line-height:1.5}.empty-state{display:flex;justify-content:center;align-items:center;height:200px;color:var(--text-muted);font-size:.875rem}.sidebar{display:flex;flex-direction:column;gap:1rem;overflow-y:auto;height:100%;min-height:0;min-width:0;width:100%}.hotkey-hint{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:var(--text-muted);font-size:.875rem}.hotkey-key{background:var(--accent);padding:.25rem .5rem;border-radius:4px;font-family:monospace;font-weight:600}.seconds-input{width:60px;padding:.25rem .5rem;border:1px solid var(--border);border-radius:4px;background:var(--primary-bg);color:var(--text);text-align:center}.queue-list{list-style:none}.queue-item{display:flex;gap:.5rem;padding:.5rem;border-radius:6px;margin-bottom:.5rem;background:#ffffff08}.queue-index{color:var(--text-muted);font-size:.75rem;min-width:20px}.queue-text{font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manual-panel textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--primary-bg);color:var(--text);font-family:inherit;resize:none;margin-bottom:.75rem}.manual-panel textarea:focus{outline:none;border-color:var(--accent)}.debug-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.debug-card{border:1px solid var(--border);border-radius:12px;padding:.75rem;background:#ffffff05}.debug-card-title{font-size:.85rem;font-weight:600;color:var(--text);margin-bottom:.5rem}.debug-actions{display:flex;gap:.5rem;align-items:center;margin-top:.5rem}.debug-muted{color:var(--text-muted);font-size:.75rem;opacity:.9}.debug-reply{margin-top:.5rem;padding:.6rem .75rem;border:1px solid rgba(46,213,115,.2);background:#2ed57314;border-radius:10px;font-size:.875rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}@media (max-width: 1024px){.debug-grid{grid-template-columns:1fr}}button{cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s ease}.btn-primary{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{width:100%;background:var(--accent);color:var(--text)}.btn-secondary:hover:not(:disabled){background:#1a4980}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-small{padding:.375rem .75rem;font-size:.75rem;background:transparent;border:1px solid var(--border);color:var(--text-muted)}.btn-small:hover{border-color:var(--text-muted);color:var(--text)}.btn-link{background:none;border:none;padding:0;color:#667eea;font-size:.7rem;text-decoration:underline;cursor:pointer}.btn-link:hover{color:#8fa0f7}.footer{padding:1rem 2rem;background:var(--secondary-bg);border-top:1px solid var(--border)}.control-panel{display:flex;justify-content:center;align-items:center;gap:2rem}.ai-monitor{width:min(980px,100%);display:grid;grid-template-columns:90px 1fr auto auto;gap:.75rem;align-items:center;padding:.75rem 1rem;border:1px solid var(--border);border-radius:12px;background:#ffffff05}.ai-monitor-label{color:var(--text-muted);font-size:.8rem;white-space:nowrap}.ai-monitor-text{color:var(--text);font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-monitor-count{color:var(--text-muted);font-size:.75rem;white-space:nowrap;opacity:.8}.phone-mode{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem;border:1px solid var(--border);border-radius:12px;background:#ffffff05}.toggle{display:flex;align-items:center;gap:.5rem;color:var(--text);font-size:.875rem;-webkit-user-select:none;user-select:none}.toggle input[type=checkbox]{width:16px;height:16px}.phone-mode-fields{display:grid;grid-template-columns:1fr 120px;gap:.75rem}.asr-debug{display:flex;flex-direction:column;gap:.35rem;padding:.5rem .75rem;border:1px dashed var(--border);border-radius:10px;background:#00000026}.asr-debug-row{display:grid;grid-template-columns:70px 1fr;gap:.5rem;align-items:start}.asr-debug-k{color:var(--text-muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.75rem}.asr-debug-v{color:var(--text);font-size:.8rem;line-height:1.35;word-break:break-word}.asr-debug-v.hit{color:var(--success)}.asr-debug-v.miss{color:var(--warning)}.mic-meter{display:inline-block;width:120px;height:8px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;overflow:hidden;vertical-align:middle;margin-right:8px}.mic-meter-bar{display:block;height:100%;background:linear-gradient(90deg,var(--warning),var(--success))}.mic-meter-num{color:var(--text-muted);font-size:.75rem;vertical-align:middle}.phone-mode .field{display:flex;flex-direction:column;gap:.25rem;color:var(--text-muted);font-size:.75rem}.phone-mode input[type=text],.phone-mode input[type=number]{padding:.5rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--primary-bg);color:var(--text);font-size:.875rem}.phone-mode input[type=text]:focus,.phone-mode input[type=number]:focus{outline:none;border-color:var(--accent)}.btn-record{padding:1rem 3rem;font-size:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:30px}.btn-record:hover{transform:translateY(-2px);box-shadow:0 4px 20px #667eea80}.btn-record.recording{background:linear-gradient(135deg,#ff4757,#ff6b81)}.volume-control{display:flex;align-items:center;gap:.75rem;color:var(--text-muted)}.volume-control input[type=range]{width:120px;accent-color:var(--accent)}.audio-panel{text-align:center}.audio-panel .btn-primary{padding:1rem 2rem;font-size:1rem}.audio-panel .btn-primary.playing{background:linear-gradient(135deg,#2ed573,#7bed9f)}@media (max-width: 1024px){.main{grid-template-columns:1fr}}@media (max-width: 768px){.main{grid-template-columns:1fr}.sidebar{order:-1;min-width:0}.header h1{font-size:1.25rem}}.ai-chat-panel{display:flex;flex-direction:column;overflow:hidden}.ai-config-form{display:flex;flex-direction:column;gap:.75rem}.ai-config-hint{color:var(--warning);font-size:.875rem;padding:.5rem;background:#ffa5021a;border-radius:8px;text-align:center}.ai-config-field{display:flex;flex-direction:column;gap:.25rem}.ai-config-field label{font-size:.75rem;color:var(--text-muted)}.ai-config-field input{padding:.5rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--primary-bg);color:var(--text);font-size:.875rem}.ai-config-field input:focus{outline:none;border-color:var(--accent)}.ai-config-note{font-size:.7rem;color:var(--text-muted);line-height:1.4;padding:.5rem;background:#ffffff08;border-radius:8px}.ai-config-actions{display:flex;gap:.5rem;align-items:center}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;padding-bottom:.5rem;min-height:0}.chat-message{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;border-radius:10px;animation:slideIn .2s ease}.chat-user{background:#667eea26;border:1px solid rgba(102,126,234,.3);align-self:flex-end;max-width:85%}.chat-assistant{background:#2ed5731a;border:1px solid rgba(46,213,115,.2);align-self:flex-start;max-width:85%}.chat-role{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.chat-user .chat-role{color:#667eea}.chat-assistant .chat-role{color:var(--success)}.chat-content{font-size:.875rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.chat-loading .chat-content{color:var(--text-muted);font-style:italic}.chat-error{padding:.5rem .75rem;border-radius:8px;background:#ff47571a;border:1px solid rgba(255,71,87,.3);color:var(--recording);font-size:.8rem;margin-bottom:.5rem}.chat-input-row{display:flex;gap:.5rem;align-items:center}.chat-input{flex:1;padding:.6rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--primary-bg);color:var(--text);font-size:.875rem}.chat-input:focus{outline:none;border-color:var(--accent)}.chat-input:disabled{opacity:.5}.chat-input-row .btn-primary{width:auto;padding:.6rem 1rem;flex-shrink:0}.chat-input-row .btn-mic{flex-shrink:0}.btn-mic.listening{background:linear-gradient(135deg,#ff4757,#ff6b81);box-shadow:0 4px 16px #ff475759}.chat-meta{margin-top:.5rem;font-size:.7rem;color:var(--text-muted);text-align:center;opacity:.6}.voice-page{display:flex;flex-direction:column;height:100vh;max-height:100vh;overflow:hidden;--voice-bg: #f6f7fb;--voice-surface: #ffffff;--voice-surface-2: #fbfbfe;--voice-border: rgba(31, 41, 55, .12);--voice-text: #1f2937;--voice-muted: #6b7280;--voice-accent: #6d5efc;background:var(--voice-bg)}.overlay-page{width:100vw;height:100vh;background:transparent;position:relative;overflow:hidden}.overlay-drag-region{position:absolute;top:0;right:0;bottom:0;left:0;-webkit-app-region:drag;z-index:1}.overlay-avatar{position:relative;width:100%;height:100%;z-index:2;-webkit-app-region:no-drag}.voice-body{display:flex;flex:1;overflow:hidden;min-height:0;position:relative}.voice-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--voice-surface);border-bottom:1px solid var(--voice-border)}.voice-header h1{font-size:1.5rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.voice-header-right{display:flex;align-items:center;gap:1rem}.admin-link{color:var(--voice-muted);font-size:.875rem;text-decoration:none;padding:.4rem .8rem;border:1px solid var(--voice-border);border-radius:8px;transition:all .2s;background:#ffffffb3}.admin-link:hover{color:var(--voice-text);border-color:#6d5efc59;background:#6d5efc14}.debug-link{color:var(--voice-muted);font-size:.875rem;text-decoration:none;padding:.4rem .8rem;border:1px solid var(--voice-border);border-radius:8px;transition:all .2s;background:#ffffffb3}.debug-link:hover{color:var(--voice-text);border-color:#1f293738}.voice-status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;background:#1f29370f;color:var(--voice-muted)}.voice-status-badge.ready{background:#667eea33;color:#667eea;animation:pulse 2s infinite}.voice-status-badge.awake{background:#2ed57333;color:var(--success);animation:pulse 1s infinite}.voice-status-badge.speaking{background:#ffa50233;color:var(--warning);animation:pulse 1s infinite}.voice-main{width:420px;flex-shrink:0;display:flex;flex-direction:column;background:var(--voice-surface);border-left:1px solid var(--voice-border);overflow:hidden;min-height:0}.voice-page.is-chat-collapsed .voice-main,.voice-page .avatar-vrma-select{display:none}.voice-chat-handle{position:absolute;right:0;top:50%;transform:translateY(-50%);width:26px;height:64px;border-radius:12px 0 0 12px;border:1px solid rgba(31,41,55,.14);border-right:none;background:#ffffffb8;color:#1f2937a6;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:80;opacity:0;pointer-events:none;transition:opacity .15s ease,background .15s ease;-webkit-user-select:none;user-select:none}.voice-chat-handle-hotzone{position:absolute;right:0;top:0;height:100%;width:22px;z-index:79}.voice-chat-handle-hotzone:hover+.voice-chat-handle,.voice-chat-handle:hover{opacity:1;pointer-events:auto;background:#ffffffe0}.voice-avatar-section{flex:1;display:flex;flex-direction:column;align-items:stretch;justify-content:stretch;padding:0;background:#fff;position:relative;overflow:hidden;min-height:0;min-width:0}.voice-avatar-container{flex:1;width:100%;min-height:0;min-height:-webkit-min-content;border-radius:0;overflow:hidden;box-shadow:none;border:none;display:flex;flex-direction:column}.avatar-topbar{position:absolute;top:8px;right:8px;z-index:30;display:flex;align-items:center;gap:8px;max-width:min(96%,560px)}.avatar-vrma-select{max-width:min(52%,220px);padding:6px 8px;font-size:.8125rem;line-height:1.3;border-radius:8px;border:1px solid rgba(100,80,160,.35);background:#ffffffeb;color:#2d2640;box-shadow:0 1px 6px #00000014;cursor:pointer}.voice-avatar-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted);background:var(--secondary-bg)}.avatar-icon{font-size:4rem}.voice-control-bar{display:flex;justify-content:center;width:100%;padding:1rem 0;position:absolute;bottom:0;left:0;z-index:10}.voice-mic-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.95rem 2.25rem;min-height:56px;min-width:156px;font-size:1.1rem;font-weight:600;border-radius:50px;background:linear-gradient(135deg,#667eea,#6d5efc 45%,#764ba2);background-size:140% 140%;color:#fff;border:none;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;box-shadow:0 10px 26px #6d5efc47,0 2px 8px #1f29372e;position:relative;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.voice-mic-btn:hover{transform:translateY(-1px);filter:brightness(1.02) saturate(1.05);box-shadow:0 12px 30px #6d5efc52,0 4px 12px #1f293733}.voice-mic-btn:active{transform:translateY(0) scale(.99);filter:brightness(.99)}.voice-mic-btn:focus-visible{outline:none;box-shadow:0 0 0 4px #6d5efc2e,0 12px 30px #6d5efc52,0 4px 12px #1f293733}.voice-mic-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,#ffffff47,#ffffff0f);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.voice-mic-btn.listening{background:linear-gradient(135deg,#ff4757,#ff6b81);box-shadow:0 4px 20px #ff475766;animation:pulse 1.5s infinite}.voice-mic-btn.listening.speaking{background:linear-gradient(135deg,#ffa502,#ffbe76);box-shadow:0 10px 26px #ffa5023d,0 2px 8px #1f29372e;animation:pulse 1.8s infinite}.voice-mic-btn.armed{background:linear-gradient(135deg,#667eea,#764ba2);animation:pulse 2s infinite}.voice-mic-btn.awake{background:linear-gradient(135deg,#2ed573,#7bed9f);box-shadow:0 4px 20px #2ed57366}.voice-mic-btn.speaking{background:linear-gradient(135deg,#ffa502,#ffbe76);box-shadow:0 10px 26px #ffa5023d,0 2px 8px #1f29372e}.voice-mic-btn.ready{background:linear-gradient(135deg,#667eea,#764ba2)}.voice-page canvas,.overlay-page canvas{max-height:100vh;max-width:100vw}.mic-icon{font-size:1.5rem}@media (prefers-reduced-motion: reduce){.voice-mic-btn,.voice-mic-btn:hover,.voice-mic-btn:active{transition:none!important}.voice-mic-btn.listening,.voice-status-badge.ready,.voice-status-badge.awake,.voice-status-badge.speaking{animation:none!important}}.voice-transcript{text-align:center;color:var(--voice-muted);font-size:.9rem;max-width:400px;min-height:24px;padding:.5rem 1rem;background:#ffffffb8;border-radius:8px;border:1px solid var(--voice-border);position:absolute;top:1rem;left:50%;transform:translate(-50%);z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.voice-ai-hint{padding:.75rem 1.5rem;background:#ffa5021a;border:1px solid rgba(255,165,2,.3);border-radius:12px;color:var(--warning);font-size:.875rem;cursor:pointer;text-align:center;position:absolute;bottom:5rem;left:50%;transform:translate(-50%);z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.voice-ai-hint:hover{background:#ffa50226}.voice-chat-section{display:flex;flex-direction:column;height:100%;overflow:hidden;min-height:0}.voice-chat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--voice-border);background:var(--voice-surface-2)}.voice-chat-header h2{font-size:1rem;margin:0;color:var(--voice-text)}.voice-chat-messages{flex:1;overflow-y:auto;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.voice-chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:.5rem;color:var(--voice-muted)}.empty-hint{font-size:1.1rem;font-weight:500}.empty-sub{font-size:.875rem;opacity:.7}.voice-msg{display:flex;flex-direction:column;gap:.25rem;animation:slideIn .2s ease}.voice-msg-user{align-items:flex-end}.voice-msg-assistant{align-items:flex-start}.voice-msg-role{font-size:.7rem;font-weight:600;color:var(--voice-muted);text-transform:uppercase;letter-spacing:.5px;padding:0 .25rem}.voice-msg-user .voice-msg-role{color:#667eea}.voice-msg-assistant .voice-msg-role{color:var(--success)}.voice-msg-bubble{max-width:80%;padding:.75rem 1rem;border-radius:16px;font-size:.9rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.voice-msg-user .voice-msg-bubble{background:linear-gradient(135deg,#667eea33,#764ba233);border:1px solid rgba(102,126,234,.3);border-bottom-right-radius:4px;color:var(--voice-text)}.voice-msg-assistant .voice-msg-bubble{background:#1f29370a;border:1px solid var(--voice-border);border-bottom-left-radius:4px;color:var(--voice-text)}.voice-msg-bubble.loading{color:var(--voice-muted);font-style:italic}.voice-chat-error{padding:.5rem .75rem;border-radius:8px;background:#ff47571a;border:1px solid rgba(255,71,87,.3);color:var(--recording);font-size:.8rem}.voice-ai-config{padding:1rem 1.5rem;border-top:1px solid var(--voice-border);display:flex;flex-direction:column;gap:.75rem;background:var(--voice-surface)}.voice-ai-config-field{display:flex;flex-direction:column;gap:.25rem}.voice-ai-config-field label{font-size:.75rem;color:var(--voice-muted)}.voice-ai-config-field input{padding:.6rem .75rem;border:1px solid var(--voice-border);border-radius:8px;background:#fff;color:var(--voice-text);font-size:.875rem}.voice-ai-config-field input:focus{outline:none;border-color:#6d5efc8c;box-shadow:0 0 0 3px #6d5efc1f}.voice-ai-config-note{font-size:.7rem;color:var(--voice-muted);line-height:1.4;padding:.5rem;background:#1f29370a;border-radius:8px}.voice-ai-config-actions{display:flex;gap:.5rem;align-items:center}.voice-chat-footer{padding:.5rem 1.5rem;border-top:1px solid var(--voice-border);background:var(--voice-surface-2)}.voice-footer-meta{font-size:.7rem;color:var(--voice-muted);opacity:.6;display:flex;align-items:center;gap:.5rem}.voice-volume{display:flex;justify-content:center;align-items:center;gap:.75rem;padding:.75rem 2rem;background:var(--voice-surface);border-top:1px solid var(--voice-border);color:var(--voice-muted)}.voice-volume input[type=range]{width:120px;accent-color:var(--voice-accent)}@media (max-width: 900px){.voice-main{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.voice-avatar-section{padding:1rem}.voice-chat-section{border-left:none;border-top:1px solid var(--voice-border)}}@media (max-width: 480px){.voice-header{padding:.75rem 1rem}.voice-header h1{font-size:1.1rem}.voice-avatar-section{padding:1rem;gap:1rem}.voice-mic-btn{padding:.75rem 1.5rem;font-size:.9rem}}.admin-login-page{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e)}.admin-login-box{background:var(--secondary-bg);padding:2.5rem;border-radius:16px;border:1px solid var(--border);width:360px;box-shadow:0 8px 32px #0000004d}.admin-login-box h1{text-align:center;font-size:1.5rem;margin-bottom:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-login-box .form-group{margin-bottom:1rem}.admin-login-box label{display:block;font-size:.875rem;color:var(--text-muted);margin-bottom:.5rem}.admin-login-box input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--primary-bg);color:var(--text);font-size:1rem}.admin-login-box input:focus{outline:none;border-color:#667eea}.admin-login-box .form-error{color:var(--recording);font-size:.875rem;margin-bottom:1rem;padding:.5rem;background:#ff47571a;border-radius:8px;text-align:center}.admin-login-box .login-hint{margin-top:1rem;text-align:center;font-size:.75rem;color:var(--text-muted);opacity:.7}.admin-back-link{margin-top:1rem;text-align:center}.admin-back-link a{color:var(--text-muted);text-decoration:none;font-size:.875rem}.admin-back-link a:hover{color:var(--text)}.admin-page{min-height:100vh;background:var(--primary-bg)}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--secondary-bg);border-bottom:1px solid var(--border)}.admin-header-left{display:flex;align-items:center;gap:1rem}.admin-header h1{font-size:1.25rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.admin-user{font-size:.875rem;color:var(--text-muted)}.admin-header-right{display:flex;align-items:center;gap:1rem}.admin-main{padding:1.5rem 2rem;max-width:1400px;margin:0 auto}.admin-section{background:var(--secondary-bg);border-radius:12px;border:1px solid var(--border);padding:1.5rem;margin-bottom:1.5rem}.admin-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.admin-settings-actions{margin-top:1rem;display:flex;justify-content:flex-end}.admin-settings-actions .btn-primary{width:auto;min-width:160px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{font-size:1.1rem;font-weight:600;color:var(--text);margin:0}.knowledge-filters{display:flex;gap:1rem;margin-bottom:1rem}.search-input{flex:1;padding:.6rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--primary-bg);color:var(--text);font-size:.875rem}.search-input:focus{outline:none;border-color:#667eea}.category-select{padding:.6rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--primary-bg);color:var(--text);font-size:.875rem;min-width:150px}.category-select:focus{outline:none;border-color:#667eea}.knowledge-list{overflow-x:auto}.knowledge-table{width:100%;border-collapse:collapse}.knowledge-table th,.knowledge-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}.knowledge-table th{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;background:#ffffff08}.knowledge-table td{font-size:.875rem;color:var(--text)}.priority-cell{text-align:center;font-weight:600;color:#667eea}.question-cell{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.answer-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted)}.category-cell{white-space:nowrap}.hit-cell{text-align:center;color:var(--text-muted)}.action-cell{white-space:nowrap}.btn-danger{color:var(--recording)!important}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem}.page-info{font-size:.875rem;color:var(--text-muted)}.test-search{display:flex;gap:.75rem;margin-bottom:1rem}.test-search .search-input{flex:1}.test-results{margin-top:1rem}.test-results h3{font-size:.875rem;color:var(--text-muted);margin-bottom:.75rem}.test-result-item{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:.75rem}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.result-index{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.result-similarity{font-size:.75rem;color:var(--text-muted)}.result-body{display:flex;flex-direction:column;gap:.5rem}.result-question{font-size:.875rem;color:var(--text)}.result-answer{font-size:.875rem;color:var(--success);padding:.5rem;background:#2ed5731a;border-radius:6px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--secondary-bg);border-radius:16px;padding:2rem;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;border:1px solid var(--border);box-shadow:0 16px 48px #0006}.modal-content h2{font-size:1.25rem;margin-bottom:1.5rem;color:var(--text)}.modal-content .form-group{margin-bottom:1rem}.modal-content label{display:block;font-size:.875rem;color:var(--text-muted);margin-bottom:.5rem}.modal-content textarea,.modal-content input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--primary-bg);color:var(--text);font-size:.875rem;font-family:inherit}.modal-content textarea{resize:vertical;min-height:80px}.modal-content textarea:focus,.modal-content input:focus{outline:none;border-color:#667eea}.form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media (max-width: 600px){.form-row,.admin-settings-grid{grid-template-columns:1fr}}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.modal-actions .btn-primary,.modal-actions .btn-secondary{width:auto;padding:.6rem 1.5rem}
