*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#d6f3ff;color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}#root,body{min-height:100vh}.chat-input-form{border-top:1px solid #1e40af33;padding:1rem 0}.chat-input{background:#fff;border:1px solid #94a3b8;border-radius:.5rem;color:#1e293b;font-size:.95rem;line-height:1.5;margin-bottom:.75rem;min-height:100px;outline:none;padding:1rem 1.25rem;resize:vertical;transition:border-color .2s;width:100%}.input-actions{align-items:center;display:flex;gap:1rem}.chat-input::placeholder{color:#94a3b8}.chat-input:focus{border-color:#2563eb}.chat-input:disabled{cursor:not-allowed;opacity:.6}.send-btn{background:#2563eb;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.25rem;transition:background .2s}.send-btn:hover:not(:disabled){background:#1d4ed8}.send-btn:disabled{cursor:not-allowed;opacity:.5}.mic-btn{background:#fff;border:1px solid #94a3b8;border-radius:.5rem;cursor:pointer;font-size:1.25rem;padding:.75rem;transition:all .2s}.mic-btn:hover:not(:disabled){background:#eff6ff;border-color:#2563eb}.mic-btn.listening{animation:pulse 1.5s ease-in-out infinite;background:#fef2f2;border-color:#dc2626}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.mic-btn:disabled{cursor:not-allowed;opacity:.5}.speech-error{color:#dc2626;display:block;font-size:.8rem;margin-top:.25rem}.audio-player{gap:.5rem;margin-top:.5rem}.audio-player,.play-btn{align-items:center;display:flex}.play-btn{background:#2563eb;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:.85rem;height:36px;justify-content:center;transition:background .2s;width:36px}.play-btn:hover:not(:disabled){background:#1d4ed8}.play-btn:disabled{cursor:not-allowed;opacity:.7}.icon-pause,.icon-play{margin-left:2px}.icon-error{font-size:1rem;font-weight:700}.spinner{animation:spin .8s linear infinite;border:2px solid #fff6;border-radius:50%;border-top-color:#fff;height:14px;width:14px}@keyframes spin{to{transform:rotate(1turn)}}.audio-label{color:#64748b;font-size:.8rem}.message{display:flex;margin-bottom:1rem}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.bubble{border-radius:1rem;line-height:1.6;max-width:92%;padding:1.1rem 1.4rem}.message.user .bubble{background:#2563eb;color:#fff}.message.assistant .bubble{background:#fff;border:1px solid #e2e8f0;box-shadow:0 1px 3px #1e40af14}.message.assistant.error .bubble{background:#fef2f2;border-color:#fecaca}.message-idioms-explanation{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.message-idioms-label{color:#b45309;display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.35rem;text-transform:uppercase}.message-idioms-text{color:#92400e;font-size:.9rem;line-height:1.5;margin:0}.text{font-size:1.05rem;line-height:1.65;margin:0 0 .75rem;white-space:pre-wrap;word-break:break-word}.message.user .text{color:#fff;margin-bottom:0}.message.assistant .text{color:#1e293b}.error-text{color:#dc2626;font-size:.9rem}@media (max-width:640px){.bubble{max-width:96%;padding:1rem 1.2rem}.text{font-size:1rem}}.global-settings{background:linear-gradient(135deg,#b6d6e3,#9ec9da 50%,#86bcd1);border:1px solid #7ab8d0;border-radius:.5rem;margin-bottom:.5rem;padding:.75rem 1rem}.global-settings-toggle{background:#e3f4ff;border:1px solid #bae6fd;border-radius:.5rem;color:#0369a1;cursor:pointer;font-size:.9rem;padding:.4rem .75rem}.global-settings-toggle:hover{background:#bae6fd;border-color:#7dd3fc}.global-settings-content{margin-top:.75rem;padding:.75rem 0}.global-settings-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.5rem}.global-settings-row:last-child{margin-bottom:0}.global-settings-row .setting-row{align-items:center;display:flex;gap:.5rem}.global-settings-row .setting-row label{color:#0c4a6e;font-size:.85rem}.global-settings-row .setting-select{background:#fff;border:1px solid #7ab8d0;border-radius:.5rem;color:#1e293b;font-size:.9rem;min-width:120px;padding:.4rem .75rem}.global-settings-cleanup{border-top:1px solid #7ab8d0;margin-top:.5rem;padding-top:.5rem}.global-settings-cleanup .cleanup-btn{background:#fff;border:1px solid #7ab8d0;border-radius:.5rem;color:#0c4a6e;cursor:pointer;font-size:.85rem;padding:.4rem .75rem}.global-settings-cleanup .cleanup-btn:hover{background:#b6d6e3}.global-settings-cleanup .cleanup-btn-all:hover{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.global-settings-cleanup .cleanup-status{color:#0369a1;font-size:.85rem;margin-left:.5rem}.stt-page{display:flex;flex-direction:column;margin:0 auto;min-height:100vh;padding:1rem;width:100%}.stt-header{border-bottom:1px solid #1e40af33;padding:1.5rem 0;text-align:center}.stt-header h1{color:#1e3a8a;font-size:1.75rem;font-weight:600;margin:0}.stt-subtitle{color:#475569;font-size:.9rem;margin:.25rem 0 0}.stt-hint{color:#94a3b8;font-size:.8rem;margin:.5rem 0 0}.stt-main{flex:1 1;padding-top:2rem}.stt-main,.stt-transcript-area{display:flex;flex-direction:column}.stt-transcript-area{gap:1rem}.stt-transcript{background:#fff;border:1px solid #94a3b8;border-radius:.75rem;color:#1e293b;font-size:1rem;line-height:1.6;min-height:200px;outline:none;padding:1.25rem;resize:vertical;transition:border-color .2s;width:100%}.stt-transcript:focus{border-color:#2563eb}.stt-transcript::placeholder{color:#94a3b8}.stt-actions{flex-wrap:wrap;gap:.75rem;justify-content:center}.stt-actions,.stt-mic-btn{align-items:center;display:flex}.stt-mic-btn{background:#fff;border:2px solid #94a3b8;border-radius:1rem;cursor:pointer;flex-direction:column;gap:.5rem;padding:1.5rem 2rem;transition:all .2s}.stt-mic-btn:hover{background:#eff6ff;border-color:#2563eb}.stt-mic-btn.listening{animation:stt-pulse 1.5s ease-in-out infinite;background:#fef2f2;border-color:#dc2626}@keyframes stt-pulse{0%,to{opacity:1}50%{opacity:.8}}.stt-mic-icon{font-size:2.5rem}.stt-mic-label{color:#475569;font-size:.9rem;font-weight:500}.stt-mic-btn.listening .stt-mic-label{color:#dc2626}.stt-action-btn{background:#fff;border:1px solid #94a3b8;border-radius:.5rem;color:#1e293b;cursor:pointer;font-size:.9rem;font-weight:500;padding:.6rem 1.25rem;transition:all .2s}.stt-action-btn:hover:not(:disabled){background:#eff6ff;border-color:#2563eb;color:#1d4ed8}.stt-action-btn:disabled{cursor:not-allowed;opacity:.5}.stt-error{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.9rem;margin-top:1rem;padding:.75rem 1rem}.stt-unsupported{align-items:center;color:#64748b;display:flex;flex:1 1;flex-direction:column;gap:.5rem;justify-content:center;padding:2rem;text-align:center}@media (max-width:640px){.stt-page{padding:.75rem}.stt-header h1{font-size:1.5rem}.stt-transcript{min-height:160px}.stt-mic-btn{padding:1.25rem 1.5rem}.stt-mic-icon{font-size:2rem}}.discuss-section{border-top:1px solid #e2e8f0;margin-top:1.5rem;padding-top:1.5rem}.discuss-section.compact{margin-top:1rem;padding-top:1rem}.discuss-section-status{align-items:center;display:flex;flex-direction:column;gap:1rem}.discuss-section-status-box{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:.75rem;display:flex;gap:.5rem;justify-content:center;min-width:240px;padding:.75rem 1rem;transition:all .3s}.discuss-section-status-box.listening{background:#fef2f2;border-color:#fecaca}.discuss-section-status-box.processing{background:#eff6ff;border-color:#93c5fd}.discuss-section-icon{font-size:1.25rem}.discuss-section-status-text{color:#475569;font-size:.9rem;font-weight:500}.discuss-section-status-box.listening .discuss-section-status-text{color:#dc2626}.discuss-section-status-box.processing .discuss-section-status-text{color:#2563eb}.discuss-section-actions{display:flex;gap:.5rem}.discuss-section-btn{border:2px solid #0000;border-radius:.5rem;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1.25rem;transition:all .2s}.discuss-section-btn-start{background:#2563eb;border-color:#1d4ed8;color:#fff}.discuss-section-btn-start:hover{background:#1d4ed8}.discuss-section-btn-done{background:#fff;border-color:#fecaca;color:#dc2626}.discuss-section-btn-done:hover{background:#fef2f2;border-color:#dc2626}.discuss-section-history{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;max-height:280px;overflow-y:auto}.discuss-section-msg{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;padding:.75rem 1rem}.discuss-section-msg.user{background:#eff6ff;border-color:#93c5fd;margin-left:1rem}.discuss-section-msg.assistant{background:#f8fafc;border-color:#e2e8f0;margin-right:1rem}.discuss-section-msg-role{color:#64748b;display:block;font-size:.7rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.discuss-section-idioms{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:.375rem;margin-bottom:.75rem;padding:.5rem .75rem}.discuss-section-idioms-label{color:#b45309;display:block;font-size:.7rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.discuss-section-idioms-text{color:#92400e;font-size:.85rem;line-height:1.5;margin:0}.discuss-section-msg .audio-player{margin-top:.5rem}.discuss-section-msg-text{word-wrap:break-word;color:#1e293b;font-size:.95rem;line-height:1.5;white-space:pre-wrap}.discuss-section-error{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.85rem;margin-top:.75rem;padding:.5rem .75rem}.url-summarize-page{display:flex;flex-direction:column;margin:0 auto;min-height:100vh;padding:1rem;width:100%}.url-summarize-header{border-bottom:1px solid #1e40af33;padding:1.5rem 0;text-align:center}.url-summarize-header h1{color:#1e3a8a;font-size:1.75rem;font-weight:600;margin:0}.url-summarize-subtitle{color:#475569;font-size:.9rem;margin:.25rem 0 0}.url-summarize-hint{color:#94a3b8;font-size:.8rem;margin:.5rem 0 0}.url-summarize-main{flex:1 1;padding-top:2rem}.url-summarize-settings{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:.75rem 0}.url-summarize-settings .setting-row label{color:#475569;font-size:.85rem}.url-summarize-settings .setting-select{background:#fff;border:1px solid #94a3b8;border-radius:.375rem;font-size:.9rem;padding:.4rem .75rem}.url-summarize-tabs{display:flex;gap:.25rem;margin-bottom:1rem}.url-summarize-tab{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.url-summarize-tab:hover{background:#e2e8f0;color:#1e293b}.url-summarize-tab.active{background:#2563eb;border-color:#2563eb;color:#fff}.url-summarize-form{display:flex;flex-direction:column;gap:1rem}.url-paste-textarea{background:#fff;border:1px solid #94a3b8;border-radius:.5rem;color:#1e293b;font-family:inherit;font-size:1rem;min-height:160px;outline:none;padding:1rem 1.25rem;resize:vertical;transition:border-color .2s;width:100%}.url-paste-textarea:focus{border-color:#2563eb}.url-paste-textarea::placeholder{color:#94a3b8}.url-paste-textarea:disabled{cursor:not-allowed;opacity:.6}.url-input-row{align-items:center;display:flex;gap:.5rem}.url-input-row .url-input{flex:1 1}.url-open-link{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.5rem;color:#2563eb;font-size:.9rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s;white-space:nowrap}.url-open-link:hover{background:#eff6ff;border-color:#93c5fd}.url-input{background:#fff;border:1px solid #94a3b8;border-radius:.5rem;color:#1e293b;font-size:1rem;outline:none;padding:1rem 1.25rem;transition:border-color .2s;width:100%}.url-input:focus{border-color:#2563eb}.url-input::placeholder{color:#94a3b8}.url-input:disabled{cursor:not-allowed;opacity:.6}.url-submit-btn{background:#2563eb;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:background .2s}.url-submit-btn:hover:not(:disabled){background:#1d4ed8}.url-submit-btn:disabled{cursor:not-allowed;opacity:.5}.url-summarize-error{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.9rem;margin-top:1rem;padding:.75rem 1rem}.url-summarize-result{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #1e40af14;margin-top:2rem;padding:1.5rem}.url-idioms-explanation{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.url-idioms-label{color:#b45309;display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.35rem;text-transform:uppercase}.url-idioms-text{color:#92400e;font-size:.9rem;line-height:1.5;margin:0}.result-title{color:#1e293b;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.result-summary{color:#334155;font-size:.95rem;line-height:1.6;white-space:pre-wrap}.result-audio,.url-discuss-options{border-top:1px solid #e2e8f0;margin-top:1rem;padding-top:1rem}.url-discuss-model-option{align-items:center;color:#475569;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem}.url-discuss-model-option input{cursor:pointer}@media (max-width:640px){.url-summarize-page{padding:.75rem}.url-summarize-header h1{font-size:1.5rem}}.discuss-page{display:flex;flex-direction:column;margin:0 auto;min-height:100vh;padding:1rem;width:100%}.discuss-header{border-bottom:1px solid #1e40af33;padding:1.5rem 0;text-align:center}.discuss-header h1{color:#1e3a8a;font-size:1.75rem;font-weight:600;margin:0}.discuss-subtitle{color:#475569;font-size:.9rem;margin:.25rem 0 0}.discuss-settings{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1rem}.discuss-settings .setting-row{align-items:center;display:flex;gap:.5rem}.discuss-settings .setting-row label{color:#475569;font-size:.85rem}.discuss-settings .setting-select{background:#fff;border:1px solid #94a3b8;border-radius:.5rem;color:#1e293b;font-size:.9rem;min-width:120px;padding:.4rem .75rem}.discuss-main{display:flex;flex:1 1;flex-direction:column;gap:1.5rem;min-height:0;padding-top:1.5rem}.discuss-status-area{align-items:center;display:flex;flex-direction:column;gap:1.25rem}.discuss-status{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:1rem;display:flex;gap:.75rem;justify-content:center;min-width:280px;padding:1rem 1.5rem;transition:all .3s}.discuss-status.listening{animation:discuss-pulse 2s ease-in-out infinite;background:#fef2f2;border-color:#fecaca}.discuss-status.processing{background:#eff6ff;border-color:#93c5fd}@keyframes discuss-pulse{0%,to{box-shadow:0 0 0 0 #ef44444d;opacity:1}50%{box-shadow:0 0 0 8px #ef444400;opacity:.95}}.discuss-status-icon{font-size:1.5rem}.discuss-status-text{color:#475569;font-size:.95rem;font-weight:500}.discuss-status.listening .discuss-status-text{color:#dc2626}.discuss-status.processing .discuss-status-text{color:#2563eb}.discuss-actions{display:flex;gap:.75rem}.discuss-btn{border:2px solid #0000;border-radius:.75rem;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.75rem;transition:all .2s}.discuss-btn-start{background:#2563eb;border-color:#1d4ed8;color:#fff}.discuss-btn-start:hover{background:#1d4ed8;transform:translateY(-1px)}.discuss-btn-done{background:#fff;border-color:#fecaca;color:#dc2626}.discuss-btn-done:hover:not(:disabled){background:#fef2f2;border-color:#dc2626;transform:translateY(-1px)}.discuss-btn-done:disabled{cursor:not-allowed;opacity:.6}.discuss-history{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;gap:1rem;min-height:240px;overflow-y:auto;padding:.75rem 0}.discuss-history-empty{align-items:center;justify-content:center}.discuss-empty-hint{color:#94a3b8;font-size:.95rem;margin:0}.discuss-msg{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;flex-shrink:0;padding:1rem 1.25rem}.discuss-msg.user{background:#eff6ff;border-color:#93c5fd;margin-left:0;margin-right:2rem}.discuss-msg.assistant{background:#f8fafc;border-color:#e2e8f0;margin-left:2rem;margin-right:0}.discuss-msg-role{color:#64748b;display:block;font-size:.7rem;font-weight:600;letter-spacing:.08em;margin-bottom:.5rem;text-transform:uppercase}.discuss-idioms{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:.5rem;margin-bottom:.75rem;padding:.5rem .75rem}.discuss-idioms-label{color:#b45309;display:block;font-size:.7rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.discuss-idioms-text{color:#92400e;font-size:.9rem;line-height:1.5;margin:0}.discuss-msg .audio-player{margin-top:.5rem}.discuss-msg-text{word-wrap:break-word;color:#1e293b;font-size:1.05rem;line-height:1.65;margin:0;white-space:pre-wrap}.discuss-error{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.9rem;padding:.75rem 1rem}@media (max-width:640px){.discuss-page{padding:.75rem}.discuss-header h1{font-size:1.5rem}.discuss-settings{gap:.75rem}.discuss-settings .setting-select{min-width:100px}.discuss-msg.user{margin-right:.5rem}.discuss-msg.assistant{margin-left:.5rem}.discuss-msg-text{font-size:1rem}}.code-page{display:flex;flex-direction:column;margin:0 auto;min-height:100vh;padding:1rem;width:100%}.code-header{border-bottom:1px solid #1e40af33;padding:1.5rem 0;text-align:center}.code-header h1{color:#1e3a8a;font-size:1.75rem;font-weight:600;margin:0}.code-subtitle{color:#475569;font-size:.9rem;margin:.25rem 0 0}.code-settings-wrap{margin-top:1rem}.code-settings-toggle{align-items:center;background:#0000;border:1px solid #94a3b8;border-radius:.5rem;color:#475569;cursor:pointer;display:flex;font-size:.9rem;gap:.35rem;padding:.4rem .75rem}.code-settings-toggle:hover{background:#f1f5f9;border-color:#64748b}.code-settings{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:.75rem}.code-settings .setting-row{align-items:center;display:flex;gap:.5rem}.code-settings .setting-row label{color:#475569;font-size:.85rem}.code-settings .setting-select{background:#fff;border:1px solid #94a3b8;border-radius:.5rem;color:#1e293b;font-size:.9rem;min-width:120px;padding:.4rem .75rem}.code-prompt-area{display:flex;justify-content:center;margin-top:.5rem}.code-text-prompt{border:1px solid #94a3b8;border-radius:.5rem;display:block;font-family:inherit;font-size:.95rem;line-height:1.5;max-width:80vw;min-height:80px;padding:.75rem 1rem;resize:vertical;width:80%}.code-text-prompt:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33;outline:none}.code-text-prompt:disabled{background:#f1f5f9;cursor:not-allowed}.code-main{flex:1 1;gap:1.5rem;min-height:0;padding-top:1.5rem}.code-main,.code-status-area{display:flex;flex-direction:column}.code-status-area{align-items:center;gap:1.25rem}.code-status{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:1rem;display:flex;gap:.75rem;justify-content:center;min-width:280px;padding:1rem 1.5rem;transition:all .3s}.code-status.listening{animation:code-pulse 2s ease-in-out infinite;background:#fef2f2;border-color:#fecaca}.code-status.processing{background:#eff6ff;border-color:#93c5fd}@keyframes code-pulse{0%,to{box-shadow:0 0 0 0 #ef44444d;opacity:1}50%{box-shadow:0 0 0 8px #ef444400;opacity:.95}}.code-status-icon{font-size:1.5rem}.code-status-text{color:#475569;font-size:.95rem;font-weight:500}.code-status.listening .code-status-text{color:#dc2626}.code-status.processing .code-status-text{color:#2563eb}.code-voice-prompt{background:#eff6ff;border:1px solid #93c5fd;border-radius:.5rem;max-width:80vw;padding:.75rem 1rem;text-align:left}.code-voice-prompt-label{color:#2563eb;display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.code-voice-prompt-text{color:#1e293b;font-size:.95rem;line-height:1.5}.code-actions{display:flex;gap:.75rem}.code-btn{border:2px solid #0000;border-radius:.75rem;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.75rem;transition:all .2s}.code-btn-generate{background:#afdbcc;border-color:#6b9080;color:#14532d}.code-btn-generate:hover:not(:disabled){background:#99d4bc;border-color:#5a8a7a;transform:translateY(-1px)}.code-btn-text{background:#d6e8c3;border-color:#a3e635;color:#365314}.code-btn-text:hover:not(:disabled){background:#bbf7d0;border-color:#86efac;transform:translateY(-1px)}.code-btn-text:disabled{cursor:not-allowed;opacity:.6}.code-btn-done{background:#fff;border-color:#fecaca;color:#dc2626}.code-btn-done:hover:not(:disabled){background:#fef2f2;border-color:#dc2626;transform:translateY(-1px)}.code-result{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0}.code-result-section{background:#fdf8f3;border:1px solid #e8dfd4;border-radius:.75rem;overflow-x:auto;padding:1.25rem}.code-result-title{color:#2d2d2d;font-size:1rem;font-weight:600;margin:0 0 1rem}.code-block-wrap{border-radius:.5rem;box-shadow:0 2px 8px #00000014;margin-bottom:1rem;overflow:hidden}.code-block-label{background:#afb1bd;border-bottom:1px solid #9a9ca9;color:#334155;font-family:Consolas,Monaco,Courier New,monospace;font-size:.8rem;font-weight:600;padding:.35rem 1rem}.code-block-wrap:last-child{margin-bottom:0}.code-block-wrap pre{overflow-x:auto!important}.code-no-blocks-hint{background:#fef3c7;border-radius:.375rem;color:#b45309;font-size:.9rem;margin:0 0 .75rem;padding:.5rem .75rem}.code-raw{background:#faf6f0;border:1px solid #e5ddd2;border-radius:.5rem;color:#2d2d2d;font-size:.9rem;line-height:1.5;margin:0;padding:1rem;white-space:pre-wrap}.code-mermaid-wrap{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 2px 8px #0000000f;display:flex;justify-content:center;overflow-x:auto;padding:1.25rem}.code-mermaid-svg{max-width:100%}.code-mermaid-svg svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.05));height:auto;max-width:100%}.code-mermaid-loading{color:#64748b;font-size:.9rem;padding:1rem}.code-mermaid-error{background:#fef2f2;border-radius:.5rem;color:#dc2626;font-size:.85rem;padding:1rem}.code-discuss-wrap{border-top:1px solid #e2e8f0;margin-top:.5rem;padding-top:1rem}.code-error{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.9rem;padding:.75rem 1rem}@media (max-width:640px){.code-page{padding:.75rem}.code-header h1{font-size:1.5rem}.code-settings .setting-select{min-width:100px}}.login-page{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);display:flex;justify-content:center;min-height:100vh}.login-card{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-width:360px;padding:2.5rem;width:100%}.login-card h1{color:#fff;font-size:1.75rem;margin:0 0 .25rem}.login-subtitle{color:#fff9;font-size:.9rem;margin:0 0 1.5rem}.login-form{gap:1rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.35rem}.form-group label{color:#fffc;font-size:.85rem}.form-group input{background:#ffffff14;border:1px solid #fff3;border-radius:6px;color:#fff;font-size:1rem;padding:.6rem .75rem}.form-group input:focus{border-color:#4a9eff;box-shadow:0 0 0 2px #4a9eff4d;outline:none}.login-error{background:#dc354533;border:1px solid #dc354580;border-radius:6px;color:#f8a5a5;font-size:.9rem;padding:.5rem .75rem}.login-btn{background:#4a9eff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;margin-top:.25rem;padding:.75rem 1rem}.login-btn:hover:not(:disabled){background:#3a8eef}.login-btn:disabled{cursor:not-allowed;opacity:.7}.app-loading{align-items:center;color:#64748b;justify-content:center}.app,.app-loading{display:flex;min-height:100vh}.app{flex-direction:column;margin:0 auto;max-width:95vw;padding:1rem;width:95%}.app-nav{border-bottom:1px solid #1e40af33;display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 0}.nav-link{background:#0000;border:1px solid #0000;border-radius:.5rem;color:#475569;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.nav-link.active,.nav-link:hover{background:#eff6ff;color:#1d4ed8}.nav-link.active{border-color:#93c5fd}.nav-link-logout{color:#dc2626;flex-shrink:0;margin-left:auto}.nav-link-logout:hover{background:#fef2f2;border-color:#fca5a5}.app-header{border-bottom:1px solid #1e40af33;padding:1.5rem 0;text-align:center}.app-header h1{color:#1e3a8a;font-size:1.75rem;font-weight:600;margin:0}.subtitle{color:#475569;font-size:.9rem;margin:.25rem 0 0}.speech-settings{flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1rem}.setting-row,.speech-settings{align-items:center;display:flex}.setting-row{gap:.5rem}.setting-row label{color:#475569;font-size:.85rem}.setting-row-checkbox{flex-basis:100%}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem}.checkbox-label input{cursor:pointer}.setting-select{font-size:.9rem;min-width:140px}.cleanup-btn,.setting-select{background:#fff;border:1px solid #94a3b8;border-radius:.5rem;color:#1e293b;padding:.4rem .75rem}.cleanup-btn{cursor:pointer;font-size:.85rem;transition:all .2s}.cleanup-btn:hover{background:#eff6ff;border-color:#2563eb}.cleanup-btn-all{border-color:#fecaca}.cleanup-btn-all:hover{background:#fef2f2;border-color:#dc2626}.cleanup-status{color:#475569;font-size:.85rem;margin:.5rem 0 0}.chat-container{display:flex;flex:1 1;flex-direction:column;padding-top:1rem}.messages{flex:1 1;overflow-y:auto;padding-bottom:1rem}.empty-state{color:#64748b;font-size:.95rem;margin:0 auto;max-width:400px;padding:2rem 1.5rem;text-align:left}.empty-state-title{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 1rem}.empty-state-steps{line-height:1.8;margin:0 0 1rem;padding-left:1.25rem}.empty-state-steps li{margin-bottom:.5rem}.empty-state-hint{color:#94a3b8;font-size:.9rem;margin:0}.loading-bubble{align-items:center;align-self:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 1px 3px #1e40af14;display:flex;gap:.75rem;margin-bottom:1rem;max-width:85%;padding:1rem 1.25rem}.loading-dots{display:flex;gap:.35rem}.loading-dots span{animation:bounce 1.4s ease-in-out infinite both;background:#64748b;border-radius:50%;height:6px;width:6px}.loading-dots span:first-child{animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.loading-text{color:#64748b;font-size:.85rem}.error-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.9rem;margin-bottom:.5rem;padding:.75rem 1rem}@media (max-width:640px){.app{padding:.75rem}.app-header h1{font-size:1.5rem}}
/*# sourceMappingURL=main.839f79fc.css.map*/