@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@600;700&family=Space+Mono:wght@400;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:Space Mono,monospace;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;overflow-x:hidden}.app{min-height:100vh;padding:2rem;position:relative}.app:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.05) 0%,transparent 50%);animation:float 20s ease-in-out infinite;pointer-events:none;z-index:0}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(120deg)}66%{transform:translate(-20px,20px) rotate(240deg)}}.header{text-align:center;margin-bottom:3rem;position:relative;z-index:1}.main-title{font-family:Fredoka,sans-serif;font-size:clamp(2.5rem,8vw,5rem);font-weight:700;color:#fff;text-shadow:4px 4px 0px rgba(0,0,0,.2),8px 8px 0px rgba(0,0,0,.1);letter-spacing:-.02em;margin-bottom:.5rem;animation:slideDown .6s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.subtitle{font-size:1.1rem;color:#ffffffe6;font-weight:400;animation:fadeIn .8s ease-out .2s both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;max-width:1400px;margin:0 auto;position:relative;z-index:1}@media(max-width:768px){.app{padding:1.5rem}.games-grid{grid-template-columns:1fr;gap:1.5rem}.main-title{font-size:2.5rem}}.game-card{position:relative;cursor:pointer;animation:cardEnter .5s ease-out both}.game-card:nth-child(1){animation-delay:.1s}.game-card:nth-child(2){animation-delay:.2s}.game-card:nth-child(3){animation-delay:.3s}.game-card:nth-child(4){animation-delay:.4s}@keyframes cardEnter{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.card-inner{background:#fffffff2;border-radius:20px;padding:2rem;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);border:3px solid transparent;box-shadow:0 10px 30px #0003}.card-inner:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:var(--card-color);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.card-inner.hovered:before{transform:scaleX(1)}.card-inner.hovered{transform:translateY(-8px) scale(1.02);border-color:var(--card-color);box-shadow:0 20px 40px #0000004d,0 0 0 3px var(--card-color)}.card-glow{position:absolute;top:-100%;left:-100%;width:300%;height:300%;background:radial-gradient(circle,var(--card-color) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.card-inner.hovered .card-glow{opacity:.1}.game-title{font-family:Fredoka,sans-serif;font-size:2rem;font-weight:700;color:#2d3748;margin-bottom:.75rem;position:relative;z-index:1}.game-description{color:#4a5568;line-height:1.6;margin-bottom:1.5rem;font-size:.95rem;position:relative;z-index:1}.game-meta{display:flex;align-items:center;gap:1rem;position:relative;z-index:1}.player-count{background:var(--card-color);color:#fff;padding:.4rem .9rem;border-radius:20px;font-size:.85rem;font-weight:700;letter-spacing:.02em}.play-arrow{position:absolute;bottom:1.5rem;right:1.5rem;font-size:2rem;color:var(--card-color);opacity:0;transform:translate(-10px);transition:all .3s ease;z-index:1}.card-inner.hovered .play-arrow{opacity:1;transform:translate(0)}.connect4-container{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem}.game-status{text-align:center}.game-status h2{font-family:Fredoka,sans-serif;font-size:2rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.winner-text{animation:bounce .5s ease}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.board{background:#2563eb;padding:1rem;border-radius:10px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;gap:.5rem}.row{display:flex;gap:.5rem}.cell{width:70px;height:70px;background:#fff;border-radius:50%;cursor:pointer;position:relative;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.cell.hovered{background:#f0f0f0;transform:scale(1.05)}.cell.empty .piece{display:none}.cell.red .piece{width:60px;height:60px;background:#ef4444;border-radius:50%;box-shadow:inset 0 -5px 10px #0000004d;animation:drop .3s ease}.cell.yellow .piece{width:60px;height:60px;background:#fbbf24;border-radius:50%;box-shadow:inset 0 -5px 10px #0000004d;animation:drop .3s ease}@keyframes drop{0%{transform:translateY(-400px)}to{transform:translateY(0)}}.reset-button{padding:1rem 2rem;font-size:1.2rem;font-weight:700;background:#fff;color:#2563eb;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;font-family:Fredoka,sans-serif}.reset-button:hover{background:#f0f0f0;transform:scale(1.05)}@media(max-width:768px){.cell{width:50px;height:50px}.cell.red .piece,.cell.yellow .piece{width:42px;height:42px}}
