@font-face{font-family:Playpen;src:url(/fonts/PlaypenSansThai-Regular.ttf);font-weight:400;font-display:swap}@font-face{font-family:Playpen;src:url(/fonts/PlaypenSansThai-SemiBold.ttf);font-weight:600;font-display:swap}@font-face{font-family:Playpen;src:url(/fonts/PlaypenSansThai-Bold.ttf);font-weight:700;font-display:swap}:root{--ink:#232333;--bg:#f5f6fb;--card:#fff;--brand:#4f46e5;--line:#e5e7eb;--ok:#15803d;--okbg:#e3f7ec;--bad:#b91c1c;--badbg:#ffeceb}*{box-sizing:border-box}body{margin:0;font-family:Playpen,Segoe UI,sans-serif;background:var(--bg);color:var(--ink)}a{color:var(--brand);text-decoration:none}.container{max-width:820px;margin:0 auto;padding:24px 18px 70px}.hdr{background:#1f2233;color:#fff;padding:12px 18px;display:flex;align-items:center;gap:14px}.hdr a{color:#fff;font-weight:700}.hdr .sp{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:14px}.hdr button{font-family:inherit;cursor:pointer;border:none;background:#3a3f5e;color:#fff;padding:6px 12px;border-radius:8px;font-size:13px}.card{background:var(--card);border:1.5px solid var(--line);border-radius:14px;padding:16px 18px;margin:14px 0;box-shadow:0 1px 2px rgba(0,0,0,.04)}.chapTitle{font-size:20px;font-weight:700;margin:0 0 4px}.subrow{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-top:1px solid var(--line)}.subrow:first-of-type{border-top:none}.badge{display:inline-block;min-width:42px;text-align:center;font-size:12px;background:#eef2ff;color:#312e81;border-radius:8px;padding:2px 8px;margin-right:8px}.btn{font-family:inherit;cursor:pointer;border:none;background:var(--brand);color:#fff;font-weight:600;font-size:15px;padding:10px 18px;border-radius:10px}.btn:hover{background:#5b53ec}.btn.sec{background:#6b7280}.btn.sm{padding:7px 13px;font-size:13px}.btn:disabled{opacity:.5;cursor:default}.qprompt{font-weight:600;font-size:16px;margin:4px 0 12px}.opt{display:flex;align-items:center;gap:9px;padding:11px 14px;margin:7px 0;border:1.6px solid var(--line);border-radius:10px;cursor:pointer;font-size:14.5px;background:#fff}.opt:hover{background:#f3f4ff}.opt.correct{background:var(--okbg);border-color:#3fb579}.opt.wrong{background:var(--badbg);border-color:#e05a4f}.opt.disabled{cursor:default}.exp{margin-top:10px;font-size:13.5px;color:#444;background:#f8f9ff;border-radius:9px;padding:9px 12px}.result{margin:14px 0;padding:14px;border-radius:11px;text-align:center;font-weight:700;font-size:17px}.result.pass{background:var(--okbg);color:var(--ok)}.result.fail{background:#fff4e5;color:#a3530a}.form{max-width:380px;margin:40px auto}.form input{width:100%;font-family:inherit;font-size:15px;padding:11px 13px;margin:7px 0;border:1.6px solid var(--line);border-radius:10px}.err{color:var(--bad);margin:6px 0}.err,.muted{font-size:13.5px}.muted{color:#6b7280}h1.page{font-size:24px}.lesson h3{font-size:16px;color:#4338ca;margin:16px 0 6px}.lesson h4{font-size:14px;margin:12px 0 4px}.lesson li,.lesson p{font-size:14.5px;line-height:1.7}.lesson ol,.lesson ul{padding-left:22px}.lesson code{font-family:DejaVu Sans Mono,Consolas,monospace;background:#eef0f4;color:#be185d;padding:1px 5px;border-radius:4px;font-size:12.5px}.lesson pre{background:#1e1e2e;color:#e6e6e6;padding:13px 15px;border-radius:9px;overflow:auto;font-size:12.5px;line-height:1.55;margin:10px 0}.lesson pre code{background:none;color:inherit;padding:0}.lesson blockquote{border-left:4px solid #f59e0b;background:#fffbeb;margin:12px 0;padding:8px 14px;border-radius:0 7px 7px 0;color:#92400e;font-size:13.5px}.lesson table{border-collapse:collapse;width:100%;margin:12px 0;font-size:13px}.lesson td,.lesson th{border:1px solid var(--line);padding:6px 9px;text-align:left}.lesson th{background:#eef2ff;color:#312e81}.codehilite .k{color:#c792ea}.codehilite .s,.codehilite .s1,.codehilite .s2{color:#c3e88d}.codehilite .c,.codehilite .c1{color:#8b90a8;font-style:italic}.codehilite .nf,.codehilite .nx{color:#82aaff}.codehilite .mf,.codehilite .mi{color:#f78c6c}.codehilite .nt{color:#f07178}.codehilite .o{color:#89ddff}.codehilite .kc,.codehilite .nb{color:#ffcb6b}