*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--surface: #1a1d27;--surface2: #22263a;--border: #2e3248;--text: #e8eaf0;--muted: #7b8199;--accent: #6c6ef5;--accent2: #8b8df7;--green: #34d399;--amber: #fbbf24;--red: #f87171;--radius: 12px;--radius-sm: 8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-size:15px;line-height:1.55}.page{min-height:100dvh;display:flex;flex-direction:column;max-width:640px;margin:0 auto}.page.centered{justify-content:center;align-items:center}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:8px}.header-right{display:flex;align-items:center;gap:4px}.header-title{font-size:17px;font-weight:600}.header-flag{font-size:20px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);border:none;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;width:100%}.btn:active{transform:scale(.98)}.btn:disabled,.btn-disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-small{padding:6px 14px;font-size:13px;width:auto}.icon-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:color .15s,background .15s}.icon-btn:hover{color:var(--text);background:var(--surface2)}.link-btn{background:none;border:none;color:var(--accent2);font-size:13px;cursor:pointer;padding:6px 0;text-align:center}.link-btn:hover{text-decoration:underline}.field{display:flex;flex-direction:column;gap:5px}.field-label{font-size:13px;color:var(--muted);font-weight:500}.field-input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:15px;padding:10px 12px;outline:none;width:100%;transition:border-color .15s}.field-input:focus{border-color:var(--accent)}.field-pw{position:relative}.field-pw .field-input{padding-right:40px}.pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%)}.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:radial-gradient(ellipse at top,#1a1d3a 0%,var(--bg) 60%)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px 28px;width:100%;max-width:400px;box-shadow:0 8px 32px #0006}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-flag{font-size:40px}.auth-title{font-size:24px;font-weight:700;margin-top:8px}.auth-subtitle{color:var(--muted);font-size:14px;margin-top:4px}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-hint{color:var(--muted);font-size:13px;line-height:1.5}.auth-switch{text-align:center;font-size:13px;color:var(--muted)}.auth-switch a{color:var(--accent2);text-decoration:none}.error-msg{color:var(--red);font-size:13px}.info-msg{color:var(--green);font-size:13px}.dashboard-main{padding:20px 16px;flex:1}.dashboard-welcome{display:flex;align-items:center;gap:12px;margin-bottom:20px}.dashboard-welcome h2{font-size:20px;font-weight:600}.difficulty-badge{background:var(--surface2);border:1px solid var(--border);border-radius:20px;font-size:11px;font-weight:600;color:var(--muted);padding:2px 10px}.suggestion-card{background:linear-gradient(135deg,#1e2040,#2a1e40);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:12px 14px;display:flex;align-items:center;gap:10px;font-size:13px;margin-bottom:20px;flex-wrap:wrap;color:var(--text)}.suggestion-card svg{color:var(--accent2);flex-shrink:0}.section-title{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.topic-list{display:flex;flex-direction:column;gap:8px}.topic-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;cursor:pointer;transition:border-color .15s,background .15s}.topic-card:hover{border-color:var(--accent);background:var(--surface2)}.topic-card.topic-needs-work{border-color:#fbbf2459}.topic-card-icon{font-size:26px;flex-shrink:0}.topic-card-body{flex:1;min-width:0}.topic-card-name{font-size:15px;font-weight:600}.topic-card-meta{font-size:12px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:6px}.topic-score{color:var(--text)}.topic-card-arrow{color:var(--muted);flex-shrink:0}.topic-badge-new{background:#6c6ef533;color:var(--accent2);border-radius:20px;padding:1px 7px;font-size:11px;font-weight:600}.topic-badge-warn{background:#fbbf2426;color:var(--amber);border-radius:20px;padding:1px 7px;font-size:11px;font-weight:600}.progress-bar-wrap{background:var(--surface2);border-radius:99px;height:5px;margin-top:6px;overflow:hidden;position:relative;width:100%}.progress-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.threshold-marker{position:absolute;top:0;width:2px;height:100%;background:#ffffff80;transform:translate(-50%)}.quiz-main{padding:16px;flex:1;display:flex;flex-direction:column;gap:16px}.quiz-progress-header{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted)}.quiz-level-badge{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:2px 9px;font-size:12px;font-weight:600;color:var(--accent2)}.quiz-progress-bar{height:4px;background:var(--surface2);border-radius:99px;overflow:hidden}.quiz-progress-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .4s ease}.quiz-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center}.quiz-lang-hint{font-size:12px;color:var(--muted);font-weight:500;letter-spacing:.05em;text-transform:uppercase;margin-bottom:10px}.quiz-lang-hint.center{text-align:center}.quiz-question{font-size:22px;font-weight:700;line-height:1.4}.quiz-answers{display:flex;flex-direction:column;gap:9px}.quiz-answer{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:15px;padding:14px 16px;text-align:left;transition:border-color .12s,background .12s;display:flex;align-items:center;gap:10px}.quiz-answer:hover:not(:disabled){border-color:var(--accent);background:var(--surface2)}.quiz-answer.answer-selected{border-color:var(--accent);background:#6c6ef51f}.quiz-answer.answer-correct{border-color:var(--green);background:#34d3991f}.quiz-answer.answer-wrong{border-color:var(--red);background:#f871711f}.quiz-answer.answer-dim{opacity:.4}.answer-icon{flex-shrink:0}.quiz-action{padding-top:4px}.results-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px 24px;max-width:420px;width:100%;margin:24px 16px;display:flex;flex-direction:column;align-items:center;gap:18px}.results-icon{display:flex}.results-pass{color:var(--green)}.results-fail{color:var(--amber)}.results-title{font-size:22px;font-weight:700}.results-score{text-align:center}.results-pct{display:block;font-size:48px;font-weight:800}.results-detail{color:var(--muted);font-size:14px}.results-threshold{font-size:13px;color:var(--muted);width:100%}.results-level-up{display:flex;align-items:center;gap:8px;background:#34d3991a;border:1px solid var(--green);border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;color:var(--green);width:100%}.results-hint{color:var(--muted);font-size:13px}.results-actions{display:flex;flex-direction:column;gap:9px;width:100%}.stats-main{padding:16px;flex:1;display:flex;flex-direction:column;gap:20px}.assessment-card{background:linear-gradient(135deg,#1e2040,#2a1e40);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:16px}.assessment-label{font-size:11px;font-weight:600;color:var(--accent2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.assessment-text{font-size:15px;font-weight:500}.stat-cards-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 12px;text-align:center}.stat-label{font-size:11px;color:var(--muted);font-weight:500;margin-bottom:6px}.stat-value{font-size:26px;font-weight:800}.stat-sub{font-size:11px;color:var(--muted);margin-top:4px}.chart-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}.chart-title{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:14px;text-transform:uppercase;letter-spacing:.05em}.topic-stats-list{display:flex;flex-direction:column;gap:10px}.topic-stat-row{display:flex;align-items:center;gap:10px}.topic-stat-icon{font-size:18px;flex-shrink:0}.topic-stat-name{font-size:13px;min-width:90px;flex-shrink:0}.topic-stat-level{font-size:11px;color:var(--muted);flex-shrink:0;min-width:32px}.topic-stat-bar{flex:1;margin-top:0}.topic-stat-pct{font-size:13px;font-weight:600;min-width:36px;text-align:right;flex-shrink:0}.customizing-main{padding:16px;flex:1;display:flex;flex-direction:column;gap:20px}.setting-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.setting-section-title{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;padding:14px 16px 10px;border-bottom:1px solid var(--border)}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:none}.setting-label{font-size:14px}.setting-value-static{font-size:14px;color:var(--muted)}.setting-hint{font-size:12px;color:var(--muted);padding:10px 16px}.option-group{display:flex;flex-direction:column}.option-btn{display:flex;flex-direction:column;align-items:flex-start;padding:13px 16px;border:none;background:none;cursor:pointer;border-bottom:1px solid var(--border);text-align:left;transition:background .12s}.option-btn:last-child{border-bottom:none}.option-btn:hover{background:var(--surface2)}.option-btn.option-active{background:#6c6ef51a}.option-btn.option-active .option-label{color:var(--accent2)}.option-label{font-size:14px;font-weight:600;color:var(--text)}.option-hint{font-size:12px;color:var(--muted);margin-top:2px}.setting-save-row{padding:0}.changelog-list{padding:12px 16px;display:flex;flex-direction:column;gap:16px}.changelog-popup{display:flex;flex-direction:column;gap:16px}.changelog-entry{display:flex;flex-direction:column;gap:4px}.changelog-version{font-size:11px;color:var(--accent2);font-weight:600;letter-spacing:.05em}.changelog-entry-title{font-size:15px;font-weight:600}.changelog-changes{list-style:none;display:flex;flex-direction:column;gap:4px;padding-left:2px}.changelog-change{font-size:13px;color:var(--muted)}.change-new{color:var(--text)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:440px;max-height:85dvh;overflow-y:auto;box-shadow:0 16px 48px #00000080}.modal-wide{max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface)}.modal-header h2{font-size:16px;font-weight:600}.modal-body{padding:20px 18px;display:flex;flex-direction:column;gap:16px}.loading-state{color:var(--muted);font-size:14px}.app-footer{display:flex;align-items:center;justify-content:center;gap:8px;font-size:11px;color:var(--muted);padding:12px 0 16px;border-top:1px solid var(--border);margin-top:auto}.footer-sep{opacity:.4}.footer-donate{color:var(--accent2);text-decoration:none;font-weight:500}.footer-donate:hover{text-decoration:underline}@media (max-width: 400px){.stat-cards-row{grid-template-columns:repeat(3,1fr)}.stat-value{font-size:20px}.quiz-question{font-size:19px}}
