:root{--bg: #1a1d23;--surface: #22262e;--surface-2: #2a2f38;--line: #333a45;--text: #eef1f5;--text-soft: #b8c0cc;--muted: #7a8494;--blue: #199fdd;--blue-lip: #157fb8;--blue-soft: rgba(25, 159, 221, .16);--green: #4fce7c;--green-lip: #3aa862;--gold: #ffc23d;--yellow: #ffc23d;--indigo: #4456ff;--purple: #a884ff;--red: #ff5a5f;--mo-body: #0a0c10;--mo-seal: #199fdd;--mo-mouth: rgba(238, 241, 245, .9);--radius: 16px;--maxw: 720px;--font-ui: ui-rounded, "Nunito", "Segoe UI", system-ui, sans-serif;--font-hanzi: "Kaiti SC", "STKaiti", "Kaiti TC", KaiTi, "Songti SC", "Noto Serif SC", serif;--shadow: none}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-ui);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;font-size:17px;min-height:100dvh}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}input{font:inherit;color:inherit}:focus-visible{outline:3px solid var(--blue);outline-offset:2px}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}.hanzi{font-family:var(--font-hanzi);line-height:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-weight:800;text-transform:uppercase;letter-spacing:.05em;font-size:15px;padding:13px 22px;border-radius:var(--radius);border:none;-webkit-tap-highlight-color:transparent;transition:filter .12s ease}.btn:active{transform:translateY(4px)}.btn-blue{background:var(--blue);color:#0c1116;box-shadow:0 4px 0 var(--blue-lip)}.btn-green{background:var(--green);color:#0c1116;box-shadow:0 4px 0 var(--green-lip)}.btn-ghost{background:var(--surface-2);color:var(--text-soft);box-shadow:0 4px 0 var(--line)}.btn:active{box-shadow:0 0 0 var(--line)}.btn:hover:not(:disabled){filter:brightness(1.06)}.btn:disabled{opacity:.45;box-shadow:none;transform:none;cursor:default}.tile{background:var(--surface);border:2px solid var(--line);border-radius:var(--radius)}.badge{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:3px 9px;border-radius:999px;white-space:nowrap}.badge.beginner{background:color-mix(in srgb,var(--green) 20%,transparent);color:var(--green)}.badge.intermediate{background:color-mix(in srgb,var(--yellow) 18%,transparent);color:var(--yellow)}.badge.advanced{background:color-mix(in srgb,var(--purple) 20%,transparent);color:var(--purple)}@page{size:A4;margin:12mm}@media print{.sidebar,.mobiletop,.bottombar,footer,.no-print{display:none!important}.app-main{padding:0!important;margin:0!important}body{background:#fff;color:#000}}.slot.svelte-pjcpc3{display:inline-block;width:34px;height:34px}.signin.svelte-pjcpc3{font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:#0c1116;background:var(--blue);box-shadow:0 3px 0 var(--blue-lip);padding:8px 14px;border-radius:12px;transition:filter .12s ease}.signin.svelte-pjcpc3:hover{filter:brightness(1.06)}.signin.svelte-pjcpc3:active{transform:translateY(3px);box-shadow:0 0 0 var(--blue-lip)}.account.svelte-pjcpc3{position:relative}.avatar.svelte-pjcpc3{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--surface-2);border:2px solid var(--line);overflow:hidden;color:var(--text);font-weight:900;font-size:15px}.avatar.svelte-pjcpc3 img:where(.svelte-pjcpc3){width:100%;height:100%;object-fit:cover}.menu.svelte-pjcpc3{position:absolute;right:0;top:calc(100% + 10px);width:220px;padding:14px;z-index:50;display:grid;gap:12px}.who.svelte-pjcpc3 .name:where(.svelte-pjcpc3){font-weight:800;font-size:16px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.who.svelte-pjcpc3 .email:where(.svelte-pjcpc3){font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pill.svelte-pjcpc3{display:inline-block;font-size:11px;font-weight:900;letter-spacing:.05em;padding:4px 10px;border-radius:999px}.pill.pro.svelte-pjcpc3{background:color-mix(in srgb,var(--green) 20%,transparent);color:var(--green)}.pill.warn.svelte-pjcpc3{background:color-mix(in srgb,var(--yellow) 18%,transparent);color:var(--yellow)}.signout.svelte-pjcpc3{width:100%;text-align:left;font-weight:800;font-size:14px;color:var(--red);padding:10px 12px;border-radius:12px;background:color-mix(in srgb,var(--red) 10%,transparent)}.signout.svelte-pjcpc3:hover{background:color-mix(in srgb,var(--red) 18%,transparent)}.app-shell.svelte-12qhfyh{min-height:100dvh}.brand.svelte-12qhfyh{display:flex;align-items:center;gap:10px}.brand.svelte-12qhfyh .mark:where(.svelte-12qhfyh){display:grid;place-items:center;width:34px;height:34px;background:var(--blue);color:#0c1116;border-radius:9px;font-size:22px;padding-bottom:2px;box-shadow:0 3px 0 var(--blue-lip)}.brand.svelte-12qhfyh .word:where(.svelte-12qhfyh){font-weight:900;font-size:21px;color:var(--text);letter-spacing:-.01em}.sidebar.svelte-12qhfyh{display:none}.side-nav.svelte-12qhfyh{display:flex;flex-direction:column;gap:4px;margin-top:22px}.side-nav.svelte-12qhfyh a:where(.svelte-12qhfyh){display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:13px;color:var(--muted);font-weight:800;font-size:15px;letter-spacing:.02em;border:2px solid transparent;transition:background .12s ease,color .12s ease}.side-nav.svelte-12qhfyh a:where(.svelte-12qhfyh) svg:where(.svelte-12qhfyh){width:24px;height:24px;flex:none}.side-nav.svelte-12qhfyh a:where(.svelte-12qhfyh):hover{background:var(--surface-2);color:var(--text-soft)}.side-nav.svelte-12qhfyh a.on:where(.svelte-12qhfyh){background:var(--blue-soft);border-color:var(--blue);color:var(--blue)}.side-foot.svelte-12qhfyh{margin-top:auto;display:flex;flex-direction:column;align-items:center;gap:14px}.mo-slot.svelte-12qhfyh{display:flex;justify-content:center}.mobiletop.svelte-12qhfyh{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:color-mix(in srgb,var(--bg) 88%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:2px solid var(--line)}.app-main.svelte-12qhfyh{min-height:calc(100dvh - 200px);padding:20px 0 96px}.bottombar.svelte-12qhfyh{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;align-items:stretch;justify-content:space-around;padding:8px 4px calc(8px + env(safe-area-inset-bottom));background:var(--surface);border-top:2px solid var(--line)}.bottombar.svelte-12qhfyh a:where(.svelte-12qhfyh){display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;padding:4px 0;color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.02em}.bottombar.svelte-12qhfyh a:where(.svelte-12qhfyh) svg:where(.svelte-12qhfyh){width:26px;height:26px}.bottombar.svelte-12qhfyh a.on:where(.svelte-12qhfyh){color:var(--blue)}@media(min-width:1024px){.mobiletop.svelte-12qhfyh,.bottombar.svelte-12qhfyh{display:none}.sidebar.svelte-12qhfyh{display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;width:240px;padding:22px 16px;border-right:2px solid var(--line);background:var(--bg);z-index:40}.sidebar.svelte-12qhfyh .brand:where(.svelte-12qhfyh){padding:0 8px}.app-main.svelte-12qhfyh{margin-left:240px;padding:28px 0 48px;min-height:100dvh}}.app-shell.immersive.svelte-12qhfyh .app-main:where(.svelte-12qhfyh){margin-left:0;padding:18px 0 0;min-height:100dvh}
