*,*: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}.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}.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;justify-content:center}.waiting-host{text-align:center;color:var(--text-muted);font-style:italic;font-size:14px}.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-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{border-left:3px solid var(--team-a)}.team-b-player{border-left:3px solid var(--team-b)}.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}.gulam-badge{font-size:9px;padding:1px 5px;border-radius:3px;background:var(--btn-danger);color:#fff;font-weight:700}.raja-badge{font-size:9px;padding:1px 5px;border-radius:3px;background:var(--gold-dark);color:#000;font-weight:700}.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-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}.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}.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}.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:15px;width:100%;pointer-events:auto;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}.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-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-left  center   top-right" "btm-left  center   btm-right" ".         bottom   .";grid-template-rows:minmax(70px,auto) 1fr 1fr minmax(175px,38%);grid-template-columns:22% 56% 22%;gap:3px;padding:4px 3px 0;overflow:hidden}.player-pos-top{align-items:stretch}.player-pos-top-left,.player-pos-top-right,.player-pos-bottom-left,.player-pos-bottom-right,.player-pos-bottom{align-items:stretch;flex-direction:column}.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:22px!important;height:30px!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:row;align-items:center;padding:5px 8px;gap:6px;background:#0000006b;border:1px solid rgba(255,255,255,.1);border-top:none;border-radius:0 0 10px 10px;width:100%;height:100%;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:column;align-items:flex-start;min-width:36px;max-width:46px;flex-shrink:0;gap:2px}.player-pos-top .player-name-label{font-size:9px;max-width:44px;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{flex:1;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-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:20px!important;height:28px!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:22px!important;height:30px!important;margin-right:-4px}.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:6px}.player-pos-top .card-suit-large{display:none}.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:100%;box-sizing:border-box;display:flex;flex-direction:column;gap:2px}.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}.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:7px;padding:0 3px;min-width:unset}.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:2px;overflow:hidden;justify-content:space-evenly}.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:center;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}.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:16px!important;height:22px!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,.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:21px!important;height:29px!important;margin-right:1px}.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}.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:6px}.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:6px}.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{display:none}.player-pos-top-left .card-corner,.player-pos-top-right .card-corner,.player-pos-bottom-left .card-corner,.player-pos-bottom-right .card-corner{padding:1px;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:8px 10px;background:linear-gradient(180deg,#00000080,#000a05e6);border:1.5px solid rgba(255,255,255,.16);border-bottom:none;gap:5px;flex:1;height:100%;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:5px;flex:1;overflow:hidden}.player-pos-bottom .card-group{display:flex;flex-direction:row;align-items:center;gap:6px;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:38px!important;height:52px!important}.player-pos-bottom .card-value{font-size:9px}.player-pos-bottom .card-suit-small{font-size:8px}.player-pos-bottom .card-suit-large{font-size:14px}.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}.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:100%}.trick-result-cards{gap:3px}.trick-result-bar .card{width:22px!important;height:30px!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}.lobby-container{padding:22px 16px;border-radius:18px}.teams-layout{flex-direction:column;gap:10px}.vs-divider{padding-top:0;justify-content:center}.team-header{font-size:15px}.player-slot{padding:10px 12px}.player-name{font-size:15px}.lobby-actions .btn{width:100%;justify-content:center}}.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;animation:speaking-bounce .6s ease-in-out infinite alternate}@keyframes speaking-bounce{0%{opacity:.7;transform:scale(.9)}to{opacity:1;transform:scale(1.1)}}.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-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{width:36px;height:36px;border-radius:50%;border:1px solid rgba(220,60,60,.5);background:#1e0a0ad9;color:#e57373;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .15s;box-shadow:0 2px 8px #0006}.host-end-game-btn:hover{background:#b41e1ee6;color:#fff;transform:scale(1.08)}.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{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:#141414d9;color:var(--text-muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .15s;box-shadow:0 2px 8px #0006}.leave-room-btn:hover{background:#321e0ae6;color:#ffcc80;transform:scale(1.08)}.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{margin-top:12px;display:flex;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-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}
