*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f1a;--surface: #1a1a2e;--surface2: #22223a;--accent: #e94560;--text: #f0f0f0;--muted: #888;--radius: 12px;--card-w: 58px;--card-h: 86px}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Nunito,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;user-select:none;-webkit-user-select:none}.app{height:100dvh;width:100%;display:flex;flex-direction:column;position:relative;overflow:hidden}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;padding:10px 24px;border-radius:30px;font-weight:800;font-size:.95rem;animation:slideDown .3s ease}.toast.error{background:#e74c3c;color:#fff}.toast.uno{background:#f39c12;color:#000;font-size:1.2rem}.toast.reconnecting{background:#2c3e50;color:#90e0ef;border:1px solid #0096c7}.rejoin-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.rejoin-box{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;background:var(--surface2);border-radius:24px;padding:40px 48px;border:2px solid #333;max-width:320px;width:100%}.rejoin-spinner{font-size:3rem;animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.92)}}.rejoin-title{font-size:1.1rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.rejoin-code{font-size:3rem;font-weight:900;letter-spacing:.3em;background:linear-gradient(135deg,#e74c3c,#f39c12);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.rejoin-hint{font-size:.85rem;color:var(--muted)}.rejoin-cancel{margin-top:8px;font-size:.85rem}@keyframes slideDown{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.btn{border:none;border-radius:30px;padding:12px 28px;font-family:Nunito,sans-serif;font-weight:800;font-size:1rem;cursor:pointer;transition:transform .1s,opacity .1s;touch-action:manipulation}.btn:active{transform:scale(.95)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--surface2);color:var(--text);border:2px solid #444}.btn-ghost{background:transparent;color:var(--muted)}.btn-large{padding:16px 40px;font-size:1.15rem;width:100%}.btn-uno{background:linear-gradient(135deg,#f39c12,#e74c3c);color:#fff;font-size:1.1rem;padding:10px 24px}.lobby{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;padding:24px}.lobby-header{text-align:center}.logo{font-size:5rem;font-weight:900;letter-spacing:.15em;background:linear-gradient(135deg,#e74c3c,#f39c12,#27ae60,#2980b9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.tagline{color:var(--muted);font-size:1rem;margin-top:8px;font-weight:700}.hub-player-name{display:flex;align-items:center;justify-content:center}.hub-name-display{display:flex;align-items:center;gap:8px;background:var(--surface2);border-radius:999px;padding:6px 14px 6px 16px}.hub-name-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.hub-name-value{font-size:1rem;font-weight:800;color:var(--text)}.hub-name-edit-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:2px 4px;border-radius:6px;line-height:1;opacity:.7;transition:opacity .15s}.hub-name-edit-btn:hover{opacity:1}.hub-name-edit{display:flex;align-items:center;gap:8px;width:100%;max-width:320px}.hub-name-input{flex:1;background:var(--surface2);border:2px solid #555;border-radius:var(--radius);color:var(--text);font-family:Nunito,sans-serif;font-size:1rem;font-weight:700;padding:8px 12px;min-width:0}.hub-name-input:focus{outline:none;border-color:var(--accent)}.hub-name-set-btn{font-size:.9rem}.lobby-buttons{display:flex;flex-direction:column;gap:16px;width:100%;max-width:320px}.lobby-form{display:flex;flex-direction:column;gap:20px;width:100%;max-width:320px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.form-group input{background:var(--surface2);border:2px solid #444;border-radius:var(--radius);color:var(--text);font-family:Nunito,sans-serif;font-size:1.1rem;font-weight:700;padding:14px 16px;outline:none;transition:border-color .2s}.form-group input:focus{border-color:var(--accent)}.form-actions{display:flex;gap:12px}.form-actions .btn-ghost{flex:0 0 auto}.form-actions .btn-primary{flex:1}.waiting-room{flex:1;display:flex;flex-direction:column;align-items:center;gap:24px;padding:24px;overflow-y:auto}.room-code-box{background:var(--surface2);border-radius:16px;padding:20px 32px;text-align:center;border:2px solid #333;cursor:pointer;transition:border-color .2s}.room-code-box:active{border-color:var(--accent)}.room-code-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;color:var(--muted)}.room-code{font-size:3rem;font-weight:900;letter-spacing:.3em;background:linear-gradient(135deg,#e74c3c,#f39c12);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.room-code-hint{font-size:.75rem;color:var(--muted);margin-top:4px}.player-list{width:100%;max-width:360px}.player-list h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:12px}.player-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface2);border-radius:12px;margin-bottom:8px;border:2px solid transparent}.player-row.empty{opacity:.3}.player-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;flex-shrink:0}.player-row.empty .player-avatar{background:#333}.player-name{font-weight:700;flex:1}.player-rename-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:2px 4px;opacity:.5;transition:opacity .15s;line-height:1;flex-shrink:0}.player-rename-btn:hover{opacity:1}.player-row-editing{border-color:var(--accent);gap:8px}.player-rename-input{flex:1;min-width:0;background:var(--surface);border:2px solid var(--accent);border-radius:8px;color:var(--text);font-family:Nunito,sans-serif;font-size:1rem;font-weight:700;padding:4px 10px}.player-rename-input:focus{outline:none}.player-rename-save,.player-rename-cancel{padding:4px 10px;font-size:.9rem;flex-shrink:0}.host-badge{background:#f39c12;color:#000;font-size:.7rem;font-weight:900;padding:3px 10px;border-radius:20px;text-transform:uppercase}.waiting-msg{color:var(--muted);font-weight:700;text-align:center}.game-picker{width:100%;max-width:360px}.game-picker-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:10px;text-align:center}.game-picker-options{display:flex;gap:10px}.game-pick-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:var(--surface2);border:2px solid #333;border-radius:14px;cursor:pointer;color:var(--text);transition:border-color .15s,background .15s;font-family:inherit}.game-pick-btn:hover:not(:disabled){border-color:var(--accent)}.game-pick-btn:disabled{cursor:default}.game-pick-btn.game-pick-selected{border-color:var(--accent);background:#e539351f}.game-pick-icon{font-size:1.5rem;line-height:1}.game-pick-name{font-size:.65rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.game-board{flex:1;display:flex;flex-direction:column;height:100dvh;overflow:hidden;position:relative}.leave-game-btn{position:absolute;top:8px;right:10px;z-index:10;font-size:.75rem;padding:4px 10px;opacity:.7}.leave-game-btn:hover{opacity:1}.opponents{display:flex;flex-direction:column;gap:4px;padding:8px 12px;background:var(--surface);border-bottom:1px solid #222;flex-shrink:0}.opponent{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:10px;border:2px solid transparent;transition:border-color .3s}.opponent.active-player{border-color:#f39c12;background:#f39c1214}.opponent-avatar{width:30px;height:30px;border-radius:50%;background:#3a3a5c;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.85rem;flex-shrink:0}.opponent-name{font-weight:700;font-size:.9rem;flex:1;display:flex;align-items:center;gap:5px}.you-badge{font-size:.6rem;font-weight:800;color:#f6ad55;background:#f6ad5526;border:1px solid rgba(246,173,85,.4);border-radius:4px;padding:1px 5px;letter-spacing:.05em;flex-shrink:0}.card-count{font-size:.85rem;color:var(--muted)}.turn-indicator{color:#f39c12;font-size:.8rem}.dir-indicator{color:#63b3ed;font-size:1rem;font-weight:700;line-height:1}.center-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:12px;min-height:0}.last-action{font-size:.8rem;font-weight:700;color:var(--muted);text-align:center;height:20px}.piles{display:flex;align-items:center;gap:24px}.pile-area{display:flex;flex-direction:column;align-items:center;gap:6px}.pile-label{font-size:.75rem;font-weight:700;color:var(--muted)}.color-indicator{width:14px;height:14px;border-radius:50%;border:3px solid;position:absolute;top:-4px;right:-4px}.pile-area:last-child{position:relative}.pile-glow{box-shadow:0 0 20px #ffc83280}.action-buttons{display:flex;gap:12px;align-items:center}.turn-msg{font-size:.85rem;font-weight:700;color:var(--muted)}.my-hand-area{background:var(--surface);border-top:1px solid #222;padding:8px 0 12px;flex-shrink:0}.hand-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:0 16px;margin-bottom:8px}.hand-scroll{display:flex;gap:6px;overflow-x:auto;padding:4px 16px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.hand-scroll::-webkit-scrollbar{display:none}.hand-card-wrapper{flex-shrink:0;display:flex;flex-direction:column;align-items:center}.card{width:var(--card-w);height:var(--card-h);border-radius:10px;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 3px 8px #0006;border:2px solid rgba(255,255,255,.15);touch-action:manipulation;flex-shrink:0}.card:active{transform:scale(.94)}.card-selected{transform:translateY(-10px);box-shadow:0 8px 20px #00000080}.card-disabled{opacity:.45;cursor:default}.card-disabled:active{transform:none}.card-small{width:44px;height:66px;font-size:.7rem}.card-back{background:#1a1a4e;border:2px solid #2a2a6e;cursor:pointer}.card-back-text{font-size:2rem;font-weight:900;background:linear-gradient(135deg,#e74c3c,#f39c12,#27ae60,#2980b9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pile-card{width:var(--card-w);height:var(--card-h)}.card-corner{position:absolute;font-size:.65rem;font-weight:900;color:#ffffffe6;line-height:1}.card-tl{top:5px;left:6px}.card-br{bottom:5px;right:6px;transform:rotate(180deg)}.card-center{font-size:1.6rem;font-weight:900;color:#fffffff2;text-shadow:0 1px 3px rgba(0,0,0,.3)}.color-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:500}.color-picker{background:var(--surface);border-radius:20px;padding:28px;text-align:center;border:2px solid #333}.color-picker h3{font-size:1.1rem;font-weight:800;margin-bottom:20px}.color-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.color-btn{width:100px;height:100px;border:none;border-radius:16px;font-family:Nunito,sans-serif;font-weight:900;font-size:.95rem;color:#fffffff2;cursor:pointer;transition:transform .1s;touch-action:manipulation;box-shadow:0 4px 12px #0000004d}.color-btn:active{transform:scale(.92)}.game-over-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:600}.game-over-box{background:var(--surface);border-radius:24px;padding:40px 32px;text-align:center;border:2px solid #333;display:flex;flex-direction:column;gap:16px;width:90%;max-width:340px}.game-over-title{font-size:2rem;font-weight:900}.game-over-winner{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#e74c3c,#f39c12);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.player-disconnected{opacity:.6;border-color:#555!important;background:#50505014!important}.disconnected-badge{font-size:.65rem;font-weight:800;color:#90e0ef;letter-spacing:.03em;animation:dc-pulse 1.4s ease-in-out infinite;white-space:nowrap}.disconnected-turn-msg{color:#90e0ef;font-style:italic;animation:dc-pulse 1.4s ease-in-out infinite}@keyframes dc-pulse{0%,to{opacity:1}50%{opacity:.4}}.hub{flex:1;display:flex;flex-direction:column;align-items:center;gap:28px;padding:32px 20px 24px;overflow-y:auto}.hub-header{text-align:center}.hub-title{font-size:2.8rem;font-weight:900;letter-spacing:.2em;color:var(--text)}.hub-subtitle{color:var(--muted);font-size:1rem;font-weight:700;margin-top:6px}.hub-games{display:flex;flex-direction:column;gap:16px;width:100%;max-width:420px}.game-tile{display:flex;flex-direction:column;background:var(--surface);border:2px solid #333;border-radius:20px;overflow:hidden;cursor:pointer;text-align:left;transition:transform .15s,border-color .2s,box-shadow .2s;touch-action:manipulation;padding:0;font-family:Nunito,sans-serif;color:var(--text)}.game-tile:active{transform:scale(.97)}.game-tile:hover{border-color:var(--tile-accent, var(--accent));box-shadow:0 0 24px color-mix(in srgb,var(--tile-accent, var(--accent)) 30%,transparent)}.game-tile-icon{width:100%;height:80px;display:flex;align-items:center;justify-content:center}.game-tile-emoji{font-size:2.8rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}.game-tile-body{padding:14px 20px 8px;flex:1}.game-tile-name{font-size:1.8rem;font-weight:900;letter-spacing:.1em;line-height:1;margin-bottom:4px}.game-tile-tagline{font-size:.85rem;font-weight:700;color:var(--muted);margin-bottom:6px}.game-tile-desc{font-size:.8rem;color:#aaa;line-height:1.4}.game-tile-play{padding:10px 20px 14px;font-weight:900;font-size:.9rem;color:var(--tile-accent, var(--accent));letter-spacing:.05em}.hub-footer{color:#555;font-size:.8rem;font-weight:700}.lobby-back-btn{position:absolute;top:16px;left:16px;font-size:.9rem}.lobby-game-icon{font-size:3rem;margin-bottom:8px}.fish-card{border:2px solid rgba(255,255,255,.2)}.fish-card-back{background:linear-gradient(160deg,#0d3b5e,#071e30);border:2px solid #1a5a8a;cursor:default}.fish-back-text{font-size:1.8rem}.fish-card-requested{border:2px solid #f5c842!important;cursor:pointer!important;animation:fish-request-pulse .9s ease-in-out infinite;transform:translateY(-6px);box-shadow:0 0 18px 4px #f5c842b3!important}.fish-card-requested:active{transform:translateY(-2px) scale(.95)}.card-wrapper-requested{animation:wrapper-bounce .9s ease-in-out infinite}@keyframes fish-request-pulse{0%,to{box-shadow:0 0 14px 3px #f5c84299}50%{box-shadow:0 0 28px 8px #f5c842f2}}@keyframes wrapper-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.gofish-board{background:linear-gradient(180deg,#071e30,#0d2840 40%,#0f172a)}.gofish-opponents{background:#00285099;border-bottom:1px solid #1a3a5a}.gofish-opponent{border:2px solid transparent}.gofish-opponent.active-player{border-color:#00b4d8;background:#00b4d814}.gofish-hand-count{font-size:.8rem;color:var(--muted);margin-right:4px}.gofish-books-mini{display:flex;align-items:center;gap:3px;flex-wrap:wrap}.book-pip{width:10px;height:10px;border-radius:50%;display:inline-block;border:1px solid rgba(255,255,255,.3)}.book-pip-more{font-size:.65rem;color:var(--muted)}.gofish-book-count{font-size:.75rem;color:#48cae4;font-weight:800;margin-left:2px}.gofish-center{background:transparent;gap:10px}.gofish-last-action{font-size:.82rem;font-weight:700;color:#90e0ef;text-align:center;min-height:20px;padding:0 12px}.gofish-pond{display:flex;align-items:center;gap:20px}.gofish-pond-card{display:flex;flex-direction:column;align-items:center;gap:6px}.gofish-score-panel{background:#00000059;border-radius:14px;padding:12px 16px;min-width:110px;border:1px solid #1a3a5a}.gofish-score-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;font-weight:800;color:#48cae4;margin-bottom:8px}.gofish-score-row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:.82rem;font-weight:700;margin-bottom:4px}.gofish-score-name{color:var(--text)}.gofish-score-val{color:#48cae4;font-weight:900}.gofish-score-total{margin-top:6px;font-size:.7rem;color:var(--muted);text-align:right}.my-books{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:center;padding:0 12px}.my-books-label{font-size:.7rem;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.my-book-tag{font-size:.6rem;font-weight:900;color:#ffffffe6;padding:2px 7px;border-radius:20px;letter-spacing:.05em}.gofish-ask-area{display:flex;flex-direction:column;align-items:center;gap:8px}.gofish-ask-prompt{display:flex;flex-direction:column;align-items:center;gap:10px;background:#0064a040;border:1px solid #0096c7;border-radius:14px;padding:12px 16px}.gofish-ask-label{font-size:.88rem;font-weight:700;color:#90e0ef}.gofish-ask-label strong{color:#fff;text-transform:capitalize}.gofish-opponent-btns{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.gofish-ask-btn{padding:8px 16px;font-size:.88rem;background:#0096c7}.gofish-turn-hint{color:#48cae4;font-weight:700;font-size:.88rem}.gofish-gameover{border-color:#0096c7}.being-asked{border-color:#f5c842!important;background:#f5c84214!important;animation:being-asked-glow 1s ease-in-out infinite}@keyframes being-asked-glow{0%,to{box-shadow:none}50%{box-shadow:0 0 12px #f5c84266}}.being-asked-badge{font-size:.65rem;font-weight:800;color:#f5c842;letter-spacing:.04em;animation:being-asked-glow 1s ease-in-out infinite}.gofish-being-asked{display:flex;flex-direction:column;align-items:center;gap:10px;background:#f5c8421a;border:2px solid #f5c842;border-radius:16px;padding:12px 16px;animation:being-asked-glow 1s ease-in-out infinite}.gofish-asked-prompt{display:flex;align-items:center;gap:12px}.gofish-fish-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;font-size:.7rem;font-weight:900;color:#fffffff2;flex-shrink:0;letter-spacing:.04em}.gofish-asked-title{font-size:.9rem;font-weight:700;color:#fff;line-height:1.3}.gofish-asked-title strong{color:#f5c842}.gofish-asked-hint{font-size:.75rem;color:#f5c842;font-weight:700;margin-top:3px}.gofish-asked-hint-none{color:#90e0ef}.gofish-gofish-btn{background:#0096c7;padding:10px 24px;font-size:1rem}.gofish-waiting-msg{font-size:.88rem;font-weight:700;color:#90e0ef;text-align:center;padding:10px 16px;background:#0064a033;border:1px solid #0096c7;border-radius:12px}.gofish-spinner{margin-right:6px;display:inline-block;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gofish-final-scores{background:#0000004d;border-radius:12px;padding:12px 16px;width:100%;display:flex;flex-direction:column;gap:6px}.op-card{width:82px;height:118px;border-radius:10px;display:flex;flex-direction:column;align-items:center;padding:5px 4px 4px;position:relative;cursor:default;border:2px solid rgba(255,255,255,.12);box-shadow:0 2px 8px #00000080;flex-shrink:0;-webkit-user-select:none;user-select:none;transition:transform .15s,box-shadow .15s}.op-card-clickable{cursor:pointer}.op-card-clickable:hover{transform:translateY(-5px);box-shadow:0 8px 18px #00000080;border-color:#ffffff4d}.op-card-back{background:#111827;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:2px dashed rgba(255,255,255,.15);cursor:pointer}.op-back-icon{font-size:1.6rem;opacity:.5}.op-back-q{font-size:2rem;font-weight:900;color:#ffffff59}.op-card-name{font-size:.38rem;font-weight:800;color:#ffffffd9;text-transform:uppercase;letter-spacing:.06em;text-align:center;width:100%;line-height:1.2}.op-card-svg{flex:1;width:100%;display:flex;align-items:center;justify-content:center;padding:2px 2px 0}.op-card-svg svg{width:100%;height:auto;max-height:88px}.op-card-selected{transform:translateY(-7px);box-shadow:0 10px 22px #ffffff40;border-color:#fff9}.op-card-disabled{opacity:.82}.op-card-old-phone{border-color:#e53e3e;box-shadow:0 0 14px #e53e3e8c,0 2px 8px #00000080;animation:op-danger-pulse 2s ease-in-out infinite}@keyframes op-danger-pulse{0%,to{box-shadow:0 0 12px #e53e3e80,0 2px 8px #0006}50%{box-shadow:0 0 24px #e53e3ed9,0 4px 14px #00000080}}.op-opponents{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.op-source-player{border-color:#f6ad55!important;box-shadow:0 0 12px #f6ad5573}.op-player-done{opacity:.55}.op-done-badge{font-size:.68rem;color:#68d391;font-weight:700}.op-hand-count{font-size:.78rem;color:#ffffffa6}.op-offering-badge{font-size:.72rem;color:#f6ad55;animation:pulse 1.6s ease-in-out infinite}.op-draw-area{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 10px;background:#ffffff0a;border-radius:12px;border:1px solid rgba(255,255,255,.08);width:100%}.op-draw-prompt{font-size:.88rem;color:#ffffffd9;text-align:center}.op-facedown-cards{display:flex;gap:5px;flex-wrap:wrap;justify-content:center}.op-facedown-slot{cursor:pointer}.op-waiting-msg{display:flex;align-items:center;gap:8px;font-size:.88rem;color:#ffffffbf;padding:10px 14px;background:#ffffff0a;border-radius:8px}.op-spinner{display:inline-block;animation:op-spin 1.2s linear infinite}@keyframes op-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.op-safe-msg{color:#68d391;font-size:.95rem;font-weight:600;text-align:center;padding:14px}.op-gameover{max-width:340px}.op-loser-announce{font-size:1rem;color:#ffffffd9;text-align:center;margin:8px 0 14px;line-height:1.5}.op-loser-name{color:#fc8181;font-weight:800;font-size:1.2rem}.op-final-scores{display:flex;flex-direction:column;gap:6px;width:100%;margin-bottom:16px}.op-score-row{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;background:#ffffff0d;border-radius:6px;font-size:.88rem}@media (max-height: 700px){:root{--card-h: 72px;--card-w: 48px}.card-center{font-size:1.2rem}.opponent{padding:4px 8px}.opponents{gap:2px;padding:6px 10px}}@media (min-width: 600px){:root{--card-w: 70px;--card-h: 100px}.card-center{font-size:2rem}.card-corner{font-size:.8rem}}.domino-tile{display:inline-flex;align-items:center;background:#f5f0e8;border:2px solid #2d2d2d;border-radius:6px;padding:4px;gap:0;cursor:pointer;flex-shrink:0;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;-webkit-user-select:none;user-select:none}.domino-tile .domino-half{display:flex;align-items:center;justify-content:center;width:28px;height:28px}.domino-tile .domino-divider{width:1.5px;height:22px;background:#2d2d2d;margin:0 2px;flex-shrink:0}.domino-pip-grid{display:grid;grid-template-columns:repeat(3,7px);grid-template-rows:repeat(3,7px);gap:0}.domino-pip{width:7px;height:7px;border-radius:50%}.domino-pip-filled{background:#1a1a2e}.domino-tile-sm{display:inline-flex;align-items:center;background:#f5f0e8;border:1.5px solid #2d2d2d;border-radius:3px;padding:3px;gap:0;flex-shrink:0}.domino-tile-sm .domino-half{display:flex;align-items:center;justify-content:center;width:18px;height:18px}.domino-tile-sm .domino-divider{width:1px;height:13px;background:#2d2d2d;margin:0 1px;flex-shrink:0}.domino-pip-grid-sm{grid-template-columns:repeat(3,4px);grid-template-rows:repeat(3,4px)}.domino-tile-sm .domino-pip{width:4px;height:4px}.domino-tile-vertical{flex-direction:column}.domino-tile-vertical .domino-divider{width:22px;height:1.5px;margin:0}.domino-tile-sm.domino-tile-vertical .domino-divider{width:13px;height:1px;margin:0}.domino-tile-selected{transform:translateY(-7px);box-shadow:0 8px 20px #a855f78c;border-color:#a855f7}.domino-tile-unplayable{opacity:.35;cursor:not-allowed}.cc-board{overflow:hidden}.cc-opponents{display:flex;gap:8px;flex-wrap:wrap;padding:8px 12px;background:var(--surface);border-bottom:1px solid rgba(255,255,255,.07)}.cc-opponent{display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 10px;border-radius:var(--radius);background:var(--surface2);border:1px solid rgba(255,255,255,.07);min-width:68px;transition:border-color .2s,box-shadow .2s}.cc-active-player{border-color:#8b5cf6!important;box-shadow:0 0 10px #8b5cf666}.cc-center{overflow:hidden;padding:10px 12px;gap:10px}.cc-last-action{font-size:.85rem;color:#fffc;text-align:center;padding:6px 14px;background:#ffffff0d;border-radius:20px;width:100%;line-height:1.4}.cc-chain-area{display:flex;align-items:center;gap:6px;width:100%;min-height:52px}.cc-end-label{display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0}.cc-end-pip{width:36px;height:36px;background:var(--surface2);border:2px solid #7c3aed;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800;color:#c084fc}.cc-end-text{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.cc-chain-scroll{flex:1;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding:6px 2px}.cc-chain-scroll::-webkit-scrollbar{height:3px}.cc-chain-scroll::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:2px}.cc-chain-tiles{display:flex;align-items:center;min-height:28px}.cc-chain-entry{display:flex;align-items:center}.cc-chain-connector{width:5px;height:1.5px;background:#ffffff38;flex-shrink:0}.cc-chain-empty{font-size:.78rem;color:var(--muted);font-style:italic;white-space:nowrap;padding:4px 8px}.cc-boneyard-row{display:flex;align-items:center;justify-content:center;padding:6px 14px;background:#ffffff0a;border-radius:8px;border:1px solid rgba(255,255,255,.07);width:100%}.cc-boneyard-info{font-size:.85rem;color:#ffffffb3}.cc-action-area{width:100%;display:flex;align-items:center;justify-content:center;min-height:46px}.cc-turn-hint{font-style:italic}.cc-side-chooser{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.cc-side-label{font-size:.82rem;color:#ffffffbf}.cc-side-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.cc-side-btn{min-width:130px}.cc-hand-area{background:var(--surface);border-top:1px solid rgba(255,255,255,.07);padding:10px 12px;flex-shrink:0}.cc-hand-label{font-size:.75rem;color:var(--muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.cc-hand-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;align-items:flex-end;-webkit-overflow-scrolling:touch}.cc-hand-scroll::-webkit-scrollbar{height:3px}.cc-hand-scroll::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:2px}.cc-gameover{max-width:360px}.cc-final-scores{display:flex;flex-direction:column;gap:6px;width:100%;margin-bottom:18px}.cc-score-row{display:flex;justify-content:space-between;align-items:center;padding:7px 14px;background:#ffffff0d;border-radius:8px;font-size:.88rem}.cc-score-row-winner{background:#8b5cf638;border:1px solid #8b5cf6;font-weight:700}.cc-pip-count{color:#c084fc;font-weight:700}.forgetter-board{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 8px 20px;max-height:100dvh;overflow-y:auto}.forgetter-players{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;width:100%}.forgetter-player{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;background:var(--surface2);border:2px solid transparent;font-size:.85rem}.forgetter-player.forgetter-active{border-color:#10b981}.forgetter-score-badge{font-size:.78rem;color:#10b981;font-weight:700}.forgetter-last-action{font-size:.88rem;color:var(--muted);text-align:center;min-height:1.4em}.forgetter-turn-hint{color:#10b981!important;font-weight:700}.forgetter-grid{display:grid;grid-template-columns:repeat(var(--grid-cols, 6),1fr);gap:7px;width:100%;max-width:500px}@media (max-width: 480px){.forgetter-grid{grid-template-columns:repeat(4,1fr);gap:5px}}.forgetter-card{aspect-ratio:2 / 3;perspective:800px;cursor:default}.forgetter-card.clickable{cursor:pointer}.forgetter-card.clickable:hover{filter:brightness(1.15)}.forgetter-card-inner{position:relative;width:100%;height:100%;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;transition:transform .35s ease;border-radius:8px}.forgetter-card.flipped .forgetter-card-inner,.forgetter-card.matched .forgetter-card-inner{transform:rotateY(180deg)}.forgetter-card.matched{opacity:.55;pointer-events:none}.forgetter-card-back,.forgetter-card-front{position:absolute;top:0;right:0;bottom:0;left:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:8px;display:flex;align-items:center;justify-content:center}.forgetter-card-back{background:linear-gradient(135deg,#1e1b4b,#312e81);border:2px solid #4338ca;color:#ffffff40;font-size:clamp(1rem,3vw,1.4rem);-webkit-user-select:none;user-select:none}.forgetter-card-front{transform:rotateY(180deg);background:#fff;border:2px solid #e2e8f0;font-size:clamp(1.2rem,4vw,2rem)}.forgetter-action{text-align:center;min-height:2rem}.forgetter-gameover{min-width:260px}.forgetter-final-scores{display:flex;flex-direction:column;gap:8px;margin:14px 0;width:100%}.forgetter-score-row{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-radius:8px;background:var(--surface2);opacity:.8}.forgetter-score-row.forgetter-score-winner{background:#064e3b;opacity:1;font-weight:700;border:1px solid #10b981}.forgetter-pair-count{font-size:.9rem;font-weight:700;color:#10b981}.action-ann-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000085;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:1;transition:opacity .4s ease}.action-ann-overlay.action-ann-fading{opacity:0}.action-ann-panel{background:#1a1a2e;border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:1.75rem 2.5rem;box-shadow:0 12px 48px #000000bf,0 0 0 1px #ffffff0d;text-align:center;animation:ann-flip-in .45s cubic-bezier(.23,1,.32,1) forwards;max-width:80vw}.action-ann-card-wrap{display:inline-block;transform:scale(1.7);transform-origin:center top;margin-top:.25rem;margin-bottom:3rem}.action-ann-icon{font-size:3.5rem;line-height:1;margin-bottom:.6rem}.action-ann-text{font-size:1.35rem;font-weight:700;color:#fff;line-height:1.4;text-shadow:0 1px 4px rgba(0,0,0,.6)}@keyframes ann-flip-in{0%{opacity:0;transform:perspective(800px) rotateY(-90deg) scale(.8)}65%{transform:perspective(800px) rotateY(8deg) scale(1.04)}to{opacity:1;transform:perspective(800px) rotateY(0) scale(1)}}
