:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#0f172a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}button{font-family:inherit}.app{width:100%;min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#0f172a,#1e293b)}.header{background:#1e293bcc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(148,163,184,.1);padding:1rem 2rem;position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.title{font-size:1.5rem;font-weight:600;color:#e2e8f0;display:flex;align-items:center;gap:.75rem}.settings-btn{background:#6366f11a;border:1px solid rgba(99,102,241,.3);color:#818cf8;padding:.5rem;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.settings-btn:hover{background:#6366f133;border-color:#6366f180}.settings-panel{background:#1e293bf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(148,163,184,.1);padding:2rem}.settings-content{max-width:800px;margin:0 auto}.settings-content h2{color:#e2e8f0;margin-bottom:1.5rem;font-size:1.25rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;color:#cbd5e1;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{width:100%;background:#0f172a99;border:1px solid rgba(148,163,184,.2);color:#e2e8f0;padding:.75rem;border-radius:8px;font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6366f180;background:#0f172acc}.form-group textarea{resize:vertical;font-family:inherit}.main{flex:1;display:flex;flex-direction:column;max-width:1200px;margin:0 auto;width:100%;padding:2rem}.status-bar{margin-bottom:1rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.status-indicator{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;text-transform:capitalize}.speaking-indicator{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;background:#8b5cf61a;color:#c4b5fd;border:1px solid rgba(139,92,246,.3)}.status-indicator.disconnected{background:#ef44441a;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.status-indicator.connecting{background:#fbbf241a;color:#fcd34d;border:1px solid rgba(251,191,36,.3)}.status-indicator.connected{background:#22c55e1a;color:#86efac;border:1px solid rgba(34,197,94,.3)}.status-indicator.error{background:#ef44441a;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.spin{animation:spin 1s linear infinite}.pulse{animation:pulse-icon 1.5s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-icon{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.1)}}.messages-container{flex:1;background:#1e293b66;border-radius:16px;padding:2rem;margin-bottom:2rem;overflow-y:auto;min-height:400px;border:1px solid rgba(148,163,184,.1)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:#64748b}.messages{display:flex;flex-direction:column;gap:1rem}.message{padding:1rem;border-radius:12px;max-width:80%;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{background:#6366f133;border:1px solid rgba(99,102,241,.3);align-self:flex-end}.message.assistant{background:#22c55e33;border:1px solid rgba(34,197,94,.3);align-self:flex-start}.message.system{background:#fbbf2433;border:1px solid rgba(251,191,36,.3);align-self:center;text-align:center;max-width:90%}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.75rem;opacity:.7}.message-role{text-transform:capitalize;font-weight:600}.message-time{font-size:.7rem}.message-content{color:#e2e8f0;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.controls{display:flex;flex-direction:column;align-items:center;gap:1rem}.mic-button{width:80px;height:80px;border-radius:50%;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 20px #6366f166}.mic-button:hover{transform:scale(1.05);box-shadow:0 6px 30px #6366f199}.mic-button:active{transform:scale(.95)}.mic-button.recording{background:linear-gradient(135deg,#ef4444,#dc2626);animation:pulse 2s ease-in-out infinite;box-shadow:0 4px 20px #ef444466}@keyframes pulse{0%,to{box-shadow:0 4px 20px #ef444466}50%{box-shadow:0 4px 40px #ef4444cc}}.mic-hint{color:#94a3b8;font-size:.875rem}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#0f172a66;border-radius:4px}.messages-container::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:#6366f180}
