:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a25;--bg-card: #16161f;--bg-hover: #1f1f2e;--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-muted: #6b6b7b;--accent-primary: #6366f1;--accent-secondary: #818cf8;--accent-glow: rgba(99, 102, 241, .3);--success: #10b981;--success-bg: rgba(16, 185, 129, .15);--error: #ef4444;--error-bg: rgba(239, 68, 68, .15);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .15);--border-color: #2a2a3a;--border-radius: 12px;--border-radius-lg: 16px;--border-radius-sm: 8px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--accent-glow);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}html{font-size:14px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;width:100%;margin:0;padding:0}.app{min-height:100vh;display:flex;flex-direction:column}.page{min-height:100vh;width:100%;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.page-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.page-title{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.page-title.clickable{cursor:pointer;padding:.3rem .6rem;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.page-title.clickable:hover{background:var(--bg-hover);color:var(--accent-secondary)}.page-title.clickable:active{transform:scale(.97)}.header-nav{display:flex;gap:.5rem}.nav-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--accent-primary)!important;border:none;border-radius:var(--border-radius-sm);color:#fff!important;cursor:pointer;transition:all var(--transition-fast)}.nav-link svg,.nav-link svg *{color:#fff!important;stroke:#fff!important;fill:none!important}.nav-link:hover{background:var(--accent-secondary);transform:scale(1.05)}.nav-link-text{display:flex;align-items:center;justify-content:center;padding:.4rem .75rem;background:var(--accent-primary);border:none;border-radius:var(--border-radius-sm);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);letter-spacing:.02em}.nav-link-text:hover{background:var(--accent-secondary);transform:scale(1.05)}.page-content{flex:1;padding:1rem;overflow-y:auto}.page-footer{padding:.75rem 1rem;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.home-page{align-items:center;padding:2rem .75rem 1rem;gap:0}.home-header{width:100%;text-align:center;margin-bottom:1rem}.logo-container{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.15rem}.logo-icon{color:var(--accent-primary);filter:drop-shadow(0 0 10px var(--accent-glow))}.app-title{font-size:1.6rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{color:var(--text-secondary);font-size:.8rem;margin-top:.15rem}.home-content{width:100%;max-width:600px;margin:0 auto}.menu-cards{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.menu-card{display:flex;flex-direction:column;align-items:center;padding:1.1rem .6rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-normal);text-align:center}.menu-card.progress-card{grid-column:1 / -1}.menu-card:hover{transform:translateY(-2px);border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.menu-icon{color:var(--accent-primary);margin-bottom:.35rem}.menu-title{font-size:1.05rem;font-weight:600;margin-bottom:.2rem}.menu-description{color:var(--text-secondary);font-size:.75rem;line-height:1.4}.menu-badge{margin-top:.5rem;padding:.15rem .5rem;background:var(--accent-glow);border-radius:20px;font-size:.65rem;color:var(--accent-secondary)}.menu-stats{margin-top:.5rem;font-size:.75rem;color:var(--success)}.quick-stats{display:flex;justify-content:center;gap:1.5rem;margin-top:.6rem;padding:.75rem;background:var(--bg-card);border-radius:var(--border-radius);border:1px solid var(--border-color)}.quick-stat{display:flex;flex-direction:column;align-items:center}.quick-stat-value{font-size:1.15rem;font-weight:700;color:var(--accent-primary)}.quick-stat-label{font-size:.65rem;color:var(--text-muted)}.data-management{margin-top:.6rem;padding:.9rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius)}.data-title{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-align:center}.data-actions{display:flex;gap:.75rem}.data-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem .75rem;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-tertiary);color:var(--text-primary)}.data-button:hover{border-color:var(--accent-primary);background:var(--bg-hover)}.data-button:active{transform:scale(.97)}.data-button.export{color:var(--accent-secondary)}.data-button.import{color:var(--success)}.import-message{margin-top:.75rem;padding:.5rem .75rem;border-radius:var(--border-radius-sm);font-size:.8rem;text-align:center;font-weight:500;animation:fadeIn .2s ease}.import-message.success{background:var(--success-bg);color:var(--success)}.import-message.error{background:var(--error-bg);color:var(--error)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.data-hint{margin-top:.6rem;font-size:.7rem;color:var(--text-muted);text-align:center}.home-footer{width:100%;text-align:center;margin-top:.6rem;padding-bottom:.5rem;color:var(--text-muted);font-size:.65rem}.phrase-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 140px)}.phrase-sticky-header{position:sticky;top:0;z-index:10;background:var(--bg-card);flex-shrink:0;border-bottom:1px solid var(--border-color)}.phrase-navigation{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.nav-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--accent-primary);border:none;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;transition:all var(--transition-fast)}.nav-button-text{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;background:var(--accent-primary);border:none;border-radius:var(--border-radius-sm);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);min-width:70px}.nav-button:hover:not(:disabled),.nav-button-text:hover:not(:disabled){background:var(--accent-secondary);transform:scale(1.05)}.nav-button:disabled,.nav-button-text:disabled{opacity:.3;cursor:not-allowed;background:var(--bg-tertiary)}.phrase-counter{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.phrase-content{padding:1rem}.german-text{display:flex;align-items:flex-start;gap:.5rem;font-size:1.05rem;font-weight:500;color:var(--text-primary);background:none;border:none;cursor:pointer;text-align:left;padding:.5rem .75rem;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);width:100%;line-height:1.5}.german-text:hover{background:var(--bg-hover)}.volume-icon{flex-shrink:0;color:var(--accent-primary);margin-top:.15rem}.japanese-text{font-size:.9rem;color:var(--text-secondary);margin-top:.35rem;padding-left:2rem;line-height:1.5}.dialog-section{display:flex;flex-direction:column;gap:1rem}.dialog-line{display:flex;gap:.75rem}.speaker{font-weight:700;color:var(--accent-primary);font-size:1rem;min-width:1.5rem}.dialog-text{flex:1}.dialog-german{font-size:1rem}.vocabulary-section{padding:1rem;border-top:none;background:var(--bg-secondary);overflow-y:auto;flex:1}.vocabulary-title{font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.vocabulary-list{display:flex;flex-direction:column;gap:.75rem}.vocab-item{padding:.75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-sm)}.vocab-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.vocab-word{display:flex;align-items:center;gap:.35rem;font-size:.95rem;font-weight:600;color:var(--accent-secondary);background:none;border:none;cursor:pointer;padding:.2rem .4rem;border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.vocab-word:hover{background:var(--bg-hover)}.volume-icon-small{color:var(--accent-primary)}.vocab-type{font-size:.65rem;padding:.15rem .4rem;background:var(--bg-tertiary);border-radius:4px;color:var(--text-muted)}.vocab-meaning{font-size:.85rem;color:var(--text-secondary);padding-left:.4rem}.vocab-conjugation{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem;padding-left:.4rem}.conjugation-form{display:flex;align-items:center;gap:.2rem;font-size:.75rem;padding:.25rem .5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.conjugation-form:hover{background:var(--bg-hover);border-color:var(--accent-primary);color:var(--accent-secondary)}.vocab-pronunciation{font-size:.75rem;color:var(--text-muted);margin-top:.35rem;padding-left:.4rem;font-family:var(--font-mono)}.phrase-selector{display:flex;justify-content:center}.phrase-dropdown{width:100%;max-width:280px;padding:.6rem .75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.phrase-dropdown:hover{border-color:var(--accent-primary)}.phrase-dropdown:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.quiz-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.quiz-header{padding:.75rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.quiz-progress{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.quiz-content{padding:1rem}.quiz-german{font-size:1rem;display:flex;flex-wrap:wrap;align-items:baseline;gap:.2rem;line-height:1.8}.quiz-instruction{text-align:center;color:var(--text-muted);font-size:.8rem;margin-top:1rem;padding:.5rem;background:var(--bg-tertiary);border-radius:var(--border-radius-sm)}.quiz-phrase,.quiz-dialog{border-radius:var(--border-radius-sm);padding:.5rem;transition:background var(--transition-fast)}.quiz-phrase:hover:not([style*=default]),.quiz-dialog:hover:not([style*=default]){background:var(--bg-hover)}.blank-button{display:inline-block;padding:.2rem .4rem;background:var(--bg-tertiary);border:2px dashed var(--accent-primary);border-radius:var(--border-radius-sm);color:var(--accent-primary);font-size:.95rem;font-weight:600;cursor:inherit;transition:all var(--transition-fast);min-width:60px;text-align:center;font-family:var(--font-mono)}.blank-button:hover:not(.disabled){background:var(--accent-glow)}.blank-button.revealed{background:var(--success-bg);border-color:var(--success);color:var(--success);border-style:solid}.blank-button.disabled{cursor:default}.quiz-actions{display:flex;gap:.75rem;padding:1rem;border-top:1px solid var(--border-color)}.answer-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.75rem;border:none;border-radius:var(--border-radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.answer-button.correct{background:var(--success);color:#fff}.answer-button.correct:hover{filter:brightness(1.1)}.answer-button.incorrect{background:var(--error);color:#fff}.answer-button.incorrect:hover{filter:brightness(1.1)}.quiz-result{padding:1rem;border-top:1px solid var(--border-color)}.result-banner{text-align:center;padding:.75rem;border-radius:var(--border-radius-sm);font-size:1.1rem;font-weight:700;margin-bottom:.75rem}.result-banner.correct{background:var(--success-bg);color:var(--success)}.result-banner.incorrect{background:var(--error-bg);color:var(--error)}.result-actions{display:flex;gap:.5rem;margin-bottom:.75rem}.action-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.action-button:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.action-button.next{background:var(--accent-primary);border-color:var(--accent-primary)}.action-button.next:hover{filter:brightness(1.1)}.action-button.play-audio{background:var(--success);border-color:var(--success)}.action-button.play-audio:hover{filter:brightness(1.1)}.action-button.primary{background:var(--accent-primary);border-color:var(--accent-primary)}.action-button.secondary{background:var(--bg-tertiary)}.explanation-section{margin-top:1rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--border-radius-sm)}.full-answer{margin-bottom:1rem}.full-answer h4{font-size:.9rem;color:var(--text-muted);margin-bottom:.5rem}.explanation-section .german-text{padding:0;cursor:default}.explanation-section .german-text:hover{background:transparent}.quiz-result-page{max-width:500px;margin:0 auto}.result-summary{text-align:center;padding:2rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);margin-bottom:1.5rem}.result-emoji{font-size:4rem;margin-bottom:1rem}.result-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem}.result-score{display:flex;align-items:baseline;justify-content:center;gap:.5rem;margin-bottom:.5rem}.score-number{font-size:3rem;font-weight:700;color:var(--accent-primary)}.score-separator{font-size:2rem;color:var(--text-muted)}.score-total{font-size:2rem;color:var(--text-secondary)}.result-percentage{font-size:1.1rem;color:var(--text-secondary)}.result-breakdown{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:1.5rem;margin-bottom:1.5rem}.result-breakdown h3{font-size:1rem;color:var(--text-secondary);margin-bottom:1rem}.result-list{display:flex;flex-direction:column;gap:.5rem}.result-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--border-radius-sm)}.result-item.correct .result-icon{color:var(--success)}.result-item.incorrect .result-icon{color:var(--error)}.result-number{font-weight:600;color:var(--text-secondary);min-width:2rem}.result-phrase{flex:1;font-size:.9rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quiz-result-page .result-actions{display:flex;flex-direction:column;gap:.75rem}.progress-page .page-content{max-width:600px;margin:0 auto}.section-title{font-size:1.1rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem}.stats-overview{margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.stat-card{display:flex;flex-direction:column;align-items:center;padding:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);text-align:center}.stat-icon{color:var(--accent-primary);margin-bottom:.5rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.progress-bar-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem}.progress-label{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem;color:var(--text-secondary)}.progress-bar{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:4px;transition:width var(--transition-slow)}.recent-sessions{margin-bottom:2rem}.sessions-list{display:flex;flex-direction:column;gap:.5rem}.session-item{display:flex;align-items:center;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-sm)}.session-date{flex:1;font-size:.9rem;color:var(--text-secondary)}.session-score{font-weight:600;margin-right:1rem}.session-percentage{font-size:.9rem;font-weight:600;padding:.25rem .5rem;border-radius:4px}.session-percentage.high{background:var(--success-bg);color:var(--success)}.session-percentage.medium{background:var(--warning-bg);color:var(--warning)}.session-percentage.low{background:var(--error-bg);color:var(--error)}.phrase-progress{margin-bottom:2rem}.phrase-list{display:flex;flex-direction:column;gap:.5rem}.phrase-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast)}.phrase-item:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.phrase-info{display:flex;align-items:center;gap:.75rem;flex:1;overflow:hidden}.phrase-number{font-size:.85rem;font-weight:600;color:var(--accent-primary);min-width:2rem}.phrase-preview{font-size:.9rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.phrase-stats{display:flex;align-items:center;gap:.5rem}.phrase-accuracy{font-size:.9rem;font-weight:600;padding:.2rem .5rem;border-radius:4px}.phrase-accuracy.high{background:var(--success-bg);color:var(--success)}.phrase-accuracy.medium{background:var(--warning-bg);color:var(--warning)}.phrase-accuracy.low{background:var(--error-bg);color:var(--error)}.phrase-attempts{font-size:.75rem;color:var(--text-muted)}.phrase-not-attempted{font-size:.85rem;color:var(--text-muted)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(min-width:600px){.home-page{padding:2rem 1.5rem}.menu-cards{grid-template-columns:repeat(3,1fr)}.menu-card.progress-card{grid-column:auto}.menu-card{padding:1.5rem 1rem}.menu-icon-size{width:48px;height:48px}.phrase-content{padding:2rem}.german-text{font-size:1.4rem}.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:400px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-card:last-child{grid-column:span 2}.quick-stats{gap:1rem}.result-score{flex-wrap:wrap}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}button:focus-visible,select:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:var(--accent-glow);color:var(--text-primary)}.pin-lock-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);z-index:9999}.pin-lock-container{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:2.5rem 2rem}.pin-lock-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--accent-glow);border-radius:50%;color:var(--accent-primary)}.pin-lock-title{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pin-lock-subtitle{font-size:.85rem;color:var(--text-muted)}.pin-inputs{display:flex;gap:.75rem}.pin-inputs.shake{animation:pinShake .4s ease}@keyframes pinShake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.pin-input{width:52px;height:60px;text-align:center;font-size:1.5rem;font-weight:700;font-family:var(--font-mono);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);transition:all var(--transition-fast);-webkit-text-security:disc;caret-color:var(--accent-primary)}.pin-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.pin-input.filled{border-color:var(--accent-secondary)}.pin-input.error{border-color:var(--error);box-shadow:0 0 0 3px #ef444433}.pin-error{font-size:.8rem;color:var(--error);font-weight:500}
