:root{font-family: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}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}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{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.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}.app{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;padding:20px}.connecting,.disconnected{text-align:center;background:#fffffff2;padding:2rem;border-radius:12px;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.connecting h2,.disconnected h2{margin-bottom:1rem;color:#333}.disconnected p{color:#666;margin:0}.main-menu{text-align:center;background:#fffffff2;padding:2.5rem;border-radius:16px;box-shadow:0 20px 60px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:400px;width:100%}.main-menu h1{font-size:2.5rem;margin-bottom:1rem;color:#333;font-weight:700}.main-menu p{color:#22c55e;font-weight:500;margin-bottom:2rem}.play-button{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;padding:1rem 2rem;font-size:1.25rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #22c55e4d;margin-bottom:1.5rem}.play-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66}.game-info{font-size:.9rem;color:#666;line-height:1.6}.queue-status{text-align:center;color:#333}.queue-status h2{margin-bottom:.5rem;color:#f59e0b}.loading-spinner{font-size:2rem;animation:spin 2s linear infinite;margin-top:1rem}.cancel-queue-button{background:#ef44441a;color:#dc2626;border:2px solid #fecaca;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .3s ease;margin-top:1rem}.cancel-queue-button:hover{background:#ef444433;border-color:#f87171;transform:translateY(-1px)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.game-container{background:#fffffff2;padding:2rem;border-radius:16px;box-shadow:0 20px 60px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center;max-width:500px;width:100%}.game-container h1{font-size:2rem;margin-bottom:1.5rem;color:#333;font-weight:700}.game-info{background:#6366f11a;padding:1rem;border-radius:8px;margin-bottom:2rem;border-left:4px solid #6366f1}.game-info p{margin:.25rem 0;color:#333;font-weight:500}.game-board{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:8px;margin:2rem auto;width:300px;height:300px;padding:0;box-sizing:content-box}.board-cell{box-sizing:border-box;width:100%;height:100%;background:#ffffffe6;border:2px solid #e5e7eb;border-radius:8px;font-size:2rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:#1f2937;margin:0;padding:0;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none}.board-cell:focus{outline:2px solid #6366f1;outline-offset:2px}.board-cell:hover{background:#6366f11a;border-color:#6366f1;transform:scale(1.02)}.board-cell.filled{background:#22c55e1a;border-color:#22c55e;cursor:default}.board-cell.filled:hover{transform:none}.board-cell:disabled{cursor:not-allowed;opacity:.6}.board-cell.clickable{box-shadow:0 2px 8px #6366f133}.board-cell.symbol-x{color:#dc2626}.board-cell.symbol-o{color:#2563eb}.players{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;padding:1rem;background:#f3f4f6cc;border-radius:8px}.player{font-weight:500;color:#333}.player strong{color:#6366f1}@media (max-width: 640px){.app{padding:10px}.main-menu,.game-container,.game-result,.difficulty-selector{padding:1.5rem}.main-menu h1,.game-container h1,.game-result h2,.difficulty-selector h1{font-size:2rem}.result-emoji{font-size:3rem}.result-actions{gap:.5rem}.difficulty-options{gap:.75rem}.difficulty-button{padding:1.25rem}.game-board{width:270px;height:270px}.board-cell{font-size:1.5rem}.players{flex-direction:column;text-align:center;gap:.5rem}}@media (max-width: 480px){.game-board{width:240px;height:240px}.board-cell{font-size:1.25rem}.game-result,.difficulty-selector{padding:1.25rem}.result-emoji{font-size:2.5rem}.difficulty-button{padding:1rem}.difficulty-icon{font-size:1.5rem}}.game-result{background:#fffffff2;padding:2.5rem;border-radius:16px;box-shadow:0 20px 60px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:400px;width:100%;text-align:center;animation:resultFadeIn .5s ease-out}.result-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.result-emoji{font-size:4rem;margin-bottom:.5rem;animation:bounce .6s ease-in-out}.game-result h2{font-size:2rem;margin:0;color:#333;font-weight:700}.game-result p{font-size:1.1rem;color:#666;margin:0;margin-bottom:1.5rem}.result-actions{display:flex;flex-direction:column;gap:.75rem;width:100%}.play-again-button{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #22c55e4d}.play-again-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66}.back-button{background:#6b72801a;color:#374151;border:2px solid #e5e7eb;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border-radius:12px;cursor:pointer;transition:all .3s ease}.back-button:hover{background:#6b728033;border-color:#d1d5db;transform:translateY(-1px)}@keyframes resultFadeIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.difficulty-selector{background:#fffffff2;padding:2.5rem;border-radius:16px;box-shadow:0 20px 60px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:500px;width:100%;text-align:center}.difficulty-selector h1{font-size:2rem;margin-bottom:.5rem;color:#333;font-weight:700}.difficulty-selector p{color:#666;margin-bottom:2rem;font-size:1rem}.difficulty-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.difficulty-button{background:#ffffffe6;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;text-align:left;display:flex;flex-direction:column;gap:.5rem}.difficulty-button:hover{border-color:#6366f1;background:#6366f10d;transform:translateY(-2px);box-shadow:0 4px 12px #6366f11a}.difficulty-button.selected{border-color:#6366f1;background:#6366f11a;box-shadow:0 4px 12px #6366f133}.difficulty-icon{font-size:2rem;margin-bottom:.25rem}.difficulty-title{font-size:1.25rem;font-weight:600;color:#333}.difficulty-description{font-size:.9rem;color:#666;line-height:1.4}.difficulty-actions{display:flex;flex-direction:column;gap:.75rem}.start-queue-button{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #22c55e4d}.start-queue-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66}
