:root{--bg: #f6f7fb;--surface: #ffffff;--surface-2: #f0f1f7;--text: #1b1d29;--muted: #6b7180;--border: #e5e7f0;--brand: #4f46e5;--brand-weak: #eef0fe;--good: #16a34a;--good-weak: #e7f6ec;--bad: #dc2626;--bad-weak: #fdecec;--warn: #d97706;--shadow: 0 1px 2px rgba(20, 22, 40, .06), 0 4px 16px rgba(20, 22, 40, .06);--radius: 16px;color-scheme:light dark}@media(prefers-color-scheme:dark){:root{--bg: #0f1117;--surface: #181b24;--surface-2: #1f2330;--text: #eceef5;--muted: #969db0;--border: #2a2f3d;--brand: #7c78ff;--brand-weak: #22233a;--good: #3ec77a;--good-weak: #16281d;--bad: #ff6b6b;--bad-weak: #2a1a1c;--warn: #f0a83b;--shadow: 0 1px 2px rgba(0, 0, 0, .3), 0 6px 20px rgba(0, 0, 0, .35)}}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Pretendard,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.55}.app{max-width:560px;margin:0 auto;min-height:100%;padding:16px 16px calc(88px + env(safe-area-inset-bottom))}h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.01em}.page-title{font-size:22px;margin-bottom:4px}.page-sub{color:var(--muted);font-size:14px;margin-bottom:18px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.card+.card{margin-top:14px}.section-title{font-size:15px;color:var(--muted);margin:22px 4px 10px;font-weight:600}.gauge{text-align:center;padding:10px 0 4px}.gauge .score{font-size:56px;font-weight:800;line-height:1;letter-spacing:-.03em}.gauge .score .unit{font-size:22px;font-weight:600;color:var(--muted)}.gauge .label{color:var(--muted);font-size:13px;margin-top:6px}.gauge.pass .score{color:var(--good)}.gauge.fail .score{color:var(--warn)}.bar{height:10px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-top:12px;position:relative}.bar>span{display:block;height:100%;border-radius:999px;background:var(--brand);transition:width .4s ease}.bar.good>span{background:var(--good)}.bar.warn>span{background:var(--warn)}.bar .cut{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--text);opacity:.35}.tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}.tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.tile .n{font-size:30px;font-weight:800;letter-spacing:-.02em}.tile .t{color:var(--muted);font-size:13px;margin-top:2px}.tile.due .n{color:var(--brand)}.tile.new .n{color:var(--warn)}button{font-family:inherit}.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:15px 18px;border:none;border-radius:14px;background:var(--brand);color:#fff;font-size:16px;font-weight:700;cursor:pointer;box-shadow:var(--shadow);transition:transform .06s ease,filter .15s}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:default}.btn.secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:none}.btn.ghost{background:transparent;color:var(--brand);box-shadow:none}.btn.sm{padding:10px 14px;font-size:14px;width:auto}.btn-row{display:flex;gap:10px;margin-top:12px}.row{display:flex;align-items:center;gap:12px;padding:13px 4px}.row+.row{border-top:1px solid var(--border)}.row .grow{flex:1;min-width:0}.row .name{font-weight:600;font-size:15px}.row .meta{color:var(--muted);font-size:12.5px;margin-top:1px}.row .val{font-weight:700;font-variant-numeric:tabular-nums}.pill{font-size:11.5px;padding:3px 8px;border-radius:999px;background:var(--surface-2);color:var(--muted);font-weight:600}.pill.due{background:var(--brand-weak);color:var(--brand)}.pill.weak{background:var(--bad-weak);color:var(--bad)}.pill.phase{background:var(--surface-2)}.tappable{cursor:pointer;border-radius:12px}.tappable:active{background:var(--surface-2)}.mini-bar{height:6px;width:100%;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-top:6px}.mini-bar>span{display:block;height:100%}.session-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}.progress{flex:1;height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden}.progress>span{display:block;height:100%;background:var(--brand);transition:width .3s}.close-x{background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;padding:0 4px;line-height:1}.q-tag{display:inline-block;font-size:12px;color:var(--brand);background:var(--brand-weak);padding:4px 10px;border-radius:999px;font-weight:600;margin-bottom:12px}.q-stem{font-size:18px;font-weight:600;line-height:1.5;margin-bottom:18px}.choices{display:flex;flex-direction:column;gap:10px}.choice{display:flex;gap:12px;align-items:flex-start;text-align:left;width:100%;padding:14px 15px;border:1.5px solid var(--border);border-radius:14px;background:var(--surface);color:var(--text);font-size:15.5px;cursor:pointer;transition:border-color .12s,background .12s}.choice:active{background:var(--surface-2)}.choice .num{flex:0 0 24px;height:24px;border-radius:999px;background:var(--surface-2);color:var(--muted);font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}.choice.correct{border-color:var(--good);background:var(--good-weak)}.choice.correct .num{background:var(--good);color:#fff}.choice.wrong{border-color:var(--bad);background:var(--bad-weak)}.choice.wrong .num{background:var(--bad);color:#fff}.choice.dim{opacity:.55}.choice[disabled]{cursor:default}.explain{margin-top:16px;padding:14px 15px;border-radius:14px;background:var(--surface-2);font-size:14.5px;line-height:1.6}.explain .verdict{font-weight:800;margin-right:6px}.explain .verdict.o{color:var(--good)}.explain .verdict.x{color:var(--bad)}.reveal-topic{display:inline-block;font-size:12.5px;font-weight:700;color:var(--brand);background:var(--brand-weak);padding:5px 11px;border-radius:999px;margin-top:16px}.tip{margin-top:12px;padding:10px 12px;border-radius:10px;background:var(--good-weak);color:var(--text);font-size:13.5px;line-height:1.55;border-left:3px solid var(--good)}.source-note{margin-top:12px;font-size:12px;color:var(--muted);line-height:1.5}.source-note .amended{color:var(--warn);font-weight:700}.result-big{text-align:center;padding:24px 0}.result-big .emoji{font-size:44px}.result-big .headline{font-size:22px;font-weight:800;margin-top:6px}.result-big .sub{color:var(--muted);margin-top:4px}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:20;display:flex;justify-content:center;gap:4px;background:color-mix(in srgb,var(--surface) 88%,transparent);-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-top:1px solid var(--border);padding:8px 8px calc(8px + env(safe-area-inset-bottom))}.tabbar .inner{display:flex;width:100%;max-width:560px}.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px;background:none;border:none;color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;text-decoration:none}.tab .ic{font-size:20px;line-height:1}.tab.active{color:var(--brand)}.empty{text-align:center;color:var(--muted);padding:40px 20px}.empty .emoji{font-size:36px}.hstack{display:flex;align-items:center;gap:8px}.spacer{flex:1}.link{color:var(--brand);font-weight:600;cursor:pointer;background:none;border:none;font-size:14px;padding:0}
