: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;padding-bottom:60px}@media (max-width: 767px) and (orientation: landscape){body{padding-bottom:45px}}@media (max-width: 320px){body{padding-bottom:55px}}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}}.lobby-game-lobby *,.lobby-game-lobby *:before,.lobby-game-lobby *:after{box-sizing:border-box}.lobby-game-lobby{display:flex;justify-content:center;align-items:center;width:100%;max-width:100vw;padding:0;box-sizing:border-box;overflow-x:hidden}.lobby-container{background:#fffffff2;border-radius:20px;padding:2rem;box-shadow:0 20px 40px #0000001a;max-width:min(800px,calc(100vw - .9rem));text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-sizing:border-box}.lobby-header{margin-bottom:2rem}.lobby-header h1{color:#333;font-size:3.5rem;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-weight:700;text-shadow:0 2px 10px rgba(0,0,0,.1)}.lobby-header h1 span{-webkit-text-fill-color:transparent}.lobby-subtitle{color:#666;font-size:1.2rem;margin:0;font-weight:500}.lobby-content{display:flex;flex-direction:column;gap:2.5rem}.lobby-create-game-section{background:#667eea1a;border-radius:15px;padding:2rem;border:1px solid rgba(102,126,234,.2);transition:all .3s ease}.lobby-create-game-section:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea26}.lobby-create-game-section h2{color:#333;margin-bottom:1.5rem;font-size:1.8rem;font-weight:600}.lobby-player-setup{display:flex;flex-direction:column;gap:1.5rem}.lobby-input-group{display:flex;flex-direction:column;gap:.7rem}.lobby-input-group label{color:#333;font-weight:600;text-align:left;font-size:1.1rem}.lobby-player-name-input{padding:1.2rem;border:2px solid #ddd;border-radius:12px;font-size:1.1rem;transition:all .3s ease;background:#fff;box-shadow:0 2px 8px #0000000d;width:100%;max-width:100%;box-sizing:border-box}.lobby-player-name-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;transform:translateY(-1px)}.lobby-player-name-input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.lobby-switch-label{display:flex;justify-content:space-between;align-items:center;width:100%;cursor:pointer;margin-bottom:.5rem}.lobby-switch-container{position:relative;width:60px;height:30px}.lobby-switch-input{opacity:0;width:0;height:0}.lobby-switch-slider{position:absolute;cursor:pointer;inset:0;background:#ccc;transition:all .3s ease;border-radius:30px;box-shadow:0 2px 8px #0000001a}.lobby-switch-slider:before{position:absolute;content:"";height:22px;width:22px;left:4px;bottom:4px;background:#fff;transition:all .3s ease;border-radius:50%;box-shadow:0 2px 8px #0003}.lobby-switch-input:checked+.lobby-switch-slider{background:linear-gradient(135deg,#667eea,#764ba2)}.lobby-switch-input:checked+.lobby-switch-slider:before{transform:translate(30px)}.lobby-switch-input:disabled+.lobby-switch-slider{background:#f5f5f5;cursor:not-allowed}.lobby-switch-input:disabled+.lobby-switch-slider:before{background:#ddd}.lobby-switch-description{font-size:.9rem;color:#666;margin:0;font-style:italic;text-align:left}.lobby-character-selection{display:flex;overflow-x:auto;gap:1rem;margin-top:.5rem;padding:.5rem;max-width:100%;box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#667eea #f0f0f0;scroll-behavior:smooth}.lobby-character-selection::-webkit-scrollbar{height:8px}.lobby-character-selection::-webkit-scrollbar-track{background:#f0f0f0;border-radius:10px}.lobby-character-selection::-webkit-scrollbar-thumb{background:#667eea;border-radius:10px}.lobby-character-selection::-webkit-scrollbar-thumb:hover{background:#5a6fd8}.lobby-character-option{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:#fffc;border:2px solid rgba(102,126,234,.3);border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);min-width:100px;flex-shrink:0;box-sizing:border-box}.lobby-character-option:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea33;border-color:#667eea80}.lobby-character-option.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;box-shadow:0 8px 25px #667eea66}.lobby-character-option.selected:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea80}.lobby-character-icon{width:50px;height:50px;margin-bottom:.5rem;border-radius:50%;background:#fff;padding:8px;box-shadow:0 4px 15px #0000001a;transition:all .3s ease}.lobby-character-option.selected .lobby-character-icon{background:#ffffffe6;box-shadow:0 4px 20px #0003}.lobby-character-name{font-size:.8rem;font-weight:600;color:#333;margin-top:.25rem}.lobby-character-option.selected .lobby-character-name{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.2)}.lobby-board-size-selection{display:flex;gap:.75rem;justify-content:center;margin-top:.5rem;flex-wrap:wrap;max-width:100%;box-sizing:border-box}.lobby-board-size-option{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:#fffc;border:2px solid rgba(102,126,234,.3);border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);min-width:100px;max-width:140px;flex:1 1 auto;box-sizing:border-box}.lobby-board-size-option:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea33;border-color:#667eea80}.lobby-board-size-option.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;box-shadow:0 8px 25px #667eea66}.lobby-board-size-option.selected:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea80}.lobby-board-preview{margin-bottom:.75rem;padding:.5rem;background:#ffffffe6;border-radius:8px;box-shadow:0 2px 8px #0000001a}.lobby-board-size-option.selected .lobby-board-preview{background:#fffffff2;box-shadow:0 4px 12px #00000026}.lobby-preview-grid{display:grid;gap:2px;width:60px;height:60px}.lobby-preview-grid.grid-3x3{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr)}.lobby-preview-grid.grid-4x4{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr)}.lobby-preview-cell{background:#667eea33;border-radius:2px;transition:background-color .3s ease}.lobby-board-size-option.selected .lobby-preview-cell{background:#4b49494d;transition:background-color 1.5s ease}.lobby-board-size-label{font-size:.9rem;font-weight:600;color:#333}.lobby-board-size-option.selected .lobby-board-size-label{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.2)}.lobby-switch-description{font-size:.85rem;color:#666;margin-top:.5rem;text-align:center;font-style:italic}.lobby-create-game-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:25px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d;margin-top:1.5rem}.lobby-create-game-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.lobby-create-game-button:active:not(:disabled){transform:translateY(0)}.lobby-create-game-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 4px 15px #667eea1a}.lobby-game-rules{background:#fffc;border-radius:15px;padding:2rem;text-align:left;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 10px 30px #0000001a}.lobby-game-rules h3{color:#333;margin-bottom:1rem;font-size:1.4rem;font-weight:600;text-align:center}.lobby-game-rules ul{list-style:none;padding:0;margin:0}.lobby-game-rules li{display:flex;align-items:center;margin-bottom:.8rem;padding:.5rem;border-radius:8px;transition:all .3s ease;font-size:1rem;color:#555;background:#ffffff80;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.lobby-game-rules li:hover{background:#667eea1a;transform:translate(5px)}.lobby-error-message{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;padding:1rem;border-radius:10px;margin-top:1rem;text-align:center;font-weight:600}.lobby-connection-status{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;padding:1rem;border-radius:10px;margin-top:1rem;text-align:center;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem}.lobby-connection-status:before{content:"";width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@media (min-width: 1024px){.lobby-character-option{min-width:120px;padding:1rem}.lobby-character-icon{width:60px;height:60px}.lobby-character-name{font-size:.9rem}}@media (min-width: 768px) and (max-width: 1023px){.lobby-character-option{min-width:100px;padding:.75rem}.lobby-character-icon{width:50px;height:50px}.lobby-character-name{font-size:.8rem}}@media (max-width: 767px){.lobby-character-option{min-width:90px;padding:.5rem}.lobby-character-icon{width:45px;height:45px}.lobby-character-name{font-size:.7rem}}@media (min-width: 1440px){.lobby-game-lobby{padding:3rem}.lobby-container{max-width:800px;padding:2rem}.lobby-header h1{font-size:4rem}.lobby-subtitle{font-size:1.4rem}.lobby-create-game-section{padding:3rem}.lobby-create-game-section h2{font-size:2rem}.lobby-player-name-input,.lobby-create-game-button{font-size:1.3rem;padding:1.4rem 2.8rem}.lobby-game-rules{padding:3rem}.lobby-game-rules h3{font-size:1.6rem}.lobby-game-rules li{font-size:1.1rem;padding:1.2rem}}@media (min-width: 1024px) and (max-width: 1439px){.lobby-game-lobby{padding:2.5rem}.lobby-container{max-width:800px;padding:2rem}.lobby-header h1{font-size:3.8rem}.lobby-subtitle{font-size:1.3rem}.lobby-create-game-section{padding:2.8rem}.lobby-create-game-section h2{font-size:1.9rem}.lobby-player-name-input,.lobby-create-game-button{font-size:1.25rem;padding:1.3rem 2.6rem}.lobby-game-rules{padding:2.8rem}.lobby-game-rules h3{font-size:1.5rem}.lobby-game-rules li{font-size:1.05rem;padding:1.1rem}}@media (min-width: 768px) and (max-width: 1023px){.lobby-game-lobby{padding:2rem}.lobby-container{max-width:600px;padding:2rem}.lobby-header h1{font-size:3rem}.lobby-subtitle{font-size:1.1rem}.lobby-create-game-section{padding:2rem}.lobby-create-game-section h2{font-size:1.6rem}.lobby-player-name-input,.lobby-create-game-button{font-size:1.1rem;padding:1.1rem 2rem}.lobby-game-rules{padding:2rem}.lobby-game-rules h3{font-size:1.3rem}.lobby-game-rules li{font-size:.95rem;padding:.9rem}}@media (min-width: 480px) and (max-width: 767px){.lobby-game-lobby{padding:1.5rem}.lobby-container{padding:2rem;border-radius:15px}.lobby-header{margin-bottom:2rem}.lobby-header h1{font-size:2.5rem}.lobby-subtitle{font-size:1rem}.lobby-content{gap:2rem}.lobby-create-game-section{padding:1.5rem}.lobby-create-game-section h2{font-size:1.4rem;margin-bottom:1.5rem}.lobby-player-setup{gap:1.5rem}.lobby-player-name-input,.lobby-create-game-button{font-size:1rem;padding:1rem 1.5rem}.lobby-game-rules{padding:1.5rem}.lobby-game-rules h3{font-size:1.2rem}.lobby-game-rules li{font-size:.9rem;padding:.8rem;margin-bottom:.8rem}}@media (max-width: 479px){.lobby-game-lobby{padding:.5rem}.lobby-container{padding:1rem;border-radius:12px}.lobby-header{margin-bottom:1.5rem}.lobby-header h1{font-size:2rem}.lobby-subtitle{font-size:.9rem}.lobby-content{gap:1.5rem}.lobby-create-game-section{padding:1.2rem}.lobby-create-game-section h2{font-size:1.2rem;margin-bottom:1.2rem}.lobby-player-setup{gap:1.2rem}.lobby-input-group label{font-size:1rem}.lobby-player-name-input,.lobby-create-game-button{font-size:.9rem;padding:.9rem 1.2rem}.lobby-game-rules{padding:1.2rem}.lobby-game-rules h3{font-size:1.1rem}.lobby-game-rules li{font-size:.85rem;padding:.7rem;margin-bottom:.7rem}.lobby-error-message,.lobby-connection-status{padding:1rem;font-size:.9rem}}@media (max-width: 359px){.lobby-game-lobby{padding:.25rem}.lobby-container{padding:.75rem;margin:0}.lobby-character-selection{gap:.75rem;padding:.5rem}.lobby-character-option{min-width:80px;padding:.5rem}.lobby-character-icon{width:35px;height:35px}.lobby-character-name{font-size:.65rem}.lobby-board-size-selection{gap:.5rem}.lobby-board-size-option{min-width:80px;padding:.5rem}.lobby-preview-grid{width:50px;height:50px}}@media (max-width: 767px) and (orientation: landscape){.lobby-game-lobby{padding:1rem;align-items:flex-start}.lobby-container{margin:1rem 0;padding:1.5rem}.lobby-header{margin-bottom:1rem}.lobby-header h1{font-size:2rem}.lobby-content{gap:1.5rem}.lobby-create-game-section,.lobby-game-rules{padding:1.2rem}.lobby-game-rules ul{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}.lobby-game-rules li{margin-bottom:0;font-size:.8rem;padding:.6rem}}@media (hover: none) and (pointer: coarse){.lobby-create-game-button:hover:not(:disabled){transform:none;box-shadow:0 4px 15px #667eea4d}.lobby-create-game-button:active:not(:disabled){transform:scale(.98);box-shadow:0 2px 8px #667eea66}.lobby-create-game-section:hover{transform:none;box-shadow:0 20px 40px #0000001a}.lobby-game-rules li:hover{transform:none}.lobby-game-rules li:active{transform:scale(.98)}.lobby-character-option:hover{transform:none;box-shadow:0 4px 15px #667eea33}.lobby-character-option:active{transform:scale(.98)}.lobby-character-option.selected:hover{transform:none;box-shadow:0 8px 25px #667eea66}.lobby-character-option.selected:active{transform:scale(.98)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 2dppx){.lobby-header h1{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media (prefers-reduced-motion: reduce){.lobby-connection-status:before{animation:none}.lobby-create-game-button:hover:not(:disabled),.lobby-create-game-section:hover,.lobby-game-rules li:hover{transform:none}.lobby-player-name-input:focus{transform:none}}@media (prefers-color-scheme: dark){.lobby-container{background:#1e1e1ef2;color:#e0e0e0;border:1px solid rgba(255,255,255,.1)}.lobby-header h1{color:#e0e0e0}.lobby-subtitle{color:#b0b0b0}.lobby-create-game-section{background:#667eea26;border:1px solid rgba(102,126,234,.3)}.lobby-create-game-section h2,.lobby-input-group label{color:#e0e0e0}.lobby-player-name-input{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#e0e0e0}.lobby-player-name-input::placeholder{color:#999}.lobby-game-rules{background:#ffffff1a;border:1px solid rgba(255,255,255,.1)}.lobby-game-rules h3{color:#e0e0e0}.lobby-game-rules li{background:#ffffff0d;color:silver;border-left:4px solid #667eea}.lobby-character-selection{scrollbar-color:#667eea #333}.lobby-character-selection::-webkit-scrollbar-track{background:#333}}.waiting-character-selection{display:flex;overflow-x:auto;gap:1rem;margin-top:.5rem;padding:.5rem;max-width:100%;box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#667eea #f0f0f0;scroll-behavior:smooth}.waiting-character-selection::-webkit-scrollbar{height:8px}.waiting-character-selection::-webkit-scrollbar-track{background:#f0f0f0;border-radius:10px}.waiting-character-selection::-webkit-scrollbar-thumb{background:#667eea;border-radius:10px}.waiting-character-selection::-webkit-scrollbar-thumb:hover{background:#5a6fd8}.waiting-character-option{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:#fffc;border:2px solid rgba(102,126,234,.3);border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);min-width:100px;flex-shrink:0;box-sizing:border-box}.waiting-character-option:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea33;border-color:#667eea80}.waiting-character-option.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;box-shadow:0 6px 20px #667eea66}.waiting-character-option.selected:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea80}.waiting-character-icon{width:50px;height:50px;margin-bottom:.25rem;border-radius:50%;background:#fff;padding:6px;box-shadow:0 3px 12px #0000001a;transition:all .3s ease}.waiting-character-option.selected .waiting-character-icon{background:#ffffffe6;box-shadow:0 3px 15px #0003}.waiting-character-name{font-size:.8rem;font-weight:600;color:#333;margin-top:.25rem}.waiting-character-option.selected .waiting-character-name{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.2)}.waiting-player-info{margin-bottom:1.5rem}.waiting-player-card{display:flex;align-items:center;gap:1rem;background:#fffc;border-radius:15px;padding:1.5rem;box-shadow:0 4px 15px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.waiting-player-avatar{flex-shrink:0}.waiting-player-icon{width:60px;height:60px;border-radius:50%;background:#fff;padding:8px;box-shadow:0 4px 15px #0000001a}.waiting-player-details h3{margin:0 0 .5rem;color:#333;font-size:1.4rem;font-weight:600}.waiting-player-details p{margin:0;color:#666;font-size:1rem}.waiting-game-creator{display:flex;align-items:center;gap:.75rem}.waiting-game-creator-icon{width:40px;height:40px;border-radius:50%;background:#fff;padding:6px;box-shadow:0 3px 12px #0000001a}.waiting-game-creator div h4{margin:0 0 .25rem;color:#333;font-size:1rem;font-weight:600}.waiting-game-creator div p{margin:0;color:#666;font-size:.85rem}.waiting-player-setup{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.waiting-input-group{display:flex;flex-direction:column;gap:.5rem}.waiting-input-group label{font-weight:600;color:#333;font-size:.95rem}.waiting-player-name-input{padding:.75rem 1rem;border:2px solid rgba(102,126,234,.3);border-radius:10px;font-size:1rem;background:#fffc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:all .3s ease;width:100%;max-width:100%;box-sizing:border-box}.waiting-player-name-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.waiting-share-description{text-align:center;color:#666;font-size:.9rem;margin-top:.5rem}@media (min-width: 1024px){.waiting-character-option{padding:1rem;min-width:120px}.waiting-character-icon{width:60px;height:60px}.waiting-character-name{font-size:.9rem}}@media (min-width: 768px) and (max-width: 1023px){.waiting-character-option{padding:.75rem;min-width:100px}.waiting-character-icon{width:45px;height:45px}.waiting-character-name{font-size:.75rem}}@media (max-width: 767px){.waiting-room{padding:1rem}.waiting-container{padding:1.5rem}.waiting-character-selection{gap:.75rem;padding:.5rem}.waiting-character-option{padding:.5rem;min-width:80px}.waiting-character-icon{width:40px;height:40px}.waiting-character-name{font-size:.7rem}.waiting-player-card{flex-direction:column;text-align:center;gap:.75rem;padding:1rem}.waiting-player-icon{width:50px;height:50px}.waiting-game-creator{flex-direction:column;gap:.5rem;text-align:center}.waiting-game-creator-icon{width:35px;height:35px}.waiting-games-grid{grid-template-columns:1fr;gap:.75rem}.waiting-share-link{flex-direction:column;gap:.75rem}.waiting-copy-button{width:100%}}@media (hover: none) and (pointer: coarse){.waiting-character-option:hover{transform:none;box-shadow:0 3px 12px #667eea33}.waiting-character-option:active{transform:scale(.98)}.waiting-character-option.selected:hover{transform:none;box-shadow:0 6px 20px #667eea66}.waiting-character-option.selected:active{transform:scale(.98)}}.waiting-room *,.waiting-room *:before,.waiting-room *:after{box-sizing:border-box}.waiting-room{display:flex;justify-content:center;align-items:center;width:100%;max-width:100vw;padding:2rem;min-height:100vh;box-sizing:border-box;overflow-x:hidden}.waiting-container{background:#fffffff2;border-radius:20px;padding:2rem;box-shadow:0 20px 40px #0000001a;max-width:min(800px,calc(100vw - .9rem));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-sizing:border-box}.waiting-header{text-align:center;margin-bottom:2rem}.waiting-header h2{color:#333;font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.waiting-subtitle{color:#666;font-size:1.1rem;margin:0;font-weight:500}.waiting-spinner{width:40px;height:40px;border:4px solid rgba(102,126,234,.3);border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.waiting-share-section{margin-top:1.5rem}.waiting-share-link{display:flex;gap:.5rem;margin-bottom:1rem}.waiting-share-input{flex:1;padding:.75rem;border:2px solid rgba(102,126,234,.3);border-radius:10px;font-size:.9rem;background:#fffc;color:#333;min-width:0;box-sizing:border-box}.waiting-copy-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.waiting-copy-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.waiting-copy-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.waiting-status{text-align:center;padding:1.5rem;background:#ffffff80;border-radius:15px;margin-top:1.5rem}.waiting-status p{margin:0;color:#666;font-size:1.1rem;font-weight:500}.waiting-games-section{margin-top:2rem}.waiting-games-section h3{color:#333;font-size:1.5rem;margin-bottom:1rem;font-weight:600;text-align:center}.waiting-no-games{text-align:center;padding:2rem;background:#ffffff80;border-radius:15px;color:#666}.waiting-games-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr));gap:1rem;max-width:100%;box-sizing:border-box}.waiting-game-card{background:#fffc;border-radius:15px;padding:1.5rem;box-shadow:0 4px 15px #0000001a;transition:all .3s ease;border:1px solid rgba(255,255,255,.2)}.waiting-game-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.waiting-game-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.waiting-indicator{background:linear-gradient(135deg,#ffeaa7,#fdcb6e);color:#e17055;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600}.waiting-game-card-info{margin-bottom:1rem;color:#666;font-size:.9rem}.waiting-game-id{font-family:monospace;background:#667eea1a;padding:.25rem .5rem;border-radius:5px;font-weight:600;color:#667eea}.waiting-private-indicator{color:#e17055;font-weight:600}.waiting-private-game-indicator{text-align:center;padding:1rem;background:#e170551a;border-radius:10px;color:#e17055}.waiting-lock-icon{font-size:1.5rem;margin-bottom:.5rem}.waiting-join-button{background:linear-gradient(135deg,#00b894,#00a085);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #00b8944d;width:100%}.waiting-join-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00b89466}.waiting-join-button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.waiting-refresh-section{text-align:center;margin-top:2rem}.waiting-refresh-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.waiting-refresh-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@media (prefers-color-scheme: dark){.waiting-container{background:#1e1e1ef2;color:#e0e0e0;border:1px solid rgba(255,255,255,.1)}.waiting-header h2{color:#e0e0e0}.waiting-subtitle{color:#b0b0b0}.waiting-player-card{background:#ffffff1a;border:1px solid rgba(255,255,255,.1)}.waiting-player-details h3{color:#e0e0e0}.waiting-player-details p{color:#b0b0b0}.waiting-game-creator div h4{color:#e0e0e0}.waiting-game-creator div p{color:#b0b0b0}.waiting-input-group label{color:#e0e0e0}.waiting-player-name-input{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#e0e0e0}.waiting-player-name-input::placeholder{color:#999}.waiting-player-name-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.waiting-character-option{background:#ffffff1a;border:2px solid rgba(255,255,255,.2)}.waiting-character-option:hover{background:#ffffff26;border-color:#667eea80;box-shadow:0 6px 20px #667eea4d}.waiting-character-name{color:#e0e0e0}.waiting-share-input{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#e0e0e0}.waiting-share-description{color:#b0b0b0}.waiting-status{background:#ffffff1a;border:1px solid rgba(255,255,255,.1)}.waiting-status p{color:#b0b0b0}.waiting-games-section h3{color:#e0e0e0}.waiting-no-games{background:#ffffff1a;color:#b0b0b0}.waiting-game-card{background:#ffffff1a;border:1px solid rgba(255,255,255,.1)}.waiting-game-card:hover{background:#ffffff26;box-shadow:0 8px 25px #0000004d}.waiting-game-card-info{color:#b0b0b0}.waiting-game-id{background:#667eea33;color:#8fa4f3}.waiting-private-indicator{color:#f99}.waiting-private-game-indicator{background:#e1705526;color:#f99}.waiting-spinner{border:4px solid rgba(102,126,234,.3);border-top:4px solid #8fa4f3}.waiting-character-selection{scrollbar-color:#667eea #333}.waiting-character-selection::-webkit-scrollbar-track{background:#333}}@media (max-width: 359px){.waiting-room{padding:.5rem}.waiting-container{padding:1rem;margin:0}.waiting-header h2{font-size:1.8rem}.waiting-subtitle{font-size:.9rem}.waiting-character-selection{gap:.5rem;padding:.5rem}.waiting-character-option{min-width:70px;padding:.4rem}.waiting-character-icon{width:35px;height:35px}.waiting-character-name{font-size:.65rem}.waiting-player-card{padding:.75rem}.waiting-player-icon{width:45px;height:45px}.waiting-game-card{padding:1rem}.waiting-game-creator-icon{width:30px;height:30px}}.waiting-toast{position:fixed;top:2rem;right:2rem;background:linear-gradient(135deg,#00b894,#00a085);color:#fff;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 8px 25px #00b89466;z-index:2000;display:flex;align-items:center;gap:.75rem;min-width:280px;max-width:400px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);animation:toastSlideIn .4s cubic-bezier(.68,-.55,.265,1.55);transform-origin:right top}.waiting-toast.waiting-toast-exit{animation:toastSlideOut .3s ease-in-out}.waiting-toast-icon{font-size:1.5rem;flex-shrink:0}.waiting-toast-content{flex:1}.waiting-toast-title{font-weight:600;font-size:1rem;margin:0 0 .25rem}.waiting-toast-message{font-size:.875rem;margin:0;opacity:.9}@keyframes toastSlideIn{0%{transform:translate(100%) scale(.8);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes toastSlideOut{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(100%) scale(.8);opacity:0}}@media (max-width: 767px){.waiting-toast{top:1rem;right:1rem;left:1rem;min-width:auto;max-width:none}@keyframes toastSlideIn{0%{transform:translateY(-100%) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes toastSlideOut{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-100%) scale(.9);opacity:0}}}@media (prefers-color-scheme: dark){.waiting-toast{background:linear-gradient(135deg,#00b894,#00a085);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 25px #00b8944d}}.cell-icon{width:80%;height:80%;max-width:60px;max-height:60px;object-fit:contain;border-radius:50%;background:#ffffff1a;padding:4px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.cell.filled .cell-icon{animation:iconAppear .4s ease-out}@keyframes iconAppear{0%{opacity:0;transform:scale(.3) rotate(-15deg)}50%{opacity:.8;transform:scale(1.1) rotate(5deg)}to{opacity:1;transform:scale(1) rotate(0)}}.cell-text{font-size:3rem;font-weight:700;color:#333;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.turn-indicator-icon{width:32px;height:32px;margin-right:8px;border-radius:50%;background:#fff3;padding:4px;box-shadow:0 2px 8px #0000001a;vertical-align:middle;transition:all .3s ease}.my-turn-indicator .turn-indicator-icon{background:#90ee904d;box-shadow:0 2px 8px #90ee904d;animation:glowIcon 2s infinite}@keyframes glowIcon{0%{box-shadow:0 2px 8px #90ee904d}50%{box-shadow:0 4px 15px #90ee9099}to{box-shadow:0 2px 8px #90ee904d}}.opponent-turn .turn-indicator-icon{background:#ffb6c14d;box-shadow:0 2px 8px #ffb6c14d}.game-board{position:relative;display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 20px 40px #0000001a;color:#fff;max-width:600px;margin:0 auto;min-height:70vh;justify-content:center}.board-container{position:relative;padding:2rem;background:#ffffff1a;border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 10px 30px #0003}.board{display:grid;gap:6px;background:#fff3;border-radius:12px;padding:12px;box-shadow:inset 0 2px 10px #0000001a}.board.board-3x3{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:360px;height:360px}.board.board-4x4{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);width:400px;height:440px}.cell{background:#fffffff2;border:none;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;cursor:default;transition:all .3s ease;box-shadow:0 4px 12px #0000001a;position:relative;overflow:hidden;min-height:100px;-webkit-user-select:none;user-select:none}.cell.clickable{cursor:pointer;transform:scale(1)}.cell.clickable:hover{transform:scale(1.05);box-shadow:0 8px 20px #0003;background:#fff}.cell.my-turn.clickable{background:#90ee90f2;animation:pulse 2s infinite}.cell.my-turn.clickable:hover{background:#90ee90}@keyframes pulse{0%{box-shadow:0 4px 12px #0000001a}50%{box-shadow:0 8px 25px #90ee9080}to{box-shadow:0 4px 12px #0000001a}}.cell-content{z-index:1;position:relative;animation:fadeIn .3s ease;display:flex;align-items:center;justify-content:center;width:100%;height:100%}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.cell:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.3),transparent);transform:translate(-100%);transition:transform .6s ease}.cell.clickable:hover:before{transform:translate(100%)}.game-info{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:1rem}.player-info{text-align:center;width:100%}.current-player{font-size:1.3rem;font-weight:600;padding:.75rem 1.5rem;border-radius:30px;background:#fff3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 15px #0000001a;min-width:200px;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.my-turn-indicator{color:#90ee90;animation:glow 2s infinite;font-weight:700;display:flex;align-items:center;gap:.5rem}@keyframes glow{0%{text-shadow:0 0 10px rgba(144,238,144,.6)}50%{text-shadow:0 0 25px rgba(144,238,144,.9)}to{text-shadow:0 0 10px rgba(144,238,144,.6)}}.opponent-turn{color:#ffb6c1;font-weight:600;display:flex;align-items:center;gap:.5rem}@media (min-width: 1440px){.cell-icon{max-width:80px;max-height:80px}.turn-indicator-icon{width:40px;height:40px}}@media (min-width: 1024px) and (max-width: 1439px){.cell-icon{max-width:70px;max-height:70px}.turn-indicator-icon{width:36px;height:36px}}@media (min-width: 768px) and (max-width: 1023px){.cell-icon{max-width:55px;max-height:55px}.turn-indicator-icon{width:30px;height:30px}}@media (max-width: 767px){.cell-icon{max-width:45px;max-height:45px}.turn-indicator-icon{width:24px;height:24px}.current-player{font-size:1.1rem;padding:.5rem 1rem;min-width:180px}}@media (max-width: 479px){.cell-icon{max-width:35px;max-height:35px}.turn-indicator-icon{width:20px;height:20px}.current-player{font-size:1rem;padding:.5rem 1rem;min-width:140px}}@media (hover: none) and (pointer: coarse){.cell.clickable:hover:before{display:none}.cell.my-turn.clickable:active{background:#90ee90cc}}@media (prefers-reduced-motion: reduce){.cell-icon,.turn-indicator-icon,.cell.filled .cell-icon,.my-turn-indicator .turn-indicator-icon{animation:none}}@media (min-width: 1440px){.game-board{max-width:700px;padding:3rem;gap:3rem}.board-container{padding:3rem}.board.board-3x3{width:450px;height:450px;gap:8px;padding:15px}.board.board-4x4{width:500px;height:550px;gap:6px;padding:15px}.cell{font-size:4rem;min-height:130px;border-radius:12px}.current-player{font-size:1.5rem;padding:1rem 2rem}}@media (min-width: 1024px) and (max-width: 1439px){.game-board{max-width:650px;padding:2.5rem;gap:2.5rem}.board-container{padding:2.5rem}.board.board-3x3{width:400px;height:400px;gap:7px;padding:14px}.board.board-4x4{width:450px;height:500px;gap:5px;padding:14px}.cell{font-size:3.5rem;min-height:115px;border-radius:11px}.current-player{font-size:1.4rem;padding:.9rem 1.8rem}}@media (min-width: 768px) and (max-width: 1023px){.game-board{max-width:500px;padding:2rem;gap:2rem}.board-container{padding:2rem}.board.board-3x3{width:320px;height:320px;gap:5px;padding:10px}.board.board-4x4{width:360px;height:400px;gap:4px;padding:10px}.cell{font-size:2.8rem;min-height:95px;border-radius:9px}.current-player{font-size:1.2rem;padding:.7rem 1.4rem;min-width:180px}}@media (min-width: 480px) and (max-width: 767px){.game-board{max-width:420px;padding:1.5rem;gap:1.5rem;border-radius:15px}.board-container{padding:1.5rem}.board.board-3x3{width:280px;height:280px;gap:4px;padding:8px}.board.board-4x4{width:320px;height:360px;gap:3px;padding:8px}.cell{font-size:2.5rem;min-height:85px;border-radius:8px}.current-player{font-size:1.1rem;padding:.6rem 1.2rem;min-width:160px}.game-info{gap:1rem}}@media (max-width: 479px){.game-board{max-width:-webkit-fill-available;padding:1rem;gap:1rem;border-radius:10px;margin:.5rem}.board-container{padding:1rem}.board.board-3x3{width:240px;height:240px;gap:3px;padding:6px}.board.board-4x4{width:280px;height:300px;gap:2px;padding:6px}.cell{font-size:2rem;min-height:70px;border-radius:6px}.current-player{font-size:1rem;padding:.5rem 1rem;min-width:140px}.game-info{gap:.8rem}}@media (hover: none) and (pointer: coarse){.cell.clickable:hover{transform:none;box-shadow:0 4px 12px #0000001a}.cell.clickable:active{transform:scale(.95);background:#fffc}.cell.my-turn.clickable:active{background:#90ee90cc}.cell:before{display:none}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 2dppx){.cell{text-shadow:0 1px 2px rgba(0,0,0,.1)}}@media (max-width: 767px) and (orientation: landscape){.game-board{flex-direction:row;align-items:flex-start;gap:1rem;padding:1rem;max-width:-webkit-fill-available;min-height:auto}.board-container{padding:1rem;flex-shrink:0}.board.board-3x3{width:200px;height:200px;gap:2px;padding:4px}.board.board-4x4{width:240px;height:260px;gap:1px;padding:4px}.cell{font-size:1.5rem;min-height:60px;border-radius:4px}.cell-icon{max-width:30px;max-height:30px}.game-info{flex-direction:column;justify-content:center;align-items:center;gap:.5rem;min-width:120px}.current-player{font-size:.9rem;padding:.4rem .8rem;min-width:100px}.turn-indicator-icon{width:18px;height:18px}}@media (max-width: 320px){.game-board{padding:.5rem;gap:.5rem}.board.board-3x3{width:200px;height:200px;gap:2px;padding:4px}.board.board-4x4{width:240px;height:260px;gap:1px;padding:4px}.cell{font-size:1.5rem;min-height:60px;border-radius:4px}.cell-icon{max-width:25px;max-height:25px}.current-player{font-size:.9rem;padding:.4rem .8rem;min-width:120px}.turn-indicator-icon{width:16px;height:16px}}@media (prefers-reduced-motion: reduce){.cell,.cell:before,.my-turn-indicator{animation:none}.cell.clickable:hover{transform:none}.cell-content{animation:none}}.disconnection-overlay{position:absolute;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;border-radius:20px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.disconnection-message{background:linear-gradient(135deg,#ff6b6b,#ee5a24);padding:2rem;border-radius:15px;text-align:center;color:#fff;box-shadow:0 20px 40px #0000004d;max-width:400px;animation:slideIn .3s ease-out}.disconnection-icon{font-size:3rem;margin-bottom:1rem}.disconnection-message h2{font-size:1.5rem;margin:0 0 1.5rem;font-weight:600;line-height:1.4}.back-to-home-button{background:#fff3;border:2px solid rgba(255,255,255,.3);color:#fff;padding:.75rem 2rem;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media (max-width: 479px){.disconnection-message{margin:1rem;padding:1.5rem}.disconnection-message h2{font-size:1.2rem}.disconnection-icon{font-size:2.5rem}.back-to-home-button{padding:.6rem 1.5rem;font-size:.9rem}}.game-actions{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem}.leave-game-button{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;border-radius:12px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #e74c3c4d;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:.5rem}.leave-game-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #e74c3c66;background:linear-gradient(135deg,#c0392b,#a93226)}.leave-game-button:active{transform:translateY(-1px);box-shadow:0 4px 15px #e74c3c4d}@media (max-width: 767px){.leave-game-button{padding:.6rem 1.2rem;font-size:.9rem}}@media (max-width: 479px){.leave-game-button{padding:.5rem 1rem;font-size:.8rem}.game-actions{margin-top:.5rem}}.game-result-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease;padding:.5rem;box-sizing:border-box}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-result-modal{background:#fff;border-radius:15px;padding:1.5rem;max-width:400px;width:100%;max-height:90vh;overflow-y:auto;text-align:center;box-shadow:0 20px 40px #0000004d;animation:slideIn .3s ease;border:1px solid rgba(0,0,0,.1)}@keyframes slideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.result-content{display:flex;flex-direction:column;gap:1.2rem}.result-icon{font-size:3rem;animation:bounce .6s ease;text-shadow:0 4px 8px rgba(0,0,0,.2)}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-15px)}60%{transform:translateY(-8px)}}.result-title{font-size:2rem;margin:0;font-weight:700;line-height:1.2}.result-content.result-win .result-title{color:#2ecc71;text-shadow:0 4px 8px rgba(46,204,113,.3)}.result-content.result-lose .result-title{color:#e74c3c;text-shadow:0 4px 8px rgba(231,76,60,.3)}.result-content.result-draw .result-title{color:#f39c12;text-shadow:0 4px 8px rgba(243,156,18,.3)}.result-game-stats{background:#0000000d;border-radius:10px;padding:1rem;color:#555;box-shadow:0 4px 15px #0000000d}.result-game-stats p{margin:.4rem 0;font-size:1rem;font-weight:500}.result-players-summary{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 0;background:#00000008;border-radius:10px;margin:.5rem 0}.result-player-card{display:flex;flex-direction:column;align-items:center;gap:1.5rem;flex:1}.result-player-symbol{width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;box-shadow:0 4px 15px #0003;transition:all .3s ease}.result-player-symbol:hover{transform:scale(1.1)}.result-player-symbol.x{background:linear-gradient(135deg,#e74c3c,#c0392b)}.result-player-symbol.o{background:linear-gradient(135deg,#3498db,#2980b9)}.result-player-name{font-size:.9rem;color:#555;font-weight:600;text-align:center;max-width:100px;word-wrap:break-word;margin-top:.5rem}.result-vs{font-size:1.2rem;font-weight:700;color:#999;text-shadow:0 2px 4px rgba(0,0,0,.1)}.result-actions{display:flex;justify-content:center;gap:1rem;margin-top:.5rem}.result-play-again-button{padding:.8rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d;text-transform:uppercase;letter-spacing:.5px}.result-play-again-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #667eea66}.result-play-again-button:active{transform:translateY(-1px)}.result-leave-game-button{padding:.8rem 1.5rem;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #e74c3c4d;text-transform:uppercase;letter-spacing:.5px}.result-leave-game-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #e74c3c66}.result-leave-game-button:active{transform:translateY(-1px)}.disconnection-overlay{position:absolute;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;border-radius:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.disconnection-message{background:linear-gradient(135deg,#ff6b6b,#ee5a24);padding:1.5rem;border-radius:12px;text-align:center;color:#fff;box-shadow:0 20px 40px #0000004d;max-width:350px;animation:slideIn .3s ease-out}.disconnection-icon{font-size:2.5rem;margin-bottom:.8rem}.disconnection-message h2{font-size:1.3rem;margin:0 0 1rem;font-weight:600;line-height:1.4}.back-to-home-button{background:#fff3;border:2px solid rgba(255,255,255,.3);color:#fff;padding:.6rem 1.5rem;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-to-home-button:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (min-width: 1440px){.game-result-modal{max-width:450px;padding:2rem}.result-content{gap:1.5rem}.result-icon{font-size:3.5rem}.result-title{font-size:2.5rem}.result-game-stats{padding:1.5rem}.result-game-stats p{font-size:1.1rem}.result-players-summary{gap:1.5rem;padding:1.5rem 0}.result-player-symbol{width:55px;height:55px;font-size:1.7rem}.result-player-name{font-size:1rem}.result-vs{font-size:1.4rem}.result-play-again-button,.result-leave-game-button{font-size:1.1rem;padding:1rem 2rem}}@media (min-width: 1024px) and (max-width: 1439px){.game-result-modal{max-width:420px;padding:1.8rem}.result-content{gap:1.4rem}.result-icon{font-size:3.2rem}.result-title{font-size:2.2rem}.result-game-stats{padding:1.3rem}.result-game-stats p{font-size:1.05rem}.result-players-summary{gap:1.2rem;padding:1.2rem 0}.result-player-symbol{width:50px;height:50px;font-size:1.6rem}.result-player-name{font-size:.95rem}.result-vs{font-size:1.3rem}.result-play-again-button,.result-leave-game-button{font-size:1.05rem;padding:.9rem 1.8rem}}@media (min-width: 768px) and (max-width: 1023px){.game-result-modal{max-width:380px;padding:1.5rem}.result-content{gap:1.2rem}.result-icon{font-size:2.8rem}.result-title{font-size:1.9rem}.result-game-stats{padding:1.2rem}.result-game-stats p{font-size:1rem}.result-players-summary{gap:1rem;padding:1rem 0}.result-player-symbol{width:45px;height:45px;font-size:1.4rem}.result-player-name{font-size:.9rem}.result-vs{font-size:1.2rem}.result-play-again-button,.result-leave-game-button{font-size:1rem;padding:.8rem 1.5rem}}@media (min-width: 480px) and (max-width: 767px){.game-result-overlay{padding:.5rem}.game-result-modal{max-width:-webkit-fill-available;padding:1.2rem;border-radius:12px}.result-content{gap:1rem}.result-icon{font-size:2.5rem}.result-title{font-size:1.7rem}.result-game-stats{padding:1rem}.result-game-stats p{font-size:.9rem}.result-players-summary{gap:1rem;padding:1rem}.result-vs{font-size:1.1rem}.result-player-symbol{width:40px;height:40px;font-size:1.2rem}.result-player-name{font-size:.8rem;max-width:120px}.result-actions{gap:.8rem}.result-play-again-button,.result-leave-game-button{font-size:.9rem;padding:.8rem 1.2rem}}@media (max-width: 479px){.game-result-overlay{padding:.5rem}.game-result-modal{max-width:-webkit-fill-available;padding:1rem;border-radius:10px}.result-content{gap:.8rem}.result-icon{font-size:2.2rem}.result-title{font-size:1.5rem}.result-game-stats{padding:.8rem}.result-game-stats p{font-size:.8rem;margin:.3rem 0}.result-players-summary{gap:.8rem;padding:.8rem}.result-vs{font-size:1rem}.result-player-symbol{width:35px;height:35px;font-size:1rem}.result-player-name{font-size:.7rem;max-width:100px}.result-actions{gap:.6rem}.result-play-again-button,.result-leave-game-button{font-size:.8rem;padding:.7rem 1rem}}@media (max-width: 767px) and (orientation: landscape){.game-result-overlay{padding:.3rem}.game-result-modal{max-width:90%;max-height:95vh;padding:1rem;overflow-y:auto}.result-content{gap:.6rem}.result-icon{font-size:2rem}.result-title{font-size:1.4rem}.result-game-stats{padding:.8rem}.result-game-stats p{font-size:.75rem;margin:.2rem 0}.result-players-summary{gap:.8rem;padding:.8rem}.result-vs{transform:none;font-size:.9rem}.result-player-symbol{width:30px;height:30px;font-size:.9rem}.result-player-name{font-size:.65rem;max-width:80px}.result-play-again-button,.result-leave-game-button{font-size:.7rem;padding:.6rem 1rem}.disconnection-message{margin:.5rem;padding:1rem}.disconnection-message h2{font-size:1rem}.disconnection-icon{font-size:2rem}.back-to-home-button{padding:.5rem 1.2rem;font-size:.8rem}}@media (hover: none) and (pointer: coarse){.result-player-symbol:hover{transform:none}.result-player-symbol:active{transform:scale(.95)}.result-play-again-button:hover{transform:none}.result-play-again-button:active{transform:scale(.98)}.leave-game-button:hover{transform:none}.leave-game-button:active{transform:scale(.98)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 2dppx){.result-title,.result-player-symbol{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media (prefers-reduced-motion: reduce){.game-result-overlay,.game-result-modal,.result-icon{animation:none}.result-play-again-button:hover,.result-leave-game-button:hover,.result-player-symbol:hover{transform:none}}@media (prefers-color-scheme: dark){.game-result-modal{background:#1a1a1a;color:#e0e0e0;border:1px solid rgba(255,255,255,.1)}.result-game-stats{background:#ffffff0d;color:silver}.result-players-summary{background:#ffffff08}.result-player-name{color:silver}.result-vs{color:#999}}@media (max-width: 320px){.game-result-modal{padding:.8rem}.result-content{gap:.6rem}.result-icon{font-size:2rem}.result-title{font-size:1.3rem}.result-game-stats{padding:.6rem}.result-game-stats p{font-size:.7rem;margin:.2rem 0}.result-players-summary{padding:.6rem}.result-player-symbol{width:30px;height:30px;font-size:.9rem}.result-player-name{font-size:.6rem;max-width:80px}.result-play-again-button,.leave-game-button{font-size:.7rem;padding:.6rem 1rem}}.app-footer{position:fixed;bottom:0;left:0;right:0;width:100%;padding:.7rem 2rem;background:#ffffff1a;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-top:1px solid rgba(255,255,255,.2);z-index:100;box-sizing:border-box;box-shadow:0 -4px 20px #0000001a;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1)}.app-footer.collapsed{padding:.4rem 2rem}.app-footer.expanded{padding:.7rem 2rem}.footer-content{display:flex;align-items:center;justify-content:center;gap:.8rem;max-width:1200px;margin:0 auto;color:#020202e6;font-size:.9rem;font-weight:500;transition:all .4s cubic-bezier(.4,0,.2,1)}.footer-text{display:flex;align-items:center;gap:.5rem}.footer-text span{text-shadow:1px 1px 2px rgba(0,0,0,.2)}.footer-icons{display:flex;align-items:center;gap:.5rem;transition:all .4s cubic-bezier(.4,0,.2,1)}.footer-icons.hidden{opacity:0;transform:translate(20px) scale(.8);pointer-events:none;max-width:0;overflow:hidden}.footer-icons.visible{opacity:1;transform:translate(0) scale(1);pointer-events:all;max-width:200px}.developer-link{color:#575555;text-decoration:none;font-weight:600;padding:.3rem .8rem;border-radius:12px;background:#ffffff26;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(77,72,72,.2);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.developer-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,#DF314F,transparent);transition:left .5s ease}.developer-link:hover{background:#ffffff40;transform:translateY(-2px);box-shadow:0 8px 25px #ffffff26;color:#df314f}.developer-link:hover:before{left:100%}.developer-link:active{transform:translateY(0);box-shadow:0 4px 15px #ffffff1a}.footer-icon{opacity:.8;transition:all .3s ease}.footer-icon-link{display:inline-flex;align-items:center;justify-content:center;color:inherit;text-decoration:none;border-radius:6px;background:transparent;border:none;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.footer-icon-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,#DF314F,transparent);transition:left .5s ease}.footer-icon-link:hover{background:#ffffff1a;transform:translateY(-1px);box-shadow:none}.footer-icon-link:hover:before{left:100%}.footer-icon-link:hover .footer-icon{opacity:1;transform:scale(1.1)}.footer-icon-link:active{transform:translateY(0);box-shadow:none}.footer-icon svg{transition:all .3s ease}@media (min-width: 1440px){.app-footer{padding:.95rem 3rem}.app-footer.collapsed{padding:.55rem 3rem}.app-footer.expanded{padding:.95rem 3rem}.footer-content{font-size:1rem;gap:1rem}.footer-text,.footer-icons{gap:.6rem}.developer-link{padding:.4rem 1rem;border-radius:14px}.footer-icon svg{width:28px;height:28px}}@media (min-width: 1024px) and (max-width: 1439px){.app-footer{padding:.85rem 2.5rem}.app-footer.collapsed{padding:.5rem 2.5rem}.app-footer.expanded{padding:.85rem 2.5rem}.footer-content{font-size:.95rem;gap:.9rem}.footer-text,.footer-icons{gap:.55rem}.developer-link{padding:.35rem .9rem;border-radius:13px}.footer-icon svg{width:26px;height:26px}}@media (min-width: 768px) and (max-width: 1023px){.app-footer{padding:.75rem 2rem}.app-footer.collapsed{padding:.45rem 2rem}.app-footer.expanded{padding:.75rem 2rem}.footer-content{font-size:.9rem;gap:.8rem}.footer-text,.footer-icons{gap:.5rem}.developer-link{padding:.3rem .8rem;border-radius:12px}.footer-icon svg{width:24px;height:24px}}@media (min-width: 480px) and (max-width: 767px){.app-footer{padding:.55rem 1.5rem}.app-footer.collapsed{padding:.35rem 1.5rem}.app-footer.expanded{padding:.55rem 1.5rem}.footer-content{font-size:.85rem;gap:.7rem;flex-direction:column}.footer-text{gap:.4rem}.footer-icons{gap:.4rem;margin-top:.2rem}.footer-icons.hidden{margin-top:0;max-height:0}.footer-icons.visible{margin-top:.2rem;max-height:50px}.developer-link{padding:.25rem .7rem;border-radius:10px}.footer-icon svg{width:22px;height:22px}}@media (max-width: 479px){.app-footer{padding:.45rem 1rem}.app-footer.collapsed{padding:.25rem 1rem}.app-footer.expanded{padding:.45rem 1rem}.footer-content{font-size:.8rem;gap:.6rem;flex-direction:column}.footer-text{gap:.3rem;text-align:center}.footer-icons{gap:.3rem;margin-top:.15rem}.footer-icons.hidden{margin-top:0;max-height:0}.footer-icons.visible{margin-top:.15rem;max-height:40px}.developer-link{padding:.2rem .6rem;border-radius:8px;font-size:.8rem}.footer-icon svg{width:20px;height:20px}}@media (max-width: 767px) and (orientation: landscape){.app-footer{padding:.25rem 1rem}.footer-content{font-size:.75rem;gap:.5rem;flex-direction:row}.footer-text{gap:.3rem}.developer-link{padding:.2rem .5rem;border-radius:8px;font-size:.75rem}.footer-icon svg{width:20px;height:20px}}@media (hover: none) and (pointer: coarse){.developer-link:hover{transform:none;background:#ffffff26}.developer-link:hover:before{left:-100%}.developer-link:active{background:#ffffff4d;transform:scale(.98)}.footer-icon-link:hover{transform:none;background:transparent}.footer-icon-link:hover:before{left:-100%}.footer-icon-link:active{background:#ffffff1a;transform:scale(.95)}.footer-icon-link:hover .footer-icon{transform:none}}@media (prefers-reduced-motion: reduce){.developer-link,.footer-icon-link,.footer-icon,.footer-icon svg{transition:none}.developer-link:before,.footer-icon-link:before{transition:none}.developer-link:hover,.developer-link:active,.footer-icon-link:hover,.footer-icon-link:active,.footer-icon-link:hover .footer-icon{transform:none}}@media (prefers-color-scheme: dark){.app-footer{background:#1e1e1ee6;border-top:1px solid rgba(255,255,255,.1);box-shadow:0 -4px 20px #0000004d}.footer-content{color:#ffffffd9}.developer-link{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#ffffffe6}.developer-link:hover{background:#fff3;color:#fff;box-shadow:0 8px 25px #ffffff1a}.developer-link:before{background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent)}.footer-icon-link{background:transparent;border:none}.footer-icon-link:hover{background:#ffffff14;box-shadow:none}.footer-icon-link:before{background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.footer-icon{opacity:.7}.footer-icon-link:hover .footer-icon{opacity:1}}@media (max-width: 320px){.app-footer{padding:.35rem .8rem}.app-footer.collapsed{padding:.2rem .8rem}.app-footer.expanded{padding:.35rem .8rem}.footer-content{font-size:.75rem;gap:.5rem;flex-direction:column}.footer-text{gap:.25rem;text-align:center}.footer-icons{gap:.25rem;margin-top:.1rem}.footer-icons.hidden{margin-top:0;max-height:0}.footer-icons.visible{margin-top:.1rem;max-height:35px}.developer-link{padding:.15rem .5rem;border-radius:6px;font-size:.75rem}.footer-icon svg{width:18px;height:18px}}.app{min-height:100vh;width:100vw;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;box-sizing:border-box;background:linear-gradient(135deg,#667eea,#764ba2);gap:2rem}.app-loading,.app-error{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;box-sizing:border-box;position:fixed;top:0;left:0;z-index:1000}.loading-content,.error-content{text-align:center;color:#fff;background:#ffffff26;padding:3rem;border-radius:24px;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.25);max-width:500px;width:90%;box-shadow:0 25px 50px #00000026,0 8px 32px #ffffff1a inset;position:relative;overflow:hidden;animation:slideIn .6s ease-out}.loading-content:before,.error-content:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.03),transparent);animation:shimmer 3s infinite linear;pointer-events:none}@keyframes slideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shimmer{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}.loading-content h2,.error-content h2{font-size:2.2rem;margin:0 0 1.5rem;font-weight:700;background:linear-gradient(135deg,#fff,#e8f4f8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 2px 4px rgba(0,0,0,.1);position:relative;z-index:1}.loading-content p,.error-content p{font-size:1.1rem;margin:0 0 2rem;line-height:1.6;opacity:.95;position:relative;z-index:1}.spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.2);border-top:4px solid #fff;border-radius:50%;animation:spin 1.2s cubic-bezier(.68,-.55,.265,1.55) infinite;margin:0 auto 2rem;box-shadow:0 4px 20px #ffffff4d,0 0 0 8px #ffffff0d;position:relative;z-index:1}.spinner:before{content:"";position:absolute;inset:-8px;border:2px solid transparent;border-top:2px solid rgba(255,255,255,.1);border-radius:50%;animation:spin 2s linear infinite reverse}@keyframes spin{0%{transform:rotate(0);filter:hue-rotate(0deg)}to{transform:rotate(360deg);filter:hue-rotate(360deg)}}.error-content{background:#ffffff1a}.error-content h2{color:#ffebee;margin-bottom:1rem}.error-content p{color:#ffcdd2;margin-bottom:2.5rem}.error-content button{padding:1.2rem 2.5rem;background:linear-gradient(135deg,#fff,#f8f9fa);color:#667eea;border:none;border-radius:16px;cursor:pointer;font-weight:700;font-size:1.1rem;margin-top:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 25px #ffffff26,0 4px 12px #0000001a;position:relative;z-index:1;overflow:hidden}.error-content button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s ease}.error-content button:hover:before{left:100%}.error-content button:hover{background:linear-gradient(135deg,#f8f9fa,#fff);transform:translateY(-3px);box-shadow:0 12px 35px #fff3,0 6px 16px #00000026}.error-content button:active{transform:translateY(-1px);box-shadow:0 6px 20px #ffffff26,0 3px 8px #0000001a}.game-container{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);max-width:1200px;width:100%;box-sizing:border-box}.game-header{text-align:center;color:#fff;margin-bottom:2rem;background:#ffffff1a;padding:2rem;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 10px 30px #0000001a}.game-header h1{font-size:3.5rem;margin:0 0 1.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.3);font-weight:700;background:linear-gradient(135deg,#fff,#e3f2fd);-webkit-background-clip:text;background-clip:text}.game-header h1 span{-webkit-text-fill-color:transparent}.players-info{display:flex;align-items:center;justify-content:center;gap:2.5rem;background:#ffffff26;padding:1.5rem 2.5rem;border-radius:25px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 15px #0000001a}.player-info{display:flex;align-items:center;gap:.8rem;padding:.5rem 1rem;background:#ffffff1a;border-radius:15px;transition:all .3s ease}.player-info:hover{background:#fff3;transform:translateY(-2px)}.player-name{font-size:1.2rem;font-weight:600;text-shadow:1px 1px 2px rgba(0,0,0,.2);margin-right:1rem}.player-symbol{width:100%;height:35px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:#fff;transition:all .3s ease}.player-symbol:hover{transform:scale(1.1)}.player-symbol.x{background:linear-gradient(135deg,#e74c3c,#c0392b)}.player-symbol.o{background:linear-gradient(135deg,#3498db,#2980b9)}.vs{font-size:1.4rem;font-weight:700;color:#ffffffe6;text-shadow:1px 1px 2px rgba(0,0,0,.2);padding-top:1rem;padding-bottom:1rem}.game-actions{display:flex;gap:1.5rem;margin-top:2rem;justify-content:center;flex-wrap:wrap}.leave-game-button{padding:1rem 2rem;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:12px;cursor:pointer;font-weight:600;font-size:1.1rem;transition:all .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);box-shadow:0 4px 15px #ffffff1a}.leave-game-button:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 6px 20px #fff3}.leave-game-button:active{transform:translateY(0)}@media (min-width: 1440px){.game-container{padding:3rem;gap:3rem}.game-header{padding:3rem;margin-bottom:3rem}.game-header h1{font-size:4.5rem}.players-info{gap:3rem;padding:2rem 3rem}.player-info{gap:1rem;padding:.8rem 1.5rem}.player-name{font-size:1.4rem}.player-symbol{width:100%;height:40px;font-size:1.4rem}.vs{font-size:1.6rem}.leave-game-button{font-size:1.2rem;padding:1.2rem 2.5rem}.app-loading,.app-error{padding:3rem}.loading-content,.error-content{padding:4rem;max-width:600px;border-radius:28px}.loading-content h2,.error-content h2{font-size:2.8rem;margin-bottom:2rem}.loading-content p,.error-content p{font-size:1.3rem;margin-bottom:2.5rem}.spinner{width:80px;height:80px;border-width:5px;margin-bottom:2.5rem}.error-content button{font-size:1.3rem;padding:1.5rem 3rem;border-radius:20px}}@media (min-width: 1024px) and (max-width: 1439px){.game-container{padding:2.5rem;gap:2.5rem}.game-header{padding:2.5rem;margin-bottom:2.5rem}.game-header h1{font-size:4rem}.players-info{gap:2.8rem;padding:1.8rem 2.8rem}.player-info{gap:.9rem;padding:.7rem 1.3rem}.player-name{font-size:1.3rem}.player-symbol{width:100%;height:38px;font-size:1.3rem}.vs{font-size:1.5rem}.leave-game-button{font-size:1.15rem;padding:1.1rem 2.2rem}.app-loading,.app-error{padding:2.5rem}.loading-content,.error-content{padding:3.5rem;max-width:550px;border-radius:26px}.loading-content h2,.error-content h2{font-size:2.5rem;margin-bottom:1.8rem}.loading-content p,.error-content p{font-size:1.2rem;margin-bottom:2.2rem}.spinner{width:70px;height:70px;border-width:5px;margin-bottom:2.2rem}.error-content button{font-size:1.2rem;padding:1.3rem 2.8rem;border-radius:18px}}@media (min-width: 768px) and (max-width: 1023px){.game-container{padding:2rem;gap:2rem}.game-header{padding:2rem;margin-bottom:2rem}.game-header h1{font-size:3rem}.players-info{gap:2rem;padding:1.5rem 2rem}.player-info{gap:.7rem;padding:.6rem 1rem}.player-name{font-size:1.1rem}.player-symbol{width:100%;height:32px;font-size:1.1rem}.vs{font-size:1.3rem}.leave-game-button{font-size:1rem;padding:1rem 1.8rem}.app-loading,.app-error{padding:2rem}.loading-content,.error-content{padding:2.5rem;max-width:480px;width:85%;border-radius:22px}.loading-content h2,.error-content h2{font-size:2.2rem;margin-bottom:1.5rem}.loading-content p,.error-content p{font-size:1.1rem;margin-bottom:2rem}.spinner{width:55px;height:55px;border-width:4px;margin-bottom:2rem}.error-content button{font-size:1.1rem;padding:1.1rem 2.2rem;border-radius:16px}}@media (min-width: 480px) and (max-width: 767px){.app{padding:.5rem}.game-container{padding:1.5rem;gap:1.5rem}.game-header{padding:1.5rem;margin-bottom:1.5rem}.game-header h1{font-size:2.5rem}.players-info{flex-direction:column;gap:1.5rem;padding:1.5rem}.player-info{gap:.6rem;padding:.5rem .8rem}.player-name{font-size:1rem}.player-symbol{width:100%;height:28px;font-size:1rem}.vs{font-size:1.2rem}.game-actions{gap:1rem;margin-top:1.5rem}.leave-game-button{font-size:.9rem;padding:.8rem 1.5rem}.app-loading,.app-error{padding:1.5rem}.loading-content,.error-content{padding:2.5rem 2rem;max-width:400px;width:90%;border-radius:20px}.loading-content h2,.error-content h2{font-size:2rem;margin-bottom:1.2rem}.loading-content p,.error-content p{font-size:1rem;margin-bottom:1.8rem}.spinner{width:50px;height:50px;border-width:4px;margin-bottom:1.8rem}.error-content button{font-size:1rem;padding:1rem 2rem;border-radius:14px}}@media (max-width: 479px){.app{padding:.5rem}.game-container{padding:1rem;gap:1rem}.game-header{padding:1rem;margin-bottom:1rem}.game-header h1{font-size:2rem}.players-info{flex-direction:column;gap:1rem;padding:1rem}.player-info{gap:.5rem;padding:.4rem .6rem}.player-name{font-size:.9rem}.player-symbol{width:100%;height:24px;font-size:.9rem}.vs{font-size:1rem}.game-actions{gap:.8rem;margin-top:1rem}.leave-game-button{font-size:.8rem;padding:.7rem 1.2rem}.app-loading,.app-error{padding:1rem}.loading-content,.error-content{padding:2rem 1.5rem;max-width:320px;width:95%;border-radius:18px}.loading-content h2,.error-content h2{font-size:1.8rem;margin-bottom:1rem}.loading-content p,.error-content p{font-size:.95rem;margin-bottom:1.5rem;line-height:1.5}.spinner{width:45px;height:45px;border-width:3px;margin-bottom:1.5rem}.error-content button{font-size:.95rem;padding:1rem 1.8rem;border-radius:12px}}@media (max-width: 767px) and (orientation: landscape){.game-container{padding:1rem;gap:1rem;justify-content:flex-start}.game-header{padding:1rem;margin-bottom:1rem}.game-header h1{font-size:1.8rem}.players-info{flex-direction:row;gap:1.5rem;padding:1rem 1.5rem}.player-info{gap:.5rem;padding:.3rem .5rem}.player-name{font-size:.8rem}.player-symbol{width:100%;height:22px;font-size:.8rem}.vs{transform:none;font-size:1rem}.game-actions{margin-top:.5rem}.leave-game-button{font-size:.7rem;padding:.6rem 1rem}}@media (hover: none) and (pointer: coarse){.player-info:hover{background:#ffffff1a;transform:none}.player-info:active{background:#fff3;transform:scale(.98)}.player-symbol:hover{transform:none}.player-symbol:active{transform:scale(.95)}.leave-game-button:hover{background:#fff3;transform:none}.leave-game-button:active{background:#ffffff4d;transform:scale(.98)}.error-content button:hover{background:linear-gradient(135deg,#fff,#f8f9fa);transform:none}.error-content button:hover:before{left:-100%}.error-content button:active{background:linear-gradient(135deg,#f0f0f0,#e8f4f8);transform:scale(.98);box-shadow:0 4px 15px #ffffff1a,0 2px 6px #0000000d}.loading-content,.error-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 2dppx){.game-header h1,.player-name{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media (prefers-reduced-motion: reduce){.spinner{animation:none;border-top-color:#fffc}.spinner:before{animation:none}.loading-content,.error-content{animation:none}.loading-content:before,.error-content:before{animation:none}.error-content button:before{transition:none}.player-info:hover,.player-symbol:hover,.leave-game-button:hover,.error-content button:hover,.player-info:active,.player-symbol:active,.leave-game-button:active,.error-content button:active{transform:none}}@media (prefers-color-scheme: dark){.app-loading,.app-error{background:linear-gradient(135deg,#1a1a2e,#16213e)}.loading-content,.error-content{background:#1e1e1ef2;color:#e0e0e0;border:1px solid rgba(255,255,255,.15);box-shadow:0 25px 50px #0000004d,0 8px 32px #ffffff0d inset}.loading-content:before,.error-content:before{background:linear-gradient(45deg,transparent,rgba(255,255,255,.02),transparent)}.loading-content h2,.error-content h2{background:linear-gradient(135deg,#e0e0e0,silver);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.error-content h2{background:linear-gradient(135deg,#ffcdd2,#f8bbd9);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.spinner{border-color:#ffffff1a;border-top-color:#e0e0e0;box-shadow:0 4px 20px #ffffff26,0 0 0 8px #ffffff08}.error-content button{background:linear-gradient(135deg,#424242,#616161);color:#e0e0e0;box-shadow:0 8px 25px #0003,0 4px 12px #ffffff0d}.error-content button:hover{background:linear-gradient(135deg,#616161,#757575)}.error-content button:before{background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.game-header{background:#1e1e1ecc;color:#e0e0e0;border:1px solid rgba(255,255,255,.1)}.game-header h1{background:linear-gradient(135deg,#e0e0e0,#b0b0b0);-webkit-background-clip:text;background-clip:text}.game-header h1 span{-webkit-text-fill-color:transparent}.players-info{background:#1e1e1eb3;border:1px solid rgba(255,255,255,.1)}.player-info{background:#ffffff1a}.player-name{color:#e0e0e0}.vs{color:#b0b0b0}.leave-game-button{background:#ffffff1a;color:#e0e0e0;border:2px solid rgba(255,255,255,.2)}}@media (max-width: 320px){.game-header h1{font-size:1.5rem}.players-info{padding:.8rem}.player-info{padding:.3rem .5rem}.player-name{font-size:.8rem}.player-symbol{width:100%;height:20px;font-size:.8rem}.leave-game-button{font-size:.7rem;padding:.6rem 1rem}.app-loading,.app-error{padding:.8rem}.loading-content,.error-content{padding:1.8rem 1.2rem;max-width:280px;width:98%;border-radius:16px}.loading-content h2,.error-content h2{font-size:1.6rem;margin-bottom:.8rem}.loading-content p,.error-content p{font-size:.9rem;margin-bottom:1.2rem;line-height:1.4}.spinner{width:40px;height:40px;border-width:3px;margin-bottom:1.2rem}.error-content button{font-size:.9rem;padding:.9rem 1.5rem;border-radius:10px}}
