:root{--color-bg-primary:#ffe4d6;--color-bg-overlay:#fff0e8;--color-grid-bg:#2d9b9b;--color-cell-empty:#4ec5c1;--color-cell-border:#fff;--color-cell-hint:#a8ffd0;--tile-tier-1:#ffd94a;--tile-tier-2:#ff8c5a;--tile-tier-3:#9b59e8;--tile-tier-4:#3ec9c9;--tile-tier-5:#2c3e8c;--color-badge-level:#6b3fa0;--color-badge-score:#2ecc71;--color-keep-border:#3ec9c9;--color-trash-border:#ff6b6b;--color-trash-counter:#f44;--color-text-primary:#2d2d2d;--color-text-light:#fff;--color-text-muted:#888;--color-drop-active:#a8ffd0;--font-display:"Fredoka One", cursive;--font-body:"Nunito", sans-serif;--speed-fast:.15s ease;--speed-med:.25s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;font-size:16px}body{font-family:var(--font-body);background:var(--color-bg-primary);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain;min-height:100dvh;overflow-x:hidden}#root{min-height:100dvh}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;-webkit-tap-highlight-color:transparent;background:0 0;border:none;outline:none}button:focus-visible{border-radius:8px;box-shadow:0 0 0 3px #6b3fa080}.game-screen{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.bg-decoration{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.bg-bubble{opacity:.12;will-change:transform;border-radius:50%;animation:20s ease-in-out infinite float;position:absolute}.bg-bubble--1{background:#ff8c5a;width:300px;height:300px;animation-duration:25s;top:-80px;left:-60px}.bg-bubble--2{background:#9b59e8;width:200px;height:200px;animation-duration:22s;animation-delay:-5s;top:20%;right:-40px}.bg-bubble--3{background:#ffd94a;width:150px;height:150px;animation-duration:18s;animation-delay:-10s;bottom:10%;left:10%}.bg-bubble--4{background:#3ec9c9;width:250px;height:250px;animation-duration:28s;animation-delay:-3s;bottom:-80px;right:15%}.bg-bubble--5{background:#ff6b6b;width:120px;height:120px;animation-duration:20s;animation-delay:-8s;top:50%;left:30%}.bg-bubble--6{background:#6b3fa0;width:180px;height:180px;animation-duration:24s;animation-delay:-12s;top:60%;right:30%}.bg-bubble--7{background:#2ecc71;width:100px;height:100px;animation-duration:19s;animation-delay:-15s;top:10%;left:50%}.bg-bubble--8{background:#ffd94a;width:160px;height:160px;animation-duration:26s;animation-delay:-6s;bottom:30%;left:-30px}@keyframes float{0%,to{transform:translateY(0)translate(0)scale(1)}25%{transform:translateY(-30px)translate(15px)scale(1.05)}50%{transform:translateY(-10px)translate(-20px)scale(.95)}75%{transform:translateY(-40px)translate(10px)scale(1.02)}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}::selection{background:#6b3fa04d}.game-screen{flex-direction:column;align-items:center;min-height:100dvh;display:flex;position:relative;overflow-x:hidden}.game-container{z-index:1;width:100%;max-width:780px;margin:0 auto;padding:8px 12px 24px;position:relative}.game-area{flex-direction:column;align-items:center;gap:20px;padding:0 4px;display:flex}.game-left{flex-direction:column;align-items:center;gap:12px;width:100%;display:flex}.game-board{background:var(--color-grid-bg);border-radius:18px;grid-template-columns:repeat(4,1fr);gap:8px;width:min(88vw,360px);padding:14px;display:grid;position:relative;box-shadow:0 8px #237878,0 12px 30px #0003}.game-board:before{content:"";pointer-events:none;border:2px solid #ffffff1f;border-radius:15px;position:absolute;inset:3px}.game-board__cell{aspect-ratio:1;transition:all var(--speed-fast);-webkit-tap-highlight-color:transparent;border-radius:10px;justify-content:center;align-items:center;display:flex;position:relative}.game-board__cell--empty{background:var(--color-cell-empty);border:2px dashed #ffffff59}.game-board__cell--empty:hover{background:#5ed4cf;border-color:#ffffff8c}.game-board__cell--occupied{background:0 0;border:2px solid #0000}.game-board__cell--dragover{transform:scale(1.06);box-shadow:0 0 16px #a8ffd080;background:var(--color-drop-active)!important;border-style:solid!important;border-color:#2ecc71!important}.game-board__cell--hint{animation:.9s ease-in-out infinite hintPulse}@keyframes hintPulse{0%,to{background-color:var(--color-cell-hint)}50%{background-color:#c3ffe8}}@media (width<=374px){.game-container{padding:4px 6px 16px}.game-board{border-radius:14px;gap:6px;width:95vw;padding:10px}.game-board__cell{border-radius:8px}.game-area{gap:14px}}@media (width>=768px){.game-area{flex-direction:row;justify-content:center;align-items:flex-start;gap:28px}.game-board{width:clamp(320px,42vw,400px)}}@media (width>=1024px){.game-container{padding-top:16px}.game-board{width:400px}}@media (height<=500px) and (orientation:landscape){.game-screen{min-height:auto}.game-area{flex-direction:row;align-items:flex-start;gap:16px}.game-board{width:clamp(240px,38vh,340px)}.game-container{padding:4px 8px 8px}}.header{justify-content:space-between;align-items:center;gap:8px;width:100%;padding:10px 4px 4px;display:flex}.header__left,.header__right{align-items:center;gap:6px;display:flex}.header__center{flex-direction:column;align-items:center;gap:2px;display:flex}.header__title{font-family:var(--font-display);color:var(--color-badge-level);text-shadow:0 2px #6b3fa033;letter-spacing:2px;font-size:clamp(20px,5vw,30px)}.header__timer{font-family:var(--font-display);color:var(--color-text-muted);align-items:center;gap:4px;font-size:16px;display:flex}.header__timer-icon{font-size:14px}.header__btn{background:var(--color-bg-overlay);width:40px;height:40px;transition:all var(--speed-fast);border:2px solid #0000;border-radius:12px;justify-content:center;align-items:center;font-size:18px;display:flex;box-shadow:0 2px 8px #00000014}.header__btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.header__btn:active{transform:translateY(0)}.header__btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.header__btn--active{background:#fff3cd;border-color:#ffd94a;box-shadow:0 0 12px #ffd94a66}.header__btn--help{font-family:var(--font-display);color:var(--color-badge-level);font-size:18px}.header__subtitle{font-family:var(--font-body);text-transform:uppercase;letter-spacing:1.5px;color:var(--color-text-muted);text-align:center;padding:4px 0 8px;font-size:11px;font-weight:700}.header__difficulty{justify-content:center;gap:6px;padding-bottom:12px;display:flex}.header__diff-btn{font-family:var(--font-body);background:var(--color-bg-overlay);color:var(--color-text-muted);transition:all var(--speed-fast);border:2px solid #0000;border-radius:20px;padding:5px 16px;font-size:12px;font-weight:800;box-shadow:0 2px 6px #0000000f}.header__diff-btn:hover{color:var(--color-text-primary);background:#ffe8d8}.header__diff-btn--active{background:var(--color-badge-level);color:#fff;border-color:#8b5ec8;box-shadow:0 2px 10px #6b3fa04d}.cat-badge-row{justify-content:center;align-items:center;gap:12px;padding:4px 0;display:flex}.cat-character{justify-content:center;align-items:center;width:56px;height:56px;display:flex}.cat-emoji{filter:drop-shadow(0 4px 6px #00000026);font-size:44px;animation:3s ease-in-out infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.badge{font-family:var(--font-body);color:var(--color-text-light);transition:transform var(--speed-fast);border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:800;display:flex;box-shadow:0 3px 8px #00000026}.badge__icon{font-size:14px}.badge--level{background:linear-gradient(135deg, var(--color-badge-level), #8b5ec8)}.badge--score{background:linear-gradient(135deg, var(--color-badge-score), #27ae60)}.badge:hover{transform:scale(1.05)}.help-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.help-modal{background:var(--color-bg-overlay);border-radius:20px;width:100%;max-width:420px;max-height:80vh;padding:28px;animation:.3s cubic-bezier(.34,1.56,.64,1) slideIn;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.help-modal__close{width:32px;height:32px;transition:all var(--speed-fast);background:#00000014;border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex;position:absolute;top:12px;right:12px}.help-modal__close:hover{background:#00000026}.help-modal h2{font-family:var(--font-display);color:var(--color-badge-level);margin-bottom:16px;font-size:24px}.help-section{margin-bottom:16px}.help-section h3{font-family:var(--font-body);margin-bottom:6px;font-size:15px;font-weight:800}.help-section p,.help-section li{color:#555;font-size:13px;line-height:1.6}.help-section ul{padding-left:0;list-style:none}.help-section li{padding:3px 0 3px 8px;position:relative}.help-section li:before{content:"•";color:var(--color-badge-level);font-weight:800;position:absolute;left:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=374px){.header__title{letter-spacing:1px;font-size:18px}.header__btn{border-radius:10px;width:34px;height:34px;font-size:15px}.header__subtitle{letter-spacing:1px;padding:2px 0 6px;font-size:9px}.header__diff-btn{padding:4px 12px;font-size:11px}.badge{gap:4px;padding:5px 10px;font-size:11px}.cat-emoji{font-size:32px}.cat-character{width:40px;height:40px}.cat-badge-row{gap:8px}.help-modal{border-radius:16px;padding:20px}.help-modal h2{font-size:20px}}@media (height<=500px) and (orientation:landscape){.header{padding:4px 4px 2px}.header__subtitle{padding:2px 0 4px;font-size:9px}.header__difficulty{padding-bottom:6px}.cat-badge-row{gap:8px;padding:2px 0}.cat-emoji{font-size:28px}.badge{padding:4px 10px;font-size:11px}}.tile{background:var(--tile-bg,var(--tile-tier-1));color:var(--color-text-light);font-family:var(--font-display);font-size:var(--tile-fs,28px);cursor:default;-webkit-user-select:none;user-select:none;transition:transform var(--speed-fast), box-shadow var(--speed-fast);-webkit-tap-highlight-color:transparent;box-shadow:0 4px 0 0 var(--tile-shadow,#00000040), 0 2px 8px #00000026;border-radius:12px;justify-content:center;align-items:center;display:flex;position:relative}.tile:after{content:"";pointer-events:none;background:linear-gradient(#ffffff59,#fff0);border-radius:8px 8px 50% 50%;height:35%;position:absolute;top:3px;left:6px;right:6px}.tile__number{z-index:1;text-shadow:0 2px 3px #0003;line-height:1;position:relative}.tile--xl{border-radius:16px;width:88px;height:88px}.tile--lg{aspect-ratio:1;border-radius:10px;width:100%;min-width:64px;height:100%;min-height:64px}.tile--md{aspect-ratio:1;border-radius:10px;width:56px;height:56px}.tile--sm{aspect-ratio:1;border-radius:8px;width:44px;height:44px;font-size:18px}.tile--tier-1{--tile-bg:var(--tile-tier-1);--tile-shadow:#e6b800}.tile--tier-2{--tile-bg:var(--tile-tier-2);--tile-shadow:#d6653a}.tile--tier-3{--tile-bg:var(--tile-tier-3);--tile-shadow:#7a3cb8}.tile--tier-4{--tile-bg:var(--tile-tier-4);--tile-shadow:#2da8a8}.tile--tier-5{--tile-bg:var(--tile-tier-5);--tile-shadow:#1a2a6c;color:#ddd}.tile--draggable{cursor:grab;touch-action:none;-webkit-touch-callout:none}.tile--draggable:hover{box-shadow:0 6px 0 0 var(--tile-shadow,#00000040), 0 4px 16px #0003;transform:scale(1.06)}.tile--draggable:active{cursor:grabbing;box-shadow:0 8px 0 0 var(--tile-shadow,#0003), 0 6px 20px #0000004d;opacity:.9;transform:scale(1.1)rotate(-2deg)}.tile--placing{animation:.25s cubic-bezier(.34,1.56,.64,1) popIn}@keyframes popIn{0%{opacity:.3;transform:scale(.5)}70%{transform:scale(1.12)}to{opacity:1;transform:scale(1)}}@keyframes popOut{0%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}to{opacity:0;transform:scale(0)}}.tile-drag-ghost{font-family:var(--font-display);color:var(--color-text-light)}@media (width<=374px){.tile--lg{min-width:48px;min-height:48px}.tile--md{width:44px;height:44px}.tile--sm{width:36px;height:36px}}.action-panel{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:12px;width:min(88vw,360px);display:flex}.keep-slot{background:var(--color-bg-overlay);border:3px solid var(--color-keep-border);min-width:80px;min-height:90px;transition:all var(--speed-fast);-webkit-tap-highlight-color:transparent;border-radius:16px;flex-direction:column;align-items:center;gap:6px;padding:10px;display:flex;box-shadow:0 4px 12px #3ec9c926}.keep-slot--dragover{background:#e8fff0;border-color:#2ecc71;transform:scale(1.05);box-shadow:0 4px 20px #2ecc714d}.keep-slot__label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:1.5px;color:var(--color-keep-border);font-size:11px;font-weight:800}.keep-slot__content{justify-content:center;align-items:center;width:56px;height:56px;display:flex}.keep-slot__empty{color:var(--color-keep-border);opacity:.5}.tile-queue{flex-direction:column;align-items:center;gap:8px;display:flex}.tile-queue__label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:1.5px;color:var(--color-text-muted);font-size:11px;font-weight:800}.tile-queue__tiles{flex-direction:row;align-items:center;gap:8px;display:flex}.tile-queue__slot{transition:all var(--speed-fast);justify-content:center;align-items:center;display:flex}.tile-queue__slot--active{width:72px;height:72px;animation:2s ease-in-out infinite glow}.tile-queue__slot:not(.tile-queue__slot--active){opacity:.6;width:56px;height:56px;transform:scale(.85)}@keyframes glow{0%,to{filter:drop-shadow(0 0 4px #6b3fa033)}50%{filter:drop-shadow(0 0 12px #6b3fa066)}}.trash-slot{background:var(--color-bg-overlay);border:3px solid var(--color-trash-border);min-width:80px;min-height:90px;transition:all var(--speed-fast);-webkit-tap-highlight-color:transparent;border-radius:16px;flex-direction:column;align-items:center;gap:6px;padding:10px;display:flex;box-shadow:0 4px 12px #ff6b6b1f}.trash-slot--dragover{border-color:var(--color-trash-counter);background:#fff0f0;transform:scale(1.05);box-shadow:0 4px 20px #ff44444d}.trash-slot--disabled{opacity:.4;cursor:not-allowed;border-color:#ccc}.trash-slot__label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:1.5px;color:var(--color-trash-border);font-size:11px;font-weight:800}.trash-slot--disabled .trash-slot__label{color:#aaa}.trash-slot__content{align-items:center;gap:6px;display:flex}.trash-slot__icon{color:var(--color-trash-border);transition:color var(--speed-fast)}.trash-slot--disabled .trash-slot__icon{color:#bbb}.trash-slot__counter{font-family:var(--font-display);color:var(--color-trash-counter);background:#ff44441a;border-radius:8px;justify-content:center;align-items:center;min-width:28px;height:28px;padding:0 4px;font-size:18px;display:flex}.trash-slot--disabled .trash-slot__counter{color:#aaa;background:#0000000d}@media (width>=768px){.action-panel{flex-direction:column;align-items:center;gap:16px;width:auto;min-width:140px}.tile-queue__tiles{flex-direction:column}.keep-slot,.trash-slot{width:100%;min-width:120px}.tile-queue__slot--active{width:80px;height:80px}.tile-queue__slot:not(.tile-queue__slot--active){width:64px;height:64px}}@media (width<=374px){.action-panel{gap:8px;width:100%;padding:0 8px}.keep-slot,.trash-slot{min-width:68px;min-height:76px;padding:8px}.keep-slot__content{width:44px;height:44px}.tile-queue__slot--active{width:60px;height:60px}.tile-queue__slot:not(.tile-queue__slot--active){width:46px;height:46px}}.gameover-overlay{z-index:500;-webkit-backdrop-filter:blur(6px);background:#0000008c;justify-content:center;align-items:center;padding:24px;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.gameover-modal{text-align:center;background:linear-gradient(145deg,#fff5ee,#ffe8d8);border-radius:28px;width:100%;max-width:360px;padding:36px 32px;animation:.4s cubic-bezier(.34,1.56,.64,1) slideIn;position:relative;overflow:hidden;box-shadow:0 24px 60px #0000004d,0 0 0 4px #ffffff4d}.gameover-modal:before{content:"";pointer-events:none;background:#9b59e814;border-radius:50%;width:180px;height:180px;position:absolute;top:-60px;left:-60px}.gameover-modal:after{content:"";pointer-events:none;background:#ffd94a1a;border-radius:50%;width:140px;height:140px;position:absolute;bottom:-40px;right:-40px}.gameover-modal__emoji{margin-bottom:8px;font-size:56px;animation:2s ease-in-out infinite bounce}.gameover-modal__title{font-family:var(--font-display);color:var(--color-badge-level);text-shadow:0 2px #6b3fa026;margin-bottom:8px;font-size:32px}.gameover-modal__newbest{font-family:var(--font-display);color:#e6a800;background:linear-gradient(135deg,#fff8dc,#fff0b3);border-radius:12px;margin-bottom:12px;padding:6px 16px;font-size:18px;animation:1.5s ease-in-out infinite pulse;display:inline-block;box-shadow:0 2px 10px #e6a80033}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}.gameover-modal__scores{z-index:1;justify-content:center;align-items:center;gap:20px;margin:16px 0;display:flex;position:relative}.gameover-modal__score-item{flex-direction:column;gap:4px;display:flex}.gameover-modal__score-label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-muted);font-size:12px;font-weight:800}.gameover-modal__score-value{font-family:var(--font-display);color:var(--color-text-primary);font-size:36px}.gameover-modal__score-value--best{color:var(--color-badge-score)}.gameover-modal__divider{background:#0000001a;border-radius:1px;width:2px;height:50px}.gameover-modal__stats{font-family:var(--font-body);color:var(--color-text-muted);z-index:1;justify-content:center;gap:8px;margin-bottom:20px;font-size:13px;font-weight:700;display:flex;position:relative}.gameover-modal__restart{font-family:var(--font-display);color:var(--color-text-light);background:linear-gradient(135deg, var(--color-badge-level), #8b5ec8);transition:all var(--speed-fast);z-index:1;border-radius:16px;padding:14px 36px;font-size:18px;position:relative;box-shadow:0 4px #4a2d73,0 6px 20px #6b3fa04d}.gameover-modal__restart:hover{transform:translateY(-2px);box-shadow:0 6px #4a2d73,0 8px 24px #6b3fa066}.gameover-modal__restart:active{transform:translateY(2px);box-shadow:0 2px #4a2d73,0 3px 10px #6b3fa04d}
