:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}#root{width:100%;min-height:100vh}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}@media (max-width: 768px){h1{font-size:2.5em}h2{font-size:1.8em}h3{font-size:1.3em}p,button,input{font-size:.95em}}@media (max-width: 480px){h1{font-size:2em}h2{font-size:1.5em}h3{font-size:1.2em}p,button,input{font-size:.9em}}#root{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.landing-page{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background-color:#242424}.hero{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;padding:0 2rem}.hero h1{font-size:4rem;margin:.5rem 0;color:#fff}.hero p{font-size:1.5rem;color:#ccc;margin-bottom:2rem}.cta-button{background-color:#1a1a1a;border:2px solid #ffffff;border-radius:12px;color:#fff;padding:1rem 2rem;font-size:1.2rem;cursor:pointer;transition:all .3s ease;margin-top:1rem}.cta-button:hover{background-color:#fff;color:#000;transform:scale(1.05)}@keyframes fallDown{0%{transform:translateY(-100vh)}to{transform:translateY(100vh)}}@keyframes rotate90{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.blocks-container{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0;pointer-events:none}.tetris-block-wrapper{position:absolute;width:180px;height:180px;animation:fallDown linear infinite}.tetris-block{width:100%;height:100%;object-fit:contain;opacity:.15;animation:rotate90 steps(4) infinite}.tetris-block-wrapper:nth-child(1){left:2%;animation-duration:18s}.tetris-block-wrapper:nth-child(1) .tetris-block{animation-duration:4.2s}.tetris-block-wrapper:nth-child(2){left:17%;animation-duration:15s;animation-delay:-7s}.tetris-block-wrapper:nth-child(2) .tetris-block{animation-duration:3.8s}.tetris-block-wrapper:nth-child(3){left:32%;animation-duration:17s;animation-delay:-3s}.tetris-block-wrapper:nth-child(3) .tetris-block{animation-duration:4.5s}.tetris-block-wrapper:nth-child(4){left:47%;animation-duration:16s;animation-delay:-9s}.tetris-block-wrapper:nth-child(4) .tetris-block{animation-duration:3.5s}.tetris-block-wrapper:nth-child(5){left:62%;animation-duration:19s;animation-delay:-5s}.tetris-block-wrapper:nth-child(5) .tetris-block{animation-duration:4.9s}.tetris-block-wrapper:nth-child(6){left:77%;animation-duration:14s;animation-delay:-11s}.tetris-block-wrapper:nth-child(6) .tetris-block{animation-duration:4.3s}.tetris-block-wrapper:nth-child(7){left:87%;animation-duration:16s;animation-delay:-8s}.tetris-block-wrapper:nth-child(7) .tetris-block{animation-duration:4.1s}.login-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background-color:#242424}.login-box{background-color:#1a1a1a;padding:2.5rem;border-radius:16px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.login-box h2{color:#fff;text-align:center;margin-bottom:2rem;font-size:1.8rem}.login-options{display:flex;flex-direction:column;gap:1rem}.login-button{display:flex;align-items:center;justify-content:center;gap:.8rem;padding:.8rem;border-radius:8px;border:1px solid #333;background-color:transparent;color:#fff;font-size:1rem;cursor:pointer;transition:all .3s ease}.login-button img{width:24px;height:24px;transition:filter .3s ease}.login-button:hover{background-color:#fff;color:#000}.login-button:hover img{filter:invert(1)}.divider{display:flex;align-items:center;text-align:center;margin:1rem 0;color:#666}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid #333}.divider span{padding:0 1rem}.game-header{position:fixed;top:0;left:0;right:0;height:64px;background-color:#1a1a1a;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:100;box-shadow:0 2px 4px #0000001a}.game-header h1{font-size:1.5rem;color:#fff;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-container{position:relative}.header-button{background:none;border:none;padding:0;cursor:pointer;transition:transform .2s}.header-button:hover{transform:scale(1.05)}.header-menu{position:absolute;top:calc(100% + 8px);right:0;background-color:#1a1a1a;border-radius:8px;padding:.5rem 0;min-width:150px;box-shadow:0 4px 6px #0000001a;animation:slideDown .2s ease-out;z-index:200}.header-menu a{display:block;padding:.5rem 1rem;color:#fff;text-decoration:none;transition:background-color .2s}.header-menu a:hover{background-color:#333}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.header-title{text-decoration:none;max-width:70%}.header-title h1{color:#fff;transition:color .2s}.header-title:hover h1{color:#646cff}.logout-button{width:100%;text-align:left;padding:.5rem 1rem;background:none;border:none;color:#fff;font-size:1rem;cursor:pointer;transition:background-color .2s}.logout-button:hover{background-color:#333}@media (max-width: 480px){.game-header{padding:0 .5rem}.game-header h1{font-size:1.2rem}.header-title{max-width:60%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background-color:#1a1a1a;padding:2rem;border-radius:12px;min-width:400px;box-shadow:0 4px 6px #0000001a;animation:slideUp .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.create-lobby-form{display:flex;flex-direction:column;gap:1.5rem}.create-lobby-form h2{color:#fff;margin:0 0 1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#fff;font-size:.9rem}.form-group input{padding:.8rem;border-radius:6px;border:1px solid #333;background-color:#242424;color:#fff;font-size:1rem}.form-group input:focus{outline:none;border-color:#646cff}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}.button{padding:.8rem 1.5rem;border-radius:6px;border:none;font-size:1rem;cursor:pointer;transition:all .2s}.button.primary{background-color:#646cff;color:#fff}.game-container{width:100vw;height:100vh;background-color:#242424;overflow-x:hidden}.game-content{padding-top:80px;min-height:calc(100vh - 80px);display:flex;align-items:flex-start;justify-content:center;color:#fff;overflow-y:auto;box-sizing:border-box}.lobby-container{width:100%;max-width:800px;padding:1rem;margin-bottom:2rem}.lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.lobbies-list{background-color:#1a1a1a;border-radius:12px;padding:1rem;min-height:400px;max-height:70vh;overflow-y:auto}.no-lobbies{text-align:center;color:#666;margin:2rem 0}.lobby-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #333;flex-wrap:wrap;gap:.5rem}.lobby-item:last-child{border-bottom:none}.lobby-name{font-size:1.1rem;color:#fff}.password-indicator{margin-left:.5rem;opacity:.7}.button:disabled{opacity:.5;cursor:not-allowed}.lobby-buttons{display:flex;flex-direction:row;align-items:center;gap:.5rem;flex-wrap:nowrap}.button.danger,.button.secondary{padding:.5rem 1.5rem;font-size:1rem;min-width:80px;height:40px;display:flex;align-items:center;justify-content:center}.button.danger{background-color:#e53935;color:#fff}.button.danger:hover{background-color:#f44336}.button.secondary{background-color:transparent;border:1px solid #333;color:#fff}.button.secondary:hover{background-color:#333}.create-lobby-wrapper{position:relative;display:inline-block}.create-lobby-wrapper .tooltip{display:none;position:absolute;top:110%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:.8rem;white-space:nowrap;z-index:10;margin-top:4px;max-width:200px;text-align:center}.create-lobby-wrapper:hover .tooltip{display:block}@media (max-width: 600px){.lobby-header,.lobby-item{flex-direction:column;align-items:flex-start}.lobby-buttons{width:100%;justify-content:flex-end}.create-lobby-wrapper .tooltip{left:0;transform:none}}.tetris-board{display:flex;gap:2rem;padding:2rem;height:calc(100vh - 80px);box-sizing:border-box;max-width:1400px;margin:0 auto;align-items:flex-start}.game-board-container{flex:1;display:flex;justify-content:center;align-items:flex-start;min-width:0;padding-top:0}.board{display:grid;grid-template-rows:repeat(20,1fr);gap:1px;background-color:#333;padding:1rem;border-radius:8px;aspect-ratio:1/2;width:100%;max-width:400px;height:auto}.row{display:grid;grid-template-columns:repeat(10,1fr);gap:1px}.cell{aspect-ratio:1;border:1px solid #444;border-radius:2px;transition:background-color .1s ease;min-width:20px;min-height:20px}.cell.filled{border:1px solid rgba(255,255,255,.2)}.game-sidebar{width:300px;display:flex;flex-direction:column;gap:1.5rem}.next-piece{background-color:#1a1a1a;border-radius:8px;padding:1.5rem}.next-piece h3{margin:0 0 1rem;color:#fff;font-size:1.2rem}.next-piece-display{display:flex;justify-content:center;align-items:center;padding:1rem;background-color:#333;border-radius:4px}.next-piece-grid{display:grid;gap:2px;background-color:#444;padding:.5rem;border-radius:4px}.next-piece-row{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}.next-piece-cell{aspect-ratio:1;min-width:18px;min-height:18px;border:1px solid #555;border-radius:2px}.game-info{background-color:#1a1a1a;border-radius:8px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.score{font-size:1.5rem;color:#fff;text-align:center}.player-info{color:#fff;text-align:center;padding:.8rem;background-color:#333;border-radius:4px}.button.danger{background-color:#dc3545;color:#fff;border:none;padding:.8rem;border-radius:4px;cursor:pointer;font-size:1rem;width:100%}.loading{display:flex;justify-content:center;align-items:center;height:100%;color:#fff;font-size:1.2rem}@media (max-width: 900px){.tetris-board{flex-direction:column;height:auto;min-height:calc(100vh - 80px);padding:1rem}.game-board-container,.game-sidebar{width:100%;max-width:400px;margin:0 auto}}@media (max-height: 800px){.tetris-board{padding:1rem;gap:1rem}.board{max-height:90vh;width:auto;aspect-ratio:1/2}}.game-info .button.danger{width:100%;min-width:0;max-width:none;margin-left:0;display:block}.game-over-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.game-over-modal{background:#222;color:#fff;padding:2rem 3rem;border-radius:12px;box-shadow:0 4px 32px #0006;text-align:center}.score-display{font-size:1.5rem;margin:1rem 0 2rem}.lobby-view-container{width:100%;max-width:800px;padding:2rem;box-sizing:border-box}.lobby-view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.lobby-view-header h2{margin:0;font-size:2rem;color:#fff}.lobby-actions{display:flex;gap:1rem;align-items:center}.players-container{background-color:#1a1a1a;border-radius:12px;padding:1.5rem;box-sizing:border-box;width:100%}.players-container h3{margin-top:0;margin-bottom:1rem;color:#fff;font-size:1.3rem}.players-list{min-height:200px;max-height:60vh;overflow-y:auto}.player-item{padding:.8rem;border-bottom:1px solid #333;display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.player-item:last-child{border-bottom:none}.player-name{color:#fff;font-size:1.1rem}.host-indicator{color:#646cff;font-size:.9rem}.no-players{text-align:center;color:#666;padding:2rem 0}.loading-message{text-align:center;color:#fff;font-size:1.2rem}.lobby-view{padding:1rem;max-width:800px;margin:64px auto 0;box-sizing:border-box;overflow-y:visible;width:100%}.lobby-info{background-color:#1a1a1a;padding:1.5rem;border-radius:8px;margin-bottom:2rem;width:100%;box-sizing:border-box}.lobby-info h2{color:#fff;margin:0 0 1rem}.players{display:flex;flex-direction:column;gap:.5rem}.player{color:#fff;padding:.5rem;background-color:#333;border-radius:4px}.game-controls{display:flex;justify-content:center;margin-top:2rem;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.button.primary{background-color:#646cff;color:#fff;padding:.8rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.button.primary:hover:not(:disabled){background-color:#747bff}.button.primary:disabled{opacity:.5;cursor:not-allowed}.lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.lobby-header h2{margin:0;font-size:2rem;color:#fff}.button.danger{background-color:#dc3545;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;width:auto;min-width:120px;max-width:200px;margin-left:auto;display:inline-block;height:48px}.button.danger:hover{background-color:#c82333}.button.secondary{background-color:#4a4a4a;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;width:auto;min-width:120px;display:inline-block;height:48px}.button.secondary:hover{background-color:#5a5a5a}@media (max-width: 600px){.lobby-view{padding:.5rem}.lobby-info{padding:1rem}.lobby-view-header{flex-direction:column;align-items:flex-start}}@media (max-height: 700px){.players-list{max-height:40vh}}@media (max-width: 900px){.lobby-view{overflow-y:auto;max-height:calc(100vh - 64px)}}.control-scheme-selection{margin-top:1.5rem;padding:1rem;background-color:#333;border-radius:8px}.control-scheme-selection h3{color:#fff;margin:0 0 1rem;font-size:1.2rem}.control-buttons{display:flex;width:100%;gap:12px;align-items:stretch}.control-buttons button{flex:1 1 0;min-width:0;box-sizing:border-box;text-align:center;padding:0;font-size:1rem;border-radius:6px;border:1px solid #6366f1;background:#22232b;color:#fff;cursor:pointer;transition:background .2s,color .2s;white-space:normal;height:48px;display:flex;align-items:center;justify-content:center}.control-buttons button.selected{background:#6366f1;color:#fff;border:1px solid #6366f1}.control-buttons button:disabled{background:#444;color:#bbb;cursor:not-allowed}.scores-container{width:100vw;height:100vh;background-color:#242424;overflow-x:hidden;display:flex;justify-content:center;overflow-y:auto}.scores-content{padding-top:80px;min-height:calc(100vh - 80px);display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;color:#fff;box-sizing:border-box;width:800px;margin:0 auto}.scores-content h2{font-size:2rem;color:#fff}.personal-highscore{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding-top:1rem;padding-bottom:2rem;text-align:left;font-size:1em;width:100%}.personal-highscore .label{color:#fff;display:inline}.personal-highscore .score{font-size:1.1em;color:#646cff;display:inline}.personal-highscore .rank{margin-left:8px;color:#fff;display:inline}.tabs{display:flex;margin-bottom:20px;justify-content:flex-start;width:100%;gap:1rem;color:#fff}.tabs button.active{background:#646cff}.filter{margin-bottom:20px;width:100%}.filter label{margin-right:10px;color:#fff}.score-table{width:100%;border-collapse:collapse;background-color:#1a1a1a;overflow:hidden;border-radius:12px}.score-table th,.score-table td{padding:10px;border:none;border-bottom:1px solid #333;text-align:left;color:#fff}.score-table th{background:#646cff;border:2px solid #646cff}.score-table tr:last-child td{border-bottom:none}.pagination{display:flex;justify-content:flex-start;align-items:center;margin-top:20px;width:100%}.button-pages{background:none;border:none;padding:0;color:#666;cursor:pointer;text-decoration:underline;font-size:inherit}.button-pages:hover{color:#646cff}@media (max-width: 900px){.scores-container{padding:0;width:100vw;overflow:auto;justify-content:flex-start}.scores-content{max-width:90vw;padding:80px 8px 16px}.pagination{padding-bottom:2vh}}@media (max-width: 600px){.scores-content{align-items:center;text-align:center}.tabs,.pagination{align-items:center;justify-content:center;width:100%;gap:.5rem}.personal-highscore{align-items:center;width:100%;text-align:center;flex-direction:column;padding-top:0rem}}.profile-container{width:100vw;height:100vh;background-color:#242424;overflow-x:hidden;display:flex;justify-content:center;overflow-y:auto}.profile-content{padding-top:80px;margin:0 auto;max-width:60vw;width:100%}.profile-content h2{font-size:2rem;color:#fff}.profile-box{background:#1a1a1a;border-radius:16px;padding:3rem;display:flex;flex-direction:column;align-items:flex-start}.profile-main-row{display:flex;align-items:stretch;width:100%;gap:32px;margin-bottom:0}.profile-avatar{border-radius:50%;object-fit:cover;margin-right:0;box-shadow:0 2px 8px #646cff14;background:#242424;height:20vh;width:auto}.profile-info-box{flex:1;display:flex;flex-direction:column;justify-content:center;gap:18px}.profile-email{color:#fff;font-size:1.05rem;margin-bottom:8px}.profile-username-row{display:flex;align-items:center;gap:10px;width:100%}.profile-username-label{color:#fff;font-weight:600;font-size:1.1rem}.profile-username-input{padding:4px 8px;font-size:1.1rem;font-weight:700;border:none;background:#242424;color:#fff;outline:none;border-radius:6px;width:100%;transition:background .2s}.profile-username-input:disabled{background:#222;color:#aaa}.profile-save-btn{margin-top:10px;padding:8px 24px;background:#646cff;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.profile-save-btn:disabled{background:#444;color:#bbb;cursor:not-allowed}.profile-save-btn:hover:not(:disabled){background:#4b4be6}.profile-status-row{margin-top:8px;min-height:22px}.profile-success{color:#2ecc40;font-weight:500;margin-left:8px}.profile-error{color:#ff4d4f;font-weight:500}.profile-no-user{text-align:center}@media (max-width: 1000px){.profile-content{max-width:80vw}}@media (max-width: 800px){.profile-container{padding:0;width:100vw;height:auto;min-height:100vh;justify-content:flex-start}.profile-content{max-width:90vw;padding:80px 8px 16px}.profile-box{padding:1.2rem .5rem;border-radius:10px}.profile-main-row{flex-direction:column;gap:16px;align-items:center}.profile-avatar{height:20vh;width:auto;margin:0 auto 12px;display:block}.profile-info-box{gap:10px;font-size:1em}.profile-title,.profile-content h2{font-size:1.3rem;margin-top:24px;margin-bottom:16px}.profile-username-input{font-size:1em;padding:4px 6px}.profile-save-btn{padding:7px 16px;font-size:.95em}}
