:root{--text:#294438;--heading:#183429;--muted-text:#5e7a6d;--felt-mid:#2f7754;--felt-dark:#1b563b;--gold:#ddb86f;--panel-bg:linear-gradient(130deg, #f4fcf7e0, #e5f4ebdb);--panel-border:#245c3f42;--seat-border:#2a624361;--btn-bg:#f8fffaf2;--btn-bg-hover:#e8f6ecf2;--btn-border:#266a4957;--btn-text:#244936;--tile-bg-1:#f5eddc;--tile-bg-2:#e6d8bf;--tile-border:#85682e6b;--font-ui:"Noto Sans SC", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-title:"Noto Serif SC", "Source Han Serif SC", "STSong", "Songti SC", serif;font-family:var(--font-ui);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{color:#f3ebda;background:radial-gradient(circle at 16% 14%,#ffdcaa29,#0000 36%),radial-gradient(circle at 84% 82%,#00000038,#0000 42%),repeating-linear-gradient(24deg,#ffdcaa0d,#ffdcaa0d 2px,#0000 2px 16px),linear-gradient(130deg,#3e2616,#5a3821 52%,#342112);min-height:100svh;margin:0}#root{min-height:100svh}button{font:inherit}.auth-page{background:radial-gradient(circle at 16% 18%,#ffbc5f33,#0000 32%),radial-gradient(circle at 88% 82%,#53b0822e,#0000 30%),linear-gradient(135deg,#162721f0,#0b1411fa);place-items:center;min-height:100svh;padding:20px;display:grid;position:relative;overflow:hidden}.auth-glow{aspect-ratio:1;filter:blur(28px);opacity:.54;pointer-events:none;border-radius:50%;width:42vmin;position:absolute}.auth-glow-left{background:radial-gradient(circle,#ffbd6ab3,#0000 68%);top:-8vmin;left:-12vmin}.auth-glow-right{background:radial-gradient(circle,#60b78ab3,#0000 68%);bottom:-10vmin;right:-10vmin}.auth-card{z-index:1;background:linear-gradient(160deg,#1c3028eb,#101d18f0),repeating-linear-gradient(-26deg,#ffffff08,#ffffff08 1px,#0000 1px 14px);border:1px solid #d8b88157;border-radius:22px;width:min(520px,100%);padding:clamp(20px,4.2vw,34px);animation:.45s ease-out both auth-card-rise;position:relative;box-shadow:0 18px 40px #00000057,inset 0 1px #ffe6ba26}.auth-header h1{color:#f8e6c2;margin:6px 0 8px;font-family:Noto Serif SC,Songti SC,serif;font-size:clamp(1.4rem,2.4vw,1.85rem)}.auth-header p{color:#eddfc4d6;margin:0;font-size:.94rem}.auth-badge{letter-spacing:.08em;color:#1d3328;text-transform:uppercase;background:linear-gradient(120deg,#f0cb88,#ffe4b0);border-radius:999px;justify-content:center;align-items:center;padding:6px 12px;font-size:.76rem;display:inline-flex}.auth-tabs{background:#0a13109e;border-radius:12px;grid-template-columns:1fr 1fr;gap:8px;margin-top:20px;padding:5px;display:grid}.auth-tabs button{color:#ecdbbdc2;cursor:pointer;background:0 0;border:0;border-radius:9px;padding:9px 14px;font-weight:700;transition:all .22s}.auth-tabs button.active{color:#1a2f24;background:linear-gradient(120deg,#f1ce8a,#ffd695);box-shadow:0 4px 14px #ffd38a47}.auth-notice{border-radius:10px;margin:14px 0 0;padding:10px 12px;font-size:.88rem}.auth-notice.error{color:#ffd8d8;background:#7a23236b;border:1px solid #f1818159}.auth-notice.success{color:#d4f0dd;background:#1e653f59;border:1px solid #73d79a4d}.auth-form{gap:13px;margin-top:14px;display:grid}.field{gap:8px;display:grid}.field span{color:#f2e1be;font-size:.88rem}.field input{color:#f7ead1;background:#09110ebd;border:1px solid #d8bb8942;border-radius:11px;outline:none;width:100%;padding:11px 12px;font-size:.94rem;transition:border-color .2s,box-shadow .2s}.field input:focus{border-color:#ffd692ad;box-shadow:0 0 0 3px #ffd69229}.primary-btn{color:#23372c;cursor:pointer;background:linear-gradient(130deg,#f3cc84,#ffdeac);border:0;border-radius:12px;width:100%;margin-top:6px;padding:12px 16px;font-weight:700;transition:transform .18s,box-shadow .18s,opacity .18s}.primary-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px #ffd79540}.primary-btn:disabled{opacity:.65;cursor:not-allowed}@keyframes auth-card-rise{0%{opacity:0;transform:translateY(14px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=540px){.auth-page{padding:14px}}.orientation-manager{width:100%;height:100%;position:relative;overflow:hidden}.orientation-manager__content{transform-origin:0 0;width:100vh;height:100vw;position:absolute;top:0;left:0;overflow:auto;transform:rotate(90deg)translateY(-100vw)}.orientation-manager__overlay{z-index:9999;pointer-events:auto;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.orientation-manager__hint{color:#fff;text-align:center;flex-direction:column;align-items:center;gap:16px;animation:2s ease-in-out infinite orientation-pulse;display:flex}.orientation-manager__icon{width:48px;height:48px;transform:rotate(-90deg)}.orientation-manager__hint p{margin:0;font-size:14px;line-height:1.5}.orientation-manager__fullscreen-btn--floating{z-index:100;position:fixed;top:12px;right:12px}.orientation-manager__fullscreen-btn{color:#fff;cursor:pointer;background:#00000080;border:1px solid #ffffff4d;border-radius:6px;padding:8px 24px;font-size:14px;transition:background .2s}.orientation-manager__fullscreen-btn:hover{background:#ffffff40}@keyframes orientation-pulse{0%,to{opacity:1}50%{opacity:.5}}.fab-menu{z-index:220;flex:none;position:relative}.menu-trigger{color:#fff7e8;cursor:pointer;background:radial-gradient(circle at 30% 25%,#ffe8b45c,#0000 46%),linear-gradient(145deg,#764f2cfa,#52351efa);border:1px solid #d1aa64c7;border-radius:50%;place-items:center;width:clamp(24px,3.1vw,32px);height:clamp(24px,3.1vw,32px);font-size:clamp(.7rem,1.22vw,.86rem);font-weight:700;line-height:1;list-style:none;display:grid;box-shadow:inset 0 1px #ffe1a66b,0 6px 14px #160c065c}.menu-panel{z-index:230;min-width:122px;transform-origin:var(--radix-popover-content-transform-origin);background:linear-gradient(165deg,#fff5defa,#f3dfbbf7),repeating-linear-gradient(0deg,#6042220f,#6042220f 1px,#0000 1px 5px);border:1px solid #b98f4eb8;border-radius:10px;gap:6px;padding:8px;display:grid;box-shadow:0 10px 20px #22140a59}.menu-panel[data-state=open]{animation:.16s ease-out menu-pop-in}@keyframes menu-pop-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.menu-item{font-size:clamp(.62rem,1.25vw,.8rem);font-weight:600;font-family:var(--font-ui);cursor:pointer;color:#3f2918;text-align:left;border:1px solid #7c522a80;border-radius:8px;padding:6px 10px}.btn-main{background:linear-gradient(140deg,#f6d79afa,#e5be7ef5)}.btn-nav{background:linear-gradient(140deg,#f6e0b8fa,#eacc9cf5)}.btn-sub{background:linear-gradient(140deg,#f0e0c4f7,#dbc4a1f2)}.btn-danger{color:#5a2010;background:linear-gradient(140deg,#f9d2befa,#ecaa90f5);border-color:#ab573894}.btn-danger:disabled{opacity:.62;cursor:not-allowed}.menu-item:hover{filter:brightness(1.03)}.board-meta{top:calc(var(--pad) + env(safe-area-inset-top));left:calc(var(--pad) + env(safe-area-inset-left));z-index:210;align-items:center;gap:6px;width:fit-content;max-width:clamp(220px,62vw,520px);display:flex;position:fixed}.preset-picker{background:linear-gradient(150deg,#f7e6c8f0,#e8cfa6eb);border:1px solid #c599589e;border-radius:999px;align-items:center;gap:4px;padding:4px 8px;display:inline-flex}.preset-label{color:#5b3920;letter-spacing:.02em;font-size:clamp(.52rem,1.02vw,.68rem);font-weight:700}.preset-select-trigger{appearance:none;color:#4a2f1a;min-width:clamp(118px,16vw,170px);font-size:clamp(.52rem,1.02vw,.68rem);font-family:var(--font-ui);cursor:pointer;background:#fff8e9f0;border:1px solid #986f43b8;border-radius:999px;justify-content:space-between;align-items:center;gap:6px;padding:2px 8px;line-height:1.4;display:inline-flex}.preset-select-trigger:focus-visible{outline-offset:1px;outline:2px solid #ba915694}.preset-select-icon{color:#674425d1;font-size:.7em}.preset-select-content{z-index:230;min-width:var(--radix-select-trigger-width);transform-origin:var(--radix-select-content-transform-origin);background:linear-gradient(165deg,#fff5defa,#f3dfbbf7),repeating-linear-gradient(0deg,#6042220f,#6042220f 1px,#0000 1px 5px);border:1px solid #986f43b8;border-radius:10px;overflow:hidden;box-shadow:0 10px 20px #22140a59}.preset-select-content[data-state=open]{animation:.16s ease-out menu-pop-in}.preset-select-viewport{gap:4px;padding:6px;display:grid}.preset-select-item{color:#4a2f1a;font-size:clamp(.52rem,1.02vw,.68rem);font-family:var(--font-ui);-webkit-user-select:none;user-select:none;cursor:pointer;border:1px solid #7c522a5c;border-radius:8px;padding:6px 26px 6px 8px;position:relative}.preset-select-item[data-highlighted]{background:linear-gradient(140deg,#f6d79ae6,#e5be7edb);border-color:#a0713f7a;outline:none}.preset-select-item[data-state=checked]{background:linear-gradient(140deg,#f6d79afa,#e5be7ef5)}.preset-select-item-indicator{color:#614023e6;font-size:.78em;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.meta-chip{color:#f3e5cc;background:linear-gradient(150deg,#48301de6,#382517e6);border:1px solid #cca76aa6;border-radius:999px;width:fit-content;padding:4px 9px;font-size:clamp(.58rem,1.2vw,.75rem);font-weight:700}.meta-status{color:#4e311b;overflow-wrap:anywhere;background:linear-gradient(150deg,#f8e8cdf5,#e8d0aaf0),repeating-linear-gradient(0deg,#85603314,#85603314 1px,#0000 1px 6px);border:1px solid #c59958a3;border-radius:9px;width:fit-content;max-width:clamp(110px,32vw,320px);padding:6px 9px;font-size:clamp(.56rem,1.18vw,.74rem);line-height:1.3}.discard-pool{background:radial-gradient(circle at 50% 44%,#ffeec414,#0000 50%),linear-gradient(165deg,#225438d6,#19422cd1);border:1px solid #bc925773;border-radius:10px;grid-template:"top top top"minmax(46px,.62fr)"left center right"minmax(0,1.72fr)"bottom bottom bottom"minmax(46px,.62fr)/minmax(0,1fr) minmax(58px,.64fr) minmax(0,1fr);gap:clamp(3px,.5vw,6px);min-height:0;padding:clamp(4px,.7vw,7px);display:grid;overflow:hidden}.discard-lane{background:linear-gradient(165deg,#286141b8,#1d4b33ad);border:1px solid #c59b5e6b;border-radius:8px;align-content:start;gap:clamp(1px,.2vw,3px);min-height:0;padding:clamp(2px,.42vw,4px);display:grid;overflow:visible}.discard-lane-top{grid-area:top;width:100%}.discard-lane-left{grid-area:left}.discard-lane-right{grid-area:right}.discard-lane-bottom{grid-area:bottom;width:100%}.discard-center{background:radial-gradient(circle,#f4daa41f,#f4daa400),linear-gradient(160deg,#2b674585,#20503680);border:1px dashed #d8b170a8;border-radius:8px;grid-area:center;place-content:center;justify-items:center;gap:clamp(2px,.4vw,5px);display:grid}.discard-center-label{letter-spacing:.08em;color:#f4e2c1e6;font-size:clamp(.5rem,.95vw,.62rem);font-weight:700}.discard-center-value{font-size:clamp(.92rem,2.2vw,1.5rem);line-height:1;font-family:var(--font-title);color:#fff3dc;text-shadow:0 1px #341e0e80;margin:0}.discard-tiles{flex-wrap:wrap;align-content:start;gap:2px;min-height:0;display:flex;overflow:visible}.discard-lane-top .discard-tiles,.discard-lane-bottom .discard-tiles{flex-wrap:nowrap;justify-content:flex-start;width:100%;overflow:visible}.discard-lane-left .discard-tiles,.discard-lane-right .discard-tiles{grid-template-columns:repeat(auto-fill, minmax(var(--side-discard-w), var(--side-discard-w)));justify-content:start;justify-items:start;gap:1px;display:grid}.discard-chip .tile-asset--chip{width:clamp(10px, calc(var(--chip-w) * .82), 20px);height:clamp(14px, calc(var(--chip-h) * .82), 28px)}.discard-lane-top .discard-chip .tile-asset--chip,.discard-lane-bottom .discard-chip .tile-asset--chip{width:clamp(12px, calc(var(--chip-w) * 1.02), 26px);height:clamp(16px, calc(var(--chip-h) * 1.02), 36px)}.discard-lane-left .discard-chip .tile-asset--chip,.discard-lane-right .discard-chip .tile-asset--chip{width:var(--side-discard-w);height:var(--side-discard-h)}.discard-flight-origin{pointer-events:none;z-index:560;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.discard-chip-floating .tile-asset--chip{width:clamp(26px, calc(var(--chip-w) * 2.15), 56px);height:clamp(36px, calc(var(--chip-h) * 2.15), 76px);filter:drop-shadow(0 10px 16px #120a046b)}.discard-chip-landing .tile-asset--chip{filter:drop-shadow(0 2px 3px #1c0f0759)}.tile-asset{display:block}.tile-asset--hand{width:var(--human-hand-w);height:var(--human-hand-h)}.tile-asset--chip,.tile-asset--meld{width:var(--chip-w);height:var(--chip-h)}.seat{z-index:1;background:radial-gradient(circle at 50% 0,#ffebbc0f,#0000 56%),linear-gradient(170deg,#225137b8,#1b432ec2);border:1px solid #bb925780;border-radius:10px;flex-direction:column;gap:clamp(2px,.4vw,5px);min-height:0;padding:clamp(4px,.8vw,8px);display:flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffe6b429,inset 0 -12px 18px #0000002e}.seat.current{border-color:#deb876d1;box-shadow:inset 0 0 0 1px #fce4ac52,0 0 0 1px #b9925247}.seat-top{grid-area:top}.seat-top .seat-header{text-align:right;justify-content:flex-end;gap:20px}.seat-left{grid-area:left}.seat-right{grid-area:right}.seat-bottom{grid-area:bottom;overflow:visible}.seat-bottom .seat-header{justify-content:flex-start;gap:20px}.seat-bottom.human-turn-active{border-color:#eccb8bf5;box-shadow:inset 0 0 0 1px #fce4ac57,0 0 0 1px #b9925252,0 0 16px #e2b86c29}.seat-bottom.human-turn-active:after{content:"";pointer-events:none;opacity:.34;border:1px solid #f2d191ad;border-radius:12px;position:absolute;inset:-2px}.seat-header{color:#dbc9a8;justify-content:space-between;align-items:center;gap:6px;font-size:clamp(.52rem,1.05vw,.7rem);display:flex}.seat-header-title-wrap{align-items:center;padding-right:clamp(22px,3vw,32px);display:inline-flex;position:relative}.seat-header strong{color:#f7ebd1;font-family:var(--font-title);letter-spacing:.02em;font-size:clamp(.56rem,1.1vw,.74rem)}.seat-presence{letter-spacing:.01em;pointer-events:none;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:1px 5px;font-size:clamp(.48rem,.9vw,.6rem);line-height:1.2;display:inline-flex;position:absolute;top:-.52em;right:0}.seat-presence.online{color:#d8ffe7;background:#1d6c3a5c;border-color:#4eae7685}.seat-presence.offline{color:#ffe2df;background:#8e201c70;border-color:#c24a3a9e}.melds,.discards{flex-wrap:wrap;align-content:flex-start;gap:clamp(1px,.28vw,4px);min-height:0;display:flex}.seat-main-row{flex:1;align-items:flex-end;gap:clamp(3px,.5vw,6px);min-height:0;display:flex}.seat-main-row .melds{flex:none;max-width:38%;overflow:hidden}.seat-main-row-human .hand-row{flex:auto}.human-hand-area{flex:auto;align-items:flex-end;min-width:0;display:flex;position:relative;overflow:visible}.human-hand-area-with-actions{padding-top:0}.human-hand-area .hand-row{width:100%}.seat-main-row-ai .hidden-hand-row{flex:auto}.hidden-hand-row{flex-wrap:nowrap;align-items:flex-end;gap:clamp(1px,.28vw,3px);min-height:0;display:flex;overflow:hidden}.seat-top .hidden-hand-row{justify-content:center}.hidden-hand-tile .tile-asset--chip{width:var(--ai-back-w);height:var(--ai-back-h)}.seat-left .hidden-hand-row,.seat-right .hidden-hand-row{flex-direction:column;justify-content:flex-start;align-items:center;gap:1px;height:100%;min-height:0}.seat-left .seat-main-row,.seat-right .seat-main-row{align-items:flex-start}.seat-left .seat-main-row-ai .hidden-hand-row{order:-1}.seat-left .hidden-hand-tile,.seat-right .hidden-hand-tile{width:var(--side-ai-back-h);height:var(--side-ai-back-w);justify-content:center;align-items:center;display:inline-flex}.seat-left .hidden-hand-tile .tile-asset--chip,.seat-right .hidden-hand-tile .tile-asset--chip{width:var(--side-ai-back-w);height:var(--side-ai-back-h);transform-origin:50%;transform:rotate(90deg)}.seat.revealed-ai-hand .tile.hand:disabled{opacity:1;cursor:default}.seat-left.revealed-ai-hand .hand-row,.seat-right.revealed-ai-hand .hand-row{flex-flow:wrap;flex:auto;place-content:flex-start;align-items:flex-end;gap:2px;width:100%;min-height:0}.seat-left.revealed-ai-hand .tile-asset--hand,.seat-right.revealed-ai-hand .tile-asset--hand{width:var(--side-reveal-hand-w);height:var(--side-reveal-hand-h)}.hand-row{flex-wrap:nowrap;justify-content:center;align-items:flex-end;gap:clamp(1px,.32vw,4px);min-height:0;display:flex;overflow:hidden}.seat-bottom .hand-row{overflow:visible}.meld-item{will-change:transform, opacity;transform-origin:50%;color:#50331c;background:linear-gradient(145deg,#fae9c6f0,#e3c799e6),repeating-linear-gradient(0deg,#74502b14,#74502b14 1px,#0000 1px 6px);border:1px solid #c69d638f;border-radius:6px;align-items:center;gap:3px;padding:2px 4px;font-size:clamp(.46rem,.9vw,.62rem);display:inline-flex}.meld-label{font-size:clamp(.44rem,.84vw,.56rem);font-weight:700}.tile.hand{cursor:pointer;transition:transform .2s,filter .2s}.tile.hand:hover:not(:disabled){transform:translateY(-2px)}.tile.hand.selected{filter:brightness(1.08);transform:translateY(-6px)}.tile.hand.drawn{transform:translateY(-1px)}.tile.hand.drawn.selected{transform:translateY(-6px)}.tile.hand:disabled{cursor:not-allowed;opacity:.6}.drawn-separator{background:linear-gradient(#e2c27e29,#e2c27edb,#e2c27e29);border-radius:999px;width:1px;height:85%;margin:0 2px}.action-float{right:calc(var(--pad) + env(safe-area-inset-right));bottom:calc(var(--pad) + env(safe-area-inset-bottom));z-index:420;pointer-events:auto;width:fit-content;max-width:min(42vw,420px);animation:.16s ease-out both float-in;position:fixed}.action-inline{z-index:8;pointer-events:auto;width:fit-content;max-width:min(100%,360px);animation:.16s ease-out both float-in;position:absolute;top:auto;bottom:calc(100% + clamp(4px,.6vw,8px));right:0}.action-ting-hint{pointer-events:none;background:#1e452fb3;border:1px solid #dfbb7c8a;border-radius:8px;align-items:center;gap:5px;max-width:min(68vw,420px);margin-bottom:0;margin-left:0;padding:3px 6px;display:inline-flex}.action-row{justify-content:flex-end;align-items:flex-start;gap:6px;width:100%;max-width:100%;display:flex}.action-ting-hint-label{color:#f2deb2;letter-spacing:.04em;flex:none;font-size:clamp(.52rem,.95vw,.66rem)}.action-ting-hint-tiles{flex-wrap:wrap;gap:3px;min-width:0;display:flex}.action-ting-hint-tile.tile-asset--chip{width:clamp(14px,1.7vw,22px);height:clamp(19px,2.35vw,30px)}.action-buttons{flex-wrap:wrap;flex:auto;justify-content:flex-end;align-items:center;gap:5px;width:auto;min-width:0;max-width:100%;margin-top:0;display:flex;overflow:visible}.action-buttons button{max-width:100%;font-size:clamp(.62rem,1.25vw,.8rem);font-weight:600;font-family:var(--font-ui);white-space:normal;cursor:pointer;color:#3f2918;background:linear-gradient(145deg,#f6d9a0fa,#dfb877f5);border:1px solid #7c522a80;border-radius:8px;padding:6px 10px;line-height:1.25}.action-buttons button:hover{filter:brightness(1.03)}.action-buttons .action-btn-hu{color:#fff6ea;background:linear-gradient(145deg,#d6543dfa,#af3a26fa);border-color:#a93924c7}.action-buttons .action-btn-peng{color:#f3fffa;background:linear-gradient(145deg,#4e9a81f5,#2a725dfa);border-color:#256759cc}.action-buttons .action-btn-gang{color:#f8f4ff;background:linear-gradient(145deg,#836dbff5,#5f4a98fa);border-color:#58448cc7}.action-buttons .action-btn-pass{color:#4f3623;background:linear-gradient(145deg,#eedbbafa,#d8bc94f5);border-color:#7c5a3ba6}.action-button-content{align-items:center;gap:4px;display:inline-flex}.action-button-label{white-space:normal}.action-button-tile.tile-asset--chip{width:clamp(12px,1.4vw,18px);height:clamp(16px,1.95vw,24px)}@keyframes float-in{0%{opacity:0;transform:translateY(6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}html,body,#root{width:100%;height:100%;margin:0}.mahjong-app{--ratio:2.16744;--table-w:min(100vw, calc(100svh * var(--ratio)));--table-h:min(100svh, calc(100vw / var(--ratio)));--pad:clamp(6px, 1.2vw, 12px);--gap:clamp(4px, .8vw, 10px);--human-hand-w:clamp(18px, calc(var(--table-w) / 17.2), 44px);--human-hand-h:calc(var(--human-hand-w) * 1.36);--chip-w:clamp(11px, calc(var(--human-hand-w) * .62), 24px);--chip-h:calc(var(--chip-w) * 1.36);--side-discard-w:clamp(8px, calc(var(--chip-w) * .64), 15px);--side-discard-h:clamp(11px, calc(var(--chip-h) * .64), 22px);--ai-back-w:clamp(10px, calc(var(--table-w) / 66), 22px);--ai-back-h:calc(var(--ai-back-w) * 1.4);--side-ai-back-w:clamp(8px, calc(var(--table-h) / 58), 14px);--side-ai-back-h:calc(var(--side-ai-back-w) * 1.55);--side-reveal-hand-w:clamp(12px, calc(var(--human-hand-w) * .78), 24px);--side-reveal-hand-h:calc(var(--side-reveal-hand-w) * 1.36);--wood-deep:#4a2f1c;--wood-mid:#6c472b;--wood-glow:#9a6d3f;--felt-deep:#245238;--felt-mid:#2f6946;--felt-light:#3b7d56;--line-gold:#d9b571b8;color:#f3ebda;box-sizing:border-box;-webkit-user-select:none;user-select:none;background:radial-gradient(circle at 48% 55%,#ffecc91f,#0000 48%),radial-gradient(circle at 18% 16%,#0000002e,#0000 38%),radial-gradient(circle at 82% 88%,#0003,#0000 44%),repeating-linear-gradient(24deg,#ffdcaa12,#ffdcaa12 2px,#0000 2px 16px),linear-gradient(130deg,#3e2616 0%,#5a3821 44%,#342112 100%);place-items:center;width:100vw;height:100svh;animation:.35s ease-out both app-fade;display:grid;overflow:hidden}@keyframes app-fade{0%{opacity:0;transform:scale(.99)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}.table-grid{width:var(--table-w);height:var(--table-h);gap:var(--gap);padding:var(--pad);background:radial-gradient(circle at 50% 45%, #f6e6b114, transparent 52%), linear-gradient(165deg, var(--felt-light) 0%, var(--felt-mid) 40%, var(--felt-deep) 100%);border:2px solid #a47644c7;border-radius:16px;grid-template:"top top top"minmax(58px,.85fr)"left center right"minmax(0,2.05fr)"bottom bottom bottom"minmax(76px,1.06fr)/minmax(92px,.95fr) minmax(0,2.3fr) minmax(92px,.95fr);display:grid;position:relative;overflow:hidden;box-shadow:inset 0 0 0 2px #38221261,inset 0 0 0 10px #50351f3d,inset 0 -14px 26px #00000040,0 12px 22px #1d100857}.table-grid:before{content:"";pointer-events:none;background:repeating-linear-gradient(-26deg,#ffffff0a,#ffffff0a 1px,#0000 1px 14px),repeating-linear-gradient(26deg,#0000000a,#0000000a 1px,#0000 1px 16px);position:absolute;inset:0}.table-grid:after{content:"";border:1px solid var(--line-gold);pointer-events:none;border-radius:12px;position:absolute;inset:8px;box-shadow:inset 0 0 0 1px #ffe0a51f,0 0 0 1px #3a241466}.center-panel{z-index:1;gap:var(--gap);grid-area:center;grid-template-rows:minmax(0,1fr);min-height:0;display:grid;position:relative}.muted{color:#d6c3a1;font-size:clamp(.5rem,.92vw,.62rem)}.tile{background:0 0;border:0;justify-content:center;align-items:center;min-width:0;padding:0;line-height:0;display:inline-flex}.room-lobby-panel{color:#eef4ff;background:#0a101cb8;border:1px solid #ffffff2e;border-radius:14px;width:min(680px,92vw);margin:18px auto 0;padding:16px}.room-seat-list{margin:12px 0;padding-left:18px}.room-lobby-actions{flex-wrap:wrap;gap:10px;display:flex}.room-lobby-actions button{min-width:104px}.room-connection-error{color:#ffd3d3;width:min(680px,92vw);margin:10px auto 0;font-size:13px}.round-settlement-overlay{z-index:80;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);background:#060a1447;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.round-settlement-dialog{color:#eef4ff;background:#090f1b9e;border:1px solid #fff3;border-radius:14px;width:min(640px,92vw);padding:18px;box-shadow:0 20px 42px #0409117a}.round-settlement-dialog h2{margin:0 0 6px}.round-settlement-dialog p{margin:0}.round-settlement-list{margin:12px 0;padding-left:18px}.round-settlement-actions{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.history-page{color:#f4e9d2;background:radial-gradient(circle at 82% 12%,#f6ca7a29,#0000 38%),radial-gradient(circle at 10% 88%,#54b08224,#0000 40%),linear-gradient(128deg,#14251d,#0f1c16 54%,#17231d);min-height:100svh;padding:clamp(16px,3vw,30px)}.history-card{background:linear-gradient(160deg,#1a2c24e6,#0e1914ed),repeating-linear-gradient(-25deg,#ffffff08,#ffffff08 1px,#0000 1px 13px);border:1px solid #e9cc973d;border-radius:16px;width:min(920px,100%);margin:0 auto;padding:clamp(14px,2vw,20px);box-shadow:0 10px 28px #0000003d}.history-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.history-kicker{color:#f7d8a2;letter-spacing:.1em;text-transform:uppercase;background:#f8dba226;border:1px solid #f8dba242;border-radius:999px;margin:0;padding:5px 10px;font-size:.7rem;display:inline-block}.history-header h1{color:#f8e6c1;margin:8px 0 0;font-size:clamp(1.3rem,2.2vw,1.8rem)}.history-back-btn{color:#f4deba;cursor:pointer;background:#09120e6b;border:1px solid #f8daa361;border-radius:10px;padding:10px 14px}.history-muted{color:#ece1c6d6;margin:10px 0 0}.history-table-wrap{margin-top:10px;overflow-x:auto}.history-table{border-collapse:collapse;width:100%;min-width:520px}.history-table th,.history-table td{text-align:left;color:#f6e6c8;border-bottom:1px solid #ecd09e33;padding:10px 8px}.history-table th{color:#f8dbac;font-weight:700}.history-load-more-btn{cursor:pointer;color:#203327;background:linear-gradient(120deg,#8fd4ac,#7ec89f);border:0;border-radius:10px;margin-top:12px;padding:10px 14px;font-weight:700}.history-load-more-btn:disabled{opacity:.58;cursor:not-allowed}.history-feedback{color:#f3dfb9;background:#fcda991c;border:1px solid #fcda993d;border-radius:10px;margin:10px 0 0;padding:8px 10px;font-size:.85rem}.history-list{gap:12px;margin-top:10px;display:grid}.history-item-card{background:#0a130f73;border:1px solid #e9cc9733;border-radius:12px;padding:10px 12px}.history-item-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.history-item-head h2{color:#f8e6c1;margin:0;font-size:1rem}.history-item-head p{color:#ece1c6c7;margin:4px 0 0;font-size:.84rem}.history-item-summary{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:inline-flex}.history-item-summary span{color:#f7ddb1;border:1px solid #f8dba233;border-radius:999px;align-items:center;padding:2px 8px;font-size:.78rem;display:inline-flex}@media (width<=620px){.history-header,.history-item-head{flex-direction:column}.history-item-summary{justify-content:flex-start}}.lobby-page{color:#f4e9d2;background:radial-gradient(circle at 78% 14%,#f6ca7a2e,#0000 38%),radial-gradient(circle at 8% 88%,#54b08229,#0000 40%),linear-gradient(128deg,#14251d,#0f1c16 54%,#17231d);min-height:100svh;padding:clamp(16px,3vw,30px)}.lobby-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.lobby-kicker{color:#f7d8a2;letter-spacing:.1em;text-transform:uppercase;background:#f8dba226;border:1px solid #f8dba242;border-radius:999px;margin:0;padding:5px 10px;font-size:.7rem;display:inline-block}.lobby-header h1{color:#f8e6c1;margin:8px 0 6px;font-size:clamp(1.4rem,2.8vw,2rem)}.lobby-header p{color:#ece1c6d6;margin:0}.ghost-btn{color:#f4deba;cursor:pointer;background:#09120e6b;border:1px solid #f8daa361;border-radius:10px;padding:10px 14px}.lobby-main{grid-template-columns:1fr;gap:16px;max-width:720px;margin:0 auto;display:grid}.lobby-panel{background:linear-gradient(160deg,#1a2c24e6,#0e1914ed),repeating-linear-gradient(-25deg,#ffffff08,#ffffff08 1px,#0000 1px 13px);border:1px solid #e9cc973d;border-radius:18px;padding:clamp(14px,2vw,20px);box-shadow:0 10px 28px #0000003d}.panel-head{justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:12px;display:flex}.panel-head h2{color:#f8e3bb;margin:0;font-size:1.08rem}.panel-head span{color:#e9ddc2b8;font-size:.82rem}.action-panel{align-content:start;gap:12px;display:grid}.primary-action,.secondary-action{cursor:pointer;border:0;border-radius:12px;padding:11px 14px;font-weight:700}.primary-action{color:#23372c;background:linear-gradient(120deg,#f3cc84,#ffdeac)}.secondary-action{color:#f4dbb2;background:#08110e8f;border:1px solid #f1d6a75c}.primary-action:disabled,.secondary-action:disabled{opacity:.58;cursor:not-allowed}.join-field,.preset-field{gap:8px;display:grid}.preset-field span{color:#efdbb7;font-size:.88rem}.preset-field select{color:#f6e6c8;background:#09130fb3;border:1px solid #e0c29052;border-radius:10px;outline:none;padding:10px 11px}.preset-field select:disabled{opacity:.65;cursor:not-allowed}.join-field span{color:#efdbb7;font-size:.88rem}.join-field div{grid-template-columns:1fr auto;gap:8px;display:grid}.join-field input{color:#f6e6c8;background:#09130fb3;border:1px solid #e0c29052;border-radius:10px;outline:none;padding:10px 11px}.join-field button{cursor:pointer;color:#203327;background:linear-gradient(120deg,#8fd4ac,#7ec89f);border:0;border-radius:10px;padding:10px 14px;font-weight:700}.feedback{color:#f3dfb9;background:#fcda991c;border:1px solid #fcda993d;border-radius:10px;margin:2px 0 0;padding:8px 10px;font-size:.85rem}@media (width<=620px){.lobby-header{flex-direction:column}}.result-page{background:radial-gradient(circle at 15% 20%,#4c84ff40,#0000 45%),radial-gradient(circle at 80% 10%,#00daaa33,#0000 42%),linear-gradient(140deg,#06101f 0%,#0a1d35 48%,#12253c 100%);place-items:center;min-height:100dvh;padding:20px;display:grid}.result-card{color:#eff6ff;background:#080e1ac7;border:1px solid #fff3;border-radius:16px;width:min(680px,92vw);padding:24px;box-shadow:0 20px 45px #03091280}.result-kicker{letter-spacing:.08em;text-transform:uppercase;color:#cae0ffe6;margin:0;font-size:12px}.result-card h1{margin:8px 0 6px;font-size:28px}.result-time{color:#e7f0ffe0;margin:0 0 18px}.result-table-wrap{overflow-x:auto}.result-table{border-collapse:collapse;width:100%}.result-table th,.result-table td{text-align:left;border-bottom:1px solid #ffffff1f;padding:10px 12px}.result-table th{color:#cde0ffe6;font-size:13px}.result-back-btn{min-width:112px;margin-top:16px}
