*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.card{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #4a5568;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;display:flex;font-weight:700;height:90px;justify-content:center;position:relative;text-shadow:1px 1px 2px #00000080;transition:all .2s ease;width:60px}.card:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.card.selected{background:linear-gradient(135deg,#f6ad55,#fc8181);border-color:#f6ad55;box-shadow:0 6px 12px #0000004d;transform:translateY(-4px)}.card.playable{border-color:#68d391;box-shadow:0 0 0 2px #68d3914d}.card.disabled{cursor:not-allowed;opacity:.6}.card.disabled:hover{box-shadow:0 2px 4px #0000001a;transform:none}.card-value{font-size:18px;font-weight:700}.discard-pile{align-items:center;background:#f7fafc;border:2px dashed #cbd5e0;border-radius:8px;display:flex;flex-direction:column;gap:1rem;margin:5px;min-height:120px;min-width:80px;padding:1rem;position:relative}.discard-pile.drag-over{background:#fffaf0;border-color:#ed8936;box-shadow:0 0 12px #ed893659;transform:translateY(-2px);transition:all .15s ease}.pile-header{margin-bottom:8px}.pile-label{color:#4a5568;font-size:14px;font-weight:700;text-align:center}.view-pile-btn{background:#38a169;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:10px;font-weight:600;margin-top:8px;padding:4px 8px;text-shadow:1px 1px 2px #0006;transition:all .2s;width:100%}.view-pile-btn:hover:not(:disabled){background:#2f855a;transform:translateY(-1px)}.view-pile-btn.disabled{background:#a0aec0;cursor:not-allowed;opacity:.6}.view-pile-btn.disabled:hover{background:#a0aec0;transform:none}.pile-cards{flex:1 1;min-height:60px}.empty-pile,.pile-cards{align-items:center;display:flex;justify-content:center}.empty-pile{color:#a0aec0;flex-direction:column;font-size:12px}.no-cards-card{align-items:center;background:#e2e8f0;border:2px dashed #cbd5e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;height:80px;justify-content:center;width:60px}.no-cards-text{color:#718096;font-size:10px;font-weight:700;line-height:1.2;text-align:center}.pile-display{align-items:center;display:flex;justify-content:center;min-height:100px}.stacked-card{position:absolute;transition:all .2s ease}.starting-card{background:#ffffff1a;border:2px dashed #cbd5e0;border-radius:8px;opacity:.7}.pile-count{color:#718096;font-size:10px;margin-top:4px;text-align:center}.select-pile-btn{background:#4299e1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;margin-top:8px;padding:6px 12px;transition:all .2s;width:100%}.select-pile-btn:hover{background:#3182ce;transform:translateY(-1px)}.select-pile-btn.selected{background:#38a169;box-shadow:0 0 10px #38a16980}.select-pile-btn.selected:hover{background:#2f855a}.select-pile-btn.disabled{background:#a0aec0;cursor:not-allowed;opacity:.6}.select-pile-btn.disabled:hover{background:#a0aec0;transform:none}.player-hand{align-items:center;display:flex;flex-direction:column;margin:10px 0}.hand-cards{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-bottom:10px;max-width:100%}.card-container{cursor:grab;position:relative;transition:transform .2s ease,opacity .2s ease}.card-container:active{cursor:grabbing}.card-container.dragging{opacity:.5;transform:rotate(5deg) scale(1.05);z-index:1000}.card-container.drag-over{transform:translateY(-10px);z-index:999}.card-container.drag-over:after{background:#4299e11a;border:2px dashed #4299e1;border-radius:8px;bottom:-5px;content:"";left:-5px;pointer-events:none;position:absolute;right:-5px;top:-5px}.hand-info{align-items:center;color:#4a5568;display:flex;flex-direction:column;font-size:12px}.selection-info{color:#f6ad55;font-weight:700;margin-top:2px}.reorder-hint{color:#a0aec0;font-size:10px;font-style:italic;font-weight:400;margin-top:2px}.pile-view-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.pile-view-modal{background:#2d3748;border:2px solid #4299e1;border-radius:15px;box-shadow:0 20px 40px #00000080;max-height:80vh;max-width:80vw;overflow-y:auto;padding:20px}.pile-view-header{align-items:center;border-bottom:2px solid #4a5568;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.pile-view-header h3{color:#4299e1;font-size:1.5rem;font-weight:700;margin:0}.close-btn{align-items:center;background:#e53e3e;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:30px;justify-content:center;text-shadow:1px 1px 2px #0006;transition:all .2s;width:30px}.close-btn:hover{background:#c53030;transform:scale(1.1)}.pile-view-content{display:flex;gap:20px}.pile-cards-list{display:flex;flex:1 1;flex-direction:column;gap:10px;max-height:60vh;overflow-y:auto;padding-right:10px}.pile-card-item{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;display:flex;gap:15px;padding:10px}.card-position{color:#a0aec0;font-size:14px;font-weight:700;min-width:30px}.pile-summary{background:#4299e11a;border:1px solid #4299e14d;border-radius:10px;height:-webkit-fit-content;height:fit-content;min-width:200px;padding:15px}.pile-summary p{color:#e2e8f0;font-size:14px;margin:0 0 10px}.pile-summary p:last-child{margin-bottom:0}.pile-summary p:first-child{color:#4299e1;font-weight:700}.pile-cards-list::-webkit-scrollbar{width:8px}.pile-cards-list::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.pile-cards-list::-webkit-scrollbar-thumb{background:#4299e1;border-radius:4px}.pile-cards-list::-webkit-scrollbar-thumb:hover{background:#3182ce}@media (max-width:768px){.pile-view-modal{max-height:90vh;max-width:95vw;padding:15px}.pile-view-content{flex-direction:column;gap:15px}.pile-cards-list{max-height:50vh}.pile-summary{min-width:auto}}.game-over-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.game-over-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000004d;max-width:400px;padding:2rem;text-align:center;width:90%}.game-over-modal h2{color:#d32f2f;font-size:1.8rem;margin:0 0 1rem}.game-over-modal p{color:#333;font-size:1.1rem;line-height:1.5;margin:0 0 2rem}.game-over-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.game-over-actions button{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:.75rem 1.5rem;transition:all .2s ease}.new-game-btn{background-color:#4caf50}.new-game-btn:hover{background-color:#45a049}.close-modal-btn{background-color:#f5f5f5;border:1px solid #ddd;color:#333}.close-modal-btn:hover{background-color:#e0e0e0}@media (max-width:480px){.game-over-modal{margin:1rem;padding:1.5rem}.game-over-actions{flex-direction:column}.game-over-actions button{width:100%}}.rules-modal-overlay{align-items:center;background-color:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.rules-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.rules-modal-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px 24px 0}.rules-modal-header h2{color:#2d3748;font-size:1.8rem;font-weight:700;margin:0}.modal-rules-content{padding:0 24px 20px}.close-rules-btn{align-items:center;background:none;border:none;border-radius:50%;color:#718096;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;text-shadow:1px 1px 2px #0006;transition:all .2s ease;width:32px}.close-rules-btn:hover{background-color:#e2e8f0;color:#2d3748}.rules-modal-footer{border-top:2px solid #e2e8f0;padding:20px 24px;text-align:center}.close-modal-btn{background-color:#4299e1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:12px 24px;text-shadow:1px 1px 2px #0006;transition:all .2s ease}.close-modal-btn:hover{background-color:#3182ce;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}@media (max-width:640px){.rules-modal-overlay{padding:10px}.rules-modal{max-height:95vh}.rules-modal-header{padding:16px 20px 0}.rules-modal-header h2{font-size:1.5rem}.modal-rules-content{padding:0 20px 16px}.rules-modal-footer{padding:16px 20px}}.rules-content{color:#4a5568;line-height:1.65;text-align:left}.rules-content section{margin-bottom:20px}.rules-content h3{border-bottom:1px solid #e2e8f0;color:#4299e1;font-size:1.3rem;font-weight:600;margin:24px 0 12px;padding-bottom:8px}.rules-content h3:first-child{margin-top:0}.rules-content h4{color:#2d3748;font-size:1.05rem;font-weight:600;margin:0 0 10px}.rules-content p{font-size:1rem;margin:0 0 16px}.rules-content ul{margin:0 0 16px;padding-left:22px}.rules-content li{margin-bottom:8px}.rules-content strong{color:#2d3748;font-weight:600}.rules-content code{background:#edf2f7;border-radius:4px;color:#2d3748;font-size:.9rem;padding:2px 6px}.rules-content .game-objective{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;padding:20px}.rules-content .game-objective h3,.rules-content .game-objective p{border:none;color:#fff}.rules-content .game-objective h3{margin-top:0;padding-bottom:4px}.rules-content .game-objective p{margin-bottom:12px}.rules-content .pile-rules{background:#f7fafc;border-left:4px solid #4299e1;border-radius:8px;padding:16px}.rules-content .setup-rules{background:#fefcf5;border-left:4px solid #d69e2e;border-radius:8px;padding:16px}.rules-content .hand-sizes{background:#fff7e6;border-left:4px solid #ed8936;border-radius:8px;margin-top:12px;padding:12px 16px}.rules-content .hand-sizes ul{margin:0;padding-left:18px}.rules-content .hand-sizes li{margin-bottom:6px}.rules-content .gameplay-rules{background:#f0fff4;border-left:4px solid #48bb78;border-radius:8px;padding:16px}.rules-content .special-rules{background:#fff5f5;border-left:4px solid #e53e3e;border-radius:8px;padding:16px}.rules-content .communication-rules{background:#ebf8ff;border-left:4px solid #3182ce;border-radius:8px;padding:16px}.rules-content .endgame-rules{background:#f7fafc;border-left:4px solid #805ad5;border-radius:8px;margin-bottom:0;padding:16px}@media (max-width:640px){.rules-content{font-size:.95rem}.rules-content h3{font-size:1.1rem}}.game{background:linear-gradient(135deg,#667eea,#764ba2);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:20px}.game-header{color:#fff;margin-bottom:30px;text-align:center}.game-header h1{font-size:3rem;margin:0 0 10px;text-shadow:2px 2px 4px #0000004d}.game-id{color:#f6ad55;font-size:1rem;font-weight:600;margin-bottom:10px;text-shadow:1px 1px 2px #0000004d}.new-game-btn{background:#e53e3e;border:none;border-radius:6px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;display:block;font-size:.9rem;font-weight:600;margin:0 auto 20px;padding:8px 16px;text-shadow:1px 1px 2px #0006;transition:all .2s}.new-game-btn:hover{background:#c53030;box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.game-status{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:20px;font-size:1.2rem;margin-bottom:20px;padding:10px 20px}.game-controls{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.game-controls button{background:#4299e1;border:none;border-radius:25px;box-shadow:0 4px 6px #0000001a;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:12px 24px;transition:all .2s ease}.game-controls button:hover:not(:disabled){background:#3182ce;box-shadow:0 6px 8px #00000026;transform:translateY(-2px)}.game-controls button:disabled{background:#a0aec0;cursor:not-allowed;transform:none}.start-game-section{background:#ffffff1a;border:2px dashed #ffffff4d;border-radius:12px;margin:20px 0;padding:20px;text-align:center}.start-game-main-btn{background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:12px;box-shadow:0 4px 12px #48bb784d;color:#fff;cursor:pointer;font-size:1.3rem;font-weight:700;letter-spacing:1px;padding:16px 32px;text-shadow:1px 1px 2px #0006;text-transform:uppercase;transition:all .3s}.start-game-main-btn:hover:not(:disabled){background:linear-gradient(135deg,#38a169,#2f855a);box-shadow:0 6px 20px #48bb7866;transform:translateY(-2px)}.start-game-main-btn:disabled{background:#a0aec0;box-shadow:0 2px 4px #0003;cursor:not-allowed;transform:none}.end-turn-btn{background:#48bb78;border:none;border-radius:8px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:12px 24px;text-shadow:1px 1px 2px #0006;transition:all .2s}.end-turn-btn:hover:not(:disabled){background:#38a169;box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.end-turn-btn:disabled{background:#a0aec0;box-shadow:none;cursor:not-allowed;transform:none}.sort-controls{align-items:center;display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.sort-buttons{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.sort-hand-btn{background:#ed8936;border:none;border-radius:6px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;margin:0;padding:8px 16px;text-shadow:1px 1px 2px #0006;transition:all .2s}.sort-hand-btn:hover:not(:disabled){background:#dd6b20;box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.sort-hand-btn:disabled{background:#a0aec0;box-shadow:none;cursor:not-allowed;transform:none}.auto-sort-toggle{align-items:center;color:#2d3748;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:8px}.auto-sort-toggle input{height:16px;width:16px}.play-card-section{align-items:center;display:flex;flex-direction:column;gap:10px;margin:20px 0}.play-card-btn{background:#4299e1;border:none;border-radius:8px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:12px 24px;text-shadow:1px 1px 2px #0006;transition:all .2s}.play-card-btn:hover:not(:disabled){background:#3182ce;box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.play-card-btn:disabled{background:#a0aec0;box-shadow:none;cursor:not-allowed;transform:none}.cant-play-btn{background:#e53e3e;border:none;border-radius:8px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:12px 24px;text-shadow:1px 1px 2px #0006;transition:all .2s}.cant-play-btn:hover:not(:disabled){background:#c53030;box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.cant-play-btn:disabled{background:#a0aec0;box-shadow:none;cursor:not-allowed;transform:none}.pile-assignment{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;border-radius:15px;margin:20px auto;max-width:800px;padding:20px}.pile-assignment h3{color:#fff;font-size:1.3rem;margin:0 0 20px;text-align:center;text-shadow:1px 1px 2px #0000004d}.single-card-assignment{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;display:flex;justify-content:center;padding:20px}.card-display{background:#4299e1;border-radius:8px;box-shadow:0 2px 4px #0003;color:#fff;font-size:1.1rem;font-weight:700;min-width:50px;padding:10px 15px;text-align:center}.pile-options{display:flex;flex-wrap:wrap;gap:15px}.pile-options label{align-items:center;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:5px;padding:5px 10px;transition:background-color .2s ease}.pile-options label:hover{background:#ffffff1a}.pile-options input[type=radio]{accent-color:#4299e1;margin:0}.pile-options label:has(input:checked){background:#4299e14d;border:1px solid #4299e1}.discard-piles{display:flex;flex-wrap:wrap;gap:40px;justify-content:center;margin-bottom:40px}.pile-group{text-align:center}.pile-group h3{color:#fff;font-size:1.2rem;margin-bottom:15px;text-shadow:1px 1px 2px #0000004d}.piles-row{display:flex;gap:10px;justify-content:center}.players{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:1200px}.player{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;transition:all .3s ease}.player.current{background:#f6ad5533;border-color:#f6ad55;box-shadow:0 0 20px #f6ad554d}.player h3{color:#fff;font-size:1.3rem;text-shadow:1px 1px 2px #0000004d}.game-info{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;border-radius:10px;bottom:20px;color:#fff;display:flex;flex-direction:column;font-size:14px;gap:8px;left:20px;padding:15px;position:fixed}.game-info div{margin-bottom:0}.turn-progress{color:#f6ad55;font-weight:700}.cards-remaining{color:#f56565;font-weight:400}.rules-btn-floating{align-self:flex-start;background:#4299e1;border:none;border-radius:6px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;margin-top:8px;padding:8px 12px;text-shadow:1px 1px 2px #0006;transition:all .2s}.rules-btn-floating:hover{background:#3182ce;box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.save-indicator{color:#a0aec0;font-size:10px;font-style:italic;margin-top:4px;text-align:center}.copy-invite-floating{align-self:flex-start;background:#48bb78;border:none;border-radius:6px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;margin-bottom:10px;margin-top:8px;padding:8px 14px;text-shadow:1px 1px 2px #0006;transition:all .2s}.copy-invite-floating:hover{background:#6b46c1;box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.copy-feedback-floating{color:#68d391;font-weight:600;margin-top:6px}@media (max-width:768px){.game{padding:10px}.game-header h1{font-size:2rem}.discard-piles{gap:20px}.game-controls,.piles-row{align-items:center;flex-direction:column}.game-info{margin-top:20px;position:static;text-align:center}}.player-section{display:flex;flex-direction:column;gap:20px;justify-content:center;margin-top:20px}.player-section .player{margin:0 auto;max-width:600px}.spectator-view{background:#ffffff1a;border-radius:15px;margin:20px auto;padding:40px;text-align:center}.player{background:#ffffff0d;border:2px solid #ffffff1a;border-radius:15px;flex:1 1;max-width:500px;min-width:300px;padding:20px}.player.current{background:#4299e11a;border-color:#4299e1;box-shadow:0 0 20px #4299e14d}.player h3{color:#4299e1;font-size:1.2rem;margin:0 0 15px;text-align:center}.player.current h3{color:#63b3ed;font-weight:700}.game-layout{display:flex;gap:20px;margin:0 auto;max-width:1400px}.game-main{flex:1 1;min-width:0}.game-sidebar{flex-shrink:0;width:300px}.waiting-for-game{background:#ffffff1a;border-radius:15px;margin:20px 0;padding:40px;text-align:center}.waiting-for-game h2{color:#fff;font-size:1.5rem;margin-bottom:15px}.waiting-for-game p{color:#fffc;font-size:1.1rem}.connection-quality{color:#68d391;font-size:.9rem;font-weight:500;margin-bottom:10px;text-shadow:1px 1px 2px #0000004d}.reconnection-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.reconnection-message{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000004d;max-width:400px;padding:30px;text-align:center;width:90%}.reconnection-message h3{color:#e53e3e;font-size:1.5rem;margin:0 0 15px}.reconnection-message p{color:#4a5568;font-size:1rem;margin:10px 0}.reconnect-btn{background:#4299e1;border:none;border-radius:8px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:15px;padding:12px 24px;text-shadow:1px 1px 2px #0006;transition:all .2s}.reconnect-btn:hover:not(:disabled){background:#3182ce;box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.reconnect-btn:disabled{background:#a0aec0;cursor:not-allowed;transform:none}@media (max-width:1200px){.game-layout{flex-direction:column}.game-sidebar{order:-1;width:100%}}.player-list{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;border-radius:15px;margin:20px 0;padding:20px}.player-list-header{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:space-between;margin-bottom:15px}.player-list-header h3{color:#fff;font-size:1.2rem;margin:0;text-shadow:1px 1px 2px #0000004d}.start-game-btn{background:#48bb78;border-radius:6px;box-shadow:0 2px 4px #0003;font-size:.9rem;font-weight:600;padding:8px 16px;transition:all .2s}.start-game-btn:hover:not(:disabled){background:#38a169;box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.start-game-btn:disabled{background:#a0aec0;box-shadow:none;cursor:not-allowed;transform:none}.players-container,.spectators-list,.spectators-section{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.spectators-list{list-style:none}.player-list-item,.spectators-list-item{background:#fff3;border:2px solid #ffffff4d;border-radius:10px;padding:12px;transition:all .2s}.player-list-item.current{background:#48bb784d;border-color:#48bb78;box-shadow:0 0 15px #48bb784d}.player-list-item.disconnected{background:#e53e3e33;border-color:#e53e3e;opacity:.7}.player-info{align-items:center;display:flex;justify-content:space-between}.player-name,.spectator-name{align-items:center;color:#fff;display:flex;font-weight:600;gap:8px;text-shadow:1px 1px 2px #0000004d}.host-badge{background:#4299e1}.current-badge,.host-badge{border-radius:4px;color:#fff;font-size:.7rem;font-weight:600;padding:2px 6px;text-transform:uppercase}.current-badge{background:#48bb78}.you-badge{background:#805ad5;border-radius:4px;color:#fff;font-size:.7rem;font-weight:600;padding:2px 6px;text-transform:uppercase}.player-status{font-size:.9rem}.status-connected{color:#48bb78;font-weight:600}.status-disconnected{color:#e53e3e;font-weight:600}.spectators-section{border-top:1px solid #fff3;padding-top:15px}.spectators-section h3{color:#fff;font-size:1.2rem;margin:0 0 10px;text-shadow:1px 1px 2px #0000004d}.spectators-container{display:flex;flex-direction:column;gap:8px}.spectator-item{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:8px 12px;transition:all .2s}.spectator-item.disconnected{background:#e53e3e1a;border-color:#e53e3e;opacity:.7}.spectator-info{align-items:center;display:flex;justify-content:space-between}.spectator-badge{background:#ed8936;border-radius:3px;color:#fff;font-size:.6rem;font-weight:600;padding:1px 4px;text-transform:uppercase}.spectator-status{font-size:.8rem}.no-players{color:#ffffffb3;font-style:italic;padding:20px;text-align:center}@media (max-width:768px){.player-list-header{align-items:stretch;flex-direction:column;gap:10px}.start-game-btn{width:100%}.player-info{align-items:flex-start;flex-direction:column;gap:5px}.player-status{align-self:flex-end}}.name-prompt-backdrop{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.name-prompt-modal{animation:fadeIn .16s ease-out;background:#fff;border-radius:16px;box-shadow:0 16px 32px #0003;display:flex;flex-direction:column;gap:16px;padding:32px;width:min(90vw,420px)}.name-prompt-modal h2{color:#2d3748;font-size:1.5rem;margin:0}.name-prompt-modal .description{color:#4a5568;font-size:.95rem;margin:0}.name-prompt-modal form{display:flex;flex-direction:column;gap:12px}.role-toggle{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px}.role-toggle input{margin-top:4px}.role-toggle-copy{display:flex;flex-direction:column;gap:2px}.role-toggle-label{color:#2d3748;font-weight:600}.role-toggle-hint{color:#4a5568;font-size:.85rem}.role-note{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;color:#4a5568;font-size:.9rem;margin:0;padding:12px}.name-prompt-modal label{color:#2d3748;font-weight:600}.name-prompt-modal input[type=text]{border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:12px 14px;transition:border-color .2s,box-shadow .2s}.name-prompt-modal input[type=text]:focus{border-color:#4299e1;box-shadow:0 0 0 3px #4299e133;outline:none}.name-prompt-modal .error{color:#e53e3e;font-size:.9rem;margin:0}.name-prompt-modal .actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.name-prompt-modal button{border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 20px;transition:transform .15s ease,box-shadow .15s ease}.name-prompt-modal button:hover:not(:disabled){box-shadow:0 4px 10px #0000001f;transform:translateY(-1px)}.name-prompt-modal button:disabled{background:#cbd5f5;box-shadow:none;color:#fff;cursor:not-allowed;transform:none}.name-prompt-modal button.secondary{background:#0000;border:1px solid #cbd5f5;color:#4a5568}.name-prompt-modal button.secondary:hover:not(:disabled){background:#f7fafc}.name-prompt-modal button[type=submit]{background:#4299e1;color:#fff}.name-prompt-modal button[type=submit]:hover:not(:disabled){background:#3182ce}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.lobby{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.lobby-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:600px;padding:40px;width:100%}.lobby h1{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:30px;text-align:center}.connection-status{align-items:center;background:#ffffff80;border-radius:10px;display:flex;justify-content:center;margin-bottom:30px;padding:10px}.status-indicator{border-radius:50%;height:12px;margin-right:10px;width:12px}.status-indicator.connected{background:#48bb78;box-shadow:0 0 10px #48bb7880}.status-indicator.disconnected{background:#e53e3e;box-shadow:0 0 10px #e53e3e80}.lobby-actions{display:flex;flex-direction:column;gap:30px}.create-room-section,.join-room-section{background:#ffffffb3;border:1px solid #0000001a;border-radius:12px;padding:20px}.create-room-section h3,.join-room-section h3{color:#2d3748;font-size:1.2rem;margin:0 0 15px}.create-room-section form,.join-room-section form{display:flex;flex-direction:column;gap:15px}.join-room-section input{border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;font-weight:600;letter-spacing:2px;padding:12px 16px;text-align:center;transition:border-color .2s}.join-room-section input:focus{border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a;outline:none}.create-room-btn,.join-room-btn{border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;text-shadow:1px 1px 2px #0006;transition:all .2s}.create-room-btn{background:#48bb78;color:#fff;text-shadow:1px 1px 2px #0006}.create-room-btn:hover:not(:disabled){background:#38a169;box-shadow:0 4px 8px #0003;transform:translateY(-1px)}.join-room-btn{background:#4299e1;color:#fff;text-shadow:1px 1px 2px #0006}.join-room-btn:hover:not(:disabled){background:#3182ce;box-shadow:0 4px 8px #0003;transform:translateY(-1px)}.create-room-btn:disabled,.join-room-btn:disabled{background:#a0aec0;box-shadow:none;cursor:not-allowed;transform:none}.lobby-info{background:#ffffff80;border:1px solid #0000001a;border-radius:12px;margin-top:30px;padding:20px}.lobby-info h4{color:#2d3748;margin:0 0 15px}.lobby-info ul{color:#4a5568;margin:0;padding-left:20px}.lobby-info li{margin-bottom:8px}.invite-link-section{border-top:1px solid #0000001a;margin-top:20px;padding-top:15px;text-align:center}.invite-link-section h5{color:#2d3748;font-size:1rem;margin:0 0 10px}.copy-invite-btn{align-items:center;background:#805ad5;border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;display:inline-flex;font-weight:600;gap:8px;padding:10px 20px;text-shadow:1px 1px 2px #0006;transition:all .2s}.copy-invite-btn:hover{background:#6b46c1;box-shadow:0 4px 8px #0003;transform:translateY(-1px)}.copy-feedback{color:#38a169;font-weight:600;margin-top:10px}.invite-tip{color:#4a5568;font-size:.9rem;margin-top:8px;word-break:break-word}.error-message{background:#fed7d7;border:1px solid #feb2b2;border-radius:8px;color:#c53030;margin-top:20px;padding:15px}.error-message p{margin:0 0 8px}.error-message p:last-child{margin-bottom:0}@media (max-width:768px){.lobby-container{margin:10px;padding:20px}.lobby h1{font-size:2rem}}.join-link{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.join-link-container{background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:420px;padding:40px;position:relative;text-align:center;width:100%;z-index:10}.join-link-container h1{color:#2d3748;font-size:2rem;font-weight:700;margin:0 0 20px}.join-link-description{color:#4a5568;font-size:1rem;margin-bottom:15px}.join-link-error{background:#fed7d7;border-radius:8px;color:#e53e3e;display:inline-block;font-size:.95rem;margin-top:10px;padding:10px 14px}.join-link-footer{color:#4a5568;font-size:.95rem;margin-top:25px}.join-link-footer span{color:#2d3748;font-weight:600}@media (max-width:480px){.join-link-container{padding:30px 20px}.join-link-container h1{font-size:1.6rem}}.game-setup{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;justify-content:center;min-height:100vh;padding:20px}.setup-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:600px;padding:40px;text-align:center;width:100%}.setup-container h1{color:#2d3748;font-size:2.5rem;margin-bottom:20px;text-shadow:1px 1px 2px #0000001a}.rules-summary{color:#4a5568;line-height:1.6;margin-bottom:30px;text-align:left}.setup-rules-content{display:block;font-size:.95rem;margin-top:12px}.setup-rules-content .game-objective,.setup-rules-content .rules-section{margin-bottom:16px}.setup-options{gap:20px}.player-selection,.setup-options{align-items:center;display:flex;flex-direction:column}.player-selection{gap:10px}.player-selection label{color:#2d3748;font-size:1.1rem;font-weight:700}.player-selection select{background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#2d3748;cursor:pointer;font-size:16px;min-width:200px;padding:12px 20px;transition:all .2s ease}.player-selection select:focus{border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a;outline:none}.start-game-btn{background:linear-gradient(135deg,#4299e1,#3182ce);border:none;border-radius:25px;box-shadow:0 6px 12px #4299e14d;color:#fff;cursor:pointer;font-size:18px;font-weight:700;letter-spacing:1px;padding:15px 40px;text-shadow:1px 1px 2px #0006;text-transform:uppercase;transition:all .3s ease}.start-game-btn:hover{background:linear-gradient(135deg,#3182ce,#2c5282);box-shadow:0 8px 16px #4299e166;transform:translateY(-2px)}.start-game-btn:active{box-shadow:0 4px 8px #4299e14d;transform:translateY(0)}.multiplayer-section{background:#48bb781a;border:2px solid #48bb7833;border-radius:15px;margin-top:30px;padding:20px}.multiplayer-section h3{color:#2d3748;font-size:1.3rem;margin:0 0 10px}.multiplayer-section p{color:#4a5568;font-size:1rem;margin:0 0 15px}.multiplayer-btn{background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:25px;box-shadow:0 6px 12px #48bb784d;color:#fff;cursor:pointer;font-size:18px;font-weight:700;letter-spacing:1px;padding:15px 40px;text-shadow:1px 1px 2px #0006;text-transform:uppercase;transition:all .3s ease}.multiplayer-btn:hover{background:linear-gradient(135deg,#38a169,#2f855a);box-shadow:0 8px 16px #48bb7866;transform:translateY(-2px)}.multiplayer-btn:active{box-shadow:0 4px 8px #48bb784d;transform:translateY(0)}@media (max-width:768px){.setup-container{margin:10px;padding:20px}.setup-container h1{font-size:2rem}.rules-summary{text-align:center}.player-selection select{min-width:150px}}.App{margin:0;min-height:100vh;padding:0}
/*# sourceMappingURL=main.24dbc05d.css.map*/