*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--table-green: #1a4a2e;--table-green-light: #1e5a36;--table-border: #0f2e1a;--card-bg: #fdf6e3;--card-shadow: rgba(0, 0, 0, .4);--card-back-bg: #1a237e;--card-back-accent: #283593;--card-red: #c62828;--card-black: #212121;--team-a: #1565c0;--team-a-light: #1976d2;--team-b: #b71c1c;--team-b-light: #c62828;--gold: #ffd700;--gold-dark: #f9a825;--text-light: #e8f5e9;--text-muted: #a5d6a7;--text-dark: #1a1a1a;--panel-bg: rgba(0, 0, 0, .45);--panel-border: rgba(255, 255, 255, .1);--btn-primary: #2e7d32;--btn-primary-hover: #388e3c;--btn-secondary: #455a64;--btn-secondary-hover: #546e7a;--btn-danger: #c62828;--btn-danger-hover: #d32f2f;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--card-w-sm: 42px;--card-h-sm: 58px;--card-w-md: 60px;--card-h-md: 84px;--card-w-lg: 80px;--card-h-lg: 112px}html,body{height:100%;font-family:var(--font);background:var(--table-green);color:var(--text-light);overflow:hidden}#root{height:100vh;display:flex;flex-direction:column}.app-root{height:100vh;position:relative;overflow:hidden;user-select:none;-webkit-user-select:none}.error-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:#b71c1c;color:#fff;padding:10px 20px;border-radius:8px;z-index:9999;display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px #0006;cursor:pointer;max-width:80vw}.error-dismiss{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font);transition:background .15s,transform .1s,opacity .15s;white-space:nowrap}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled,.btn-disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--btn-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--btn-primary-hover)}.btn-secondary{background:var(--btn-secondary);color:#fff}.btn-secondary:hover:not(:disabled){background:var(--btn-secondary-hover)}.btn-danger{background:var(--btn-danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--btn-danger-hover)}.btn-large{padding:12px 28px;font-size:16px;border-radius:10px}.input{width:100%;padding:10px 14px;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:15px;font-family:var(--font);transition:border-color .2s}.input:focus{outline:none;border-color:#ffffff80}.input::placeholder{color:#ffffff4d}.input-mono{font-family:monospace;letter-spacing:2px;text-transform:uppercase}.home-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1e5a36,#0f2e1a)}.home-card{background:#00000080;border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:40px;width:380px;max-width:95vw;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 40px #00000080}.home-logo{display:flex;justify-content:center;gap:8px;margin-bottom:8px}.suit-symbol{font-size:32px}.suit-symbol.red{color:var(--card-red)}.suit-symbol.black{color:#fff}.home-title{text-align:center;font-size:36px;font-weight:700;color:var(--gold);margin-bottom:4px}.home-subtitle{text-align:center;color:var(--text-muted);margin-bottom:28px;font-size:14px}.home-form{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;color:var(--text-muted);font-weight:500}.divider{display:flex;align-items:center;gap:12px;color:var(--text-muted);font-size:13px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#ffffff26}.home-rules-hint{margin-top:24px;text-align:center;color:var(--text-muted);font-size:12px;display:flex;flex-direction:column;align-items:center;gap:8px}.btn-rules-link{background:none;border:1px solid rgba(255,215,0,.3);color:var(--gold);padding:5px 14px;border-radius:20px;cursor:pointer;font-size:12px;font-family:var(--font);transition:background .2s,border-color .2s}.btn-rules-link:hover{background:#ffd7001a;border-color:var(--gold)}.lobby-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1e5a36,#0f2e1a);padding:20px;overflow-y:auto}.lobby-container{background:#00000080;border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:36px;width:600px;max-width:95vw;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lobby-title{text-align:center;color:var(--gold);font-size:28px;margin-bottom:20px}.lobby-room-info{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:16px}.room-id-label{color:var(--text-muted);font-size:14px}.room-id-value{font-family:monospace;font-size:22px;font-weight:700;color:var(--gold);letter-spacing:4px}.lobby-share{display:flex;gap:10px;margin-bottom:16px}.share-link-input{flex:1;font-size:13px}.player-count{text-align:center;color:var(--text-muted);font-size:14px;margin-bottom:20px}.teams-layout{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}.team-column{flex:1;display:flex;flex-direction:column;gap:8px}.team-header{font-size:16px;font-weight:700;text-align:center;padding:6px;border-radius:6px}.team-seats-label{text-align:center;font-size:11px;color:var(--text-muted);margin-bottom:4px}.team-a-label{color:var(--team-a-light)}.team-b-label{color:var(--team-b-light)}.vs-divider{display:flex;align-items:center;color:var(--text-muted);font-weight:700;padding-top:40px}.player-slot{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;background:#0003;border:1px solid rgba(255,255,255,.08)}.player-slot.occupied{border-color:#fff3;background:#ffffff0f}.player-slot.is-me{border-color:var(--gold);background:#ffd70014}.seat-number{font-size:11px;color:var(--text-muted);font-family:monospace;min-width:24px}.player-name{flex:1;font-weight:600;font-size:14px}.waiting-text{flex:1;color:var(--text-muted);font-style:italic;font-size:13px}.team-badge{font-size:11px;font-weight:700;padding:2px 7px;border-radius:4px}.team-a-badge{background:var(--team-a);color:#fff}.team-b-badge{background:var(--team-b);color:#fff}.lobby-actions{display:flex;flex-direction:row;align-items:stretch;gap:12px;justify-content:center}.lobby-actions>.btn{flex:1;justify-content:center}.waiting-host{text-align:center;color:var(--text-muted);font-style:italic;font-size:14px}.disconnect-banner{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 16px;background:#282828eb;color:#f0c040;font-size:.9rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none}.disconnect-banner--urgent{background:#b41e1eeb;color:#fff;animation:urgent-pulse 1.2s ease-in-out infinite}@keyframes urgent-pulse{0%,to{opacity:1}50%{opacity:.72}}.disconnect-spinner{flex-shrink:0;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:dc-spin .75s linear infinite}@keyframes dc-spin{to{transform:rotate(360deg)}}.game-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:20px;color:var(--text-muted)}.game-screen{display:flex;height:100vh;background:radial-gradient(ellipse at center,var(--table-green-light) 0%,var(--table-green) 50%,var(--table-border) 100%);overflow:hidden}.game-sidebar-left{width:180px;min-width:180px;display:flex;flex-direction:column;gap:8px;padding:8px;background:#0000004d;border-right:1px solid rgba(255,255,255,.08);overflow-y:auto}.game-board{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.player-table{flex:1;position:relative;display:grid;grid-template-areas:". top ." "top-left center top-right" "btm-left center btm-right" ". bottom .";grid-template-columns:1fr 2fr 1fr;grid-template-rows:auto 1fr 1fr auto;gap:4px;padding:8px;min-height:0}.player-slot-pos{display:flex;align-items:stretch}.player-pos-top{grid-area:top;justify-content:center}.player-pos-top-right{grid-area:top-right;align-items:flex-start}.player-pos-top-left{grid-area:top-left;align-items:flex-start}.player-pos-bottom-right{grid-area:btm-right;align-items:flex-end}.player-pos-bottom-left{grid-area:btm-left;align-items:flex-end}.player-pos-bottom{grid-area:bottom;justify-content:center}.table-center{grid-area:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#0003;border-radius:50%;padding:16px;position:relative}.trump-display-center{display:flex;flex-direction:column;align-items:center;line-height:1}.trump-symbol-big{font-size:32px}.trump-red .trump-symbol-big{color:var(--card-red)}.trump-black .trump-symbol-big{color:#fff}.trump-joker .trump-symbol-big{font-size:28px}.trump-suit-hearts .trump-symbol-big{color:#c62828}.trump-suit-diamonds .trump-symbol-big{color:#d84315}.trump-suit-clubs .trump-symbol-big{color:#2e7d32}.trump-suit-spades .trump-symbol-big{color:#1a1a1a}.trump-joker .trump-label-small{color:#f9a825}.trump-label-small{font-size:10px;text-transform:capitalize;color:var(--text-muted)}.current-trick{width:100%}.trick-cards{display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.trick-card-slot{display:flex;flex-direction:column;align-items:center;gap:2px}.trick-player-name{font-size:9px;color:var(--text-muted);max-width:50px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trick-count{font-size:13px;font-weight:600}.team-a-text{color:#64b5f6}.team-b-text{color:#ef9a9a}.trick-divider{color:var(--text-muted)}.trick-result-msg{position:absolute;background:#000000bf;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:600;color:var(--gold);white-space:nowrap}.center-bid-display{font-size:13px}.center-bid-value{font-weight:700;color:var(--gold)}.action-panel{grid-area:center;position:relative;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px;pointer-events:none}.center-panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;padding:12px 16px;min-width:280px;max-width:500px;width:100%;pointer-events:auto}.waiting-turn-msg{text-align:center;color:var(--text-muted);font-style:italic;font-size:13px;padding:8px}.my-turn-indicator{background:#ffd70026;border:1px solid var(--gold);border-radius:8px;padding:6px 14px;color:var(--gold);font-weight:600;font-size:13px}.player-area{background:#00000040;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:6px 8px;display:flex;flex-direction:column;gap:4px;width:100%;transition:border-color .2s}.player-area-me{background:#00000059;border-color:#ffffff26}.player-turn-active{border-color:var(--gold)!important;box-shadow:0 0 8px #ffd7004d}.team-a-player{background:#1565c02e;border-left:3px solid var(--team-a)}.team-b-player{background:#b71c1c2e;border-left:3px solid var(--team-b)}.team-a-player.player-area-me{background:#1565c047}.team-b-player.player-area-me{background:#b71c1c47}.player-info-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.player-name-label{font-size:12px;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-name-me{color:var(--gold)}.player-badges{display:flex;gap:4px;flex-wrap:wrap}.shuffler-badge{font-size:10px;padding:1px 5px;border-radius:3px;background:#ffd70033;color:var(--gold);font-weight:700}.shuffle-count-badge{font-size:10px;padding:1px 4px;border-radius:3px;background:#64b5f626;color:#64b5f6d9;font-weight:600}.gulam-badge{font-size:9px;padding:1px 5px;border-radius:3px;background:var(--btn-danger);color:#fff;font-weight:700;align-content:center}.raja-badge{font-size:9px;padding:1px 5px;border-radius:3px;background:var(--gold-dark);color:#000;font-weight:700;align-content:center}.announcement-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:3000;pointer-events:none;animation:announce-bg-in .35s ease forwards,announce-bg-out .4s 2.8s ease forwards}.gulam-announcement-overlay{background:#780a0a8c}.raja-announcement-overlay{background:#6446008c}.announcement-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:28px 52px;border-radius:20px;text-align:center;animation:announce-card-in .45s cubic-bezier(.34,1.56,.64,1) forwards,announce-card-out .4s 2.8s ease forwards}.gulam-announcement-overlay .announcement-card{background:#1e0505ed;border:2px solid #ef5350;box-shadow:0 0 50px #dc3232b3,inset 0 0 20px #c81e1e26}.raja-announcement-overlay .announcement-card{background:#140e00ed;border:2px solid #fdd835;box-shadow:0 0 50px #ffd20099,inset 0 0 20px #c8a00026}.announcement-icon{font-size:3.2rem;line-height:1;animation:announce-icon-pop .5s .2s cubic-bezier(.34,1.56,.64,1) both}.announcement-name{font-size:1rem;font-weight:600;color:#ffffffbf;letter-spacing:1px;text-transform:uppercase}.announcement-title{font-size:2.8rem;font-weight:900;letter-spacing:6px;line-height:1}.gulam-announce-title{color:#ff6b6b;text-shadow:0 0 20px rgba(255,80,80,.8);animation:gulam-shake .5s .5s ease both}.raja-announce-title{color:#fdd835;text-shadow:0 0 20px rgba(255,210,0,.8);animation:raja-glow-pulse .8s .4s ease-in-out infinite alternate}.announcement-sub{font-size:.8rem;color:#ffffff8c;font-style:italic;letter-spacing:.5px}@keyframes announce-bg-in{0%{opacity:0}to{opacity:1}}@keyframes announce-bg-out{0%{opacity:1}to{opacity:0}}@keyframes announce-card-in{0%{opacity:0;transform:scale(.4) translateY(-30px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes announce-card-out{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.85) translateY(16px)}}@keyframes announce-icon-pop{0%{transform:scale(0) rotate(-30deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}@keyframes gulam-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes raja-glow-pulse{0%{text-shadow:0 0 10px rgba(255,210,0,.6)}to{text-shadow:0 0 30px rgba(255,220,0,1),0 0 60px rgba(255,180,0,.5)}}.connected-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.connected-dot.connected{background:#66bb6a}.connected-dot.disconnected{background:#ef5350}.turn-indicator{font-size:10px;font-weight:700;color:var(--gold);background:#ffd70026;padding:1px 6px;border-radius:4px;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.player-cards{display:flex;flex-wrap:wrap;gap:4px}.card-group{display:flex;flex-direction:column;gap:2px}.card-group-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.card-row{display:flex;gap:2px;flex-wrap:wrap}.card{position:relative;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-user-select:none;user-select:none;box-shadow:0 2px 6px var(--card-shadow);transition:transform .12s,box-shadow .12s}.card-sm{width:var(--card-w-sm);height:var(--card-h-sm);font-size:10px}.card-md{width:var(--card-w-md);height:var(--card-h-md);font-size:13px}.card-lg{width:var(--card-w-lg);height:var(--card-h-lg);font-size:16px}.card-empty{background:#ffffff0d;border:1px dashed rgba(255,255,255,.15)}.card-back{background:var(--card-back-bg);border:1px solid rgba(255,255,255,.15);overflow:hidden}.card-back-pattern{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,var(--card-back-bg),var(--card-back-bg) 4px,var(--card-back-accent) 4px,var(--card-back-accent) 8px)}.card-back-inner{background:var(--card-back-bg);border:2px solid rgba(255,255,255,.2);border-radius:4px;width:75%;height:75%;display:flex;align-items:center;justify-content:center}.card-back-symbol{font-size:1.4em;font-weight:700;color:#ffffff4d}.card-face{background:var(--card-bg);border:1px solid rgba(0,0,0,.15);padding:3px;overflow:hidden}.card-red{color:var(--card-red)}.card-black{color:var(--card-black)}.card-suit-hearts{color:#c62828}.card-suit-diamonds{color:#d84315}.card-suit-clubs{color:#2e7d32}.card-suit-spades{color:#1a1a1a}.card-corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1.1}.card-top-left{top:3px;left:3px}.card-bottom-right{bottom:3px;right:3px;transform:rotate(180deg)}.card-value{font-weight:700;font-size:.9em}.card-suit-small{font-size:.8em}.trick-result-cards .card-suit-small{font-size:0}.trick-result-cards .card-suit-large{font-size:1em}.card-center{display:flex;align-items:center;justify-content:center}.card-suit-large{font-size:1.8em}.card-playable{cursor:pointer;box-shadow:0 0 0 2px #4caf50,0 2px 8px var(--card-shadow)}.card-playable:hover{transform:translateY(-6px);box-shadow:0 0 0 2px #81c784,0 6px 16px #00000080}.bidding-panel{display:flex;flex-direction:column;gap:10px}.bidding-title{font-size:16px;font-weight:700;color:var(--gold);text-align:center}.current-bid-info{font-size:13px;display:flex;gap:4px;align-items:center;justify-content:center}.label{color:var(--text-muted)}.bid-value{font-weight:700;color:var(--gold);font-size:16px}.bid-by{color:var(--text-muted)}.your-turn-msg{text-align:center;color:var(--gold);font-weight:600;font-size:13px}.bid-buttons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.btn-bid{min-width:52px;padding:8px 14px;font-size:15px;font-weight:700;border-radius:8px;background:#1565c0;color:#fff;border:1px solid rgba(255,255,255,.15)}.btn-bid:hover{background:#1976d2}.btn-pass{background:var(--btn-secondary)}.btn-pass:hover{background:var(--btn-secondary-hover)}.btn-bot{background:linear-gradient(135deg,#1a237e,#283593);color:#fff;border:1px solid rgba(100,130,255,.4)}.btn-bot:hover{background:linear-gradient(135deg,#283593,#3949ab)}.bid-history{margin-top:6px}.bid-history-title{font-size:11px;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px}.bid-history-list{display:flex;flex-direction:column;gap:2px;max-height:80px;overflow-y:auto}.bid-history-item{display:flex;gap:8px;font-size:12px}.bid-player-name{color:var(--text-muted)}.bid-amount.bid-pass{color:#ef5350}.bid-amount.bid-num{color:var(--gold);font-weight:700}.trump-selector{display:flex;flex-direction:column;gap:10px;align-items:center}.trump-selector-title{font-size:15px;font-weight:700;color:var(--gold);text-align:center}.trump-selector-subtitle{font-size:13px;color:var(--text-muted);text-align:center}.trump-suit-buttons{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.btn-trump{min-width:80px;padding:12px 16px;border-radius:10px;display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--card-bg)}.btn-trump-red{color:var(--card-red)}.btn-trump-black{color:var(--card-black)}.btn-trump-joker{color:#f9a825;border:2px solid #f9a825}.btn-trump:hover{transform:scale(1.08);box-shadow:0 4px 12px #0000004d}.trump-symbol{font-size:28px}.trump-label{font-size:12px;font-weight:600}.btn-trump-hidden{color:var(--text-muted);border:2px dashed var(--border);font-size:22px}.trump-hidden-pick-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:8px 0}.trump-hidden-card-btn{background:none;border:2px solid transparent;border-radius:8px;padding:3px;cursor:pointer;transition:border-color .15s,transform .15s}.trump-hidden-card-btn:hover{border-color:var(--gold);transform:scale(1.08)}.call8-info{display:flex;flex-direction:column;gap:8px;align-items:center}.call8-info h3{color:var(--gold);font-size:15px}.call8-info p{font-size:13px;color:var(--text-muted)}.call8-sub{font-size:13px;color:var(--text-muted);margin:2px 0}.call8-warning{color:#ef9a9a!important;font-size:12px}.call8-buttons{display:flex;gap:10px;justify-content:center}.game-info-panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:6px}.game-info-row{display:flex;justify-content:space-between;gap:6px;font-size:12px;align-items:center}.info-label{color:var(--text-muted);font-size:11px;text-transform:uppercase;white-space:nowrap}.info-value{font-weight:600;font-size:12px;text-align:right;word-break:break-word}.trump-display{font-size:14px}.text-red{color:var(--card-red)}.text-black{color:#fff}.suit-color-hearts{color:#c62828}.suit-color-diamonds{color:#d84315}.suit-color-clubs{color:#2e7d32}.suit-color-spades{color:#1a1a1a}.suit-color-joker{color:#f9a825}.score-positive{color:#81c784}.score-negative{color:#ef9a9a}.turn-name{color:var(--gold)}.phase-label{text-transform:capitalize;color:var(--text-muted)}.scoreboard-panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:10px;padding:10px 12px}.scoreboard-title{font-size:13px;font-weight:700;color:var(--gold);margin-bottom:8px;text-align:center}.scoreboard-team{display:flex;flex-direction:column;gap:4px}.scoreboard-team-header{font-size:11px;font-weight:700;text-transform:uppercase;margin-bottom:2px}.scoreboard-divider{height:1px;background:#ffffff1a;margin:8px 0}.scoreboard-row{display:flex;align-items:center;gap:4px;font-size:11px;padding:2px 0}.gulam-row{opacity:.7}.sb-seat{font-family:monospace;color:var(--text-muted);min-width:20px}.sb-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-shuffler-badge{color:var(--gold);font-size:10px}.sb-badges{display:flex;gap:2px}.sb-score{font-weight:700;font-size:12px;min-width:28px;text-align:right}.round-end-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.round-end-modal{background:#0f2e1a;border:2px solid rgba(255,255,255,.15);border-radius:20px;padding:36px;max-width:480px;width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px #000000b3;display:flex;flex-direction:column;gap:16px}.round-end-title{text-align:center;color:var(--gold);font-size:22px}.game-over-title{text-align:center;color:var(--gold);font-size:28px}.game-over-winner{text-align:center;font-size:20px;font-weight:700}.game-over-modal{border-color:var(--gold);max-width:520px}.game-over-actions{display:flex;flex-direction:column;gap:10px;margin-top:4px}.game-over-actions .btn{width:100%;justify-content:center}.btn-ghost{background:transparent;color:#ffffff80;border:1px solid rgba(255,255,255,.2)}.btn-ghost:hover:not(:disabled){background:#ffffff12;color:#ffffffbf}.game-summary{display:flex;flex-direction:column;gap:0}.game-summary-stats{display:flex;justify-content:center;align-items:center;gap:0;background:#00000040;border-radius:10px;padding:14px 12px}.game-summary-stat{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.game-summary-stat-value{font-size:20px;font-weight:700;color:#fff}.game-summary-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#ffffff73}.game-summary-stat-divider{width:1px;height:36px;background:#ffffff1f;flex-shrink:0}.game-summary-team-scores{display:flex;align-items:center;justify-content:space-between;background:#0003;border-radius:8px;padding:10px 14px;margin-top:8px;gap:8px}.gs-team-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.gs-team-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.gs-team-stat{font-size:13px;color:#ffffffbf}.gs-team-vs{font-size:11px;color:#ffffff4d;flex-shrink:0}.game-summary-section-title{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#fff6;margin:14px 0 6px;padding-bottom:4px;border-bottom:1px solid rgba(255,255,255,.08)}.gulam-raja-list{display:flex;flex-wrap:wrap;gap:6px}.gulam-raja-chip{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.gulam-chip{background:#b71c1c40;border:1px solid rgba(239,83,80,.4);color:#ef9a9a}.raja-chip{background:#f5d7001a;border:1px solid rgba(245,215,0,.35);color:#ffd54f}.round-history-scroll{max-height:180px;overflow-y:auto;border-radius:8px;border:1px solid rgba(255,255,255,.08)}.round-history-table{width:100%;border-collapse:collapse;font-size:12px}.round-history-table th{color:#ffffff73;font-weight:500;padding:5px 7px;text-align:left;border-bottom:1px solid rgba(255,255,255,.1);background:#0000004d;position:sticky;top:0}.round-history-table td{padding:4px 7px;color:#fffc;vertical-align:middle}.round-history-table tr:nth-child(2n) td{background:#ffffff08}.rh-round{color:#fff6;font-size:11px;text-align:center;width:48px}.rh-gulam-cell{color:#ef9a9a;font-weight:500}.rh-raja-cell{color:#ffd54f;font-weight:500}.gameover-prompt-modal{border-color:var(--gold)}.gameover-prompt-sub{text-align:center;color:var(--text-muted);font-size:14px}.gameover-prompt-buttons{display:flex;gap:12px;justify-content:center;margin-top:8px;flex-wrap:wrap}.gameover-prompt-buttons .btn{min-width:140px;padding:12px 20px;font-size:15px;font-weight:700}.round-result-details{background:#0000004d;border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:8px}.result-row{display:flex;justify-content:space-between;font-size:14px;gap:12px}.result-row span:first-child{color:var(--text-muted)}.result-score{font-weight:700;font-size:16px}.gulam-event{color:#ef9a9a;font-weight:700}.deal-transfer{color:#90caf9}.round-end-scores{background:#0000004d;border-radius:10px;padding:14px}.round-end-scores h4{color:var(--text-muted);font-size:12px;text-transform:uppercase;margin-bottom:8px}.score-row{display:flex;justify-content:space-between;font-size:13px;padding:3px 0}.call8-title{color:var(--gold);font-size:15px;text-align:center}.call8-panel{text-align:center}.call8-panel p{font-size:13px;color:var(--text-muted)}.call8-warning{color:#ef9a9a!important;font-size:12px!important}.dealing-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a1e12ed;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.dealing-content{display:flex;flex-direction:column;align-items:center;gap:20px}.dealing-deck-anim{position:relative;width:80px;height:110px}.dealing-card-anim{position:absolute;top:0;left:0;animation:deal-fly 2.4s ease-in-out infinite}@keyframes deal-fly{0%{transform:translate(0) rotate(0);opacity:1}40%{transform:translate(60px,-40px) rotate(15deg);opacity:1}60%{transform:translate(120px,-10px) rotate(25deg);opacity:.6}80%{transform:translate(80px,40px) rotate(10deg);opacity:.3}to{transform:translate(0) rotate(0);opacity:0}}.dealing-title{font-size:22px;color:var(--gold);font-weight:700;text-align:center}.dealing-subtitle{font-size:14px;color:var(--text-muted);text-align:center}.dealing-players{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;max-width:280px}.dealing-player-chip{font-size:12px;padding:3px 10px;border-radius:12px;font-weight:600}.trick-result-bar{background:#0a1e12f7;border:2px solid currentColor;border-radius:12px;padding:10px 16px;display:flex;flex-direction:column;align-items:center;gap:6px;box-shadow:0 4px 20px #0009;font-weight:700;font-size:12px;width:100%;pointer-events:auto;align-self:center;animation:trick-pop .2s ease-out}.trick-result-cards{display:flex;gap:4px;flex-wrap:wrap;justify-content:center}@keyframes trick-pop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.trick-reveal-msg{background:#ffd70026;border:1px solid var(--gold);border-radius:8px;padding:6px 16px;color:var(--gold);font-weight:600;font-size:14px;text-align:center}.tricks-scoreboard{display:flex;flex-direction:column;gap:4px;width:100%;padding:0 4px}.tricks-team{display:flex;align-items:center;gap:4px;opacity:.7;transition:opacity .2s}.tricks-team-bidding{opacity:1}.tricks-team-label{font-size:10px;font-weight:700;min-width:42px}.tricks-bar{display:flex;gap:2px;flex:1}.tricks-pip{flex:1;height:8px;border-radius:2px;transition:background .3s}.pip-empty{background:#ffffff1f}.pip-filled-a{background:#1976d2}.pip-filled-b{background:#c62828}.tricks-count{font-size:11px;font-weight:700;min-width:14px;text-align:right}.tricks-bid-target{font-size:10px;color:var(--text-muted);text-align:center}.scoreboard{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.scoreboard-title{font-size:13px;font-weight:700;color:var(--gold);text-align:center}.shuffler-score-block{display:flex;flex-direction:column;gap:4px}.shuffler-score-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;display:flex;align-items:center;gap:4px}.shuffler-name{font-size:14px;font-weight:700;color:var(--text-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shuffler-score-value{font-size:26px;font-weight:800;line-height:1}.score-bar-track{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;position:relative}.score-bar-fill{height:100%;border-radius:4px;transition:width .5s ease,background .5s ease}.score-bar-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--text-muted)}.trump-inline{font-size:13px;font-weight:600;text-align:center;padding:4px;background:#0003;border-radius:6px}.trump-inline.trump-red{color:var(--card-red)}.trump-inline.trump-black{color:#fff}.gulam-item{display:flex;align-items:center;gap:4px;font-size:11px}.gulam-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted)}.result-big{font-weight:800;font-size:18px;padding:4px 0}.round-end-score-block{text-align:center;background:#0000004d;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:2px}.score-label{font-size:11px;color:var(--text-muted);text-transform:uppercase}.score-value-big{font-size:32px;font-weight:800;line-height:1}.score-delta-label{font-size:12px;font-weight:600;opacity:.85}.next-round-countdown{text-align:center;font-size:14px;color:var(--text-muted)}.countdown-num{font-size:20px;font-weight:800;color:var(--gold);display:inline-block;min-width:24px}.chat-toggle-btn{position:fixed;bottom:20px;right:20px;z-index:500;width:52px;height:52px;border-radius:50%;border:none;background:#1e5a32f2;box-shadow:0 4px 16px #00000080;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s}.chat-toggle-btn:hover{transform:scale(1.08);box-shadow:0 6px 20px #0009}.chat-unread-badge{position:absolute;top:2px;right:2px;background:#c62828;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;pointer-events:none}.chat-panel{position:fixed;bottom:84px;right:16px;z-index:600;width:300px;max-width:calc(100vw - 32px);height:400px;max-height:60dvh;background:#06160cf7;border:1px solid rgba(255,215,0,.2);border-radius:16px;display:flex;flex-direction:column;box-shadow:0 8px 32px #000000b3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);overflow:hidden;animation:chat-slide-up .18s ease-out}@keyframes chat-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.chat-title{font-weight:700;font-size:14px;color:var(--gold);letter-spacing:.5px}.chat-close{background:none;border:none;color:#ffffff80;font-size:16px;cursor:pointer;padding:2px 6px;border-radius:6px;line-height:1;transition:color .15s}.chat-close:hover{color:#fff}.chat-messages{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:6px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.chat-empty{text-align:center;color:#ffffff4d;font-size:12px;margin-top:20px}.chat-msg{display:flex;flex-direction:column;align-items:flex-start;gap:1px;max-width:90%}.chat-msg-me{align-self:flex-end;align-items:flex-end}.chat-msg-name{font-size:10px;font-weight:700;opacity:.85}.chat-spectator-tag{font-size:9px;margin-right:3px;opacity:.7}.chat-msg-text{background:#ffffff1a;border-radius:10px 10px 10px 2px;padding:5px 10px;font-size:13px;line-height:1.4;word-break:break-word}.chat-msg-me .chat-msg-text{background:#2e7d3299;border-radius:10px 10px 2px;color:#e8f5e9}.chat-input-row{display:flex;gap:6px;padding:8px 10px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.chat-input{flex:1;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:7px 14px;color:#fff;font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s}.chat-input:focus{border-color:#ffd70066}.chat-input::placeholder{color:#ffffff4d}.chat-send-btn{width:36px;height:36px;border-radius:50%;border:none;background:#2e7d32;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,opacity .15s}.chat-send-btn:disabled{opacity:.4;cursor:default}.chat-send-btn:not(:disabled):hover{background:#388e3c}.mobile-topbar,.mobile-side-stat{display:none}@media (max-width: 900px){.game-sidebar-left{width:140px;min-width:140px}}@media (max-width: 700px){html,body{overflow:hidden}:root{--card-w-sm: 30px;--card-h-sm: 42px;--card-w-md: 46px;--card-h-md: 64px}.mobile-topbar{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#071a0f,#0f3a1c,#071a0f);border-bottom:1px solid rgba(255,215,0,.15);padding:5px 12px;gap:8px;flex-shrink:0;height:40px;box-shadow:0 2px 10px #00000080}.mtb-left,.mtb-center,.mtb-right{display:flex;align-items:center;gap:8px}.mtb-center{flex:1;justify-content:center}.mtb-right{justify-content:flex-end}.mtb-round{font-size:11px;font-weight:800;color:var(--gold);letter-spacing:.5px;background:#ffd70026;padding:2px 7px;border-radius:6px}.mtb-room-id{font-size:10px;font-weight:700;font-family:monospace;color:#ffd700b3;letter-spacing:.5px;opacity:.8}.mtb-room-id-copy{cursor:pointer;padding:1px 4px;border-radius:3px;transition:background .15s}.mtb-room-id-copy:active{background:#ffd70026}.mtb-trump{font-size:20px;font-weight:700;line-height:1}.mtb-red{color:var(--card-red)}.mtb-black{color:#fff}.mtb-joker{color:#f9a825}.mtb-bid{font-size:11px;color:var(--text-muted)}.mtb-bid strong{color:var(--gold);font-size:13px}.mtb-phase{font-size:11px;font-weight:600;text-transform:capitalize;color:#fff9;background:#ffffff0f;padding:2px 8px;border-radius:6px}.mtb-shuffler-name{font-size:11px;color:var(--text-muted);max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mtb-score{font-size:15px;font-weight:800;min-width:28px;text-align:right}.game-sidebar-left{display:none}.game-screen{flex-direction:column;height:100dvh;overflow:hidden;position:relative;background:radial-gradient(ellipse at 50% 15%,#1a5c30,#0a2015 65%)}.game-board{display:flex;flex-direction:column;flex:1;min-height:0;overflow:visible;position:relative}.player-table{flex:1;min-height:0;display:grid;position:relative;grid-template-areas:"top        top" "top-left   top-right" "center     center" "btm-left   btm-right" "bottom     bottom";grid-template-rows:auto .9fr 1.5fr .9fr auto;grid-template-columns:1fr 1fr;gap:10px;padding:4px 3px 0;overflow:hidden}.player-pos-top{align-items:stretch;min-width:0}.player-pos-top-left,.player-pos-top-right{align-items:stretch;flex-direction:column;min-width:0;overflow:hidden;justify-content:flex-start}.player-pos-bottom-left,.player-pos-bottom-right{align-items:stretch;flex-direction:column;min-width:0;overflow:hidden;justify-content:flex-end}.player-pos-bottom{align-items:stretch;flex-direction:column;min-width:0}.table-center{grid-area:center;position:relative;left:unset;top:unset;bottom:unset;transform:none;width:auto;border-radius:10px;background:radial-gradient(ellipse at center,#0a2d14cc,#04120aa6);border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 0 20px #0006;padding:8px 6px;gap:6px;justify-content:center;overflow:hidden}.trump-display-center{gap:2px}.trump-symbol-big{font-size:26px}.trump-label-small{font-size:8px;display:block}.tricks-scoreboard{gap:3px;width:100%}.tricks-team{gap:2px}.tricks-bar{gap:1px;flex-wrap:wrap}.tricks-pip{height:5px;width:9px;border-radius:2px}.tricks-team-label{font-size:8px;min-width:26px;font-weight:700}.tricks-count{font-size:10px;font-weight:800}.tricks-bid-target{font-size:8px;color:var(--gold);display:block;text-align:center}.trick-cards{gap:3px;flex-wrap:wrap;justify-content:center}.trick-card-slot{align-items:center;gap:1px}.trick-player-name{font-size:7px}.center-bid-display{font-size:10px}.table-center .card{width:28px!important;height:36px!important;border-radius:3px!important}.table-center .card-value{font-size:7px}.table-center .card-suit-small{font-size:6px}.table-center .card-suit-large{display:none}.table-center .card-corner{padding:1px;gap:0}.player-pos-top .player-area{flex-direction:column;align-items:stretch;padding:6px;gap:3px;background:#0000006b;border:1px solid rgba(255,255,255,.1);border-top:none;border-radius:0 0 10px 10px;width:80%;min-height:80px;box-sizing:border-box;overflow:hidden}.player-pos-top .player-area.player-turn-active{border-color:#f59e0b!important;box-shadow:0 4px 14px #f59e0b59}.player-pos-top .player-info-bar{flex-direction:row;align-items:center;width:100%;min-width:unset;max-width:unset;flex-shrink:0;gap:3px;flex-wrap:wrap}.player-pos-top .player-name-label{font-size:9px;max-width:none;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-pos-top .team-badge{font-size:7px;padding:0 3px;min-width:unset}.player-pos-top .spectator-join-btn{width:14px;height:14px;font-size:11px;margin-right:2px}.player-pos-top .turn-indicator{font-size:7px;padding:1px 3px}.player-pos-top .player-cards{width:100%;flex-direction:row;flex-wrap:nowrap;gap:4px;overflow:hidden}.player-pos-top .card-group{flex:1;flex-direction:column;align-items:flex-start;gap:2px;min-width:0}.player-pos-top .card-group.card-group-visible{margin-right:10%}.player-pos-top .card-group-label{font-size:6px;color:#ffffff59;line-height:1}.player-pos-top .card-row{flex-direction:row;gap:1px;flex-wrap:nowrap;overflow:hidden}.player-pos-top .card{width:22px!important;height:31px!important;border-radius:3px!important;flex-shrink:0;margin-right:-5px}.player-pos-top .card:last-child{margin-right:0}.player-pos-top .card-group-visible .card{width:30px!important;height:40px!important;margin-right:0}.player-pos-top .card-group-visible .card:last-child{margin-right:0}.player-pos-top .card-value{font-size:5px;line-height:1}.player-pos-top .card-group-visible .card-value{font-size:6px}.player-pos-top .card-suit-small{font-size:5px}.player-pos-top .card-group-visible .card-suit-small{font-size:3px}.player-pos-top .card-suit-large{font-size:11px}.player-pos-top .card-corner{padding:1px;gap:0}.player-pos-top .card-back-symbol{font-size:7px}.player-pos-top-left .player-area,.player-pos-top-right .player-area,.player-pos-bottom-left .player-area,.player-pos-bottom-right .player-area{padding:4px 3px;border-radius:8px;background:#0000006b;border:1px solid rgba(255,255,255,.1);overflow:hidden;height:100%;width:75%;box-sizing:border-box;display:flex;flex-direction:column;gap:2px}.player-pos-top-right .player-area,.player-pos-bottom-right .player-area{align-self:end}.player-pos-top-left .player-area.player-turn-active,.player-pos-top-right .player-area.player-turn-active,.player-pos-bottom-left .player-area.player-turn-active,.player-pos-bottom-right .player-area.player-turn-active{border-color:#f59e0b!important;box-shadow:0 0 8px #f59e0b66;background:#1e140085}.player-pos-top-left .player-info-bar,.player-pos-top-right .player-info-bar,.player-pos-bottom-left .player-info-bar,.player-pos-bottom-right .player-info-bar{flex-wrap:nowrap;overflow:hidden;gap:3px;flex-shrink:0;height:12px}.player-pos-top-left .player-name-label,.player-pos-top-right .player-name-label,.player-pos-bottom-left .player-name-label,.player-pos-bottom-right .player-name-label{font-size:8px;max-width:50px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-pos-top-left .team-badge,.player-pos-top-right .team-badge,.player-pos-bottom-left .team-badge,.player-pos-bottom-right .team-badge{font-size:8px;padding:0 3px;min-width:unset;align-content:space-around}.player-pos-top-left .spectator-join-btn,.player-pos-top-right .spectator-join-btn,.player-pos-bottom-left .spectator-join-btn,.player-pos-bottom-right .spectator-join-btn{width:14px;height:14px;font-size:11px;margin-right:2px}.player-pos-top-left .player-cards,.player-pos-top-right .player-cards,.player-pos-bottom-left .player-cards,.player-pos-bottom-right .player-cards{flex-direction:column;flex-wrap:nowrap;flex:1;gap:3px;overflow:hidden;justify-content:flex-start}.player-pos-top-left .card-group,.player-pos-top-right .card-group,.player-pos-bottom-left .card-group,.player-pos-bottom-right .card-group{flex-direction:row;align-items:flex-start;gap:2px;flex-shrink:0}.player-pos-top-left .card-group-label,.player-pos-top-right .card-group-label,.player-pos-bottom-left .card-group-label,.player-pos-bottom-right .card-group-label{font-size:6px;color:#ffffff4d;min-width:10px;flex-shrink:0;line-height:1;padding-top:1px}.player-pos-top-left .card-row,.player-pos-top-right .card-row,.player-pos-bottom-left .card-row,.player-pos-bottom-right .card-row{gap:1px;flex-wrap:nowrap;overflow:hidden}.player-pos-top-left .card,.player-pos-top-right .card,.player-pos-bottom-left .card,.player-pos-bottom-right .card{width:26px!important;height:32px!important;border-radius:2px!important;flex-shrink:0;margin-right:-6px}.player-pos-top-left .card:last-child,.player-pos-top-right .card:last-child,.player-pos-bottom-left .card:last-child,.player-pos-bottom-right .card:last-child{margin-right:0}.player-pos-top-left .card-group-visible .card-row,.player-pos-top-right .card-group-visible .card-row,.player-pos-bottom-left .card-group-visible .card-row,.player-pos-bottom-right .card-group-visible .card-row{flex-wrap:wrap;gap:2px;overflow:visible}.player-pos-top-left .card-group-visible .card,.player-pos-top-right .card-group-visible .card,.player-pos-bottom-left .card-group-visible .card,.player-pos-bottom-right .card-group-visible .card{width:clamp(28px,7vw,30px)!important;height:clamp(36px,9vw,40px)!important;margin-right:0!important;margin-top:-15px!important}.player-pos-top-left .card-group-visible .card:last-child,.player-pos-top-right .card-group-visible .card:last-child,.player-pos-bottom-left .card-group-visible .card:last-child,.player-pos-bottom-right .card-group-visible .card:last-child{margin-right:0!important}.player-pos-top-left .card-value,.player-pos-top-right .card-value,.player-pos-bottom-left .card-value,.player-pos-bottom-right .card-value{font-size:5px;line-height:1}.player-pos-top-left .card-group-visible .card-value,.player-pos-top-right .card-group-visible .card-value,.player-pos-bottom-left .card-group-visible .card-value,.player-pos-bottom-right .card-group-visible .card-value{font-size:7px}.player-pos-top-left .card-suit-small,.player-pos-top-right .card-suit-small,.player-pos-bottom-left .card-suit-small,.player-pos-bottom-right .card-suit-small{font-size:5px}.player-pos-top-left .card-group-visible .card-suit-small,.player-pos-top-right .card-group-visible .card-suit-small,.player-pos-bottom-left .card-group-visible .card-suit-small,.player-pos-bottom-right .card-group-visible .card-suit-small{font-size:4px}.player-pos-top-left .card-suit-large,.player-pos-top-right .card-suit-large,.player-pos-bottom-left .card-suit-large,.player-pos-bottom-right .card-suit-large{font-size:10px}.player-pos-top-left .card-corner,.player-pos-top-right .card-corner,.player-pos-bottom-left .card-corner,.player-pos-bottom-right .card-corner{gap:0}.player-pos-top-left .card-back-symbol,.player-pos-top-right .card-back-symbol,.player-pos-bottom-left .card-back-symbol,.player-pos-bottom-right .card-back-symbol{font-size:7px}.player-pos-bottom .player-area{border-radius:12px 12px 0 0;padding:5px 12px;background:linear-gradient(180deg,#00000080,#000a05e6);border:1.5px solid rgba(255,255,255,.16);border-bottom:none;gap:3px;flex:1;min-height:170px;box-sizing:border-box;flex-direction:column}.player-pos-bottom .player-area.player-turn-active{border-color:#f59e0b!important;box-shadow:0 -4px 18px #f59e0b4d}.player-pos-bottom .player-info-bar{flex-wrap:nowrap;overflow:hidden}.player-pos-bottom .player-name-label{font-size:12px;color:#fbbf24}.player-pos-bottom .player-cards{flex-direction:column;flex-wrap:nowrap;gap:3px;flex:1;overflow:hidden}.player-pos-bottom .card-group{display:flex;flex-direction:row;align-items:center;gap:5px;flex-shrink:0}.player-pos-bottom .card-group-label{font-size:7px;color:#fff6;min-width:10px;flex-shrink:0;text-transform:uppercase;letter-spacing:.3px}.player-pos-bottom .card-row{display:flex;flex-direction:row;gap:4px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.player-pos-bottom .card-row::-webkit-scrollbar{display:none}.player-pos-bottom .card{width:clamp(30px,7.5vw,40px)!important;height:clamp(40px,9.5vw,50px)!important}.player-pos-bottom .card-value{font-size:clamp(7px,1.8vw,9px)}.player-pos-bottom .card-suit-small{font-size:clamp(5px,1.5vw,8px)}.player-pos-bottom .card-suit-large{font-size:clamp(11px,2.8vw,15px)}.player-pos-top .team-a-player,.player-pos-top-left .team-a-player,.player-pos-top-right .team-a-player,.player-pos-bottom-left .team-a-player,.player-pos-bottom-right .team-a-player,.player-pos-bottom .team-a-player{background:#1565c038!important}.player-pos-top .team-b-player,.player-pos-top-left .team-b-player,.player-pos-top-right .team-b-player,.player-pos-bottom-left .team-b-player,.player-pos-bottom-right .team-b-player,.player-pos-bottom .team-b-player{background:#b71c1c38!important}.player-pos-bottom .team-a-player{background:linear-gradient(180deg,#1565c04d,#1565c026)!important}.player-pos-bottom .team-b-player{background:linear-gradient(180deg,#b71c1c4d,#b71c1c26)!important}.action-panel{grid-area:center;position:relative;z-index:20;display:flex;flex-direction:column;align-items:stretch;justify-content:center;padding:0;pointer-events:none;background:none;max-height:unset;overflow-y:unset}.center-panel{pointer-events:auto;width:100%;max-width:100%;min-width:unset;padding:10px 12px;border-radius:10px;background:#040e08f7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1.5px solid rgba(255,215,0,.25);box-shadow:inset 0 0 20px #00000080;max-height:100%;overflow-y:auto}.center-panel-waiting{pointer-events:none;width:auto;align-self:center;padding:5px 12px;border-radius:20px;background:#0000008c;border:1px solid rgba(255,255,255,.12);box-shadow:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);max-height:unset;overflow-y:unset}.waiting-turn-msg{font-size:11px;padding:0;text-align:center;color:#ffffffa6}.waiting-turn-msg strong{color:#ffffffe6}.waiting-bid-info{margin-left:4px}.my-turn-indicator{pointer-events:none;font-size:11px;padding:4px 12px;border-radius:20px;animation:pulse 1s infinite;white-space:nowrap;align-self:center}.trick-reveal-msg{pointer-events:none;font-size:11px;padding:4px 12px;border-radius:20px;text-align:center;white-space:nowrap;align-self:center}.btn{min-height:46px;padding:12px 18px;font-size:15px;border-radius:12px}.btn-bid{min-width:58px;min-height:52px;font-size:20px;font-weight:800;padding:12px 10px;border-radius:12px}.bidding-panel{gap:6px}.bidding-title{font-size:13px;margin-bottom:0}.your-turn-msg,.current-bid-info{font-size:12px}.bid-buttons{gap:8px;justify-content:center}.btn-bid{min-width:52px;min-height:44px;font-size:18px;font-weight:800;padding:8px 10px;border-radius:10px}.bid-history{margin-top:4px}.bid-history-title{font-size:9px;margin-bottom:2px}.bid-history-list{flex-direction:row!important;flex-wrap:wrap;gap:2px 6px;max-height:36px;overflow-y:hidden}.bid-history-item{font-size:10px;gap:3px}.bid-player-name{color:#ffffff8c}.btn-trump{min-width:76px;min-height:72px;padding:10px;border-radius:12px}.trump-symbol{font-size:28px}.trump-label{font-size:11px;font-weight:700}.trump-suit-buttons{gap:8px}.trump-selector-title{font-size:14px}.round-end-overlay{padding:8px}.round-end-modal{padding:22px 18px;gap:14px;border-radius:20px;max-height:90dvh;margin:0}.round-end-title{font-size:20px}.game-over-title{font-size:26px}.result-row{font-size:13px}.result-big{font-size:17px}.score-value-big{font-size:30px}.next-round-countdown{font-size:13px}.countdown-num{font-size:22px}.game-summary-stat-value{font-size:17px}.round-history-scroll{max-height:140px}.round-history-table{font-size:11px}.round-history-table th,.round-history-table td{padding:3px 5px}.dealing-title{font-size:20px}.dealing-subtitle{font-size:13px}.trick-result-bar{font-size:12px;padding:8px 10px;border-radius:10px;min-width:unset;width:75%;height:50%}.trick-result-cards{gap:3px}.trick-result-bar .card{width:30px!important;height:40px!important}.home-screen{padding:16px}.home-card{padding:28px 20px;border-radius:20px;width:100%;max-width:420px}.home-title{font-size:32px}.home-subtitle{font-size:14px}.home-form{gap:16px}.lobby-screen{padding:12px;align-items:center;justify-content:flex-start}.lobby-container{padding:22px 16px;border-radius:18px;width:100%}.teams-layout{flex-direction:row;align-items:flex-start;gap:8px}.team-column{flex:1;min-width:0}.vs-divider{padding-top:0;align-self:center}.team-header{font-size:13px}.team-seats-label{font-size:10px}.player-slot{padding:7px 8px;gap:5px;overflow:hidden}.player-name,.waiting-text{font-size:12px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-number{font-size:11px;flex-shrink:0}.team-badge{font-size:10px;padding:1px 4px;flex-shrink:0;margin-left:auto}.add-bot-btn{font-size:14px;flex-shrink:0}.lobby-actions{flex-direction:column;align-items:stretch}.lobby-actions .btn,.lobby-leave-row{width:100%;justify-content:center}.leave-room-area,.host-end-game-area{display:none!important}.mtb-action-btn{background:none;border:none;cursor:pointer;padding:0;line-height:0;opacity:.88;transition:opacity .15s,transform .1s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.mtb-action-btn:active{opacity:1;transform:scale(.92)}.mtb-confirm-row{display:flex;align-items:center;gap:4px;flex-shrink:0}.mtb-confirm-text{font-size:10px;color:#ffffffb3;white-space:nowrap}.mtb-confirm-btn{border:none;border-radius:3px;padding:2px 6px;font-size:11px;font-weight:700;cursor:pointer;color:#fff;line-height:1.4}.mtb-confirm-yes{background:#2e7d32d9}.mtb-confirm-danger .mtb-confirm-yes{background:#c62828d9}.mtb-confirm-no{background:#464646b3}.mtb-leave-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.88;transition:opacity .15s,transform .15s}.mtb-leave-btn:hover{opacity:1;transform:scale(1.1)}}.voice-join-btn{position:fixed;bottom:88px;right:20px;height:44px;padding:0 14px;border-radius:22px;border:none;background:#1e1e1eeb;box-shadow:0 4px 16px #00000080;font-size:18px;cursor:pointer;display:flex;align-items:center;gap:6px;z-index:200;transition:background .2s,transform .15s,box-shadow .2s}.voice-join-btn:hover{transform:scale(1.05);box-shadow:0 6px 20px #0009}.voice-controls{position:fixed;bottom:88px;right:20px;display:flex;gap:8px;z-index:200}.voice-mic-btn,.voice-leave-btn{height:44px;padding:0 14px;border-radius:22px;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;gap:6px;box-shadow:0 4px 16px #00000080;transition:background .2s,transform .15s,box-shadow .2s}.voice-mic-btn{background:#1e6428eb;box-shadow:0 4px 16px #00c85033}.voice-mic-btn:hover{transform:scale(1.05)}.voice-mic-muted{background:#8c1e1eeb;box-shadow:0 4px 16px #c8323233}.voice-leave-btn{background:#3c3c3ceb}.voice-leave-btn:hover{background:#b41e1eeb;transform:scale(1.05)}.voice-btn-label{font-size:12px;font-weight:600;color:#ffffffe6;letter-spacing:.3px}.voice-error{position:fixed;bottom:144px;right:16px;background:#b41e1ee6;color:#fff;font-size:12px;padding:6px 12px;border-radius:8px;z-index:200;max-width:200px;text-align:center}.player-speaking{box-shadow:0 0 0 2px #50dc78cc,0 0 12px #50dc7866!important;animation:speaking-pulse .8s ease-in-out infinite alternate}@keyframes speaking-pulse{0%{box-shadow:0 0 0 2px #50dc78cc,0 0 8px #50dc784d}to{box-shadow:0 0 0 3px #50dc78,0 0 18px #50dc7899}}.speaking-indicator{font-size:11px;line-height:1;opacity:.5;transition:opacity .2s}.speaking-indicator.speaking-active{opacity:1;animation:speaking-bounce .6s ease-in-out infinite alternate}.speaking-indicator.speaking-muted{opacity:.4}@keyframes speaking-bounce{0%{opacity:.8;transform:scale(.9)}to{opacity:1;transform:scale(1.15)}}.spectator-badge{position:fixed;top:12px;left:50%;transform:translate(-50%);background:#643c00e6;color:var(--gold);font-size:11px;font-weight:800;letter-spacing:1.5px;padding:4px 14px;border-radius:20px;border:1px solid rgba(255,215,0,.3);z-index:300;pointer-events:none}.spectator-count-wrap{position:fixed;top:12px;left:50%;transform:translate(-50%);z-index:300;display:flex;flex-direction:column;align-items:center}.spectator-count-badge{background:#000000a6;color:var(--text-muted);font-size:12px;padding:4px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:background .15s,color .15s}.spectator-count-badge:hover{background:#282828e6;color:var(--text-light)}.spectator-count-badge-self{background:#3c2800bf;border-color:#ffd70040;color:var(--gold)}.spectator-count-badge-self:hover{background:#5a3c00e6}.watchers-popover{margin-top:6px;background:#0f190ff7;border:1px solid rgba(255,215,0,.2);border-radius:10px;padding:8px 14px;min-width:130px;box-shadow:0 4px 16px #0009;animation:chat-slide-up .15s ease-out}.watchers-popover-title{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-bottom:6px}.watchers-popover-name{font-size:13px;color:var(--text-light);padding:3px 0;border-bottom:1px solid rgba(255,255,255,.05)}.watchers-popover-name:last-child{border-bottom:none}.spectator-panel{position:fixed;bottom:160px;right:20px;background:#0a1e0ff2;border:1px solid rgba(255,215,0,.2);border-radius:12px;padding:12px 14px;z-index:200;min-width:170px;max-width:220px;display:flex;flex-direction:column;gap:10px;box-shadow:0 4px 20px #0009}.spectator-panel-section{display:flex;flex-direction:column;gap:5px}.spectator-panel-label{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--gold);text-transform:uppercase}.spectator-chip{font-size:12px;color:var(--text-muted);background:#ffffff0f;padding:3px 8px;border-radius:8px}.spectator-none{font-size:11px;color:#ffffff4d;font-style:italic}.spectator-swap-btn{font-size:12px;background:#1e5032b3;border:1px solid rgba(80,200,100,.2);color:var(--text-light);border-radius:8px;padding:5px 10px;cursor:pointer;text-align:left;transition:background .15s}.spectator-swap-btn:hover{background:#28783ce6}.swap-btn-offline{background:#502800b3;border-color:#ffa0324d;color:#ffa040}.swap-btn-offline:hover{background:#783c00e6}.spectator-request-toggle{width:100%;margin-top:4px}.spectator-choose-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.spectator-close-btn{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;padding:0 2px;line-height:1}.spectator-close-btn:hover{color:var(--text-light)}.spectator-subsection-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.spectator-player-row{display:block;width:100%;text-align:left;padding:6px 10px;font-size:12px;color:var(--text-light);background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;margin-bottom:4px;transition:background .15s}.spectator-player-row:hover{background:#ffffff1f}.spectator-confirm{background:#0a1e14fa;border:1px solid rgba(255,215,0,.25);border-radius:10px;padding:10px 12px;margin-top:6px}.spectator-confirm-text{font-size:12px;color:var(--text-light);margin-bottom:8px}.spectator-confirm-actions{display:flex;gap:6px}.swap-request-toast{position:fixed;top:20px;right:20px;background:#0a2814f7;border:1px solid rgba(255,215,0,.4);border-radius:14px;padding:14px 18px;z-index:500;min-width:220px;box-shadow:0 6px 24px #000000b3;animation:chat-slide-up .2s ease-out}.swap-request-msg{font-size:13px;color:var(--text-light);margin-bottom:10px}.swap-request-actions{display:flex;gap:8px}.btn-sm{padding:6px 14px;font-size:13px}.btn-viewer{background:#1a3a5c;color:#7ec8e3;border:1px solid #3a6a9c;border-radius:8px;font-weight:600;cursor:pointer;transition:background .15s}.btn-viewer:hover{background:#264d7a}.viewer-badge{position:fixed;bottom:16px;left:50%;transform:translate(-50%);background:#0a1e32eb;border:1px solid #3a6a9c;color:#7ec8e3;border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600;z-index:400;pointer-events:none;white-space:nowrap}.viewer-badge.viewer-playing{border-color:#fdd835;color:#fdd835;background:#140f00eb}.btn-watch{background:linear-gradient(135deg,#37474f,#455a64);color:#cfd8dc;border:1px solid rgba(255,255,255,.1)}.host-end-game-area{position:fixed;bottom:140px;right:20px;z-index:200;display:flex;align-items:center}.host-end-game-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.88;transition:opacity .15s,transform .15s}.host-end-game-btn:hover{opacity:1;transform:scale(1.1)}.host-end-confirm{display:flex;align-items:center;gap:6px;background:#140a0af2;border:1px solid rgba(220,60,60,.5);border-radius:20px;padding:5px 10px;box-shadow:0 4px 16px #00000080}.host-end-confirm-label{font-size:12px;color:#ef9a9a;white-space:nowrap}.room-timer{font-variant-numeric:tabular-nums;color:var(--text-muted);font-size:12px}.room-id-mono{font-family:Courier New,monospace;font-weight:700;letter-spacing:1px;color:var(--gold);font-size:13px}.btn-watch:hover{background:linear-gradient(135deg,#455a64,#546e7a)}.leave-room-area{position:fixed;bottom:188px;right:20px;z-index:200;display:flex;align-items:center}.leave-room-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.88;transition:opacity .15s,transform .15s}.leave-room-btn:hover{opacity:1;transform:scale(1.1)}.leave-room-confirm{display:flex;align-items:center;gap:6px;background:#0f0f0ff2;border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:5px 10px;box-shadow:0 4px 16px #00000080}.leave-room-confirm-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.lobby-leave-row{flex:1;display:flex;justify-content:stretch}.lobby-leave-row>.btn{flex:1;justify-content:center}.lobby-leave-row>.lobby-leave-confirm{flex:1;justify-content:center}.lobby-leave-confirm{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.15);color:var(--text-muted);padding:6px 16px;border-radius:8px;cursor:pointer;font-size:13px;transition:background .2s,color .2s}.btn-ghost:hover{background:#ffffff12;color:var(--text-light)}.player-slot.vacant{opacity:.5;border-style:dashed}.swap-btn-vacant{background:#143c14b3!important;border-color:#64c86466!important;color:#a5d6a7!important}.swap-btn-vacant:hover{background:#1e5a1ee6!important}.host-crown{font-size:11px;margin-right:3px}.spectator-join-btn{width:20px;height:20px;border-radius:50%;border:1.5px solid rgba(100,200,120,.6);background:#143c1ed9;color:#81c784;font-size:15px;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,transform .1s;margin-right:4px}.spectator-join-btn:hover{background:#286432f2;transform:scale(1.15)}.spectator-join-vacant{border-color:#ffc832b3;background:#3c2800d9;color:#ffd54f}.spectator-join-vacant:hover{background:#644600f2}.spectator-join-pending{border-color:#96969680;background:#1e1e1eb3;color:#aaa;cursor:not-allowed}.spectator-join-pending:hover{background:#1e1e1eb3;transform:none}.bot-countdown{font-size:10px;color:#ff9800;font-weight:600;margin-left:4px;opacity:.9}.spectator-request-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:600}.spectator-request-modal{background:#0c1e0ffa;border:1px solid rgba(255,215,0,.3);border-radius:14px;padding:20px 24px;min-width:260px;box-shadow:0 8px 32px #000000b3;text-align:center}.spectator-request-modal-text{font-size:14px;color:var(--text-light);margin-bottom:16px}.spectator-request-modal-actions{display:flex;gap:10px;justify-content:center}.rules-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.rules-modal{background:#0f2a18;border:1px solid rgba(255,215,0,.25);border-radius:14px;max-width:560px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 16px 48px #000000b3}.rules-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.rules-title{font-size:18px;font-weight:700;color:var(--gold);margin:0}.rules-close-btn{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .2s,background .2s}.rules-close-btn:hover{color:#fff;background:#ffffff1a}.rules-body{overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px}.rules-section h3{font-size:13px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px}.rules-section p,.rules-section li{font-size:13px;color:var(--text-light);line-height:1.6;margin:0}.rules-section ul{margin:6px 0 0;padding-left:18px;display:flex;flex-direction:column;gap:4px}.add-bot-btn{background:#ffd7001a;border:1px solid rgba(255,215,0,.3);color:var(--gold);border-radius:6px;padding:2px 8px;font-size:13px;cursor:pointer;margin-left:auto;transition:background .2s,border-color .2s;flex-shrink:0}.add-bot-btn:hover{background:#ffd70033;border-color:var(--gold)}.dehla-player-table{flex:1;position:relative;display:grid;grid-template-areas:". top ." "left center right" ". bottom .";grid-template-columns:1fr 2fr 1fr;grid-template-rows:auto 1fr auto;gap:4px;padding:8px;min-height:0}.player-pos-right{grid-area:right;align-items:center;justify-content:flex-start}.player-pos-left{grid-area:left;align-items:center;justify-content:flex-end}.dehla-info-panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.dehla-info-title{font-size:13px;font-weight:700;color:var(--gold);text-align:center;margin-bottom:2px}.dehla-team-row{display:flex;flex-direction:column;gap:3px}.dehla-team-label{font-size:11px;font-weight:700;text-transform:uppercase}.dehla-tens-bar{display:flex;gap:4px;align-items:center}.dehla-ten-pip{width:18px;height:24px;border-radius:3px;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700}.dehla-ten-pip.pip-captured{background:var(--gold);color:#000;border-color:var(--gold)}.dehla-ten-pip.pip-empty{background:#ffffff0d;color:var(--text-muted)}.dehla-court-badge{font-size:10px;padding:2px 6px;border-radius:4px;background:#ffd70033;color:var(--gold);font-weight:700;text-align:center}.dehla-table-section{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}.dehla-table-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.dehla-table-cards-row{display:flex;flex-wrap:wrap;gap:2px;justify-content:center;max-width:220px;opacity:.6}.dehla-current-round{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}.spectator-banner{position:fixed;top:48px;left:50%;transform:translate(-50%);background:#ffa5002e;border:1px solid rgba(255,165,0,.4);color:#ffb347;font-size:11px;font-weight:600;padding:3px 14px;border-radius:12px;pointer-events:none;z-index:20;white-space:nowrap}.hand-fan-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;padding:2px 0}.hand-fan{position:relative;width:80px;height:58px}.hand-fan-card{position:absolute;bottom:0;left:50%;transform-origin:bottom center}.hand-fan-empty{color:var(--text-muted);font-size:13px}.hand-fan-count{font-size:11px;font-weight:700;color:#ffffffb3;background:#0006;padding:1px 8px;border-radius:8px;letter-spacing:.3px}.dehla-trump-pending{font-size:11px;color:var(--text-muted);font-style:italic;text-align:center}.mobile-topbar-dehla{height:auto!important;min-height:48px;padding:5px 10px!important;align-items:center}.mtb-trump-block{display:flex;flex-direction:column;align-items:center;line-height:1;gap:1px}.mtb-trump-label{font-size:8px;color:#ffffff80;text-transform:capitalize;letter-spacing:.2px}.mtb-dehla-stats{display:flex;flex-direction:column;gap:3px;width:100%}.mtb-dehla-stat-row{display:flex;align-items:center;gap:4px}.mtb-dehla-stat-team{font-size:10px;font-weight:800;min-width:10px;line-height:1}.mtb-dehla-court{font-size:10px;color:var(--gold);line-height:1}.mtb-dehla-deal{font-size:10px;color:var(--text-muted);line-height:1}.mtb-trump-none{font-size:14px;color:#ffffff4d}.dehla-scoreboard{display:flex;flex-direction:column;gap:4px;width:100%;padding:0 4px}.dehla-score-row{display:flex;align-items:center;gap:5px}.dehla-score-team{font-size:11px;font-weight:800;min-width:14px}.dehla-score-tens{font-size:11px;font-weight:700;min-width:22px;text-align:right}.dehla-score-courts{font-size:11px;color:var(--gold);min-width:22px;font-weight:600}.dehla-score-deals{font-size:11px;color:var(--text-muted);font-weight:500}.dehla-table-clickable{cursor:pointer;transition:filter .15s}.dehla-table-clickable:hover{filter:brightness(1.2)}.dehla-table-clickable:active{filter:brightness(.9)}.dehla-pile-tap-hint{font-size:10px;opacity:.7;margin-left:2px}.table-pile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;z-index:500;display:flex;align-items:center;justify-content:center;padding:16px}.table-pile-modal{background:linear-gradient(160deg,#0f2e1a,#071a0f);border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:16px;max-width:360px;width:100%;max-height:80vh;display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 32px #0009}.table-pile-header{display:flex;align-items:center;gap:8px}.table-pile-title{font-size:15px;font-weight:700;color:var(--text-light);flex:1}.table-pile-subtitle{font-size:11px;color:var(--gold);background:#ffd7001f;padding:2px 8px;border-radius:10px}.table-pile-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:2px 6px;border-radius:4px;transition:color .15s}.table-pile-close:hover{color:var(--text-light)}.table-pile-cards{display:flex;flex-wrap:wrap;gap:6px;overflow-y:auto;justify-content:flex-start;align-content:flex-start;padding:4px 2px}.dehla-pile-wrap{display:flex;flex-direction:column;align-items:center;gap:4px}.dehla-pile-stack{display:flex;align-items:center}.dehla-pile-card{flex-shrink:0;box-shadow:2px 2px 6px #00000080}.dehla-pile-meta{display:flex;gap:6px;align-items:center}.dehla-pile-count{font-size:11px;color:var(--text-muted);font-weight:600}.dehla-pile-tens{font-size:11px;font-weight:700;color:var(--gold);background:#ffd70026;padding:1px 6px;border-radius:4px}@media (max-width: 700px){.dehla-player-table{grid-template-columns:22% 1fr 22%;grid-template-rows:80px 1fr 170px;grid-template-areas:". top ." "left center right" "bottom bottom bottom";gap:2px;padding:4px 3px 0;overflow:hidden}.dehla-player-table .player-pos-top{align-items:flex-start}.dehla-player-table .player-pos-top .player-area{height:100%;max-height:80px!important;min-height:unset!important;overflow:hidden;flex-direction:row;align-items:center;gap:6px;padding:5px 8px}.dehla-player-table .player-pos-top .player-info-bar{flex:1;min-width:0;flex-direction:column;align-items:flex-start;gap:3px;flex-wrap:nowrap}.dehla-player-table .player-pos-top .player-name-label{font-size:10px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.dehla-player-table .player-pos-top .player-badges{display:flex;flex-direction:row;gap:2px;align-items:center;flex-wrap:nowrap}.dehla-player-table .player-pos-top .team-badge{font-size:8px;padding:0 3px}.dehla-player-table .player-pos-top .shuffler-badge,.dehla-player-table .player-pos-top .shuffle-count-badge{font-size:8px;padding:0 2px}.dehla-player-table .player-pos-top .connected-dot{width:6px;height:6px}.dehla-player-table .player-pos-top .turn-indicator{font-size:7px;padding:1px 3px}.dehla-player-table .player-pos-top .speaking-indicator{font-size:10px}.dehla-player-table .player-pos-top .hand-fan-wrap{flex-shrink:0;transform:scale(.82);transform-origin:center center;display:flex;flex-direction:column;align-items:center}.dehla-player-table .player-pos-right,.dehla-player-table .player-pos-left{align-items:flex-start;flex-direction:column;min-width:0;overflow:hidden;justify-content:flex-start}.dehla-player-table .player-pos-right .player-area,.dehla-player-table .player-pos-left .player-area{padding:4px 3px;border-radius:8px;background:#0000006b;border:1px solid rgba(255,255,255,.1);overflow:hidden;height:auto;width:100%;box-sizing:border-box;display:flex;flex-direction:column;gap:2px;margin-top:150%}.dehla-player-table .player-pos-right .player-area.player-turn-active,.dehla-player-table .player-pos-left .player-area.player-turn-active{border-color:#f59e0b!important;box-shadow:0 0 8px #f59e0b66}.dehla-player-table .player-pos-right .player-info-bar,.dehla-player-table .player-pos-left .player-info-bar{flex-wrap:nowrap;overflow:hidden;gap:2px;flex-shrink:0;height:14px}.dehla-player-table .player-pos-right .player-name-label,.dehla-player-table .player-pos-left .player-name-label{font-size:8px;max-width:44px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dehla-player-table .player-pos-right .team-badge,.dehla-player-table .player-pos-left .team-badge{font-size:7px;padding:0 2px;min-width:unset}.dehla-player-table .player-pos-right .shuffler-badge,.dehla-player-table .player-pos-left .shuffler-badge{font-size:6px;padding:1px 2px}.dehla-player-table .player-pos-right .turn-indicator,.dehla-player-table .player-pos-left .turn-indicator{font-size:7px;padding:1px 2px}.dehla-player-table .player-pos-bottom{padding:0 2px 2px}.dehla-player-table .player-pos-bottom .player-area{height:100%;min-height:unset!important;flex:unset!important;display:flex;flex-direction:column;gap:3px;padding:5px 80px 4px 8px;border-radius:10px 10px 0 0;background:linear-gradient(180deg,#0006,#000a05d9);border:1.5px solid rgba(255,255,255,.14);border-bottom:none;overflow:hidden}.dehla-player-table .player-pos-bottom .player-area.player-turn-active{border-color:#f59e0b!important;box-shadow:0 -4px 14px #f59e0b47}.dehla-player-table .player-pos-bottom .player-info-bar{flex-shrink:0;flex-wrap:nowrap;overflow:hidden}.dehla-player-table .player-pos-bottom .player-name-label{font-size:12px;color:#fbbf24}.dehla-player-table .player-pos-bottom .player-cards{flex:1;display:flex;flex-direction:column;justify-content:center}.dehla-player-table .player-pos-bottom .card-group{gap:0}.dehla-player-table .player-pos-bottom .card-row{display:flex;flex-wrap:wrap;gap:3px;justify-content:flex-start;align-content:flex-start}.dehla-player-table .player-pos-bottom .card{width:clamp(28px,12vw,44px)!important;height:clamp(38px,16vw,60px)!important;flex-shrink:0}.dehla-player-table .player-pos-bottom .card-value{font-size:clamp(7px,2vw,10px)}.dehla-player-table .player-pos-bottom .card-suit-small{font-size:clamp(5px,1.5vw,8px)}.dehla-player-table .player-pos-bottom .card-suit-large{font-size:clamp(10px,3vw,16px)}.dehla-player-table .table-center{justify-content:flex-start!important;align-items:center;padding:6px 6px 4px;gap:5px;overflow-y:auto}.dehla-player-table .table-center .trump-display-center{padding:2px 6px;font-size:11px}.dehla-player-table .table-center .trump-symbol-big{font-size:18px}.dehla-player-table .table-center .trump-label-small{font-size:9px}.dehla-player-table .table-center .dehla-table-section{width:100%}.dehla-player-table .table-center .dehla-table-label{font-size:9px}.dehla-player-table .table-center .current-trick{width:100%}.dehla-player-table .table-center .trick-cards{gap:3px;flex-wrap:wrap;justify-content:center}.dehla-player-table .table-center .trick-player-name{font-size:8px}.dehla-player-table .table-center .dehla-scoreboard{gap:3px;padding:0 2px}.dehla-player-table .table-center .dehla-score-row{gap:3px}.dehla-player-table .table-center .dehla-score-team,.dehla-player-table .table-center .dehla-score-tens,.dehla-player-table .table-center .dehla-score-courts,.dehla-player-table .table-center .dehla-score-deals{font-size:10px}.dehla-player-table .table-center .tricks-pip{height:6px}.dehla-player-table .player-pos-right .hand-fan-wrap,.dehla-player-table .player-pos-left .hand-fan-wrap{transform:scale(.78);transform-origin:top center;gap:3px}.dehla-player-table .player-pos-right .team-a-player,.dehla-player-table .player-pos-left .team-a-player{background:#1565c038!important}.dehla-player-table .player-pos-right .team-b-player,.dehla-player-table .player-pos-left .team-b-player{background:#b71c1c38!important}}.callbreak-table{flex:1;display:grid;grid-template-areas:".      top    ." "left   center right" ".      bottom .";grid-template-columns:minmax(100px,160px) 1fr minmax(100px,160px);grid-template-rows:auto 1fr auto;gap:8px;width:100%;min-height:0;padding:8px;box-sizing:border-box}.callbreak-slot-top{grid-area:top;display:flex;justify-content:center}.callbreak-slot-left{grid-area:left;display:flex;align-items:center}.callbreak-slot-right{grid-area:right;display:flex;align-items:center}.callbreak-slot-center{grid-area:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.callbreak-slot-bottom{grid-area:bottom;display:flex;justify-content:center}.callbreak-player-area{background:#00000059;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:6px 8px;min-width:80px;max-width:200px;transition:border-color .2s,box-shadow .2s}.callbreak-player-area.active-turn{border-color:gold;box-shadow:0 0 10px #ffd70066}.callbreak-player-area.disconnected{opacity:.65;border-color:#f4433680}.callbreak-player-area.empty{opacity:.4}.callbreak-player-name{font-size:12px;font-weight:600;color:var(--text-light);display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-bottom:3px}.callbreak-player-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:10px;color:var(--text-muted);min-height:16px}.callbreak-opp-hand{display:flex;margin-top:4px;align-items:flex-end;flex-wrap:nowrap;overflow:hidden}.callbreak-opp-count{font-size:10px;color:var(--text-muted);margin-left:4px;white-space:nowrap}.card-back-mini{width:18px;height:26px;background:linear-gradient(135deg,#1565c0,#0d47a1);border:1px solid rgba(255,255,255,.2);border-radius:3px}.callbreak-bottom{max-width:100%;width:100%;box-sizing:border-box}.callbreak-hand{display:flex;padding:4px 0 2px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-top:6px;flex-wrap:nowrap;align-items:flex-end}.callbreak-hand::-webkit-scrollbar{display:none}.callbreak-card-wrapper{flex-shrink:0;margin-right:-16px;transition:margin .15s,transform .15s;position:relative}.callbreak-card-wrapper:last-child{margin-right:0}.callbreak-card-wrapper.playable{margin-right:-4px;transform:translateY(-10px);z-index:5;cursor:pointer}.callbreak-card-wrapper.playable:hover{transform:translateY(-14px)}.callbreak-trump-badge{background:#0000008c;border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:3px 12px;font-size:12px;font-weight:700;color:#fff;letter-spacing:.5px}.callbreak-trick{display:grid;grid-template-areas:". top ." "left . right" ". bottom .";grid-template-columns:1fr auto 1fr;grid-template-rows:auto auto auto;gap:4px;width:160px;min-height:80px}.callbreak-trick-slot{display:flex;flex-direction:column;align-items:center;gap:2px}.trick-top{grid-area:top;justify-self:center}.trick-left{grid-area:left;justify-self:end}.trick-right{grid-area:right;justify-self:start}.trick-bottom{grid-area:bottom;justify-self:center}.trick-player-name{font-size:9px;color:var(--text-muted)}.trick-winner-flash{text-align:center;animation:fadeInUp .3s ease;display:flex;flex-direction:column;align-items:center;gap:6px}.callbreak-center-scores{background:#0006;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:4px 8px;font-size:11px}.callbreak-center-score-row{display:flex;justify-content:space-between;gap:16px;padding:1px 0;color:var(--text-muted)}.callbreak-center-score-row.me{color:var(--text-light);font-weight:600}.callbreak-bid-grid{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;max-width:280px;padding:4px}.callbreak-bid-btn{width:38px;height:38px;border-radius:50%;border:2px solid #4caf50;background:transparent;color:#4caf50;cursor:pointer;font-weight:700;font-size:13px;transition:background .15s,color .15s}.callbreak-bid-btn:hover{background:#4caf50;color:#fff}.callbreak-score-table{width:100%;border-collapse:collapse;font-size:12px;color:var(--text-light)}.callbreak-score-table th{font-size:10px;color:var(--text-muted);font-weight:600;padding:2px 4px;text-align:left;border-bottom:1px solid rgba(255,255,255,.1)}.callbreak-score-table td{padding:2px 4px}.callbreak-score-table tr.me{background:#ffffff12}.callbreak-winner-row{color:gold;font-weight:700}@media (max-width: 700px){.callbreak-table{grid-template-areas:".      top    ." "left   center right" "bottom bottom bottom";grid-template-columns:minmax(70px,100px) 1fr minmax(70px,100px);padding:4px;gap:4px}.callbreak-slot-bottom{grid-column:1 / -1}.callbreak-bottom{max-width:100%;width:100%}.callbreak-bid-btn{width:32px;height:32px;font-size:11px}.callbreak-card-wrapper{margin-right:-18px}.callbreak-card-wrapper.playable{margin-right:-4px;transform:translateY(-10px)}.callbreak-player-area{padding:4px 6px}.callbreak-trick{width:120px}}
