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;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}body,html{height:100%}.App,body,html{overflow:hidden}.App{background:linear-gradient(135deg,#0a0a0acc,#1a1a1acc 50%,#0a0a0acc),url(/static/media/background.604b3ab17a4f408360a6.jpg);background-attachment:fixed;background-position:50%;background-size:cover;color:#fff;height:100vh;text-align:center}.App-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(145deg,#0f0f0ff2,#191919f2 50%,#0f0f0ff2);background-clip:padding-box;border-bottom:2px solid #0000;box-shadow:0 4px 16px #0009,0 0 0 1px #d4af374d,inset 0 1px 0 #ffffff1a;margin-bottom:0;overflow:hidden;padding:12px 10px;position:relative}.App-header:before{animation:headerBorderGlow 4s linear infinite;background:linear-gradient(45deg,#d4af37,#e6c547,#d4af37,#e6c547,#d4af37);bottom:0;content:"";left:0;position:absolute;right:0;top:-3px;z-index:-1}@keyframes headerBorderGlow{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.header-content{position:relative;text-align:center;z-index:2}.casino-brand{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:5px}.brand-symbols{display:flex;gap:8px}.symbol{animation:symbolFloat 3s ease-in-out infinite;color:#d4af37;font-size:1rem;text-shadow:0 0 8px #d4af3799}.symbol:first-child{animation-delay:0s}.symbol:nth-child(2){animation-delay:.5s}@keyframes symbolFloat{0%,to{opacity:.8;transform:translateY(0) rotate(0deg)}50%{opacity:1;transform:translateY(-8px) rotate(5deg)}}.app-title{animation:titleGlow 3s ease-in-out infinite;color:#ecdfcc;font-size:1.3rem;font-weight:900;letter-spacing:2px;margin:0;text-shadow:0 2px 4px #000c,0 0 10px #d4af3766}@keyframes titleGlow{0%,to{text-shadow:0 4px 8px #000c,0 0 20px #d4af3766}50%{text-shadow:0 4px 8px #000c,0 0 30px #d4af37b3,0 0 40px #d4af3780}}.header-subtitle{color:#ccc;font-size:.55rem;font-weight:500;letter-spacing:1px;opacity:.9;text-shadow:0 1px 2px #000c}.header-controls{position:absolute;right:20px;top:50%;transform:translateY(-50%);z-index:99999!important}.header-decoration{animation:decorationPulse 6s ease-in-out infinite alternate;background-image:radial-gradient(circle at 20% 20%,#d4af371a 0,#0000 50%),radial-gradient(circle at 80% 80%,#d4af371a 0,#0000 50%);bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}@keyframes decorationPulse{0%{opacity:.3}to{opacity:.7}}button{background:linear-gradient(135deg,#4a4a4a,#5a5a5a);border:1px solid #3a3a3a;border-radius:8px;box-shadow:0 4px 15px #0000004d,inset 0 1px 0 #ffffff1a;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}button:hover{background:linear-gradient(135deg,#5a5a5a,#6a6a6a);box-shadow:0 6px 20px #0006,inset 0 1px 0 #fff3;transform:translateY(-2px)}input{border:2px solid #ddd;border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .3s ease}input:focus{border-color:#212529;box-shadow:0 0 0 3px #2125291a;outline:none}@media (max-height:1000px) and (orientation:portrait){.App.in-game{height:100vw;left:50%;margin-left:-50vh;margin-top:-50vw;overflow:hidden;position:fixed;top:50%;transform:rotate(90deg);transform-origin:center center;width:100vh}.App.in-game .App-header{display:none}}.orientation-message{align-items:center;background:#000000e6;bottom:0;color:#fff;display:none;flex-direction:column;justify-content:center;left:0;padding:20px;position:fixed;right:0;text-align:center;top:0;z-index:9999}.orientation-message i{animation:rotate 2s linear infinite;color:#d4af37;font-size:4rem;margin-bottom:20px}.orientation-message h2{color:#d4af37;font-size:1.5rem;margin-bottom:10px}.orientation-message p{font-size:1rem;opacity:.8}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(90deg)}}@keyframes rotateBack{0%{transform:rotate(90deg)}to{transform:rotate(0deg)}}@media (max-height:1000px) and (orientation:portrait){.App.in-game .orientation-message{display:flex}}@media (max-height:500px) and (orientation:landscape){.App{-webkit-overflow-scrolling:touch;font-size:.75rem;height:100vh;overflow:hidden;padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.App-header,.marquee-container{display:none}button{min-width:36px}button,input{font-size:14px;min-height:36px;padding:8px 12px}*{touch-action:manipulation}@supports (-webkit-touch-callout:none){.App{-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}}}@media (max-width:480px){.App{font-size:.8rem}.App-header{align-items:center;display:flex;justify-content:space-between;min-height:auto;padding:12px 10px}.header-content{flex:1 1;margin-right:10px;min-width:0}.casino-brand{align-items:center;flex-direction:row;gap:6px;transform:scale(.75)}.brand-symbols{flex-wrap:nowrap;gap:3px;justify-content:center}.symbol{flex-shrink:0;font-size:.8rem}.app-title{font-size:1.2rem;letter-spacing:.8px}.header-subtitle{font-size:.65rem;letter-spacing:.4px}.header-controls{right:15px;transform:scale(.9)}button{min-width:44px}button,input{font-size:16px;min-height:44px;padding:12px 16px}*{touch-action:manipulation}.App{-webkit-overflow-scrolling:touch}@media (display-mode:standalone){.App{padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.App-header{padding-top:max(12px,env(safe-area-inset-top))}}@supports (-webkit-touch-callout:none){.App{-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;-webkit-overflow-scrolling:touch;-webkit-user-select:none;user-select:none}}}.error-banner{background:linear-gradient(135deg,#ff6b6b,#ee5a52);border-bottom:2px solid #e74c3c;box-shadow:0 4px 20px #ff6b6b4d;color:#fff;left:0;padding:16px;position:fixed;right:0;top:0;z-index:1000}.error-content{align-items:center;display:flex;gap:12px;justify-content:center;margin:0 auto;max-width:600px}.error-icon{flex-shrink:0;font-size:20px}.error-text{flex-grow:1;font-size:16px;font-weight:600}.error-close-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;padding:8px 12px;transition:all .2s ease}.error-close-btn:hover{background:#ffffff4d;box-shadow:0 2px 8px #0003;transform:none}.update-banner{background:linear-gradient(135deg,#4caf50,#45a049);border-bottom:2px solid #388e3c;box-shadow:0 4px 20px #4caf504d;color:#fff;left:0;padding:16px;position:fixed;right:0;top:0;z-index:1000}.update-content{align-items:center;display:flex;gap:12px;justify-content:center;margin:0 auto;max-width:600px}.update-icon{flex-shrink:0;font-size:20px}.update-text{flex-grow:1;font-size:16px;font-weight:600}.update-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease}.update-btn:hover{background:#ffffff4d;box-shadow:0 2px 8px #0003;transform:none}.update-close-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;padding:8px 12px;transition:all .2s ease}.update-close-btn:hover{background:#ffffff4d;box-shadow:0 2px 8px #0003;transform:none}.lobby{align-items:flex-start;background:#0000;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:40px 20px 20px;position:relative}.lobby-background{z-index:1}.casino-pattern,.lobby-background{bottom:0;left:0;position:absolute;right:0;top:0}.casino-pattern{animation:casinoGlow 8s ease-in-out infinite alternate;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(135deg,#0006,#0003 50%,#0006),radial-gradient(circle at 20% 20%,#d4af371a 0,#0000 50%),radial-gradient(circle at 80% 80%,#d4af371a 0,#0000 50%),radial-gradient(circle at 40% 60%,#d4af370d 0,#0000 50%)}@keyframes casinoGlow{0%{opacity:.3}to{opacity:.7}}.lobby-container{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:linear-gradient(145deg,#141414d9,#1e1e1ed9 50%,#141414d9);background-clip:padding-box;border:2px solid #0000;border-radius:20px;box-shadow:0 20px 60px #000c,0 0 0 1px #ffd7004d,inset 0 1px 0 #ffffff1a;max-width:300px;padding:33px 27px;position:relative;width:100%;z-index:2}.lobby-container:before{animation:borderGlow 3s linear infinite;background:linear-gradient(45deg,#c6a631,#eedb8c,#c6a631,#eedb8c,#c6a631);border-radius:22px;bottom:-2px;content:"";left:-2px;position:absolute;right:-2px;top:-2px;z-index:-1}@keyframes borderGlow{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.lobby-header{margin-bottom:27px;text-align:center}.casino-logo{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:13px}.card-symbol{animation:symbolPulse 2s ease-in-out infinite;color:#d4af37;font-size:1.68rem;text-shadow:0 0 15px #d4af3799}.casino-title{animation:titleShimmer 3s ease-in-out infinite;color:#fff;font-size:1.47rem;font-weight:900;letter-spacing:3px;text-shadow:0 0 8px #d4af3799,0 0 15px #d4af3766,0 0 25px #d4af374d}@keyframes symbolPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes titleShimmer{0%,to{text-shadow:0 0 8px #d4af3799,0 0 15px #d4af3766,0 0 25px #d4af374d}50%{text-shadow:0 0 12px #d4af37cc,0 0 20px #d4af3799,0 0 30px #d4af3766}}.lobby-title{color:#fff;font-size:1.88rem;font-weight:700;letter-spacing:2px;margin:0 0 10px;text-shadow:0 4px 8px #000c}.lobby-subtitle{color:#fff;font-size:.74rem;margin:0;opacity:.9;text-shadow:0 2px 4px #000c}.join-form{display:flex;flex-direction:column;gap:17px}.form-divider{background:linear-gradient(90deg,#0000,#1616144d 20%,rgba(69,62,42,.927) 50%,#1615134d 80%,#0000);height:1px}.form-divider,.form-group,.input-container{position:relative}.input-container{align-items:center;display:flex}.casino-input{background:linear-gradient(145deg,#282828e6,#1e1e1ee6);border:2px solid #d4af3766;border-radius:12px;box-shadow:inset 0 2px 4px #0000004d,0 4px 8px #0003;color:#fff;font-size:.74rem;font-weight:500;padding:12px 50px 12px 13px;transition:all .3s ease;width:100%}.casino-input:focus{background:linear-gradient(145deg,#323232e6,#282828e6);border-color:#d4af37;box-shadow:inset 0 2px 4px #0000004d,0 0 0 3px #d4af3733,0 4px 8px #0003;outline:none}.join-btn{align-items:center;background:linear-gradient(145deg,#e98e27,#e6c547 50%,#e98e27);border:none;border-radius:8px;box-shadow:0 4px 8px #d4af3766,inset 0 1px 0 #ffffff4d;color:#1a1a1a;cursor:pointer;display:flex;font-size:.8rem;font-weight:700;gap:4px;height:32px;justify-content:center;letter-spacing:1px;min-width:40px;overflow:hidden;padding:8px 12px;position:absolute;right:6px;top:50%;transform:translateY(-50%);transition:all .3s ease}.join-btn:hover:before{left:100%}.join-btn:hover{background:linear-gradient(145deg,#f0a020,#f4d03f 50%,#f0a020);box-shadow:0 6px 12px #d4af3799,0 0 15px #d4af3766,inset 0 1px 0 #fff9;transform:translateY(-50%)}.join-btn:disabled{cursor:not-allowed}.btn-text{position:relative;z-index:1}.casino-footer{margin-top:27px;text-align:center}.card-symbols{display:flex;gap:13px;justify-content:center}.card-symbols span{animation:cardFloat 3s ease-in-out infinite;color:#d4af37;font-size:1.21rem;text-shadow:0 0 8px #d4af3780}.card-symbols span:first-child{animation-delay:0s}.card-symbols span:nth-child(2){animation-delay:.5s}.card-symbols span:nth-child(3){animation-delay:1s}.card-symbols span:nth-child(4){animation-delay:1.5s}@keyframes cardFloat{0%,to{opacity:.7;transform:translateY(0) rotate(0deg)}50%{opacity:1;transform:translateY(-10px) rotate(5deg)}}.random-match-section{margin-top:17px;text-align:center}.random-match-btn{align-items:center;background:linear-gradient(145deg,#e98e27,#e6c547 50%,#e98e27);border:none;border-radius:12px;box-shadow:0 6px 12px #d4af3766,inset 0 1px 0 #ffffff4d;color:#1a1a1a;cursor:pointer;display:flex;font-size:.8rem;font-weight:700;gap:8px;justify-content:center;letter-spacing:1px;overflow:hidden;padding:12px 20px;position:relative;transition:all .3s ease;width:100%}.random-match-btn:hover{background:linear-gradient(145deg,#f0a020,#f4d03f 50%,#f0a020);box-shadow:0 8px 16px #d4af3799,0 0 20px #d4af3766,inset 0 1px 0 #ffffff80;transform:translateY(-2px)}.random-match-btn:disabled{cursor:not-allowed;transform:none}.random-match-btn .btn-icon{font-size:1rem}.marquee-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#000000e6,#141414e6 50%,#000000e6);border-top:2px solid #d4af374d;bottom:0;height:54px;left:0;overflow:hidden;position:fixed;right:0;z-index:10}.marquee-track{animation:marqueeScroll 60s linear infinite;display:flex;height:100%;width:200%}.marquee-content{align-items:center;display:flex;flex-shrink:0;gap:27px;height:100%;justify-content:flex-start;padding:0 20px;width:50%}.marquee-text{color:#d4af37;font-family:Hiragino Sans,Yu Gothic,sans-serif;font-size:.8rem;font-weight:600;opacity:.8;text-shadow:0 0 8px #d4af3799;white-space:nowrap}@keyframes marqueeScroll{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@media (max-height:500px) and (orientation:landscape){.lobby{align-items:center;min-height:100vh;padding:10px 20px}.lobby-container{max-width:600px;padding:20px 25px;transform:scale(.8);width:100%}.lobby-header{margin-bottom:15px}.casino-logo{gap:6px;margin-bottom:8px}.card-symbol{font-size:1.2rem}.casino-title{font-size:1.1rem;letter-spacing:2px}.lobby-title{font-size:1.4rem;margin:0 0 6px}.lobby-subtitle{font-size:.6rem}.join-form{gap:12px}.casino-input{font-size:.7rem;padding:10px 12px}.join-btn{font-size:.7rem;gap:4px;height:28px;min-width:35px;padding:6px 10px}.btn-icon{font-size:.8rem}.random-match-section{margin-top:12px}.random-match-btn{font-size:.7rem;gap:6px;padding:10px 16px;width:100%}.random-match-btn .btn-icon{font-size:.9rem}.casino-footer{margin-top:15px}.card-symbols{gap:10px}.card-symbols span{font-size:1rem}.marquee-container{display:none}}.pwa-guide-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;padding:20px;position:fixed;right:0;top:0;z-index:10000}.pwa-guide-modal{animation:slideIn .3s ease-out;background:linear-gradient(145deg,#0f0f0ff2,#191919f2 50%,#0f0f0ff2);border:2px solid #d4af374d;border-radius:20px;box-shadow:0 20px 60px #00000080,0 0 0 1px #d4af3733,inset 0 1px 0 #ffffff1a;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.pwa-guide-header{border-bottom:1px solid #d4af3733;padding:30px 30px 20px;text-align:center}.pwa-guide-icon{animation:iconPulse 2s ease-in-out infinite;color:#d4af37;font-size:3rem;margin-bottom:15px}@keyframes iconPulse{0%,to{color:#d4af37;transform:scale(1)}50%{color:#f4d03f;transform:scale(1.1)}}.pwa-guide-title{color:#fff;font-size:1.5rem;font-weight:700;margin:0 0 8px;text-shadow:0 2px 4px #00000080}.pwa-guide-subtitle{color:#ccc;font-size:.9rem;margin:0;opacity:.8}.pwa-guide-content{padding:25px 30px}.pwa-install-section{margin-bottom:25px}.install-btn-container{background:#d4af371a;border:2px solid #d4af374d;border-radius:15px;padding:20px;text-align:center}.install-btn{align-items:center;background:linear-gradient(135deg,#d4af37,#f4d03f);border:none;border-radius:12px;box-shadow:0 4px 15px #d4af374d;color:#1a1a1a;cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;gap:10px;justify-content:center;letter-spacing:.5px;margin:0 auto 10px;padding:15px 30px;text-transform:uppercase;transition:all .3s ease}.install-btn:hover{background:linear-gradient(135deg,#f4d03f,#d4af37);box-shadow:0 6px 20px #d4af3766;transform:translateY(-2px)}.install-btn:active{transform:translateY(0)}.install-btn i{font-size:1.2rem}.install-note{color:#d4af37;font-size:.85rem;font-weight:500;margin:0}.pwa-manual-install h3{color:#d4af37;font-size:1.1rem;font-weight:600;margin:0 0 20px;text-align:center}.pwa-guide-steps{margin-bottom:25px}.step{align-items:flex-start;background:#ffffff0d;border:1px solid #d4af371a;border-radius:12px;display:flex;margin-bottom:20px;padding:15px;transition:all .3s ease}.step:hover{background:#ffffff14;border-color:#d4af374d;transform:translateX(5px)}.step-number{align-items:center;background:linear-gradient(135deg,#d4af37,#f4d03f);border-radius:50%;box-shadow:0 2px 8px #d4af374d;color:#1a1a1a;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;height:30px;justify-content:center;margin-right:15px;width:30px}.step-content{flex:1 1}.step-content p{color:#fff;font-size:.95rem;line-height:1.4;margin:0}.step-content i{color:#d4af37;margin:0 3px}.pwa-benefits{background:#d4af371a;border:1px solid #d4af3733;border-radius:12px;padding:20px}.pwa-benefits h3{color:#d4af37;font-size:1.1rem;font-weight:600;margin:0 0 15px;text-align:center}.pwa-benefits ul{list-style:none;margin:0;padding:0}.pwa-benefits li{align-items:center;color:#fff;display:flex;font-size:.9rem;margin-bottom:10px}.pwa-benefits li:last-child{margin-bottom:0}.pwa-benefits li i{color:#4caf50;font-size:.8rem;margin-right:10px}.pwa-guide-footer{border-top:1px solid #d4af3733;display:flex;gap:15px;padding:20px 30px 30px}.pwa-guide-btn{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;letter-spacing:.5px;padding:12px 20px;text-transform:uppercase;transition:all .3s ease}.pwa-guide-btn.secondary{background:#ffffff1a;border:1px solid #fff3;color:#ccc}.pwa-guide-btn.secondary:hover{background:#ffffff26;color:#fff;transform:translateY(-2px)}.pwa-guide-btn.primary{background:linear-gradient(135deg,#d4af37,#f4d03f);border:1px solid #d4af37;box-shadow:0 4px 15px #d4af374d;color:#1a1a1a}.pwa-guide-btn.primary:hover{background:linear-gradient(135deg,#f4d03f,#d4af37);box-shadow:0 6px 20px #d4af3766;transform:translateY(-2px)}@media (max-width:768px){.pwa-guide-modal{border-radius:15px;margin:10px;max-width:none}.pwa-guide-header{padding:25px 20px 15px}.pwa-guide-icon{font-size:2.5rem}.pwa-guide-title{font-size:1.3rem}.pwa-guide-content{padding:20px}.step{margin-bottom:15px;padding:12px}.step-number{font-size:.8rem;height:25px;margin-right:12px;width:25px}.step-content p{font-size:.9rem}.pwa-guide-footer{flex-direction:column;padding:15px 20px 25px}.pwa-guide-btn{font-size:.9rem;padding:14px 20px}}@media (max-height:500px){.pwa-guide-modal{max-height:95vh}.pwa-guide-header{padding:20px 30px 15px}.pwa-guide-icon{font-size:2rem;margin-bottom:10px}.pwa-guide-title{font-size:1.2rem}.pwa-guide-content{padding:15px 30px}.step{margin-bottom:10px;padding:10px}.pwa-benefits{padding:15px}.pwa-guide-footer{padding:15px 30px 20px}}.game-message-banner{background:linear-gradient(135deg,#4ecdc433,#44a08d33);border:1px solid #4ecdc44d;margin-bottom:17px;width:100%}.broadcast-announcement{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:linear-gradient(135deg,rgba(92,147,30,.627),#3bf69c33);border:1px solid #90f0cd;border-radius:20px;display:flex;gap:5px;margin-bottom:13px;padding:7px 11px}.broadcast-label{color:#99f3d2;font-size:.5rem;font-weight:600}.waiting-message-text{color:#fff;font-size:.55rem;font-weight:500;text-shadow:0 1px 2px #0006}.waiting-room{box-sizing:border-box;margin:0 auto;max-width:800px;padding:20px;width:100%}.waiting-room .players-container{flex-direction:row;gap:15px;margin-bottom:20px;max-width:100%;min-height:168px;overflow:hidden;padding:20px;width:100%}.waiting-room .player,.waiting-room .players-container{align-items:center;box-sizing:border-box;display:flex;justify-content:center;position:relative}.waiting-room .player{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-direction:column;flex-shrink:0;flex:1 1;height:160px;min-width:0;padding:13px;transition:all .3s ease}.waiting-room .ready-text{font-size:.7rem}.waiting-room .player h3{color:#fff;font-size:.85rem;font-weight:600;line-height:1.2;margin:0 0 8px}.waiting-room .player.player-shining .ready-text{color:#85e4d6;font-weight:700;text-shadow:0 0 10px #4caf5099}.player-label{margin-bottom:4px}.my-label{background:linear-gradient(45deg,#4ecdc4,#44a08d);border-radius:8px;box-shadow:0 2px 8px #4ecdc44d;color:#fff;font-size:.54rem;font-weight:600;padding:3px 5px}.waiting-player .other-label{background:#fff3;border-radius:8px;color:#ffffffe6;font-size:.45rem;font-weight:500;margin-bottom:30px;padding:3px 5px}.waiting-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;box-sizing:border-box;margin-bottom:20px;padding:27px;text-align:center;width:100%}.waiting-section p{color:#ffffffe6;font-size:.65rem;margin-bottom:13px}.button-container{align-items:center;display:flex;flex-direction:column;gap:8px;margin:0 auto;max-width:268px}.main-action{gap:12px;height:auto;min-height:0;padding:0;width:100%}.cancel-ready-btn,.main-action,.ready-btn,.resort-btn{align-items:center;display:flex;justify-content:center;margin:0}.cancel-ready-btn,.ready-btn,.resort-btn{border:none;border-radius:15px;color:#fff;cursor:pointer;font-weight:600;gap:5px;line-height:1;min-width:120px;overflow:hidden;padding:11px 21px;position:relative;text-align:center;transition:all .3s ease}.ready-btn{background:linear-gradient(45deg,#4ecdc4,#44a08d);box-shadow:0 6px 20px #4ecdc466;font-size:.5rem}.ready-btn:hover{background:linear-gradient(45deg,#2d5a4f,#1e3d35);box-shadow:0 8px 25px #2d5a4f80;transform:translateY(-3px)}.ready-btn i{font-size:.65rem;transition:transform .3s ease}.ready-btn:hover i{transform:rotate(1turn)}.cancel-ready-btn{background:linear-gradient(45deg,#ff9f6b,#ee5a24);box-shadow:0 6px 20px #ff6b6b66;font-size:.5rem}.cancel-ready-btn:hover{background:linear-gradient(45deg,#c44569,#e43434);box-shadow:0 8px 25px #c4456980;transform:translateY(-3px)}.cancel-ready-btn i{font-size:.65rem;transition:transform .3s ease}.cancel-ready-btn:hover i{transform:rotate(180deg)}.leave-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ff6b6b4d;border-radius:12px;box-shadow:0 2px 8px #ff6b6b26;color:#ff6b6b;cursor:pointer;display:flex;font-size:.5rem;font-weight:500;gap:4px;justify-content:center;min-width:70px;padding:6px 12px;text-align:center;transition:all .3s ease}.leave-btn:hover{background:#ff6b6b33;border-color:#ff6b6b99;box-shadow:0 4px 12px #ff6b6b40;color:#ff4757;transform:translateY(-1px)}.leave-btn i{font-size:.6rem;transition:transform .3s ease}.leave-btn:hover .leave-icon{transform:translateX(-2px)}.resort-btn{background:linear-gradient(45deg,#6c5ce7,#a29bfe);box-shadow:0 6px 20px #6c5ce766;font-size:.5rem}.resort-btn:hover{background:linear-gradient(45deg,#5f3dc4,#9775fa);box-shadow:0 8px 25px #6c5ce780;transform:translateY(-3px)}.resort-btn i{font-size:.65rem;transition:transform .3s ease}.resort-btn:hover i{transform:rotate(180deg)}@media (max-height:500px) and (orientation:landscape){.waiting-room{margin:0;max-width:100%;padding:10px}.broadcast-announcement{margin:0;padding:2px 11px}.waiting-room .players-container{flex-wrap:nowrap;gap:15px;justify-content:space-around;min-height:100px;padding:10px}.waiting-room .player{aspect-ratio:1.14;flex:0 0 100px;height:100px;padding:8px}.waiting-room .player h3{font-size:.7rem;margin:2px 0}.waiting-room .player p{margin:1px 0}.waiting-section{padding:10px}.waiting-section p{margin:0}.waiting-room .button-container{flex-direction:row;flex-wrap:wrap;gap:6px;justify-content:center;margin:0;max-width:100%;transform:scale(.8)}.cancel-ready-btn,.ready-btn,.resort-btn{flex:1 1;max-width:110px}.cancel-ready-btn,.leave-btn,.ready-btn,.resort-btn{font-size:.6rem;min-height:36px;min-width:70px;padding:8px 12px}.leave-btn{flex:0 0 auto;max-width:none}.button-container{margin-top:10px}}.game-board{grid-gap:20px;align-items:center;box-sizing:border-box;display:grid;gap:20px;grid-template-areas:". top ." "left center right" ". bottom .";grid-template-columns:1fr auto 1fr;grid-template-rows:auto 1fr auto;justify-items:center;margin:20px auto 30px;max-width:800px;min-height:268px;position:relative;width:100%}@keyframes winner-glow{0%,to{box-shadow:0 0 5px #ffd70080;transform:scale(1)}50%{box-shadow:0 0 20px #ffd700cc,0 0 30px #ffd70099,0 0 40px #ffd70066;transform:scale(1.02)}}@keyframes winner-sparkle{0%,to{opacity:.7}50%{opacity:1}}.hand-container.winner-glow{animation:winner-glow 1.5s ease-in-out infinite;background:radial-gradient(circle,#ffd7001a 0,#0000 70%);border-radius:15px}.hand-card-3d.winner-card-glow{animation:winner-sparkle 1s ease-in-out infinite;border:2px solid #ffd700cc!important;box-shadow:0 0 10px #ffd700b3,0 4px 8px #0003}.winner-message{animation:winner-sparkle 1.2s ease-in-out infinite;color:gold;font-size:18px;text-shadow:2px 2px 4px #0000004d}.waiting-confirm-indicator,.winner-message{font-weight:700;margin-top:10px;text-align:center}.waiting-confirm-indicator{animation:waiting-pulse 1.5s ease-in-out infinite;background:#ffa5001a;border:1px solid #ffa50066;border-radius:20px;color:orange;font-size:16px;padding:8px 16px}@keyframes waiting-pulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}.trick-judging-indicator{animation:judging-pulse 2s ease-in-out infinite;background:#ffa5001a;border:1px solid #ffa5004d;border-radius:15px;color:orange;font-size:14px;font-weight:700;margin-top:8px;padding:6px 12px;text-align:center}@keyframes judging-pulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}.player.winner-player{border-radius:8px;box-shadow:0 0 5px #ffd70033}.other-label.winner-name-glow{background:linear-gradient(135deg,#ffd7004d,#ffb30033)!important;border:1px solid #ffd70080!important;color:gold!important;font-weight:700!important}.player.player-shining .other-label{background:#4b422fc8!important;color:#adebe7!important}.played-card.winner-played-card-glow{animation:elegant-glow-pulse 3s ease-in-out infinite;background:linear-gradient(45deg,#ffd700e6,#fffc 25%,#ffd700b3 50%,#fff9 75%,#ffd700cc)!important;border:none!important;box-shadow:0 0 25px #ffd700cc,0 0 50px #ffd70099,0 0 75px #ffd70066,0 0 100px #ffd70033;overflow:visible;position:relative;transform:scale(1.3);transition:all .3s ease;z-index:10}@keyframes elegant-glow-pulse{0%,to{box-shadow:0 0 25px #ffd700cc,0 0 50px #ffd70099,0 0 75px #ffd70066,0 0 100px #ffd70033;transform:scale(1.3)}50%{box-shadow:0 0 35px gold,0 0 70px #ffd700cc,0 0 105px #ffd70099,0 0 140px #ffd70066;transform:scale(1.35)}}.card-content{color:#fff;font-weight:700;position:relative;text-shadow:1px 1px 2px #00000080;z-index:2}.sparkle{font-size:16px;pointer-events:none;position:absolute;z-index:1}.sparkle-1{animation:sparkle-dance-1 2.5s ease-in-out infinite;left:-8px;top:-8px}.sparkle-2{animation:sparkle-dance-2 2.8s ease-in-out infinite;right:-8px;top:-8px}.sparkle-3{animation:sparkle-dance-3 3.1s ease-in-out infinite;bottom:-8px;left:-8px}.sparkle-4{animation:sparkle-dance-4 2.2s ease-in-out infinite;bottom:-8px;right:-8px}@keyframes sparkle-dance-1{0%,to{opacity:.6;transform:translateY(0) rotate(0deg) scale(1)}25%{opacity:1;transform:translateY(-3px) rotate(45deg) scale(1.2)}50%{opacity:.8;transform:translateY(-1px) rotate(90deg) scale(.9)}75%{opacity:1;transform:translateY(-4px) rotate(135deg) scale(1.1)}}@keyframes sparkle-dance-2{0%,to{opacity:.7;transform:translateX(0) rotate(180deg) scale(1)}33%{opacity:1;transform:translateX(2px) rotate(225deg) scale(1.3)}66%{opacity:.5;transform:translateX(-1px) rotate(270deg) scale(.8)}}@keyframes sparkle-dance-3{0%,to{opacity:.5;transform:translateY(0) rotate(270deg) scale(1.1)}40%{opacity:1;transform:translateY(2px) rotate(315deg) scale(1.2)}80%{opacity:.8;transform:translateY(-2px) rotate(1turn) scale(.9)}}@keyframes sparkle-dance-4{0%,to{opacity:.6;transform:translateX(0) translateY(0) rotate(0deg) scale(1)}20%{opacity:1;transform:translateX(-2px) translateY(1px) rotate(72deg) scale(1.4)}40%{opacity:.7;transform:translateX(1px) translateY(-2px) rotate(144deg) scale(.7)}60%{opacity:1;transform:translateX(2px) translateY(1px) rotate(216deg) scale(1.1)}80%{opacity:.9;transform:translateX(-1px) translateY(-1px) rotate(288deg) scale(1.2)}}.player.left,.player.right{align-self:center}.played-cards{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;padding:25px}.played-cards h3{color:#fff;font-size:1.4rem;margin:0 0 20px}.card{font-size:1.2rem}.played-card{background:linear-gradient(45deg,#34495e,#2c3e50)!important;border:1px solid #ffffff4d!important;border-radius:8px!important;box-shadow:0 2px 8px #0003!important;color:#fff!important}.playing-controls-area{align-items:center;animation:slideUp .5s ease-out;background:#0000;bottom:120px;display:flex;justify-content:center;left:0;min-height:120px;padding:20px 0 0;position:fixed;right:0;z-index:1001}.hand-container{align-items:flex-end;min-height:120px}.trick-records-display{height:auto;margin:20px 0;padding:0;position:relative;width:100%;z-index:5}.trick-records-combined,.trick-records-display{align-items:center;display:flex;flex-direction:column;gap:0}.trick-records-combined{margin:0 auto;width:-webkit-fit-content;width:fit-content}.trick-records-bar{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000c;border:1px solid #ffffff1a;border-radius:12px 12px;border-top:none;box-shadow:0 4px 12px #0000004d;display:flex;flex-direction:row;gap:16px;max-width:none;min-width:600px;padding:16px 20px;width:60%}.trick-records-title{color:#ffffffe6;flex-shrink:0;font-size:16px;font-weight:700;margin:0;min-width:70px;padding:0;text-align:center;white-space:nowrap}.trick-records-list{display:flex;flex:1 1;flex-direction:row;gap:8px;max-width:none;min-height:60px;overflow-x:auto;overflow-y:hidden;padding:0;scroll-behavior:smooth}.trick-records-list::-webkit-scrollbar{height:4px;width:4px}.trick-records-list::-webkit-scrollbar-track{background:#ffffff1a;border-radius:2px}.trick-records-list::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.trick-records-list::-webkit-scrollbar-thumb:hover{background:#ffffff80}.trick-record-item{align-items:center;background:#ffffff14;border-radius:8px;display:flex;flex-direction:column;flex-shrink:0;font-size:14px;gap:4px;justify-content:center;min-width:65px;padding:10px 14px;text-align:center}.trick-number{color:#fffc;font-size:14px;font-weight:600;white-space:nowrap}.trick-team{font-size:12px;font-weight:700;white-space:nowrap}.trick-team.our-team{color:#4caf50}.trick-team.their-team{color:#f44336}.trick-summary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000c;border:1px solid #ffffff1a;border-bottom:none;border-radius:12px 12px 0 0;box-shadow:0 4px 12px #0000004d;flex-direction:row;flex-shrink:0;gap:20px;margin:0;padding:16px 20px;width:-webkit-fit-content;width:fit-content}.team-score,.trick-summary{display:flex;justify-content:center}.team-score{align-items:center;background:#ffffff14;border-radius:8px;font-size:16px;font-weight:700;padding:8px 16px;text-align:center;white-space:nowrap}.team-score.our-score{color:#4caf50}.team-score.their-score{color:#f44336}.game-message-center{align-items:center;display:flex;grid-area:center;height:100%;justify-content:center;width:100%}.message-text{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#228b2266,#2e7d324d 25%,#228b2266 50%,#2e7d324d 75%,#228b2266);border:2px solid #4caf50b3;border-radius:25px;box-shadow:inset 0 1px 0 #fff3,inset 0 -1px 0 #0003;color:#fff;display:inline-block;font-size:.7em;font-weight:700;overflow:hidden;padding:12px 24px;position:relative;text-shadow:0 0 10px #4caf50e6,0 2px 4px #00000080}.message-text:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@media screen and (max-height:500px) and (orientation:landscape){.playing-controls-area{bottom:75px}.trick-records-bar{display:none}.trick-summary{border-radius:8px;font-size:.7rem;gap:10px;max-width:200px;min-width:auto;padding:8px 12px;position:fixed;right:15px;top:10px;width:auto;z-index:2000}.team-score{font-size:.6rem;padding:2px 6px}}.bidding-board{grid-gap:10px;align-items:start;box-sizing:border-box;display:grid;gap:10px;grid-template-areas:". top ." "left center right" ". bottom .";grid-template-columns:auto 400px auto;grid-template-rows:auto auto auto;height:auto;justify-items:start;margin:0 auto;overflow:visible;padding-bottom:20px;position:relative;width:-webkit-fit-content;width:fit-content}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.bidding-center{align-items:center;align-self:start;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:16px;display:flex;flex-direction:column;grid-column:2;grid-row:2;height:auto;justify-content:flex-start;max-height:45vh;min-height:30px;min-width:268px;overflow:visible;padding:16px;width:400px}.bidding-message{margin-bottom:1px;text-align:center;width:100%}@keyframes sweep{0%{left:-100%}50%{left:100%}to{left:100%}}.bidding-history{flex:1 1 auto;max-height:60vh;overflow-x:hidden;overflow-y:auto;width:80%}.bidding-history::-webkit-scrollbar{width:6px}.bidding-history::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.bidding-history::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px;-webkit-transition:background .3s ease;transition:background .3s ease}.bidding-history::-webkit-scrollbar-thumb:hover{background:#ffffff80}.bidding-history .text-label{color:#fff;font-size:.7em;font-weight:600;margin-bottom:12px;text-align:center;text-shadow:0 1px 2px #0000004d}.bids-list{display:flex;flex-direction:column-reverse;gap:8px}.bid-item{align-items:center;animation:passSlideIn .4s ease-out;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#58575700;border-bottom:3px solid #000;border-left:3px solid #909490;border-radius:8px;box-shadow:0 1px 3px #0000001a,inset 0 1px 0 #ffffff1a;display:flex;justify-content:space-between;padding:5px 8px;transition:all .3s ease}.bid-item:hover{background:linear-gradient(135deg,#ffffff2e,#ffffff1f);transform:translateX(4px)}@keyframes bidSlideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes passSlideIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.bidder-name{color:#fff;flex-shrink:0;font-size:.7em;font-weight:600;text-shadow:0 1px 2px #0000004d}.bid-content{align-items:center;background:#0003;border:1px solid #ffffff1a;border-radius:6px;display:flex;font-size:.85em;gap:4px;justify-content:center;min-width:60px;padding:1px 6px;width:60px}.bid-level{color:#fff;font-size:.85em}.bid-level,.bid-suit{font-weight:700;text-shadow:0 1px 2px #00000080}.bid-suit{color:#f8fafc;filter:drop-shadow(0 0 3px currentColor)}.bid-suit,.bid-suit.nt{font-size:.7em}.pass-text{background:rgba(154,11,11,.176);border-radius:6px;color:#fff;display:inline-block;font-size:.6em;font-weight:400;min-width:60px;padding:2px 6px;text-align:center;text-shadow:0 1px 2px #0000004d;width:60px}.hand-title{font-size:1.2rem}.hand-card:first-child{animation-delay:0s}.hand-card:nth-child(2){animation-delay:.1s}.hand-card:nth-child(3){animation-delay:.2s}.hand-card:nth-child(4){animation-delay:.3s}.hand-card:nth-child(5){animation-delay:.4s}.hand-card:nth-child(6){animation-delay:.5s}.hand-card:nth-child(7){animation-delay:.6s}.hand-card:nth-child(8){animation-delay:.7s}.hand-card:nth-child(9){animation-delay:.8s}.hand-card:nth-child(10){animation-delay:.9s}.hand-card:nth-child(11){animation-delay:1s}.hand-card:nth-child(12){animation-delay:1.1s}.hand-card:nth-child(13){animation-delay:1.2s}.hand-card.red{color:#e74c3c}.hand-card.black{color:#2c3e50}.hand-card:first-child{transform:rotate(-18deg) translateY(0)}.hand-card:nth-child(2){transform:rotate(-15deg) translateY(1px)}.hand-card:nth-child(3){transform:rotate(-12deg) translateY(2px)}.hand-card:nth-child(4){transform:rotate(-9deg) translateY(3px)}.hand-card:nth-child(5){transform:rotate(-6deg) translateY(4px)}.hand-card:nth-child(6){transform:rotate(-3deg) translateY(5px)}.hand-card:nth-child(7){transform:rotate(0deg) translateY(6px)}.hand-card:nth-child(8){transform:rotate(3deg) translateY(5px)}.hand-card:nth-child(9){transform:rotate(6deg) translateY(4px)}.hand-card:nth-child(10){transform:rotate(9deg) translateY(3px)}.hand-card:nth-child(11){transform:rotate(12deg) translateY(2px)}.hand-card:nth-child(12){transform:rotate(15deg) translateY(1px)}.hand-card:nth-child(13){transform:rotate(18deg) translateY(0)}.bidding-controls-area{align-items:center;animation:slideUp .5s ease-out;background:#0000;bottom:130px;display:flex;justify-content:center;left:0;min-height:120px;padding:20px 0 0;position:fixed;right:0;z-index:1002}.bidding-controls{align-items:center;display:flex;flex-direction:column;gap:5px;margin:0 auto;max-width:536px;padding:10px 20px;width:100%}.bid-selector{align-items:center;display:flex;gap:40px}.level-selector,.suit-selector{align-items:center;display:flex;flex-direction:row}.level-selector label,.suit-selector label{color:#fff;font-size:1em;font-weight:700;min-width:50px;text-shadow:0 2px 4px #00000080;white-space:nowrap}.level-buttons,.suit-buttons{display:flex;gap:8px}.level-btn,.suit-btn{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff1a;border:2px solid #ffffff40;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:700;height:30px;justify-content:center;text-align:center;transition:all .2s ease;width:60px}.level-btn:hover,.suit-btn:hover{background:#fff3;transform:scale(1.05)}.level-btn.selected,.suit-btn.selected{background:linear-gradient(45deg,#4ade80,#22c55e);border-color:#16a34a;box-shadow:0 4px 12px #22c55e4d;color:#fff}.bid-actions{display:flex;gap:20px}.bid-btn,.pass-btn{border:none;border-radius:6px;box-shadow:0 2px 4px #0000004d;cursor:pointer;font-size:.8em;font-weight:700;padding:6px 12px;transition:all .3s ease}.bid-btn.valid{background:linear-gradient(45deg,#4ade80,#22c55e);box-shadow:0 4px 15px #22c55e4d;color:#fff}.bid-btn.valid:hover{background:linear-gradient(45deg,#22c55e,#16a34a);box-shadow:0 3px 10px #22c55e66;transform:translateY(-1px)}.bid-btn.invalid{background:#6b7280;color:#d1d5db;cursor:not-allowed}.pass-btn{background:linear-gradient(45deg,#ef4444,#dc2626);box-shadow:0 4px 15px #ef44444d;color:#fff}.pass-btn:hover{background:linear-gradient(45deg,#dc2626,#b91c1c);box-shadow:0 3px 10px #ef444466;transform:translateY(-1px)}.waiting-turn{color:#a0d4c7;font-size:.7em;text-align:center}.game-starting-message{animation:startingPulse 2s ease-in-out infinite;color:#a0d4c7;font-size:1.1em;font-style:italic}@keyframes startingPulse{0%,to{opacity:.7}50%{opacity:1}}@media (max-height:500px) and (orientation:landscape){.bidding-controls-area{bottom:100px;min-height:60px;padding:5px 10px}.bidding-controls{align-items:center;flex-direction:row;gap:2px;justify-content:center}.bid-selector{gap:15px;margin-right:15px}.bid-btn{width:80px}.bid-btn,.pass-btn{border-radius:6px;font-size:.5rem;height:20px;padding:2px 4px}.pass-btn{width:50px}.level-btn,.suit-btn{border-radius:8px;font-size:.6rem;padding:2px 4px;width:40px}.bid-actions{gap:6px}.bidding-center{max-height:40vh;min-height:20px;padding:8px}.waiting-turn{display:none}}.game-room{display:flex;flex-direction:column;height:100vh;margin:0 auto;overflow:hidden;padding:20px}.room-header{grid-gap:10px;align-items:center;animation:headerPulse 6s ease-in-out infinite;background:linear-gradient(135deg,#0a0a0a,#1a1a1a 50%,#0a0a0a);border:2px solid gold;border-radius:15px;box-shadow:0 0 20px #ffd7004d,inset 0 1px 0 #ffd7001a,0 2px 6px #0006,0 4px 12px #00000080,0 6px 18px #0009;cursor:pointer;display:grid;gap:10px;grid-template-columns:1fr 1fr 1fr;min-height:100px;overflow:hidden;padding:10px 18px;position:relative;transition:all .4s ease}@keyframes headerPulse{0%,to{box-shadow:0 0 40px #ffd7004d,inset 0 1px 0 #ffd7001a,0 4px 12px #0006,0 8px 24px #00000080,0 12px 36px #0009;transform:scale(1)}50%{box-shadow:0 0 50px #ffd70066,inset 0 1px 0 #ffd70026,0 6px 16px #00000080,0 12px 32px #0009,0 18px 48px #000000b3;transform:scale(1.01)}}.room-header:before{background:radial-gradient(circle at 20% 20%,#ffd70014 0,#0000 50%),radial-gradient(circle at 80% 80%,#2e7d3214 0,#0000 50%),radial-gradient(circle at 50% 50%,#ffd7000d 0,#0000 70%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.room-header:after{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border:1px solid gold;border-radius:12px;color:gold;content:"♠ ♥ ♦ ♣";font-size:.45rem;left:50%;padding:2px 8px;position:absolute;top:-5px;transform:translateX(-50%);z-index:0}.header-left{align-items:center!important;display:flex!important;justify-content:flex-start!important;margin:auto 0;position:relative;z-index:1}.player-info{background:linear-gradient(135deg,#ffd7001a,#ffb3000d);border:1px solid #ffd7004d;border-radius:10px;box-shadow:0 3px 12px #ffd70033,inset 0 1px 0 #ffd7001a;gap:12px;padding:6px 12px;transition:all .3s ease}.player-avatar,.player-info{align-items:center;display:flex}.player-avatar{background:linear-gradient(135deg,gold,#ffb300 50%,#ff8f00);border:2px solid gold;border-radius:50%;box-shadow:0 0 15px #ffd70066,0 3px 8px #0000004d,inset 0 1px 2px #fff3;color:#1a1a1a;font-size:1.3rem;font-weight:700;height:36px;justify-content:center;position:relative;width:36px}.player-name-display{color:gold;font-size:.8rem;font-weight:800;letter-spacing:.8px;margin:0;text-shadow:0 0 8px #ffd70080,0 2px 4px #00000080;text-transform:uppercase}.header-center{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;margin:auto 0;position:relative;z-index:1}.game-status-banner{background:linear-gradient(135deg,#1a1a1a,#2d2d2d 50%,#1a1a1a);border-radius:12px;cursor:pointer;overflow:hidden;padding:8px 15px;position:relative;transition:all .3s ease}.game-status-banner:before{animation:shimmer 4s ease-in-out infinite;background:linear-gradient(90deg,#0000,#ffd7001a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}.status-indicator{align-items:center;color:gold;display:flex;font-size:.85rem;font-weight:700;gap:15px;letter-spacing:1px;position:relative;text-shadow:0 0 10px #ffd70080,0 2px 4px #00000080;text-transform:uppercase;z-index:1}@keyframes shimmer{0%{left:-100%;opacity:0}50%{opacity:1}to{left:100%;opacity:0}}.header-right{align-items:flex-start!important;display:flex!important;flex-direction:column!important;gap:8px;margin:auto 0;position:relative;z-index:1}.room-info{align-items:flex-start;background:linear-gradient(135deg,#ffd7001a,#ffb3000d);border:1px solid #ffd7004d;border-radius:10px;box-shadow:0 3px 12px #ffd70033,inset 0 1px 0 #ffd7001a;display:flex;flex-direction:column;padding:8px 6px;transition:all .3s ease}.player-count,.room-id-display{align-items:center;display:flex;flex-direction:row;gap:8px;justify-content:flex-start}.count-label,.room-label{color:#ffd700cc;font-size:.5rem;font-weight:600;letter-spacing:.5px;text-shadow:0 1px 2px #0000004d;text-transform:uppercase}.count-number,.room-number{animation:numberGlow 2s ease-in-out infinite;background:linear-gradient(135deg,gold,#ffb300 50%,#ff8f00);border:1px solid gold;border-radius:6px;box-shadow:0 0 12px #ffd70066,0 3px 6px #0000004d;color:#1a1a1a;font-size:.6rem;font-weight:800;padding:3px 6px;text-shadow:0 1px 2px #0003}@keyframes numberGlow{0%,to{box-shadow:0 0 15px #ffd70066,0 3px 8px #0000004d}50%{box-shadow:0 0 25px #ffd70099,0 4px 12px #0006}}.player{background:linear-gradient(120deg,#9b9898,#58575700 20%,#58575700)!important;border:1px solid #fff3!important;border-bottom:4px solid #000!important;border-radius:15px;box-shadow:0 2px 4px #0000001a,inset 0 1px 0 #ffffff1a!important;box-sizing:border-box;height:120px;padding:16px;position:relative;transition:all .3s ease;width:160px}.player,.player-info-container{align-items:center;display:flex;flex-direction:column;justify-content:center}.player-info-container{gap:8px;height:100%;text-align:center;width:100%}.player p{color:#fffc;font-size:.85rem;line-height:1.2;margin:3px 0}.player-label{margin-bottom:6px}.player.player-shining{background:linear-gradient(120deg,#4ecdc4cc,#4ecdc44d 20%,#58575700)!important;border:2px solid #4ecdc4!important;border-bottom:4px solid #2c5c59!important;box-shadow:0 0 20px #4ecdc466,0 4px 8px #0003,inset 0 1px 0 #ffffff4d!important}.player.player-shining:hover,.player:hover{box-shadow:0 4px 8px #0003,inset 0 1px 0 #fff3;transform:translateY(-5px)}.player.right{align-self:start;grid-area:right;justify-self:end}.player.left{align-self:start;grid-area:left;justify-self:start}.player.top{align-self:end;grid-area:top;justify-self:center}.player.bottom{align-self:start;grid-area:bottom;justify-self:center}.current-turn{animation:turnPulse 2s ease-in-out infinite;background:linear-gradient(135deg,gold,#ffb300 50%,#ff8f00);border:2px solid gold;border-radius:25px;box-shadow:0 0 15px #ffd70066,0 3px 8px #0000004d;color:#1a1a1a;font-size:.85rem;font-weight:700;letter-spacing:1px;padding:8px 16px;text-transform:uppercase}@keyframes turnPulse{0%,to{box-shadow:0 0 15px #ffd70066,0 3px 8px #0000004d;transform:scale(1)}50%{box-shadow:0 0 25px #ffd70099,0 4px 12px #0006;transform:scale(1.05)}}.game-message-banner{animation:slideIn .5s ease-out;background:linear-gradient(135deg,#2e7d32cc,#4caf5099 50%,#ffd70066);border:1px solid #ffd70066;border-radius:15px;box-shadow:0 3px 10px #4caf5033;margin-bottom:25px;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.message-content{align-items:center;color:#fff;display:flex;gap:12px;padding:15px 20px;text-shadow:0 1px 2px #0000004d}.message-icon{font-size:.85rem}.other-label{background:linear-gradient(135deg,#ffd70026,#ffb3001a);border-radius:8px;box-shadow:0 2px 4px #0003,inset 0 1px 0 #ffd7001a;color:gold;font-size:.6rem;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.other-label.winner-name-glow{animation:bounceTwice 1.5s ease-in-out infinite}@keyframes bounceTwice{0%,to{transform:translateY(0)}10%{transform:translateY(-8px)}20%{transform:translateY(0)}30%{transform:translateY(-6px)}40%{transform:translateY(0)}50%,to{transform:translateY(0)}}.current-turn-indicator{animation:pulse 2s infinite;background:linear-gradient(45deg,#4ecdc4,#44a08d);border:1px solid #ffffff4d;border-radius:15px;box-shadow:0 4px 15px #4ecdc44d;color:#fff;font-size:.4rem;font-weight:700;padding:2px 5px;position:absolute;right:-10px;top:-10px;z-index:10}.game-section{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr;margin-bottom:120px}.my-hand,.played-cards{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;padding:25px}.my-hand h3,.played-cards h3{color:#fff;font-size:1.2rem;margin:0 0 20px}.cards-display{flex-wrap:wrap;gap:10px}.card,.cards-display{display:flex;justify-content:center}.card{align-items:center;background:#fff;border:2px solid #fff;border-radius:8px;color:#333;font-size:.85rem;font-weight:700;height:80px;transition:all .3s ease;width:60px}.card.red{color:#e74c3c}.card.black{color:#2c3e50}.played-card{background:linear-gradient(45deg,#f39c12,#e67e22);border-color:#f39c12;color:#fff}.hand-card{cursor:pointer;transition:all .3s ease}.hand-card.clickable:hover{box-shadow:0 5px 15px #0000004d;transform:translateY(-5px)}.hand-card:disabled{cursor:not-allowed;opacity:.6;transform:none}.back-to-lobby-btn{background:linear-gradient(45deg,#667eea,#764ba2);border:none;border-radius:25px;color:#fff;font-weight:600;padding:15px 30px}.back-to-lobby-btn:hover{box-shadow:0 6px 20px #667eea4d}.first-person-hand{animation:slideUp .5s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(0deg,#000000e6,#000000b3,#0000);bottom:0;left:0;padding:20px 0 40px;position:fixed;right:0;z-index:1000}.hand-container{gap:8px;margin:0 auto;padding:0 20px}.hand-card-3d,.hand-container{align-items:center;display:flex;justify-content:center}.hand-card-3d{animation:cardDeal .6s ease-out;aspect-ratio:.73;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #fff;border-radius:8px;box-shadow:0 4px 8px #0000004d;color:#333;cursor:pointer;font-size:1.1rem;font-weight:700;height:auto;position:relative;transform:rotateY(0deg);transition:all .3s ease;width:70px}@keyframes cardDeal{0%{opacity:0;transform:translateY(-100px) rotate(180deg)}to{opacity:1;transform:rotate(0deg)}}.hand-card-3d:first-child{animation-delay:0s}.hand-card-3d:nth-child(2){animation-delay:.1s}.hand-card-3d:nth-child(3){animation-delay:.2s}.hand-card-3d:nth-child(4){animation-delay:.3s}.hand-card-3d:nth-child(5){animation-delay:.4s}.hand-card-3d:nth-child(6){animation-delay:.5s}.hand-card-3d:nth-child(7){animation-delay:.6s}.hand-card-3d:nth-child(8){animation-delay:.7s}.hand-card-3d:nth-child(9){animation-delay:.8s}.hand-card-3d:nth-child(10){animation-delay:.9s}.hand-card-3d:nth-child(11){animation-delay:1s}.hand-card-3d:nth-child(12){animation-delay:1.1s}.hand-card-3d:nth-child(13){animation-delay:1.2s}.hand-card-3d.red{color:#e74c3c}.hand-card-3d.black{color:#2c3e50}.hand-card-3d.clickable:hover{box-shadow:0 8px 20px #0006;transform:translateY(-15px) rotateY(5deg);z-index:10}.hand-card-3d:disabled{cursor:not-allowed;opacity:.6;transform:none}.hand-card-3d:disabled:hover{box-shadow:0 4px 8px #0000004d;transform:none}.hand-card-3d:first-child{transform:rotate(-18deg) translateY(0)}.hand-card-3d:nth-child(2){transform:rotate(-15deg) translateY(1px)}.hand-card-3d:nth-child(3){transform:rotate(-12deg) translateY(2px)}.hand-card-3d:nth-child(4){transform:rotate(-9deg) translateY(3px)}.hand-card-3d:nth-child(5){transform:rotate(-6deg) translateY(4px)}.hand-card-3d:nth-child(6){transform:rotate(-3deg) translateY(5px)}.hand-card-3d:nth-child(7){transform:rotate(0deg) translateY(6px)}.hand-card-3d:nth-child(8){transform:rotate(3deg) translateY(5px)}.hand-card-3d:nth-child(9){transform:rotate(6deg) translateY(4px)}.hand-card-3d:nth-child(10){transform:rotate(9deg) translateY(3px)}.hand-card-3d:nth-child(11){transform:rotate(12deg) translateY(2px)}.hand-card-3d:nth-child(12){transform:rotate(15deg) translateY(1px)}.hand-card-3d:nth-child(13){transform:rotate(18deg) translateY(0)}.hand-card-3d.clickable:hover:first-child{transform:translateY(-15px) rotate(-18deg)}.hand-card-3d.clickable:hover:nth-child(2){transform:translateY(-15px) rotate(-15deg)}.hand-card-3d.clickable:hover:nth-child(3){transform:translateY(-15px) rotate(-12deg)}.hand-card-3d.clickable:hover:nth-child(4){transform:translateY(-15px) rotate(-9deg)}.hand-card-3d.clickable:hover:nth-child(5){transform:translateY(-15px) rotate(-6deg)}.hand-card-3d.clickable:hover:nth-child(6){transform:translateY(-15px) rotate(-3deg)}.hand-card-3d.clickable:hover:nth-child(7){transform:translateY(-15px) rotate(0deg)}.hand-card-3d.clickable:hover:nth-child(8){transform:translateY(-15px) rotate(3deg)}.hand-card-3d.clickable:hover:nth-child(9){transform:translateY(-15px) rotate(6deg)}.hand-card-3d.clickable:hover:nth-child(10){transform:translateY(-15px) rotate(9deg)}.hand-card-3d.clickable:hover:nth-child(11){transform:translateY(-15px) rotate(12deg)}.hand-card-3d.clickable:hover:nth-child(12){transform:translateY(-15px) rotate(15deg)}.hand-card-3d.clickable:hover:nth-child(13){transform:translateY(-15px) rotate(18deg)}.hand-title{color:#fff;font-size:.85rem;font-weight:600;margin-bottom:15px;text-align:center;text-shadow:0 2px 4px #00000080}.turn-indicator-3d{animation:turnIndicatorPulse 2s infinite;background:linear-gradient(45deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 8px 25px #667eea66,0 4px 12px #764ba24d,0 2px 6px #0003;color:#fff;display:inline-block;font-size:.6rem;font-weight:700;margin-top:6px;padding:5px 10px;position:relative;transform:translateY(-2px);transition:all .3s ease;z-index:10}@keyframes turnIndicatorPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.game-ended{align-items:center;background:linear-gradient(135deg,#0a0a0a00,#5361387b 50%,#0a0a0a52);display:flex;flex-direction:column;justify-content:center;min-height:70vh;padding:40px 20px;position:relative}.contract-result{background:linear-gradient(135deg,#1e1e1e,#2d2d2d);border:1px solid gold;border-radius:8px;box-shadow:0 0 12px #ffd7004d,inset 0 1px 0 #ffd7001a,0 1px 4px #0000004d,0 2px 8px #0006,0 4px 12px #00000080;cursor:pointer;margin-bottom:12px;max-width:500px;padding:15px;position:relative;transition:all .4s ease;width:100%;z-index:1}.contract-result:hover{box-shadow:0 15px 50px #ffd70080,0 0 60px #ffd7004d,inset 0 1px 0 #ffd70033;transform:translateY(-8px) scale(1.03)}.contract-result:hover:before{transform:translateX(-6px) translateY(-6px) rotate(-3deg);transition:transform .3s ease}.contract-result:hover:after{transform:translateX(-12px) translateY(-12px) rotate(4deg);transition:transform .3s ease}.contract-result:before{border:2px solid gold;border-radius:18px;bottom:-2px;box-shadow:0 3px 10px #0006;left:-2px;right:-6px;top:-4px;transform:rotate(-1deg);z-index:-1}.contract-result:after,.contract-result:before{background:#1a1a1a;content:"";position:absolute}.contract-result:after{border:2px solid gold;border-radius:21px;bottom:-6px;box-shadow:0 5px 15px #00000080;left:-4px;right:-2px;top:-8px;transform:rotate(2deg);z-index:-2}.result-banner{border-radius:6px;cursor:pointer;margin-bottom:12px;overflow:visible;padding:8px;position:relative;text-align:center;transition:all .3s ease}.result-banner:hover:before{transform:translateX(-4px) translateY(-4px) rotate(-3deg);transition:transform .3s ease}.result-banner.success{background:linear-gradient(135deg,#2e7d32,#4caf50 50%,gold);border:3px solid #2e7d32;box-shadow:0 0 20px #4caf5099;color:#fff;text-shadow:0 2px 4px #00000080}.result-banner.failure{background:linear-gradient(135deg,#424242,#616161 50%,#d32f2f);box-shadow:0 0 20px #d32f2f99;color:#fff;text-shadow:0 2px 4px #00000080}.result-banner h4{font-size:.9rem;font-weight:700;letter-spacing:.3px;margin:0;text-transform:uppercase}.result-details{display:flex;flex-direction:column;gap:8px}.contract-info h5{color:gold;font-size:.7rem;font-weight:700;letter-spacing:.3px;margin:6px 0 8px;text-align:center}.required-tricks{color:gold;font-size:.6rem;font-weight:400;margin-left:4px}.team-results{display:flex;gap:8px;justify-content:space-between}.team-info{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border:1px solid #ffd7004d;border-radius:6px;cursor:pointer;flex:1 1;padding:8px;position:relative;transition:all .3s ease}.team-info:before{background:#1a1a1a;border:1px solid gold;border-radius:10px;bottom:-1px;box-shadow:0 2px 6px #0003;content:"";left:-1px;position:absolute;right:-3px;top:-2px;transform:rotate(1deg);z-index:-1}.team-info h5{border-bottom:1px solid #ffd7004d;color:gold;font-weight:700;letter-spacing:.3px;margin:0 0 6px;padding-bottom:4px;text-align:center}.team-info h5,.team-player,.team-target{font-size:.7rem}.team-player{border-radius:4px;cursor:pointer;font-weight:600;letter-spacing:.2px;margin:4px 0;overflow:hidden;padding:6px 8px;position:relative;text-align:center;transition:all .3s ease}.team-player:hover{box-shadow:0 4px 12px #0000004d;transform:translateY(-1px) scale(1.02)}.team-player:before{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.team-player:hover:before{left:100%}.team-player.winner{background:linear-gradient(135deg,#2b684b,#4caf50 50%,#d0ba3d);box-shadow:0 4px 15px #4caf504d}.team-player.loser,.team-player.winner{color:#fff;text-shadow:0 1px 3px #00000080}.team-player.loser{background:linear-gradient(135deg,#424242,#4d1b1b);box-shadow:0 2px 8px #4242424d}.back-to-lobby-btn{animation:buttonFloat 3s ease-in-out infinite;background:linear-gradient(135deg,gold,#ffb300 50%,#ff8f00);border:2px solid gold;border-radius:8px;color:#1a1a1a;cursor:pointer;font-size:.85rem;font-weight:700;letter-spacing:1px;overflow:hidden;padding:15px 40px;position:relative;text-transform:uppercase;transition:all .3s ease;z-index:1}@keyframes buttonFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.back-to-lobby-btn:before{background:radial-gradient(circle,#ffffff4d,#0000 70%);content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:0;z-index:-1}.back-to-lobby-btn:hover{box-shadow:0 8px 25px #ffd70066;color:#000;transform:translateY(-2px)}.back-to-lobby-btn:hover:before{height:300px;width:300px}.game-actions{display:flex;gap:20px;justify-content:center;margin-top:20px}.auto-leave-message{animation:countdownPulse 1s ease-in-out infinite;color:gold;font-size:.9rem;font-weight:600;text-align:center;text-shadow:0 0 10px #ffd70080}@keyframes countdownPulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.continue-game-btn{animation:buttonFloat 3s ease-in-out infinite;background:linear-gradient(135deg,#4caf50,#66bb6a 50%,#4caf50);border:2px solid #2e7d32;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:700;letter-spacing:1px;overflow:hidden;padding:15px 40px;position:relative;text-transform:uppercase;transition:all .3s ease;z-index:1}.continue-game-btn:before{background:radial-gradient(circle,#ffffff4d,#0000 70%);content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:0;z-index:-1}.continue-game-btn:hover{box-shadow:0 8px 25px #4caf5066;color:#fff;transform:translateY(-2px)}.continue-game-btn:hover:before{height:300px;width:300px}.trick-records{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border:1px solid gold;border-radius:8px;box-shadow:0 0 15px #ffd70033,inset 0 1px 0 #ffd7001a;margin-top:15px;max-height:300px;overflow:hidden;overflow-y:auto;padding:12px;position:relative}.trick-records::-webkit-scrollbar{width:8px}.trick-records::-webkit-scrollbar-track{background:#1a1a1acc;border:1px solid #ffd70033;border-radius:4px}.trick-records::-webkit-scrollbar-thumb{background:linear-gradient(135deg,gold,#ffed4e);border:1px solid #0000004d;border-radius:4px;box-shadow:0 2px 4px #0000004d}.trick-records::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#ffed4e,gold);box-shadow:0 0 8px #ffd70099}.trick-records::-webkit-scrollbar-thumb:active{background:linear-gradient(135deg,#e6c200,gold)}.trick-records{scrollbar-color:gold #1a1a1acc;scrollbar-width:thin}.trick-records:before{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border:1px solid gold;border-radius:15px;color:gold;content:"🎯";font-size:.6rem;left:50%;padding:1px 5px;position:absolute;top:-8px;transform:translateX(-50%);z-index:1}.trick-records h5{color:gold;font-size:.9rem;font-weight:700;letter-spacing:.5px;margin:8px 0 12px;text-align:center;text-shadow:0 2px 4px #00000080;text-transform:uppercase}.trick-list{display:flex;flex-direction:column;gap:6px}.trick-record{align-items:center;background:linear-gradient(135deg,#ffffff14,#ffffff08);border:1px solid #ffd7004d;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;overflow:hidden;padding:8px 12px;position:relative;transition:all .4s ease}.trick-record:before{background:linear-gradient(90deg,#0000,#ffd7001a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.trick-record:hover:before{left:100%}.trick-record:hover{background:linear-gradient(135deg,#ffffff1f,#ffffff0f);border-color:#ffd70099;box-shadow:0 4px 15px #ffd7004d;transform:translateY(-1px) scale(1.01)}.trick-record.our-team{background:linear-gradient(135deg,#4caf501a,#ffffff08);border-left:3px solid #4caf50}.trick-record.their-team{background:linear-gradient(135deg,#d32f2f1a,#ffffff08);border-left:3px solid #d32f2f}.trick-record.our-team:hover{border-color:#4caf50cc;box-shadow:0 8px 25px #4caf5066}.trick-record.their-team:hover{border-color:#d32f2fcc;box-shadow:0 8px 25px #d32f2f66}.trick-record span{color:#e0e0e0;font-size:.75rem;font-weight:500;text-shadow:0 1px 2px #0000004d}.trick-record .win{animation:winGlow 2s ease-in-out infinite;color:#4caf50;font-weight:700;text-shadow:0 0 10px #4caf5080}.trick-record .lose{animation:loseGlow 2s ease-in-out infinite;color:#d32f2f;font-weight:700;text-shadow:0 0 10px #d32f2f80}@keyframes winGlow{0%,to{text-shadow:0 0 10px #4caf5080}50%{text-shadow:0 0 20px #4caf50cc}}@keyframes loseGlow{0%,to{text-shadow:0 0 10px #d32f2f80}50%{text-shadow:0 0 20px #d32f2fcc}}.contract-info{background:linear-gradient(135deg,#1a1a1a,#2d2d2d)!important;border-color:gold;border-radius:3px;border-style:solid;border-width:1px 14px;box-shadow:0 2px 8px #ffd70033,inset 0 1px 0 #ffd7001a;color:gold;font-size:.9rem;font-weight:700;left:20px;letter-spacing:.3px;margin:5px;max-width:200px;overflow:visible;padding:6px 10px;position:fixed;text-align:center;top:100px;width:auto;z-index:2000}.unified-hand-area{animation:slideUp .5s ease-out;background:linear-gradient(0deg,rgba(0,0,0,.805),#fff0,#0000);bottom:0;left:0;padding:10px 0 20px;right:0;z-index:1000}.hand-player-and-room-info,.unified-hand-area{align-items:center;display:flex;justify-content:center;position:fixed}.hand-player-and-room-info{background:#0000;border-radius:4px;bottom:20px;flex-direction:column;left:20px;padding:2px 4px;z-index:1002}.hand-card{align-items:center;border:1px solid #333;border-radius:4px;box-shadow:0 1px 3px #0000004d;display:flex;font-size:12px;font-weight:700;height:56px;justify-content:center;transition:transform .2s ease;width:40px}.hand-card.red{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff}.hand-card.black{background:linear-gradient(135deg,#4a4a4a,#2c2c2c);color:#fff}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (max-height:500px){.hand-player-and-room-info{display:none!important}.player{height:80px;max-width:130px}.hand-container{gap:2px!important;max-width:90vw!important;overflow-x:visible!important;padding:3px!important;width:90vw!important}.unified-hand-area{align-items:center!important;justify-content:flex-start!important;max-width:100vw!important;min-height:60px!important;padding:5px 0 10px!important;width:100vw!important}.contract-info{font-size:.5rem!important;font-weight:700!important;left:15px!important;top:10px!important}.player.player-shining{box-shadow:0 0 8px #4ecdc44d,0 2px 4px #0003,inset 0 1px 0 #fff3!important}.room-header{min-height:75px!important}.status-text{font-size:.6rem!important}.game-actions{margin:5px!important}.team-results{display:none!important}.game-ended{padding:10px!important}.game-actions button{border-radius:8px!important;font-size:.7rem!important;height:32px!important;min-width:60px!important;padding:6px 12px!important}.contract-result{border-radius:6px!important;box-shadow:0 2px 8px #ffd70033,0 1px 3px #0000004d!important;box-sizing:border-box!important;flex-direction:row!important;gap:12px!important;height:100%!important;justify-content:space-between!important;margin:5px auto!important;max-width:80vw!important;min-height:40px!important;padding:8px 16px!important;width:80vw!important}.contract-result,.contract-result .result-banner{align-items:center!important;display:flex!important}.contract-result .result-banner{border-radius:4px!important;flex-shrink:0!important;font-size:.7rem!important;height:90%!important;justify-content:center!important;min-width:50px!important;padding:4px 8px!important}.contract-result .result-banner h4{letter-spacing:20px!important;line-height:1.2!important;writing-mode:vertical-rl!important}.contract-result .result-details{align-items:center!important;box-sizing:border-box!important;display:flex!important;flex:1 1!important;flex-direction:row!important;gap:8px!important;height:100%!important;margin:0!important;overflow:hidden!important;padding:0!important;width:100%!important}.trick-records{height:210px!important;margin:0 auto!important;overflow-y:auto!important;width:80vw!important}.contract-result:after,.contract-result:before,.trick-records:before{display:none!important}}.offline-indicator:before{animation:fadeIn .3s ease-out;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);background:#0000004d;content:"";height:200vh;left:-50vw;pointer-events:none;position:fixed;top:-50vh;width:200vw;z-index:-1}.offline-indicator{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #ffffff4d;border-radius:20px;box-shadow:0 8px 32px #0003,0 2px 8px #0000001a,inset 0 1px 0 #fff3;font-size:16px;font-weight:500;left:50%;max-width:320px;min-width:280px;padding:20px 32px;position:fixed;text-align:center;top:50%;transform:translate(-50%,-50%);transition:all .4s cubic-bezier(.4,0,.2,1);z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.offline-indicator.offline{background:#dc2626f2;border:1px solid #b91c1c4d;color:#fff}.offline-indicator.online{background:#3ee88df2;border:1px solid #2ecc714d;color:#fff}.indicator-content{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center}.indicator-content i{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));font-size:24px}.indicator-text{font-size:16px;font-weight:600;letter-spacing:.5px;text-shadow:0 1px 2px #0000004d}.indicator-subtitle{font-size:12px;font-weight:400;margin-top:4px;opacity:.8;text-shadow:0 1px 2px #0000004d}@media (max-width:480px){.offline-indicator{border-radius:16px;font-size:14px;max-width:280px;min-width:240px;padding:16px 24px}.indicator-content i{font-size:20px}.indicator-text{font-size:14px}.indicator-subtitle{font-size:11px}}@media (min-width:481px) and (max-width:768px){.offline-indicator{max-width:360px;min-width:300px;padding:18px 28px}}@media (min-width:769px){.offline-indicator{max-width:400px;min-width:320px;padding:24px 36px}.indicator-content i{font-size:28px}.indicator-text{font-size:18px}}.music-control{align-items:center;display:flex;gap:8px;position:relative;z-index:99999!important}.music-toggle-btn{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:linear-gradient(145deg,#d4af3733,#e6c5474d 50%,#d4af3733);border:1px solid #d4af3766;border-radius:8px;color:#766220;cursor:pointer;display:flex;font-size:14px;height:36px;justify-content:center;min-width:36px;padding:8px 12px;transition:all .3s ease}.music-toggle-btn:hover{background:linear-gradient(145deg,#d4af3766,#e6c54780 50%,#d4af3766);border-color:#d4af3799;box-shadow:0 4px 12px #d4af374d;transform:translateY(-1px)}.music-toggle-btn:active{box-shadow:0 2px 6px #d4af3733;transform:translateY(0)}.music-toggle-btn i{text-shadow:0 0 4px #d4af3780}@media (max-width:768px){.music-toggle-btn{font-size:12px;min-height:32px;min-width:32px;padding:6px 10px}}@media (max-width:480px){.music-toggle-btn{font-size:12px;min-height:32px;min-width:32px;padding:6px 10px}}
/*# sourceMappingURL=main.d4066e52.css.map*/