:root{--color-cream: #F5F5F7;--color-cream-dark: #E5E5EA;--color-warm-white: #FFFFFF;--color-sand: #D1D1D6;--color-terracotta: #0A84FF;--color-terracotta-dark: #0071E3;--color-terracotta-light: #409CFF;--color-sage: #34C759;--color-sage-dark: #248A3D;--color-charcoal: #1C1C1E;--color-charcoal-light: #3A3A3C;--color-text: #1C1C1E;--color-text-muted: #6E6E73;--color-error: #FF3B30;--color-success: #34C759;--color-border: #D1D1D6;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-display: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, sans-serif;--font-body: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .12);--transition-fast: .12s ease-out;--transition-normal: .2s ease-out;--transition-slow: .3s ease-out}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--color-cream);color:var(--color-text);line-height:1.5;min-height:100vh;min-height:100dvh}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.25;color:var(--color-text)}h1{font-size:1.75rem;letter-spacing:-.02em}h2{font-size:1.375rem;letter-spacing:-.01em}h3{font-size:1.125rem}.app{flex:1;display:flex;flex-direction:column;max-width:1200px;margin:0 auto;width:100%;padding:var(--space-md)}@media(min-width:768px){.app{padding:var(--space-lg)}}.header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) 0;margin-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.header-logo{display:flex;align-items:center;gap:var(--space-sm)}.header-logo-img{width:32px;height:32px;border-radius:var(--radius-sm)}.header-logo h1{font-size:1.25rem;font-weight:600;color:var(--color-text)}.header-logo-icon{display:none}.header-lang-select{display:flex;align-items:center;gap:var(--space-xs)}.header-lang-label{font-size:.75rem;color:var(--color-text-muted);display:none}@media(min-width:480px){.header-lang-label{display:block}}.nav{display:flex;gap:2px;background:var(--color-cream-dark);padding:2px;border-radius:var(--radius-md);margin-bottom:var(--space-lg)}.nav-item{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);min-height:44px;border:none;background:transparent;border-radius:calc(var(--radius-md) - 2px);font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.nav-item:hover{color:var(--color-text)}.nav-item.active{background:var(--color-warm-white);color:var(--color-terracotta);box-shadow:var(--shadow-sm)}.nav-item svg{width:18px;height:18px}@media(max-width:480px){.nav-item span{display:none}.nav-item{padding:var(--space-sm)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px var(--space-md);min-height:44px;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--color-terracotta);outline-offset:2px}.btn-primary{background:var(--color-terracotta);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-terracotta-dark)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-secondary{background:var(--color-warm-white);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-cream);border-color:var(--color-sand)}.btn-ghost{background:transparent;color:var(--color-text-muted)}.btn-ghost:hover:not(:disabled){background:var(--color-cream-dark);color:var(--color-text)}.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--radius-md)}.btn-icon svg{width:20px;height:20px}.btn-large{padding:14px var(--space-lg);font-size:1rem;font-weight:600}.btn-small{padding:6px var(--space-sm);min-height:32px;font-size:.8125rem;border-radius:var(--radius-sm)}.card{background:var(--color-warm-white);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--color-border)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.card-title{font-size:1.125rem;font-weight:600}.input{width:100%;padding:10px var(--space-md);min-height:44px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;background:var(--color-warm-white);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-terracotta);box-shadow:0 0 0 3px #0a84ff26}.input::placeholder{color:var(--color-text-muted)}.input:disabled{background:var(--color-cream);color:var(--color-text-muted);cursor:not-allowed}.textarea{min-height:120px;resize:vertical;line-height:1.5}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236E6E73' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;margin-bottom:var(--space-xs);font-weight:500;font-size:.875rem;color:var(--color-text)}.form-hint{font-size:.8125rem;color:var(--color-text-muted);margin-top:var(--space-xs)}.toggle{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer}.toggle-track{width:51px;height:31px;background:var(--color-cream-dark);border-radius:var(--radius-full);padding:2px;transition:background var(--transition-fast)}.toggle.active .toggle-track{background:var(--color-sage)}.toggle-thumb{width:27px;height:27px;background:#fff;border-radius:var(--radius-full);box-shadow:0 2px 4px #00000026;transition:transform var(--transition-fast)}.toggle.active .toggle-thumb{transform:translate(20px)}.slider-container{display:flex;align-items:center;gap:var(--space-md)}.slider{flex:1;-webkit-appearance:none;height:4px;background:var(--color-cream-dark);border-radius:var(--radius-full);outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:28px;height:28px;background:#fff;border-radius:var(--radius-full);cursor:pointer;box-shadow:0 2px 6px #0003;border:1px solid var(--color-border)}.slider::-moz-range-thumb{width:28px;height:28px;background:#fff;border-radius:var(--radius-full);cursor:pointer;border:1px solid var(--color-border);box-shadow:0 2px 6px #0003}.slider-value{font-weight:600;font-size:.875rem;min-width:48px;text-align:center;color:var(--color-terracotta)}.slider-labels{display:flex;justify-content:space-between;margin-top:var(--space-xs);font-size:.75rem;color:var(--color-text-muted)}.script-list{display:flex;flex-direction:column;gap:var(--space-sm)}.script-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);background:var(--color-warm-white);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:border-color var(--transition-fast)}.script-item:hover{border-color:var(--color-sand)}.script-info{flex:1;min-width:0}.script-title{font-weight:600;font-size:1rem;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.script-meta{display:flex;gap:var(--space-sm);font-size:.8125rem;color:var(--color-text-muted)}.script-actions{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.line-list{display:flex;flex-direction:column;gap:2px;max-height:300px;overflow-y:auto;background:var(--color-cream);border-radius:var(--radius-md);padding:var(--space-xs)}.line-item{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);font-size:.9375rem;line-height:1.4}.line-item:hover{background:var(--color-cream-dark)}.line-item.active{background:var(--color-terracotta);color:#fff}.line-item.completed,.line-item.completed .line-number{color:var(--color-sage)}.line-item.active.completed{color:#fff}.line-number{font-size:.75rem;font-weight:600;color:var(--color-text-muted);min-width:24px;padding-top:2px}.line-item.active .line-number{color:#ffffffb3}.line-text{flex:1}.current-line{background:var(--color-warm-white);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);border:1px solid var(--color-border);text-align:center}.current-line-label{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.current-line-text{font-size:1.5rem;font-weight:500;line-height:1.4;margin-bottom:var(--space-md);color:var(--color-text)}.current-line-translation{font-size:1rem;color:var(--color-text-muted);padding:var(--space-sm) var(--space-md);background:var(--color-cream);border-radius:var(--radius-sm);margin-top:var(--space-sm)}.transcript-display{margin-top:var(--space-md);padding:var(--space-md);background:var(--color-cream);border-radius:var(--radius-md);text-align:left}.transcript-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.transcript-text{font-size:.9375rem;color:var(--color-text-muted);font-style:italic}.score-display{text-align:center;padding:var(--space-md);margin-bottom:var(--space-md)}.score-circle{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;width:100px;height:100px;border-radius:var(--radius-full);background:var(--color-cream);margin-bottom:var(--space-sm)}.score-circle.success{background:#34c75926;color:var(--color-sage)}.score-circle.fail{background:#ff3b301a;color:var(--color-error)}.score-value{font-size:2rem;font-weight:700;line-height:1}.score-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.score-feedback{font-size:1rem;font-weight:500;color:var(--color-text)}.record-btn-container{display:flex;flex-direction:column;align-items:center;margin:var(--space-lg) 0}.record-btn{width:80px;height:80px;border-radius:var(--radius-full);border:none;background:var(--color-terracotta);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:0 4px 12px #0a84ff4d}.record-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 6px 16px #0a84ff66}.record-btn:active:not(:disabled){transform:scale(.95)}.record-btn:disabled{opacity:.4;cursor:not-allowed}.record-btn.recording{background:var(--color-error);animation:pulse 1.5s ease-in-out infinite;box-shadow:0 4px 12px #ff3b3066}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.record-btn svg{width:32px;height:32px}.record-btn-label{margin-top:var(--space-sm);font-size:.875rem;font-weight:500;color:var(--color-text-muted)}.controls{display:flex;justify-content:center;gap:var(--space-sm);margin-top:var(--space-md)}.practice-options{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-md);margin:var(--space-md) 0;padding:var(--space-md);background:var(--color-warm-white);border-radius:var(--radius-md);border:1px solid var(--color-border)}.practice-option{display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem}.pause-selector{display:flex;gap:2px;background:var(--color-cream);padding:2px;border-radius:var(--radius-sm)}.pause-btn{padding:6px 12px;border:none;background:transparent;border-radius:calc(var(--radius-sm) - 2px);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-muted)}.pause-btn:hover{color:var(--color-text)}.pause-btn.active{background:var(--color-warm-white);color:var(--color-terracotta);box-shadow:var(--shadow-sm)}.language-controls{display:flex;flex-wrap:wrap;gap:var(--space-md);padding:var(--space-md);background:var(--color-warm-white);border-radius:var(--radius-md);border:1px solid var(--color-border);margin-bottom:var(--space-md)}.language-control{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;min-width:140px}.language-control-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.language-control .select{font-size:.875rem;padding:8px 36px 8px 12px;min-height:36px}.mobile-lang-toggle{display:none}@media(max-width:640px){.language-controls{display:none}.language-controls.expanded{display:flex;flex-direction:column}.mobile-lang-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);width:100%;padding:var(--space-sm);margin-bottom:var(--space-sm);background:var(--color-warm-white);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text-muted);cursor:pointer}.mobile-lang-toggle:hover{background:var(--color-cream)}}@media(min-width:641px){.language-controls{display:flex!important}}.progress-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm);margin-bottom:var(--space-lg)}@media(min-width:480px){.progress-grid{grid-template-columns:repeat(4,1fr)}}.progress-stat{background:var(--color-warm-white);padding:var(--space-md);border-radius:var(--radius-md);text-align:center;border:1px solid var(--color-border)}.progress-stat-value{font-size:1.75rem;font-weight:700;font-family:var(--font-display);color:var(--color-terracotta)}.progress-stat-label{font-size:.6875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;padding:var(--space-md);z-index:1000;animation:fadeIn var(--transition-fast)}.modal{background:var(--color-warm-white);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp var(--transition-normal)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.modal-title{font-size:1.125rem}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;border-radius:var(--radius-sm);color:var(--color-text-muted);transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-cream);color:var(--color-text)}.modal-body{padding:var(--space-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}.help-section:last-child{margin-bottom:0}.help-section h3{color:var(--color-terracotta);margin-bottom:var(--space-sm);font-size:1rem}.help-section p{color:var(--color-text-muted);font-size:.9375rem;line-height:1.6;white-space:pre-line}.limit-message{background:#ff3b3014;border:1px solid rgba(255,59,48,.2);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;margin-bottom:var(--space-md)}.limit-message h3{color:var(--color-error);margin-bottom:var(--space-xs);font-size:1rem}.limit-message p{color:var(--color-text-muted);font-size:.875rem;margin-bottom:var(--space-sm)}.limit-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:4px 10px;background:var(--color-cream);border-radius:var(--radius-full);font-size:.75rem;font-weight:500;color:var(--color-text-muted)}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-md)}.empty-state-icon{width:64px;height:64px;margin:0 auto var(--space-md);opacity:.4}.empty-state-logo{width:48px;height:48px;margin:0 auto var(--space-md);opacity:.3;border-radius:var(--radius-sm)}.empty-state h3{margin-bottom:var(--space-xs);font-size:1.125rem}.empty-state p{color:var(--color-text-muted);font-size:.9375rem;margin-bottom:var(--space-lg)}.import-section{margin-bottom:var(--space-lg)}.import-tabs{display:flex;gap:2px;background:var(--color-cream-dark);padding:2px;border-radius:var(--radius-md);margin-bottom:var(--space-md)}.import-tab{flex:1;padding:var(--space-sm);min-height:40px;border:none;background:transparent;border-radius:calc(var(--radius-md) - 2px);font-weight:500;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-muted)}.import-tab:hover{color:var(--color-text)}.import-tab.active{background:var(--color-warm-white);color:var(--color-terracotta);box-shadow:var(--shadow-sm)}.file-drop{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--space-2xl);text-align:center;cursor:pointer;transition:all var(--transition-fast)}.file-drop:hover,.file-drop.dragover{border-color:var(--color-terracotta);background:#0a84ff0a}.file-drop input{display:none}.file-drop-icon{width:40px;height:40px;margin:0 auto var(--space-sm);color:var(--color-text-muted)}.session-complete{text-align:center;padding:var(--space-2xl) var(--space-md)}.session-complete-icon{width:72px;height:72px;background:var(--color-sage);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md);color:#fff;font-size:2rem}.session-complete h2{margin-bottom:var(--space-md)}.session-stats{display:flex;justify-content:center;gap:var(--space-xl);margin-bottom:var(--space-lg)}.session-stat{text-align:center}.session-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-terracotta)}.session-stat-label{font-size:.75rem;color:var(--color-text-muted)}.settings-section{margin-bottom:var(--space-lg)}.settings-section>h3{margin-bottom:var(--space-sm);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.settings-row:last-child{border-bottom:none}.settings-label{font-weight:500}.settings-desc{font-size:.8125rem;color:var(--color-text-muted);margin-top:2px}.coming-soon{position:relative;opacity:.6}.coming-soon:after{content:attr(data-label);position:absolute;top:var(--space-sm);right:var(--space-sm);padding:4px 8px;background:var(--color-cream-dark);border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.spinner{width:20px;height:20px;border:2px solid var(--color-cream);border-top-color:var(--color-terracotta);border-radius:var(--radius-full);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.audio-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.audio-btn.playing{background:var(--color-sage)}.practice-layout{display:flex;flex-direction:column;gap:var(--space-md)}@media(min-width:900px){.practice-layout{flex-direction:row;align-items:flex-start}.practice-main{flex:1;min-width:0}.practice-sidebar{width:320px;flex-shrink:0;position:sticky;top:var(--space-md);max-height:calc(100vh - 100px);overflow-y:auto;background:var(--color-warm-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:var(--space-md)}.practice-sidebar .line-list{max-height:none}}.lines-drawer-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);width:100%;padding:var(--space-sm);background:var(--color-warm-white);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;margin-bottom:var(--space-md)}.lines-drawer-toggle:hover{background:var(--color-cream)}@media(min-width:900px){.lines-drawer-toggle{display:none}}.lines-drawer{display:none;margin-bottom:var(--space-md)}.lines-drawer.open{display:block}@media(min-width:900px){.lines-drawer{display:none!important}}.focus-mode .header,.focus-mode .nav,.focus-mode .practice-sidebar,.focus-mode .lines-drawer-toggle,.focus-mode .language-controls,.focus-mode .mobile-lang-toggle,.focus-mode .limit-badge{display:none!important}.focus-mode .app{max-width:600px}.focus-mode .current-line-text{font-size:2rem;line-height:1.35}.focus-mode .practice-options{background:transparent;border:none;padding:var(--space-sm)}.focus-mode .record-btn{width:100px;height:100px}.focus-mode .record-btn svg{width:40px;height:40px}.edit-form{display:flex;flex-direction:column;gap:var(--space-md)}.edit-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;padding-top:var(--space-md);border-top:1px solid var(--color-border)}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.mt-xs{margin-top:var(--space-xs)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-xs{margin-bottom:var(--space-xs)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-sand);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.pause-duration-display{display:flex;flex-direction:column;gap:var(--space-sm);width:100%;max-width:280px}.pause-duration-value{text-align:center;font-size:.875rem;color:var(--color-text-muted)}.pause-duration-value strong{color:var(--color-terracotta);font-weight:600}.chunk-nav{display:flex;justify-content:center;align-items:center;gap:var(--space-sm);margin:var(--space-sm) 0 var(--space-md)}.chunk-nav .btn{min-height:36px}.practice-option-wide{width:100%;max-width:520px;flex:1 1 520px;display:flex;flex-direction:column;gap:var(--space-sm)}.current-line-emphasized{background:var(--color-warm-white);border:2px solid var(--color-terracotta);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md)}.current-line-emphasized .current-line-text{font-size:1.5rem;font-weight:600;color:var(--color-charcoal);line-height:1.4}.current-line-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.save-line-btn{color:var(--color-text-muted);transition:color var(--transition-fast)}.save-line-btn:hover{color:var(--color-terracotta)}.comprehension-translation{font-size:1rem;color:var(--color-text-muted);margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-cream);border-radius:var(--radius-sm);text-align:center;transition:opacity var(--transition-normal);cursor:pointer}.comprehension-translation.hidden{opacity:.5;background:var(--color-cream-dark)}.comprehension-translation .tap-to-show{font-style:italic;color:var(--color-text-muted)}.transcript-highlighted{line-height:1.6}.word-correct{color:var(--color-success);font-weight:500}.word-incorrect{color:var(--color-error);font-weight:500}.score-circle.animating{animation:scorePopIn .6s ease-out}.rotating-status{transition:opacity var(--transition-fast)}.saved-toast{position:fixed;bottom:var(--space-xl);left:50%;transform:translate(-50%);background:var(--color-charcoal);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem;font-weight:500;z-index:1000;animation:toastSlideUp var(--transition-normal);box-shadow:var(--shadow-lg)}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.focus-toggle{position:fixed;top:var(--space-md);right:var(--space-md);z-index:100;padding:var(--space-sm) var(--space-md);background:var(--color-warm-white);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.8125rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:var(--space-xs);box-shadow:var(--shadow-md)}@media(max-width:767px){.focus-toggle{top:auto;bottom:var(--space-md);right:var(--space-md)}}.focus-toggle:hover{background:var(--color-cream)}.focus-mode .focus-toggle{background:var(--color-terracotta);color:#fff;border-color:var(--color-terracotta)}.focus-mode .focus-toggle:hover{background:var(--color-terracotta-dark)}.line-content{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.line-translation{font-size:.75rem;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-item.active .line-translation{color:var(--color-terracotta-light)}.saved-line-card{background:var(--color-warm-white);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.saved-line-content{margin-bottom:var(--space-sm)}.saved-line-text{font-size:1.125rem;font-weight:500;color:var(--color-text);line-height:1.4}.saved-line-translation{display:block;font-size:.9375rem;color:var(--color-text-muted);margin-top:var(--space-xs)}.saved-line-yousaid{background:var(--color-cream);padding:var(--space-sm);border-radius:var(--radius-sm);font-size:.875rem;margin-bottom:var(--space-sm)}.saved-line-yousaid-label{font-weight:500;color:var(--color-text-muted);margin-right:var(--space-xs)}.saved-line-meta{display:flex;gap:var(--space-md);font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.saved-line-source{font-style:italic}.saved-line-lang{background:var(--color-cream);padding:2px var(--space-xs);border-radius:var(--radius-sm)}.saved-line-note-section{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border)}.saved-line-note{font-size:.875rem;color:var(--color-text-muted);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.saved-line-note:hover{background:var(--color-cream)}.saved-line-note-label{font-weight:500;margin-right:var(--space-xs)}.saved-line-note-edit{display:flex;flex-direction:column;gap:var(--space-sm)}.saved-line-note-actions{display:flex;justify-content:flex-end;gap:var(--space-sm)}.saved-line-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-sm)}.transcript-display{background:var(--color-cream);border-radius:var(--radius-md);padding:var(--space-md);margin:var(--space-md) 0}.transcript-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.transcript-text{font-size:1rem;color:var(--color-text)}.score-display{text-align:center;margin:var(--space-md) 0}.score-circle{width:80px;height:80px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto var(--space-sm);border:3px solid var(--color-border)}.score-circle.success{border-color:var(--color-success);background:#34c7591a}.score-circle.fail{border-color:var(--color-error);background:#ff3b301a}.score-value{font-size:1.5rem;font-weight:700;font-family:var(--font-display)}.score-circle.success .score-value{color:var(--color-success)}.score-circle.fail .score-value{color:var(--color-error)}.score-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.score-feedback{font-size:.9375rem;font-weight:500;color:var(--color-text)}.current-line-translation{margin-top:var(--space-sm);padding:var(--space-sm);background:var(--color-cream);border-radius:var(--radius-sm);color:var(--color-text-muted);text-align:center}@media(max-width:640px){.focus-toggle{top:auto;bottom:var(--space-xl);right:var(--space-md);z-index:100}}.current-line-emphasized{background:var(--color-warm-white);border:2px solid var(--color-terracotta);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 4px 20px #0a84ff26;position:relative}.current-line-emphasized:before{content:"";position:absolute;inset:-2px;border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(10,132,255,.1),transparent);z-index:-1}.current-line-emphasized .current-line-text{font-size:1.625rem;font-weight:600;color:var(--color-text)}.comprehension-translation{font-size:.9375rem;color:var(--color-text-muted);padding:var(--space-sm) var(--space-md);background:var(--color-cream);border-radius:var(--radius-sm);margin-bottom:var(--space-md);text-align:center;transition:opacity var(--transition-normal),max-height var(--transition-normal);cursor:pointer}.comprehension-translation.hidden{opacity:.3;max-height:20px;overflow:hidden}.comprehension-translation.hidden:after{content:" (tap to show)";font-size:.75rem;color:var(--color-text-muted)}.current-line.comprehension-first{border-color:var(--color-sage)}.current-line.comprehension-first:before{background:linear-gradient(135deg,rgba(52,199,89,.1),transparent)}.transcript-highlighted{font-style:normal}.word-correct{color:var(--color-sage);font-weight:500}.word-incorrect{color:var(--color-error);font-weight:500;text-decoration:underline;text-decoration-style:wavy;text-underline-offset:3px}.line-translation-inline{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:2px;font-style:italic}.line-item.active .line-translation-inline{color:var(--color-terracotta-light)}.select-small{padding:6px 28px 6px 10px!important;font-size:.8125rem!important;min-height:32px!important;min-width:140px}.record-btn-label{min-height:1.25em}.header-focus-btn{display:flex;align-items:center;gap:var(--space-xs);padding:6px 12px;background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);color:var(--color-text)}.header-focus-btn:hover{background:var(--color-cream-dark)}.header-focus-btn.active{background:var(--color-terracotta);color:#fff;border-color:var(--color-terracotta)}.header-focus-btn.active:hover{background:var(--color-terracotta-dark)}.focus-toggle{display:none!important}.comprehension-translation{font-size:1.125rem;font-weight:500;color:var(--color-text);padding:var(--space-md);background:linear-gradient(135deg,#0a84ff14,#34c75914);border-radius:var(--radius-md);margin-bottom:var(--space-md);text-align:center;transition:filter var(--transition-normal);cursor:pointer;position:relative;border:1px solid rgba(10,132,255,.2)}.comprehension-translation.blurred{filter:blur(8px);-webkit-user-select:none;user-select:none}.comprehension-translation .tap-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;color:var(--color-terracotta);font-weight:600;text-transform:uppercase;letter-spacing:.05em;filter:none;background:var(--color-warm-white);padding:4px 12px;border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.current-line-translation{font-size:.9375rem;color:var(--color-text-muted);padding:var(--space-sm) var(--space-md);background:var(--color-cream);border-radius:var(--radius-sm);margin-top:var(--space-sm)}.transcript-highlighted{font-style:normal;text-align:center}.word-correct{background:#34c75926;color:var(--color-sage-dark);padding:2px 4px;border-radius:4px;margin:0 1px;font-weight:500}.word-incorrect{background:#ff3b3026;color:var(--color-error);padding:2px 4px;border-radius:4px;margin:0 1px;font-weight:500;text-decoration:underline;text-decoration-style:wavy;text-decoration-color:var(--color-error);text-underline-offset:3px}.feedback-area{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);margin:var(--space-md) 0}.feedback-area .transcript-display{margin:0;width:100%;max-width:500px;text-align:center}.feedback-area .score-display{margin:0;padding:var(--space-sm)}.feedback-area .score-circle{width:80px;height:80px}.feedback-area .score-value{font-size:1.5rem}.feedback-area .record-btn-container{margin:var(--space-sm) 0}.feedback-area .record-btn{width:70px;height:70px}.feedback-area .record-btn svg{width:28px;height:28px}.line-item{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.line-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.line-text{font-size:.875rem;color:var(--color-text);word-wrap:break-word}.line-translation-below{font-size:.75rem;color:var(--color-text-muted);font-style:italic;word-wrap:break-word;line-height:1.4}.line-item.active .line-translation-below{color:#fffc}.line-translation-inline{display:none}.header-logo-img{width:32px;height:32px;border-radius:var(--radius-sm);object-fit:contain}.header-actions{display:flex;align-items:center;gap:var(--space-sm)}.select-small{padding:6px 28px 6px 10px!important;font-size:.8125rem!important;min-height:32px!important;min-width:130px}.save-line-row{display:flex;justify-content:center}.saved-line-btn{color:var(--color-terracotta)}.saved-line-btn svg{fill:var(--color-terracotta)}.saved-lines-list{display:flex;flex-direction:column;gap:var(--space-md)}.saved-line-item{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);background:var(--color-cream);border-radius:var(--radius-md)}.saved-line-content{flex:1;min-width:0}.saved-line-text{font-weight:500;margin-bottom:var(--space-xs)}.saved-line-note{font-size:.8125rem;color:var(--color-terracotta);margin-bottom:var(--space-xs)}.saved-line-yousaid{font-size:.8125rem;color:var(--color-text-muted);font-style:italic;margin-bottom:var(--space-xs)}.saved-line-meta{font-size:.75rem;color:var(--color-text-muted)}.modal.modal-large{max-width:600px;max-height:80vh}.score-circle.score-animating{animation:scorePopIn .6s cubic-bezier(.175,.885,.32,1.275)}@keyframes scorePopIn{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.practice-option-title{font-size:.875rem;color:var(--color-text-muted)}.focus-mode .header-focus-btn{background:var(--color-terracotta);color:#fff;border-color:var(--color-terracotta)}.focus-mode .header{display:flex!important}.my-lines-view{max-width:800px}.my-lines-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.my-lines-header h2{margin:0}.my-lines-content{display:flex;flex-direction:column;gap:var(--space-lg)}.my-lines-group{background:var(--color-warm-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.my-lines-group-title{padding:var(--space-md);background:var(--color-cream);font-size:.875rem;font-weight:600;color:var(--color-text-muted);margin:0;border-bottom:1px solid var(--color-border)}.my-lines-list{padding:var(--space-sm)}.my-line-card{display:flex;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);transition:background var(--transition-fast)}.my-line-card:hover{background:var(--color-cream)}.my-line-card+.my-line-card{border-top:1px solid var(--color-border)}.my-line-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-xs)}.my-line-text{font-size:1.0625rem;font-weight:500;color:var(--color-text);line-height:1.4}.my-line-translation{font-size:.9375rem;color:var(--color-terracotta);padding:var(--space-sm);background:#0a84ff14;border-radius:var(--radius-sm);border-left:3px solid var(--color-terracotta)}.my-line-note{display:flex;align-items:center;gap:var(--space-xs);font-size:.8125rem;color:var(--color-sage-dark);font-style:italic}.my-line-note svg{flex-shrink:0;color:var(--color-sage)}.my-line-yousaid{font-size:.8125rem;color:var(--color-text-muted)}.my-line-yousaid-label{font-weight:600;margin-right:var(--space-xs)}.my-line-meta{display:flex;gap:var(--space-md);font-size:.75rem;color:var(--color-text-muted)}.my-line-lang{background:var(--color-cream);padding:2px 8px;border-radius:var(--radius-sm)}.my-line-actions .btn-icon.active{color:var(--color-terracotta);background:#0a84ff1a}.save-line-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;background:linear-gradient(135deg,#0a84ff1a,#34c7591a);border:2px dashed var(--color-terracotta);border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;color:var(--color-terracotta);cursor:pointer;transition:all var(--transition-fast)}.save-line-btn:hover{background:linear-gradient(135deg,#0a84ff26,#34c75926);border-style:solid;transform:scale(1.02)}.save-line-btn.saved{background:var(--color-terracotta);border-color:var(--color-terracotta);border-style:solid;color:#fff}.save-line-btn.saved:hover{background:var(--color-terracotta-dark);border-color:var(--color-terracotta-dark)}.save-line-btn.saved svg{fill:#fff}.save-line-row{display:flex;justify-content:center;margin-top:var(--space-md)}@media(max-width:640px){.my-lines-header{flex-direction:column;align-items:stretch}.my-lines-header h2{text-align:center}.my-line-card{flex-direction:column}.my-line-actions{flex-direction:row;justify-content:flex-end}}.focus-progress-bar{height:8px;background:var(--color-cream);border-radius:var(--radius-full);margin:var(--space-lg) 0;position:relative;overflow:hidden}.focus-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-sage),var(--color-terracotta));border-radius:var(--radius-full);transition:width .3s ease}.focus-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;max-width:800px;margin:0 auto;width:100%}.focus-translation{font-size:1.25rem;color:var(--color-terracotta);padding:var(--space-md);background:#0a84ff1a;border-radius:var(--radius-md);margin-bottom:var(--space-lg);transition:filter .3s ease}.focus-translation.blurred{filter:blur(8px);cursor:pointer}.focus-line-meta{font-size:1rem;color:var(--color-text-muted);margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-md)}.focus-unit-count{background:var(--color-cream);padding:2px 8px;border-radius:var(--radius-sm);font-size:.875rem}.focus-target-text{font-size:2.5rem;font-weight:600;line-height:1.3;color:var(--color-text);margin-bottom:var(--space-lg)}.focus-nav{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.focus-play-btn{width:64px;height:64px;border-radius:var(--radius-full);background:var(--color-cream);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.focus-transcript{margin-bottom:var(--space-md)}.focus-transcript-label{font-size:.875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.focus-transcript-text{font-size:1.5rem}.focus-score{padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg);margin-bottom:var(--space-lg)}.focus-score.success{background:#34c75926}.focus-score.fail{background:#ff3b301a}.focus-score-value{font-size:3rem;font-weight:700;display:block}.focus-score.success .focus-score-value{color:var(--color-sage)}.focus-score.fail .focus-score-value{color:var(--color-error)}.focus-score-feedback{font-size:1rem;color:var(--color-text-muted)}.focus-record-area{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.focus-record-label{font-size:1.125rem;color:var(--color-text-muted)}@media(max-width:640px){.focus-target-text{font-size:1.75rem}.focus-nav-btn{padding:10px 16px;font-size:.875rem}.focus-play-btn{width:50px;height:50px}.focus-record-btn{width:80px;height:80px}.focus-score-value{font-size:2.5rem}}.focus-mode .header{display:none!important}.voice-analysis-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-md)}.voice-analysis-container.compact{padding:var(--space-sm);flex-direction:row;gap:var(--space-md)}.waveform-bars{display:flex;align-items:center;justify-content:center;gap:4px;height:40px}.waveform-bars span{width:4px;background:var(--color-terracotta);border-radius:2px;animation:waveform 1s ease-in-out infinite}.waveform-bars span:nth-child(1){animation-delay:0s;height:20px}.waveform-bars span:nth-child(2){animation-delay:.1s;height:30px}.waveform-bars span:nth-child(3){animation-delay:.2s;height:40px}.waveform-bars span:nth-child(4){animation-delay:.3s;height:30px}.waveform-bars span:nth-child(5){animation-delay:.4s;height:20px}.voice-analysis-parrot{width:48px;height:48px}.voice-analysis-parrot img{width:100%;height:100%;object-fit:contain}.analysis-status{font-size:.875rem;color:var(--color-text-muted)}.script-progress-header{margin-bottom:var(--space-md)}.script-progress-bar{height:6px;background:var(--color-cream);border-radius:var(--radius-full);overflow:hidden}.script-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-sage),var(--color-terracotta));transition:width .3s ease}.script-progress-text{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-xs)}.unit-count-badge{background:var(--color-cream);padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;margin-left:var(--space-sm)}.line-unit-count{font-size:.6875rem;color:var(--color-text-muted);margin-top:2px}.level-progress-card{background:linear-gradient(135deg,var(--color-terracotta),var(--color-sage));border-radius:var(--radius-lg);padding:var(--space-lg);color:#fff}.level-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.level-badge{font-size:1.5rem;font-weight:700}.level-xp{font-size:.875rem;opacity:.9}.level-progress-bar{height:12px;background:#ffffff4d;border-radius:var(--radius-full);overflow:hidden}.level-progress-fill{height:100%;background:#fff;border-radius:var(--radius-full);transition:width .5s ease}.level-progress-text{font-size:.75rem;text-align:center;margin-top:var(--space-xs);opacity:.9}.share-section{background:var(--color-cream);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center}.share-buttons{display:flex;justify-content:center;gap:var(--space-sm);flex-wrap:wrap}.share-btn{display:flex;align-items:center;gap:var(--space-xs);padding:10px 16px;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.share-btn.copy{background:var(--color-warm-white);border:1px solid var(--color-border);color:var(--color-text)}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.progress-header h2{margin:0}.xp-explanation h4{color:var(--color-terracotta);margin-bottom:var(--space-sm)}.xp-item{display:flex;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border)}.celebration-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease}.celebration-modal{background:#fff;border-radius:var(--radius-xl);padding:var(--space-xl);text-align:center;animation:celebrationPop .5s cubic-bezier(.175,.885,.32,1.275)}.celebration-icon{font-size:4rem;margin-bottom:var(--space-md)}.celebration-modal h2{color:var(--color-terracotta);margin-bottom:var(--space-sm)}.celebration-xp{font-size:1.5rem;font-weight:700;color:var(--color-sage);margin-top:var(--space-md)}@keyframes celebrationPop{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.my-line-player{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.my-line-player-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-top:var(--space-md)}.record-btn-mini{width:50px;height:50px;border-radius:var(--radius-full);background:var(--color-terracotta);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.record-btn-mini:hover:not(:disabled){transform:scale(1.05)}.record-btn-mini.recording{background:var(--color-error);animation:pulse 1.5s ease-in-out infinite}.my-line-transcript{padding:var(--space-sm);background:var(--color-warm-white);border-radius:var(--radius-sm);margin-bottom:var(--space-sm)}.my-line-score{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md)}.my-line-score.success{background:#34c75926;color:var(--color-sage-dark)}.my-line-score.fail{background:#ff3b301a;color:var(--color-error)}.my-line-score .score-value{font-size:1.25rem;font-weight:700}.set-progress{margin-top:var(--space-sm)}.set-progress-bar{height:4px;background:var(--color-cream-dark);border-radius:var(--radius-full);overflow:hidden}.set-progress-fill{height:100%;background:var(--color-sage);transition:width .3s ease}.set-progress-text{font-size:.6875rem;color:var(--color-text-muted);margin-top:2px}.my-line-stats{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-xs)}.my-line-reps,.my-line-sets,.my-line-unit-count{font-size:.75rem;color:var(--color-text-muted)}.my-line-sets{color:var(--color-terracotta);font-weight:500}.creator-library-card{display:block;position:relative;text-decoration:none;color:inherit;transition:all var(--transition-fast);border:2px dashed var(--color-border)}.creator-library-card:hover{border-color:var(--color-terracotta);transform:translateY(-2px);box-shadow:var(--shadow-md)}.creator-library-card h3{color:var(--color-text-muted);margin-bottom:var(--space-xs)}.coming-soon-badge{position:absolute;top:var(--space-sm);right:var(--space-sm);background:var(--color-terracotta);color:#fff;font-size:.6875rem;font-weight:600;padding:4px 8px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em}.help-content{max-height:60vh;overflow-y:auto}.help-section{margin-bottom:var(--space-lg)}.help-section h3{margin-bottom:var(--space-sm);color:var(--color-terracotta)}.help-section p,.help-section li{color:var(--color-text-muted);line-height:1.6}.help-section ol,.help-section ul{margin-left:var(--space-md);margin-top:var(--space-xs)}.help-section li{margin-bottom:var(--space-xs)}.help-tip{background:#0a84ff1a;padding:var(--space-sm);border-radius:var(--radius-sm);margin-top:var(--space-sm);border-left:3px solid var(--color-terracotta)}.empty-state-logo{width:64px;height:64px;margin-bottom:var(--space-md);opacity:.5}.btn-danger{background:var(--color-error)!important;color:#fff!important}.btn-danger:hover{background:#e53935!important}.focus-mode .header,.focus-mode .nav{display:none!important}.focus-mode-container{position:fixed;inset:0;background:var(--color-warm-white);z-index:1000;display:flex;flex-direction:column;padding:var(--space-md);overflow-y:auto}.focus-exit-btn{position:absolute;top:var(--space-md);right:var(--space-md);display:flex;align-items:center;gap:var(--space-xs);padding:8px 16px;background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;z-index:10}.focus-exit-btn:hover{background:var(--color-cream-dark)}.focus-progress-bar{width:100%;max-width:600px;height:8px;background:var(--color-cream);border-radius:4px;margin:0 auto var(--space-lg);position:relative;overflow:hidden}.focus-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-sage),var(--color-terracotta));border-radius:4px;transition:width var(--transition-normal)}.focus-progress-text{position:absolute;right:0;top:12px;font-size:.75rem;color:var(--color-text-muted)}.focus-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:700px;margin:0 auto;text-align:center;padding:var(--space-lg)}.focus-line-label{font-size:1rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.focus-line-text{font-size:2.5rem;font-weight:600;line-height:1.3;color:var(--color-text);margin-bottom:var(--space-sm)}.focus-unit-count{font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-lg)}.focus-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-lg)}.focus-nav-btn{display:flex;align-items:center;gap:var(--space-xs);padding:12px 24px;background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.focus-nav-btn:hover:not(:disabled){background:var(--color-cream-dark)}.focus-nav-btn:disabled{opacity:.4;cursor:not-allowed}.focus-play-btn{width:80px;height:80px;border-radius:var(--radius-full);background:var(--color-cream);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.focus-play-btn:hover:not(:disabled){background:var(--color-cream-dark);transform:scale(1.05)}.focus-play-btn svg{color:var(--color-terracotta)}.focus-transcript{margin-bottom:var(--space-md);padding:var(--space-md);background:var(--color-cream);border-radius:var(--radius-md);width:100%;max-width:500px}.focus-transcript-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;margin-bottom:var(--space-xs)}.focus-transcript-text{font-size:1.25rem}.focus-score{display:inline-flex;flex-direction:column;align-items:center;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg);margin-bottom:var(--space-lg)}.focus-score.success{background:#34c75926;color:var(--color-sage)}.focus-score.fail{background:#ff3b301a;color:var(--color-error)}.focus-score.animating{animation:scorePopIn .6s cubic-bezier(.175,.885,.32,1.275)}.focus-score-value{font-size:3rem;font-weight:700;line-height:1}.focus-score-feedback{font-size:1rem;font-weight:500;margin-top:var(--space-xs)}.focus-record-area{display:flex;flex-direction:column;align-items:center}.focus-record-btn{width:100px;height:100px;border-radius:var(--radius-full);background:var(--color-terracotta);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 20px #0a84ff4d}.focus-record-btn:hover:not(:disabled){transform:scale(1.05)}.focus-record-btn:disabled{opacity:.4;cursor:not-allowed}.focus-record-btn.recording{background:var(--color-error);animation:pulse 1.5s ease-in-out infinite}.focus-record-btn svg{width:40px;height:40px}.focus-record-label{font-size:1rem;color:var(--color-text-muted);margin-top:var(--space-sm)}@media(max-width:640px){.focus-line-text{font-size:1.75rem}.focus-nav{gap:var(--space-md)}.focus-nav-btn{padding:10px 16px;font-size:.875rem}.focus-play-btn{width:60px;height:60px}.focus-record-btn{width:80px;height:80px}}.voice-analysis-container{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-md)}.waveform-bars{display:flex;align-items:center;gap:4px;height:40px}.waveform-bars span{width:6px;background:var(--color-terracotta);border-radius:3px;animation:waveform .6s ease-in-out infinite}.waveform-bars span:nth-child(1){height:20px;animation-delay:0s}.waveform-bars span:nth-child(2){height:30px;animation-delay:.1s}.waveform-bars span:nth-child(3){height:40px;animation-delay:.2s}.waveform-bars span:nth-child(4){height:30px;animation-delay:.3s}.waveform-bars span:nth-child(5){height:20px;animation-delay:.4s}@keyframes waveform{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.voice-analysis-parrot{width:50px;height:50px;position:relative}.voice-analysis-parrot .parrot-static{position:absolute;width:100%;height:100%;object-fit:contain;opacity:0}.voice-analysis-parrot .parrot-animated{position:absolute;width:100%;height:100%;object-fit:contain;opacity:1}.script-progress-bar{width:100%;height:24px;background:var(--color-cream);border-radius:var(--radius-md);margin-bottom:var(--space-md);position:relative;overflow:hidden}.script-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-sage),var(--color-terracotta));border-radius:var(--radius-md);transition:width var(--transition-normal)}.script-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:600;color:var(--color-text)}.current-line-unit-count{font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--space-md)}.line-unit-count{font-size:.6875rem;color:var(--color-text-muted)}.my-line-unit-count{font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.my-line-progress{display:flex;align-items:center;gap:var(--space-md);margin:var(--space-sm) 0}.reps-progress{flex:1;display:flex;align-items:center;gap:var(--space-sm)}.reps-bar{flex:1;height:6px;background:var(--color-cream);border-radius:3px;overflow:hidden}.reps-fill{height:100%;background:linear-gradient(90deg,var(--color-sage),var(--color-terracotta));border-radius:3px;transition:width var(--transition-normal)}.sets-badges{display:flex;align-items:center;gap:var(--space-sm)}.set-badge{font-size:.75rem;font-weight:600;color:var(--color-terracotta);background:#0a84ff1a;padding:2px 8px;border-radius:var(--radius-sm)}.rep-count{font-size:.6875rem;color:var(--color-text-muted)}.my-line-card.practicing{background:var(--color-cream);border:2px solid var(--color-terracotta)}.my-line-practice-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-md)}.record-btn-inline{width:50px;height:50px;border-radius:var(--radius-full);background:var(--color-terracotta);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.record-btn-inline:hover:not(:disabled){transform:scale(1.05)}.record-btn-inline.recording{background:var(--color-error);animation:pulse 1.5s ease-in-out infinite}.my-line-practice-result{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-sm);background:var(--color-warm-white);border-radius:var(--radius-sm)}.practice-label{font-size:.6875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;display:block;margin-bottom:2px}.practice-text{font-size:.875rem}.practice-score{font-size:1rem;font-weight:700;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.practice-score.passed{color:var(--color-sage);background:#34c75926}.practice-score.failed{color:var(--color-error);background:#ff3b301a}.congrats-modal,.explainer-modal{max-width:400px;text-align:center}.congrats-content,.explainer-content{padding:var(--space-lg)}.congrats-emoji,.explainer-emoji{font-size:4rem;margin-bottom:var(--space-md)}.congrats-content h2,.explainer-content h2{margin-bottom:var(--space-md)}.congrats-line{font-style:italic;color:var(--color-text-muted);margin:var(--space-md) 0}.congrats-xp{font-size:1.5rem;font-weight:700;color:var(--color-terracotta);margin-bottom:var(--space-lg)}.explainer-hint{font-size:.875rem;color:var(--color-text-muted);margin-top:var(--space-md)}.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-sm)}.level-progress-card{padding:var(--space-lg);background:linear-gradient(135deg,var(--color-cream),var(--color-warm-white));border-radius:var(--radius-lg);border:1px solid var(--color-border)}.level-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.level-badge{font-size:1.25rem;font-weight:700;color:var(--color-terracotta)}.level-xp{font-size:.875rem;color:var(--color-text-muted)}.level-progress-bar{height:12px;background:var(--color-cream);border-radius:6px;overflow:hidden;margin-bottom:var(--space-sm)}.level-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-sage),var(--color-terracotta));border-radius:6px;transition:width var(--transition-normal)}.level-progress-text{font-size:.75rem;color:var(--color-text-muted);text-align:center}.share-section{padding:var(--space-lg);background:var(--color-cream);border-radius:var(--radius-lg);text-align:center}.share-section h3{margin-bottom:var(--space-xs)}.share-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm)}.share-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:10px 16px;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.share-btn.twitter{background:#000;color:#fff}.share-btn.facebook{background:#1877f2;color:#fff}.share-btn.copy{background:var(--color-warm-white);color:var(--color-text);border:1px solid var(--color-border)}.share-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.xp-explanation h4{margin-top:var(--space-md);margin-bottom:var(--space-sm);color:var(--color-terracotta)}.xp-explanation h4:first-child{margin-top:0}.xp-item{display:flex;justify-content:space-between;padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border)}.xp-action{color:var(--color-text)}.xp-value{font-weight:600;color:var(--color-sage)}.creator-library-card{display:block;position:relative;padding:var(--space-lg);background:linear-gradient(135deg,#0a84ff0d,#34c7590d);border:1px dashed var(--color-border);text-decoration:none;color:var(--color-text);transition:all var(--transition-fast)}.creator-library-card:hover{border-color:var(--color-terracotta);background:linear-gradient(135deg,#0a84ff1a,#34c7591a)}.creator-library-card h3{margin-bottom:var(--space-xs)}.coming-soon-badge{position:absolute;top:var(--space-md);right:var(--space-md);padding:4px 10px;background:var(--color-terracotta);color:#fff;font-size:.6875rem;font-weight:600;border-radius:var(--radius-sm);text-transform:uppercase}.external-link-icon{position:absolute;bottom:var(--space-md);right:var(--space-md);color:var(--color-text-muted)}.empty-state-logo{width:80px;height:80px;margin-bottom:var(--space-md);opacity:.6}.session-bonus-msg{font-size:1rem;color:var(--color-sage);font-weight:600;margin-bottom:var(--space-lg)}.header-parrot-img{width:48px;height:48px;object-fit:contain;margin-left:var(--space-sm)}.parrot-mic-group{display:flex;align-items:center;justify-content:center;position:relative}.parrot-mic-group .record-btn,.parrot-mic-group .focus-record-btn{position:relative;z-index:1}.parrot-container{position:absolute;right:calc(100% + var(--space-sm));width:70px;height:70px;background:transparent!important}.parrot-container.parrot-large{width:90px;height:90px}.parrot-img{width:100%;height:100%;object-fit:contain;background:transparent!important}.parrot-img,.parrot-static,.parrot-animated,.practice-parrot-static,.practice-parrot-animated,.voice-analysis-parrot img{background:none!important;background-color:transparent!important;border:none!important;box-shadow:none!important}.parrot-record-group{display:flex;align-items:center;gap:var(--space-sm);background:transparent!important}.practice-parrot-static,.practice-parrot-animated{width:50px;height:50px;object-fit:contain;background:transparent!important}.my-lines-view.full-width,.my-lines-view.full-width .my-lines-group{max-width:100%}.my-lines-view.full-width .my-line-card{flex-direction:row;align-items:flex-start}.my-line-practice{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border)}.my-line-practice-row{display:flex;align-items:center;justify-content:center;gap:var(--space-md);flex-wrap:wrap}.my-line-practice-result{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-top:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:var(--color-warm-white);border-radius:var(--radius-sm)}.my-line-practice-controls{display:none}.my-line-card{padding:var(--space-sm) var(--space-md)}.my-line-main{gap:2px}.my-line-progress{margin:var(--space-xs) 0}.reps-text{font-size:.625rem}.my-line-meta{font-size:.6875rem}.current-line{position:relative}.current-line-top-actions{position:absolute;top:var(--space-sm);right:var(--space-sm);z-index:5}.save-line-btn-compact{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-cream);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-muted)}.save-line-btn-compact:hover{background:var(--color-cream-dark);color:var(--color-terracotta)}.save-line-btn-compact.saved{background:var(--color-terracotta);border-color:var(--color-terracotta);color:#fff}.save-line-btn-compact.saved svg{fill:#fff}.create-line-row{display:flex;justify-content:center}.create-line-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:8px 16px;background:var(--color-cream);border:1px dashed var(--color-border);border-radius:var(--radius-md);font-size:.8125rem;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.create-line-btn:hover{background:var(--color-cream-dark);border-color:var(--color-terracotta);color:var(--color-terracotta)}.save-line-row{display:none!important}img[src*=parrot],.voice-analysis-parrot,.parrot-container,.parrot-record-group{background:transparent!important;background-color:transparent!important}.my-lines-layout{display:flex;gap:var(--space-lg)}.my-lines-folders{width:200px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-xs)}.folder-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:var(--color-cream);border:2px solid transparent;color:var(--color-text)}.folder-item:hover{background:var(--color-cream-dark)}.folder-item.active{background:#0a84ff!important;color:#fff!important;border-color:#0071e3!important}.folder-item.active svg{stroke:#fff!important}.folder-item.active span{color:#fff!important}.folder-item.active .folder-count{background:#ffffff4d!important;color:#fff!important}.folder-item.drag-over:not(.active){border-color:var(--color-terracotta);background:#0a84ff1a}.folder-item span{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-count{font-size:.75rem;color:var(--color-text-muted);background:var(--color-warm-white);padding:2px 8px;border-radius:var(--radius-sm);font-weight:500}.folder-actions{display:none;gap:2px}.folder-item:hover .folder-actions{display:flex}.btn-icon-sm{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center}.folder-rename-input{flex:1;padding:2px 4px;font-size:inherit;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff}.folder-add-btn{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px dashed var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem}.folder-add-btn:hover{border-color:var(--color-terracotta);color:var(--color-terracotta)}.folder-select-list{display:flex;flex-direction:column;gap:var(--space-xs)}.folder-select-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-cream);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.folder-select-item:hover{background:var(--color-terracotta);color:#fff;border-color:var(--color-terracotta)}.folder-select-item:hover svg{stroke:#fff}.my-line-drag-handle{cursor:grab;padding:var(--space-xs);color:var(--color-text-muted);opacity:.5;transition:opacity var(--transition-fast)}.my-line-card:hover .my-line-drag-handle{opacity:1}.my-line-card.dragging{opacity:.5;transform:scale(.98)}@media(max-width:768px){.my-lines-layout{flex-direction:column}.my-lines-folders{width:100%;flex-direction:row;overflow-x:auto;padding-bottom:var(--space-sm)}.folder-item{white-space:nowrap}.folder-actions{display:none!important}}.reading-assist-text{display:flex;flex-wrap:wrap;justify-content:center;gap:4px}.reading-assist-word{cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);background:#0a84ff14;border:1px solid transparent;transition:all var(--transition-fast)}.reading-assist-word:hover{background:#0a84ff33;border-color:var(--color-terracotta);color:var(--color-terracotta);transform:translateY(-1px)}.word-popup{position:fixed;z-index:1000;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000026;padding:var(--space-md) var(--space-lg);min-width:180px;max-width:300px;text-align:center;cursor:pointer;animation:popupFadeIn .2s ease-out}.word-popup-header{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);margin-bottom:var(--space-sm)}.word-popup-header-icon{font-size:1.25rem}.word-popup-header-text{font-size:.875rem;font-weight:600;color:#f59e0b;letter-spacing:.02em}@keyframes popupFadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.word-popup-word{font-size:1.5rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs)}.word-popup-reading{font-size:1rem;color:var(--color-terracotta);margin-bottom:var(--space-xs);font-weight:500}.word-popup-meaning{font-size:.9375rem;color:var(--color-text-muted);margin-bottom:var(--space-sm);line-height:1.4}.word-popup-hint{font-size:.6875rem;color:var(--color-text-muted);opacity:.7}img[src*=parrot]{background:transparent!important;background-color:transparent!important;border:none!important;box-shadow:none!important}.header-lang-label{font-size:.75rem;color:var(--color-text-muted);font-weight:500;margin-right:4px}.btn.btn-ghost.btn-small[class*=translation],button[class*=showTranslation]{color:var(--color-terracotta)!important;font-weight:500}.current-line .btn-ghost{background:#0a84ff1a;color:var(--color-terracotta);border:1px solid var(--color-terracotta);font-weight:500}.current-line .btn-ghost:hover{background:var(--color-terracotta);color:#fff}.my-lines-content{flex:1;min-width:0}.my-lines-group{margin-bottom:var(--space-lg)}.my-lines-group-title{font-size:.875rem;color:var(--color-text-muted);font-weight:600;margin-bottom:var(--space-sm);padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border)}.my-lines-list{display:flex;flex-direction:column;gap:var(--space-md)}.my-line-card{display:flex;align-items:flex-start;gap:var(--space-sm);background:var(--color-warm-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);transition:all var(--transition-fast);width:100%}.my-line-card:hover{border-color:var(--color-terracotta);box-shadow:var(--shadow-sm)}.my-line-card.practicing{border-color:var(--color-terracotta);background:var(--color-cream)}.my-line-main{flex:1;min-width:0}.my-line-text{font-size:1.125rem;font-weight:500;color:var(--color-text);margin-bottom:var(--space-xs);word-break:break-word}.my-line-unit-count{font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.my-line-translation{background:#0a84ff14;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--color-terracotta);font-size:.9375rem;margin-bottom:var(--space-sm);border-left:3px solid var(--color-terracotta)}.my-line-note{display:flex;align-items:center;gap:var(--space-xs);font-size:.8125rem;color:var(--color-text-muted);font-style:italic;margin-bottom:var(--space-sm)}.my-line-progress{margin-bottom:var(--space-sm)}.reps-progress{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.reps-bar{flex:1;height:6px;background:var(--color-cream-dark);border-radius:3px;overflow:hidden}.reps-fill{height:100%;background:linear-gradient(90deg,var(--color-success),#34d399);border-radius:3px;transition:width .3s ease}.reps-text{font-size:.6875rem;color:var(--color-text-muted);white-space:nowrap}.sets-badges{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.set-badge{font-size:.75rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:2px 8px;border-radius:var(--radius-sm);font-weight:600}.rep-count{font-size:.75rem;color:var(--color-text-muted)}.my-line-meta{display:flex;align-items:center;gap:var(--space-sm);font-size:.75rem;color:var(--color-text-muted)}.my-line-lang{background:var(--color-cream);padding:2px 6px;border-radius:var(--radius-sm)}.my-line-actions{display:flex;flex-direction:column;gap:var(--space-xs);align-items:flex-end}.my-line-confirm-delete{display:flex;gap:var(--space-xs)}.my-line-practice{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.my-line-practice-row{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.record-btn-inline{width:48px;height:48px;border-radius:50%;background:var(--color-terracotta);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.record-btn-inline:hover{transform:scale(1.05)}.record-btn-inline.recording{background:var(--color-error);animation:pulse 1s infinite}.my-line-practice-result{display:flex;align-items:center;gap:var(--space-md);margin-top:var(--space-sm);padding:var(--space-sm);background:var(--color-cream);border-radius:var(--radius-md)}.practice-transcript{flex:1}.practice-score{font-size:1.25rem;font-weight:700;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md)}.practice-score.passed{background:var(--color-success);color:#fff}.practice-score.failed{background:var(--color-error);color:#fff}@media(max-width:768px){.my-lines-layout{flex-direction:column}.my-lines-folders{width:100%;flex-direction:row;overflow-x:auto;padding-bottom:var(--space-sm);gap:var(--space-xs)}.folder-item{white-space:nowrap;padding:var(--space-xs) var(--space-sm);font-size:.875rem}.folder-item.active{background:#0a84ff!important;color:#fff!important;border-color:#0071e3!important}.folder-item.active svg{stroke:#fff!important}.folder-item.active span{color:#fff!important}.folder-item.active .folder-count{background:#ffffff4d!important;color:#fff!important}.folder-actions{display:none!important}.my-line-card{flex-direction:column}.my-line-drag-handle{display:none}.my-line-actions{flex-direction:row;width:100%;justify-content:flex-end;padding-top:var(--space-sm);border-top:1px solid var(--color-border);margin-top:var(--space-sm)}.my-line-practice-row{justify-content:center}}.word-popup-pos{font-size:.6875rem;color:var(--color-text-muted);text-transform:lowercase;font-style:italic;margin-bottom:var(--space-xs)}.word-popup-meanings{text-align:left}.word-popup-meaning-item{font-size:.875rem;color:var(--color-text);padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border);line-height:1.4}.word-popup-meaning-item:last-child{border-bottom:none}.meaning-num{color:var(--color-terracotta);font-weight:600;margin-right:var(--space-xs)}.my-lines-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-sm)}.my-lines-header-actions{display:flex;align-items:center;gap:var(--space-sm)}.translation-lang-hint{font-size:.75rem;color:var(--color-text-muted);padding:var(--space-xs) var(--space-sm);background:var(--color-cream);border-radius:var(--radius-sm)}.my-line-same-lang{font-size:.75rem;color:var(--color-text-muted);font-style:italic;padding:var(--space-xs) var(--space-sm);background:var(--color-cream);border-radius:var(--radius-sm);margin-bottom:var(--space-sm)}.voice-controls{display:flex;align-items:center;justify-content:flex-start;gap:var(--space-lg);padding:var(--space-sm) var(--space-md);background:var(--color-cream);border-radius:var(--radius-md);margin-bottom:var(--space-md);flex-wrap:wrap}.voice-select-inline{display:flex;align-items:center;gap:var(--space-sm)}.voice-label{font-size:.8125rem;font-weight:500;color:var(--color-text)}.voice-dropdown{min-width:100px;padding:var(--space-xs) var(--space-sm);font-size:.875rem}.voice-dropdown:disabled{opacity:.6;cursor:not-allowed}.pro-badge-inline{font-size:.625rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#8b5cf6,#7c3aed);padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em}.vocab-assist-inline{display:flex;align-items:center;gap:var(--space-sm)}.vocab-assist-label{font-size:.8125rem;font-weight:500;color:var(--color-text)}.toggle.toggle-small{transform:scale(.85)}.pro-locked-feature{position:relative}.pro-locked-content{opacity:.5;pointer-events:none}.pro-lock-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);color:var(--color-text-muted)}.pro-upgrade-hint{font-size:.75rem;font-weight:600;color:#7c3aed}@media(max-width:768px){.voice-controls{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}}.vocab-burst-view{padding:var(--space-lg);max-width:800px;margin:0 auto}.vocab-burst-header{text-align:center;margin-bottom:var(--space-xl)}.vocab-burst-header h2{font-size:1.75rem;font-weight:700;margin-bottom:var(--space-xs)}.vocab-burst-subtitle{font-size:1rem;color:var(--color-text-muted)}.vocab-burst-locked{display:flex;justify-content:center;padding:var(--space-2xl) var(--space-lg)}.locked-content{text-align:center;max-width:400px}.locked-icon{display:flex;justify-content:center;margin-bottom:var(--space-md);color:var(--color-text-muted)}.locked-content h3{font-size:1.25rem;margin-bottom:var(--space-sm)}.locked-content p{color:var(--color-text-muted);margin-bottom:var(--space-lg);line-height:1.5}.btn-upgrade{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none}.btn-upgrade:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9)}.vocab-burst-modes{display:flex;flex-direction:column;gap:var(--space-md)}.mode-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--color-warm-white);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.mode-card:hover{border-color:var(--color-terracotta);box-shadow:var(--shadow-md)}.mode-card.selected{border-color:var(--color-terracotta);background:#0a84ff0d}.mode-indicator{width:24px;height:24px;border-radius:50%;flex-shrink:0}.mode-indicator.story{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.mode-indicator.sentence{background:linear-gradient(135deg,#22c55e,#16a34a)}.mode-content h3{font-size:1.125rem;font-weight:600;margin-bottom:var(--space-xs)}.mode-content p{font-size:.875rem;color:var(--color-text-muted)}.vocab-burst-config{margin-top:var(--space-lg);padding:var(--space-lg);background:var(--color-cream);border-radius:var(--radius-lg)}.config-section{margin-bottom:var(--space-md)}.config-section label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.length-options{display:flex;gap:var(--space-sm)}.length-options .btn.active{background:var(--color-terracotta);color:#fff}.btn-start-vocab{width:100%;margin-top:var(--space-md)}.vocab-burst-footer{margin-top:var(--space-xl);text-align:center}.vocab-burst-footer p{font-size:.875rem}.auth-shell{width:100%;display:flex;justify-content:flex-start;margin:12px 0 18px}.auth-card{width:100%;max-width:520px;border:1px solid var(--color-border);background:#fff;border-radius:16px;padding:14px 14px 12px;box-shadow:0 10px 24px #0000000f}.auth-header{margin-bottom:10px}.auth-title{font-size:16px;font-weight:700;color:var(--color-text-main);margin-bottom:2px}.auth-subtitle{font-size:13px;color:var(--color-text-secondary)}.auth-tabs{display:flex;gap:8px;background:var(--color-cream);border:1px solid var(--color-border);border-radius:12px;padding:6px;margin:10px 0 12px}.auth-tab{flex:1;border:0;border-radius:10px;padding:10px;font-weight:600;background:transparent;color:var(--color-text-secondary);cursor:pointer}.auth-tab.active{background:#fff;color:var(--color-text-main);box-shadow:0 6px 16px #00000014;border:1px solid var(--color-border)}.auth-form{display:grid;gap:10px}.auth-label{display:grid;gap:6px;font-size:12px;color:var(--color-text-secondary)}.auth-input{height:42px;border-radius:12px;border:1px solid var(--color-border);padding:0 12px;font-size:14px;outline:none}.auth-input:focus{border-color:var(--color-terracotta);box-shadow:0 0 0 3px #0a84ff2e}.auth-alert{border-radius:12px;padding:10px 12px;font-size:13px}.auth-alert.error{background:#ff3b3014;border:1px solid rgba(255,59,48,.25);color:#8b1a12}.auth-alert.ok{background:#34c7591a;border:1px solid rgba(52,199,89,.25);color:#0a5a2a}.auth-primary{height:44px;border:0;border-radius:12px;background:var(--color-terracotta);color:#fff;font-weight:700;cursor:pointer}.auth-primary:disabled{opacity:.55;cursor:not-allowed}.auth-secondary{height:42px;border-radius:12px;border:1px solid var(--color-border);background:#fff;color:var(--color-text-main);font-weight:600;cursor:pointer}.auth-footnote{margin-top:10px;font-size:12px;color:var(--color-text-secondary)}
