.qc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#0000004d;display:flex;align-items:flex-end;justify-content:center;animation:qcFadeIn .15s ease-out}@keyframes qcFadeIn{0%{opacity:0}to{opacity:1}}.qc-picker{width:100%;max-width:500px;background:var(--bg-card);border-radius:16px 16px 0 0;padding:12px 8px;padding-bottom:max(12px,env(safe-area-inset-bottom));animation:qcSlideUp .2s ease-out}@keyframes qcSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.qc-strip{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px}.qc-strip::-webkit-scrollbar{display:none}.qc-item{flex-shrink:0;scroll-snap-align:start;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:var(--bg-surface);font-size:24px;border:none;cursor:pointer;transition:transform .1s,background .15s;-webkit-tap-highlight-color:transparent}.qc-item:active{transform:scale(.9);background:var(--bg-hover)}.qc-item.qc-text{width:auto;min-width:48px;padding:0 12px;font-size:13px;font-weight:600;color:var(--text)}.qc-bubbles-bar{position:fixed;bottom:56px;left:50%;transform:translate(-50%);display:flex;gap:8px;z-index:800;pointer-events:none}.qc-bubble-chip{display:flex;align-items:center;gap:4px;background:var(--bg-card);border:1px solid var(--bg-hover);border-radius:20px;padding:4px 10px 4px 4px;box-shadow:0 2px 12px #0006;animation:qcBubbleIn .2s ease-out,qcBubbleOut .4s ease-in 2.1s forwards}.qc-bubble-avatar{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.qc-bubble-emoji{font-size:15px;line-height:1;white-space:nowrap}@keyframes qcBubbleIn{0%{opacity:0;transform:translateY(8px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes qcBubbleOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-8px) scale(.8)}}.kinito-page{justify-content:flex-start;padding-top:16px;gap:0}.kinito-players{display:flex;gap:8px;padding:8px 16px;overflow-x:auto;width:100%;max-width:500px;scrollbar-width:none}.kinito-players::-webkit-scrollbar{display:none}.kinito-player-arrow{color:var(--text-dim);font-size:18px;flex-shrink:0;opacity:.5;align-self:center}.kinito-player-chip{display:flex;align-items:center;gap:6px;padding:6px 12px 6px 6px;border-radius:24px;background:var(--bg-card);flex-shrink:0;position:relative;transition:background .2s}.kinito-player-chip.active{background:var(--bg-hover);box-shadow:0 0 0 2px var(--primary)}.kinito-player-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff}.kinito-player-name{font-size:13px;font-weight:500;white-space:nowrap}.kinito-turn-dot{position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:6px;height:6px;border-radius:50%;background:var(--primary)}.kinito-game-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:24px;width:100%;max-width:500px}.kinito-phase-label{font-size:20px;font-weight:700;text-align:center}.kinito-hint{font-size:14px;color:var(--text-dim);text-align:center}.kinito-chance-label{color:var(--accent)}.dice-container{display:flex;gap:16px;justify-content:center}.dice-face{width:72px;height:72px;background:#fff;border-radius:14px;padding:10px;box-shadow:0 4px 16px #0000004d}.dice-landed{animation:diceLand .3s ease-out}.dice-rolling{animation:diceRoll .6s ease-out}@keyframes diceRoll{0%{transform:rotate(0) scale(.6);opacity:.3}30%{transform:rotate(180deg) scale(1.1);opacity:.7}60%{transform:rotate(360deg) scale(.95)}to{transform:rotate(360deg) scale(1);opacity:1}}@keyframes diceLand{0%{transform:scale(1.05)}to{transform:scale(1)}}.dice-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:100%;height:100%}.dice-cell{display:flex;align-items:center;justify-content:center}.dice-dot{width:12px;height:12px;border-radius:50%;background:#1a1a2e}.kinito-dice-hidden{display:flex;gap:12px;font-size:48px;opacity:.4;animation:pulse 1.5s infinite}.kinito-announce-grid{display:flex;flex-direction:column;gap:8px;width:100%}.kinito-announce-row{display:flex;gap:6px;justify-content:center}.kinito-announce-btn{padding:12px 14px;border-radius:10px;background:var(--bg-surface);color:var(--text);font-weight:600;font-size:15px;border:2px solid transparent;transition:all .15s;min-width:56px}.kinito-announce-pair{display:flex;flex-direction:column;align-items:center;gap:1px;padding:8px 10px}.kinito-pair-top{font-size:11px;font-weight:500;opacity:.7}.kinito-pair-bottom{font-size:15px;font-weight:700}.kinito-announce-btn:hover:not(:disabled){background:var(--bg-hover)}.kinito-announce-btn:disabled{opacity:.25;pointer-events:none}.kinito-announce-btn.truthful{border-color:var(--success);background:#2ecc7126}.kinito-announcement{font-size:36px;font-weight:800;text-align:center;color:var(--accent);text-shadow:0 0 20px rgba(255,211,105,.3)}.kinito-decide-actions{display:flex;gap:12px;width:100%}.kinito-decide-actions .btn{flex:1}.kinito-reveal{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px;border-radius:var(--radius);width:100%;animation:fadeIn .3s ease-out}.kinito-reveal.lie{background:#e74c3c1a}.kinito-reveal.truth{background:#2ecc711a}.kinito-reveal-info{display:flex;gap:16px;font-size:15px;color:var(--text-dim)}.kinito-verdict{font-size:28px;font-weight:800;animation:shake .5s ease-out}.kinito-reveal.lie .kinito-verdict{color:var(--danger)}.kinito-reveal.truth .kinito-verdict{color:var(--success)}.kinito-sips{font-size:18px;font-weight:600;text-align:center}.kinito-kinito-banner{font-size:40px;font-weight:800;color:var(--accent);text-shadow:0 0 30px rgba(255,211,105,.5);animation:bounce .6s ease-out;text-align:center}.kinito-target-list{display:flex;flex-direction:column;gap:8px;width:100%}.kinito-chances{display:flex;gap:8px;justify-content:center}.kinito-chance-dot{width:14px;height:14px;border-radius:50%;background:var(--bg-surface);transition:background .2s}.kinito-chance-dot.active{background:var(--accent);box-shadow:0 0 8px #ffd36980}.kinito-roll-btn{max-width:280px}.kinito-roll-icon{font-size:24px;display:inline-block;animation:shake 1s infinite}.kinito-ended{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.garame-page{justify-content:flex-start;padding-top:12px;gap:0}.garame-info-bar{display:flex;gap:16px;justify-content:center;padding:8px 16px;font-size:14px;font-weight:600;color:var(--text-dim);width:100%;max-width:500px}.garame-info-bar .garame-pot{color:var(--accent)}.garame-players{display:flex;gap:6px;padding:8px 16px;overflow-x:auto;width:100%;max-width:500px;scrollbar-width:none}.garame-players::-webkit-scrollbar{display:none}.garame-player-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;border-radius:12px;background:var(--bg-card);flex-shrink:0;position:relative;transition:all .2s;min-width:64px}.garame-player-chip.active{background:var(--bg-hover);box-shadow:0 0 0 2px var(--primary)}.garame-player-chip.eliminated{opacity:.35}.garame-player-chip.me{border:1px solid var(--primary)}.garame-player-name{font-size:12px;font-weight:600;white-space:nowrap}.garame-player-balance{font-size:11px;color:var(--accent);font-weight:500}.garame-player-cards{font-size:10px;color:var(--text-dim)}.garame-player-bet-badge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--success);display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff}.garame-game-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:16px 8px;width:100%;max-width:500px}.garame-phase-label{font-size:18px;font-weight:700;text-align:center}.garame-hint{font-size:14px;color:var(--text-dim);text-align:center}.garame-trick{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;min-height:100px;padding:12px}.garame-trick-entry{display:flex;flex-direction:column;align-items:center;gap:4px}.garame-trick-entry .garame-trick-name{font-size:11px;color:var(--text-dim);font-weight:500}.garame-trick-entry.winner .garame-trick-name{color:var(--accent);font-weight:700}.garame-hand{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;padding:8px;width:100%}.garame-card{width:60px;height:84px;border-radius:10px;background:#fff;border:2px solid #e0e0e0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:all .15s;position:relative;font-family:inherit}.garame-card:hover:not(:disabled){transform:translateY(-6px);box-shadow:0 6px 16px #0000004d}.garame-card:disabled,.garame-card.disabled{opacity:.4;cursor:default;pointer-events:none}.garame-card.highlight{border-color:var(--success);box-shadow:0 0 12px #2ecc7166}.garame-card.small{width:44px;height:62px}.garame-card-value{font-size:22px;font-weight:800;line-height:1}.garame-card.small .garame-card-value{font-size:16px}.garame-card-suit{font-size:18px;line-height:1}.garame-card.small .garame-card-suit{font-size:14px}.garame-card-back{background:var(--primary);border-color:var(--primary);cursor:default}.garame-card-back-pattern{font-size:24px;opacity:.6}.garame-card.small .garame-card-back-pattern{font-size:18px}.garame-bet-section{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.garame-bet-amount{font-size:36px;font-weight:800;color:var(--accent)}.garame-bet-players{display:flex;flex-direction:column;gap:8px;width:100%}.garame-bet-player{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-card);border-radius:10px;font-size:14px}.garame-bet-status{font-size:12px;padding:4px 10px;border-radius:12px;font-weight:600}.garame-bet-status.confirmed{background:#2ecc7133;color:var(--success)}.garame-bet-status.waiting{background:var(--bg-surface);color:var(--text-dim)}.garame-round-result{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;background:#ffd3691a;border-radius:var(--radius);width:100%;animation:fadeIn .3s ease-out}.garame-winner-name{font-size:28px;font-weight:800;color:var(--accent)}.garame-win-amount{font-size:18px;font-weight:600}.garame-trick-indicator{font-size:13px;color:var(--text-dim);font-weight:500}.garame-lead-suit{font-size:32px;text-align:center}.poker-page{justify-content:flex-start;padding-top:8px;gap:8px}.poker-info-bar{display:flex;gap:16px;justify-content:center;padding:4px 16px;font-size:13px;font-weight:600;color:var(--text-dim);width:100%;max-width:500px}.poker-phase-badge{padding:2px 10px;border-radius:10px;background:var(--bg-surface);font-size:11px;text-transform:uppercase;letter-spacing:.5px}.poker-table-container{position:relative;width:100%;max-width:500px;aspect-ratio:4 / 3;flex-shrink:0}.poker-table-felt{position:absolute;top:15%;left:12%;right:12%;bottom:15%;background:radial-gradient(ellipse at center,#1a6b3c,#145a30 60%,#0f4a26);border-radius:50%;border:4px solid #8b6914;box-shadow:0 0 0 6px #5a4510,0 0 0 8px #3a2e0a,0 8px 32px #00000080;display:flex;align-items:center;justify-content:center}.poker-table-center{display:flex;flex-direction:column;align-items:center;gap:6px}.poker-community{display:flex;gap:3px;justify-content:center}.poker-community-placeholder{width:48px;height:68px;border:2px dashed rgba(255,255,255,.15);border-radius:6px}.poker-community-placeholder.small{width:42px;height:60px}.poker-seat{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:2px;z-index:2;transition:opacity .3s}.poker-seat.folded{opacity:.3}.poker-seat-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;flex-shrink:0;position:relative;z-index:1}.poker-seat.me .poker-seat-avatar{box-shadow:0 0 0 2px var(--primary)}.poker-seat-turn-ring{position:absolute;top:-1px;left:50%;transform:translate(-50%);width:42px;height:42px;border-radius:50%;border:2px solid var(--accent);animation:turnPulse 1.2s ease-in-out infinite;z-index:0}@keyframes turnPulse{0%,to{box-shadow:0 0 6px #ffd36966}50%{box-shadow:0 0 14px #ffd369cc}}.poker-seat-info{display:flex;flex-direction:column;align-items:center;background:var(--bg-card);border-radius:8px;padding:2px 8px;gap:0;min-width:48px}.poker-seat-name{font-size:10px;font-weight:700;white-space:nowrap;max-width:60px;overflow:hidden;text-overflow:ellipsis}.poker-seat-chips{font-size:9px;color:var(--accent);font-weight:600}.poker-seat-role{position:absolute;top:-4px;right:-8px;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:800;z-index:3}.poker-seat-role.dealer{background:var(--accent);color:#1a1a2e}.poker-seat-role.sb{background:#3498db;color:#fff}.poker-seat-role.bb{background:#e74c3c;color:#fff}.poker-seat-bet{position:absolute;bottom:-16px;left:50%;transform:translate(-50%);z-index:2}.poker-seat-allin{font-size:8px;padding:1px 5px;border-radius:4px;background:#e74c3c4d;color:var(--danger);font-weight:800;letter-spacing:.5px}.poker-seat-cards{display:flex;gap:2px;margin-top:2px}.poker-card{width:58px;height:82px;border-radius:8px;background:#fff;border:2px solid #e0e0e0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;position:relative;font-family:inherit;flex-shrink:0;animation:fadeIn .3s ease-out}.poker-card.small{width:42px;height:60px}.poker-card-rank{font-size:22px;font-weight:800;line-height:1}.poker-card.small .poker-card-rank{font-size:16px}.poker-card-suit{font-size:22px;line-height:1}.poker-card.small .poker-card-suit{font-size:16px}.poker-card-back{background:var(--primary);border-color:var(--primary);color:#fff}.poker-card-back-pattern{font-size:24px;opacity:.6}.poker-card.small .poker-card-back-pattern{font-size:16px}.poker-my-hand{display:flex;flex-direction:column;align-items:center;gap:4px}.poker-hole-cards{display:flex;gap:8px;justify-content:center}.poker-hole-label{font-size:11px;color:var(--text-dim);text-align:center}.poker-actions{display:flex;flex-direction:column;gap:6px;width:100%;max-width:420px;padding:0 12px}.poker-actions-row{display:flex;gap:6px}.poker-actions-row .btn{flex:1}.poker-raise-row{display:flex;gap:6px;align-items:center}.poker-raise-input{flex:1;padding:8px 10px;border-radius:10px;border:2px solid var(--bg-surface);background:var(--bg-card);color:var(--text);font-size:15px;font-weight:600;text-align:center;font-family:inherit}.poker-raise-input:focus{outline:none;border-color:var(--primary)}.poker-raise-presets{display:flex;gap:4px;justify-content:center;flex-wrap:wrap}.poker-raise-preset{padding:3px 8px;border-radius:8px;background:var(--bg-surface);color:var(--text-dim);font-size:11px;font-weight:600;border:none;cursor:pointer;font-family:inherit}.poker-raise-preset:hover{background:var(--bg-hover);color:var(--text)}.poker-hint{font-size:13px;color:var(--text-dim);text-align:center}.poker-showdown{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px;background:#ffd3691a;border-radius:var(--radius);width:100%;max-width:420px;animation:fadeIn .3s ease-out}.poker-showdown-winner{display:flex;flex-direction:column;align-items:center;gap:4px}.poker-winner-name{font-size:20px;font-weight:800;color:var(--accent)}.poker-winner-hand{font-size:13px;color:var(--text-dim)}.poker-winner-amount{font-size:16px;font-weight:700}.poker-showdown-cards{display:flex;gap:3px;justify-content:center}.poker-sidepots{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.poker-sidepot{padding:2px 8px;border-radius:6px;background:#0000004d;font-size:10px;color:#ffffffb3}.poker-sidepot .amount{color:var(--accent);font-weight:600}.poker-dealing-intro{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;padding:24px;width:100%;max-width:500px}.poker-dealing-title{font-size:28px;font-weight:800;color:var(--accent);text-shadow:0 0 20px rgba(255,211,105,.3);animation:dealingPulse 1.5s ease-in-out infinite}@keyframes dealingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.03)}}.poker-dealing-roles{display:flex;gap:16px;justify-content:center}.poker-dealing-role{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 20px;background:var(--bg-card);border-radius:14px;animation:dealingSlideUp .5s ease-out backwards}.poker-dealing-role:nth-child(1){animation-delay:.2s}.poker-dealing-role:nth-child(2){animation-delay:.5s}.poker-dealing-role:nth-child(3){animation-delay:.8s}@keyframes dealingSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.poker-dealing-role-badge{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800}.poker-dealing-role-badge.dealer{background:var(--accent);color:#1a1a2e}.poker-dealing-role-badge.sb{background:#3498db;color:#fff}.poker-dealing-role-badge.bb{background:#e74c3c;color:#fff}.poker-dealing-role-label{font-size:11px;color:var(--text-dim);font-weight:500}.poker-dealing-role-name{font-size:14px;font-weight:700;white-space:nowrap}.poker-dealing-role-amount{font-size:16px;font-weight:800;color:var(--accent)}.poker-dealing-cards{display:flex;gap:12px;animation:dealingDeal .6s ease-out 1.2s backwards}@keyframes dealingDeal{0%{opacity:0;transform:scale(.5) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0)}}.poker-chip-pot{display:flex;flex-direction:column;align-items:center;gap:4px}.poker-chip-stacks{display:flex;gap:4px;justify-content:center;align-items:flex-end;height:30px}.poker-chip-stack{position:relative;width:18px}.poker-chip{position:absolute;width:18px;height:5px;border-radius:2px;left:0}.poker-chip-pot-amount{font-size:14px;font-weight:800;color:#ffd369;text-shadow:0 1px 4px rgba(0,0,0,.5)}.poker-chip-mini{display:flex;align-items:center;gap:3px;background:var(--bg-card);padding:1px 6px;border-radius:8px;white-space:nowrap}.poker-chip-mini-stacks{display:flex;gap:1px}.poker-chip-mini-dot{width:8px;height:8px;border-radius:50%}.poker-chip-mini-amount{font-size:9px;font-weight:700;color:var(--accent)}.poker-muck-controls{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-card);border-radius:var(--radius);width:100%;max-width:420px;animation:fadeIn .3s ease-out}.poker-muck-buttons{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.poker-muck-buttons .btn{font-size:12px;padding:6px 12px}.checkers-page{justify-content:center;gap:6px;padding:4px;max-width:100%}.checkers-header{display:flex;justify-content:space-between;align-items:center;width:100%;gap:8px}.checkers-player-tag{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);background:var(--bg-card);font-size:14px;font-weight:600;transition:all .2s;flex:1}.checkers-player-tag.active{background:var(--primary);color:#fff;box-shadow:0 0 12px #e9456066}.checkers-player-tag .dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--text-dim);flex-shrink:0}.checkers-player-tag .dot.white{background:beige;border-color:#ccc}.checkers-player-tag .dot.black{background:#333;border-color:#555}.checkers-board-wrapper{position:relative;width:100%;aspect-ratio:1;max-width:min(96vw,75vh);margin:0 auto;flex-shrink:1}.checkers-board{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:100%;height:100%;border-radius:var(--radius-sm);overflow:hidden;border:3px solid var(--bg-surface);box-shadow:0 4px 20px #0006}.checkers-cell{position:relative;display:flex;align-items:center;justify-content:center;cursor:default}.checkers-cell.light{background:#e8d5a8}.checkers-cell.dark{background:#b58863}.checkers-cell.highlight{background:#2ecc7159;cursor:pointer}.checkers-cell.highlight:after{content:"";width:30%;height:30%;border-radius:50%;background:var(--success);opacity:.7}.checkers-cell.capture-highlight{background:#e945604d;cursor:pointer}.checkers-cell.capture-highlight:after{content:"";width:30%;height:30%;border-radius:50%;background:var(--danger);opacity:.7}.checkers-cell.last-from,.checkers-cell.last-to{box-shadow:inset 0 0 0 2px var(--accent)}.checkers-piece{width:82%;height:82%;border-radius:50%;position:absolute;cursor:pointer;transition:transform .15s;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.checkers-piece:hover{transform:scale(1.08)}.checkers-piece.white{background:radial-gradient(circle at 35% 35%,#fff,#e8dcc8);border:3px solid #c9b896;box-shadow:0 2px 8px #0000004d,inset 0 -2px 4px #0000001a;color:#a08050}.checkers-piece.black{background:radial-gradient(circle at 35% 35%,#4a4a4a,#0a0a0a);border:3px solid #e74c3c;box-shadow:0 2px 8px #00000080,0 0 6px #e74c3c4d;color:#e74c3c}.checkers-crown{font-size:22px;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.checkers-crown.white{color:#fff;text-shadow:0 0 4px rgba(255,255,255,.8),0 1px 2px rgba(0,0,0,.3)}.checkers-crown.black{color:#111;text-shadow:0 0 4px rgba(0,0,0,.8),0 0 6px rgba(231,76,60,.4)}.checkers-piece.selected{transform:scale(1.12);box-shadow:0 0 14px var(--accent),0 2px 8px #0006}.checkers-piece.must-capture{animation:checkers-pulse 1s infinite}@keyframes checkers-pulse{0%,to{box-shadow:0 0 4px var(--danger)}50%{box-shadow:0 0 14px var(--danger)}}.checkers-status{text-align:center;font-size:15px;color:var(--text-dim);min-height:24px}.checkers-status strong{color:var(--text)}.checkers-ended{text-align:center;padding:24px 16px}.checkers-ended h2{font-size:24px;margin-bottom:8px;color:var(--accent)}.checkers-ended p{color:var(--text-dim);margin-bottom:16px}.checkers-score{display:flex;justify-content:center;gap:24px;margin-bottom:20px}.checkers-score-item{text-align:center}.checkers-score-item .count{font-size:28px;font-weight:700;color:var(--text)}.checkers-score-item .label{font-size:12px;color:var(--text-dim)}.chess-page{justify-content:center;gap:6px;padding:4px;max-width:100%}.chess-header{display:flex;justify-content:space-between;align-items:center;width:100%;gap:8px}.chess-player-tag{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);background:var(--bg-card);font-size:14px;font-weight:600;transition:all .2s;flex:1}.chess-player-tag.active{background:var(--primary);color:#fff;box-shadow:0 0 12px #e9456066}.chess-player-tag .dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--text-dim);flex-shrink:0}.chess-player-tag .dot.white{background:beige;border-color:#ccc}.chess-player-tag .dot.black{background:#333;border-color:#555}.chess-captured{display:flex;flex-wrap:wrap;gap:1px;font-size:14px;min-height:20px;margin-left:4px}.chess-status{text-align:center;font-size:15px;color:var(--text-dim);min-height:24px}.chess-status strong{color:var(--text)}.chess-board-wrapper{position:relative;width:100%;aspect-ratio:1;max-width:min(96vw,75vh);margin:0 auto;flex-shrink:1}.chess-board{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:100%;height:100%;border-radius:var(--radius-sm);overflow:hidden;border:3px solid var(--bg-surface);box-shadow:0 4px 20px #0006}.chess-cell{position:relative;display:flex;align-items:center;justify-content:center;cursor:default;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.chess-cell.light{background:#e8d5a8}.chess-cell.dark{background:#b58863}.chess-cell.selected{background:#ffff648c!important}.chess-cell.highlight{cursor:pointer}.chess-cell.highlight:after{content:"";position:absolute;width:28%;height:28%;border-radius:50%;background:#0000002e;pointer-events:none;z-index:2}.chess-cell.capture-highlight{cursor:pointer}.chess-cell.capture-highlight:after{content:"";position:absolute;width:90%;height:90%;border-radius:50%;border:4px solid rgba(0,0,0,.18);background:transparent;pointer-events:none;z-index:2;box-sizing:border-box}.chess-cell.last-from{background:#9bc70069!important}.chess-cell.last-to{background:#9bc70082!important}.chess-cell.in-check{background:radial-gradient(ellipse at center,rgba(255,0,0,.6),rgba(200,0,0,.2) 70%,transparent)!important}.chess-piece{position:absolute;width:85%;height:85%;display:flex;align-items:center;justify-content:center;font-size:min(10vw,8vh,56px);cursor:pointer;transition:transform .12s;z-index:1;line-height:1;filter:drop-shadow(1px 2px 2px rgba(0,0,0,.35))}.chess-piece.white{color:#fff;text-shadow:0 0 2px rgba(0,0,0,.6);filter:drop-shadow(1px 2px 2px rgba(0,0,0,.35))}.chess-piece.black{color:#222;text-shadow:0 0 2px rgba(255,255,255,.3);filter:drop-shadow(1px 2px 2px rgba(0,0,0,.35))}.chess-piece:hover{transform:scale(1.08)}.chess-piece.selected{transform:scale(1.12)}.chess-promotion-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.chess-promotion-modal{background:var(--bg-card);border-radius:var(--radius);padding:16px;text-align:center}.chess-promotion-modal h3{margin-bottom:12px;font-size:16px;color:var(--text)}.chess-promotion-choices{display:flex;gap:8px;justify-content:center}.chess-promotion-btn{width:60px;height:60px;font-size:40px;background:var(--bg-surface);border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1}.chess-promotion-btn:hover{border-color:var(--primary);background:var(--bg-card);transform:scale(1.1)}.chess-coord-col{position:absolute;bottom:1px;right:3px;font-size:10px;font-weight:600;pointer-events:none;z-index:3;opacity:.6}.chess-cell.light .chess-coord-col,.chess-cell.light .chess-coord-row{color:#b58863}.chess-cell.dark .chess-coord-col,.chess-cell.dark .chess-coord-row{color:#e8d5a8}.chess-coord-row{position:absolute;top:1px;left:3px;font-size:10px;font-weight:600;pointer-events:none;z-index:3;opacity:.6}.chess-ended{text-align:center;padding:24px 16px}.chess-ended h2{font-size:24px;margin-bottom:8px;color:var(--accent)}.chess-ended p{color:var(--text-dim);margin-bottom:16px}.chess-ended-captures{display:flex;justify-content:center;gap:24px;margin-bottom:20px}.chess-ended-captures .capture-group{text-align:center}.chess-ended-captures .pieces{font-size:20px;min-height:28px}.chess-ended-captures .label{font-size:12px;color:var(--text-dim);margin-top:4px}*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f0f1a;--bg-card: #1a1a2e;--bg-surface: #232342;--bg-hover: #2d2d52;--primary: #e94560;--primary-glow: rgba(233, 69, 96, .3);--secondary: #533483;--accent: #ffd369;--text: #eaeaea;--text-dim: #8888aa;--success: #2ecc71;--danger: #e74c3c;--radius: 16px;--radius-sm: 10px}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Inter,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}#root{display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;outline:none;-webkit-tap-highlight-color:transparent}button:active{transform:scale(.96)}input{font-family:inherit;outline:none;border:none}.page{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:safe center;padding:24px;gap:24px;overflow-y:auto}@media (max-width: 600px){.page{padding:12px 8px;gap:16px}}.card{background:var(--bg-card);border-radius:var(--radius);padding:28px 24px;width:100%;max-width:400px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:var(--radius-sm);font-size:16px;font-weight:600;transition:background .15s,transform .1s;width:100%}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 20px var(--primary-glow)}.btn-primary:hover{background:#d63b54}.btn-primary:disabled{opacity:.4;pointer-events:none}.btn-secondary{background:var(--bg-surface);color:var(--text)}.btn-secondary:hover{background:var(--bg-hover)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:10px 18px;font-size:14px;border-radius:8px}.btn-ghost{background:transparent;color:var(--text-dim);font-size:14px;padding:10px}.input{width:100%;padding:14px 18px;background:var(--bg-surface);color:var(--text);border-radius:var(--radius-sm);font-size:16px;border:2px solid transparent;transition:border-color .2s}.input:focus{border-color:var(--primary)}.input::placeholder{color:var(--text-dim)}.title{font-size:28px;font-weight:800;text-align:center}.subtitle{font-size:15px;color:var(--text-dim);text-align:center}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;background:var(--bg-surface);color:var(--text-dim)}.badge-active{background:var(--primary);color:#fff}.badge-public{background:var(--success);color:#fff}.badge-private{background:var(--danger);color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes homeDiceRoll{0%{transform:translateY(-10px) rotate(-14deg)}25%{transform:translateY(2px) rotate(10deg)}50%{transform:translateY(-4px) rotate(-6deg)}75%{transform:translateY(1px) rotate(4deg)}to{transform:translateY(0) rotate(0)}}.fade-in{animation:fadeIn .3s ease-out}.pulse{animation:pulse 1.5s infinite}.home-stats{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px 24px}.home-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.home-stat-value{font-size:24px;font-weight:800;color:var(--accent)}.home-stat-label{font-size:11px;color:var(--text-dim);font-weight:500;white-space:nowrap}.home-stat-sep{width:1px;height:32px;background:var(--bg-surface)}.home-dice{font-size:48px;margin-bottom:8px;display:inline-block;line-height:1}.home-dice.rolling{animation:homeDiceRoll .9s ease-out}.public-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;padding:0 4px}.public-toggle-track{position:relative;width:40px;height:22px;border-radius:11px;background:var(--danger);transition:background .2s;flex-shrink:0}.public-toggle-track.active{background:var(--success)}.public-toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s}.public-toggle-track.active .public-toggle-thumb{transform:translate(18px)}.public-table-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-surface);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;width:100%;text-align:left}.public-table-row:hover{background:var(--bg-hover)}.public-table-info{display:flex;flex-direction:column;gap:2px}.public-table-leader{font-size:14px;font-weight:600;color:var(--text)}.public-table-code{font-size:11px;color:var(--text-dim);font-family:monospace}.btn-leave-game{position:fixed;bottom:12px;left:12px;z-index:50;width:auto;background:transparent;color:var(--text-dim);font-size:13px;padding:8px 12px;opacity:.5;transition:opacity .2s}.btn-leave-game:hover,.btn-leave-game:active{opacity:1;color:var(--text)}.global-donate{position:fixed;bottom:10px;right:12px;font-size:12px;color:var(--text-dim);text-decoration:none;opacity:.5;transition:opacity .2s;z-index:50}.global-donate:hover{opacity:1;color:var(--text)}.seats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;max-width:320px}.seat-cell{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:transform .15s,box-shadow .15s}.seat-cell.empty{background:var(--bg-surface);border:2px dashed var(--bg-hover)}.seat-cell.empty .seat-number{font-size:16px;font-weight:700;color:var(--text-dim);opacity:.3}.seat-cell.occupied{cursor:pointer;border:2px solid transparent}.seat-cell.occupied.me{border-color:var(--accent)}.seat-cell.occupied.selected{border-color:var(--accent);box-shadow:0 0 12px var(--accent);transform:scale(1.05)}.seat-cell.center{background:var(--bg-surface);font-size:32px;color:var(--text-dim);opacity:.5;border:none}.seat-crown{position:absolute;top:2px;right:4px;font-size:12px;line-height:1}.seat-initial{font-size:22px;font-weight:800;color:#fff;line-height:1;text-shadow:0 1px 3px rgba(0,0,0,.3)}.seat-name{font-size:11px;font-weight:600;color:#ffffffd9;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 4px}.seat-name.me{color:var(--accent)}.donate-endgame{display:inline-block;margin-top:12px;font-size:13px;color:var(--text-dim);text-decoration:none;transition:color .2s}.donate-endgame:hover{color:var(--accent)}
