:root{--bg: #f6efe3;--bg-dot: rgba(51, 40, 75, .07);--surface: #fffdf8;--surface-2: #efe5d2;--text: #33284b;--text-muted: #877a9b;--accent: #7c5cff;--accent-2: #ff7fa5;--danger: #ef4757;--ink: #33284b;--gold: #ffb62e;--game-c1: #ff5b4d;--game-c2: #4a94ff;--game-c3: #3bce6b;--game-c4: #ffc72e;--game-c5: #9d66ff;--game-c6: #ff8a3c;--game-c7: #23c3e6;--game-c8: #ff6fae;--game-c9: #c9e05e;--radius: 20px;--header-h: 56px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--font-display: "Fredoka", "Baloo 2", -apple-system, "Segoe UI", system-ui, sans-serif}@media (prefers-color-scheme: dark){:root{--bg: #1e1832;--bg-dot: rgba(255, 255, 255, .05);--surface: #2c2547;--surface-2: #3a3160;--text: #f1ecff;--text-muted: #a99cc7;--ink: #120e22;--border: rgba(255, 255, 255, .1)}}:root[data-bg-theme=nacht]{--bg: #101b33;--bg-dot: rgba(255, 255, 255, .1);--bg-glow-1: #2f5fd8;--bg-glow-2: #7c3ae2;--surface: #1c2a4a;--surface-2: #16223d;--text: #eef2ff;--text-muted: #9fb0d6;--ink: #0a1226}:root[data-bg-theme=ruimte]{--bg: #0b0616;--bg-dot: rgba(200, 180, 255, .12);--bg-glow-1: #8a2be2;--bg-glow-2: #ff3d81;--surface: #1a1030;--surface-2: #251640;--text: #f3ecff;--text-muted: #b8a6dc;--ink: #050210}:root[data-bg-theme=oceaan-bg]{--bg: #dbf1ef;--bg-dot: rgba(20, 80, 90, .08);--bg-glow-1: #2bb3a3;--bg-glow-2: #1f7ae0;--surface: #f2fbfa;--surface-2: #c9e9e4;--text: #1c3b3f;--text-muted: #5f8286;--ink: #173032}:root[data-bg-theme=snoep]{--bg: #ffe6f0;--bg-dot: rgba(120, 40, 80, .07);--bg-glow-1: #ff8ac0;--bg-glow-2: #ffb27a;--surface: #fff6fb;--surface-2: #ffdbe9;--text: #5a2340;--text-muted: #9c6d84;--ink: #4a1d34}:root[data-bg-theme=bos]{--bg: #e6efdd;--bg-dot: rgba(40, 80, 30, .09);--bg-glow-1: #5fa35a;--bg-glow-2: #9bcf6a;--surface: #f4f8ee;--surface-2: #d3e4c3;--text: #243d1c;--text-muted: #5f7a52;--ink: #1d3016}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;height:100%;height:100dvh;overflow:hidden;overscroll-behavior:none}body{font-family:var(--font-display);background:var(--bg);color:var(--text);-webkit-user-select:none;user-select:none;touch-action:manipulation}#app{position:relative;height:100%;height:100dvh;max-width:480px;margin:0 auto;background:radial-gradient(circle at 15% -5%,color-mix(in srgb,var(--bg-glow-1, var(--accent)) 12%,transparent),transparent 40%),radial-gradient(circle at 90% 110%,color-mix(in srgb,var(--bg-glow-2, var(--accent-2)) 11%,transparent),transparent 45%),radial-gradient(var(--bg-dot) 1.5px,transparent 1.6px) 0 0 / 22px 22px,var(--bg);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 0 60px #140c282e}.screen{flex:1;min-height:0;display:flex;flex-direction:column;padding:calc(var(--safe-top) + 8px) 16px calc(var(--safe-bottom) + 16px);gap:14px}.home-screen,.levelselect-screen,.settings-screen{overflow-y:auto}.play-screen{overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:var(--header-h)}.brand{display:flex;align-items:center;gap:10px}.brand-logo{font-size:1.7rem;display:inline-block;transform:rotate(-10deg);filter:drop-shadow(2px 3px 0 rgba(51,40,75,.25));animation:brand-wiggle 5s ease-in-out infinite}@keyframes brand-wiggle{0%,88%,to{transform:rotate(-10deg)}92%{transform:rotate(6deg) scale(1.08)}96%{transform:rotate(-14deg)}}.brand-name{font-size:1.55rem;font-weight:700;letter-spacing:.5px;background:linear-gradient(100deg,var(--accent) 20%,var(--accent-2) 80%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.header-right{display:flex;align-items:center;gap:8px}.coins{font-weight:600;font-size:.95rem;background:var(--surface);padding:7px 14px;border-radius:999px;border:2px solid var(--ink);box-shadow:0 3px 0 var(--ink)}.icon-btn{background:var(--surface);width:44px;height:44px;border-radius:14px;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);border:2px solid var(--ink);box-shadow:0 3px 0 var(--ink);transition:transform .08s ease,box-shadow .08s ease}.icon-btn:active{transform:translateY(3px);box-shadow:0 0 0 var(--ink)}.level-header-title{font-size:1.25rem;font-weight:600;flex:1;text-align:center;letter-spacing:.3px}.cloud-status{margin:0;font-size:.8rem;color:var(--text-muted);text-align:right;font-weight:500}.section-title{margin:6px 0 2px;font-size:1.15rem;font-weight:600;letter-spacing:.3px;display:flex;align-items:center;gap:10px}.section-title:after{content:"";flex:1;height:4px;border-radius:999px;background:repeating-linear-gradient(90deg,var(--ink) 0 8px,transparent 8px 16px);opacity:.18}.game-grid{display:flex;flex-direction:column;gap:16px}.game-card{display:flex;align-items:center;gap:14px;padding:16px;border:2px solid var(--ink);border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:left;color:var(--text);font-family:inherit;box-shadow:0 5px 0 var(--ink);transition:transform .08s ease,box-shadow .08s ease;animation:card-in .4s cubic-bezier(.34,1.4,.64,1) backwards}.game-card:nth-child(1){animation-delay:.04s}.game-card:nth-child(2){animation-delay:.1s}.game-card:nth-child(3){animation-delay:.16s}.game-card:nth-child(4){animation-delay:.22s}@keyframes card-in{0%{opacity:0;transform:translateY(14px) scale(.97)}}.game-card:active{transform:translateY(5px);box-shadow:0 0 0 var(--ink)}.game-icon{font-size:2.5rem;width:66px;height:66px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 22%,var(--surface));border:2px solid var(--ink);border-radius:18px;flex-shrink:0;transform:rotate(-5deg);box-shadow:inset 0 -4px #33284b1f}.game-info{flex:1;min-width:0}.game-title{font-size:1.2rem;font-weight:600;letter-spacing:.2px}.game-tagline{font-size:.85rem;color:var(--text-muted);margin-top:2px;font-weight:500}.game-meta{display:inline-block;font-size:.75rem;color:var(--text);font-weight:600;margin-top:8px;padding:3px 10px;border-radius:999px;background:color-mix(in srgb,var(--accent) 18%,var(--surface));border:1.5px solid color-mix(in srgb,var(--accent) 55%,var(--ink))}.game-chevron{font-size:1.4rem;font-weight:600;color:var(--text);width:34px;height:34px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surface-2);border:2px solid var(--ink)}.footer-note{margin-top:auto;font-size:.75rem;color:var(--text-muted);text-align:center;padding-top:12px;font-weight:500}.level-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;padding-top:4px}.level-tile{position:relative;aspect-ratio:1;border:2px solid var(--ink);border-radius:18px;background:var(--surface);font-family:inherit;font-weight:600;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text);box-shadow:0 4px 0 var(--ink);transition:transform .08s ease,box-shadow .08s ease}.level-tile:active{transform:translateY(4px);box-shadow:0 0 0 var(--ink)}.level-tile.done{background:color-mix(in srgb,var(--accent) 24%,var(--surface))}.level-tile.locked{background:transparent;border-style:dashed;border-color:color-mix(in srgb,var(--ink) 40%,transparent);color:var(--text-muted);cursor:not-allowed;box-shadow:none;opacity:.75}.level-tile.locked:active{transform:none}.level-num{font-size:1.35rem}.level-lock{font-size:1.05rem;filter:grayscale(.4)}.stars{display:inline-flex;gap:2px}.star{color:color-mix(in srgb,var(--ink) 22%,transparent);line-height:1;text-shadow:none}.star.on{color:var(--gold);text-shadow:0 1.5px 0 rgba(51,40,75,.35)}.play-screen{gap:10px}.play-header{flex-shrink:0}.play-title{font-size:1.1rem;font-weight:600;flex:1;text-align:center;display:flex;flex-direction:column;line-height:1.15}.play-level{font-size:.75rem;color:var(--text-muted);font-weight:600;letter-spacing:.4px;text-transform:uppercase}.play-status{font-weight:600;font-size:.9rem;color:var(--accent);min-width:60px;text-align:right}.play-area{position:relative;flex:1;min-height:0;display:flex;flex-direction:column}.btn{border:2px solid var(--ink);border-radius:16px;padding:13px 18px;font-size:1rem;font-weight:600;font-family:inherit;letter-spacing:.3px;background:var(--surface);color:var(--text);cursor:pointer;box-shadow:0 4px 0 var(--ink);transition:transform .08s ease,box-shadow .08s ease}.btn:active{transform:translateY(4px);box-shadow:0 0 0 var(--ink)}.btn.primary{background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 82%,#fff),var(--accent));color:#fff;text-shadow:0 1px 0 rgba(51,40,75,.3)}.btn.danger{background:color-mix(in srgb,var(--danger) 12%,var(--surface));color:var(--danger);border-color:color-mix(in srgb,var(--danger) 55%,var(--ink));box-shadow:0 4px color-mix(in srgb,var(--danger) 55%,var(--ink))}.btn.danger:active{box-shadow:0 0 color-mix(in srgb,var(--danger) 55%,var(--ink))}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#18102c8c;display:flex;align-items:center;justify-content:center;z-index:50;opacity:0;transition:opacity .2s ease;padding:20px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-backdrop.show{opacity:1}.modal-card{background:var(--surface);border:2px solid var(--ink);border-radius:24px;padding:26px 22px;width:min(100%,340px);text-align:center;box-shadow:0 8px 0 var(--ink),0 24px 50px #0c061e66;transform:translateY(16px) scale(.96);transition:transform .22s cubic-bezier(.34,1.56,.64,1)}.modal-backdrop.show .modal-card{transform:translateY(0) scale(1)}.modal-title{margin:0 0 12px;font-size:1.45rem;font-weight:600;letter-spacing:.3px}.modal-body{margin:0 0 16px;color:var(--text-muted);font-weight:500}.modal-actions{display:flex;flex-direction:column;gap:12px}.win-body{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:18px}.win-lines{margin:0;font-weight:600;color:var(--text)}.win-sub{margin:0;color:var(--accent);font-weight:600;font-size:.9rem}.win-mascot{font-size:2rem;animation:mascot-cheer .7s ease}@keyframes mascot-cheer{0%{transform:scale(.4) rotate(-12deg);opacity:0}60%{transform:scale(1.18) rotate(6deg)}to{transform:scale(1) rotate(0);opacity:1}}.brand-mascot{display:inline-block;font-size:1.25rem;margin-left:6px;animation:mascot-bob 2.6s ease-in-out infinite}@keyframes mascot-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@media (prefers-reduced-motion: reduce){.brand-mascot{animation:none}}@keyframes pip-breathe{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-5px) scale(1.012)}}@keyframes pip-tail{0%,to{transform:rotate(0)}50%{transform:rotate(-4deg)}}@keyframes pip-blink{0%,92%,to{transform:scaleY(1)}96%{transform:scaleY(.08)}}@keyframes pip-bounce{0%,to{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-8px) rotate(1.5deg)}}.pip-cat{transform-box:fill-box;transform-origin:50% 100%;animation:pip-breathe 4.2s ease-in-out infinite}.pip-tail{transform-box:fill-box;transform-origin:88% 8%;animation:pip-tail 5s ease-in-out infinite}.pip-eyes{transform-box:fill-box;transform-origin:50% 45%;animation:pip-blink 6.5s ease-in-out infinite}.mascot-svg{display:inline-block;line-height:0}.mascot-svg svg{display:block}.brand-mascot-svg{display:inline-block;width:32px;margin-left:4px;flex-shrink:0;pointer-events:none}.brand-mascot-svg svg{width:100%;height:auto;overflow:visible}.win-mascot-svg{display:flex;align-items:center;justify-content:center;gap:4px}.win-mascot-svg .mascot-svg{width:84px}.win-mascot-svg .pip-cat{animation:pip-bounce 1.1s ease-in-out infinite}.mascot-prev-svg{overflow:hidden}.mascot-prev-svg .mascot-svg{width:48px;transform:translateY(6px)}@media (prefers-reduced-motion: reduce){.pip-cat,.pip-tail,.pip-eyes,.win-mascot-svg .pip-cat{animation:none}}.toast{position:fixed;left:50%;bottom:calc(var(--safe-bottom) + 24px);transform:translate(-50%) translateY(20px);background:var(--ink);color:#fff;padding:12px 22px;border-radius:999px;border:2px solid rgba(255,255,255,.25);font-weight:600;font-size:.9rem;opacity:0;pointer-events:none;transition:all .25s ease;z-index:60;box-shadow:0 8px 24px #0c061e66}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.settings-card{background:var(--surface);border:2px solid var(--ink);border-radius:var(--radius);padding:4px 16px;box-shadow:0 4px 0 var(--ink)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;font-weight:500}.settings-row+.settings-row{border-top:2px dashed color-mix(in srgb,var(--ink) 18%,transparent)}.settings-note{font-size:.82rem;color:var(--text-muted);margin:-4px 4px 0;font-weight:500}.cloud-pill{background:color-mix(in srgb,var(--accent) 16%,var(--surface));border:1.5px solid color-mix(in srgb,var(--accent) 55%,var(--ink));padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:600}.switch{width:54px;height:32px;border-radius:999px;border:2px solid var(--ink);background:var(--surface-2);position:relative;cursor:pointer;transition:background .2s ease;box-shadow:inset 0 2px 3px #33284b26}.switch.on{background:var(--accent)}.switch-knob{position:absolute;top:2px;left:2px;width:24px;height:24px;border-radius:50%;background:#fff;border:2px solid var(--ink);box-sizing:border-box;box-shadow:0 1.5px 0 var(--ink);transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.switch.on .switch-knob{transform:translate(22px)}.shop-screen{overflow-y:auto}.shop-list{display:flex;flex-direction:column;gap:12px}.shop-card{display:flex;align-items:center;gap:14px;padding:12px 14px;border:2px solid var(--ink);border-radius:var(--radius);background:var(--surface);box-shadow:0 4px 0 var(--ink)}.shop-card.equipped{background:color-mix(in srgb,var(--accent) 14%,var(--surface))}.shop-info{flex:1;min-width:0}.shop-name{font-size:1.05rem;font-weight:600;letter-spacing:.2px}.shop-desc{font-size:.8rem;color:var(--text-muted);margin-top:2px;font-weight:500}.shop-swatches{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;width:54px;flex-shrink:0}.shop-swatch{width:15px;height:15px;border-radius:50%;border:1.5px solid var(--ink)}.bg-prev{width:72px;height:48px;border-radius:12px;border:2px solid var(--ink);box-shadow:0 3px 0 var(--ink);flex-shrink:0}.bg-prev-default{background:radial-gradient(circle at 18% 0%,rgba(124,92,255,.35),transparent 60%),radial-gradient(circle at 90% 100%,rgba(255,127,165,.35),transparent 60%),#f6efe3}.bg-prev-nacht{background:radial-gradient(circle at 18% 0%,#2f5fd8,transparent 62%),radial-gradient(circle at 90% 100%,#7c3ae2,transparent 62%),#101b33}.bg-prev-ruimte{background:radial-gradient(circle at 18% 0%,#8a2be2,transparent 60%),radial-gradient(circle at 90% 100%,#ff3d81,transparent 60%),#0b0616}.bg-prev-oceaan-bg{background:radial-gradient(circle at 18% 0%,#2bb3a3,transparent 62%),radial-gradient(circle at 90% 100%,#1f7ae0,transparent 62%),#dbf1ef}.bg-prev-snoep{background:radial-gradient(circle at 18% 0%,#ff8ac0,transparent 62%),radial-gradient(circle at 90% 100%,#ffb27a,transparent 62%),#ffe6f0}.bg-prev-bos{background:radial-gradient(circle at 18% 0%,#5fa35a,transparent 62%),radial-gradient(circle at 90% 100%,#9bcf6a,transparent 62%),#e6efdd}.mascot-prev{width:54px;height:48px;flex-shrink:0;display:grid;place-items:center;font-size:1.9rem;background:var(--surface-2);border:2px solid var(--ink);border-radius:12px;box-shadow:0 3px 0 var(--ink)}.shop-btn{border:2px solid var(--ink);border-radius:14px;padding:9px 14px;font-size:.9rem;font-weight:700;font-family:inherit;cursor:pointer;flex-shrink:0;box-shadow:0 3px 0 var(--ink);transition:transform .08s ease,box-shadow .08s ease}.shop-btn:active{transform:translateY(3px);box-shadow:0 0 0 var(--ink)}.shop-btn.buy{background:linear-gradient(180deg,color-mix(in srgb,var(--gold) 78%,#fff),var(--gold));color:#3a2a05}.shop-btn.use{background:var(--surface);color:var(--text)}.shop-btn[disabled]{opacity:.45;cursor:not-allowed;box-shadow:0 3px 0 var(--ink)}.shop-btn[disabled]:active{transform:none;box-shadow:0 3px 0 var(--ink)}.shop-badge{flex-shrink:0;font-weight:700;font-size:.85rem;color:#fff;background:var(--accent);border:2px solid var(--ink);border-radius:999px;padding:7px 14px;box-shadow:0 3px 0 var(--ink)}.coins{font-family:inherit;color:var(--text);cursor:pointer}.bj{display:flex;flex-direction:column;height:100%;gap:12px;--c-red: var(--game-c1, #ff5b4d);--c-blue: var(--game-c2, #4a94ff);--c-green: var(--game-c3, #3bce6b);--c-yellow: var(--game-c4, #ffc72e);--c-purple: var(--game-c5, #9d66ff);--c-orange: var(--game-c6, #ff8a3c);--c-cyan: var(--game-c7, #23c3e6);--c-pink: var(--game-c8, #ff6fae);--bj-ink-mix: #241a3a}.bj-stage{position:relative;flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.bj-board{position:relative;background:repeating-linear-gradient(90deg,rgba(255,255,255,.05) 0 2px,transparent 2px 26px),linear-gradient(160deg,#c98f5e,#ad7343);border-radius:16px;box-shadow:0 0 0 2.5px var(--ink, #33284b),0 7px 0 2.5px var(--ink, #33284b),0 22px 36px #140a2847,inset 0 2px 5px #ffffff47,inset 0 -4px 8px #0000002e;padding:0}.bj-cell{position:absolute;box-sizing:border-box;border-radius:10px;background:#3a200a2b;box-shadow:inset 0 2px 3px #00000038,inset 0 -1px #ffffff24;margin:0;transform:scale(.9)}.bj-gate{position:absolute;background:var(--bc, #999);border:2px solid var(--ink, #33284b);border-radius:7px;box-shadow:inset 0 2px #ffffff59,0 2px 5px #0000004d;z-index:1}.bj-gate.side-top,.bj-gate.side-bottom{height:14px}.bj-gate.side-left,.bj-gate.side-right{width:14px}.bj-block{position:absolute;box-sizing:border-box;border-radius:12px;cursor:grab;z-index:2;touch-action:none;border:none;background:transparent;transform:translate(0);will-change:transform;padding:0}.bj-block.dragging{cursor:grabbing;z-index:5;filter:brightness(1.08)}.bj-block.hinted{animation:bj-pulse .4s ease-in-out 3}@keyframes bj-pulse{50%{filter:brightness(1.4);transform:scale(1.05)}}.bj-grip{position:absolute;top:2.5px;right:2.5px;bottom:2.5px;left:2.5px;border-radius:10px;background:linear-gradient(180deg,color-mix(in srgb,var(--bc, #999) 68%,#fff) 0%,var(--bc, #999) 46%,color-mix(in srgb,var(--bc, #999) 84%,var(--bj-ink-mix)) 100%);border:2px solid color-mix(in srgb,var(--bc, #999) 52%,var(--bj-ink-mix));box-shadow:0 3px color-mix(in srgb,var(--bc, #999) 45%,var(--bj-ink-mix)),inset 0 2px #ffffff59}.bj-grip:after{content:"";position:absolute;left:9%;right:9%;top:7%;height:24%;border-radius:999px;background:linear-gradient(180deg,#ffffff73,#fff0);pointer-events:none}.bj-arrow{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:calc(var(--cell, 48px) * .42);font-weight:700;line-height:1;color:#ffffffe6;text-shadow:0 1.5px 0 rgba(20,10,40,.35);pointer-events:none}.bj-wall{position:absolute;box-sizing:border-box;border-radius:10px;background:repeating-linear-gradient(45deg,rgba(255,255,255,.06) 0 6px,transparent 6px 12px),linear-gradient(160deg,#6b4d33,#4a3521);border:2px solid rgba(32,20,8,.65);box-shadow:inset 0 2px #ffffff26,inset 0 -4px 6px #00000059,0 2px #20140880;z-index:1;transform:scale(.92)}.bj-block.frozen{cursor:not-allowed;filter:saturate(.35) brightness(1.12)}.bj-block.frozen:after{content:"";position:absolute;top:2.5px;right:2.5px;bottom:2.5px;left:2.5px;border-radius:10px;background:linear-gradient(135deg,#d2f0ff8c,#96d2f559);box-shadow:inset 0 0 0 2px #dcf5ffcc;pointer-events:none}.bj-ice-badge{position:absolute;top:-7px;right:-7px;z-index:3;min-width:22px;height:22px;padding:0 4px;border-radius:999px;background:#e0f4ff;color:#1a6f9e;font-size:.72rem;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000004d;pointer-events:none}.bj-block.thawed{animation:bj-thaw .6s ease}@keyframes bj-thaw{0%{filter:saturate(.35) brightness(1.3)}60%{filter:saturate(1.4) brightness(1.2)}to{filter:none}}.bj-block.shake{animation:bj-shake .35s ease}@keyframes bj-shake{0%,to{translate:0 0}25%{translate:-4px 0}50%{translate:4px 0}75%{translate:-3px 0}}.c-red{--bc: var(--c-red)}.c-blue{--bc: var(--c-blue)}.c-green{--bc: var(--c-green)}.c-yellow{--bc: var(--c-yellow)}.c-purple{--bc: var(--c-purple)}.c-orange{--bc: var(--c-orange)}.c-cyan{--bc: var(--c-cyan)}.c-pink{--bc: var(--c-pink)}.c-rainbow{--bc: var(--c-purple)}.bj-gate.c-rainbow,.bj-block.c-rainbow .bj-grip{background:linear-gradient(115deg,#ff6b6b,#ffb347,#ffe14d,#6bdb77,#58b7ff,#b07cf7,#ff6b6b);background-size:250% 250%;animation:bj-rainbow 3.2s linear infinite}@keyframes bj-rainbow{0%{background-position:0% 50%}to{background-position:100% 50%}}.bj-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 4px}.bj-moves{font-weight:700;font-size:.9rem;color:var(--text-muted, #555)}.bj-btn{border:2px solid var(--ink, #33284b);border-radius:14px;padding:10px 14px;font-size:.9rem;font-weight:600;font-family:inherit;background:var(--surface, #fffdf8);color:var(--text, #33284b);cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:0 3px 0 var(--ink, #33284b);transition:transform .08s ease,box-shadow .08s ease}.bj-btn:active{transform:translateY(3px);box-shadow:0 0 0 var(--ink, #33284b)}.bj-btn.primary{background:var(--accent, #7c5cff);color:#fff}.bj-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0c18148c;border-radius:16px;z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.bj-overlay-card{background:var(--surface, #fff);border:2px solid var(--ink, #33284b);border-radius:20px;padding:24px;text-align:center;display:flex;flex-direction:column;gap:10px;width:min(80%,280px);box-shadow:0 6px 0 var(--ink, #33284b),0 18px 40px #0000004d}.bj-overlay-card h3{margin:0;font-size:1.3rem}.bj-overlay-card p{margin:0;color:var(--text-muted, #666)}.cm{display:flex;flex-direction:column;height:100%;gap:12px}.cm-progress{position:relative;height:24px;border-radius:999px;background:var(--surface, #fffdf8);border:2px solid var(--ink, #33284b);overflow:hidden;box-shadow:inset 0 2px 3px #0000001a;flex-shrink:0}.cm-bar-fill{position:absolute;inset:0 auto 0 0;width:0;background:linear-gradient(90deg,color-mix(in srgb,var(--accent, #0891b2) 75%,#000),var(--accent, #0891b2),color-mix(in srgb,var(--accent, #0891b2) 60%,#fff));border-radius:999px;transition:width .35s cubic-bezier(.22,1,.36,1)}.cm-progress-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:var(--text, #33284b);text-shadow:0 0 3px var(--surface, #fffdf8),0 0 6px var(--surface, #fffdf8)}.cm-board{flex:1;min-height:0;display:grid;grid-template-columns:repeat(var(--cols, 4),1fr);grid-template-rows:repeat(var(--rows, 5),1fr);gap:4px;padding:12px;background:linear-gradient(170deg,#c7b3f2,#a688e3);border:2px solid var(--ink, #33284b);border-radius:22px;box-shadow:0 5px 0 var(--ink, #33284b),inset 0 3px #ffffff47,inset 0 -8px 14px #3c1e7838;align-self:center;width:100%;max-width:420px;aspect-ratio:var(--cols, 4) / var(--rows, 5);max-height:100%}.cm-cell{position:relative;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.cm-cell:before{content:"";position:absolute;left:4%;right:4%;top:18%;bottom:10%;border-radius:50%;background:linear-gradient(180deg,#3a1c784d,#3a1c7829);box-shadow:inset 0 3px 5px #28105a4d,0 1px #ffffff47}.cm-cell.drop-ok:before{box-shadow:inset 0 3px 5px #28105a4d,0 0 0 3px #fff,0 0 0 6px var(--accent, #0891b2)}.cm-plate{position:relative;width:97%;aspect-ratio:100 / 78;display:block;touch-action:none}.cm-plate svg{display:block;width:100%;height:100%}.cm-plate.small{width:90%}.cm-plate.pop{animation:cm-pop .34s cubic-bezier(.34,1.56,.64,1)}@keyframes cm-pop{0%{transform:scale(.4)}70%{transform:scale(1.14)}to{transform:scale(1)}}.cm-ghost{position:fixed;width:76px;height:59px;transform:translate(-50%,-50%);pointer-events:none;z-index:100;opacity:.95}.cm-tray{display:flex;justify-content:center;gap:14px;padding:12px 10px;background:linear-gradient(170deg,#ffb493,#f5926f);border:2px solid var(--ink, #33284b);border-radius:18px;box-shadow:0 4px 0 var(--ink, #33284b),inset 0 2px #ffffff59,inset 0 -6px 10px #9632142e;flex-shrink:0}.cm-tray-slot{width:84px;height:64px;border-radius:50%;background:#ffffff47;box-shadow:inset 0 3px 5px #963c1e38;display:flex;align-items:center;justify-content:center;touch-action:none;-webkit-tap-highlight-color:transparent}.cm-tray-slot.selected{box-shadow:inset 0 3px 5px #963c1e38,0 0 0 3px #fff,0 0 0 6px var(--accent, #0891b2);background:#ffffff80}.cm-controls{display:flex;justify-content:center;gap:12px;flex-shrink:0}.cm-booster{border:2px solid var(--ink, #33284b);border-radius:14px;padding:10px 18px;font-size:1rem;font-weight:600;font-family:inherit;background:var(--surface, #fffdf8);color:var(--text, #33284b);cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:0 3px 0 var(--ink, #33284b);transition:transform .08s ease,box-shadow .08s ease}.cm-booster:active{transform:translateY(3px);box-shadow:0 0 0 var(--ink, #33284b)}.cm-booster.active,.cm-booster.primary{background:var(--accent, #7c5cff);color:#fff}.cm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0c18148c;z-index:20;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.cm-overlay-card{background:var(--surface, #fff);border:2px solid var(--ink, #33284b);border-radius:20px;padding:24px;text-align:center;display:flex;flex-direction:column;gap:10px;width:min(80%,280px);box-shadow:0 6px 0 var(--ink, #33284b),0 18px 40px #0000004d}.cm-overlay-card h3{margin:0;font-size:1.3rem}.cm-overlay-card p{margin:0;color:var(--text-muted, #666)}.ws{position:relative;display:flex;flex-direction:column;height:100%;gap:12px}.ws-stage{flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.ws-board{display:flex;flex-wrap:wrap;justify-content:center;align-content:center;gap:14px 10px;padding:18px 12px;width:100%;max-width:420px;background:linear-gradient(170deg,#ffe3c2,#f7c58e);border:2px solid var(--ink, #33284b);border-radius:22px;box-shadow:0 5px 0 var(--ink, #33284b),inset 0 3px #ffffff59,inset 0 -8px 14px #96500a2e}.ws-bottle{position:relative;width:52px;height:148px;border-radius:10px 10px 24px 24px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .18s cubic-bezier(.22,1,.36,1);touch-action:manipulation}.ws-bottle.selected{transform:translateY(-12px) scale(1.05);z-index:2}.ws-bottle.hinted{animation:ws-hint-pulse .5s ease-in-out 2}@keyframes ws-hint-pulse{50%{transform:translateY(-8px);filter:brightness(1.15)}}.ws-glass{position:absolute;top:0;right:0;bottom:0;left:0;border:3px solid rgba(60,40,90,.55);border-radius:10px 10px 24px 24px;background:linear-gradient(105deg,#ffffff6b 8%,#ffffff0f 30%,#fff0 55%,#ffffff2e 92%);box-shadow:inset 0 2px 4px #ffffff80,0 3px 6px #3c1e5a40;pointer-events:none}.ws-glass:before{content:"";position:absolute;left:-5px;right:-5px;top:-6px;height:9px;border-radius:6px;background:linear-gradient(180deg,#efe6f7,#c9b8dd);border:2px solid rgba(60,40,90,.55)}.ws-liquid{position:absolute;top:4px;right:4px;bottom:4px;left:4px;display:flex;flex-direction:column-reverse;border-radius:6px 6px 20px 20px;overflow:hidden}.ws-unit{height:20%;flex:0 0 20%;box-shadow:inset 0 2px 2px #ffffff40;background:linear-gradient(180deg,color-mix(in srgb,var(--wc, #888) 65%,#fff),color-mix(in srgb,var(--wc, #888) 88%,#000))}.ws-unit.ws-c-1{--wc: var(--game-c1)}.ws-unit.ws-c-2{--wc: var(--game-c2)}.ws-unit.ws-c-3{--wc: var(--game-c3)}.ws-unit.ws-c-4{--wc: var(--game-c4)}.ws-unit.ws-c-5{--wc: var(--game-c5)}.ws-unit.ws-c-6{--wc: var(--game-c6)}.ws-unit.ws-c-7{--wc: var(--game-c7)}.ws-unit.ws-c-8{--wc: var(--game-c8)}.ws-unit.ws-c-9{--wc: var(--game-c9)}.ws-unit.ws-new{animation:ws-splash .28s cubic-bezier(.22,1,.36,1)}@keyframes ws-splash{0%{transform:translateY(-140%)}to{transform:translateY(0)}}.ws-bottle.served{animation:ws-serve .45s ease-in forwards;pointer-events:none}@keyframes ws-serve{25%{transform:translateY(-10px) scale(1.12);filter:brightness(1.2)}to{transform:translateY(-26px) scale(.4);opacity:0}}.ws-toolbar{display:flex;align-items:center;justify-content:center;gap:10px;flex-shrink:0;padding-bottom:4px}.ws-moves{font-size:.85rem;font-weight:700;color:var(--text, #33284b);min-width:110px;text-align:center}.ws-btn{border:2px solid var(--ink, #33284b);border-radius:12px;background:var(--surface, #fffdf8);color:var(--text, #33284b);font-weight:700;font-size:.85rem;padding:8px 12px;cursor:pointer;box-shadow:0 3px 0 var(--ink, #33284b);-webkit-tap-highlight-color:transparent}.ws-btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--ink, #33284b)}.ws-btn.primary{background:var(--accent, #e2761c);color:#fff}.ws-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#28144673;z-index:10;border-radius:inherit}.ws-overlay-card{display:flex;flex-direction:column;gap:10px;align-items:stretch;background:var(--surface, #fffdf8);border:2px solid var(--ink, #33284b);border-radius:18px;box-shadow:0 6px 0 var(--ink, #33284b);padding:20px 24px;min-width:200px;text-align:center}.ws-overlay-card h3{margin:0;font-size:1.2rem}.ws-overlay-card p{margin:0 0 6px;font-size:.9rem;opacity:.8}@media (max-width: 400px){.ws-bottle{width:46px;height:134px}}.pp{display:flex;flex-direction:column;height:100%;gap:12px}.pp-stage{flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.pp-board{display:grid;gap:6px;padding:14px;width:100%;max-width:420px;background:linear-gradient(160deg,#e4ecf7,#bcccea);border:2px solid var(--ink, #33284b);border-radius:22px;box-shadow:0 5px 0 var(--ink, #33284b),inset 0 3px #fff6,inset 0 -8px 14px #283c7826}.pp-tile{position:relative;aspect-ratio:1;padding:0;border:none;border-radius:10px;background:var(--surface, #fffdf8);cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 2px #33284b1a;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:background .15s ease}.pp-tile:active{filter:brightness(.96)}.pp-rot{width:100%;height:100%;display:flex;transition:transform .13s cubic-bezier(.34,1.4,.64,1)}.pp-svg{width:100%;height:100%;display:block}.pp-svg line{stroke-width:15;stroke-linecap:round;fill:none}.pp-tile.pp-dead .pp-svg line,.pp-tile.pp-dead .pp-hub{stroke:color-mix(in srgb,var(--text-muted, #877a9b) 65%,transparent);fill:color-mix(in srgb,var(--text-muted, #877a9b) 65%,transparent)}.pp-tile.pp-live{background:color-mix(in srgb,var(--game-c7, #23c3e6) 14%,var(--surface, #fffdf8))}.pp-tile.pp-live .pp-svg line{stroke:var(--game-c7, #23c3e6)}.pp-tile.pp-live .pp-hub{fill:var(--game-c7, #23c3e6)}.pp-tile.pp-hint{animation:pp-hint .5s ease-in-out 2;box-shadow:0 0 0 3px var(--gold, #ffb62e),inset 0 0 0 2px #33284b1a;z-index:2}@keyframes pp-hint{50%{transform:scale(.9)}}.pp-board.pp-win .pp-tile{animation:pp-flow .45s ease}@keyframes pp-flow{50%{filter:brightness(1.35);transform:scale(1.06)}}.pp-toolbar{display:flex;align-items:center;justify-content:center;gap:10px;flex-shrink:0;padding-bottom:4px}.pp-moves{font-size:.85rem;font-weight:700;color:var(--text, #33284b);min-width:130px;text-align:center}.pp-btn{border:2px solid var(--ink, #33284b);border-radius:12px;background:var(--surface, #fffdf8);color:var(--text, #33284b);font-weight:700;font-size:.85rem;padding:8px 12px;cursor:pointer;box-shadow:0 3px 0 var(--ink, #33284b);-webkit-tap-highlight-color:transparent}.pp-btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--ink, #33284b)}.bp{display:flex;flex-direction:column;height:100%;gap:10px;--bp-1: var(--game-c1, #ff5b4d);--bp-2: var(--game-c2, #4a94ff);--bp-3: var(--game-c3, #3bce6b);--bp-4: var(--game-c4, #ffc72e);--bp-5: var(--game-c5, #9d66ff);--bp-6: var(--game-c6, #ff8a3c)}.bp-stage{flex:1;display:flex;flex-direction:column;justify-content:flex-start;min-height:0;touch-action:none}.bp-field{position:relative;width:100%;max-width:440px;margin:0 auto;background:linear-gradient(180deg,#ffffff40,#ffffff0d);border:2px solid var(--ink, #33284b);border-radius:16px;overflow:hidden;box-shadow:inset 0 2px #ffffff40,0 5px 0 var(--ink, #33284b)}.bp-deadline{position:absolute;left:0;right:0;height:0;border-top:2px dashed color-mix(in srgb,var(--danger, #ef4757) 70%,transparent);pointer-events:none}.bp-bubble{position:absolute;top:0;left:0;border-radius:50%;background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.85) 0 12%,transparent 42%),radial-gradient(circle at 50% 50%,color-mix(in srgb,var(--bc, #999) 60%,#fff) 0%,var(--bc, #999) 62%,color-mix(in srgb,var(--bc, #999) 72%,#000) 100%);border:2px solid color-mix(in srgb,var(--bc, #999) 55%,var(--ink, #33284b));box-sizing:border-box;pointer-events:none;will-change:transform}.bp-c-1{--bc: var(--bp-1)}.bp-c-2{--bc: var(--bp-2)}.bp-c-3{--bc: var(--bp-3)}.bp-c-4{--bc: var(--bp-4)}.bp-c-5{--bc: var(--bp-5)}.bp-c-6{--bc: var(--bp-6)}.bp-bubble.bp-in{animation:bp-in .16s ease}@keyframes bp-in{0%{scale:.6}to{scale:1}}.bp-bubble.bp-pop{animation:bp-pop .32s ease forwards}@keyframes bp-pop{40%{scale:1.25;opacity:1}to{scale:.1;opacity:0}}.bp-bubble.bp-fall{animation:bp-fall .42s ease-in forwards}@keyframes bp-fall{to{translate:0 70vh;opacity:0}}.bp-aim-dot{position:absolute;top:0;left:0;width:6px;height:6px;border-radius:50%;background:var(--accent, #2f7fe0);opacity:0;pointer-events:none}.bp-shooter{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:440px;margin:6px auto 0;min-height:58px;padding:0 8px}.bp-next-wrap{display:flex;align-items:center;gap:8px;width:96px}.bp-next-spacer{width:96px}.bp-next-label{font-size:.72rem;font-weight:600;color:var(--text-muted, #877a9b)}.bp-bubble.bp-next{position:static;width:26px;height:26px}.bp-bubble.bp-cannon{position:static;outline:3px solid color-mix(in srgb,var(--accent, #2f7fe0) 55%,transparent);outline-offset:3px}.bp-toolbar{display:flex;align-items:center;justify-content:center;gap:14px;padding-bottom:4px}.bp-moves{font-size:.85rem;font-weight:600;color:var(--text, #33284b)}.bp-btn{font-family:inherit;font-size:.9rem;font-weight:700;border:2px solid var(--ink, #33284b);border-radius:14px;padding:9px 14px;background:var(--surface, #fffdf8);color:var(--text, #33284b);cursor:pointer;box-shadow:0 3px 0 var(--ink, #33284b);transition:transform .08s ease,box-shadow .08s ease}.bp-btn:active{transform:translateY(3px);box-shadow:0 0 0 var(--ink, #33284b)}.bp-btn.primary{background:var(--accent, #2f7fe0);color:#fff}.bp-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#140c2873;z-index:10}.bp-overlay-card{display:flex;flex-direction:column;gap:12px;background:var(--surface, #fffdf8);border:2px solid var(--ink, #33284b);border-radius:var(--radius, 20px);box-shadow:0 6px 0 var(--ink, #33284b);padding:20px 22px;max-width:300px;text-align:center}.bp-overlay-card h3{margin:0}.bp-overlay-card p{margin:0;color:var(--text-muted, #877a9b);font-size:.9rem}
