:root{--bg: #0e0e12;--surface: #18181f;--surface-2: #20202a;--line: #262630;--ink: #f2efe9;--ink-soft: #b9b6bf;--muted: #8a8895;--accent: #3fbf86;--accent-text: #54d199;--accent-grad: linear-gradient(150deg, #4ccf92, #2f9e6f);--on-accent: #06150e;--shadow: 0 22px 48px -24px rgba(0, 0, 0, .7), 0 2px 8px -4px rgba(0, 0, 0, .5);--shadow-sm: 0 10px 26px -18px rgba(0, 0, 0, .7);--accent-shadow: 0 14px 30px -14px rgba(63, 191, 134, .45);--r-lg: 24px;--r-md: 18px;--r-sm: 13px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}html,body{overflow-x:hidden;max-width:100%}body{font-family:Onest,-apple-system,system-ui,sans-serif;color:var(--ink);background:radial-gradient(125% 90% at 12% -8%,#181820 0%,var(--bg) 48%,#0b0b0e 100%);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overscroll-behavior-y:none}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:9;pointer-events:none;opacity:.04;mix-blend-mode:screen;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.hanzi{font-family:"Noto Serif SC",Songti SC,serif}.display{font-weight:800;letter-spacing:-.03em}.tnum{font-variant-numeric:tabular-nums}.app{position:relative;z-index:1;max-width:460px;margin:0 auto;min-height:100%;padding:calc(var(--safe-top) + 18px) 18px calc(var(--safe-bottom) + 92px);display:flex;flex-direction:column}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:20;padding-bottom:var(--safe-bottom);background:linear-gradient(to top,#08080af5 60%,#08080ab3);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--line)}.tabbar-inner{max-width:460px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);padding:8px 6px 6px}.tab{background:none;border:none;cursor:pointer;font-family:Onest,sans-serif;display:flex;flex-direction:column;align-items:center;gap:4px;padding:7px 0;color:var(--muted);font-size:10px;font-weight:700;transition:color .15s ease,transform .12s ease}.tab span{letter-spacing:.01em}.tab:active{transform:scale(.92)}.tab.active{color:var(--accent-text)}.tab.active svg{filter:drop-shadow(0 4px 10px rgba(63,191,134,.5))}.greet{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.greet>div:first-child{min-width:0}.greet .hi{font-size:22px;font-weight:800;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.greet .hi-sub{font-size:12.5px;color:var(--muted);font-weight:600;margin-top:3px}.lvl-chip{flex-shrink:0;display:inline-flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--line);color:var(--accent-text);font-size:12px;font-weight:800;padding:7px 11px;border-radius:99px}.level-card{display:flex;align-items:center;gap:18px;padding:18px 20px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--line);margin-bottom:12px;box-shadow:var(--shadow-sm)}.lc-num{font-size:26px;font-weight:800;line-height:1;letter-spacing:-.03em}.lc-lab{font-size:9.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-top:2px}.level-meta{flex:1;min-width:0}.lm-top{display:flex;align-items:center;gap:6px;color:var(--accent-text);font-weight:800;font-size:15px;margin-bottom:9px}.lm-bar{height:9px;background:var(--surface-2);border-radius:99px;overflow:hidden}.lm-bar .fill{height:100%;border-radius:99px;background:var(--accent-grad)}.lm-sub{font-size:12px;color:var(--muted);font-weight:600;margin-top:9px}.lm-sub b{color:var(--ink-soft);font-weight:800}.streak-card{padding:17px 19px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--line);margin-bottom:12px;box-shadow:var(--shadow-sm)}.sc-head{display:flex;align-items:center;gap:10px;margin-bottom:15px}.sc-flame{display:flex;align-items:center;gap:6px;color:#e8893f;font-weight:800;font-size:19px}.sc-cap{font-size:13px;color:var(--muted);font-weight:600}.week{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}.day{display:flex;flex-direction:column;align-items:center;gap:6px}.day .dot{width:30px;height:30px;border-radius:10px;background:var(--surface-2);display:grid;place-items:center;color:var(--on-accent);transition:all .2s ease}.day.on .dot{background:var(--accent-grad);box-shadow:var(--accent-shadow)}.day.today .dot{outline:2px solid var(--accent-text);outline-offset:2px}.day .wl{font-size:10px;font-weight:700;color:var(--muted)}.day.on .wl{color:var(--accent-text)}.quest{padding:17px 19px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--line);margin-bottom:12px;box-shadow:var(--shadow-sm)}.q-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:11px}.q-title{font-weight:800;font-size:15px}.q-count{color:var(--accent-text);font-weight:800;font-size:15px}.q-foot{font-size:12px;color:var(--muted);font-weight:600;margin-top:10px}.ach-strip{width:100%;display:flex;align-items:center;justify-content:space-between;padding:15px 19px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);cursor:pointer;font-family:Onest,sans-serif;transition:transform .12s ease}.ach-strip:active{transform:scale(.98)}.as-left{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14.5px;color:var(--ink)}.as-left svg{color:var(--accent-text)}.as-count{color:var(--muted);font-weight:800}.profile-hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:8px 0 6px;margin-bottom:16px}.ph-name{font-size:21px;font-weight:800;letter-spacing:-.02em;margin-top:14px}.ph-xp{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--muted);font-weight:600;margin-top:5px}.ph-xp svg{color:var(--accent-text)}.pstat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.pstat{padding:15px 8px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);text-align:center}.ps-ic{color:var(--accent-text);display:grid;place-items:center;margin-bottom:6px}.pstat .v{font-size:23px;font-weight:800;letter-spacing:-.03em;line-height:1}.pstat .l{font-size:11px;color:var(--muted);font-weight:600;margin-top:5px}.badges{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.badge{display:flex;align-items:center;gap:12px;padding:15px 16px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);opacity:.55}.badge.got{opacity:1}.badge .b-ic{width:40px;height:40px;border-radius:12px;flex-shrink:0;display:grid;place-items:center;background:var(--surface-2);color:var(--muted)}.badge.got .b-ic{background:var(--accent-grad);color:var(--on-accent);box-shadow:var(--accent-shadow)}.badge .b-title{font-size:13px;font-weight:700;line-height:1.2}.topbar{display:flex;align-items:center;gap:13px;margin-bottom:24px}.seal{position:relative;width:46px;height:46px;border-radius:14px;flex-shrink:0;background:var(--accent-grad);display:grid;place-items:center;color:var(--on-accent);font-family:"Noto Serif SC",serif;font-weight:700;font-size:25px;box-shadow:var(--accent-shadow),inset 0 1px #ffffff40}.brand h1{font-size:20px;font-weight:800;margin:0;letter-spacing:-.02em}.brand p{margin:3px 0 0;font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.16em;text-transform:uppercase}.eyebrow{font-size:11px;font-weight:700;color:var(--accent-text);letter-spacing:.18em;text-transform:uppercase;margin:4px 2px 14px}.hero{position:relative;overflow:hidden;border-radius:var(--r-lg);padding:23px 23px 21px;margin-bottom:13px;background:var(--accent-grad);color:var(--on-accent);box-shadow:var(--accent-shadow)}.hero:before{content:"师";position:absolute;right:-14px;bottom:-48px;font-family:"Noto Serif SC",serif;font-size:176px;line-height:1;color:#0000001a;pointer-events:none}.hero .row{display:flex;align-items:center;gap:8px;font-weight:700;font-size:12.5px;opacity:.82}.hero .num{font-size:60px;font-weight:800;line-height:.95;margin-top:8px;letter-spacing:-.045em}.hero .sub{font-size:13px;font-weight:600;opacity:.78;margin-top:3px}.metric-row{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:13px}.metric{padding:16px 17px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line)}.metric .v{font-size:30px;font-weight:800;letter-spacing:-.035em;line-height:1}.metric .l{margin-top:7px;font-size:12.5px;color:var(--muted);font-weight:600}.goal{padding:16px 17px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);margin-bottom:13px}.goal .head{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}.goal .head .t{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13.5px}.goal .head .t .ic{color:var(--accent-text);display:grid}.goal .head .c{color:var(--muted);font-weight:700;font-size:13px}.bar{height:8px;background:var(--surface-2);border-radius:99px;overflow:hidden}.bar .fill{height:100%;border-radius:99px;background:var(--accent-grad)}.btn{width:100%;border:none;border-radius:var(--r-md);padding:16px;font-family:Onest,sans-serif;font-size:16px;font-weight:700;letter-spacing:-.01em;color:var(--on-accent);background:var(--accent-grad);box-shadow:var(--accent-shadow);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;transition:transform .12s ease,box-shadow .2s ease}.btn:active{transform:translateY(2px) scale(.992)}.btn:disabled{opacity:.4;box-shadow:none}.btn.ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line);box-shadow:none;margin-top:11px}.cta-stack{margin-top:auto;padding-top:18px}.review-stage{flex:1;display:flex;flex-direction:column}.backlink{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--muted);font-family:Onest,sans-serif;font-weight:700;font-size:14px;cursor:pointer;padding:0;margin-bottom:16px;align-self:flex-start}.progress{height:7px;background:var(--surface-2);border-radius:99px;overflow:hidden;margin-bottom:18px}.progress .fill{height:100%;border-radius:99px;background:var(--accent-grad)}.flashcard{flex:1;min-height:350px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:28px;position:relative;cursor:pointer;overflow:hidden}.flashcard:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(75% 55% at 50% 0%,rgba(63,191,134,.06),transparent 70%)}.flashcard .big{font-size:96px;font-weight:600;line-height:1;color:var(--ink)}.flashcard .big.sm{font-size:60px}.flashcard .pinyin{font-size:27px;font-weight:700;color:var(--accent-text);margin-top:6px;letter-spacing:-.01em}.flashcard .trans{font-size:21px;font-weight:700;margin-top:14px}.flashcard .example{margin-top:18px;font-size:16px;color:var(--ink-soft);line-height:1.5;max-width:38ch}.flashcard .example .ru{display:block;color:var(--muted);font-size:14px;margin-top:5px}.flashcard .hint{position:absolute;bottom:20px;font-size:12.5px;color:var(--muted);font-weight:600}.sound-btn{margin-top:18px;width:54px;height:54px;border-radius:50%;border:1px solid var(--line);background:var(--surface-2);color:var(--accent-text);display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .12s ease}.sound-btn:active{transform:scale(.92)}.grade-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:16px}.grade{border:none;border-radius:var(--r-sm);padding:15px 5px;font-family:Onest,sans-serif;font-size:12.5px;font-weight:700;cursor:pointer;line-height:1.15;transition:transform .12s ease;color:#fff}.grade:active{transform:translateY(2px)}.grade.g0{background:#b0432f}.grade.g1{background:#b5832f}.grade.g2{background:#3f9e72}.grade.g3{background:#2f8d63}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.chip{border:1px solid var(--line);background:var(--surface);border-radius:var(--r-sm);padding:10px 14px;font-size:13.5px;font-weight:700;cursor:pointer;color:var(--ink-soft);transition:all .15s ease}.chip:active{transform:scale(.96)}.chip.active{background:var(--accent-grad);color:var(--on-accent);border-color:transparent;box-shadow:var(--accent-shadow)}.field{width:100%;border:1px solid var(--line);background:var(--surface);border-radius:var(--r-md);padding:16px;font-family:Onest,sans-serif;font-size:16px;color:var(--ink);outline:none;margin-bottom:12px;transition:border-color .15s ease,box-shadow .15s ease}.field::placeholder{color:var(--muted)}.field:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3fbf8624}.stream{display:flex;flex-direction:column;gap:9px;margin-top:6px}.wrow{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:13px 16px}.wrow .idx{font-size:11px;font-weight:800;color:var(--muted);width:18px}.wrow .wz{font-family:"Noto Serif SC",serif;font-size:27px;font-weight:600;line-height:1}.wrow .meta{flex:1;min-width:0}.wrow .wp{font-size:14px;font-weight:700;color:var(--accent-text)}.wrow .wt{font-size:13.5px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wrow .hsk{font-size:10.5px;font-weight:800;color:var(--accent-text);background:#3fbf861f;border-radius:6px;padding:4px 7px;letter-spacing:.03em}.loading-label{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;color:var(--accent-text);letter-spacing:.16em;text-transform:uppercase;margin:4px 2px 14px}.spin{width:15px;height:15px;border:2px solid rgba(63,191,134,.25);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;margin:auto;padding:30px}.empty .mark{width:72px;height:72px;border-radius:22px;margin:0 auto 18px;background:var(--accent-grad);display:grid;place-items:center;color:var(--on-accent);font-family:"Noto Serif SC",serif;font-size:38px;box-shadow:var(--accent-shadow)}.empty .t{font-size:21px;font-weight:800;letter-spacing:-.02em}.empty .s{color:var(--muted);font-weight:600;margin-top:6px;font-size:14px}.skel{background:linear-gradient(100deg,var(--surface) 30%,var(--surface-2) 50%,var(--surface) 70%);background-size:220% 100%;animation:shimmer 1.3s ease-in-out infinite;border-radius:var(--r-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-40% 0}}.done{text-align:center;padding:22px 10px 8px}.done .big{font-size:34px;font-weight:800;color:var(--accent-text);letter-spacing:-.03em}.done .s{color:var(--muted);font-weight:600;margin-top:4px;font-size:14px}.splash{flex:1;display:grid;place-items:center}.splash-seal{width:64px;height:64px;border-radius:20px;background:var(--accent-grad);display:grid;place-items:center;color:var(--on-accent);font-family:"Noto Serif SC",serif;font-size:34px;box-shadow:var(--accent-shadow);animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.08);opacity:1}}.onb{flex:1;display:flex;flex-direction:column}.onb-dots{display:flex;gap:7px;justify-content:center;margin-bottom:28px}.onb-dot{width:26px;height:5px;border-radius:99px;background:var(--surface-2);transition:background .3s ease}.onb-dot.on{background:var(--accent)}.onb-step{flex:1;display:flex;flex-direction:column}.onb-seal{width:76px;height:76px;border-radius:24px;background:var(--accent-grad);display:grid;place-items:center;color:var(--on-accent);font-family:"Noto Serif SC",serif;font-size:42px;box-shadow:var(--accent-shadow);margin-bottom:22px}.onb-h1{font-size:27px;font-weight:800;letter-spacing:-.03em;line-height:1.1}.onb-p{font-size:15px;color:var(--ink-soft);font-weight:500;line-height:1.5;margin-top:12px;max-width:34ch}.onb-opts{display:flex;flex-direction:column;gap:10px;margin-top:24px}.onb-opt{display:flex;align-items:center;gap:12px;padding:17px 18px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);cursor:pointer;font-family:Onest,sans-serif;text-align:left;transition:border-color .15s ease,transform .12s ease}.onb-opt:active{transform:scale(.98)}.onb-opt.sel{border-color:var(--accent);box-shadow:0 0 0 3px #3fbf861f}.oo-text{flex:1}.oo-title{font-size:16px;font-weight:800;color:var(--ink)}.oo-sub{font-size:13px;color:var(--muted);font-weight:500;margin-top:3px}.oo-check{width:26px;height:26px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;border:1px solid var(--line);color:var(--on-accent)}.onb-opt.sel .oo-check{background:var(--accent-grad);border-color:transparent}.onb-goals{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:24px}.onb-goal{padding:20px 8px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);cursor:pointer;font-family:Onest,sans-serif;text-align:center;transition:border-color .15s ease,transform .12s ease}.onb-goal:active{transform:scale(.96)}.onb-goal.sel{border-color:var(--accent);box-shadow:0 0 0 3px #3fbf861f}.og-n{font-size:30px;font-weight:800;letter-spacing:-.03em;line-height:1}.onb-goal.sel .og-n{color:var(--accent-text)}.og-l{font-size:12px;color:var(--muted);font-weight:600;margin-top:7px}.basics-card{width:100%;display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);cursor:pointer;font-family:Onest,sans-serif;margin-bottom:11px;transition:transform .12s ease}.basics-card:active{transform:scale(.98)}.bc-glyph{width:44px;height:44px;border-radius:13px;flex-shrink:0;display:grid;place-items:center;font-size:26px;background:var(--surface-2);color:var(--accent-text)}.bc-text{flex:1;text-align:left}.bc-title{font-size:15px;font-weight:800;color:var(--ink)}.bc-sub{font-size:12.5px;color:var(--muted);font-weight:500;margin-top:2px}.bc-arrow{color:var(--muted);font-size:18px;font-weight:700}.tones-title{font-size:28px;font-weight:800;letter-spacing:-.03em;margin:0}.tones-lead{font-size:14.5px;color:var(--ink-soft);font-weight:500;line-height:1.5;margin:12px 0 22px}.tones-lead b{color:var(--accent-text);font-weight:800}.tones-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:11px}.tone-card{text-align:left;font-family:Onest,sans-serif;padding:16px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);cursor:pointer;transition:transform .12s ease,border-color .15s ease}.tone-card:active{transform:scale(.97);border-color:var(--accent)}.tc-top{display:flex;align-items:center;justify-content:space-between}.tc-tone{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.tc-curve{color:var(--accent-text)}.tc-hanzi{font-size:46px;font-weight:600;line-height:1;margin:10px 0 4px;color:var(--ink)}.tc-pin{font-size:20px;font-weight:700;color:var(--accent-text)}.tc-mark{color:var(--muted);margin-left:4px}.tc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px}.tc-mean{font-size:13.5px;color:var(--ink-soft);font-weight:600}.tc-play{color:var(--accent-text);display:grid}.tc-curve-lbl{font-size:11.5px;color:var(--muted);font-weight:600;margin-top:8px}.tones-note{font-size:13.5px;color:var(--ink-soft);font-weight:500;line-height:1.55;margin-top:18px;padding:15px 16px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line)}.tones-note b{color:var(--accent-text)}.wrow-skel{height:56px}.lesson{flex:1;display:flex;flex-direction:column}.lesson-top{display:flex;align-items:center;gap:12px;margin-bottom:26px}.lesson-close{background:none;border:none;color:var(--muted);cursor:pointer;padding:0;display:grid}.lesson-body{flex:1;display:flex;flex-direction:column}.q-label{font-size:12px;font-weight:700;color:var(--accent-text);letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px}.q-hanzi{font-size:84px;font-weight:600;line-height:1;text-align:center;margin:14px 0 6px;cursor:pointer}.q-pin{display:flex;align-items:center;justify-content:center;gap:7px;font-size:21px;font-weight:700;color:var(--accent-text);cursor:pointer;margin-bottom:8px}.q-big{font-size:30px;font-weight:800;letter-spacing:-.02em;margin:10px 0 6px}.q-build-ru{font-size:21px;font-weight:700;margin:6px 0 10px;line-height:1.3}.big-listen{width:116px;height:116px;border-radius:32px;border:none;margin:18px auto 10px;display:grid;place-items:center;color:var(--on-accent);background:var(--accent-grad);box-shadow:var(--accent-shadow);cursor:pointer;transition:transform .12s ease}.big-listen:active{transform:scale(.94)}.reveal{text-align:center;color:var(--muted);font-weight:600;font-size:17px;margin-top:8px}.opts{display:flex;flex-direction:column;gap:10px;margin-top:auto}.opt{width:100%;text-align:left;padding:16px 18px;border-radius:var(--r-md);background:var(--surface);border:1.5px solid var(--line);color:var(--ink);font-family:Onest,sans-serif;font-size:16.5px;font-weight:700;cursor:pointer;transition:border-color .14s ease,transform .1s ease}.opt:active{transform:scale(.99)}.opt.sel{border-color:var(--accent);box-shadow:0 0 0 3px #3fbf861f}.opt.right{border-color:transparent;background:var(--accent-grad);color:var(--on-accent)}.opt.wrong{border-color:transparent;background:#b0432f;color:#fff}.build{margin-top:20px}.build-answer{min-height:64px;display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start;align-content:flex-start;padding:12px;border-radius:var(--r-md);background:var(--surface);border:1px dashed var(--line);margin-bottom:18px}.build-ph{color:var(--muted);font-size:13.5px;font-weight:600;align-self:center}.build-bank{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.tok{font-family:"Noto Serif SC",serif;font-size:24px;font-weight:600;padding:9px 14px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);color:var(--ink);cursor:pointer;transition:transform .1s ease}.tok:active{transform:scale(.93)}.lesson-foot{margin-top:18px}.feedback{border-radius:var(--r-md);padding:14px 16px 16px}.feedback.ok{background:#3fbf8621}.feedback.no{background:#b0432f29}.fb-row{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-weight:800;font-size:15px}.feedback.ok .fb-row{color:var(--accent-text)}.feedback.no .fb-row{color:#e07a5f}.fb-ic{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;font-weight:800}.feedback.ok .fb-ic{background:var(--accent-grad);color:var(--on-accent)}.feedback.no .fb-ic{background:#b0432f;color:#fff}.fb-text{display:inline-flex;align-items:center;gap:6px}.fb-text b{color:var(--ink);margin-left:3px}.lesson-done-stats{display:flex;gap:22px;justify-content:center;margin-top:20px}.lds{text-align:center}.lds .v{font-size:26px;font-weight:800;letter-spacing:-.03em;color:var(--accent-text)}.lds .l{font-size:12px;color:var(--muted);font-weight:600;margin-top:4px}.illust{display:block;margin:0 auto 12px;opacity:.95}.q-big+.illust,.illust+.q-hanzi{margin-top:0}.speak-wrap{margin-top:auto}.speak{display:flex;flex-direction:column;align-items:center;gap:14px;padding-top:8px}.mic-btn{width:96px;height:96px;border-radius:50%;border:none;display:grid;place-items:center;color:var(--on-accent);background:var(--accent-grad);box-shadow:var(--accent-shadow);cursor:pointer;transition:transform .12s ease}.mic-btn:active{transform:scale(.93)}.mic-btn.rec{background:#b0432f;box-shadow:0 14px 30px -12px #b0432f99;color:#fff}.mic-btn.ghost{background:var(--surface-2);color:var(--accent-text);box-shadow:none}.speak-hint{font-size:13.5px;color:var(--muted);font-weight:600}.speak-res{text-align:center;padding:14px 18px;border-radius:var(--r-md);width:100%}.speak-res.ok{background:#3fbf8621}.speak-res.no{background:#b0432f24}.sr-hanzi{font-size:34px;font-weight:600;line-height:1}.speak-res.ok .sr-hanzi{color:var(--accent-text)}.speak-res.no .sr-hanzi{color:#e07a5f}.sr-label{font-size:13px;color:var(--ink-soft);font-weight:600;margin-top:8px}.speak-skip{background:none;border:none;color:var(--muted);font-family:Onest,sans-serif;font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;padding:4px}.rooms-title{font-size:28px;font-weight:800;letter-spacing:-.03em;margin:0}.rooms-lead{font-size:14px;color:var(--ink-soft);font-weight:500;line-height:1.5;margin:11px 0 18px}.rooms-actions{display:flex;gap:8px;margin-bottom:6px}.rooms-form{margin:12px 0 6px}.rooms-err{color:#e07a5f;font-size:13px;font-weight:600;margin-top:8px}.rooms-list{display:flex;flex-direction:column;gap:10px;margin-top:16px}.room-card{width:100%;display:flex;align-items:center;gap:13px;padding:15px 16px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);cursor:pointer;font-family:Onest,sans-serif;transition:transform .12s ease}.room-card:active{transform:scale(.98)}.rc-ic{width:42px;height:42px;border-radius:12px;flex-shrink:0;display:grid;place-items:center;background:var(--surface-2);color:var(--accent-text)}.rc-text{flex:1;text-align:left;min-width:0}.rc-name{font-size:15.5px;font-weight:800;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rc-sub{font-size:12.5px;color:var(--muted);font-weight:600;margin-top:2px}.rc-arrow{color:var(--muted);transform:rotate(180deg);flex-shrink:0}.room-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}.room-name{font-size:25px;font-weight:800;letter-spacing:-.03em;margin:0}.live-dot{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:99px;padding:3px 8px;transition:all .3s ease}.live-dot.on{color:var(--on-accent);background:var(--accent-grad);border-color:transparent}.invite{display:flex;align-items:center;gap:12px;margin-top:12px;padding:14px 16px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line)}.inv-text{flex:1}.inv-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.inv-code{font-size:24px;font-weight:800;letter-spacing:.12em;color:var(--accent-text);margin-top:3px}.lb{display:flex;flex-direction:column;gap:8px}.lb-row{display:flex;align-items:center;gap:12px;padding:13px 15px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line)}.lb-row.me{border-color:var(--accent);box-shadow:0 0 0 2px #3fbf861f}.lb-rank{width:28px;height:28px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;font-size:13px;font-weight:800;background:var(--surface-2);color:var(--muted)}.lb-rank.r1{background:linear-gradient(150deg,#e7c25f,#c79a2e);color:#1a1207}.lb-rank.r2{background:linear-gradient(150deg,#cdd2d6,#9aa0a6);color:#1a1a1c}.lb-rank.r3{background:linear-gradient(150deg,#d9a06a,#b07640);color:#1a1207}.lb-name{flex:1;font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lb-xp{font-size:14px;font-weight:800;color:var(--accent-text)}.lb-xp .tnum{color:var(--ink)}.lb-empty{text-align:center;color:var(--muted);font-weight:600;font-size:13.5px;padding:18px}.wrow{cursor:pointer}.wrow-play{color:var(--accent-text);display:grid;flex-shrink:0;opacity:.7}.ach-toast{position:fixed;top:calc(var(--safe-top) + 12px);left:50%;transform:translate(-50%);z-index:30;display:flex;align-items:center;gap:9px;padding:12px 18px;border-radius:99px;background:var(--accent-grad);color:var(--on-accent);font-weight:800;font-size:14px;box-shadow:var(--accent-shadow);max-width:90%}.ach-toast b{font-weight:800}
