:root{--felt-green: #2d6b3f;--felt-dark: #0f3018;--wood-brown: #5a3a1a;--wood-light: #8b6914;--card-glow-gold: #ffd700;--card-glow-green: #4caf50;--card-glow-blue: #42a5f5;--team-defender: #3b6ea5;--team-attacker: #c0392b;--panel-bg: rgba(10, 30, 15, .65);--panel-border: rgba(180, 160, 120, .3);--text-light: #e8e0d0;--text-muted: #a09880;--card-w: clamp(72px, 7vw, 110px);--card-h: clamp(100px, 9.8vw, 154px);--card-scale-hand: 1;--card-scale-trick-base: .65;--card-scale-trick: var(--card-scale-trick-base);--card-scale-mini: .5;--card-scale-result: .6;--z-table-content: 1;--z-seat: 10;--z-card-hover: 20;--z-overlay-subtle: 50;--z-overlay-ui: 100;--z-dropdown: 200;--z-toast: 300;--z-floating: 400;--z-banner: 500;--z-modal: 600;--z-demo: 700;font-size:clamp(16px,.85rem + .4vw,22px);font-family:Space Grotesk,system-ui,sans-serif;color:var(--text-light)}*{box-sizing:border-box}body{margin:0;background:radial-gradient(ellipse at center,var(--felt-green) 0%,var(--felt-dark) 100%);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;padding:8px;gap:8px}.lobby-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;position:relative;overflow:hidden}.lobby-particles{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.lobby-particles:before,.lobby-particles:after{content:"♠♥♦♣";position:absolute;top:-20%;right:-10%;bottom:-20%;left:-10%;font-size:80px;letter-spacing:120px;line-height:160px;color:#ffd7000a;white-space:pre-wrap;word-wrap:break-word;animation:particle-drift 25s linear infinite;pointer-events:none}.lobby-particles:after{font-size:60px;letter-spacing:100px;line-height:140px;color:#ffffff05;animation-duration:35s;animation-direction:reverse}@keyframes particle-drift{0%{transform:translateY(0)}to{transform:translateY(-160px)}}.lobby-container{position:relative;z-index:1;max-width:720px;width:100%;padding:24px 16px;display:flex;flex-direction:column;gap:16px}.lobby-hero{text-align:center}.lobby-title{font-size:2.5rem;font-weight:800;margin:0;background:linear-gradient(135deg,gold,#ff9800);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;filter:drop-shadow(0 2px 8px rgba(255,215,0,.3))}.lobby-subtitle{margin:8px 0 0;font-size:14px;color:var(--text-muted);font-weight:600}.lobby-join-panel,.lobby-profile-panel{display:flex;flex-direction:column;gap:8px}.lobby-panel-heading{margin:0 0 4px;font-size:16px;font-weight:700;color:var(--card-glow-gold)}.form-group{display:flex;flex-direction:column;gap:4px}.form-group input,.form-group select{width:100%}.form-row{display:flex;gap:8px;align-items:center}.form-row select{flex:0 0 auto}.form-row input{flex:1;min-width:0}.btn-primary{flex:1;background:linear-gradient(135deg,#b8860b,#daa520);border:1px solid #b8860b;color:#fff;font-weight:800;font-size:14px;padding:10px 16px;border-radius:8px;box-shadow:0 2px 8px #daa5204d;transition:background .2s,box-shadow .2s,transform .1s}.btn-primary:hover{background:linear-gradient(135deg,#daa520,gold);box-shadow:0 4px 16px #ffd70066}.btn-primary:active{transform:translateY(1px)}.profile-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:24px;color:#fff;background:var(--team-defender);margin:0 auto 4px;position:relative;border:3px solid transparent;background-clip:padding-box;box-shadow:0 0 0 3px var(--card-glow-gold);animation:avatar-border-rotate 4s linear infinite}@keyframes avatar-border-rotate{0%{box-shadow:0 0 0 3px #ffd70099}50%{box-shadow:0 0 0 3px #ff980099}to{box-shadow:0 0 0 3px #ffd70099}}.profile-name{text-align:center;font-weight:700;font-size:15px;color:var(--text-light);margin-bottom:4px}.profile-email-section{display:flex;align-items:center;gap:8px;justify-content:center}.profile-email-badge{font-size:12px;font-weight:600;color:var(--text-muted);padding:2px 8px;border-radius:999px;background:#ffffff14;border:1px solid var(--panel-border)}.profile-logout-btn{font-size:11px;padding:3px 10px;background:#ffffff14;border:1px solid var(--panel-border)}.profile-email-form{margin-top:4px}.profile-stats-row{display:flex;gap:8px;margin-top:8px}.stat-box{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px;border-radius:8px;background:#0003;border:1px solid var(--panel-border)}.stat-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:18px;font-weight:800;color:var(--text-light);margin-top:2px}.room-list-empty{color:var(--text-muted);font-size:13px;text-align:center;padding:12px}.room-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--card-glow-gold) transparent}.room-list-row{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;background:#00000026;border:1px solid rgba(255,255,255,.06);font-size:12px;transition:background .15s}.room-list-row:hover{background:#00000040}.room-list-id{font-weight:700;color:var(--text-light);min-width:60px}.room-list-players{font-weight:700;color:var(--card-glow-gold);min-width:32px;text-align:center}.room-list-phase{font-size:11px;font-weight:600;color:var(--text-muted);padding:1px 6px;border-radius:999px;background:#ffffff0f;min-width:50px;text-align:center}.room-list-seats{display:flex;gap:3px;align-items:center;flex:1}.room-list-dot{width:6px;height:6px;border-radius:50%}.room-list-dot.online{background:#4caf50}.room-list-dot.offline{background:#f44336}.room-list-join-btn{padding:4px 10px;font-size:11px;font-weight:700;background:linear-gradient(135deg,#b8860b,#daa520);border:1px solid #b8860b;color:#fff;border-radius:6px;min-height:auto}.room-list-join-btn:hover{background:linear-gradient(135deg,#daa520,gold)}.history-stats-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.history-stats-row .stat-box{flex:1 1 80px;min-width:80px}.elo-value{color:var(--card-glow-gold)!important;font-size:22px!important}.history-match-list{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--card-glow-gold) transparent}.history-match-list::-webkit-scrollbar{width:6px}.history-match-list::-webkit-scrollbar-thumb{background:var(--card-glow-gold);border-radius:3px}.history-match-list::-webkit-scrollbar-track{background:transparent}.history-empty{color:var(--text-muted);font-size:13px;text-align:center;padding:12px}.history-match-row{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;background:#00000026;border:1px solid rgba(255,255,255,.06);font-size:12px}.history-match-row.win{border-left:3px solid #4caf50}.history-match-row.loss{border-left:3px solid #ef5350}.history-match-row.pending{border-left:3px solid var(--text-muted)}.history-result-badge{font-size:11px;font-weight:800;padding:2px 8px;border-radius:999px;min-width:40px;text-align:center}.history-result-badge.win{background:#4caf5033;color:#66bb6a}.history-result-badge.loss{background:#f4433633;color:#ef5350}.history-result-badge.pending{background:#ffffff14;color:var(--text-muted)}.history-match-room{font-weight:700;color:var(--text-light);min-width:60px}.history-match-players{color:var(--text-muted);font-weight:600}.history-match-levels{color:var(--text-muted);font-weight:600;flex:1}.history-match-date{color:var(--text-muted);font-size:11px;margin-left:auto}.history-load-more{margin-top:8px;width:100%;padding:6px;font-size:12px}.lobby-footer{display:flex;align-items:center;justify-content:center;gap:12px}.lobby-version{font-size:11px;color:var(--text-muted)}.panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:10px;padding:10px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.row{display:flex;gap:8px;flex-wrap:wrap}button{cursor:pointer;border:1px solid var(--wood-brown);background:var(--wood-brown);color:#fef9f0;padding:8px 12px;border-radius:8px;font-weight:600;box-shadow:inset 0 1px #ffffff26,0 2px 4px #0000004d;transition:background .15s ease,transform .1s ease}button:hover{background:#6d4a24}button:active{transform:translateY(1px);box-shadow:inset 0 1px #ffffff1a}button:disabled{opacity:.4;cursor:not-allowed}input,select{padding:8px 10px;border-radius:8px;border:1px solid var(--panel-border);background:#0000004d;color:var(--text-light)}input::placeholder{color:var(--text-muted)}.identity-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:8px}.identity-chip{display:inline-block;padding:4px 10px;border-radius:999px;border:1px solid var(--panel-border);background:#00000040;font-size:13px;font-weight:600;color:var(--text-light)}.game-layout{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;padding:0;position:relative}.game-body{flex:1 1 auto;display:flex;align-items:center;justify-content:center;min-height:0;padding:4px;position:relative;overflow:visible;gap:8px}.game-main{flex:1 1 auto;display:flex;min-height:0;overflow:hidden}.game-content{flex:1 1 auto;display:flex;flex-direction:column;min-width:0;min-height:0}.chat-sidebar{flex:0 0 280px;display:flex;flex-direction:column;background:var(--panel-bg);border-left:1px solid var(--panel-border);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);overflow:hidden}.game-footer{flex:0 0 auto;display:flex;flex-direction:column;gap:2px;padding:0 4px 4px;overflow:visible;position:relative}.scoreboard-header{display:flex;align-items:center;gap:8px;padding:4px 8px;font-size:13px;flex-wrap:wrap;flex:0 0 auto}.score-controls-left{flex:0 0 auto}.score-controls-left .leave-btn{padding:4px 10px;font-size:12px}.score-center{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;gap:4px}.score-teams{display:flex;align-items:center;gap:20px}.score-team{display:flex;flex-direction:column;align-items:center;gap:1px}.team-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.team-score{font-size:28px;font-weight:800;font-variant-numeric:tabular-nums;line-height:1}.defender-score{color:var(--team-defender)}.attacker-score{color:var(--team-attacker)}.team-level{font-size:11px;font-weight:700;color:var(--text-muted)}.score-vs{font-size:14px;font-weight:700;color:var(--card-glow-gold);text-shadow:0 0 8px rgba(255,215,0,.3)}.score-progress-bar{width:100%;max-width:200px;height:4px;border-radius:2px;background:#ffffff1a;overflow:hidden}.score-progress-fill{height:100%;border-radius:2px;transition:width .5s ease,background .5s ease}.score-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;font-size:12px}.room-badge,.kitty-badge{font-size:11px;font-weight:600;color:var(--text-muted);padding:1px 6px;border-radius:999px;background:#0003;border:1px solid var(--panel-border)}.score-controls-right{flex:0 0 auto;display:flex;gap:4px;align-items:center}.streak-badge{font-size:12px;font-weight:700;color:#ff6b35;padding:1px 8px;border-radius:999px;background:#ff6b3526;border:1px solid rgba(255,107,53,.3);animation:streak-flicker 1s ease-in-out infinite}@keyframes streak-flicker{0%,to{opacity:1}50%{opacity:.7}}.captured-cards-expanded{width:100%;display:flex;gap:3px;flex-wrap:wrap;padding-top:4px;border-top:1px solid var(--panel-border);margin-top:4px}.trump-wrap{display:inline-flex;align-items:center;gap:4px}.trump-mini-card{display:inline-flex;align-items:center;gap:2px;padding:2px 6px;border:1px solid var(--panel-border);border-radius:6px;background:#ffffff1f;font-weight:700;min-width:34px;justify-content:center}.trump-mini-card.red{color:#ff6b6b}.trump-mini-card.black{color:#e8e0d0}.trump-mini-card.nt{color:#90caf9}.trump-mini-suit{font-size:12px}.score-captured-row{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.captured-cards{display:inline-flex;gap:3px;flex-wrap:wrap}.captured-mini-card{display:inline-flex;align-items:center;gap:1px;padding:1px 4px;border:1px solid var(--panel-border);border-radius:4px;background:#ffffff1a;font-weight:700;font-size:11px;line-height:1.2}.captured-mini-card.red{color:#ff6b6b}.captured-mini-card.black{color:#e8e0d0}.captured-empty{color:var(--text-muted);font-size:12px}.event-log-sidebar{display:flex;flex-direction:column;gap:2px;max-height:60px;overflow-y:auto;scrollbar-width:none;flex:0 0 auto;padding:2px 6px}.event-log-sidebar::-webkit-scrollbar{display:none}.event-log-title,.event-log-empty{display:none}.event-log-item-v{font-size:11px;font-weight:600;color:var(--text-muted);padding:3px 6px;background:#00000059;border-radius:6px;word-break:break-word;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:.7}.event-log-item-v:last-child{color:var(--card-glow-gold);background:#00000080;opacity:1}.game-table{position:relative;width:100%;max-width:min(96vw,1200px);aspect-ratio:16 / 9;max-height:100%;border:6px solid var(--wood-brown);border-radius:50%/40%;background:radial-gradient(ellipse at center,#35845a,#256b42 60%,#1a5434);box-shadow:inset 0 0 60px #0000004d,0 4px 20px #0006,inset 0 0 2px 1px #ffffff0d;margin:0 auto;overflow:visible}.game-table:before{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:2px solid rgba(255,255,255,.06);border-radius:50%/40%;pointer-events:none;z-index:1}.game-layout:before{content:"♠♥♦♣";position:fixed;top:-10%;right:-5%;bottom:-10%;left:-5%;font-size:40px;letter-spacing:80px;line-height:120px;color:#ffd70005;white-space:pre-wrap;word-wrap:break-word;animation:particle-drift 30s linear infinite;pointer-events:none;z-index:0;opacity:.3}.seat-sidebar{display:flex;flex-direction:column;gap:4px;flex:0 0 180px;width:180px;min-width:180px;max-width:180px;padding:4px;box-sizing:border-box;overflow:hidden;overflow-y:auto;max-height:100%;scrollbar-width:thin;scrollbar-color:var(--card-glow-gold) transparent}.seat-slot{display:flex;flex-direction:column;align-items:center}.seat-card{position:relative;display:flex;flex-direction:row;align-items:center;gap:8px;padding:5px 10px;border-radius:16px;border:2px solid transparent;background:var(--panel-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:100%;box-sizing:border-box;overflow:visible;transition:border-color .3s ease,box-shadow .3s ease}.seat-card.is-turn{border-color:var(--card-glow-gold);box-shadow:0 0 12px #ffd70080;animation:turn-pulse 1.5s ease-in-out infinite}.seat-card.is-turn:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:12px;background:conic-gradient(from 0deg,rgba(255,215,0,.4),transparent 30%,rgba(255,215,0,.4) 50%,transparent 80%);animation:rotate-border 3s linear infinite;z-index:-1}@keyframes rotate-border{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes turn-pulse{0%,to{box-shadow:0 0 8px #ffd70066}50%{box-shadow:0 0 18px #ffd700b3}}.seat-card.empty{border:2px dashed var(--panel-border);opacity:.5}.seat-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:#fff;flex-shrink:0}.seat-avatar.defender{background:var(--team-defender)}.seat-avatar.attacker{background:var(--team-attacker)}.seat-name{font-size:11px;font-weight:700;color:var(--text-light);flex:1 1 0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-badge{font-size:10px;font-weight:700;padding:1px 6px;border-radius:999px;background:#ffd70040;color:var(--card-glow-gold);border:1px solid rgba(255,215,0,.4)}.seat-cards-pill{font-size:10px;font-weight:600;color:var(--text-muted)}.seat-turns-away{font-size:11px;font-weight:800;color:var(--card-glow-gold);padding:2px 8px;border-radius:999px;background:#ffd70026;border:1px solid rgba(255,215,0,.35);min-width:22px;text-align:center}.seat-connection{width:6px;height:6px;border-radius:50%;position:absolute;top:4px;right:4px}.seat-connection.online{background:#4caf50}.seat-connection.offline{background:#f44336}.declare-marker{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border:1px solid rgba(255,215,0,.5);border-radius:999px;background:#ffd70026;color:var(--card-glow-gold);font-size:10px;font-weight:700}.seat-ready-btn{width:100%;margin-top:2px;padding:4px 6px;font-size:11px}.seat-ready-btn.is-ready{background:#2e7d32;border-color:#1b5e20}.seat-ready-btn.remove-bot-btn{background:#c62828;border-color:#b71c1c}.seat-ready-btn.stand-up-btn{background:#e65100;border-color:#bf360c}.seat-avatar.is-bot{font-size:18px;line-height:1}.seat-badge.bot-difficulty{font-size:9px;background:#ffffff1f;border-radius:3px;padding:1px 4px}.empty-seat{opacity:1}.seat-card.empty-seat-cta{border:2px dashed var(--card-glow-gold);animation:empty-seat-pulse 2s ease-in-out infinite}@keyframes empty-seat-pulse{0%,to{border-color:#ffd70066;box-shadow:0 0 6px #ffd7001a}50%{border-color:#ffd700e6;box-shadow:0 0 12px #ffd7004d}}.empty-seat .seat-avatar.empty{background:#ffffff1a;color:#fff6}.empty-seat-actions{display:flex;flex-direction:column;gap:2px;width:100%}.bot-difficulty-picker{display:flex;flex-wrap:wrap;gap:2px}.bot-diff-btn{flex:1;min-width:0;font-size:10px!important;padding:2px 4px!important}.lobby-ready-bar{display:flex;gap:6px;align-items:center}.lobby-ready-btn.is-ready{background:#2e7d32;border-color:#1b5e20}.ready-state{font-size:10px;font-weight:700}.ready-state.ready{color:#66bb6a}.ready-state.not-ready{color:#ef5350}.table-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:var(--z-table-content)}.table-center-inner{position:relative;width:80%;height:80%}.trick-play{position:absolute;display:flex;gap:clamp(4px,.5vw,10px);align-items:center;pointer-events:none;filter:drop-shadow(0 8px 14px rgba(0,0,0,.35))}.trick-play-anchor{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.trick-play .card-face{pointer-events:none;--cs: var(--card-scale-trick) !important}.trick-play .card-face+.card-face{margin-left:clamp(6px,1vw,12px)}.trick-player-label{font-size:10px;font-weight:700;color:#ffffffb3;text-align:center;margin-bottom:2px;white-space:nowrap;text-shadow:0 0 6px rgba(0,0,0,.6)}.trick-player-label.winning{color:var(--card-glow-gold);text-shadow:0 0 6px rgba(255,215,0,.5)}.trick-play.trick-winning .card-face{box-shadow:0 0 8px #ffd70066;border-color:#ffd70080;animation:trick-win-pulse .35s ease-in-out 0s 3}@keyframes trick-win-pulse{0%{box-shadow:0 0 8px #ffd70066;transform:scale(1)}50%{box-shadow:0 0 18px #ffd700cc;transform:scale(1.06)}to{box-shadow:0 0 8px #ffd70066;transform:scale(1)}}.trick-win-banner{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:4;padding:10px 18px;border-radius:14px;border:1px solid rgba(255,215,0,.8);background:radial-gradient(circle at 50% 30%,#fff5b4e6,#ffcd508c 35%,#371905e0);box-shadow:0 0 0 2px #ffd70040,0 0 24px #ffd7008c,0 10px 24px #00000080;animation:trick-win-banner-pulse .38s ease-in-out 0s 3}.trick-win-title{font-size:12px;font-weight:900;letter-spacing:1.2px;text-align:center;color:#fff3cc;text-shadow:0 0 10px rgba(255,215,0,.65)}.trick-win-name{margin-top:2px;font-size:11px;font-weight:800;text-align:center;color:#fff}@keyframes trick-win-banner-pulse{0%{transform:translate(-50%,-50%) scale(1);filter:saturate(100%)}50%{transform:translate(-50%,-50%) scale(1.05);filter:saturate(140%)}to{transform:translate(-50%,-50%) scale(1);filter:saturate(100%)}}.no-trick-msg{color:#ffffff4d;font-size:13px;font-style:italic;text-align:center}.card-face{--cs: var(--card-scale, 1);position:relative;display:inline-flex;align-items:center;justify-content:center;width:calc(var(--card-w) * var(--cs));height:calc(var(--card-h) * var(--cs));margin:0;border:2px solid transparent;border-radius:8px;background:#fff;padding:0;box-shadow:0 2px 8px #00000040;cursor:default;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;overflow:hidden;touch-action:manipulation;vertical-align:bottom;flex-shrink:0}.card-face img{display:block;height:100%;width:100%;object-fit:contain;pointer-events:none}.card-face.mini{--cs: var(--card-scale-mini);border-radius:5px;border-width:1px}.card-face.clickable{cursor:pointer}.card-face.clickable:hover{transform:translateY(-8px);z-index:var(--z-card-hover);box-shadow:0 6px 16px #00000059}.card-face.selected{border-color:var(--card-glow-gold);box-shadow:0 0 12px var(--card-glow-gold),0 4px 12px #0000004d;transform:translateY(-12px);z-index:var(--z-card-hover)}.card-face.hinted:not(.selected){border-color:var(--card-glow-green);box-shadow:0 0 8px var(--card-glow-green)}.card-face.pair-hinted:not(.selected){border-color:var(--card-glow-blue);box-shadow:0 0 8px var(--card-glow-blue)}.card-face.dimmed:not(.selected){opacity:.4;filter:grayscale(60%)}.card-face.is-trump:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 30%,rgba(255,215,0,.12) 45%,rgba(255,215,0,.2) 50%,rgba(255,215,0,.12) 55%,transparent 70%);animation:card-shimmer 3s ease-in-out infinite;pointer-events:none;border-radius:6px}@keyframes card-shimmer{0%,to{transform:translate(-100%)}50%{transform:translate(100%)}}.card-face.joker-small,.card-face.joker-big{background:linear-gradient(180deg,#fff,#f0f0f0)}.joker-inner{display:flex;flex-direction:column;align-items:center;gap:1px}.joker-type{font-size:16px;font-weight:900;line-height:1}.joker-star{font-size:28px;line-height:1}.joker-label{font-size:9px;font-weight:800;letter-spacing:1px}.joker-corner{display:block;position:absolute;top:3px;left:4px;font-size:10px;font-weight:900;line-height:1;letter-spacing:.4px;text-shadow:0 1px 0 rgba(255,255,255,.8);pointer-events:none}.card-face.joker-small{color:#1565c0}.card-face.joker-big{color:#c62828}.card-face.mini .joker-type{font-size:10px}.card-face.mini .joker-star{font-size:14px}.card-face.mini .joker-label{font-size:6px}.card-face.mini .joker-corner{font-size:8px;top:2px;left:3px}.card-face.peeked img{object-position:top center}.card-face.peeked.joker-small .joker-inner,.card-face.peeked.joker-big .joker-inner{opacity:0}.card-face.peeked.joker-small .joker-corner,.card-face.peeked.joker-big .joker-corner{display:block}.card-face.peeked.clickable:hover,.card-face.peeked.selected{transform:none}.hand-section{padding:2px 4px 0}.hand-label{font-size:11px;font-weight:700;color:var(--text-muted);margin-bottom:1px;text-align:center}.hand-layout-controls{display:flex;align-items:center;justify-content:center;gap:4px;flex-wrap:wrap;margin-bottom:2px}.hand-layout-btn{min-height:auto;border:1px solid var(--panel-border);background:#00000059;color:var(--text-muted);border-radius:999px;font-size:10px;font-weight:700;padding:2px 8px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.hand-layout-btn.active{color:#fff;border-color:#ffd70099;background:#b8860b73}.hand-scroll-wrapper{display:flex;align-items:center;gap:0;position:relative;flex:1 1 auto;min-width:0}.hand-scroll-btn{flex:0 0 auto;width:32px;height:48px;border-radius:6px;background:#0006;border:1px solid var(--panel-border);color:var(--card-glow-gold);font-size:18px;font-weight:900;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:var(--z-overlay-subtle);opacity:.7;transition:opacity .15s,background .15s;min-height:auto}.hand-scroll-btn:hover{opacity:1;background:#0009}.hand-container{display:flex;justify-content:center;align-items:flex-end;padding:18px 0 8px;min-height:15vh;position:relative;perspective:800px;flex:1 1 auto;min-width:0;max-width:100%;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.hand-container.compact{scroll-snap-type:x proximity}.hand-container.layered{display:block;overflow-x:hidden;overflow-y:auto;padding:2px 0 6px}.hand-card-wrap{display:inline-block;transform-origin:bottom center}.hand-card-wrap-peek{height:calc(var(--card-h) * var(--card-scale-hand) * .24);overflow:hidden}.hand-layers{display:flex;flex-direction:column;gap:6px}.hand-layer{display:grid;grid-template-columns:52px minmax(0,1fr);align-items:end;gap:6px}.hand-layer-label{font-size:9px;font-weight:800;letter-spacing:.4px;color:var(--text-muted);text-align:right;padding-bottom:4px}.hand-layer-trump{color:gold}.hand-layer-s{color:#d6d6d6}.hand-layer-h{color:#ff7e7e}.hand-layer-d{color:#ffb25b}.hand-layer-c{color:#88c77d}.hand-layer-cards{display:flex;align-items:flex-end;min-width:0;overflow-x:auto;overflow-y:hidden;padding-bottom:2px;-webkit-overflow-scrolling:touch}.hand-container .card-face{--cs: var(--card-scale-hand)}.action-panel{position:absolute;bottom:4px;right:8px;display:flex;flex-direction:column;gap:4px;align-items:flex-end;padding:6px 12px;background:#0a1e0fbf;border:1px solid var(--panel-border);border-radius:12px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:var(--z-overlay-ui);pointer-events:auto;white-space:nowrap}.action-panel:not(:has(button,.action-status,.surrender-vote-bar,.declare-timer-bar,.bury-confirm-bar)){display:none}.lobby-ready-btn{align-self:center;min-width:160px}.lang-toggle{padding:3px 8px;font-size:11px;font-weight:700;min-width:auto;background:#ffffff1a;border:1px solid var(--panel-border)}.lobby-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.lobby-header h2{margin:0}.bury-confirm-bar{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#ffd7001a;border:1px solid rgba(255,215,0,.3);border-radius:8px}.bury-confirm-text{font-size:13px;font-weight:700;color:var(--card-glow-gold)}.bury-yes{background:#2e7d32!important;border-color:#1b5e20!important}.bury-no{background:#ffffff1a!important;border-color:var(--panel-border)!important;min-width:auto!important;width:auto!important;padding:6px 10px!important}.action-buttons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.action-btn{width:120px}.action-declare-countdown{align-self:center;font-size:13px;font-weight:700;color:var(--card-glow-gold);background:#ffd7001a;border:1px solid rgba(255,215,0,.3);border-radius:999px;padding:4px 10px}.action-declare-countdown-wrap{display:flex;gap:8px;justify-content:center;align-items:center;flex-wrap:wrap}.no-snatch-btn{min-width:110px}.surrender-btn{background:#8b2020!important;border-color:#6b1515!important}.surrender-btn:hover{background:brown!important}.surrender-vote-bar{display:flex;flex-direction:column;gap:6px;padding:8px 12px;background:#c0392b1f;border:1px solid rgba(192,57,43,.4);border-radius:8px;width:100%;max-width:400px}.surrender-vote-header{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:700;color:var(--team-attacker)}.surrender-countdown{font-size:14px;font-weight:800;color:var(--team-attacker);font-variant-numeric:tabular-nums}.surrender-vote-chips{display:flex;gap:6px;flex-wrap:wrap}.surrender-vote-chip{padding:2px 10px;border-radius:999px;font-size:12px;font-weight:700}.surrender-vote-chip.yes{background:#4caf5040;color:#66bb6a;border:1px solid rgba(76,175,80,.4)}.surrender-vote-chip.no{background:#f4433640;color:#ef5350;border:1px solid rgba(244,67,54,.4)}.surrender-vote-chip.pending{background:#ffffff14;color:var(--text-muted);border:1px solid var(--panel-border)}.surrender-vote-actions{display:flex;gap:8px;justify-content:center}.action-status{font-size:13px;font-weight:700;color:var(--card-glow-gold);text-align:center;padding:6px 12px;background:#ffd70014;border:1px solid rgba(255,215,0,.2);border-radius:8px;animation:status-pulse 2s ease-in-out infinite}@keyframes status-pulse{0%,to{opacity:.7}50%{opacity:1}}.chat-sidebar.chat-sidebar-mobile{position:fixed;top:0;right:0;bottom:0;width:100%;z-index:var(--z-overlay-ui);flex:none}.chat-drawer-header{display:flex;align-items:center;gap:6px;padding:8px 10px;border-bottom:1px solid var(--panel-border);flex:0 0 auto}.chat-drawer-title{flex:1;font-size:13px;font-weight:700;color:var(--text-muted)}.chat-drawer-btn{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;font-size:14px;background:#ffffff14;border:1px solid var(--panel-border);border-radius:6px;color:var(--text-muted);min-height:auto}.chat-drawer-btn:hover{background:#ffffff26;color:var(--text-light)}.chat-drawer-body{flex:1;display:flex;flex-direction:column;padding:6px 8px;min-height:0}.chat-title{font-size:13px;font-weight:700;margin-bottom:4px;color:var(--text-muted)}.chat-log{background:#00000040;border:1px solid var(--panel-border);border-radius:6px;min-height:32px;flex:1;overflow-y:auto;padding:4px 6px;margin-bottom:4px}.chat-empty{color:var(--text-muted);font-size:11px}.chat-row{display:flex;gap:4px;font-size:11px;line-height:1.3}.chat-name{font-weight:700;color:var(--card-glow-gold);flex:0 0 auto}.chat-name.self{color:#66bb6a}.chat-text{word-break:break-word;color:var(--text-light)}.chat-reactions{display:flex;gap:2px;flex-wrap:wrap;padding:2px 0}.chat-reaction-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:4px 6px;font-size:18px;cursor:pointer;transition:background .15s,transform .1s;line-height:1}.chat-reaction-btn:hover{background:#ffffff2e;transform:scale(1.15)}.chat-reaction-btn:active{transform:scale(.95)}.chat-input-row{display:flex;gap:4px;align-items:center;flex-wrap:nowrap}.chat-inline-label{font-size:12px;font-weight:700;color:var(--text-muted);flex:0 0 auto}.chat-input-row input{flex:1 1 120px;min-width:0;padding:5px 8px;font-size:12px}.chat-input-row button{flex:0 0 auto;padding:5px 10px;font-size:12px}.chat-fab{position:fixed;width:44px;height:44px;border-radius:50%;z-index:var(--z-overlay-ui);background:var(--panel-bg);border:1px solid var(--panel-border);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;padding:0;min-height:auto;box-shadow:0 2px 10px #0000004d;transition:background .15s,box-shadow .15s}.chat-fab:hover{background:#0a1e0fd9;box-shadow:0 4px 16px #0006}.chat-fab{right:12px;bottom:12px}.chat-fab-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:9px;background:var(--team-attacker);color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.announcements-container{position:fixed;top:30%;left:50%;transform:translate(-50%);z-index:var(--z-modal);display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none}.announcement{background:#000c;color:var(--card-glow-gold);padding:10px 24px;border-radius:12px;font-size:20px;font-weight:800;text-shadow:0 1px 4px rgba(0,0,0,.5);border:1px solid rgba(255,215,0,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap}.toasts-container{position:fixed;bottom:16px;right:16px;z-index:var(--z-toast);display:flex;flex-direction:column;gap:4px;max-width:320px;pointer-events:none}.toast{background:#000000bf;color:#fff;padding:6px 10px;border-radius:8px;font-size:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.declare-timer-bar{display:flex;align-items:center;gap:12px;justify-content:center;padding:4px 0}.declare-timer-circle{width:48px;height:48px;border-radius:50%;border:3px solid var(--card-glow-gold);display:flex;align-items:center;justify-content:center;background:#ffd7001a;animation:timer-pulse 1s ease-in-out infinite;flex-shrink:0}@keyframes timer-pulse{0%,to{border-color:var(--card-glow-gold);box-shadow:0 0 8px #ffd7004d}50%{border-color:#fa0;box-shadow:0 0 16px #ffaa0080}}.declare-timer-number{font-size:22px;font-weight:900;color:var(--card-glow-gold);line-height:1}.declare-timer-info{display:flex;flex-direction:column;gap:4px;align-items:flex-start}.declare-timer-label{font-size:13px;font-weight:700;color:var(--card-glow-gold)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-card{max-width:520px;width:100%}.modal-title{font-weight:700;margin-bottom:8px;color:var(--card-glow-gold)}.modal-text{white-space:pre-wrap;margin:0 0 12px;font-family:inherit}.round-result-card{width:100vw;height:100vh;max-width:100vw;max-height:100vh;border-radius:0;border:none;background:linear-gradient(180deg,#2d6b3ff7,#0f3018fc);box-shadow:none;display:flex;flex-direction:column;justify-content:space-between;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:12px clamp(8px,2vw,24px)}.round-result-scroll{overflow-y:auto;padding-right:4px}.round-result-title{font-size:24px;line-height:1.1;font-weight:900;letter-spacing:.4px;color:var(--card-glow-gold);text-transform:uppercase;margin-bottom:10px}.round-result-text{font-size:18px;line-height:1.3;font-weight:700;color:var(--text-light);margin:0 0 10px}.round-cards-grid{display:grid;gap:6px;margin-bottom:10px}.round-cards-grid.four,.round-cards-grid.six{grid-template-columns:1fr}.round-seat-block{border:1px solid rgba(255,255,255,.15);background:#0003;border-radius:8px;padding:6px;display:flex;align-items:flex-start;gap:6px}.round-kitty-block{border:1px solid rgba(255,255,255,.15);background:#0003;border-radius:8px;padding:6px;display:flex;align-items:center;gap:12px;flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start}.round-seat-title{font-size:12px;font-weight:800;margin-top:2px;margin-bottom:0;color:var(--card-glow-gold);min-width:60px;flex:0 0 auto}.round-seat-cards{display:flex;flex-wrap:wrap;gap:2px;flex:1 1 auto}.round-result-card .card-face.mini{--cs: var(--card-scale-result);border-color:#fff3;background:#fff;box-shadow:none;margin:0}.round-result-card .round-seat-cards{gap:0}.round-result-card .trick-table-td{padding:2px 1px}.round-result-card .trick-table-td .card-face.mini{margin:0 -1px}.round-result-card button{width:100%;font-size:18px;font-weight:900;padding:12px 14px;border:2px solid #0f4f32;background:#1f7a4b;color:#f4fff8}.round-end-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:var(--z-banner);pointer-events:none}.round-end-banner{animation:banner-enter .5s ease-out forwards}.round-end-banner.win .round-end-text{font-size:48px;font-weight:900;color:gold;text-shadow:0 0 24px rgba(255,215,0,.5),0 4px 12px rgba(0,0,0,.4);text-transform:uppercase}.round-end-banner.loss .round-end-text{font-size:36px;font-weight:700;color:var(--text-light);text-shadow:0 2px 8px rgba(0,0,0,.4);opacity:.9}@keyframes banner-enter{0%{transform:scale(.3);opacity:0}60%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:1}}.round-summary-group{background:#00000026;border:1px solid var(--panel-border);border-radius:12px;padding:10px;margin-bottom:10px;display:flex;flex-direction:column;gap:6px}.round-result-banner{text-align:center;padding:10px 16px;margin-bottom:0;border-radius:8px}.round-result-banner.defender{background:linear-gradient(135deg,#3b6ea54d,#3b6ea51a);border:1px solid rgba(59,110,165,.4)}.round-result-banner.attacker{background:linear-gradient(135deg,#c0392b4d,#c0392b1a);border:1px solid rgba(192,57,43,.4)}.round-result-winner-text{font-size:clamp(18px,2.5vw,28px);font-weight:800;color:var(--card-glow-gold)}.round-result-game-over{display:block;font-size:14px;font-weight:700;color:var(--text-muted);margin-top:4px}.round-result-scores{display:flex;gap:10px;justify-content:center;margin-bottom:0}.round-score-col{display:flex;flex-direction:column;align-items:center;padding:4px 12px;border-radius:6px;background:#0003;border:1px solid var(--panel-border)}.round-score-label{font-size:11px;font-weight:600;color:var(--text-muted)}.round-score-value{font-size:clamp(22px,3vw,32px);font-weight:800;font-variant-numeric:tabular-nums}.round-score-col.defender .round-score-value{color:var(--team-defender)}.round-score-col.attacker .round-score-value{color:var(--team-attacker)}.round-level-change{text-align:center;margin-bottom:8px;font-size:14px;font-weight:700;color:var(--text-light)}.round-level-label{color:var(--text-muted);margin-right:6px}.round-level-arrow{color:var(--card-glow-gold);margin:0 4px}.round-level-delta{color:var(--card-glow-gold);margin-left:4px;font-size:12px}.trick-table-wrap{overflow-x:auto;margin-bottom:12px;-webkit-overflow-scrolling:touch}.trick-table{width:100%;border-collapse:collapse;font-size:12px;background:#fff0}.trick-table-th{padding:6px 4px;font-weight:700;color:var(--card-glow-gold);border-bottom:2px solid rgba(255,255,255,.1);text-align:center;white-space:nowrap;font-size:13px;background:#0003}.trick-table-th.trick-num{width:30px;color:var(--text-muted)}.trick-table-row:nth-child(2n){background:#0000001a}.trick-table-td{padding:6px 4px;text-align:center;vertical-align:middle;border-bottom:1px solid rgba(255,255,255,.1);background:#0003;min-width:90px}.trick-table-td.trick-num{font-weight:700;color:var(--text-muted);font-size:11px}.trick-cell-cards{display:inline-flex;gap:1px;justify-content:center}.trick-cell-empty{color:#fff6;font-size:14px}.trick-cell-seat{display:flex;justify-content:center;align-items:center;gap:4px;flex-wrap:wrap;font-size:10px;color:#ffffffb3;margin-bottom:4px}.trick-cell-lead{padding:0 4px;border-radius:999px;background:#ffd70033;color:var(--card-glow-gold);font-size:10px;font-weight:700}.trick-total-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:12px}.trick-total-info{text-align:center;font-size:12px;color:var(--text-light);padding:6px 12px;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:#0003;min-width:110px}.trick-total-name{display:block;font-weight:600;color:#fffc}.trick-total-pts{display:block;font-size:14px;font-weight:800;color:var(--card-glow-gold)}.trick-winner-cell{background:#ffd7001f;box-shadow:inset 0 0 0 1px #ffd70040}.trick-totals-row{border-top:2px solid rgba(255,255,255,.2)}.trick-total-cell{font-weight:800;color:var(--card-glow-gold);font-size:14px}.round-roles-swapped{text-align:center;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:0;padding:6px 14px;border-radius:999px;background:#ffd7001a;display:inline-block;margin-left:auto;margin-right:auto}.round-analytics{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:0}.round-analytics-stat{display:flex;flex-direction:column;align-items:center;padding:4px;border-radius:6px;background:#00000040;border:1px solid var(--panel-border)}.round-analytics-label{font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:2px}.round-analytics-value{font-size:18px;font-weight:800;color:var(--card-glow-gold);font-variant-numeric:tabular-nums}.round-player-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:6px;margin-bottom:12px}.round-player-stat{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;background:#00000026;border:1px solid rgba(255,255,255,.08)}.round-player-stat-name{font-size:13px;font-weight:700;color:var(--text-light);flex:0 0 auto;min-width:70px}.round-player-stat-detail{font-size:12px;color:var(--text-muted)}.round-player-stat-pts{font-weight:800;color:var(--card-glow-gold);margin-left:auto;font-size:14px}.floating-points-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:var(--z-floating);pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:8px}.floating-point{animation:float-up 2s ease-out forwards;font-size:20px;font-weight:800;color:var(--card-glow-gold);text-shadow:0 2px 8px rgba(0,0,0,.5)}@keyframes float-up{0%{transform:translateY(0);opacity:1}to{transform:translateY(-60px);opacity:0}}.game-badges-container{position:fixed;top:4rem;right:16px;z-index:var(--z-floating);display:flex;flex-direction:column;gap:6px;pointer-events:none}.game-badge{animation:badge-slide-in .4s ease-out forwards;padding:6px 14px;border-radius:999px;background:linear-gradient(135deg,#ffd70033,#ff980026);border:1px solid rgba(255,215,0,.4);color:var(--card-glow-gold);font-size:12px;font-weight:700;white-space:nowrap}@keyframes badge-slide-in{0%{transform:translate(80px);opacity:0}to{transform:translate(0);opacity:1}}@media (prefers-reduced-motion: reduce){.lobby-particles:before,.lobby-particles:after,.game-layout:before{animation:none!important}.seat-card.is-turn:before{animation:none!important}.card-face.is-trump:after{animation:none!important}.profile-avatar{animation:none!important}.round-end-banner,.floating-point,.game-badge{animation:none!important;opacity:1}.score-progress-fill{transition:none!important}.game-table.screen-shake{animation:none!important}.impact-particle,.trump-flash-bg,.trump-suit-icon{animation:none!important;opacity:0}.level-up-text{animation:none!important;opacity:1}.throw-punished-overlay{animation:none!important;opacity:0}.koudi-card-flip{animation:none!important;opacity:1;transform:none}.trick-play.trick-winning{animation:none!important}}.voice-picker-wrap{position:relative}.voice-picker-dropdown{position:absolute;top:100%;right:0;z-index:var(--z-dropdown);background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:6px;padding:6px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:200px}.voice-picker-dropdown select{width:100%;padding:5px 8px;font-size:12px;border-radius:4px;background:#0000004d;color:var(--text-light);border:1px solid var(--panel-border)}.demo-tab-bar{position:fixed;top:8px;right:8px;display:flex;gap:4px;padding:4px;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);border-radius:8px;z-index:calc(var(--z-demo) + 1);flex-wrap:wrap;max-width:320px}.demo-tab-toggle{padding:4px 10px;border:1px solid rgba(255,215,0,.4);border-radius:6px;background:#ffd70026;color:var(--card-glow-gold);font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s}.demo-tab-toggle:hover{background:#ffd7004d}.demo-player-toggle{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.demo-player-count{padding:4px 10px;border:1px solid rgba(255,255,255,.25);border-radius:6px;background:#ffffff0d;color:var(--text-light);font-size:11px;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.demo-player-count.active{background:var(--card-glow-gold);color:#1a1a1a;border-color:var(--card-glow-gold)}.demo-tab{padding:6px 16px;border:1px solid var(--panel-border);border-radius:6px;background:var(--panel-bg);color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.demo-tab.active{background:var(--card-glow-gold);color:#1a1a1a;border-color:var(--card-glow-gold)}.demo-tab:hover:not(.active){background:#ffffff1a;color:var(--text-light)}.demo-game-wrapper{flex:1;min-height:0;overflow:hidden}.demo-game-wrapper .game-layout{height:100%}.demo-label-wrap{position:relative;flex:0 0 auto;min-width:0;min-height:0;overflow:visible}.demo-wrap-game-table{flex:1 1 auto;display:flex;flex-direction:inherit;align-items:center;justify-content:center}.demo-wrap-seat-sidebar{flex:0 0 auto;display:flex;flex-direction:inherit}.demo-label-tag{position:absolute;top:0;left:0;z-index:var(--z-demo);font-size:9px;font-weight:800;letter-spacing:.5px;color:#fff;background:#ff0064b3;padding:1px 5px;border-radius:0 0 4px;pointer-events:none;line-height:1.4;text-transform:uppercase}@media (max-width: 900px){.game-table{aspect-ratio:4 / 3;border-width:4px}.score-teams{gap:10px}.team-score{font-size:18px}.seat-avatar{width:28px;height:28px;font-size:12px}.seat-name{font-size:12px}.seat-card{padding:4px 12px}}@media (max-width: 600px){.lobby-title{font-size:1.8rem}.lobby-container{padding:16px 8px}.game-layout{padding:4px;gap:4px}.game-table{aspect-ratio:4 / 3;border-radius:16px;border-width:3px}.card-face{border-radius:5px}.card-face.clickable:hover{transform:none}.card-face.selected{transform:translateY(-10px)}.hand-container{overflow-x:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start;padding:18px 4px 16px;scroll-snap-type:x proximity}.hand-card-wrap{transform:none!important;scroll-snap-align:start}.hand-layer{grid-template-columns:42px minmax(0,1fr);gap:4px}.hand-layer-label{font-size:8px;padding-bottom:2px}.scoreboard-header{font-size:11px;padding:2px 6px}.score-teams{gap:8px}.team-score{font-size:16px}.score-vs{font-size:10px}.chat-sidebar:not(.chat-sidebar-mobile){display:none}.action-panel button{width:100%;min-height:44px}.action-buttons,.action-btn,.lobby-ready-btn{width:100%}.leave-btn{width:auto!important;min-height:auto!important}.game-body{flex-direction:column;align-items:stretch;gap:4px}.seat-sidebar{flex-direction:row;flex-wrap:wrap;flex:0 0 auto;width:100%;min-width:0;max-width:100%;min-height:auto;max-height:none;overflow-x:auto;overflow-y:visible;gap:4px;padding:2px}.game-badges-container{top:auto;bottom:60px}.seat-card{min-width:70px;max-width:120px;padding:2px 6px;gap:4px;border-radius:10px}.seat-avatar{width:24px;height:24px;font-size:11px}.seat-name{font-size:9px}.seat-badge{font-size:8px;padding:0 4px}.seat-cards-pill{font-size:9px}.trick-play .card-face+.card-face{margin-left:-5vw}button{min-height:44px}.lang-toggle{min-height:36px}.btn-primary{min-height:44px}.hand-scroll-btn{width:24px}.hand-layout-btn{font-size:9px;padding:2px 7px}.surrender-vote-bar{max-width:100%}.trick-play .card-face{--cs: calc(var(--card-scale-trick) * .85)}.history-match-list{max-height:200px}.round-end-banner.win .round-end-text{font-size:32px}.round-end-banner.loss .round-end-text{font-size:24px}}.dev-demo-fab{position:fixed;z-index:var(--z-toast);padding:6px 14px;background:#000c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,215,0,.4);border-radius:20px;font-size:11px;font-weight:700;color:gold;text-decoration:none;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;white-space:nowrap;box-shadow:0 2px 8px #0006;transition:box-shadow .15s,background .15s}.dev-demo-fab:hover{background:#000000e6;box-shadow:0 2px 12px #ffd70040;text-decoration:none;color:#ffe44d}.dev-demo-fab:active{cursor:grabbing}@keyframes screen-shake{0%,to{transform:translate(0)}10%{transform:translate(-4px,2px)}30%{transform:translate(3px,-3px)}50%{transform:translate(-3px,3px)}70%{transform:translate(4px,-1px)}90%{transform:translate(-1px,-3px)}}@keyframes screen-shake-sm{0%,to{transform:translate(0)}10%{transform:translate(-2px,1px)}30%{transform:translate(2px,-2px)}50%{transform:translate(-2px,2px)}70%{transform:translate(2px,-1px)}90%{transform:translate(-1px,-2px)}}.game-table.screen-shake{animation:screen-shake .3s ease-out}@media (max-width: 768px){.game-table.screen-shake{animation:screen-shake-sm .3s ease-out}}@keyframes impact-particle{0%{transform:translate(0) scale(1);opacity:1}to{opacity:0}}.impact-burst-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:900}.impact-particle{position:absolute;width:8px;height:8px;border-radius:50%;animation:impact-particle .4s ease-out forwards}@keyframes trump-flash{0%{opacity:0;transform:scale(.5)}30%{opacity:.8;transform:scale(1.2)}60%{opacity:.6;transform:scale(1.5)}to{opacity:0;transform:scale(1.8)}}@keyframes trump-suit-symbol{0%{opacity:0;transform:scale(.3)}20%{opacity:1;transform:scale(1.1)}50%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.3)}}.trump-declare-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:910}.trump-flash-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle,rgba(255,215,0,.3) 0%,transparent 70%);animation:trump-flash .8s ease-out forwards}.trump-suit-icon{font-size:120px;text-shadow:0 0 40px rgba(255,215,0,.8),0 0 80px rgba(255,215,0,.4);animation:trump-suit-symbol 1s ease-out forwards}@keyframes level-up-glow{0%,to{text-shadow:0 0 10px rgba(255,215,0,.6)}50%{text-shadow:0 0 30px rgba(255,215,0,1),0 0 60px rgba(255,165,0,.6)}}.level-up-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:920}.level-up-text{font-size:48px;font-weight:900;color:gold;animation:banner-enter .6s cubic-bezier(.34,1.56,.64,1) forwards,level-up-glow 1s ease-in-out infinite;text-transform:uppercase;letter-spacing:4px}@keyframes punished-flash{0%{opacity:0}20%{opacity:.35}to{opacity:0}}.throw-punished-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#dc1e1e40;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:905;animation:punished-flash .5s ease-out forwards}.punished-x-icon{font-size:100px;color:#dc1e1eb3;font-weight:900;animation:trump-suit-symbol .5s ease-out forwards}@keyframes card-flip{0%{transform:rotateY(180deg);opacity:0}50%{opacity:.5}to{transform:rotateY(0);opacity:1}}.koudi-card-flip{animation:card-flip .5s ease-out forwards;transform-style:preserve-3d}@keyframes trick-win-sweep{0%{box-shadow:0 0 #ffd70000}50%{box-shadow:0 0 20px #ffd70099,0 0 40px #ffd7004d}to{box-shadow:0 0 #ffd70000}}.trick-play.trick-winning{animation:trick-win-sweep .8s ease-out}.insights-page{max-width:960px;margin:0 auto;padding:24px 16px 60px;min-height:100vh}.insights-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.insights-back{color:var(--text-muted);text-decoration:none;font-size:.85rem;transition:color .2s}.insights-back:hover{color:var(--card-glow-gold)}.insights-lang-toggle{background:#ffffff0f;border:1px solid var(--panel-border);border-radius:6px;color:var(--text-muted);font-size:.75rem;font-weight:600;padding:4px 12px;cursor:pointer;transition:color .2s,border-color .2s}.insights-lang-toggle:hover{color:var(--card-glow-gold);border-color:#ffd7004d}.insights-header{display:flex;align-items:center;gap:20px;margin-bottom:28px}.insights-avatar-ring{width:72px;height:72px;border-radius:50%;background:conic-gradient(var(--card-glow-gold),#ffaa00,var(--card-glow-gold));padding:3px;flex-shrink:0}.insights-avatar{width:100%;height:100%;border-radius:50%;background:var(--felt-dark);display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;color:var(--card-glow-gold)}.insights-header-info{flex:1;min-width:0}.insights-player-name{font-size:1.6rem;font-weight:700;margin:0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.insights-ai-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;background:linear-gradient(135deg,gold,#fa0);color:#1a1a1a;padding:3px 10px;border-radius:20px;animation:sparkle-pulse 2s ease-in-out infinite}.insights-grade-label{margin:4px 0 0;font-size:.85rem;color:var(--text-muted)}.insights-grade{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,gold,#ff8c00);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:#1a1a1a;flex-shrink:0;box-shadow:0 0 20px #ffd7004d}@keyframes sparkle-pulse{0%,to{box-shadow:0 0 4px #ffd70066}50%{box-shadow:0 0 12px #ffd700cc,0 0 24px #ffd7004d}}.insights-panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.insights-panel-title{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 14px}.insights-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;padding:18px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px}.insights-card-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.insights-card-sub{font-size:.78rem;color:var(--text-muted)}.insights-card-rank{font-size:.7rem;color:var(--card-glow-gold);font-weight:600}.insights-big-number{font-size:2rem;font-weight:700;color:var(--text-light);line-height:1.1}.insights-trend-up{color:var(--card-glow-green)}.insights-level-current{font-size:2rem;font-weight:700;color:var(--card-glow-gold);line-height:1.1}.insights-xp-bar{width:100%;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.insights-xp-fill{height:100%;background:linear-gradient(90deg,var(--card-glow-gold),#ffaa00);border-radius:3px;transition:width 1s ease}.insights-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.insights-ai-panel{background:var(--panel-bg);border-radius:14px;padding:22px;margin-bottom:24px;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:2px solid transparent;background-clip:padding-box;box-shadow:0 0 0 2px #ffd70026;animation:gradient-border-shift 4s ease infinite}.insights-ai-panel:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:16px;background:linear-gradient(90deg,var(--card-glow-gold),#ff8c00,var(--card-glow-gold));background-size:200% 100%;animation:gradient-border-shift 4s ease infinite;z-index:-1;opacity:.3}@keyframes gradient-border-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.insights-ai-panel-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.insights-ai-panel-header h2{margin:0;font-size:1.1rem;font-weight:700}.insights-ai-sparkle{font-size:1.3rem;animation:sparkle-pulse 2s ease-in-out infinite}.insights-ai-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.insights-ai-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px;display:flex;gap:12px;align-items:flex-start;position:relative}.insights-ai-card-icon{font-size:1.4rem;flex-shrink:0;line-height:1}.insights-ai-card-body{flex:1;min-width:0}.insights-ai-card-title{font-weight:600;font-size:.85rem;margin-bottom:4px}.insights-ai-card-desc{font-size:.75rem;color:var(--text-muted);line-height:1.45;margin:0}.insights-trend-badge{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:10px;flex-shrink:0;white-space:nowrap}.insights-trend-badge.positive{background:#4caf5026;color:var(--card-glow-green)}.insights-trend-badge.warning{background:#ff980026;color:#ff9800}.insights-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:24px}.insights-streak-blocks{display:flex;flex-wrap:wrap;gap:3px;padding-top:4px}.insights-streak-block{width:16px;height:16px;border-radius:3px;transition:transform .15s;cursor:default}.insights-streak-block:hover{transform:scale(1.4)}.insights-streak-block.win{background:var(--card-glow-green)}.insights-streak-block.loss{background:var(--team-attacker)}.insights-role-bars{display:flex;flex-direction:column;gap:10px}.insights-role-row{display:flex;align-items:center;gap:8px}.insights-role-label{width:65px;font-size:.78rem;font-weight:500;flex-shrink:0}.insights-role-track{flex:1;height:8px;background:#ffffff0f;border-radius:4px;overflow:hidden}.insights-role-fill{height:100%;border-radius:4px;transition:width 1s ease}.insights-role-value{font-size:.78rem;font-weight:600;width:38px;text-align:right;flex-shrink:0}.insights-role-count{font-size:.7rem;color:var(--text-muted);width:28px;flex-shrink:0}.insights-histogram{display:flex;flex-direction:column;gap:8px}.insights-histogram-bars{display:flex;gap:8px;align-items:flex-end;height:100px}.insights-histogram-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.insights-histogram-pair{display:flex;gap:2px;align-items:flex-end;flex:1;width:100%}.insights-histogram-bar{flex:1;border-radius:3px 3px 0 0;transition:height 1s ease;min-height:2px}.insights-histogram-bar.attacker{background:var(--team-attacker)}.insights-histogram-bar.defender{background:var(--team-defender)}.insights-histogram-label{font-size:.6rem;color:var(--text-muted);white-space:nowrap}.insights-histogram-legend{display:flex;gap:14px;justify-content:center}.insights-legend-item{font-size:.7rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.insights-legend-dot{width:8px;height:8px;border-radius:2px}.insights-legend-dot.attacker{background:var(--team-attacker)}.insights-legend-dot.defender{background:var(--team-defender)}.insights-improve-panel{margin-bottom:24px}.insights-improve-header{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:4px}.insights-improve-header .insights-panel-title{margin-bottom:0}.insights-improve-subtitle{font-size:.7rem;color:var(--text-muted);opacity:.7}.insights-improve-list{display:flex;flex-direction:column;gap:12px}.insights-improve-item{display:flex;gap:14px;padding:14px;border-radius:10px;border:1px solid rgba(255,255,255,.05);background:#ffffff05;transition:border-color .2s}.insights-improve-item:hover{border-color:#ffd70026}.insights-improve-rank{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;min-width:44px}.insights-improve-priority{font-size:1.1rem;font-weight:700;color:var(--text-muted)}.insights-improve-impact{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:8px}.insights-improve-impact.high{background:#c0392b33;color:var(--team-attacker)}.insights-improve-impact.medium{background:#ff980026;color:#ff9800}.insights-improve-body{flex:1;min-width:0}.insights-improve-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px;flex-wrap:wrap}.insights-improve-title{font-weight:600;font-size:.88rem}.insights-improve-grades{display:flex;align-items:center;gap:4px;flex-shrink:0}.insights-improve-grade{font-size:.72rem;font-weight:700;padding:1px 6px;border-radius:4px}.insights-improve-grade.current{background:#ffffff14;color:var(--text-muted)}.insights-improve-grade.target{background:#4caf5033;color:var(--card-glow-green)}.insights-improve-arrow{font-size:.7rem;color:var(--text-muted)}.insights-improve-desc{font-size:.78rem;color:var(--text-muted);line-height:1.5;margin:0 0 8px}.insights-improve-drill{font-size:.72rem;color:var(--card-glow-gold);background:#ffd7000d;border:1px solid rgba(255,215,0,.1);border-radius:6px;padding:8px 10px;line-height:1.45}.insights-improve-drill-label{font-weight:700;text-transform:uppercase;font-size:.65rem;letter-spacing:.04em}.insights-replay-panel{margin-bottom:24px}.insights-replay-subtitle{font-size:.75rem;color:var(--text-muted);margin:-8px 0 16px}.insights-replay-game{border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:16px;margin-bottom:14px;background:#ffffff04}.insights-replay-game:last-child{margin-bottom:0}.insights-replay-game.win{border-left:3px solid var(--card-glow-green)}.insights-replay-game.loss{border-left:3px solid var(--team-attacker)}.insights-replay-game-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}.insights-replay-result{font-weight:800;font-size:.9rem}.insights-replay-result.win{color:var(--card-glow-green)}.insights-replay-result.loss{color:var(--team-attacker)}.insights-replay-role{font-size:.78rem;font-weight:600;color:var(--text-light)}.insights-replay-vs,.insights-replay-score,.insights-replay-date{font-size:.72rem;color:var(--text-muted)}.insights-replay-summary{font-size:.78rem;color:var(--text-muted);line-height:1.5;margin:0 0 12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.04)}.insights-replay-moves{display:flex;flex-direction:column;gap:8px}.insights-replay-move{padding:10px 12px;border-radius:8px;border-left:3px solid transparent}.insights-replay-move.brilliant{background:#ffd7000f;border-left-color:var(--card-glow-gold)}.insights-replay-move.great{background:#4caf500d;border-left-color:var(--card-glow-green)}.insights-replay-move.mistake{background:#ff98000d;border-left-color:#ff9800}.insights-replay-move.blunder{background:#c0392b14;border-left-color:var(--team-attacker)}.insights-replay-move-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.insights-replay-verdict{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:8px;display:flex;align-items:center;gap:3px}.insights-replay-verdict-icon{font-size:.75rem}.insights-replay-verdict.brilliant{background:#ffd70033;color:var(--card-glow-gold)}.insights-replay-verdict.great{background:#4caf5033;color:var(--card-glow-green)}.insights-replay-verdict.mistake{background:#ff980033;color:#ff9800}.insights-replay-verdict.blunder{background:#c0392b33;color:var(--team-attacker)}.insights-replay-trick,.insights-replay-seat{font-size:.72rem;color:var(--text-muted)}.insights-replay-cards{font-size:.82rem;font-weight:600;color:var(--text-light);letter-spacing:.02em}.insights-replay-swing{font-size:.7rem;font-weight:700;margin-left:auto}.insights-replay-swing.positive{color:var(--card-glow-green)}.insights-replay-swing.negative{color:var(--team-attacker)}.insights-replay-explanation{font-size:.75rem;color:var(--text-muted);line-height:1.5;margin:0}@media (max-width: 480px){.insights-improve-item{flex-direction:column;gap:8px}.insights-improve-rank{flex-direction:row;min-width:auto}}.insights-playstyle{display:flex;align-items:center;gap:24px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);margin-bottom:24px}.insights-playstyle-chart{flex-shrink:0;width:240px}.insights-playstyle-info{flex:1;min-width:0}.insights-playstyle-label{font-size:1.4rem;font-weight:700;margin:0 0 8px;background:linear-gradient(135deg,var(--card-glow-gold),#ff8c00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.insights-playstyle-desc{font-size:.82rem;color:var(--text-muted);line-height:1.55;margin:0}.insights-timeline{position:relative;padding-left:20px}.insights-timeline-line{position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:#ffffff14;border-radius:1px}.insights-timeline-item{display:flex;align-items:flex-start;gap:12px;padding:8px 0;position:relative}.insights-timeline-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:3px;position:absolute;left:-20px}.insights-timeline-dot.win{background:var(--card-glow-green);box-shadow:0 0 6px #4caf5080}.insights-timeline-dot.loss{background:var(--team-attacker);box-shadow:0 0 6px #c0392b80}.insights-timeline-content{flex:1;min-width:0}.insights-timeline-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.insights-timeline-result{font-weight:700;font-size:.82rem}.insights-timeline-result.win{color:var(--card-glow-green)}.insights-timeline-result.loss{color:var(--team-attacker)}.insights-timeline-role,.insights-timeline-level,.insights-timeline-points{font-size:.75rem;color:var(--text-muted)}.insights-timeline-moment{font-size:.72rem;color:var(--text-muted);opacity:.7;margin-top:2px}.insights-social-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:24px}.insights-social-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04)}.insights-social-row:last-child{border-bottom:none}.insights-social-name{flex:1;font-size:.82rem;font-weight:500}.insights-social-matches{font-size:.72rem;color:var(--text-muted)}.insights-social-wr{font-size:.78rem;font-weight:600;width:42px;text-align:right}.insights-social-grade{font-size:.7rem;font-weight:700;width:28px;text-align:center;padding:2px 0;border-radius:4px}.insights-social-grade.grade-Aplus{background:#4caf5033;color:var(--card-glow-green)}.insights-social-grade.grade-A{background:#42a5f533;color:var(--card-glow-blue)}.insights-social-grade.grade-Bplus{background:#ffd70026;color:var(--card-glow-gold)}.insights-social-difficulty{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:2px 8px;border-radius:8px}.insights-social-difficulty.nemesis{background:#c0392b33;color:var(--team-attacker)}.insights-social-difficulty.rival{background:#ff980026;color:#ff9800}.insights-social-difficulty.favorable{background:#4caf5026;color:var(--card-glow-green)}.insights-achievements-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.insights-achievement{text-align:center;padding:16px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;transition:transform .2s}.insights-achievement:hover{transform:translateY(-2px)}.insights-achievement.unlocked{border-color:#ffd70040;background:#ffd7000a}.insights-achievement.locked{opacity:.5;filter:grayscale(.6)}.insights-achievement-icon{font-size:1.6rem;margin-bottom:6px}.insights-achievement-name{font-size:.78rem;font-weight:600;margin-bottom:2px}.insights-achievement-desc{font-size:.65rem;color:var(--text-muted);line-height:1.3}.insights-achievement-progress{margin-top:6px;display:flex;align-items:center;gap:6px}.insights-achievement-bar{flex:1;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.insights-achievement-fill{height:100%;background:var(--card-glow-gold);border-radius:2px}.insights-achievement-count{font-size:.6rem;color:var(--text-muted);white-space:nowrap}.insights-footer{text-align:center;font-size:.75rem;color:var(--text-muted);opacity:.6;margin-top:32px;padding-bottom:16px}@media (max-width: 768px){.insights-stats-grid{grid-template-columns:repeat(2,1fr)}.insights-ai-grid,.insights-charts-grid,.insights-social-grid{grid-template-columns:1fr}.insights-achievements-grid{grid-template-columns:repeat(2,1fr)}.insights-playstyle{flex-direction:column}.insights-playstyle-chart{width:200px}}@media (max-width: 480px){.insights-stats-grid,.insights-achievements-grid{grid-template-columns:1fr}.insights-header{flex-wrap:wrap}.insights-ai-card{flex-direction:column;align-items:flex-start}}.fill-bots-btn{background:linear-gradient(135deg,#e65100,#ff8f00);color:#fff;border:1px solid rgba(255,160,0,.5);border-radius:6px;padding:6px 14px;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s,box-shadow .2s}.fill-bots-btn:hover{background:linear-gradient(135deg,#bf360c,#e65100);box-shadow:0 0 8px #ffa00066}.play-drop-zone{position:absolute;top:10%;right:10%;bottom:10%;left:10%;border:3px dashed transparent;border-radius:50%;pointer-events:none;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s;z-index:var(--z-overlay-subtle)}.play-drop-zone.active{border-color:#ffd70099;background:#ffd7000f;animation:drop-zone-pulse 1.2s ease-in-out infinite}.play-drop-zone-label{font-size:14px;font-weight:700;color:#ffd700b3;text-transform:uppercase;letter-spacing:1px}@keyframes drop-zone-pulse{0%,to{border-color:#ffd7004d}50%{border-color:#ffd700cc}}.btn-full{width:100%}.form-hint{font-size:11px;color:var(--text-muted);margin:2px 0 0}.form-label{font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:2px}.room-list-age{font-size:10px;color:var(--text-muted);min-width:40px;text-align:center}.room-list-names{font-size:11px;color:var(--text-muted);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-gear-btn{font-size:20px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;line-height:1;transition:color .2s}.settings-gear-btn:hover{color:var(--card-glow-gold)}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.settings-modal{max-width:400px;width:90%;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.settings-header{display:flex;align-items:center;justify-content:space-between}.settings-divider{border:none;border-top:1px solid var(--panel-border);margin:4px 0}.settings-section-title{margin:0;font-size:14px;font-weight:700;color:var(--text-light)}.lobby-chat-panel{display:flex;flex-direction:column;gap:8px}.lobby-chat-log{max-height:160px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--card-glow-gold) transparent;display:flex;flex-direction:column;gap:2px;font-size:12px}.chat-tabs{display:flex;gap:4px}.chat-tab{padding:4px 12px;font-size:12px;font-weight:600;border:1px solid var(--panel-border);border-radius:6px 6px 0 0;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.chat-tab.active{background:#ffd70026;color:var(--card-glow-gold);border-bottom-color:transparent}.chat-tab:hover:not(.active){background:#ffffff0d}.chat-bubble{position:absolute;top:-8px;left:50%;transform:translate(-50%,-100%);background:#000c;color:#fff;padding:4px 8px;border-radius:8px;font-size:12px;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;animation:bubble-fade 5s ease-out forwards;pointer-events:none;z-index:10}@keyframes bubble-fade{0%,80%{opacity:1}to{opacity:0}}@media (max-width: 600px){.round-result-card{padding:8px clamp(4px,1.5vw,12px);overflow-y:auto;-webkit-overflow-scrolling:touch}.round-result-scroll{flex:1 1 auto;min-height:0;overflow-y:auto}.round-result-title{font-size:18px;margin-bottom:6px}.round-result-text{font-size:14px;margin-bottom:6px}.round-seat-title{font-size:10px;min-width:45px}.round-seat-block{padding:4px;gap:4px}.round-result-card .card-face.mini{--cs: .4}.round-result-card .trick-table-td{padding:1px 0;font-size:10px;min-width:60px}.trick-table-th{font-size:10px;padding:4px 2px}.trick-table-wrap{margin-bottom:6px}.round-result-card button{position:sticky;bottom:0;flex-shrink:0;font-size:16px;padding:10px 12px;z-index:1}.modal-card{max-height:90vh;overflow-y:auto;padding:8px}}.feedback-tab-btn{position:fixed;bottom:16px;right:16px;background:linear-gradient(135deg,#b8860b,#daa520);color:#fff;border:none;padding:8px 16px;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;z-index:var(--z-toast);box-shadow:0 2px 8px #0000004d}.feedback-panel{position:fixed;bottom:16px;right:16px;width:300px;background:var(--panel-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--panel-border);border-radius:12px;padding:12px;z-index:var(--z-toast);display:flex;flex-direction:column;gap:8px}.feedback-header{display:flex;justify-content:space-between;align-items:center}.feedback-title{font-weight:700;color:var(--card-glow-gold)}.feedback-textarea{width:100%;background:#0000004d;color:var(--text-light);border:1px solid var(--panel-border);border-radius:6px;padding:8px;font-size:13px;resize:vertical;font-family:inherit}.feedback-thanks{text-align:center;color:var(--card-glow-green);padding:16px 0}@keyframes hint-flash-pulse{0%,to{box-shadow:0 0 #4caf5000}25%{box-shadow:0 0 12px 4px #4caf5099}50%{box-shadow:0 0 #4caf5000}75%{box-shadow:0 0 12px 4px #4caf5099}}.hand-card-wrap.hint-flash{animation:hint-flash-pulse 1.5s ease-in-out;z-index:50!important}.hand-clear-btn{display:inline-flex;align-items:center;gap:2px;margin-left:8px;padding:1px 8px;font-size:10px;font-weight:700;color:var(--text-muted);background:#ffffff14;border:1px solid var(--panel-border);border-radius:4px;cursor:pointer;vertical-align:middle}.hand-clear-btn:hover{color:var(--text-light);background:#ffffff26}.phase-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;font-size:11px;font-weight:800;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}.phase-badge.flip-trump{background:#ff980033;color:#ff9800;border:1px solid rgba(255,152,0,.4)}.phase-badge.bury-kitty{background:#2196f333;color:#42a5f5;border:1px solid rgba(33,150,243,.4)}.phase-badge.trick-play{background:#4caf5033;color:#4caf50;border:1px solid rgba(76,175,80,.4)}.phase-badge.round-score{background:#9c27b033;color:#ce93d8;border:1px solid rgba(156,39,176,.4)}.conn-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}.conn-dot.connected{background:#4caf50}.conn-dot.reconnecting{background:#ff9800;animation:conn-pulse 1.2s ease-in-out infinite}.conn-dot.disconnected{background:#f44336}@keyframes conn-pulse{0%,to{opacity:1}50%{opacity:.3}}.reconnecting-banner{position:fixed;top:0;left:0;right:0;z-index:var(--z-banner);background:#ff9800e6;color:#fff;text-align:center;font-size:12px;font-weight:700;padding:4px 0;animation:conn-pulse 1.2s ease-in-out infinite}.waiting-indicator{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);padding:4px 0}.waiting-dots:after{content:"";animation:waiting-dots 1.5s steps(4,end) infinite}@keyframes waiting-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.trump-table-indicator{position:absolute;top:8px;left:50%;transform:translate(-50%);z-index:var(--z-overlay-subtle);display:flex;align-items:center;gap:6px;padding:4px 14px;border-radius:999px;background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,215,0,.3);font-size:18px;font-weight:800;pointer-events:none}.trump-table-suit{font-size:22px;line-height:1}.trump-table-suit.red{color:#e53935}.trump-table-suit.black{color:#e8e0d0}.trump-table-suit.nt{color:#9e9e9e}.trump-table-rank{color:var(--card-glow-gold)}.trick-history-toggle{position:absolute;bottom:8px;right:8px;z-index:var(--z-overlay-subtle);padding:4px 10px;font-size:11px;font-weight:700;background:#0006;color:var(--text-muted);border:1px solid var(--panel-border);border-radius:6px;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.trick-history-toggle:hover{color:var(--text-light);background:#0009}.trick-history-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay-ui);background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;padding:12px;overflow-y:auto}.trick-history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.trick-history-title{font-size:14px;font-weight:800;color:var(--card-glow-gold)}.trick-history-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px}.trick-history-list{display:flex;flex-direction:column;gap:6px}.trick-history-entry{display:flex;align-items:center;gap:8px;padding:4px 8px;background:#ffffff0d;border-radius:6px;font-size:11px}.trick-history-num{font-weight:800;color:var(--card-glow-gold);min-width:20px}.trick-history-winner{color:var(--card-glow-green);font-weight:700}.trick-history-plays{display:flex;gap:4px;flex-wrap:wrap}.team-you-badge{display:inline-block;padding:0 6px;font-size:9px;font-weight:800;border-radius:3px;background:#4caf504d;color:#4caf50;margin-left:4px;vertical-align:middle;text-transform:uppercase}.score-team.is-your-team{border:1px solid rgba(76,175,80,.3);border-radius:8px;padding:4px 8px}.action-hint{font-size:11px;color:var(--text-muted);text-align:center;padding:2px 8px;line-height:1.4}.throw-warning{font-size:11px;color:#ff9800;text-align:center;padding:2px 8px;font-weight:600}.play-confirm-bar{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#ffd7001a;border:1px solid rgba(255,215,0,.3);border-radius:8px}.play-confirm-text{font-size:13px;font-weight:700;color:var(--card-glow-gold)}.key-hint{font-size:9px;color:var(--text-muted);margin-left:4px;opacity:.7}.captured-summary{display:flex;gap:4px;font-size:10px;color:var(--text-muted);flex-wrap:wrap;cursor:pointer}.captured-chip{padding:1px 4px;background:#ffffff0f;border-radius:3px;font-weight:600}.settings-help{font-size:10px;color:var(--text-muted);opacity:.7;margin-top:-2px}.guide-page{min-height:100vh;padding:24px 16px;max-width:720px;margin:0 auto}.guide-page h1{font-size:2rem;font-weight:800;color:var(--card-glow-gold);margin:0 0 16px}.guide-page h2{font-size:1.3rem;font-weight:700;color:var(--card-glow-gold);margin:24px 0 8px;border-bottom:1px solid var(--panel-border);padding-bottom:4px}.guide-page h3{font-size:1.1rem;font-weight:700;color:var(--text-light);margin:16px 0 4px}.guide-page p,.guide-page li{font-size:14px;color:var(--text-light);line-height:1.6}.guide-page ul{padding-left:20px}.guide-back-btn{display:inline-block;margin-bottom:16px;padding:6px 14px;font-size:13px;font-weight:700;color:var(--text-light);background:#ffffff14;border:1px solid var(--panel-border);border-radius:6px;cursor:pointer;text-decoration:none}.guide-back-btn:hover{background:#ffffff26}.guide-link-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;font-size:13px;font-weight:700;color:var(--text-light);background:#ffffff0f;border:1px solid var(--panel-border);border-radius:6px;cursor:pointer;text-decoration:none}.guide-link-btn:hover{background:#ffffff1f}.event-log-toggle-btn{position:fixed;bottom:8px;left:8px;z-index:var(--z-overlay-subtle);padding:3px 8px;font-size:10px;font-weight:700;background:#00000080;color:var(--text-muted);border:1px solid var(--panel-border);border-radius:4px;cursor:pointer}@media (max-width: 600px){.event-log-sidebar.hidden-mobile{display:none}}@media (max-width: 600px){.score-collapsible{display:none}.score-collapsible.expanded{display:flex}.score-expand-btn{display:inline-flex;align-items:center;font-size:10px;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:0 4px}}@media (min-width: 601px){.score-expand-btn{display:none}.score-collapsible{display:flex!important}}
