.hand-animation{position:fixed;top:0;left:0;pointer-events:none;z-index:2000;transform-origin:center}.hand-sprite{width:60px;height:60px;object-fit:contain;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.3))}.tile-highlight{position:fixed;top:0;left:0;width:80px;height:80px;border-radius:15px;pointer-events:none;z-index:1900;transform:translate(-50%,-50%);transform-origin:center}.source-highlight{background:#2ecc714d;border:3px solid #2ecc71;box-shadow:0 0 20px #2ecc7180}.target-highlight{background:#3498db4d;border:3px solid #3498db;box-shadow:0 0 20px #3498db80}.merge-animation-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:1500}.merge-animation-category-tile{box-shadow:0 12px 24px #0006}.merge-animation-spawn-tile{background:#e8f5e8;border-color:#4caf50;box-shadow:0 6px 12px #4caf504d}.board-container{position:relative;width:100%;height:100%;max-width:100vw;max-height:100vh;padding:15px;background:#f5f5dcb3;border-radius:15px;border:2px solid #2c3e50;box-sizing:border-box;overflow:hidden}.board-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(6,1fr);gap:8px 8px;row-gap:20px;width:100%;height:100%;position:relative;padding:8px;box-sizing:border-box;min-height:0;min-width:0}.tile{background:wheat;border:1px solid #2c3e50;border-radius:min(12px,15%);display:flex;align-items:center;justify-content:center;font-weight:700;color:#2c3e50;cursor:grab;-webkit-user-select:none;user-select:none;box-shadow:0 2px 4px #0000001a;text-align:center;padding:min(6px,8%);box-sizing:border-box;transform-origin:center;will-change:transform,opacity;width:100%;height:100%;max-width:100%;max-height:100%;aspect-ratio:1 / .6;min-width:40px;min-height:32px;overflow:hidden;position:relative}.tile.hovered{transform:scale(1.02);border-color:#fff}.tile.hint-highlight-1{background:linear-gradient(135deg,#66f9c4,#66e0b2);border-color:#66e082;transform:scale(1.05);color:#2c3e50}.tile.hint-highlight-2{background:linear-gradient(135deg,#e3f2fd,#b3e5fc);border-color:#81d4fa;transform:scale(1.05);color:#2c3e50}.tile.hint-highlight-3{background:linear-gradient(135deg,#f3e5f5,#e1bee7);border-color:#ce93d8;transform:scale(1.05);color:#2c3e50}.tile.final-row.hint-highlight-1,.tile.final-row.hint-highlight-2,.tile.final-row.hint-highlight-3{box-shadow:inherit}.tile.final-row{cursor:default}@keyframes gentle-pulse{0%,to{box-shadow:0 0 8px #4caf504d,0 2px 4px #0000001a}50%{box-shadow:0 0 12px #4caf5080,0 2px 4px #0000001a}}.tile:active{cursor:grabbing}.tile.category-tile{background:wheat;border-color:#2c3e50}.tile.category-tile.hint-highlighted{background:linear-gradient(135deg,#e8f5e8,#d4f1d4);border-color:#4caf50}.tile-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:min(2px,3%);width:100%;height:100%;max-width:100%;max-height:100%;overflow:hidden}.tile-icon{line-height:1;flex-shrink:0;max-width:100%;max-height:50%}.tile-label{font-weight:700;text-transform:uppercase;line-height:1;text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-height:0}.tile-word{font-weight:700;line-height:1.1;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;text-align:center;width:100%;max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center;height:100%;overflow:hidden;padding:2px;box-sizing:border-box}.empty-slot{border:1px solid rgba(139,69,19,.2);border-radius:min(12px,15%);background:#8b45131a;width:100%;height:100%;max-width:100%;max-height:100%;aspect-ratio:1 / .8;min-width:40px;min-height:32px}.tile[style*="position: fixed"]{pointer-events:none;box-shadow:0 8px 16px #0000004d;border-width:2px;z-index:1000;transition:none!important}@keyframes tileSwap{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes tileMerge{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}to{transform:scale(.8);opacity:0}}@keyframes tileSpawn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1);opacity:.8}to{transform:scale(1);opacity:1}}.tile.swapping{animation:tileSwap .3s ease-in-out}.tile.merging{animation:tileMerge .4s ease-in-out forwards}.tile.spawning{animation:tileSpawn .4s ease-out}@media (hover: none) and (pointer: coarse){.tile{cursor:default;touch-action:none}.tile:active{transform:scale(1.05);box-shadow:0 8px 16px #0000004d}}.board-container{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;touch-action:none}@media (max-width: 768px){.board-container{padding:10px}.board-grid{gap:6px 6px;row-gap:18px;padding:6px}.tile,.empty-slot{min-width:35px;min-height:28px;border-radius:min(8px,15%)}.final-row-label{font-size:min(12px,3vw);padding:4px 12px;letter-spacing:.3px}}@media (max-width: 480px){.board-container{padding:8px}.board-grid{gap:4px 4px;row-gap:18px;padding:4px}.tile,.empty-slot{min-width:30px;min-height:24px;border-radius:min(6px,15%)}.final-row-label{font-size:min(10px,2.5vw);padding:3px 8px;letter-spacing:.2px;border-radius:15px}}.tile.final-row{border-width:2px;animation:finalRowGlow 2s ease-in-out infinite}.final-row-tray{border:3px solid;border-radius:18px;z-index:1}.final-row-tab{position:relative;z-index:0;pointer-events:none;top:5px}.final-row-tab-content{position:absolute;top:-22px;left:50%;transform:translate(-50%);padding:4px 25px;border:3px solid;border-bottom:none;border-top-left-radius:12px;border-top-right-radius:12px;font-size:8px;font-weight:700;text-transform:uppercase;white-space:nowrap}@keyframes finalRowGlow{0%{box-shadow:0 0 12px #0097a766,0 4px 8px #0003}50%{box-shadow:0 0 20px #0097a799,0 4px 8px #0003}to{box-shadow:0 0 12px #0097a766,0 4px 8px #0003}}.win-screen-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .5s ease-out}.win-screen-content{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:40px 30px;max-width:400px;width:90%;text-align:center;position:relative;overflow:hidden;box-shadow:0 25px 50px #0000004d;transform:scale(.8) translateY(30px);opacity:0;transition:all .6s cubic-bezier(.34,1.56,.64,1)}.win-screen-content.show{transform:scale(1) translateY(0);opacity:1}.win-animation{position:relative;margin-bottom:30px;height:120px}.celebration-circle{position:absolute;border-radius:50%;animation:float 3s ease-in-out infinite}.circle-1{width:80px;height:80px;background:linear-gradient(45deg,gold,#ffed4e);top:20px;left:50%;transform:translate(-50%);animation-delay:0s}.circle-2{width:60px;height:60px;background:linear-gradient(45deg,#ff6b6b,#ff8e8e);top:10px;right:20px;animation-delay:.5s}.circle-3{width:50px;height:50px;background:linear-gradient(45deg,#4ecdc4,#6dd5ed);top:30px;left:20px;animation-delay:1s}.celebration-stars{position:absolute;top:0;left:0;width:100%;height:100%}.star{position:absolute;color:gold;font-size:20px;animation:sparkle 2s ease-in-out infinite}.star-1{top:10px;left:10%;animation-delay:.2s}.star-2{top:20px;right:15%;animation-delay:.7s}.star-3{bottom:30px;left:20%;animation-delay:1.2s}.star-4{bottom:20px;right:10%;animation-delay:1.7s}.star-5{top:50%;left:5%;animation-delay:2.2s}.win-text{color:#fff;margin-bottom:70px}.win-title{font-size:32px;font-weight:700;margin:0 0 10px;text-shadow:2px 2px 4px rgba(0,0,0,.3);animation:glow 2s ease-in-out infinite alternate}.win-subtitle{font-size:18px;margin:0 0 15px;opacity:.9}.win-message{font-size:14px;margin:0;opacity:.8}.win-actions{display:flex;flex-direction:column;gap:15px}.win-button{background:linear-gradient(45deg,#2ecc71,#27ae60);color:#fff;border:none;border-radius:50px;padding:15px 25px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 8px 20px #2ecc714d}.win-button:hover{transform:translateY(-2px);box-shadow:0 12px 25px #2ecc7166}.win-button:active{transform:translateY(0)}.download-button{background:linear-gradient(45deg,#e74c3c,#c0392b);box-shadow:0 8px 20px #e74c3c4d}.download-button:hover{box-shadow:0 12px 25px #e74c3c66}.restart-button{background:linear-gradient(45deg,#3498db,#2980b9);box-shadow:0 8px 20px #3498db4d}.restart-button:hover{box-shadow:0 12px 25px #3498db66}.button-icon{font-size:18px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes sparkle{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}@keyframes glow{0%{text-shadow:2px 2px 4px rgba(0,0,0,.3)}to{text-shadow:2px 2px 4px rgba(0,0,0,.3),0 0 20px rgba(255,255,255,.5)}}@media (max-width: 480px){.win-screen-content{padding:30px 20px;margin:20px}.win-title{font-size:28px}.win-subtitle{font-size:16px}.win-message{font-size:13px}.win-button{padding:12px 20px;font-size:14px}}.app{margin:0;padding:0;background:linear-gradient(45deg,#deb887,wheat);display:flex;justify-content:center;align-items:center;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}.game-container{position:relative;width:min(440px,95vw);height:100vh;max-height:100vh;min-height:500px;padding:1vh;box-sizing:border-box;display:flex;flex-direction:column}.game-title{position:absolute;top:1vh;left:50%;transform:translate(-50%);font-size:clamp(14px,3vw,18px);font-weight:700;color:#8b4513;text-align:center;pointer-events:none;z-index:100}.game-subtitle{position:absolute;top:3.5vh;left:50%;transform:translate(-50%);font-size:clamp(9px,2vw,12px);color:#8b4513;text-align:center;pointer-events:none;width:300px;z-index:100}.progress-bar{position:absolute;top:7vh;left:50%;transform:translate(-50%);width:min(160px,40vw);height:clamp(10px,2vh,16px);background:linear-gradient(180deg,#2c1810,#1a0f08,#2c1810);border-radius:8px;overflow:hidden;border:2px solid #8b4513;box-shadow:inset 0 2px 4px #0006,inset 0 -2px 4px #ffffff1a,0 2px 8px #0000004d;z-index:100}.progress-bar:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0px,transparent 8px,rgba(139,69,19,.3) 8px,rgba(139,69,19,.3) 10px);pointer-events:none}.progress-bar:after{content:"";position:absolute;top:2px;left:2px;right:2px;height:2px;background:linear-gradient(90deg,rgba(255,255,255,.3) 0%,rgba(255,255,255,.1) 50%,transparent 100%);border-radius:4px;pointer-events:none}.progress-fill{height:100%;background:linear-gradient(180deg,var(--progress-color-top) 0%,var(--progress-color-mid) 50%,var(--progress-color-bottom) 100%);width:30%;min-width:12px;transition:width .3s ease,background .3s ease;border-radius:6px;position:relative;box-shadow:inset 0 1px 2px #ffffff4d,inset 0 -1px 2px #0000004d}.progress-fill:before{content:"";position:absolute;top:1px;left:1px;right:1px;height:2px;background:linear-gradient(90deg,#fff9,#fff3);border-radius:4px}.progress-fill:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0px,transparent 3px,rgba(0,0,0,.1) 3px,rgba(0,0,0,.1) 4px);border-radius:6px}.game-board{position:absolute;inset:11vh 1vh;background:transparent}.ui-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:200}.ui-button{position:absolute;pointer-events:auto;padding:clamp(6px,1.5vh,12px) clamp(12px,3vw,24px);background:linear-gradient(45deg,#4caf50,#45a049);color:#fff;border:none;border-radius:25px;cursor:pointer;font-size:clamp(12px,2.5vw,16px);font-weight:700;transition:all .3s;box-shadow:0 4px 15px #0003;text-transform:uppercase}.ui-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.hint-button{position:absolute;top:3vh;right:2vh;cursor:pointer;pointer-events:auto}.hint-image{width:clamp(50px,7vw,70px);height:clamp(50px,7vw,70px);display:block;transition:transform .3s ease}.hint-button:hover .hint-image{transform:scale(1.1)}.hint-counter{position:absolute;top:6%;right:11%;width:clamp(18px,3.5vw,24px);height:clamp(18px,3.5vw,24px);display:flex;align-items:center;justify-content:center;color:#fff;font-size:clamp(9px,2vw,12px);font-weight:700}.download-button{bottom:3vh;left:50%;transform:translate(-50%);background:linear-gradient(180deg,#a8ff78,#4caf50);font-size:clamp(16px,3vw,24px);padding:clamp(6px,1.5vh,12px) clamp(20px,5vw,40px);color:#fff;font-weight:700;letter-spacing:2px;border:3px solid #388e3c;border-radius:16px;box-shadow:0 6px #388e3c,0 8px 24px #0000004d;text-shadow:0 2px 0 #388e3c,0 4px 8px rgba(0,0,0,.5);position:absolute;overflow:hidden;z-index:1}.download-button:hover{transform:translate(-50%) translateY(-2px)}.download-button:before{content:"";position:absolute;top:8px;left:12px;width:60%;height:30%;background:#ffffff80;border-radius:50px 50px 30px 30px;pointer-events:none;z-index:2}@media (max-height: 600px){.game-container{min-height:450px;padding:.5vh}.game-title{top:.5vh;font-size:clamp(12px,2.5vw,16px)}.game-subtitle{top:2.5vh;font-size:clamp(8px,1.8vw,10px)}.progress-bar{top:5vh;height:clamp(8px,1.5vh,12px)}.game-board{top:8vh;bottom:8vh}.hint-button{top:2vh}.download-button{bottom:.5vh;font-size:clamp(14px,2.5vw,20px)}}@media (max-height: 500px){.game-container{min-height:400px;padding:.3vh}.game-title{top:.3vh;font-size:clamp(10px,2vw,14px)}.game-subtitle{top:2vh;font-size:clamp(7px,1.5vw,9px)}.progress-bar{top:4vh;height:clamp(6px,1vh,10px)}.game-board{top:6vh;bottom:6vh}.hint-button{top:1.5vh}.download-button{bottom:.3vh;font-size:clamp(12px,2vw,18px)}}
