:root{--ink: #2a1a12;--lacquer: #8e1b1b;--lacquer-dark: #5f0f0f;--lacquer-hi: #b23434;--gold: #e7b53c;--gold-hi: #ffd877;--jade: #1f7a55;--jade-deep: #14573c;--cream: #fff7e6;--parch: #f6e7c4;--red: #c62828;--dark-suit: #2a1a12;--card-w: 58px;--card-h: 82px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Trebuchet MS,Verdana,system-ui,-apple-system,sans-serif;background:#4a0f0f;background-image:repeating-linear-gradient(90deg,#4a0f0f 0,#4a0f0f 38px,#420c0c 38px,#420c0c 41px);color:var(--ink);overflow:hidden;-webkit-user-select:none;user-select:none}.app{max-width:560px;margin:0 auto;height:100%;display:flex;flex-direction:column;background:var(--parch);border-left:5px solid var(--lacquer);border-right:5px solid var(--lacquer)}.loading{display:grid;place-items:center;height:100%;font-size:1.3rem;color:var(--lacquer);font-weight:700}.topbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:8px 12px;background:linear-gradient(var(--lacquer-hi),var(--lacquer));border-bottom:4px solid var(--lacquer-dark)}.brand{font-weight:700;font-size:20px;letter-spacing:1px;color:var(--gold-hi);text-shadow:2px 2px 0 var(--lacquer-dark)}.mode{display:flex;gap:6px}.mode button{font-family:inherit;cursor:pointer;border:2.5px solid var(--ink);background:var(--cream);color:var(--lacquer);font-weight:700;border-radius:10px;padding:5px 12px;box-shadow:2px 2px 0 var(--ink);font-size:13px}.mode button.active{background:var(--gold);color:var(--lacquer-dark)}.mode button:disabled{opacity:.5;cursor:default}.diff{margin-left:auto;font-size:13px;color:var(--gold-hi);font-weight:600;display:flex;align-items:center}.diff select{font-family:inherit;border:2.5px solid var(--ink);border-radius:8px;padding:3px 6px;font-weight:700;background:var(--cream);color:var(--lacquer-dark);cursor:pointer}.table{flex:1;display:flex;flex-direction:column;min-height:0;padding:10px;gap:10px}.felt{position:relative;background:var(--jade);border:3px solid var(--ink);border-radius:16px;box-shadow:inset 0 0 0 3px var(--gold),inset 0 0 0 7px var(--jade-deep),3px 3px 0 var(--ink);padding:10px 6px;flex:1;min-height:0;display:grid;grid-template-columns:82px 1fr 82px;grid-template-rows:auto 1fr;grid-template-areas:"top top top" "left center right";gap:4px;align-items:center}.felt:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:url(/table/emblem.png) center 58% / min(60%,300px) auto no-repeat;opacity:.15}.opponents{display:contents}.center{grid-area:center;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:0}.opp{position:relative;z-index:1;text-align:center;transition:transform .15s;display:flex;flex-direction:column;align-items:center;min-width:0}.opp.active{transform:translateY(-2px)}.opp-mid{grid-area:top;justify-self:center}.opp-left{grid-area:left;justify-self:start;align-self:center}.opp-right{grid-area:right;justify-self:end;align-self:center}.seat-head{position:relative;display:inline-flex}.avatar{border-radius:14px;overflow:hidden;border:3px solid var(--gold);background:var(--cream);box-shadow:0 0 0 2.5px var(--ink),0 0 10px 1px #e7b53c73,2px 2px 0 var(--ink);position:relative;flex:0 0 auto}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.opp.active .avatar{box-shadow:0 0 0 2.5px var(--ink),0 0 15px 4px var(--gold-hi),2px 2px 0 var(--ink)}.status-tab{position:absolute;top:-11px;left:50%;transform:translate(-50%);z-index:3;white-space:nowrap;font-size:10px;font-weight:700;letter-spacing:.3px;padding:1px 8px;border-radius:8px;border:2px solid var(--ink);background:var(--cream);color:var(--lacquer-dark);box-shadow:1.5px 1.5px 0 var(--ink)}.status-tab.on{background:var(--gold-hi);color:var(--lacquer-dark)}.seat-label{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:3px;margin-top:5px;max-width:100%}.seat-name{font-size:11px;color:var(--gold-hi);font-weight:700;background:var(--lacquer-dark);border:1.5px solid var(--ink);border-radius:8px;padding:1px 7px;display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:72px}.opp-mid .seat-name{max-width:120px}.opp.active .seat-name{background:var(--gold);color:var(--lacquer-dark)}.lvl-plaque{font-size:9.5px;font-weight:800;letter-spacing:.3px;color:var(--lacquer-dark);background:linear-gradient(var(--gold-hi),var(--gold));border:1.5px solid var(--ink);border-radius:7px;padding:1px 5px;box-shadow:1px 1px 0 var(--ink);white-space:nowrap;flex:0 0 auto}.backfan{position:relative;display:inline-flex;align-items:flex-end;justify-content:center;height:40px;margin-top:7px;padding:0 6px}.cback{width:22px;height:31px;border-radius:4px;border:2px solid var(--ink);background:url(/table/cardback.png) center / cover;margin-left:-13px;box-shadow:1px 1px #00000059;transform-origin:50% 130%;transform:rotate(calc((var(--k) - (var(--n) - 1) / 2) * 12deg))}.cback:first-child{margin-left:0}.ccount{position:absolute;bottom:-4px;right:-2px;font-size:10.5px;font-weight:800;color:var(--gold-hi);background:var(--lacquer-dark);border:1.5px solid var(--ink);border-radius:8px;padding:0 5px;box-shadow:1px 1px 0 var(--ink)}.turn{background:var(--cream);border:2.5px solid var(--ink);border-radius:8px;box-shadow:2px 2px 0 var(--ink);color:var(--lacquer);font-weight:700;font-size:14px;padding:4px 16px;position:relative;z-index:2}.turn.you{background:var(--gold);color:var(--lacquer-dark)}.turn-arrows{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;display:flex;align-items:center;justify-content:space-between;padding:0 2px}.turn-arrow{font-size:34px;line-height:1;color:var(--gold-hi);opacity:.28;text-shadow:1px 1px 0 var(--jade-deep)}.turn-arrow.ta-r{transform:scaleX(-1)}.play-banner{font-size:12.5px;font-weight:800;letter-spacing:1px;color:var(--lacquer-dark);background:linear-gradient(var(--gold-hi),var(--gold));border:2.5px solid var(--ink);border-radius:999px;padding:3px 16px;box-shadow:2px 2px 0 var(--ink);text-transform:uppercase}.pile{min-height:calc(var(--card-h) + 18px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;position:relative;z-index:1}.pile-cards{display:flex}.pile-cards .card{margin-left:-22px}.pile-cards .card:first-child{margin-left:0}.pile-cards.tight .card{margin-left:-30px}.pile-cards.tight .card:first-child{margin-left:0}.pile-owner{font-size:12px;color:#eafff2;font-weight:600;text-shadow:1px 1px 0 var(--jade-deep)}.pile-empty{color:#eafff2;font-weight:500;font-style:italic;opacity:.92}.me{display:flex;flex-direction:column;align-items:center;gap:8px}.you-row{position:relative;display:flex;align-items:center;gap:8px}.you-row.active .avatar{box-shadow:0 0 0 2.5px var(--ink),0 0 15px 4px var(--gold-hi),2px 2px 0 var(--ink)}.you-row .status-tab{position:static;transform:none;box-shadow:1.5px 1.5px 0 var(--ink)}.you-name{font-size:13px;font-weight:700;color:var(--lacquer-dark)}.you-name em{font-style:normal;font-weight:500;opacity:.7}.hand{display:flex;justify-content:center;align-items:flex-end;max-width:100%;padding-top:24px;min-height:calc(var(--card-h) + 34px)}.hand .card{--rot: calc((var(--i) - (var(--n) - 1) / 2) * 4deg);margin-left:-18px;transform-origin:50% 320%;transform:rotate(var(--rot));transition:transform .12s}.hand .card:first-child{margin-left:0}.hand .card:not(:disabled):hover{transform:rotate(var(--rot)) translateY(-12px);z-index:5}.hand .card.selected{transform:rotate(var(--rot)) translateY(-22px);z-index:6}.controls{display:flex;gap:14px;padding-bottom:6px}.btn{font-family:inherit;cursor:pointer;position:relative;border:3px solid var(--ink);border-radius:16px;font-weight:700;font-size:16px;padding:10px 28px;box-shadow:3px 3px 0 var(--ink);color:var(--lacquer-dark)}.btn.play{background:linear-gradient(var(--gold-hi) 0 45%,var(--gold) 45% 100%)}.btn.pass{background:linear-gradient(var(--cream) 0 45%,#f3e4c0 45% 100%);color:#8a6a3a}.btn:active:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.btn:disabled{opacity:.45;cursor:default}.btn.big{font-size:18px;padding:12px 34px;margin-top:12px}.toast{position:fixed;bottom:92px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--gold-hi);border:2.5px solid #000;border-radius:12px;padding:9px 16px;font-size:.9rem;font-weight:500;max-width:90vw;text-align:center;box-shadow:3px 3px #0006}@media (max-width: 440px){:root{--card-w: 50px;--card-h: 72px}.felt{grid-template-columns:72px 1fr 72px}.hand .card{margin-left:-22px}.brand{font-size:17px}.seat-name{max-width:56px}.cback{width:19px;height:27px;margin-left:-12px}}@keyframes np-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}@keyframes np-bob{0%,to{transform:translateY(-2px)}50%{transform:translateY(-9px)}}@keyframes np-deal{0%{opacity:0;transform:translateY(28px) rotate(-7deg)}to{opacity:1}}@keyframes np-slap{0%{opacity:0;transform:scale(1.5) rotate(-9deg)}60%{opacity:1;transform:scale(.93) rotate(2deg)}to{transform:scale(1) rotate(0)}}@keyframes np-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes np-dance{0%,to{transform:rotate(-7deg) scale(1.06)}25%{transform:rotate(7deg) scale(1.13) translateY(-4px)}50%{transform:rotate(-5deg) scale(1.08)}75%{transform:rotate(6deg) scale(1.13) translateY(-3px)}}.avatar img{animation:np-breathe 3.4s ease-in-out infinite;transform-origin:50% 100%}.opp.active{animation:np-bob .85s ease-in-out infinite}.turn.you{animation:np-pulse 1.15s ease-in-out infinite}.opp.leading .avatar img,.you-row.leading .avatar img{animation:np-dance .6s ease-in-out infinite}.hand .card{animation:np-deal .5s ease-out backwards;animation-delay:calc(var(--i, 0) * 75ms)}.pile-cards .card{animation:np-slap .26s ease-out}@media (prefers-reduced-motion: reduce){.avatar img,.opp.active,.turn.you,.opp.leading .avatar img,.you-row.leading .avatar img,.hand .card,.pile-cards .card{animation:none!important}}.hand-tools{position:relative;display:flex;justify-content:flex-end;align-items:center;padding:0 8px 2px;min-height:26px}.sort-toggle{display:inline-flex;align-items:center;gap:4px;background:#00000047;border:1.5px solid rgba(255,216,119,.4);border-radius:999px;padding:3px 4px 3px 10px}.sort-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--gold-hi);opacity:.85}.sort-toggle button{font:inherit;font-size:12px;font-weight:800;cursor:pointer;border:none;border-radius:999px;padding:4px 12px;background:transparent;color:var(--parch)}.sort-toggle button.on{background:linear-gradient(180deg,var(--gold-hi),var(--gold));color:var(--lacquer-dark)}.sort-hint{position:absolute;right:6px;bottom:30px;z-index:8;display:flex;align-items:center;gap:8px;max-width:260px;background:var(--cream);color:var(--ink);border:2px solid var(--gold);border-radius:12px;padding:8px 10px;font-size:12.5px;box-shadow:0 6px 16px #0006;animation:sort-hint-pop .25s ease}.sort-hint:after{content:"";position:absolute;right:26px;bottom:-8px;width:14px;height:14px;background:var(--cream);border-right:2px solid var(--gold);border-bottom:2px solid var(--gold);transform:rotate(45deg)}.sort-hint-x{border:none;background:#0000001a;color:var(--lacquer-dark);width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:15px;line-height:1;flex-shrink:0}@keyframes sort-hint-pop{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.sort-hint{animation:none}}.turn-timer{display:inline-block;margin-left:8px;min-width:30px;padding:1px 8px;border-radius:999px;font-weight:900;font-size:.8em;background:#00000059;border:1.5px solid var(--gold);color:var(--gold-hi);vertical-align:middle}.turn-timer.mine{border-color:var(--gold-hi);color:#fff;background:#1f7a5580}.turn-timer.low{border-color:var(--red);color:#fff;background:#c6282899;animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}@media (prefers-reduced-motion: reduce){.turn-timer.low{animation:none}}.btn.bomb{background:linear-gradient(180deg,#e85d3b,#a01e0e);color:#fff;border:2px solid var(--gold-hi);box-shadow:0 4px #6d1207,0 8px 16px #00000059;font-weight:900;text-shadow:0 1px 2px rgba(0,0,0,.4)}.btn.bomb:not(:disabled):active{transform:translateY(2px);box-shadow:0 2px #6d1207}.btn.bomb:disabled{opacity:.5}.card{width:var(--card-w);height:var(--card-h);background:radial-gradient(120% 90% at 50% 0%,var(--cream) 0%,var(--cream) 62%,#fdeecb 100%);border:2.5px solid var(--ink);border-radius:11px;box-shadow:2px 2px 0 var(--ink);position:relative;cursor:pointer;flex:0 0 auto;padding:0;font-family:Georgia,Trebuchet MS,serif;overflow:hidden}.card.sm{width:48px;height:68px;border-radius:9px}.card.red{color:var(--red)}.card.black{color:var(--ink)}.card:disabled{cursor:default}.card:before{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border:1.5px solid var(--gold);border-radius:7px;pointer-events:none;z-index:1}.card.sm:before{top:2.5px;right:2.5px;bottom:2.5px;left:2.5px;border-radius:6px}.card .corner{position:absolute;z-index:3;display:flex;flex-direction:column;align-items:center;line-height:.92;font-weight:700;font-size:13px;letter-spacing:-.5px}.card .corner .csuit{font-size:11px;line-height:1}.card.sm .corner{font-size:11px}.card.sm .corner .csuit{font-size:9px}.card .corner.tl{top:5px;left:5px}.card .corner.br{bottom:5px;right:5px;transform:rotate(180deg)}.card.sm .corner.tl{top:4px;left:4px}.card.sm .corner.br{bottom:4px;right:4px}.card .filigree{position:absolute;z-index:2;width:12px;height:12px;color:var(--gold);opacity:.85;pointer-events:none}.card .filigree.tr{top:4px;right:4px}.card .filigree.bl{bottom:4px;left:4px;transform:rotate(180deg)}.card.sm .filigree{width:9px;height:9px}.card .face{position:absolute;top:12px;right:9px;bottom:12px;left:9px;z-index:2}.card.sm .face{top:10px;right:7px;bottom:10px;left:7px}.card .pip-grid{position:absolute;top:0;right:0;bottom:0;left:0}.card .pip{position:absolute;transform:translate(-50%,-50%);font-size:16px;line-height:1}.card .pip.flip{transform:translate(-50%,-50%) rotate(180deg)}.card.sm .pip{font-size:12px}.card .pip.center-big{top:50%;left:50%;font-size:2rem}.card.sm .pip.center-big{font-size:1.4rem}.card .court{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center}.card .seal{width:76%;aspect-ratio:1 / 1.18;border-radius:46%/40%;background:radial-gradient(120% 120% at 50% 18%,var(--lacquer-hi) 0%,var(--lacquer) 55%,var(--lacquer-dark) 100%);border:2px solid var(--gold);box-shadow:0 0 0 1.5px var(--ink),inset 0 0 0 2px var(--lacquer-dark),inset 0 0 0 3.5px var(--gold);display:grid;place-items:center;position:relative}.card .seal:before{content:"";position:absolute;top:14%;right:14%;bottom:14%;left:14%;border:1.5px solid var(--gold);border-radius:44%/38%;opacity:.75}.card .seal .glyph{font-family:Georgia,serif;font-weight:900;font-size:1.95rem;color:var(--gold-hi);text-shadow:1px 1px 0 var(--lacquer-dark),0 0 6px rgba(0,0,0,.35);line-height:1}.card.sm .seal .glyph{font-size:1.3rem}.card .ace{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center}.card .ace .ring{width:60%;aspect-ratio:1;border-radius:50%;display:grid;place-items:center;border:2px dashed var(--gold);box-shadow:inset 0 0 0 3px #e7b53c2e;position:relative}.card .ace .ring:before,.card .ace .ring:after{content:"✦";position:absolute;left:50%;transform:translate(-50%);color:var(--gold);font-size:.7rem}.card .ace .ring:before{top:-9px}.card .ace .ring:after{bottom:-9px}.card .ace .ace-pip{font-size:2.1rem;line-height:1}.card.sm .ace .ace-pip{font-size:1.4rem}.card.sm .ace .ring:before,.card.sm .ace .ring:after{font-size:.55rem}.card.deuce .pip,.card.deuce .corner{color:#c79528}.card.deuce.red .pip,.card.deuce.red .corner{color:var(--red)}.card.deuce .face .pip{text-shadow:0 0 5px rgba(231,181,60,.6)}.card .crown{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;color:var(--gold);font-size:1.05rem;text-shadow:0 1px 0 var(--lacquer-dark);filter:drop-shadow(0 0 4px rgba(255,216,119,.7))}.card.sm .crown{font-size:.8rem}.card.selected{outline:3px solid var(--gold);outline-offset:-1px;box-shadow:2px 2px 0 var(--ink),0 0 12px 2px var(--gold-hi)}.card.selected:before{border-color:var(--gold-hi)}@media (prefers-reduced-motion: reduce){.card,.card .crown,.card .pip{animation:none!important}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2a1a12b8;display:grid;place-items:center;padding:20px;z-index:100}.result{background:var(--parch);border:4px solid var(--lacquer);border-radius:18px;box-shadow:5px 5px 0 var(--lacquer-dark),0 0 0 2px var(--gold);padding:22px 26px;text-align:center;min-width:280px;max-width:92vw;position:relative;z-index:2;animation:fx-pop .32s cubic-bezier(.34,1.56,.64,1) both!important}.result-champ{display:flex;justify-content:center;margin-bottom:8px}.result-champ.you-won .avatar{animation:fx-champ-glow 1.4s ease-in-out infinite;box-shadow:0 0 0 2.5px var(--ink),0 0 18px 6px var(--gold-hi),2px 2px 0 var(--ink)}.result h2{margin:0 0 14px;font-size:1.5rem;letter-spacing:1px}.result h2.win{color:var(--jade);text-shadow:2px 2px 0 #bfe6d2}.result h2.lose{color:var(--lacquer);text-shadow:2px 2px 0 #f6c9c9}.scores{width:100%;border-collapse:collapse;margin-bottom:4px}.scores th,.scores td{padding:7px 8px;border-bottom:2px dotted #cba86a;font-size:.92rem;text-align:left;color:#4a3a22}.scores th:last-child,.scores td:last-child{text-align:right}.scores .winrow{font-weight:700;background:#fbefc9}.confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:1}.confetti span{position:absolute;top:-14px;border-radius:2px;animation-name:fx-fall!important;animation-timing-function:linear;animation-iteration-count:infinite}.confetti span.big-win{animation-name:fx-fall-big!important}.liondance{position:fixed;z-index:3;pointer-events:none;bottom:22%;left:0;width:96px;height:96px;object-fit:contain;animation:fx-lion-run 3.2s cubic-bezier(.37,0,.63,1) infinite,fx-lion-hop .48s ease-in-out infinite;image-rendering:pixelated;filter:drop-shadow(3px 3px 0 var(--ink))}.liondance.big-win{animation-delay:-1.6s,-.24s;bottom:30%;animation-duration:3.9s,.52s}.pigsy{position:fixed;z-index:3;pointer-events:none;bottom:18px;right:14px;width:72px;height:72px;object-fit:contain;animation:fx-belly-bounce .6s ease-in-out infinite;transform-origin:50% 100%;filter:drop-shadow(2px 2px 0 var(--ink))}@keyframes fx-pop{0%{opacity:0;transform:scale(.7) rotate(-2deg)}65%{transform:scale(1.04) rotate(.5deg)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes fx-champ-glow{0%,to{box-shadow:0 0 0 2.5px var(--ink),0 0 14px 4px var(--gold),2px 2px 0 var(--ink)}50%{box-shadow:0 0 0 2.5px var(--ink),0 0 26px 10px var(--gold-hi),2px 2px 0 var(--ink)}}@keyframes fx-fall{0%{transform:translateY(-14px) rotate(0);opacity:0}10%{opacity:1}to{transform:translateY(480px) rotate(500deg);opacity:.9}}@keyframes fx-fall-big{0%{transform:translateY(-14px) rotate(0) scale(1);opacity:0}8%{opacity:1}50%{transform:translateY(240px) rotate(250deg) scale(1.2)}to{transform:translateY(520px) rotate(600deg) scale(.8);opacity:.8}}@keyframes fx-lion-run{0%{transform:translate(-120px)}to{transform:translate(calc(100vw + 120px))}}@keyframes fx-lion-hop{0%{margin-bottom:0}30%{margin-bottom:24px}55%{margin-bottom:2px}70%{margin-bottom:14px}85%{margin-bottom:0}to{margin-bottom:0}}@keyframes fx-belly-bounce{0%{transform:scaleY(1) translateY(0)}20%{transform:scaleY(1.14) translateY(-8px)}40%{transform:scaleY(.92) translateY(4px)}60%{transform:scaleY(1.08) translateY(-4px)}80%{transform:scaleY(.97) translateY(2px)}to{transform:scaleY(1) translateY(0)}}@media (prefers-reduced-motion: reduce){.result,.result-champ.you-won .avatar,.confetti span,.confetti span.big-win,.liondance,.liondance.big-win,.pigsy{animation:none!important}.liondance{left:8px;transform:none!important}}.result-champ.victory-dance{animation:victory-dance .7s ease-in-out infinite}@keyframes victory-dance{0%,to{transform:translateY(0) rotate(-6deg)}25%{transform:translateY(-14px) rotate(6deg) scale(1.06)}50%{transform:translateY(0) rotate(-6deg)}75%{transform:translateY(-8px) rotate(4deg) scale(1.03)}}.bomb-victim{display:flex;flex-direction:column;align-items:center;gap:4px;margin:2px 0 6px}.bombed-avatar{position:relative}.bombed-avatar .avatar img{filter:brightness(.12) contrast(1.4) grayscale(1);animation:bombed-shake .4s ease-in-out 3}@keyframes bombed-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px) rotate(-3deg)}40%{transform:translate(4px) rotate(3deg)}60%{transform:translate(-3px) rotate(-2deg)}80%{transform:translate(3px) rotate(2deg)}}.smoke{position:absolute;bottom:40%;left:50%;width:22px;height:22px;margin-left:-11px;background:radial-gradient(circle,rgba(90,90,90,.85),rgba(60,60,60,.35) 60%,transparent 70%);border-radius:50%;opacity:0;animation:smoke-rise 1.8s ease-out infinite}.smoke.s2{left:38%;width:18px;animation-delay:.5s}.smoke.s3{left:62%;width:16px;animation-delay:1s}@keyframes smoke-rise{0%{transform:translateY(0) scale(.5);opacity:0}20%{opacity:.9}to{transform:translateY(-56px) scale(1.9);opacity:0}}.bomb-victim-label{font-weight:900;font-size:.9rem;color:var(--red);text-shadow:0 1px 0 rgba(0,0,0,.3)}@media (prefers-reduced-motion: reduce){.result-champ.victory-dance,.bombed-avatar .avatar img,.smoke{animation:none!important}.smoke{opacity:.5}}.btn.league-standings{margin-top:8px;background:linear-gradient(180deg,var(--gold-hi),var(--gold));color:var(--lacquer-dark);border:2px solid var(--lacquer);font-weight:800}.fair{margin:10px auto 2px;max-width:320px;text-align:center}.fair-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;font-size:.8rem;font-weight:800;color:var(--jade-deep);background:#1f7a5524;border:1px solid rgba(31,122,85,.5);border-radius:999px;cursor:pointer}.fair-badge:hover{background:#1f7a5538}.fair-panel{margin-top:8px;padding:10px 12px;background:#fff7e6d9;border:1px solid rgba(142,27,27,.28);border-radius:10px;text-align:left}.fair-note{margin:0 0 8px;font-size:.78rem;line-height:1.35;color:var(--ink)}.fair-kv{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:.76rem;margin:3px 0}.fair-kv>span{color:var(--lacquer);font-weight:700}.fair-kv>code{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.72rem;color:var(--ink);background:#0000000f;padding:2px 6px;border-radius:5px}.fair-verify-btn{margin-top:8px;width:100%;padding:7px 10px;font-size:.84rem;font-weight:800;color:var(--cream);background:linear-gradient(var(--jade),var(--jade-deep));border:1px solid var(--jade-deep);border-radius:8px;cursor:pointer}.fair-verify-btn:disabled{opacity:.5;cursor:default}.fair-result{list-style:none;margin:8px 0 0;padding:0;font-size:.8rem;font-weight:700}.fair-result>li{margin:3px 0}.fair-result>li.ok{color:var(--jade-deep)}.fair-result>li.bad{color:var(--red)}.fair-result>li.muted{color:#8a7a5c}.share{display:flex;flex-direction:column;align-items:center;gap:6px;margin:8px 0 2px}.share.compact{margin-top:10px}.share-label{font-size:.82rem;font-weight:800;color:var(--gold);letter-spacing:.04em;text-transform:uppercase}.share-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.share-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;font-size:.86rem;font-weight:700;color:var(--cream);background:#00000040;border:1px solid rgba(231,181,60,.45);border-radius:999px;cursor:pointer;transition:transform .08s ease,background .15s ease,border-color .15s ease;white-space:nowrap}.share-btn:hover{transform:translateY(-1px);background:#00000061;border-color:var(--gold)}.share-btn:active{transform:translateY(0)}.share-btn.wa:hover{border-color:#25d366}.share-btn.tg:hover{border-color:#29a9eb}.share-btn.copy:hover{border-color:var(--gold-hi)}.result .share-btn{color:var(--ink);background:#fff7e6b3;border-color:#8e1b1b59}.result .share-btn:hover{background:#fff;border-color:var(--lacquer)}.result .share-label{color:var(--lacquer)}.landing{display:flex;flex-direction:column;align-items:center;min-height:100%;padding:0 0 28px;background:linear-gradient(180deg,var(--lacquer-dark) 0%,var(--lacquer) 42%,#7a1616 100%);overflow-y:auto;overflow-x:hidden;position:relative}.landing-petals{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.landing-petal{position:absolute;top:-20px;width:10px;height:10px;border-radius:50% 0;opacity:0;animation:l-fall linear infinite}@keyframes l-fall{0%{transform:translateY(-20px) rotate(0);opacity:0}8%{opacity:.7}90%{opacity:.55}to{transform:translateY(105vh) rotate(520deg);opacity:0}}.landing-lantern{position:absolute;top:-28px;width:12px;height:16px;border-radius:50%/60% 60% 40% 40%;opacity:0;animation:l-lantern-fall linear infinite}@keyframes l-lantern-fall{0%{transform:translateY(-28px) scale(1) rotate(-6deg);opacity:0}10%{opacity:.55}50%{transform:translateY(50vh) scale(.9) rotate(6deg)}90%{opacity:.45}to{transform:translateY(105vh) scale(.8) rotate(-6deg);opacity:0}}@media (prefers-reduced-motion: reduce){.landing-petal,.landing-lantern{animation:none!important;opacity:0!important}}.landing-shimmer{position:fixed;top:-10%;right:-20%;bottom:-10%;left:-20%;pointer-events:none;overflow:hidden;z-index:0}.landing-shimmer-line{position:absolute;top:-10%;height:130%;width:2px;border-radius:2px;background:linear-gradient(to bottom,transparent 0%,rgba(255,216,119,0) 12%,rgba(255,216,119,.55) 46%,rgba(255,255,255,.85) 50%,rgba(255,216,119,.55) 54%,rgba(255,216,119,0) 88%,transparent 100%);filter:blur(.4px) drop-shadow(0 0 6px rgba(255,216,119,.5));opacity:0;transform:rotate(16deg);animation:l-shimmer linear infinite}@keyframes l-shimmer{0%{transform:translate(-8vw) rotate(16deg);opacity:0}12%{opacity:.85}88%{opacity:.85}to{transform:translate(112vw) rotate(16deg);opacity:0}}@media (prefers-reduced-motion: reduce){.landing-shimmer-line{animation:none!important;opacity:0!important}}.landing-modes{position:relative;z-index:1;width:100%;max-width:440px;display:flex;flex-direction:column;gap:12px;padding:4px 16px 0}.mode-card{border:2.5px solid var(--gold);border-radius:16px;padding:14px 16px;background:linear-gradient(155deg,#5f0f0fd1,#3c0a0ae6);box-shadow:0 8px 22px #00000059,inset 0 0 0 1px #ffd87740}.mode-card.ranked{border-color:var(--gold-hi)}.mode-card-head{display:flex;align-items:center;gap:8px}.mode-card-title{font-size:19px;font-weight:900;color:var(--gold-hi);letter-spacing:.5px}.mode-info-btn{margin-left:auto;width:26px;height:26px;border:1.5px solid var(--gold);border-radius:50%;background:transparent;color:var(--gold-hi);font-size:14px;font-weight:800;cursor:pointer;line-height:1}.mode-info-btn:hover{background:#ffd87726}.mode-info-text{margin:8px 0 4px;font-size:12.5px;line-height:1.5;color:var(--parch);background:#00000038;border-radius:9px;padding:8px 10px}.mode-go{width:100%;margin-top:10px;padding:11px;font:inherit;font-weight:800;font-size:16px;border:none;border-radius:11px;cursor:pointer;background:linear-gradient(180deg,var(--gold-hi),var(--gold));color:var(--lacquer-dark);box-shadow:0 4px #a97e1e,0 8px 16px #0000004d}.mode-go:active{transform:translateY(2px);box-shadow:0 2px #a97e1e}.mode-go:disabled{opacity:.5;cursor:default;box-shadow:none}.mode-go.small{width:auto;margin-top:0;padding:9px 16px;font-size:14px}.private-actions{display:flex;flex-direction:column;gap:8px;margin-top:10px}.private-join{display:flex;gap:8px}.private-code-input{flex:1;font-family:inherit;font-weight:800;letter-spacing:3px;text-align:center;border:2.5px solid var(--ink);border-radius:10px;padding:8px;background:var(--cream);color:var(--lacquer-dark)}.landing-practice{position:relative;z-index:1;margin-top:12px}.practice-toggle{background:none;border:none;color:var(--parch);opacity:.85;font:inherit;font-weight:700;font-size:14px;text-decoration:underline;cursor:pointer}.practice-panel{display:flex;align-items:center;gap:10px;padding:8px 14px;background:#00000040;border:1.5px solid rgba(255,216,119,.35);border-radius:12px}.practice-label{font-size:13px;font-weight:800;color:var(--gold-hi)}.landing-hero{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;padding:28px 16px 18px;width:100%}.landing-emblem{width:clamp(90px,30vw,140px);height:clamp(90px,30vw,140px);object-fit:contain;filter:drop-shadow(0 0 10px rgba(231,181,60,.45));animation:l-emblem-breathe 4s ease-in-out infinite}@keyframes l-emblem-breathe{0%,to{transform:scale(1);filter:drop-shadow(0 0 10px rgba(231,181,60,.45))}50%{transform:scale(1.04);filter:drop-shadow(0 0 18px rgba(255,216,119,.65))}}@media (prefers-reduced-motion: reduce){.landing-emblem{animation:none!important}}.landing-title{margin:10px 0 0;font-size:clamp(3rem,14vw,5.2rem);font-weight:900;letter-spacing:.06em;color:var(--gold-hi);text-shadow:0 0 0 var(--ink),3px 3px 0 var(--lacquer-dark),5px 5px 0 var(--ink);line-height:1;position:relative}.landing-title-wrap{display:flex;align-items:center;gap:10px;width:100%;justify-content:center}.landing-rule{flex:1;max-width:60px;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);border-radius:2px}.landing-tagline{margin:10px 0 0;font-size:clamp(.7rem,3vw,.9rem);color:var(--parch);text-align:center;font-style:italic;opacity:.88;letter-spacing:.03em;max-width:320px;line-height:1.45}.landing-panel{position:relative;z-index:1;width:100%;max-width:520px;padding:0 12px;margin-top:16px}.landing-section-head{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin:0 0 8px 2px;display:flex;align-items:center;gap:6px}.landing-section-head:after{content:"";flex:1;height:1.5px;background:linear-gradient(90deg,var(--gold),transparent);border-radius:1px;opacity:.5}.landing-mode-group{display:flex;gap:10px;width:100%}.landing-mode-btn{flex:1;font-family:inherit;cursor:pointer;border:3px solid var(--ink);border-radius:16px;font-weight:700;font-size:1rem;padding:11px 10px;box-shadow:3px 3px 0 var(--ink);background:var(--cream);color:var(--lacquer-dark);transition:background .1s,color .1s,transform .1s;position:relative}.landing-mode-btn.active{background:linear-gradient(var(--gold-hi) 0 45%,var(--gold) 45% 100%);color:var(--lacquer-dark)}.landing-mode-btn:active:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.landing-mode-btn:disabled{opacity:.45;cursor:default}.landing-online-note{font-size:.7rem;font-weight:600;color:var(--lacquer);margin-top:5px;padding:4px 8px;background:var(--parch);border:1.5px solid var(--gold);border-radius:8px;text-align:center}.landing-diff-row{display:flex;align-items:center;gap:10px;margin-top:8px}.landing-diff-label{font-size:.82rem;font-weight:700;color:var(--parch)}.landing-diff-select{font-family:inherit;border:2.5px solid var(--ink);border-radius:10px;padding:6px 10px;font-weight:700;font-size:.9rem;background:var(--cream);color:var(--lacquer-dark);cursor:pointer;box-shadow:2px 2px 0 var(--ink)}.landing-cast{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;padding:4px 0}.landing-cast-slot{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;position:relative}.landing-cast-slot .avatar{transition:transform .13s,box-shadow .13s}.landing-cast-slot:hover .avatar{transform:translateY(-3px)}.landing-cast-slot.pinned .avatar{box-shadow:0 0 0 2.5px var(--ink),0 0 0 5px var(--gold-hi),3px 3px 0 var(--ink)}.landing-pin-badge{position:absolute;top:-6px;right:-6px;width:18px;height:18px;background:var(--gold-hi);border:2px solid var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--lacquer-dark);box-shadow:1px 1px 0 var(--ink);z-index:2;pointer-events:none}.landing-cast-name{font-size:.62rem;font-weight:700;color:var(--parch);text-align:center;line-height:1.2;max-width:58px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.landing-pin-counter{font-size:.72rem;font-weight:700;color:var(--gold-hi);letter-spacing:.04em;margin:6px 0 0;text-align:center}.landing-cta{position:relative;z-index:1;display:flex;justify-content:center;padding:8px 12px 0;width:100%;max-width:520px}.rule-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.rule-field{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--parch)}.rule-field select{font:inherit;font-weight:800;padding:4px 6px;border-radius:8px;border:2px solid var(--ink);background:var(--cream);color:var(--lacquer-dark)}.rule-check{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--parch);cursor:pointer}.rule-check input{width:16px;height:16px;accent-color:var(--lacquer)}.league-fields{display:flex;flex-direction:column;gap:5px;margin-top:2px}.league-input{font:inherit;font-weight:700;padding:7px 9px;border-radius:9px;border:2px solid var(--ink);background:var(--cream);color:var(--lacquer-dark)}.league-input.code{letter-spacing:2px;text-align:center;font-weight:800}.league-input:disabled{opacity:.5}.league-or{font-size:11px;text-align:center;color:var(--parch);opacity:.7;font-weight:700}.portal{min-height:100%;overflow-y:auto;overflow-x:hidden;background:linear-gradient(180deg,var(--lacquer-dark) 0%,#3a0c0c 55%,#1c0606 100%);padding-bottom:26px}.portal-feature{position:relative;height:320px;overflow:hidden;border-bottom:3px solid var(--gold)}.portal-feature.big2{background:radial-gradient(circle at 35% 28%,#c8412f,var(--lacquer) 55%,#4a0d0d)}.portal-feature.mahjong{background:radial-gradient(circle at 40% 28%,#2aa06a,var(--jade) 52%,#0c3a28)}.portal-feature .pf-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 62% 42%,rgba(255,216,119,.22),transparent 55%);pointer-events:none}.portal-feature .pf-art{position:absolute;right:-6px;bottom:-8px;height:262px;object-fit:contain;filter:drop-shadow(0 8px 14px rgba(0,0,0,.5));pointer-events:none;-webkit-user-select:none;user-select:none}.portal-feature .pf-glyph{position:absolute;right:6px;bottom:-18px;font-size:220px;line-height:1;filter:drop-shadow(0 8px 14px rgba(0,0,0,.4));pointer-events:none}.portal-feature .pf-scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(0,0,0,.35) 0%,transparent 30%,transparent 55%,rgba(0,0,0,.45) 100%);pointer-events:none}.portal-feature .pf-cap{position:absolute;left:16px;right:16px;bottom:16px;z-index:2}.portal-feature .pf-kicker{font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-hi)}.portal-feature .pf-title{margin:4px 0 5px;font-size:clamp(2rem,10vw,2.6rem);color:var(--gold-hi);letter-spacing:1px;line-height:.95;text-shadow:2px 2px 0 var(--lacquer-dark),4px 4px 0 var(--ink)}.portal-feature .pf-title em{font-style:normal;font-size:.42em;opacity:.82;margin-left:8px}.portal-feature .pf-tag{margin:0 0 11px;font-size:12.5px;color:var(--parch);max-width:260px;line-height:1.4}.portal-feature .pf-row{display:flex;align-items:center;gap:11px}.pf-go{padding:11px 24px;border:none;border-radius:12px;font:inherit;font-weight:900;font-size:15px;cursor:pointer;background:linear-gradient(180deg,var(--gold-hi),var(--gold));color:var(--lacquer-dark);box-shadow:0 4px #a97e1e,0 8px 14px #0000004d}.pf-go:active{transform:translateY(2px);box-shadow:0 2px #a97e1e}.pf-note{font-size:11.5px;font-weight:700;color:#8ff0bd;display:flex;align-items:center;gap:6px}.pf-note:before{content:"";width:7px;height:7px;border-radius:50%;background:#28c07a;box-shadow:0 0 0 3px #28c07a38}.portal-feature.mahjong .pf-note{color:#cfe9ff}.portal-feature.mahjong .pf-note:before{background:#6fb2ff;box-shadow:0 0 0 3px #6fb2ff38}.pf-dots{position:absolute;top:54px;right:14px;display:flex;gap:6px;z-index:3}.pf-dots button{width:8px;height:8px;border-radius:50%;border:none;padding:0;cursor:pointer;background:#fff6;transition:width .18s,background .18s}.pf-dots button.on{width:18px;border-radius:4px;background:var(--gold-hi)}.portal-sec{padding:16px 0 2px}.portal-sec-head{padding:0 15px;margin:0 0 10px;font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:8px}.portal-sec-head:after{content:"";flex:1;height:1.5px;background:linear-gradient(90deg,var(--gold),transparent);opacity:.5}.portal-rail{display:flex;gap:12px;overflow-x:auto;padding:0 15px 8px;scroll-snap-type:x mandatory;scrollbar-width:none}.portal-rail::-webkit-scrollbar{height:0}.rtile{flex:0 0 138px;scroll-snap-align:start;border-radius:16px;overflow:hidden;border:2px solid var(--gold);box-shadow:0 8px 18px #0006;cursor:pointer;transition:transform .15s,box-shadow .15s;font:inherit;padding:0;text-align:left;color:inherit}.rtile:hover{transform:translateY(-3px);box-shadow:0 14px 26px #00000080}.rtile:active{transform:translateY(-1px)}.rtile .rt-art{height:98px;display:flex;align-items:center;justify-content:center;position:relative}.rtile.big2 .rt-art{background:radial-gradient(circle at 40% 35%,#c33,var(--lacquer) 72%)}.rtile.mahjong .rt-art{background:radial-gradient(circle at 60% 35%,#2aa06a,var(--jade-deep) 78%)}.rtile .rt-art img{height:84px;object-fit:contain;filter:drop-shadow(0 4px 6px rgba(0,0,0,.4))}.rtile .rt-art .rt-glyph{font-size:54px}.rtile .rt-beta{position:absolute;top:6px;right:6px;background:#06281c;color:#7bf0b6;font-size:9px;font-weight:800;padding:2px 6px;border-radius:999px;border:1px solid #2aa06a}.rtile .rt-meta{background:#140606f5;padding:8px 9px 10px}.rtile.mahjong .rt-meta{background:#061e16f5}.rtile .rt-meta b{display:block;font-size:13.5px;color:var(--gold-hi)}.rtile .rt-meta small{font-size:10.5px;color:var(--parch);opacity:.78;display:block;margin-top:2px}.rtile.soon{border-color:#ffd8774d;border-style:dashed;opacity:.6;cursor:default}.rtile.soon:hover{transform:none;box-shadow:0 8px 18px #0006}.rtile.soon .rt-art{background:#00000038}.rtile.soon .rt-meta{background:#0000004d}.portal-jump{margin:6px 15px 0;background:#fff7e614;border:1.5px solid rgba(255,216,119,.28);border-radius:14px;padding:11px 13px;display:flex;align-items:center;gap:11px}.portal-jump .pj-ic{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;font-size:26px;border:2px solid var(--gold);overflow:hidden;flex:0 0 auto}.portal-jump .pj-ic.big2{background:radial-gradient(circle at 40% 35%,#c33,var(--lacquer))}.portal-jump .pj-ic.mahjong{background:radial-gradient(circle at 60% 35%,#2aa06a,var(--jade-deep))}.portal-jump .pj-ic img{width:100%;height:100%;object-fit:cover}.portal-jump .pj-txt{flex:1;min-width:0}.portal-jump .pj-txt b{color:var(--gold-hi);font-size:14px}.portal-jump .pj-txt small{display:block;color:var(--parch);opacity:.75;font-size:11.5px;margin-top:2px}.pj-go{background:linear-gradient(180deg,var(--gold-hi),var(--gold));color:var(--lacquer-dark);border:none;border-radius:10px;font:inherit;font-weight:800;font-size:12.5px;padding:9px 14px;cursor:pointer;flex:0 0 auto}.pj-go:active{transform:translateY(1px)}.portal-online-note{margin:12px 15px 0;font-size:11px;font-weight:700;color:var(--parch);opacity:.7;text-align:center}.invite-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:20px;background:#140806b8;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.invite-card{width:min(400px,92vw);padding:26px 24px 20px;text-align:center;background:radial-gradient(120% 120% at 50% 0%,var(--parch),var(--cream));border:2px solid var(--gold);border-radius:18px;box-shadow:0 18px 50px #00000080,inset 0 0 0 4px #8e1b1b26;animation:invite-pop .28s ease-out}@keyframes invite-pop{0%{transform:scale(.92) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.invite-emoji{font-size:2.6rem;line-height:1;margin-bottom:6px}.invite-card h2{margin:4px 0;font-size:1.35rem;color:var(--lacquer)}.invite-sub{margin:2px 0 12px;font-size:.92rem;color:var(--ink)}.invite-code{display:inline-block;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:1.3rem;font-weight:800;letter-spacing:.18em;color:var(--jade-deep);background:#1f7a551f;border:1px dashed rgba(31,122,85,.5);border-radius:10px;padding:6px 16px;margin-bottom:16px}.invite-card .btn.play.big{width:100%}.invite-dismiss{display:block;width:100%;margin-top:10px;padding:6px;font-size:.86rem;font-weight:600;color:#7a5a2c;background:none;border:none;cursor:pointer;text-decoration:underline}.invite-fineprint{margin:12px 0 0;font-size:.72rem;color:#8a7a5c}.mj{--felt1:#124a37;--felt2:#0a2c21;--gold:#d4af37;--gold-dim:#a9862a;--lacquer:#8c1c13;--lacquer-lite:#b3261e;--jade:#1f7a3d;--dot:#1e5aa8;--tile:#f6f0df;--tile-edge:#e4d9bd;--ink:#22252b;color:#f3ead2}.mjt{border-radius:6px;background:linear-gradient(#fffef7,var(--tile));border:1px solid var(--tile-edge);box-shadow:0 2px #c9bd9c,0 3px 5px #00000059;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--ink);-webkit-user-select:none;user-select:none;flex:0 0 auto}.mjt.sm{width:26px;height:35px}.mjt.md{width:34px;height:46px}.mjt.lg{width:44px;height:60px}.mjt .num{font-weight:800;line-height:1;color:#1a1a2e}.mjt .wan{font-weight:800;line-height:1;color:#b3261e}.mjt.sm .num{font-size:12px}.mjt.sm .wan{font-size:11px}.mjt.md .num{font-size:15px}.mjt.md .wan{font-size:13px}.mjt.lg .num{font-size:19px}.mjt.lg .wan{font-size:17px}.mjt.honor .big{font-weight:800;color:#1a1a2e}.mjt.sm.honor .big{font-size:17px}.mjt.md.honor .big{font-size:20px}.mjt.lg.honor .big{font-size:27px}.mjt .t-red{color:#b3261e}.mjt .t-green{color:#1f7a3d}.mjt .t-white{color:#1e5aa8}.mjt-svg{width:86%;height:86%}.mjt-bird{line-height:1}.mjt.sm .mjt-bird{font-size:20px}.mjt.md .mjt-bird{font-size:26px}.mjt.lg .mjt-bird{font-size:34px}.mjt.clickable{cursor:pointer;transition:transform .12s}.mjt.clickable:hover{transform:translateY(-8px)}.mjt.draw{box-shadow:0 0 0 2px var(--gold),0 3px 6px #0006;transform:translateY(-4px)}.mjt.hot{outline:2px solid #e7b84b}.mjt-row{display:flex;gap:4px;align-items:flex-end;flex-wrap:wrap}.mjt-back{width:22px;height:30px;border-radius:4px;background:linear-gradient(#a12118,#6f130d);border:1px solid #d8b24b;flex:0 0 auto}.mjt-back.h{width:30px;height:22px}.mj-topbar{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}.mj-brand{font-weight:800;letter-spacing:.5px;font-size:20px;color:var(--gold)}.mj-brand small{color:#cdbb8f;font-weight:600;font-size:12px;letter-spacing:2px}.mj-chip{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}.mj-pill{padding:6px 11px;border-radius:999px;background:#1a1c14;border:1px solid #3a3626;font-size:12px;color:#e7d9ac}.mj-pill b{color:var(--gold)}.mj-btn{border:1px solid var(--gold-dim);background:linear-gradient(#1b1d16,#121309);color:#f0e2ba;border-radius:9px;padding:7px 12px;font-size:13px;font-weight:600;cursor:pointer}.mj-btn.gold{background:linear-gradient(#e9cf72,#c8a53a);color:#3a2a06;border-color:#8a6a1e}.mj-layout{display:grid;grid-template-columns:1fr 260px;gap:14px;align-items:start}@media (max-width:860px){.mj-layout{grid-template-columns:1fr}}.mj-table{position:relative;height:560px;border-radius:22px;background:radial-gradient(ellipse at 50% 42%,var(--felt1),var(--felt2) 72%);border:2px solid var(--gold-dim);box-shadow:inset 0 0 0 8px #00000040,inset 0 0 90px #0000008c,0 18px 50px #0009}.mj-emblem{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:190px;color:#d4af370f;pointer-events:none;font-weight:800}.mj-seat{position:absolute;display:flex;gap:10px;align-items:center}.mj-seat.top{top:14px;left:50%;transform:translate(-50%);flex-direction:column}.mj-seat.left{left:14px;top:50%;transform:translateY(-50%);flex-direction:column}.mj-seat.right{right:14px;top:50%;transform:translateY(-50%);flex-direction:column}.mj-plaque{display:flex;align-items:center;gap:9px;background:linear-gradient(#20130f,#160d0a);border:1px solid var(--gold-dim);border-radius:12px;padding:6px 10px;min-width:150px}.mj-plaque.active{box-shadow:0 0 0 2px var(--gold),0 0 22px #d4af3780}.mj-ava{width:42px;height:42px;border-radius:9px;background:linear-gradient(135deg,#b3261e,#6d140f);display:flex;align-items:center;justify-content:center;font-size:22px;border:1px solid var(--gold-dim);overflow:hidden}.mj-ava img{width:100%;height:100%;object-fit:cover}.mj-who{line-height:1.2}.mj-who .nm{font-weight:700;font-size:13px;color:#f4e7c2}.mj-who .lv{font-size:11px;color:#c7b483}.mj-wind{margin-left:auto;font-size:18px;font-weight:800;color:var(--gold)}.mj-wind small{display:block;font-size:9px;color:#b49c63;font-weight:600}.mj-melds{display:flex;gap:6px;flex-wrap:wrap;max-width:230px}.mj-meld{display:flex;gap:2px;background:#00000038;padding:3px;border-radius:6px}.mj-river{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:320px;min-height:120px;display:grid;grid-template-columns:repeat(8,1fr);gap:4px;padding:12px;background:#00000029;border-radius:12px;border:1px solid rgba(212,175,55,.18)}.mj-center-info{position:absolute;top:50%;left:50%;transform:translate(-50%,-158px);display:flex;gap:10px;align-items:center}.mj-bubble{position:absolute;background:var(--gold);color:#3a2a06;font-weight:800;padding:5px 12px;border-radius:14px;font-size:20px;box-shadow:0 4px 10px #0006;z-index:5;animation:mj-pop .25s ease}.mj-bubble:after{content:"";position:absolute;bottom:-7px;left:22px;border:7px solid transparent;border-top-color:var(--gold);border-bottom:0}@keyframes mj-pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}.mj-you{margin-top:12px;display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}.mj-hand{display:flex;gap:4px;align-items:flex-end;flex-wrap:wrap}.mj-yourmeld{display:flex;gap:6px}.mj-claimbar{display:flex;gap:9px;margin-top:12px;align-items:center;flex-wrap:wrap}.mj-cbtn{font-size:17px;font-weight:800;padding:9px 16px;border-radius:11px;border:1px solid #6b5518;background:linear-gradient(#241a08,#171105);color:#5c5238;cursor:not-allowed}.mj-cbtn.on{color:#3a2a06;background:linear-gradient(#f0d879,#cba63c);border-color:#8a6a1e;cursor:pointer;box-shadow:0 3px 10px #d4af374d}.mj-cbtn.win.on{background:linear-gradient(#ff6a3d,#d33417);color:#fff;border-color:#8a1c0c}.mj-timer{margin-left:auto;font-size:13px;color:#e7d9ac}.mj-timer b{color:#ff8a5c}.mj-hints{background:linear-gradient(#141610,#0d0f0a);border:1px solid #34301f;border-radius:14px;padding:14px}.mj-hints h3{margin:0 0 6px;font-size:14px;color:var(--gold);display:flex;align-items:center;gap:6px}.mj-hints .sub{font-size:11px;color:#9c8f6a;margin-bottom:10px}.mj-wait{display:flex;align-items:center;gap:8px;margin:7px 0;font-size:13px;color:#eadfbe}.mj-wait .tag{margin-left:auto;font-size:11px;background:#241a08;border:1px solid #6b5518;color:var(--gold);border-radius:6px;padding:2px 7px}.mj-shanten{font-size:13px;color:#eadfbe;background:#d4af3714;border-radius:8px;padding:8px 10px;margin-bottom:10px}.mj-shanten b{color:var(--jade)}.mj-legend{font-size:10.5px;color:#7d724f;margin-top:10px;line-height:1.5}.mj-result-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#040a07b8;display:flex;align-items:center;justify-content:center;z-index:50;animation:mj-fade .2s ease}@keyframes mj-fade{0%{opacity:0}to{opacity:1}}.mj-result-card{width:min(420px,92vw);background:linear-gradient(#171a12,#0d0f0a);border:2px solid var(--gold-dim);border-radius:18px;padding:22px;text-align:center;box-shadow:0 24px 60px #0009}.mj-result-card h2{font-size:26px}.mj-breakdown{text-align:left;background:#d4af370f;border-radius:10px;padding:8px 12px;margin:6px 0 4px}.mj-taiitem{display:flex;justify-content:space-between;font-size:13px;color:#eadfbe;padding:3px 0}.mj-taiitem b{color:var(--gold)}.mj-delta{font-size:22px;font-weight:800;margin-top:10px}.mj-delta.up{color:#5fd08a}.mj-delta.down{color:#ff8a5c}.mj-rules{width:min(560px,94vw);max-height:88vh;overflow:auto;background:linear-gradient(#171a12,#0d0f0a);border:2px solid var(--gold-dim);border-radius:18px;padding:22px;box-shadow:0 24px 60px #0009}.mj-rule{font-size:13.5px;line-height:1.55;color:#eadfbe;padding:8px 0;border-top:1px solid #2a2718}.mj-rule:first-of-type{border-top:0}.mj-rule b{color:#f4e7c2}.mj-rule ul{margin:6px 0 0;padding-left:18px}.mj-rule li{margin:3px 0}.mj-inline{display:inline-flex;align-items:center;gap:4px;margin:0 6px;vertical-align:middle}.mj-landing{max-width:560px;margin:18px auto 0;background:linear-gradient(#141610,#0d0f0a);border:1px solid #3a3626;border-radius:16px;padding:16px 18px}.mj-landing h3{margin:0 0 4px;color:var(--gold);font-size:17px}.mj-landing p{margin:0 0 12px;font-size:12.5px;color:#9c8f6a;line-height:1.5}.mj-landing .row{display:flex;gap:10px;flex-wrap:wrap}.mj-landing .row button{flex:1;min-width:150px}.mj-lobby{position:relative;min-height:100%;overflow-y:auto;background:linear-gradient(180deg,var(--lacquer-dark,#5f0f0f),#1c0606);padding:56px 12px 26px}.waiting{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;align-items:center;gap:12px;padding:22px 16px 28px;text-align:center}.waiting-title{margin:4px 0 0;font-size:1.7rem;color:var(--lacquer);text-shadow:2px 2px 0 var(--gold-hi)}.waiting-sub{margin:0;font-size:.86rem;color:#6b513a;max-width:320px}.waiting-code{font-size:2.2rem;font-weight:800;letter-spacing:8px;padding:8px 18px 8px 26px;color:var(--gold-hi);background:linear-gradient(var(--lacquer-hi),var(--lacquer));border:3px solid var(--ink);border-radius:14px;box-shadow:3px 3px 0 var(--ink)}.waiting-copy{font-family:inherit;cursor:pointer;font-weight:700;font-size:13px;color:var(--lacquer-dark);background:var(--cream);border:2.5px solid var(--ink);border-radius:10px;padding:5px 14px;box-shadow:2px 2px 0 var(--ink)}.waiting-copy:active{transform:translate(2px,2px);box-shadow:none}.waiting-roster{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;width:100%;max-width:340px;margin:6px 0}.waiting-seat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;border-radius:14px;border:2.5px dashed #c9a86a;background:#fff7e680}.waiting-seat.filled{border-style:solid;border-color:var(--gold);background:var(--cream);box-shadow:2px 2px 0 var(--ink)}.waiting-seat-name{font-size:12px;font-weight:700;color:var(--lacquer-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.waiting-seat-status{font-size:10.5px;font-weight:800;color:#8a6a3a}.waiting-seat-status.you{color:var(--jade)}.waiting-seat-status.ready{color:var(--lacquer)}.waiting-host{font-size:.95rem;font-weight:700;color:var(--lacquer);margin-top:6px}.waiting-leave{font-family:inherit;cursor:pointer;font-weight:700;font-size:13px;margin-top:2px;color:#8a6a3a;background:transparent;border:none;text-decoration:underline}.waiting-finding{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--lacquer);font-size:1rem}.waiting-spinner{width:20px;height:20px;border:3px solid rgba(142,27,27,.25);border-top-color:var(--lacquer);border-radius:50%;animation:waiting-spin .9s linear infinite}@keyframes waiting-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.waiting-spinner{animation-duration:2.4s}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:16px;background:#140806a8;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:modal-fade .18s ease}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal-card{position:relative;width:100%;max-width:420px;max-height:calc(100vh - 32px);overflow-y:auto;background:linear-gradient(168deg,var(--cream),var(--parch));border:3px solid var(--gold);border-radius:18px;box-shadow:0 18px 50px #00000080,inset 0 0 0 1.5px var(--lacquer);padding:22px 22px 24px;color:var(--ink)}.modal-card h2{margin:0 0 4px;font-size:22px;color:var(--lacquer-dark);letter-spacing:.5px}.modal-sub{margin:0 0 16px;font-size:13px;opacity:.8}.modal-close{position:absolute;top:10px;right:12px;width:30px;height:30px;border:none;border-radius:50%;background:#00000014;color:var(--lacquer-dark);font-size:18px;cursor:pointer;line-height:1}.modal-close:hover{background:#00000029}.auth-field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.auth-field label{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1px;opacity:.75}.auth-field input{font:inherit;padding:9px 11px;border:2px solid var(--ink);border-radius:9px;background:#fff;color:var(--ink)}.auth-field input:focus{outline:none;border-color:var(--lacquer);box-shadow:0 0 0 3px #8e1b1b2e}.auth-error{background:#c628281f;border:1.5px solid var(--red);color:var(--lacquer-dark);border-radius:9px;padding:8px 10px;font-size:13px;margin-bottom:12px}.auth-submit{width:100%;margin-top:4px;padding:11px;font:inherit;font-weight:800;font-size:16px;border:none;border-radius:11px;background:linear-gradient(180deg,var(--lacquer-hi),var(--lacquer-dark));color:var(--gold-hi);cursor:pointer;box-shadow:0 4px 0 var(--lacquer-dark),0 8px 18px #0000004d}.auth-submit:disabled{opacity:.55;cursor:default}.auth-toggle{margin:14px 0 0;text-align:center;font-size:13px}.auth-toggle button{background:none;border:none;color:var(--lacquer);font:inherit;font-weight:800;cursor:pointer;text-decoration:underline;padding:0 2px}.auth-guest{margin-top:14px;padding-top:14px;border-top:1.5px dashed rgba(142,27,27,.3);text-align:center;font-size:13px}.auth-guest button{background:none;border:none;color:var(--ink);opacity:.8;font:inherit;font-weight:700;cursor:pointer;text-decoration:underline}.acct-chip{display:inline-flex;align-items:center;gap:8px;padding:5px 12px 5px 6px;border:2px solid var(--gold);border-radius:999px;background:#5f0f0f8c;color:var(--gold-hi);font-weight:800;font-size:14px;cursor:pointer}.acct-chip:hover{background:#5f0f0fcc}.acct-chip .avatar{width:30px;height:30px;border-width:2px}.acct-chip.signin{padding:7px 16px}.profile-char{display:flex;align-items:center;gap:14px;margin:4px 0 18px}.profile-char .avatar{width:72px;height:72px}.profile-name{font-size:20px;font-weight:900;color:var(--lacquer-dark)}.profile-email{font-size:12px;opacity:.7}.profile-section-head{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--lacquer);margin:16px 0 8px;border-bottom:1.5px solid rgba(142,27,27,.25);padding-bottom:4px}.stat-table{width:100%;border-collapse:collapse;font-size:13px}.stat-table th,.stat-table td{padding:7px 6px;text-align:right}.stat-table th:first-child,.stat-table td:first-child{text-align:left}.stat-table thead th{font-size:11px;text-transform:uppercase;letter-spacing:.5px;opacity:.7}.stat-table tbody tr{border-top:1px solid rgba(42,26,18,.12)}.stat-table .mode-cell{font-weight:800;color:var(--lacquer-dark)}.stat-empty{font-size:13px;opacity:.65;padding:10px 0;text-align:center;font-style:italic}.stat-win{color:var(--jade-deep);font-weight:800}.stat-loss{color:var(--red);font-weight:800}.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px;margin-top:6px}.char-slot{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;border:2px solid transparent;border-radius:12px;cursor:pointer;background:#fff6}.char-slot .avatar{width:50px;height:50px}.char-slot.sel{border-color:var(--gold);background:#e7b53c40}.char-slot-name{font-size:10px;font-weight:700;text-align:center;line-height:1.1;color:var(--ink)}.profile-actions{display:flex;gap:10px;margin-top:20px}.profile-actions button{flex:1;padding:10px;font:inherit;font-weight:800;border-radius:10px;cursor:pointer}.btn-signout{border:2px solid var(--lacquer);background:transparent;color:var(--lacquer-dark)}.btn-done{border:none;background:linear-gradient(180deg,var(--jade),var(--jade-deep));color:var(--cream)}.tut-card{max-width:460px;text-align:center}.tut-stage{min-height:188px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:6px 4px 4px}.tut-emoji{font-size:46px;line-height:1}.tut-heading{font-size:21px;font-weight:900;color:var(--lacquer-dark);margin:0}.tut-body{font-size:14.5px;line-height:1.5;color:var(--ink);margin:0}.tut-body .hi{color:var(--lacquer);font-weight:800}.tut-rank{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-top:4px}.tut-chip{display:inline-block;padding:3px 8px;border-radius:7px;font-weight:800;font-size:13px;background:var(--cream);border:1.5px solid var(--ink);color:var(--ink)}.tut-chip.red{color:var(--red)}.tut-dots{display:flex;gap:7px;justify-content:center;margin:14px 0 12px}.tut-dot{width:9px;height:9px;border-radius:50%;background:#8e1b1b40}.tut-dot.on{background:var(--lacquer)}.tut-nav{display:flex;align-items:center;justify-content:space-between;gap:10px}.tut-nav button{padding:10px 16px;font:inherit;font-weight:800;border-radius:10px;cursor:pointer}.tut-skip{background:none;border:none;color:var(--ink);opacity:.65;text-decoration:underline}.tut-next{border:none;background:linear-gradient(180deg,var(--lacquer-hi),var(--lacquer-dark));color:var(--gold-hi);box-shadow:0 3px 0 var(--lacquer-dark)}.tut-back{border:2px solid var(--ink);background:transparent;color:var(--ink)}.tut-back:disabled{opacity:.3;cursor:default}.rules-btn{font:inherit;cursor:pointer}.landing-topbar{position:absolute;top:12px;left:0;right:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 14px}.ltb-cluster{display:flex;gap:8px;align-items:center}.ltb-brand{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:7px;pointer-events:none}.ltb-emblem{width:26px;height:26px;object-fit:contain;filter:drop-shadow(0 0 4px rgba(255,216,119,.5))}.ltb-word{font-weight:900;font-size:14px;letter-spacing:1.5px;color:var(--gold-hi);text-shadow:1px 1px 0 var(--lacquer-dark)}@media (max-width: 460px){.ltb-word{display:none}}@media (max-width: 420px){.landing-topbar{top:8px;padding:0 8px}.acct-chip{font-size:13px}.acct-chip span{max-width:96px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.lb-copy{border:1.5px solid var(--lacquer);background:transparent;color:var(--lacquer-dark);border-radius:7px;padding:1px 8px;font:inherit;font-size:11px;font-weight:800;cursor:pointer}.lb-copy:hover{background:#8e1b1b1a}
