: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}h1{font-size:3.2em;line-height:1.1}#app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.vanilla:hover{filter:drop-shadow(0 0 2em #f7df1eaa)}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}.message-section,.button-section{margin-top:2rem;display:flex;flex-direction:column;gap:1rem;align-items:center}#timingBtn{background-color:#ff6b35;color:#fff;border:none;padding:.8em 1.5em;font-size:1em;border-radius:8px;cursor:pointer;transition:background-color .25s;font-weight:600}#timingBtn:hover{background-color:#e55a2b}#timingBtn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}#timingBtn:disabled:hover{background-color:#6c757d}#messageInput{padding:.8em 1.2em;font-size:1em;border-radius:8px;border:1px solid #ccc;background-color:#1a1a1a;color:#ffffffde;width:300px;max-width:90%}#messageInput:focus{outline:none;border-color:#646cff}#sendMessageBtn{background-color:#5865f2;color:#fff;border:none;padding:.8em 1.5em;font-size:1em;border-radius:8px;cursor:pointer;transition:background-color .25s}#sendMessageBtn:hover{background-color:#4752c4}#sendMessageBtn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}#sendMessageBtn:disabled:hover{background-color:#6c757d}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}#messageInput{background-color:#fff;color:#213547;border-color:#ccc}}.notification{position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:8px;color:#fff;font-weight:700;z-index:1000;max-width:300px;word-wrap:break-word;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out}.notification.info{background-color:#007bff}.notification.warning{background-color:#ffc107;color:#000}.notification.error{background-color:#dc3545}.notification.success{background-color:#28a745}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.link-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;text-decoration:none;display:inline-block;transition:all .3s ease;margin:.5rem 0}.link-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.link-button:active{transform:translateY(0);box-shadow:0 4px 15px #667eea4d}.link-button:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.database-section{margin-top:2rem;display:flex;flex-direction:column;gap:1rem;align-items:center}#databaseBtn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;padding:.8em 1.8em;font-size:1em;border-radius:8px;cursor:pointer;transition:all .25s ease;font-weight:600;box-shadow:0 4px 15px #28a7454d}#databaseBtn:hover{background:linear-gradient(135deg,#218838,#1ba085);transform:translateY(-2px);box-shadow:0 8px 25px #28a74566}#databaseBtn:active{transform:translateY(0);box-shadow:0 4px 15px #28a7454d}#databaseBtn:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.connection-status{margin:1rem 0;padding:.75rem;border-radius:8px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:500}.status-disconnected{color:#dc3545}.status-connecting{color:#ffc107}.status-connected{color:#28a745}.status-error{color:#dc3545}.connected-users{margin:1rem 0;text-align:left;max-width:600px;margin-left:auto;margin-right:auto}.users-list h4{margin:0 0 .5rem;color:#ffffffde;font-size:1rem}.user-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;margin:.25rem 0;background-color:#ffffff0d;border-radius:4px;border:1px solid rgba(255,255,255,.1)}.username{font-weight:500;color:#ffffffde}.activity{font-size:1.2em}.websocket-controls{margin:2rem 0;display:grid;grid-template-columns:1fr 300px;gap:2rem;max-width:1000px;margin-left:auto;margin-right:auto}@media (max-width: 768px){.websocket-controls{grid-template-columns:1fr;gap:1rem}}.chat-section{border:1px solid rgba(255,255,255,.2);border-radius:8px;overflow:hidden;background-color:#ffffff0d}.chat-messages{height:300px;overflow-y:auto;padding:1rem;background-color:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.chat-message{margin-bottom:.5rem;padding:.5rem;border-radius:4px;font-size:.9rem;line-height:1.4}.chat-system{background-color:#2196f31a;border-left:3px solid #2196f3}.chat-error{background-color:#f443361a;border-left:3px solid #f44336}.chat-user{background-color:#ffffff0d;border-left:3px solid #4caf50}.chat-game{background-color:#ff98001a;border-left:3px solid #ff9800}.chat-activity{background-color:#9c27b01a;border-left:3px solid #9c27b0}.chat-timing{background-color:#4caf501a;border-left:3px solid #4caf50}.chat-action{background-color:#00bcd41a;border-left:3px solid #00bcd4}.chat-time{color:#fff9;font-size:.8rem;margin-right:.5rem}.chat-icon{margin-right:.5rem}.chat-username{font-weight:600;margin-right:.5rem;color:#ffffffe6}.chat-text{word-wrap:break-word;color:#ffffffde}.chat-input-container{display:flex;padding:1rem;gap:.5rem}#chatInput{flex:1;padding:.5rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;font-size:.9rem;background-color:#ffffff0d;color:#ffffffde}#chatInput:focus{outline:none;border-color:#5865f2;box-shadow:0 0 0 .2rem #5865f240}#chatInput::placeholder{color:#ffffff80}#sendChatBtn{padding:.5rem 1rem;background-color:#5865f2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500}#sendChatBtn:hover{background-color:#4752c4}.game-actions{display:flex;flex-direction:column;gap:1rem}.game-btn{padding:.75rem 1rem;background-color:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.game-btn:hover{background-color:#218838}.game-btn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}@media (prefers-color-scheme: light){.connection-status{background-color:#f8f9fa;border-color:#dee2e6}.users-list h4,.username{color:#495057}.user-item{background-color:#f8f9fa;border-color:#e9ecef}.chat-section{border-color:#dee2e6;background-color:#fff}.chat-messages{background-color:#f8f9fa;border-bottom-color:#dee2e6}.chat-system{background-color:#e3f2fd}.chat-error{background-color:#ffebee}.chat-user{background-color:#fff}.chat-game{background-color:#fff3e0}.chat-activity{background-color:#f3e5f5}.chat-timing{background-color:#e8f5e8}.chat-action{background-color:#e1f5fe}.chat-time{color:#6c757d}.chat-username{color:#495057}.chat-text{color:#212529}#chatInput{border-color:#ced4da;background-color:#fff;color:#495057}#chatInput::placeholder{color:#6c757d}}.game-section{margin:2rem 0;padding:1.5rem;background-color:#2a2a2a;border-radius:12px;box-shadow:0 4px 6px #0000001a}.game-status{margin-bottom:1.5rem}.game-status h3{margin:0 0 1rem;color:#fff;font-size:1.5em}#gameInfo{margin-bottom:1rem}#gameStatusText{font-size:1.1em;color:#e0e0e0;margin:.5rem 0}.player-info{background-color:#3a3a3a;padding:1rem;border-radius:8px;margin:1rem 0}.player-info p{margin:0;font-weight:700}.hidden{display:none!important}#gameControls{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.game-btn{border-radius:8px;border:1px solid transparent;padding:.8em 1.5em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .25s}.game-btn.primary{background-color:#4caf50;color:#fff;border:1px solid #4CAF50}.game-btn.primary:hover{background-color:#45a049;border-color:#45a049}.game-btn.secondary{background-color:#f44336;color:#fff;border:1px solid #f44336}.game-btn.secondary:hover{background-color:#da190b;border-color:#da190b}.players-display{background-color:#3a3a3a;padding:1.5rem;border-radius:8px;margin-top:1rem}.players-display h4{margin:0 0 1rem;color:#fff}#playersList{text-align:left}.player-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background-color:#4a4a4a;border-radius:4px;margin-bottom:.5rem}.player-name{font-weight:700;flex-grow:1}.player-color{font-size:1.2em;font-weight:700}.player-symbol{font-family:monospace;font-weight:700;background-color:#5a5a5a;padding:.2rem .4rem;border-radius:3px}
