:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:22px;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #f5f6fa;--surface: #ffffff;--surface-alt: #f9fafb;--surface-textarea: #f8fafc;--text-primary: #111827;--text-body: #1f2937;--text-secondary: #374151;--text-muted: #4b5563;--text-subtle: #6b7280;--text-faint: #9ca3af;--text-faintest: #b0b7c3;--border-light: #e5e7eb;--border-soft: #e9ecef;--border-medium: #d1d5db;--border-strong: #cbd5e1;--play-bg: #111827;--play-color: #ffffff;--play-hover-bg: #1f2937;--active-bg: #111827;--active-bg-alt: #374151;--active-color: #ffffff;--highlight-text: #2563eb;--highlight-bg: #eff6ff;--success-border: #15803d;--success-bg: #15803d;--success-hover: #166534;--success-text: #166534;--success-flash-bg: #ecfdf3;--danger-border: #ef4444;--danger-text: #b91c1c;--danger-hover: #dc2626;--score-default: #d1d5db;--score-good: #16a34a;--score-medium: #ca8a04;--score-poor: #dc2626;--help-accent: #6366f1;--help-accent-hover: #4f46e5;--shadow-sm: rgba(17, 24, 39, .08);--shadow-md: rgba(17, 24, 39, .12)}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-alt: #192236;--surface-textarea: #172032;--text-primary: #f1f5f9;--text-body: #e2e8f0;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-subtle: #64748b;--text-faint: #8da4be;--text-faintest: #7690a8;--border-light: #263347;--border-soft: #2d3d52;--border-medium: #334155;--border-strong: #3b4e66;--play-bg: #f1f5f9;--play-color: #0f172a;--play-hover-bg: #e2e8f0;--active-bg: #f1f5f9;--active-bg-alt: #cbd5e1;--active-color: #0f172a;--highlight-text: #60a5fa;--highlight-bg: #1e3a5f;--success-border: #16a34a;--success-bg: #16a34a;--success-hover: #15803d;--success-text: #4ade80;--success-flash-bg: #052e16;--danger-border: #f87171;--danger-text: #fca5a5;--danger-hover: #ef4444;--score-default: #475569;--score-good: #22c55e;--score-medium: #eab308;--score-poor: #f87171;--help-accent: #818cf8;--help-accent-hover: #6366f1;--shadow-sm: rgba(0, 0, 0, .25);--shadow-md: rgba(0, 0, 0, .35)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg);color:var(--text-body);transition:background .2s ease,color .2s ease}#root{min-height:100vh}.container{width:min(820px,100%);margin:0 auto;padding:1rem 1rem 2.5rem}.header h1{margin:0;font-size:2rem}.header p{margin:.5rem 0 0;color:var(--text-muted)}.topBar{display:flex;justify-content:flex-end;align-items:center;margin-top:.25rem}.nativeLanguageSelect{min-width:145px;border:1px solid var(--border-strong);border-radius:.75rem;background:var(--surface);color:var(--text-primary);padding:.42rem .6rem;font-size:.82rem}.topBarActions{display:inline-flex;gap:.5rem;align-items:center}.practiceHeader{display:flex;align-items:center;justify-content:flex-start;gap:.75rem;margin-bottom:1rem}.practiceHeader h2{margin:0}.settingsHeader{display:flex;align-items:center;justify-content:flex-start;gap:.75rem;margin-bottom:1rem}.settingsHeader h2{margin:0}.practiceLanguageSelect{min-width:170px;border:1px solid var(--border-strong);border-radius:.75rem;background:var(--surface);color:var(--text-primary);padding:.5rem .7rem;font-size:.9rem}.settingsVoiceInline{display:inline-flex;align-items:center;gap:.35rem}.settingsVoiceSelectInline{border:1px solid var(--border-medium);border-radius:.55rem;background:var(--surface);color:var(--text-primary);padding:.28rem .45rem;font-size:.72rem;width:9rem;min-width:0;max-width:100%}.settingsVoicePreviewStatus{font-size:.78rem;color:var(--text-muted);opacity:.92}.iconButton{width:2.1rem;height:2.1rem;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-strong);border-radius:.75rem;background:var(--surface);cursor:pointer;font-size:.95rem}.iconButton.isActive{border-color:var(--text-primary)}.tabs{display:flex;gap:.5rem;margin:1.5rem 0 1rem}.tab,button{border:1px solid var(--border-strong);border-radius:.75rem;background:var(--surface);color:var(--text-primary);padding:.6rem 1rem;font-size:.95rem;cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}.tab.isActive{border-color:var(--text-primary);font-weight:600}.card{background:var(--surface);border:1px solid var(--border-light);border-radius:1rem;padding:1.25rem}.card h2{margin-top:0}.field{display:grid;gap:.4rem;margin-bottom:1rem}.field select,.field input[type=number],.field input[type=range],.field textarea{width:100%}.field textarea{resize:vertical;padding:.7rem}.settingsTextarea{min-height:220px;border:0;border-radius:0;background:var(--surface-textarea);color:var(--text-primary);line-height:1.43;font-size:.78rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;margin:0;padding:.7rem;resize:none;overflow:auto;white-space:pre-wrap;overflow-wrap:break-word}.settingsTextarea:focus{outline:none}.settingsTextarea::placeholder{color:var(--text-subtle)}.settingsTextareaShell{min-height:220px;border:1px solid var(--border-medium);border-radius:.9rem;background:var(--surface-textarea);overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}.settingsTextareaShell:focus-within{border-color:var(--text-faint);box-shadow:0 0 0 3px var(--shadow-md)}.phraseBox{border:1px solid var(--border-light);border-radius:.75rem;padding:1rem;margin-bottom:1rem;background:var(--surface-alt);min-height:7.5rem;display:flex;flex-direction:column;gap:0}.phraseNotices{margin-top:auto;padding-top:.4rem;display:flex;flex-wrap:wrap;gap:.2rem .6rem;min-height:1.2rem}.phraseStatus{font-size:.7rem;color:var(--text-faint);line-height:1.4}.phraseError{font-size:.7rem;color:#ef4444;opacity:.8;line-height:1.4}.phraseText{margin:0;font-size:1.25rem;line-height:1.6}.phraseWord{display:inline;transition:color .1s ease,background-color .1s ease;border-radius:.2em;padding:0 .05em}.phraseWordClickable{cursor:pointer}.phraseWordClickable:hover{text-decoration:underline}.phraseWord+.phraseWord:before{content:" ";white-space:pre}.phraseWordActive{color:var(--highlight-text);background-color:var(--highlight-bg)}.phraseMeta{margin:.6rem 0 0;color:var(--text-muted);font-style:italic;line-height:1.5;font-size:.92rem;opacity:.88}.row{display:flex;gap:.5rem;flex-wrap:wrap}.settingsActions{margin-top:.25rem}.settingsActionButton{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;padding:.28rem .55rem;border-radius:.55rem;border-color:var(--border-medium);background:var(--surface);color:var(--text-primary);font-size:.78rem;font-weight:500;transition:border-color .2s ease,box-shadow .2s ease,transform .12s ease}.settingsActionButton:hover:not(:disabled){border-color:var(--text-faint);box-shadow:0 2px 8px var(--shadow-sm)}.settingsActionButton:active:not(:disabled){transform:translateY(1px)}.settingsActionButton:focus-visible{outline:none;box-shadow:0 0 0 3px var(--shadow-md)}.settingsActionButtonPrimary{border-color:var(--success-border);background:var(--success-bg);color:#fff}.settingsActionButtonPrimary:hover:not(:disabled){border-color:var(--success-hover);background:var(--success-hover)}.settingsActionButtonDanger{border-color:var(--danger-border);color:var(--danger-text)}.settingsActionButtonDanger:hover:not(:disabled){border-color:var(--danger-hover);box-shadow:0 2px 8px #dc26261f}.settingsActionIcon{line-height:1;font-size:.78rem}.settingsCounterItem{display:inline-flex;align-items:center;padding:.1rem .35rem;border:1px solid var(--border-light);border-radius:999px;background:var(--surface-alt);color:var(--text-faint);font-size:.68rem;font-weight:500}.settingsCounterInline{margin-inline-start:auto;align-self:center}.settingsSaveStatusInline{font-size:.76rem;color:var(--success-text);opacity:.92;align-self:center;white-space:nowrap}.settingsTextarea.isSuccessFlash{background:var(--success-flash-bg);transition:background .45s ease}.settingsTextareaGutter.isSuccessFlash{background:var(--success-flash-bg);color:var(--success-text);transition:background .45s ease,color .45s ease}.controlLine{display:flex;gap:.75rem;align-items:stretch;justify-content:center;flex-wrap:nowrap;margin-top:.65rem}.transportGroup{display:flex;gap:.45rem;align-items:center;justify-content:center;padding:.2rem .5rem;border:1px solid var(--border-light);border-radius:.9rem;background:var(--surface-alt);align-self:stretch}.transportBlock{display:flex;align-items:stretch}.inlineStatus{margin:0;padding-left:.2rem;font-size:.78rem;color:var(--text-subtle);opacity:.88}.keyboardHint{margin:.6rem 0 0;font-size:.76rem;color:var(--text-subtle);opacity:.9}.iconControlButton{width:2.2rem;height:2.2rem;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;color:var(--text-primary);background:var(--surface);border:1px solid var(--border-medium);box-shadow:0 1px 2px var(--shadow-sm)}.iconControlButton:hover:not(:disabled){border-color:var(--text-faint)}.playButton{width:2.4rem;height:2.4rem;background:var(--play-bg);color:var(--play-color);border-color:var(--play-bg)}.playButton:hover:not(:disabled){background:var(--play-hover-bg);border-color:var(--play-hover-bg)}.autoToggle{width:2rem;height:2rem;border:1px solid var(--border-strong);border-radius:999px;background:var(--surface);color:var(--text-primary);padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:600}.autoToggle.isActive{border-color:var(--active-bg);background:var(--active-bg);color:var(--active-color)}.autoToggle.smallToggle{width:1.8rem;height:1.8rem;border-color:var(--border-medium)}.autoToggle.smallToggle .iconGlyph{width:1rem;height:1rem}.autoToggle.smallToggle.isActive{border-color:var(--active-bg-alt);background:var(--active-bg-alt)}.iconGlyph{width:1.1rem;height:1.1rem}.miniFields{display:grid;grid-template-columns:auto repeat(3,minmax(80px,1fr));gap:.25rem;flex:1;padding:.2rem;border:1px solid var(--border-light);border-radius:.9rem;background:var(--surface-alt);align-items:stretch}.toggleColumn{display:flex;flex-direction:column;justify-content:center;gap:.15rem;border-right:1px solid var(--border-soft);padding-right:.4rem;margin-right:.05rem}.toggleColumnLabel{font-size:.6rem;color:var(--text-faintest);font-weight:500;text-transform:uppercase;letter-spacing:.05em;line-height:1;padding-left:.1rem}.toggleRow{display:flex;flex-direction:row;gap:.18rem;align-items:center}.miniField{min-width:60px;background:var(--surface);border:1px solid var(--border-light);border-radius:.6rem;padding:.1rem .3rem}.fieldGrid{display:grid;grid-template-columns:1fr;gap:.75rem;margin-top:1rem}.compactControls{gap:.5rem}.compactField{margin-bottom:0}.compactField span{font-size:.58rem;color:var(--text-faint);white-space:nowrap}.compactField input[type=number]{height:1.75rem;padding:.15rem .35rem;font-size:.82rem;border:1px solid var(--border-strong);border-radius:.45rem;background:var(--surface);color:var(--text-primary)}.compactField input[type=range]{height:.85rem}.compactField input[type=range]:disabled{opacity:.35;cursor:not-allowed}.compactField select{height:1.75rem;padding:.15rem .35rem;font-size:.82rem;border:1px solid var(--border-strong);border-radius:.45rem;background:var(--surface);color:var(--text-primary)}@media(max-width:900px){:root{font-size:18px}.controlLine{flex-direction:column;align-items:stretch;gap:.55rem}.transportGroup{width:100%;justify-content:center}.transportBlock{width:100%}.miniFields{grid-template-columns:repeat(3,1fr) auto;width:100%}.toggleColumnLabel{display:none}.settingsHeader{flex-wrap:wrap}}@media(max-width:640px){:root{font-size:16px}.card{padding:1rem}.practiceHeader,.settingsHeader{flex-wrap:wrap;align-items:flex-start;gap:.5rem}.practiceLanguageSelect{min-width:0;width:100%}.transportGroup{gap:.35rem;padding:.2rem}.transportBlock{width:100%}.iconControlButton,.playButton,.autoToggle{width:2.75rem;height:2.75rem}.controlLine{gap:.5rem}.miniFields{gap:.3rem;padding:.2rem;grid-template-columns:1fr 1fr 1fr}.toggleColumn{grid-column:1 / -1;flex-direction:row;align-items:center;border-left:none;border-top:1px solid var(--border-soft);padding-left:.1rem;padding-top:.3rem;margin-left:0;margin-top:.1rem}.toggleColumnLabel{display:none}.miniField{padding:.4rem .5rem}.inlineStatus{padding-left:0}.keyboardHint{font-size:.84rem;line-height:1.35;opacity:.96}.settingsActionButton{padding:.28rem .55rem;font-size:.78rem}.settingsSaveStatusInline,.settingsCounterInline{width:100%;margin-inline-start:0}.settingsTextarea{-webkit-overflow-scrolling:touch}.phraseMeta{font-size:.86rem;opacity:.78}}@media(min-width:900px){.fieldGrid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:end}}.status{margin:1rem 0 0;color:var(--text-secondary)}.errorText{margin:.75rem 0 0;color:var(--danger-text)}.autoToggle.isRecording{color:var(--danger-hover);animation:micPulse .9s ease-in-out infinite}@keyframes micPulse{0%,to{opacity:1}50%{opacity:.4}}.scoreDot{display:inline-block;width:.55rem;height:.55rem;border-radius:50%;flex-shrink:0;align-self:center;background:var(--score-default)}.scoreDot.score-good{background:var(--score-good)}.scoreDot.score-medium{background:var(--score-medium)}.scoreDot.score-poor{background:var(--score-poor)}.helpBackdrop{position:fixed;inset:0;background:#00000085;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem}.helpCard{background:var(--surface);border-radius:1rem;box-shadow:0 8px 32px var(--shadow-sm);max-width:26rem;width:100%;max-height:88vh;display:flex;flex-direction:column;overflow:hidden}.helpHeader{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.1rem .75rem;border-bottom:1px solid var(--border-light);flex-shrink:0}.helpTitle{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0}.helpCloseBtn{background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--text-subtle);padding:.2rem .35rem;border-radius:.35rem;line-height:1;transition:background .12s,color .12s}.helpCloseBtn:hover{background:var(--surface-alt);color:var(--text-primary)}.helpBody{flex:1;overflow-y:auto;display:flex;flex-direction:column}.helpIntro{margin:0;padding:.75rem 1.1rem .6rem;font-size:.79rem;line-height:1.55;color:var(--text-muted);background:var(--surface-alt);border-bottom:1px solid var(--border-light)}.helpStepList{list-style:decimal;padding:.8rem 1.1rem .8rem 2.1rem;margin:0;display:flex;flex-direction:column;gap:.8rem}.helpStep{display:flex;flex-direction:column;gap:.15rem;padding-left:.2rem}.helpStep::marker{color:var(--help-accent);font-weight:700;font-size:.82rem}.helpStepTitle{display:block;font-size:.82rem;font-weight:600;color:var(--text-secondary)}.helpStepText{display:block;font-size:.78rem;color:var(--text-subtle);line-height:1.45}.helpFooter{padding:.65rem 1.1rem .8rem;border-top:1px solid var(--border-light);display:flex;justify-content:center;flex-shrink:0}.helpFooterBtn{background:var(--help-accent);color:#fff;border:none;border-radius:.55rem;padding:.38rem 1.4rem;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .12s}.helpFooterBtn:hover{background:var(--help-accent-hover)}
