*,:before,:after{box-sizing:border-box}body{color:#e0e0e0;background:#0f0f1e;min-height:100vh;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif}#root{min-height:100vh}.nav{background:#1a1a2e;border-bottom:1px solid #2a2a4a;flex-wrap:wrap;align-items:center;gap:1.5rem;padding:.75rem 1.5rem;display:flex}.nav-brand{color:#e8b84b;white-space:nowrap;font-size:1.2rem;font-weight:700}.nav-links{flex-wrap:wrap;gap:1.25rem;display:flex}.nav-links a{color:#aaa;border-radius:4px;padding:.25rem .5rem;font-size:.95rem;text-decoration:none;transition:color .15s,background .15s}.nav-links a:hover{color:#fff;background:#ffffff12}.nav-links a.active{color:#e8b84b;font-weight:600}.session-container{background:#0f0f1a;justify-content:center;align-items:flex-start;min-height:calc(100vh - 56px);padding:1.5rem 1rem;display:flex}.session-card{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;flex-direction:column;gap:1.25rem;width:100%;max-width:600px;padding:2rem 1.5rem;display:flex}.session-title{color:#e8b84b;text-align:center;margin:0;font-size:2rem;font-weight:700}.start-subtitle{text-align:center;color:#aaa;margin:0;font-size:1rem}.start-meta{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.meta-badge{color:#aaa;background:#2a2a4a;border-radius:6px;padding:.3rem .75rem;font-size:.9rem}.start-hint{text-align:center;color:#666;margin:0;font-size:.9rem}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:#aaa;cursor:pointer;text-align:center;background:0 0;border:1px solid #3a3a5a;border-radius:8px;padding:.65rem 1.25rem;font-size:.95rem;transition:color .15s,border-color .15s}.progress-bar-wrap{background:#2a2a4a;border-radius:4px;height:6px;overflow:hidden}.progress-bar-fill{background:#e8b84b;height:100%;transition:width .3s}.progress-text{text-align:right;color:#888;margin-top:-.5rem;font-size:.85rem}.replay-btn{color:#e0e0e0;cursor:pointer;background:#2a2a4a;border:1px solid #3a3a5a;border-radius:8px;width:100%;padding:.75rem 1.5rem;font-size:1.1rem;font-weight:600;transition:background .15s}.replay-btn:hover{background:#3a3a5a}.characters-display{text-align:center;color:#e8b84b;margin:.5rem 0;font-size:2.5rem;line-height:1.3}.english-reveal{text-align:center;color:#888;font-size:1rem;font-style:italic}.choices-grid{flex-direction:column;gap:.75rem;display:flex}.answer-btn{color:#e0e0e0;cursor:pointer;text-align:center;background:#22223a;border:1px solid #3a3a5a;border-radius:8px;width:100%;min-height:56px;padding:.75rem 1rem;font-size:1.1rem;transition:background .15s,border-color .15s}.answer-btn:hover:not(:disabled){background:#2e2e4e;border-color:#6a6a8a}.answer-btn:disabled{cursor:not-allowed}.answer-btn.correct{color:#fff;background:#4caf50;border-color:#4caf50}.answer-btn.incorrect{color:#fff;background:#f44336;border-color:#f44336}.answer-btn.dimmed{opacity:.45}.type-area{flex-direction:column;gap:.75rem;display:flex}.pinyin-toggle{align-self:flex-start}.pinyin-display{color:#aaa;background:#22223a;border-radius:6px;padding:.4rem .75rem;font-size:1rem}.type-input{color:#e0e0e0;box-sizing:border-box;background:#22223a;border:2px solid #3a3a5a;border-radius:8px;outline:none;width:100%;padding:.75rem 1rem;font-size:1.4rem;transition:border-color .15s}.type-input:focus{border-color:#e8b84b}.type-input.correct{background:#4caf501f;border-color:#4caf50}.type-input.close{background:#ff98001f;border-color:#ff9800}.type-input.incorrect{background:#f443361f;border-color:#f44336}.type-input:disabled{opacity:.7}.hint-close{color:#fff;text-align:center;background:#ff9800;border-radius:8px;padding:.65rem 1rem;font-weight:600}.correct-reveal{color:#aaa;text-align:center;font-size:.95rem}.correct-chars{color:#4caf50;margin-top:.25rem;font-size:1.3rem;font-weight:700;display:block}.next-btn{margin-top:.25rem}.score-display{text-align:center}.score-big{color:#e8b84b;font-size:1.8rem;font-weight:700}.streak-badge{text-align:center;color:#ff9800;background:#ff980026;border:1px solid #ff9800;border-radius:8px;padding:.6rem 1rem;font-size:1rem;font-weight:600}@media (width>=500px){.choices-grid{grid-template-columns:1fr 1fr;display:grid}}.speed-control{border-top:1px solid #ffffff14;align-items:center;gap:.5rem;margin-top:1rem;padding-top:.75rem;display:flex}.speed-emoji{flex-shrink:0;font-size:1.1rem}.speed-slider{accent-color:#e8b84b;cursor:pointer;flex:1}.speed-label{color:#aaa;text-align:right;flex-shrink:0;min-width:2.5rem;font-size:.85rem}.mode-toggle{gap:.5rem;width:100%;max-width:320px;display:flex}.session-mode-hint{color:#aaa;text-align:center;cursor:pointer;font-size:.8rem}.session-mode-hint:hover{color:#3b5bdb}.change-link{text-decoration:underline}.speak-area{flex-direction:column;align-items:center;gap:1rem;padding:1rem 0;display:flex}.mic-btn{cursor:pointer;background:#fff;border:3px solid #3b5bdb;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;font-size:2.5rem;transition:all .15s;display:flex}.mic-btn:hover{background:#f0f4ff;transform:scale(1.05)}.mic-btn.listening{background:#f44;border-color:#f44;animation:1s infinite pulse}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.mic-processing{color:#888;font-size:.95rem}.transcript-display{color:#555;text-align:center;font-size:.95rem}.transcript-text{color:#1a1a2e;font-size:1.3rem;font-weight:600}.speech-unsupported{color:#856404;text-align:center;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:.75rem 1rem;font-size:.9rem}.mic-listening-indicator{flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 1rem;display:flex;position:relative}.mic-pulse-ring{opacity:0;border:3px solid #3b5bdb;border-radius:50%;width:140px;height:140px;animation:1.2s ease-out infinite ring-pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes ring-pulse{0%{opacity:.8;transform:translate(-50%,-50%)scale(.8)}to{opacity:0;transform:translate(-50%,-50%)scale(1.6)}}.mic-icon-large{font-size:3.5rem;line-height:1}.mic-listening-label{color:#3b5bdb;margin:0;font-size:1.1rem;font-weight:600}.mic-listening-hint{color:#888;margin:0;font-size:.85rem}.btn-cancel-speech{color:#999;cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:.85rem;text-decoration:underline}.btn-cancel-speech:hover{color:#f44336}.spinner{border:3px solid #eee;border-top-color:#3b5bdb;border-radius:50%;width:32px;height:32px;margin:0 auto .5rem;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.phonetic-score{opacity:.85;font-size:.9rem}.phonetic-score-display{color:#555;text-align:center;font-size:.95rem}.speak-result{text-align:center;flex-direction:column;gap:.4rem;display:flex}.voice-test{color:#e0e0e0;max-width:860px;margin:0 auto;padding:2rem 1.5rem}.voice-test h1{color:#e8b84b;margin-bottom:1.5rem;font-size:1.8rem}.vt-section{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:10px;margin-bottom:2rem;padding:1.5rem}.vt-section h2{color:#c8c8ff;margin:0 0 .75rem;font-size:1.2rem}.polly-section{background:#15213a;border-color:#3a4a6a}.polly-section h2{color:#7eb8f7}.polly-note{border-left-color:#4a7abf!important}.vt-note{color:#aaa;background:#ffffff0a;border-left:3px solid #444;border-radius:4px;margin-bottom:1rem;padding:.6rem .8rem;font-size:.88rem;line-height:1.6}.test-sentence{color:#e8b84b;font-size:1rem;font-weight:500}.vt-warning{color:#f4a0a0;background:#3a1a1a;border:1px solid #6a3a3a;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.vt-count{color:#888;margin-bottom:.75rem;font-size:.85rem}.voice-table{border-collapse:collapse;width:100%;font-size:.9rem}.voice-table th{text-align:left;color:#888;white-space:nowrap;border-bottom:1px solid #2a2a4a;padding:.5rem .75rem;font-weight:600}.voice-table td{vertical-align:middle;border-bottom:1px solid #1e1e3a;padding:.55rem .75rem}.voice-table tr:last-child td{border-bottom:none}.voice-table.secondary{opacity:.75}.preferred-row{background:#e8b84b0f}.play-btn{color:#7aba7a;cursor:pointer;white-space:nowrap;background:#2a4a2a;border:1px solid #3a6a3a;border-radius:5px;padding:.3rem .75rem;font-size:.85rem;transition:background .15s,transform .1s}.play-btn:hover{color:#aaeaaa;background:#3a6a3a}.play-btn.playing{color:#f4a0a0;background:#4a2a2a;border-color:#8a4a4a}.pref-btn{color:#888;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #444;border-radius:5px;padding:.25rem .6rem;font-size:.82rem;transition:all .15s}.pref-btn:hover{color:#e8b84b;border-color:#e8b84b}.pref-btn.active{color:#e8b84b;background:#e8b84b26;border-color:#e8b84b}.tag{white-space:nowrap;border-radius:4px;padding:.15rem .5rem;font-size:.78rem;font-weight:600;display:inline-block}.tag-neural{color:#7eb8f7;background:#7eb8f726;border:1px solid #4a7abf}.tag-standard{color:#aaa;background:#b4b4b41a;border:1px solid #555}.other-voices{margin-top:1.25rem}.toggle-btn{color:#888;cursor:pointer;background:0 0;border:none;margin-bottom:.75rem;padding:.25rem 0;font-size:.9rem;transition:color .15s}.toggle-btn:hover{color:#ccc}code{background:#ffffff12;border-radius:3px;padding:.1rem .35rem;font-family:monospace;font-size:.85em}.settings-container{background:#0f0f1a;justify-content:center;align-items:flex-start;min-height:calc(100vh - 56px);padding:1.5rem 1rem;display:flex}.settings-card{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;flex-direction:column;gap:1.75rem;width:100%;max-width:480px;padding:2rem 1.5rem;display:flex}.settings-title{color:#e8b84b;text-align:center;margin:0;font-size:1.5rem;font-weight:700}.settings-section{flex-direction:column;gap:.75rem;display:flex}.settings-label{color:#888;text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.85rem;font-weight:600}.settings-hint{color:#555;margin:0;font-size:.8rem}.level-grid{flex-wrap:wrap;gap:.5rem;display:flex}.level-btn{color:#e0e0e0;cursor:pointer;background:#22223a;border:2px solid #3a3a5a;border-radius:8px;width:44px;height:44px;font-size:1rem;font-weight:600;transition:all .15s}.level-btn:hover:not(:disabled){background:#2e2e4e;border-color:#e8b84b}.level-btn.active{color:#1a1a2e;background:#e8b84b;border-color:#e8b84b}.level-btn.unavailable{opacity:.3;cursor:not-allowed}.mode-toggle{gap:.5rem;width:100%;display:flex}.mode-toggle-btn{color:#e0e0e0;cursor:pointer;background:#22223a;border:2px solid #3a3a5a;border-radius:10px;flex:1;min-height:48px;font-family:inherit;font-size:.9rem;transition:all .15s}.mode-toggle-btn:hover{background:#2e2e4e;border-color:#e8b84b}.mode-toggle-btn.active{color:#1a1a2e;background:#e8b84b;border-color:#e8b84b;font-weight:700}.voice-select{color:#e0e0e0;cursor:pointer;background:#22223a;border:1px solid #3a3a5a;border-radius:8px;outline:none;width:100%;padding:.65rem .75rem;font-size:.95rem}.voice-select:focus{border-color:#e8b84b}.voice-test-link{align-self:flex-start}.btn-primary{color:#1a1a2e;cursor:pointer;background:#e8b84b;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;transition:background .15s}.btn-primary:hover{background:#f5c95f}.btn-large{width:100%;padding:1rem;font-size:1.1rem}.btn-secondary{color:#aaa;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:8px;padding:.65rem 1.25rem;font-size:.95rem;transition:color .15s,border-color .15s}.btn-secondary:hover{color:#fff;border-color:#6a6a8a}
