:root,[data-theme=light]{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light;--bg-page: #f5f5f5;--bg-header: #282c34;--bg-card: #fff;--bg-elevated: #f8f9fa;--input-bg: #fff;--input-text: #212529;--text-primary: #333;--text-secondary: #666;--text-muted: #6c757d;--text-on-header: #fff;--border: #dee2e6;--border-input: #ddd;--shadow: 0 2px 4px rgba(0, 0, 0, .1);--link: #646cff;--link-hover: #535bf2;--error-bg: #f8d7da;--error-border: #f5c6cb;--error-text: #dc3545;--focus-ring: rgba(0, 123, 255, .25);--btn-bg: #f9f9f9;--btn-border: transparent;--btn-primary: #007bff;--btn-primary-hover: #0056b3;--btn-danger: #f44336;--btn-success: #28a745;--btn-success-hover: #218838;--btn-secondary: #6c757d;--btn-secondary-hover: #5a6268;--info-bg: #e8f4fd;--info-border: #2196f3}[data-theme=dark]{color-scheme:dark;--bg-page: #121212;--bg-header: #1e1e1e;--bg-card: #2d2d2d;--bg-elevated: #383838;--input-bg: #2d2d2d;--input-text: #e5e5e5;--text-primary: #e5e5e5;--text-secondary: #b0b0b0;--text-muted: #888;--text-on-header: #fff;--border: #404040;--border-input: #505050;--shadow: 0 2px 4px rgba(0, 0, 0, .3);--link: #7b83ff;--link-hover: #9ba2ff;--error-bg: #4a2a2a;--error-border: #5c3535;--error-text: #f08080;--focus-ring: rgba(123, 131, 255, .35);--btn-bg: #383838;--btn-border: #505050;--btn-primary: #4a7cff;--btn-primary-hover: #6b9aff;--btn-danger: #f44336;--btn-success: #28a745;--btn-success-hover: #218838;--btn-secondary: #5a6268;--btn-secondary-hover: #6c757d;--info-bg: #1e2a3a;--info-border: #2196f3}a{font-weight:500;color:var(--link);text-decoration:inherit}a:hover{color:var(--link-hover)}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;color:var(--text-primary);background-color:var(--bg-page)}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid var(--btn-border);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--btn-bg);color:var(--text-primary);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--link)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.audio-transcription{display:flex;flex-direction:column;gap:20px;padding:20px;max-width:800px;margin:0 auto}.controls{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap}.controls button{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-size:16px;transition:all .3s ease}.controls button:disabled{opacity:.5;cursor:not-allowed}.controls button.start{background-color:var(--btn-success);color:#fff}.controls button.stop{background-color:var(--btn-danger);color:#fff}.controls button:hover:not(:disabled){opacity:.9}.connection-status{color:var(--text-secondary);font-size:14px;padding:5px 10px;background-color:var(--bg-elevated);border-radius:4px}.transcription-container{background-color:var(--bg-elevated);padding:20px;border-radius:8px;min-height:200px}.transcription-container h3{margin-top:0;color:var(--text-primary)}.transcription-text{white-space:pre-wrap;line-height:1.5;color:var(--text-secondary)}.error{color:var(--error-text);margin-bottom:10px;padding:10px;background-color:var(--error-bg);border-radius:4px}.error-message{color:var(--error-text);background-color:var(--error-bg);border:1px solid var(--error-border);border-radius:4px;padding:10px;margin:10px 0;font-size:14px}.word-timestamps{margin-top:20px;padding:15px;background-color:var(--bg-elevated);border-radius:4px;border:1px solid var(--border)}.word-timestamps h4{margin:0 0 10px;color:var(--text-secondary);font-size:16px}.words-list{display:flex;flex-wrap:wrap;gap:8px}.word-item{display:inline-flex;align-items:center;background-color:var(--bg-elevated);padding:4px 8px;border-radius:4px;font-size:14px}.word-item .word{font-weight:500;margin-right:6px;color:var(--text-primary)}.word-item .timestamp{color:var(--text-muted);font-size:12px}.audio-files{margin:20px 0;padding:15px;background-color:var(--bg-elevated);border-radius:8px}.audio-files h4{margin:0 0 10px;color:var(--text-primary)}.download-links{display:flex;gap:15px}.download-link{display:inline-block;padding:8px 16px;background-color:var(--btn-primary);color:#fff;text-decoration:none;border-radius:4px;transition:background-color .2s}.download-link:hover{background-color:var(--btn-primary-hover)}.text-to-speech{display:flex;flex-direction:column;gap:20px;padding:20px;max-width:800px;margin:0 auto;background-color:var(--bg-card);border-radius:8px;box-shadow:var(--shadow)}.service-info{margin:15px 0;padding:10px;background-color:var(--info-bg);border-radius:5px;border-left:4px solid var(--info-border)}.service-description{margin:0 0 5px;font-size:14px;color:var(--text-primary)}.service-note{margin:0;font-size:12px;color:var(--text-secondary)}.text-input-container{width:100%}.text-input-container textarea{width:100%;padding:12px;border:1px solid var(--border-input);border-radius:4px;font-size:16px;resize:vertical;min-height:100px;font-family:inherit;background-color:var(--input-bg);color:var(--input-text)}.text-input-container textarea:focus{outline:none;border-color:var(--btn-primary);box-shadow:0 0 0 2px var(--focus-ring)}.language-label{color:var(--text-primary);margin-right:10px}.provider-selector{display:flex;align-items:center;gap:10px;min-width:200px}.provider-label{color:var(--text-primary);margin-right:10px;white-space:nowrap;font-weight:500}.provider-selector select{flex:1;padding:8px;border:1px solid var(--border-input);border-radius:4px;font-size:14px;background-color:var(--input-bg);color:var(--input-text);min-width:120px}.provider-selector select:focus{outline:none;border-color:var(--btn-primary);box-shadow:0 0 0 2px var(--focus-ring)}.provider-info{margin:15px 0;padding:10px;background-color:var(--info-bg);border-radius:5px;border-left:4px solid var(--info-border)}.provider-description{margin:0 0 5px;font-size:14px;color:var(--text-primary)}.provider-note{margin:0;font-size:12px;color:var(--text-secondary)}.voice-selector{display:flex;align-items:center;gap:10px;min-width:200px}.voice-selector label{white-space:nowrap;color:var(--text-primary);font-weight:500}.voice-selector select{flex:1;padding:8px;border:1px solid var(--border-input);border-radius:4px;font-size:14px;background-color:var(--input-bg);color:var(--input-text);min-width:120px}.voice-selector select:focus{outline:none;border-color:var(--btn-primary);box-shadow:0 0 0 2px var(--focus-ring)}.controls button.convert{background-color:var(--btn-primary);color:#fff;padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-size:16px;transition:all .3s ease}.controls button.convert:hover:not(:disabled){background-color:var(--btn-primary-hover)}.controls button.convert:disabled{opacity:.5;cursor:not-allowed}.audio-player{margin-top:20px;padding:15px;background-color:var(--bg-elevated);border-radius:8px;border:1px solid var(--border)}.audio-player h4{margin:0 0 10px;color:var(--text-secondary)}.audio-player audio{width:100%;margin-bottom:10px}@media (max-width: 768px){.controls{flex-direction:column;align-items:stretch}.voice-selector{width:100%;min-width:unset}.voice-selector select,.controls button{width:100%}}.api-key-manager{background-color:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:20px;margin-bottom:20px}.api-key-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.api-key-header h3{margin:0;color:var(--text-primary)}.edit-button{background-color:var(--btn-secondary);color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background-color .2s}.edit-button:hover{background-color:var(--btn-secondary-hover)}.api-key-inputs{display:flex;flex-direction:column;gap:15px}.api-key-input{display:flex;flex-direction:column;gap:5px}.api-key-input label{color:var(--text-secondary);font-weight:500}.api-key-input input{padding:8px;border:1px solid var(--border);border-radius:4px;font-size:14px;background-color:var(--input-bg);color:var(--input-text)}.api-key-input input:focus{outline:none;border-color:var(--btn-primary);box-shadow:0 0 0 .2rem var(--focus-ring)}.save-button{background-color:var(--btn-success);color:#fff;border:none;padding:10px;border-radius:4px;cursor:pointer;transition:background-color .2s;margin-top:10px}.save-button:hover{background-color:var(--btn-success-hover)}.api-key-status{color:var(--text-secondary)}.api-key-status p{margin:5px 0;display:flex;align-items:center;gap:8px}.phonics-detection{display:flex;flex-direction:column;gap:16px;padding:20px;max-width:800px;margin:0 auto;color:var(--text-primary)}.phonics-description{margin:0 0 10px;font-size:14px;color:var(--text-secondary)}.phonics-controls{display:flex;flex-direction:column;gap:10px;align-items:stretch}.phonics-language-selector{display:flex;flex-direction:column;gap:6px}.phonics-language-selector label{font-size:14px;font-weight:500;color:var(--text-primary)}.phonics-language-selector select{padding:8px 12px;border:1px solid var(--border);border-radius:5px;font-size:14px;background-color:var(--input-bg);color:var(--input-text);cursor:pointer;max-width:240px}.phonics-language-selector select:disabled{opacity:.6;cursor:not-allowed}.phonics-buttons{display:flex;flex-direction:column;gap:10px}.phonics-btn{padding:10px 18px;border:none;border-radius:5px;cursor:pointer;font-size:14px;transition:all .2s ease;width:100%}.phonics-btn:disabled{opacity:.5;cursor:not-allowed}.phonics-btn.record{background-color:var(--btn-success);color:#fff}.phonics-btn.stop{background-color:var(--btn-danger);color:#fff}.phonics-btn.upload{background-color:var(--btn-primary);color:#fff;display:inline-flex;align-items:center;justify-content:center}.phonics-btn:hover:not(:disabled){opacity:.9}.phonics-error{color:var(--error-text);background-color:var(--error-bg);border:1px solid var(--error-border);border-radius:4px;padding:10px;font-size:14px}.phonics-loading{color:var(--text-secondary);font-style:italic;padding:10px}.phonics-results{background-color:var(--bg-elevated);padding:20px;border-radius:8px;border:1px solid var(--border);color:var(--text-primary)}.phonics-results h4{margin:16px 0 8px;color:var(--text-primary);font-size:16px}.phonics-results h4:first-child{margin-top:0}.phonics-text{color:var(--text-secondary);line-height:1.5}.phonics-words-table{display:flex;flex-direction:column;gap:4px;margin-top:8px}.phonics-table-header,.phonics-table-row{display:grid;grid-template-columns:1fr 80px 80px 80px;gap:12px;padding:8px 12px;align-items:center}.phonics-table-header{font-weight:600;color:var(--text-secondary);background-color:var(--bg-elevated);border-radius:4px}.phonics-table-row{background-color:var(--bg-card);border-radius:4px;font-size:14px;color:var(--text-primary)}.phonics-table-row .phonics-hit{font-weight:600;color:var(--btn-success)}.phonics-empty{color:var(--text-muted);font-style:italic;margin:0}.phonics-audio-files{margin:16px 0}.phonics-download-links{display:flex;gap:12px}.phonics-download-link{display:inline-block;padding:8px 16px;background-color:var(--btn-primary);color:#fff;text-decoration:none;border-radius:4px;font-size:14px}.phonics-download-link:hover{opacity:.9}.phonics-results h4{color:var(--text-primary)}.phonics-summary{display:flex;flex-direction:column;gap:12px}.phonics-sound-group{padding:12px;background-color:var(--bg-card);border-radius:4px;border-left:4px solid var(--info-border);color:var(--text-primary)}.phonics-sound-group strong{color:var(--text-primary)}.phonics-sound-group ul{margin:8px 0 0;padding-left:20px}.phonics-sound-group li{margin:4px 0;font-size:14px;color:var(--text-secondary)}#root{width:100%;margin:0 auto;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:var(--text-muted)}.App{text-align:center;min-height:100vh;background-color:var(--bg-page)}.App-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;background-color:var(--bg-header);padding:20px;color:var(--text-on-header);margin-bottom:30px}.App-header h1{margin:0;font-size:2rem}.theme-toggle{display:flex;align-items:center;gap:8px}.theme-toggle button{padding:8px 16px;font-size:.9rem;background-color:#ffffff26;color:var(--text-on-header);border:1px solid rgba(255,255,255,.3)}.theme-toggle button:hover{background-color:#ffffff40;border-color:#ffffff80}.components-container{margin:0 auto;padding:0 20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.component-section{background-color:var(--bg-card);border-radius:8px;box-shadow:var(--shadow);padding:20px}.component-section h2,.section-heading{color:var(--text-primary);margin-top:0;margin-bottom:20px;font-size:1.5rem}@media (max-width: 768px){.components-container{grid-template-columns:1fr}.component-section{margin-bottom:20px}}
