:root{--bg: #f1ede3;--surface: #faf7ef;--surface-2: #eae3d4;--line: #e3dccb;--ink: #1b1813;--ink-soft: #5e564a;--muted: #9b9181;--accent: #d8452e;--accent-text: #c43d28;--accent-grad: linear-gradient(150deg, #e2503a, #c0331f);--on-accent: #fdf6ee;--ok: #3a8f6e;--ok-grad: linear-gradient(150deg, #4aa882, #318063);--shadow: 0 26px 54px -28px rgba(50, 32, 16, .22), 0 4px 12px -6px rgba(50, 32, 16, .08);--shadow-sm: 0 12px 28px -18px rgba(50, 32, 16, .2);--accent-shadow: 0 16px 34px -14px rgba(216, 69, 46, .34);--hi: inset 0 1px 0 rgba(255, 255, 255, .7);--r-lg: 26px;--r-md: 20px;--r-sm: 14px;--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:Golos Text,-apple-system,system-ui,sans-serif;color:var(--ink);background:radial-gradient(125% 90% at 12% -8%,#fbf6ec 0%,var(--bg) 55%,#ece3d2 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:.045;mix-blend-mode:multiply;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:700;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,#fcfaf5f7 62%,#fcfaf5b8);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:Golos Text,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:700;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:700;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:700;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:700;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:700}.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:700;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:700;font-size:15px}.q-count{color:var(--accent-text);font-weight:700;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:Golos Text,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:700}.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:700;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:700;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:700;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:700;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:700;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:Golos Text,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:Golos Text,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:Golos Text,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:Golos Text,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:700;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:700;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:700;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:700;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:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px}.splash-seal{width:84px;height:84px;border-radius:26px;background:linear-gradient(155deg,#cb573a,#98381f);display:grid;place-items:center;color:#f7ead6;font-family:"Noto Serif SC",serif;font-weight:700;font-size:46px;box-shadow:0 22px 44px -16px #78281480,inset 0 2px #ffffff47;animation:pulse 1.3s ease-in-out infinite}.splash-name{font-size:26px;font-weight:700;letter-spacing:-.03em;color:var(--ink)}.splash-dots{display:flex;gap:8px}.splash-dots span{width:9px;height:9px;border-radius:50%;background:var(--accent);animation:bounce 1s ease-in-out infinite}.splash-dots span:nth-child(2){animation-delay:.15s}.splash-dots span:nth-child(3){animation-delay:.3s}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.07)}}@keyframes bounce{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(-7px);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:700;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:Golos Text,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:700;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:Golos Text,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:700;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:Golos Text,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:700;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:700;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:700}.tones-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:11px}.tone-card{text-align:left;font-family:Golos Text,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:700;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:700;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:Golos Text,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:700;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:700}.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:700;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:Golos Text,sans-serif;font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;padding:4px}.rooms-title{font-size:28px;font-weight:700;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:Golos Text,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:700;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:700;letter-spacing:-.03em;margin:0}.live-dot{font-size:10px;font-weight:700;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:700;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:700;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:700;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:700;font-size:14px;box-shadow:var(--accent-shadow);max-width:90%}.ach-toast b{font-weight:700}.onb-banner{width:100%;height:auto;border-radius:20px;margin-bottom:22px;box-shadow:0 18px 40px -24px #3c281452;display:block}.screen-banner{width:100%;height:auto;border-radius:18px;margin-bottom:16px;display:block;box-shadow:0 14px 34px -22px #3c28144d}.img-opts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:auto}.img-opt{aspect-ratio:1 / 1;background:var(--surface);border:1.5px solid var(--line);border-radius:20px;display:grid;place-items:center;padding:14px;cursor:pointer;transition:border-color .14s ease,transform .1s ease}.img-opt:active{transform:scale(.97)}.img-opt img{width:100%;height:100%;object-fit:contain}.img-opt.sel{border-color:var(--accent);box-shadow:0 0 0 3px #3fbf8624}.img-opt.right{border-color:transparent;background:#3fbf8629;box-shadow:0 0 0 2px var(--accent)}.img-opt.wrong{border-color:transparent;background:#b0432f29;box-shadow:0 0 0 2px #b0432f}.oo-rec{display:inline-block;font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--on-accent);background:var(--accent-grad);border-radius:6px;padding:3px 7px;margin-bottom:6px}.lesson{position:relative}.lesson-top .combo{flex-shrink:0;font-size:12px;font-weight:700;letter-spacing:.02em;color:#fff;background:linear-gradient(150deg,#e8a23f,#cb573a);padding:6px 11px;border-radius:99px;box-shadow:0 8px 18px -8px #cb573a99}.confetti{position:absolute;left:50%;top:28%;width:0;height:0;pointer-events:none;z-index:40}.confetti span{position:absolute;width:11px;height:11px;left:-5px;top:0}.illust{border-radius:16px;object-fit:cover;box-shadow:var(--shadow-sm)}.img-opt{padding:0;overflow:hidden}.img-opt img{width:100%;height:100%;object-fit:cover;border-radius:18px}.build-listen{display:inline-flex;align-items:center;gap:7px;margin-top:12px;background:var(--surface);border:1px solid var(--line);color:var(--accent-text);font-family:Golos Text,sans-serif;font-weight:700;font-size:14px;padding:9px 15px;border-radius:12px;cursor:pointer;box-shadow:var(--shadow-sm)}.build-listen:active{transform:scale(.97)}.level-card,.streak-card,.quest,.goal,.metric,.ach-strip,.basics-card,.room-card,.pstat,.invite,.lb-row,.onb-opt,.onb-goal,.opt,.tone-card,.wrow{box-shadow:var(--shadow-sm),var(--hi)}.flashcard,.level-card{box-shadow:var(--shadow),var(--hi)}.btn{box-shadow:var(--accent-shadow),inset 0 1px #ffffff52}.btn.ghost{box-shadow:var(--shadow-sm),var(--hi)}.btn:active{box-shadow:var(--shadow-sm),inset 0 1px #ffffff52}.tab{position:relative}.tab.active:before{content:"";position:absolute;top:-1px;width:22px;height:3px;border-radius:99px;background:var(--accent-grad);box-shadow:0 2px 8px -2px #3fbf8699}.greet .hi{font-size:25px;letter-spacing:-.03em}.metric .v{font-size:33px}.lc-num{font-size:28px}.q-title,.sc-flame,.flashcard .big{letter-spacing:-.01em}.metric,.level-card,.streak-card,.quest{transition:transform .14s ease}.tabbar{box-shadow:0 -16px 30px -20px #3a26122e}.q-hanzi,.flashcard .big{text-shadow:0 2px 0 rgba(255,255,255,.6)}.btn{background:linear-gradient(160deg,#2c261c,#15110a);color:#faf6ee;box-shadow:0 18px 32px -16px #140f0880,inset 0 1px #ffffff1f}.btn:active{box-shadow:0 8px 18px -12px #140f0880,inset 0 1px #ffffff1f}.btn:disabled{opacity:.4}.btn.ghost{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm),var(--hi)}.vhero{position:relative;overflow:hidden;border-radius:28px;padding:24px;margin-bottom:13px;background:linear-gradient(145deg,#4ccf92,#2f9e6f);color:#06231a;box-shadow:0 22px 42px -18px #3fbf8699,inset 0 1px #ffffff47}.vhero-seal{position:absolute;right:-12px;bottom:-32px;font-size:152px;font-weight:700;color:#00000014;line-height:1;pointer-events:none}.vhero-lab{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;opacity:.7}.vhero-num{font-size:66px;font-weight:700;letter-spacing:-.04em;line-height:.9;margin:6px 0 14px}.vhero-bar{height:12px;background:#00000029;border-radius:99px;overflow:hidden}.vhero-bar .fill{height:100%;background:#fff;border-radius:99px}.vhero-sub{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;opacity:.82;margin-top:11px}.vrow{display:flex;gap:12px;margin-bottom:13px}.vgold{flex:1;border-radius:24px;padding:18px;color:#3a2606;background:linear-gradient(145deg,#f0c25a,#d4912f);box-shadow:0 18px 32px -16px #d4912f8c,inset 0 1px #ffffff52}.vwhite{flex:1;border-radius:24px;padding:18px;background:var(--surface);box-shadow:var(--shadow-sm),var(--hi)}.vc-ic{margin-bottom:6px}.vc-num{font-size:40px;font-weight:700;letter-spacing:-.03em;line-height:1}.vc-lab{font-size:13px;font-weight:700;margin-top:4px;opacity:.85}.vwhite .vc-lab{color:var(--muted);opacity:1}.vc-num2{font-size:13px;font-weight:700;color:var(--accent-text);margin-top:12px}.vc-num2 span{color:var(--muted);font-weight:600}.vweek{display:flex;gap:7px;margin-bottom:13px}.vd{flex:1;height:38px;border-radius:12px;background:var(--surface);display:grid;place-items:center;color:var(--accent-text);box-shadow:var(--shadow-sm),var(--hi)}.vd.on{background:var(--accent-grad);color:#06231a;box-shadow:var(--accent-shadow)}.vd .vd-l{font-size:12px;font-weight:700;color:var(--muted)}.vd.today{outline:2px solid var(--accent);outline-offset:2px}.vquest{background:var(--surface);border-radius:20px;padding:16px 18px;margin-bottom:13px;box-shadow:var(--shadow-sm),var(--hi)}.vq-head{display:flex;justify-content:space-between;font-weight:700;font-size:14.5px;margin-bottom:11px}.vq-c{color:var(--accent-text)}.vquest-bar{height:9px;background:var(--surface-2);border-radius:99px;overflow:hidden}.vquest-bar .fill{height:100%;background:var(--accent-grad);border-radius:99px}.opt.right{background:var(--ok-grad);color:#fff}.img-opt.right{box-shadow:0 0 0 2px var(--ok);background:#3a8f6e29}.grade.g2{background:#5e9e7e}.grade.g3{background:var(--ok)}.feedback.ok{background:#3a8f6e24}.feedback.ok .fb-row{color:var(--ok)}.feedback.ok .fb-ic{background:var(--ok-grad);color:#fff}.speak-res.ok{background:#3a8f6e21}.speak-res.ok .sr-hanzi{color:var(--ok)}.lb-xp{color:var(--accent-text)}.btn{background:linear-gradient(165deg,#2a2620,#161310);color:#f7f1e8;border-radius:16px;box-shadow:0 16px 30px -16px #160f0973}.btn:active{box-shadow:0 8px 16px -10px #160f0973}.ed-kick{font:700 12px Golos Text;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-text)}.ed-hi{font:700 36px Golos Text;letter-spacing:-.035em;line-height:1;color:var(--ink);margin:9px 0 0}.ed-hero{position:relative;padding:28px 0 24px;margin-top:12px;border-bottom:1px solid var(--line)}.ed-hero-hz{position:absolute;right:-4px;top:-10px;font:700 124px "Noto Serif SC";line-height:1;color:#d8452e17;pointer-events:none}.ed-hero-row{display:flex;align-items:flex-end;gap:15px;position:relative}.ed-lv{font:700 76px Golos Text;letter-spacing:-.05em;line-height:.8;color:var(--accent-text)}.ed-lv-meta{padding-bottom:9px}.ed-lv-lab{font:700 12px Golos Text;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}.ed-xp{font:700 18px Golos Text;color:var(--ink);margin-top:4px}.ed-line{height:3px;background:var(--surface-2);border-radius:99px;overflow:hidden;margin-top:18px}.ed-line .fill{height:100%;background:var(--accent);border-radius:99px}.ed-line .fill.ok{background:var(--ok)}.ed-hint{font:600 12.5px Golos Text;color:var(--muted);margin-top:11px}.ed-eye{font:700 12px Golos Text;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:26px 0 16px}.ed-stats{display:flex}.ed-st{flex:1}.ed-st+.ed-st{border-left:1px solid var(--line);padding-left:16px}.ed-st:not(:last-child){padding-right:10px}.ed-n{font:700 40px Golos Text;letter-spacing:-.04em;line-height:1;color:var(--ink)}.ed-n.acc{color:var(--accent-text)}.ed-l{font:600 12.5px Golos Text;color:var(--muted);margin-top:8px}.ed-week{display:flex;gap:8px;margin-top:24px}.ed-week .wd{flex:1;height:5px;border-radius:99px;background:var(--surface-2)}.ed-week .wd.on{background:var(--accent)}.ed-quest{margin-top:26px}.ed-q-head{display:flex;justify-content:space-between;font:700 14px Golos Text;color:var(--ink);margin-bottom:12px}.ed-q-head .c{color:var(--accent-text)}.ed-rows{margin-top:26px;border-top:1px solid var(--line)}.ed-row{width:100%;display:flex;align-items:center;gap:14px;padding:16px 2px;border:none;border-bottom:1px solid var(--line);background:none;cursor:pointer;font-family:Golos Text;text-align:left}.ed-row-hz{font:700 26px "Noto Serif SC";color:var(--accent-text);width:30px;text-align:center}.ed-row-ic{color:var(--accent-text);width:30px;display:grid;place-items:center}.ed-row-t{flex:1;display:flex;flex-direction:column}.ed-row-t b{font:700 15px Golos Text;color:var(--ink)}.ed-row-t small{font:600 12px Golos Text;color:var(--muted);margin-top:2px}.ed-row-meta{font:700 14px Golos Text;color:var(--muted)}.ed-cta-wrap{margin-top:30px}.ed-textlink{display:block;width:100%;text-align:center;background:none;border:none;color:var(--accent-text);font:700 15px Golos Text;padding:15px;cursor:pointer;margin-top:4px}.tab.active svg{filter:drop-shadow(0 4px 10px rgba(216,69,46,.45))}.ed-lead{font:600 15px Golos Text;color:var(--ink-soft);line-height:1.5;margin-top:12px;max-width:34ch}.ed-roomact{margin-top:22px}.ed-empty{font:600 14px Golos Text;color:var(--muted);margin-top:24px;line-height:1.5}.ed-roomhead{display:flex;align-items:center;gap:12px;margin-top:4px}.ed-coop{display:flex;align-items:baseline;gap:8px;margin-top:8px}.ed-coop-n{font:700 56px Golos Text;letter-spacing:-.04em;line-height:1;color:var(--ink)}.ed-coop-g{font:700 20px Golos Text;color:var(--muted)}.ed-invite{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:22px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.ed-code{font:700 28px Golos Text;letter-spacing:.14em;color:var(--accent-text);margin-top:4px}.ed-lbrow{display:flex;align-items:center;gap:14px;padding:14px 2px;border-bottom:1px solid var(--line)}.ed-lbrow.me .ed-lbname{color:var(--accent-text)}.ed-rank{width:26px;height:26px;flex-shrink:0;display:grid;place-items:center;border-radius:8px;font:700 13px Golos Text;background:var(--surface-2);color:var(--muted)}.ed-rank.r1{background:linear-gradient(150deg,#e7c25f,#c79a2e);color:#3a2606}.ed-rank.r2{background:linear-gradient(150deg,#cdd2d6,#9aa0a6);color:#1a1a1c}.ed-rank.r3{background:linear-gradient(150deg,#d9a06a,#b07640);color:#2a1606}.ed-lbname{flex:1;font:600 15px Golos Text;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ed-lbxp{font:700 15px Golos Text;color:var(--ink)}.ed-lbxp span{color:var(--muted);font-weight:600;font-size:12px}.ed-badges{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ed-badge{display:flex;align-items:center;gap:11px;padding:14px 15px;border-radius:16px;background:var(--surface);box-shadow:var(--shadow-sm),var(--hi);opacity:.5}.ed-badge.got{opacity:1}.ed-badge-ic{width:38px;height:38px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;background:var(--surface-2);color:var(--muted)}.ed-badge.got .ed-badge-ic{background:var(--accent-grad);color:#fff;box-shadow:var(--accent-shadow)}.ed-badge-t{font:700 13px Golos Text;color:var(--ink);line-height:1.2}.ed-rbanner{width:100%;height:152px;object-fit:cover;object-position:center;border-radius:20px;margin-bottom:22px;display:block;box-shadow:var(--shadow-sm)}
