@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Noto+Sans+HK:wght@400;500;700;900&display=swap";.app-container{background-color:var(--bg-color);flex-direction:column;min-height:100vh;display:flex;overflow:hidden}.loading-screen{height:100vh;color:var(--text-color);justify-content:center;align-items:center;font-size:1.1rem;display:flex}.auth-page{background:var(--bg-color);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.top-navbar{z-index:1000;background:var(--card-bg);border-bottom:1px solid var(--border-color);box-sizing:border-box;justify-content:space-between;align-items:center;width:100%;height:64px;padding:0 20px;display:flex;position:fixed;top:0;left:0}.nav-logo{color:var(--text-color);align-items:center;gap:8px;font-size:1.25rem;font-weight:700;display:flex}.navbar-right{align-items:center;gap:12px;display:flex}.theme-btn{color:var(--text-color);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;display:flex}.theme-btn:hover{background:var(--bg-color)}.volume-control-container{position:relative}.volume-overlay{z-index:1000;background:0 0;width:100vw;height:100vh;position:fixed;top:0;left:0}.volume-panel{background:var(--card-bg);border:1px solid var(--border-color);z-index:1001;border-radius:16px;flex-direction:column;align-items:center;gap:8px;min-width:140px;padding:16px 12px;display:flex;position:absolute;top:55px;right:0;box-shadow:0 10px 30px #00000026}.account-dropdown-container{position:relative}.account-btn{border:1px solid var(--border-color);cursor:pointer;color:var(--text-color);background:0 0;border-radius:30px;align-items:center;gap:8px;padding:5px 12px 5px 6px;display:flex}.avatar-circle{background:var(--primary-color);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.dropdown-menu{background:var(--card-bg);border:1px solid var(--border-color);z-index:1001;border-radius:12px;width:220px;position:absolute;top:110%;right:0;overflow:hidden;box-shadow:0 8px 25px #00000026}.dropdown-header{border-bottom:1px solid var(--border-color);padding:12px 16px}.role-text,.email-text{margin:4px 0;font-size:.85rem}.dropdown-item{text-align:left;width:100%;color:var(--text-color);cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;padding:12px 16px;display:flex}.dropdown-item:hover{background:var(--bg-color)}.logout-item{color:#e74c3c;border-top:1px solid var(--border-color)}.side-nav{background:var(--card-bg);border-right:1px solid var(--border-color);z-index:900;flex-direction:column;width:220px;height:calc(100vh - 64px);padding:20px 0;transition:transform .3s;display:flex;position:fixed;top:64px;left:0}.nav-btn{color:var(--nav-text);cursor:pointer;background:0 0;border:none;align-items:center;gap:14px;padding:14px 24px;font-weight:500;transition:all .2s;display:flex}.nav-btn:hover{background:var(--bg-color);color:var(--text-color)}.nav-btn.active{background:var(--primary-color);color:#fff}.main-layout-content{flex-direction:column;flex:1;margin-left:220px;padding:84px 40px 40px;transition:margin-left .3s;display:flex}.content-wrapper{flex-direction:column;flex-grow:1;width:100%;max-width:1200px;margin:0 auto;display:flex}.bottom-nav-reveal,.bottom-nav-collapse{display:none}.main-layout-content--practice,.main-layout-content--training{box-sizing:border-box;height:100dvh;padding-top:64px;padding-bottom:0;overflow:hidden}.main-layout-content--practice .content-wrapper,.main-layout-content--training .content-wrapper{max-width:none;height:100%;min-height:0}@media (width<=1024px){.side-nav{width:100vw!important;height:calc(70px + env(safe-area-inset-bottom))!important;padding:0 0 env(safe-area-inset-bottom)!important;background-color:var(--card-bg,#fff)!important;border-top:1px solid var(--border-color,#e0e0e0)!important;z-index:9999!important;border-right:none!important;flex-direction:row!important;justify-content:space-around!important;align-items:center!important;transition:transform .3s cubic-bezier(.4,0,.2,1)!important;display:flex!important;position:fixed!important;top:auto!important;bottom:0!important;left:0!important;transform:translateY(0)!important}.side-nav.hidden{transform:translateY(calc(100% + env(safe-area-inset-bottom)))!important}.side-nav .nav-btn{border-radius:8px!important;flex-direction:column!important;flex:1!important;justify-content:center!important;gap:4px!important;min-width:0!important;margin:0 4px!important;padding:8px 0!important;font-size:11px!important;display:flex!important}.bottom-nav-reveal{z-index:10000;border:1px solid var(--border-color);background:var(--card-bg);width:58px;height:28px;color:var(--text-color);cursor:pointer;touch-action:pan-y;left:50%;bottom:max(6px, env(safe-area-inset-bottom));border-radius:14px 14px 6px 6px;justify-content:center;align-items:center;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 4px 14px #0000002e}.bottom-nav-collapse{z-index:2;border:1px solid var(--border-color);background:var(--card-bg);width:36px;height:20px;color:var(--text-color);cursor:pointer;touch-action:manipulation;border-radius:0 0 12px 12px;justify-content:center;align-items:center;display:flex;position:absolute;top:3px;left:50%;transform:translate(-50%);box-shadow:0 3px 10px #00000024}.side-nav.collapsible .nav-btn{padding-top:20px!important;padding-bottom:4px!important}.main-layout-content{padding:84px 20px calc(80px + env(safe-area-inset-bottom));margin-left:0}.main-layout-content.nav-hidden{padding-bottom:64px}.main-layout-content--practice,.main-layout-content--training{padding:64px 12px 0!important}}@media (width<=767px){.top-navbar{padding:0 12px}.main-layout-content{margin-left:0;padding:74px 12px 70px!important}.main-layout-content--practice,.main-layout-content--training{padding:64px 8px 0!important}.side-nav{background-color:var(--card-bg,#fff)!important;border-top:1px solid var(--border-color,#e0e0e0)!important;z-index:9999!important;border-right:none!important;flex-direction:row!important;justify-content:space-around!important;align-items:center!important;width:100vw!important;height:70px!important;transition:transform .3s cubic-bezier(.4,0,.2,1)!important;display:flex!important;position:fixed!important;top:auto!important;bottom:0!important;left:0!important;transform:translateY(0)!important}.side-nav.hidden{transform:translateY(100%)!important}.side-nav .nav-btn{border-radius:8px!important;flex-direction:column!important;flex:1!important;justify-content:center!important;gap:4px!important;margin:0 4px!important;padding:8px 0!important;font-size:11px!important;display:flex!important}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:12000;background:#000000b3;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.modal-content{background:var(--card-bg);color:var(--text-color);border:1px solid var(--border-color);border-radius:20px;width:90%;max-width:420px;max-height:85vh;padding:32px 28px;position:relative;overflow-y:auto;box-shadow:0 20px 50px #0000004d}.modal-close-btn{color:var(--nav-text);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:6px;position:absolute;top:16px;right:16px}.modal-close-btn:hover{background:var(--bg-color);color:var(--text-color)}.input-group{align-items:center;display:flex;position:relative}.input-group input{border:1px solid var(--border-color);background:var(--bg-color);width:100%;color:var(--text-color);border-radius:12px;padding:14px 16px 14px 48px;font-size:16px}.submit-btn{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:12px;margin-top:10px;padding:14px;font-size:16px;font-weight:700}.message{text-align:center;border-radius:10px;padding:12px;font-size:14px}.message.success{color:#2ecc71;background:#2ecc7126}.message.error{color:#e74c3c;background:#e74c3c26}.eye-btn{color:var(--nav-text);cursor:pointer;background:0 0;border:none;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.character-breakdown{flex-direction:column;align-items:center;width:100%;display:flex}.character-breakdown__title{text-align:center;color:var(--nav-text);justify-content:center;align-items:center;gap:6px;margin-bottom:8px;font-size:14px;font-weight:700;display:flex}.character-breakdown__box{aspect-ratio:1;background:var(--card-bg);border:2px solid var(--border-color);box-sizing:border-box;border-radius:12px;justify-content:center;align-items:center;width:100%;max-width:280px;height:auto;margin:0 auto;display:flex;overflow:hidden;box-shadow:inset 0 2px 8px #00000005}.character-breakdown--sm .character-breakdown__box{border-width:1px;border-radius:10px;max-width:150px}.character-breakdown--sm .character-breakdown__title{margin-bottom:6px;font-size:12px}.character-breakdown__stroke{transition:fill .3s}.character-breakdown__shared-stroke-hint{fill:none;stroke-width:30px;stroke-linecap:round;stroke-linejoin:round;opacity:.9;pointer-events:none;transition:stroke .3s}.character-breakdown__empty{color:var(--nav-text);text-align:center;padding:12px;font-size:13px;font-weight:600}.practice-wrapper{--f1-bg:#ffebee;--f1-bd:#ef9a9a;--f2-bg:#fff3e0;--f2-bd:#ffcc80;--f3-bg:#fffde7;--f3-bd:#fff59d;--f4-bg:#e8f5e9;--f4-bd:#a5d6a7;--f5-bg:#e0f7fa;--f5-bd:#80deea;--f6-bg:#e3f2fd;--f6-bd:#90caf9;--f7-bg:#f3e5f5;--f7-bd:#ce93d8;--f8-bg:#fce4ec;--f8-bd:#f48fb1;--f9-bg:#f5f5f5;--f9-bd:#eee;--hint-text:#2c3e50;--hint-text-sub:#7f8c8d;--hint-shadow:none;flex-direction:column;flex-grow:1;justify-content:flex-start;align-items:center;width:100%;height:100%;min-height:0;display:flex;overflow:hidden}.practice-wrapper.dark-mode{--f1-bg:#b71c1c;--f1-bd:#7f0000;--f2-bg:#e65100;--f2-bd:#ac1900;--f3-bg:#f57f17;--f3-bd:#bc5100;--f4-bg:#1b5e20;--f4-bd:#030;--f5-bg:#006064;--f5-bd:#00363a;--f6-bg:#01579b;--f6-bd:#002f6c;--f7-bg:#4a148c;--f7-bd:#12005e;--f8-bg:#880e4f;--f8-bd:#560027;--f9-bg:#212121;--f9-bd:#000;--hint-text:#fff;--hint-text-sub:#ffffffb3;--hint-shadow:0 2px 4px #000c}.practice-display-card{--practice-display-space:390px;background:var(--card-bg);border:1px solid var(--border-color);box-sizing:border-box;border-radius:12px;flex-direction:column;flex-grow:1;align-items:center;gap:14px;width:100%;max-width:none;min-height:0;margin-bottom:20px;padding:20px;display:flex;box-shadow:0 4px 12px #0000000d}.practice-focus-header{justify-content:space-between;align-items:flex-start;gap:20px;width:100%;display:flex}.practice-focus-copy{text-align:left;min-width:0}.practice-kicker{color:var(--primary-color);align-items:center;gap:6px;font-size:13px;font-weight:800;line-height:1.2;display:inline-flex}.practice-focus-copy h1{color:var(--text-color);letter-spacing:0;margin:6px 0;font-size:30px;line-height:1.15}.practice-focus-copy p{color:var(--nav-text);margin:0;font-size:15px;font-weight:600;line-height:1.45}.practice-shortcut-badge{border:1px solid var(--border-color);background:var(--bg-color);min-height:42px;color:var(--text-color);white-space:nowrap;border-radius:8px;flex:none;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-size:15px;font-weight:800;display:inline-flex}.practice-guidance-strip{background:var(--bg-color);border:1px solid var(--border-color);box-sizing:border-box;border-radius:8px;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;width:100%;padding:8px;display:grid}.practice-guidance-item{min-width:0;min-height:36px;color:var(--nav-text);text-align:center;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:800;line-height:1.2;display:flex}.practice-guidance-item svg{color:var(--primary-color);flex:none}.settings-pill-bar{background:var(--bg-color);border:1px solid var(--border-color);box-sizing:border-box;border-radius:12px;flex-wrap:wrap;justify-content:center;align-items:center;gap:15px;width:100%;padding:10px 20px;display:flex}.pill-group{gap:8px;display:flex}.pill-divider{background:var(--border-color);width:2px;height:24px}.pill-btn{color:var(--nav-text);cursor:pointer;background:0 0;border:none;border-radius:30px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:700;transition:all .2s;display:flex}.pill-btn:hover{background:#007bff1a}.pill-btn.active{background:var(--primary-color);color:#fff;box-shadow:0 2px 8px #007bff4d}.target-area{flex-direction:column;flex:auto;justify-content:center;align-items:center;width:100%;min-height:0;padding-top:0;display:flex;position:relative;overflow:hidden}.status-text{text-align:center;min-height:32px;margin-bottom:14px;font-size:20px;font-weight:700;line-height:1.25;transition:color .2s}.target-char-container{flex:auto;justify-content:center;align-items:center;width:100%;min-height:0;display:flex}.target-char{font-size:clamp(54px, calc(var(--practice-display-space) * .32), 140px);color:var(--text-color);font-weight:700;line-height:1;transition:transform .1s}.shake{animation:.3s cubic-bezier(.36,.07,.19,.97) both shakeAnim;color:#e74c3c!important}@keyframes shakeAnim{10%,90%{transform:translate(-4px)}20%,80%{transform:translate(8px)}30%,50%,70%{transform:translate(-16px)}40%,60%{transform:translate(16px)}}.start-action-btn{color:#fff;cursor:pointer;background:#e74c3c;border:none;border-radius:12px;justify-content:center;align-items:center;gap:12px;padding:18px 40px;font-size:26px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 8px 24px #e74c3c66}.start-action-btn:hover{background:#ff6b6b;transform:scale(1.05)!important}.start-action-btn:active{box-shadow:0 4px 10px #e74c3c66;transform:scale(.95)!important}.start-action-btn.pulse-anim{animation:2s ease-in-out infinite pulseAnim}@keyframes pulseAnim{0%{transform:scale(1);box-shadow:0 8px 24px #e74c3c66}50%{transform:scale(1.05);box-shadow:0 15px 40px #e74c3cb3}to{transform:scale(1);box-shadow:0 8px 24px #e74c3c66}}.keyboard-container{background:0 0;border-radius:20px;flex-direction:column;align-items:flex-start;gap:12px;width:fit-content;margin:0 auto;padding:20px;display:flex;position:relative}.practice-mode-kbd{box-sizing:border-box;width:100%}.kbd-row{gap:12px;display:flex}.kbd-row-2{margin-left:52px}.kbd-row-3{margin-left:78px}.kbd-row-4{margin-left:130px}.kbd-row-5{justify-content:center;width:100%;margin-left:0}.key{background-color:var(--card-bg);border-bottom:8px solid var(--border-color);cursor:not-allowed;-webkit-user-select:none;user-select:none;box-sizing:border-box;border-left:1px solid var(--border-color);border-right:1px solid var(--border-color);border-radius:12px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:104px;height:104px;transition:background-color .1s,border-color .1s,transform .1s;display:flex;position:relative;top:0}.keyboard-container.is-touch .key{cursor:pointer!important;pointer-events:auto!important}.key.space{width:720px;margin:0 auto}.key.disabled-key{opacity:.15;pointer-events:none}.key-text{color:var(--text-color);z-index:10;font-size:36px;font-weight:700;position:relative}.key-en{color:var(--nav-text);z-index:10;margin-bottom:4px;font-size:20px;font-weight:500;position:relative}.key-cj{color:var(--text-color);z-index:10;font-size:36px;font-weight:700;position:relative}.keyboard-container.show-hints .finger-1{background-color:var(--f1-bg);border-bottom-color:var(--f1-bd)}.keyboard-container.show-hints .finger-2{background-color:var(--f2-bg);border-bottom-color:var(--f2-bd)}.keyboard-container.show-hints .finger-3{background-color:var(--f3-bg);border-bottom-color:var(--f3-bd)}.keyboard-container.show-hints .finger-4{background-color:var(--f4-bg);border-bottom-color:var(--f4-bd)}.keyboard-container.show-hints .finger-5{background-color:var(--f5-bg);border-bottom-color:var(--f5-bd)}.keyboard-container.show-hints .finger-6{background-color:var(--f6-bg);border-bottom-color:var(--f6-bd)}.keyboard-container.show-hints .finger-7{background-color:var(--f7-bg);border-bottom-color:var(--f7-bd)}.keyboard-container.show-hints .finger-8{background-color:var(--f8-bg);border-bottom-color:var(--f8-bd)}.keyboard-container.show-hints .finger-9{background-color:var(--f9-bg);border-bottom-color:var(--f9-bd)}.keyboard-container.show-hints .key-en{color:var(--hint-text-sub);text-shadow:var(--hint-shadow)}.keyboard-container.show-hints .key-cj,.keyboard-container.show-hints .key-text{color:var(--hint-text);text-shadow:var(--hint-shadow)}.key.active-target{top:-4px;transform:scale(1.05)}.key.active-target:after{content:"";border:6px solid var(--primary-color);pointer-events:none;z-index:5;border-radius:16px;animation:1.5s ease-in-out infinite targetBreathe;position:absolute;inset:-8px -8px -16px}@keyframes targetBreathe{0%,to{opacity:.2;box-shadow:0 0 10px var(--primary-color)}50%{opacity:1;box-shadow:0 0 30px var(--primary-color)}}#hands-overlay{pointer-events:none;z-index:20;opacity:1;transition:opacity .3s;position:absolute;inset:0}#hands-overlay.ghost-hidden{opacity:0}.finger-wrapper{z-index:25;transition:all .2s;position:absolute}.svg-skin{fill:none;stroke:#2c3e50bf;stroke-width:8px;stroke-linecap:round;transition:all .15s,stroke .3s}.finger-wrapper.active-finger{z-index:30;animation:1.5s ease-in-out infinite breatheLightFinger}.finger-wrapper.active-finger .svg-skin{stroke-width:13px;stroke:#444!important}@keyframes breatheLightFinger{0%,to{opacity:0;filter:drop-shadow(0 0 8px #4446)drop-shadow(0 0 15px #4443)}50%{opacity:1;filter:drop-shadow(0 0 20px #444444e6)drop-shadow(0 0 35px #4449)}}.practice-wrapper.dark-mode .svg-skin{stroke:#ecf0f199}.practice-wrapper.dark-mode .finger-wrapper.active-finger{animation:1.5s ease-in-out infinite breatheDarkFinger}.practice-wrapper.dark-mode .finger-wrapper.active-finger .svg-skin{stroke:#fff!important}@keyframes breatheDarkFinger{0%,to{opacity:0;filter:drop-shadow(0 0 8px #fff6)drop-shadow(0 0 15px #fff3)}50%{opacity:1;filter:drop-shadow(0 0 24px #fff)drop-shadow(0 0 40px #ffffffb3)}}.prac-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#00000080;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.prac-modal-content{background:var(--card-bg);color:var(--text-color);text-align:center;border:1px solid var(--border-color);border-radius:24px;max-width:500px;padding:40px;box-shadow:0 20px 40px #0003}.prac-modal-content h2{margin-top:0;font-size:28px}.prac-modal-content p{color:var(--nav-text);margin-bottom:30px;font-size:18px;line-height:1.6}.prac-modal-btn{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:16px 32px;font-size:20px;font-weight:700}.prac-modal-btn.error-btn{background:#e74c3c}@media (width<=1024px){.keyboard-viewport{justify-content:center!important;width:100%!important;display:flex!important;overflow:visible!important}.practice-mode-kbd{width:100%!important;padding:14px 20px 20px!important}.practice-focus-header{box-sizing:border-box;flex-direction:column;gap:8px;padding:0 8px}.practice-kicker{font-size:11px}.practice-focus-copy h1{margin:4px 0;font-size:20px}.practice-focus-copy p{display:none}.practice-shortcut-badge{box-sizing:border-box;width:100%;min-height:34px;font-size:12px}.practice-guidance-strip{grid-template-columns:1fr;gap:4px;padding:6px;display:none}.practice-guidance-item{text-align:left;box-sizing:border-box;justify-content:flex-start;min-height:28px;padding:0 8px;font-size:11px}.settings-pill-bar{white-space:normal;border-radius:12px;flex-wrap:wrap;justify-content:center;gap:4px;margin-bottom:5px;padding:6px}.pill-group{flex-wrap:wrap;justify-content:center;gap:4px}.pill-divider{display:none}.pill-btn{gap:4px;padding:4px 8px;font-size:11px}.practice-display-card{border-radius:8px;gap:6px;margin-bottom:0;padding:8px 10px}.target-area{min-height:0;padding-top:0}.status-text{min-height:24px;margin-bottom:0;font-size:14px}.target-char-container{min-height:0}.start-action-btn{padding:12px 28px;font-size:18px}.prac-modal-content{box-sizing:border-box;border-radius:12px;width:calc(100vw - 32px);padding:24px 18px}.prac-modal-content h2{font-size:20px}.prac-modal-content p{font-size:15px}.prac-modal-btn{padding:12px 18px;font-size:16px}}@media screen and (width<=1024px) and (height<=670px){.practice-display-card{margin-bottom:5px!important;padding:5px 2px!important}.practice-focus-header{gap:4px!important}.practice-shortcut-badge{min-height:28px!important}.settings-pill-bar{margin-bottom:4px!important;padding:4px!important}.pill-btn{padding:4px 8px!important;font-size:11px!important}.target-area{min-height:60px!important;padding-top:0!important}.target-char-container{min-height:45px!important}.target-char{font-size:40px!important}.status-text{min-height:16px!important;margin-bottom:4px!important;font-size:12px!important}.start-action-btn{padding:8px 20px!important;font-size:15px!important}}.training-wrapper{justify-content:flex-start;height:100%;min-height:0;overflow:hidden}.training-master-container{overflow:visible}.training-master-scaler{justify-content:flex-start}.training-display-card{--training-display-space:360px;--training-target-size:clamp(160px, calc(var(--training-display-space) - 180px), 280px);--training-input-height:clamp(42px, calc(var(--training-display-space) - 430px), 52px);--training-action-height:clamp(40px, calc(var(--training-display-space) - 440px), 48px);gap:14px;max-width:none;height:auto;min-height:0}.training-display-card .target-area{flex:auto;gap:8px;min-height:0;padding-top:0;overflow:hidden}.training-level-tabs{background:var(--bg-color);border:1px solid var(--border-color);box-sizing:border-box;border-radius:8px;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;width:100%;padding:6px;display:flex}.training-level-tab{min-height:38px;color:var(--nav-text);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 14px;font-size:14px;font-weight:700;transition:background .2s,color .2s,box-shadow .2s}.training-level-tab:hover{color:var(--text-color);background:#007bff1a}.training-level-tab.active{background:var(--primary-color);color:#fff;box-shadow:0 2px 8px #007bff40}.training-level-tab:disabled{opacity:.65;cursor:wait}.training-vocab-count{color:var(--nav-text);opacity:.75;font-size:14px;font-weight:700}.training-target-container{flex-direction:column;flex:none;gap:14px;min-height:0}.training-character-breakdown{width:min(var(--training-target-size), 64vw);max-width:280px}.training-character-breakdown.character-breakdown .character-breakdown__box{max-width:var(--training-target-size);background:var(--bg-color);border-radius:8px}.training-code-input-shell{width:min(360px,80vw);height:var(--training-input-height);min-height:var(--training-input-height);flex:0 0 var(--training-input-height);border:2px solid var(--border-color);background:var(--bg-color);color:var(--text-color);box-sizing:border-box;cursor:text;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border-radius:8px;justify-content:center;align-items:center;transition:border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.training-code-input-shell:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff29}.training-code-input-shell--feedback-wrong{border-color:var(--error-color,#e74c3c);background:#e74c3c29;box-shadow:0 0 0 3px #e74c3c29}.training-code-input-shell--feedback-correct{border-color:var(--success-color,#2ecc71);background:#2ecc7129;box-shadow:0 0 0 3px #2ecc7129}.training-code-input{color:#0000;caret-color:#0000;opacity:0;cursor:text;background:0 0;border:0;outline:none;width:100%;height:100%;padding:0;position:absolute;inset:0}.training-code-visual{box-sizing:border-box;text-align:center;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:100%;height:100%;padding:0 16px;line-height:1;display:flex}.training-code-visual__en{color:var(--text-color);letter-spacing:0;font-size:24px;font-weight:800}.training-code-visual__cj{color:var(--text-color);letter-spacing:0;font-size:28px;font-weight:800}.training-code-input-shell--both .training-code-visual__en{color:var(--nav-text);font-size:15px;font-weight:700}.training-code-input-shell--both .training-code-visual__cj{font-size:24px}.training-code-visual__placeholder{color:var(--nav-text);opacity:.45;font-size:18px;font-weight:800}.training-code-visual__message{color:var(--nav-text);overflow-wrap:anywhere;font-size:16px;font-weight:800;line-height:1.2}.training-code-feedback-icon{stroke-width:3.2px;width:30px;height:30px}.training-code-input-shell--feedback-wrong .training-code-feedback-icon{color:var(--error-color,#e74c3c)}.training-code-input-shell--feedback-correct .training-code-feedback-icon{color:var(--success-color,#2ecc71)}.training-action-row{flex:none;grid-template-columns:minmax(108px,auto) minmax(0,1fr) minmax(108px,auto) minmax(150px,auto);align-items:stretch;gap:10px;width:100%;max-width:900px;margin-top:0;display:grid}.training-action-btn{min-height:var(--training-action-height);border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-color);cursor:pointer;white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:6px;font-size:16px;font-weight:800;transition:background .2s,color .2s,border-color .2s,transform .1s;display:flex}.training-action-btn:hover{border-color:var(--primary-color);transform:translateY(-1px)}.training-action-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.training-action-btn--five-color.active{background:linear-gradient(90deg,#d32f2f,#f57c00,#2e7d32,#1565c0,#6a1b9a);border-color:#0000}.training-hint-box{min-height:var(--training-action-height);border:1px solid var(--border-color);background:var(--bg-color);color:var(--text-color);box-sizing:border-box;text-align:center;overflow-wrap:anywhere;border-radius:8px;justify-content:center;align-items:center;padding:0 14px;font-size:17px;font-weight:800;line-height:1.25;display:flex}.training-mode-kbd .key.answer-highlight{overflow:clip;background:var(--answer-key-bg)!important;background-color:var(--answer-key-bg)!important;border-top:0!important;border-left:0!important;border-right:0!important;border-bottom:8px solid color-mix(in srgb, var(--answer-key-edge) 68%, #000)!important;box-shadow:0 0 18px color-mix(in srgb, var(--answer-key-glow) 55%, transparent)!important;color:#fff!important;background-clip:border-box!important;transform:translateY(-2px)!important}.training-mode-kbd .key.answer-highlight--animating{animation:.32s ease-out answerKeyPulse;transform:translateY(-5px)scale(1.06)!important}.training-mode-kbd.kbd-no-border .key.answer-highlight{box-shadow:0 0 14px color-mix(in srgb, var(--answer-key-glow) 42%, transparent)!important;border:none!important;transform:translateY(4px)!important}.training-mode-kbd.kbd-no-border .key.answer-highlight--animating{transform:translateY(4px)scale(1.03)!important}.training-mode-kbd .key.answer-highlight .key-en,.training-mode-kbd .key.answer-highlight .key-cj,.training-mode-kbd .key.answer-highlight .key-text{color:#fff!important;text-shadow:0 1px 2px #00000073!important}.answer-key-order-badge{z-index:30;color:#fff;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 2px #00000080;pointer-events:none;background:#00000047;border-radius:5px;max-width:calc(100% - 14px);padding:2px 5px;font-size:12px;font-weight:900;line-height:1.1;position:absolute;top:7px;left:8px;overflow:hidden}.answer-key-sequence{z-index:30;pointer-events:none;width:24px;position:absolute;top:0;bottom:0;left:0}.answer-key-sequence__item{white-space:nowrap;text-align:left;width:100%;padding:4px 0 0 5px;position:absolute;overflow:hidden}.answer-key-sequence__badge{color:#fff;letter-spacing:0;text-shadow:0 1px 2px #0000008c;background:#00000047;border-radius:5px;justify-content:center;align-items:center;min-width:15px;min-height:15px;padding:1px 4px;font-size:11px;font-weight:900;line-height:1.1;display:inline-flex}@keyframes answerKeyPulse{0%{filter:brightness(.92)}55%{filter:brightness(1.22)}to{filter:brightness()}}.start-action-btn:disabled{opacity:.65;cursor:wait;animation:none}@media (width<=800px){.training-display-card{--training-target-size:clamp(112px, calc(var(--training-display-space) - 260px), 230px);--training-input-height:clamp(36px, calc(var(--training-display-space) - 445px), 48px);--training-action-height:clamp(34px, calc(var(--training-display-space) - 450px), 44px);gap:8px}.training-level-tabs{gap:4px;padding:4px}.training-level-tab{min-height:30px;padding:5px 8px;font-size:12px}.training-target-container{gap:6px;min-height:0}.training-character-breakdown{width:min(var(--training-target-size), 68vw)}.training-character-breakdown.character-breakdown .character-breakdown__box{max-width:var(--training-target-size)}.training-code-input-shell{width:min(260px,78vw);height:var(--training-input-height);min-height:var(--training-input-height);flex-basis:var(--training-input-height)}.training-code-visual{padding:0 10px}.training-code-visual__en{font-size:18px}.training-code-visual__cj{font-size:22px}.training-code-input-shell--both .training-code-visual__en{font-size:12px}.training-code-input-shell--both .training-code-visual__cj{font-size:18px}.training-code-visual__placeholder{font-size:14px}.training-code-visual__message{font-size:12px}.training-action-row{grid-template-columns:86px minmax(0,1fr) 86px;gap:6px;max-width:100%}.training-action-btn{min-height:var(--training-action-height);gap:4px;font-size:13px}.training-action-btn--five-color{grid-column:1/-1}.training-hint-box{min-height:var(--training-action-height);padding:0 8px;font-size:13px}.training-vocab-count{font-size:12px}}@media (width>=560px) and (width<=800px){.training-action-row{grid-template-columns:minmax(76px,auto) minmax(0,1fr) minmax(76px,auto) minmax(126px,auto)}.training-action-btn--five-color{grid-column:auto}}@media screen and (width<=800px) and (height<=670px){.training-display-card{--training-target-size:clamp(112px, calc(var(--training-display-space) - 210px), 170px);--training-input-height:clamp(36px, calc(var(--training-display-space) - 405px), 42px);--training-action-height:clamp(34px, calc(var(--training-display-space) - 410px), 40px);gap:5px!important}.training-level-tabs{padding:3px!important}.training-level-tab{min-height:26px!important;padding:3px 6px!important;font-size:11px!important}.training-target-container{gap:5px!important;min-height:0!important}.training-character-breakdown{width:min(var(--training-target-size), 58vw, 30dvh)!important}.training-character-breakdown.character-breakdown .character-breakdown__box{max-width:var(--training-target-size)!important}.training-code-input-shell{width:min(210px,72vw)!important;height:var(--training-input-height)!important;min-height:var(--training-input-height)!important;flex-basis:var(--training-input-height)!important}.training-code-visual{gap:2px!important;padding:0 8px!important}.training-code-visual__en{font-size:15px!important}.training-code-visual__cj{font-size:17px!important}.training-code-input-shell--both .training-code-visual__en{font-size:10px!important}.training-code-input-shell--both .training-code-visual__cj{font-size:15px!important}.training-code-visual__placeholder{font-size:12px!important}.training-code-visual__message{font-size:10px!important}.training-action-btn{min-height:var(--training-action-height)!important;font-size:12px!important}.training-hint-box{min-height:var(--training-action-height)!important;padding:0 6px!important;font-size:12px!important}}@keyframes popUpCenter{0%{opacity:0;transform:translateX(-50%) scale(var(--kbd-settings-scale,1))}to{opacity:1;transform:translateX(-50%) scale(var(--kbd-settings-scale,1))}}@keyframes popUpAbsoluteCenter{0%{opacity:0;transform:translate(-50%, -50%) scale(var(--kbd-settings-scale,1))}to{opacity:1;transform:translate(-50%, -50%) scale(var(--kbd-settings-scale,1))}}.kbd-settings-popup{background:var(--card-bg);box-sizing:border-box;z-index:10001;border:1px solid var(--border-color);transform-origin:bottom;width:min(450px,100vw - 24px);max-width:450px;transform:translateX(-50%) scale(var(--kbd-settings-scale,1));color:var(--text-color);border-radius:18px;max-height:none;padding:22px 28px;animation:.16s ease-out forwards popUpCenter;position:fixed;overflow:visible;box-shadow:0 10px 40px #0003}.kbd-settings-popup.centered-mode{transform:translate(-50%, -50%) scale(var(--kbd-settings-scale,1));transform-origin:50%!important;animation:.16s ease-out forwards popUpAbsoluteCenter!important;bottom:auto!important}.close-popup-btn{background:var(--bg-color);border:1px solid var(--border-color);color:var(--nav-text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;padding:0;transition:all .2s;display:flex;position:absolute;top:14px;right:14px}.close-popup-btn:hover{background:var(--border-color);color:var(--text-color)}.kbd-setting-group{margin-bottom:16px}.kbd-setting-group label{color:var(--nav-text);margin-bottom:8px;font-size:14px;font-weight:700;display:block}.kbd-setting-options{flex-wrap:wrap;gap:8px;display:flex}.kbd-setting-options button{border:1px solid var(--border-color);background:var(--bg-color);min-height:38px;color:var(--text-color);cursor:pointer;border-radius:10px;padding:8px 14px;font-size:14px;font-weight:700;transition:all .2s}.kbd-setting-options button:hover{background:#007bff1a}.kbd-setting-options button.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 4px 12px #007bff4d}.kbd-setting-group--toggle{justify-content:space-between;align-items:center;gap:14px;display:flex}.kbd-setting-group--toggle label{margin-bottom:0}.kbd-toggle-switch{border:1px solid var(--border-color);background:var(--bg-color);min-height:38px;color:var(--text-color);cursor:pointer;touch-action:manipulation;border-radius:999px;align-items:center;gap:10px;padding:5px 12px 5px 6px;font-size:14px;font-weight:800;transition:background .2s,border-color .2s,color .2s;display:inline-flex}.kbd-toggle-switch.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.kbd-toggle-switch__track{box-sizing:border-box;background:#7f8c8d59;border-radius:999px;align-items:center;width:38px;height:22px;padding:2px;transition:background .2s;display:flex}.kbd-toggle-switch.active .kbd-toggle-switch__track{background:#ffffff59}.kbd-toggle-switch__thumb{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;transform:translate(0);box-shadow:0 1px 4px #00000040}.kbd-toggle-switch.active .kbd-toggle-switch__thumb{transform:translate(16px)}.kbd-toggle-switch__text{text-align:center;min-width:28px}.kbd-settings-popup h3{font-size:20px;line-height:1.2;margin-bottom:16px!important}.kbd-settings-popup .scale-slider-container{gap:12px!important;padding-bottom:10px!important}.kbd-settings-popup .apply-btn{border-radius:12px!important;margin-top:2px!important;padding:13px!important;font-size:17px!important}.kbd-theme-blue .key{background-color:#e3f2fd!important;border-bottom-color:#90caf9!important;border-left-color:#bbdefb!important;border-right-color:#bbdefb!important}.kbd-theme-blue .key-en,.kbd-theme-blue .key-cj,.kbd-theme-blue .key-text{color:#0d47a1!important}.kbd-theme-green .key{background-color:#e8f5e9!important;border-bottom-color:#a5d6a7!important;border-left-color:#c8e6c9!important;border-right-color:#c8e6c9!important}.kbd-theme-green .key-en,.kbd-theme-green .key-cj,.kbd-theme-green .key-text{color:#1b5e20!important}.kbd-theme-dark .key{background-color:#2d3748!important;border-bottom-color:#1a202c!important;border-left-color:#4a5568!important;border-right-color:#4a5568!important}.kbd-theme-dark .key-en,.kbd-theme-dark .key-cj,.kbd-theme-dark .key-text{color:#f7fafc!important}.training-mode-kbd .key--control{color:var(--text-color)}.training-mode-kbd .key-control-icon{color:currentColor;flex-shrink:0}.training-mode-kbd .key-control-label{text-align:center;overflow-wrap:anywhere;max-width:calc(100% - 14px);line-height:1}.kbd-theme-blue .key--control:not(.active){color:#0d47a1}.kbd-theme-green .key--control:not(.active){color:#1b5e20}.kbd-theme-dark .key--control:not(.active){color:#f7fafc}.training-mode-kbd .key--instant-check.active{color:#fff}.kbd-no-border .key{transform:translateY(4px);border:none!important;border-radius:10px!important;box-shadow:0 5px 12px #0000001a!important}.kbd-no-border .key.active-target{box-shadow:0 0 20px var(--primary-color)!important;transform:translateY(0)scale(1.05)!important}.training-mode-kbd{touch-action:manipulation}.training-mode-kbd .key{height:var(--training-key-height,104px);min-height:var(--training-key-height,104px);touch-action:manipulation;-webkit-tap-highlight-color:transparent;overflow:hidden;cursor:pointer!important}.training-mode-kbd .key>span,.training-mode-kbd .key>div{max-width:100%}.disabled-key{filter:grayscale();opacity:.35!important;pointer-events:none!important;cursor:not-allowed!important}.keyboard-glow-active{background-color:#007bff0d!important;border-radius:12px!important}.keyboard-glow-active:after{content:"";border-radius:inherit;z-index:10;pointer-events:none;position:absolute;inset:0;box-shadow:inset 0 0 0 4px var(--primary-color), inset 0 0 30px #007bff66!important}@media (width<=767px){.kbd-settings-popup{border-radius:14px!important;width:calc(100vw - 20px)!important;max-width:380px!important;max-height:none!important;padding:14px 12px!important;overflow:visible!important}.close-popup-btn{width:30px!important;height:30px!important;top:12px!important;right:12px!important}.kbd-settings-popup h3{margin-bottom:12px!important;font-size:17px!important}.kbd-setting-group{margin-bottom:10px!important}.kbd-setting-group label{margin-bottom:6px!important;font-size:13px!important}.kbd-setting-options{gap:5px!important}.kbd-setting-options button{border-radius:8px!important;min-height:34px!important;padding:7px 8px!important;font-size:13px!important}.kbd-toggle-switch{min-height:34px!important;padding:4px 10px 4px 5px!important;font-size:13px!important}.kbd-toggle-switch__track{width:34px!important;height:20px!important}.kbd-toggle-switch__thumb{width:16px!important;height:16px!important}.kbd-toggle-switch.active .kbd-toggle-switch__thumb{transform:translate(14px)!important}.kbd-settings-popup .scale-slider-container{gap:9px!important;padding-bottom:8px!important}.scale-slider-container span{font-size:12px!important}.scale-slider-container span:last-child{font-size:16px!important}.kbd-settings-popup .apply-btn{border-radius:10px!important;margin-top:0!important;padding:10px!important;font-size:15px!important}}.kids-page{--kids-text:var(--text-color);--kids-muted:var(--nav-text);--kids-panel:var(--card-bg);--kids-bg:var(--bg-color);--kids-border:var(--border-color);--theme-main:#16a34a;--theme-soft:#16a34a24;--theme-border:#16a34a47;min-height:calc(100dvh - 124px);color:var(--kids-text)}.kids-page button{font:inherit;-webkit-tap-highlight-color:transparent}.kids-theme-emerald{--theme-main:#059669;--theme-soft:#05966924;--theme-border:#0596694d}.kids-theme-amber{--theme-main:#d97706;--theme-soft:#d9770629;--theme-border:#d977064d}.kids-theme-rose{--theme-main:#e11d48;--theme-soft:#e11d4821;--theme-border:#e11d4842}.kids-theme-sky{--theme-main:#0284c7;--theme-soft:#0284c724;--theme-border:#0284c747}.kids-theme-slate{--theme-main:#475569;--theme-soft:#47556924;--theme-border:#47556947}.kids-theme-purple{--theme-main:#7c3aed;--theme-soft:#7c3aed24;--theme-border:#7c3aed47}.kids-theme-orange{--theme-main:#ea580c;--theme-soft:#ea580c24;--theme-border:#ea580c47}.kids-theme-indigo{--theme-main:#4f46e5;--theme-soft:#4f46e524;--theme-border:#4f46e547}.kids-map{max-width:980px;margin:0 auto;padding:8px 0 32px;position:relative}.kids-map-header{text-align:center;justify-items:center;gap:10px;margin-bottom:34px;display:grid}.kids-bag{color:#0284c7;background:#fff;border:4px solid #38bdf8;border-radius:28px;place-items:center;width:92px;height:92px;font-weight:950;animation:2.4s ease-in-out infinite kids-bounce;display:grid;box-shadow:0 14px 28px #0284c72e}.kids-mini-kicker{color:var(--theme-main);justify-content:center;align-items:center;gap:7px;font-size:13px;font-weight:950;display:inline-flex}.kids-map-header h1,.kids-celebration h1,.kids-assigned-note h1{color:#075985;margin:0;font-size:clamp(34px,5vw,58px);font-weight:950;line-height:1.05}.kids-map-header p,.kids-assigned-note p{color:#0369a1;margin:0;font-size:18px;font-weight:900}.kids-map-progress{border:1px solid var(--kids-border);background:var(--kids-panel);width:min(560px,100%);box-shadow:var(--shadow);border-radius:8px;gap:8px;margin-top:8px;padding:12px;display:grid}.kids-map-progress span,.kids-quiz-progress span{color:var(--kids-muted);font-weight:900}.kids-progress-track{border:1px solid var(--theme-border);background:var(--theme-soft);border-radius:999px;height:18px;overflow:hidden}.kids-progress-fill{border-radius:inherit;background:var(--theme-main);height:100%;transition:width .35s}.kids-level-path{gap:22px;display:grid;position:relative}.kids-level-path:before{content:"";background:#0ea5e92e;border-radius:999px;width:8px;position:absolute;top:28px;bottom:28px;left:50%;transform:translate(-50%)}.kids-level-node{z-index:1;display:flex;position:relative}.kids-level-node.left{justify-content:flex-start}.kids-level-node.right{justify-content:flex-end}.kids-level-card{border:3px solid var(--theme-border);background:var(--theme-soft);width:min(420px,100vw - 48px);min-height:132px;color:var(--kids-text);cursor:pointer;text-align:left;border-radius:8px;grid-template-columns:76px minmax(0,1fr);grid-template-areas:"mascot copy""mascot action";align-items:center;gap:8px 14px;padding:18px;transition:transform .18s,box-shadow .18s,opacity .18s;display:grid;box-shadow:0 16px 34px #0f172a1f}.kids-level-card.unlocked:hover{transform:translateY(-4px);box-shadow:0 20px 42px #0f172a29}.kids-level-card.locked{cursor:not-allowed;filter:grayscale(.65);opacity:.58}.kids-level-mascot{background:var(--kids-panel);width:76px;height:76px;color:var(--theme-main);border-radius:24px;grid-area:mascot;place-items:center;font-size:30px;font-weight:950;display:grid;box-shadow:inset 0 -5px #0f172a14}.kids-level-copy{grid-area:copy;gap:5px;min-width:0;display:grid}.kids-level-copy strong{font-size:22px;font-weight:950;line-height:1.1}.kids-level-copy small{color:var(--kids-muted);font-weight:900}.kids-level-action{background:var(--theme-main);color:#fff;border-radius:999px;grid-area:action;justify-content:center;justify-self:start;align-items:center;min-height:34px;padding:0 14px;font-size:13px;font-weight:950;display:inline-flex}.kids-parent-tools{text-align:center;margin-top:34px}.kids-parent-tools button{color:var(--kids-muted);cursor:pointer;background:0 0;border:0;font-size:13px;font-weight:850;text-decoration:underline}.kids-map-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.kids-dex{background:linear-gradient(135deg, #0ea5e92e, #22c55e1f), var(--kids-bg);border-radius:8px;min-height:calc(100dvh - 142px);padding:18px}.kids-dex-layout{grid-template-columns:minmax(0,1.25fr) minmax(300px,.75fr);align-items:start;gap:18px;display:grid}.kids-elf-grid{gap:14px;display:grid}.kids-elf-generation{border:1px solid var(--theme-border);background:#ffffffb8;border-radius:8px;gap:10px;padding:12px;display:grid}.kids-elf-generation-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.kids-elf-generation-head span,.kids-elf-generation-head strong{color:var(--theme-main);font-size:12px;font-weight:950}.kids-elf-generation-head h2{color:var(--kids-text);margin:2px 0 0;font-size:22px;font-weight:950;line-height:1.05}.kids-elf-generation p{color:var(--kids-muted);margin:0;font-size:14px;font-weight:850;line-height:1.45}.kids-elf-row{grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:10px;display:grid}.kids-elf-card{color:#fff;cursor:pointer;text-align:center;border:3px solid #ffffff94;border-radius:8px;align-content:center;justify-items:center;gap:5px;min-height:144px;padding:12px;transition:transform .16s,box-shadow .16s,outline-color .16s;display:grid;box-shadow:inset 0 -8px #0f172a21,0 12px 22px #0f172a24}.kids-elf-card:hover,.kids-elf-card.active{transform:translateY(-3px);box-shadow:inset 0 -8px #0f172a21,0 18px 30px #0f172a33}.kids-elf-card.active{outline-offset:2px;outline:4px solid #0f172a38}.kids-elf-letter{background:#ffffff38;border-radius:8px;place-items:center;min-width:38px;min-height:30px;font-size:18px;font-weight:950;display:inline-grid}.kids-elf-sigil{place-items:center;min-height:22px;font-size:19px;line-height:1;display:grid}.kids-elf-card strong{font-size:42px;font-weight:950;line-height:1}.kids-elf-card small{min-height:34px;color:inherit;place-items:center;font-size:12px;font-weight:950;line-height:1.2;display:grid}.kids-elf-detail{color:#fff;border:4px solid #ffffff94;border-radius:8px;gap:16px;padding:18px;display:grid;position:sticky;top:84px;box-shadow:inset 0 -10px #0f172a21,0 18px 38px #0f172a2e}.kids-elf-portrait{background:#ffffff2e;border-radius:8px;place-items:center;min-height:156px;display:grid}.kids-elf-portrait b{margin-bottom:-24px;font-size:34px;line-height:1}.kids-elf-portrait span{text-shadow:0 8px 18px #0f172a33;font-size:clamp(78px,12vw,118px);font-weight:950;line-height:1}.kids-elf-portrait i{color:#0f172a;background:#fff;border-radius:50%;place-items:center;width:54px;height:54px;margin-top:-18px;font-style:normal;font-weight:950;display:grid}.kids-elf-copy{gap:8px;display:grid}.kids-elf-copy .kids-mini-kicker{color:#ffffffe6}.kids-elf-copy h2{margin:0;font-size:clamp(26px,4vw,38px);font-weight:950;line-height:1.08}.kids-elf-copy p{margin:0;font-size:16px;font-weight:850;line-height:1.45}.kids-skill-panel{background:#ffffff2e;border-radius:8px;gap:10px;padding:12px;display:grid}.kids-skill-panel h3{margin:0;font-size:15px;font-weight:950}.kids-skill-list,.kids-monster-tags{flex-wrap:wrap;gap:8px;display:flex}.kids-skill-list span,.kids-monster-tags span{color:#0f172a;background:#ffffffeb;border-radius:999px;align-items:center;min-height:32px;padding:0 10px;font-size:13px;font-weight:950;display:inline-flex}.kids-monster-arena{border:1px solid var(--kids-border);background:var(--kids-panel);box-shadow:var(--shadow);border-radius:8px;grid-template-columns:minmax(170px,.3fr) minmax(0,.7fr);gap:18px;margin-top:18px;padding:18px;display:grid}.kids-monster-picker{grid-template-columns:repeat(3,minmax(0,1fr));align-content:start;gap:8px;display:grid}.kids-monster-picker button{border:2px solid var(--kids-border);background:var(--kids-bg);min-height:74px;color:var(--kids-text);cursor:pointer;border-radius:8px;align-content:center;justify-items:center;gap:4px;font-weight:950;display:grid}.kids-monster-picker button.active{border-color:var(--theme-main);background:var(--theme-soft);color:var(--theme-main)}.kids-monster-picker span{font-size:30px;line-height:1}.kids-monster-picker small{color:var(--kids-muted);font-weight:950}.kids-monster-stage{align-content:start;gap:14px;display:grid}.kids-monster-battle{grid-template-columns:132px minmax(0,1fr);align-items:center;gap:16px;display:grid}.kids-monster-glyph{border:5px solid var(--theme-border);background:linear-gradient(135deg, #ffffffe6, #ffffff8c), var(--theme-soft);color:#0f172a;border-radius:8px;place-items:center;width:132px;height:132px;font-size:78px;font-weight:950;display:grid;box-shadow:inset 0 -10px #0f172a14}.kids-monster-copy{gap:8px;min-width:0;display:grid}.kids-monster-copy h2{color:var(--kids-text);margin:0;font-size:clamp(24px,4vw,38px);font-weight:950;line-height:1.08}.kids-monster-copy p,.kids-monster-reward{color:var(--kids-muted);margin:0;font-size:16px;font-weight:900;line-height:1.45}.kids-code-chain{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;display:grid}.kids-code-step{color:#fff;cursor:pointer;border:3px solid #ffffff94;border-radius:8px;align-content:center;justify-items:center;gap:5px;min-height:86px;display:grid;box-shadow:inset 0 -8px #0f172a21}.kids-code-step strong{font-size:26px;line-height:1}.kids-code-step span{font-size:28px;font-weight:950;line-height:1}.kids-learning{background:#0f172a;border-radius:8px;min-height:calc(100dvh - 142px);padding:18px}.kids-learning-toolbar{background:#0f172ac7;border:1px solid #ffffff1f;border-radius:8px;grid-template-columns:minmax(130px,auto) minmax(0,1fr) minmax(130px,auto);align-items:center;gap:12px;margin-bottom:20px;padding:12px;display:grid}.kids-level-title{color:#fff;text-align:center;justify-content:center;align-items:center;gap:10px;min-width:0;font-size:clamp(20px,3vw,30px);font-weight:950;display:inline-flex}.kids-level-title svg{color:var(--theme-main)}.kids-learning-tip{border:1px solid var(--theme-border);color:#fff;text-align:center;background:#0f172aa3;border-radius:999px;width:fit-content;max-width:100%;margin:0 auto 20px;padding:10px 18px;font-size:18px;font-weight:950}.kids-card-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;display:grid}.kids-flip-card{cursor:pointer;perspective:1000px;background:0 0;border:0;height:242px;padding:0}.kids-flip-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .55s cubic-bezier(.2,.7,.2,1);display:block;position:relative}.kids-flip-card.flipped .kids-flip-inner{transform:rotateY(180deg)}.kids-card-face{color:#fff;backface-visibility:hidden;border:4px solid #ffffff8c;border-radius:8px;align-content:center;justify-items:center;gap:10px;padding:18px;display:grid;position:absolute;inset:0;box-shadow:inset 0 -10px #0f172a1f,0 14px 24px #00000038}.kids-card-back{color:#111827;transform:rotateY(180deg);background:#fff!important}.kids-card-emoji{background:#fff3;border-radius:999px;min-height:26px;padding:4px 9px;font-size:15px;font-weight:950}.kids-card-face strong{font-size:clamp(52px,7vw,78px);font-weight:950;line-height:1}.kids-card-face small{max-width:160px;color:inherit;opacity:.95;text-align:center;font-size:15px;font-weight:950;line-height:1.25}.kids-card-key{color:#fff;background:#0f172a;border-radius:8px;justify-content:center;align-items:center;min-width:74px;min-height:50px;padding:0 12px;font-size:28px;font-weight:950;display:inline-flex}.kids-card-skill{color:#0f172a;background:#0f172a1a;border-radius:999px;align-items:center;min-height:30px;padding:0 10px;font-size:13px;font-weight:950;display:inline-flex}.kids-card-red{background:#ef4444}.kids-card-yellow{background:#eab308}.kids-card-gold{background:#f59e0b}.kids-card-green{background:#22c55e}.kids-card-blue{background:#38bdf8}.kids-card-orange{background:#f97316}.kids-card-brown{background:#92400e}.kids-card-slate{background:#475569}.kids-card-indigo{background:#6366f1}.kids-card-purple{background:#8b5cf6}.kids-card-rose{background:#f43f5e}.kids-card-teal{background:#14b8a6}.kids-spirit-img{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 10px 12px #442d1c2e);border:0;width:100%;height:100%;display:block}.kids-dex{background:radial-gradient(circle at 18% 0,#fffffff5,#0000 28rem),radial-gradient(circle at 96% 6%,#c6e0d85c,#0000 20rem),linear-gradient(#fffdf8 0%,#fffaf3 58%,#fff7e9 100%)}.kids-dex .kids-learning-toolbar{background:#fffdf8d1;border-color:#6c4e3129;box-shadow:0 12px 30px #54382314}.kids-dex .kids-level-title{color:#3f3328}.kids-dex .kids-elf-generation{background:#fffdf8d6;border-color:#6c4e3129;box-shadow:0 12px 32px #54382314}.kids-dex .kids-elf-generation-head span,.kids-dex .kids-elf-generation-head strong,.kids-dex .kids-elf-copy .kids-mini-kicker{color:#9b7652}.kids-dex .kids-elf-card{color:#3f3328;background:linear-gradient(#ffffffe0,#fff8edb8),#fffaf3;border:1px solid #6c4e3129;min-height:166px;padding:10px;box-shadow:0 10px 30px #54382314}.kids-dex .kids-elf-card:hover,.kids-dex .kids-elf-card.active{box-shadow:0 18px 38px #54382324}.kids-dex .kids-elf-card.active{outline:4px solid #d8a25438}.kids-dex .kids-elf-letter{color:#765d45;background:#ffffffad;justify-self:start;min-width:34px;min-height:28px;font-size:14px}.kids-elf-sprite{place-items:center;width:min(96px,88%);height:86px;display:grid}.kids-dex .kids-elf-card strong{color:#3f3328;font-size:22px}.kids-dex .kids-elf-card small{color:#6f5d4d;min-height:28px}.kids-dex .kids-elf-detail{color:#3f3328;background:linear-gradient(#ffffffe6,#fff8edc7),#fffaf3;border:1px solid #6c4e3129;box-shadow:0 18px 44px #573a221f}.kids-dex .kids-elf-portrait{background:#ffffff94;min-height:240px;box-shadow:inset 0 -8px #5438230a}.kids-elf-portrait-img{width:min(230px,82%);height:186px}.kids-dex .kids-elf-portrait i{color:#765d45;background:#fffaf3;margin-top:-24px;box-shadow:0 8px 18px #54382324}.kids-dex .kids-elf-copy p{color:#6f5d4d}.kids-dex .kids-skill-panel{background:#ffffff8f}.kids-dex .kids-skill-list span,.kids-dex .kids-monster-tags span{color:#4d3e31;background:#fffaf3eb}.kids-card-front{color:#3f3328;border-color:#6c4e3129;background:linear-gradient(#ffffffdb,#fff8edb8),#fffaf3!important}.kids-card-spirit{place-items:center;width:min(150px,88%);height:118px;display:grid}.kids-card-spirit .kids-spirit-img{object-fit:contain;filter:drop-shadow(0 10px 12px #442d1c2e);width:100%;max-width:100%;height:100%;max-height:100%;display:block}.kids-code-spirit{width:58px;height:54px}.kids-quiz{background:var(--theme-soft);border-radius:8px;place-items:center;min-height:calc(100dvh - 142px);padding:18px;display:grid}.kids-quiz-shell{width:min(760px,100%)}.kids-quiz-progress{border:1px solid var(--kids-border);background:#ffffffbd;border-radius:999px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;margin-bottom:16px;padding:10px;display:grid}.kids-icon-btn{border:1px solid var(--kids-border);width:42px;height:42px;color:var(--theme-main);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.kids-question-card{border:6px solid var(--theme-border);text-align:center;background:#fff;border-radius:8px;padding:clamp(22px,5vw,42px);position:relative;overflow:hidden;box-shadow:0 22px 52px #0f172a29}.kids-question-card h2{color:#0f172a;margin:12px 0 24px;font-size:clamp(24px,4vw,42px);font-weight:950;line-height:1.2}.kids-answer-grid{gap:12px;display:grid}.kids-answer-btn{color:#334155;cursor:pointer;text-align:left;background:#fff;border:3px solid #e2e8f0;border-radius:8px;grid-template-columns:minmax(0,1fr) 30px;align-items:center;gap:12px;min-height:66px;padding:12px 18px;font-size:20px;font-weight:950;display:grid}.kids-answer-btn:hover,.kids-answer-btn.selected{border-color:var(--theme-main);background:var(--theme-soft)}.kids-answer-btn.correct{background:#22c55e1f;border-color:#22c55e}.kids-answer-btn.wrong{background:#ef44441f;border-color:#ef4444}.kids-answer-btn i{border:4px solid #cbd5e1;border-radius:50%;width:30px;height:30px}.kids-feedback-overlay{z-index:2;background:#fffffff2;align-content:center;justify-items:center;gap:10px;animation:.28s ease-out kids-pop;display:grid;position:absolute;inset:0}.kids-feedback-mark{color:#fff;border-radius:50%;place-items:center;width:108px;height:108px;display:grid}.kids-feedback-overlay.correct .kids-feedback-mark{background:#22c55e}.kids-feedback-overlay.wrong .kids-feedback-mark{background:#ef4444}.kids-feedback-mark svg{width:58px;height:58px}.kids-feedback-overlay strong{color:#0f172a;font-size:34px;font-weight:950}.kids-feedback-overlay p{color:#64748b;margin:0;font-weight:900}.kids-celebration,.kids-confirm-screen{border-radius:8px;place-items:center;min-height:calc(100dvh - 142px);padding:24px;display:grid}.kids-celebration{background:linear-gradient(135deg,#fde047,#fb923c,#38bdf8)}.kids-celebration-card,.kids-confirm-box,.kids-assigned-note{text-align:center;background:#ffffffe0;border:1px solid #ffffff61;border-radius:8px;justify-items:center;gap:16px;width:min(620px,100%);padding:clamp(24px,5vw,44px);display:grid;box-shadow:0 22px 60px #0f172a38}.kids-trophy,.kids-confirm-icon{color:#d97706;background:#fff;border-radius:28px;place-items:center;width:112px;height:112px;font-size:26px;font-weight:950;animation:2.2s ease-in-out infinite kids-bounce;display:grid}.kids-celebration-card p,.kids-confirm-box p{color:#475569;margin:0;font-size:20px;font-weight:900;line-height:1.4}.kids-celebration-card strong{color:#d97706}.kids-confirm-screen{background:#0f172ac7}.kids-confirm-box h2{color:#0f172a;margin:0;font-size:28px;font-weight:950}.kids-confirm-actions{gap:10px;width:100%;display:grid}.kids-primary-btn,.kids-secondary-btn,.kids-danger-btn{cursor:pointer;border:2px solid #0000;border-radius:999px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:0 18px;font-weight:950;transition:transform .16s,background .16s;display:inline-flex}.kids-primary-btn{background:var(--theme-main);color:#fff}.kids-primary-btn:hover{transform:translateY(-2px)}.kids-secondary-btn{background:var(--kids-bg);border-color:var(--kids-border);color:var(--kids-text)}.kids-danger-btn{color:#fff;background:#ef4444}.kids-assigned-note{margin:0 auto 18px}.kids-assigned-note h1{color:var(--kids-text)}.kids-assigned-note p{color:var(--kids-muted)}.kids-page--dark .kids-map-header h1{color:#e0f2fe}.kids-page--dark .kids-map-header p{color:#bae6fd}.kids-page--dark .kids-question-card,.kids-page--dark .kids-answer-btn,.kids-page--dark .kids-celebration-card,.kids-page--dark .kids-confirm-box,.kids-page--dark .kids-assigned-note,.kids-page--dark .kids-monster-arena{background:#1f2937}.kids-page--dark .kids-question-card h2,.kids-page--dark .kids-answer-btn,.kids-page--dark .kids-confirm-box h2,.kids-page--dark .kids-feedback-overlay strong{color:#f8fafc}.kids-page--dark .kids-monster-glyph{background:linear-gradient(135deg, #1f2937eb, #0f172ab3), var(--theme-soft);color:#f8fafc}@keyframes kids-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes kids-pop{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}@media (width<=1024px){.kids-level-path:before{left:30px}.kids-level-node,.kids-level-node.left,.kids-level-node.right{justify-content:flex-start;padding-left:52px}.kids-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.kids-dex-layout{grid-template-columns:1fr}.kids-elf-detail{position:static}.kids-elf-row{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width<=767px){.kids-page{min-height:auto}.kids-map-header h1{font-size:34px}.kids-bag{border-radius:22px;width:76px;height:76px}.kids-level-path:before{display:none}.kids-level-node,.kids-level-node.left,.kids-level-node.right{padding-left:0}.kids-level-card{grid-template-columns:62px minmax(0,1fr);width:100%;padding:14px}.kids-level-mascot{border-radius:18px;width:62px;height:62px}.kids-learning,.kids-dex{padding:12px}.kids-elf-row{grid-template-columns:repeat(3,minmax(0,1fr))}.kids-elf-card{min-height:116px;padding:10px 8px}.kids-elf-card strong{font-size:34px}.kids-monster-arena{grid-template-columns:1fr;padding:12px}.kids-monster-battle{text-align:center;grid-template-columns:1fr;justify-items:center}.kids-code-chain{grid-template-columns:repeat(3,minmax(0,1fr))}.kids-learning-toolbar{grid-template-columns:1fr}.kids-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.kids-flip-card{height:210px}.kids-card-face strong{font-size:54px}.kids-quiz-progress{border-radius:8px;grid-template-columns:auto minmax(0,1fr)}.kids-quiz-progress span{text-align:center;grid-column:1/-1}.kids-answer-btn{min-height:58px;font-size:17px}}@media (width<=440px){.kids-elf-row,.kids-monster-picker,.kids-code-chain{grid-template-columns:repeat(2,minmax(0,1fr))}.kids-card-grid{grid-template-columns:1fr}}*,:before,:after{box-sizing:border-box}:root{--bg-color:#f4f7f6;--text-color:#333;--card-bg:#fff;--nav-bg:#fff;--border-color:#e0e0e0;--primary-color:#007bff;--primary-hover:#0056b3;--nav-text:#666;--nav-active:#007bff;--shadow:0 2px 10px #0000000d}[data-theme=dark]{--bg-color:#121212;--text-color:#e0e0e0;--card-bg:#1e1e1e;--nav-bg:#1e1e1e;--border-color:#333;--primary-color:#4a90e2;--primary-hover:#357abd;--nav-text:#aaa;--nav-active:#4a90e2;--shadow:0 2px 10px #00000080}button,input,textarea,select{font-family:inherit}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-color);color:var(--text-color);min-height:100vh;margin:0;padding:0;font-family:Inter,Noto Sans HK,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:background-color .3s,color .3s}.card{background-color:var(--card-bg);box-shadow:var(--shadow);border:1px solid var(--border-color);border-radius:12px;margin-bottom:20px;padding:20px}.app-container{flex-direction:column;width:100%;max-width:1440px;min-height:100vh;margin:0 auto;display:flex}.auth-container{box-sizing:border-box;justify-content:center;align-items:center;width:100%;margin-top:30px;padding:0 20px;display:flex}.auth-box{background:var(--card-bg);color:var(--text-color);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:400px;padding:40px;transition:background .3s,color .3s,border-color .3s;box-shadow:0 8px 24px #0000001a}.auth-box h2{text-align:center;margin-top:0;margin-bottom:25px}.input-group{margin-bottom:20px}.input-group label{color:var(--text-color);margin-bottom:8px;font-size:.9rem;font-weight:700;display:block}.input-group input{box-sizing:border-box;background:var(--bg-color);width:100%;color:var(--text-color);border:1px solid var(--border-color);border-radius:8px;padding:12px;font-size:16px;transition:background .3s,color .3s}.input-group input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #007bff33}.school-notice{color:var(--nav-text);background-color:var(--bg-color);border:1px solid var(--border-color);border-left:4px solid #ffba08;border-radius:6px;margin-top:12px;padding:10px;font-size:.85rem;line-height:1.4}.submit-btn{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:10px;padding:12px;font-size:16px;font-weight:700;transition:opacity .2s}.submit-btn:hover{opacity:.9}.submit-btn:disabled{cursor:not-allowed;background:#9e9e9e}.message-box{border-radius:6px;margin-bottom:20px;padding:10px;font-size:.9rem;font-weight:700}.message-box.error{color:#e53935;background-color:#e539351a;border:1px solid #e539354d}.message-box.success{color:#43a047;background-color:#43a0471a;border:1px solid #43a0474d}
