*{box-sizing:border-box}:root{background:#0f1115;color:#e8e8ea;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";line-height:1.45}body{margin:0}a{color:inherit}#app{max-width:980px;margin:0 auto;padding:18px}html{overflow-y:scroll;scrollbar-gutter:stable}.panel{background:#161a22;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px;box-shadow:0 10px 26px #00000059}.row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.spacer{flex:1}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(max-width:860px){.grid2{grid-template-columns:1fr}}.badge{width:160px;text-align:center;padding:6px 10px;border-radius:999px;font-weight:800;font-size:13px;border:1px solid rgba(255,255,255,.1);-webkit-user-select:none;user-select:none}.badge.up{background:#00b47829}.badge.down{background:#788cff29}.kpiRow{align-items:center}.kpi{display:flex;align-items:center;justify-content:space-between;gap:10px;flex:0 0 140px;min-width:140px}.kpi .value{font-size:28px;font-feature-settings:"tnum";line-height:1;text-align:right;min-width:4ch}.kpi .value.small{font-size:18px;font-weight:900}.status{min-width:72px;text-align:right}.statusText.playing{color:#22c55e;font-weight:900}.statusText.ended{color:#ffffffd9;font-weight:900}.resultRow{min-height:28px;display:flex;align-items:center;padding-top:6px}.resultPlaceholder{visibility:hidden}.btn{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:#0b0d12;color:#fff;cursor:pointer;font-weight:800}.select{padding:9px 10px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:#0b0d12;color:#fff;font-weight:800}.btn:hover:not(:disabled){filter:brightness(1.08)}.btn:disabled{opacity:.45;cursor:not-allowed}.playerList{display:grid;gap:8px}.playerRow{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#101522}.playerRow .name{font-weight:900}.playerRow .muted{color:#fff9;font-size:12px}.playerRow .turn{margin-left:auto;font-weight:950;color:#22c55e;font-size:12px;line-height:1;min-width:18px;text-align:right}.cardArea{display:flex;gap:12px;align-items:center}.playCard{width:112px;height:156px;border-radius:16px;border:1px solid #d9d9d9;background:#fff;box-shadow:0 10px 24px #00000047;position:relative;overflow:hidden}.playCard .corner{position:absolute;top:10px;left:10px;font-size:12px;font-weight:900;line-height:1.05}.playCard .corner.br{inset:auto 10px 10px auto;transform:rotate(180deg)}.playCard .center{position:absolute;inset:0;display:grid;place-items:center;text-align:center}.playCard .rank{font-size:40px;font-weight:950;line-height:1}.playCard .suit{margin-top:4px;font-size:26px;font-weight:900;opacity:.9}.playCard.black{color:#111}.playCard.red{color:#b00020}.playCard.joker{color:#111;background:linear-gradient(135deg,#fff,#f1f4ff)}.handGrid{display:flex;min-height:128px;gap:10px;flex-wrap:wrap}.cardBtn{width:92px;height:128px;border-radius:14px;border:1px solid #d9d9d9;background:#fff;box-shadow:0 10px 24px #0000003d;position:relative;cursor:pointer;padding:0;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}.cardBtn:hover:not(:disabled){transform:translateY(-6px);box-shadow:0 14px 30px #0000004d;filter:brightness(1.02)}.cardBtn:active:not(:disabled){transform:translateY(-2px)}.cardBtn:disabled{opacity:.45;cursor:not-allowed}.cardBtn .corner{position:absolute;top:8px;left:8px;font-size:12px;font-weight:900;line-height:1.05}.cardBtn .corner.br{inset:auto 8px 8px auto;transform:rotate(180deg)}.cardBtn .center{position:absolute;inset:0;display:grid;place-items:center;text-align:center}.cardBtn .rank{font-size:32px;font-weight:950;line-height:1}.cardBtn .suit{margin-top:2px;font-size:20px;font-weight:900;opacity:.9}.cardBtn.black{color:#111}.cardBtn.red{color:#b00020}.cardBtn.joker{color:#111;background:linear-gradient(135deg,#fff,#f1f4ff)}.playMeta .title{font-weight:900}.playMeta .sub{color:#ffffffb8;font-size:12px;margin-top:4px}.logBox{background:#0b0d12;color:#e8e8ea;padding:12px;border-radius:12px;overflow:auto;max-height:280px;border:1px solid rgba(255,255,255,.1)}.logRow{display:flex;gap:10px;align-items:baseline;padding:7px 8px;border-bottom:1px solid rgba(255,255,255,.08);border-left:4px solid transparent;border-radius:8px}.logRow .no{min-width:44px;color:#ffffff8c}.logRow .main{flex:1}.logRow .note{color:#ffffffa6;font-size:12px}.logRow.j{border-left-color:#f0ad4e;font-weight:900}.logRow.cancel{border-left-color:#22c55e;font-weight:900}.logRow.lose{border-left-color:#ff4d6d;font-weight:950}.logIcon{width:14px;height:14px;object-fit:contain;flex:0 0 auto;transform:translateY(1px);filter:drop-shadow(0 1px 1px rgba(0,0,0,.2));opacity:.95}.input{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#fff;font-weight:800}#logModalOverlay{position:fixed;inset:0;background:#000000b3;display:none;z-index:9999;padding:16px;box-sizing:border-box;overflow-y:auto;align-items:flex-end;justify-content:center}#logModalOverlay.open{display:flex}.logModal{position:relative;background:#111;opacity:.8;border-radius:12px;padding:20px;width:auto;box-sizing:border-box;margin:0;max-height:80vh;overflow-y:auto}.logModal.empty{width:100%}.logModalClose{position:absolute;top:10px;right:14px;font-size:22px;background:none;border:none;color:#fff;cursor:pointer}#logToggleBtn{display:block;width:min(100%,360px);margin:0 auto 12px}.jpOverlay{position:fixed;inset:0;background:#000000b8;display:grid;place-items:center;z-index:9999;padding:16px}.jpModal{width:min(520px,100%);background:#0f121af5;border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:14px;box-shadow:0 10px 40px #00000073}.jpTitle{font-weight:950;font-size:18px;margin-bottom:8px;color:#fff}.jpInfo{color:#ffffffbf;font-weight:800;margin-bottom:6px}.jpSafe{color:#ffffffb3;font-weight:800;margin-bottom:10px}.jpRow{display:grid;grid-template-columns:1fr 100px;gap:10px;align-items:center;margin-bottom:10px}.jpRange{width:100%}.jpNumber{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#fff;font-weight:900}.jpPresets{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}.jpPresetBtn{padding:8px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#ffffffe6;font-weight:900;cursor:pointer}.jpPresetBtn:hover{transform:translateY(-1px)}.jpResult{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:#ffffffeb;font-weight:950;margin-bottom:12px}.jpResult.jpOut{border-color:#ff4d6d80;background:#ff4d6d1f;color:#ff4d6d}.jpBtnRow{display:flex;gap:10px;justify-content:flex-end}.jpBtn{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#ffffffe6;font-weight:950;cursor:pointer}.jpBtn:disabled{opacity:.45;cursor:not-allowed}.jpPrimary{background:#22c55e2e;border-color:#22c55e59}.appHeader{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;margin:18px 0 14px}.appTitle{margin:0;line-height:1;font-size:44px;font-weight:1000;letter-spacing:.1em;padding:8px 18px;position:relative;-webkit-text-stroke:1px rgba(0,0,0,.55);background:linear-gradient(90deg,#fff,#c7d2fe,#fff);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 10px 30px rgba(0,0,0,.35)}.appTitle:after{content:"";position:absolute;left:50%;transform:translate(-50%);bottom:-10px;width:220px;height:3px;border-radius:999px;background:linear-gradient(90deg,#fff0,#ffffffe6,#fff0);opacity:.8}.appTag{font-size:12px;font-weight:900;letter-spacing:.28em;color:#ffffffa6}.cardTip{position:fixed;z-index:9999;display:none;max-width:320px;padding:10px 12px;border-radius:12px;background:#0f121aeb;border:1px solid rgba(255,255,255,.14);box-shadow:0 12px 28px #00000059;color:#ffffffeb;font-size:13px;line-height:1.35;pointer-events:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.cardTip .tTitle{font-weight:950;margin-bottom:6px;letter-spacing:.02em}.cardTip .tRow{display:flex;gap:8px}.cardTip .tKey{width:88px;flex:0 0 auto;color:#ffffffa6;font-weight:800}.cardTip .tVal{flex:1 1 auto}.cardTip{position:fixed;left:0;top:0;z-index:9999;display:none;pointer-events:none;max-width:min(360px,calc(100vw - 28px));padding:10px 12px;border-radius:12px;background:#0a0c12eb;border:1px solid rgba(255,255,255,.14);box-shadow:0 14px 40px #0000008c;color:#ffffffeb;font-size:12px;line-height:1.35}.cardTip .tTitle{font-weight:900;margin-bottom:6px;color:#fffffff2}.cardTip .tRow{display:flex;gap:10px;align-items:baseline}.cardTip .tKey{min-width:86px;color:#ffffffb3;font-weight:800}.cardTip .tVal{flex:1}.cardTip .mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.rmOverlay{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:9999}.rmModal{width:min(520px,calc(100vw - 32px));border-radius:16px;padding:18px 18px 14px;background:#141820f2;border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 70px #0000008c}.rmTitle{font-weight:950;font-size:18px;margin-bottom:8px}.rmBody{color:#ffffffd9;line-height:1.6;margin-bottom:12px}.rmActions{display:flex;justify-content:flex-end;gap:10px}@media(orientation:portrait)and (max-width:820px){#app{padding:12px}:root{--m-grid2-h: 230px}.appHeader{gap:4px;margin:6px 0}.appTitle{font-size:26px;padding:4px 10px}.appTitle:after{width:120px;bottom:-6px}.appTag{font-size:9px;padding:2px 8px}.kpiRow{gap:10px}.badge{width:140px;padding:5px 8px;font-size:12px}.kpi{flex:0 0 120px;min-width:120px;gap:8px}.kpi .value{font-size:24px}.kpi .value.small{font-size:16px}.status{min-width:64px}.grid2{grid-template-columns:1.05fr .95fr;gap:8px;align-items:stretch}.grid2>.panel{min-height:var(--m-grid2-h);height:auto;padding:8px}.playerList{max-height:none;overflow:visible}.playerRow{padding:6px 8px}.playerRow .muted{font-size:10px}.cardArea{gap:8px;align-items:flex-start}.playCard{transform:scale(.8);transform-origin:top left}.playMeta .title{font-size:12px}.playMeta .sub{font-size:11px;line-height:1.25;margin-top:3px}#hand{gap:8px}#hand .cardBtn{width:72px;height:104px}#hand .corner{font-size:10px}#hand .center .rank{font-size:22px}#hand .center .suit{font-size:14px}#drawBtn,#restartBtn,#homeBtn{padding:8px 10px;font-size:12px}}
