:root{--primary:#2563eb;--primary-dark:#1d4ed8;--secondary:#64748b;--accent:#f59e0b;--success:#10b981;--danger:#ef4444;--bg:#f8fafc;--card:#fff;--text:#1e293b;--text-light:#64748b;--border:#e2e8f0;--shadow:0 4px 6px -1px #0000001a;--radius:12px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5}#app{max-width:800px;margin:0 auto;padding:1rem 1rem 5rem}header{text-align:center;margin-bottom:2rem;position:relative}.header-top{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.profile-selector{align-items:center;gap:.5rem;display:flex}.profile-select{border:1px solid var(--border);background:var(--card);border-radius:8px;padding:.4rem .8rem;font-size:.9rem}h1{color:var(--primary);margin-bottom:.2rem;font-size:1.8rem}.subtitle{color:var(--text-light);font-size:.9rem}.tabs{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);scrollbar-width:none;gap:.5rem;margin-bottom:2rem;padding:.5rem;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{min-width:max-content;color:var(--text-light);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.7rem 1rem;font-weight:600;transition:all .2s;display:flex}.tab.active{background:var(--primary);color:#fff}.tab-badge{background:var(--accent);color:#fff;border-radius:10px;padding:2px 6px;font-size:.7rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--card);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow);padding:1.5rem}.stat-value{color:var(--primary);font-size:1.5rem;font-weight:700}.stat-label{color:var(--text-light);font-size:.8rem}.daily-goal{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:2rem;padding:1.5rem}.daily-goal h2{margin-bottom:1rem;font-size:1.1rem}.progress-bar{background:var(--border);border-radius:6px;height:12px;margin-bottom:.5rem;overflow:hidden}.progress-fill{background:var(--success);height:100%;transition:width .3s}.progress-bar.slim{height:8px}.recommended-action{margin-bottom:2rem}.recommended-card{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.recommended-info h3{margin-bottom:.2rem;font-size:1.2rem}.recommended-info p{opacity:.9;font-size:.9rem}.level-badge{background:#fff3;border-radius:4px;margin-bottom:.5rem;padding:2px 8px;font-size:.75rem;font-weight:700;display:inline-block}section h2{margin-bottom:1rem;font-size:1.2rem}.level-cards{flex-direction:column;gap:1rem;display:flex}.level-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.2rem}.level-card-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.level-card h3{font-size:1.1rem}.level-status{font-size:1.2rem}.level-description{color:var(--text-light);margin-bottom:1rem;font-size:.9rem}.level-progress{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.level-progress .progress-bar{flex:1;margin-bottom:0}.progress-text{color:var(--text-light);white-space:nowrap;font-size:.8rem}.btn{cursor:pointer;text-align:center;border:none;border-radius:8px;padding:.8rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .2s}.btn.primary{background:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-dark)}.btn.secondary{background:var(--border);color:var(--text)}.btn.secondary:hover{background:#cbd5e1}.levels-list{flex-direction:column;gap:2rem;display:flex}.level-section-header{border-bottom:2px solid var(--border);justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:.5rem;display:flex}.level-section-progress{text-align:right;min-width:80px}.level-section-progress span{color:var(--primary);font-weight:700}.chapters-list{grid-template-columns:1fr;gap:1.5rem;display:grid}.chapter-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.chapter-main{gap:1rem;display:flex}.chapter-number{background:var(--bg);color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-weight:700;display:flex}.chapter-info{flex:1}.chapter-info h4{margin-bottom:.2rem}.chapter-info p{color:var(--text-light);margin-bottom:.5rem;font-size:.85rem}.chapter-meta{color:var(--text-light);gap:1rem;margin-bottom:.5rem;font-size:.75rem;display:flex}.category{background:var(--bg);border-radius:4px;padding:2px 6px}.chapter-progress{align-items:center;gap:.5rem;display:flex}.chapter-progress span{color:var(--text-light);font-size:.75rem;font-weight:600}.chapter-words-preview{flex-wrap:wrap;gap:.4rem;display:flex}.word-chip{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:2px 8px;font-size:.8rem}.word-more{color:var(--text-light);align-self:center;font-size:.75rem}.practice-section{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.quiz-setup{flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.quiz-setup label{flex-direction:column;gap:.4rem;display:flex}.quiz-setup span{font-size:.9rem;font-weight:600}.quiz-setup select{border:1px solid var(--border);background:var(--bg);border-radius:8px;padding:.8rem;font-family:inherit}.quiz-overlay{z-index:1000;background:#000c;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.quiz-container{background:var(--bg);border-radius:var(--radius);flex-direction:column;width:100%;max-width:500px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a}.quiz-header{background:var(--card);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem;display:flex}.close-quiz{cursor:pointer;color:var(--text-light);background:0 0;border:none;font-size:1.5rem}.quiz-content{flex:1;padding:2rem;overflow-y:auto}.question{text-align:center}.question-word{margin-bottom:.5rem;font-size:2rem;font-weight:700}.question-article{color:var(--primary);margin-bottom:1.5rem;font-size:1.1rem;font-weight:600}.options{grid-template-columns:1fr;gap:.8rem;margin-top:2rem;display:grid}.option-btn{border:2px solid var(--border);background:var(--card);cursor:pointer;border-radius:12px;padding:1rem;font-size:1rem;font-weight:600;transition:all .2s}.option-btn:hover{border-color:var(--primary);color:var(--primary)}.write-answer{border:2px solid var(--border);text-align:center;border-radius:12px;width:100%;margin-bottom:1rem;padding:1rem;font-size:1.1rem}.write-answer:focus{border-color:var(--primary);outline:none}.feedback{text-align:center;border-radius:var(--radius);padding:1rem}.feedback.correct{background:#10b9811a}.feedback.incorrect{background:#ef44441a}.feedback-icon{margin-bottom:1rem;font-size:3rem}.feedback-text{margin-bottom:1.5rem;font-size:1.2rem;font-weight:600}.feedback-explanation{color:var(--text-light);margin-bottom:1.5rem;font-size:.95rem}.speak-btn{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:.4rem .8rem;font-size:1rem}.speak-correct{background:#fff;margin:1rem auto;display:block}.review-due{background:var(--accent);color:#fff;border-radius:var(--radius);text-align:center;margin-bottom:2rem;padding:2rem}.review-due h2{margin-bottom:.5rem;font-size:1.5rem}.review-due p{opacity:.9;margin-bottom:1.5rem;font-size:1rem}.srs-info{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}.srs-info h3{margin-bottom:1rem}.srs-boxes{justify-content:space-between;gap:.5rem;display:flex}.srs-box{background:var(--bg);text-align:center;border-bottom:4px solid var(--border);border-radius:8px;flex:1;padding:1rem .5rem}.srs-box.active-box{border-color:var(--primary)}.box-number{color:var(--text-light);font-size:.75rem;display:block}.box-count{color:var(--text);font-size:1.2rem;font-weight:700}.weakness-card{border-left:4px solid var(--danger);background:#ef44440d!important}.category-stat{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.profile-modal{background:var(--card);border-radius:var(--radius);width:100%;max-width:400px;padding:2rem}.profile-modal h2,.input-group{margin-bottom:1.5rem}.input-group label{margin-bottom:.5rem;font-weight:600;display:block}.input-group input{border:1px solid var(--border);border-radius:8px;width:100%;padding:.8rem}.achievement-notification{background:var(--card);border-radius:var(--radius);z-index:2000;border-left:4px solid var(--accent);width:90%;max-width:350px;padding:1rem;transition:transform .3s cubic-bezier(.175,.885,.32,1.275);position:fixed;top:1rem;left:50%;transform:translate(-50%)translateY(-100%);box-shadow:0 10px 15px -3px #0000001a}.achievement-notification.show{transform:translate(-50%)translateY(0)}.achievement-content{align-items:center;gap:1rem;display:flex}.achievement-icon{font-size:2rem}.achievement-text strong{color:var(--accent);font-size:.9rem;display:block}.achievement-text p{font-size:1rem;font-weight:600}.achievements-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-top:1.5rem;display:grid}.achievement-card{background:var(--card);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow);flex-direction:column;gap:.5rem;padding:1.5rem 1rem;transition:transform .2s;display:flex}.achievement-card:hover{transform:translateY(-4px)}.achievement-card.locked{opacity:.6;filter:grayscale()}.achievement-card .achievement-icon{font-size:2.5rem}.achievement-card .achievement-title{font-size:.8rem;font-weight:600}.quiz-results{text-align:center}.results-summary{justify-content:space-around;margin:2rem 0;display:flex}.result-item{flex-direction:column;display:flex}.result-value{color:var(--primary);font-size:2rem;font-weight:700}.result-label{color:var(--text-light);font-size:.8rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tab-content:not(.hidden){animation:.3s ease-out slideUp}@media (width<=480px){h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.tabs{padding:.3rem}.tab{padding:.5rem .8rem;font-size:.85rem}.quiz-content{padding:1.5rem}}.hidden{display:none!important}.example-sentence{color:var(--text-light);background:var(--bg);border-radius:8px;margin-top:1rem;padding:.8rem;font-size:.9rem;font-style:italic}.example-translation{opacity:.7;margin-top:.4rem;font-size:.8rem;display:block}
