html{min-height:100%}body{min-width:320px;min-height:100svh;margin:0;font-family:ui-rounded,Arial Rounded MT Bold,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{min-height:100svh}:root{--ink:#392f3a;--sky:#aee4f8;--grass:#74cf83;--cream:#fff8dc;--yellow:#ffd35d;--teal:#62bda7;--purple:#8a80da;--coral:#f26e6e;--white:#fff;--shadow:0 12px 0 #392f3a1f;--tap:64px;color:var(--ink);background:#d9f3ff}*{box-sizing:border-box}button{font:inherit;color:inherit;-webkit-tap-highlight-color:transparent}.start-shell,.jump-shell{background:linear-gradient(#d9f3ff 0%,#bceaf8 52%,#d2f5d7 53% 100%);min-height:100svh;padding:82px 14px 14px}.start-shell{background:radial-gradient(circle at 11% 10%,#fff5b7f5 0 58px,#0000 59px),linear-gradient(#d9f3ff 0%,#bceaf8 52%,#d2f5d7 53% 100%);place-items:center;display:grid}.start-hero{border:5px solid var(--ink);width:min(1040px,100%);min-height:min(650px,100svh - 112px);box-shadow:var(--shadow);background:#fff8dceb;border-radius:8px;grid-template-columns:.92fr 1.08fr;align-items:center;gap:24px;padding:30px;display:grid}.start-copy h1{letter-spacing:0;max-width:7em;margin:0;font-size:clamp(42px,5.8vw,66px);line-height:1}.start-copy p{margin:18px 0 26px;font-size:clamp(24px,3vw,36px);font-weight:900;line-height:1.18}.start-button{border:5px solid var(--ink);background:var(--yellow);min-width:min(380px,100%);min-height:96px;box-shadow:var(--shadow);cursor:pointer;border-radius:8px;font-size:36px;font-weight:900}.start-secondary{flex-wrap:wrap;gap:12px;margin-top:16px;display:flex}.start-preview{border:5px solid var(--ink);width:100%;min-height:320px;box-shadow:var(--shadow);background:var(--sky);border-radius:8px}.preview-qingqing{animation:2s ease-in-out infinite previewJump}.preview-star{animation:2s ease-in-out infinite rewardJump}.preview-frog{animation:1.2s ease-in-out infinite readyBounce}.preview-label{fill:var(--ink);paint-order:stroke;stroke:#fff;stroke-width:5px;stroke-linejoin:round;font-size:28px;font-weight:900}.jump-shell{touch-action:none;place-items:stretch center;display:grid;overflow:hidden}.jump-stage{border:5px solid var(--ink);background:var(--sky);width:min(1120px,100%);height:min(680px,100svh - 96px);min-height:0;box-shadow:var(--shadow);border-radius:8px;grid-template-rows:auto minmax(0,1fr) auto;display:grid;position:relative;overflow:hidden}.jump-hud{border-bottom:5px solid var(--ink);background:#ffffffd1;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;min-height:84px;padding:12px 16px;display:grid}.jump-level-chip{align-items:center;gap:12px;min-width:0;display:flex}.jump-level-chip span{border:4px solid var(--ink);background:var(--yellow);border-radius:50%;flex:0 0 62px;place-items:center;width:62px;height:62px;font-size:29px;font-weight:900;display:grid}.jump-level-chip h1,.jump-overlay h2{letter-spacing:0;margin:0;font-weight:900;line-height:1.05}.jump-level-chip h1{font-size:30px}.jump-level-chip p{margin:4px 0 0;font-size:18px;font-weight:900}.jump-status{border:4px solid var(--ink);background:#fff6c9;border-radius:8px;place-items:center;min-width:112px;min-height:58px;font-size:21px;font-weight:900;display:grid}.jump-controls{gap:8px;display:flex}.jump-controls button{border:4px solid var(--ink);background:var(--white);cursor:pointer;border-radius:8px;min-width:72px;min-height:56px;font-weight:900;box-shadow:0 5px #392f3a24}.jump-playfield{touch-action:none;-webkit-user-select:none;user-select:none;cursor:pointer;contain:paint;outline:none;width:100%;height:100%;min-height:0;display:block;transform:translateZ(0)}.jump-player.jumping{filter:drop-shadow(0 0 .4rem #fff36d)}.jump-zone-marker{pointer-events:none;animation:1.1s ease-in-out infinite zonePulse}.jump-zone-label{fill:var(--ink);paint-order:stroke;stroke:#fff;stroke-width:4px;stroke-linejoin:round;font-size:24px;font-weight:900}.puddle-art{filter:drop-shadow(0 4px #392f3a1a)}.jump-player.dirty{animation:.36s ease-in-out 2 gentleNo}.jump-message{z-index:4;border:5px solid var(--ink);text-align:center;pointer-events:none;background:#fff;border-radius:22px;place-items:center;width:min(520px,100% - 260px);min-height:58px;padding:8px 18px;font-size:24px;font-weight:900;display:grid;position:absolute;top:128px;left:50%;transform:translate(-50%);box-shadow:0 6px #392f3a1f}.jump-overlay{z-index:8;background:#392f3a33;place-items:center;padding:18px;display:grid;position:absolute;inset:0}.jump-overlay>div{border:5px solid var(--ink);width:min(420px,100%);box-shadow:var(--shadow);text-align:center;background:#fff8dc;border-radius:8px;place-items:center;gap:14px;padding:24px;display:grid}.jump-overlay h2{font-size:42px}.jump-overlay p{margin:0;font-size:24px;font-weight:900}.privacy-note{text-align:center;color:#392f3ac7;padding:8px 12px 12px;font-size:15px;font-weight:850}.app-shell{background:linear-gradient(#d9f3ff 0%,#bceaf8 49%,#d2f5d7 50% 100%);place-items:stretch center;min-height:100svh;padding:82px 14px 14px;display:grid;overflow:hidden}.game-layout{grid-template-columns:minmax(0,1fr) 190px;gap:14px;width:min(1240px,100%);height:min(760px,100svh - 96px);min-height:0;display:grid}.stage-panel,.control-dock,.sticker-card,.parent-modal{border:5px solid var(--ink);box-shadow:var(--shadow);border-radius:8px}.stage-panel{background:var(--sky);grid-template-rows:auto minmax(0,1fr);min-width:0;display:grid;position:relative;overflow:hidden}.top-hud{border-bottom:5px solid var(--ink);background:#ffffffc7;justify-content:space-between;align-items:center;gap:12px;min-height:94px;padding:12px 16px;display:flex}.level-chip{align-items:center;gap:12px;min-width:0;display:flex}.level-badge{border:4px solid var(--ink);background:var(--yellow);border-radius:50%;flex:0 0 62px;place-items:center;width:62px;height:62px;font-size:29px;font-weight:900;display:grid}.level-chip h1,.sticker-page h1,.parent-modal h2,.sticker-card h2{letter-spacing:0;margin:0;font-weight:900;line-height:1.05}.level-chip h1{font-size:30px}.level-chip p{margin:5px 0 0;font-size:19px;font-weight:850}.tiny-status{border:4px solid var(--ink);background:var(--cream);border-radius:8px;place-items:center;min-width:76px;min-height:58px;font-size:24px;font-weight:900;display:grid}.scene-frame{width:100%;height:100%;min-height:0;position:relative;overflow:hidden}.game-scene{touch-action:none;-webkit-user-select:none;user-select:none;contain:paint;width:100%;height:100%;min-height:0;display:block;transform:translateZ(0)}.character,.target,.advanced-choice,.memory-pad,.free-puddle{cursor:pointer;outline:none}.static-character{pointer-events:none;cursor:default}.character:focus-visible,.target:focus-visible,.advanced-choice:focus-visible,.memory-pad:focus-visible,.free-puddle:focus-visible{filter:drop-shadow(0 0 .55rem #fff)}.active-character{filter:drop-shadow(0 0 .45rem #fff36d)}.ability-ready{animation:.9s ease-in-out infinite readyBounce}.oops-character{animation:.36s ease-in-out 2 gentleNo}.scene-label,.map-number,.guide-text{fill:var(--ink);paint-order:stroke;stroke:#fff;stroke-width:4px;stroke-linejoin:round;font-weight:900}.scene-label{font-size:22px}.map-number{font-size:26px}.guide-bubble{pointer-events:none}.scene-message{z-index:4;border:5px solid var(--ink);text-align:center;pointer-events:none;background:#fff;border-radius:24px;place-items:center;width:min(530px,100% - 260px);min-height:66px;padding:8px 18px;font-size:24px;font-weight:900;display:grid;position:absolute;top:42px;left:50%;transform:translate(-50%);box-shadow:0 6px #392f3a1f}.oops-message{background:#fff1df;animation:.36s ease-in-out gentleNo}.guide-text{font-size:24px}.oops-bubble{animation:.36s ease-in-out gentleNo}.target,.memory-pad,.free-puddle{transition:opacity .16s}.done-target{opacity:.7}.current-target{filter:drop-shadow(0 0 .65rem #fff36d)}.guide-hand{paint-order:stroke;stroke:#fff;stroke-width:4px;font-size:38px;animation:.85s ease-in-out infinite handTap}.hidden-step{opacity:0}.scene-effect{pointer-events:none;animation:.9s ease-out both popFade}.reward-pop{z-index:5;border:5px solid var(--ink);min-width:210px;min-height:178px;box-shadow:var(--shadow);text-align:center;background:#fff6c9;border-radius:8px;place-items:center;gap:8px;padding:14px;font-size:28px;font-weight:900;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.reward-next{background:var(--yellow);min-width:138px}.reward-art{width:96px;height:96px;animation:.58s ease-out both rewardJump}.reward-art svg{width:100%;height:100%;display:block}.control-dock{background:#fff8dc;align-content:center;gap:18px;padding:16px 12px;display:grid}.character-switch{grid-template-columns:1fr 1fr;gap:8px;display:grid}.dock-button,.mini-button,.big-button,.danger-button,.setting-toggle,.segmented button,.icon-button,.parent-gate,.level-dot{min-height:var(--tap);border:4px solid var(--ink);background:var(--white);cursor:pointer;border-radius:8px;font-weight:900;box-shadow:0 7px #392f3a29}.dock-button:active,.mini-button:active,.big-button:active,.danger-button:active,.setting-toggle:active,.segmented button:active,.parent-gate:active,.level-dot:active{transform:translateY(3px);box-shadow:0 4px #392f3a29}.dock-button{width:100%;min-height:104px;padding:10px;font-size:23px}.mode-status{color:#392f3ac7;background:#ffffff6b;border:4px dashed #392f3a59;border-radius:8px;place-items:center;min-height:78px;font-size:20px;font-weight:900;display:grid}.mini-button{min-height:58px;font-size:18px}.selected,.dock-button.selected{background:var(--teal);color:#fff}.sound-button{background:#d8d2ff}.next-button,.reward-next{background:#ffd35d}.level-strip{grid-template-columns:repeat(3,1fr);gap:7px;display:grid}.level-dot{min-height:46px;padding:0;font-size:17px}.level-dot.done{background:#c5f4c8}.level-dot.current{background:var(--yellow)}.level-dot.progress{background:#d8d2ff}.parent-gate{z-index:20;background:#fff;min-width:96px;min-height:58px;padding-inline:16px;font-size:18px;position:fixed;top:16px;right:16px}.parent-gate.holding{background:var(--yellow)}.modal-backdrop{z-index:30;background:#392f3a38;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.parent-modal{background:var(--cream);width:min(520px,100%);max-height:calc(100svh - 36px);padding:10px;overflow:auto}.modal-row,.setting-row,.sticker-bar{justify-content:space-between;align-items:center;gap:14px;display:flex}.parent-modal h2{font-size:28px}.icon-button{width:58px;min-width:58px;min-height:58px;font-size:32px;line-height:1}.setting-row{border-top:3px solid #392f3a26;min-height:54px;font-size:22px;font-weight:900}.setting-toggle{background:#d8d2ff;min-width:104px;min-height:52px}.setting-toggle.active,.danger-button{background:#ffb2a3}.segmented button.selected{background:var(--teal);color:#fff}.segmented{gap:7px;display:flex}.segmented button{min-width:82px;min-height:46px}.danger-button{width:100%;min-height:54px;margin-top:10px;font-size:21px}.parent-levels{border-top:3px solid #392f3a26;padding-top:12px}.parent-levels h3{margin:0;font-size:24px}.parent-level-strip{grid-template-columns:repeat(6,1fr);margin-top:10px}.parent-level-strip .level-dot{min-height:44px;font-size:16px}.moving-bridge-art{animation:1.4s ease-in-out infinite bridgeSlide}.sticker-page{background:linear-gradient(#d9f3ff 0% 34%,#d2f5d7 35%);min-height:100svh;padding:18px}.sticker-view .parent-gate{top:96px}.sticker-bar{max-width:1050px;margin:0 auto 16px}.sticker-bar h1{font-size:44px}.big-button{background:var(--yellow);min-width:124px;padding-inline:16px;font-size:22px}.sticker-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:13px;max-width:1050px;margin:0 auto;display:grid}.sticker-card{text-align:center;background:#fff;justify-items:center;gap:5px;min-height:182px;padding:12px;display:grid}.sticker-art{width:88px;height:88px}.sticker-art svg{width:100%;height:100%;display:block}.locked-card{background:#edf2f4}.locked-art{opacity:.36;filter:grayscale()}.sticker-card h2{font-size:22px}.sticker-card p{margin:0;font-size:15px;font-weight:800}@keyframes popFade{0%{opacity:0;transform:scale(.25)}20%{opacity:1;transform:scale(1.05)}to{opacity:0;transform:translateY(-30px)scale(1)}}@keyframes targetGlow{0%,to{filter:drop-shadow(0 0 .25rem #fff36d);opacity:1}50%{filter:drop-shadow(0 0 .75rem #fff36d);opacity:.82}}@keyframes handTap{0%,to{opacity:1}50%{opacity:.45}}@keyframes readyBounce{0%,to{filter:drop-shadow(0 0 .25rem #fff36d)}50%{filter:drop-shadow(0 0 .85rem #fff36d)}}@keyframes gentleNo{0%,to{opacity:1}25%{opacity:.65}75%{opacity:.65}}@keyframes rewardJump{0%{transform:translateY(18px)scale(.72)}70%{transform:translateY(-6px)scale(1.08)}to{transform:translateY(0)scale(1)}}@keyframes previewJump{0%,to{transform:translate(172px,220px)}45%{transform:translate(245px,145px)}72%{transform:translate(332px,218px)}}@keyframes bridgeSlide{0%,to{transform:translate(-10px)}50%{transform:translate(10px)}}@keyframes zonePulse{0%,to{opacity:.82}50%{opacity:1}}@media (width<=900px){.start-shell,.jump-shell{padding:72px 8px 8px}.start-hero{grid-template-columns:1fr;gap:14px;min-height:calc(100svh - 84px);padding:18px}.start-preview{min-height:260px}.jump-stage{height:calc(100svh - 84px);min-height:0}.jump-hud{grid-template-columns:minmax(0,1fr) auto auto;align-items:stretch;gap:8px;min-height:74px;padding:8px}.jump-controls{display:flex}.jump-controls button{min-width:62px;min-height:50px;font-size:18px}.jump-status{min-width:96px;min-height:50px;font-size:18px}.jump-level-chip span{flex-basis:52px;width:52px;height:52px;font-size:24px}.jump-level-chip h1{font-size:24px}.jump-level-chip p{font-size:15px}.jump-message{width:min(480px,100% - 120px);min-height:52px;font-size:22px;top:118px}.app-shell{padding:72px 8px 8px;overflow:auto}.game-layout{grid-template-rows:minmax(0,1fr) auto;grid-template-columns:1fr;min-height:calc(100svh - 80px)}.control-dock{grid-template-columns:repeat(4,minmax(0,1fr));align-content:stretch}.dock-button,.mini-button{min-height:56px;font-size:17px}.level-dot{min-height:42px}.top-hud{min-height:82px;padding:8px 10px}.level-badge{flex-basis:54px;width:54px;height:54px;font-size:24px}.level-chip h1{font-size:25px}.level-chip p{font-size:17px}.tiny-status{min-width:68px;min-height:52px;font-size:21px}.parent-gate{min-height:52px;top:10px;right:10px}.parent-level-strip{grid-template-columns:repeat(4,1fr)}}@media (width>=901px) and (width<=1100px){.app-shell{padding:72px 8px 8px}.game-layout{grid-template-columns:minmax(0,1fr) 168px;gap:8px;height:min(680px,100svh - 84px)}.top-hud{min-height:74px;padding:8px 10px}.level-badge{flex-basis:54px;width:54px;height:54px;font-size:24px}.level-chip h1{font-size:25px}.level-chip p{font-size:17px}.tiny-status{min-width:68px;min-height:52px;font-size:21px}.scene-message{width:min(520px,100% - 180px);min-height:58px;font-size:22px;top:34px}.control-dock{gap:10px;padding:10px 8px}.dock-button,.mode-status{min-height:78px;font-size:21px}.parent-gate{min-height:50px;top:8px;right:8px}.sticker-view .parent-gate{top:82px}.parent-modal{width:min(560px,100vw - 24px);max-height:calc(100svh - 24px);padding:8px}.parent-modal h2{font-size:26px}.icon-button{width:52px;min-width:52px;min-height:52px}.setting-row{min-height:44px;font-size:20px}.parent-modal .setting-toggle,.parent-modal .segmented button{min-height:42px}.parent-modal .danger-button{min-height:52px}}@media (orientation:portrait) and (width<=900px){.stage-panel{min-height:66svh}.control-dock{grid-template-columns:1fr}.jump-level-chip h1{font-size:21px}.jump-level-chip p{font-size:14px}.jump-hud{grid-template-columns:1fr}.jump-message{width:calc(100% - 60px);font-size:20px;top:178px}.sticker-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=560px){.sticker-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){.preview-qingqing,.preview-star,.preview-frog,.moving-bridge-art,.jump-zone-marker,.ability-ready,.scene-effect{animation:none}}.reduce-motion .preview-qingqing,.reduce-motion .preview-star,.reduce-motion .preview-frog,.reduce-motion .moving-bridge-art,.reduce-motion .jump-zone-marker,.reduce-motion .ability-ready,.reduce-motion .scene-effect{animation:none}
