*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f0e;--surface:#1a1a18;--surface2:#242421;--surface3:#2e2e2a;--border:#3a3a35;--border2:#4a4a44;--accent:#d4a843;--accent2:#e8c068;--accent-dim:#8a6c28;--text:#f0ede4;--text2:#a8a49a;--text3:#6a6660;--green:#4caf7d;--green-bg:#0d2619;--red:#e05c5c;--red-bg:#280d0d;--blue:#5b9bd5;--blue-bg:#0d1a28;--radius:12px;--radius-lg:18px;--transition:0.2s ease}body,html{height:100%;overflow:hidden}body{font-family:Outfit,sans-serif;background:var(--bg);color:var(--text);display:flex;flex-direction:column;font-size:15px}.header{justify-content:space-between;flex-wrap:wrap;gap:8px;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;position:relative}.header,.logo{display:flex;align-items:center}.logo{gap:10px}.logo-icon{width:34px;height:34px;background:var(--accent);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#0f0f0e}.logo-icon,.logo-text{font-family:"DM Serif Display",serif;font-size:20px}.logo-text{letter-spacing:-.3px;color:var(--text)}.logo-text span{color:var(--accent)}.header-right{display:flex;align-items:center;gap:10px}.level-group,.provider-group{display:flex;gap:4px}.level-btn{padding:5px 11px;font-family:DM Mono,monospace;font-size:11px;font-weight:500;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text3);cursor:pointer;transition:var(--transition);letter-spacing:.5px}.level-btn:hover{border-color:var(--border2);color:var(--text2)}.level-btn.active{background:var(--accent);border-color:var(--accent);color:#0f0f0e;font-weight:600}.level-btn.key-set{border-color:var(--green);color:var(--green)}.level-btn.key-missing{border-color:var(--accent-dim);color:var(--accent2);border-style:dashed}.support-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:8px;font-size:12px;font-weight:500;color:var(--text2);border:1px solid var(--border);background:transparent;text-decoration:none;transition:var(--transition);white-space:nowrap;letter-spacing:.2px}.support-btn:hover{color:var(--accent2);border-color:var(--accent-dim);background:rgba(212,168,67,.06)}.modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px}.modal{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:32px 28px;display:flex;flex-direction:column;gap:18px;width:100%;max-width:420px;box-shadow:0 24px 64px rgba(0,0,0,.6)}.modal-title{font-family:"DM Serif Display",serif;font-size:20px;color:var(--accent);letter-spacing:-.3px}.modal-desc{font-size:13px;color:var(--text2);line-height:1.6}.modal-key-input{width:100%;background:var(--surface3);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-family:DM Mono,monospace;font-size:13px;outline:none;transition:border-color var(--transition)}.modal-key-input:focus{border-color:var(--accent-dim)}.modal-key-input::placeholder{color:var(--text3)}.modal-actions{display:flex;gap:8px;flex-wrap:wrap}.modal-btn{padding:9px 18px;font-family:DM Mono,monospace;font-size:12px;font-weight:500;border:1px solid var(--border);border-radius:8px;background:var(--surface3);color:var(--text2);cursor:pointer;transition:var(--transition)}.modal-btn:hover{border-color:var(--border2);color:var(--text)}.modal-btn:disabled{opacity:.4;cursor:not-allowed}.modal-btn.primary{background:var(--accent);border-color:var(--accent);color:#0f0f0e;font-weight:600}.modal-btn.primary:hover:not(:disabled){background:var(--accent2);border-color:var(--accent2)}.modal-btn.danger{border-color:#3a1515;color:var(--red)}.modal-btn.danger:hover{background:var(--red-bg)}.modal-link{font-size:12px;color:var(--text3);font-family:DM Mono,monospace;text-decoration:underline;text-underline-offset:3px;align-self:flex-start}.modal-link:hover{color:var(--accent2)}.info-strip{display:flex;align-items:center;justify-content:space-between;padding:6px 24px;background:var(--blue-bg);border-bottom:1px solid #1a2d42;flex-shrink:0;font-size:11px;color:var(--blue);font-family:DM Mono,monospace;gap:12px}.chat-wrap{overflow:hidden}.chat-area,.chat-wrap{flex:1 1;display:flex;flex-direction:column;min-height:0}.chat-area{overflow-y:auto;padding:24px;gap:14px;scroll-behavior:smooth}.chat-area::-webkit-scrollbar{width:4px}.chat-area::-webkit-scrollbar-track{background:transparent}.chat-area::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.welcome{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:18px;padding:40px 20px;animation:fadeUp .7s ease forwards}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.welcome-flag{font-size:36px}.welcome-de{font-family:"DM Serif Display",serif;font-size:48px;color:var(--accent);line-height:1;letter-spacing:-1.5px}.welcome-tagline{font-size:15px;color:var(--text2);max-width:420px;line-height:1.65}.welcome-tagline strong{color:var(--text);font-weight:500}.starter-section{margin-top:4px;width:100%;max-width:500px}.starter-label{font-size:11px;color:var(--text3);font-family:DM Mono,monospace;letter-spacing:.8px;text-transform:uppercase;margin-bottom:10px}.starter-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.chip{padding:7px 15px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;font-size:13px;color:var(--text2);cursor:pointer;transition:var(--transition)}.chip:hover{border-color:var(--accent-dim);color:var(--accent2);background:var(--surface3)}.msg{display:flex;flex-direction:column;gap:5px;animation:fadeUp .3s ease forwards;opacity:0}.msg-user{align-items:flex-end}.msg-ai{align-items:flex-start}.msg-role{font-family:DM Mono,monospace;font-size:10px;font-weight:500;letter-spacing:1px;text-transform:uppercase;padding:0 4px}.msg-user .msg-role{color:var(--accent-dim)}.msg-ai .msg-role{color:var(--text3)}.bubble{max-width:75%;padding:11px 16px;border-radius:var(--radius-lg);line-height:1.7;font-size:14.5px}.msg-user .bubble{background:var(--accent);color:#0f0f0e;border-bottom-right-radius:4px;font-weight:500}.msg-ai .bubble{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px;transition:border-color .4s,box-shadow .4s}.msg-ai.speaking .bubble{border-color:var(--accent-dim);box-shadow:0 0 0 3px rgba(212,168,67,.12)}.correction{max-width:75%;padding:11px 15px;background:var(--red-bg);border:1px solid #3a1515;border-left:3px solid var(--red);border-radius:var(--radius);font-size:13.5px}.correction-label{font-family:DM Mono,monospace;font-size:10px;font-weight:500;letter-spacing:1px;color:var(--red);margin-bottom:6px;text-transform:uppercase}.correction-wrong{color:#cc8888;text-decoration:line-through;font-style:italic}.correction-arrow{color:var(--text3);margin:0 6px}.correction-right{color:#f0a0a0;font-weight:600}.correction-note{color:var(--text2);margin-top:6px;font-style:italic;font-size:12.5px;padding-top:6px;border-top:1px solid #3a1515}.feedback-good{max-width:75%;padding:8px 13px;background:var(--green-bg);border:1px solid #1a3a28;border-left:3px solid var(--green);border-radius:var(--radius);font-size:12px;color:#88cc99}.feedback-good,.sys-note{font-family:DM Mono,monospace}.sys-note{text-align:center;font-size:11px;color:var(--text3);padding:4px 0}.voice-panel{gap:14px;padding:9px 24px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.voice-left,.voice-panel{display:flex;align-items:center}.voice-left{gap:10px;flex:1 1;min-width:0}.state-badge{display:flex;align-items:center;gap:6px;padding:4px 11px;border-radius:20px;font-family:DM Mono,monospace;font-size:11px;font-weight:500;letter-spacing:.3px;border:1px solid var(--border);background:var(--surface2);color:var(--text3);white-space:nowrap;flex-shrink:0;transition:background .3s,border-color .3s,color .3s}.state-dot{width:7px;height:7px;border-radius:50%;background:var(--text3);flex-shrink:0;transition:background .3s}.state-badge.listening{border-color:#4a2020;background:var(--red-bg);color:var(--red)}.state-badge.listening .state-dot{background:var(--red);animation:pulse-dot 1s ease-in-out infinite}.state-badge.thinking{border-color:#1e3550;background:var(--blue-bg);color:var(--blue)}.state-badge.thinking .state-dot{background:var(--blue);animation:blink 1.2s infinite}.state-badge.speaking{border-color:#1e3a2a;background:var(--green-bg);color:var(--green)}.state-badge.speaking .state-dot{background:var(--green);animation:pulse-dot .8s ease-in-out infinite}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.6}}@keyframes blink{0%,80%,to{opacity:.2}40%{opacity:1}}#vizCanvas{height:26px;width:160px;border-radius:5px;flex-shrink:0}.interim-text{font-size:12.5px;color:var(--text2);font-style:italic;flex:1 1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.voice-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.voice-select{background:var(--surface2);padding:5px 8px;color:var(--text2);outline:none;max-width:150px}.icon-btn,.voice-select{border:1px solid var(--border);border-radius:6px;font-family:DM Mono,monospace;font-size:11px;cursor:pointer}.icon-btn{padding:5px 11px;font-weight:500;background:transparent;color:var(--text3);transition:var(--transition);white-space:nowrap}.icon-btn.active{background:var(--green-bg);border-color:var(--green);color:var(--green)}.icon-btn.muted{background:var(--surface3);border-color:var(--border2);color:var(--text3)}.input-area{padding:12px 24px 14px;background:var(--surface);flex-shrink:0}.input-row{display:flex;gap:10px;align-items:flex-end}.msg-input{flex:1 1;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:11px 15px;color:var(--text);font-family:Outfit,sans-serif;font-size:14px;resize:none;outline:none;min-height:46px;max-height:130px;line-height:1.5;transition:border-color var(--transition)}.msg-input:focus{border-color:var(--accent-dim)}.msg-input::placeholder{color:var(--text3)}.mic-btn{width:46px;height:46px;background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0}.mic-btn svg{width:19px;height:19px;fill:var(--text2)}.mic-btn:hover{border-color:var(--border2)}.mic-btn.recording{background:var(--red);border-color:var(--red);animation:mic-pulse 1s ease-in-out infinite}.mic-btn.recording svg{fill:#fff}.mic-btn.no-support{opacity:.3;cursor:not-allowed}@keyframes mic-pulse{0%,to{box-shadow:0 0 0 0 rgba(224,92,92,.5)}50%{box-shadow:0 0 0 10px rgba(224,92,92,0)}}.send-btn{width:46px;height:46px;background:var(--accent);border:none;border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0}.send-btn:hover{background:var(--accent2)}.send-btn:disabled{background:var(--surface3);cursor:not-allowed}.send-btn svg{width:19px;height:19px;fill:#0f0f0e}.send-btn:disabled svg{fill:var(--text3)}.input-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:11px;color:var(--text3);font-family:DM Mono,monospace}.stats{display:flex;gap:16px}.stat{display:flex;align-items:center;gap:5px}.stat-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.footer-actions{display:flex;gap:12px}.text-btn{background:none;border:none;cursor:pointer;color:var(--text3);font-size:11px;font-family:DM Mono,monospace;text-decoration:underline;text-underline-offset:2px}.text-btn:hover{color:var(--text2)}@media (max-width:940px){.header{flex-direction:column;align-items:flex-start;gap:10px}.header-right{width:100%;flex-wrap:wrap}.provider-group{order:1}.level-group{order:2}}