*{box-sizing:border-box;margin:0;padding:0}:root{--table-bg:#0a1a12;--table-felt:#0d2818;--table-border:#1a3d2a;--chrome-bg:#111;--chrome-surface:#161e18;--chrome-border:#243028;--chrome-text:#e0e0e0;--chrome-dim:#9a9a9a;--card-bg:#fffef7;--card-border:#ccc;--card-shadow:#0006;--card-red:#d40000;--card-black:#1a1a1a;--card-back-bg:#c0392b;--card-back-pattern:#a93226;--accent:#2d9d5c;--accent-glow:#2d9d5c4d;--gold:#d4a017;--green:#22c55e;--card-w:72px;--card-h:100px;--card-radius:6px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px)}:root[data-theme=midnight],.theme-swatch[data-theme=midnight]{--table-bg:#0a0e1a;--table-felt:#101830;--table-border:#1a2545;--card-back-bg:#1b4965;--card-back-pattern:#153d55;--accent:#4a9eff;--accent-glow:#4a9eff4d;--chrome-surface:#141a26;--chrome-border:#243044}:root[data-theme=crimson],.theme-swatch[data-theme=crimson]{--table-bg:#1a0a0a;--table-felt:#2a1015;--table-border:#3d1a22;--card-back-bg:#8b1a2b;--card-back-pattern:#701525;--accent:#d4775a;--accent-glow:#d4775a4d;--chrome-surface:#1f1316;--chrome-border:#3a2228}:root[data-theme=slate],.theme-swatch[data-theme=slate]{--table-bg:#141418;--table-felt:#1e1e24;--table-border:#2a2a33;--card-back-bg:#4a4a5a;--card-back-pattern:#3d3d4d;--accent:#8a7fbf;--accent-glow:#8a7fbf4d;--chrome-surface:#1b1b22;--chrome-border:#2e2e3a}:root[data-theme=jade],.theme-swatch[data-theme=jade]{--table-bg:#0a1410;--table-felt:#0f2a1c;--table-border:#1a4030;--card-back-bg:#1a6b4a;--card-back-pattern:#15573d;--accent:#3daa6d;--accent-glow:#3daa6d4d;--chrome-surface:#131e18;--chrome-border:#22382c}:root[data-theme=ocean],.theme-swatch[data-theme=ocean]{--table-bg:#08121a;--table-felt:#0c1e2e;--table-border:#153550;--card-back-bg:#1a5276;--card-back-pattern:#154565;--accent:#5aadcf;--accent-glow:#5aadcf4d;--chrome-surface:#121e26;--chrome-border:#22384a}:root[data-theme=gold],.theme-swatch[data-theme=gold]{--table-bg:#121008;--table-felt:#1e1a0f;--table-border:#3a3018;--card-back-bg:#1a1a1a;--card-back-pattern:#2a2520;--accent:#d4a017;--accent-glow:#d4a0174d;--chrome-surface:#1c1810;--chrome-border:#3a2e18}:root[data-theme=paper],.theme-swatch[data-theme=paper]{--table-bg:#f5f0e8;--table-felt:#ede7db;--table-border:#d4cbbf;--chrome-bg:#faf8f4;--chrome-surface:#f0ece4;--chrome-border:#ddd6cc;--chrome-text:#2a2520;--chrome-dim:#6b6560;--card-bg:#fffef7;--card-border:#c0b8a8;--card-shadow:#0000001f;--card-back-bg:#c0392b;--card-back-pattern:#a93226;--accent:#2d8a4e;--accent-glow:#2d8a4e33;--gold:#b8860b;--green:#1a9d48}html,body{height:100%;color:var(--chrome-text);background:var(--table-bg);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}#app{width:100%;height:100%;position:relative}.screen{width:100%;height:100%;display:none;position:absolute;top:0;left:0;overflow:hidden}.screen.active{display:flex}#lobby{padding:calc(16px + var(--safe-top)) 16px calc(16px + var(--safe-bottom));background:radial-gradient(ellipse at center, var(--table-felt) 0%, var(--table-bg) 70%);flex-direction:column;justify-content:center;align-items:center;gap:16px}.title-logo{width:320px;max-width:80%;height:auto;transform:translate(-20px)}#lobby .subtitle{color:var(--chrome-dim);margin-top:-8px;font-size:14px}.lobby-form{flex-direction:column;gap:12px;width:280px;margin-top:24px;display:flex}.lobby-form input{border:1px solid var(--chrome-border);background:var(--chrome-surface);color:var(--chrome-text);text-align:center;border-radius:8px;outline:none;padding:12px 16px;font-size:16px}.lobby-form input:focus{border-color:var(--accent)}.lobby-section{flex-direction:column;gap:6px;display:flex}.lobby-label{text-transform:uppercase;letter-spacing:1px;color:var(--chrome-dim);font-size:11px}.lobby-rank{cursor:pointer;background:#0000004d;border-radius:10px;justify-content:center;align-items:center;gap:10px;padding:10px 14px;transition:background .15s;display:flex}.lobby-rank:hover{background:#00000073}.lobby-rank-info{flex-direction:column;gap:2px;display:flex}.lobby-rank-name{color:var(--chrome-text);font-size:14px;font-weight:600}.lobby-rank-points{color:var(--chrome-dim);font-size:11px}.rank-ladder{flex-direction:column;gap:4px;padding:4px 0;display:flex}.rank-ladder-row{color:var(--chrome-dim);border-radius:6px;align-items:center;gap:10px;padding:6px 10px;font-size:13px;display:flex}.rank-ladder-row.current{color:var(--chrome-text);background:#ffffff14;font-weight:600}.rank-ladder-emoji{text-align:center;width:28px;font-size:18px}.rank-ladder-name{flex:1}.rank-ladder-pts{color:var(--chrome-dim);text-align:right;min-width:50px;font-size:11px}.rank-ladder-border{border-radius:50%;flex-shrink:0;width:10px;height:10px}.rank-lore-text{text-align:center;color:var(--chrome-dim);margin:0;padding:8px 0 2px;font-size:13px;line-height:1.4;display:block}.ceremony-overlay{z-index:110;background:#000000e0;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.ceremony-modal{background:var(--chrome-surface);text-align:center;background-image:linear-gradient(135deg,#d4a01714 0%,#0000 50%,#d4a0170a 100%);border:1px solid #d4a01780;border-radius:16px;flex-direction:column;align-items:center;gap:12px;width:85%;max-width:320px;padding:36px 28px 28px;animation:.6s cubic-bezier(.34,1.56,.64,1) thanbai-unlock-pop;display:flex;position:relative}.ceremony-avatar{filter:drop-shadow(0 0 16px #d4a01780);font-size:56px;line-height:1}.ceremony-title{color:var(--gold);letter-spacing:.5px;margin:0;font-size:24px;font-weight:800}.ceremony-subtitle{color:var(--chrome-dim);letter-spacing:1px;text-transform:uppercase;margin-top:-4px;font-size:13px}.ceremony-lore{color:var(--chrome-fg);max-width:260px;font-size:14px;font-style:italic;line-height:1.5}.ceremony-criteria{color:var(--chrome-dim);align-items:center;gap:6px;font-size:12px;display:flex}.ceremony-criteria:before{content:"✔";color:var(--gold);font-size:14px}.ceremony-cta{border:1px solid var(--gold);color:var(--gold);cursor:pointer;background:linear-gradient(135deg,#d4a01733,#d4a01714);border-radius:8px;margin-top:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .2s,transform .1s}.ceremony-cta:hover{background:linear-gradient(135deg,#d4a0174d,#d4a01726)}.ceremony-cta:active{transform:scale(.97)}@keyframes thanbai-unlock-pop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.ceremony-modal{animation:.4s ease-out thanbai-unlock-fade}.ceremony-avatar{filter:none}@keyframes thanbai-unlock-fade{0%{opacity:0}to{opacity:1}}}.results-casual-badge{color:var(--chrome-dim);letter-spacing:.5px;text-transform:uppercase;background:#ffffff14;border:1px solid #ffffff26;border-radius:999px;align-self:center;margin:6px auto 4px;padding:4px 12px;font-size:11px;font-weight:600;display:inline-block}.signin-btn.signin-error{color:var(--red);border-color:var(--red);background:#dc262614}.guest-btn.signin-btn{color:var(--chrome-dim);background:0 0;border-style:dashed;margin-top:6px}.guest-btn.signin-btn:hover{border-color:var(--accent);color:var(--chrome-text);background:#ffffff0a}.my-rank-panel{background:#ffffff0a;border-radius:10px;flex-direction:column;gap:10px;margin-bottom:14px;padding:14px 14px 16px;display:flex}.my-rank-header{align-items:center;gap:14px;display:flex}.my-rank-info{flex-direction:column;flex:1;gap:3px;display:flex}.my-rank-name{color:var(--chrome-text);font-size:18px;font-weight:700}.my-rank-pts{color:var(--chrome-dim);font-size:13px}.my-rank-to-next{color:var(--chrome-dim);text-align:center;font-size:12px}.my-rank-highest{color:var(--chrome-dim);text-align:center;opacity:.75;font-size:11px;font-style:italic}.rank-progress{flex-direction:column;align-items:center;gap:6px;width:100%;padding:10px 0 4px;display:flex}.rank-progress-label{color:var(--chrome-text);font-size:15px;font-weight:700;transition:all .4s}.rank-progress-label.rank-promoted{color:var(--gold);text-shadow:0 0 12px #d4a01799;animation:.6s rankUpPulse}.rank-bar-outer{background:#ffffff1a;border-radius:4px;width:100%;height:8px;overflow:hidden}.rank-bar-inner{background:linear-gradient(90deg, var(--accent), var(--green));border-radius:4px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.rank-progress-pts{color:var(--chrome-dim);font-size:11px}.rank-progress-msg{color:var(--chrome-dim);font-size:11px;font-style:italic}.results-row.rematch-ready:after{content:"✓";color:var(--green);margin-left:6px;font-size:14px;font-weight:700}.btn-ready{opacity:.7}.results-force-start{font-size:13px}.results-modal .btn-primary,.results-modal .results-leave{width:220px;max-width:100%}.results-leave{color:var(--chrome-text);border:1px solid var(--chrome-border);background:0 0}.results-leave:hover:not(:disabled){border-color:var(--chrome-dim);background:#ffffff0f}@keyframes rankUpPulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.btn-group{gap:6px;display:flex}.btn-chip{border:1px solid var(--chrome-border);background:var(--chrome-surface);color:var(--chrome-dim);cursor:pointer;border-radius:6px;flex:1;padding:12px 8px;font-size:13px;font-weight:600;transition:all .15s}.btn-chip:hover{border-color:var(--accent);color:var(--chrome-text)}.btn-chip:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.btn-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.toggle-list{flex-direction:column;gap:4px;display:flex}.toggle-row{color:var(--chrome-dim);cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:6px 8px;font-size:13px;transition:background .15s;display:flex}.toggle-row:hover{background:#ffffff0d}.toggle-row input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.btn{cursor:pointer;border:none;border-radius:8px;padding:12px 24px;font-size:16px;font-weight:600;transition:background .15s,transform .1s}.btn:active{transform:scale(.96)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:disabled{opacity:.4;cursor:default;transform:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent);filter:brightness(1.12);box-shadow:0 0 12px var(--accent-glow)}.btn-primary:focus-visible{filter:brightness(1.12);box-shadow:0 0 12px var(--accent-glow);outline:none}.btn-secondary{background:var(--chrome-surface);color:var(--chrome-text);border:1px solid var(--chrome-border)}.btn-secondary:hover:not(:disabled){background:#252525}.beta-wrap{display:block;position:relative}.beta-wrap .btn{width:100%}.beta-ribbon{color:#fff;letter-spacing:1px;pointer-events:none;text-transform:uppercase;z-index:1;background:#d04040;padding:2px 22px;font-size:10px;font-weight:700;position:absolute;top:8px;right:-18px;transform:rotate(20deg);box-shadow:0 2px 6px #0006}.hint-btn{flex:none;min-width:38px;padding:0 10px;font-size:18px;line-height:1}.card.card-hint{animation:.6s ease-out card-hint-glow}@keyframes card-hint-glow{0%{box-shadow:0 0 #f5c85000}20%{box-shadow:0 0 16px #f5c850d9,0 0 4px #f5c85099}to{box-shadow:0 0 #f5c85000}}@media (prefers-reduced-motion:reduce){.card.card-hint{animation:none;box-shadow:0 0 12px #f5c850b3}}#game{background:radial-gradient(ellipse at center, var(--table-felt) 0%, var(--table-bg) 70%);flex-direction:column;position:relative}.opponent{z-index:1;flex-direction:column;align-items:center;gap:6px;display:flex;position:absolute}.opponent-top{top:calc(12px + var(--safe-top));left:50%;transform:translate(-50%)}.opponent-top .opponent-cards{margin-top:10px}.opponent-left{top:18%;left:12px}.opponent-right{top:18%;right:12px}.opponent-info{color:var(--chrome-dim);background:#0009;border:1px solid #0000;border-radius:14px;align-items:center;gap:8px;padding:6px 12px;font-size:13px;display:flex}.opponent-name{color:var(--chrome-text);font-weight:600}.opponent-count{background:var(--chrome-surface);text-align:center;min-width:24px;color:var(--chrome-text);border-radius:8px;padding:2px 8px;font-size:14px;font-weight:700}.placement-badge{letter-spacing:.5px;border-radius:8px;padding:2px 8px;font-size:12px;font-weight:800}.placement-badge.place-0{background:var(--gold);color:#1a1a1a}.placement-badge.place-1{color:#1a1a1a;background:#a0a0a0}.placement-badge.place-2{color:#fff;background:#8b5e3c}.placement-badge.place-3{color:#999;background:#444}.opponent-cards{gap:0;display:flex}.opponent.active-turn .opponent-info{border:1px solid var(--accent)}.opponent-info{position:relative;overflow:hidden}.opponent.active-turn .opponent-info:after,#player-area.active-turn #player-info:after{content:"";height:2px;width:calc(var(--turn-bar-pct,100) * 1%);background:var(--turn-bar-color,var(--accent));border-radius:0 0 14px 14px;transition:width .1s linear;position:absolute;bottom:0;left:0}.opponent.active-turn[data-turn-pulse] .opponent-info,#player-area.active-turn[data-turn-pulse] #player-info{animation:.6s ease-in-out infinite turn-pill-pulse}@keyframes turn-pill-pulse{0%,to{border-color:var(--turn-bar-color,var(--accent))}50%{border-color:#0000}}@media (prefers-reduced-motion:reduce){.opponent.active-turn[data-turn-pulse] .opponent-info,#player-area.active-turn[data-turn-pulse] #player-info{animation:none}}.opponent[data-mp-status] .opponent-info:before,#player-area[data-mp-status] #player-info:before{content:"";vertical-align:middle;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-right:6px;display:inline-block}.opponent[data-mp-status=reconnecting] .opponent-info:before,#player-area[data-mp-status=reconnecting] #player-info:before{background:#f5a623;animation:1.2s ease-in-out infinite mp-status-pulse;box-shadow:0 0 6px #f5a62399}.opponent[data-mp-status=grace] .opponent-info:before{background:#d04040;animation:.6s ease-in-out infinite mp-status-pulse;box-shadow:0 0 6px #d04040b3}@keyframes mp-status-pulse{0%,to{opacity:.45}50%{opacity:1}}@media (prefers-reduced-motion:reduce){.opponent[data-mp-status] .opponent-info:before,#player-area[data-mp-status] #player-info:before{opacity:1;animation:none}}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:20px;line-height:1;display:flex;position:relative;overflow:hidden}.avatar-bronze{border:2px solid #b87333;box-shadow:0 0 6px #b8733366}.avatar-silver{border:2px solid silver;box-shadow:0 0 6px #c0c0c066}.avatar-gold{border:2px solid #d4a017;box-shadow:0 0 8px #d4a01780}#play-area{z-index:2;flex-direction:column;align-items:center;gap:8px;min-width:200px;min-height:120px;display:flex;position:absolute;top:40%;left:50%;transform:translate(-50%,-50%)}#trick-cards{min-height:var(--card-h);justify-content:center;display:flex;position:relative}.trick-play-group{margin-left:calc(var(--card-w) / -2);margin-top:calc(var(--card-h) / -2);width:var(--card-w);height:var(--card-h);display:flex;position:absolute;top:50%;left:50%}#trick-cards.clearing .trick-play-group{opacity:0;transition:transform .3s,opacity .3s;transform:scale(.6)!important}.trick-play-group .card{transition:none;position:relative}#game-message{color:var(--chrome-dim);text-align:center;min-height:18px;padding:4px 0;font-size:13px;line-height:1.5}#game-message.thinking:after{content:"";vertical-align:middle;background:currentColor;border-radius:50%;width:3px;height:3px;margin-left:6px;animation:1.2s ease-in-out infinite thinking-dots;display:inline-block}@keyframes thinking-dots{0%,80%,to{opacity:.3;box-shadow:6px 0,12px 0}20%{opacity:1;box-shadow:6px 0 #ffffff4d,12px 0 #ffffff4d}40%{opacity:.3;box-shadow:6px 0,12px 0 #ffffff4d}}@media (prefers-reduced-motion:reduce){#game-message.thinking:after{opacity:.6;animation:none}}#play-log{color:var(--chrome-dim);text-align:center;min-height:4px;font-size:11px;line-height:1.6}#player-area{padding:8px 0 calc(16px + var(--safe-bottom));z-index:10;background:linear-gradient(transparent, var(--table-bg) 30%);flex-direction:column;align-items:center;gap:6px;display:flex;position:absolute;bottom:0;left:0;right:0}.player-info-wrap{width:fit-content;position:relative}#player-info{background:#00000080;border:1px solid #0000;border-radius:12px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;display:flex;position:relative;overflow:hidden}.player-info-wrap>.speech-bubble{top:-38px;bottom:auto}.chat-preset-bar{justify-content:center;align-items:center;gap:6px;margin-top:2px;padding:2px 0;display:flex}.chat-preset-bar[hidden]{display:none}.chat-preset-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:999px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:18px;line-height:1;transition:background .15s,transform .1s,opacity .2s;display:flex}.chat-preset-btn:hover:not(:disabled){background:#ffffff1f}.chat-preset-btn:active:not(:disabled){transform:scale(.92)}.chat-preset-btn:disabled{opacity:.35;cursor:not-allowed}.chat-preset-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){.chat-preset-btn{transition:none}}#player-area.active-turn #player-info{border:1px solid var(--accent)}#hand{height:calc(var(--card-h) + 16px);justify-content:center;align-items:flex-end;width:100%;padding:0 16px;display:flex;position:relative}#action-buttons{gap:12px;display:flex}#action-buttons .btn{min-width:80px;min-height:44px;padding:10px 20px;font-size:15px}.card{width:var(--card-w);height:var(--card-h);border-radius:var(--card-radius);flex-shrink:0;transition:transform .15s;position:relative}.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card-face{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:0 2px 4px var(--card-shadow);cursor:pointer}.card-face .card-corner{flex-direction:column;align-items:center;font-weight:700;line-height:1;display:flex;position:absolute}.card-face .card-corner-tl{top:4px;left:5px}.card-face .card-corner-br{bottom:4px;right:5px;transform:rotate(180deg)}.card-face .card-rank{font-size:13px}.card-face .card-suit-small{margin-top:-1px;font-size:11px}.card-face .card-suit-center{font-size:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.card-face.red{color:var(--card-red)}.card-face.black{color:var(--card-black)}.lobby-links{justify-content:center;gap:16px;display:flex}.link-btn{color:var(--chrome-dim);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:4px 0;font-size:13px;text-decoration:underline}.link-btn:hover,.link-btn:focus-visible{color:var(--chrome-text)}.link-btn:focus-visible{outline:1px solid var(--accent);outline-offset:2px;border-radius:4px}.modal{padding:env(safe-area-inset-top,0px) env(safe-area-inset-right,0px) env(safe-area-inset-bottom,0px) env(safe-area-inset-left,0px);box-sizing:border-box;z-index:200;background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal.hidden{display:none}dialog.modal{width:100%;max-width:none;height:100%;max-height:none;color:inherit;box-sizing:border-box;border:none;margin:0}dialog.modal:not([open]),dialog.modal::backdrop{display:none}.modal-content{background:var(--chrome-surface);border:1px solid var(--chrome-border);border-radius:12px;flex-direction:column;gap:16px;width:90%;max-width:320px;padding:24px;display:flex}.modal-content.modal-wide{max-width:420px;max-height:calc(100% - 20px);overflow-y:auto}.modal-scroll{flex-direction:column;flex:auto;gap:16px;min-height:0;padding:14px 2px 20px;display:flex;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000 0,#000 10px calc(100% - 10px),#0000 100%);mask-image:linear-gradient(#0000 0,#000 10px calc(100% - 10px),#0000 100%)}.signout-btn-scrolled{color:#e74c3c;border-color:#e74c3c4d;margin-top:8px}.signout-btn-scrolled:hover{color:#ff5a4a;background:#e74c3c14;border-color:#e74c3c}.modal-content h3{color:var(--chrome-text);margin:0;font-size:20px}.modal-subtitle{color:var(--chrome-dim);margin-top:-8px;font-size:12px}.modal-close{align-self:stretch}.rules-body{flex-direction:column;gap:12px;display:flex}.rules-section h4{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin:0 0 4px;font-size:13px}.rules-section p{color:var(--chrome-dim);margin:0 0 2px;font-size:13px;line-height:1.5}.card-suit-small,.card-suit-center{-webkit-text-stroke:.5px currentColor}.card-face.is-two{background:linear-gradient(135deg, var(--card-bg) 60%, #fff8e7);border-color:#d4a01744}.card-face.selected{box-shadow:0 4px 12px var(--accent-glow), 0 2px 4px var(--card-shadow);border-color:var(--accent);transition:transform .1s;transform:translateY(-16px)}@media (prefers-reduced-motion:reduce){.card-face.selected{transition:none;transform:translateY(-12px)}}.card-face.playable{cursor:pointer}#hand .card-face:not(.playable){cursor:default;opacity:.7}#player-area:not(.active-turn) #hand{opacity:.6;pointer-events:none}#hand .card.dragging{z-index:100;transform-origin:0 0;pointer-events:none;margin-left:0;transition:none;position:fixed;transform:scale(1.08);box-shadow:0 8px 24px #0006}#hand .card.shift-right{transform:translateX(var(--card-shift));transition:transform .15s}#hand .card.shift-right.selected{transform:translateX(var(--card-shift)) translateY(-16px);transition:transform .15s}.card-back{border:1px solid var(--card-border);box-shadow:0 1px 3px var(--card-shadow);background:#fffef7;overflow:hidden}.card-back-pattern{border-radius:2px;flex-direction:column;display:flex;position:absolute;inset:4px;overflow:hidden}.card-back-border{background:#d4a017;flex-shrink:0;height:7px;position:relative;overflow:hidden}.card-back-border:after{content:"";background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Crect width='12' height='7' fill='%232c3e8c'/%3E%3Cpath d='M0,0h1v6h10v-5h-8v1h7v3h-5v-1h4v-1h-6v4h10v1h-12z' fill='%23d4a017'/%3E%3Cpath d='M3,2h5v1h-4v1h3' fill='none' stroke='%23b8860b' stroke-width='0.3' opacity='0.5'/%3E%3C/svg%3E") 0 0/12px 7px repeat-x;position:absolute;inset:0}.card-back-field{background:#c0392b;flex:1;position:relative;overflow:hidden}.card-back-field:before{content:"";opacity:.14;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cdefs%3E%3Cstyle%3Epath%7Bfill:none;stroke:white;stroke-width:1;stroke-linecap:round%7D%3C/style%3E%3C/defs%3E%3C!-- Cloud scroll motif --%3E%3Cpath d='M5,30 C5,22 12,18 18,22 C20,14 30,12 32,20 C36,14 46,16 44,24 C50,22 56,28 50,34 C54,38 48,46 42,42 C40,48 32,48 30,42 C26,48 16,46 18,38 C12,42 4,38 5,30Z'/%3E%3C!-- Inner spiral details --%3E%3Cpath d='M18,28 C18,24 24,22 26,26' opacity='0.7'/%3E%3Cpath d='M34,26 C36,22 42,24 40,28' opacity='0.7'/%3E%3Cpath d='M24,36 C22,40 28,42 30,38' opacity='0.7'/%3E%3C!-- Small corner florets --%3E%3Ccircle cx='4' cy='4' r='2' fill='white' fill-opacity='0.3' stroke='none'/%3E%3Ccircle cx='56' cy='56' r='2' fill='white' fill-opacity='0.3' stroke='none'/%3E%3Ccircle cx='56' cy='4' r='1.5' fill='white' fill-opacity='0.2' stroke='none'/%3E%3Ccircle cx='4' cy='56' r='1.5' fill='white' fill-opacity='0.2' stroke='none'/%3E%3C/svg%3E") 0 0/30px 30px;position:absolute;inset:0}.card-back-field:after{content:"";opacity:.08;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'%3E%3Cdefs%3E%3Cstyle%3Epath%7Bfill:none;stroke:white;stroke-width:0.8%7D%3C/style%3E%3C/defs%3E%3C!-- Four-petal rosette --%3E%3Cpath d='M20,10 C16,14 16,18 20,20 C24,18 24,14 20,10Z'/%3E%3Cpath d='M20,30 C16,26 16,22 20,20 C24,22 24,26 20,30Z'/%3E%3Cpath d='M10,20 C14,16 18,16 20,20 C18,24 14,24 10,20Z'/%3E%3Cpath d='M30,20 C26,16 22,16 20,20 C22,24 26,24 30,20Z'/%3E%3C!-- Centre dot --%3E%3Ccircle cx='20' cy='20' r='1.5' fill='white' fill-opacity='0.5' stroke='none'/%3E%3C!-- Diagonal connecting tendrils --%3E%3Cpath d='M4,4 C8,8 12,8 14,6' opacity='0.5'/%3E%3Cpath d='M36,36 C32,32 28,32 26,34' opacity='0.5'/%3E%3Cpath d='M36,4 C32,8 28,8 26,6' opacity='0.5'/%3E%3Cpath d='M4,36 C8,32 12,32 14,34' opacity='0.5'/%3E%3C/svg%3E") 0 0/20px 20px;position:absolute;inset:0}.card-back-center{color:#c0392b;z-index:1;background:#ffffffeb;border:1px solid #d4a01766;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;font-weight:700;line-height:1;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.opponent-cards .card-back{border-radius:var(--card-radius);z-index:0;width:48px;height:67px;margin-left:-30px}.opponent-cards .card-back:first-child{margin-left:0}.opponent-cards .card-back .card-back-center{width:14px;height:14px;font-size:9px}.opponent-cards .card-back .card-back-border{height:5px}.opponent-cards .card-back .card-back-pattern{inset:3px}.opponent-right .opponent-cards{flex-direction:column;align-items:center}.opponent-right .opponent-cards .card-back{margin-top:-42px;margin-left:0;transform:rotate(90deg)}.opponent-right .opponent-cards .card-back:first-child{margin-top:0}.opponent-left .opponent-cards{flex-direction:column-reverse;align-items:center}.opponent-left .opponent-cards .card-back{margin-bottom:-42px;margin-left:0;transform:rotate(90deg)}.opponent-left .opponent-cards .card-back:first-child{margin-bottom:0}#hand .card{margin-left:-28px;transition:transform .15s}#hand .card:first-child{margin-left:0}@media (width<=500px){:root{--card-w:56px;--card-h:78px}#hand{padding:0 8px}#hand .card{margin-left:-31px}.card-face .card-rank{font-size:12px}.card-face .card-suit-small{font-size:11px}.card-face .card-suit-center{font-size:20px}.opponent-cards .card-back{width:32px;height:45px;margin-left:-22px}.opponent-right .opponent-cards .card-back{margin-top:-35px;margin-left:0}.opponent-left .opponent-cards .card-back{margin-bottom:-35px;margin-left:0}.opponent-top{top:calc(60px + var(--safe-top))}.opponent-top .opponent-cards{margin-top:7px}.opponent-left{align-items:flex-start;top:26%;left:6px}.opponent-left .opponent-cards{margin-left:14px}.opponent-right{align-items:flex-end;top:26%;right:6px}.opponent-right .opponent-cards{margin-right:14px}#play-area{top:44%}.opponent-info{padding:3px 8px;font-size:11px}.opponent-count{padding:2px 6px;font-size:12px}#game-message{min-height:16px;line-height:1.6}#play-log{font-size:12px;line-height:1.5}}#hand .card.dealing{animation:.4s ease-out backwards dealIn}@keyframes dealIn{0%{opacity:0;transform:translateY(-200px)scale(.6)rotate(15deg)}to{opacity:1;transform:translateY(0)scale(1)rotate(0)}}#results{background:radial-gradient(ellipse at center, var(--table-felt) 0%, var(--table-bg) 70%);flex-direction:column;justify-content:center;align-items:center;gap:24px}#results-title{color:var(--card-bg);font-size:28px}#results-placements{flex-direction:column;gap:8px;width:240px;display:flex}.placement-row{background:#0000004d;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;display:flex}.placement-position{text-align:center;width:28px;font-size:18px;font-weight:700}.placement-row:first-child .placement-position{color:var(--gold)}.placement-row:nth-child(2) .placement-position{color:silver}.placement-name{flex:1;font-size:15px}.effect-text{color:#f44;text-shadow:2px 2px #000c,0 0 16px #ff444480;pointer-events:none;z-index:100;font-size:48px;font-weight:900;animation:2.5s ease-out forwards effectPop;position:fixed;top:38%;left:50%;transform:translate(-50%,-50%)}@keyframes effectPop{0%{opacity:0;transform:translate(-50%,-50%)scale(.5)}10%{opacity:1;transform:translate(-50%,-50%)scale(1.3)}20%{transform:translate(-50%,-50%)scale(1)}70%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-55%)scale(1)}}.screen-shake{animation:.35s ease-in-out shake}.screen-shake-heavy{animation:.5s ease-in-out shakeHeavy}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-5px,2px)}40%{transform:translate(4px,-2px)}60%{transform:translate(-3px,1px)}80%{transform:translate(3px,-1px)}}@keyframes shakeHeavy{0%,to{transform:translate(0)}10%{transform:translate(-8px,3px)}20%{transform:translate(7px,-4px)}30%{transform:translate(-6px,2px)}40%{transform:translate(5px,-3px)}50%{transform:translate(-4px,3px)}60%{transform:translate(6px,-2px)}70%{transform:translate(-3px,1px)}80%{transform:translate(4px,-1px)}90%{transform:translate(-2px,1px)}}.chop-flash{pointer-events:none;z-index:98;background:radial-gradient(circle,#e74c3c4d,#e74c3c00 70%);animation:.4s ease-out forwards chopFlash;position:fixed;inset:0}.chop-flash-heavy{pointer-events:none;z-index:98;background:radial-gradient(circle,#e74c3c80,#e74c3c1a 70%);animation:.6s ease-out forwards chopFlash;position:fixed;inset:0}@keyframes chopFlash{0%{opacity:1}to{opacity:0}}.effect-text-heavy{color:#e74c3c;text-shadow:3px 3px #000c,0 0 24px #ff282899,0 0 48px #ff28284d;pointer-events:none;z-index:100;font-size:56px;font-weight:900;animation:3s ease-out forwards effectPopHeavy;position:fixed;top:38%;left:50%;transform:translate(-50%,-50%)}@keyframes effectPopHeavy{0%{opacity:0;transform:translate(-50%,-50%)scale(.3)}8%{opacity:1;transform:translate(-50%,-50%)scale(1.6)}15%{transform:translate(-50%,-50%)scale(1.1)}20%{transform:translate(-50%,-50%)scale(1.25)}65%{opacity:1;transform:translate(-50%,-50%)scale(1.2)}to{opacity:0;transform:translate(-50%,-55%)scale(1.1)}}.arena-splash{letter-spacing:4px;background:linear-gradient(#ffd23f 0%,#ff7b00 50%,#b82000 100%);-webkit-text-fill-color:transparent;text-shadow:none;filter:drop-shadow(0 0 2px #000000f2)drop-shadow(4px 4px #000000d9)drop-shadow(0 0 32px #ff780099);pointer-events:none;z-index:500;-webkit-background-clip:text;background-clip:text;font-family:Impact,Arial Black,sans-serif;font-size:clamp(64px,18vw,140px);font-weight:900;animation:1.3s cubic-bezier(.22,1.2,.36,1) forwards arenaSplash;position:fixed;top:40%;left:50%;transform:translate(-50%,-50%)rotate(-8deg)scale(.4)}.arena-splash.heavy{background:linear-gradient(#fff2b3 0%,#ff3e1a 45%,#7a0015 100%);-webkit-background-clip:text;background-clip:text;font-size:clamp(78px,22vw,180px);animation-duration:1.7s}@keyframes arenaSplash{0%{opacity:0;transform:translate(-50%,-50%)rotate(-18deg)scale(.2)}12%{opacity:1;transform:translate(-50%,-50%)rotate(4deg)scale(1.35)}22%{transform:translate(-50%,-50%)rotate(-6deg)scale(1.05)}35%{transform:translate(-50%,-50%)rotate(-8deg)scale(1.12)}70%{opacity:1;transform:translate(-50%,-50%)rotate(-8deg)scale(1.12)}to{opacity:0;transform:translate(-50%,-60%)rotate(-12deg)scale(1)}}.arena-shockwave{pointer-events:none;z-index:450;mix-blend-mode:screen;border:3px solid #ffc83ce6;border-radius:50%;width:20px;height:20px;animation:.75s cubic-bezier(.16,1,.3,1) forwards arenaShockwave;position:fixed;transform:translate(-50%,-50%)scale(0);box-shadow:0 0 20px #ffa01eb3,inset 0 0 12px #ffdc7866}@keyframes arenaShockwave{0%{opacity:0;border-width:6px;transform:translate(-50%,-50%)scale(0)}10%{opacity:1}to{opacity:0;border-width:1px;transform:translate(-50%,-50%)scale(25)}}.arena-chromatic{pointer-events:none;z-index:480;mix-blend-mode:screen;animation:.22s ease-out forwards arenaChromatic;position:fixed;inset:0}@keyframes arenaChromatic{0%{opacity:0;box-shadow:inset 0 0 #f000}10%{opacity:1;box-shadow:inset 20px 0 60px #ff004073,inset -20px 0 60px #00c8ff59}to{opacity:0;box-shadow:inset 0 0 #f000}}.arena-hit-stop{filter:saturate(.4)contrast(1.15);transition:filter 40ms ease-out,transform 40ms ease-out;transform:scale(1.008);animation-play-state:paused!important}.arena-hit-stop.heavy{filter:saturate(.2)contrast(1.25)brightness(1.05);transform:scale(1.015)}.arena-hit-stop *{animation-play-state:paused!important}.arena-shake{animation:.45s cubic-bezier(.36,.07,.19,.97) both arenaShake}.arena-shake-heavy{animation:.7s cubic-bezier(.36,.07,.19,.97) both arenaShakeHeavy}.arena-shake-reduced{animation:.3s ease-out both arenaShakeReduced}@keyframes arenaShake{0%,to{transform:translate(0)rotate(0)}10%{transform:translate(-6px,4px)rotate(-.5deg)}20%{transform:translate(7px,-3px)rotate(.6deg)}30%{transform:translate(-8px,2px)rotate(-.4deg)}40%{transform:translate(6px,-4px)rotate(.5deg)}50%{transform:translate(-4px,3px)rotate(-.3deg)}60%{transform:translate(5px,-2px)rotate(.3deg)}70%{transform:translate(-3px,2px)rotate(-.2deg)}80%{transform:translate(2px,-1px)rotate(.1deg)}90%{transform:translate(-1px,1px)rotate(0)}}@keyframes arenaShakeHeavy{0%,to{transform:translate(0)rotate(0)}5%{transform:translate(-10px,6px)rotate(-.8deg)}15%{transform:translate(12px,-5px)rotate(1deg)}25%{transform:translate(-13px,4px)rotate(-.7deg)}35%{transform:translate(10px,-6px)rotate(.8deg)}45%{transform:translate(-8px,5px)rotate(-.5deg)}55%{transform:translate(7px,-3px)rotate(.4deg)}65%{transform:translate(-5px,2px)rotate(-.3deg)}75%{transform:translate(3px,-2px)rotate(.2deg)}90%{transform:translate(-1px,1px)rotate(0)}}@keyframes arenaShakeReduced{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.arena-pile-pop{animation:.35s cubic-bezier(.22,1.3,.32,1) both arenaPilePop}@keyframes arenaPilePop{0%{transform:scale(1)}25%{filter:brightness(1.35);transform:scale(1.18)}55%{transform:scale(.95)}to{filter:brightness();transform:scale(1)}}body.reduced-motion .arena-shockwave,body.reduced-motion .arena-chromatic,body.reduced-motion .arena-hit-stop,body.reduced-motion .arena-shake,body.reduced-motion .arena-shake-heavy,body.reduced-motion .arena-pile-pop{filter:none;display:none;transform:none;animation:none!important}.instant-win-overlay{z-index:50;background:#000000b3;flex-direction:column;justify-content:center;align-items:center;gap:16px;animation:.5s fadeIn;display:flex;position:fixed;inset:0}.instant-win-label{color:var(--gold);text-shadow:0 2px 12px #d4a01780;font-size:36px;font-weight:800}.instant-win-cards{justify-content:center;align-items:flex-end;max-width:90%;display:flex}.instant-win-cards .card{margin-left:-28px}.instant-win-cards .card:first-child{margin-left:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-btn{top:calc(12px + var(--safe-top));z-index:20;width:44px;height:44px;color:var(--chrome-dim);cursor:pointer;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;line-height:1;display:flex;position:absolute;right:12px}.settings-btn:hover{color:var(--chrome-text);background:#0009}.settings-btn-game{z-index:20}.stats-btn{top:calc(12px + var(--safe-top));z-index:20;width:44px;height:44px;color:var(--chrome-dim);cursor:pointer;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;line-height:1;display:flex;position:absolute;right:64px}.stats-btn:hover{color:var(--chrome-text);background:#0009}.about-btn{top:calc(12px + var(--safe-top));z-index:20;width:44px;height:44px;color:var(--chrome-dim);cursor:pointer;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;line-height:1;display:flex;position:absolute;right:116px}.about-btn:hover{color:var(--chrome-text);background:#0009}.about-intro{color:var(--chrome-dim);text-align:center;margin:0 0 16px;font-size:13px;line-height:1.5}.about-cards{flex-direction:column;gap:10px;display:flex}.about-card{background:var(--chrome-surface);border:1px solid var(--chrome-border);border-radius:10px;align-items:flex-start;gap:12px;padding:12px;display:flex}.about-card.legendary{background:linear-gradient(135deg,#d4a0171f,#d4a0170a);border-color:#d4a01780}.about-card.locked{opacity:.6}.about-card-emoji{background:#0000004d;border-radius:8px;flex:0 0 44px;justify-content:center;align-items:center;height:44px;font-size:32px;display:flex}.about-card.legendary .about-card-emoji{background:#d4a01726}.about-card-body{flex:1;min-width:0}.about-card-header{justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:4px;display:flex}.about-card-name{color:var(--chrome-text);font-size:15px;font-weight:600}.about-card-rating{color:#d4a017;letter-spacing:1px;flex-shrink:0;font-size:13px}.about-card-rating .star-empty{color:#ffffff26}.about-card-legend{letter-spacing:1px;color:#d4a017;text-transform:uppercase;flex-shrink:0;font-size:11px;font-weight:700}.about-card-blurb{color:var(--chrome-dim);font-size:13px;line-height:1.4}.hidden{display:none!important}.signin-btn{border:1px solid var(--chrome-border);color:var(--chrome-text);cursor:pointer;background:#ffffff0a;border-radius:999px;justify-content:center;align-items:center;gap:10px;margin-top:12px;padding:10px 18px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}.signin-btn:hover{border-color:var(--accent);background:#ffffff14}.signin-btn.hidden{display:none}.signin-btn .g-icon{color:#fff;background:linear-gradient(135deg,#4285f4,#34a853,#fbbc05,#ea4335);border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;font-weight:800;display:inline-flex}.lobby-user-chip{border:1px solid var(--chrome-border);background:#00000040;border-radius:999px;align-items:center;gap:10px;width:fit-content;margin:0 auto;padding:8px 14px 8px 8px;display:flex}.lobby-user-chip.hidden{display:none}.lobby-user-chip .user-chip-avatar{background:var(--accent);color:#fff;background-position:50%;background-size:cover;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:800;display:flex}.user-chip-info{flex-direction:column;line-height:1.2;display:flex}.user-chip-greeting{text-transform:uppercase;letter-spacing:1px;color:var(--chrome-dim);font-size:10px}.user-chip-name{color:var(--chrome-text);font-size:14px;font-weight:700}.settings-account.hidden{display:none}.account-info{background:#00000040;border-radius:8px;align-items:center;gap:12px;margin-bottom:8px;padding:10px 12px;display:flex}.account-avatar{background:var(--accent);color:#fff;background-position:50%;background-size:cover;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;font-weight:800;display:flex}.account-meta{flex-direction:column;flex:1;min-width:0;display:flex}.account-name{color:var(--chrome-text);font-size:14px;font-weight:700}.account-email{color:var(--chrome-dim);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.account-nickname{flex-direction:column;gap:4px;margin:8px 0;display:flex}.account-nickname-label{text-transform:uppercase;letter-spacing:1px;color:var(--chrome-dim);font-size:11px}.account-nickname-row{align-items:stretch;gap:8px;display:flex}.account-nickname-row input{border:1px solid var(--chrome-border);color:var(--chrome-text);background:#0000004d;border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:14px}.account-nickname-row input:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.account-nickname-row .btn{padding:8px 14px;font-size:13px}.account-nickname-status{color:var(--chrome-dim);text-align:right;min-height:14px;font-size:11px}.account-nickname-status.success{color:var(--accent)}.merge-summary{background:#00000040;border-radius:8px;flex-direction:column;gap:6px;width:100%;padding:12px;font-size:13px;display:flex}.merge-summary-row{color:var(--chrome-dim);justify-content:space-between;display:flex}.merge-summary-row strong{color:var(--chrome-text);font-weight:700}.modal-actions{gap:8px;width:100%;margin-top:4px;display:flex}.modal-actions .btn{flex:1}.stats-tabs{gap:8px;width:100%;margin-bottom:8px;display:flex}.stats-tab{border:1px solid var(--chrome-border);color:var(--chrome-dim);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:8px 12px;font-size:14px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.stats-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.stats-tab:disabled{opacity:.4;cursor:not-allowed}.stats-body{flex-direction:column;gap:14px;width:100%;display:flex}.stats-empty{text-align:center;color:var(--chrome-dim);padding:24px 8px;font-size:14px;line-height:1.6}.stats-headline{background:#00000040;border-radius:12px;justify-content:space-around;align-items:stretch;gap:12px;padding:16px 12px;display:flex}.stats-headline-item{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.stats-headline-value{color:var(--chrome-text);font-size:26px;font-weight:800}.stats-headline-label{text-transform:uppercase;letter-spacing:1px;color:var(--chrome-dim);font-size:11px}.stats-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.stats-tile{border:1px solid var(--chrome-border);color:var(--chrome-dim);background:#0003;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;font-size:13px;display:flex}.stats-tile-value{color:var(--chrome-text);font-size:15px;font-weight:700}.stats-recent{justify-content:center;gap:4px;padding:8px 0;display:flex}.stats-recent-pill{border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:flex}.stats-recent-pill.place-0{background:var(--gold);color:#1a1a1a}.stats-recent-pill.place-1{color:#1a1a1a;background:silver}.stats-recent-pill.place-2{color:#1a1a1a;background:#cd7f32}.stats-recent-pill.place-3{color:var(--chrome-dim);background:#ffffff1a}.settings-section{flex-direction:column;gap:4px;display:flex}.settings-heading{text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin:0;font-size:12px;font-weight:700}.settings-subheading{color:var(--chrome-dim);margin:8px 0 0;font-size:11px}.settings-select{border:1px solid var(--chrome-border);background:var(--chrome-surface);color:var(--chrome-text);cursor:pointer;border-radius:8px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:14px}.settings-select:focus{border-color:var(--accent)}.theme-picker{flex-wrap:wrap;gap:10px;padding:4px 0;display:flex}.theme-option{cursor:pointer;flex-direction:column;align-items:center;gap:4px;display:flex}.theme-swatch{border:2px solid var(--chrome-border);cursor:pointer;background:0 0;border-radius:8px;flex-direction:column;width:44px;height:44px;padding:0;transition:border-color .15s,transform .15s;display:flex;overflow:hidden}.theme-swatch:hover{border-color:var(--chrome-dim);transform:scale(1.08)}.theme-swatch.active{border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.swatch-felt{background:var(--table-felt);flex:2;display:block}.swatch-card{background:var(--card-back-bg);flex:1;display:block}.swatch-label{color:var(--chrome-dim);text-align:center;font-size:10px}.settings-how-to-play-row{gap:8px;display:flex}.settings-how-to-play{flex:1 1 0;width:100%}.opponent-count.last-card{color:#fff;background:#d40000;animation:.8s ease-in-out 3 lastCardPulse}@keyframes lastCardPulse{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.speech-bubble{color:var(--card-bg);white-space:nowrap;pointer-events:none;z-index:25;background:#000000bf;border-radius:10px;padding:4px 10px;font-size:12px;font-weight:600;animation:2.2s ease-out forwards bubbleFade;position:absolute;bottom:-28px;left:50%;transform:translate(-50%)}@keyframes bubbleFade{0%{opacity:0;transform:translate(-50%)translateY(4px)}10%{opacity:1;transform:translate(-50%)translateY(0)}75%{opacity:1}to{opacity:0}}.opponent.has-passed{opacity:.35;transition:opacity .4s}.opponent:not(.has-passed){transition:opacity .3s}.pass-indicator{color:var(--chrome-dim);text-transform:uppercase;letter-spacing:1px;pointer-events:none;z-index:20;font-size:13px;font-weight:700;animation:1.2s ease-out forwards passFade;position:absolute}@keyframes passFade{0%{opacity:0;transform:translateY(0)}15%{opacity:1}70%{opacity:1}to{opacity:0;transform:translateY(-12px)}}.smoke-particle{pointer-events:none;z-index:99;background:#c8b496b3;border-radius:50%;animation:.6s ease-out forwards smokeExpand;position:fixed}@keyframes smokeExpand{0%{opacity:.8;transform:translate(0)scale(1)}to{opacity:0;transform:translate(var(--dx), var(--dy)) scale(.3)}}@media (width>=501px) and (width<=599px){:root{--card-w:68px;--card-h:95px}#hand .card{margin-left:-38px}.card-face .card-rank{font-size:13px}.card-face .card-suit-small{font-size:10px}.card-face .card-suit-center{font-size:24px}.opponent-cards .card-back{width:42px;height:59px;margin-left:-30px}.opponent-right .opponent-cards .card-back{margin-top:-47px;margin-left:0}.opponent-left .opponent-cards .card-back{margin-bottom:-47px;margin-left:0}#game-message{min-height:18px;font-size:13px}#play-btn,#pass-btn{padding:10px 20px;font-size:14px}}@media (width>=600px){:root{--card-w:84px;--card-h:118px}#hand .card{margin-left:-46px}.card-face .card-rank{font-size:16px}.card-face .card-suit-small{font-size:12px}.card-face .card-suit-center{font-size:32px}.opponent-cards .card-back{width:56px;height:78px;margin-left:-40px}.opponent-right .opponent-cards .card-back{margin-top:-62px;margin-left:0}.opponent-left .opponent-cards .card-back{margin-bottom:-62px;margin-left:0}.opponent-top .opponent-cards{margin-top:11px}.opponent-left{top:16%;left:12%}.opponent-right{top:16%;right:12%}}@media (width>=1100px){:root{--card-w:96px;--card-h:134px}#hand .card{margin-left:-54px}.card-face .card-rank{font-size:18px}.card-face .card-suit-small{font-size:13px}.card-face .card-suit-center{font-size:38px}.opponent-cards .card-back{width:64px;height:90px;margin-left:-46px}.opponent-top .opponent-cards{margin-top:13px}.opponent-left{top:12%;left:20%}.opponent-right{top:12%;right:20%}#play-area{top:40%}.opponent-right .opponent-cards .card-back{margin-top:-72px;margin-left:0}.opponent-left .opponent-cards .card-back{margin-bottom:-72px;margin-left:0}}@media (height<=500px) and (orientation:landscape){:root{--card-w:48px;--card-h:67px}#hand .card{margin-left:-26px}.card-face .card-rank{font-size:11px}.card-face .card-suit-small{font-size:10px}.card-face .card-suit-center{font-size:18px}.opponent-top{top:calc(4px + var(--safe-top))}.opponent-top .opponent-cards{margin-top:6px}.opponent-left{top:20%;left:6px}.opponent-right{top:20%;right:6px}#play-area{top:40%}#player-area{padding:4px 0 calc(8px + var(--safe-bottom));gap:2px}#hand{height:calc(var(--card-h) + 20px)}#play-area{min-height:90px}#game-message{min-height:14px}#action-buttons{gap:8px}#action-buttons .btn{min-height:38px;padding:8px 16px;font-size:13px}.opponent-cards .card-back{width:28px;height:40px;margin-left:-18px}.opponent-right .opponent-cards .card-back{margin-top:-30px;margin-left:0}.opponent-left .opponent-cards .card-back{margin-bottom:-30px;margin-left:0}.opponent-info{padding:2px 6px;font-size:11px}}.results-overlay{z-index:100;background:#000000d9;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.results-modal{background:var(--chrome-surface);border:1px solid var(--chrome-border);border-radius:16px;flex-direction:column;align-items:center;gap:16px;width:90%;max-width:360px;padding:28px 24px;display:flex;position:relative;overflow:hidden}.modal-child-in{animation:.4s cubic-bezier(.25,.46,.45,.94) both modalChildIn}@keyframes modalChildIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.update-toast{bottom:calc(16px + var(--safe-bottom,0px));background:var(--chrome-surface);border:1px solid var(--accent);color:var(--chrome-text);box-shadow:0 6px 18px #00000080, 0 0 16px var(--accent-glow);z-index:9999;border-radius:999px;align-items:center;gap:12px;padding:10px 12px 10px 18px;font-size:14px;animation:.5s cubic-bezier(.25,.46,.45,.94) forwards updateToastIn;display:flex;position:fixed;left:50%;transform:translate(-50%)translateY(80px)}@keyframes updateToastIn{0%{opacity:0;transform:translate(-50%)translateY(80px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.update-toast button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:700}.update-toast button:hover{filter:brightness(1.12)}body.reduced-motion .update-toast{animation:none!important;transform:translate(-50%)translateY(0)!important}body.reduced-motion .card.dealing{opacity:1!important;animation:none!important}body.reduced-motion .chop-flash,body.reduced-motion .chop-flash-heavy,body.reduced-motion .smoke-particle{display:none!important}body.reduced-motion .screen-shake,body.reduced-motion .screen-shake-heavy{animation:none!important}body.reduced-motion .effect-text,body.reduced-motion .effect-text-heavy{animation:.6s forwards effectTextCalm!important}@keyframes effectTextCalm{0%{opacity:0;transform:translate(-50%,-50%)scale(.95)}20%{opacity:1;transform:translate(-50%,-50%)scale(1)}80%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(1)}}body.reduced-motion .modal-child-in{animation:.2s both modalChildInCalm!important}@keyframes modalChildInCalm{0%{opacity:0}to{opacity:1}}body.reduced-motion .results-row{transition:opacity .25s!important;transform:none!important}body.reduced-motion .results-row.revealed{transform:none!important}body.reduced-motion .trick-play-group{transition:none!important}.results-close{color:var(--chrome-dim);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex;position:absolute;top:12px;right:12px}.results-close:hover{color:var(--chrome-text);background:#ffffff1a}.results-modal h2{color:var(--card-bg);margin:0;font-size:24px}.results-placements{flex-direction:column;gap:6px;width:100%;display:flex}.results-row{opacity:0;background:#0000004d;border-left:3px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;transition:opacity .4s,transform .4s;display:flex;transform:translate(-20px)}.results-row.revealed{opacity:1;transform:translate(0)}.results-row.standing-gold{border-left-color:var(--gold);background:#d4a0171f}.results-row.standing-silver{background:#c0c0c014;border-left-color:silver}.results-row.standing-bronze{background:#cd7f3214;border-left-color:#cd7f32}.results-row .placement-name{flex:1}.results-row.is-self .placement-name{font-weight:700}.results-row.is-self{box-shadow:inset 0 0 0 1px var(--accent-glow)}.results-total{color:var(--chrome-text);text-align:right;min-width:48px;font-size:14px;font-weight:700}.results-gained{color:var(--green);text-align:right;opacity:0;min-width:28px;font-size:13px;font-weight:700;transition:opacity .3s}.results-gained.visible{opacity:1}.results-gained.gained-placement{color:#5b9bf5}.results-gained.gained-instant{color:var(--gold);text-shadow:0 0 8px #d4a01780;font-size:15px}.results-gained.gained-chop{color:#e74c3c;text-shadow:0 0 8px #e74c3c66}.results-gained.gained-chop-loss{color:#95a5a6;text-shadow:0 0 8px #95a5a64d}.results-highlights{color:#e74c3c;text-align:center;font-size:14px;font-weight:600;line-height:1.8}.card-error{animation:.4s cardShake;border-color:#f44!important;box-shadow:0 0 8px #ff444480!important}@keyframes cardShake{0%,to{transform:translateY(-16px)translate(0)}20%{transform:translateY(-16px)translate(-4px)}40%{transform:translateY(-16px)translate(4px)}60%{transform:translateY(-16px)translate(-3px)}80%{transform:translateY(-16px)translate(2px)}}.quit-btn{top:calc(12px + var(--safe-top));z-index:20;width:44px;height:44px;color:var(--chrome-dim);cursor:pointer;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;line-height:1;display:flex;position:absolute;left:12px}.quit-btn:hover{color:var(--chrome-text);background:#0009}.tutorial-mode .quit-btn{position:absolute}.tutorial-mode .quit-btn:after{content:attr(title);color:var(--chrome-dim);white-space:nowrap;pointer-events:none;margin-left:6px;font-size:11px;position:absolute;top:50%;left:100%;transform:translateY(-50%)}.online-lobby-inner{width:92%;max-width:560px;padding:calc(24px + var(--safe-top)) 16px calc(32px + var(--safe-bottom));flex-direction:column;gap:20px;margin:0 auto;display:flex}.online-lobby-header{text-align:center}.online-lobby-header h2{letter-spacing:2px;text-transform:uppercase;opacity:.85;margin:0 0 12px;font-size:20px}.online-lobby-code-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}.online-lobby-code-label{letter-spacing:2px;text-transform:uppercase;opacity:.6;font-size:11px}.online-lobby-code{letter-spacing:6px;color:var(--accent);background:#00000040;border:1px solid #ffffff1f;border-radius:6px;padding:4px 12px;font-family:Courier New,ui-monospace,monospace;font-size:26px;font-weight:800}.online-lobby-rules{border:1px solid var(--chrome-border);background:#ffffff08;border-radius:8px;margin:8px 0 12px;padding:10px 14px}.online-lobby-rules-heading{text-transform:uppercase;letter-spacing:1px;color:var(--chrome-dim);margin-bottom:6px;font-size:11px;font-weight:700}.online-lobby-rules-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.online-lobby-rules-list li{color:var(--chrome-text);padding-left:14px;font-size:12px;position:relative}.online-lobby-rules-list li:before{content:"✓";color:var(--gold);font-weight:700;position:absolute;left:0}.online-lobby-seats{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width<=480px){.online-lobby-seats{grid-template-columns:1fr}}.online-lobby-seat{background:#00000040;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:12px;min-height:68px;padding:12px 14px;transition:border-color .2s,background .2s;display:flex}.online-lobby-seat.seat-you{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.online-lobby-seat.seat-empty{opacity:.75;border-style:dashed}.online-lobby-seat.seat-bot{background:#00000026}.seat-avatar{background:#ffffff0d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:28px;line-height:1;display:flex;position:relative}.seat-avatar.ring-bronze{border:2px solid #b87333}.seat-avatar.ring-silver{border:2px solid silver}.seat-avatar.ring-gold{border:2px solid #d4a017}.online-lobby-seat.seat-entering{animation:.35s cubic-bezier(.2,.9,.3,1.1) both seat-enter}@keyframes seat-enter{0%{opacity:0;transform:translateY(-8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.online-lobby-seat.seat-entering{animation:.25s ease-out both seat-enter-fade}@keyframes seat-enter-fade{0%{opacity:0}to{opacity:1}}}.seat-host-badge{background:var(--chrome-bg,#111);border:1.5px solid var(--gold,#d4a017);pointer-events:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;line-height:1;display:flex;position:absolute;top:-4px;right:-4px;box-shadow:0 1px 3px #0006}.seat-body{flex-direction:column;flex:auto;gap:2px;min-width:0;display:flex}.seat-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.seat-meta{opacity:.6;letter-spacing:1px;text-transform:uppercase;font-size:11px}.seat-meta.ready{color:var(--green,#4ade80)}.seat-actions{flex-direction:column;flex-shrink:0;gap:4px;display:flex}.seat-actions .btn-chip{min-width:60px;padding:4px 10px;font-size:11px}.seat-you .seat-actions .btn-chip:not(.active){animation:2.4s ease-in-out infinite ready-pulse}@keyframes ready-pulse{0%,to{border-color:var(--chrome-border);box-shadow:0 0 #fff0}50%{border-color:var(--accent);box-shadow:0 0 12px 2px var(--accent-glow)}}@media (prefers-reduced-motion:reduce){.seat-you .seat-actions .btn-chip:not(.active){animation:none}}.seat-actions select.btn-chip{appearance:none;cursor:pointer;text-align:center;text-align-last:center;background-image:none;font-family:inherit}.seat-actions select.btn-chip option{color:#f0f0f0;background:#1a1a1a}.online-lobby-footer{flex-direction:column;align-items:center;gap:10px;margin-top:4px;display:flex}.online-lobby-footer .btn{min-width:220px}.online-lobby-hint{opacity:.6;text-align:center;margin:0;font-size:12px}.online-auth-prompt{flex-direction:column;gap:10px;margin-top:12px;display:flex}.online-auth-text{text-align:center;color:var(--chrome-dim);margin:0;font-size:13px}.online-mode-buttons{flex-direction:column;gap:10px;margin-top:12px;display:flex}.online-join-row{flex-direction:column;gap:8px;margin-top:12px;display:flex}.online-join-row input{letter-spacing:8px;text-align:center;text-transform:uppercase;color:var(--accent);background:#0000004d;border:1px solid #ffffff26;border-radius:6px;flex:1;padding:10px;font-family:Courier New,ui-monospace,monospace;font-size:22px;font-weight:800}.online-join-row input:focus{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow);outline:none}.online-join-error{color:#ff6b6b;text-align:center;margin:8px 0 0;font-size:12px}.modal-cancel{width:100%;margin-top:16px}
