*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;animation:gradientFlow 15s ease infinite;background:linear-gradient(-45deg,#1a1a2e,#16213e,#0f3460,#1a1a2e);background-size:400% 400%;font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}@keyframes gradientFlow{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1,h2,h3,h4,h5,h6{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:600}.App{text-align:center}.App-header{align-items:center;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh;padding:20px}.App-header h1{-webkit-text-fill-color:#0000;animation:titleFloat 3s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:3.5rem;margin-bottom:30px;text-shadow:0 4px 20px #667eea4d}@keyframes titleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.glass-panel{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 32px 0 #1f26875e}.glass-panel,input{background:#ffffff0d}input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid #ffffff1a;border-radius:12px;color:#fff;font-family:Poppins,sans-serif;font-size:16px;margin-right:10px;padding:14px 20px;transition:all .3s ease}input::placeholder{color:#ffffff80}input:focus{background:#ffffff1a;border-color:#667eea;box-shadow:0 0 20px #667eea4d;outline:none}button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;font-family:Poppins,sans-serif;font-size:16px;font-weight:600;overflow:hidden;padding:14px 28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}button:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}button:hover:before{left:100%}button:hover{box-shadow:0 6px 25px #667eea99;transform:translateY(-2px)}button:active{transform:translateY(0)}button:disabled{background:#64646480;box-shadow:none;cursor:not-allowed;transform:none}button:disabled:before{display:none}select{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:2px solid #ffffff1a;border-radius:12px;color:#fff;cursor:pointer;font-family:Poppins,sans-serif;font-size:16px;padding:14px 20px;transition:all .3s ease}select:focus{background:#ffffff1a;border-color:#667eea;outline:none}select option{background:#1a1a2e;color:#fff}hr{background:linear-gradient(90deg,#0000,#fff3,#0000);border:none;height:1px;margin:30px 0;width:80%}ul{list-style:none;padding:0}.lobby{margin:0 auto;max-width:700px;padding:40px 20px;position:relative}.social-links{display:flex;gap:12px;left:20px;position:fixed;top:20px;z-index:1000}.social-btn{align-items:center;border:none;border-radius:50%;box-shadow:0 4px 15px #0000004d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:50px;justify-content:center;text-decoration:none;transition:all .3s ease;width:50px}.social-btn.linkedin{background:linear-gradient(135deg,#0077b5,#005582)}.social-btn.github{background:linear-gradient(135deg,#333,#1a1a1a)}.social-btn:hover{box-shadow:0 6px 20px #0006;transform:translateY(-3px)}.social-btn.linkedin:hover{box-shadow:0 6px 20px #0077b599}.social-btn.github:hover{box-shadow:0 6px 20px #3339}.social-icon{color:#fff;height:24px;width:24px}.help-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 4px 15px #667eea80;color:#fff;cursor:pointer;display:flex;font-size:28px;font-weight:700;height:50px;justify-content:center;position:fixed;right:20px;top:20px;transition:all .3s ease;width:50px;z-index:1000}.help-button:hover{box-shadow:0 6px 20px #667eeab3;transform:scale(1.1)}.rules-modal-overlay{align-items:center;animation:fadeIn .3s ease-out;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.rules-modal{animation:slideUp .4s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1a1a2ef2;border:1px solid #ffffff1a;border-radius:24px;box-shadow:0 8px 32px #00000080;max-height:80vh;max-width:700px;overflow-y:auto;padding:40px;position:relative;width:100%}.rules-modal::-webkit-scrollbar{width:8px}.rules-modal::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.rules-modal::-webkit-scrollbar-thumb{background:#667eea80;border-radius:10px}.rules-modal::-webkit-scrollbar-thumb:hover{background:#667eeab3}.close-modal{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:28px;height:40px;justify-content:center;position:absolute;right:15px;top:15px;transition:all .3s ease;width:40px}.close-modal:hover{background:#fff3;transform:rotate(90deg)}.rules-modal h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;margin-bottom:30px;text-align:center}.rules-content{color:#fff}.rules-content section{margin-bottom:25px}.rules-content h3{color:#667eea;font-size:1.4rem;margin-bottom:12px}.rules-content p{color:#ffffffe6;line-height:1.6;margin-bottom:10px}.rules-content ol,.rules-content ul{color:#ffffffd9;line-height:1.8;margin-left:20px}.rules-content li{margin-bottom:8px}.rules-content strong{color:#667eea;font-weight:600}.lobby hr{background:linear-gradient(90deg,#0000,#fff3,#0000);border:none;height:1px;margin:40px 0}.lobby h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2rem;margin-bottom:30px;text-align:center}.lobby>p{color:#ffffffb3;font-size:1.1rem;margin:20px 0;text-align:center}.connection-status{animation:statusPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:16px;box-shadow:0 8px 20px #f093fb66;color:#fff;font-weight:500;margin-bottom:25px;padding:16px 24px}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.8}}.error-message{align-items:center;animation:errorShake .5s ease-in-out;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);border-radius:16px;box-shadow:0 8px 20px #ff6b6b66;color:#fff;display:flex;justify-content:space-between;margin-bottom:25px;padding:18px 24px}@keyframes errorShake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.error-message button{background:#fff3;border:2px solid #fff;font-size:14px;padding:8px 16px}.player-setup{align-items:center;background:#ffffff08;border:1px solid #ffffff14;border-radius:20px;display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:30px;padding:30px}.player-setup input{min-width:200px}.rounds-selector{align-items:center;display:flex;gap:10px}.rounds-selector label{color:#ffffffe6;font-size:15px;font-weight:500}.rounds-selector select{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:2px solid #ffffff1a;border-radius:12px;color:#fff;cursor:pointer;font-family:Poppins,sans-serif;font-size:15px;min-width:120px;padding:12px 16px;transition:all .3s ease}.rounds-selector select:focus{background:#ffffff1a;border-color:#667eea;box-shadow:0 0 20px #667eea4d;outline:none}.rounds-selector select option{background:#1a1a2e;color:#fff}.games-list{list-style:none;margin:0 auto;max-width:600px;padding:0}.game-item{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;display:flex;justify-content:space-between;margin:20px 0;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.game-item:hover{background:#ffffff14;border-color:#667eea80;box-shadow:0 12px 30px #0000004d;transform:translateY(-4px)}.game-info{align-items:flex-start;display:flex;flex-direction:column;gap:8px}.game-info strong{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:18px}.game-info span{font-size:14px;opacity:.8}.rounds-info{background:#667eea33;border-radius:20px;color:#667eea;font-weight:600;padding:4px 12px}.waiting-room{margin:0 auto;max-width:600px;text-align:center}.waiting-room h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin-bottom:20px}.players-list{margin:25px 0}.players-list ul{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;padding:24px}.players-list li{border-bottom:1px solid #ffffff1a;display:block;font-size:16px;padding:12px 0;transition:all .3s ease;width:auto}.players-list li:last-child{border-bottom:none}.players-list li:hover{color:#667eea;transform:translateX(5px)}.current-player{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-weight:700}.start-game-btn{background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 8px 25px #4caf5066;font-size:18px;margin-top:25px;padding:18px 36px}.start-game-btn:hover{box-shadow:0 12px 35px #4caf5099}.game-finished{padding:50px;text-align:center}.game-finished h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4caf50,#45a049);-webkit-background-clip:text;background-clip:text;margin-bottom:20px}.card{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 15px #0003;color:#333;cursor:default;height:100px;padding:4px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;width:70px}.card-rank{font-size:16px;font-weight:700;line-height:1;top:4px}.card-rank,.card-suit{left:6px;position:absolute}.card-suit{font-size:12px;top:20px}.card:after{bottom:4px;content:attr(data-rank);font-size:16px;font-weight:700}.card:after,.card:before{line-height:1;position:absolute;right:6px;transform:rotate(180deg)}.card:before{bottom:20px;content:attr(data-suit);font-size:12px}.card .suit-symbol{font-size:32px;left:50%;opacity:.15;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%)}.card.diamonds .card-rank,.card.diamonds .card-suit,.card.diamonds:after,.card.diamonds:before,.card.hearts .card-rank,.card.hearts .card-suit,.card.hearts:after,.card.hearts:before{color:#e74c3c}.card.clubs .card-rank,.card.clubs .card-suit,.card.clubs:after,.card.clubs:before,.card.spades .card-rank,.card.spades .card-suit,.card.spades:after,.card.spades:before{color:#2c3e50}.card.diamonds .suit-symbol,.card.hearts .suit-symbol{color:#e74c3c}.card.clubs .suit-symbol,.card.spades .suit-symbol{color:#2c3e50}.mini-card.diamonds .suit-symbol,.mini-card.hearts .suit-symbol{color:#e74c3c}.mini-card.clubs .suit-symbol,.mini-card.spades .suit-symbol{color:#2c3e50}.card.selectable{border:2px solid #667eea;cursor:pointer}.card.selectable:hover{border-color:#667eea;box-shadow:0 12px 35px #667eea80;transform:translateY(-12px) scale(1.08);z-index:10}.card.selected{animation:selectedGlow 2s infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 16px 45px #667eeab3;color:#fff;transform:scale(1.05)}.card.selected .card-rank,.card.selected .card-suit{color:#fff}@keyframes selectedGlow{0%,to{box-shadow:0 16px 45px #667eeab3}50%{box-shadow:0 16px 45px #667eeae6,0 0 30px #667eea80}}.card.disabled{cursor:not-allowed;filter:grayscale(70%);opacity:.5}.unrevealed{background:linear-gradient(135deg,#434343,#000);border-color:#555;box-shadow:0 4px 15px #0006;color:#888;cursor:not-allowed}.unrevealed:before{content:"🎴";font-size:32px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.card-container{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:15px;padding:10px}.game-room{margin:0 auto;max-width:1400px;padding:25px}.game-header{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 32px #0003;display:flex;justify-content:space-between;margin-bottom:25px;padding:25px}.game-info h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin:0 0 10px}.game-meta{color:#fffc;display:flex;font-size:14px;font-weight:500;gap:18px}.turn-indicator{text-align:right}.my-turn-indicator{animation:turnPulse 2s infinite;background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 8px 25px #4caf5080;font-weight:700}.my-turn-indicator,.other-turn-indicator{align-items:center;border-radius:30px;color:#fff;display:flex;flex-direction:column;min-width:160px;padding:16px 24px}.other-turn-indicator{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#64646480;border:1px solid #ffffff1a}.turn-icon{font-size:22px;margin-bottom:6px}.turn-text{font-size:16px;font-weight:700;margin-bottom:4px}.turn-action{font-size:12px;font-weight:400;opacity:.9}@keyframes turnPulse{0%,to{box-shadow:0 8px 25px #4caf5080;transform:scale(1)}50%{box-shadow:0 12px 35px #4caf50b3;transform:scale(1.05)}}.plate-section{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 32px #0003;margin-bottom:35px;padding:30px;text-align:center}.plate-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:25px}.plate-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin:0}.plate-info{display:flex;font-size:14px;font-weight:600;gap:18px}.card-count{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea4d}.card-count,.top-card-info{border-radius:20px;color:#fff;padding:6px 16px}.top-card-info{background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 4px 15px #4caf504d}.plate-container{background:linear-gradient(135deg,#00640033,#0050004d);border:3px dashed #fff3;border-radius:20px;justify-content:center;min-height:160px;padding:20px;position:relative}.empty-plate,.plate-container{align-items:center;display:flex}.empty-plate{flex-direction:column;gap:10px}.empty-plate-text{font-size:24px;font-weight:700}.empty-plate-hint{font-size:14px;opacity:.7}.plate-cards{flex-wrap:wrap;gap:10px}.plate-card{transition:transform .3s ease}.plate-card.top-card{border:2px solid #667eea;box-shadow:0 0 25px #667eeab3;transform:scale(1.05)}.game-controls{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 32px #0003;margin-bottom:35px;padding:25px;text-align:center}.selection-info{background:linear-gradient(135deg,#667eea33,#764ba233);border:1px solid #667eea4d;border-radius:30px;gap:18px;justify-content:center;margin-bottom:20px;padding:14px 24px}.clear-selection{background:#0000;border:2px solid #667eea80;border-radius:20px;color:#667eea;font-size:14px;padding:6px 18px}.clear-selection:hover{background:#667eea33;border-color:#667eea}.action-buttons{display:flex;gap:20px;justify-content:center;margin-bottom:18px}.play-button{background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:12px;box-shadow:0 6px 20px #4caf5066;color:#fff;cursor:pointer;font-size:17px;font-weight:700;padding:16px 32px}.play-button:hover{box-shadow:0 8px 30px #4caf5099}.play-button:disabled{background:#64646480;box-shadow:none;cursor:not-allowed}.take-plate-button{background:linear-gradient(135deg,#ff9800,#f57c00);border:none;border-radius:12px;box-shadow:0 6px 20px #ff980066;color:#fff;cursor:pointer;font-size:17px;font-weight:700;padding:16px 32px}.take-plate-button:hover{box-shadow:0 8px 30px #ff980099}.take-plate-button:disabled{background:#64646480;box-shadow:none;cursor:not-allowed}.play-validation-error{background:#ff6b6b33;border:1px solid #ff6b6b4d;border-radius:12px;color:#ff6b6b;font-size:14px;font-weight:500;padding:12px 18px}.turn-waiting{color:#ffffffb3;font-style:italic;padding:12px}.player-hands{margin-bottom:35px}.hand-section{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 8px 32px #0003;margin-bottom:25px;padding:20px}.hand-section h4{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin-bottom:15px}.opponents-section{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 32px #0003;margin-bottom:35px;padding:30px}.opponents-section h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin:0 0 25px;text-align:center}.opponents-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.opponent-info{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;padding:24px;transition:all .3s ease}.opponent-info:hover{background:#ffffff14;box-shadow:0 12px 30px #0000004d;transform:translateY(-4px)}.opponent-info.current-opponent{animation:opponentPulse 2s infinite;background:#4caf501a;border-color:#4caf50;box-shadow:0 0 20px #4caf504d}@keyframes opponentPulse{0%,to{box-shadow:0 0 20px #4caf504d}50%{box-shadow:0 0 30px #4caf5080}}.opponent-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:18px;padding-bottom:12px}.opponent-name{-webkit-text-fill-color:#0000;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;display:flex;font-size:18px;font-weight:700;gap:10px}.current-turn-badge{animation:badgePulse 1.5s infinite;background:linear-gradient(135deg,#4caf50,#45a049);border-radius:12px;color:#fff;font-size:14px;padding:4px 10px}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.opponent-total{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 4px 15px #667eea4d;color:#fff;font-weight:700;padding:6px 16px}.opponent-hand-breakdown{display:flex;gap:12px;justify-content:space-between;margin-bottom:18px}.hand-stat{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff0d;border-radius:12px;flex:1 1;padding:14px;text-align:center}.hand-label{color:#ffffffb3;font-size:12px;letter-spacing:1px;margin-bottom:6px;text-transform:uppercase}.hand-count{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:700}.opponent-revealed-cards{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff0d;border-radius:12px;padding:14px}.revealed-label{color:#ffffffb3;font-size:12px;font-weight:600;letter-spacing:1px;margin-bottom:12px;text-transform:uppercase}.revealed-cards{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.mini-card{background:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 8px #00000026;color:#333;height:60px;padding:3px;position:relative;width:45px}.mini-card-rank{font-size:12px;font-weight:700;left:4px;line-height:1;position:absolute;top:3px}.mini-card-suit{font-size:9px;left:4px;position:absolute;top:15px}.mini-card:after{bottom:3px;content:attr(data-rank);font-size:12px;font-weight:700}.mini-card:after,.mini-card:before{line-height:1;position:absolute;right:4px;transform:rotate(180deg)}.mini-card:before{bottom:15px;content:attr(data-suit);font-size:9px}.mini-card .suit-symbol{font-size:20px;left:50%;opacity:.15;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%)}.mini-card.diamonds .mini-card-rank,.mini-card.diamonds .mini-card-suit,.mini-card.diamonds:after,.mini-card.diamonds:before,.mini-card.hearts .mini-card-rank,.mini-card.hearts .mini-card-suit,.mini-card.hearts:after,.mini-card.hearts:before{color:#e74c3c}.mini-card.clubs .mini-card-rank,.mini-card.clubs .mini-card-suit,.mini-card.clubs:after,.mini-card.clubs:before,.mini-card.spades .mini-card-rank,.mini-card.spades .mini-card-suit,.mini-card.spades:after,.mini-card.spades:before{color:#2c3e50}.game-history{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 32px #0003;margin-top:25px;max-height:250px;overflow-y:auto;padding:25px}.game-history::-webkit-scrollbar{width:8px}.game-history::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.game-history::-webkit-scrollbar-thumb{background:#667eea80;border-radius:10px}.game-history::-webkit-scrollbar-thumb:hover{background:#667eeab3}.history-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:18px;padding-bottom:12px}.history-header h4{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:18px;margin:0}.history-count{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 15px #667eea4d;color:#fff;font-size:12px;font-weight:700;padding:4px 12px}.history-list{gap:12px}.history-item{align-items:center;animation:historySlideIn .4s ease-out;border-left:3px solid #0000;border-radius:12px;font-size:14px;justify-content:space-between;padding:14px 18px;transition:all .2s ease}@keyframes historySlideIn{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.history-content{display:flex;flex-direction:column;gap:4px}.history-message{font-weight:500;line-height:1.5}.history-time{opacity:.7}.history-icon{opacity:.8}.history-item.info{border-left-color:#667eea;color:#667eea}.history-item.action{border-left-color:#4caf50;color:#4caf50}.history-item.special{animation:historySlideIn .4s ease-out,specialShine 2s infinite;border-left-color:#ff9800;color:#ff9800}@keyframes specialShine{0%,to{box-shadow:0 0 5px #ff98004d}50%{box-shadow:0 0 20px #ff980099}}.history-item.warning{border-left-color:#ff6b6b;color:#ff6b6b}.game-error{animation:errorAppear .4s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#ff6b6be6,#ee5a6fe6);border:1px solid #ff6b6b80;border-radius:16px;box-shadow:0 8px 25px #ff6b6b66;color:#fff;margin-bottom:25px;padding:24px}@keyframes errorAppear{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.error-content{align-items:flex-start;display:flex;gap:18px}.error-icon{flex-shrink:0;font-size:26px}.error-details{flex:1 1}.error-actions{display:flex;gap:12px;margin-top:12px}.error-action-btn{background:#fff3;border:2px solid #ffffff80;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .3s ease}.error-action-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.loading-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-content{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;padding:40px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #667eea33;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto 20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{color:#fff;font-size:18px;font-weight:500}@media (max-width:768px){.App-header h1{font-size:2.5rem}.game-header{flex-direction:column;gap:20px}.game-meta{justify-content:center}.turn-indicator{text-align:center}.my-turn-indicator,.other-turn-indicator{min-width:140px}.card{height:85px;width:60px}.card-rank{font-size:18px}.card-suit{font-size:12px}.opponents-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.play-button,.take-plate-button{width:100%}}@media (max-width:480px){.App-header h1{font-size:2rem}.card{height:75px;width:50px}.card-rank{font-size:16px}.game-room{padding:15px}}.game-room-table{animation:gradientFlow 15s ease infinite;background:linear-gradient(-45deg,#1a1a2e,#16213e,#0f3460,#1a1a2e);background-size:400% 400%;height:100vh;overflow:hidden;position:relative;width:100vw}.compact-game-info{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;justify-content:space-between;left:20px;padding:12px 20px;position:absolute;right:20px;top:20px;z-index:100}.compact-game-info,.info-left{align-items:center;display:flex}.info-left{gap:12px}.game-id{color:#fff;font-size:14px;font-weight:600}.final-turns-badge,.rounds-badge{background:#667eea4d;border-radius:12px;color:#667eea;font-size:12px;font-weight:600;padding:4px 10px}.final-turns-badge{background:#ff98004d;color:#ff9800}.info-right .turn-badge{border-radius:20px;font-size:13px;font-weight:600;padding:6px 16px}.turn-badge.my-turn{animation:turnPulse 2s infinite;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.turn-badge.waiting{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#64646480;color:#fffc}.game-error.compact{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ff6b6be6;border-radius:12px;color:#fff;display:flex;font-size:14px;gap:12px;left:20px;padding:12px 20px;position:absolute;right:20px;top:80px;z-index:100}.game-error.compact .error-btn{background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;margin-left:auto;padding:6px 14px}.reconnection-indicator.compact{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ff9800e6;border-radius:12px;color:#fff;font-size:14px;gap:12px;left:20px;padding:12px 20px;right:20px;top:80px;z-index:100}.reconnection-indicator.compact,.table-container{align-items:center;display:flex;position:absolute}.table-container{gap:40px;height:55vh;justify-content:center;left:50%;max-height:600px;max-width:1400px;top:45%;transform:translate(-50%,-50%);width:90vw}.opponents-list{bottom:10px;display:flex;flex-direction:column;gap:12px;left:20px;overflow-y:auto;padding:10px;position:fixed;top:20px;width:200px;z-index:10}.opponents-list::-webkit-scrollbar{width:6px}.opponents-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.opponents-list::-webkit-scrollbar-thumb{background:#667eea80;border-radius:10px}.opponents-list::-webkit-scrollbar-thumb:hover{background:#667eeab3}.central-plate{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#0064004d,#00500066);border:3px solid #fff3;border-radius:50%;box-shadow:0 8px 32px #0000004d;display:flex;flex-shrink:0;height:280px;justify-content:center;width:280px}.empty-plate{color:#ffffff80;text-align:center}.plate-icon{font-size:48px;margin-bottom:8px}.plate-hint{font-size:14px;opacity:.8}.plate-cards{align-items:center;display:flex;height:200px;justify-content:center;position:relative;width:200px}.plate-cards .mini-card{left:50%;margin:-30px 0 0 -22.5px;position:absolute;top:50%;transition:all .3s ease}.plate-cards .mini-card.top-card{border:2px solid #667eea;box-shadow:0 0 30px #667eeacc;filter:brightness(1.1);z-index:100!important}.plate-count{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 15px #667eea80;color:#fff;font-size:15px;font-weight:700;height:36px;justify-content:center;position:absolute;right:-40px;top:-40px;width:36px}.opponent-card,.plate-count{align-items:center;display:flex}.opponent-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:2px solid #ffffff1a;border-radius:12px;flex-direction:column;gap:8px;min-width:180px;padding:12px 16px;text-align:center;transition:all .3s ease}.opponent-card.active{animation:opponentPulse 2s infinite;border-color:#4caf50;box-shadow:0 0 25px #4caf5080}.opponent-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 15px #667eea66;color:#fff;display:flex;font-size:18px;font-weight:700;height:40px;justify-content:center;width:40px}.opponent-name{color:#fff;font-size:13px;font-weight:600}.opponent-revealed-cards{flex-wrap:wrap;gap:4px;min-height:45px;width:100%}.opponent-mini-card,.opponent-revealed-cards{align-items:center;display:flex;justify-content:center}.opponent-mini-card{background:linear-gradient(135deg,#fff,#f5f5f5);border:1px solid #0003;border-radius:4px;box-shadow:0 2px 6px #0000004d;flex-direction:column;font-size:10px;font-weight:700;height:45px;margin:0 -4px;position:relative;transition:all .2s ease;width:32px}.opponent-mini-card:hover{margin:0 2px;transform:translateY(-3px);z-index:10}.opponent-mini-card.diamonds,.opponent-mini-card.hearts{color:#d32f2f}.opponent-mini-card.clubs,.opponent-mini-card.spades{color:#1a1a1a}.opponent-card-rank{font-size:12px}.opponent-card-suit{font-size:10px}.no-revealed-cards{color:#fff6;font-size:11px;font-style:italic}.opponent-hands-mini{color:#ffffffb3;display:flex;font-size:12px;gap:8px;justify-content:center}.opponent-hands-mini span{background:#ffffff1a;border-radius:8px;min-width:28px;padding:4px 8px;text-align:center}.player-area{bottom:10px;left:50%;max-width:90vw;padding:10px 20px;position:absolute;transform:translateX(-50%);width:auto}.action-bar{justify-content:center}.action-bar,.selection-info{align-items:center;display:flex;gap:8px}.selection-info{background:#667eea4d;border-radius:16px;color:#fff;font-size:13px;font-weight:600;padding:6px 12px}.clear-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:20px;justify-content:center;transition:all .2s ease;width:20px}.clear-btn:hover{background:#ffffff4d;transform:scale(1.1)}.action-btn{border:none;border-radius:10px;cursor:pointer;font-size:13px;font-weight:600;padding:8px 18px;transition:all .3s ease}.play-btn{background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 2px 10px #4caf504d;color:#fff}.play-btn:hover:not(:disabled){box-shadow:0 4px 15px #4caf5080;transform:translateY(-1px)}.play-btn:disabled{background:#64646480;box-shadow:none;cursor:not-allowed}.take-btn{background:linear-gradient(135deg,#ff9800,#f57c00);box-shadow:0 2px 10px #ff98004d;color:#fff}.take-btn:hover:not(:disabled){box-shadow:0 4px 15px #ff980080;transform:translateY(-1px)}.take-btn:disabled{background:#64646480;box-shadow:none;cursor:not-allowed}.player-hand{flex-direction:column;gap:4px;margin-top:10px;padding:0 60px}.hand-row,.player-hand{align-items:center;display:flex}.hand-row{gap:8px;justify-content:center;position:relative}.hand-label{color:#fff9;font-size:11px;font-weight:600;left:-70px;position:absolute;text-align:right;width:60px}.hand-row .cards{display:flex;height:65px;padding:0 10px;position:relative}.hand-row .card{flex-shrink:0;height:60px;margin-left:-28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:45px}.hand-row .card:first-child{margin-left:0}.hand-row .card .card-rank{font-size:14px;left:4px;top:3px}.hand-row .card .card-suit{font-size:10px;left:4px;top:17px}.hand-row .card:after{bottom:3px;font-size:14px;right:4px}.hand-row .card:before{bottom:17px;font-size:10px;right:4px}.hand-row .card .suit-symbol{font-size:24px}.hand-row .card:hover{transform:translateY(-15px) scale(1.08);z-index:50!important}.hand-row .card.selected{transform:scale(1.05)}.hand-row .card.selectable:hover{transform:translateY(-15px) scale(1.08)}.card-back{font-size:20px}.history-sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000000e6;border-left:1px solid #ffffff1a;bottom:0;display:flex;flex-direction:column;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s ease;width:350px;z-index:200}.history-sidebar.open{transform:translateX(0)}.history-toggle{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000000e6;border:1px solid #ffffff1a;border-radius:8px 0 0 8px;border-right:none;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-size:14px;font-weight:600;gap:8px;left:-40px;padding:12px 8px;position:absolute;text-orientation:mixed;top:50%;transform:translateY(-50%);transition:all .3s ease;writing-mode:vertical-rl}.history-toggle:hover{background:#667eea4d}.history-toggle-text{writing-mode:vertical-rl}.history-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;font-size:11px;min-width:20px;padding:2px 6px;text-align:center}.history-content{flex:1 1;overflow-y:auto;padding:20px}.history-content .history-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:12px}.history-content h4{color:#fff;font-size:16px;margin:0}.history-content .history-count{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:12px;font-weight:700;padding:4px 10px}.history-list{display:flex;flex-direction:column;gap:10px}.history-item{animation:historySlideIn .3s ease-out;border-radius:10px;display:flex;gap:12px;padding:12px}.history-item.info{background:#667eea26}.history-item.action{background:#4caf5026}.history-item.special{background:#ff980026}.history-item.warning{background:#ff6b6b26}.history-icon{flex-shrink:0;font-size:18px}.history-text{flex:1 1}.history-message{color:#fff;font-size:13px;line-height:1.4;margin-bottom:4px}.history-time{color:#ffffff80;font-size:11px}@media (max-width:768px){.compact-game-info{flex-direction:column;gap:8px;padding:10px}.table-container{flex-direction:column;gap:20px;height:50vh;width:95vw}.opponents-list{bottom:auto;flex-direction:row;left:10px;overflow-x:auto;overflow-y:hidden;padding:5px;position:fixed;top:80px;width:calc(100vw - 20px)}.opponent-card{min-width:150px}.central-plate{height:200px;width:200px}.plate-cards{height:160px;width:160px}.opponent-card{min-width:100px;padding:12px}.opponent-avatar{font-size:18px;height:40px;width:40px}.opponent-mini-card{height:38px;margin:0 -6px;width:28px}.opponent-card-rank{font-size:10px}.opponent-card-suit{font-size:8px}.hand-row .card{height:55px;margin-left:-25px;width:40px}.hand-row .card:first-child{margin-left:0}.hand-row .card .card-rank{font-size:12px;top:2px}.hand-row .card .card-suit{font-size:9px;top:14px}.hand-row .card:after{bottom:2px;font-size:12px}.hand-row .card:before{bottom:14px;font-size:9px}.hand-label{font-size:10px;left:-55px;width:50px}.action-btn{font-size:12px;padding:6px 14px}.history-sidebar{width:280px}.action-bar{flex-wrap:wrap}.player-area{bottom:5px;padding:8px 10px}.player-hand{padding:0 50px}}.round-transition-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000d9;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.round-transition-content{animation:slideUp .5s ease-out;background:linear-gradient(135deg,#667eea33,#764ba233);border:2px solid #fff3;border-radius:30px;max-width:600px;padding:60px 80px;text-align:center}.transition-icon{animation:iconPulse 2s ease-in-out infinite;font-size:5rem;margin-bottom:20px}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.transition-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:3rem;margin-bottom:15px}.transition-subtitle{color:#fffc;font-size:1.5rem;margin-bottom:20px}.first-player{color:#667eea;font-size:1.3rem;font-weight:600;margin-top:15px}.round-scores{display:flex;flex-direction:column;gap:12px;margin-top:30px;max-height:200px;overflow-y:auto}.score-item{align-items:center;background:#ffffff1a;border:1px solid #ffffff1a;border-radius:12px;display:flex;justify-content:space-between;padding:12px 20px}.score-name{color:#fff;font-size:1.2rem;font-weight:500}.score-value{color:#667eea;font-size:1.3rem;font-weight:700}.tournament-results{align-items:center;display:flex;justify-content:center;min-height:80vh;padding:20px}.results-container{animation:slideUp .6s ease-out;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;box-shadow:0 8px 32px 0 #1f26875e;max-width:600px;padding:50px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.results-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:3rem;margin-bottom:10px;text-align:center}.rounds-info{color:#ffffffb3;font-size:1.1rem}.rounds-info,.winner-section{margin-bottom:30px;text-align:center}.winner-section{border-bottom:1px solid #ffffff1a;padding:40px 0}.winner-trophy{animation:trophyBounce 1s ease-in-out infinite;font-size:5rem;margin-bottom:20px}@keyframes trophyBounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.05)}}.winner-name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,gold,#ffed4e);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;margin-bottom:10px}.winner-score{color:#fffc;font-size:1.3rem}.final-standings h4{color:#fff;font-size:1.5rem;margin-bottom:20px;text-align:center}.standings-list{display:flex;flex-direction:column;gap:12px}.standing-item{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;display:flex;padding:16px 20px;transition:all .3s ease}.standing-item:hover{background:#ffffff1a;transform:translateX(5px)}.standing-item.rank-1{background:linear-gradient(135deg,#ffd70033,#ffed4e1a);border:1px solid #ffd7004d}.standing-item.rank-2{background:linear-gradient(135deg,#c0c0c033,#c0c0c01a);border:1px solid #c0c0c04d}.standing-item.rank-3{background:linear-gradient(135deg,#cd7f3233,#cd7f321a);border:1px solid #cd7f324d}.rank{color:#fff9;font-size:1.2rem;font-weight:700;min-width:40px}.standing-item.rank-1 .rank{color:gold}.standing-item.rank-2 .rank{color:silver}.standing-item.rank-3 .rank{color:#cd7f32}.player-name{color:#fff;flex:1 1;font-size:1.2rem;font-weight:500;text-align:left}.player-score{color:#ffffffe6;font-size:1.3rem;font-weight:700;min-width:60px;text-align:right}.play-again-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:30px;padding:18px;transition:all .3s ease;width:100%}.play-again-btn:hover{box-shadow:0 8px 25px #667eea99;transform:translateY(-2px)}@media (max-width:768px){.results-container{padding:30px 20px}.results-title{font-size:2rem}.winner-trophy{font-size:3.5rem}.winner-name{font-size:1.8rem}.winner-score{font-size:1.1rem}.final-standings h4{font-size:1.2rem}.standing-item{padding:12px 16px}.rank{min-width:35px}.player-name,.rank{font-size:1rem}.player-score{font-size:1.1rem}.play-again-btn{font-size:1rem;padding:14px}.lobby{padding:20px 15px}.lobby h2{font-size:1.6rem}.social-links{gap:10px;left:15px;top:15px}.social-btn{height:45px;width:45px}.social-icon{height:20px;width:20px}.help-button{font-size:24px;height:45px;right:15px;top:15px;width:45px}.rules-modal{max-height:85vh;padding:30px 20px}.rules-modal h2{font-size:2rem}.rules-content h3{font-size:1.2rem}.player-setup{gap:10px;padding:20px 15px}.player-setup input{min-width:100%;width:100%}.rounds-selector{justify-content:center;width:100%}.rounds-selector select{flex:1 1}.player-setup button{width:100%}.game-item{flex-direction:column;gap:15px;padding:18px;text-align:center}.game-info{align-items:center}.game-item button{width:100%}.round-transition-content{margin:0 20px;padding:40px 30px}.transition-icon{font-size:3.5rem}.transition-title{font-size:2rem}.transition-subtitle{font-size:1.2rem}.first-player{font-size:1.1rem}.score-item{padding:10px 16px}.score-name{font-size:1rem}.score-value{font-size:1.1rem}}
/*# sourceMappingURL=main.eed82f13.css.map*/