:root{--bg:#eef1f4;--surface:#fff;--surface-2:#f7f8fa;--ink:#16203b;--muted:#5c6679;--line:#e2e6ec;--line-2:#c4ccd6;--accent:#1f7a8c;--accent-dk:#155e6c;--accent-2:#2bb3a3;--accent-bg:#e6f2f4;--ok:#2f8f5b;--ok-bg:#e8f5ee;--ok-line:#a9dcc0;--no:#c0453b;--no-bg:#fbebe9;--no-line:#e6bbb5;--warn:#b5852a;--warn-bg:#fbf1dc;--warn-line:#ead3a0;--ch:#6d4aa8;--radius:16px;--shadow:0 1px 2px #141e370d, 0 8px 28px #141e3712;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Be Vietnam Pro,system-ui,Segoe UI,Roboto,sans-serif;line-height:1.55}#app{min-height:100vh}.wrap{max-width:760px;margin:0 auto;padding:26px 16px 64px}.topnav{justify-content:space-between;align-items:center;gap:12px;margin-bottom:6px;padding:2px 2px 0;display:flex}.topnav .brand{color:var(--ink);font-family:Lora,Georgia,serif;font-size:15px;font-weight:600}.navlink{font:inherit;cursor:pointer;color:var(--accent-dk);background:var(--accent-bg);border:1px solid #bcdde2;border-radius:999px;padding:7px 15px;font-size:14px;font-weight:600;transition:all .15s}.navlink:hover{border-color:var(--accent);background:#fff}.about p{color:var(--ink);margin:0 0 10px;font-size:15px;line-height:1.65}.about a,.foot a{color:var(--accent);font-weight:600;text-decoration:none}.about a:hover,.foot a:hover{text-decoration:underline}.about-head{align-items:center;gap:14px;margin-bottom:6px;display:flex}.about-ava{color:#fff;background:linear-gradient(135deg, var(--accent), var(--accent-2));border-radius:16px;flex:none;place-items:center;width:56px;height:56px;font-family:Lora,Georgia,serif;font-size:19px;font-weight:600;display:grid;box-shadow:0 6px 16px #1f7a8c4d}.about-name{color:var(--ink);font-family:Lora,Georgia,serif;font-size:20px;font-weight:600}.about-role{color:var(--muted);margin-top:2px;font-size:13.5px}.about-links{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.about-links .btn{text-decoration:none}.src-list{margin:4px 0 10px;padding-left:20px}.src-list li{color:var(--ink);margin-bottom:4px;font-size:14.5px;line-height:1.7}.src-list li b{color:var(--accent-dk)}.hero{text-align:center;padding:10px 0 4px}.hero h1{letter-spacing:.2px;color:var(--ink);margin:0 0 8px;font-family:Lora,Georgia,serif;font-size:clamp(22px,4vw,32px);font-weight:600}.sub{color:var(--muted);margin:0;font-size:.95rem}.sub b{color:var(--accent-dk);font-weight:600}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin:16px 0;padding:22px}.card h2{text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin:22px 0 11px;font-size:12px;font-weight:600}.card h2:first-child{margin-top:0}.chip-row{flex-wrap:wrap;gap:9px;display:flex}.chip,.pill{cursor:pointer;border:1.5px solid var(--line);background:var(--surface-2);-webkit-user-select:none;user-select:none;border-radius:12px;align-items:center;gap:9px;padding:10px 14px;transition:all .15s;display:inline-flex;position:relative}.chip{border-radius:12px;width:100%}.pill{border-radius:999px}.chip:hover,.pill:hover{border-color:var(--line-2)}.chip input,.pill input{accent-color:var(--accent);flex:none;width:17px;height:17px}.chip span em,.chip span{color:var(--ink);font-size:14px}.chip span b{font-weight:600}.chip span em{color:var(--muted);font-style:normal}.chip-all{background:#fff}.pill span{color:var(--ink);font-size:14px}:is(.pill:has(input:checked),.chip:has(input:checked)){border-color:var(--accent);background:var(--accent-bg);box-shadow:inset 0 0 0 1px var(--accent)}.src-row{gap:12px}.srcpill{cursor:pointer;border:1.5px solid var(--line);background:var(--surface-2);-webkit-user-select:none;user-select:none;border-radius:14px;flex-direction:column;flex:240px;gap:4px;padding:15px 16px 15px 44px;transition:all .15s;display:flex;position:relative}.srcpill input{accent-color:var(--accent);width:18px;height:18px;position:absolute;top:17px;left:16px}.srcpill:hover{border-color:var(--line-2)}.srcpill.on{border-color:var(--accent);background:var(--accent-bg);box-shadow:inset 0 0 0 1px var(--accent)}.srcttl{color:var(--ink);font-family:Lora,Georgia,serif;font-size:16px;font-weight:600}.srcmeta{color:var(--accent-dk);font-size:13px;font-weight:600}.srcdesc{color:var(--muted);font-size:13px}.actions{flex-wrap:wrap;align-items:center;gap:14px;margin-top:22px;display:flex}.actions.center{justify-content:center}.btn{font:inherit;cursor:pointer;border:1.5px solid var(--line);color:var(--ink);background:#fff;border-radius:12px;padding:12px 20px;font-weight:600;transition:all .15s}.btn:hover{border-color:var(--line-2);background:var(--surface-2)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn.small{padding:8px 13px;font-size:13px}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 6px 18px #1f7a8c47}.btn.primary:hover{background:var(--accent-dk);border-color:var(--accent-dk)}.btn.success{background:var(--ok);border-color:var(--ok);color:#fff;box-shadow:0 6px 18px #2f8f5b42}.btn.success:hover{background:#277a4d;border-color:#277a4d}.btn.ghost{color:var(--muted);background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--surface-2);border-color:var(--line);color:var(--ink)}.count-info{color:var(--muted);font-size:14px}.btn.exam{background:linear-gradient(135deg, #7c4ddb, var(--ch));border-color:var(--ch);color:#fff;box-shadow:0 6px 18px #6d4aa847}.btn.exam:hover{filter:brightness(1.06);background:linear-gradient(135deg, #7c4ddb, var(--ch));border-color:var(--ch)}.exam-cta{border-top:1px dashed var(--line-2);flex-wrap:wrap;align-items:center;gap:14px;margin-top:16px;padding-top:16px;display:flex}.exam-note{color:var(--muted);font-size:13px;line-height:1.5}.exam-note b{color:var(--ch);font-weight:600}.tag-exam{color:#fff;background:linear-gradient(135deg, #7c4ddb, var(--ch))}.tag-pts{color:var(--accent-dk);background:var(--accent-bg);border:1px solid #bcdde2}.adv-toggle{width:100%;font:inherit;color:var(--ink);cursor:pointer;text-align:left;background:var(--surface-2);border:1.5px solid var(--line);border-radius:12px;align-items:center;gap:10px;margin-top:22px;padding:13px 16px;transition:all .15s;display:flex}.adv-toggle:hover{border-color:var(--line-2);background:#fff}.adv-ic{font-size:16px;line-height:1}.adv-label{font-weight:600}.adv-sum{color:var(--muted);font-size:13px;font-weight:400}.adv-arrow{color:var(--muted);margin-left:auto;transition:transform .2s}.adv-toggle.open .adv-arrow{transform:rotate(90deg)}.adv-toggle.open .adv-sum{display:none}.adv{max-height:0;transition:max-height .3s;overflow:hidden}.adv.open{max-height:2000px}.adv>h2:first-child{margin-top:20px}.history{flex-direction:column;gap:8px;display:flex}.hist-row{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;align-items:center;gap:14px;padding:9px 12px;font-size:14px;display:flex}.hist-pct{white-space:nowrap;width:62px;font-weight:700}.hist-pct small{color:var(--muted);font-size:11px;font-weight:600}.hist-pct.good{color:var(--ok)}.hist-pct.mid{color:var(--warn)}.hist-pct.bad{color:var(--no)}.muted{color:var(--muted)}.foot{text-align:center;color:var(--muted);margin-top:26px;font-size:12.5px}.foot b{color:var(--accent-dk);font-weight:600}.lock-btn{cursor:pointer;opacity:.3;vertical-align:middle;background:0 0;border:none;margin-left:6px;padding:2px 5px;font-size:13px;line-height:1;transition:opacity .15s}.lock-btn:hover{opacity:1}.topbar{align-items:center;gap:14px;margin-bottom:16px;display:flex}.progress{background:#dde2e9;border-radius:999px;flex:1;height:8px;overflow:hidden}.bar{background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:999px;height:100%;transition:width .35s cubic-bezier(.4,0,.2,1)}.counter{color:var(--muted);white-space:nowrap;font-size:14px}.counter b{color:var(--ink);font-size:16px}.question{padding:24px}.qmeta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.tag{border-radius:8px;padding:4px 10px;font-size:12px;font-weight:600}.tag-ch{color:#fff;background:var(--ch)}.tag-type{color:var(--accent-dk);background:var(--accent-bg);border:1px solid #bcdde2}.tag-lv.lv15{color:var(--ok);background:var(--ok-bg)}.tag-lv.lv25{color:var(--warn);background:var(--warn-bg)}.tag-lv.lv35{color:var(--no);background:var(--no-bg)}.lvpill span em{color:var(--muted);font-size:13px;font-style:normal}.lvpill .lvdot{border-radius:50%;flex:none;width:9px;height:9px}.lvpill.lv15:has(input:checked){border-color:var(--ok);background:var(--ok-bg);box-shadow:inset 0 0 0 1px var(--ok)}.lvpill.lv25:has(input:checked){border-color:var(--warn);background:var(--warn-bg);box-shadow:inset 0 0 0 1px var(--warn)}.lvpill.lv35:has(input:checked){border-color:var(--no);background:var(--no-bg);box-shadow:inset 0 0 0 1px var(--no)}.lvpill.lv15 input{accent-color:var(--ok)}.lvpill.lv25 input{accent-color:var(--warn)}.lvpill.lv35 input{accent-color:var(--no)}.sec-box{flex-direction:column;gap:9px;display:flex}.sec-row{gap:8px}.sec-all{background:#fff}.secpill span em{color:var(--muted);font-size:13px;font-style:normal}.sec-hint{color:var(--muted);background:var(--surface-2);border:1px dashed var(--line-2);border-radius:12px;padding:12px 14px;font-size:14px}.sec-hint b{color:var(--accent-dk)}.flag{color:var(--line-2);cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:20px;line-height:1;transition:all .15s}.flag:hover{color:var(--warn);transform:scale(1.15)}.flag.on{color:var(--warn)}.qsec{color:var(--accent-dk);background:var(--accent-bg);border:1px solid #bcdde2;border-radius:8px;align-items:center;gap:6px;margin-bottom:14px;padding:5px 11px;font-size:12.5px;font-weight:600;display:inline-flex}.qsec-ic{opacity:.8;font-size:11px}.stem{color:var(--ink);white-space:pre-wrap;margin-bottom:18px;font-family:Lora,Georgia,serif;font-size:1.18rem;font-weight:500;line-height:1.45}.stmts{flex-direction:column;gap:8px;margin:0 0 18px;padding:0;list-style:none;display:flex}.stmts li{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;align-items:flex-start;gap:11px;padding:10px 13px;font-size:15px;display:flex}.sn{border:1px solid var(--line);width:24px;height:24px;color:var(--accent-dk);background:#fff;border-radius:7px;flex:none;place-items:center;font-size:13px;font-weight:700;display:grid}.choices{flex-direction:column;gap:10px;display:flex}.choice{text-align:left;cursor:pointer;background:var(--surface-2);border:1.5px solid var(--line);width:100%;color:var(--ink);font:inherit;border-radius:12px;align-items:center;gap:13px;padding:13px 15px;transition:border-color .15s,background .15s;display:flex}.choice:hover:not(:disabled){border-color:var(--accent);background:#fff}.choice .key{border:1.5px solid var(--line);width:28px;height:28px;color:var(--muted);background:#fff;border-radius:8px;flex:none;place-items:center;font-size:.82rem;font-weight:700;transition:all .15s;display:grid}.choice .txt{font-size:15px;line-height:1.45}.choice.selected{border-color:var(--accent);background:var(--accent-bg)}.choice.selected .key{background:var(--accent);color:#fff;border-color:var(--accent)}.choice.correct{border-color:var(--ok-line);background:var(--ok-bg)}.choice.correct .key{background:var(--ok);color:#fff;border-color:var(--ok)}.choice.wrong{border-color:var(--no-line);background:var(--no-bg)}.choice.wrong .key{background:var(--no);color:#fff;border-color:var(--no)}.choice:disabled{cursor:default}.match{gap:14px;display:grid}.bank{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:13px 15px}.bank-title{text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:8px;font-size:12px}.bankitem{align-items:baseline;gap:9px;padding:4px 0;font-size:15px;display:flex}.bankitem .key{color:var(--accent-dk);flex:none;width:22px;font-weight:700}.blanks{flex-direction:column;gap:9px;display:flex}.blankrow{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.blabel{min-width:120px;font-weight:600}.bselect{min-width:200px;font:inherit;color:var(--ink);border:1.5px solid var(--line);background:#fff;border-radius:10px;flex:1;padding:10px 12px}.bselect:focus{border-color:var(--accent);outline:none}.blankrow.correct .bselect{border-color:var(--ok);background:var(--ok-bg)}.blankrow.wrong .bselect{border-color:var(--no);background:var(--no-bg)}.fixhint{color:var(--ok);font-size:13px;font-weight:600}.feedback{border-radius:12px;margin-top:18px;padding:14px 16px;font-size:15px;line-height:1.5;display:none}.feedback.show{animation:.25s pop;display:block}.feedback.ok{background:var(--ok-bg);border:1px solid var(--ok-line);color:#1d5e3a}.feedback.ok b{color:var(--ok)}.feedback.no{background:var(--no-bg);border:1px solid var(--no-line);color:#8a2f28}.feedback.no b{color:var(--no)}.feedback.warn{background:var(--warn-bg);border:1px solid var(--warn-line);color:#7a5a18}.feedback .ans{font-weight:700}.feedback .explain{color:var(--ink);border-top:1px solid #16203b1f;margin-top:10px;padding-top:10px;font-size:14px;font-weight:400;line-height:1.6}@keyframes pop{0%{opacity:0;transform:translateY(6px)}}.navbar{align-items:center;gap:10px;margin:18px 0 8px;display:flex}.grow{flex:1}.dotgrid{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:10px;display:flex}.dot{border:1.5px solid var(--line);width:32px;height:32px;color:var(--muted);cursor:pointer;background:#fff;border-radius:9px;font-size:12px;font-weight:600;transition:all .12s;position:relative}.dot:hover{border-color:var(--accent);color:var(--ink)}.dot.active{border-color:var(--accent);color:#fff;background:var(--accent)}.dot.a{background:var(--accent-bg);color:var(--accent-dk);border-color:#bcdde2}.dot.c{background:var(--ok-bg);border-color:var(--ok-line);color:var(--ok)}.dot.w{background:var(--no-bg);border-color:var(--no-line);color:var(--no)}.dot.active.a,.dot.active.c,.dot.active.w{color:#fff;background:var(--accent);border-color:var(--accent)}.dot.f:after{content:"★";color:var(--warn);font-size:11px;position:absolute;top:-7px;right:-4px}.result{text-align:center}.result h1{margin:16px 0 4px;font-family:Lora,Georgia,serif;font-weight:600}.ring{border:7px solid var(--accent);background:#fff;border-radius:50%;place-items:center;width:150px;height:150px;margin:6px auto 4px;display:grid}.ring.good{border-color:var(--ok)}.ring.mid{border-color:var(--warn)}.ring.bad{border-color:var(--no)}.ring span{color:var(--ink);font-family:Lora,Georgia,serif;font-size:40px;font-weight:600}.ring small{color:var(--muted);font-size:18px}.rev{border-left:3px solid var(--line);background:var(--surface-2);border-radius:0 10px 10px 0;margin:10px 0;padding:11px 15px}.rev.ok{border-color:var(--ok)}.rev.no{border-color:var(--no)}.rev-h{align-items:flex-start;gap:10px;display:flex}.rev-i{border:1px solid var(--line);width:24px;height:24px;color:var(--muted);background:#fff;border-radius:7px;flex:none;place-items:center;font-size:12px;font-weight:700;display:grid}.rev-st{font-size:15px}.rev-sec{color:var(--accent-dk);align-items:center;gap:7px;margin-top:5px;padding-left:34px;font-size:12.5px;display:flex}.rev-lv{border-radius:6px;padding:1px 7px;font-weight:700}.rev-lv.lv15{color:var(--ok);background:var(--ok-bg)}.rev-lv.lv25{color:var(--warn);background:var(--warn-bg)}.rev-lv.lv35{color:var(--no);background:var(--no-bg)}.rev-a{color:var(--muted);margin-top:6px;padding-left:34px;font-size:14px}.rev-a .g{color:var(--ok)}@media (width<=600px){.wrap{padding:16px 12px 50px}.question{padding:18px 16px}.stem{font-size:1.08rem}.blabel{min-width:90px}.dot{width:28px;height:28px}}
