:root{--bg:#FBF7FF;--bg2:#F3ECFE;--card:#FFFFFF;--ink:#1B1430;--ink2:#5A5170;--muted:#9A8FB4;--line:#ECE4FA;--outline:#1B1430;--primary:#7C4DFF;--primary-d:#5B27F0;--primary-soft:#EEE6FF;--pink:#FF4D8D;--pink-soft:#FFE3EE;--cyan:#13C2C2;--cyan-soft:#DEFAFA;--lime:#A7E635;--gold:#FFB72B;--gold-soft:#FFF0D2;--green:#23C765;--green-soft:#DEF8E8;--green-d:#16A552;--red:#FF5470;--red-soft:#FFE3E8;--tone-mid:#8B8FA0;--tone-low:#3B82F6;--tone-falling:#9B5BE6;--tone-high:#F59E0B;--tone-rising:#10B981;--ele:#A6C2DC;--ele-in:#84A6C6;--ele-dk:#5E82A6;--cheek:#F4A6A0;--font-d:"Fredoka",sans-serif;--font-ui:"Nunito",sans-serif;--font-th:"Noto Sans Thai Looped",sans-serif;--r:20px;--sh:4px 5px 0 var(--outline);--sh-sm:3px 3px 0 var(--outline)}*{box-sizing:border-box}html,body{margin:0;padding:0}button{font-family:inherit;cursor:pointer;border:none;background:none}.app-root{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;display:flex;justify-content:center;align-items:stretch;background:var(--bg);font-family:var(--font-ui)}.app-frame{position:relative;width:100%;max-width:480px;height:100%;display:flex;background:var(--bg)}.screen{position:relative;width:100%;height:100%;overflow:hidden;background:var(--bg);display:flex;flex-direction:column;color:var(--ink)}.safetop{flex:0 0 auto;height:env(safe-area-inset-top,0px)}@media (min-width:520px){.app-root{align-items:center;background:radial-gradient(125% 120% at 50% -10%,#efe7ff,#e7ddfb 55%,#ddd0f6)}.app-frame{height:min(920px,100%);margin:auto;border-left:2.5px solid var(--outline);border-right:2.5px solid var(--outline);box-shadow:0 30px 80px #28125038}}.scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.scroll::-webkit-scrollbar{width:0;display:none}.scroll{scrollbar-width:none}.pad{padding:0 18px}.pb{padding-bottom:26px}.nav{flex:0 0 auto;display:flex;justify-content:space-around;align-items:center;padding:8px 6px 14px;background:var(--card);border-top:2.5px solid var(--outline);z-index:50}.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:800;color:var(--muted);width:62px;padding:4px 0;border-radius:14px;transition:.12s}.nav-item svg{width:26px;height:26px}.nav-item.on{color:var(--primary)}.nav-item.on svg{transform:translateY(-1px)}.topbar{display:flex;align-items:center;gap:10px;padding:6px 16px 10px;flex:0 0 auto}.topbar .back{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);flex:0 0 auto;color:var(--ink)}.topbar .back:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--outline)}.topbar .ttl{font-family:var(--font-d);font-weight:600;font-size:18px;line-height:1.05}.topbar .sub{font-size:11px;font-weight:700;color:var(--muted)}.appbar{display:flex;align-items:center;gap:8px;padding:4px 16px 8px;flex:0 0 auto}.flag{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;font-family:var(--font-d);font-weight:600;font-size:11px;color:#fff;background:linear-gradient(135deg,#2b5fd6,#e23b4e);border:2px solid var(--outline);box-shadow:var(--sh-sm)}.stat{display:flex;align-items:center;gap:4px;font-family:var(--font-d);font-weight:600;font-size:15px}.stat svg{width:19px;height:19px}.stat.flame{color:#ff8a2b}.stat.gem{color:#23b6e8}.stat.heart{color:var(--red)}.spacer{flex:1}.btn{font-family:var(--font-d);font-weight:600;font-size:16px;letter-spacing:.3px;color:#fff;background:var(--primary);border:2.5px solid var(--outline);border-radius:16px;padding:14px 18px;box-shadow:var(--sh);transition:transform .08s,box-shadow .08s;width:100%;text-align:center;display:block}.btn:active{transform:translate(4px,5px);box-shadow:0 0 0 var(--outline)}.btn.green{background:var(--green)}.btn.pink{background:var(--pink)}.btn.cyan{background:var(--cyan)}.btn.gold{background:var(--gold);color:var(--ink)}.btn.ghost{background:var(--card);color:var(--ink)}.btn.lg{font-size:18px;padding:16px}.btn[disabled]{opacity:.45;box-shadow:none;transform:none;filter:grayscale(.2);cursor:not-allowed}.btn-row{display:flex;gap:10px}.chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-ui);font-weight:800;font-size:12px;padding:6px 11px;border-radius:20px;border:2px solid var(--outline);background:var(--card);color:var(--ink);box-shadow:2px 2px 0 var(--outline);white-space:nowrap}.clf{display:inline-block;max-width:94%;margin-top:9px;font-family:var(--font-ui);font-weight:800;font-size:12px;line-height:1.35;padding:7px 13px;border-radius:14px;border:2px solid var(--outline);background:var(--pink-soft);color:var(--ink);box-shadow:2px 2px 0 var(--outline)}.clf b{font-family:var(--font-th);font-weight:600}.card{background:var(--card);border:2.5px solid var(--outline);border-radius:var(--r);box-shadow:var(--sh)}.card.flat{box-shadow:none}.card.soft{border-width:2px;box-shadow:2px 2px 0 var(--line)}.sec-h{font-family:var(--font-d);font-weight:600;font-size:14px;letter-spacing:.4px;text-transform:uppercase;color:var(--ink2);margin:18px 4px 9px;display:flex;align-items:center;gap:9px;white-space:nowrap}.sec-h .ln{flex:1;height:2px;background:var(--line);border-radius:2px}.tdot{display:grid;place-items:center;color:#fff;border-radius:9px;border:2px solid var(--outline)}.tdot svg{width:62%;height:62%}.tone-syll{display:inline-flex;flex-direction:column;align-items:center;line-height:1}.tone-syll .th{font-family:var(--font-th);font-weight:600}.tone-syll .pa{font-family:var(--font-ui);font-weight:800;font-size:.42em;margin-top:.18em;letter-spacing:.3px}.tone-bar{height:5px;border-radius:4px;margin-top:.22em;width:100%}.audio{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;color:#fff;background:var(--tone-low);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);flex:0 0 auto;transition:transform .08s}.audio:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--outline)}.audio svg{width:20px;height:20px;margin-left:2px}.audio.sm{width:34px;height:34px}.audio.sm svg{width:15px;height:15px}.audio.playing{animation:apulse .6s ease infinite}@keyframes apulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.pbar{height:14px;border-radius:8px;background:var(--line);border:2px solid var(--outline);overflow:hidden}.pbar i{display:block;height:100%;background:var(--green);border-radius:6px;transition:width .4s cubic-bezier(.3,1.2,.4,1)}.unit{margin:2px 16px 8px;border-radius:var(--r);padding:13px 15px;display:flex;align-items:center;gap:10px;background:var(--primary);color:#fff;border:2.5px solid var(--outline);box-shadow:var(--sh)}.unit .ulabel{font-size:10.5px;font-weight:900;letter-spacing:1px;opacity:.9;text-transform:uppercase}.unit .utitle{font-family:var(--font-d);font-weight:600;font-size:17px;line-height:1.1;margin-top:1px}.unit .ubook{margin-left:auto;width:40px;height:40px;border-radius:13px;display:grid;place-items:center;background:#ffffff38;border:2px solid rgba(255,255,255,.5);color:#fff}.unit .ubook svg{width:21px;height:21px}.path{position:relative;padding:18px 0 8px}.spine{position:absolute;left:50%;top:6px;bottom:6px;width:0;border-left:3px dashed var(--line);transform:translate(-50%)}.pnode{position:relative;display:flex;justify-content:center;margin:0 auto;z-index:1}.node{position:relative;width:66px;height:66px;display:grid;place-items:center;border-radius:50%;color:#fff;border:2.5px solid var(--outline);background:var(--primary);box-shadow:var(--sh);transition:transform .1s}.node:active{transform:translate(3px,4px);box-shadow:1px 1px 0 var(--outline)}.node svg{width:28px;height:28px}.node.done{background:var(--cyan)}.node.locked{background:#eae2f6;color:#bbaeda;border-color:#cdbfe6;box-shadow:none}.node.chest{background:var(--pink)}.node.boss{background:var(--gold);color:var(--ink);width:74px;height:74px}.node .crown{position:absolute;top:-15px;left:50%;transform:translate(-50%) rotate(-8deg);color:var(--gold)}.node .crown svg{width:24px;height:16px}.node .ringpulse{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:3px solid var(--primary);animation:pulse 1.7s ease-out infinite}@keyframes pulse{0%{transform:scale(.92);opacity:.55}70%{transform:scale(1.2);opacity:0}to{opacity:0}}.startbub{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:var(--card);color:var(--primary);font-family:var(--font-d);font-weight:600;font-size:12px;letter-spacing:.5px;padding:6px 12px;border-radius:12px;white-space:nowrap;border:2.5px solid var(--outline);box-shadow:var(--sh-sm)}.startbub:before{content:"";position:absolute;left:-6px;top:50%;transform:translateY(-50%) rotate(45deg);width:10px;height:10px;background:var(--card);border-left:2.5px solid var(--outline);border-bottom:2.5px solid var(--outline)}.mascot-wrap{position:absolute;right:calc(100% + 6px);bottom:-8px;width:66px}.mascot{display:block;filter:drop-shadow(0 4px 5px rgba(0,0,0,.14))}.mascot-wrap .mascot{width:100%;height:auto}.lhead{display:flex;align-items:center;gap:12px;padding:10px 18px 4px;flex:0 0 auto}.lhead .x{color:var(--muted);width:26px;height:26px;flex:0 0 auto}.lhead .hh{display:flex;align-items:center;gap:3px;color:var(--red);font-family:var(--font-d);font-weight:600;font-size:15px;flex:0 0 auto}.lhead .hh svg{width:19px;height:19px}.lbody{flex:1;display:flex;flex-direction:column;padding:10px 18px 0;overflow-y:auto}.lbody::-webkit-scrollbar{display:none}.combo{align-self:flex-end;display:flex;align-items:center;gap:5px;font-family:var(--font-d);font-weight:600;font-size:13px;color:#ff8a2b;background:var(--gold-soft);padding:5px 12px;border-radius:20px;border:2px solid var(--outline);box-shadow:2px 2px 0 var(--outline);margin-bottom:8px}.combo svg{width:15px;height:15px}.qprompt{font-family:var(--font-d);font-weight:600;font-size:21px;line-height:1.15;margin:4px 0 14px}.opt{display:flex;align-items:center;gap:12px;padding:14px;border-radius:16px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);margin-bottom:11px;transition:transform .08s;width:100%;text-align:left}.opt:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--outline)}.opt.sel{border-color:var(--primary);background:var(--primary-soft);box-shadow:3px 3px 0 var(--primary)}.opt.right{border-color:var(--green);background:var(--green-soft);box-shadow:3px 3px 0 var(--green)}.opt.wrong{border-color:var(--red);background:var(--red-soft);box-shadow:3px 3px 0 var(--red)}.opt .ix{width:26px;height:26px;border-radius:8px;border:2px solid var(--outline);display:grid;place-items:center;font-family:var(--font-d);font-weight:600;font-size:13px;flex:0 0 auto}.lfoot{flex:0 0 auto;padding:12px 18px 18px;border-top:2.5px solid var(--line);background:var(--card)}.lfoot.right{background:var(--green-soft);border-color:var(--green)}.lfoot.wrong{background:var(--red-soft);border-color:var(--red)}.fb{display:flex;align-items:center;gap:10px;margin-bottom:10px}.fb .fi{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;border:2.5px solid var(--outline);flex:0 0 auto}.fb b{font-family:var(--font-d);font-weight:600;font-size:16px;display:block}.fb span{font-size:12.5px;font-weight:700;color:var(--ink2)}.tonegrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.tonechip{display:flex;align-items:center;gap:10px;padding:12px;border-radius:15px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);transition:transform .08s;text-align:left}.tonechip:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--outline)}.tonechip.wide{grid-column:1/-1}.tonechip.sel{box-shadow:3px 3px 0 var(--cc)}.tonechip .dot{width:34px;height:34px;flex:0 0 auto}.tonechip .tn{font-family:var(--font-d);font-weight:600;font-size:15px;line-height:1;display:block}.tonechip .tt{font-family:var(--font-th);font-size:12px;color:var(--muted);font-weight:500}.tiles{display:flex;flex-wrap:wrap;gap:9px}.tilewrap{display:flex;flex-direction:column;align-items:center;gap:3px}.tilegloss{font-size:10.5px;font-weight:800;color:var(--muted);text-transform:lowercase}.lvlbadge{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:8px;font-size:10px;font-weight:800;background:var(--bg2);border:2px solid var(--outline);color:var(--ink2);vertical-align:middle}.seriesrow{display:flex;align-items:center;gap:11px;width:100%;padding:9px 8px;border-radius:12px;background:none;text-align:left}.seriesrow+.seriesrow{border-top:2px solid var(--line)}.knowntag{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:8px;font-size:10px;font-weight:800;background:var(--green-soft);color:var(--green-d);border:2px solid var(--green)}.skillwrap{display:flex;flex-direction:column;gap:11px}.skillbar-h{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}.linkbtn{display:block;margin:10px auto 0;background:none;border:none;color:#fff;opacity:.9;font-weight:800;font-size:12.5px;text-decoration:underline;text-underline-offset:3px}.placecard{display:flex;gap:12px;align-items:flex-start;background:var(--primary-soft);border:2.5px solid var(--outline);border-radius:16px;padding:13px 14px;box-shadow:var(--sh-sm);margin-bottom:14px}.placecard .mascot-mini{flex:0 0 auto}.placecard .btn.sm{font-size:13px;padding:9px 14px}.placecard .linkbtn{margin:0;align-self:center;color:var(--muted);opacity:.95;text-decoration:none}.tile{font-family:var(--font-th);font-weight:600;font-size:18px;padding:10px 14px;border-radius:13px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);transition:transform .08s}.tile:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--outline)}.tile.used{opacity:.32;pointer-events:none}.answerline{min-height:54px;display:flex;flex-wrap:wrap;gap:8px;align-content:flex-start;padding:10px;border-radius:14px;border:2.5px dashed var(--line);margin-bottom:16px}.matchgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.matchcol{display:flex;flex-direction:column;gap:10px}.matchcell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:58px;padding:10px 8px;border-radius:15px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);transition:transform .08s,opacity .15s;text-align:center}.matchcell:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--outline)}.matchcell.sel{border-color:var(--primary);background:var(--primary-soft);box-shadow:3px 3px 0 var(--primary)}.matchcell.wrong{border-color:var(--red);background:var(--red-soft);box-shadow:3px 3px 0 var(--red)}.matchcell.done{opacity:.34;pointer-events:none;border-color:var(--green);background:var(--green-soft)}.search{display:flex;align-items:center;gap:9px;padding:11px 14px;border-radius:15px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);margin:2px 0 6px}.search input{flex:1;border:none;outline:none;font-family:var(--font-ui);font-weight:700;font-size:14px;color:var(--ink);background:none}.segments{display:flex;gap:7px;padding:4px 0 10px}.seg{flex:1;text-align:center;font-family:var(--font-d);font-weight:600;font-size:13px;padding:9px;border-radius:13px;border:2.5px solid var(--outline);background:var(--card);color:var(--ink);box-shadow:2px 2px 0 var(--outline)}.seg.on{background:var(--ink);color:#fff}.themepills{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;margin:0 -2px}.themepills::-webkit-scrollbar{display:none}.tpill{flex:0 0 auto;font-family:var(--font-ui);font-weight:800;font-size:12.5px;padding:7px 13px;border-radius:20px;border:2px solid var(--outline);background:var(--card);box-shadow:2px 2px 0 var(--outline);white-space:nowrap;color:var(--ink)}.tpill.on{background:var(--primary);color:#fff}.wrow{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:16px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);margin-bottom:10px;transition:transform .08s;cursor:pointer;width:100%;text-align:left}.wrow:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--outline)}.wrow .wmain{flex:0 1 auto;min-width:78px;max-width:54%;overflow:hidden}.wrow .wth{font-family:var(--font-th);font-weight:600;font-size:23px;line-height:1.1;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wrow .wpa{font-family:var(--font-ui);font-weight:800;font-size:11.5px;color:var(--ink2);margin-top:2px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wrow .wen{flex:1;text-align:left;font-weight:800;font-size:12.5px;color:var(--ink2);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.wrow .wend{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:7px}.mbar{width:5px;align-self:stretch;min-height:40px;border-radius:3px;border:1.5px solid var(--outline);flex:0 0 auto}.mlevel{width:9px;height:9px;border-radius:3px;border:1.5px solid var(--outline);flex:0 0 auto}.cefr{display:grid;place-items:center;min-width:30px;height:20px;padding:0 6px;border-radius:7px;border:2px solid var(--outline);font-family:var(--font-d);font-weight:600;font-size:10.5px;color:#fff}.track{width:32px;height:32px;border-radius:10px;border:2.5px solid var(--outline);background:var(--card);display:grid;place-items:center;color:var(--muted);box-shadow:2px 2px 0 var(--outline);transition:transform .08s}.track.on{background:var(--gold);color:var(--ink)}.track:active{transform:translate(2px,2px);box-shadow:none}.filtlabel{font-size:10px;font-weight:900;letter-spacing:.6px;color:var(--muted);margin:6px 4px 5px}.pdot{width:9px;height:9px;border-radius:3px;border:1.5px solid var(--outline);display:inline-block;margin-right:5px;vertical-align:-1px}.wtools{display:flex;align-items:center;gap:8px;margin:8px 2px 12px}.wtools .cnt{font-size:11.5px;font-weight:800;color:var(--muted)}.wtools .spacer{flex:1}.minibtn{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-ui);font-weight:800;font-size:12px;padding:7px 11px;border-radius:11px;border:2px solid var(--outline);background:var(--card);color:var(--ink);box-shadow:2px 2px 0 var(--outline)}.minibtn.on{background:var(--gold);color:var(--ink)}.minibtn:active{transform:translate(2px,2px);box-shadow:none}.empty{text-align:center;color:var(--muted);font-weight:800;font-size:13px;padding:34px 0}.subpills{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;margin:0 -2px}.subpills::-webkit-scrollbar{display:none}.note-sm{font-size:12px;font-weight:700;color:var(--ink2);line-height:1.45;background:var(--bg2);border:2px solid var(--line);border-radius:12px;padding:10px 12px;margin-bottom:12px}.note-sm b{color:var(--ink)}.legend{display:flex;gap:7px;flex-wrap:wrap;margin:2px 0 10px}.lchip{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;color:var(--ink2);padding:5px 9px;border-radius:20px;border:2px solid var(--outline);background:var(--card);box-shadow:2px 2px 0 var(--outline)}.ldot{width:11px;height:11px;border-radius:4px;border:1.5px solid var(--outline)}.cgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}.ccard{position:relative;aspect-ratio:1;border-radius:14px;border:2.5px solid var(--outline);box-shadow:var(--sh-sm);background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;transition:transform .08s}.ccard:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--outline)}.ccard .cch{font-family:var(--font-th);font-weight:600;font-size:32px;line-height:1}.ccard .cnm{font-size:9px;font-weight:800;color:var(--muted);text-align:center;line-height:1.1}.ccard .ccls{position:absolute;top:6px;right:6px;width:9px;height:9px;border-radius:3px;border:1.5px solid var(--outline)}.vgrid{grid-template-columns:repeat(3,1fr)}.vcard{gap:3px}.lenbadge{position:absolute;top:5px;left:6px;font-size:7.5px;font-weight:900;letter-spacing:.3px;padding:2px 5px;border-radius:6px;border:1.5px solid var(--outline)}.lenbadge.long{background:var(--primary-soft);color:var(--primary)}.lenbadge.short{background:var(--gold-soft);color:#9a6b00}.ngrid{grid-template-columns:repeat(4,1fr)}.ncard{aspect-ratio:auto;padding:12px 4px;gap:2px}.toneref{display:flex;align-items:center;gap:12px;padding:12px;border-radius:15px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);margin-bottom:10px;width:100%;text-align:left;transition:transform .08s}.toneref:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--outline)}.whero{margin-top:6px;border-radius:24px;padding:22px 18px 18px;text-align:center;position:relative;border:2.5px solid var(--outline);box-shadow:var(--sh)}.whero .big{font-family:var(--font-th);font-weight:600;font-size:60px;line-height:1.05;letter-spacing:1px}.whero .pa{font-family:var(--font-d);font-weight:600;font-size:22px;margin-top:4px}.whero .en{font-weight:800;font-size:16px;margin-top:6px;color:var(--ink2)}.meta-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:12px}.sylls{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin:6px 0 2px}.syll-card{min-width:74px;border-radius:16px;padding:11px 10px 9px;text-align:center;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm)}.syll-card .s-th{font-family:var(--font-th);font-weight:600;font-size:30px;line-height:1}.syll-card .s-pa{font-family:var(--font-d);font-weight:600;font-size:14px;margin-top:3px}.syll-card .s-tone{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;margin-top:3px}.exrow{padding:13px 14px;border-radius:16px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);margin-bottom:11px;display:flex;gap:11px;align-items:flex-start}.exrow .ex-th{font-family:var(--font-th);font-weight:600;font-size:19px;line-height:1.35}.exrow .ex-pa{font-weight:800;font-size:12px;color:var(--primary);margin-top:3px}.exrow .ex-en{font-size:12.5px;color:var(--ink2);font-weight:700;margin-top:2px}.mnem{display:flex;gap:11px;align-items:flex-start;padding:14px;border-radius:16px;background:var(--gold-soft);border:2.5px solid var(--outline);box-shadow:var(--sh-sm)}.mnem .mi{width:34px;height:34px;flex:0 0 auto;border-radius:10px;background:var(--gold);border:2px solid var(--outline);display:grid;place-items:center}.related{display:flex;gap:9px;flex-wrap:wrap}.relpill{display:flex;flex-direction:column;align-items:center;gap:1px;padding:9px 13px;border-radius:14px;background:var(--card);border:2.5px solid var(--outline);box-shadow:2px 2px 0 var(--outline)}.relpill .r-th{font-family:var(--font-th);font-weight:600;font-size:18px}.relpill .r-en{font-size:10px;font-weight:800;color:var(--muted)}.convhead{border-radius:20px;padding:16px;color:#fff;border:2.5px solid var(--outline);box-shadow:var(--sh);background:linear-gradient(120deg,var(--primary),var(--pink))}.bubble{max-width:84%;padding:12px 14px;border-radius:18px;border:2.5px solid var(--outline);box-shadow:var(--sh-sm);margin-bottom:14px;position:relative}.bubble.them{background:var(--card);border-bottom-left-radius:6px;margin-right:auto}.bubble.you{background:var(--primary-soft);border-bottom-right-radius:6px;margin-left:auto}.bubble .b-th{font-family:var(--font-th);font-weight:600;font-size:19px;line-height:1.35}.bubble .b-pa{font-weight:800;font-size:11.5px;color:var(--primary);margin-top:3px}.bubble .b-en{font-size:12px;color:var(--ink2);font-weight:700;margin-top:2px}.bubble .b-aud{position:absolute;bottom:-12px;right:10px}.bubble.you .b-aud{right:auto;left:10px}.spkr{font-family:var(--font-d);font-weight:600;font-size:11px;color:var(--muted);margin:0 4px 4px;display:flex;gap:6px;align-items:center}.gcard{padding:15px;border-radius:18px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh);margin-bottom:13px}.gpattern{font-family:var(--font-d);font-weight:500;font-size:15px;padding:10px 13px;border-radius:12px;background:var(--bg2);border:2px solid var(--line);margin:5px 0;display:flex;align-items:center;gap:7px;flex-wrap:wrap}.gtok{padding:3px 9px;border-radius:8px;font-family:var(--font-th);font-weight:600;font-size:16px;border:2px solid var(--outline)}.tense-tab{display:flex;gap:7px;margin:4px 0 12px;flex-wrap:wrap}.tense-tab .tt-b{font-family:var(--font-d);font-weight:600;font-size:12.5px;padding:8px 12px;border-radius:12px;border:2.5px solid var(--outline);background:var(--card);box-shadow:2px 2px 0 var(--outline);color:var(--ink)}.tense-tab .tt-b.on{background:var(--cyan);color:#fff}.tense-show{border-radius:18px;padding:18px;text-align:center;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh)}.tense-show .marker{display:inline-block;font-family:var(--font-th);font-weight:600;font-size:14px;padding:3px 10px;border-radius:9px;background:var(--cyan-soft);border:2px solid var(--outline);margin-bottom:8px}.review-hero{border-radius:22px;padding:20px;color:#fff;text-align:center;border:2.5px solid var(--outline);box-shadow:var(--sh);background:linear-gradient(135deg,var(--cyan),var(--primary))}.review-hero .num{font-family:var(--font-d);font-weight:600;font-size:54px;line-height:1}.mastery-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mcell{padding:13px;border-radius:16px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm)}.mcell .mc-n{font-family:var(--font-d);font-weight:600;font-size:26px;line-height:1}.mcell .mc-l{font-size:11px;font-weight:800;color:var(--ink2);margin-top:2px}.weakrow{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:15px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);margin-bottom:9px;width:100%;text-align:left}.phero{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:8px}.pavatar{width:104px;height:104px;border-radius:28px;background:var(--primary-soft);border:2.5px solid var(--outline);box-shadow:var(--sh);display:grid;place-items:center;position:relative}.pavatar .lvl{position:absolute;bottom:-10px;right:-10px;background:var(--gold);color:var(--ink);font-family:var(--font-d);font-weight:600;font-size:13px;padding:4px 10px;border-radius:11px;border:2.5px solid var(--outline);box-shadow:var(--sh-sm)}.pstats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:9px;margin-top:8px}.pstat{padding:13px 8px;border-radius:15px;text-align:center;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm)}.pstat .ps-n{font-family:var(--font-d);font-weight:600;font-size:21px;line-height:1}.pstat .ps-l{font-size:9.5px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-top:3px}.badges{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.badge{aspect-ratio:1;border-radius:16px;display:grid;place-items:center;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);position:relative}.badge.locked{background:var(--bg2);opacity:.55}.badge svg{width:32px;height:32px}.setting{display:flex;align-items:center;gap:12px;padding:13px;border-radius:15px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);margin-bottom:10px}.toggle{margin-left:auto;width:50px;height:28px;border-radius:16px;border:2.5px solid var(--outline);background:var(--line);position:relative;flex:0 0 auto;transition:background .15s}.toggle.on{background:var(--green)}.toggle i{position:absolute;top:1.5px;left:2px;width:21px;height:21px;border-radius:50%;background:#fff;border:2px solid var(--outline);transition:transform .15s}.toggle.on i{transform:translate(21px)}.onb{flex:1;display:flex;flex-direction:column;padding:30px 22px 22px;text-align:center}.onb h1{font-family:var(--font-d);font-weight:600;font-size:30px;line-height:1.08;margin:14px 0 8px}.onb .th-x{font-family:var(--font-th);color:var(--primary)}.onb p{font-size:15px;font-weight:700;color:var(--ink2);line-height:1.5;margin:0 0 6px}.goal{display:flex;align-items:center;gap:13px;padding:15px;border-radius:17px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm);margin-bottom:11px;text-align:left;width:100%}.goal.on{border-color:var(--primary);background:var(--primary-soft);box-shadow:3px 3px 0 var(--primary)}.goal .gi{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;border:2px solid var(--outline);flex:0 0 auto}.goal b{font-family:var(--font-d);font-weight:600;font-size:16px;display:block}.goal span{font-size:12px;font-weight:700;color:var(--muted)}.dotnav{display:flex;gap:7px;justify-content:center;margin:14px 0}.dotnav i{width:8px;height:8px;border-radius:50%;background:var(--line);border:2px solid var(--outline)}.dotnav i.on{background:var(--primary);width:22px;border-radius:5px}.nameinput{width:100%;padding:15px 16px;border-radius:16px;border:2.5px solid var(--outline);background:var(--card);font-family:var(--font-d);font-weight:600;font-size:18px;color:var(--ink);box-shadow:var(--sh-sm);outline:none}.nameinput:focus{border-color:var(--primary);box-shadow:3px 3px 0 var(--primary)}.nameinput::placeholder{color:var(--muted);font-weight:700}.celebrate{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;text-align:center;background:radial-gradient(120% 90% at 50% 0%,var(--primary-soft),var(--bg))}.celebrate h1{font-family:var(--font-d);font-weight:600;font-size:32px;line-height:1.08;margin:18px 0 6px;width:100%}.celebrate p{width:100%;margin:0 0 6px}.confetti{position:absolute;top:-20px;width:11px;height:15px;border:2px solid var(--outline);animation:fall linear forwards}@keyframes fall{to{transform:translateY(900px) rotate(540deg);opacity:.9}}.reward-row{display:flex;gap:10px;width:100%;margin-top:18px}.reward{flex:1;padding:14px 8px;border-radius:16px;text-align:center;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh-sm)}.reward .rv{font-family:var(--font-d);font-weight:600;font-size:24px;line-height:1}.reward .rl{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;margin-top:3px}.trace-wrap{position:relative;border-radius:22px;background:var(--card);border:2.5px solid var(--outline);box-shadow:var(--sh);aspect-ratio:1;display:grid;place-items:center;overflow:hidden}.trace-guide{font-family:var(--font-th);font-weight:500;font-size:200px;color:var(--line);line-height:1;position:absolute;-webkit-user-select:none;user-select:none}.trace-wrap canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;touch-action:none}.trace-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:50% 50%;opacity:.6}.fade-in{animation:fadeIn .28s ease both}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.pop-in{animation:popIn .3s cubic-bezier(.3,1.4,.5,1) both}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:none}}
