.app{height:100vh;overflow:hidden}header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #646cff}header p{color:#888;margin-top:.5rem}.container{display:flex;flex-direction:column;gap:2rem}.section{background-color:#1a1a1a;color:#fff;padding:1.5rem;border-radius:8px;border:1px solid #333}.section h2{margin-top:0;color:#646cff}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input,.form-group textarea{width:100%}.form-group textarea{min-height:100px;font-family:Courier New,monospace;resize:vertical}.button-group{display:flex;gap:.5rem;flex-wrap:wrap}.list{list-style:none;padding:0}.list-item{padding:.75rem;margin-bottom:.5rem;background-color:#0f0f0f;color:#fff;border-radius:4px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background-color .2s}.list-item:hover{background-color:#2a2a2a;color:#fff}.list-item.selected{background-color:#2a3f5f;color:#fff;border:1px solid #646cff}.doc-state{background-color:#0f0f0f;color:#fff;padding:1rem;border-radius:4px;margin-top:1rem}.doc-state h3{margin-top:0;font-size:1.1em;color:#646cff}.doc-state pre{margin:0;font-size:.875em}.ws-status{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.ws-status-dot{width:10px;height:10px;border-radius:50%;background-color:#6b7280}.ws-status-dot.connected{background-color:#059669;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.patch-form{margin-top:1rem;padding:1rem;background-color:#0f0f0f;color:#fff;border-radius:4px}.empty-state{text-align:center;padding:2rem;color:#888}.error{color:#dc2626;padding:.75rem;background-color:#1a0f0f;border-radius:4px;margin-top:.5rem}.game-room-container{display:flex;height:100vh;overflow:hidden}.chat-main-content{flex:1;padding:2rem;overflow-y:auto;background-color:#0a0a0a}.chat-main-content h1{color:#646cff;margin-bottom:1rem}.chat-main-content p{color:#888}.chat-sidebar-wrapper{width:350px;display:flex;flex-direction:column;background-color:#1a1a1a;border-left:1px solid #333}.chat-menu{background-color:#1a1a1a;padding:2rem;border-radius:8px;border:1px solid #333;max-width:500px;margin:0 auto;margin-top:10vh}.chat-menu h1,.chat-menu h2{color:#646cff;margin-top:0;text-align:center}.menu-buttons{display:flex;flex-direction:column;gap:1.5rem;margin-top:2rem}.join-section{display:flex;gap:.5rem}.join-section input{flex:1;text-transform:uppercase;letter-spacing:.1em;text-align:center;font-size:1.2em;font-weight:700}.room-code-display{text-align:center;margin:2rem 0}.room-code{font-size:3em;font-weight:700;letter-spacing:.2em;color:#646cff;background-color:#0f0f0f;padding:1rem 2rem;border-radius:8px;margin-top:1rem;-webkit-user-select:all;user-select:all}.name-input{display:flex;gap:.5rem;margin-top:2rem}.name-input input{flex:1}.btn-primary{background-color:#646cff;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1em;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#535bf2}.btn-secondary{background-color:#444;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1em;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:#555}.btn-leave{background-color:#dc2626;color:#fff;padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.btn-leave:hover{background-color:#b91c1c}.btn-send{background-color:#646cff;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.btn-send:hover{background-color:#535bf2}.chat-header{background-color:#1a1a1a;padding:1rem;border-bottom:1px solid #333}.chat-header h2{margin:0;color:#646cff;font-size:1.1em}.connection-status{font-size:.85em;color:#888;margin-top:.25rem}.chat-header-actions{display:flex;gap:.5rem;margin-top:.5rem}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-users-section{padding:1rem;border-bottom:1px solid #333;max-height:200px;overflow-y:auto}.chat-users-section h3{margin-top:0;margin-bottom:.5rem;color:#646cff;font-size:.9em}.user-list{list-style:none;padding:0;margin:0}.user-list li{padding:.4rem;margin-bottom:.25rem;background-color:#0f0f0f;border-radius:4px;font-size:.85em}.user-indicator{margin-right:.5rem}.you-badge{color:#646cff;font-size:.85em}.chat-messages-section{flex:1;display:flex;flex-direction:column;overflow:hidden}.messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.message{background-color:#0f0f0f;padding:.6rem;border-radius:6px;border-left:2px solid #444;max-width:100%}.message-own{background-color:#1a2332;border-left-color:#646cff}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem;font-size:.75em}.message-author{font-weight:700;color:#646cff}.message-time{color:#888;font-size:.9em}.message-text{line-height:1.3;word-wrap:break-word;font-size:.9em}.message-input{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background-color:#0f0f0f;border-top:1px solid #333}.message-input input{width:100%;padding:.6rem;border:1px solid #333;border-radius:4px;background-color:#1a1a1a;color:#fff;font-size:.9em}.message-input input:focus{outline:none;border-color:#646cff}.message-input button{width:100%}.game-selector{padding:2rem;text-align:center}.game-selector h1{margin-bottom:.5rem}.game-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;max-width:800px;margin:0 auto}.game-card{background-color:#1a1a1a;border:2px solid #333;border-radius:12px;padding:2rem;cursor:pointer;transition:all .3s ease}.game-card:hover{border-color:#646cff;transform:translateY(-4px);box-shadow:0 4px 12px #646cff4d}.game-emoji{font-size:4rem;margin-bottom:1rem}.game-card h3{margin:.5rem 0;color:#fff}.game-card p{color:#888;margin:.5rem 0}.game-info{margin-top:1rem;font-size:.9em;color:#aaa}.tic-tac-toe{padding:2rem;text-align:center}.tic-tac-toe h2{margin-bottom:1rem}.game-status{margin-bottom:2rem}.game-status h3{margin-bottom:1rem}.board{display:grid;grid-template-columns:repeat(3,100px);grid-template-rows:repeat(3,100px);gap:8px;margin:0 auto;width:fit-content}.cell{background-color:#1a1a1a;border:2px solid #333;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:3rem;transition:all .2s ease}.cell.clickable{cursor:pointer}.cell.clickable:hover{background-color:#252525;border-color:#646cff}.drawing-board{padding:2rem;text-align:center}.drawing-board h2{margin-bottom:.5rem}: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}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-height:100vh}#root{height:100vh;overflow:hidden}h1{font-size:2.5em;line-height:1.1;margin-bottom:1rem}h2{font-size:1.5em;margin-top:1.5rem;margin-bottom:.5rem}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;color:#fff;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}button:disabled{opacity:.5;cursor:not-allowed}input,textarea{padding:.5em;border-radius:4px;border:1px solid #646cff;background-color:#1a1a1a;color:#ffffffde;font-family:inherit;font-size:1em}input:focus,textarea:focus{outline:2px solid #646cff;outline-offset:2px}.card{padding:1.5rem;background-color:#1a1a1a;color:#fff;border-radius:8px;margin-bottom:1rem}.status{display:inline-block;padding:.25em .75em;border-radius:4px;font-size:.875em;font-weight:600}.status.success{background-color:#059669;color:#fff}.status.error{background-color:#dc2626;color:#fff}.status.info{background-color:#3b82f6;color:#fff}.status.disconnected{background-color:#6b7280;color:#fff}pre{background-color:#0f0f0f;padding:1rem;border-radius:4px;overflow-x:auto;margin:.5rem 0}code{font-family:Courier New,monospace}
