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-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)}button:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}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-width:768px){.App-header{padding:25px 15px}.casino-brand{gap:15px}.symbol{font-size:1.2rem}.app-title{font-size:1.47rem;letter-spacing:2px}.header-subtitle{font-size:1rem;letter-spacing:1px}button{padding:10px 20px}button,input{font-size:14px}input{padding:10px 14px}}@media (max-width:480px){.App-header{padding:20px 10px}.casino-brand{flex-direction:column;gap:10px}.brand-symbols{gap:6px}.symbol{font-size:1rem}.app-title{font-size:1.2rem;letter-spacing:1px}.header-subtitle{font-size:.9rem}}.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}.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-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 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}.dice-btn{align-items:center;border:none;border-radius:8px;box-shadow:0 4px 8px #d4af374d,inset 0 1px 0 #ffffff4d;cursor:pointer;display:flex;font-size:.8rem;height:27px;justify-content:center;position:absolute;right:8px;transition:all .3s ease;width:27px}.dice-btn:hover{box-shadow:0 6px 12px #d4af3780,inset 0 1px 0 #fff6;transform:translateY(-2px) rotate(10deg)}.dice-btn:active{transform:translateY(0) rotate(0deg)}.join-btn{align-items:center;background:linear-gradient(145deg,#e98e27,#e6c547 50%,#e98e27);border:none;border-radius:12px;box-shadow:0 8px 16px #d4af3766,inset 0 1px 0 #ffffff4d;color:#1a1a1a;cursor:pointer;display:flex;font-size:.87rem;font-weight:700;gap:7px;justify-content:center;letter-spacing:1px;overflow:hidden;padding:12px 20px;position:relative;transition:all .3s ease}.join-btn:hover:before{left:100%}.join-btn:hover{animation:buttonPulse .6s ease-in-out;background:linear-gradient(145deg,#f0a020,#f4d03f 50%,#f0a020);box-shadow:0 12px 24px #d4af37cc,0 0 20px #d4af3766,inset 0 1px 0 #fff9;transform:translateY(-3px) scale(1.05)}.join-btn:active{transform:translateY(-1px)}.btn-text{position:relative;z-index:1}.btn-icon{animation:arrowPulse 1.5s ease-in-out infinite;font-size:.94rem;font-weight:700}@keyframes arrowPulse{0%,to{opacity:.8;transform:translateX(0)}50%{opacity:1;transform:translateX(5px)}}.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)}}.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-width:768px){.lobby{padding:15px}.lobby-container{max-width:100%;padding:27px 20px}.casino-title{font-size:1.2rem;letter-spacing:2px}.lobby-title{font-size:1.47rem}.casino-input{font-size:.67rem;padding:11px 12px}.join-btn{font-size:.8rem;padding:11px 17px}.card-symbols{gap:10px}.card-symbols span{font-size:1rem}.marquee-container{height:40px}.marquee-text{font-size:.67rem}.marquee-content{gap:20px;padding:0 10px}}@media (max-width:480px){.lobby-container{padding:20px 13px}.casino-logo{gap:7px}.card-symbol{font-size:1.34rem}.casino-title{font-size:1rem;letter-spacing:1px}.lobby-title{font-size:1.21rem}.input-container{flex-direction:column;gap:7px}.dice-btn{height:30px;position:static;width:100%}.marquee-container{height:34px}.marquee-text{font-size:.6rem}.marquee-content{gap:13px;padding:0 7px}}.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}.waiting-room .players-container{flex-direction:row;gap:10px;margin-bottom:20px;max-width:100%;min-height:168px;overflow:hidden;padding:20px}.waiting-room .player,.waiting-room .players-container{align-items:center;display:flex;justify-content:center;position:relative}.waiting-room .player{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-sizing:border-box;flex-direction:column;flex-shrink:0;height:134px;padding:13px;transition:all .3s ease;width:161px}.waiting-room .ready-text{font-size:.5rem}.waiting-room .player.player-shining .ready-text{color:#85e4d6;font-size:.7rem;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;margin-bottom:20px;padding:27px;text-align:center}.waiting-section p{color:#ffffffe6;font-size:.65rem;margin-bottom:13px}.button-container{align-items:center;display:flex;flex-direction:column;gap:13px;margin:0 auto;max-width:268px}.main-action,.secondary-action{display:flex;justify-content:center;width:100%}.secondary-action{position:relative}.secondary-action:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:1px;left:50%;position:absolute;top:-10px;transform:translateX(-50%);width:40px}.ready-btn{align-items:center;background:linear-gradient(45deg,#4ecdc4,#44a08d);border:none;border-radius:25px;box-shadow:0 6px 20px #4ecdc466;color:#fff;cursor:pointer;display:flex;font-size:.5rem;font-weight:600;gap:5px;justify-content:center;min-width:107px;overflow:hidden;padding:11px 21px;position:relative;text-align:center;transition:all .3s ease}.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:scale(1.1)}.cancel-ready-btn{align-items:center;background:linear-gradient(45deg,#ff9f6b,#ee5a24);border:none;border-radius:25px;box-shadow:0 6px 20px #ff6b6b66;color:#fff;cursor:pointer;display:flex;font-size:.5rem;font-weight:600;gap:5px;justify-content:center;min-width:107px;overflow:hidden;padding:11px 21px;position:relative;text-align:center;transition:all .3s ease}.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:scale(1.1)}.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)}@media (max-width:768px){.button-container{gap:10px;max-width:201px}.cancel-ready-btn,.ready-btn{font-size:.67rem;min-width:94px;padding:9px 19px}.leave-btn{font-size:.57rem;min-width:67px;padding:5px 11px}}@media (max-width:480px){.button-container{gap:8px;max-width:168px}.cancel-ready-btn,.ready-btn{font-size:.64rem;min-width:80px;padding:8px 16px}.leave-btn{font-size:.54rem;min-width:60px;padding:4px 8px}}.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:0 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}.player-info-container.winner-info-glow{background:none;border:none}.player-name.winner-name-glow{color:gold;font-weight:700}.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 h3{font-size:1.2rem}.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}.hand-main-area{max-width:90vw}.playing-controls-area{align-items:center;animation:slideUp .5s ease-out;background:#0000;bottom:160px;display:flex;justify-content:center;left:0;min-height:120px;padding:20px 0 0;position:fixed;right:0;z-index:1001}.hand-card-3d{font-size:1.3rem}.turn-indicator-3d{border-radius:20px;box-shadow:0 4px 15px #667eea4d;font-size:.9rem;margin-top:10px;padding:8px 16px}@media (max-width:768px){.game-board{gap:15px;grid-template-areas:"top" "left" "center" "right" "bottom";grid-template-columns:1fr;grid-template-rows:auto auto auto auto auto;min-height:350px}.player.bottom,.player.left,.player.right,.player.top{align-self:center;justify-self:center;transform:none}.player{max-width:300px;width:100%}.game-section{gap:20px;grid-template-columns:1fr}.card{font-size:1rem;height:70px;width:50px}.bidding-result-display{font-size:13px;left:10px;max-width:none;min-width:auto;padding:14px 16px;position:absolute;right:10px;top:10px;width:auto}}.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:100%}.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%}.bidding-board{grid-gap:20px;align-items:start;display:grid;font-family:Arial,sans-serif;gap:20px;grid-template-areas:". top ." "left center right" ". bottom .";grid-template-columns:1fr 400px 1fr;grid-template-rows:auto 1fr auto;height:70vh;justify-items:start;margin:0 auto;max-width:1000px;overflow:hidden;padding:20px;width:100%}.bidding-board,.bidding-player{box-sizing:border-box;position:relative}.bidding-player{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(120deg,#9b9898,#58575700 20%,#58575700);border:1px solid #fff3;border-bottom:4px solid #000;border-radius:15px;box-shadow:0 2px 4px #0000001a,inset 0 1px 0 #ffffff1a;display:flex;flex-direction:column;height:80px;justify-content:center;padding:16px;transition:all .3s ease;width:134px}.bidding-player:hover{box-shadow:0 4px 8px #0003,;transform:translateY(-5px)}.bidding-player.current-bidder{background:linear-gradient(135deg,#4ecdc4cc,#4ecdc44d 40%,#58575700);border:2px solid #4ecdc4;border-bottom:4px solid #2c5c59;box-shadow:0 0 20px #4ecdc466,0 4px 8px #0003,inset 0 1px 0 #ffffff4d;transform:scale(1.05)}.bidding-player.left{align-self:start;grid-area:left;justify-self:end}.bidding-player.top{align-self:end;flex-direction:row;grid-area:top;justify-self:center}.bidding-player.right{align-self:start;grid-area:right;justify-self:start}.bidding-player.bottom{display:none}.bidding-player-info{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center;width:100%}.bidding-player .player-name{color:#fff;font-size:1.2rem;font-weight:600;line-height:1.2;margin:0 0 8px}.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-container{margin:0 auto 20px;max-width:800px}.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;gap:15px}.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:27px;justify-content:center;text-align:center;transition:all .2s ease;width:47px}.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-width:768px){.bidding-board{gap:15px;grid-template-columns:1fr;grid-template-rows:auto 1fr;height:70vh;padding:15px}.bidding-player.left,.bidding-player.right,.bidding-player.top{display:flex;flex-direction:row;grid-column:1;grid-row:1;justify-content:space-around;margin-bottom:10px;padding:10px}.bidding-center{grid-column:1;grid-row:2;min-height:80px;min-width:100%;padding:16px;width:100%}.bid-selector{flex-direction:column;gap:20px}.level-selector,.suit-selector{flex-direction:row;gap:10px;justify-content:center}.level-selector label,.suit-selector label{font-size:.9em;min-width:40px}.hand-container{flex-wrap:wrap;max-height:200px;overflow-y:auto}.hand-card{font-size:1.4rem;height:90px;width:65px}.hand-card:nth-child(n){transform:none!important}.bidding-controls{padding:15px}}.player{background:linear-gradient(120deg,#9b9898,#58575700 20%,#58575700)!important;border:1px solid #fff3!important;border-bottom:4px solid #000!important;box-shadow:0 2px 4px #0000001a,inset 0 1px 0 #ffffff1a!important}.player:hover{box-shadow:0 4px 8px #0003,inset 0 1px 0 #fff3}.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;transform:scale(1.05)}.game-room{display:flex;flex-direction:column;margin:0 auto;max-width:800px;overflow:hidden;padding:20px}.game-room,.game-room.bidding-mode{height:100vh}.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;margin-bottom:15px;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:.75rem;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{animation:avatarGlow 3s ease-in-out infinite;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}@keyframes avatarGlow{0%,to{box-shadow:0 0 20px #ffd70066,0 4px 12px #0000004d,inset 0 2px 4px #fff3}50%{box-shadow:0 0 30px #ffd70099,0 6px 16px #0006,inset 0 2px 4px #ffffff4d}}.player-avatar:before{animation:rotate 4s linear infinite;background:linear-gradient(45deg,gold,#ffb300,#ff8f00,gold);border-radius:50%;bottom:-3px;content:"";left:-3px;position:absolute;right:-3px;top:-3px;z-index:-1}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.player-details{display:flex;flex-direction:column;gap:8px}.player-name-display{animation:nameShimmer 2s ease-in-out infinite;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}@keyframes nameShimmer{0%,to{text-shadow:0 0 10px #ffd70080,0 2px 4px #00000080}50%{text-shadow:0 0 20px #ffd700cc,0 2px 4px #00000080}}.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%}@keyframes shimmer{0%{left:-100%;opacity:0}50%{opacity:1}to{left:100%;opacity:0}}@keyframes casinoSpin{0%,to{transform:rotate(0deg)}25%{transform:rotate(5deg)}75%{transform:rotate(-5deg)}}.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}.status-icon{animation:iconPulse 2s ease-in-out infinite;font-size:1.2rem}@keyframes iconPulse{0%,to{filter:drop-shadow(0 0 5px rgba(255,215,0,.5));transform:scale(1)}50%{filter:drop-shadow(0 0 10px rgba(255,215,0,.8));transform:scale(1.1)}}@keyframes textGlow{0%,to{text-shadow:0 0 10px #ffd70080,0 2px 4px #00000080}50%{text-shadow:0 0 20px #ffd700cc,0 2px 4px #00000080}}.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)}}.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}}.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}.players-container{grid-gap:20px;align-items:center;display:grid;gap:20px;grid-template-areas:". top ." "left . right" ". bottom .";grid-template-columns:1fr auto 1fr;grid-template-rows:auto 1fr auto;justify-items:center;margin-bottom:30px;min-height:400px;position:relative}.player.top{align-self:end;grid-area:top;justify-self:center}.player.right{align-self:center;grid-area:right;justify-self:end}.player.left{align-self:center;grid-area:left;justify-self:start}.player.bottom{align-self:start;grid-area:bottom;justify-self:center}.player{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:15px;box-sizing:border-box;display:flex;flex-direction:column;height:120px;justify-content:center;padding:16px;position:relative;transition:all .3s ease;width:200px}.player:hover{transform:translateY(-5px)}.current-player{background:#4ecdc426;border:3px solid #4ecdc4;box-shadow:0 0 25px #4ecdc466;transform:scale(1.05)}.player-info-container{align-items:center;display:flex;flex-direction:column;gap:8px;height:100%;justify-content:center;text-align:center;width:100%}.player h3{color:#fff;font-weight:600;margin:0 0 8px}.player h3,.player p{font-size:.85rem;line-height:1.2}.player p{color:#fffc;margin:3px 0}.player-label{margin-bottom:6px}.other-label{background:#fff3;color:#ffffffe6;font-size:.5rem}.other-label,.waiting-label{border-radius:12px;font-weight:500;padding:4px 8px}.waiting-label{background:#ffffff1a;border:1px solid #fff3;color:#ffffffb3;font-size:.8rem}.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}.turn-indicator{background:linear-gradient(45deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:inline-block;font-weight:700;margin-top:8px;padding:6px 12px}.game-ended{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;padding:40px;text-align:center}.game-ended h3{color:#fff;font-size:1.5rem;margin-bottom:20px}.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{align-items:flex-end;gap:8px;margin:0 auto;max-width:1200px;min-height:120px;padding:0 20px}.hand-card-3d{align-items:center;animation:cardDeal .6s ease-out;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #fff;border-radius:8px;box-shadow:0 4px 8px #0000004d;color:#333;cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;height:95px;justify-content:center;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:pulse 2s infinite;background:linear-gradient(45deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 2px 8px #667eea4d;color:#fff;display:inline-block;font-size:.6rem;font-weight:700;margin-top:6px;padding:5px 10px}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@media (max-width:768px){.game-room{padding:10px}.room-header{gap:20px;grid-template-columns:1fr;padding:20px;text-align:center}.header-center,.header-left,.header-right{align-self:center;justify-self:center}.player-info,.room-info{flex-direction:column;gap:15px;text-align:center}.player-info{padding:5px}.player-avatar{font-size:2.4rem;height:60px;width:60px}.player-name-display{font-size:1.2rem}.status-indicator{font-size:.9rem}.count-number,.room-number{font-size:.9rem;padding:6px 12px}.game-section{gap:20px;grid-template-columns:1fr}.players-container{gap:15px;grid-template-areas:"top" "left" "right" "bottom";grid-template-columns:1fr;grid-template-rows:auto auto auto auto;min-height:auto}.player.bottom,.player.left,.player.right,.player.top{align-self:center;justify-self:center;transform:none}.player{max-width:300px;width:100%}.card{font-size:.85rem;height:70px;width:50px}}.game-ended{align-items:center;animation:gameEndPulse 6s ease-in-out infinite;background:linear-gradient(135deg,#0a0a0a,#1a1a1a 50%,#0a0a0a);display:flex;flex-direction:column;justify-content:center;min-height:70vh;padding:40px 20px;position:relative}@keyframes gameEndPulse{0%,to{box-shadow:0 0 20px #ffd7001a;transform:scale(1)}50%{box-shadow:0 0 30px #ffd70033;transform:scale(1.01)}}.game-ended:before{background:radial-gradient(circle at 25% 25%,#ffd7000d 0,#0000 50%),radial-gradient(circle at 75% 75%,#2e7d320d 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}@keyframes floatingCards{0%,to{opacity:.3;transform:translateY(0) rotate(0deg)}25%{opacity:.5;transform:translateY(-10px) rotate(5deg)}50%{opacity:.3;transform:translateY(0) rotate(0deg)}75%{opacity:.5;transform:translateY(10px) rotate(-5deg)}}.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);border-color:gold;border-radius:3px;border-style:solid;border-width:1px 14px;box-shadow:0 4px 15px #ffd70033,inset 0 1px 0 #ffd7001a;color:gold;font-size:.9rem;font-weight:700;letter-spacing:.5px;margin:20px 0;overflow:hidden;padding:15px 20px;position:relative;text-align:center;width:100%}.unified-hand-area{animation:slideUp .5s ease-out;background:linear-gradient(0deg,rgba(0,0,0,.805),#fff0,#0000);bottom:0;left:0;min-height:150px;padding:15px 0 25px;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-main-area{display:flex;justify-content:center;width:100%}.hand-container{flex-wrap:nowrap;gap:4px;padding:6px}.hand-card,.hand-container{align-items:center;display:flex;justify-content:center}.hand-card{border:1px solid #333;border-radius:4px;box-shadow:0 1px 3px #0000004d;font-size:12px;font-weight:700;height:56px;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)}}
/*# sourceMappingURL=main.893e4ce5.css.map*/