:root{--bg: #ffffff;--bg2: #f6f6f6;--bg3: #eeeeee;--fg: #111111;--fg2: #444444;--fg3: #888888;--border: #cccccc;--accent: #111111;--accent-inv: #ffffff;--correct: #1a7a1a;--correct-bg: #eaf6ea;--incorrect: #b00000;--incorrect-bg: #fdecea;--pass: #1a6e1a;--pass-bg: #eaf6ea;--fail: #b00000;--fail-bg: #fdecea;--radius: 6px;--shadow: 0 1px 4px rgba(0,0,0,.08);--font: "Inter", system-ui, -apple-system, Arial, sans-serif}[data-theme=dark],.dark{--bg: #0e0e0e;--bg2: #1a1a1a;--bg3: #252525;--fg: #f0f0f0;--fg2: #bbbbbb;--fg3: #777777;--border: #333333;--accent: #f0f0f0;--accent-inv: #0e0e0e;--correct: #4caf50;--correct-bg: #0d2e0d;--incorrect: #ef5350;--incorrect-bg: #2e0d0d;--pass: #4caf50;--pass-bg: #0d2e0d;--fail: #ef5350;--fail-bg: #2e0d0d;--shadow: 0 1px 4px rgba(0,0,0,.4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);font-size:16px;line-height:1.6;background:var(--bg);color:var(--fg);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border);padding:0 20px;display:flex;align-items:center;gap:16px;height:52px}.app-title{font-size:18px;font-weight:700;white-space:nowrap}.title-ged{letter-spacing:1px}.title-prep{font-weight:300}.tab-nav{display:flex;gap:2px;flex:1;overflow-x:auto;scrollbar-width:none}.tab-nav::-webkit-scrollbar{display:none}.tab-btn{background:none;border:none;color:var(--fg3);font-size:14px;font-family:var(--font);padding:6px 14px;cursor:pointer;border-radius:var(--radius);white-space:nowrap;transition:color .15s,background .15s}.tab-btn:hover{color:var(--fg);background:var(--bg2)}.tab-btn.active{color:var(--fg);font-weight:600;background:var(--bg3)}.theme-toggle{background:none;border:1px solid var(--border);color:var(--fg);font-size:18px;width:34px;height:34px;border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.app-main{flex:1;max-width:860px;margin:0 auto;padding:24px 20px;width:100%}.loading{text-align:center;padding:60px;color:var(--fg3)}.empty{text-align:center;padding:40px;color:var(--fg3)}.question-card{display:flex;flex-direction:column;gap:16px}.q-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--fg3)}.q-subject{font-weight:600;color:var(--fg2)}.q-section:before{content:"·";margin-right:8px}.q-count{margin-left:auto;font-variant-numeric:tabular-nums}.passage-block{background:var(--bg2);border-left:3px solid var(--border);padding:14px 16px;border-radius:0 var(--radius) var(--radius) 0;font-size:14px;color:var(--fg2);max-height:220px;overflow-y:auto}.passage-title{font-weight:700;font-size:13px;margin-bottom:8px;color:var(--fg)}.passage-text{line-height:1.7}.figure-block{margin:16px 0;padding:12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);text-align:center}.figure-block img{max-width:100%;height:auto;display:inline-block}.question-text{font-size:17px;font-weight:500;line-height:1.5}.options{display:flex;flex-direction:column;gap:8px}.option{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg);font-family:var(--font);font-size:15px;text-align:left;cursor:pointer;transition:border-color .15s,background .15s;width:100%}.option:hover:not(:disabled){border-color:var(--fg);background:var(--bg2)}.option:disabled{cursor:default}.option.selected{border-color:var(--fg);background:var(--bg3)}.option.correct{border-color:var(--correct);background:var(--correct-bg);color:var(--correct)}.option.incorrect{border-color:var(--incorrect);background:var(--incorrect-bg);color:var(--incorrect)}.opt-label{font-weight:700;flex-shrink:0;min-width:20px}.feedback{padding:14px 16px;border-radius:var(--radius);font-size:14px;line-height:1.6}.feedback-correct{background:var(--correct-bg);border:1px solid var(--correct);color:var(--correct)}.feedback-incorrect{background:var(--incorrect-bg);border:1px solid var(--incorrect);color:var(--fg)}.feedback-verdict{font-weight:700;margin-bottom:6px}.feedback-explanation,.feedback-incorrect .feedback-explanation{color:var(--fg2)}.q-nav{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.nav-btn{padding:8px 20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg);font-family:var(--font);font-size:14px;cursor:pointer;transition:background .15s}.nav-btn:hover{background:var(--bg2)}.nav-btn.primary{background:var(--accent);color:var(--accent-inv);border-color:var(--accent)}.nav-btn.primary:hover{opacity:.85}.practice-section{display:flex;flex-direction:column;gap:20px}.practice-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.practice-header h2{font-size:22px;font-weight:700}.subject-filter{display:flex;gap:6px;flex-wrap:wrap}.filter-btn{padding:5px 12px;border:1px solid var(--border);border-radius:20px;background:var(--bg);color:var(--fg2);font-size:13px;font-family:var(--font);cursor:pointer;transition:all .15s}.filter-btn:hover{border-color:var(--fg);color:var(--fg)}.filter-btn.active{background:var(--accent);color:var(--accent-inv);border-color:var(--accent)}.timed-section{display:flex;flex-direction:column;gap:24px}.timed-section h2{font-size:22px;font-weight:700}.timed-intro{color:var(--fg2)}.test-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.test-card{border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:8px}.test-card-name{font-weight:700;font-size:15px}.test-card-desc{font-size:13px;color:var(--fg2)}.test-card-pool{font-size:12px;color:var(--fg3)}.start-btn{margin-top:auto;padding:8px 16px;background:var(--accent);color:var(--accent-inv);border:none;border-radius:var(--radius);font-family:var(--font);font-size:14px;cursor:pointer}.start-btn:hover{opacity:.85}.start-btn:disabled{opacity:.4;cursor:default}.timed-bar{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius)}.timed-bar-left{display:flex;flex-direction:column;gap:2px;flex:1}.timed-test-name{font-weight:600;font-size:14px}.timed-q-pos{font-size:12px;color:var(--fg3)}.timer{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums}.timer.warning{color:#b05800}.timer.urgent{color:var(--incorrect)}.end-btn{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg);font-family:var(--font);font-size:13px;cursor:pointer}.end-btn:hover{background:var(--bg3)}.test-results{display:flex;flex-direction:column;gap:20px;max-width:480px}.test-results h2{font-size:22px;font-weight:700}.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.result-stat{text-align:center;padding:16px;border:1px solid var(--border);border-radius:var(--radius)}.stat-val{font-size:28px;font-weight:700;display:block}.stat-label{font-size:12px;color:var(--fg3);margin-top:4px;display:block}.results-note{font-size:14px;color:var(--fg2);line-height:1.6}.progress-section{display:flex;flex-direction:column;gap:24px}.progress-header{display:flex;justify-content:space-between;align-items:center}.progress-header h2{font-size:22px;font-weight:700}.clear-btn{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg3);font-family:var(--font);font-size:13px;cursor:pointer}.clear-btn:hover{color:var(--incorrect);border-color:var(--incorrect)}.progress-actions{display:flex;gap:8px}.action-btn{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg3);font-family:var(--font);font-size:13px;cursor:pointer}.action-btn:hover{color:var(--accent);border-color:var(--accent)}.readiness{border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;display:flex;flex-direction:column;gap:10px;background:var(--bg2)}.readiness.is-ready{border-color:var(--pass);background:var(--pass-bg)}.readiness-top{display:flex;justify-content:space-between;align-items:baseline}.readiness-title{font-size:16px;font-weight:700}.readiness-frac{font-size:13px;color:var(--fg3)}.readiness-bar-wrap{height:10px;border-radius:999px;background:var(--bg3);overflow:hidden}.readiness-bar{height:100%;background:var(--pass);border-radius:999px;transition:width .4s ease}.readiness-chips{display:flex;flex-wrap:wrap;gap:8px}.rchip{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;border:1px solid var(--border)}.rchip.ok{color:var(--pass);border-color:var(--pass);background:var(--pass-bg)}.rchip.thin{color:var(--fg2)}.rchip.low{color:var(--fail);border-color:var(--fail);background:var(--fail-bg)}.readiness-msg{font-size:13px;line-height:1.6;color:var(--fg2)}.readiness-msg a{color:inherit;font-weight:700}.readiness-tip{color:var(--fg3)}.overall-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.overall-stat{text-align:center;padding:14px;border:1px solid var(--border);border-radius:var(--radius)}.stat-num{display:block;font-size:26px;font-weight:700}.stat-desc{display:block;font-size:12px;color:var(--fg3);margin-top:2px}.progress-section h3{font-size:16px;font-weight:600;color:var(--fg2)}.subject-stats{display:flex;flex-direction:column;gap:14px}.subject-card{border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:8px}.subject-card.pass{border-color:var(--pass)}.subject-card.fail{border-color:var(--fail)}.sc-name{font-weight:600;font-size:15px}.sc-bar-wrap{height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}.sc-bar{height:100%;background:var(--fg);border-radius:2px;transition:width .4s}.sc-numbers{display:flex;justify-content:space-between;font-size:13px;color:var(--fg3)}.sc-score{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.sc-pct{font-size:20px;font-weight:700}.sc-ged{font-size:13px}.sc-ged.pass{color:var(--pass)}.sc-ged.fail{color:var(--fail)}.sc-score-empty{font-size:13px;color:var(--fg3)}.progress-note{font-size:12px;color:var(--fg3);padding-top:4px}.review-section{display:flex;flex-direction:column;gap:20px}.review-header{display:flex;justify-content:space-between;align-items:center}.review-header h2{font-size:22px;font-weight:700}.missed-count{font-size:13px;color:var(--fg3)}.empty-review{padding:40px;text-align:center;color:var(--fg3);border:1px solid var(--border);border-radius:var(--radius)}.planner-section{display:flex;flex-direction:column;gap:20px}.planner-section h2{font-size:22px;font-weight:700}.planner-form{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg2)}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:13px;color:var(--fg2);font-weight:600}.form-group input,.form-group select{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg);font-family:var(--font);font-size:14px;width:100%}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--fg)}.score-inputs{display:flex;flex-direction:column;gap:6px}.score-row{display:flex;align-items:center;gap:8px;font-size:13px}.score-row span{flex:1}.score-row input{width:64px;flex-shrink:0;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg);font-family:var(--font)}.planner-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.generate-btn{padding:9px 20px;background:var(--accent);color:var(--accent-inv);border:none;border-radius:var(--radius);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer}.generate-btn:hover{opacity:.85}.plan-status{font-size:13px;color:var(--fg3)}.pace-status{font-size:13px;font-weight:600}.pace-ahead{color:var(--pass)}.pace-behind{color:var(--fail)}.plan-grid{display:flex;flex-direction:column;gap:8px}.plan-day{border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.plan-day.done{opacity:.55;background:var(--bg2)}.plan-day.today{border-color:var(--fg)}.plan-day-date{font-weight:600;font-size:14px;white-space:nowrap}.plan-day-tasks{flex:1;display:flex;flex-direction:column;gap:2px}.plan-task{font-size:13px;color:var(--fg2)}.plan-task strong{color:var(--fg)}.mark-btn{padding:4px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg);font-family:var(--font);font-size:12px;cursor:pointer;white-space:nowrap;flex-shrink:0}.mark-btn:hover{background:var(--bg3)}.practice-settings{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius)}.setting-group{display:flex;align-items:center;gap:4px;padding-left:12px;border-left:1px solid var(--border)}.practice-settings>.setting-btn:last-child{margin-left:auto}.setting-label{font-size:12px;color:var(--fg3);margin-right:2px}.setting-btn{padding:4px 11px;border:1px solid var(--border);border-radius:20px;background:var(--bg);color:var(--fg2);font-size:13px;font-family:var(--font);cursor:pointer;transition:all .15s;white-space:nowrap}.setting-btn:hover{border-color:var(--fg);color:var(--fg)}.setting-btn.active{background:var(--accent);color:var(--accent-inv);border-color:var(--accent)}.q-timer-bar{display:flex;align-items:center;gap:8px}.q-timer-track{flex:1;height:5px;background:var(--bg3);border-radius:3px;overflow:hidden}.q-timer-fill{height:100%;background:var(--correct);border-radius:3px;transition:width .9s linear,background .3s}.q-timer-fill.warning{background:#d97706}.q-timer-fill.urgent{background:var(--incorrect)}.q-timer-num{font-size:12px;font-variant-numeric:tabular-nums;color:var(--fg3);min-width:3ch;text-align:right;flex-shrink:0}.kbd-hint{font-size:11px;color:var(--fg3);text-align:center;letter-spacing:.02em;padding-top:2px}.drill-advance{margin-top:8px;font-size:13px;color:var(--fg3);font-style:italic}.feedback-timeout{background:var(--bg3);border:1px solid var(--border);color:var(--fg2)}@media (max-width: 600px){.app-header{padding:0 12px;gap:10px}.app-main{padding:16px 12px}.overall-stats{grid-template-columns:repeat(2,1fr)}.planner-form{grid-template-columns:1fr}.practice-header{flex-direction:column;align-items:flex-start}.results-grid{grid-template-columns:repeat(3,1fr)}}
