:root{--paper: #fffaf0;--paper-2: #f3f8f2;--surface: #ffffff;--surface-soft: #fff7ea;--ink: #2f2a24;--ink-soft: #645b51;--muted: #91897f;--coral: #ff6f3d;--coral-d: #d94f25;--green: #69b943;--green-d: #3e8f2d;--blue: #3a9fe8;--blue-soft: #eaf6ff;--violet: #7c6ad8;--violet-soft: #f0edff;--yellow: #ffc83d;--red: #ef6461;--line: #ded8c8;--shadow: 0 16px 36px rgba(87, 63, 24, .12);--shadow-sm: 0 7px 18px rgba(87, 63, 24, .1);--radius: 20px;--radius-sm: 12px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;overflow-x:hidden;background:linear-gradient(180deg,#fffaf0,#fff7e6 42%,#edf8ef)}button,input{font:inherit}button{-webkit-appearance:none;-moz-appearance:none;appearance:none}.app{max-width:880px;margin:0 auto;padding:24px 26px 56px;min-height:100%}.app.has-tabs{padding-bottom:96px}.topbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.app-header{padding:4px 2px 2px}.brand-lockup{display:flex;align-items:center;gap:12px;min-width:0}.brand-wordmark{position:relative;display:inline-block;padding:0 18px 18px 0;color:#f0552f;transform:rotate(-2deg)}.brand-wordmark span{display:block;font-size:clamp(38px,8.5vw,62px);line-height:.92;font-weight:950;text-shadow:0 4px 0 #ffd49c,0 7px 14px rgba(210,76,31,.12)}.brand-wordmark i{position:absolute;top:-8px;left:97px;color:var(--yellow);font-style:normal;font-size:23px;text-shadow:0 2px 0 #fff}.brand-wordmark:after{content:"";position:absolute;left:6px;right:18px;bottom:4px;height:12px;border-bottom:5px solid #f2aa22;border-radius:50%;transform:rotate(-2deg)}.spacer{flex:1}.header-stats{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.pill{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#ffffffe0;border:1px solid rgba(222,216,200,.85);border-radius:999px;padding:9px 14px;color:var(--ink);font-weight:850;font-size:15px;box-shadow:var(--shadow-sm);white-space:nowrap}.stat-pill{min-height:50px;min-width:112px;font-size:20px;padding:10px 18px}.hero-avatar{width:70px;height:70px;border-radius:50%;font-size:38px;border:7px solid #dff4c9;background:#fff;box-shadow:var(--shadow-sm);padding:0}.trace-pill{max-width:min(72vw,520px);overflow-wrap:anywhere;font-size:12px}.acct-switch{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.account-rail{background:#ffffff94;border:1px solid rgba(222,216,200,.72);border-radius:18px;padding:8px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.avatar{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;font-size:24px;background:#fff;box-shadow:inset 0 0 0 1px #ded8c8a6;border:3px solid transparent;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease}.avatar:active{transform:scale(.94)}.avatar.active{transform:translateY(-2px);box-shadow:0 10px 20px #4939201f}.card{background:#ffffffeb;border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;border:1px solid rgba(222,216,200,.78)}.btn{border:none;border-radius:18px;padding:14px 22px;min-height:54px;color:#fff;cursor:pointer;font-size:18px;font-weight:900;background:linear-gradient(180deg,#ff8c60,var(--coral));box-shadow:0 6px 0 var(--coral-d),var(--shadow-sm);transition:transform .08s ease,box-shadow .08s ease,opacity .12s ease}.btn:active{transform:translateY(4px);box-shadow:0 2px 0 var(--coral-d)}.btn.secondary{background:#fff;color:var(--ink);box-shadow:0 6px #e0d8c6,var(--shadow-sm)}.btn.secondary:active{box-shadow:0 2px #e0d8c6}.btn.grape{background:linear-gradient(180deg,#8f80e8,var(--violet));box-shadow:0 6px #5e50b8,var(--shadow-sm)}.btn.grape:active{box-shadow:0 2px #5e50b8}.btn.ghost{background:#ffffffb8;color:var(--ink-soft);box-shadow:none;border:1px solid rgba(222,216,200,.78);min-height:42px;padding:10px 14px;font-size:15px}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-row{display:flex;gap:12px;flex-wrap:wrap}h1,h2,h3{margin:0 0 10px;letter-spacing:0}.muted{color:var(--muted)}.center{text-align:center}.big-emoji{font-size:70px;line-height:1;filter:drop-shadow(0 6px 8px rgba(0,0,0,.12))}.daily-bar{--daily-pct: 0%;display:flex;align-items:center;gap:20px;background:#ffffffeb;border:1px solid rgba(237,224,197,.92);border-radius:26px;padding:22px 18px;margin-bottom:24px;box-shadow:var(--shadow)}.db-icon{width:78px;height:78px;border-radius:22px;display:grid;place-items:center;background:linear-gradient(145deg,#fff9df,#ffe3a8);color:var(--green-d);font-size:43px;font-weight:950;box-shadow:inset 0 0 0 3px #ffffffe6,0 5px #edbd40;flex:none}.db-main{min-width:0;flex:1;display:grid;gap:14px}.db-head{display:flex;align-items:center;gap:10px}.db-label{font-weight:950;font-size:clamp(24px,4vw,34px);color:#2f251b}.db-msg{color:var(--ink-soft);font-weight:850;font-size:14px}.db-metrics{display:grid;grid-template-columns:repeat(3,auto);gap:0;align-items:center;color:var(--ink);font-size:clamp(15px,2.6vw,20px);font-weight:750}.db-metrics span{padding:0 20px;border-left:1px solid #ded8c8;white-space:nowrap}.db-metrics span:first-child{padding-left:0;border-left:none}.db-metrics b{font-size:1.55em;line-height:1}.db-metrics .orange{color:#f25c2d}.db-metrics .green{color:#49a52d}.db-metrics .blue{color:#2388f2}.db-track{height:10px;background:#eee7d7;border-radius:999px;overflow:hidden}.db-track>i{display:block;height:100%;width:var(--daily-pct);background:linear-gradient(90deg,var(--green),var(--coral));border-radius:inherit;transition:width .25s ease}.db-dots{display:flex;gap:4px;font-size:16px;color:#c5bbab}.db-dot.on{color:var(--yellow);text-shadow:0 1px 0 #fff}.db-ring{width:76px;height:76px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--green) 0 var(--daily-pct),#ece5d5 var(--daily-pct) 100%);color:var(--ink);font-weight:950;position:relative;flex:none;font-size:21px}.db-ring:before{content:"";position:absolute;top:7px;right:7px;bottom:7px;left:7px;background:#fffaf3;border-radius:inherit}.db-ring b,.db-ring span{position:relative;z-index:1}.db-ring span{color:var(--muted);margin-left:2px}.db-done{color:var(--green-d);font-weight:950;padding:8px 12px;border-radius:999px;background:#eff8ea}.db-quiz{min-height:44px;padding:10px 16px;font-size:15px;box-shadow:0 4px #5e50b8}.db-arrow{border:none;background:transparent;color:#c3beb2;font-size:58px;line-height:1;font-weight:500;padding:0 2px;cursor:pointer}.db-arrow[aria-hidden=true]{cursor:default}.learn{display:grid;gap:0}.learn-overview{display:block;background:transparent;border:none;border-radius:0;padding:0;box-shadow:none;margin-bottom:24px}.learn-overview h1{font-size:clamp(25px,4vw,38px);line-height:1.08;font-weight:950;color:var(--ink)}.learn-overview p{margin:0;color:var(--green-d);font-weight:850}.overview-art{width:94px;height:70px;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid rgba(222,216,200,.8);background:#fff7ea}.overview-art img{width:100%;height:100%;display:block;object-fit:cover}.subject-tabs{position:relative;display:flex;gap:0;padding:0;overflow:hidden;background:linear-gradient(180deg,#f8fbff,#edf5ff);border-radius:22px;border:4px solid #d9e0ef;box-shadow:inset 0 0 0 1px #fdfefe;flex:none}.subject-tab{flex:1;min-width:112px;border:none;border-radius:0;padding:19px 20px;font-size:28px;font-weight:950;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;background:transparent;color:var(--ink-soft);transition:background .15s ease,color .15s ease,transform .08s ease}.subject-tab span{font-size:36px;line-height:1}.subject-tab:active{transform:scale(.97)}.subject-tab.yw.on,.subject-tab.sx.on{background:linear-gradient(180deg,#ff8757,#ff6a38);color:#fff;box-shadow:inset 0 -5px #d0461a73,0 8px 16px #f15d2f33}.block-stack{display:grid;gap:0}.block{position:relative;overflow:hidden;border-radius:42px 42px 12px 12px;padding:28px 34px 34px;background:linear-gradient(180deg,#ffffeb80,#f3ffe280),url(/assets/learning-visuals/learning-map-bg-v2.png) center top / cover no-repeat;border:1px solid rgba(204,232,152,.9);box-shadow:inset 0 8px #8bcc5047,var(--shadow)}.block:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,#fffff533,#f2ffe25c)}.block-head,.trail,.trail-more{position:relative;z-index:1}.block-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(190px,330px);gap:18px;align-items:start;margin-bottom:26px}.block-icon{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;background:#ffffffe6;font-size:26px;box-shadow:var(--shadow-sm);flex:none}.map-title-wrap h2{margin:0 0 12px;font-size:clamp(28px,5vw,42px);line-height:1.1;font-weight:950;color:#2d2118}.map-title-wrap p{margin:14px 0 0;color:#736353;font-size:clamp(15px,2.4vw,20px);font-weight:750}.block-title{font-size:22px;font-weight:950;display:block}.block-sub{font-size:13px;color:var(--ink-soft);font-weight:800;margin-top:2px}.block-prog{font-size:14px;font-weight:900;color:var(--ink-soft);margin-left:auto}.freq-pill{display:inline-flex;align-items:center;gap:6px;font-size:20px;font-weight:950;padding:7px 15px;border-radius:10px;border:2px solid rgba(100,172,58,.55);white-space:nowrap}.freq-pill.hot{background:#fff3cf;color:#855000}.freq-pill.mid{background:#f2f9e8;color:var(--green-d)}.freq-pill.low{background:#f0eef6;color:var(--violet)}.mastery-card{background:linear-gradient(145deg,#f6fcfff5,#e8f6ffeb);border:2px solid rgba(160,204,235,.9);border-radius:24px;padding:18px 18px 16px;box-shadow:var(--shadow-sm)}.mastery-title{font-size:20px;font-weight:950;margin-bottom:12px;color:#243a4c}.mastery-body{display:flex;align-items:center;gap:16px}.mastery-ring{width:82px;height:82px;border-radius:50%;display:grid;place-items:center;flex:none;position:relative;background:radial-gradient(circle,#f8fcff 0 56%,transparent 57%),conic-gradient(var(--green) var(--mastery-pct),#dce8f0 0)}.mastery-ring b{font-size:25px;line-height:1}.mastery-ring span{display:block;margin-top:-18px;font-size:11px;color:#516270;font-weight:800}.mastery-lines{display:grid;gap:10px;color:#344152;font-size:19px;font-weight:750}.mastery-lines b{color:#1f2c3b}.mastery-go{margin-left:auto;color:#b6bdc6;font-size:52px;line-height:1}.trail{display:grid;gap:40px;padding:34px 10px 22px 78px}.trail:before{content:"";position:absolute;left:102px;top:18px;bottom:28px;width:10px;border-radius:999px;background:repeating-linear-gradient(180deg,rgba(82,176,44,.72) 0 14px,transparent 14px 27px)}.node{position:relative;z-index:1;width:auto;min-width:0;max-width:100%;min-height:94px;display:flex;align-items:center;gap:14px;border:2px solid rgba(151,202,116,.72);border-radius:22px;padding:17px 24px 17px 112px;background:linear-gradient(180deg,#ffffffeb,#f5ffefe0);color:var(--ink);box-shadow:0 5px #709e5329,var(--shadow-sm);text-align:left;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.node:active{transform:scale(.985)}.node:disabled{cursor:not-allowed}.node.current{min-height:116px;border:5px solid var(--coral);background:linear-gradient(180deg,#fffdf8,#fff6e9);box-shadow:0 10px #d94f2538,var(--shadow)}.node.done{border-color:#69b943a6;background:linear-gradient(180deg,#ffffffeb,#effce8e0)}.node.locked{border-color:#c2becde6;background:linear-gradient(180deg,#ffffffeb,#f1eff7e6);box-shadow:0 5px #6e687c1c,var(--shadow-sm);color:#6e6783}.node .emoji{position:absolute;left:-42px;top:50%;transform:translateY(-50%);width:96px;height:96px;border-radius:50%;flex:none;display:grid;place-items:center;background:linear-gradient(145deg,#fff4d9,#ffe1ad);color:var(--coral-d);font-size:44px;font-weight:950;box-shadow:inset 0 0 0 8px #fff,0 6px #da6f1b38,var(--shadow-sm)}.node .emoji span{line-height:1}.node .emoji em{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);color:#ffd438;font-size:20px;font-style:normal;letter-spacing:-4px;text-shadow:0 2px 0 #fff,0 2px 6px rgba(135,97,0,.24);white-space:nowrap}.node.done .emoji{background:linear-gradient(145deg,#9be44f,#60bd28);color:#fff;font-size:45px}.node.current .emoji{width:114px;height:114px;left:-56px;font-size:58px;background:linear-gradient(145deg,#ff9a3d,#ff671f);color:#fff}.node.locked .emoji{background:linear-gradient(145deg,#d7d5df,#a8a4b6);color:#fff;font-size:25px}.node .meta{flex:1;min-width:0}.node .meta .t{font-weight:950;font-size:clamp(22px,3.6vw,34px);line-height:1.2;overflow-wrap:break-word}.node .meta .s{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:8px;font-size:clamp(15px,2.4vw,20px);font-weight:850;color:var(--muted)}.node .meta .s i{width:1px;height:20px;background:#d7cfbf}.node.current .meta .s{color:var(--coral-d)}.stars{color:#e9a600;letter-spacing:1px;font-size:19px;flex:none;white-space:nowrap}.node-cta{flex:none;min-width:138px;border-radius:22px;padding:15px 20px;text-align:center;color:#fff;background:linear-gradient(180deg,#ff8b4b,#ff652f);font-size:clamp(18px,3vw,28px);font-weight:950;box-shadow:0 5px 0 var(--coral-d),var(--shadow-sm)}.node:not(.current) .node-cta{min-width:auto;padding:0;color:#7fa56c;background:transparent;box-shadow:none;font-size:44px}.node.locked .node-cta{color:#6f6594;background:transparent;box-shadow:none;font-size:18px;min-width:88px}.current-tag{position:absolute;right:24px;top:0;transform:translateY(-1px);color:var(--coral-d);background:#fff3db;border-radius:0 0 15px 15px;padding:9px 18px;font-weight:950;font-size:16px}.trail-more{width:100%;margin-top:14px;color:var(--violet);background:#ffffffe0;box-shadow:none;border:1px solid rgba(222,216,200,.82)}.q-wrap{max-width:720px;margin:0 auto}.q-topbar{margin-bottom:16px}.q-title-pill{background:#fff7e8;color:var(--coral-d)}.q-count-pill{background:var(--blue-soft);color:#1c6fa7}.q-progress{height:13px;background:#ebe3d3;border-radius:999px;overflow:hidden;margin-bottom:18px;box-shadow:inset 0 0 0 1px #ded8c8b3}.q-progress>i{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--yellow),var(--coral));transition:width .3s;border-radius:inherit}.q-card{background:#fffffff5;border-radius:28px;box-shadow:var(--shadow);padding:clamp(20px,4vw,34px);text-align:center;border:1px solid rgba(222,216,200,.82)}.q-card-top{display:flex;justify-content:space-between;gap:10px;margin-bottom:14px;color:var(--muted);font-size:13px;font-weight:850}.q-card-top span{padding:6px 10px;border-radius:999px;background:#f7f1e6}.q-text{font-size:clamp(24px,4vw,34px);font-weight:950;line-height:1.45;margin:8px 0 18px}.q-math{font-size:clamp(46px,9vw,68px);font-weight:950;letter-spacing:2px;margin:10px 0}.opts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}.opt{min-height:70px;border-radius:18px;border:2px solid #e8dfcf;background:#fff;color:var(--ink);font-size:clamp(22px,3.8vw,30px);font-weight:950;cursor:pointer;display:grid;place-items:center;padding:12px;box-shadow:var(--shadow-sm);transition:transform .08s ease,border-color .12s ease,background .12s ease}.opt:active{transform:scale(.97)}.opt.correct{border-color:var(--green);background:#eff9e9;color:var(--green-d)}.opt.wrong{border-color:var(--red);background:#fff0ef;color:#b83e3b}.speaker{font-size:28px;background:linear-gradient(180deg,#ffe078,var(--yellow));border:none;border-radius:50%;width:66px;height:66px;cursor:pointer;box-shadow:0 5px #d99f00;color:#6f4d00}.speaker:active{transform:translateY(3px);box-shadow:0 2px #d99f00}.feedback{font-size:21px;font-weight:950;min-height:30px;margin-top:14px}.feedback.ok{color:var(--green-d)}.feedback.no{color:var(--red)}.clock-wrap{display:grid;place-items:center;gap:14px;margin:6px 0 4px}.clockface{width:min(74vw,280px);height:min(74vw,280px);touch-action:none}.clockface.hit{animation:clkPop .5s cubic-bezier(.2,1.4,.4,1)}@keyframes clkPop{0%{transform:scale(1)}40%{transform:scale(1.06)}to{transform:scale(1)}}.clk-rim{fill:#ffd23f}.clk-face{fill:#fffdf7;stroke:#fff;stroke-width:3}.tick{stroke:#d9d2ef;stroke-width:2;stroke-linecap:round}.tick.big{stroke:var(--violet);stroke-width:4}.clk-num{font-size:20px;font-weight:900;fill:var(--ink);text-anchor:middle}.hand{stroke-linecap:round}.hand.hour{stroke:var(--ink);stroke-width:9}.hand.minute{stroke:var(--coral);stroke-width:6}.clk-cap{fill:var(--coral);stroke:#fff;stroke-width:3}.grab{fill:#7c6ad82e;stroke:var(--violet);stroke-width:2.5;cursor:grab}.grab.minute{stroke:var(--coral);fill:#ff6f3d2e}.clock-set-bar{display:grid;place-items:center;gap:10px;width:100%}.clk-readout{font-size:19px;font-weight:750;color:var(--muted)}.clk-readout b{color:var(--violet);font-size:22px}.clk-target{color:var(--coral-d)}.clk-hit-tag{font-size:20px;font-weight:950;color:var(--green-d)}.intro-card,.welcome-card{max-width:520px;margin:24px auto}.intro-card{overflow:hidden;position:relative}.intro-art{height:min(48vw,260px);margin:-6px -6px 14px;border-radius:22px;overflow:hidden;background:#fff7ea;border:1px solid rgba(222,216,200,.78);box-shadow:var(--shadow-sm)}.intro-art img{width:100%;height:100%;object-fit:cover;display:block}.intro-badge{width:64px;height:64px;margin:-46px auto 10px;border-radius:50%;display:grid;place-items:center;position:relative;z-index:1;background:#fff;box-shadow:inset 0 0 0 6px #fff3cf,var(--shadow-sm);font-size:32px}.intro-brief{font-size:19px;font-weight:800;line-height:1.6;margin:8px 0;color:var(--ink)}.intro-pitfall{font-size:15px;color:var(--coral-d);background:#fff2e9;border-radius:16px;padding:11px 14px;margin-top:10px;font-weight:850}.speaker.mini{width:42px;height:42px;font-size:20px;vertical-align:middle;box-shadow:0 3px #d99f00;margin-left:6px}.sorttask{display:grid;gap:14px}.sort-answer{min-height:66px;border-radius:16px;border:2px dashed #d6cdbd;background:#fffaf0;padding:12px;display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:center}.sort-answer.shake{animation:shakeX .4s;border-color:var(--red);background:#fff0ef}@keyframes shakeX{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.sort-pool,.classify-pool,.bin-items,.fc-words{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.word-chip,.match-item{font-size:23px;font-weight:950;padding:12px 17px;border-radius:16px;cursor:pointer;background:#fff;border:2px solid #e8dfcf;box-shadow:var(--shadow-sm);color:var(--ink)}.word-chip:active,.match-item:active{transform:scale(.96)}.word-chip.picked{background:#eff9e9;border-color:var(--green)}.matchtask{display:grid;grid-template-columns:1fr 1fr;gap:12px 28px}.match-col{display:grid;gap:12px}.match-item.sel{border-color:var(--violet);background:var(--violet-soft)}.match-item.matched{border-color:var(--green);background:#eff9e9;opacity:.7;cursor:default}.match-item.bad{border-color:var(--red);background:#fff0ef}.classifytask{display:grid;gap:14px}.classify-pool{min-height:48px}.classify-bins{display:grid;grid-template-columns:1fr 1fr;gap:12px}.bin{border:2px dashed #d6cdbd;border-radius:18px;padding:12px;min-height:92px;cursor:pointer;background:#fffaf0;text-align:center}.bin.sel-target{border-color:var(--violet);background:var(--violet-soft)}.bin.bad{border-color:var(--red);animation:shakeX .4s}.bin-name{font-weight:950;font-size:16px;color:var(--violet);margin-bottom:8px}.chip-sel{outline:3px solid var(--violet)}.flashcard{display:grid;place-items:center;gap:6px}.fc-pinyin{font-size:26px;font-weight:850;color:#c9c0b4;min-height:36px;letter-spacing:1px}.fc-pinyin.show{color:var(--violet)}.fc-char{font-size:110px;font-weight:950;line-height:1.1;color:var(--ink);cursor:pointer;background:linear-gradient(135deg,#fffaf0,#fff0df);border:1px solid rgba(222,216,200,.85);border-radius:28px;width:200px;height:200px;display:grid;place-items:center;box-shadow:var(--shadow);transition:transform .1s}.fc-char:active{transform:scale(.97)}.fc-words{margin-top:6px}.fc-word{font-size:20px;font-weight:850;background:var(--blue-soft);color:var(--ink);padding:8px 16px;border-radius:14px;cursor:pointer;border:1px solid #cde8fa}.trace-box{display:grid;place-items:center}.trace-canvas{background:#fff;border-radius:18px;box-shadow:var(--shadow-sm);touch-action:none}.trace-line{display:none}.panel-page,.parent-panel{display:grid;gap:14px}.page-title,.parent-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#ffffffe6;border:1px solid rgba(222,216,200,.78);border-radius:24px;padding:18px;box-shadow:var(--shadow-sm)}.page-title h2,.parent-hero h1{font-size:clamp(26px,4vw,38px);font-weight:950}.page-title p,.parent-hero p{margin:0;color:var(--muted);font-weight:800}.page-symbol{font-size:42px}.review-callout{display:flex;gap:10px;align-items:center;border-left:6px solid var(--yellow)}.empty-state{padding:34px;color:var(--muted);font-weight:850}.parent-score{--parent-score-pct: 0%;width:112px;height:112px;display:grid;place-items:center;flex:none;border-radius:50%;background:radial-gradient(circle,#fff 0 58%,transparent 59%),conic-gradient(var(--green) 0 var(--parent-score-pct),#e9e2d3 var(--parent-score-pct) 100%);color:var(--green-d);font-size:28px;font-weight:950;position:relative}.parent-score:before,.parent-score:after{content:none}.metric-grid{margin-top:0}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.metric-card{display:grid;gap:4px;align-content:center;min-height:132px}.metric-number{font-size:46px;font-weight:950;color:var(--green-d)}.metric-line{font-size:22px;font-weight:900;margin-top:8px}.info-strip{margin-top:0}.wrong-book-card{display:grid;gap:10px}.wrong-book-due{display:flex;flex-wrap:wrap;align-items:center;gap:4px 6px;color:var(--ink);font-weight:900}.empty-state.compact{padding:18px}.mast-grid.compact{gap:6px}.mast-grid.compact .mast-row{padding:10px 12px;box-shadow:none}.section-h{display:inline-flex;align-items:center;gap:8px;width:fit-content;font-weight:950;font-size:16px;color:#fff;background:linear-gradient(90deg,var(--green),var(--blue));padding:9px 15px;border-radius:999px;margin:12px 0 4px;box-shadow:var(--shadow-sm)}.mast-grid{display:grid;grid-template-columns:1fr;gap:8px}.mast-row{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#ffffffeb;border-radius:16px;box-shadow:var(--shadow-sm);border:1px solid rgba(222,216,200,.78)}.dot{width:16px;height:16px;border-radius:50%;flex:none}.dot.green{background:var(--green)}.dot.yellow{background:var(--yellow)}.dot.red{background:var(--red)}.dot.grey{background:#c8c1b6}.report pre{white-space:pre-wrap;font-family:inherit;font-size:15px;line-height:1.75;background:#fffaf0;padding:16px;border-radius:16px;border:1px solid rgba(222,216,200,.72)}.badge{display:inline-flex;gap:6px;align-items:center;background:#fff3cf;color:#765000;border-radius:999px;padding:7px 12px;font-weight:900;font-size:14px;margin:4px 4px 0 0}.input{font-size:18px;padding:12px 14px;border-radius:14px;border:2px solid #ddd3c2;width:100%}.input:focus{outline:none;border-color:var(--blue)}.swatches{display:flex;gap:10px;justify-content:center;margin:12px 0}.swatch{width:38px;height:38px;border-radius:50%;cursor:pointer;border:3px solid #fff;box-shadow:var(--shadow-sm)}.setting-row{display:flex;align-items:center;gap:14px}.setting-row>div:first-child{flex:1}.toggle{flex:none;width:60px;height:34px;border-radius:999px;border:none;cursor:pointer;background:#d9d0c1;position:relative;transition:background .2s;padding:0}.toggle.on{background:var(--green)}.toggle .knob{position:absolute;top:4px;left:4px;width:26px;height:26px;border-radius:50%;background:#fff;box-shadow:0 2px 5px #0000002e;transition:transform .2s}.toggle.on .knob{transform:translate(26px)}.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%);background:linear-gradient(180deg,var(--violet),#5e50b8);color:#fff;padding:14px 22px;border-radius:999px;font-weight:900;box-shadow:0 10px 24px #3f368247;z-index:50}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2f2a247a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100;padding:16px}.modal{background:var(--surface);border-radius:26px;padding:28px;max-width:460px;width:100%;box-shadow:0 20px 60px #2f2a2447;text-align:center;border:1px solid rgba(222,216,200,.9);animation:modalIn .25s cubic-bezier(.2,1.2,.4,1)}@keyframes modalIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:120}.confetti-bit{position:absolute;top:-24px;display:inline-block;border-radius:3px;animation-name:confFall;animation-timing-function:cubic-bezier(.3,.6,.5,1);animation-fill-mode:forwards}@keyframes confFall{0%{transform:translateY(-10vh) rotate(0);opacity:0}10%{opacity:1}to{transform:translateY(112vh) rotate(var(--rot));opacity:1}}.bottom-tabs{position:fixed;left:0;right:0;bottom:0;z-index:50;max-width:880px;margin:0 auto;display:flex;background:#fffffff5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid rgba(222,216,200,.82);box-shadow:0 -8px 24px #4939201a;padding:10px 16px calc(10px + env(safe-area-inset-bottom));border-radius:32px 32px 0 0}.bottom-tabs button{flex:1;border:none;background:none;cursor:pointer;display:grid;place-items:center;gap:2px;min-width:0;padding:12px 0;color:#7f7d88;font-weight:950;border-radius:28px}.bottom-tabs button:active{transform:scale(.95)}.bottom-tabs button.on{color:var(--coral-d);background:#fff2df}.bt-ico{font-size:34px;filter:grayscale(.35)}.bottom-tabs button.on .bt-ico{filter:none}.bt-txt{font-size:18px}@media (max-width: 760px){.app{padding:26px 12px 52px}.app.has-tabs{padding-bottom:112px}.app-header{flex-wrap:nowrap;justify-content:space-between}.brand-wordmark span{font-size:clamp(32px,9.5vw,44px)}.brand-wordmark i{left:78px;top:-7px;font-size:17px}.brand-wordmark:after{height:9px;border-bottom-width:4px}.spacer{display:none}.header-stats{flex:none;flex-wrap:nowrap;gap:6px}.stat-pill{min-height:42px;min-width:76px;padding:8px 10px;font-size:17px}.hero-avatar{width:54px;height:54px;border-width:5px;font-size:28px}.daily-bar{gap:10px;padding:16px 12px;border-radius:24px}.db-icon{width:58px;height:58px;border-radius:17px;font-size:31px}.db-main{gap:8px}.db-label{font-size:22px}.db-metrics{grid-template-columns:repeat(3,minmax(0,1fr));font-size:12px;gap:0}.db-metrics span{padding:0 6px;white-space:normal;text-align:center}.db-metrics b{font-size:1.55em}.db-ring{width:58px;height:58px;font-size:17px}.db-arrow{font-size:38px}.learn-overview{padding:0}.overview-art{display:none}.subject-tabs{width:100%}.subject-tab{flex:1;min-width:0;padding:15px 10px;font-size:23px}.subject-tab span{font-size:28px}.block{padding:22px 12px 26px;border-radius:34px 34px 12px 12px}.block-head{grid-template-columns:minmax(0,1fr) 160px;gap:10px}.map-title-wrap h2{font-size:21px;white-space:nowrap}.map-title-wrap p{font-size:13px;margin-top:10px}.freq-pill{font-size:16px;padding:5px 10px}.mastery-card{padding:12px;border-radius:18px}.mastery-title{font-size:14px;margin-bottom:8px}.mastery-body{gap:8px}.mastery-ring{width:58px;height:58px}.mastery-ring b{font-size:18px}.mastery-ring span{display:none}.mastery-lines{font-size:13px;gap:5px}.mastery-go{display:none}.trail{gap:33px;padding:24px 0 16px}.trail:before{left:48px;width:7px}.node{min-height:80px;padding:14px 12px 14px 96px;border-radius:20px}.node.current{min-height:100px;border-width:4px}.node .emoji{width:74px;height:74px;left:12px;font-size:34px;box-shadow:inset 0 0 0 6px #fff,0 5px #da6f1b33,var(--shadow-sm)}.node .emoji em{font-size:16px;bottom:-8px}.node.current .emoji{width:92px;height:92px;left:8px;font-size:47px}.node .meta .t{font-size:21px}.node .meta .s{font-size:13px;gap:8px}.node .meta .s i{height:15px}.node-cta{min-width:112px;padding:13px 15px;font-size:20px;border-radius:18px}.node.current .meta{padding-right:0}.node.current .meta .t{font-size:20px;padding-right:10px}.node.current .meta .s{padding-right:116px}.node.current .node-cta{position:absolute;right:14px;bottom:17px;min-width:104px;padding:11px 13px;font-size:18px}.node:not(.current) .node-cta{font-size:30px}.node.locked .node-cta{font-size:13px;min-width:72px}.current-tag{right:14px;padding:7px 13px;font-size:13px}.opts,.grid2{grid-template-columns:1fr}.parent-hero{align-items:flex-start}.parent-score{width:92px;height:92px;font-size:24px}.intro-art{height:220px}}@media (max-width: 480px){.app-header{gap:4px}.brand-wordmark{padding-right:8px}.header-stats{gap:5px}.stat-pill{min-width:62px;font-size:15px;padding:7px 8px}.hero-avatar{width:48px;height:48px;font-size:25px}.account-rail .pill{width:100%}.node{gap:8px}.node.current .meta .t{padding-top:10px}.intro-art{height:190px}.matchtask,.classify-bins{grid-template-columns:1fr}.bottom-tabs{border-radius:26px 26px 0 0;padding-left:10px;padding-right:10px}.bt-ico{font-size:30px}.bt-txt{font-size:16px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}:root{--ink: #32251d;--ink-soft: #5f5248;--muted: #8d8b87;--faint: #c4c7cc;--coral: #ff6b2c;--coral-d: #eb5522;--orange-2: #ff9b42;--green: #68b532;--green-d: #4b9b24;--green-path: #7fc242;--blue: #218de8;--violet: #7667c6;--line: #ece6d8;--paper: #fffdf4}body{background:#d8dde5;font-family:Noto Sans SC,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;-webkit-font-smoothing:antialiased}.app.skinned{max-width:432px;min-height:100vh;margin:0 auto;padding:0;overflow-x:hidden;color:var(--ink);background:radial-gradient(circle at 20% -10%,#fffffff2,#fff0 34%),linear-gradient(180deg,#fff6df,#fffaf0 28%,#fefcf4 58%,#fbfff4)}.app.skinned.has-tabs{padding-bottom:116px}.app.skinned button{font-family:inherit}.app.skinned .topbar{margin:0}.flow-shell{min-height:100vh;color:var(--ink);font-family:Noto Sans SC,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}.flow-shell button{font-family:inherit}.app.skinned .app-header{display:flex;align-items:center;gap:8px;padding:24px 16px 8px;background:transparent;border:0;box-shadow:none;flex-wrap:nowrap}.app.skinned .brand-logo{display:block;width:138px;height:auto;flex:0 0 auto;margin-right:auto}.app.skinned .header-stats{display:flex;align-items:center;gap:7px;flex:0 0 auto}.app.skinned .header-stats .stat-pill{min-width:66px;height:42px;padding:0 12px;border:1px solid rgba(235,222,190,.85);border-radius:999px;background:#ffffffe6;box-shadow:0 6px 14px #805d2017;color:#342820;font-size:13px;font-weight:850;white-space:nowrap}.app.skinned .header-stats .fire-pill{min-width:91px}.app.skinned .header-stats .stat-pill img{width:22px;height:22px;object-fit:contain}.app.skinned .header-stats .stat-pill b{color:var(--coral-d);font-size:18px;font-weight:950}.app.skinned .hero-avatar{width:50px;height:50px;padding:0;border:4px solid #d9f4b8;border-radius:50%;overflow:hidden;background:#fff;box-shadow:0 5px 12px #4d672629;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.app.skinned .hero-avatar:hover{border-color:#b9ec75;box-shadow:0 8px 16px #4d672633;transform:translateY(-1px)}.app.skinned .hero-avatar:active{transform:scale(.96)}.app.skinned .hero-avatar:focus-visible{outline:3px solid rgba(78,174,50,.28);outline-offset:3px}.app.skinned .hero-avatar img{width:100%;height:100%;display:block;object-fit:cover}.app.skinned .daily-card{display:flex;align-items:center;gap:12px;min-height:76px;margin:6px 14px 10px;padding:10px 13px;border:1px solid rgba(236,226,199,.86);border-radius:22px;background:#fffffff2;box-shadow:0 8px 18px #795b1f14}.app.skinned .daily-card .dc-icon{width:52px;height:52px;object-fit:contain;flex:0 0 auto}.app.skinned .daily-card .dc-main{min-width:0;flex:1;display:grid;gap:9px}.app.skinned .daily-card .dc-title{display:block;font-size:22px;line-height:1;font-weight:950;color:#33251e;letter-spacing:0}.app.skinned .daily-card .dc-metrics{display:flex;align-items:center;gap:7px;color:#5f5952;font-size:11px;font-weight:700;white-space:nowrap}.app.skinned .daily-card .dc-metrics b{font-size:16px;line-height:1;font-weight:950}.app.skinned .daily-card .dc-metrics .orange{color:var(--coral-d)}.app.skinned .daily-card .dc-metrics .green{color:var(--green-d)}.app.skinned .daily-card .dc-metrics .blue{color:var(--blue)}.app.skinned .daily-card .dc-metrics .sep{width:1px;height:18px;background:var(--line);flex:0 0 auto}.app.skinned .dc-side{display:flex;align-items:center;gap:6px;flex:0 0 auto}.app.skinned .daily-card .dc-ring{width:54px;height:54px;padding:0;border:0;border-radius:50%;background:conic-gradient(var(--green) 0 var(--daily-pct, 0%),var(--coral) var(--daily-pct, 0%) 34%,#eef0ee 34% 100%);display:grid;place-items:center;cursor:pointer}.app.skinned .daily-card .dc-ring:disabled{cursor:default;opacity:1}.app.skinned .daily-card .dc-ring i{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;background:#fff;color:#2e2924;font-style:normal;font-size:14px;font-weight:950}.app.skinned .daily-card .dc-arrow{border:0;background:transparent;color:#bdc1c6;font-size:32px;line-height:1;padding:0;cursor:pointer}.app.skinned .daily-card .dc-arrow:disabled{cursor:default;opacity:.75}.app.skinned .db-done{color:var(--green-d);font-size:13px;font-weight:950;padding:8px 9px;border-radius:999px;background:#eef9e8}.app.skinned .learn{display:block}.app.skinned .learn-overview{display:block;margin:0;padding:0;background:transparent;border:0;box-shadow:none}.app.skinned .subject-tabs{display:flex;height:50px;margin:0 14px 8px;padding:0;overflow:hidden;border:3px solid #dbe3f1;border-radius:18px;background:linear-gradient(180deg,#f9fcff,#eff6ff);box-shadow:inset 0 0 0 1px #ffffffe6}.app.skinned .subject-tab{position:relative;flex:1;min-width:0;border:0;border-radius:0;background:transparent;color:#767980;font-size:19px;font-weight:950;display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer}.app.skinned .subject-tab img{width:26px;height:26px;object-fit:contain;filter:saturate(.95)}.app.skinned .subject-tab.on{color:#fff;background:linear-gradient(180deg,#ff8749,#ff682b);box-shadow:inset 0 -4px #d1451359,0 5px 14px #ef5b2442}.app.skinned .subject-tab.yw.on{border-radius:14px 18px 18px 14px;clip-path:polygon(0 0,96% 0,100% 100%,0 100%)}.app.skinned .subject-tab.sx.on{border-radius:18px 14px 14px 18px;clip-path:polygon(4% 0,100% 0,100% 100%,0 100%)}.app.skinned .block-stack{display:grid;gap:18px;padding:0}.app.skinned .block{position:relative;overflow:hidden;min-height:676px;margin:0;padding:24px 18px;border:0;border-radius:24px 24px 18px 18px;background:linear-gradient(180deg,#ffffee80,#eeffdc6b),url(/assets/learning-visuals/learning-map-bg-v2.png) center top / cover no-repeat;box-shadow:inset 0 9px #94cb4e47}.app.skinned .block:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(180px 120px at 18% 24%,rgba(255,255,255,.38),transparent 72%),radial-gradient(160px 120px at 86% 36%,rgba(180,225,118,.28),transparent 72%),linear-gradient(180deg,#fff3,#f4ffe54d)}.app.skinned .block-head,.app.skinned .trail,.app.skinned .trail-more{position:relative;z-index:2}.app.skinned .block-head{display:grid;grid-template-columns:minmax(0,1fr) 166px;gap:12px;align-items:start;margin-bottom:18px}.app.skinned .map-title-wrap h2{margin:0;color:#2f231d;font-size:20px;line-height:1.18;font-weight:950;letter-spacing:0}.app.skinned .freq-pill{display:inline-flex;align-items:center;gap:6px;margin:10px 0 7px;padding:5px 10px;border:1.5px solid rgba(79,155,36,.55);border-radius:8px;background:#ffffff8c;color:var(--green-d);font-size:15px;font-weight:950;white-space:nowrap}.app.skinned .freq-pill img{width:16px;height:16px;object-fit:contain}.app.skinned .map-title-wrap p{margin:0;color:#7f755f;font-size:12px;line-height:1.45;font-weight:700}.app.skinned .mastery-card{min-height:98px;padding:12px 13px;border:1.5px solid rgba(149,205,244,.9);border-radius:17px;background:linear-gradient(145deg,#f9fdfff5,#ebf8fff0);box-shadow:0 6px 13px #3969921c}.app.skinned .mastery-title{margin:0 0 8px;color:#23394d;font-size:12px;font-weight:950}.app.skinned .mastery-body{display:flex;align-items:center;gap:9px}.app.skinned .mastery-ring{position:relative;width:56px;height:56px;border-radius:50%;flex:0 0 auto;background:radial-gradient(circle,#fff 0 56%,transparent 57%),conic-gradient(var(--green) 0 var(--mastery-pct, 0%),#dfe8ef var(--mastery-pct, 0%) 100%);display:grid;place-items:center;text-align:center}.app.skinned .mastery-ring:after{content:none}.app.skinned .mastery-ring b{color:#27313c;font-size:17px;line-height:1;font-weight:950;white-space:nowrap;font-variant-numeric:tabular-nums}.app.skinned .mastery-ring span{display:none}.app.skinned .mastery-lines{min-width:0;display:grid;gap:4px;color:#425066;font-size:12px;font-weight:750}.app.skinned .mastery-lines b{color:#1f2c3b;font-weight:950}.app.skinned .mastery-go{margin-left:auto;color:#b7bec8;font-size:28px;line-height:1}.app.skinned .trail{display:grid;gap:0;padding:4px 0 2px}.app.skinned .trail:before{content:none}.app.skinned .trail-sprite{position:absolute;z-index:1;pointer-events:none;opacity:.88}.app.skinned .connector{position:relative;height:38px;z-index:1}.app.skinned .connector svg{position:absolute;left:92px;top:-2px;overflow:visible;transform:scale(.88);transform-origin:left top}.app.skinned .node{position:relative;z-index:2;display:flex;align-items:center;width:100%;min-height:76px;padding:0;border:0;background:transparent;text-align:left;cursor:pointer}.app.skinned .node:disabled{cursor:default}.app.skinned .node-badge-wrap{width:78px;flex:0 0 78px;margin-right:-16px;position:relative;z-index:3;display:grid;place-items:center}.app.skinned .node-badge{width:66px;display:block}.app.skinned .node:not(.done):not(.locked) .node-badge{opacity:0}.app.skinned .node:not(.done):not(.locked) .node-badge-wrap:before{content:"";position:absolute;width:66px;height:66px;border-radius:50%;background:linear-gradient(180deg,#ff9c3e,#ff6824);box-shadow:inset 0 0 0 6px #ffffffeb,0 5px #de5d173d,0 8px 12px #c55b1933}.app.skinned .node:not(.done):not(.locked) .node-badge-wrap:after{content:"";position:absolute;z-index:-1;bottom:2px;width:76px;height:26px;border-radius:999px;background:#fff5e9;box-shadow:0 5px #e05b162e}.app.skinned .node-badge-num{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:25px;line-height:1;font-weight:950;text-shadow:0 2px 3px rgba(118,68,15,.18)}.app.skinned .node-badge-num.done{font-size:28px}.app.skinned .node.current .node-badge-wrap{width:96px;flex-basis:96px;margin-right:-24px}.app.skinned .node.current .node-badge{width:88px;filter:drop-shadow(0 8px 10px rgba(224,95,26,.22))}.app.skinned .node.current .node-badge-wrap:before{width:88px;height:88px;box-shadow:inset 0 0 0 7px #fffffff0,0 7px #de5d173d,0 10px 16px #c55b1938}.app.skinned .node.current .node-badge-wrap:after{width:96px;height:32px;bottom:0}.app.skinned .node.current .node-badge-num{font-size:32px}.app.skinned .node.locked .node-badge{width:62px}.app.skinned .node-card{position:relative;min-width:0;min-height:66px;flex:1;display:flex;align-items:center;gap:8px;padding:12px 14px 12px 30px;border:1.5px solid rgba(164,205,140,.62);border-radius:17px;background:#ffffffdb;box-shadow:0 6px 12px #4061231a}.app.skinned .node.current .node-card{min-height:108px;padding:24px 13px 15px 34px;border:3px solid var(--coral);border-radius:19px;background:linear-gradient(180deg,#fffdf8,#fff3dd);box-shadow:0 9px #ee671d2e,0 12px 20px #ae5c1824}.app.skinned .node.done .node-card{background:#ffffffd6;border-color:#79bb4e8c}.app.skinned .node.locked .node-card{background:#f8f7f8eb;border-color:#cac7d3cc;box-shadow:0 4px 10px #45405614}.app.skinned .node .meta{min-width:0;flex:1}.app.skinned .node .t{color:#262523;font-size:16px;line-height:1.22;font-weight:950;overflow-wrap:anywhere}.app.skinned .node.current .t{font-size:20px;padding-right:58px}.app.skinned .node.locked .t{color:#696b72}.app.skinned .node .s{margin-top:6px;color:#827f7a;font-size:12px;line-height:1.2;font-weight:750}.app.skinned .node.current .s{color:#a97a4a;font-size:12px}.app.skinned .node.locked .s{color:#a7a8ae}.app.skinned .current-tag{position:absolute;top:-2px;right:-2px;padding:5px 12px;border-radius:0 16px 0 14px;background:#fff0d7;color:var(--coral-d);font-size:12px;line-height:1;font-weight:950}.app.skinned .node-cta{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-width:104px;min-height:43px;padding:0 18px;border-radius:999px;color:#fff;background:linear-gradient(180deg,#ff9543,#ff6728);box-shadow:0 5px #e45622,0 7px 12px #e0501847;font-size:16px;font-weight:950;white-space:nowrap}.app.skinned .node:not(.current) .node-cta{min-width:auto;min-height:auto;padding:0;border-radius:0;background:transparent;box-shadow:none;color:#7c9d6a;font-size:28px}.app.skinned .node-lock{flex:0 0 auto;color:var(--violet);font-size:12px;line-height:1.35;font-weight:850;text-align:right;white-space:nowrap}.app.skinned .stars{flex:0 0 auto;color:#ffcf30;font-size:13px;letter-spacing:-1px;text-shadow:0 2px 0 #fff;white-space:nowrap}.app.skinned .trail-more{display:block;width:calc(100% - 30px);min-height:38px;margin:14px auto 0;padding:8px 14px;border:0;border-radius:999px;background:#ffffffb8;box-shadow:none;color:var(--green-d);font-size:13px;font-weight:900}:where(.app.skinned,.flow-shell) .home-test-screen{min-height:100vh;padding:24px 18px;background:radial-gradient(circle at 80% 8%,#fffffff2,#fff0 30%),linear-gradient(180deg,#fff6df,#fffaf0 44%,#fbfff4)}:where(.app.skinned,.flow-shell) .home-test-topbar{display:flex;align-items:center;gap:14px;margin-bottom:18px}:where(.app.skinned,.flow-shell) .home-test-back{width:52px;height:52px;border:1px solid var(--line);border-radius:18px;background:#ffffffe0;color:var(--ink-soft);font-size:34px;font-weight:800;line-height:1;box-shadow:0 8px 18px #504a3c14}:where(.app.skinned,.flow-shell) .home-test-back.placeholder{visibility:hidden}:where(.app.skinned,.flow-shell) .home-test-topbar h1{margin:0;color:var(--ink);font-size:26px;line-height:1.15;font-weight:950;letter-spacing:0}:where(.app.skinned,.flow-shell) .home-test-topbar p{margin:5px 0 0;color:var(--muted);font-size:13px;font-weight:800}:where(.app.skinned,.flow-shell) .home-test-panel{padding:18px;border:1px solid rgba(236,226,199,.86);border-radius:24px;background:#ffffffd6;box-shadow:0 10px 24px #805d2014}:where(.app.skinned,.flow-shell) .home-test-field{display:grid;gap:8px}:where(.app.skinned,.flow-shell) .home-test-field span{color:var(--ink-soft);font-size:14px;font-weight:900}:where(.app.skinned,.flow-shell) .home-test-field input{width:100%;height:58px;padding:0 16px;border:1px solid var(--line);border-radius:18px;background:var(--paper);color:var(--ink);font-size:20px;font-weight:900;outline:none}:where(.app.skinned,.flow-shell) .home-test-field input:focus{border-color:var(--green-path);box-shadow:0 0 0 4px #7fc2422e}:where(.app.skinned,.flow-shell) .home-test-primary{width:100%;min-height:56px;margin-top:18px;border:0;border-radius:999px;background:var(--green);color:#fff;font-size:18px;font-weight:950;box-shadow:0 10px 18px #4b9b242e}:where(.app.skinned,.flow-shell) .home-test-primary:disabled{background:var(--faint);box-shadow:none;cursor:not-allowed}:where(.app.skinned,.flow-shell) .home-test-hint{margin:10px 2px 0;color:var(--muted);font-size:13px;font-weight:800}:where(.app.skinned,.flow-shell) .home-test-subjects{display:grid;gap:14px}:where(.app.skinned,.flow-shell) .home-test-subject{position:relative;min-height:116px;padding:18px;border:1px solid var(--line);border-radius:22px;background:var(--paper);display:flex;align-items:center;gap:16px;color:var(--ink);text-align:left;box-shadow:0 8px 16px #805d2012}:where(.app.skinned,.flow-shell) .test-hub-subjects .home-test-subject:after{content:"›";position:absolute;right:18px;top:18px;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#ffffffb8;color:#b48b42;font-size:25px;font-weight:950;line-height:1}:where(.app.skinned,.flow-shell) .home-test-subject.active,:where(.app.skinned,.flow-shell) .home-test-subject:focus-visible{border-color:var(--green-path);box-shadow:0 0 0 4px #7fc24229}:where(.app.skinned,.flow-shell) .home-test-subject .subject-mark{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;flex:0 0 auto;font-size:30px;font-weight:950}:where(.app.skinned,.flow-shell) .home-test-subject strong{display:block;font-size:24px;font-weight:950;letter-spacing:0}:where(.app.skinned,.flow-shell) .home-test-subject small{display:block;margin-top:6px;color:var(--muted);font-size:13px;font-weight:800;line-height:1.45}:where(.app.skinned,.flow-shell) .test-hub-progress{display:inline-flex;align-items:center;gap:8px;max-width:100%;margin-top:10px;padding:7px 10px;border-radius:999px;background:#ffeeb5b3;color:#7a4d00;font-size:14px;font-style:normal;font-weight:950;line-height:1.2}:where(.app.skinned,.flow-shell) .test-hub-progress i{min-width:0;overflow:hidden;color:var(--ink-soft);font-size:12px;font-style:normal;font-weight:850;text-overflow:ellipsis;white-space:nowrap}:where(.app.skinned,.flow-shell) .test-hub-explain-slot{width:min(760px,100%);margin:18px auto 0;display:flex;justify-content:flex-end}:where(.app.skinned,.flow-shell) .test-hub-explain-btn{min-width:min(100%,284px);min-height:76px;padding:14px 18px;border:1px solid rgba(255,198,95,.78);border-radius:22px;background:linear-gradient(135deg,#fffaebf5,#fff1cbf5),var(--paper);color:var(--ink);text-align:left;box-shadow:0 12px 26px #805d201a}:where(.app.skinned,.flow-shell) .test-hub-explain-btn:after{content:"›";float:right;margin-top:-2px;color:#d56828;font-size:28px;font-weight:950;line-height:1}:where(.app.skinned,.flow-shell) .test-hub-explain-btn span,:where(.app.skinned,.flow-shell) .test-hub-explain-btn small{display:block}:where(.app.skinned,.flow-shell) .test-hub-explain-btn span{color:#d85d26;font-size:18px;line-height:1.2;font-weight:950}:where(.app.skinned,.flow-shell) .test-hub-explain-btn small{margin-top:6px;padding-right:20px;color:var(--ink-soft);font-size:13px;line-height:1.35;font-weight:850}:where(.app.skinned,.flow-shell) .test-hub-explain-btn:focus-visible{outline:none;box-shadow:0 0 0 4px #ff975433,0 12px 26px #805d201a}.test-explain-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:24px;background:#2a221c47;overflow:auto}.test-explain-sheet{width:min(640px,100%);max-height:min(88vh,940px);padding:22px;border:1px solid rgba(232,216,184,.92);border-radius:30px;background:radial-gradient(circle at 92% 0%,#ddf6ce94,#fff0 28%),linear-gradient(180deg,#fffdf7,#fff9ec);box-shadow:0 24px 70px #362c2238;overflow:auto}.test-explain-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.test-explain-head span{color:#2b8a72;font-size:14px;font-weight:950}.test-explain-head h2{margin:4px 0 0;color:#2d2118;font-size:30px;line-height:1.12;font-weight:950;letter-spacing:0}.test-explain-close{width:42px;height:42px;border:1px solid rgba(232,216,184,.9);border-radius:999px;background:#ffffffe0;color:#6b5f55;font-size:28px;line-height:1;font-weight:850}.test-explain-sheet .prep-section{margin-top:14px}.test-explain-chip{display:grid;gap:4px;padding:10px;border:1px solid #eadfc8;border-radius:12px;background:#fffdf8}.test-explain-chip.ok{border-color:#cfe9c1;background:#f7fcf3}.test-explain-chip.fallback{border-color:#ffe1a5;background:#fffaf0}.test-explain-chip span{color:#7e7469;font-size:12px;font-weight:950}.test-explain-chip strong{color:#28705d;font-size:14px;line-height:1.25;font-weight:950}.test-explain-done{width:100%;min-height:52px;margin-top:16px;border:0;border-radius:999px;background:#29aa83;color:#fff;font-size:17px;font-weight:950;box-shadow:0 12px 24px #29aa8333}:where(.app.skinned,.flow-shell) .child-picker-grid{display:grid;gap:14px}:where(.app.skinned,.flow-shell) .child-picker-card{min-height:104px;padding:18px;border:1px solid var(--line);border-radius:22px;background:var(--paper);color:var(--ink);text-align:left;display:grid;grid-template-columns:auto 1fr;grid-template-areas:"icon name" "icon hint";column-gap:14px;align-items:center;box-shadow:0 8px 16px #805d2012}:where(.app.skinned,.flow-shell) .child-picker-card:not(.add){display:block;padding:0;overflow:hidden}:where(.app.skinned,.flow-shell) .child-picker-main{width:100%;min-height:104px;padding:18px;border:0;background:transparent;color:inherit;text-align:left;display:grid;grid-template-columns:auto 1fr;grid-template-areas:"icon name" "icon hint";column-gap:14px;align-items:center}:where(.app.skinned,.flow-shell) .child-picker-card.active,:where(.app.skinned,.flow-shell) .child-picker-card:focus-visible{border-color:var(--green-path);box-shadow:0 0 0 4px #7fc24229}:where(.app.skinned,.flow-shell) .child-picker-card span{grid-area:icon;width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:#68b5321f;font-size:30px;font-weight:950}:where(.app.skinned,.flow-shell) .child-picker-card strong{grid-area:name;font-size:24px;font-weight:950;letter-spacing:0}:where(.app.skinned,.flow-shell) .child-picker-card small{grid-area:hint;color:var(--muted);font-size:13px;font-weight:850}:where(.app.skinned,.flow-shell) .child-picker-card.add span{color:var(--green-d);background:#68b5322e}:where(.app.skinned,.flow-shell) .child-picker-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 18px 16px}:where(.app.skinned,.flow-shell) .child-picker-actions button{min-height:40px;border:1px solid var(--line);border-radius:14px;background:#ffffffc7;color:var(--ink-soft);font-size:13px;font-weight:900}:where(.app.skinned,.flow-shell) .child-picker-actions button.danger{border-color:#ff6b2c59;background:#ff6b2c14;color:var(--coral-d)}.parent-switch-btn{min-height:38px;padding:0 14px}.parent-wide-btn{width:100%;margin-bottom:14px}.app.skinned .bottom-tabs{position:fixed;left:50%;right:auto;bottom:8px;z-index:50;width:calc(100% - 32px);max-width:400px;min-height:82px;transform:translate(-50%);display:grid;grid-template-columns:repeat(4,minmax(0,1fr));align-items:center;gap:8px;padding:10px 12px calc(10px + env(safe-area-inset-bottom));border:1px solid rgba(235,222,190,.82);border-radius:26px;background:#fffffff5;box-shadow:0 -10px 28px #433d341a,0 10px 24px #805d2014;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app.skinned .bottom-tabs button{min-width:0;width:100%;min-height:62px;padding:8px 4px;border:0;border-radius:22px;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:#7f7f86;cursor:pointer;transform:translateY(0);transition:transform .16s ease,background .16s ease,box-shadow .16s ease,color .16s ease}.app.skinned .bottom-tabs button:hover{transform:translateY(-1px)}.app.skinned .bottom-tabs button:active{transform:scale(.97)}.app.skinned .bottom-tabs button:focus-visible{outline:3px solid rgba(78,174,50,.24);outline-offset:2px}.app.skinned .bottom-tabs button.on{background:linear-gradient(180deg,#fff7e9,#fff0d9);box-shadow:inset 0 0 0 1px #ffd697c7,0 8px 18px #ff8f4221;color:var(--coral-d)}.app.skinned .bottom-tabs .tab-icon{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;background:#fff4dc;box-shadow:inset 0 0 0 1px #ffe6bcad;color:var(--coral-d);font-size:24px;line-height:1;font-weight:950;transition:width .16s ease,height .16s ease,border-radius .16s ease,transform .16s ease,background .16s ease}.app.skinned .bottom-tabs img{width:23px;height:23px;object-fit:contain;opacity:.86}.app.skinned .bottom-tabs .tab-icon svg{width:27px;height:27px;display:block}.app.skinned .bottom-tabs .test-tab-icon{background:#e7f7dd;color:var(--green-d);box-shadow:inset 0 0 0 1px #68b53229}.app.skinned .bottom-tabs .prep-tab-icon{background:#fff0d7;color:#e46b1d;box-shadow:inset 0 0 0 1px #ffb75842}.app.skinned .tab-me .tab-icon{border-radius:50%;background:#fff;color:var(--coral-d);box-shadow:inset 0 0 0 3px #fffffff2,0 3px 9px #8b572a1f}.app.skinned .bottom-tabs button.on .tab-icon{width:40px;height:40px;border-radius:14px;transform:translateY(-1px)}.app.skinned .bottom-tabs button.on .tab-icon svg{width:30px;height:30px}.app.skinned .bottom-tabs .tab-test.on .tab-icon{background:#dff5d2;color:var(--green-d)}.app.skinned .bottom-tabs .tab-me.on .tab-icon{width:40px;height:40px;border-radius:50%;background:#fff;color:var(--coral-d)}.app.skinned .bottom-tabs button.tab-me.on .me-tab-icon{width:42px;height:42px}.app.skinned .bottom-tabs .tab-me.on .tab-icon svg{width:36px;height:36px}.app.skinned .bottom-tabs button.on img{opacity:1}.app.skinned .bottom-tabs .bt-txt{color:#7f7f86;font-size:14px;line-height:1;font-weight:900;letter-spacing:0;white-space:nowrap}.app.skinned .bottom-tabs button.on .bt-txt{color:var(--coral-d);font-weight:950}@media (min-width: 721px){.app.skinned.test-hub-shell{width:min(860px,calc(100vw - 64px));max-width:none;min-height:100svh;border-left:1px solid rgba(236,226,199,.52);border-right:1px solid rgba(236,226,199,.52);box-shadow:0 24px 80px #433d341f}.app.skinned.test-hub-shell.has-tabs{padding-bottom:112px}.app.skinned.test-hub-shell .home-test-screen{min-height:calc(100svh - 112px);padding:30px 36px 26px;background:radial-gradient(circle at 18% 0%,#fffffff2,#fff0 30%),radial-gradient(circle at 90% 12%,#ddf6cea8,#fff0 28%),linear-gradient(180deg,#fff8e7,#fffdf3,#fbfff4)}.app.skinned.test-hub-shell .home-test-topbar{margin:0 auto 22px;max-width:760px;align-items:center}.app.skinned.test-hub-shell .home-test-back.placeholder{display:none}.app.skinned.test-hub-shell .home-test-topbar h1{font-size:34px}.app.skinned.test-hub-shell .home-test-topbar p{margin-top:6px;font-size:15px;line-height:1.4}.app.skinned.test-hub-shell .home-test-panel{max-width:760px;margin:0 auto;padding:26px;border-radius:28px;background:#ffffffc7;box-shadow:inset 0 1px #ffffffd1,0 18px 42px #805d201a}.app.skinned.test-hub-shell .test-hub-subjects{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.app.skinned.test-hub-shell .test-hub-subjects .home-test-subject{min-height:292px;padding:24px 22px 22px;display:grid;grid-template-rows:auto 1fr;align-content:start;gap:18px;border-radius:26px;background:linear-gradient(180deg,#ffffffd6,#fffaebf5),var(--paper);box-shadow:0 14px 28px #805d2017}.app.skinned.test-hub-shell .test-hub-subjects .home-test-subject:nth-child(2){background:linear-gradient(180deg,#ffffffdb,#effff7f5),var(--paper)}.app.skinned.test-hub-shell .test-hub-subjects .home-test-subject:hover{transform:translateY(-2px);box-shadow:0 18px 34px #805d2021}.app.skinned.test-hub-shell .home-test-subject .subject-mark{width:78px;height:78px;border-radius:24px;font-size:42px}.app.skinned.test-hub-shell .home-test-subject strong{padding-right:34px;font-size:32px;line-height:1.1}.app.skinned.test-hub-shell .home-test-subject small{margin-top:12px;min-height:48px;font-size:16px;line-height:1.5}.app.skinned.test-hub-shell .test-hub-progress{width:fit-content;max-width:100%;flex-direction:column;align-items:flex-start;justify-content:center;gap:3px;margin-top:20px;padding:10px 12px;border-radius:16px;font-size:17px;white-space:nowrap}.app.skinned.test-hub-shell .test-hub-progress i{font-size:14px;white-space:nowrap}.app.skinned.test-hub-shell .bottom-tabs{bottom:14px;width:min(760px,calc(100vw - 96px));max-width:none;min-height:76px;padding:9px 14px calc(9px + env(safe-area-inset-bottom));border-radius:24px}.app.skinned.test-hub-shell .bottom-tabs button{min-height:58px;border-radius:18px;flex-direction:row;gap:9px}.app.skinned.test-hub-shell .bottom-tabs .tab-icon,.app.skinned.test-hub-shell .bottom-tabs button.on .tab-icon{width:38px;height:38px}.app.skinned.test-hub-shell .bottom-tabs .bt-txt{font-size:17px}}@media (max-width: 390px){.app.skinned .brand-logo{width:120px}.app.skinned .app-header{padding-left:12px;padding-right:12px;gap:5px}.app.skinned .header-stats{gap:5px}.app.skinned .header-stats .stat-pill{min-width:58px;height:39px;padding:0 9px;font-size:12px}.app.skinned .header-stats .fire-pill{min-width:82px}.app.skinned .hero-avatar{width:46px;height:46px;border-width:3px}.app.skinned .daily-card{margin-left:12px;margin-right:12px;gap:9px}.app.skinned .daily-card .dc-icon{width:50px;height:50px}.app.skinned .daily-card .dc-title{font-size:20px}.app.skinned .daily-card .dc-metrics{font-size:10px;gap:5px}.app.skinned .subject-tabs{margin-left:12px;margin-right:12px}.app.skinned .block-head{grid-template-columns:minmax(0,1fr) 150px;gap:8px}.app.skinned .map-title-wrap h2{font-size:18px}.app.skinned .mastery-card{padding:10px}.app.skinned .mastery-lines{font-size:11px}.app.skinned .node.current .t{font-size:18px}.app.skinned .node-cta{min-width:92px;padding:0 14px;font-size:15px}}@media (prefers-reduced-motion: reduce){.app.skinned *,.app.skinned *:before,.app.skinned *:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
