: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}}.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}}.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-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}.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}.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}@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}}
