:root{--bg:#0f0e1f;--primary:#1b1938;--primary-2:#262248;--on-primary:#fff;--ink:#222026;--ink-mute:#76736d;--ink-faint:#a7a49e;--canvas:#fff;--canvas-soft:#f6f5f1;--violet:#bda6f2;--violet-deep:#7a62c4;--teal:#1f6f6f;--teal-soft:#e6efee;--line:#ebe7df;--line-2:#f2efe8;--line-dark:#33304f;--sig-no:#b3505a;--sig-no-bg:#f5e9eb;--sig-fuzzy:#b07b3c;--sig-fuzzy-bg:#f5eee0;--sig-ok:#3c7a5f;--sig-ok-bg:#e7f0eb;--sig-yes:#3d5fa8;--sig-yes-bg:#e9edf6;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:22px;--r-full:9999px;--sh-1:0 1px 2px #120e260a,0 1px 3px #120e260f;--sh-2:0 4px 16px #120e261a;--e:cubic-bezier(.22,1,.36,1)}body{color:var(--ink);background:var(--canvas-soft);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif;font-weight:440}input{font-family:inherit}.t-app{height:100dvh;display:flex;overflow:hidden}#side{background:var(--primary);color:#fff;flex-direction:column;flex-shrink:0;width:248px;padding:24px 16px;display:flex}#side .brand{letter-spacing:-.02em;padding:6px 10px 22px;font-size:18px;font-weight:680}#side .brand small{color:#ffffff80;margin-top:4px;font-size:12px;font-weight:430;display:block}.nav{border-radius:var(--r-md);color:#ffffff8c;text-align:left;width:100%;transition:.16s var(--e);align-items:center;gap:12px;margin-bottom:4px;padding:12px 14px;font-size:14px;font-weight:560;display:flex}.nav:hover{color:#fff;background:#ffffff0f}.nav.on{color:#fff;background:#ffffff1f}#main{flex-direction:column;flex:1;display:flex;overflow:hidden}#top{background:var(--canvas);border-bottom:1px solid var(--line);flex-shrink:0;align-items:center;gap:14px;height:64px;padding:0 28px;display:flex}#top .ttl{letter-spacing:-.02em;flex:1;font-size:17px;font-weight:640}#top .who{color:var(--ink-mute);align-items:center;gap:10px;font-size:13px;display:flex}#top .av{background:var(--violet-deep);color:#fff;border-radius:50%;place-items:center;width:34px;height:34px;font-size:13px;font-weight:680;display:grid}#body{flex:1;padding:28px;overflow-y:auto}.view{display:none}@keyframes vin{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.grid4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.kpi{padding:20px}.kpi .v{letter-spacing:-.03em;font-size:26px;font-weight:720}.kpi .l{color:var(--ink-mute);margin-top:6px;font-size:13px}.secT{letter-spacing:-.02em;align-items:center;gap:8px;margin:28px 0 14px;font-size:14px;font-weight:640;display:flex}table{border-collapse:collapse;width:100%;font-size:14px}th{text-align:left;color:var(--ink-mute);border-bottom:1px solid var(--line);text-transform:uppercase;letter-spacing:.03em;padding:12px 14px;font-size:12px;font-weight:620}td{border-bottom:1px solid var(--line-2);padding:14px}tr:last-child td{border-bottom:0}tr:hover td{background:var(--canvas-soft)}.pill{border-radius:var(--r-full);padding:4px 10px;font-size:12px;font-weight:640;display:inline-block}.btn{border-radius:var(--r-md);transition:.14s var(--e);justify-content:center;align-items:center;gap:7px;padding:11px 18px;font-size:14px;font-weight:660;display:inline-flex}.btn-sm{padding:7px 13px;font-size:13px}.btn-ghost{background:var(--canvas);border:1px solid var(--line);color:var(--ink)}.in{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--canvas);outline:none;width:100%;padding:12px 14px;font-size:14px}.in:focus{border-color:var(--primary);box-shadow:0 0 0 4px #1b193814}.modal-bg{z-index:50;background:#0f0e1f80;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-bg.on{display:flex}.modal{background:var(--canvas);border-radius:var(--r-xl);width:100%;max-width:420px;box-shadow:var(--sh-2);padding:26px}.ck{width:18px;height:18px;accent-color:var(--primary)}@media (width<=880px){.t-app{flex-direction:column}#side{flex-direction:row;gap:6px;width:100%;padding:10px;overflow-x:auto}#side .brand{display:none}.nav{white-space:nowrap;width:auto;margin:0}.grid4{grid-template-columns:1fr 1fr}}:root{--bg:#0f0e1f;--primary:#1b1938;--primary-2:#262248;--on-primary:#fff;--ink:#222026;--ink-mute:#76736d;--ink-faint:#a7a49e;--canvas:#fff;--canvas-soft:#f6f5f1;--violet:#bda6f2;--violet-deep:#7a62c4;--teal:#1f6f6f;--teal-soft:#e6efee;--line:#ebe7df;--line-2:#f2efe8;--line-dark:#33304f;--sig-no:#b3505a;--sig-no-bg:#f5e9eb;--sig-fuzzy:#b07b3c;--sig-fuzzy-bg:#f5eee0;--sig-ok:#3c7a5f;--sig-ok-bg:#e7f0eb;--sig-yes:#3d5fa8;--sig-yes-bg:#e9edf6;--gold:#b0892c;--silver:#8a8783;--bronze:#a06743;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:22px;--r-full:9999px;--sh-1:0 1px 2px #120e260a,0 1px 3px #120e260f;--sh-2:0 4px 16px #120e261a;--sh-card:0 24px 60px -22px #0a081a8c;--e:cubic-bezier(.22,1,.36,1)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{height:100%}body{color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-weight:440}h1,h2,h3,p{margin:0}button{cursor:pointer;color:inherit;background:0 0;border:0;font-family:inherit}.disp{letter-spacing:-.025em;font-weight:600;line-height:1.05}.ic{stroke:currentColor;fill:none;stroke-width:1.75px;stroke-linecap:round;stroke-linejoin:round;width:22px;height:22px;display:block}.no-sb{scrollbar-width:none;-ms-overflow-style:none}.no-sb::-webkit-scrollbar{display:none}#stage{background:var(--bg);justify-content:center;align-items:center;height:100dvh;display:flex}#frame{background:var(--canvas);flex-direction:column;width:100%;max-width:460px;height:100dvh;display:flex;position:relative;overflow:hidden}@media (width>=768px){#frame{height:min(908px,94dvh);box-shadow:var(--sh-card),0 0 0 1px #ffffff0d;border-radius:40px}}#views{flex:1;position:relative;overflow:hidden}.view{flex-direction:column;display:none;position:absolute;inset:0;overflow:hidden}.view.on{animation:vin .3s var(--e);display:flex}.hdr{background:var(--primary);color:#fff;flex-shrink:0;padding:26px 22px 22px}.hdr h1{letter-spacing:-.03em;font-size:23px;font-weight:600}.hdr .sub{color:#ffffff8c;margin-top:5px;font-size:13px;font-weight:430}.hdr .row{align-items:center;gap:13px;display:flex}.iconbtn{border-radius:var(--r-full);color:#fff;width:38px;height:38px;transition:.16s var(--e);background:#ffffff1a;flex-shrink:0;place-items:center;display:grid}.iconbtn:active{background:#fff3;transform:scale(.9)}.iconbtn.dark{background:var(--canvas);border:1px solid var(--line);color:var(--ink)}#tabs{background:var(--primary);padding:9px 4px calc(9px + env(safe-area-inset-bottom));border-top:1px solid #ffffff0f;flex-shrink:0;display:flex}.tab{color:#ffffff61;letter-spacing:-.01em;transition:color .18s var(--e);flex-direction:column;flex:1;align-items:center;gap:5px;min-height:46px;padding:6px 0;font-size:10.5px;font-weight:560;display:flex;position:relative}.tab .ic{stroke-width:1.9px;width:21px;height:21px}.tab.on{color:#fff}.tab.on:before{content:"";background:var(--violet);border-radius:9999px;width:20px;height:2.5px;position:absolute;top:0}.btn{border-radius:var(--r-md);letter-spacing:-.01em;transition:transform .13s var(--e),background .16s;justify-content:center;align-items:center;gap:8px;padding:15px 22px;font-size:15px;font-weight:680;display:inline-flex}.btn:active{transform:scale(.98)}.btn-pri{background:var(--primary);color:#fff}.btn-pri:active{background:#120f26}.btn-light{color:var(--primary);background:#fff}.seg{background:var(--canvas-soft);border-bottom:1px solid var(--line-2);gap:6px;padding:13px 16px;display:flex}.seg button{border-radius:var(--r-full);color:var(--ink-mute);background:var(--canvas);border:1px solid var(--line);transition:.16s var(--e);letter-spacing:-.01em;white-space:nowrap;flex:1;padding:9px 4px;font-size:12.5px;font-weight:600}.seg button.on{background:var(--primary);color:#fff;border-color:var(--primary)}.card{background:var(--canvas);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1)}.scroll{overscroll-behavior:contain;flex:1;overflow-y:auto}#feed{scroll-snap-type:y mandatory;background:var(--bg);flex:1;overflow-y:scroll}.slide{scroll-snap-align:start;scroll-snap-stop:always;flex-direction:column;justify-content:center;align-items:center;gap:22px;height:100%;padding:26px 24px;display:flex}.chips{align-items:center;gap:8px;display:flex}.chip{border-radius:var(--r-full);letter-spacing:.01em;padding:6px 12px;font-size:11px;font-weight:640}.chip-k{color:#ffffffb3;background:#ffffff14}.flip{perspective:1500px;cursor:pointer;touch-action:manipulation;flex-shrink:0;width:min(372px,84vw);height:252px}.flip .in{width:100%;height:100%;transform-style:preserve-3d;transition:transform .5s var(--e);position:relative}.face{backface-visibility:hidden;text-align:center;color:#fff;border:1px solid #ffffff12;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;padding:30px;display:flex;position:absolute;inset:0}.face.front{background:var(--primary)}.face.back{background:var(--teal);transform:rotateY(180deg)}.face .w{letter-spacing:-.03em;font-size:34px;font-weight:600}.face .m{letter-spacing:-.02em;font-size:23px;font-weight:560}.face .ex{color:#ffffffb3;max-width:280px;margin-top:14px;font-size:13.5px;font-style:italic;font-weight:420;line-height:1.55}.face .hint{color:#ffffff73;align-items:center;gap:6px;font-size:11px;font-weight:480;display:flex;position:absolute;bottom:16px}.face .hint .ic{stroke-width:2px;width:13px;height:13px}.grade{grid-template-columns:repeat(4,1fr);gap:9px;width:min(372px,84vw);display:grid}.grade button{border-radius:var(--r-md);letter-spacing:-.01em;transition:transform .12s var(--e);flex-direction:column;align-items:center;gap:6px;padding:14px 0;font-size:12px;font-weight:640;display:flex}.grade button:active{transform:translateY(2px)scale(.97)}.grade .ic{stroke-width:2px;width:18px;height:18px}.empty{text-align:center;color:#fff;background:var(--bg);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.empty .ic{stroke-width:1.5px;width:44px;height:44px;color:var(--violet);margin-bottom:18px}.lst{background:var(--canvas-soft);padding:18px}.wb{text-align:left;align-items:center;gap:14px;width:100%;margin-bottom:11px;padding:18px;display:flex}.wb-ic{background:var(--primary);color:#fff;border-radius:13px;flex-shrink:0;place-items:center;width:46px;height:46px;display:grid}.wb-ic .ic{width:21px;height:21px}.wb-m{flex:1;min-width:0}.wb-m .nm{letter-spacing:-.02em;align-items:center;gap:7px;font-size:16px;font-weight:600;display:flex}.off-tag{color:var(--ink-faint);background:var(--canvas-soft);border:1px solid var(--line);border-radius:var(--r-full);padding:2px 8px;font-size:11px;font-weight:640}.wb-m .ct{color:var(--ink-mute);margin-top:3px;font-size:12.5px;font-weight:440}.bar{background:var(--line-2);border-radius:9999px;height:5px;margin-top:9px;overflow:hidden}.bar i{background:var(--violet-deep);border-radius:9999px;height:100%;display:block}.wb.dim .wb-ic{background:var(--ink-faint)}.wb.dim .nm,.wb.dim .ct{color:var(--ink-faint)}.go{color:var(--ink-faint);flex-shrink:0}.sw{flex-shrink:0;width:46px;height:27px;position:relative}.sw input{opacity:0;width:0;height:0;position:absolute}.sw .tk{background:var(--line);transition:.22s var(--e);border-radius:9999px;position:absolute;inset:0}.sw .kn{width:21px;height:21px;transition:.22s var(--e);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #00000040}.sw input:checked~.tk{background:var(--primary)}.sw input:checked~.kn{left:22px}.secT{letter-spacing:-.02em;color:var(--ink-mute);align-items:center;gap:7px;margin:4px 2px 10px;font-size:13px;font-weight:620;display:flex}.secT .ic{stroke-width:2px;width:15px;height:15px}.wrow{background:var(--canvas);border:1px solid var(--line);border-radius:var(--r-md);text-align:left;width:100%;transition:.14s var(--e);justify-content:space-between;align-items:center;margin-bottom:7px;padding:14px 15px;display:flex}.wrow:active{background:var(--canvas-soft);transform:scale(.992)}.wrow .en{letter-spacing:-.01em;font-size:15px;font-weight:580}.wrow .ko{color:var(--ink-mute);margin-left:8px;font-size:13px;font-weight:430}.wrow .pc{flex-shrink:0;margin-left:10px;font-size:13px;font-weight:700}.wd-hero{background:var(--primary);color:#fff;text-align:center;padding:34px 24px}.wd-hero .w{letter-spacing:-.03em;font-size:34px;font-weight:600}.wd-hero .meta{justify-content:center;gap:8px;margin-top:12px;display:flex}.wd-hero .mchip{border-radius:var(--r-full);color:#fffc;background:#ffffff1a;padding:5px 12px;font-size:11.5px;font-weight:640}.wd-sec{padding:18px 20px}.wd-lab{letter-spacing:.04em;color:var(--ink-faint);text-transform:uppercase;margin-bottom:8px;font-size:11.5px;font-weight:680}.wd-mean{letter-spacing:-.02em;font-size:20px;font-weight:580}.wd-ex{color:var(--ink);font-size:15px;font-style:italic;line-height:1.6}.wd-ex .ko{color:var(--ink-mute);margin-top:6px;font-size:13.5px;font-style:normal;display:block}.divln{background:var(--line-2);height:1px;margin:0 20px}.prog{background:var(--line-2);border-radius:9999px;height:7px;overflow:hidden}.prog i{background:var(--primary);height:100%;transition:width .4s var(--e);border-radius:9999px;display:block}.opt{text-align:left;border-radius:var(--r-md);background:var(--canvas);border:1px solid var(--line);letter-spacing:-.01em;width:100%;transition:.14s var(--e);align-items:center;gap:13px;padding:16px 18px;font-size:15.5px;font-weight:520;display:flex}.opt:active{transform:scale(.99)}.opt .lt{background:var(--canvas-soft);border:1px solid var(--line);width:26px;height:26px;color:var(--ink-mute);border-radius:8px;flex-shrink:0;place-items:center;font-size:12.5px;font-weight:700;display:grid}.qin{border:1px solid var(--line);border-radius:var(--r-sm);width:100%;color:var(--ink);background:var(--canvas);outline:none;padding:16px;font-family:inherit;font-size:16px;font-weight:520;transition:all .16s}.qin:focus{border-color:var(--primary);box-shadow:0 0 0 4px #1b193817}.result{text-align:center;color:#fff;background:var(--teal);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:34px 30px;display:flex}.result .ring{color:#fff;background:#ffffff1f;border-radius:50%;place-items:center;width:64px;height:64px;display:grid}.result .big{letter-spacing:-.03em;margin-top:16px;font-size:50px;font-weight:600}.toast{background:var(--primary);color:#fff;border-radius:var(--r-md);box-shadow:var(--sh-2);opacity:0;z-index:99;transition:.3s var(--e);pointer-events:none;align-items:center;gap:9px;padding:14px 22px;font-size:14px;font-weight:580;display:flex;position:fixed;bottom:104px;left:50%;transform:translate(-50%)translateY(20px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.toast .ic{width:18px;height:18px;color:var(--violet);stroke-width:2.2px}.lrow{border-radius:var(--r-md);background:var(--canvas);border:1px solid var(--line);transition:.18s var(--e);align-items:center;gap:13px;margin-bottom:8px;padding:13px 15px;display:flex}.lrow.me{background:var(--primary);border-color:var(--primary);color:#fff}.rank{text-align:center;width:30px;color:var(--ink-faint);font-size:14px;font-weight:760}.lrow.me .rank{color:#ffffff80}.medal{border-radius:50%;flex-shrink:0;place-items:center;width:30px;height:30px;display:grid}.medal .ic{stroke-width:2.2px;color:#fff;width:15px;height:15px}.av{color:#fff;background:var(--violet-deep);border-radius:50%;flex-shrink:0;place-items:center;width:38px;height:38px;font-size:13.5px;font-weight:680;display:grid}.lrow.me .av{background:#ffffff29}.lname{letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:14.5px;font-weight:560;overflow:hidden}.lval{letter-spacing:-.02em;font-size:17px;font-weight:700}.lval small{color:var(--ink-faint);margin-left:3px;font-size:11px;font-weight:480}.lrow.me .lval small{color:#ffffff80}.pf-top{align-items:center;gap:14px;display:flex}.pf-av{color:#fff;background:var(--violet-deep);border-radius:50%;flex-shrink:0;place-items:center;width:54px;height:54px;font-size:19px;font-weight:700;display:grid}.streak{background:var(--primary);color:#fff;border-radius:var(--r-lg);align-items:center;gap:16px;padding:20px;display:flex}.streak .fl{width:50px;height:50px;color:var(--violet);background:#ffffff1a;border-radius:14px;place-items:center;display:grid}.streak .fl .ic{stroke-width:2px;width:24px;height:24px}.streak .big{letter-spacing:-.03em;font-size:30px;font-weight:680;line-height:1}.streak .lb{color:#ffffff8c;margin-top:4px;font-size:12.5px}.grid2{grid-template-columns:1fr 1fr;gap:11px;display:grid}.stat{background:var(--canvas);border:1px solid var(--line);border-radius:var(--r-md);padding:16px}.stat .v{letter-spacing:-.025em;font-size:22px;font-weight:700}.stat .v small{color:var(--ink-faint);margin-left:2px;font-size:13px;font-weight:560}.stat .l{color:var(--ink-mute);margin-top:4px;font-size:12px;font-weight:480}.stat .ic{width:17px;height:17px;color:var(--violet-deep);stroke-width:2px;margin-bottom:9px}
