:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-color:#07130f;--felt:#0f3b30;--felt-light:#165246;--panel:#111827;--panel-soft:#182238;--panel-border:#ffffff1f;--text-main:#f8fafc;--text-muted:#aab6c5;--accent-color:#2f80ed;--accent-strong:#1d4ed8;--warning:#d99124;--danger:#c2412d;--success:#22a06b;--card-back:#2f80ed;--card-back-ink:#dbeafe;--card-width:clamp(58px, 17vw, 88px);--card-height:calc(var(--card-width) * 1.5);--detail-card-width:clamp(58px, 16vw, 80px);--detail-card-height:calc(var(--detail-card-width) * 1.5);--table-card-width:clamp(76px, 22vw, 112px);--table-card-height:calc(var(--table-card-width) * 1.5);--hand-card-overlap:clamp(6px, 2vw, 10px);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.35}*{box-sizing:border-box}html{background:var(--bg-color);overscroll-behavior:none;width:100%;height:100%;overflow:hidden}body{background:var(--bg-color);width:100%;min-width:320px;height:100%;color:var(--text-main);overscroll-behavior:none;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;margin:0;position:fixed;inset:0;overflow:hidden}button,input,select{font:inherit}input,select{-webkit-user-select:text;user-select:text}button{touch-action:manipulation}#root{overscroll-behavior:none;width:100%;height:100%;position:absolute;inset:0;overflow:hidden}.glass-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#111827bf;border:1px solid #ffffff14;border-radius:16px;box-shadow:0 24px 50px #00000073}.btn{letter-spacing:.02em;text-transform:uppercase;cursor:pointer;color:#fff;background:linear-gradient(135deg,#2f80ed 0%,#1d4ed8 100%);border:0;border-radius:12px;min-height:44px;padding:0 16px;font-size:.8rem;font-weight:800;transition:transform .12s,opacity .12s,background-color .12s,box-shadow .12s;box-shadow:0 4px 12px #2f80ed4d}.btn:active{transform:translateY(2px);box-shadow:0 2px 6px #00000026}.btn:disabled{cursor:not-allowed;opacity:.4;box-shadow:none;transform:none}.btn-primary{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);box-shadow:0 4px 12px #3b82f64d}.btn-primary:not(:disabled):hover{background:linear-gradient(135deg,#60a5fa 0%,#2563eb 100%);box-shadow:0 6px 16px #3b82f673}.btn-secondary{color:#fff;background:linear-gradient(135deg,#4b5563 0%,#1f2937 100%);border:1px solid #ffffff14;box-shadow:0 4px 12px #0003}.btn-secondary:not(:disabled):hover{background:linear-gradient(135deg,#6b7280 0%,#374151 100%)}.btn-warning{color:#111827;background:linear-gradient(135deg,#fbbf24 0%,#d97706 100%);box-shadow:0 4px 12px #f59e0b4d}.btn-warning:not(:disabled):hover{background:linear-gradient(135deg,#fcd34d 0%,#b45309 100%)}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#b91c1c 100%);box-shadow:0 4px 12px #ef44444d}.btn-danger:not(:disabled):hover{background:linear-gradient(135deg,#f87171 0%,#dc2626 100%)}.btn-makao{color:#111827;background:linear-gradient(135deg,#fcd34d 0%,#d97706 100%);box-shadow:0 4px 12px #f59e0b4d}input,select{border:1px solid var(--panel-border);width:100%;min-height:48px;color:var(--text-main);background:#0b1220;border-radius:8px;outline:none;padding:0 14px}input:focus,select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #2f80ed40}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.eyebrow{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin:0 0 4px;font-size:.78rem;font-weight:800}.home-screen,.lobby-screen{height:100dvh;padding:max(18px, env(safe-area-inset-top)) 18px max(18px, env(safe-area-inset-bottom));overscroll-behavior:none;scrollbar-width:none;overflow:hidden}.home-screen::-webkit-scrollbar{display:none}.lobby-screen::-webkit-scrollbar{display:none}.game-screen::-webkit-scrollbar{display:none}.home-screen{background:linear-gradient(180deg, var(--felt) 0%, var(--bg-color) 58%);align-content:center;gap:24px;display:grid}.home-hero{text-align:center}.home-hero h1{margin:0;font-size:clamp(3rem,17vw,5.5rem);line-height:.95}.home-card{gap:14px;width:min(100%,430px);margin:0 auto;padding:18px;display:grid}.home-session-notice{color:#f8e8a3;background:#f2c14e1f;border:1px solid #f2c14e61;border-radius:8px;padding:10px 12px;font-size:.86rem;font-weight:800}.form-divider{color:var(--text-muted);text-align:center;font-size:.85rem;font-weight:800}.server-panel{gap:8px;padding-top:2px;display:grid}.home-settings{gap:10px;display:grid}.home-settings-backdrop{z-index:70;padding:max(12px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));background:linear-gradient(#0108061a,#010806b8);place-items:end center;display:grid;position:fixed;inset:0}.home-server-sheet{background:linear-gradient(#121a2af5,#080d16fa),#0a101cfa;border:1px solid #f2c14e47;border-radius:18px;gap:12px;width:min(100%,430px);max-height:calc(100dvh - 28px);padding:12px;display:grid;overflow:hidden;box-shadow:0 24px 58px #0000008a}.home-server-sheet-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.home-server-sheet-head span{color:var(--text-muted);text-transform:uppercase;font-size:.72rem;font-weight:900}.home-server-sheet-head .btn{min-height:36px;padding-inline:12px}.settings-toggle{border:1px solid var(--panel-border);width:100%;min-height:46px;color:var(--text-main);font:inherit;text-align:left;cursor:pointer;background:#0f172ab8;border-radius:8px;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:0 12px;font-weight:900;display:grid}.settings-toggle-icon{background:#ffffff1a;border-radius:999px;place-items:center;width:26px;height:26px;font-size:1rem;line-height:1;display:grid}.server-row,.server-actions{justify-content:space-between;align-items:center;gap:8px;display:flex}.server-row span{color:var(--text-muted);font-size:.86rem;font-weight:800}.server-status{color:var(--text-muted);white-space:nowrap;background:#ffffff1a;border-radius:999px;padding:3px 8px;font-size:.74rem}.server-status-connected{color:#67e8a5}.server-status-error,.server-status-disconnected{color:#fca5a5}.server-actions .btn{flex:1 1 0;min-height:42px;padding:0 10px}.home-flow-head,.settings-card-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.home-flow-step,.home-field span,.settings-card-head span{color:var(--text-muted);text-transform:uppercase;font-size:.74rem;font-weight:900}.home-field{gap:6px;display:grid}.home-value-button,.settings-card input{color:#f8fafc;background:#030a14bd;border:1px solid #ffffff1f;border-radius:14px;outline:none;width:100%;min-height:48px;padding:0 14px;font-weight:900}.home-value-button{color:#f8fafc80;font:inherit;text-align:left;touch-action:manipulation;justify-content:flex-start;align-items:center;display:flex}.home-value-button,.home-input-value,.home-input-placeholder{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.home-value-filled{color:#f8fafc}.home-value-button:focus-visible,.settings-card input:focus{border-color:#60a5fae6;box-shadow:0 0 0 3px #3b82f633}.home-mode-switch{background:#03090eb3;border:1px solid #ffffff14;border-radius:999px;grid-template-columns:1fr 1fr;gap:6px;min-height:46px;padding:5px;display:grid}.home-mode-button{color:#eef5f2a8;touch-action:manipulation;background:0 0;border:0;border-radius:999px;min-height:36px;font-weight:900}.home-mode-active{color:#fff8d5;background:linear-gradient(#f2c14e42,#674a1475);box-shadow:inset 0 1px #ffffff2e,0 8px 16px #00000042}.home-entry-panel{gap:10px;display:grid}.home-primary-action{min-height:52px}.room-code-slots{grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.room-code-slot{color:#eef5f26b;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;place-items:center;min-height:42px;font-size:1rem;font-weight:900;display:grid}.room-code-slot-filled{color:#dff8ea;background:#67e8a51f;border-color:#67e8a56b}.home-input-backdrop{z-index:90;padding:max(12px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));background:linear-gradient(#0108061f,#010806b3);place-items:end center;display:grid;position:fixed;inset:0}.home-input-panel{background:linear-gradient(#121a2af5,#080d16fa),#0a101cfa;border:1px solid #f2c14e4d;border-radius:18px;gap:8px;width:min(100%,780px);padding:10px;display:grid;box-shadow:0 22px 54px #0000008c}.home-input-head{color:var(--text-muted);text-transform:uppercase;justify-content:space-between;align-items:center;gap:10px;font-size:.68rem;font-weight:900;display:flex}.home-input-counter{color:#e8edf7;background:#ffffff14;border-radius:999px;padding:3px 8px;font-size:.64rem}.home-input-display{color:#f8fafc;background:#030a14c7;border:1px solid #60a5fa6b;border-radius:14px;align-items:center;min-height:42px;padding:0 12px;font-size:1rem;font-weight:900;display:grid;box-shadow:inset 0 0 0 1px #3b82f638}.home-input-placeholder{color:#f8fafc73}.home-input-code-slots{grid-template-columns:repeat(6,minmax(0,1fr));gap:6px;display:grid}.game-keyboard{gap:5px;display:grid}.game-key-row{grid-template-columns:repeat(var(--key-count), minmax(0, 1fr));gap:5px;display:grid}.game-key{color:#f8fafc;min-width:0;min-height:34px;font:inherit;touch-action:manipulation;background:linear-gradient(#293752f5,#0e1624fa);border:1px solid #ffffff1f;border-radius:10px;font-size:.86rem;font-weight:900;box-shadow:inset 0 1px #ffffff14,0 6px 12px #00000038}.game-key:active{transform:translateY(1px)}.home-input-actions{grid-template-columns:repeat(auto-fit,minmax(82px,1fr));gap:6px;display:grid}.home-input-actions .game-key{min-height:36px;font-size:.72rem}.game-key-primary{background:linear-gradient(#438df2 0%,#1d4ed8 100%);border-color:#60a5fa8a}.lobby-screen{align-content:start;gap:16px;width:min(100%,760px);margin:0 auto;display:grid}.lobby-screen>*{min-width:0}.lobby-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.lobby-header>div{flex:190px;min-width:0}.lobby-header h1{overflow-wrap:anywhere;margin:0;font-size:clamp(1.85rem,10vw,3.4rem);line-height:1}.room-code{color:var(--text-muted);margin:6px 0 0;font-size:.9rem;font-weight:800}.lobby-header-actions,.invite-card{align-items:center;gap:8px;display:flex}.lobby-header-actions{flex-wrap:wrap;flex:100%;justify-content:flex-start}.lobby-header-actions .btn{min-width:58px;padding:0 10px}.lobby-card{padding:18px}.lobby-card h2{margin:0 0 14px;font-size:1.35rem}.invite-card{justify-content:space-between}.invite-card h2{margin-bottom:6px}.invite-card p{max-width:100%;color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.82rem;overflow:hidden}.invite-card>div{min-width:0}.invite-card .btn{flex:none}.copy-status{color:#67e8a5;margin-top:6px;font-size:.78rem;font-weight:800;display:inline-block}.player-list{gap:8px;margin:0 0 14px;padding:0;list-style:none;display:grid}.player-list li,.setting-row{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;gap:12px;min-height:48px;display:flex}.player-list li{flex-direction:column;align-items:stretch;padding-block:8px}.player-main,.player-actions,.host-chip-actions,.host-admin-panel{align-items:center;gap:8px;display:flex}.player-main{justify-content:space-between}.player-main>span:first-child{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.player-actions,.host-chip-actions{justify-content:flex-end}.player-actions .btn,.host-chip-actions .btn{min-height:36px;padding:0 10px;font-size:.82rem}.status-ready{color:#67e8a5;font-weight:800}.status-waiting{color:#fca5a5;font-weight:800}.settings-list,.setting-column{gap:12px;display:grid}.setting-hint-row,.custom-turn-limit{justify-content:space-between;align-items:center;gap:8px;display:flex}.setting-column span,.setting-row span,.setting-hint-row span{color:var(--text-muted)}.setting-hint-row span{min-width:0;font-size:.84rem}.setting-hint-row .btn,.custom-turn-limit .btn{flex:none;min-height:38px;padding:0 12px;font-size:.82rem}.custom-turn-limit input{min-width:0}.setting-column select{margin-top:6px}.setting-info-card{border:1px solid var(--panel-border);background:#ffffff0f;border-radius:8px;gap:4px;margin-top:2px;padding:10px;line-height:1.35;display:grid}.setting-info-card strong{color:#eef5f2;font-size:.86rem}.setting-info-card small{color:var(--text-muted);font-size:.8rem}.setting-row select{width:min(46vw,142px)}.setting-row input[type=checkbox]{width:28px;min-height:28px}.settings-table{gap:10px;display:grid}.settings-card{background:linear-gradient(#141f30c7,#070d16d1),#0b121cdb;border:1px solid #ffffff1a;border-radius:16px;gap:10px;min-width:0;padding:12px;display:grid;box-shadow:inset 0 1px #ffffff0d}.settings-card-head strong{color:#fff8d5;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.95rem;font-weight:900;overflow:hidden}.settings-stepper{grid-template-columns:42px minmax(0,1fr) 42px;align-items:center;gap:7px;min-height:42px;display:grid}.settings-stepper button,.settings-segment,.settings-toggle-chip,.settings-player-chip,.settings-inline-action{color:#eef5f2;touch-action:manipulation;background:#ffffff14;border:1px solid #ffffff1a;border-radius:999px;min-height:40px;font-weight:900}.settings-stepper button{padding:0;font-size:1.15rem}.settings-stepper span{color:#eef5f2c2;text-align:center;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.78rem;font-weight:900;overflow:hidden}.settings-stepper button:disabled,.settings-segment:disabled,.settings-toggle-chip:disabled,.settings-player-chip:disabled,.settings-inline-action:disabled{opacity:.44}.settings-segments{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;display:grid}.settings-segments-two{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-segment,.settings-player-chip{padding:0 10px;font-size:.74rem}.settings-segment-active,.settings-player-chip-active,.settings-toggle-chip-on{color:#8df0ba;background:#67e8a524;border-color:#67e8a56b}.settings-toggle-chip{width:100%}.settings-inline-action{color:#f8e6ad;background:#f2c14e1a;border-color:#f2c14e47;min-height:34px;font-size:.72rem}.settings-rule-note{color:#eef5f2ad;margin:0;font-size:.76rem;font-weight:800;line-height:1.25}.settings-player-grid{overscroll-behavior-x:contain;gap:7px;max-width:100%;padding-bottom:2px;display:flex;overflow-x:auto}.settings-player-chip{flex:none}.settings-custom-row{align-items:stretch}.lobby-start{min-height:56px;font-size:1.15rem}.game-screen{width:100%;max-width:100vw;height:100dvh;padding:max(10px, env(safe-area-inset-top)) 10px max(8px, env(safe-area-inset-bottom));background:radial-gradient(circle at 50% 34%, #16524680 0%, #0f3b30f2 45%, #07130f 100%), radial-gradient(#ffffff04 1px, transparent 0), radial-gradient(#ffffff04 1px, transparent 0), var(--bg-color);background-position:0 0,0 0,12px 12px;background-size:100% 100%,24px 24px,24px 24px;grid-template-rows:auto auto minmax(0,1fr) auto;gap:10px;display:grid;overflow:hidden}.landscape-gate{display:none}.game-screen>*{min-width:0}.game-topbar{justify-content:space-between;align-items:flex-start;gap:10px;display:flex;overflow:hidden}.turn-summary{flex:auto;min-width:0}.turn-summary h1{margin:0;font-size:clamp(1.35rem,7vw,2.35rem);line-height:1.05}.status-line{flex-wrap:wrap;gap:6px;min-height:22px;margin-top:6px;display:flex}.status-line span,.opponent-flags span,.hand-count-pill{color:var(--text-muted);background:#ffffff1f;border-radius:999px;padding:3px 8px;font-size:.74rem;font-weight:800}.status-line .turn-timer-pill{color:#f8fafc}.status-line .turn-timer-expired{color:#fecaca;background:#c2412d47}.topbar-actions{flex:none;align-items:center;gap:6px;margin-right:6px;display:flex}.topbar-action{flex:0 0 78px;width:78px;min-width:78px;min-height:40px;padding:0;font-size:.84rem}.opponent-strip{overscroll-behavior-x:contain;gap:8px;max-width:100%;padding:2px 0 4px;scroll-padding-inline:10px;display:flex;overflow-x:auto}.opponent-chip{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1118278c;border:1px solid #ffffff14;border-radius:12px;flex:0 0 min(78vw,260px);gap:8px;padding:12px;transition:border-color .15s,box-shadow .15s,opacity .15s;display:grid}@keyframes active-opponent-pulse{0%,to{border-color:#f2c14e73;box-shadow:0 0 10px #f2c14e26,inset 0 0 8px #f2c14e0d}50%{border-color:#f2c14ed9;box-shadow:0 0 16px #f2c14e59,inset 0 0 12px #f2c14e26}}.opponent-active{animation:2s ease-in-out infinite active-opponent-pulse}.opponent-row{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.opponent-row strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.opponent-row span{color:var(--text-muted);white-space:nowrap;font-size:.82rem}.opponent-flags{flex-wrap:wrap;gap:4px;min-height:22px;display:flex}.flag-badge{text-transform:uppercase;letter-spacing:.04em;border:1px solid #0000;border-radius:4px!important;padding:2px 6px!important;font-size:.68rem!important;font-weight:900!important}.flag-turn{border-color:#67e8a547;color:#67e8a9!important;background:#67e8a51f!important}.flag-offline{border-color:#9ca3af38;color:#9ca3af!important;background:#9ca3af1a!important}.flag-timeout{border-color:#c2412d47;color:#fca5a5!important;background:#c2412d1f!important}.flag-skip{border-color:#d9912447;color:#fcd34d!important;background:#d991241f!important}.flag-makao{border-color:#ef444459;animation:1.2s ease-in-out infinite flag-makao-pulse;color:#ef4444!important;background:#ef444426!important}@keyframes flag-makao-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(.96)}}.mini-hand{align-items:center;gap:3px;display:flex}.catch-button{width:100%;min-height:38px}.host-chip-actions{width:100%}.host-chip-actions .btn{flex:1 1 0}.table-zone{align-content:center;gap:10px;min-height:0;padding:2px 4px;display:grid}.table-banner,.table-hint,.turn-events,.history-strip{border-radius:8px;width:min(100%,560px);margin-inline:auto}.table-banner{text-align:center;justify-content:center;align-items:center;gap:10px;padding:10px 12px;font-weight:800;display:flex}.banner-success{background:#22a06b2e;border:1px solid #22a06bbf}.banner-danger{background:#c2412d33;border:1px solid #c2412dcc}.banner-warning{background:#d9912433;border:1px solid #d99124cc}.table-hint{color:#dff8ea;text-align:center;background:#081e199e;border:1px solid #67e8a547;padding:9px 11px;font-size:.84rem;font-weight:800;line-height:1.32}.turn-events{color:#d6dee9;text-align:center;gap:3px;font-size:.9rem;display:grid}.game-over-actions{justify-content:center;align-items:center;width:min(100%,560px);min-height:44px;margin-inline:auto;display:flex}.game-over-actions .btn{min-height:44px}.game-over-actions span{color:var(--text-muted);text-align:center;font-size:.9rem;font-weight:800}.host-admin-panel{overscroll-behavior-x:contain;justify-content:center;width:min(100%,560px);margin-inline:auto;padding:2px 0 4px;overflow-x:auto}.host-admin-panel .btn{flex:none;min-height:38px;padding:0 12px;font-size:.82rem}.table-cards{justify-content:center;align-items:center;gap:clamp(24px,10vw,82px);display:flex}.pile-slot{color:var(--text-muted);justify-items:center;gap:6px;font-weight:800;display:grid}.pile-slot .playing-card-table{transition:transform .15s,box-shadow .15s,filter .15s}.pile-slot-active .playing-card-table{transform:translateY(-4px);box-shadow:0 16px 28px #0000005c,0 0 0 3px #67e8a56b}.pile-slot-drop-ready .playing-card-table{filter:saturate(1.12);box-shadow:0 16px 28px #0000005c,0 0 0 3px #f2c14eb8}.pile-slot-discard{color:#fff}.history-strip{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-muted);background:#0a101c73;border:1px solid #ffffff14;border-radius:12px;gap:4px;padding:10px 12px;font-size:.78rem;display:grid}.history-strip-head{color:#eef5f2;justify-content:space-between;align-items:center;gap:8px;font-size:.76rem;font-weight:900;display:flex}.history-strip-head button{border:1px solid var(--panel-border);color:#eef5f2;background:#ffffff14;border-radius:8px;min-height:30px;padding:0 9px;font-size:.72rem;font-weight:900}.hand-sheet{width:100%;min-width:0;padding:10px 10px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--panel-border);background:#0a101cf5;box-shadow:0 -16px 36px #00000057}.hand-header{justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:8px;display:flex}.hand-header strong{font-size:1.08rem;display:block}.hand-kicker,.selection-count{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;overflow:hidden}.hand-controls{justify-items:end;gap:5px;min-width:0;display:grid}.selection-count{text-align:right;max-width:150px}.hand-tool-row{justify-content:flex-end;gap:6px;max-width:100%;display:flex}.hand-tool-button{border:1px solid var(--panel-border);color:#eef5f2;touch-action:manipulation;white-space:nowrap;background:#ffffff14;border-radius:8px;min-height:34px;padding:0 9px;font-size:.76rem;font-weight:900}.hand-tool-button-active{color:#8df0ba;background:#67e8a529;border-color:#67e8a5ad}.action-bar{overscroll-behavior-x:contain;gap:8px;max-width:100%;padding-bottom:8px;scroll-padding-inline:10px;display:flex;overflow-x:auto}.action-bar .btn{flex:none}.action-bar .makao-action{color:#f8e6ad;background:#f2c14e24;border:1px solid #f2c14e8c;min-width:86px}.action-bar .makao-action-armed{color:#8df0ba;opacity:1;background:#67e8a526;border-color:#67e8a59e}.selection-preview{color:#f8e6ad;background:#f2c14e1a;border:1px solid #f2c14e57;border-radius:8px;margin:-1px 0 8px;padding:8px 10px;font-size:.82rem;font-weight:800;line-height:1.3}.hand-scroll{max-width:100%;padding:10px calc(4px + var(--hand-card-overlap)) 4px 4px;overscroll-behavior-x:contain;scrollbar-width:none;align-items:flex-start;gap:0;scroll-padding-inline:12px;display:flex;overflow:auto hidden}.hand-scroll::-webkit-scrollbar{display:none}.hand-scroll>.playing-card,.hand-scroll>.hand-group{transition:margin-left .16s,transform .14s,box-shadow .14s}.hand-scroll>.playing-card+.playing-card,.hand-scroll>.playing-card+.hand-group,.hand-scroll>.hand-group+.playing-card,.hand-scroll>.hand-group+.hand-group{margin-left:calc(var(--hand-card-overlap) * -1)}.hand-scroll>.playing-card-selected,.hand-scroll>.hand-group-expanded,.hand-scroll>.hand-group-selected{z-index:2}.hand-scrollbar{background:#ffffff1a;border-radius:999px;height:4px;margin:7px 12px 0;position:relative;overflow:hidden}.hand-scrollbar-thumb{inset-block:0;left:var(--scroll-thumb-left);width:var(--scroll-thumb-width);border-radius:inherit;background:#f2c14ee6;transition:left .12s,width .12s;position:absolute;box-shadow:0 0 10px #f2c14e47}.hand-group{width:var(--card-width);min-height:calc(var(--card-height) + 30px);color:var(--text-main);cursor:pointer;transform:translateY(var(--hand-card-lift,0)) rotate(var(--hand-card-tilt,0deg));transform-origin:50% 118%;background:0 0;border:0;border-radius:8px;flex:none;justify-items:center;gap:5px;padding:0;display:grid;position:relative}.hand-group:not(:disabled):hover{--hand-card-lift:-10px}.hand-group-card{width:var(--card-width);height:var(--card-height);color:var(--card-color);background:#fffdf7;border:1px solid #0f172a3d;border-radius:8px;position:relative;overflow:hidden;box-shadow:0 8px 18px #0000003d}.hand-group-count{min-width:48px;color:var(--text-muted);text-align:center;white-space:nowrap;background:#ffffff1a;border-radius:999px;padding:3px 8px;font-size:.74rem;font-weight:900}.hand-group-action-hint{color:#8df0ba;margin-top:-2px;font-size:.66rem;font-weight:900;line-height:1}.hand-group-expanded{--hand-card-lift:-14px}.hand-group-expanded .hand-group-card{box-shadow:0 12px 22px #00000052,0 0 0 3px #f2c14e}.hand-group-selected{--hand-card-lift:-14px}.hand-group-selected .hand-group-card{box-shadow:0 12px 22px #00000052, 0 0 0 3px var(--accent-color)}.hand-group-drawn .hand-group-card:after{content:"";border:2px solid var(--accent-color);border-radius:10px;position:absolute;inset:-4px}.hand-group-blocked{opacity:.68}.hand-group-blocked .hand-group-card{filter:grayscale(.45)brightness(.9)}.hand-group-badge{background:var(--accent-color);color:#fff;border-radius:999px;place-items:center;min-width:24px;height:24px;font-size:.8rem;font-weight:900;display:grid;position:absolute;top:-7px;right:-4px}.hand-group-drawer{border:1px solid var(--panel-border);background:#111827e0;border-radius:8px;gap:8px;max-width:100%;margin-bottom:8px;padding:10px;display:grid}.hand-group-drawer-header{align-items:center;gap:8px;min-width:0;display:flex}.hand-group-drawer-header strong{font-size:1.1rem}.hand-group-drawer-header span{min-width:0;color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex:auto;font-size:.8rem;overflow:hidden}.hand-group-drawer-header button{color:#fff;background:#334155;border:0;border-radius:8px;flex:none;min-height:34px;padding:0 10px;font-weight:800}.hand-group-cards{overscroll-behavior-x:contain;gap:8px;max-width:100%;padding:6px 4px 5px;scroll-padding-inline:10px;display:flex;overflow:auto hidden}.playing-card{width:var(--card-width);height:var(--card-height);color:var(--card-color);cursor:default;background:#fffdf7;border:1px solid #0f172a3d;border-radius:10px;flex:none;padding:0;position:relative;overflow:hidden;box-shadow:0 8px 18px #0000003d}.playing-card:not(:disabled){cursor:pointer}.playing-card-inspectable:not(:disabled){cursor:zoom-in}.playing-card-table{width:var(--table-card-width);height:var(--table-card-height);border-radius:10px}.playing-card-detail{width:var(--detail-card-width);height:var(--detail-card-height);border-radius:10px}.playing-card-inspect{border-radius:12px;width:min(42vw,150px);height:calc(1.5*min(42vw,150px))}.playing-card-mini{width:24px;height:34px;box-shadow:none;border-radius:4px}.playing-card-back{background:repeating-linear-gradient(45deg, #ffffff0d 0px, #ffffff0d 2px, transparent 2px, transparent 10px), repeating-linear-gradient(-45deg, #ffffff0d 0px, #ffffff0d 2px, transparent 2px, transparent 10px), linear-gradient(135deg, #ffffff1a 0%, transparent 100%), var(--card-back);color:#0000;border:2px solid #f2c14eb3;box-shadow:inset 0 0 10px #00000073,0 8px 18px #00000059}.playing-card-with-art,.hand-group-card-with-art{background-color:#fff;background-image:var(--card-image);color:#0000;background-position:50%;background-repeat:no-repeat;background-size:cover}.playing-card-back.playing-card-with-art{background-image:var(--card-image)}.playing-card-selectable{touch-action:pan-x;transform:translateY(var(--hand-card-lift,0)) rotate(var(--hand-card-tilt,0deg));transform-origin:50% 118%;transition:margin-left .16s,transform .14s,box-shadow .14s,opacity .14s}.playing-card-selectable:not(:disabled):hover{--hand-card-lift:-16px;box-shadow:0 14px 24px #00000052}@keyframes legal-card-pulse{0%,to{box-shadow:0 8px 18px #0000003d,0 0 0 2px #67e8a580}50%{box-shadow:0 12px 24px #00000052,0 0 0 4.5px #67e8a5e6}}.playing-card-legal{animation:1.8s ease-in-out infinite legal-card-pulse}.playing-card-blocked{opacity:.68;filter:grayscale(.45)brightness(.9)}.playing-card-selected{--hand-card-lift:-28px;animation:none;box-shadow:0 18px 32px #00000073,0 0 0 3.5px #f2c14e;z-index:10!important}.playing-card-drawn:after{content:"";border:2px solid var(--accent-color);pointer-events:none;border-radius:10px;position:absolute;inset:-4px}.card-corner{font-size:clamp(.8rem,3.5vw,1rem);font-weight:900;line-height:1;position:absolute;left:7px}.card-corner-top{top:7px}.card-corner-bottom{bottom:7px;left:auto;right:7px;transform:rotate(180deg)}.card-suit{place-items:center;font-size:clamp(2.2rem,10vw,3.3rem);line-height:1;display:grid;position:absolute;inset:0}.joker-marker{z-index:1;color:#fffdf7;letter-spacing:0;background:#0f172ad1;border-radius:999px;padding:2px 6px;font-size:.62rem;font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,calc(22px - 50%))}.drag-card-preview{z-index:1200;pointer-events:none;filter:drop-shadow(0 18px 30px #0000007a);position:fixed;transform:translate(-50%,-56%)rotate(-4deg)scale(1.06)}.drag-card-preview .playing-card{opacity:.96}.selected-card-preview{display:none}.modal-backdrop{z-index:1000;background:#000000b8;place-items:end center;padding:18px;display:grid;position:fixed;inset:0}.modal-sheet{gap:12px;width:min(100%,420px);padding:18px;display:grid}.modal-sheet h3{margin:0;font-size:1.25rem}.modal-sheet p{color:var(--text-muted);margin:0}.sort-modal-sheet{width:min(100%,430px)}.history-modal-sheet{width:min(100%,520px);max-height:min(76dvh,680px)}.card-inspect-sheet{width:min(100%,430px)}.card-inspect-layout{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:14px;display:grid}.card-inspect-details{gap:10px;min-width:0;display:grid}.card-inspect-details h3{overflow-wrap:anywhere}.card-inspect-tags{flex-wrap:wrap;gap:6px;display:flex}.card-inspect-tags span{color:#d6dee9;background:#ffffff1a;border-radius:999px;padding:5px 8px;font-size:.78rem;font-weight:800}.history-modal-list{overscroll-behavior-y:contain;gap:7px;max-height:52dvh;padding-right:4px;display:grid;overflow-y:auto}.history-modal-item{background:#07130f57;border:1px solid #ffffff14;border-radius:8px;gap:2px;padding:8px 10px;display:grid}.history-modal-item span{color:var(--text-muted);font-size:.74rem;font-weight:800}.history-modal-item strong{color:#eef5f2;font-size:.88rem;line-height:1.28}.sort-mode-list{gap:8px;display:grid}.sort-mode-option{border:1px solid var(--panel-border);color:#eef5f2;text-align:left;background:#ffffff12;border-radius:8px;gap:3px;min-height:54px;padding:9px 10px;display:grid}.sort-mode-option strong{font-size:.94rem}.sort-mode-option span{color:var(--text-muted);font-size:.78rem;line-height:1.25}.sort-mode-option-active{background:#f2c14e21;border-color:#f2c14eb8}.modal-sheet .modal-hint{color:#f8e6ad;background:#f2c14e1a;border-radius:8px;padding:8px 10px;font-size:.86rem;font-weight:800;line-height:1.35}.choice-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.rank-grid{grid-template-columns:repeat(3,1fr)}.joker-modal-sheet{width:min(100%,460px)}.joker-rank-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.joker-rank-option{border:1px solid var(--panel-border);color:#17202a;background:#fffdf7;border-radius:8px;min-height:52px;font-size:1.05rem;font-weight:900}.joker-rank-selected{border-color:#f2c14e;box-shadow:0 0 0 3px #f2c14e73}.joker-rank-option:disabled{opacity:.36}.joker-suit-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.joker-suit-grid .btn:disabled{opacity:.58}.suit-red{background:#b91c1c}.suit-black{background:#17202a}.loading{min-height:100dvh;color:var(--text-muted);place-items:center;display:grid}@media (width>=720px){.game-screen{width:min(100%,1024px);margin-inline:auto;padding-inline:18px}.hand-sheet{padding-inline:18px}.opponent-chip{flex-basis:260px}}@media (orientation:landscape){input,select{min-height:40px;padding-inline:12px}.btn{min-height:40px;padding-inline:13px}.home-screen{padding:max(10px, env(safe-area-inset-top)) 14px max(10px, env(safe-area-inset-bottom));grid-template-columns:minmax(190px,30vw) minmax(360px,520px);justify-content:center;align-items:center;gap:clamp(16px,4vw,42px)}.home-hero{text-align:left}.home-hero h1{font-size:clamp(3rem,8vw,4.5rem)}.home-card{gap:8px;width:100%;max-height:calc(100dvh - 24px);margin:0;padding:12px;overflow:hidden}.form-divider{font-size:.72rem}.settings-toggle{min-height:38px}.settings-toggle-icon{width:22px;height:22px;font-size:.86rem}.server-panel{gap:6px}.server-actions .btn{min-height:36px}.lobby-screen{width:100%;max-width:none;padding:max(8px, env(safe-area-inset-top)) 10px max(8px, env(safe-area-inset-bottom));grid-template:"lobbyHeader lobbyHeader lobbyHeader""players settings invite"minmax(0,1fr)/minmax(160px,21vw) minmax(250px,1fr) minmax(180px,22vw);align-content:stretch;gap:8px}.lobby-header{flex-wrap:nowrap;grid-area:lobbyHeader;align-items:center}.lobby-header>div{flex:auto}.lobby-header h1{font-size:clamp(1.35rem,3.2vw,2.2rem)}.room-code{margin-top:2px;font-size:.78rem}.lobby-header-actions{flex:none;justify-content:flex-end}.lobby-header-actions .btn{min-width:52px;min-height:36px;font-size:.78rem}.lobby-card{min-height:0;padding:10px;overflow:hidden}.lobby-card h2{margin-bottom:8px;font-size:1rem}.invite-card{grid-area:invite;align-content:start;align-items:stretch;gap:8px;display:grid}.invite-card p{white-space:normal;-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box}.invite-card .btn{width:100%;min-height:38px}.lobby-screen>.lobby-card:nth-of-type(2){grid-area:players}.lobby-screen>.lobby-card:nth-of-type(3){grid-area:settings}.player-list{gap:5px;max-height:calc(100dvh - 148px);margin-bottom:8px;overflow-y:auto}.player-list li{padding-block:5px}.player-list li,.setting-row{min-height:38px}.player-actions .btn,.host-chip-actions .btn{min-height:32px;padding-inline:8px;font-size:.74rem}.settings-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px 10px}.setting-column,.settings-list{min-width:0}.setting-column{gap:5px}.setting-column span,.setting-row span,.setting-hint-row span{font-size:.72rem}.setting-info-card{display:none}.setting-row select{width:min(22vw,118px)}.setting-row input[type=checkbox]{width:24px;min-height:24px}.setting-hint-row,.custom-turn-limit{min-height:34px}.setting-hint-row{display:none}.setting-hint-row .btn,.custom-turn-limit .btn{min-height:32px;padding-inline:9px;font-size:.72rem}.lobby-start{right:max(10px, env(safe-area-inset-right));bottom:max(10px, env(safe-area-inset-bottom));z-index:5;min-width:min(190px,24vw);min-height:42px;font-size:.9rem;position:fixed;box-shadow:0 12px 24px #00000057}.game-screen{--card-width:clamp(58px, 8.2vw, 88px);--table-card-width:clamp(88px, 11.5vw, 132px);--hand-card-overlap:calc(var(--card-width) * .32);width:100%;max-width:none;height:100dvh;padding:max(8px, env(safe-area-inset-top)) 10px max(6px, env(safe-area-inset-bottom));background:radial-gradient(circle at 50% 44%,#196a529e 0%,#0c2f27b8 44%,#051310 100%),linear-gradient(#0f3b30 0%,#07130f 100%);grid-template:"top""opponents"minmax(54px,13dvh)"table"minmax(0,1fr)"hand"clamp(132px,33dvh,174px)/minmax(0,1fr);gap:6px;overflow:hidden}.game-topbar{grid-area:top;align-items:center;min-height:42px}.turn-summary h1{font-size:clamp(1.08rem,2.8vw,1.7rem)}.turn-summary .eyebrow{margin-bottom:0;font-size:.64rem}.status-line{gap:4px;min-height:18px;margin-top:3px}.status-line span{padding:2px 7px;font-size:.68rem}.topbar-action{flex-basis:70px;width:70px;min-width:70px;min-height:36px;font-size:.78rem}.opponent-strip{flex-direction:row;grid-area:opponents;align-items:stretch;max-height:none;padding:0 2px 3px;overflow:auto hidden}.opponent-chip{background:#09121ab8;border-color:#ffffff14;flex:0 0 clamp(138px,23vw,210px);grid-template-rows:auto auto;grid-template-columns:minmax(0,1fr) auto;gap:4px 8px;width:auto;padding:7px 8px;box-shadow:inset 0 0 0 1px #ffffff08}.mini-hand{grid-area:1/2/3;overflow:hidden}.opponent-row{align-items:center}.opponent-row span{font-size:.72rem}.opponent-flags{gap:3px;min-height:18px}.catch-button,.host-chip-actions{display:none}.table-zone{min-height:0;box-shadow:none;background:0 0;border:0;border-radius:0;grid-area:table;grid-template-columns:minmax(0,1fr) minmax(138px,22vw);align-content:center;align-items:center;gap:6px 12px;padding:5px 12px 2px;position:relative}.table-zone:before{content:"";z-index:0;pointer-events:none;background:radial-gradient(circle,#f6d47e1f,#07130f85 62%,#0000 72%);border-radius:999px;position:absolute;inset:4px 170px 8px 18px;box-shadow:inset 0 12px 36px #00000057}.table-zone>*{z-index:1;position:relative}.table-banner,.table-hint,.turn-events,.game-over-actions,.host-admin-panel{grid-column:1/-1;width:100%}.table-cards{grid-column:1;align-self:center;gap:clamp(42px,12vw,126px)}.pile-slot{min-height:var(--table-card-height);text-shadow:0 2px 5px #00000073;gap:4px;position:relative}.pile-slot span{max-width:calc(var(--table-card-width) - 12px);color:#eef5f2;white-space:nowrap;background:#07130fc7;border-radius:999px;padding:3px 8px;font-size:.72rem;line-height:1;position:absolute;bottom:7px;left:50%;transform:translate(-50%)}.history-strip{background:#061411a3;grid-column:2;align-self:center;width:100%;max-height:100%;padding:7px 8px;font-size:.7rem;overflow:auto}.hand-sheet{height:100%;max-height:none;padding:4px 12px calc(4px + env(safe-area-inset-bottom));background:linear-gradient(#060a12c2 0%,#070a12f5 100%);border-top:1px solid #f2c14e38;grid-template:"handHeader handCards handActions"minmax(0,1fr)"handPreview handPreview handPreview""handDrawer handDrawer handDrawer"/minmax(96px,14vw) minmax(0,1fr) minmax(88px,12vw);grid-area:hand;align-items:center;gap:4px 8px;display:grid;box-shadow:0 -16px 42px #0000006b}.hand-header{grid-area:handHeader;align-items:center;margin-bottom:2px}.hand-header strong{font-size:1rem}.hand-kicker,.selection-count{font-size:.72rem}.hand-controls{justify-items:start}.hand-tool-row{justify-content:flex-start}.hand-tool-button{min-height:30px;padding:0 8px;font-size:.7rem}.action-bar{flex-direction:column;grid-area:handActions;align-self:center;padding-bottom:4px;overflow:visible}.action-bar .btn{width:96px;min-height:40px;padding:0 10px}.hand-scroll{grid-area:handCards;justify-content:center;align-items:flex-end;min-width:0;height:100%;padding:24px 28px 8px}.playing-card-blocked{opacity:.7}.hand-scrollbar{grid-area:1/2;align-self:end;margin:0 14px 2px}.selection-preview{grid-area:handPreview;margin:0}.hand-group-drawer{grid-area:handDrawer;margin-bottom:0}.game-screen{--card-width:clamp(86px, 11.2vw, 122px);--table-card-width:clamp(94px, 12vw, 130px);--hand-card-overlap:calc(var(--card-width) * .54);--focus-card-width:clamp(106px, 13vw, 136px);background:radial-gradient(#238a63b8 0%,#0c3d2db3 30%,#04100ef5 66%,#020807 100%),linear-gradient(90deg,#f2c14e1f,#0000 22% 78%,#f2c14e1f),#06110f;padding:0;display:block;position:relative}.game-screen:before{content:"";pointer-events:none;background:radial-gradient(at 50% 44%,#58c0872e,#0000 42%),radial-gradient(at 50% 52%,#02060500 0%,#0206055c 64%,#020605b8 100%);border:1px solid #f2c14e29;border-radius:50%;position:absolute;inset:62px 18px 130px;box-shadow:inset 0 28px 70px #0000007a,0 18px 60px #00000061}.game-screen:after{content:"";pointer-events:none;background:linear-gradient(#0000 0%,#020509c2 42%,#020509fa 100%);height:150px;position:absolute;bottom:0;left:0;right:0}.game-topbar{z-index:20;top:max(6px, env(safe-area-inset-top));left:max(10px, env(safe-area-inset-left));right:max(10px, env(safe-area-inset-right));pointer-events:none;grid-template-columns:minmax(0,1fr) auto;align-items:start;min-height:0;display:grid;position:absolute}.turn-summary{grid-template-rows:auto auto;grid-template-columns:auto minmax(0,1fr);align-items:center;column-gap:8px;min-width:0;display:grid}.turn-summary .eyebrow{color:#eef5f2d1;letter-spacing:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:auto;background:#040b10a3;border-radius:999px;grid-area:1/1;margin:0;padding:4px 8px;font-size:.6rem}.turn-summary h1{color:#fff8d5;text-shadow:0 2px 6px #00000085;pointer-events:auto;background:linear-gradient(#f2c14e38,#57340f6b);border:1px solid #f2c14e5c;border-radius:999px;grid-area:2/1;width:fit-content;margin-top:4px;padding:5px 12px 6px;font-size:clamp(.92rem,2.2vw,1.22rem);line-height:1;box-shadow:0 10px 26px #0000004d}.status-line{pointer-events:auto;grid-area:1/2/3;align-content:start;max-width:min(48vw,430px);min-height:0;margin:0;overflow:hidden}.status-line span{color:#eef5f2c7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#040b1080;border:1px solid #ffffff0f;padding:2px 7px;font-size:.62rem}.status-chip-first,.status-chip-version{display:none}.topbar-actions{pointer-events:auto;gap:8px;margin:0}.topbar-action.topbar-icon-action{color:#f8fafc;letter-spacing:0;background:radial-gradient(circle at 36% 28%,#ffffff2e,#171f2aeb);border:1px solid #ffffff29;border-radius:999px;flex-basis:42px;width:42px;min-width:42px;height:42px;min-height:42px;padding:0;font-size:.9rem;box-shadow:0 10px 22px #00000057}.opponent-strip{z-index:12;top:max(52px, calc(env(safe-area-inset-top) + 50px));left:max(12px, env(safe-area-inset-left));right:max(12px, env(safe-area-inset-right));scrollbar-width:none;gap:9px;height:56px;padding:0;position:absolute}.opponent-strip::-webkit-scrollbar{display:none}.opponent-chip{min-width:0;box-shadow:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:0 0;border:0;border-radius:0;flex:0 0 clamp(128px,17vw,178px);grid-template-rows:auto auto;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:2px 8px;padding:2px 0 0;display:grid;position:relative}.opponent-chip:before{content:"";z-index:-1;background:radial-gradient(#0000005c,#0000 70%);border-radius:50%;position:absolute;inset:28px 2px 2px}.opponent-active{animation:1.8s ease-in-out infinite active-opponent-pulse}.opponent-row{min-width:0}.opponent-row strong{color:#f7f5e8;background:#03090d9e;border-radius:999px;max-width:100%;padding:2px 7px;font-size:.7rem;display:inline-block}.opponent-row span{color:#d6c990;font-size:.64rem;display:none}.opponent-flags{min-height:16px;max-height:17px;overflow:hidden}.opponent-flags span,.hand-count-pill{padding:1px 5px;font-size:.56rem}.mini-hand{grid-area:1/2/3;transform:translate(2px)translateY(1px)}.mini-hand .playing-card-mini{width:18px;height:26px;margin-left:-9px}.mini-hand .playing-card-mini:first-child{margin-left:0}.table-zone{z-index:5;min-height:0;padding:0;display:block;position:absolute;inset:78px 0 164px}.table-zone:before{background:radial-gradient(at 50% 38%,#f2c14e21,#0000 35%),radial-gradient(at 50% 52%,#1652466b,#05100eb8 66%,#0000 73%);border-radius:50%;inset:4px 36px 0;box-shadow:inset 0 20px 46px #00000075}.table-cards{justify-content:center;align-items:center;gap:clamp(50px,12vw,118px);width:max-content;display:flex;position:absolute;top:42%;left:50%;transform:translate(-50%,-50%)}.pile-slot{filter:drop-shadow(0 18px 22px #0000005c)}.pile-slot .playing-card-table{border-radius:12px;box-shadow:0 14px 28px #00000061}.pile-slot-active .playing-card-table{transform:translateY(-6px)scale(1.02);box-shadow:0 20px 34px #00000070,0 0 0 3px #67e8a575}.pile-slot span{color:#f8efd0;background:#03090dd1;border:1px solid #f2c14e38;padding:4px 9px;font-size:.68rem;bottom:8px;box-shadow:0 8px 16px #00000057}.pile-slot-discard span{display:none}.table-banner,.table-hint,.turn-events,.game-over-actions{z-index:6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#050f13b8;border-radius:999px;width:min(58vw,520px);padding:7px 14px;font-size:.74rem;line-height:1.18;position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:0 10px 22px #00000052}.table-hint{color:#dff8ea}.turn-events{color:#eef5f2d1;text-align:center;width:min(54vw,460px);max-height:30px;display:block;top:auto;bottom:-6px;overflow:hidden}.turn-events div:not(:last-child){display:none}.game-over-actions{width:auto;min-height:0;box-shadow:none;background:0 0;padding:0;top:42px}.history-strip{right:max(10px, env(safe-area-inset-right));z-index:7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#050f13b8;border:1px solid #ffffff1a;border-radius:999px;place-items:center;width:42px;height:42px;padding:0;display:grid;position:absolute;bottom:7px;overflow:hidden;box-shadow:0 10px 22px #00000052}.history-strip>div:not(.history-strip-head){display:none}.history-strip-head{place-items:center;display:grid}.history-strip-head span{display:none}.history-strip-head button{color:#f8efd0;background:0 0;border:0;border-radius:999px;width:42px;height:42px;min-height:42px;padding:0;font-size:0}.history-strip-head button:before{content:"H";font-size:.9rem;font-weight:900}.host-admin-panel{display:none}.hand-sheet{z-index:18;height:150px;padding:0 max(8px, env(safe-area-inset-right)) max(3px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));background:radial-gradient(at 50% 0,#2d5e6180,#0000 52%),linear-gradient(#070c14a8,#03060cfa);border-top:1px solid #f2c14e33;border-radius:26px 26px 0 0;display:block;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -18px 42px #00000080}.hand-header{left:max(10px, env(safe-area-inset-left));bottom:calc(10px + env(safe-area-inset-bottom));z-index:3;gap:6px;width:74px;margin:0;display:grid;position:absolute}.hand-header>div:first-child{background:#03080c94;border:1px solid #ffffff14;border-radius:14px;gap:1px;padding:6px 7px;display:grid}.hand-header strong{font-size:.86rem;line-height:1}.hand-kicker{display:none}.hand-controls{justify-items:stretch;gap:4px;display:grid}.selection-count{display:none}.hand-tool-row{grid-template-columns:1fr 1fr;gap:4px;display:grid}.hand-tool-button{background:#ffffff14;border-radius:10px;min-height:28px;padding:0;font-size:.56rem}.action-bar{right:max(10px, env(safe-area-inset-right));bottom:calc(10px + env(safe-area-inset-bottom));z-index:4;grid-template-columns:88px;grid-auto-rows:40px;gap:6px;max-height:92px;padding:0;display:grid;position:absolute;overflow:visible}.action-bar .btn{letter-spacing:0;border-radius:999px;width:88px;min-height:38px;padding:0 8px;font-size:.66rem;box-shadow:0 10px 20px #00000057}.action-bar .btn:nth-child(n+3){display:none}.hand-scroll{z-index:2;left:calc(max(8px, env(safe-area-inset-left)) + 82px);right:calc(max(8px, env(safe-area-inset-right)) + 104px);height:auto;padding:30px calc(var(--hand-card-overlap) + 26px) 10px;justify-content:center;align-items:flex-end;position:absolute;top:-34px;bottom:2px;-webkit-mask-image:linear-gradient(90deg,#0000 0,#000 28px calc(100% - 28px),#0000 100%);mask-image:linear-gradient(90deg,#0000 0,#000 28px calc(100% - 28px),#0000 100%)}.hand-scroll>.playing-card+.playing-card,.hand-scroll>.playing-card+.hand-group,.hand-scroll>.hand-group+.playing-card,.hand-scroll>.hand-group+.hand-group{margin-left:calc(var(--hand-card-overlap) * -1)}.playing-card-selectable{transform-origin:50% 140%}.playing-card-selectable:not(:disabled):hover{--hand-card-lift:-26px}.playing-card-selected{--hand-card-lift:-46px;box-shadow:0 22px 34px #00000085,0 0 0 3px #f2c14e,0 0 28px #f2c14e5c}.playing-card-legal{animation:none;box-shadow:0 9px 18px #00000047,0 0 0 2px #67e8a56b}.playing-card-blocked{opacity:.72;filter:grayscale(.42)brightness(.92)}.selection-preview{left:max(12px, env(safe-area-inset-left));z-index:24;text-align:left;background:#39260bd6;border-radius:999px;width:min(34vw,280px);margin:0;padding:7px 12px;font-size:.7rem;position:absolute;bottom:156px;transform:none;box-shadow:0 10px 22px #00000059}.selected-card-preview{z-index:23;pointer-events:none;filter:drop-shadow(0 20px 30px #00000080);display:block;position:absolute;bottom:126px;left:50%;transform:translate(-50%)rotate(-2deg)}.selected-card-preview .playing-card{width:var(--focus-card-width);height:calc(var(--focus-card-width) * 1.5);opacity:.98;border-radius:12px;transform:none;box-shadow:0 22px 34px #0000007a,0 0 0 3px #f2c14e,0 0 30px #f2c14e59}.hand-scrollbar{left:calc(max(8px, env(safe-area-inset-left)) + 112px);right:calc(max(8px, env(safe-area-inset-right)) + 132px);bottom:calc(4px + env(safe-area-inset-bottom));z-index:5;height:3px;margin:0;position:absolute}.hand-group{transform-origin:50% 140%}.hand-group-count,.hand-group-action-hint{display:none}.hand-group-card{border-radius:10px}.hand-group-badge{top:-5px;right:4px}.hand-group-drawer{left:max(12px, env(safe-area-inset-left));right:max(12px, env(safe-area-inset-right));z-index:28;background:#050d14e6;border-radius:14px;margin:0;padding:8px;position:absolute;bottom:154px;box-shadow:0 14px 28px #0006}.hand-group-drawer-header{min-height:28px}.hand-group-drawer-header strong{font-size:.92rem}.hand-group-drawer-header span{font-size:.68rem}.hand-group-drawer-header button{border-radius:999px;min-height:30px;font-size:.68rem}.hand-group-cards{padding:4px}.home-screen,.lobby-screen{background:radial-gradient(at 50% 58%,#1f7d5a94 0%,#0c3026ad 38%,#030c0afa 76%),linear-gradient(120deg,#f2c14e1a,#0000 22% 78%,#2f80ed14),#050d0b;width:100%;max-width:none;height:100dvh;margin:0;padding:0;position:relative;overflow:hidden}.home-screen:before,.lobby-screen:before{content:"";pointer-events:none;background:radial-gradient(at 50% 42%,#44ba7e33,#0000 36%),radial-gradient(at 50% 52%,#030a080f 0%,#030a088f 72%,#000000b8 100%);border:1px solid #f2c14e29;border-radius:50%;position:absolute;inset:58px 34px 26px;box-shadow:inset 0 32px 80px #00000080,0 20px 70px #0000006b}.home-table-scene{pointer-events:none;position:absolute;inset:0}.home-table-scene:before{content:"";aspect-ratio:1.65;background:radial-gradient(#00000052,#0000 68%);border-radius:50%;width:min(34vw,330px);position:absolute;bottom:13%;left:7%}.home-floating-card{aspect-ratio:2/3;opacity:.86;background:repeating-linear-gradient(45deg,#ffffff1f 0 3px,#0000 3px 11px),linear-gradient(135deg,#2f80ede6,#0d2b60f5);border:2px solid #f2c14e80;border-radius:8px;width:clamp(44px,6vw,66px);position:absolute;box-shadow:0 18px 24px #0000005c}.home-floating-card-1{top:24%;left:11%;transform:rotate(-15deg)}.home-floating-card-2{bottom:20%;left:28%;transform:rotate(14deg)}.home-floating-card-3{opacity:.54;top:16%;right:41%;transform:rotate(8deg)}.home-hero{z-index:2;left:max(28px, env(safe-area-inset-left));text-align:left;width:min(38vw,380px);position:absolute;top:50%;transform:translateY(-50%)}.home-hero .eyebrow{color:#f8fafcb8;letter-spacing:.14em;margin-bottom:8px;font-size:.72rem}.home-hero h1{color:#fffdf2;text-shadow:0 7px #00000042,0 20px 34px #0000007a;font-size:clamp(4.3rem,11vw,8rem);line-height:.82}.home-card{z-index:3;top:50%;right:max(28px, env(safe-area-inset-right));background:linear-gradient(#121a2aeb,#080d16f5),#0a101cf5;border:1px solid #f2c14e3d;border-radius:22px;gap:7px;width:min(46vw,520px);max-height:calc(100dvh - 42px);margin:0;padding:12px;display:grid;position:absolute;overflow:hidden;transform:translateY(-50%);box-shadow:inset 0 1px #ffffff0f,0 26px 58px #0000007a}.home-card .home-value-button,.home-card .settings-toggle{background:#030a14b8;border-radius:13px;min-height:40px}.home-settings-backdrop{padding:max(12px, env(safe-area-inset-top)) max(28px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(28px, env(safe-area-inset-left));background:linear-gradient(90deg,#01080614,#010806b3);place-items:center end}.home-server-sheet{border-radius:20px;width:min(46vw,520px);max-height:calc(100dvh - 28px)}.home-session-notice{padding:7px 10px;font-size:.74rem}.home-flow-head{min-height:28px}.home-field span,.home-flow-step{font-size:.62rem}.home-mode-switch{min-height:38px;padding:4px}.home-mode-button{min-height:30px;font-size:.72rem}.home-entry-panel{gap:8px}.home-card .btn{background:linear-gradient(#438df2 0%,#1d4ed8 100%);border-radius:999px;min-height:42px;box-shadow:inset 0 1px #ffffff38,0 12px 20px #00000047}.form-divider{opacity:.72;font-size:.64rem}.home-code-value{text-align:center;letter-spacing:.18em;justify-content:center}.room-code-slot{border-radius:9px;min-height:32px}.lobby-header{z-index:20;top:max(8px, env(safe-area-inset-top));left:max(18px, env(safe-area-inset-left));right:max(18px, env(safe-area-inset-right));grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px;display:grid;position:absolute}.lobby-header>div{min-width:0}.lobby-header h1{color:#fffdf2;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 5px 12px #00000070;width:fit-content;max-width:46vw;margin:2px 0 0;font-size:clamp(1.28rem,3.8vw,2.5rem);line-height:.94;overflow:hidden}.lobby-header .eyebrow,.room-code{color:#eef5f2ad;margin:0;font-size:.72rem}.lobby-header-actions{justify-content:flex-end;gap:8px;display:flex}.lobby-header-actions .btn{background:radial-gradient(circle at 36% 28%,#ffffff2e,#171f2aeb);border:1px solid #ffffff24;border-radius:999px;min-width:44px;min-height:42px;padding:0 13px;font-size:.72rem;box-shadow:0 10px 22px #00000057}.lobby-settings-button{width:42px;padding:0!important;font-size:1rem!important}.lobby-table-stage{z-index:3;position:absolute;inset:66px 16px 72px}.lobby-table-oval{background:radial-gradient(at 50% 42%,#40b17338,#0000 38%),radial-gradient(#072219db,#020808eb 74%);border:1px solid #f2c14e33;border-radius:50%;width:min(76vw,820px);height:min(48dvh,250px);position:absolute;top:52%;left:50%;transform:translate(-50%,-50%);box-shadow:inset 0 26px 68px #0000008c,0 22px 56px #0000006b}.lobby-table-code,.lobby-table-count{color:#f8efd0;background:#040a0eb8;border-radius:999px;padding:5px 12px;font-weight:900;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 8px 16px #00000057}.lobby-table-code{letter-spacing:.12em;font-size:1.25rem;top:38%}.lobby-table-count{color:#eef5f2c2;font-size:.72rem;top:58%}.lobby-seat-list{margin:0;padding:0;list-style:none;display:block;position:absolute;inset:0}.lobby-seat-list li,.lobby-seat{background:linear-gradient(90deg,#061119e6,#082225b8);border:0;border-radius:999px;align-items:center;width:clamp(132px,18vw,184px);min-height:48px;padding:6px 9px;display:grid;position:absolute;box-shadow:0 12px 20px #0000005c,inset 0 1px #ffffff0f}.lobby-seat:after{content:"";pointer-events:none;background:radial-gradient(#0000006b,#0000 70%);border-radius:50%;width:70%;height:18px;position:absolute;bottom:-16px;left:50%;transform:translate(-50%)}.lobby-seat-ready{outline:2px solid #67e8a57a}.lobby-seat-waiting{outline:1px solid #f2c14e40}.lobby-seat-empty{opacity:.42;outline:1px dashed #fff3}.lobby-seat-1{bottom:5%;left:50%;transform:translate(-50%)}.lobby-seat-2{top:1%;left:50%;transform:translate(-50%)}.lobby-seat-3{top:46%;left:6%;transform:translateY(-50%)}.lobby-seat-4{top:46%;right:6%;transform:translateY(-50%)}.lobby-seat-5{top:13%;left:19%}.lobby-seat-6{top:13%;right:19%}.lobby-seat-7{bottom:10%;left:20%}.lobby-seat-8{bottom:10%;right:20%}.lobby-seat .player-main{grid-template-columns:minmax(0,1fr) auto;gap:6px;display:grid}.lobby-seat .player-main>span:first-child{color:#f8fafc;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.78rem;font-weight:900;overflow:hidden}.host-seat-badge{color:#f8efd0;vertical-align:1px;background:#f2c14e2e;border-radius:999px;place-items:center;width:16px;height:16px;margin-left:5px;font-size:.58rem;line-height:1;display:inline-grid}.lobby-seat .status-ready,.lobby-seat .status-waiting,.lobby-seat-empty .player-main span:last-child{white-space:nowrap;background:#ffffff14;border-radius:999px;padding:2px 7px;font-size:.64rem;font-weight:900}.lobby-seat .player-actions{display:none}.lobby-action-dock{z-index:18;left:50%;bottom:max(12px, env(safe-area-inset-bottom));align-items:center;gap:10px;display:flex;position:absolute;transform:translate(-50%)}.lobby-action-dock>.btn,.lobby-start{background:linear-gradient(#438df2 0%,#1d4ed8 100%);border-radius:999px;min-height:48px;padding-inline:22px;font-size:.76rem;box-shadow:inset 0 1px #ffffff38,0 12px 20px #00000057}.lobby-invite-dock{background:#040a0eb8;border:1px solid #ffffff14;border-radius:999px;align-items:center;gap:8px;min-height:48px;padding:4px 10px 4px 4px;display:flex}.lobby-invite-dock .btn{border-radius:999px;min-height:40px;padding-inline:12px;font-size:.68rem}.lobby-invite-dock span{color:#eef5f2c2;white-space:nowrap;font-size:.72rem;font-weight:900}.lobby-start{z-index:19;right:max(18px, env(safe-area-inset-right));bottom:max(12px, env(safe-area-inset-bottom));min-width:170px;position:absolute}.lobby-settings-sheet{background:#090f19f5;border-radius:20px;width:min(94vw,920px);max-height:calc(100dvh - 28px);padding:14px;overflow-y:auto}.lobby-settings-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.lobby-settings-head h3{margin:0}.lobby-settings-head .btn{border-radius:999px;width:42px;min-height:42px;padding:0}.lobby-settings-sheet .settings-table{grid-template-columns:repeat(4,minmax(0,1fr));gap:7px}.lobby-settings-sheet .settings-card-wide{grid-column:auto}.lobby-settings-sheet .settings-card{border-radius:15px;gap:7px;padding:8px}.lobby-settings-sheet .settings-segment,.lobby-settings-sheet .settings-player-chip,.lobby-settings-sheet .settings-toggle-chip{min-height:34px;font-size:.62rem}.lobby-settings-sheet .settings-stepper{min-height:36px}.lobby-settings-sheet .settings-stepper button{min-height:34px}.lobby-settings-sheet .settings-card input{min-height:36px}.lobby-settings-sheet .settings-card-head span{font-size:.62rem}.lobby-settings-sheet .settings-card-head strong{font-size:.82rem}.lobby-settings-sheet .settings-rule-note{-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.68rem;display:-webkit-box;overflow:hidden}}@media (orientation:portrait) and (width<=900px){.game-screen{background:radial-gradient(circle at 50% 42%, var(--felt-light) 0%, var(--felt) 38%, var(--bg-color) 100%);place-items:center;min-height:100dvh;padding:24px;display:grid}.game-screen>:not(.landscape-gate){display:none!important}.landscape-gate{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);text-align:center;background:#0a101ce0;border:1px solid #ffffff26;border-radius:16px;justify-items:center;gap:16px;width:min(90%,340px);padding:28px 24px;display:grid;box-shadow:0 24px 50px #00000080}.landscape-gate strong{color:var(--text-main);font-size:1.4rem;font-weight:800}.landscape-gate span{color:var(--text-muted);font-size:.92rem;font-weight:600}.phone-rotate-icon{background:#2f80ed1f;border-radius:50%;place-items:center;width:64px;height:64px;margin-bottom:4px;display:grid}@keyframes phone-rotate{0%,to{transform:rotate(0)}50%{transform:rotate(-90deg)}}.phone-rotate-icon svg{color:var(--accent-color);animation:2.4s ease-in-out infinite phone-rotate}}
