:root{--bg-light: #c8f04a;--bg-mid: #9ed838;--bg-deep: #6fb91c;--hill: #5fa315;--tile-bg: #fff;--tile-shadow: rgba(0,0,0,.18);--top-pill-bg: rgba(0,0,0,.55);--btn-yellow: #ffd24a;--btn-yellow-dk: #cb8e0e;--btn-blue: #57b6ff;--btn-blue-dk: #2b88d6;--btn-pink: #ff8fb6;--btn-pink-dk: #cf5a85;--combo-red: #e3344a;--combo-stroke: #fff;--text-dark: #1f1f1f;--text-mid: #555;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;overflow:hidden;font-family:Nunito,Noto Sans SC,PingFang SC,HarmonyOS Sans SC,Microsoft YaHei,Helvetica Neue,system-ui,sans-serif;font-weight:700;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;color:var(--text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3{font-family:Nunito,Noto Sans SC,sans-serif;font-weight:900}.rainbow-text{background:linear-gradient(90deg,#ff5e9b,#ff9a3a,#ffd24a,#6fc6ff,#b076ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 3px 0 rgba(0,0,0,.15));font-weight:700}.candy-text{background:linear-gradient(180deg,#ff6f8d,#d8395d);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}.sky-text{background:linear-gradient(180deg,#6fc6ff,#2b88d6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}.sunny-text{background:linear-gradient(180deg,#ffe27a,#ff8c42);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}body{background:var(--bg-mid)}.app{position:relative;width:100%;height:100%;overflow:hidden;background:radial-gradient(ellipse 130% 70% at 50% 110%,var(--hill) 0%,var(--hill) 35%,transparent 36%),radial-gradient(ellipse 60% 30% at 50% 100%,rgba(95,163,21,.6) 0%,transparent 70%),linear-gradient(180deg,var(--bg-light) 0%,var(--bg-mid) 40%,var(--bg-mid) 75%,var(--bg-deep) 100%)}.dot{position:absolute;pointer-events:none;-webkit-user-select:none;user-select:none}.dot-flower{font-size:14px;opacity:.8}.dot-grass{color:#285a1480;font-size:14px}.topbar{position:absolute;top:0;left:0;right:0;padding:calc(12px + var(--safe-top)) 12px 0;display:flex;align-items:center;gap:8px;z-index:6}.pause-btn{width:40px;height:40px;background:var(--btn-yellow);color:#5c3700;border:2.5px solid #fff;border-radius:10px;font-size:18px;font-weight:900;box-shadow:0 4px 0 var(--btn-yellow-dk);cursor:pointer;display:flex;align-items:center;justify-content:center}.pause-btn:active{transform:translateY(2px);box-shadow:0 2px 0 var(--btn-yellow-dk)}.coin-pill{background:var(--top-pill-bg);color:#fff;border:2.5px solid #fff;border-radius:18px;padding:4px 10px 4px 6px;display:flex;align-items:center;gap:6px;font-size:13px;font-weight:800}.coin-emoji{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;background:radial-gradient(circle at 30% 30%,#ffed7a,#f5b40a);border-radius:50%;border:1.5px solid #c98300}.task-pill{background:#00000080;color:#fff;border:2px solid #fff;border-radius:16px;padding:5px 12px 5px 28px;font-size:12px;font-weight:700;position:relative;transform:rotate(-2deg)}.task-pill:before{content:"🐼";position:absolute;left:4px;top:50%;transform:translateY(-50%);font-size:16px}.spacer{flex:1}.rank-bubble{position:absolute;top:calc(64px + var(--safe-top));right:10px;z-index:4;display:flex;flex-direction:column;align-items:flex-end;pointer-events:none}.rank-bubble .badge{background:linear-gradient(180deg,#ff6f8d,#d8395d);color:#fff;font-size:10px;font-weight:800;padding:2px 8px;border-radius:8px;border:2px solid #fff;box-shadow:0 2px #0003;white-space:nowrap}.rank-bubble .row{background:#fff;border-radius:14px;margin-top:4px;padding:3px 8px 3px 26px;font-size:11px;font-weight:800;color:#d8395d;position:relative;border:2px solid #ffb1c1;box-shadow:0 2px #0000001a}.rank-bubble .row:before{content:"🐼";position:absolute;left:4px;top:50%;transform:translateY(-50%);font-size:16px}.combo-side{position:absolute;top:110px;left:8px;z-index:6;font-family:Nunito,Noto Sans SC,sans-serif;font-weight:800;font-size:30px;color:var(--combo-red);-webkit-text-stroke:2px var(--combo-stroke);text-shadow:0 4px 0 rgba(0,0,0,.18);letter-spacing:2px;pointer-events:none;animation:combo-pop .4s cubic-bezier(.18,.89,.32,1.28)}.combo-side .x{font-size:18px;margin-right:2px;vertical-align:4px}.combo-side .n{font-size:36px}@keyframes combo-pop{0%{transform:scale(.4) rotate(-10deg);opacity:0}60%{transform:scale(1.25) rotate(2deg);opacity:1}to{transform:scale(1) rotate(0)}}.board{position:absolute;top:90px;bottom:200px;left:0;right:0;display:flex;align-items:center;justify-content:center}.board-inner{position:relative}.tile{position:absolute;width:56px;height:56px;background:var(--tile-bg);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:36px;line-height:1;box-shadow:0 3px #00000026,0 6px 12px #0000002e,inset 0 -3px #0000000f;transition:transform .15s ease,filter .2s ease,opacity .25s ease;cursor:pointer;overflow:hidden}.tile:after{content:"";position:absolute;top:4px;left:6px;right:6px;height:35%;background:linear-gradient(180deg,rgba(255,255,255,.7),transparent);border-radius:10px 10px 30px 30px;pointer-events:none}.tile.covered{filter:brightness(.55) saturate(.7);cursor:not-allowed;pointer-events:none}.tile.active:active{transform:scale(.88) translateY(2px)!important}.tile.exit{animation:tile-vanish .3s forwards}@keyframes tile-vanish{to{transform:scale(.3) rotate(20deg);opacity:0}}.tray-wrap{position:absolute;left:8px;right:8px;bottom:calc(92px + var(--safe-bottom));z-index:4}.tray{background:repeating-linear-gradient(90deg,#a06a3c 0,#a06a3c 18px,#8e5a32 18px,#8e5a32 20px);border:4px solid #5c3514;border-radius:14px;padding:8px;display:flex;gap:6px;min-height:70px;box-shadow:inset 0 2px #ffffff2e,0 4px 14px #00000038;position:relative}.slot{flex:1;aspect-ratio:1 / 1;max-width:56px;background:#fff5cc;border:2px solid #d99c44;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:26px;line-height:1;box-shadow:inset 0 2px 4px #0003}.slot.empty{background:#fff5cc52;border-style:dashed}.slot.fresh{animation:pop-in .25s cubic-bezier(.18,.89,.32,1.28)}@keyframes pop-in{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.18)}to{transform:scale(1)}}.tray-warn{outline:4px solid #ff4d4d;animation:shake .4s}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.tools{position:absolute;left:8px;right:8px;bottom:calc(14px + var(--safe-bottom));display:flex;gap:12px;z-index:5}.tool-btn{flex:1;height:78px;border:4px solid #fff;border-radius:22px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-family:Nunito,Noto Sans SC,sans-serif;font-size:16px;font-weight:700;position:relative;overflow:visible;transition:transform .15s ease;animation:tool-idle 3.5s ease-in-out infinite}.tool-btn:nth-child(2){animation-delay:-1.2s}.tool-btn:nth-child(3){animation-delay:-2.4s}@keyframes tool-idle{0%,to{transform:translateY(0) rotate(var(--tilt, 0deg))}50%{transform:translateY(-3px) rotate(calc(var(--tilt, 0deg) + 1deg))}}.tool-btn:active{transform:translateY(3px) rotate(0) scale(.96)!important;animation:none}.tool-btn:disabled{opacity:.5;cursor:not-allowed;animation:none}.tool-pink{--tilt: -4deg;background:linear-gradient(180deg,#ffb6d0,#ff7aa8);color:#5e1a32;box-shadow:0 6px #c54a78,0 10px 16px #ff7aa859}.tool-blue{--tilt: 3deg;background:linear-gradient(180deg,#b6e4ff,#6fc6ff);color:#073052;box-shadow:0 6px #2b88d6,0 10px 16px #56b6ff59}.tool-purple{--tilt: -3deg;background:linear-gradient(180deg,#d9c1ff,#b076ff);color:#2a0c5a;box-shadow:0 6px #6a3fc1,0 10px 16px #b076ff59}.tool-mascot-wrap{position:relative;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;line-height:1}.tool-mascot{font-size:30px;line-height:1;filter:drop-shadow(0 2px 0 rgba(0,0,0,.18))}.tool-action{position:absolute;bottom:-4px;right:-6px;width:22px;height:22px;background:#fff;border-radius:50%;font-size:13px;display:flex;align-items:center;justify-content:center;border:2px solid currentColor;box-shadow:0 2px #00000026}.tool-label{font-size:14px;letter-spacing:1px;margin-top:-2px;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tool-badge{position:absolute;top:-8px;right:-8px;background:#fff;color:#e3344a;font-family:Nunito,sans-serif;font-size:12px;font-weight:700;border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:3px solid #e3344a;box-shadow:0 3px #0003;animation:badge-pop 2.5s ease-in-out infinite}@keyframes badge-pop{0%,90%,to{transform:scale(1)}95%{transform:scale(1.18)}}.combo-pop{position:fixed;top:36%;left:50%;transform:translate(-50%,-50%);z-index:80;pointer-events:none;font-family:Nunito,sans-serif;font-weight:700;font-size:56px;background:linear-gradient(180deg,#ffd24a,#ff7a00 60%,#d8395d);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;-webkit-text-stroke:3px #fff;filter:drop-shadow(0 6px 0 rgba(0,0,0,.2));letter-spacing:2px;text-align:center;animation:combo-fly .9s cubic-bezier(.18,.89,.32,1.28) forwards}.combo-pop .plus{display:block;font-size:22px;margin-top:4px;color:#ffd24a;-webkit-text-stroke:2px #6a4500}@keyframes combo-fly{0%{transform:translate(-50%,-50%) scale(.4);opacity:0}35%{transform:translate(-50%,-50%) scale(1.25);opacity:1}60%{transform:translate(-50%,-50%) scale(1)}to{transform:translate(-50%,-90%) scale(.9);opacity:0}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:fade-in .18s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.card{width:100%;max-width:360px;background:#fffdf5;border-radius:22px;overflow:hidden;box-shadow:0 20px 60px #0006;animation:card-pop .28s cubic-bezier(.18,.89,.32,1.28);max-height:92vh;display:flex;flex-direction:column}@keyframes card-pop{0%{transform:scale(.72);opacity:0}to{transform:scale(1);opacity:1}}.card-header{background:linear-gradient(180deg,#ffe27a,#ffd24a);padding:16px 20px 12px;text-align:center;border-bottom:4px solid #e8b51c;position:relative}.card-header:before,.card-header:after{content:"✨";position:absolute;top:14px;font-size:18px;opacity:.7}.card-header:before{left:16px}.card-header:after{right:16px}.card-emoji{font-size:78px;line-height:1;filter:drop-shadow(0 4px 0 rgba(0,0,0,.12))}.card-en{font-family:Nunito,sans-serif;margin:6px 0 2px;font-size:34px;font-weight:700;background:linear-gradient(180deg,#ff8c42,#d8395d);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 0 rgba(255,255,255,.6));letter-spacing:.5px}.card-zh{font-family:Noto Sans SC,sans-serif;font-size:18px;color:#5e3e00;letter-spacing:2px}.card-body{padding:14px 18px 4px;overflow-y:auto}.ipa-row{display:flex;align-items:center;gap:10px;background:#fff7df;border:2px solid #ffe082;border-radius:12px;padding:7px 10px;margin-bottom:7px}.ipa-flag{display:inline-flex;width:28px;height:18px;border-radius:4px;font-size:10px;font-weight:800;color:#fff;align-items:center;justify-content:center;flex-shrink:0}.flag-uk{background:linear-gradient(135deg,#012169,#c8102e)}.flag-us{background:linear-gradient(135deg,#002868,#bf0a30)}.flag-cn{background:linear-gradient(135deg,#de2910,#ffde00);color:#fff!important;font-size:12px!important}.card-pinyin{font-family:Nunito,Noto Sans SC,sans-serif;font-size:18px;color:#b56500;letter-spacing:2px;margin-top:4px;font-style:italic;font-weight:800}.bi-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.bi-speak{background:#57b6ff;color:#fff;border:2px solid #fff;width:28px;height:28px;border-radius:9px;font-size:12px;cursor:pointer;box-shadow:0 2px #2b88d6;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.bi-speak:active{transform:translateY(1px);box-shadow:0 1px #2b88d6}.ipa-text{font-family:Lucida Sans Unicode,Segoe UI,sans-serif;font-style:italic;color:#444;flex:1;font-size:14px}.speak-btn{background:var(--btn-blue);color:#fff;border:2px solid #fff;width:36px;height:36px;border-radius:11px;font-size:15px;cursor:pointer;box-shadow:0 3px 0 var(--btn-blue-dk);flex-shrink:0}.speak-btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--btn-blue-dk)}.speak-btn.playing{animation:pulse .6s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 3px 0 var(--btn-blue-dk),0 0 #56b6ff80}50%{box-shadow:0 3px 0 var(--btn-blue-dk),0 0 0 8px #56b6ff00}}.expand-toggle{margin-top:10px;width:100%;height:40px;background:#fff;color:var(--btn-blue-dk);border:2.5px dashed var(--btn-blue);border-radius:12px;font-size:13px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}.expand-panel{margin-top:10px;background:linear-gradient(180deg,#fff8e5,#fff);border:2px solid #ffe082;border-radius:14px;padding:12px;animation:slide-down .3s ease}@keyframes slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.bi-block{margin-bottom:10px}.bi-block:last-child{margin-bottom:0}.bi-title{font-size:11px;font-weight:800;color:#b56500;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}.bi-en{font-size:13px;line-height:1.45;color:var(--text-dark);font-weight:600}.bi-zh{font-size:12.5px;line-height:1.45;color:var(--text-mid);margin-top:2px}.bi-block.example .bi-en{font-style:italic;color:#2c4f7b;padding-left:9px;border-left:3px solid var(--btn-blue)}.bi-block.example .bi-zh{padding-left:9px;border-left:3px solid rgba(86,182,255,.4)}.card-close{margin:12px 18px 16px;height:48px;background:var(--btn-yellow);color:#5b3a00;border:3px solid #fff;border-radius:14px;font-size:15px;font-weight:900;cursor:pointer;box-shadow:0 5px 0 var(--btn-yellow-dk)}.card-close:active{transform:translateY(2px);box-shadow:0 2px 0 var(--btn-yellow-dk)}.modal{width:min(82vw,320px);background:#fffdf5;border-radius:22px;padding:28px 24px;text-align:center;box-shadow:0 20px 60px #0006;animation:card-pop .28s cubic-bezier(.18,.89,.32,1.28)}.modal h2{margin:0 0 8px;font-family:Nunito,Noto Sans SC,sans-serif;font-size:28px;background:linear-gradient(180deg,#ff8c42,#d8395d);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:2px}.modal p{color:#666;margin:0 0 22px;font-size:14px}.modal .primary{background:var(--btn-blue);color:#fff;border:3px solid #fff;border-radius:12px;padding:12px 28px;font-size:15px;font-weight:900;cursor:pointer;box-shadow:0 5px 0 var(--btn-blue-dk)}.modal .primary:active{transform:translateY(2px);box-shadow:0 2px 0 var(--btn-blue-dk)}.home{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 130% 70% at 50% 110%,var(--hill) 0%,var(--hill) 35%,transparent 36%),linear-gradient(180deg,#ffd9e8 0%,#ffb8d4 40%,#c8f04a 70%,var(--bg-mid) 100%);overflow:hidden}.home-top{position:absolute;top:calc(12px + var(--safe-top));left:12px;right:12px;display:flex;align-items:center;justify-content:space-between;z-index:5}.streak-pill{background:linear-gradient(180deg,#ff6f8d,#d8395d);color:#fff;border:2.5px solid #fff;border-radius:18px;padding:6px 12px;font-size:13px;font-weight:800;box-shadow:0 3px #0003}.side-rail{position:absolute;top:70px;left:8px;display:flex;flex-direction:column;gap:8px;z-index:5}.rail-btn{width:60px;min-height:60px;background:#fff;border:2.5px solid #ffb1c1;border-radius:14px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:10px;font-weight:800;color:#d8395d;box-shadow:0 3px #d8395d40}.rail-btn:active{transform:translateY(2px);box-shadow:0 1px #d8395d40}.rail-icon{font-size:22px;line-height:1}.rail-label{letter-spacing:.5px}.stage{position:absolute;top:80px;left:80px;right:12px;bottom:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:4}.title-en{font-family:Nunito,sans-serif;font-size:36px;font-weight:700;background:linear-gradient(90deg,#ff5e9b,#ff9a3a 30%,#ffd24a 50%,#6fc6ff,#b076ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 3px 0 rgba(0,0,0,.18));letter-spacing:1px}.title-zh{font-family:Noto Sans SC,sans-serif;margin-top:0;font-size:18px;background:linear-gradient(180deg,#d8395d,#834050);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:6px}.mascot{font-size:130px;line-height:1;margin-top:8px;filter:drop-shadow(0 8px 0 rgba(0,0,0,.12));animation:hover 3s ease-in-out infinite}@keyframes hover{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.mascot-shadow{margin-top:4px;width:110px;height:14px;background:radial-gradient(ellipse,rgba(0,0,0,.25),transparent 70%);animation:shadow-pulse 3s ease-in-out infinite}@keyframes shadow-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(.85);opacity:.7}}.speech-bubble{margin-top:12px;background:#fff;border:2.5px solid #ffb1c1;border-radius:18px;padding:8px 14px;font-size:13px;font-weight:700;color:#d8395d;position:relative;box-shadow:0 3px #d8395d33}.speech-bubble:after{content:"";position:absolute;top:-10px;left:30px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:10px solid #ffb1c1}.home-bottom{position:absolute;left:12px;right:12px;bottom:calc(16px + var(--safe-bottom));z-index:5}.stat-strip{display:flex;background:#ffffffeb;border:2.5px solid #fff;border-radius:14px;padding:8px;margin-bottom:12px;box-shadow:0 4px #00000014}.stat{flex:1;text-align:center}.stat+.stat{border-left:1px dashed rgba(216,57,93,.3)}.stat-n{font-family:Nunito,sans-serif;font-size:22px;font-weight:700;background:linear-gradient(180deg,#ff8c42,#d8395d);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.1}.stat-l{font-family:Noto Sans SC,sans-serif;font-size:12px;color:#888;margin-top:2px;letter-spacing:1px}.play-btn{width:100%;height:66px;background:linear-gradient(180deg,#6fc6ff,#2b88d6);color:#fff;border:4px solid #fff;border-radius:22px;font-family:Nunito,Noto Sans SC,sans-serif;font-size:26px;font-weight:800;letter-spacing:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 6px #1a5e9c,0 10px 18px #0003;margin-bottom:10px;text-shadow:0 2px 0 rgba(0,0,0,.25);position:relative;overflow:hidden}.play-btn:after{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.35),transparent);border-radius:18px 18px 0 0;pointer-events:none}.play-btn:active{transform:translateY(3px);box-shadow:0 3px #1a5e9c}.bottom-grid{display:flex;gap:10px}.grid-btn{flex:1;height:52px;background:#ffd24a;color:#5c3700;border:3px solid #fff;border-radius:14px;font-size:13px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;box-shadow:0 4px #cb8e0e}.grid-btn:active{transform:translateY(2px);box-shadow:0 2px #cb8e0e}.grid-icon{font-size:20px}.sub-screen{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#fff7e0,#fff);display:flex;flex-direction:column;overflow:hidden}.sub-top{display:flex;align-items:center;gap:10px;padding:calc(14px + var(--safe-top)) 12px 10px;background:linear-gradient(180deg,#ffd24a,#ffc44a);border-bottom:4px solid #e8b51c;flex-shrink:0}.back-btn{width:36px;height:36px;background:#fff;color:#5c3700;border:2px solid #fff;border-radius:10px;font-size:22px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 3px #00000026;line-height:1}.back-btn:active{transform:translateY(2px)}.sub-title{flex:1;font-family:Noto Sans SC,sans-serif;font-size:22px;font-weight:800;background:linear-gradient(180deg,#ff5e9b,#d8395d);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 0 rgba(255,255,255,.6));text-align:center;margin-right:36px;letter-spacing:2px}.sub-subtitle{position:absolute;right:16px;top:18px;background:#0000002e;color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:10px}.cat-tabs{display:flex;gap:6px;padding:10px 12px;overflow-x:auto;flex-shrink:0;background:#fff8e5;border-bottom:1px solid #ffe082}.cat-tabs::-webkit-scrollbar{display:none}.cat-tab{flex-shrink:0;background:#fff;border:2px solid #ffe082;color:#b56500;border-radius:16px;padding:6px 14px;font-size:12px;font-weight:800;cursor:pointer}.cat-tab.on{background:#ff8c42;color:#fff;border-color:#ff8c42}.word-list{flex:1;overflow-y:auto;padding:10px 12px}.word-row{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:#fff;border:2px solid #ffe082;border-radius:12px;margin-bottom:8px;cursor:pointer;font:inherit;text-align:left}.word-row.locked{opacity:.55;background:#f5f5f5;border-color:#ddd;cursor:not-allowed}.word-row:not(.locked):active{transform:scale(.98)}.wr-emoji{font-size:32px;line-height:1;flex-shrink:0}.wr-text{flex:1;min-width:0}.wr-en{font-size:16px;font-weight:800;color:#2b2b2b}.wr-zh{font-size:12px;color:#666;margin-top:2px}.wr-stat{font-size:14px;color:#ff9a3a;display:flex;align-items:center;gap:4px}.wr-x{font-size:11px;color:#999}.daily-banner{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#ff8fb6,#d8395d);color:#fff;margin:14px 14px 0;padding:14px;border-radius:16px;box-shadow:0 4px 12px #d8395d4d}.db-emoji{font-size:40px;line-height:1}.db-title{font-size:16px;font-weight:900}.db-sub{font-size:12px;opacity:.9;margin-top:2px}.daily-grid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:14px}.daily-grid>:nth-child(7){grid-column:1 / -1;background:linear-gradient(180deg,#fff3a0,#ffd24a)!important;border-color:#e8b51c!important}.daily-cell{background:#fff;border:2px dashed #ffd24a;border-radius:14px;padding:10px 6px;text-align:center;position:relative}.daily-cell.today{border-style:solid;background:#fff8e5;border-color:#ff8c42;animation:today-pulse 1.5s ease-in-out infinite}@keyframes today-pulse{0%,to{box-shadow:0 0 #ff8c4266}50%{box-shadow:0 0 0 6px #ff8c4200}}.daily-cell.got{background:linear-gradient(180deg,#c8e6a0,#a3d36a);border-color:#6fb91c;border-style:solid}.dc-day{font-size:11px;color:#888;font-weight:700}.dc-emoji{font-size:28px;line-height:1;margin:4px 0 2px}.dc-amount{font-size:11px;font-weight:800;color:#5c3700}.dc-check{position:absolute;top:-8px;right:-8px;background:#6fb91c;color:#fff;width:22px;height:22px;border-radius:50%;font-size:12px;font-weight:900;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.daily-btn{margin:0 14px calc(14px + var(--safe-bottom));height:56px;background:linear-gradient(180deg,#ff8fb6,#d8395d);color:#fff;border:3px solid #fff;border-radius:16px;font-size:16px;font-weight:900;cursor:pointer;box-shadow:0 5px #a01f3e}.daily-btn.done{background:#ccc;box-shadow:0 5px #999;cursor:not-allowed}.set-list{flex:1;overflow-y:auto;padding:10px 14px calc(20px + var(--safe-bottom))}.set-group{font-size:11px;font-weight:800;color:#b56500;letter-spacing:1px;text-transform:uppercase;margin:16px 4px 6px}.set-group:first-child{margin-top:4px}.set-row{width:100%;display:flex;align-items:center;justify-content:space-between;background:#fff;border:2px solid #ffe082;border-radius:12px;padding:12px 14px;margin-bottom:8px;font-size:14px;font-weight:700;color:#2b2b2b;cursor:pointer}.set-row.danger{color:#d8395d;border-color:#ffb1c1}.set-info{background:#fff8e5;border:2px solid #ffe082;border-radius:12px;padding:12px 14px;font-size:12px;color:#555;line-height:1.7}.set-info b{color:#b56500}.set-note{margin-top:8px;padding-top:8px;border-top:1px dashed #ffd24a;color:#b56500;font-size:11px}.toggle{width:48px;height:26px;background:#ccc;border:none;border-radius:13px;position:relative;cursor:pointer;transition:background .2s}.toggle.on{background:#6fb91c}.toggle .knob{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 2px 4px #0003}.toggle.on .knob{transform:translate(22px)}.seg{display:flex;gap:4px}.seg-btn{background:#fff;border:2px solid #ffe082;color:#b56500;border-radius:10px;padding:5px 10px;font-size:12px;font-weight:700;cursor:pointer}.seg-btn.on{background:#ff8c42;color:#fff;border-color:#ff8c42}.track-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.track-card{background:#fff;border:2.5px solid #ffe082;color:#b56500;border-radius:12px;padding:10px 8px;font-family:Nunito,Noto Sans SC,sans-serif;font-size:13px;font-weight:800;cursor:pointer;text-align:center;letter-spacing:.5px;transition:transform .1s ease}.track-card:active{transform:scale(.96)}.track-card.on{background:linear-gradient(180deg,#ffd24a,#ff8c42);color:#fff;border-color:#ff8c42;box-shadow:0 3px #cb8e0e}.rank-list{flex:1;overflow-y:auto;padding:14px}.rank-row{display:flex;align-items:center;gap:12px;background:#fff;border:2px solid #ffe082;border-radius:12px;padding:10px 14px;margin-bottom:8px;font-weight:700}.rank-row.me{background:linear-gradient(135deg,#fff3a0,#ffd24a);border-color:#ff8c42;border-width:3px}.rank-no{width:40px;text-align:center;font-size:18px;font-weight:900;color:#b56500}.rank-no.rank-1,.rank-no.rank-2,.rank-no.rank-3{font-size:26px}.rank-name{flex:1;font-size:14px}.rank-words{color:#d8395d;font-size:13px}.rank-note{text-align:center;color:#999;font-size:11px;padding:8px 14px calc(14px + var(--safe-bottom))}.about-body{flex:1;overflow-y:auto;padding:18px 18px calc(20px + var(--safe-bottom))}.about-hero{text-align:center;padding:12px 0 20px}.about-mascot{font-size:90px;line-height:1;filter:drop-shadow(0 6px 0 rgba(0,0,0,.1));animation:hover 3s ease-in-out infinite}.about-hero h2{margin:8px 0 4px;font-size:22px}.about-hero p{color:#666;font-size:13px;margin:0}.about-block{background:#fff;border:2px solid #ffe082;border-radius:14px;padding:14px;margin-bottom:12px}.ab-title{font-size:14px;font-weight:900;color:#b56500;margin-bottom:6px}.about-block p{margin:0;font-size:13px;color:#555;line-height:1.6}.about-block ul{margin:4px 0 0;padding-left:20px;font-size:13px;color:#555;line-height:1.8}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#000000d9;color:#fff;padding:10px 18px;border-radius:22px;font-size:13px;font-weight:700;z-index:200;animation:toast-in .25s ease,toast-out .3s ease 1.9s forwards;box-shadow:0 6px 18px #0000004d}@keyframes toast-in{0%{transform:translate(-50%,20px);opacity:0}to{transform:translate(-50%);opacity:1}}@keyframes toast-out{0%{opacity:1}to{opacity:0;transform:translate(-50%,-10px)}}.music-toggle{position:fixed;top:calc(8px + var(--safe-top));left:50%;transform:translate(-50%);z-index:9999;width:56px;height:56px;border-radius:50%;border:4px solid #fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:28px;transition:transform .18s ease;box-shadow:0 6px #0003,0 9px 18px #00000040}.music-toggle:active{transform:translate(-50%) scale(.92) translateY(2px)!important}.music-toggle.on{background:linear-gradient(180deg,#ff8fb6,#d8395d);color:#fff}.music-toggle.off{background:linear-gradient(180deg,#ddd,#999);color:#fff}.music-toggle .mt-icon{line-height:1;filter:drop-shadow(0 1px 0 rgba(0,0,0,.25))}.music-toggle .mt-bars{position:absolute;bottom:-3px;right:-3px;width:20px;height:20px;background:#fff;border:2px solid currentColor;border-radius:50%;display:flex;align-items:center;justify-content:center;gap:2px;padding:4px 3px;box-sizing:border-box}.music-toggle .mt-bars span{width:2px;height:6px;background:currentColor;border-radius:1px}.music-toggle.on .mt-bars span{animation:mt-bar .9s ease-in-out infinite}.music-toggle.on .mt-bars span:nth-child(2){animation-delay:.15s}.music-toggle.on .mt-bars span:nth-child(3){animation-delay:.3s}@keyframes mt-bar{0%,to{height:4px}50%{height:9px}}.music-toggle.pulse:before{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:3px solid #d8395d;opacity:0;animation:mt-pulse 1.4s ease-out 3}@keyframes mt-pulse{0%{opacity:.8;transform:scale(.95)}to{opacity:0;transform:scale(1.35)}}@media (min-width: 700px){.app{max-width:430px;margin:0 auto;border-left:1px solid rgba(0,0,0,.08);border-right:1px solid rgba(0,0,0,.08);box-shadow:0 0 40px #0000001f}}
