*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}#root{width:100%;height:100vh}button{border-radius:8px;border:none;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .3s ease}button:active{transform:scale(.95)}input[type=range]{-webkit-appearance:none;appearance:none;background:transparent;cursor:pointer}input[type=range]:focus{outline:none}.level,.level *{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}html{scroll-behavior:smooth}.app{width:100%;height:100vh;position:relative;overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.progress-indicator{position:fixed;top:2rem;left:2rem;display:flex;gap:1rem;z-index:1000;padding:1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50px;box-shadow:0 4px 15px #0003}.progress-dot{width:15px;height:15px;border-radius:50%;background:#fff6;transition:all .3s ease;position:relative}.progress-dot.active{background:#fff;box-shadow:0 0 15px #fffc;transform:scale(1.3)}.progress-dot.active:after{content:"";position:absolute;width:100%;height:100%;border-radius:50%;background:#ffffff80;animation:pulse-ring 1.5s ease-out infinite}@keyframes pulse-ring{0%{transform:scale(1);opacity:1}to{transform:scale(2.5);opacity:0}}.progress-dot.completed{background:linear-gradient(135deg,#4caf50,#8bc34a);box-shadow:0 0 10px #4caf50cc}.level{width:100%;height:100vh;position:relative;display:flex;align-items:center;justify-content:center}.level-content{width:100%;height:100%;position:relative}.superpower-icon{font-size:6rem;margin-bottom:1rem;animation:icon-appear 1s ease}@keyframes icon-appear{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.superpower-title{font-size:3rem;color:#fff;margin-bottom:1rem;text-shadow:0 2px 10px rgba(0,0,0,.3);animation:title-appear 1s ease .2s backwards}@keyframes title-appear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.superpower-description{font-size:1.3rem;color:#fff;max-width:600px;margin:0 auto;line-height:1.8;text-shadow:0 1px 5px rgba(0,0,0,.3);animation:description-appear 1s ease .4s backwards}@keyframes description-appear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.next-level-button{margin-top:2rem;padding:1rem 3rem;font-size:1.3rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#fff3,#ffffff1a);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.5);border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003;animation:button-appear 1s ease .6s backwards}.next-level-button:hover{background:linear-gradient(135deg,#ffffff4d,#fff3);border-color:#fffc;transform:translateY(-3px);box-shadow:0 6px 20px #0000004d}.next-level-button:active{transform:translateY(-1px)}@keyframes button-appear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.progress-indicator{top:1rem;left:1rem;gap:.6rem;padding:.8rem}.progress-dot{width:12px;height:12px}.superpower-icon{font-size:4rem}.superpower-title{font-size:2rem}.superpower-description{font-size:1.1rem;padding:0 1rem}.next-level-button{font-size:1.1rem;padding:.8rem 2rem}}@media(hover:none)and (pointer:coarse){.level{touch-action:manipulation}button,.clickable,.key,.point,.cozy-item,.humor-item{min-width:44px;min-height:44px}}.start-screen{width:100%;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.start-screen:before{content:"";position:absolute;width:100%;height:100%;background-image:radial-gradient(circle,rgba(255,255,255,.1) 2px,transparent 2px),radial-gradient(circle,rgba(255,255,255,.1) 2px,transparent 2px);background-size:60px 60px,80px 80px;background-position:0 0,40px 40px;animation:pattern-move 20s linear infinite}@keyframes pattern-move{0%{background-position:0 0,40px 40px}to{background-position:60px 60px,100px 100px}}.start-content{text-align:center;z-index:10;animation:fade-in-up 1s ease;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:2rem}.photo-frame{width:450px;height:450px;border-radius:50%;overflow:hidden;border:5px solid rgba(255,255,255,.8);box-shadow:0 10px 40px #0000004d;animation:photo-glow 3s ease-in-out infinite}@keyframes photo-glow{0%,to{box-shadow:0 10px 40px #0000004d}50%{box-shadow:0 10px 50px #ffffff80}}.main-photo{width:100%;height:100%;object-fit:cover}.floating-photos{position:absolute;width:100%;height:100%;pointer-events:none;z-index:5}.floating-photo{position:absolute;width:180px;height:180px;border-radius:15px;object-fit:cover;border:3px solid rgba(255,255,255,.6);box-shadow:0 5px 20px #0000004d;opacity:.7;animation:float-photo 4s ease-in-out infinite}.floating-photo:nth-child(1){animation-duration:5s}.floating-photo:nth-child(2){animation-duration:6s;animation-delay:1s}.floating-photo:nth-child(3){animation-duration:5.5s;animation-delay:2s}.floating-photo:nth-child(4){animation-duration:6.5s;animation-delay:.5s}@keyframes float-photo{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-15px) rotate(5deg)}50%{transform:translateY(-30px) rotate(-5deg)}75%{transform:translateY(-15px) rotate(3deg)}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.title-container{margin-bottom:1rem}.title-container h1{font-size:3.5rem;font-weight:800;color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.3);animation:title-glow 3s ease-in-out infinite;margin:0}.main-title{font-size:3.5rem;font-weight:800;color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.3);animation:title-glow 3s ease-in-out infinite}@keyframes title-glow{0%,to{text-shadow:0 4px 20px rgba(0,0,0,.3)}50%{text-shadow:0 4px 30px rgba(255,255,255,.5),0 0 40px rgba(255,255,255,.3)}}.subtitle{font-size:1.5rem;color:#fffffff2;text-shadow:0 2px 10px rgba(0,0,0,.3);font-weight:400}.intro-text{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:2rem;margin-bottom:3rem;box-shadow:0 8px 32px #0003}.intro-text p{font-size:1.3rem;color:#fff;margin-bottom:1.5rem;line-height:1.6}.preview-icons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.preview-icons span{font-size:2.5rem;animation:bounce-icon 2s ease-in-out infinite;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.preview-icons span:nth-child(1){animation-delay:0s}.preview-icons span:nth-child(2){animation-delay:.2s}.preview-icons span:nth-child(3){animation-delay:.4s}.preview-icons span:nth-child(4){animation-delay:.6s}.preview-icons span:nth-child(5){animation-delay:.8s}.preview-icons span:nth-child(6){animation-delay:1s}@keyframes bounce-icon{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.start-button{background:linear-gradient(135deg,#fff,#f0f0f0);color:#667eea;font-size:1.8rem;font-weight:700;padding:1.5rem 5rem;border:none;border-radius:50px;cursor:pointer;box-shadow:0 10px 30px #0000004d;transition:all .3s ease;animation:pulse-button 2s ease-in-out infinite}.start-button:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 15px 40px #0006}.start-button:active{transform:translateY(-2px) scale(1.02)}@keyframes pulse-button{0%,to{box-shadow:0 10px 30px #0000004d}50%{box-shadow:0 10px 40px #fff6}}.button-icon{font-size:2rem;animation:rotate-icon 2s linear infinite}@keyframes rotate-icon{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.decorative-elements{position:absolute;width:100%;height:100%;pointer-events:none}.floating-element{position:absolute;font-size:3rem;animation:float-around 6s ease-in-out infinite;opacity:.7;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.floating-element:nth-child(1){animation-duration:5s}.floating-element:nth-child(2){animation-duration:7s;animation-delay:1s}.floating-element:nth-child(3){animation-duration:6s;animation-delay:2s}.floating-element:nth-child(4){animation-duration:8s;animation-delay:.5s}@keyframes float-around{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(20px,-20px) rotate(90deg)}50%{transform:translate(-20px,-40px) rotate(180deg)}75%{transform:translate(-40px,-20px) rotate(270deg)}}@media(max-width:768px){.photo-frame{width:350px;height:350px}.main-title{font-size:2rem}.subtitle{font-size:1.2rem}.floating-photo{width:120px;height:120px}.intro-text{padding:1.5rem;margin-bottom:2rem}.intro-text p{font-size:1.1rem}.preview-icons span{font-size:2rem}.start-button{font-size:1.2rem;padding:1.2rem 3rem}.button-icon{font-size:1.5rem}.floating-element{font-size:2rem}}.level1{background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.level1:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:shimmer 3s infinite}@keyframes shimmer{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(10%,10%) rotate(180deg)}}.ice-container{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#c8e6ffcc,#96c8ffe6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:opacity .3s ease;cursor:pointer}.ice-overlay{text-align:center;color:#003d66}.ice-crystal{font-size:8rem;animation:float 3s ease-in-out infinite,sparkle 2s infinite;filter:drop-shadow(0 0 20px rgba(255,255,255,.8))}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes sparkle{0%,to{filter:drop-shadow(0 0 20px rgba(255,255,255,.8))}50%{filter:drop-shadow(0 0 40px rgba(255,255,255,1))}}.ice-hint{font-size:1.5rem;font-weight:600;margin-top:2rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}.superpower-reveal{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;transition:opacity .5s ease;z-index:10}.superpower-icon{font-size:6rem;margin-bottom:1rem;filter:drop-shadow(0 0 30px rgba(255,100,100,.6))}.superpower-title{font-size:3rem;color:#fff;margin-bottom:1rem;text-shadow:0 2px 10px rgba(0,0,0,.3)}.superpower-description{font-size:1.3rem;color:#fff;max-width:600px;line-height:1.8;text-shadow:0 1px 5px rgba(0,0,0,.3)}.animate-in{animation:fadeInUp 1s ease forwards}.progress-bar{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);width:80%;max-width:400px;height:10px;background:#ffffff4d;border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#ff6b6b,#ff8e8e);border-radius:10px;transition:width .3s ease;box-shadow:0 0 20px #ff6b6b99}@media(max-width:768px){.ice-crystal{font-size:5rem}.ice-hint{font-size:1.2rem}.superpower-icon{font-size:4rem}.superpower-title{font-size:2rem}.superpower-description{font-size:1.1rem}}.level2{background:linear-gradient(135deg,#f093fb,#f5576c);position:relative;overflow:hidden}.puzzle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:1rem auto;max-width:400px;padding:.8rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #0000004d}.puzzle-piece{aspect-ratio:1;background-size:300% 300%;background-repeat:no-repeat;cursor:grab;border:3px solid rgba(255,255,255,.3);border-radius:12px;transition:all .3s ease;box-shadow:0 4px 15px #0003}.puzzle-piece:hover{transform:scale(1.05);border-color:#fff9;box-shadow:0 6px 20px #ffffff4d}.puzzle-piece.dragging{opacity:.5;cursor:grabbing;transform:scale(1.1)}.puzzle-piece.correct{border-color:#4caf50;box-shadow:0 0 20px #4caf5099}@media(max-width:768px){.puzzle-grid{max-width:320px;gap:6px;padding:.8rem}.puzzle-piece{border-width:2px;border-radius:8px}.completion-message{padding:1.5rem;margin-top:1.5rem}.wish-text{font-size:1.1rem;line-height:1.6}}.level3{background:linear-gradient(135deg,#4facfe,#00f2fe);position:relative;overflow:hidden}.content-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:10;width:90%;max-width:800px}.hearts-container{display:flex;justify-content:space-around;align-items:center;margin:2rem auto;max-width:700px;gap:2rem}.heart-section{flex:1;text-align:center}.heart{font-size:5rem;cursor:pointer;transition:transform .15s ease;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 4px 20px rgba(0,0,0,.3))}.player-heart:active{transform:scale(.9)}.target-heart.beating{animation:heartbeat .3s ease}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.heart-label{margin-top:.5rem;font-size:1.1rem;color:#fff;font-weight:600;text-shadow:0 2px 10px rgba(0,0,0,.3)}.heart-hint{margin-top:.25rem;font-size:.9rem;color:#fffc;font-style:italic}.sync-indicator{flex:0 0 auto;min-width:120px;text-align:center}.sync-bar{width:100%;height:30px;background:#fff3;border-radius:15px;overflow:hidden;box-shadow:inset 0 2px 10px #0003}.sync-fill{height:100%;background:linear-gradient(90deg,#ff6b6b,#4ecdc4,#45b7d1);transition:width .3s ease;border-radius:15px;box-shadow:0 0 20px #45b7d199}.sync-label{margin-top:.5rem;font-size:.9rem;color:#fff;font-weight:600;text-shadow:0 2px 5px rgba(0,0,0,.3)}.completion-message{margin-top:2rem;padding:2rem;background:#ffffff26;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;box-shadow:0 8px 32px #0003}.wish-text{font-size:1.4rem;line-height:1.8;color:#fff;margin-bottom:1.5rem;text-shadow:0 2px 10px rgba(0,0,0,.3);font-weight:500}@media(max-width:768px){.hearts-container{flex-direction:column;gap:2rem}.heart{font-size:4rem}.sync-indicator{order:-1;width:100%;min-width:auto}.completion-message{padding:1.5rem}.wish-text{font-size:1.1rem;line-height:1.6}}.level4{background:linear-gradient(135deg,#2c3e50,#34495e);position:relative;overflow:hidden;transition:filter .5s ease}.room-background{width:100%;height:100%;position:relative;background-size:cover;background-position:center;background-repeat:no-repeat}.hint-text{position:absolute;top:2rem;left:50%;transform:translate(-50%);text-align:center;color:#ffffffe6;z-index:10}.hint-text p{font-size:1.2rem;opacity:.8;text-shadow:0 1px 5px rgba(0,0,0,.5)}.cozy-item{position:absolute;width:80px;height:80px;cursor:pointer;transform:translate(-50%,-50%);transition:all .3s ease;filter:grayscale(1) brightness(.5);opacity:.6}.cozy-item:hover:not(.activated){transform:translate(-50%,-50%) scale(1.2);filter:grayscale(.7) brightness(.7);opacity:.8}.cozy-item.activated{filter:grayscale(0) brightness(1.5) drop-shadow(0 0 20px rgba(255,200,0,.8));opacity:1;animation:activate .8s ease}@keyframes activate{0%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.5) rotate(10deg)}to{transform:translate(-50%,-50%) scale(1) rotate(0)}}.item-emoji{font-size:4rem;text-align:center;position:relative;z-index:2;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}.item-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120%;height:120%;background:radial-gradient(circle,rgba(255,200,100,0),transparent);border-radius:50%;opacity:0;transition:opacity .5s ease}.cozy-item.activated .item-glow{opacity:1;background:radial-gradient(circle,rgba(255,200,100,.6),transparent);animation:glow-pulse 2s ease-in-out infinite}@keyframes glow-pulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.3);opacity:1}}.item-sparkles{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:1.5rem;animation:sparkle-float 2s ease-in-out infinite}@keyframes sparkle-float{0%,to{transform:translate(-50%) translateY(0);opacity:1}50%{transform:translate(-50%) translateY(-20px);opacity:.5}}.warmth-indicator{position:absolute;bottom:3rem;left:50%;transform:translate(-50%);width:80%;max-width:400px;color:#fff;text-align:center}.warmth-indicator span{display:block;font-size:1.3rem;margin-bottom:.8rem;font-weight:600;text-shadow:0 2px 5px rgba(0,0,0,.5)}.warmth-bar{width:100%;height:12px;background:#fff3;border-radius:10px;overflow:hidden;box-shadow:inset 0 2px 5px #0000004d}.warmth-fill{height:100%;background:linear-gradient(90deg,#ff9a56,#ffcc70,gold);border-radius:10px;transition:width .5s ease;box-shadow:0 0 20px #ffc864cc}@media(max-width:768px){.hint-text h3{font-size:1.5rem}.hint-text p{font-size:1rem}.cozy-item{width:80px;height:80px}.item-emoji{font-size:3rem}}.level5{background:linear-gradient(135deg,#1e3c72,#2a5298);position:relative;overflow:hidden;width:100%;height:100vh}.hint-text h3{font-size:2rem;margin-bottom:.5rem;text-shadow:0 2px 10px rgba(0,0,0,.5)}.hint-text p{font-size:1.2rem;opacity:.9;text-shadow:0 1px 5px rgba(0,0,0,.5)}.door-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:300px;height:450px;perspective:1000px}.door{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform 1s ease}.door-left,.door-right{position:absolute;width:50%;height:100%;background:linear-gradient(135deg,#8b5a3c,#6d4c41);border:4px solid #4a3228;box-shadow:inset 0 0 30px #00000080,0 10px 30px #00000080;transition:transform 1s ease;transform-origin:center}.door-left{left:0;border-radius:10px 0 0 10px}.door-right{right:0;border-radius:0 10px 10px 0}.door.open .door-left{transform:rotateY(-120deg)}.door.open .door-right{transform:rotateY(120deg)}.lock{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;background:radial-gradient(circle,gold,#ffb700);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px #ffd70099,inset 0 0 10px #0000004d;z-index:10;transition:all .5s ease}.door.open .lock{transform:translate(-50%,-50%) scale(0);opacity:0}.lock-icon{font-size:2.5rem;filter:drop-shadow(0 2px 5px rgba(0,0,0,.3))}.keys-container{position:absolute;bottom:4rem;left:50%;transform:translate(-50%);display:flex;gap:1.5rem;z-index:20}.key{width:70px;height:70px;background:linear-gradient(135deg,#f5f5f5,#d4d4d4);border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:grab;transition:all .3s ease;box-shadow:0 5px 15px #0000004d}.key:hover{transform:translateY(-10px) scale(1.1);box-shadow:0 10px 25px #0006}.key:active,.key.dragging{cursor:grabbing;transform:scale(1.15)}.key.wrong{animation:shake .5s ease;background:linear-gradient(135deg,#ff6b6b,#ff4757)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.key-icon{font-size:2.5rem;filter:drop-shadow(0 2px 5px rgba(0,0,0,.3))}.sudoku-container{position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:20;margin:0;padding:0}.sudoku-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:fit-content;padding:1.5rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #0000004d}.sudoku-cell{width:80px;height:80px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;border-radius:12px;transition:all .3s ease;-webkit-user-select:none;user-select:none}.sudoku-cell.fixed{background:#fff3;color:#fff;cursor:default;box-shadow:inset 0 2px 10px #0003}.sudoku-cell.editable{background:#ffffff4d;color:gold;cursor:pointer;border:3px solid rgba(255,255,255,.4);box-shadow:0 4px 15px #0003}.sudoku-cell.editable:hover{background:#ffffff80;transform:scale(1.1);border-color:#ffd700cc;box-shadow:0 6px 20px #ffd70066}.sudoku-cell.editable:active{transform:scale(1.05);background:#ffd7004d}.sudoku-cell.solved{background:#4caf504d;border-color:#4caf50;animation:celebrate .6s ease}@keyframes celebrate{0%,to{transform:scale(1)}25%{transform:scale(1.1) rotate(5deg)}75%{transform:scale(1.1) rotate(-5deg)}}@media(max-width:768px){.hint-text h3{font-size:1.5rem}.hint-text p{font-size:1rem}.door-container{width:250px;height:375px}.keys-container{gap:1rem}.key{width:60px;height:60px}.key-icon{font-size:2rem}.sudoku-grid{padding:1rem}.sudoku-cell{width:70px;height:70px;font-size:2rem}}.level6{background:linear-gradient(135deg,#fa709a,#fee140);position:relative;overflow:hidden}.level6:before{content:"";position:absolute;width:100%;height:100%;background-image:radial-gradient(circle,rgba(255,255,255,.2) 1px,transparent 1px),radial-gradient(circle,rgba(255,255,255,.15) 1px,transparent 1px);background-size:50px 50px,80px 80px;background-position:0 0,40px 40px;animation:slide 20s linear infinite}@keyframes slide{0%{background-position:0 0,40px 40px}to{background-position:50px 50px,90px 90px}}.hint-text{position:absolute;top:2rem;left:50%;transform:translate(-50%);text-align:center;color:#fff;z-index:10}.hint-text h3{font-size:2rem;margin-bottom:.5rem;text-shadow:0 2px 10px rgba(0,0,0,.3)}.hint-text p{font-size:1.2rem;opacity:.95;text-shadow:0 1px 5px rgba(0,0,0,.3)}.memes-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;gap:2rem;z-index:5;align-items:center;justify-content:center}.meme-card{cursor:pointer;transition:all .3s ease;border-radius:20px;overflow:hidden;box-shadow:0 10px 30px #0000004d;background:#fff}.meme-card:hover{transform:translateY(-15px) scale(1.05);box-shadow:0 15px 40px #0006}.meme-image{max-width:400px;max-height:400px;width:auto;height:auto;object-fit:contain;display:block}@media(max-width:768px){.memes-container{flex-direction:column;gap:1.5rem}.meme-image{max-width:300px;max-height:300px}.hint-text h3{font-size:1.5rem}.hint-text p{font-size:1rem}}@keyframes wrong-shake{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-10px) rotate(-5deg)}75%{transform:translate(10px) rotate(5deg)}}.humor-item.correct .item-box{animation:correct-bounce .8s ease;background:#ffff96}@keyframes correct-bounce{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.3) rotate(10deg)}50%{transform:scale(.9) rotate(-10deg)}75%{transform:scale(1.2) rotate(5deg)}}.humor-item.revealed .item-box{animation:revealed-dance 1s ease infinite}@keyframes revealed-dance{0%,to{transform:rotate(0) scale(1.2)}25%{transform:rotate(-15deg) scale(1.3)}75%{transform:rotate(15deg) scale(1.3)}}.laugh-effect{position:absolute;top:-40px;left:50%;transform:translate(-50%);display:flex;gap:1rem;animation:laugh-appear .5s ease}@keyframes laugh-appear{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.laugh-effect span{font-size:2rem;animation:laugh-bounce 1s ease-in-out infinite;filter:drop-shadow(0 2px 5px rgba(0,0,0,.3))}.laugh-effect span:nth-child(1){animation-delay:0s}.laugh-effect span:nth-child(2){animation-delay:.2s}.laugh-effect span:nth-child(3){animation-delay:.4s}@keyframes laugh-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.superpower-reveal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:30;width:90%;max-width:700px}.fade-in{animation:fadeInScale 1s ease forwards}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@media(max-width:768px){.hint-text h3{font-size:1.5rem}.hint-text p{font-size:1rem}.items-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.item-box{width:100px;height:100px}.item-emoji{font-size:3rem}}.final-screen{width:100%;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);position:relative;overflow-y:auto;overflow-x:hidden}.final-content{max-width:1200px;margin:0 auto;padding:3rem 2rem;position:relative;z-index:10}.celebration{text-align:center;margin-bottom:3rem;animation:fadeInDown 1s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.celebration-emoji{font-size:5rem;animation:rotate-scale 2s ease-in-out infinite;display:inline-block;margin-bottom:1rem}@keyframes rotate-scale{0%,to{transform:rotate(0) scale(1)}25%{transform:rotate(-15deg) scale(1.2)}75%{transform:rotate(15deg) scale(1.2)}}.final-title{font-size:3rem;color:#fff;margin-bottom:1rem;text-shadow:0 4px 10px rgba(0,0,0,.3);font-weight:700}.final-subtitle{font-size:1.5rem;color:#fffffff2;text-shadow:0 2px 5px rgba(0,0,0,.3)}.photo-gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem;margin:3rem auto;padding:0 2rem;max-width:1400px}.gallery-photo{border-radius:25px;overflow:hidden;box-shadow:0 15px 40px #00000080;animation:photoAppear .8s ease forwards;opacity:0;transition:all .5s cubic-bezier(.34,1.56,.64,1);position:relative;cursor:pointer;transform-origin:center}.photo-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#667eeacc,#764ba2cc);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s ease;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);padding:1rem}.photo-heart{font-size:4rem;transform:scale(0) rotate(-15deg);transition:transform .5s cubic-bezier(.34,1.56,.64,1);filter:drop-shadow(0 5px 15px rgba(0,0,0,.5))}.photo-emoji{width:100%;height:100%;max-width:50px;max-height:50px;object-fit:contain;transform:scale(0) rotate(-15deg);transition:transform .5s cubic-bezier(.34,1.56,.64,1);filter:drop-shadow(0 5px 15px rgba(0,0,0,.5))}.gallery-photo:hover .photo-overlay{opacity:1}.gallery-photo:hover .photo-heart,.gallery-photo:hover .photo-emoji{transform:scale(1) rotate(0)}.photo-1,.photo-4,.photo-7{grid-column:span 2;grid-row:span 2}.gallery-photo:hover{transform:translateY(-15px) scale(1.05);box-shadow:0 25px 70px #ffffff80;z-index:10}.gallery-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:filter .5s ease;border-radius:25px}.gallery-photo:hover img{filter:brightness(1.15) saturate(1.1)}@keyframes photoAppear{0%{opacity:0;transform:scale(.5) translateY(50px) rotate(-10deg)}to{opacity:1;transform:scale(1) translateY(0) rotate(0)}}} } .personal-touches{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-bottom:3rem}.personal-item{background:#ffffffe6;padding:1rem 2rem;border-radius:50px;font-size:1.3rem;font-weight:600;color:#333;box-shadow:0 5px 15px #0003;animation:fadeIn 1s ease forwards;opacity:0}@keyframes fadeIn{to{opacity:1}}.animate-float{animation:float-item 3s ease-in-out infinite}@keyframes float-item{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.restart-button{display:block;margin:0 auto 3rem;padding:1.2rem 3rem;font-size:1.3rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50px;cursor:pointer;box-shadow:0 8px 20px #0000004d;transition:all .3s ease;animation:pulse-button 2s ease-in-out infinite}.restart-button:hover{transform:scale(1.1);box-shadow:0 12px 30px #0006}.restart-button:active{transform:scale(.95)}@keyframes pulse-button{0%,to{box-shadow:0 8px 20px #0000004d}50%{box-shadow:0 8px 30px #667eea99}}.restart-button span{display:inline-block;margin-right:.5rem;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.birthday-message{text-align:center;color:#fff;animation:fadeInUp 1.5s ease}.birthday-message p{font-size:2rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 3px 8px rgba(0,0,0,.3)}.birthday-wish{font-size:1.3rem!important;font-weight:400!important;opacity:.95}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.confetti{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:5}.confetti-piece{position:absolute;width:10px;height:10px;top:-10px;opacity:.8;animation:confetti-fall 5s linear infinite}@keyframes confetti-fall{to{transform:translateY(100vh) rotate(360deg);opacity:0}}@media(max-width:768px){.final-content{padding:2rem 1rem}.celebration-emoji{font-size:3.5rem}.final-title{font-size:2rem}.final-subtitle{font-size:1.2rem}.photo-gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px;gap:.8rem;padding:0 1rem}.photo-1,.photo-4,.photo-7{grid-column:span 2;grid-row:span 2}.photo-2,.photo-3,.photo-5,.photo-6,.photo-8,.photo-9,.photo-10{grid-column:span 1;grid-row:span 1}.photo-10{grid-row:span 1}.personal-item{font-size:1.1rem;padding:.8rem 1.5rem}.restart-button{font-size:1.1rem;padding:1rem 2rem}.birthday-message p{font-size:1.5rem}.birthday-wish{font-size:1.1rem!important}}
