:root{--ink: #1e2a4a;--ink-soft: #5a6785;--paper: #fafbfd;--bg: #eef1f7;--hi: #ffd64d;--hi-soft: #fff3c9;--blue: #3d6bff;--green: #22b573;--green-soft: #e3f7ee;--coral: #ff6b6b;--coral-soft: #ffecec;--radius: 20px;--shadow: 0 2px 10px rgba(30, 42, 74, .08)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}#root{width:100%}body{background:#d9dee9;font-family:Noto Sans TC,sans-serif;color:var(--ink)}#phone{width:100%;max-width:430px;height:100dvh;margin:0 auto;background:var(--bg);display:flex;flex-direction:column;overflow:hidden;position:relative}.screen{flex:1;overflow-y:auto;padding:20px 18px 32px;display:flex;flex-direction:column}h1,h2,.disp{font-family:"Baloo 2",Noto Sans TC,sans-serif}button{font:inherit}.login-screen{align-items:center;justify-content:center;text-align:center;gap:18px;flex:1}.login-logo{font-family:"Baloo 2";font-size:40px;font-weight:800}.login-logo .hl{background:linear-gradient(transparent 55%,var(--hi) 55%)}.login-sub{color:var(--ink-soft);font-size:14px;margin-bottom:12px}.login-error{color:var(--coral);font-size:13px;margin-top:8px}.login-loading{color:var(--ink-soft);font-size:14px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.hello{font-size:15px;color:var(--ink-soft);font-weight:500}.hello b{display:block;font-size:22px;color:var(--ink);font-weight:900;letter-spacing:.5px}.chips{display:flex;gap:8px}.chip{background:var(--paper);border-radius:999px;padding:7px 12px;font-weight:800;font-size:14px;box-shadow:var(--shadow);display:flex;align-items:center;gap:5px}.chip .n{font-family:"Baloo 2";font-size:15px}.goal-card{background:var(--ink);color:#fff;border-radius:var(--radius);padding:18px;display:flex;align-items:center;gap:16px;margin-bottom:22px;box-shadow:0 6px 18px #1e2a4a40}.goal-info{flex:1}.goal-info .eyebrow{font-size:12px;letter-spacing:2px;color:#aab6d8;font-weight:700;margin-bottom:4px}.goal-info h2{font-size:20px;line-height:1.3;font-weight:800}.goal-info p{font-size:13px;color:#aab6d8;margin-top:4px}.ring{position:relative;width:74px;height:74px;flex-shrink:0}.ring svg{transform:rotate(-90deg)}.ring .lbl{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:"Baloo 2";font-weight:800}.ring .lbl .big{font-size:18px;line-height:1}.ring .lbl .sm{font-size:10px;color:#aab6d8;font-weight:600}.cta{display:block;width:100%;margin:-10px 0 24px;padding:15px;background:var(--hi);color:var(--ink);border:none;border-radius:16px;font-family:"Baloo 2",Noto Sans TC;font-size:17px;font-weight:800;cursor:pointer;box-shadow:0 4px #e0b62e;transition:transform .08s}.cta:active{transform:translateY(3px);box-shadow:0 1px #e0b62e}.cta:disabled{opacity:.6;cursor:default}.sec-title{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}.sec-title h2{font-size:18px;font-weight:900}.sec-title span{font-size:12px;color:var(--ink-soft)}.deck{background:var(--paper);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:14px;margin-bottom:12px;box-shadow:var(--shadow);cursor:pointer;border:2px solid transparent;transition:border .15s;width:100%;text-align:left}.deck:active{border-color:var(--hi)}.deck-ring{width:56px;height:56px;position:relative;flex-shrink:0}.deck-ring svg{transform:rotate(-90deg)}.deck-ring .pct{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:"Baloo 2";font-size:13px;font-weight:800}.deck-info{flex:1;min-width:0}.deck-info h3{font-size:16px;font-weight:800;margin-bottom:3px}.deck-info .tags{display:flex;gap:6px;flex-wrap:wrap}.tag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;background:var(--hi-soft);color:#9a7b0a}.tag.b{background:#e7edff;color:var(--blue)}.tag.g{background:var(--green-soft);color:var(--green)}.deck-source{margin-top:6px}.deck-source summary{font-size:11px;color:var(--ink-soft);cursor:pointer;list-style:none}.deck-source summary::-webkit-details-marker{display:none}.deck-source summary:before{content:"ⓘ "}.deck-source p{margin-top:4px;font-size:11px;color:var(--ink-soft);line-height:1.5}.deck-due{text-align:center;flex-shrink:0}.deck-due .n{font-family:"Baloo 2";font-size:20px;font-weight:800;color:var(--blue);line-height:1}.deck-due .t{font-size:10px;color:var(--ink-soft)}.sess-top{display:flex;align-items:center;gap:12px;margin-bottom:18px}.x-btn{background:none;border:none;font-size:22px;color:var(--ink-soft);cursor:pointer;padding:4px}.pbar{flex:1;height:12px;background:#dde2ee;border-radius:99px;overflow:hidden}.pbar>div{height:100%;width:0;background:var(--hi);border-radius:99px;transition:width .4s cubic-bezier(.4,0,.2,1)}.xp-chip{font-family:"Baloo 2";font-weight:800;font-size:14px;color:var(--blue);white-space:nowrap}.mode-tag{align-self:center;font-size:12px;font-weight:800;letter-spacing:2px;color:var(--ink-soft);margin-bottom:14px}.card{background:var(--paper);border-radius:24px;box-shadow:var(--shadow);padding:30px 22px;text-align:center;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;perspective:1000px;position:relative}.word{font-family:Libre Baskerville,Georgia,serif;font-size:38px;font-weight:700;position:relative;display:inline-block;padding:0 6px}.word.hl-swipe:before{content:"";position:absolute;left:0;right:0;bottom:4px;height:45%;background:var(--hi);z-index:-1;border-radius:4px;transform-origin:left;animation:swipe .45s ease-out both}@keyframes swipe{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.kk{font-size:15px;color:var(--ink-soft);font-family:Libre Baskerville;font-style:italic}.pos{font-size:12px;font-weight:700;color:var(--blue);background:#e7edff;border-radius:999px;padding:2px 10px}.zh-big{font-size:24px;font-weight:900;margin-top:4px}.ex{font-size:14px;color:var(--ink-soft);line-height:1.7;margin-top:8px;border-top:1px dashed #d5dae8;padding-top:12px}.ex i{font-family:Libre Baskerville;display:block}.speak{background:#e7edff;border:none;border-radius:50%;width:52px;height:52px;font-size:22px;cursor:pointer;transition:transform .1s;flex-shrink:0}.speak:active{transform:scale(.9)}.speak.big{width:84px;height:84px;font-size:36px;background:var(--ink);box-shadow:0 5px #0e1830}.hint{font-size:13px;color:var(--ink-soft)}.opts{display:flex;flex-direction:column;gap:10px;margin-top:18px}.opt{background:var(--paper);border:2px solid #e2e6f0;border-radius:16px;padding:15px;font-size:16px;font-weight:700;color:var(--ink);cursor:pointer;text-align:left;display:flex;align-items:center;gap:10px;transition:all .12s}.opt .k{font-family:"Baloo 2";font-size:13px;color:var(--ink-soft);background:#eef1f7;border-radius:8px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.opt:active{border-color:var(--blue)}.opt.correct{background:var(--green-soft);border-color:var(--green);color:var(--green)}.opt.wrong{background:var(--coral-soft);border-color:var(--coral);color:var(--coral)}.opt:disabled{cursor:default}.judge{display:flex;gap:12px;margin-top:18px}.judge button{flex:1;padding:16px;border-radius:16px;border:none;font-size:16px;font-weight:800;font-family:Noto Sans TC;cursor:pointer;transition:transform .08s}.judge button:active{transform:translateY(2px)}.j-no{background:var(--coral-soft);color:var(--coral)}.j-yes{background:var(--green);color:#fff;box-shadow:0 4px #17915a}.flip-hint{margin-top:14px;text-align:center;font-size:13px;color:var(--ink-soft)}.spell-row{display:flex;gap:10px;margin-top:18px}.spell-input{flex:1;padding:15px;border-radius:16px;border:2px solid #e2e6f0;font-size:18px;font-family:Libre Baskerville;text-align:center;letter-spacing:2px;outline:none;background:var(--paper)}.spell-input:focus{border-color:var(--blue)}.spell-input.ok{border-color:var(--green);background:var(--green-soft)}.spell-input.no{border-color:var(--coral);background:var(--coral-soft);animation:shake .3s}@keyframes shake{25%{transform:translate(-6px)}75%{transform:translate(6px)}}.spell-go{padding:0 20px;border:none;border-radius:16px;background:var(--ink);color:#fff;font-weight:800;font-size:15px;cursor:pointer}.feedback{margin-top:16px;border-radius:16px;padding:14px 16px;font-size:14px;line-height:1.6;display:none}.feedback.show{display:block;animation:pop .25s ease-out}@keyframes pop{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.feedback.ok{background:var(--green-soft);color:#116a44}.feedback.no{background:var(--coral-soft);color:#b23a3a}.feedback b{font-size:16px}.next-btn{display:none;width:100%;margin-top:14px;padding:15px;border:none;border-radius:16px;background:var(--ink);color:#fff;font-size:16px;font-weight:800;font-family:Noto Sans TC;cursor:pointer;box-shadow:0 4px #0e1830}.next-btn:active{transform:translateY(3px);box-shadow:0 1px #0e1830}.next-btn.show{display:block}.result{align-items:center;text-align:center}.trophy{font-size:64px;margin:24px 0 6px;animation:bounceIn .6s cubic-bezier(.34,1.56,.64,1)}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}.result h1{font-size:26px;font-weight:900;margin-bottom:4px}.result .sub{color:var(--ink-soft);font-size:14px;margin-bottom:22px}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;margin-bottom:20px}.stat{background:var(--paper);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.stat .n{font-family:"Baloo 2";font-size:28px;font-weight:800;line-height:1.1}.stat .t{font-size:12px;color:var(--ink-soft);font-weight:700;margin-top:2px}.stat .n.blue{color:var(--blue)}.stat .n.green{color:var(--green)}.stat .n.fire{color:#f5822a}.streak-note{width:100%;background:var(--hi-soft);border-radius:16px;padding:12px 16px;font-size:14px;font-weight:700;color:#8a6d06;margin-bottom:20px}.word-review{width:100%;text-align:left}.word-review h3{font-size:15px;font-weight:900;margin-bottom:10px}.wr-item{background:var(--paper);border-radius:14px;padding:11px 14px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow);font-size:14px}.wr-item .w{font-family:Libre Baskerville;font-weight:700;font-size:16px}.wr-item .m{font-size:12px;font-weight:800}.wr-item .m.up{color:var(--green)}.wr-item .m.down{color:var(--coral)}.home-btn{width:100%;margin-top:16px;padding:16px;border:none;border-radius:16px;background:var(--hi);color:var(--ink);font-size:17px;font-weight:800;font-family:"Baloo 2",Noto Sans TC;cursor:pointer;box-shadow:0 4px #e0b62e}.home-btn:active{transform:translateY(3px);box-shadow:0 1px #e0b62e}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
