:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;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}html,body{max-width:100vw;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#242424;color:#ffffffde}*{box-sizing:border-box}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{max-width:1200px;margin:0 auto;padding:.5rem;height:100vh;box-sizing:border-box}@media(max-width:768px){#root{padding:.3rem;font-size:14px;height:100dvh;-ms-overflow-style:none}#root ::-webkit-scrollbar{display:none}}.lobby{max-width:800px;margin:0 auto}.lobby h1{text-align:center;margin-bottom:1rem}.connection-status{text-align:center;padding:.5rem;margin-bottom:1.5rem;border-radius:4px;background-color:#2a2a2a;color:#888}.create-room{display:flex;gap:.5rem;margin-bottom:1.5rem}.create-room input{flex:1;padding:.75rem 1rem;border:1px solid #3a3a3a;border-radius:6px;background-color:#2a2a2a;color:#fff;font-size:1rem}.create-room input::placeholder{color:#888}.create-room button{padding:.75rem 1.5rem;background-color:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;white-space:nowrap}.create-room button:hover:not(:disabled){background-color:#535bf2}.create-room button:disabled{background-color:#3a3a3a;cursor:not-allowed}.room-list{background-color:#1a1a1a;border-radius:8px;padding:1.5rem}.room-list h2{margin:0 0 1rem;font-size:1.2rem}.room-list ul{list-style:none;padding:0;margin:0}.room-item{display:flex;align-items:center;padding:1rem;background-color:#2a2a2a;border-radius:6px;margin-bottom:.5rem}.room-item:last-child{margin-bottom:0}.room-name{flex:1;font-weight:500}.room-players{color:#888;margin-right:1rem}.join-btn{padding:.5rem 1rem;background-color:#646cff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.join-btn:hover{background-color:#535bf2}.no-rooms{color:#888;text-align:center;padding:2rem;margin:0}.error-message{background-color:#f44;color:#fff;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;text-align:center}
