:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#f4f7f2;background:#06130e;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#app{overscroll-behavior:none}body{background:radial-gradient(circle at top,#17422e,#06130e 55%);min-height:100vh;margin:0}button,input{font:inherit}button{cursor:pointer;color:#f4f7f2;background:#213a31;border:0;border-radius:10px;padding:.6rem .8rem;box-shadow:inset 0 0 0 1px #355f50}button:hover:not(:disabled){background:#2c5244}button:disabled{opacity:.45;cursor:not-allowed}button.primary{color:#1f1300;box-shadow:none;background:linear-gradient(135deg,#f7c948,#f59e0b);font-weight:800}button.discard{background:#4d1f28;box-shadow:inset 0 0 0 1px #7f3342}button.danger{background:#4d1f28;box-shadow:inset 0 0 0 1px #9f4554}main{width:min(1280px,96vw);margin:0 auto;padding:1.4rem 0 3rem}h1{letter-spacing:-.04em;margin:0;font-size:clamp(1.8rem,4vw,3.2rem)}h2,h3{margin:0}.topbar{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.topbar p{color:#b7c9bf;margin:.2rem 0 0}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.compact-game-header{align-items:flex-start;margin-bottom:.55rem}.compact-game-header h1{font-size:clamp(1.45rem,6vw,2.35rem)}.game-status-pill{color:#d7eadf;white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:999px;align-items:center;gap:.45rem;padding:.42rem .68rem;display:inline-flex}.game-status-pill strong{color:#f7c948}.game-status-pill span{color:#b7c9bf}.room-menu{margin-left:auto;position:relative}.room-menu summary{cursor:pointer;background:#ffffff12;border-radius:999px;padding:.5rem .85rem;font-weight:800;list-style:none;box-shadow:inset 0 0 0 1px #355f50}.room-menu summary::-webkit-details-marker{display:none}.room-menu[open] .topbar-actions{z-index:10;background:#05120dfa;border:1px solid #ffffff24;border-radius:16px;grid-template-columns:1fr;width:min(82vw,270px);padding:.55rem;display:grid;position:absolute;top:calc(100% + .45rem);right:0;box-shadow:0 18px 44px #00000061}.message{background:#4d1f28;border:1px solid #dd6175;border-radius:14px;margin:1rem 0;padding:.85rem 1rem}.setup{max-width:760px}.setup p{color:#cfe3d9;font-size:1.1rem}.sharebox{grid-template-columns:1fr auto;gap:.5rem;margin:.8rem 0 1rem;display:grid}form{background:#ffffff12;border:1px solid #ffffff1f;border-radius:20px;gap:.8rem;padding:1rem;display:grid}label{gap:.3rem;font-weight:700;display:grid}input{color:#fff;background:#0b1c15;border:1px solid #466b5d;border-radius:10px;width:100%;padding:.75rem}.players{grid-template-columns:repeat(auto-fit,minmax(310px,1fr));align-items:start;gap:1rem;display:grid}.play-area{gap:.8rem;display:grid}.focus-player .player{margin:0}.opponents{color:#d6e6de;margin-top:.4rem}.visible-opponents{background:#ffffff09;border:1px solid #ffffff14;border-radius:20px;padding:.55rem}.visible-opponents h2{color:#f7c948;font-size:1.15rem}.visible-opponents p{color:#b7c9bf;margin:.3rem 0 .7rem}.opponents-list{margin-top:0}.turn-notice{z-index:5;color:#1f1300;background:#f7c948;border-radius:16px;justify-content:space-between;align-items:center;gap:.8rem;margin:.75rem 0;padding:.7rem .9rem;font-size:1.05rem;font-weight:800;display:flex;position:sticky;top:.4rem;box-shadow:0 12px 32px #00000059}.turn-notice button{color:#1f1300;box-shadow:none;background:#1f130029;padding:.35rem .65rem}.player,.hand-panel,.result,.log,.rules{background:#05120dd1;border:1px solid #ffffff1f;border-radius:22px;padding:1rem;box-shadow:0 20px 80px #00000038}.player.current{outline:3px solid #f7c948}.active-player-badge{color:#1f1300;background:#f7c948;border-radius:999px;align-items:center;width:max-content;margin:-.25rem 0 .45rem;padding:.25rem .65rem;font-weight:900;display:inline-flex;box-shadow:0 8px 22px #f7c9482e}.player.focus-card{background:#081c14f0}.player header{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.8rem;display:flex}.player header span,.player header em{color:#f7c948;font-style:normal;font-weight:800}.board-row{touch-action:pan-y;grid-template-columns:92px 1fr;align-items:center;gap:.4rem;margin:.45rem 0;display:grid}.board-row small{color:#9ec8b5;grid-column:2}.row-cards{flex-wrap:wrap;align-items:center;gap:.32rem;min-height:48px;display:flex}.slot{color:#426254;border:1px dashed #426254;border-radius:9px;place-items:center;width:42px;height:58px;display:inline-grid}.card{color:#111827;-webkit-user-select:none;user-select:none;background:#f9fafb;border-radius:9px;grid-template-rows:1fr 1fr;place-items:center;width:42px;height:58px;font-weight:900;line-height:.95;display:inline-grid;box-shadow:0 5px 12px #00000040}.card .rank{font-size:1.05em}.card .suit{margin-top:-.15em;font-size:1.25em}.card.heart,.card.diamond{color:#d90429}.card.black{color:#111827}.card.hidden-card{color:#f7c948;background:linear-gradient(135deg,#17382c,#0b1c15);border:2px solid #355f50}.card.small{width:34px;height:48px;font-size:.85rem}.rank-summary{color:#bcebd4;margin-top:.7rem;font-size:.9rem}.rank-summary.bad{color:#ff8ea1;font-weight:800}.hand-panel{margin-top:.65rem}.hand-panel p{color:#d8efe4}.compact-waiting{padding-block:.55rem}.compact-waiting p{margin:0}.hand-panel-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.8rem;margin-bottom:.45rem;display:flex}.hand-panel-header p{margin:0}.hint{margin:.35rem 0 .6rem;font-weight:700;color:#f7c948!important}.hand{flex-wrap:wrap;gap:.75rem;display:flex}.hand-grid{background:#ffffff0b;border:1px solid #ffffff14;border-radius:18px;grid-template-columns:repeat(auto-fill,58px);justify-content:start;align-items:center;gap:.58rem;min-height:0;padding:.65rem;display:grid;overflow:visible}.fan-hand{scrollbar-width:thin;align-items:flex-end;gap:0;min-height:122px;padding:1rem .4rem .55rem;overflow:auto visible}.hand-card{background:#ffffff0f;border-radius:15px;justify-items:center;gap:.5rem;padding:.7rem;display:grid}.board-card{box-shadow:none;touch-action:none;background:0 0;padding:0}.board-card.selected .card{border:3px solid #f7c948;transform:translateY(-4px);box-shadow:0 12px 22px #f7c94838}.fan-card{width:62px;min-width:62px;box-shadow:none;transform:translateY(calc((var(--i) - (var(--n) - 1) / 2) * 1px)) rotate(calc((var(--i) - (var(--n) - 1) / 2) * 1.7deg));touch-action:none;background:0 0;flex:0 0 49px;margin-right:-10px;padding:0}.hand-grid .fan-card{flex:none;justify-self:center;width:58px;min-width:58px;margin-right:0;transform:none}.fantasy-hand-panel{background:linear-gradient(#0c241bf2,#05120de0);border-color:#f7c94857}.clean-fantasy-hand{grid-template-columns:repeat(auto-fill,58px);gap:.58rem}.clean-fantasy-hand .clean-card{flex:none;justify-self:center;width:58px;min-width:58px;margin-right:0;transform:none}.clean-fantasy-hand .clean-card .card{width:54px;height:74px}.fan-card .card{border:3px solid #0000;width:58px;height:80px;font-size:1.08rem}.fan-card.selected .card{border-color:#f7c948;transform:translateY(-10px);box-shadow:0 16px 28px #f7c94840}.fan-card.drag-source{opacity:.35}.drag-ghost{z-index:9999;pointer-events:none;filter:drop-shadow(0 18px 22px #00000073);opacity:.96;position:fixed;transform:translate(-50%,-58%)scale(1.08)}.drag-ghost .card{width:64px;height:88px}.drop-actions{grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem;margin-top:.85rem;display:grid}.clean-drop-actions{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-top:.55rem}.drop-button{border:1px dashed #6ea58d;min-height:48px}.drop-button.drop-hot,.drop-row.drop-hot,.hand-grid.drop-hot{background:#f7c9482e;outline:3px solid #f7c948;box-shadow:0 0 0 4px #f7c9482e}.drop-row{cursor:pointer;border-radius:14px;outline:1px dashed #f7c94859;padding:.25rem}.drop-row:hover{background:#f7c94814}.actions{flex-wrap:wrap;justify-content:center;gap:.35rem;max-width:230px;display:flex}.actions button{padding:.45rem .55rem;font-size:.85rem}.turn-actions{justify-content:flex-end;gap:.6rem;margin-top:.8rem;display:flex}.compact-turn-actions{grid-template-columns:repeat(2,minmax(180px,1fr));align-items:stretch;max-width:520px;margin-top:.6rem;margin-left:auto;display:grid}.compact-turn-actions .finish-button{min-height:52px;font-size:1.08rem}.compact-turn-actions button:only-child{grid-column:1/-1}.mobile-turn-bar{display:none}.result{margin-top:1rem}.result ol{gap:.6rem;padding-left:1.2rem;display:grid}.result small{color:#aec9bd;margin-top:.15rem;display:block}.log{color:#cbded5;margin-top:1rem}.log h3{margin-bottom:.5rem}.rules{color:#d6e6de;margin-top:1rem}.rules summary{cursor:pointer;color:#f7c948;font-weight:900}.rules li{margin:.45rem 0}@media (width<=720px){main{width:100%;padding:.75rem .7rem calc(7.25rem + env(safe-area-inset-bottom))}h1{font-size:clamp(1.65rem,8vw,2.35rem)}.topbar,.player header{flex-direction:column;align-items:flex-start}.topbar{gap:.55rem;margin-bottom:.5rem}.compact-game-header{flex-direction:row;align-items:center;gap:.5rem}.compact-game-header h1{font-size:1.75rem}.game-status-pill{gap:.35rem;padding:.36rem .55rem;font-size:.9rem}.room-menu{flex:none}.room-menu summary{min-height:42px;padding:.48rem .72rem}.topbar-actions{grid-template-columns:1fr 1fr;width:100%;display:grid}.topbar-actions button{min-height:44px;padding:.48rem .55rem}.topbar-actions button[data-action=enable-notifications]{grid-column:1/-1}.player,.hand-panel,.result,.log,.rules{border-radius:18px;padding:.72rem;box-shadow:0 10px 34px #0000002e}.player.current{outline:2px solid #f7c948}.active-player-badge{margin:-.1rem 0 .35rem;padding:.22rem .55rem;font-size:.86rem}.player header{gap:.18rem;margin-bottom:.45rem}.player header h2{font-size:1.55rem}.board-row{grid-template-columns:1fr;gap:.25rem;margin:.28rem 0;padding:.28rem}.board-row b{font-size:1.05rem}.board-row small{grid-column:1}.row-cards{flex-wrap:nowrap;gap:.26rem;min-height:46px;overflow-x:auto}.card,.slot{border-radius:8px;width:38px;height:52px}.card .rank{font-size:.98em}.card .suit{font-size:1.12em}.rank-summary{margin-top:.45rem;font-size:.85rem}.hand-panel{margin-top:0}.hand-panel h2{font-size:1.45rem}.hand-panel-header{gap:.25rem}.hand-panel p{margin:.35rem 0}.hint{font-size:.98rem;line-height:1.15}.fan-hand{min-height:102px;padding:.55rem .15rem .35rem}.hand-grid{grid-template-columns:repeat(auto-fill,minmax(48px,1fr));justify-content:stretch;gap:.38rem;padding:.45rem}.fan-card{min-width:52px;transform:rotate(calc((var(--i) - (var(--n) - 1) / 2) * .65deg));flex-basis:42px;margin-right:-12px}.hand-grid .fan-card,.clean-fantasy-hand .clean-card{width:100%;min-width:0;margin-right:0;transform:none}.fan-card .card{width:52px;height:72px;font-size:1rem}.clean-fantasy-hand{grid-template-columns:repeat(auto-fit,minmax(48px,1fr));gap:.4rem}.clean-fantasy-hand .clean-card .card{width:52px;height:72px}.drop-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:.4rem;margin-top:.55rem}.clean-drop-actions{grid-template-columns:1fr}.drop-button{min-height:46px;padding:.45rem}.desktop-turn-actions{display:none}.mobile-turn-bar{left:.65rem;right:.65rem;bottom:calc(.65rem + env(safe-area-inset-bottom));z-index:40;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#05120df5;border:1px solid #f7c94861;border-radius:18px;grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:.45rem;padding:.5rem;display:grid;position:fixed;box-shadow:0 18px 48px #0000008c,inset 0 0 0 1px #ffffff0d}.mobile-turn-bar button{border-radius:13px;min-height:54px;padding:.5rem .45rem;font-size:.98rem;font-weight:900}.mobile-turn-bar button:only-child{grid-column:1/-1}.mobile-finish-action{font-size:1.03rem}.turn-actions{flex-direction:column;gap:.45rem;margin-top:.6rem}.compact-turn-actions{grid-template-columns:1fr 1fr;display:grid}.compact-turn-actions .finish-button{grid-column:1/-1;min-height:50px}.turn-actions button{min-height:44px;padding:.45rem .6rem}.desktop-turn-actions,.desktop-drop-actions{display:none!important}.opponents summary{padding:.55rem 0}.opponents-list{grid-template-columns:1fr}.log{font-size:.86rem}}
