.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;transition:opacity .3s ease}.modal-overlay.active{opacity:1}.modal-content{background:#fff;padding:30px;border-radius:15px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d;scrollbar-width:thin;position:relative}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-thumb{background:#667eea4d;border-radius:3px}.modal-content.large-modal{max-width:700px;max-height:85vh}.modal-content h2{color:#667eea;margin-bottom:20px;font-size:24px;text-align:center;font-weight:700}.modal-actions{display:flex;gap:12px;justify-content:center;margin-top:24px}.modal-actions button{padding:12px 24px;font-size:16px;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease}.how-to-play-content{text-align:left;padding:20px 0;line-height:1.7;color:#333}.how-to-play-content h3{color:#667eea;margin-top:24px;margin-bottom:12px;font-size:18px;font-weight:700}.how-to-play-content h3:first-child{margin-top:0}.how-to-play-content p{margin-bottom:12px;color:#333}.how-to-play-content ul,.how-to-play-content ol{margin-bottom:16px;padding-left:25px}.how-to-play-content li{margin-bottom:8px;color:#555}.how-to-play-content strong{color:#667eea;font-weight:600}.results-table-wrapper{margin:20px 0;overflow-x:auto;border-radius:12px;box-shadow:0 2px 8px #0000001a;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.results-table{width:100%;border-collapse:collapse;background:#fff;font-size:14px;min-width:500px}.results-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.results-table th{padding:14px 12px;text-align:left;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid rgba(255,255,255,.2)}.results-table th:first-child{border-top-left-radius:12px}.results-table th:last-child{border-top-right-radius:12px}.results-table tbody tr{border-bottom:1px solid #e0e0e0;transition:all .2s ease;animation:slideInRow .4s ease-out backwards}.results-table tbody tr:nth-child(2n){background:#f8f9fa}.results-table tbody tr:nth-child(odd){background:#fff}.results-table tbody tr:hover{background:#f0f4ff;transform:translate(2px)}.results-table tbody tr.winner-row{background:#4caf50;color:#fff;font-weight:600;box-shadow:0 2px 8px #4caf504d}.results-table tbody tr.winner-row:hover{background:#45a049}.results-table tbody tr.winner-row td{color:#fff}.results-table td{padding:14px 12px;vertical-align:middle}.icon-cell{text-align:center;font-size:20px;width:60px;padding:14px 8px;display:flex;align-items:center;justify-content:center;gap:6px;line-height:1}.name-cell{font-weight:500;color:#212121}.hand-value-cell,.round-score-cell,.total-score-cell,.final-score-cell{text-align:right;font-weight:600;font-family:Courier New,monospace}.round-score-cell .score-value{color:#667eea}.total-score-cell .score-value{color:#212121;font-size:15px}.final-score-cell .score-value{color:#212121;font-size:16px;font-weight:700}.winner-announcement{text-align:center;padding:24px;background:linear-gradient(135deg,#ffd93d,#ffb347);border-radius:12px;margin-bottom:24px;box-shadow:0 4px 12px #ffd93d66;animation:fadeInDown .6s ease-out}.winner-announcement h3{font-size:28px;color:#212121;margin-bottom:8px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.winner-announcement p{font-size:18px;color:#333;font-weight:600}@media (max-width: 768px){.modal-content{padding:20px;width:95%;max-height:90vh}.modal-content h2{font-size:20px}.results-table{min-width:400px;font-size:12px}.results-table th,.results-table td{padding:10px 8px}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.pregame-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px 20px 48px;position:relative;z-index:1}.pregame-content{background:var(--card-bg);border-radius:20px;padding:40px;max-width:500px;width:100%;box-shadow:0 20px 60px #00000040,0 0 0 1px #ffffff1a}.game-logo h1{font-family:var(--font-primary);font-size:3.2rem;font-weight:700;text-align:center;color:#1e1b4b;margin-bottom:8px;letter-spacing:2px;text-shadow:2px 2px 0 rgba(139,92,246,.2)}.logo-subtitle{font-family:var(--font-primary);text-align:center;color:var(--accent-violet);font-size:1.1rem;font-weight:500;line-height:1.5}.logo-subtitle .logo-tagline{font-size:1rem;font-weight:700;color:var(--text-primary);margin-top:4px;letter-spacing:.5px}.input-group{margin:24px 0}.input-group label{font-family:var(--font-primary);display:block;margin-bottom:8px;color:var(--text-primary);font-weight:600}.input-group input{font-family:var(--font-primary);width:100%;padding:14px 16px;border:2px solid #e0e7ff;border-radius:12px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.input-group input:focus{outline:none;border-color:var(--accent-violet);box-shadow:0 0 0 3px #8b5cf633}.action-buttons{display:flex;flex-direction:column;gap:12px;margin-top:28px;position:relative;z-index:10}.action-buttons .btn{width:100%;min-width:0;align-self:stretch;display:block;box-sizing:border-box}.pregame-footer{position:absolute;bottom:16px;left:0;right:0;text-align:center;font-family:var(--font-primary);font-size:.9rem;color:#ffffffe6;z-index:5}.btn{padding:16px 24px;border:none;border-radius:12px;font-family:var(--font-primary);font-size:1rem;font-weight:600;cursor:pointer;transition:all .25s ease;pointer-events:auto;position:relative;z-index:1;text-align:center}.btn-primary{background:linear-gradient(135deg,var(--accent-coral) 0%,#ea580c 100%);color:#fff;box-shadow:0 4px 14px #f9731666}.btn-primary:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 24px #f9731680}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4338ca;border:2px solid #a5b4fc}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#c7d2fe,#a5b4fc);transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.input-group .btn{flex:1;min-width:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{font-family:var(--font-primary);background:#fff;border-radius:20px;padding:32px;max-width:500px;width:90%;box-shadow:0 24px 48px #0003,0 0 0 1px #8b5cf61a}.modal-content h2{font-family:var(--font-primary);margin-bottom:24px;color:var(--text-primary);font-weight:700}.room-code-display{margin:24px 0}.code-value{font-family:var(--font-primary),"Courier New",monospace;font-size:2rem;font-weight:700;color:var(--accent-violet);letter-spacing:6px;text-align:center;margin:16px 0}.btn-copy{width:100%;margin-top:12px}.room-type-badge{font-family:var(--font-primary);display:inline-block;padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:600;margin-top:10px}.room-type-toggle{margin:24px 0}.room-type-toggle label{font-family:var(--font-primary);display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:500}.lobby-container{max-width:600px;margin:0 auto;padding:20px;min-height:100vh}.lobby-header{text-align:center;margin-bottom:30px}.lobby-header h1{font-size:2.5rem;color:#fff;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.lobby-header p{color:#ffffffe6;font-size:1.1rem}.room-info-section,.players-section{background:var(--card-bg);border-radius:15px;padding:25px;margin-bottom:20px;box-shadow:0 4px 15px #0003}.room-code-section{margin-bottom:15px}.room-code-section label{display:block;font-size:.9rem;color:#666;margin-bottom:8px;font-weight:500}.room-code-display{display:flex;align-items:center;gap:10px;background:#f5f5f5;border-radius:8px;padding:12px 15px}.room-code-value{font-family:Courier New,monospace;font-size:1.5rem;font-weight:700;color:#667eea;letter-spacing:2px;flex:1}.room-type-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.9rem;font-weight:500;margin-top:10px}.room-type-badge.public{background:#e3f2fd;color:#1976d2}.room-type-badge.private{background:#fff3e0;color:#f57c00}.players-section h4{margin:0 0 15px;color:#333;font-size:1.1rem}.players-list{list-style:none;padding:0;margin:0}.players-list li{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;margin-bottom:8px;background:#f9f9f9;border-radius:8px;transition:all .2s;border-left:4px solid transparent}.players-list li:hover{background:#f0f0f0;border-left-color:#667eea;transform:translate(5px)}.players-list li.you{background:#e8eaf6;border-left-color:#667eea;font-weight:500}.player-name{display:flex;align-items:center;gap:8px;flex:1}.host-crown{font-size:1.2rem}.you-indicator{color:#667eea;font-weight:600;margin-left:5px}.ai-badge{font-size:.75rem;color:#999;font-style:italic}.ready-badge{background:#4caf50;color:#fff;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:500}.ready-badge.ai{background:#999}.joining-animation{text-align:center;padding:15px;color:#667eea;font-style:italic;font-size:.95rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.lobby-actions{display:flex;gap:15px;margin-top:20px}.lobby-actions .btn{flex:1}.auto-start-message{text-align:center;margin-top:20px;padding:15px;background:#e8f5e9;border-radius:10px;color:#2e7d32;font-weight:500;font-size:1rem}.card{width:60px;height:90px;border-radius:6px;position:relative;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0003;display:flex;flex-direction:column;justify-content:space-between;padding:5px 4px 6px;overflow:hidden}.card.face-up{background:#fff;border:1px solid #b8b8b8}.card.face-down{background:transparent;border:none;padding:0;box-shadow:none;border-radius:0}.card.selectable:hover{transform:translateY(-10px);box-shadow:0 6px 12px #0000004d}.card.selected{transform:translateY(-15px);box-shadow:0 4px 8px #0006;border:2px solid #667eea}.card.newly-picked{border:3px solid #4ade80;box-shadow:0 8px 20px #4ade8099;animation:pulse-newly-picked 1.5s ease-in-out;transform:translateY(-10px)}@keyframes pulse-newly-picked{0%{box-shadow:0 8px 24px #4ade80e6;transform:translateY(-10px) scale(1.05)}50%{box-shadow:0 8px 20px #4ade80b3;transform:translateY(-10px) scale(1.02)}to{box-shadow:0 8px 16px #4ade8080;transform:translateY(-10px) scale(1)}}@keyframes cardPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.card.red{color:#d32f2f}.card.black{color:#212121}.card-rank{font-size:14px;font-weight:700;line-height:1;flex-shrink:0}.card-rank-bottom{transform:rotate(180deg);flex-shrink:0}.card-suit{font-size:16px;line-height:1;text-align:center;flex-grow:1;flex-shrink:1;display:flex;align-items:center;justify-content:center;min-height:0}.card-back{width:100%;height:100%;display:block;overflow:visible;border-radius:0;padding:0;margin:0;background:transparent}.card-back img{width:100%;height:100%;object-fit:contain;display:block;border-radius:0;padding:0;margin:0;border:none}.card-stack{position:relative;display:inline-block}.stack-count{position:absolute;top:-10px;right:-10px;background:#667eea;color:#fff;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-shadow:0 2px 4px #0003}.opponent-hand .card{width:35px;height:52px;box-shadow:0 1px 3px #0003}.opponent-hand .card-rank{font-size:10px}.opponent-hand .card-suit{font-size:14px}.opponent-hand .card-back{font-size:20px}.opponent-player.admin-view .opponent-hand .card{width:40px;height:60px}.opponent-player.admin-view .opponent-hand .card.face-down{display:none}.card.own-discard{opacity:.6;filter:grayscale(30%);border:2px dashed #999;cursor:not-allowed}@media (max-width: 480px){.card{width:40px;height:60px;padding:4px}.card.face-down{padding:0;box-shadow:none;border-radius:0}.card-rank{font-size:12px}.card-suit{font-size:14px}.card-back{font-size:24px}.opponent-hand .card{width:28px;height:40px}.opponent-hand .card-rank{font-size:8px}.opponent-hand .card-suit{font-size:11px}.opponent-hand .card-back{font-size:16px}.opponent-player.admin-view .opponent-hand .card{width:32px;height:46px}.discard-history .card{width:28px;height:40px}.discard-history .card-rank{font-size:8px}.discard-history .card-suit{font-size:11px}.stack-count{width:22px;height:22px;font-size:11px;top:-8px;right:-8px}}.recent-plays{background:#fffffff2;border-radius:8px;padding:6px 8px;min-width:0;flex:1;max-width:200px;box-shadow:0 2px 4px #0000001a;flex-shrink:1}.plays-header{font-weight:700;font-size:11px;margin-bottom:4px;color:#667eea;text-align:center}.plays-table{max-height:80px;overflow-y:auto;font-size:10px;scrollbar-width:thin}.plays-table::-webkit-scrollbar{width:4px}.plays-table::-webkit-scrollbar-thumb{background:#667eea4d;border-radius:2px}.no-plays{text-align:center;color:#999;padding:20px;font-style:italic}.play-row{display:flex;align-items:center;gap:8px;padding:5px;margin:3px 0;background:#667eea0d;border-radius:5px;border-left:3px solid #667eea;transition:all .3s ease}.play-row:hover{background:#667eea1a;transform:translate(3px)}.play-row.recent{background:#667eea26;border-left-color:#764ba2;animation:slideIn .5s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.play-player{font-weight:700;color:#667eea;min-width:80px;font-size:11px;flex-shrink:0}.play-cards{display:flex;gap:3px;flex-wrap:wrap;flex:1;justify-content:flex-start}.play-card{width:25px;height:35px;font-size:8px;border-radius:4px}.play-card .card-rank{font-size:9px}.play-card .card-suit{font-size:10px}.play-action{font-size:10px;color:#666;font-style:italic;flex-shrink:0;min-width:60px;text-align:right}@media (max-width: 768px){.recent-plays{min-width:100%;max-width:100%}.play-row{flex-wrap:wrap}.play-player{width:100%;margin-bottom:4px}.play-action{width:100%;text-align:left}}body.game-page{background:#1e1e1e!important;overflow-y:hidden}.game-container{max-width:100%;margin:0 auto;display:flex;flex-direction:column;gap:6px;flex:1;overflow:hidden;padding:6px 8px;min-height:100vh;max-height:100vh;background:#1e1e1e}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff;text-align:center}.loading-screen h2{margin-bottom:16px;font-size:24px}.game-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;position:relative;z-index:100;flex-shrink:0}.game-logo{font-size:24px;font-weight:700;color:#fff;letter-spacing:2px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.help-controls{display:flex;gap:8px;align-items:center;justify-content:flex-end}.btn-mute-sound,.btn-how-to-play{padding:8px 16px;font-size:13px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;font-weight:700;transition:all .3s ease;white-space:nowrap}.btn-mute-sound:hover,.btn-how-to-play:hover{background:#ffffff4d;border-color:#ffffff80;transform:scale(1.05)}.btn-mute-sound{min-width:44px;padding:8px 12px}.game-status-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#0e3b00f2;border-radius:6px;flex-shrink:0}.game-status-bar .round-info{font-size:16px;font-weight:700;color:#fff}.game-status-bar .turn-info{font-size:16px;font-weight:700;color:#ffd93d}.game-status-bar .turn-info.your-turn{color:#ffd93d}.game-status-bar .turn-info.opponent-turn{color:#fff}.opponents-area{display:flex;flex-direction:row;justify-content:space-between;gap:6px;flex-wrap:nowrap;flex-shrink:0;overflow-x:auto;overflow-y:hidden;padding-bottom:2px;-webkit-overflow-scrolling:touch}.opponent-player{background:#fffffff2;border-radius:10px;padding:8px 10px;min-width:90px;flex:1;flex-shrink:0;box-shadow:0 2px 6px #00000026;transition:all .3s ease;border:1px solid rgba(0,0,0,.1)}.opponent-player.current-turn{background:#ffff00f2;box-shadow:0 0 20px #ffff0080;transform:scale(1.05)}.player-header{display:flex;align-items:flex-start;gap:8px;margin-bottom:6px}.opponent-player .player-header{margin-bottom:4px}.player-avatar{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;box-shadow:0 2px 4px #0003;border:1px solid rgba(255,255,255,.8)}.player-info{display:flex;flex-direction:column;gap:2px;flex:1;font-size:11px;min-width:0}.opponent-player .player-info{gap:2px;font-size:10px;min-width:0;overflow:hidden}.opponent-player .opponent-name-row{display:flex;flex-wrap:nowrap;align-items:center;gap:6px}.opponent-player .opponent-name-row .player-name{flex:1 1 auto;min-width:30px;overflow:hidden;text-overflow:ellipsis}.player-name-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:4px}.player-name{font-weight:700;font-size:14px;color:#212121;letter-spacing:-.5px;flex:1 1 auto;min-width:0}.opponent-player .player-name{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 0;min-width:20px}.player-rank{font-size:12px;color:#666;white-space:nowrap}.rank-value{font-weight:700;color:#2196f3;font-size:14px}.player-stats{display:flex;gap:2px;flex-wrap:wrap;font-size:12px;color:#666;margin-top:0}.player-stats span{white-space:nowrap}.score-value,.cards-value{font-weight:600;color:#212121}.player-declared{display:inline-block;font-weight:700;font-size:10px;color:#d32f2f;background:#ffeb3b4d;padding:2px 6px;border-radius:4px;border:1px solid #d32f2f;margin-top:2px;text-align:center;animation:pulse-declare 2s ease-in-out infinite;white-space:nowrap;overflow:hidden;max-width:100%;flex-shrink:0}.opponent-hand{display:flex;gap:0;flex-wrap:nowrap;justify-content:center;align-items:center;position:relative;height:52px;padding:2px 0}.opponent-hand .card{position:relative;margin-left:-20px;pointer-events:none}.opponent-hand .card:first-child{margin-left:0}.game-board{background:#0e3b00f2;border:6px solid #592c00;border-radius:8px;padding:16px 14px;min-height:200px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:12px;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.pile{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-width:80px;flex:1;max-width:140px;overflow:hidden}.pile.discard-pile{max-width:180px}.pile-label{font-weight:700;margin-bottom:8px;font-size:14px;text-transform:uppercase;letter-spacing:.5px;color:#fc0;width:100%;text-align:center}.pile-count{margin-top:8px;font-size:12px;color:#fff;font-weight:500;text-align:center}.discard-pile-container{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%;overflow:hidden}.discard-history{display:flex;gap:4px;flex-wrap:nowrap;justify-content:center;align-items:center;width:100%;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.discard-history::-webkit-scrollbar{display:none}.discard-history .card,.discard-history .discard-history-card{width:35px;height:52px;flex-shrink:0}.discard-history .card-rank{font-size:10px}.discard-history .card-suit{font-size:14px}.card.top-card{border:2px solid #ffa94d;box-shadow:0 8px 16px #ffa94d80;animation:pulse-top 1s ease-in-out infinite}@keyframes pulse-top{0%,to{box-shadow:0 8px 16px #ffa94d80}50%{box-shadow:0 8px 20px #ffa94dcc}}.human-player-area{background:#fffffff2;border-radius:8px;padding:8px 10px;box-shadow:0 2px 4px #0000001a;flex-shrink:0;min-height:0;overflow:hidden}.human-hand{display:flex;gap:4px;flex-wrap:wrap;justify-content:left;align-items:center;margin:4px 0;position:relative;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scrollbar-width:thin;min-height:80px}.human-hand::-webkit-scrollbar{height:4px}.human-hand::-webkit-scrollbar-thumb{background:#667eea4d;border-radius:2px}.human-hand .card{position:relative;margin:0;transition:transform .3s ease,z-index .3s ease;cursor:pointer;flex-shrink:0}.human-hand .card:hover{transform:translateY(-10px) scale(1.05);z-index:10}.human-hand .card.selected{transform:translateY(-15px) scale(1.1);z-index:15;border:2px solid #667eea}.first-time-hint{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:12px 16px;margin-bottom:12px;box-shadow:0 4px 6px #26262666;animation:slideIn .5s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.hint-content{display:flex;align-items:center;gap:12px;color:#fff}.hint-icon{font-size:24px;flex-shrink:0}.hint-text{flex:1;font-size:14px;font-weight:500}.hint-close{background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .3s ease;flex-shrink:0}.hint-close:hover{background:#ffffff4d}.action-buttons{display:flex;flex-direction:column;gap:6px;margin-top:8px;flex-shrink:0}.button-row{display:flex;width:100%;justify-content:center;gap:8px}.button-row button,.button-row .button-group button{flex:1;min-width:0}.button-group{display:flex;width:100%;gap:8px;justify-content:center}.button-group button{flex:1;min-width:0}.primary-buttons-row button,.hold-row button{width:100%;flex:1;min-width:0}.continue-row{display:flex;gap:8px}.continue-row button{flex:1;max-width:300px}button{padding:12px 20px;font-size:14px;font-weight:700;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;background:#667eea;color:#fff}.btn{padding:12px 20px;font-size:14px;font-weight:700;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease}.btn-primary{background:#667eea;color:#fff}.action-buttons .primary-buttons-row .btn-primary:first-child{background:#ffd93d;color:#333}.action-buttons .hold-row .btn-primary:first-child{background:#ff6b6b;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-secondary{background:#4facfe;color:#fff}.btn-secondary:hover:not(:disabled){background:#3d8bfe;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-warning{background:#51cf66;color:#fff}.btn-warning:hover:not(:disabled){background:#40c057;transform:translateY(-2px);box-shadow:0 4px 8px #0003}button:disabled,.btn:disabled{opacity:.4;background:#999!important;color:#666!important;cursor:not-allowed;transform:none!important;box-shadow:none!important;filter:grayscale(.5);pointer-events:none}button:disabled:hover,.btn:disabled:hover{background:#999!important;color:#666!important;transform:none!important;box-shadow:none!important}.btn-primary:disabled{background:#999!important;opacity:.4}.btn-secondary:disabled{background:#999!important;opacity:.4}.btn-warning:disabled{background:#999!important;opacity:.4}button:active:not(:disabled){transform:translateY(0)}@media (max-width: 768px){.game-container{padding:4px 6px}.opponents-area{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.opponent-player{min-width:100px;flex-shrink:0;padding:6px 8px}.opponent-player .player-avatar{width:28px;height:28px;font-size:16px}.opponent-player .player-name{font-size:14px}.opponent-hand{height:40px}.game-board{flex-wrap:wrap;padding:8px}.recent-plays{display:none}.action-buttons{display:grid;grid-template-columns:1fr 1fr;gap:6px}.btn-primary,.btn-warning{grid-column:span 2}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRow{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-declare{0%,to{box-shadow:0 0 #d32f2f66}50%{box-shadow:0 0 0 4px #d32f2f00}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes celebrate{0%,to{transform:scale(1)}25%{transform:scale(1.1) rotate(-5deg)}75%{transform:scale(1.1) rotate(5deg)}}.player-declared{animation:pulse-declare 2s ease-in-out infinite}.celebrating{animation:celebrate 1s ease-out}.game-footer{text-align:center;padding:6px 8px;color:#ffffffb3;font-size:11px;flex-shrink:0}.game-footer p,.game-footer span{margin:0}.game-id-display{color:#fff9;font-size:10px;font-family:Courier New,monospace}.footer-separator{color:#fff6;margin:0 4px}.public-rooms-container{min-height:100vh;padding:20px;background:linear-gradient(135deg,#06b6d4,#8b5cf6,#ec4899);background-attachment:fixed}.public-rooms-header{text-align:center;margin-bottom:30px;color:#fff}.public-rooms-header h1{font-size:2rem;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.public-rooms-header p{opacity:.95;font-size:1rem}.public-rooms-actions{display:flex;gap:15px;margin-bottom:30px;justify-content:center;flex-wrap:wrap}.btn-random-room{background:#ffd93d;color:#333;font-weight:600;padding:12px 24px;border:none;border-radius:10px;cursor:pointer;transition:all .2s}.btn-random-room:hover:not(:disabled){background:#ffc107;transform:translateY(-2px)}.btn-random-room:disabled{opacity:.6;cursor:not-allowed}.btn-back{background:#fff3;color:#fff;border:2px solid white;padding:12px 24px;border-radius:10px;cursor:pointer;transition:all .2s}.btn-back:hover{background:#ffffff4d}.btn-refresh{background:#fff3;color:#fff;border:2px solid white;padding:12px 24px;border-radius:10px;cursor:pointer;transition:all .2s}.btn-refresh:hover{background:#ffffff4d}.rooms-list{max-width:800px;margin:0 auto}.rooms-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;color:#fff}.rooms-list-header h2{font-size:1.5rem}.rooms-count{font-size:1rem;opacity:.9}.rooms-container{display:flex;flex-direction:column;gap:15px}.room-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 8px #0000001a;transition:transform .2s,box-shadow .2s;cursor:pointer}.room-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.room-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.room-code{font-family:Courier New,monospace;font-size:1.25rem;font-weight:700;letter-spacing:2px;color:#667eea}.room-players{color:#666;font-size:.9rem}.room-info{display:flex;gap:20px;color:#666;font-size:.9rem;margin-bottom:15px}.room-info-item{display:flex;align-items:center;gap:5px}.join-room-btn{margin-top:5px;width:100%;padding:12px;background:var(--primary-gradient);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.join-room-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.no-rooms{text-align:center;padding:60px 20px;color:#fff;background:#ffffff1a;border-radius:12px}.no-rooms h3{margin-bottom:10px;font-size:1.25rem}.no-rooms p{margin-bottom:20px;opacity:.9}.no-rooms.error{background:#f4433633;border:2px solid rgba(244,67,54,.5)}.loading{text-align:center;padding:40px;color:#fff;font-size:1.1rem}.public-rooms-container .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.public-rooms-container .modal-content{background:#fff;border-radius:15px;padding:30px;max-width:500px;width:90%;box-shadow:0 8px 32px #0000004d}.public-rooms-container .modal-content h2{color:#667eea;margin-bottom:20px}.public-rooms-container .input-group{margin:15px 0}.public-rooms-container .input-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.public-rooms-container .input-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem}.public-rooms-container .modal-actions{display:flex;gap:10px;margin-top:20px}.connection-warning{margin-top:15px;color:#f44336;font-size:.9rem}*{margin:0;padding:0;box-sizing:border-box}:root{--font-primary: "Alan Sans", -apple-system, BlinkMacSystemFont, sans-serif;--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--vibrant-gradient: linear-gradient(135deg, #06b6d4 0%, #8b5cf6 50%, #ec4899 100%);--dark-bg: #0a0e27;--card-bg: rgba(255, 255, 255, .98);--text-primary: #1e1b4b;--text-secondary: #4f46e5;--success-color: #10b981;--error-color: #ef4444;--accent-coral: #f97316;--accent-cyan: #06b6d4;--accent-violet: #8b5cf6}body{font-family:var(--font-primary);background:var(--vibrant-gradient);background-attachment:fixed;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}
