body{font-family:system-ui,-apple-system,sans-serif}*{box-sizing:border-box;margin:0;padding:0}.app{width:100vw;height:100vh;height:100dvh;display:flex;flex-direction:column;align-items:center;background:#1a1a2e;padding:16px;padding-top:max(16px,env(safe-area-inset-top));padding-bottom:max(16px,env(safe-area-inset-bottom));overflow:hidden;gap:12px}.title{color:#fff;font-size:28px;font-weight:800;text-transform:uppercase;letter-spacing:3px;margin:0;flex-shrink:0;background:linear-gradient(135deg,#a5b4fc,#c4b5fd,#f0abfc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grid-toggle{display:flex;background:#ffffff1a;border-radius:12px;overflow:hidden;flex-shrink:0}.grid-toggle button{padding:12px 24px;font-size:16px;font-weight:600;border:none;background:transparent;color:#ffffff80;cursor:pointer;transition:all .2s ease}.grid-toggle button.active{background:#ffffff40;color:#f0abfc}.grid-toggle button:hover:not(.active){color:#e0e7ff}.status{color:#e0e7ff;font-size:16px;text-align:center;font-weight:500;flex-shrink:0}.status.loser{color:#fca5a5;font-size:22px;font-weight:700;animation:shake .5s ease-in-out,pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-10px)}40%{transform:translate(10px)}60%{transform:translate(-10px)}80%{transform:translate(10px)}}.grid{display:grid;grid-template-columns:repeat(var(--grid-cols),1fr);grid-template-rows:repeat(var(--grid-cols),1fr);flex:1;width:100%;max-width:100%;gap:0}.tile{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;transition:transform .15s ease;font-size:min(20vw,20vh)}.tile:hover:not(:disabled){transform:scale(1.1)}.tile:active:not(:disabled){transform:scale(.9)}.tile:disabled{cursor:default}.tile.safe{opacity:0;pointer-events:none;animation:fadeOut .3s ease-out forwards}.tile.loser{animation:explode .6s ease-out,loserGlow .8s ease-in-out infinite alternate;filter:drop-shadow(0 0 20px rgba(255,107,107,.8))}@keyframes loserGlow{0%{filter:drop-shadow(0 0 10px rgba(255,107,107,.5))}to{filter:drop-shadow(0 0 30px rgba(255,107,107,1))}}@keyframes fadeOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.5)}}@keyframes explode{0%{transform:scale(1)}15%{transform:scale(1.4) rotate(-10deg)}30%{transform:scale(1.6) rotate(10deg)}45%{transform:scale(1.3) rotate(-5deg)}60%{transform:scale(1.5) rotate(8deg)}75%{transform:scale(1.2) rotate(-3deg)}to{transform:scale(1) rotate(0)}}.reset-btn{padding:14px 32px;font-size:18px;font-weight:600;border:none;border-radius:12px;background:linear-gradient(135deg,#a5b4fc,#c4b5fd);color:#1a1a2e;cursor:pointer;transition:all .2s ease;animation:fadeIn .5s ease-out;flex-shrink:0}.reset-btn:hover{transform:scale(1.05);box-shadow:0 8px 25px #a5b4fc80}.reset-btn:active{transform:scale(.95)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out;padding:20px}.modal{background:linear-gradient(145deg,#2d2d4a,#1a1a2e);border-radius:24px;padding:40px;text-align:center;max-width:400px;width:100%;box-shadow:0 25px 50px #00000080;animation:modalPop .4s ease-out;border:1px solid rgba(255,255,255,.1);position:relative;overflow:visible}@keyframes modalPop{0%{opacity:0;transform:scale(.5) translateY(50px)}70%{transform:scale(1.05) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-emoji{font-size:80px;margin-bottom:16px;animation:bounce .6s ease-in-out infinite,wiggle .3s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}@keyframes wiggle{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}.modal-title{color:#fca5a5;font-size:36px;font-weight:800;margin-bottom:12px;text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 20px rgba(252,165,165,.5);animation:titlePulse .5s ease-in-out infinite alternate,glowPulse 1s ease-in-out infinite}@keyframes titlePulse{0%{transform:scale(1)}to{transform:scale(1.05)}}@keyframes glowPulse{0%,to{text-shadow:0 0 20px rgba(252,165,165,.5)}50%{text-shadow:0 0 40px rgba(252,165,165,.8),0 0 60px rgba(252,165,165,.4)}}.modal-message{color:#fffc;font-size:18px;margin-bottom:28px;line-height:1.5}.modal-btn{padding:16px 40px;font-size:18px;font-weight:600;border:none;border-radius:12px;background:linear-gradient(135deg,#a5b4fc,#c4b5fd);color:#1a1a2e;cursor:pointer;transition:all .2s ease}.modal-btn:hover{transform:scale(1.05);box-shadow:0 8px 25px #a5b4fc80}.modal-btn:active{transform:scale(.95)}.confetti{position:absolute;width:10px;height:10px;border-radius:2px;animation:confettiFall 3s ease-in-out infinite;pointer-events:none}.confetti:nth-child(1){left:10%;background:#ff6b6b;animation-delay:0s}.confetti:nth-child(2){left:20%;background:#feca57;animation-delay:.2s}.confetti:nth-child(3){left:30%;background:#48dbfb;animation-delay:.4s}.confetti:nth-child(4){left:40%;background:#ff9ff3;animation-delay:.1s}.confetti:nth-child(5){left:50%;background:#54a0ff;animation-delay:.3s}.confetti:nth-child(6){left:60%;background:#5f27cd;animation-delay:.5s}.confetti:nth-child(7){left:70%;background:#00d2d3;animation-delay:.15s}.confetti:nth-child(8){left:80%;background:#ff6b6b;animation-delay:.35s}.confetti:nth-child(9){left:90%;background:#feca57;animation-delay:.25s}.confetti:nth-child(10){left:15%;background:#1dd1a1;animation-delay:.45s}.confetti:nth-child(11){left:25%;background:#ff9f43;animation-delay:.55s}.confetti:nth-child(12){left:35%;background:#ee5a24;animation-delay:.05s}.confetti:nth-child(13){left:45%;background:#48dbfb;animation-delay:.6s}.confetti:nth-child(14){left:55%;background:#a29bfe;animation-delay:.22s}.confetti:nth-child(15){left:65%;background:#fd79a8;animation-delay:.42s}.confetti:nth-child(16){left:75%;background:#00cec9;animation-delay:.12s}.confetti:nth-child(17){left:85%;background:#fdcb6e;animation-delay:.32s}.confetti:nth-child(18){left:5%;background:#e17055;animation-delay:.52s}.confetti:nth-child(19){left:95%;background:#74b9ff;animation-delay:.18s}.confetti:nth-child(20){left:50%;background:#b2bec3;animation-delay:.38s}@keyframes confettiFall{0%{transform:translateY(-100px) rotate(0) scale(1);opacity:1}50%{opacity:1}to{transform:translateY(400px) rotate(720deg) scale(.5);opacity:0}}.modal-overlay:before{content:"";position:absolute;top:50%;left:50%;width:300px;height:300px;background:radial-gradient(circle,rgba(255,107,107,.3) 0%,transparent 70%);transform:translate(-50%,-50%);animation:spotlightPulse 1.5s ease-in-out infinite;pointer-events:none}@keyframes spotlightPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.5);opacity:.8}}.modal-message{animation:messageAppear .5s ease-out .3s both}@keyframes messageAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.app{padding:12px;gap:10px}.grid-toggle button{padding:10px 20px;font-size:14px}.status{font-size:14px}.status.loser{font-size:18px}.tile{font-size:min(22vw,18vh)}.reset-btn{padding:12px 24px;font-size:16px}.modal{padding:30px 24px;border-radius:20px}.modal-emoji{font-size:60px}.modal-title{font-size:28px}.modal-message{font-size:16px;margin-bottom:24px}.modal-btn{padding:14px 32px;font-size:16px}}@media(max-width:360px){.tile{font-size:min(20vw,16vh)}.modal-emoji{font-size:50px}.modal-title{font-size:24px}}@media(orientation:landscape)and (max-height:500px){.app{flex-direction:row;flex-wrap:wrap;justify-content:center;align-content:center;gap:10px;padding:10px}.grid-toggle{position:absolute;top:10px;left:10px}.grid-toggle button{padding:8px 14px;font-size:12px}.status{position:absolute;top:10px;right:10px;font-size:12px}.status.loser{font-size:14px}.grid{width:auto;height:calc(100vh - 60px);aspect-ratio:1}.tile{font-size:min(15vh,12vw)}.reset-btn{position:absolute;bottom:10px;left:50%;transform:translate(-50%);padding:8px 20px;font-size:14px}.modal{padding:20px 30px;max-width:350px}.modal-emoji{font-size:40px;margin-bottom:10px}.modal-title{font-size:22px;margin-bottom:8px}.modal-message{font-size:14px;margin-bottom:16px}.modal-btn{padding:10px 24px;font-size:14px}}@media(min-width:768px){.status{font-size:20px}.status.loser{font-size:26px}.tile{font-size:min(15vw,15vh,120px)}.modal{padding:50px}.modal-emoji{font-size:100px}.modal-title{font-size:42px}.modal-message{font-size:20px}}
