:root{--void: #20262a;--void-deep: #14181b;--void-edge: #0e1113;--panel: #262d31;--panel-2: #2e363b;--panel-line: #46525a;--well: #15191c;--felt: #2f7057;--felt-2: #245c46;--felt-deep: #173d2e;--cream: #f6f4ec;--cream-2: #e9e6d8;--cream-edge: #d9d5c2;--ink: #232833;--text: #f3f1e9;--muted: #a9bab4;--red: #eb4d3d;--red-d: #a52c1f;--red-light: #ff9d8f;--blue: #2e94e8;--blue-d: #1b62a8;--green: #35b654;--green-d: #1f7a37;--orange: #f5a338;--orange-d: #b06f1c;--gold: #ffce4d;--gold-d: #a8842a;--purple: #7d5fff;--purple-d: #4a37a0;--font-display: "Russo One", "Rubik", system-ui, sans-serif;--font-body: "Rubik", system-ui, sans-serif;--font-num: "Archivo", system-ui, sans-serif;--font-pixel: "Press Start 2P", monospace;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 24px;--s-6: 32px;--r-card: 10px;--r-btn: 10px;--r-panel: 12px;--card-w: clamp(44px, 11.5vw, 72px);--card-h: calc(var(--card-w) * 1.44);--control-h: clamp(40px, 5vw, 46px);--back-w: calc(var(--card-w) * .4);--back-h: calc(var(--back-w) * 1.44);--seat-w: clamp( 66px, 19vw, 128px );--gutter: clamp(10px, 2.2vw, 26px)}*{box-sizing:border-box;margin:0;padding:0}html{background:var(--void-edge)}body{min-height:100vh;min-height:100dvh;background:var(--void-edge);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}.swirl{position:absolute;left:50%;top:50%;width:max(160vw,160vh);height:max(160vw,160vh);margin-left:calc(max(160vw,160vh)/-2);margin-top:calc(max(160vw,160vh)/-2);z-index:0;pointer-events:none;background:radial-gradient(42% 38% at 30% 32%,rgba(226,49,74,.9),transparent 62%),radial-gradient(38% 42% at 72% 26%,rgba(48,108,233,.85),transparent 64%),radial-gradient(46% 42% at 62% 76%,rgba(158,28,48,.85),transparent 64%),radial-gradient(36% 34% at 22% 78%,rgba(32,68,158,.9),transparent 60%),radial-gradient(30% 30% at 50% 50%,rgba(125,95,255,.5),transparent 70%),#150c26;filter:blur(clamp(30px,6vw,70px)) saturate(1.25);animation:wf-swirl 52s linear infinite}@keyframes wf-swirl{to{transform:rotate(360deg)}}#root{position:relative;z-index:1;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center}.frame{position:relative;width:100%;flex:1;display:flex;flex-direction:column;background:radial-gradient(120% 90% at 50% 16%,#262d31 0%,var(--void) 45%,var(--void-deep) 100%);box-shadow:inset 0 0 140px #00000080;overflow:hidden;padding:clamp(12px,2.4vw,24px) var(--gutter)}.frame:has(.arena),.frame:not(.hero):has(.lobby){background:radial-gradient(50% 44% at 68% 24%,rgba(255,255,255,.07),transparent 70%),radial-gradient(42% 40% at 22% 60%,rgba(9,40,28,.5),transparent 72%),radial-gradient(46% 42% at 80% 76%,rgba(9,40,28,.45),transparent 70%),radial-gradient(120% 100% at 50% 30%,var(--felt) 0%,var(--felt-2) 55%,var(--felt-deep) 100%)}.frame:before,.frame:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}.frame:before{background:radial-gradient(130% 120% at 50% 40%,transparent 58%,rgba(0,0,0,.45) 100%)}.frame:after{background:repeating-linear-gradient(rgba(0,0,0,.14) 0 1px,transparent 1px 3px);mix-blend-mode:multiply;opacity:.35}.scene{position:relative;z-index:2;display:flex;flex-direction:column;gap:var(--s-4);width:100%;max-width:1240px;margin:0 auto;flex:1}.event-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;pointer-events:none}.bar{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);flex-wrap:wrap;min-height:40px}.bar>.row:last-child{margin-left:auto}.frame.hero .bar{position:absolute;top:0;right:0;z-index:5;min-height:0}.brand{font-family:var(--font-pixel);font-size:clamp(13px,2.8vw,17px);letter-spacing:1px;color:var(--text);text-shadow:0 2px 0 rgba(0,0,0,.6),0 0 18px rgba(255,206,77,.25);text-wrap:balance}.brand .accent{color:var(--gold)}.code-copy{display:inline-flex;align-items:center;gap:8px;min-height:38px;font-family:var(--font-body);color:var(--text);background:var(--well);border:1px solid var(--panel-line);border-radius:10px;padding:4px 12px;cursor:pointer;box-shadow:inset 0 2px 6px #00000073}.code-copy:hover{border-color:var(--gold-d)}.code-copy .code-val{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-weight:700;font-size:14px;letter-spacing:3px;color:var(--gold)}.code-copy .code-act{font-size:12px;color:var(--muted);border:1px solid rgba(255,255,255,.16);border-radius:6px;padding:2px 8px}.code-copy:hover .code-act{border-color:var(--gold-d)}.code-copy.big{flex-direction:column;align-items:center;gap:6px;width:100%;padding:16px;background:linear-gradient(180deg,#1c2124,#101416);border:2px dashed var(--gold-d);box-shadow:inset 0 0 26px #00000080,0 0 26px #ffce4d14}.code-copy.big .code-label{font-family:var(--font-display);font-size:13px;letter-spacing:2px;color:var(--gold)}.code-copy.big .code-val{font-size:clamp(28px,7vw,42px);letter-spacing:8px;line-height:1;color:#fff;text-shadow:0 3px 0 rgba(0,0,0,.55),0 0 26px rgba(255,206,77,.4)}.code-copy.big .code-act{font-size:13px}.code-panel{align-items:center;text-align:center;gap:var(--s-3)}.trump{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--panel-line);border-radius:var(--r-panel);padding:6px 14px 6px 8px;box-shadow:0 3px #0006,inset 0 0 0 1px #ffce4d24;animation:bob 3.6s ease-in-out infinite}.trump .em{width:32px;height:42px;border-radius:7px;background:linear-gradient(#fff,#efece0);display:flex;align-items:center;justify-content:center;font-family:var(--font-num);font-weight:900;font-size:22px;color:var(--ink);box-shadow:0 3px 0 var(--gold-d),0 0 16px #ffce4d73}.trump .em.red{color:var(--red)}.trump small{display:block;font-family:var(--font-display);font-size:10px;letter-spacing:2px;color:var(--gold)}.trump strong{font-size:15px;color:var(--text)}.status{font-size:14px;color:var(--text);text-align:center;background:var(--panel);border:1px solid var(--panel-line);border-radius:999px;padding:8px 16px;align-self:center;text-wrap:balance;box-shadow:0 3px #00000059}.status .taking{color:var(--red-light);font-weight:700}.role-banner{font-family:var(--font-display);font-size:clamp(18px,4vw,26px);font-weight:400;line-height:1.25;letter-spacing:.5px;text-align:center;text-wrap:balance;align-self:center;width:max-content;max-width:100%;padding:10px 22px;border-radius:var(--r-panel);color:#fff;background:var(--panel);border:1px solid var(--panel-line);box-shadow:0 4px #00000059,inset 0 2px #ffffff24;text-shadow:0 2px 0 rgba(0,0,0,.35)}.role-banner.attack,.role-banner.throwin{background:var(--gold);border-color:var(--gold-d);color:var(--ink);text-shadow:none;box-shadow:0 4px 0 var(--gold-d),inset 0 2px #ffffff59}.role-banner.defend{background:#2456c4;border-color:#163a88;box-shadow:0 4px #163a88,inset 0 2px #ffffff2e}.role-banner.finish{background:#1e7a3e;border-color:#135227;box-shadow:0 4px #135227,inset 0 2px #ffffff2e}.role-banner.fool{background:#b02f24;border-color:#7c1e15;box-shadow:0 4px #7c1e15,inset 0 2px #ffffff29}.role-banner.over{color:var(--text)}.role-banner.wait{color:var(--muted);font-size:clamp(15px,3vw,19px)}.role-banner.attack,.role-banner.throwin,.role-banner.defend,.role-banner.finish{animation:rolePulse 1.9s ease-in-out infinite}@keyframes rolePulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.12)}}.arena{display:flex;flex-direction:column;gap:var(--s-3);margin:var(--s-2) 0 var(--s-1);padding:var(--s-3) 0 var(--s-4)}.sky{position:relative;min-height:clamp(150px,22vh,220px)}.seat{position:absolute;transform:translate(-50%);width:var(--seat-w);display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 10px 10px;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1.5px solid var(--panel-line);border-radius:14px;box-shadow:0 3px #00000059;opacity:.72;transition:opacity .2s ease,box-shadow .2s ease,border-color .2s ease}.seat.attacker{border-color:var(--gold-d)}.seat.defender{border-color:var(--blue)}.seat.taking{border-color:var(--red)}.seat.active{opacity:1;border-color:var(--gold);box-shadow:0 3px #00000059,0 0 26px #ffce4d66,inset 0 0 0 1px #ffce4d40}.seat.off{opacity:.45}.seat .pname{font-size:13px;color:var(--text);text-align:center;background:none;border:none;padding:0;overflow-wrap:anywhere;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.seat.active .pname{color:var(--gold)}.seat-tag{font-size:11px;letter-spacing:1px;padding:1px 8px;border-radius:10px;background:var(--gold);color:var(--ink);font-weight:700;box-shadow:0 2px #00000059}.seat.defender .seat-tag{background:var(--blue);color:#fff}.seat-tag.taking{background:var(--red);color:#fff}.seat .seat-tag{font-size:9px;letter-spacing:.5px;padding:1px 5px}.backs{display:flex;height:var(--back-h)}.back{width:var(--back-w);height:var(--back-h);border-radius:5px;margin-left:calc(var(--back-w) * -.55);background:radial-gradient(circle at 50% 50%,rgba(255,206,77,.16) 0 18%,transparent 20%),repeating-linear-gradient(45deg,#4a3787 0,#4a3787 5px,#332561 5px,#332561 10px);border:1.5px solid #5d49a0;box-shadow:0 3px 6px #0006}.back:first-child{margin-left:0}.cnt{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.you-plate{display:flex;align-items:center;justify-content:center;gap:var(--s-3);align-self:center;padding:5px 16px;border-radius:999px;border:1.5px solid var(--panel-line);background:linear-gradient(180deg,var(--panel-2),var(--panel));box-shadow:0 3px #00000059;opacity:.9}.you-plate.active{opacity:1;border-color:var(--gold);box-shadow:0 3px #00000059,0 0 22px #ffce4d59}.you-plate.defender{border-color:var(--blue)}.you-plate.taking{border-color:var(--red)}.you-plate .pname{color:var(--text);font-size:15px}.you-plate.active .pname{color:var(--gold)}.center-band{display:flex;align-items:center;justify-content:space-between;gap:var(--s-4);width:100%;max-width:640px;margin:0 auto;min-height:var(--card-h);padding:var(--s-2) var(--s-5) var(--s-5)}.center-band .pile{flex:0 0 auto}.center-band .pairs{flex:1 1 auto}.pile{position:relative;width:var(--card-w);height:var(--card-h)}.pile .d{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--r-card);background:radial-gradient(circle at 50% 50%,rgba(255,206,77,.16) 0 16%,transparent 18%),repeating-linear-gradient(45deg,#4a3787 0,#4a3787 5px,#332561 5px,#332561 10px);border:1.5px solid #5d49a0;box-shadow:0 6px 12px #00000073}.pile .d.discard{background:linear-gradient(#1e4a39,#123125);border-color:#2b6950}.pile .d2{transform:translate(3px,-3px)}.pile .d3{transform:translate(6px,-6px)}.pile .tag{position:absolute;bottom:-22px;left:50%;transform:translate(-50%);width:max-content;font-size:11px;letter-spacing:.5px;color:#dbe7e1;font-variant-numeric:tabular-nums;white-space:nowrap;background:#15191c;border:1px solid var(--panel-line);border-radius:999px;padding:1px 8px}.center-band .pile:first-child .tag{left:0;transform:none}.center-band .pile:last-child .tag{left:auto;right:0;transform:none}.pairs{display:flex;flex-wrap:wrap;gap:28px var(--s-3);justify-content:center;align-items:center}.pair{position:relative;width:var(--card-w);height:var(--card-h)}.pair .def{position:absolute;top:14%;left:26%;transform:rotate(12deg)}.pair.open .card{outline:2px solid var(--gold);outline-offset:2px;box-shadow:0 6px #00000038,0 12px 20px #00000073,0 0 16px #ffce4d8c}.pair.taking .card{outline:2px solid var(--red);outline-offset:2px;box-shadow:0 6px #00000038,0 12px 20px #00000073,0 0 16px #eb4d3d99}.pair-badge{position:absolute;bottom:-16px;left:50%;transform:translate(-50%);z-index:3;font-size:9px;font-weight:700;letter-spacing:.3px;padding:1px 6px;border-radius:8px;white-space:nowrap;color:var(--ink);background:var(--gold);border:1px solid var(--gold-d)}.empty{color:#d5e3dc;font-size:14px;padding:10px 18px;border:1.5px dashed rgba(255,255,255,.3);border-radius:12px}.card{width:var(--card-w);height:var(--card-h);border-radius:var(--r-card);background:linear-gradient(#ffffff,var(--cream-2));border:1px solid var(--cream-edge);box-shadow:0 6px #00000040,0 12px 20px #00000059;position:relative;color:var(--ink);font-family:var(--font-num);font-weight:900;-webkit-user-select:none;user-select:none}.card.red{color:#e03a30}.card .r{position:absolute;top:5px;left:7px;font-size:calc(var(--card-w) * .28);line-height:.9;text-align:center;font-variant-numeric:tabular-nums}.card .r small{display:block;font-size:calc(var(--card-w) * .2)}.card .r.b{top:auto;left:auto;bottom:5px;right:7px;transform:rotate(180deg)}.card .pip{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:calc(var(--card-w) * .55)}.card.joker{background:radial-gradient(circle at 50% 32%,#2a2142,#161029);border:1px solid var(--gold);color:var(--gold);box-shadow:0 6px #0000004d,0 12px 20px #00000080,inset 0 0 18px #ffce4d26}.card.joker .pip{text-shadow:0 0 14px rgba(255,206,77,.7)}.card.joker .r{font-family:var(--font-display);font-weight:400;font-size:calc(var(--card-w) * .2);letter-spacing:1px}.hand-wrap{padding-top:var(--s-4)}.hand-label{align-self:center;width:max-content;max-width:100%;margin:0 auto var(--s-2);text-align:center;font-size:14px;color:#e9efec;background:#00000073;border-radius:999px;padding:4px 14px;font-variant-numeric:tabular-nums}.hand-wrap{display:flex;flex-direction:column}.hand{display:flex;justify-content:center;align-items:flex-end;padding:38px var(--s-3) 32px;overflow:visible}.card-hit{background:none;border:none;padding:0;flex:0 0 auto;position:relative;cursor:grab;border-radius:var(--r-card);transform-origin:bottom center;transition:transform .2s cubic-bezier(.34,1.56,.64,1);touch-action:none}.card-deal,.card-tilt,.card-arc{display:block;transform-origin:bottom center}.card-hit:hover{z-index:5;transform:translateY(-20px) scale(1.08)}.card-hit.sel{outline:3px solid var(--gold);outline-offset:2px;transform:translateY(-14px)}.card-hit.sel:hover{transform:translateY(-26px) scale(1.08)}.card-hit.dragging{opacity:.22}.card-hit:active{cursor:grabbing}.card-hit.sel .card{box-shadow:0 6px #00000038,0 12px 20px #00000073,0 0 22px #ffce4d80}.foot{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:var(--s-3)}@media(max-width:999px){.foot{flex-direction:column;align-items:stretch}.foot>.log{flex:0 0 auto;width:100%;max-height:96px}}.log{font-size:13px;color:var(--text);background:var(--well);border:1px solid var(--panel-line);border-radius:10px;padding:8px 12px;flex:1 1 240px;max-height:150px;overflow-y:auto;box-shadow:inset 0 2px 8px #00000073}.log ul{list-style:none;display:flex;flex-direction:column;gap:3px}.acts{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr));gap:var(--s-2);align-content:flex-start;flex:1 1 260px;overflow-y:auto;max-height:232px;padding-bottom:12px;margin-bottom:-12px}.btn{font-family:var(--font-display);font-weight:400;font-size:15px;letter-spacing:.4px;color:#fff;border:none;border-radius:var(--r-btn);height:var(--control-h);padding:0 18px;display:inline-flex;align-items:center;justify-content:center;line-height:1;cursor:pointer;text-shadow:0 1px 1px rgba(0,0,0,.35);transition:transform .12s ease-out,filter .12s ease-out}.btn:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.08)}.btn:active{transform:translateY(3px) scale(.97);filter:brightness(1.35)}.btn:disabled{filter:saturate(.35) brightness(.62);cursor:default}.btn:focus-visible,.card-hit:focus-visible,.input:focus-visible,.code-copy:focus-visible,.suit-tile:focus-visible,.rank-tile:focus-visible{outline:3px solid var(--gold);outline-offset:3px}.btn.green{background:var(--green);color:var(--ink);text-shadow:none;box-shadow:0 4px 0 var(--green-d)}.btn.red{background:var(--red);box-shadow:0 4px 0 var(--red-d)}.btn.blue{background:var(--blue);box-shadow:0 4px 0 var(--blue-d)}.btn.purple{background:var(--purple);box-shadow:0 4px 0 var(--purple-d)}.btn.gold{background:var(--gold);color:var(--ink);text-shadow:none;box-shadow:0 4px 0 var(--gold-d)}.btn.cream{background:var(--cream);color:var(--ink);text-shadow:none;box-shadow:0 4px 0 var(--cream-edge)}.btn.ghost{background:var(--panel-2);color:var(--text);box-shadow:0 4px #0d1012;border:1px solid var(--panel-line)}.btn.sm{font-size:14px;height:calc(var(--control-h) - 4px);padding:0 13px}.acts .btn{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;line-height:calc(var(--control-h) - 6px)}.btn.xl{font-size:clamp(15px,4.4vw,18px);height:calc(var(--control-h) + 8px);padding:0 22px}.lobby .btn.xl{width:100%}.lobby{display:flex;flex-direction:column;gap:var(--s-4);width:100%;max-width:520px;margin:0 auto;padding-top:var(--s-3)}.panel{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--panel-line);border-radius:var(--r-panel);padding:var(--s-4);display:flex;flex-direction:column;gap:var(--s-3);box-shadow:0 4px #00000059,inset 0 1px #ffffff0f}.panel h2{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:400;font-size:14px;color:var(--gold);letter-spacing:2px;text-shadow:0 2px 0 rgba(0,0,0,.5)}.panel h2:before,.panel h2:after{content:"";flex:1;height:2px;border-radius:1px;background:linear-gradient(90deg,transparent,var(--panel-line))}.panel h2:after{background:linear-gradient(90deg,var(--panel-line),transparent)}.field{display:flex;flex-wrap:wrap;gap:var(--s-2);align-items:center}.field label{display:flex;gap:var(--s-2);align-items:center;flex-wrap:wrap}.field.trump-change{flex-direction:column;align-items:stretch;gap:var(--s-3)}.trump-slider{display:flex;align-items:center;gap:var(--s-2);flex-wrap:wrap}.trump-name{flex:0 0 auto}.trump-slider input[type=range]{flex:1;min-width:120px;accent-color:var(--gold);cursor:pointer}.trump-slider input[type=range]:disabled{cursor:default;opacity:.4}.trump-val{font-variant-numeric:tabular-nums;color:var(--gold);min-width:6ch;text-align:center;font-size:13px;background:var(--well);border:1px solid var(--panel-line);border-radius:8px;padding:3px 8px}.input{font-family:var(--font-body);font-size:16px;padding:0 12px;height:var(--control-h);border-radius:10px;border:1px solid var(--panel-line);background:var(--well);color:var(--text);box-shadow:inset 0 2px 6px #00000080}.input::placeholder{color:var(--muted);opacity:.7}input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:22px;height:22px;flex:0 0 auto;border-radius:6px;background:var(--well);border:1px solid var(--panel-line);box-shadow:inset 0 2px 5px #0000008c;cursor:pointer}input[type=checkbox]:checked{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3 8.5 6.5 12 13 4.5' fill='none' stroke='%23232833' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / 72% no-repeat,var(--gold);border-color:var(--gold-d);box-shadow:0 2px 0 var(--gold-d)}input[type=checkbox]:focus-visible{outline:3px solid var(--gold);outline-offset:2px}.players{list-style:none;display:flex;flex-direction:column;gap:6px;background:var(--well);border:1px solid rgba(0,0,0,.45);border-radius:10px;padding:var(--s-2);box-shadow:inset 0 2px 8px #00000073}.players li{display:flex;align-items:center;gap:8px;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--panel-line);border-radius:8px;padding:7px 12px;overflow-wrap:anywhere;box-shadow:0 2px #0000004d}.players li:before{content:"♠";color:var(--gold);flex:0 0 auto}.players li:nth-child(4n+2):before{content:"♥";color:var(--red-light)}.players li:nth-child(4n+3):before{content:"♣";color:var(--green)}.players li:nth-child(4n):before{content:"♦";color:var(--blue)}.muted{color:var(--muted)}.tag{font-size:11px;color:var(--gold)}.err{color:var(--red-light);text-align:center;background:#7a1a0f80;border:1px solid var(--red-d);border-radius:10px;padding:8px 12px}.row{display:flex;flex-wrap:wrap;gap:var(--s-2);align-items:center}.bots{justify-content:space-between}.lobby>.row{justify-content:center}.lobby>p.muted{align-self:center;width:max-content;max-width:100%;text-align:center;background:#00000073;border-radius:999px;padding:6px 16px;color:#dfe9e4}@media(min-width:1000px){.lobby:not(.join){display:grid;grid-template-columns:1fr 1fr;align-items:start;max-width:980px;column-gap:var(--s-4)}.lobby:not(.join)>:nth-child(1){grid-column:1}.lobby:not(.join)>:nth-child(2){grid-column:1}.lobby:not(.join)>:nth-child(3){grid-column:2;grid-row:1 / span 2}.lobby:not(.join)>:nth-child(n+4){grid-column:1 / -1}}.sound-panel{flex-direction:row;align-items:center;gap:var(--s-3)}.volume{display:flex;align-items:center;gap:var(--s-2);flex:1}.volume input[type=range]{flex:1;accent-color:var(--gold);cursor:pointer}.volume-icon{display:inline-flex;color:var(--muted)}.volume-val{font-variant-numeric:tabular-nums;color:var(--muted);min-width:3.5ch;text-align:right;font-size:13px}.join{margin:auto;padding:clamp(20px,4.5vh,56px) 0}.title-hero{position:relative;text-align:center;padding:clamp(6px,1.6vw,16px) var(--s-3) clamp(6px,1.6vw,14px)}.brand-big{position:relative;z-index:1;font-family:var(--font-pixel);font-weight:400;font-size:clamp(28px,7.5vw,62px);line-height:1.2;letter-spacing:2px;color:#fff;text-shadow:0 5px 0 rgba(0,0,0,.55),0 0 34px rgba(0,0,0,.4);text-wrap:balance}.brand-big .accent{color:var(--gold);text-shadow:0 5px 0 rgba(0,0,0,.55),0 0 34px rgba(255,206,77,.55)}.hero-sub{position:relative;z-index:1;display:inline-block;margin-top:var(--s-3);color:#e8e4f2;font-size:15px;letter-spacing:.5px;background:#0a0a1299;border-radius:999px;padding:6px 18px}.hero-suits{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hero-suits span{position:absolute;font-size:clamp(26px,6vw,46px);opacity:.3;text-shadow:0 3px 6px rgba(0,0,0,.4);animation:heroFloat 6.5s ease-in-out infinite}.hero-suits span:nth-child(1){left:4%;top:4%;color:#f2ecdc}.hero-suits span:nth-child(2){right:4%;top:2%;color:#ffb3a6;animation-delay:-2s}.hero-suits span:nth-child(3){left:10%;bottom:0;color:#a8ccf5;animation-delay:-3.4s}.hero-suits span:nth-child(4){right:9%;bottom:4%;color:#cdbcff;animation-delay:-5s}@keyframes heroFloat{0%,to{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-12px) rotate(6deg)}}@media(max-width:560px){.hero-suits span{font-size:24px;opacity:.22}.hero-suits span:nth-child(3),.hero-suits span:nth-child(4){display:none}}.join .btn,.join .field label{width:100%}.join .input{flex:1;min-width:0}.menu-sep{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:13px;letter-spacing:.5px;margin:var(--s-1) 0}.menu-sep:before,.menu-sep:after{content:"";flex:1;height:1px;background:var(--panel-line)}.join .code-row{align-items:center}.join .code-row label{flex:1 1 180px;width:auto;min-width:0}.join .code-row .btn{flex:1 1 130px;width:auto}.icon-btn{display:inline-flex;align-items:center;justify-content:center;line-height:1;background:linear-gradient(180deg,var(--panel-2),var(--panel));color:var(--text);border:1px solid var(--panel-line);border-radius:10px;min-width:40px;min-height:40px;cursor:pointer;box-shadow:0 3px #00000059;transition:filter .12s ease-out}.icon-btn:hover{filter:brightness(1.15)}.icon-btn:focus-visible{outline:3px solid var(--gold);outline-offset:3px}.drag-ghost{position:fixed;z-index:100;pointer-events:none;transform:translate(-50%,-55%) rotate(-5deg);filter:drop-shadow(0 18px 22px rgba(0,0,0,.6));opacity:.96}.arena.droppable{outline:2px dashed var(--gold);outline-offset:-6px;border-radius:16px;background:#ffce4d0f}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s-3);background:#070c0a9e;pointer-events:none;perspective:900px}.reveal-card{width:clamp(96px,26vw,140px);height:clamp(138px,37vw,200px);border-radius:var(--r-card);background:linear-gradient(#ffffff,var(--cream-2));border:1px solid var(--cream-edge);box-shadow:0 10px #00000040,0 22px 44px #0009,0 0 50px #ffce4d8c;display:flex;align-items:center;justify-content:center;transform-style:preserve-3d}.reveal-label{font-family:var(--font-num);font-weight:900;font-size:clamp(40px,11vw,60px);color:var(--ink)}.reveal-label.red{color:#e03a30}.reveal-cap{font-family:var(--font-display);font-size:13px;letter-spacing:2px;color:var(--gold);text-transform:uppercase}.joker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:130;display:flex;align-items:center;justify-content:center;padding:var(--s-4);background:#080610b8}.joker-dialog{display:flex;flex-direction:column;align-items:stretch;gap:var(--s-3);width:min(92vw,420px);max-height:86vh;overflow-y:auto;padding:var(--s-4);background:var(--panel);border:1px solid var(--panel-line);border-radius:var(--r-panel);box-shadow:0 10px #00000040,0 22px 44px #0009}.joker-title{font-size:15px;letter-spacing:.5px;color:var(--gold);text-align:center}.suit-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-2)}.suit-tile{height:clamp(64px,17vw,84px);font-size:clamp(30px,8vw,42px);line-height:1;display:flex;align-items:center;justify-content:center;color:var(--ink);background:linear-gradient(var(--cream),var(--cream-2));border:1px solid var(--cream-edge);border-radius:var(--r-card);box-shadow:0 4px 0 var(--cream-edge);cursor:pointer}.suit-tile.red{color:var(--red)}.rank-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:var(--s-2)}.rank-tile{height:var(--control-h);display:flex;align-items:center;justify-content:center;gap:2px;font-family:var(--font-num);font-weight:700;font-size:18px;color:var(--ink);background:linear-gradient(var(--cream),var(--cream-2));border:1px solid var(--cream-edge);border-radius:var(--r-card);box-shadow:0 4px 0 var(--cream-edge);cursor:pointer}.rank-tile small{font-size:12px}.rank-tile.red{color:var(--red)}.suit-tile:hover:not(:disabled),.rank-tile:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.05)}.suit-tile:active,.rank-tile:active{transform:translateY(2px) scale(.97)}.suit-tile:disabled,.rank-tile:disabled{opacity:.3;cursor:default}.target-list{display:flex;flex-direction:column;gap:var(--s-2)}.joker-cancel{align-self:center}.trump .em{animation:trumpGlow .8s ease-out}@keyframes trumpGlow{0%{box-shadow:0 3px 0 var(--gold-d),0 0 #ffce4d00}35%{box-shadow:0 3px 0 var(--gold-d),0 0 34px #ffce4df2}}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@media(prefers-reduced-motion:reduce){*,.card-hit,.pair .card,.trump,.role-banner,.seat,.btn{animation:none!important;transition:none!important}.swirl,.hero-suits span{animation:none!important}.card-hit:hover,.card-hit.sel,.card-hit.sel:hover,.btn:active{transform:none}}@keyframes wf-breathe{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.hand .card{animation:wf-breathe 5.5s ease-in-out infinite}.hand .card-hit:nth-child(2n) .card{animation-delay:-1.9s}.hand .card-hit:nth-child(3n) .card{animation-delay:-3.5s}@keyframes wf-shake{0%,to{transform:translate(0) rotate(0)}15%{transform:translate(-6px) rotate(-3deg)}35%{transform:translate(5px) rotate(2deg)}55%{transform:translate(-4px) rotate(-1.5deg)}75%{transform:translate(3px) rotate(1deg)}90%{transform:translate(-1px)}}.card-hit.shake .card{animation:wf-shake .45s ease-in-out}.side-info{display:none}.si-counts{display:flex;gap:var(--s-2)}.si-box{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border-radius:10px;padding:8px 10px;color:#fff;box-shadow:0 3px #00000059}.si-box small{font-size:11px;letter-spacing:.5px;opacity:.9}.si-box strong{font-family:var(--font-display);font-weight:400;font-size:20px;line-height:1.1;font-variant-numeric:tabular-nums}.si-box.blue{background:#2456c4}.si-box.red{background:#b02f24}@media(min-width:1000px){.scene:has(.arena){display:grid;grid-template-columns:clamp(280px,26vw,340px) 1fr;grid-template-rows:auto auto auto auto 1fr auto auto auto;grid-template-areas:"bar bar" "banner arena" "status arena" "info arena" "log arena" "log you" "log hand" "log acts";column-gap:var(--s-5)}.scene:has(.arena)>.side-info{display:flex;flex-direction:column;gap:var(--s-2);grid-area:info}.scene:has(.arena)>.side-info .trump{justify-content:flex-start}.scene:has(.arena)>.bar .trump{display:none}.scene:has(.arena) .pile .tag{display:none}.scene:has(.arena)>.bar{grid-area:bar}.scene:has(.arena)>.role-banner{grid-area:banner;justify-self:center}.scene:has(.arena)>.status{grid-area:status}.scene:has(.arena)>.arena{grid-area:arena;margin:0}.scene:has(.arena)>.you-plate{grid-area:you;justify-self:center}.scene:has(.arena)>.hand-wrap{grid-area:hand}.scene:has(.arena)>.foot{display:contents}.scene:has(.arena) .log{grid-area:log;align-self:start;width:100%;max-height:42vh;min-height:120px;background:var(--panel)}.scene:has(.arena) .log:before{content:"Лог партии";display:block;font-family:var(--font-display);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);padding-bottom:6px;margin-bottom:8px;border-bottom:1px solid var(--panel-line)}.scene:has(.arena) .acts{grid-area:acts;justify-content:center}}.flip3d{position:relative;transform-style:preserve-3d}.flip3d .card,.flip3d .card-back-face{backface-visibility:hidden}.card-back-face{position:absolute;top:0;right:0;bottom:0;left:0;transform:rotateY(180deg);border-radius:var(--r-card);background:radial-gradient(circle at 50% 50%,rgba(255,206,77,.16) 0 16%,transparent 18%),repeating-linear-gradient(45deg,#4a3787 0,#4a3787 5px,#332561 5px,#332561 10px);border:1.5px solid #5d49a0;box-shadow:0 6px 12px #00000073}
