*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--felt-green: #1a7a4c;--felt-dark: #0d4e30;--felt-border: #0a2e1c;--card-bg: #fffef8;--card-shadow: rgba(0, 0, 0, .3);--gold: #d4a843;--gold-light: #f0d078;--gold-dark: #a67c2e;--sidebar-bg: #0c1219;--sidebar-text: #e0e8f0;--text-primary: #060a10;--accent-blue: #2980b9;--accent-red: #e74c3c;--success: #27ae60;--warning: #f39c12;--error: #e74c3c;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .15);--shadow-md: 0 4px 16px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4)}html,body,#root{height:100%;width:100%;overflow:hidden;touch-action:manipulation}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--text-primary);color:var(--sidebar-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{height:100dvh;height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;gap:14px;padding:12px 28px;background:linear-gradient(180deg,#0a1018,#0d1520);border-bottom:1px solid rgba(212,168,67,.2);box-shadow:0 2px 16px #00000080,inset 0 -1px #d4a84314;position:relative;z-index:10}.app-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(212,168,67,.4) 50%,transparent 100%)}.app-header h1{font-size:24px;font-weight:800;background:linear-gradient(135deg,var(--gold-light) 0%,var(--gold) 50%,var(--gold-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:3px;text-transform:uppercase}.subtitle{font-size:11px;color:#5a6a7a;font-weight:500;letter-spacing:1px;text-transform:uppercase}.game-table{flex:1;display:flex;min-height:0}.table-felt{flex:1;min-height:0;background:radial-gradient(ellipse at 50% 50%,#1f9058,#177a45 30%,#0f5c33 55%,#0a4426 75%,#062d19);border-right:1px solid rgba(0,0,0,.4);display:grid;grid-template-rows:auto 1fr minmax(120px,auto);grid-template-columns:auto 1fr auto;grid-template-areas:". top ." "left center right" ". bottom .";padding:16px;position:relative}.table-felt:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 50%,transparent 25%,rgba(0,0,0,.5) 100%),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none}.table-felt:after{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;border:3px solid rgba(212,168,67,.15);border-radius:50%/45%;pointer-events:none;box-shadow:inset 0 0 80px #00000040,0 0 40px #d4a8430d,inset 0 0 120px #0028144d}.table-ambient-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(240,208,120,.05) 0%,rgba(39,174,96,.03) 40%,transparent 70%);pointer-events:none;animation:ambientPulse 5s ease-in-out infinite;z-index:0}@keyframes ambientPulse{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}}.table-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.table-particle{position:absolute;width:2px;height:2px;border-radius:50%;background:#d4a84326;animation:particleFloat linear infinite}@keyframes particleFloat{0%{transform:translateY(100%) translate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100vh) translate(30px);opacity:0}}.table-trump-badge{position:absolute;top:14px;left:50%;transform:translate(-50%);z-index:5;display:flex;align-items:center;gap:6px;padding:6px 18px;border-radius:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:trumpBadgeAppear .4s cubic-bezier(.16,1,.3,1)}.table-trump-badge.trump-red{background:#e74c3c33;border:1.5px solid rgba(231,76,60,.5);box-shadow:0 0 20px #e74c3c26}.table-trump-badge.trump-black{background:#34495e4d;border:1.5px solid rgba(176,196,222,.4);box-shadow:0 0 20px #b0c4de1a}.table-trump-symbol{font-size:22px;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.table-trump-badge.trump-red .table-trump-symbol{color:#ff6b6b}.table-trump-badge.trump-black .table-trump-symbol{color:#dce6f0}@keyframes trumpBadgeAppear{0%{opacity:0;transform:translate(-50%) translateY(-8px) scale(.9)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.opponent-hand{display:flex;flex-direction:column;align-items:center;gap:6px;padding:4px}.opponent-top{grid-area:top}.opponent-left{grid-area:left;justify-content:center}.opponent-right{grid-area:right;justify-content:center}.opponent-label{font-size:11px;font-weight:600;color:#ffffffb3;text-shadow:0 1px 3px rgba(0,0,0,.5);display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.5px}.opponent-active .opponent-label{color:var(--gold-light);text-shadow:0 0 10px rgba(212,168,67,.4)}.partner-badge{font-size:9px;background:#27ae6040;border:1px solid rgba(39,174,96,.5);padding:2px 7px;border-radius:10px;color:#6ede9e;font-weight:700;letter-spacing:.3px}.bid-status{position:absolute;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.3px;animation:bidStatusIn .3s ease;z-index:10;white-space:nowrap}.bid-status-thinking{background:#2980b933;border:1px solid rgba(41,128,185,.4);color:#7ec8e3}.bid-status-bid{background:#d4a84333;border:1px solid rgba(212,168,67,.5);color:var(--gold-light)}.bid-status-passed{background:#ffffff0f;border:1px solid rgba(255,255,255,.15);color:#fff6}.bid-thinking{display:flex;gap:3px;align-items:center}.bid-thinking-dot{width:5px;height:5px;border-radius:50%;background:#7ec8e3;animation:bidThink 1.4s ease-in-out infinite}.bid-thinking-dot:nth-child(2){animation-delay:.2s}.bid-thinking-dot:nth-child(3){animation-delay:.4s}.bid-announced{font-size:13px;font-weight:700}.bid-passed{font-style:italic;opacity:.7}@keyframes bidStatusIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes bidThink{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}.last-trick-btn{position:absolute;bottom:-8px;right:-8px;padding:4px 10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;background:#141e2bd9;border:1px solid rgba(255,255,255,.15);border-radius:12px;color:#e0e8f0b3;cursor:pointer;transition:all .2s;user-select:none;-webkit-user-select:none;z-index:5}.last-trick-btn:hover{border-color:#d4a84366;color:#e0e8f0f2}.last-trick-btn:active{transform:scale(.95)}.last-trick-btn-center{position:relative;bottom:auto;right:auto;padding:8px 16px;font-size:11px}.trick-card-last{opacity:.7;animation:lastTrickIn .2s ease}.trick-card-faded{opacity:.3}@keyframes lastTrickIn{0%{opacity:0;transform:scale(.9)}to{opacity:.7;transform:scale(1)}}.opponent-cards{display:flex}.opponent-cards-left,.opponent-cards-right{flex-direction:column}.card{width:72px;height:100px;background:linear-gradient(160deg,#fff,#faf8f4 40%,#f2efe8);border-radius:8px;border:1px solid rgba(0,0,0,.1);box-shadow:0 2px 4px #0000001f,0 4px 14px #0000001a,0 8px 20px #0000000f,inset 0 1px #fffffff2;position:relative;-webkit-user-select:none;user-select:none;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s ease}.card-table{width:68px;height:96px;box-shadow:0 4px 12px #0006,0 8px 28px #00000040,inset 0 1px #fffffff2}.card-table .card-rank{font-size:13px}.card-table .card-suit-small{font-size:10px}.card-table .card-center{font-size:26px}.card-small{width:56px;height:78px}.card-small .card-rank{font-size:11px}.card-small .card-suit-small{font-size:9px}.card-small .card-center{font-size:20px}.card-back{background:linear-gradient(145deg,#1c5a8c,#1a4470 40%,#112d50);border:2px solid #0d2440;box-shadow:0 2px 8px #0006,0 4px 16px #0003,inset 0 1px #ffffff0f}.card-back-pattern{position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:4px;border:1.5px solid rgba(212,168,67,.25);background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(212,168,67,.06) 4px,rgba(212,168,67,.06) 8px),repeating-linear-gradient(-45deg,transparent,transparent 4px,rgba(212,168,67,.04) 4px,rgba(212,168,67,.04) 8px)}.card-opponent{width:40px;height:56px}.card-corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1}.card-corner-top{top:5px;left:6px}.card-corner-bottom{bottom:5px;right:6px;transform:rotate(180deg)}.card-rank{font-size:14px;font-weight:800}.card-suit-small{font-size:11px}.card-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:28px}.card-playable{box-shadow:0 0 0 2px var(--gold),0 0 20px #d4a84380,0 4px 12px #0003;animation:cardGlow 2s ease-in-out infinite;transform:translateY(-8px);cursor:pointer}@keyframes cardGlow{0%,to{box-shadow:0 0 0 2px var(--gold),0 0 14px #d4a84366,0 4px 12px #0003}50%{box-shadow:0 0 0 3px var(--gold-light),0 0 28px #d4a84399,0 6px 16px #00000040}}.card-clickable{cursor:pointer;pointer-events:auto}.card-clickable:hover{transform:translateY(-18px) scale(1.06);box-shadow:0 16px 32px #00000059,0 0 0 2px var(--gold),0 0 24px #d4a84380;z-index:10}.trick-area{grid-area:center;position:relative;display:flex;align-items:center;justify-content:center;min-height:240px}.trick-table-surface{position:relative;width:220px;height:200px;display:flex;align-items:center;justify-content:center}.trick-card{position:absolute;transition:all .35s cubic-bezier(.16,1,.3,1);z-index:2}.trick-card-enter{animation:trickCardDeal .3s cubic-bezier(.16,1,.3,1) both}@keyframes trickCardDeal{0%{opacity:0;transform:translate(var(--deal-x, 0),var(--deal-y, 0)) scale(.7)}to{opacity:1;transform:translate(0) scale(1)}}.trick-card-north{top:0;left:50%;transform:translate(-50%);--deal-y: -30px}.trick-card-south{bottom:0;left:50%;transform:translate(-50%);--deal-y: 30px}.trick-card-east{right:0;top:50%;transform:translateY(-50%);--deal-x: 30px}.trick-card-west{left:0;top:50%;transform:translateY(-50%);--deal-x: -30px}.trick-winner .card{box-shadow:0 0 0 3px var(--gold),0 0 30px #d4a843b3,0 4px 16px #0000004d;animation:winnerPulse 1s ease-in-out 2}@keyframes winnerPulse{0%,to{box-shadow:0 0 0 3px var(--gold),0 0 20px #d4a84380,0 4px 16px #0000004d}50%{box-shadow:0 0 0 4px var(--gold-light),0 0 40px #d4a843cc,0 4px 16px #0000004d}}.trick-empty{color:#ffffff40;font-size:13px;font-style:italic;letter-spacing:.3px;text-shadow:0 1px 3px rgba(0,0,0,.3)}.player-hand{grid-area:bottom;display:flex;justify-content:center;padding:8px 0;perspective:800px;position:relative;z-index:5}.hand-card-wrapper{position:relative;transition:transform .15s ease;z-index:1}.hand-card-wrapper:hover{z-index:10}.bottom-area{grid-area:bottom;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative;padding-bottom:8px;z-index:5}.sidebar{width:290px;background:linear-gradient(180deg,#0c1219,#090f16);padding:16px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;border-left:1px solid rgba(212,168,67,.06)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#d4a84333;border-radius:2px}.scoreboard{background:linear-gradient(135deg,#0000004d,#0000002e);border-radius:var(--radius-md);padding:16px;border:1px solid rgba(212,168,67,.06);box-shadow:inset 0 1px #ffffff05}.scoreboard-title{font-size:11px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px;text-align:center}.scoreboard-grid{display:flex;align-items:center;gap:12px}.score-team{flex:1;text-align:center}.score-label{font-size:10px;color:#6a7a8a;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.score-value{font-size:34px;font-weight:800;color:#f0f4f8;line-height:1;text-shadow:0 1px 3px rgba(0,0,0,.3)}.score-tricks{font-size:11px;color:#5a6a7a;margin-top:5px;font-weight:500}.score-hook{font-size:10px;color:var(--warning);font-weight:700;margin-top:4px;text-transform:uppercase;letter-spacing:.5px;animation:hookPulse 1.5s ease-in-out infinite}@keyframes hookPulse{0%,to{opacity:.7}50%{opacity:1}}.score-divider{width:1px;height:55px;background:linear-gradient(180deg,transparent,rgba(212,168,67,.3),transparent)}.trump-banner{padding:12px 16px;border-radius:var(--radius-md);text-align:center;margin-bottom:12px;animation:trumpBannerAppear .5s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.trump-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.06) 0%,transparent 50%);pointer-events:none}.trump-banner.trump-red{background:linear-gradient(135deg,#e74c3c26,#c0392b14);border:1.5px solid rgba(231,76,60,.4);box-shadow:0 0 20px #e74c3c1a,inset 0 0 20px #e74c3c0d}.trump-banner.trump-black{background:linear-gradient(135deg,#34495e40,#2c3e501f);border:1.5px solid rgba(176,196,222,.3);box-shadow:0 0 20px #b0c4de14,inset 0 0 20px #b0c4de08}.trump-banner-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:2px;margin-bottom:4px;opacity:.7}.trump-banner.trump-red .trump-banner-label{color:#ff8a80}.trump-banner.trump-black .trump-banner-label{color:#b0c4de}.trump-banner-suit{font-size:36px;line-height:1.2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.trump-banner.trump-red .trump-banner-suit{color:#ff6b6b;text-shadow:0 0 16px rgba(255,107,107,.4)}.trump-banner.trump-black .trump-banner-suit{color:#e8f0f8;text-shadow:0 0 16px rgba(176,196,222,.3)}.trump-banner-name{font-size:12px;font-weight:700;text-transform:capitalize;letter-spacing:1px;margin-top:2px}.trump-banner.trump-red .trump-banner-name{color:#ff8a80}.trump-banner.trump-black .trump-banner-name{color:#b0c4de}@keyframes trumpBannerAppear{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.round-bonus{text-align:center;font-size:12px;color:var(--warning);font-weight:700;margin-top:8px;padding:4px 8px;background:#f39c1214;border-radius:var(--radius-sm)}.message-box{background:linear-gradient(135deg,#d4a84314,#d4a8430a);border:1px solid rgba(212,168,67,.2);border-radius:var(--radius-md);padding:12px 14px;font-size:13px;line-height:1.5;color:var(--gold-light);animation:fadeIn .3s ease}.bidding-panel{background:linear-gradient(135deg,#0003,#0000001f);border-radius:var(--radius-md);padding:14px;border:1px solid rgba(255,255,255,.05);animation:fadeIn .3s ease}.bidding-panel h3{font-size:12px;font-weight:700;color:var(--gold);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.current-bid,.my-best{font-size:12px;color:#6a7a8a;margin-bottom:6px}.bid-buttons{display:flex;flex-wrap:wrap;gap:8px}.btn{padding:8px 16px;border-radius:var(--radius-sm);border:none;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1)}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,var(--accent-blue),#1a6d9e);color:#fff;width:100%;padding:12px;border-radius:var(--radius-md);box-shadow:0 4px 12px #2980b940}.btn-primary:hover{background:linear-gradient(135deg,#3498db,var(--accent-blue));box-shadow:0 6px 16px #2980b959}.btn-bid{background:linear-gradient(135deg,var(--success),#1e8e4e);color:#fff;box-shadow:0 2px 8px #27ae6033}.btn-bid:hover{box-shadow:0 4px 12px #27ae604d}.btn-pass{background:#ffffff0f;color:#89a;border:1px solid rgba(255,255,255,.1)}.btn-pass:hover{background:#ffffff1a;color:#b0c4de}.btn-suit{padding:8px 14px;background:#ffffff0f;color:#e0e8f0;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm)}.btn-suit:hover{background:#ffffff1f;border-color:#fff3}.btn-suit-clubs,.btn-suit-spades{color:#b0c4de}.btn-suit-hearts,.btn-suit-diamonds{color:#ff8a80}.rules-hint{margin-top:auto;padding:12px;background:#0000001f;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.03)}.rules-hint h4{font-size:10px;font-weight:700;color:#5a6a7a;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.rules-hint p{font-size:11px;color:#4a5a6a;line-height:1.6;margin-bottom:3px}.mobile-info-bar,.mobile-bidding-overlay,.mobile-action-overlay,.mobile-panel-overlay{display:none}@media(max-width:1024px){.sidebar{width:240px;padding:12px;gap:10px}.rules-hint{display:none}.score-value,.trump-banner-suit{font-size:28px}}@media(max-width:768px){.app-header{padding:0 12px;height:32px;min-height:32px}.app-header h1{font-size:13px;letter-spacing:1px}.subtitle,.sidebar{display:none}.game-table{flex-direction:column;min-height:0;height:100%}.table-felt{padding:6px 6px 86px;grid-template-rows:auto minmax(0,1fr);grid-template-areas:". top ." "left center right";overflow:hidden;min-height:0}.table-felt:after{top:4px;right:4px;bottom:4px;left:4px;border-width:1px}.trick-table-surface{width:180px;height:170px}.card-table{width:56px;height:80px}.card-table .card-rank{font-size:11px}.card-table .card-suit-small{font-size:9px}.card-table .card-center{font-size:22px}.bottom-area{position:fixed;bottom:0;left:0;right:0;z-index:40;background:linear-gradient(to top,rgba(10,20,15,.97) 70%,transparent 100%);padding:4px 8px env(safe-area-inset-bottom,6px);display:flex;justify-content:center;align-items:flex-end}.player-hand{padding:2px 0;max-width:100%;justify-content:center;flex-wrap:nowrap}.your-turn-badge{top:-22px}.mobile-info-bar{display:flex;position:absolute;top:8px;right:8px;z-index:20;align-items:center;gap:8px;padding:4px 10px;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;border:1px solid rgba(255,255,255,.1)}.mobile-score{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:700}.mobile-score-us{color:var(--gold-light)}.mobile-score-sep{color:#5a6a7a;font-size:12px}.mobile-score-them{color:#a0b0c0}.mobile-trump{font-size:18px;line-height:1}.mobile-trump.trump-red{color:#ff6b6b}.mobile-trump.trump-black{color:#e0e8f0}.mobile-info-toggle{background:none;border:none;color:#89a;font-size:16px;cursor:pointer;padding:2px 4px;line-height:1}.mobile-panel-overlay{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);align-items:flex-start;justify-content:center;padding:60px 16px 16px;animation:fadeIn .2s ease}.mobile-panel{background:var(--sidebar-bg);border-radius:var(--radius-lg);padding:16px;width:100%;max-width:360px;max-height:70vh;overflow-y:auto;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:12px}.mobile-bidding-overlay{display:block;position:absolute;bottom:auto;top:50%;left:50%;transform:translate(-50%,-50%);z-index:30;width:calc(100% - 24px);max-width:320px;animation:fadeIn .3s ease}.mobile-bidding-overlay .bidding-panel{background:#141e2bf2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(212,168,67,.2);box-shadow:var(--shadow-lg)}.mobile-action-overlay{display:block;position:absolute;bottom:auto;top:50%;left:50%;transform:translate(-50%,-50%);z-index:30;width:calc(100% - 48px);max-width:280px;animation:fadeIn .3s ease}.card{width:52px;height:72px}.card .card-rank{font-size:11px}.card .card-suit-small{font-size:9px}.card .card-center{font-size:20px}.card-corner-top{top:3px;left:4px}.card-corner-bottom{bottom:3px;right:4px}.card-small{width:44px;height:62px}.card-small .card-rank{font-size:10px}.card-small .card-suit-small{font-size:8px}.card-small .card-center{font-size:16px}.card-opponent{width:30px;height:42px}.hand-card-wrapper{margin-left:-12px!important}.hand-card-wrapper:first-child{margin-left:0!important}.card-clickable:hover{transform:translateY(-6px) scale(1.01)}.table-trump-badge{bottom:auto;left:8px;top:8px;transform:none;padding:3px 10px;border-radius:14px}.table-trump-symbol{font-size:16px}.trick-area{min-height:80px}.trick-card-north{top:5px}.trick-card-south{bottom:5px}.trick-card-east{right:10px}.trick-card-west{left:10px}.opponent-label{font-size:10px}.partner-badge{font-size:8px;padding:1px 5px}.opponent-hand{gap:3px;padding:2px;overflow:hidden}.opponent-left,.opponent-right{max-height:100%;overflow:hidden}.lobby-card{padding:32px 24px 28px;border-radius:18px}.lobby-title{font-size:40px;letter-spacing:2px}.lobby-subtitle{font-size:13px}.lobby-emblem{gap:6px}.emblem-suit{font-size:18px}.floating-card{font-size:24px}.lobby-btn{padding:14px 16px;font-size:14px}.lobby-btn-main{padding:16px;font-size:15px}.lobby-divider{margin:16px auto 20px}.btn-header-back,.btn-header-stats{padding:4px 10px;font-size:11px}}@media(max-width:480px){.app-header{height:28px;min-height:28px;padding:0 10px}.app-header h1{font-size:12px;letter-spacing:1px}.table-felt{padding:4px 4px 72px}.table-felt:after{display:none}.card{width:44px;height:62px}.card .card-rank{font-size:10px}.card .card-suit-small{font-size:8px}.card .card-center{font-size:17px}.card-small{width:38px;height:54px}.card-small .card-rank{font-size:9px}.card-small .card-suit-small{font-size:7px}.card-small .card-center{font-size:14px}.card-opponent{width:26px;height:36px}.hand-card-wrapper{margin-left:-14px!important}.hand-card-wrapper:first-child{margin-left:0!important}.trick-area{min-height:100px}.trick-table-surface{width:160px;height:140px}.card-table{width:48px;height:68px}.card-table .card-rank{font-size:10px}.card-table .card-suit-small{font-size:8px}.card-table .card-center{font-size:18px}.opponent-label{font-size:9px}.mobile-info-bar{top:4px;right:4px;padding:3px 8px;gap:6px}.mobile-score{font-size:12px}.mobile-trump{font-size:15px}.lobby-card{padding:24px 20px;border-radius:14px}.lobby-title{font-size:32px}.lobby-form-title{font-size:22px}.lobby-input{padding:12px 14px;font-size:14px}.lobby-btn{padding:12px 14px;font-size:13px;border-radius:10px}.lobby-btn-main{padding:14px;font-size:14px;border-radius:12px}.bid-buttons{gap:6px}.btn-suit,.btn-bid{padding:6px 10px;font-size:12px}.mobile-bidding-overlay{width:calc(100% - 16px)}.bidding-panel{padding:10px}.bidding-panel h3{font-size:11px;margin-bottom:6px}}@media(max-height:500px)and (max-width:900px){.app-header{height:24px;min-height:24px;padding:0 12px}.app-header h1{font-size:12px}.table-felt{padding:4px 4px 64px}.card{width:40px;height:56px}.card .card-rank{font-size:9px}.card .card-suit-small{font-size:7px}.card .card-center{font-size:15px}.card-small{width:34px;height:48px}.card-opponent{width:24px;height:34px}.hand-card-wrapper{margin-left:-10px!important}.hand-card-wrapper:first-child{margin-left:0!important}.trick-area{min-height:60px}.opponent-hand{gap:2px}.opponent-label{font-size:8px}.mobile-bidding-overlay{top:45%}}@media(pointer:coarse){.card-clickable{min-width:44px;min-height:44px}.btn{min-height:44px;padding:10px 16px}.btn-suit{min-height:40px;padding:8px 12px}.mobile-info-toggle{min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}}.dealing-indicator{text-align:center;font-size:14px;color:var(--gold-light);font-weight:600;padding:12px;animation:pulse 1.2s ease-in-out infinite;background:#d4a8430d;border-radius:var(--radius-md);border:1px solid rgba(212,168,67,.1)}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.trick-card{animation:cardDeal .25s cubic-bezier(.16,1,.3,1)}@keyframes cardDeal{0%{opacity:0;transform:translateY(20px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}.card-flip-in{animation:cardFlipIn .4s cubic-bezier(.16,1,.3,1) both}@keyframes cardFlipIn{0%{opacity:0;transform:rotateY(90deg) scale(.8)}to{opacity:1;transform:rotateY(0) scale(1)}}.card-dealing{animation:cardDealFromDeck .3s cubic-bezier(.16,1,.3,1) both}.card-dealt{animation:cardReveal .35s cubic-bezier(.16,1,.3,1) both}@keyframes cardDealFromDeck{0%{opacity:0;transform:translateY(-60px) translate(40px) rotate(-15deg) scale(.6)}to{opacity:1;transform:translateY(0) translate(0) rotate(0) scale(1)}}@keyframes cardReveal{0%{transform:rotateY(180deg) scale(.9)}to{transform:rotateY(0) scale(1)}}.card-deal-anim{animation:cardDealIn .3s cubic-bezier(.16,1,.3,1) both}@keyframes cardDealIn{0%{opacity:0;transform:translateY(-20px) scale(.7)}to{opacity:1;transform:translateY(0) scale(1)}}.score-animated{display:inline-block;transition:transform .2s ease,color .3s ease}.score-changing{color:var(--gold-light);animation:scorePopup .4s cubic-bezier(.16,1,.3,1)}@keyframes scorePopup{0%{transform:scale(1)}40%{transform:scale(1.3)}to{transform:scale(1)}}.trick-card-sweep{animation:trickSweep .4s cubic-bezier(.4,0,.2,1) forwards}@keyframes trickSweep{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(var(--sweep-x, 0),var(--sweep-y, 0)) scale(.6)}}.card-hint-glow{animation:hintPulse 1.5s ease-in-out infinite}@keyframes hintPulse{0%,to{filter:drop-shadow(0 0 4px rgba(212,168,67,.3))}50%{filter:drop-shadow(0 0 12px rgba(212,168,67,.7))}}.opponent-avatar{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:18px;border-radius:50%;background:linear-gradient(145deg,#1e3246e6,#0f1e32e6);border:2px solid rgba(255,255,255,.15);box-shadow:0 2px 8px #0006,inset 0 1px #ffffff14;transition:all .3s cubic-bezier(.16,1,.3,1)}.avatar-active{background:linear-gradient(145deg,#d4a8434d,#a0782833);border-color:var(--gold);box-shadow:0 0 16px #d4a84366,0 2px 8px #0006,inset 0 1px #ffffff1a;animation:seatPulse 2s ease-in-out infinite}@keyframes seatPulse{0%,to{box-shadow:0 0 12px #d4a8434d,0 2px 8px #0006}50%{box-shadow:0 0 24px #d4a84380,0 2px 8px #0006}}.opponent-name{font-size:inherit}.avatar-initial{font-size:14px;font-weight:700;color:#ffffffe6;text-shadow:0 1px 2px rgba(0,0,0,.5);letter-spacing:-.5px}.turn-timer-ring{position:absolute;top:-4px;left:-4px;width:44px;height:44px;transform:rotate(-90deg)}.turn-timer-bg{fill:none;stroke:#ffffff14;stroke-width:2}.turn-timer-progress{fill:none;stroke:var(--gold-light);stroke-width:2.5;stroke-linecap:round;stroke-dasharray:100;stroke-dashoffset:100;animation:timerSpin 1.5s linear infinite}@keyframes timerSpin{0%{stroke-dashoffset:100}to{stroke-dashoffset:0}}.your-turn-badge{position:absolute;top:-32px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#d4a84340,#d4a84314);border:1.5px solid rgba(212,168,67,.5);color:var(--gold-light);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;padding:5px 16px;border-radius:12px;animation:turnBadgePulse 1.5s ease-in-out infinite;box-shadow:0 2px 12px #d4a84333}@keyframes turnBadgePulse{0%,to{opacity:.7}50%{opacity:1;box-shadow:0 0 12px #d4a8434d}}.trick-counter{position:absolute;top:8px;right:8px;display:flex;flex-direction:column;gap:4px;z-index:5}.trick-counter-team{display:flex;align-items:center;gap:6px}.trick-counter-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#ffffff80;width:30px;text-align:right}.trick-pips{display:flex;gap:3px}.trick-pip{width:8px;height:8px;border-radius:50%;background:#ffffff14;border:1px solid rgba(255,255,255,.12);transition:all .3s cubic-bezier(.16,1,.3,1)}.trick-pip-filled{transform:scale(1.1);border-color:transparent}.trick-pip-us{background:var(--gold-light);box-shadow:0 0 6px #d4a84366}.trick-pip-them{background:#e74c3c;box-shadow:0 0 6px #e74c3c66}.bid-history{background:#00000026;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md);padding:10px;margin-bottom:12px}.bid-history-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#fff6;margin-bottom:6px}.bid-history-list{display:flex;flex-direction:column;gap:3px;max-height:100px;overflow-y:auto}.bid-history-entry{display:flex;justify-content:space-between;align-items:center;font-size:11px;padding:3px 6px;border-radius:4px}.bid-history-bid{background:#d4a84314}.bid-history-pass{background:#ffffff05}.bid-history-player{color:#ffffffb3;font-weight:500}.bid-history-action{font-weight:600}.bid-history-bid .bid-history-action{color:var(--gold-light)}.bid-history-pass .bid-history-action{color:#ffffff59;font-style:italic}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000;overflow:hidden}.confetti-particle{position:absolute;border-radius:2px;animation:confettiFall 2s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes confettiFall{0%{transform:translate(0) rotate(0);opacity:1}to{transform:translate(calc(cos(var(--angle)) * var(--speed) * 60px),calc(sin(var(--angle)) * var(--speed) * 60px + 200px)) rotate(720deg);opacity:0}}.mute-btn{position:absolute;bottom:8px;right:8px;width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:#0000004d;color:#fff9;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.mute-btn:hover{background:#00000080;border-color:#fff3;color:#ffffffe6}.lobby{flex:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 30%,rgba(212,168,67,.03) 0%,transparent 50%),radial-gradient(ellipse at 50% 40%,#131e2c,#0a1218,#050a0f);padding:20px;position:relative;overflow:hidden}.lobby-glow{position:absolute;top:25%;left:50%;transform:translate(-50%,-50%);width:700px;height:500px;background:radial-gradient(ellipse,rgba(212,168,67,.04) 0%,transparent 60%);pointer-events:none;animation:lobbyGlowPulse 6s ease-in-out infinite}@keyframes lobbyGlowPulse{0%,to{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.05)}}.floating-cards{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.floating-card{position:absolute;bottom:-60px;font-size:36px;color:#b0c4de0f;animation:floatUp linear infinite;will-change:transform;filter:blur(.5px)}.floating-card-red{color:#f096960f}@keyframes floatUp{0%{transform:translateY(0) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-110vh) rotate(360deg);opacity:0}}.lobby-card{background:linear-gradient(165deg,#142030f7,#0a101afc);border:1px solid rgba(212,168,67,.12);border-radius:28px;padding:52px 44px 40px;max-width:460px;width:100%;text-align:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:relative;z-index:1;box-shadow:0 40px 100px #00000080,0 0 0 1px #ffffff05,inset 0 1px #ffffff0a,inset 0 0 80px #d4a84305;animation:cardAppear .6s cubic-bezier(.16,1,.3,1)}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.lobby-card-form{padding-top:56px}.lobby-emblem{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:14px}.emblem-suit{font-size:24px;color:#b0c4de66;animation:suitPulse 3s ease-in-out infinite;filter:drop-shadow(0 0 4px rgba(176,196,222,.15))}.emblem-suit:nth-child(2){animation-delay:.4s}.emblem-suit:nth-child(3){animation-delay:.8s}.emblem-suit:nth-child(4){animation-delay:1.2s}.emblem-red{color:#f0828266;filter:drop-shadow(0 0 4px rgba(240,130,130,.15))}@keyframes suitPulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.9;transform:scale(1.15)}}.lobby-title{font-size:60px;font-weight:800;background:linear-gradient(135deg,var(--gold-light) 0%,var(--gold) 40%,var(--gold-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px;letter-spacing:4px;filter:drop-shadow(0 2px 12px rgba(212,168,67,.3))}.lobby-subtitle{font-size:14px;color:#6a7f94;margin-bottom:8px;letter-spacing:1px;font-weight:500}.lobby-divider{width:80px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:24px auto 32px;border-radius:1px;opacity:.7}.lobby-buttons{display:flex;flex-direction:column;gap:12px}.lobby-btn{width:100%;padding:16px 20px;font-size:15px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px;border-radius:14px;position:relative;overflow:hidden;transition:all .25s cubic-bezier(.16,1,.3,1)}.lobby-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.12) 0%,transparent 50%);opacity:0;transition:opacity .25s}.lobby-btn:hover:after{opacity:1}.lobby-btn-main{padding:18px 20px;font-size:16px;font-weight:700;border-radius:14px;background:linear-gradient(135deg,#3498db,#2176ad);box-shadow:0 4px 20px #2980b959,inset 0 1px #ffffff26;letter-spacing:.3px}.lobby-btn-main:hover{box-shadow:0 8px 32px #2980b973,inset 0 1px #fff3;transform:translateY(-3px)}.btn-icon{font-size:17px;opacity:.9}.btn-multiplayer{background:linear-gradient(135deg,#2ecc71,#21a65a);color:#fff;box-shadow:0 4px 20px #27ae6040,inset 0 1px #ffffff1f}.btn-multiplayer:hover{background:linear-gradient(135deg,#3cdc80,#27ae60);box-shadow:0 8px 32px #27ae6059,inset 0 1px #ffffff2e;transform:translateY(-3px)}.btn-join{background:#ffffff08;color:#b0c4de;border:1px solid rgba(255,255,255,.08)}.btn-join:hover{background:#ffffff12;border-color:#ffffff2e;transform:translateY(-3px);color:#d0e0f0}.lobby-footer{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:32px;padding-top:20px;border-top:1px solid rgba(212,168,67,.08)}.lobby-link{background:none;border:none;color:var(--gold);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;padding:0;transition:color .15s}.lobby-link:hover{color:var(--gold-light);text-decoration:underline}.lobby-footer-dot{width:3px;height:3px;border-radius:50%;background:#4a5a6a}.lobby-footer-text{font-size:12px;color:#4a5a6a}.form-back-arrow{position:absolute;top:20px;left:24px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#89a;font-size:18px;width:36px;height:36px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.form-back-arrow:hover{background:#ffffff1a;color:#e0e8f0;transform:translate(-2px)}.lobby-form-title{font-size:26px;font-weight:700;color:var(--gold);margin-bottom:6px}.lobby-form-subtitle{font-size:13px;color:#6a7a8a;margin-bottom:24px}.lobby-form{display:flex;flex-direction:column;gap:16px}.input-group{text-align:left}.input-label{display:block;font-size:12px;font-weight:600;color:#7a8fa3;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.lobby-input{width:100%;padding:14px 16px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#f0f4f8;font-family:inherit;font-size:15px;outline:none;transition:border-color .2s,box-shadow .2s}.lobby-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px #d4a8431a}.lobby-input::placeholder{color:#3d4d5d}.lobby-input-code{font-size:20px;font-weight:700;letter-spacing:6px;text-align:center;text-transform:uppercase}.lobby-error{color:var(--error);font-size:13px;font-weight:500;background:#e74c3c14;border:1px solid rgba(231,76,60,.2);padding:8px 12px;border-radius:8px}.lobby-btn-submit{margin-top:4px;padding:16px;font-size:15px;border-radius:12px}.lobby-form-buttons{display:flex;flex-direction:column;gap:10px;margin-top:8px}.btn-loading{display:flex;align-items:center;justify-content:center;gap:8px}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lobby-copyright{position:absolute;bottom:20px;left:50%;transform:translate(-50%);font-size:11px;color:#3d4d5d;letter-spacing:.3px;white-space:nowrap;z-index:1}.lobby-copyright a{color:#d4a84399;text-decoration:none;font-weight:500;transition:color .2s}.lobby-copyright a:hover{color:var(--gold)}.lang-switcher{position:absolute;top:20px;right:24px;display:flex;gap:0;z-index:10;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:3px}.lang-option{display:flex;align-items:center;gap:6px;padding:6px 12px;border:none;border-radius:6px;background:transparent;color:#ffffff80;cursor:pointer;font-size:.7rem;font-weight:600;letter-spacing:.5px;transition:all .2s ease}.lang-option:hover{color:#fffc;background:#ffffff0d}.lang-option-active{color:#fff;background:#d4a84326;box-shadow:0 1px 4px #0003}.lang-option-active .lang-flag-icon{opacity:1}.lang-flag-icon{display:block;border-radius:2px;opacity:.7;transition:opacity .2s ease}.lang-label{line-height:1}.kicked-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.kicked-modal{background:var(--card-bg, #1a2332);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px 40px;text-align:center;max-width:380px;width:90%;box-shadow:0 20px 60px #00000080}.kicked-icon{width:48px;height:48px;border-radius:50%;background:#ef444426;border:2px solid rgba(239,68,68,.4);color:#ef4444;font-size:24px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.kicked-title{color:#fff;font-size:1.2rem;margin:0 0 8px}.kicked-message{color:#ffffffb3;font-size:.9rem;line-height:1.5;margin:0 0 24px}.kicked-btn{min-width:100px}.waiting-room{max-width:480px}.room-code-display{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:24px;padding:12px;background:#0003;border-radius:8px}.room-code-label{font-size:13px;color:#89a}.room-code-value{font-size:28px;font-weight:700;color:var(--gold);letter-spacing:4px;cursor:pointer}.btn-copy{padding:6px 12px;font-size:11px;background:#ffffff14;color:#abc;border:1px solid rgba(255,255,255,.12);border-radius:4px}.players-list{margin-bottom:20px}.players-list h3{font-size:13px;color:#89a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.player-slot{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:8px;margin-bottom:6px;background:#00000026;border:1px solid rgba(255,255,255,.04)}.player-slot-filled{background:#27ae6014;border-color:#27ae6033}.player-position{font-size:12px;color:#6a7a8a;font-weight:500}.player-name-display{font-size:14px;color:#e0e8f0;font-weight:600}.player-name-empty{font-size:12px;color:#456;font-style:italic}.ai-note{font-size:12px;color:#6a7a8a;margin-bottom:16px}.waiting-text{font-size:14px;color:#89a;text-align:center;padding:10px;animation:pulse 1.5s ease-in-out infinite}.waiting-room-enhanced{max-width:520px}.share-panel{background:linear-gradient(135deg,#d4a8430f,#1a7a4c0f);border:1px solid rgba(212,168,67,.2);border-radius:12px;padding:20px;margin-bottom:24px;position:relative;overflow:hidden}.share-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.6}.share-panel-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px}.share-icon{color:var(--gold);flex-shrink:0;margin-top:2px}.share-panel-title{font-size:15px;font-weight:600;color:#e0e8f0;margin-bottom:3px}.share-panel-subtitle{font-size:12px;color:#6a7a8a;line-height:1.4}.share-code-block{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 20px;background:#0000004d;border:1px solid rgba(212,168,67,.15);border-radius:10px;cursor:pointer;transition:all .2s ease;margin-bottom:12px}.share-code-block:hover{border-color:#d4a84366;background:#0006;transform:translateY(-1px)}.share-code-block:active{transform:translateY(0)}.share-code-tiny-label{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:#6a7a8a;font-weight:500}.share-code-digits{display:flex;gap:6px}.share-code-char{display:flex;align-items:center;justify-content:center;width:38px;height:44px;background:#d4a84314;border:1px solid rgba(212,168,67,.25);border-radius:8px;font-size:22px;font-weight:800;color:var(--gold);letter-spacing:0;font-family:JetBrains Mono,Fira Code,monospace;animation:charAppear .3s ease backwards}.share-code-char:nth-child(1){animation-delay:.05s}.share-code-char:nth-child(2){animation-delay:.1s}.share-code-char:nth-child(3){animation-delay:.15s}.share-code-char:nth-child(4){animation-delay:.2s}.share-code-char:nth-child(5){animation-delay:.25s}.share-code-char:nth-child(6){animation-delay:.3s}@keyframes charAppear{0%{opacity:0;transform:translateY(8px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}.share-code-hint{font-size:11px;color:#567;transition:color .2s ease}.share-code-block:hover .share-code-hint{color:#89a}.share-code-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:#d4a84326;border-radius:10px;animation:flashFade .6s ease forwards;pointer-events:none}@keyframes flashFade{0%{opacity:1}to{opacity:0}}.share-link-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px 16px;background:#2980b91f;border:1px solid rgba(41,128,185,.3);border-radius:8px;color:#7ab8e0;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.share-link-btn:hover{background:#2980b933;border-color:#2980b980;transform:translateY(-1px)}.share-link-btn-success{background:#27ae601f;border-color:#27ae604d;color:#5fd89c}.share-divider{display:flex;align-items:center;gap:12px;margin:16px 0}.share-divider:before,.share-divider:after{content:"";flex:1;height:1px;background:#ffffff0f}.share-divider span{font-size:11px;color:#567;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.share-buttons-row{display:flex;gap:8px}.share-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.share-btn:hover{transform:translateY(-2px)}.share-btn:active{transform:translateY(0)}.share-btn span{white-space:nowrap}.share-btn-whatsapp{background:#25d3661a;color:#25d366;border-color:#25d36633}.share-btn-whatsapp:hover{background:#25d3662e;border-color:#25d36666}.share-btn-facebook{background:#1877f21a;color:#4599f7;border-color:#1877f233}.share-btn-facebook:hover{background:#1877f22e;border-color:#1877f266}.share-btn-native{background:#ffffff0d;color:#89a;border-color:#ffffff1a}.share-btn-native:hover{background:#ffffff1a;border-color:#fff3;color:#abc}.room-badge{text-align:center;font-size:12px;color:#89a;padding:6px 10px;background:#0003;border-radius:6px}.room-badge strong{color:var(--gold);letter-spacing:2px}.players-sidebar{padding:10px;background:#00000026;border-radius:8px}.players-sidebar h4{font-size:11px;color:#6a7a8a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.player-sidebar-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#89a;padding:4px 0}.player-sidebar-item.active-player{color:var(--gold-light);font-weight:600}.player-dot{width:8px;height:8px;border-radius:50%}.btn-header-back{padding:7px 16px;background:#ffffff0a;color:#7a8a9a;border:1px solid rgba(255,255,255,.08);font-size:12px;font-weight:500;border-radius:8px;transition:all .2s ease}.btn-header-back:hover{background:#ffffff14;color:#e0e8f0;border-color:#ffffff26}.how-to-play-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .2s ease}.how-to-play-modal{background:linear-gradient(145deg,#1c2a3a,#0f1e2e);border:1px solid rgba(212,168,67,.2);border-radius:20px;padding:36px 32px;max-width:560px;width:100%;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 24px 64px #00000080,0 0 0 1px #ffffff0a}.how-to-play-modal::-webkit-scrollbar{width:6px}.how-to-play-modal::-webkit-scrollbar-track{background:transparent}.how-to-play-modal::-webkit-scrollbar-thumb{background:#d4a8434d;border-radius:3px}.how-to-play-close{position:absolute;top:16px;right:20px;background:none;border:none;color:#6a7a8a;font-size:28px;cursor:pointer;line-height:1;padding:4px 8px;border-radius:4px;transition:color .15s,background .15s}.how-to-play-close:hover{color:#e0e8f0;background:#ffffff14}.how-to-play-title{font-size:26px;font-weight:700;color:var(--gold);margin-bottom:8px;letter-spacing:.5px}.how-to-play-intro{font-size:14px;line-height:1.6;color:#a0b0c0;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.06)}.how-to-play-sections{display:flex;flex-direction:column;gap:20px;margin-bottom:28px}.how-to-play-section{display:flex;gap:14px;align-items:flex-start}.section-icon{min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#d4a8431f;border:1px solid rgba(212,168,67,.25);border-radius:50%;font-size:14px;font-weight:700;color:var(--gold)}.section-content h3{font-size:15px;font-weight:600;color:#e0e8f0;margin-bottom:6px}.section-content p{font-size:13px;line-height:1.6;color:#89a}.section-content em{color:var(--gold-light);font-style:normal;font-weight:500}.trump-cards-display{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.trump-card-badge{padding:4px 10px;border-radius:6px;font-size:13px;font-weight:700;background:#ffffff0f;border:1px solid rgba(255,255,255,.1)}.trump-card-badge.dark{color:#b0c4de}.trump-card-badge.red{color:#ff8a80}.points-table{display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;margin-top:8px;max-width:220px}.points-row{display:contents}.points-card{font-size:13px;color:#a0b0c0;font-weight:500}.points-value{font-size:13px;color:var(--gold-light);font-weight:700;text-align:right}.points-total{margin-top:8px;font-size:11px;color:#6a7a8a;font-style:italic}.how-to-play-done{margin-top:4px}@media(max-width:600px){.how-to-play-modal{padding:24px 20px;max-height:90vh;border-radius:14px}.how-to-play-title{font-size:22px}.section-icon{min-width:28px;height:28px;font-size:12px}}@media(max-width:600px){.waiting-room-enhanced{max-width:100%}.share-panel{padding:16px}.share-code-char{width:32px;height:38px;font-size:18px}.share-code-digits{gap:4px}.share-buttons-row{flex-direction:column;gap:8px}.share-btn{padding:12px 16px}}.admin-panel{flex:1;display:flex;flex-direction:column;background:#0a1420;overflow:hidden}.admin-header{display:flex;align-items:center;gap:16px;padding:16px 24px;background:linear-gradient(135deg,#0d1b2a,#1b2838);border-bottom:1px solid rgba(212,168,67,.2)}.admin-title{font-size:22px;font-weight:700;color:var(--gold);letter-spacing:.5px}.admin-back-btn{background:#ffffff0f;color:#89a;border:1px solid rgba(255,255,255,.1);padding:8px 14px;font-size:13px;border-radius:8px}.admin-back-btn:hover{background:#ffffff1a;color:#e0e8f0}.admin-content{flex:1;overflow-y:auto;padding:24px}.admin-section{max-width:900px;margin:0 auto}.admin-section-header h2{font-size:20px;font-weight:600;color:#e0e8f0;margin-bottom:6px}.admin-section-desc{font-size:13px;color:#6a7a8a;line-height:1.5;margin-bottom:20px}.admin-toolbar{display:flex;gap:12px;align-items:center;margin-bottom:24px;flex-wrap:wrap}.admin-search{flex:1;min-width:200px;padding:10px 14px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#f0f4f8;font-family:inherit;font-size:14px;outline:none;transition:border-color .2s}.admin-search:focus{border-color:var(--gold)}.admin-search::placeholder{color:#4a5a6a}.admin-lang-tabs{display:flex;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.admin-lang-tab{padding:8px 16px;background:#ffffff08;border:none;color:#6a7a8a;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.admin-lang-tab:first-child{border-right:1px solid rgba(255,255,255,.1)}.admin-lang-tab:hover{background:#ffffff0f;color:#a0b0c0}.admin-lang-tab.active{background:#d4a8431a;color:var(--gold)}.trans-section{display:flex;flex-direction:column;gap:0}.trans-header{margin-bottom:20px}.trans-header-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:4px}.trans-save-all-btn{background:linear-gradient(135deg,#27ae60,#1e8e4e);color:#fff;padding:8px 16px;font-size:12px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s}.trans-save-all-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #27ae604d}.trans-save-all-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.trans-desc{color:#6a7a8a;font-size:13px;margin:0 0 16px}.trans-stats-bar{display:flex;align-items:center;gap:20px;padding:14px 18px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:12px}.trans-stat{display:flex;flex-direction:column;gap:2px}.trans-stat-value{font-size:18px;font-weight:700;color:#f0f4f8}.trans-stat-modified{color:#6ede9e}.trans-stat-label{font-size:11px;color:#5a6a7a;text-transform:uppercase;letter-spacing:.5px}.trans-progress-bar{flex:1;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden;margin-left:auto}.trans-progress-fill{height:100%;background:linear-gradient(90deg,#27ae60,#2ecc71);border-radius:3px;transition:width .5s ease}.trans-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}.trans-search-wrap{position:relative;flex:1;min-width:200px}.trans-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.4}.trans-search{width:100%;padding:10px 36px;background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:#f0f4f8;font-size:13px;outline:none;transition:border-color .2s}.trans-search:focus{border-color:var(--gold)}.trans-search::placeholder{color:#4a5a6a}.trans-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#89a;width:20px;height:20px;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.trans-toolbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.trans-lang-toggle,.trans-view-toggle,.trans-filter-group{display:flex;gap:0;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:3px}.trans-lang-btn,.trans-view-btn,.trans-filter-btn{padding:6px 12px;border:none;border-radius:6px;background:transparent;color:#6a7a8a;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.trans-lang-btn:hover,.trans-view-btn:hover,.trans-filter-btn:hover{color:#a0b0c0;background:#ffffff0a}.trans-lang-btn.active,.trans-view-btn.active,.trans-filter-btn.active{color:var(--gold);background:#d4a8431a}.trans-categories{display:flex;flex-direction:column;gap:4px}.trans-category{border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden;transition:border-color .2s}.trans-category:hover{border-color:#ffffff1a}.trans-category-header{display:flex;align-items:center;gap:10px;width:100%;padding:14px 18px;background:#ffffff05;border:none;color:#f0f4f8;cursor:pointer;text-align:left;font-size:13px;transition:background .15s}.trans-category-header:hover{background:#ffffff0a}.trans-category-arrow{font-size:10px;color:#5a6a7a;width:14px}.trans-category-name{font-weight:600;font-size:13px}.trans-category-count{margin-left:auto;font-size:11px;color:#5a6a7a}.trans-category-modified{color:#6ede9e}.trans-grid{padding:8px 12px 12px;display:flex;flex-direction:column;gap:6px}.trans-row{background:#ffffff04;border:1px solid rgba(255,255,255,.04);border-radius:10px;padding:12px 14px;transition:all .2s}.trans-row:hover{border-color:#ffffff1a;background:#ffffff06}.trans-row-modified{border-left:3px solid rgba(39,174,96,.5)}.trans-row-saved{border-left:3px solid rgba(41,128,185,.5)}.trans-row-key{display:flex;align-items:center;gap:8px;margin-bottom:6px}.trans-key-code{font-size:11px;font-weight:600;color:#7a8a9a;font-family:JetBrains Mono,Fira Code,monospace;background:#ffffff0a;padding:2px 6px;border-radius:4px}.trans-row-badges{display:flex;gap:4px;margin-left:auto}.trans-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:4px}.trans-badge-saving{background:#f1c40f26;color:#f5d86e;animation:pulse 1s infinite alternate}.trans-badge-saved{background:#2980b926;color:#7ec8e3;animation:fadeIn .2s ease}.trans-badge-pending{background:#f1c40f1a;color:#d4a84880}.trans-badge-custom{background:#27ae601f;color:#6ede9e}@keyframes pulse{0%{opacity:.6}to{opacity:1}}.trans-row-reference{display:flex;gap:6px;margin-bottom:4px;font-size:11px;align-items:baseline}.trans-ref-label{color:#4a5a6a;font-weight:600;flex-shrink:0}.trans-ref-value{color:#5a7a9a;font-style:italic;line-height:1.4}.trans-row-default{display:flex;gap:6px;margin-bottom:8px;font-size:12px;align-items:baseline}.trans-default-label{color:#4a5a6a;flex-shrink:0;font-weight:500}.trans-default-value{color:#7a8a9a;line-height:1.4}.trans-row-edit{display:flex;gap:6px;align-items:flex-start}.trans-textarea{flex:1;padding:8px 12px;background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:#f0f4f8;font-family:inherit;font-size:13px;line-height:1.5;resize:vertical;min-height:36px;outline:none;transition:border-color .2s,box-shadow .2s}.trans-textarea:focus{border-color:var(--gold);box-shadow:0 0 0 2px #d4a8431a}.trans-textarea::placeholder{color:#3d4d5d}.trans-revert-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(231,76,60,.3);border-radius:6px;background:#e74c3c14;color:#e74c3c;font-size:16px;cursor:pointer;flex-shrink:0;transition:all .15s;margin-top:4px}.trans-revert-btn:hover{background:#e74c3c33;border-color:#e74c3c80}.trans-empty{text-align:center;color:#5a6a7a;padding:40px 20px;font-size:14px}@media(max-width:768px){.trans-toolbar{flex-direction:column;align-items:stretch}.trans-toolbar-actions{justify-content:space-between}.trans-stats-bar{flex-wrap:wrap;gap:12px}.trans-row-edit{flex-direction:column}.trans-revert-btn{align-self:flex-end;margin-top:0}}.admin-login{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.admin-login-card{background:linear-gradient(135deg,#0d1b2a,#1b2838);border:1px solid rgba(212,168,67,.2);border-radius:16px;padding:40px 36px;width:100%;max-width:380px}.admin-login-title{font-size:22px;font-weight:700;color:#f0f4f8;margin-bottom:4px}.admin-login-subtitle{font-size:13px;color:#6a7a8a;margin-bottom:24px}.admin-login-form{display:flex;flex-direction:column;gap:16px}.admin-input{width:100%;padding:12px 14px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#f0f4f8;font-family:inherit;font-size:14px;outline:none;transition:border-color .2s;box-sizing:border-box}.admin-input:focus{border-color:var(--gold)}.admin-input::placeholder{color:#4a5a6a}.admin-error{color:#e74c3c;font-size:13px;margin:0}.admin-login-btn{margin-top:4px;padding:14px;font-size:15px}.admin-logout-btn{margin-left:auto;background:#e74c3c1a;color:#e74c3c;border:1px solid rgba(231,76,60,.3);padding:8px 14px;font-size:12px;border-radius:8px}.admin-logout-btn:hover{background:#e74c3c33}.admin-loading{color:#6a7a8a;text-align:center;padding:60px 24px;font-size:14px}.admin-settings-section{margin-bottom:0}.admin-section-title{font-size:18px;font-weight:600;color:#e0e8f0;margin-bottom:16px}.admin-setting-row{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:16px 20px}.admin-setting-info{display:flex;flex-direction:column;gap:4px}.admin-setting-label{font-size:14px;font-weight:600;color:#e0e8f0}.admin-setting-desc{font-size:12px;color:#6a7a8a;line-height:1.4}.admin-toggle{position:relative;width:48px;height:26px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:13px;cursor:pointer;flex-shrink:0;transition:all .25s ease}.admin-toggle.active{background:#27ae6066;border-color:#27ae6099}.admin-toggle-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#89a;border-radius:50%;transition:all .25s ease}.admin-toggle.active .admin-toggle-knob{left:25px;background:#6ede9e}.admin-divider{height:1px;background:#ffffff0f;margin:28px 0}.admin-tabs{display:flex;gap:2px;padding:0 24px;background:#0003;border-bottom:1px solid rgba(255,255,255,.06)}.admin-tab{padding:14px 20px;font-size:13px;font-weight:600;color:#ffffff80;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.admin-tab:hover{color:#fffc;background:#ffffff05}.admin-tab.active{color:#fff;border-bottom-color:var(--gold);background:#d4a8430a}.admin-tab-icon{font-size:15px;opacity:.8}.activity-dashboard{padding:24px;max-width:1400px;margin:0 auto;width:100%}.dash-loading{padding:60px;text-align:center;color:#fff6;font-size:14px}.dash-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.dash-title{font-size:22px;font-weight:700;color:#fff;letter-spacing:.3px}.dash-toolbar-right{display:flex;align-items:center;gap:12px}.dash-refresh-time{font-size:11px;color:#ffffff59}.dash-refresh-btn{padding:6px 14px;font-size:12px;font-weight:600;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ffffffb3;cursor:pointer;transition:all .15s}.dash-refresh-btn:hover{background:#ffffff1a;color:#fff}.dash-stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:24px}.dash-stat-card{background:#141e2bcc;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;transition:border-color .2s}.dash-stat-card:hover{border-color:#ffffff1f}.dash-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#ffffff0f;border-radius:14px 14px 0 0}.dash-stat-primary:before{background:linear-gradient(90deg,#27ae60,#2ecc71)}.dash-stat-ai:before{background:linear-gradient(90deg,#8e44ad,#9b59b6)}.dash-stat-gold:before{background:linear-gradient(90deg,var(--gold),#e8c04a)}.dash-stat-icon{font-size:20px;opacity:.5}.dash-stat-primary .dash-stat-icon{color:#27ae60;opacity:1}.dash-stat-ai .dash-stat-icon{color:#9b59b6;opacity:1}.dash-stat-gold .dash-stat-icon{color:var(--gold);opacity:1}.dash-stat-body{display:flex;flex-direction:column;gap:2px}.dash-stat-value{font-size:32px;font-weight:800;color:#fff;line-height:1;letter-spacing:-.5px}.dash-stat-label{font-size:12px;color:#ffffff80;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.dash-stat-sub{font-size:11px;color:#ffffff4d;margin-top:auto}.dash-columns{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.dash-panel{background:#141e2bcc;border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden}.dash-panel-full{width:100%}.dash-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.04);background:#00000026}.dash-panel-title{font-size:14px;font-weight:700;color:#fff;display:flex;align-items:center;gap:8px}.dash-panel-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dash-dot-live{background:#27ae60;box-shadow:0 0 8px #27ae6080;animation:livePulse 1.5s ease-in-out infinite}.dash-dot-gold{background:var(--gold);box-shadow:0 0 8px #d4a84366}.dash-dot-neutral{background:#ffffff4d}.dash-panel-count{font-size:11px;color:#fff6;font-weight:500}.dash-panel-header-right{display:flex;gap:6px;align-items:center}.dash-type-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:4px}.dash-type-ai{background:#9b59b61f;color:#c39bd3;border:1px solid rgba(155,89,182,.25)}.dash-type-pvp{background:#3498db1f;color:#7fb3d3;border:1px solid rgba(52,152,219,.25)}.dash-panel-body{max-height:360px;overflow-y:auto}.dash-empty{padding:40px 20px;text-align:center;color:#ffffff4d;font-size:13px}.dash-table{width:100%;border-collapse:collapse;font-size:12px}.dash-table thead{position:sticky;top:0;z-index:1}.dash-table th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#ffffff59;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.04)}.dash-table td{padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.03);color:#ffffffb3;vertical-align:middle}.dash-table tbody tr{transition:background .15s}.dash-table tbody tr:hover{background:#ffffff05}.dash-row-active{background:#27ae600a}.dash-row-active td{color:#ffffffe6}.dash-row-stale{background:#e74c3c0a}.dash-row-stale td{color:#ffffff80}.dash-code{font-family:var(--font-mono, monospace);font-weight:700;letter-spacing:1px;color:var(--gold);font-size:12px}.dash-name{font-weight:600;color:#fff}.dash-time{color:#ffffff59;font-size:11px;white-space:nowrap}.dash-round{font-family:var(--font-mono, monospace);font-weight:600}.dash-players-cell{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-score-cell{font-family:var(--font-mono, monospace);font-weight:600}.dash-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.dash-badge-playing{background:#27ae6026;color:#6ede9e;border:1px solid rgba(39,174,96,.3)}.dash-badge-stale{background:#e74c3c1f;color:#e88a82;border:1px solid rgba(231,76,60,.25)}.dash-remove-btn{padding:4px 10px;font-size:11px;font-weight:600;background:#e74c3c14;border:1px solid rgba(231,76,60,.2);border-radius:4px;color:#e88a82;cursor:pointer;transition:all .15s}.dash-remove-btn:hover{background:#e74c3c33;border-color:#e74c3c66;color:#f5a8a2}.dash-cleanup-btn-sm{padding:5px 12px;font-size:11px}.dash-badge-waiting{background:#f1c40f1a;color:#f5d76e;border:1px solid rgba(241,196,15,.2)}.dash-badge-finished,.dash-badge-completed{background:#ffffff0d;color:#fff6;border:1px solid rgba(255,255,255,.08)}.dash-badge-ai{background:#9b59b61f;color:#c39bd3;border:1px solid rgba(155,89,182,.25)}.dash-badge-pvp{background:#3498db1f;color:#7fb3d3;border:1px solid rgba(52,152,219,.25)}.dash-badge-registration{background:#3498db1a;color:#7ec8e3;border:1px solid rgba(52,152,219,.2)}.dash-result{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;font-size:11px;font-weight:800}.dash-result-win{background:#27ae6026;color:#6ede9e;border:1px solid rgba(39,174,96,.3)}.dash-result-loss{background:#e74c3c1f;color:#e88a82;border:1px solid rgba(231,76,60,.25)}.dash-result-draw{background:#f1c40f1a;color:#f5d76e;border:1px solid rgba(241,196,15,.2)}.dash-cleanup-panel{margin-bottom:20px;border-color:#f1c40f1a}.dash-dot-warn{background:#e67e22;box-shadow:0 0 8px #e67e2266}.dash-cleanup-total{font-size:11px;font-weight:600;color:#e67e22;background:#e67e221a;border:1px solid rgba(230,126,34,.2);padding:3px 8px;border-radius:4px}.dash-cleanup-body{padding:16px 20px}.dash-cleanup-result{padding:8px 12px;margin-bottom:16px;background:#27ae6014;border:1px solid rgba(39,174,96,.2);border-radius:6px;color:#6ede9e;font-size:12px;font-weight:500}.dash-cleanup-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dash-cleanup-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:#0003;border:1px solid rgba(255,255,255,.04);border-radius:10px;transition:border-color .2s}.dash-cleanup-item:hover{border-color:#ffffff14}.dash-cleanup-info{display:flex;flex-direction:column;gap:2px;min-width:0}.dash-cleanup-count{font-size:22px;font-weight:800;color:#fff;line-height:1}.dash-cleanup-label{font-size:13px;font-weight:600;color:#ffffffbf}.dash-cleanup-desc{font-size:11px;color:#ffffff59;line-height:1.3}.dash-cleanup-btn{flex-shrink:0;padding:8px 16px;font-size:12px;font-weight:600;background:#e74c3c1a;border:1px solid rgba(231,76,60,.25);border-radius:6px;color:#e88a82;cursor:pointer;transition:all .15s}.dash-cleanup-btn:hover:not(:disabled){background:#e74c3c33;border-color:#e74c3c66;color:#f5a8a2}.dash-cleanup-btn:disabled{opacity:.4;cursor:not-allowed}.dash-cleanup-all-btn{display:block;width:100%;margin-top:16px;padding:12px 20px;font-size:13px;font-weight:700;background:#e74c3c1f;border:1px solid rgba(231,76,60,.3);border-radius:8px;color:#e88a82;cursor:pointer;transition:all .15s}.dash-cleanup-all-btn:hover:not(:disabled){background:#e74c3c33;border-color:#e74c3c80;color:#f5c4c0}.dash-cleanup-all-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:1100px){.dash-stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.dash-stats-grid{grid-template-columns:repeat(2,1fr)}.dash-columns,.dash-cleanup-grid{grid-template-columns:1fr}}@media(max-width:600px){.dash-stats-grid{grid-template-columns:1fr}.activity-dashboard{padding:16px 12px}.dash-toolbar{flex-direction:column;align-items:flex-start;gap:8px}}.tutorial-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease}.tutorial-modal{background:linear-gradient(165deg,#1c2a3afa,#0f1926fc);border:1px solid rgba(212,168,67,.2);border-radius:20px;padding:36px 32px;max-width:480px;width:90%;text-align:center}.tutorial-progress{display:flex;justify-content:center;gap:8px;margin-bottom:24px}.tutorial-dot{width:10px;height:10px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);transition:all .3s}.tutorial-dot-active{background:var(--gold-light);border-color:var(--gold-light);box-shadow:0 0 8px #d4a84366}.tutorial-dot-done{background:#27ae6099;border-color:#27ae60cc}.tutorial-title{font-size:22px;font-weight:700;color:var(--gold-light);margin-bottom:12px}.tutorial-desc{font-size:14px;line-height:1.6;color:#ffffffbf;margin-bottom:24px}.tutorial-visual{min-height:100px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.tutorial-bid-demo,.tutorial-play-demo,.tutorial-score-demo{display:flex;flex-direction:column;align-items:center;gap:12px}.tutorial-speech{background:#d4a8431a;border:1px solid rgba(212,168,67,.3);border-radius:12px;padding:8px 16px}.tutorial-speech-text{color:var(--gold-light);font-weight:600;font-size:14px}.tutorial-hand-demo{display:flex;gap:4px}.tutorial-trick-demo{display:flex;gap:12px;align-items:flex-end}.tutorial-trick-card{display:flex;flex-direction:column;align-items:center;gap:4px}.tutorial-card-label{font-size:10px;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.tutorial-trick-winner .tutorial-card-label{color:var(--gold-light);font-weight:700}.tutorial-score-box{background:#0003;border-radius:12px;padding:16px 24px;display:flex;align-items:center;gap:16px}.tutorial-score-team{display:flex;flex-direction:column;gap:2px}.tutorial-score-name{font-size:11px;color:#ffffff80}.tutorial-score-val{font-size:18px;font-weight:700;color:#fff}.tutorial-score-arrow{color:#27ae60;font-weight:700;font-size:16px}.tutorial-actions{display:flex;justify-content:center;gap:12px}.stats-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease}.stats-modal{background:linear-gradient(165deg,#1c2a3afa,#0f1926fc);border:1px solid rgba(212,168,67,.2);border-radius:20px;padding:32px;max-width:520px;width:90%;max-height:80vh;overflow-y:auto;position:relative}.stats-close{position:absolute;top:12px;right:16px;font-size:24px;background:none;border:none;color:#ffffff80;cursor:pointer}.stats-close:hover{color:#fff}.stats-title{font-size:20px;font-weight:700;color:var(--gold-light);margin-bottom:16px;text-align:center}.stats-tabs{display:flex;gap:4px;margin-bottom:20px;background:#0003;border-radius:8px;padding:3px}.stats-tab{flex:1;padding:8px 12px;border:none;background:none;color:#ffffff80;font-size:12px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s}.stats-tab-active{background:#d4a84326;color:var(--gold-light)}.stats-loading,.stats-empty{text-align:center;color:#fff6;padding:24px;font-size:13px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{background:#00000026;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:4px}.stat-card-highlight{border-color:#d4a8434d;background:#d4a8430d}.stat-value{font-size:22px;font-weight:700;color:#fff}.stat-value-suit{font-size:14px}.stat-label{font-size:10px;color:#fff6;text-transform:uppercase;letter-spacing:.4px}.match-history-list{display:flex;flex-direction:column;gap:6px;max-height:400px;overflow-y:auto}.match-history-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;background:#0000001a;border:1px solid rgba(255,255,255,.04)}.match-win{border-left:3px solid #27ae60}.match-loss{border-left:3px solid #e74c3c}.match-result-badge{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.match-win .match-result-badge{background:#27ae6033;color:#27ae60}.match-loss .match-result-badge{background:#e74c3c33;color:#e74c3c}.match-details{flex:1;display:flex;flex-direction:column;gap:2px}.match-score{font-size:13px;font-weight:600;color:#fff}.match-type{font-size:10px;color:#fff6}.match-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.match-rounds{font-size:11px;color:#ffffff80}.match-date{font-size:10px;color:#ffffff4d}.chat-toggle{position:absolute;bottom:48px;right:8px;width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:#0006;color:#ffffffb3;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:15;transition:all .2s}.chat-toggle:hover{background:#0009;color:#fff}.chat-unread{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:#e74c3c;color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}.chat-panel{position:absolute;bottom:90px;right:8px;width:260px;max-height:320px;background:#0f1926f5;border:1px solid rgba(255,255,255,.1);border-radius:12px;display:flex;flex-direction:column;overflow:hidden;z-index:15;animation:fadeIn .2s ease}.chat-header{padding:8px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#ffffff80;border-bottom:1px solid rgba(255,255,255,.06)}.chat-messages{flex:1;min-height:120px;max-height:180px;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.chat-empty{color:#ffffff4d;font-size:11px;text-align:center;padding:24px 0}.chat-msg{font-size:12px;padding:4px 8px;border-radius:6px;background:#ffffff0a;word-break:break-word}.chat-msg-mine{background:#d4a84314}.chat-msg-emote{font-size:20px;text-align:center;background:none;animation:emoteIn .3s ease}@keyframes emoteIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.chat-sender{font-weight:600;color:#fff9;margin-right:6px;font-size:10px}.chat-text{color:#ffffffd9}.chat-quick{display:flex;flex-wrap:wrap;gap:4px;padding:6px 8px;border-top:1px solid rgba(255,255,255,.06)}.chat-quick-btn{font-size:9px;padding:3px 8px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:#fff9;cursor:pointer;transition:all .15s}.chat-quick-btn:hover{background:#d4a8431a;border-color:#d4a8434d;color:var(--gold-light)}.chat-input-row{display:flex;border-top:1px solid rgba(255,255,255,.06)}.chat-input{flex:1;border:none;background:#0003;color:#fff;padding:8px 10px;font-size:12px;outline:none}.chat-input::placeholder{color:#ffffff4d}.chat-send-btn{padding:8px 12px;background:#d4a84326;border:none;color:var(--gold-light);font-size:11px;font-weight:600;cursor:pointer;transition:background .15s}.chat-send-btn:hover{background:#d4a84340}.emote-bar{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:10}.emote-btn{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:#0000004d;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.emote-btn:hover{transform:scale(1.2);background:#00000080;border-color:#fff3}.spectator-badge{position:absolute;top:8px;left:50%;transform:translate(-50%);background:#e74c3c26;border:1px solid rgba(231,76,60,.4);color:#e74c3c;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:4px 14px;border-radius:10px;z-index:10}.spectator-link-btn{margin-left:8px;font-size:10px;padding:2px 8px;border-radius:4px;border:1px solid rgba(212,168,67,.3);background:#d4a8431a;color:var(--gold-light);cursor:pointer;transition:all .15s}.spectator-link-btn:hover{background:#d4a84333}.header-actions{display:flex;gap:8px;align-items:center;margin-left:auto}.hand-card-wrapper{transition:transform .15s ease,opacity .15s ease}.hand-card-wrapper:active{transform:translateY(-30px) scale(.9);opacity:.7}@media(max-width:768px){.chat-panel{width:220px;bottom:80px}.emote-bar{bottom:4px}.emote-btn{width:28px;height:28px;font-size:14px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:6px}.tutorial-modal{padding:24px 20px}}.tournament-lobby,.tournament-view{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:24px 16px;overflow-y:auto}.tournament-card{background:#141e2beb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(212,168,67,.15);border-radius:20px;padding:40px 32px;max-width:440px;width:100%;box-shadow:0 20px 60px #00000080}.tournament-card-wide{max-width:600px}.tournament-header{text-align:center;margin-bottom:32px}.tournament-trophy{font-size:48px;color:var(--gold);margin-bottom:8px;text-shadow:0 0 20px rgba(212,168,67,.4)}.tournament-title{font-family:var(--font-heading);font-size:28px;color:#fff;letter-spacing:1px;margin-bottom:6px}.tournament-subtitle{color:#ffffff80;font-size:13px}.tournament-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}.tournament-btn{padding:14px 20px;font-size:14px;font-weight:600;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#cdd6e0;cursor:pointer;transition:all .2s}.tournament-btn:hover{background:#ffffff1a;border-color:#fff3}.tournament-btn-main{background:linear-gradient(135deg,var(--gold),#c49030);color:#1a1a2e;border:none;font-weight:700}.tournament-btn-main:hover{background:linear-gradient(135deg,#e8c04a,#d4a838);transform:translateY(-1px);box-shadow:0 4px 16px #d4a8434d}.tournament-btn-main:disabled{opacity:.5;cursor:not-allowed;transform:none}.tournament-btn-start{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff;border:none;font-weight:700;font-size:15px;padding:16px}.tournament-btn-start:hover{background:linear-gradient(135deg,#3dd87a,#2ecc71);transform:translateY(-1px)}.tournament-btn-start:disabled{opacity:.5;cursor:not-allowed;transform:none}.tournament-btn-back{background:transparent;border-color:#ffffff14;color:#89a;font-weight:500}.tournament-btn-back:hover{color:#abc}.tournament-btn-info{border-color:#d4a84333;color:var(--gold);display:flex;align-items:center;justify-content:center;gap:8px}.tournament-btn-info:hover{border-color:#d4a84366;background:#d4a8430f}.info-btn-icon{font-size:18px;line-height:1}.tournament-card-guide{max-width:640px;padding:36px 32px}.guide-header{text-align:center;margin-bottom:28px}.guide-icon{font-size:42px;color:var(--gold);margin-bottom:6px;text-shadow:0 0 20px rgba(212,168,67,.3)}.guide-sections{display:flex;flex-direction:column;gap:2px}.guide-section{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}.guide-section:last-child{border-bottom:none}.guide-step-number{flex-shrink:0;width:32px;height:32px;background:linear-gradient(135deg,var(--gold),#c49030);color:#1a1a2e;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;margin-top:2px}.guide-step-content{flex:1;min-width:0}.guide-step-title{color:#fff;font-size:15px;font-weight:700;margin-bottom:4px;letter-spacing:.2px}.guide-step-text{color:#fff9;font-size:13px;line-height:1.6}.guide-step-text strong{color:#ffffffe6;font-weight:600}.guide-tips{margin-top:24px;padding:16px 20px;background:#d4a8430a;border:1px solid rgba(212,168,67,.12);border-radius:12px}.guide-tips-title{font-size:13px;font-weight:700;color:var(--gold);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.guide-tips-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.guide-tips-list li{color:#ffffff8c;font-size:12px;line-height:1.5;padding-left:16px;position:relative}.guide-tips-list li:before{content:"•";position:absolute;left:0;color:var(--gold);opacity:.6}.tournament-form{display:flex;flex-direction:column;gap:12px;margin:16px 0}.tournament-form-inline{display:grid;grid-template-columns:1fr;gap:12px}.tournament-form-group{display:flex;flex-direction:column;gap:4px}.tournament-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#ffffff80}.tournament-input{padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#0000004d;color:#fff;font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}.tournament-input:focus{border-color:var(--gold)}.tournament-input option{background:#1a2030;color:#fff}.tournament-error{color:#e74c3c;font-size:12px;text-align:center;margin-top:8px}.tournament-reg-header{text-align:center;margin-bottom:20px}.tournament-code-badge{display:inline-block;background:#d4a8431a;border:1px solid rgba(212,168,67,.3);padding:4px 14px;border-radius:20px;font-size:12px;color:var(--gold);margin:8px 0}.tournament-code-value{font-weight:700;font-family:var(--font-mono, monospace);letter-spacing:2px}.tournament-register-section{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:20px;margin-bottom:20px}.tournament-section-title{font-size:14px;font-weight:600;color:#cdd6e0;margin-bottom:12px}.tournament-registered-badge{background:#2ecc711a;border:1px solid rgba(46,204,113,.3);color:#2ecc71;padding:12px 16px;border-radius:10px;text-align:center;font-size:13px;margin-bottom:20px}.tournament-teams-list{margin-bottom:20px}.tournament-team-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;background:#ffffff08;margin-bottom:6px;transition:background .15s}.tournament-team-row:hover{background:#ffffff0f}.tournament-team-seed{width:24px;height:24px;border-radius:50%;background:#ffffff14;display:flex;align-items:center;justify-content:center;font-size:11px;color:#ffffff80;font-weight:600;flex-shrink:0}.tournament-team-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.tournament-team-name{font-size:13px;font-weight:600;color:#fff}.tournament-team-players{font-size:11px;color:#fff6}.tournament-remove-btn{width:24px;height:24px;border-radius:50%;border:1px solid rgba(231,76,60,.3);background:#e74c3c1a;color:#e74c3c;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.tournament-remove-btn:hover{background:#e74c3c33}.tournament-waiting{text-align:center;color:#fff6;font-size:13px;font-style:italic}.tournament-empty{text-align:center;color:#ffffff4d;font-size:12px;padding:16px}.tournament-view-header{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:700px;margin-bottom:20px;gap:12px}.tournament-view-title-area{display:flex;flex-direction:column;gap:6px}.tournament-view-name{font-family:var(--font-heading);font-size:22px;color:#fff;letter-spacing:.5px}.tournament-view-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.tournament-status{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:3px 10px;border-radius:12px}.tournament-status-in_progress{background:#2ecc7126;color:#2ecc71;border:1px solid rgba(46,204,113,.3)}.tournament-status-completed{background:#d4a84326;color:var(--gold);border:1px solid rgba(212,168,67,.3)}.tournament-round-badge{font-size:12px;color:#ffffff80}.tournament-code-mini{font-size:11px;color:#ffffff4d;font-family:var(--font-mono, monospace)}.tournament-tabs{display:flex;gap:4px;width:100%;max-width:700px;background:#0000004d;border-radius:12px;padding:4px;margin-bottom:20px}.tournament-tab{flex:1;padding:10px 16px;font-size:13px;font-weight:600;border:none;background:transparent;color:#fff6;border-radius:9px;cursor:pointer;transition:all .2s}.tournament-tab.active{background:#ffffff14;color:#fff}.tournament-tab:hover:not(.active){color:#ffffffb3}.tournament-standings{width:100%;max-width:700px}.tournament-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.tournament-table th{text-align:left;padding:10px 12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff6;border-bottom:1px solid rgba(255,255,255,.06)}.tournament-table td{padding:12px;border-bottom:1px solid rgba(255,255,255,.04);color:#cdd6e0}.tournament-row-highlight td{background:#d4a8430d}.tournament-rank{width:32px;text-align:center}.tournament-medal{display:inline-flex;width:22px;height:22px;border-radius:50%;align-items:center;justify-content:center;font-size:10px;font-weight:700}.tournament-medal.gold{background:linear-gradient(135deg,var(--gold),#c49030);color:#1a1a2e}.tournament-medal.silver{background:linear-gradient(135deg,#bdc3c7,#95a5a6);color:#2c3e50}.tournament-medal.bronze{background:linear-gradient(135deg,#cd7f32,sienna);color:#fff}.tournament-team-cell{font-weight:600;color:#fff}.tournament-players-cell{color:#fff6;font-size:12px}.tournament-pts{font-weight:700;color:var(--gold);text-align:center}.tournament-buch{color:#fff6;text-align:center;font-size:12px}.tournament-rounds-view{width:100%;max-width:700px}.tournament-round-selector{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.tournament-round-btn{padding:8px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:#ffffff80;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.tournament-round-btn.active{background:#d4a84326;border-color:#d4a84366;color:var(--gold)}.tournament-round-btn:hover:not(.active){background:#ffffff14}.round-check{color:#2ecc71}.tournament-matches-list{display:flex;flex-direction:column;gap:10px}.tournament-match-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:16px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.tournament-match-card.completed{border-color:#2ecc7126}.match-table-number{font-size:10px;font-weight:600;text-transform:uppercase;color:#ffffff4d;min-width:56px}.match-teams{display:flex;align-items:center;gap:8px;flex:1}.match-team{font-size:13px;color:#cdd6e0;font-weight:500}.match-team.winner{color:#2ecc71;font-weight:700}.match-vs{font-size:10px;color:#ffffff4d;text-transform:uppercase}.match-score{min-width:70px;text-align:center}.match-final-score{font-weight:700;font-size:15px;color:#fff;font-family:var(--font-mono, monospace)}.match-pending-label{font-size:11px;color:#ffffff4d;font-style:italic}.match-report{display:flex;align-items:center;gap:6px;flex-basis:100%;margin-top:8px}.match-score-input{width:48px;padding:6px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:#fff;font-size:13px;text-align:center;outline:none}.match-score-input:focus{border-color:var(--gold)}.match-score-dash{color:#ffffff4d}.tournament-btn-report{padding:6px 12px;font-size:11px;font-weight:600;border-radius:6px;border:1px solid rgba(46,204,113,.3);background:#2ecc711a;color:#2ecc71;cursor:pointer;transition:all .15s}.tournament-btn-report:hover{background:#2ecc7133}.tournament-btn-report:disabled{opacity:.5;cursor:not-allowed}.tournament-my-match{width:100%;max-width:700px}.my-match-card{background:#ffffff08;border:1px solid rgba(212,168,67,.15);border-radius:16px;padding:24px}.my-match-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.my-match-table{font-size:12px;color:#fff6;text-transform:uppercase;font-weight:600}.my-match-status{font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px}.my-match-status.pending,.my-match-status.in_progress{background:#3498db26;color:#3498db}.my-match-status.completed{background:#2ecc7126;color:#2ecc71}.my-match-teams{display:flex;align-items:center;justify-content:center;gap:24px;margin-bottom:20px}.my-match-team{text-align:center}.my-match-team-name{font-size:16px;font-weight:700;color:#fff;display:block}.my-match-team.winner .my-match-team-name{color:#2ecc71}.my-match-you{font-size:11px;color:var(--gold);font-weight:500}.my-match-vs{font-size:12px;color:#fff3;font-weight:700}.my-match-result{text-align:center;margin-bottom:16px}.my-match-score{font-size:28px;font-weight:700;color:#fff;font-family:var(--font-mono, monospace)}.my-match-win-badge{display:inline-block;margin-left:12px;padding:3px 12px;border-radius:12px;background:#2ecc7133;color:#2ecc71;font-size:12px;font-weight:700}.my-match-loss-badge{display:inline-block;margin-left:12px;padding:3px 12px;border-radius:12px;background:#e74c3c33;color:#e74c3c;font-size:12px;font-weight:700}.my-match-draw-badge{display:inline-block;margin-left:12px;padding:3px 12px;border-radius:12px;background:#ffffff1a;color:#ffffff80;font-size:12px;font-weight:700}.my-match-room{background:#0003;border-radius:12px;padding:16px;text-align:center}.my-match-room-label{font-size:11px;color:#fff6;text-transform:uppercase;margin-bottom:8px}.my-match-room-code{font-size:24px;font-weight:700;color:var(--gold);font-family:var(--font-mono, monospace);letter-spacing:4px}.my-match-instructions{font-size:12px;color:#fff6;margin-top:10px;line-height:1.5}.my-match-play-section{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08)}.tournament-play-btn{font-size:16px;padding:14px 36px;border-radius:12px;display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#27ae60,#1e8c4c);border:1px solid rgba(39,174,96,.5);box-shadow:0 4px 20px #27ae6040;transition:all .2s ease}.tournament-play-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 28px #27ae6059}.play-btn-icon{font-size:14px}.my-match-play-hint{font-size:12px;color:#fff6;margin-top:12px}.my-match-bye{text-align:center;padding:24px;background:#d4a8430f;border-radius:12px;border:1px solid rgba(212,168,67,.15);margin-top:16px}.bye-badge{display:inline-block;font-size:18px;font-weight:700;color:var(--gold);letter-spacing:3px;margin-bottom:8px}.tournament-tab-match{position:relative}.tab-live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#27ae60;margin-left:6px;animation:livePulse 1.5s ease-in-out infinite}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.3}}.match-status-in_progress{color:#27ae60}.match-status-pending{color:#ffffff80}.tournament-match-complete-section{text-align:center;display:flex;flex-direction:column;gap:12px}.tournament-match-result-banner{background:#27ae6026;border:1px solid rgba(39,174,96,.4);color:#6ede9e;padding:10px 16px;border-radius:10px;font-size:13px;font-weight:600;letter-spacing:.3px}.tournament-champion{width:100%;max-width:700px;text-align:center;padding:32px;background:radial-gradient(ellipse at center,rgba(212,168,67,.08) 0%,transparent 70%);border:1px solid rgba(212,168,67,.2);border-radius:20px;margin-top:20px}.champion-trophy{font-size:56px;color:var(--gold);text-shadow:0 0 30px rgba(212,168,67,.5);margin-bottom:12px;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.champion-title{font-family:var(--font-heading);font-size:24px;color:#fff;margin-bottom:16px}.champion-team{display:flex;flex-direction:column;gap:4px;align-items:center}.champion-name{font-size:20px;font-weight:700;color:var(--gold)}.champion-players{font-size:13px;color:#ffffff80}.champion-points{font-size:14px;font-weight:700;color:#2ecc71;margin-top:4px}.lobby-btn-tournament{background:linear-gradient(135deg,#d4a8431a,#d4a8430a);border:1px solid rgba(212,168,67,.2);color:var(--gold-light);box-shadow:inset 0 1px #d4a84314}.lobby-btn-tournament:hover{background:linear-gradient(135deg,#d4a8432e,#d4a84314);border-color:#d4a84366;transform:translateY(-3px);box-shadow:0 6px 24px #d4a84326,inset 0 1px #d4a84326}@media(max-width:600px){.tournament-card{padding:28px 20px;border-radius:16px}.tournament-title{font-size:22px}.tournament-trophy{font-size:36px}.tournament-view-header{flex-direction:column;align-items:flex-start;gap:8px}.tournament-view-name{font-size:18px}.tournament-match-card{flex-direction:column;align-items:flex-start;gap:8px}.match-teams{flex-wrap:wrap}.tournament-table th,.tournament-table td{padding:8px 6px;font-size:11px}.tournament-players-cell{display:none}.my-match-teams{flex-direction:column;gap:12px}.my-match-room-code{font-size:20px}}
