:root{font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;line-height:1.5;font-weight:400;color:#f6efe3;background:radial-gradient(circle at top,rgba(236,184,82,.22),transparent 30%),linear-gradient(160deg,#123524,#0c1f17 45%,#081411);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{min-width:320px}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{border:0}#root{min-height:100vh}.shell{width:min(1240px,calc(100% - 24px));margin:0 auto;padding:20px 0 34px}.shell--narrow{width:min(980px,calc(100% - 24px));min-height:calc(100vh - 54px);display:grid;align-content:center}.hero{display:grid;grid-template-columns:1.08fr .92fr;gap:18px}.hero--single{grid-template-columns:1fr .92fr}.hero__content,.panel{border:1px solid rgba(255,255,255,.09);background:#07140ea8;box-shadow:0 16px 50px #00000047;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hero__content{border-radius:24px;padding:28px}.hero__card{border-radius:24px}.eyebrow,.panel__label{margin:0 0 8px;color:#e2b45c;letter-spacing:.14em;text-transform:uppercase;font-size:12px}.hero h1,.panel h2,h3,h4{margin:0}.hero h1{font-size:clamp(2rem,3vw,3rem);line-height:1.08}.hero__desc{margin:12px 0 0;color:#f6efe3cc}.status-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.status-pill,.status-meta,.table-status span{border-radius:999px;padding:8px 14px;font-size:.88rem}.status-pill{border:1px solid rgba(255,255,255,.14)}.status-pill--online{background:#349d5c3d;color:#bff3bf}.status-pill--offline{background:#ad42423b;color:#ffc7c7}.status-meta,.table-status span{background:#ffffff12;color:#f6efe3db}.panel{border-radius:22px;padding:20px}.panel__header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.field{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.field input{width:100%;border:1px solid rgba(255,255,255,.13);border-radius:14px;padding:12px 14px;color:#f6efe3;background:#ffffff0f;outline:none}.field input:focus{border-color:#e2b45cb3}.actions{display:flex;flex-wrap:wrap;gap:10px}.actions button{border-radius:14px;padding:10px 16px;background:linear-gradient(135deg,#e2b45c,#c9822c);color:#1f1304;font-weight:700;cursor:pointer;transition:transform .16s ease}.actions button:hover:not(:disabled){transform:translateY(-1px)}.actions button:disabled{opacity:.45;cursor:not-allowed}.button-ghost{background:#ffffff14!important;color:#f6efe3!important}.error-banner{margin-top:14px;border:1px solid rgba(255,98,98,.25);border-radius:14px;padding:10px 12px;background:#7a161642;color:#ffc9c9;cursor:pointer}.table-shell{position:relative;min-height:670px;padding:14px 16px 22px;background:radial-gradient(circle at center,#1c5c3c73,#0a1e16c7 60%),#07140ea8}.table-shell--dealing{box-shadow:0 0 0 2px #e2b45c3d,0 16px 50px #00000047}.table-status{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.seat{position:absolute}.seat--upper-left{top:64px;left:22px;width:min(260px,36%)}.seat--upper-right{top:64px;right:22px;width:min(260px,36%)}.seat--self{left:18px;right:18px;bottom:14px;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#0000002e;padding:10px 12px}.opponent{border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#00000038;padding:10px}.opponent h4{margin:0;font-size:1rem}.opponent__meta,.opponent__count{margin:6px 0 0;color:#f6efe3c2;font-size:.86rem}.opponent__cards{margin-top:8px;display:flex;flex-wrap:nowrap;overflow:hidden;gap:4px}.card-back{width:56px;height:82px;border-radius:10px;border:1px solid rgba(255,255,255,.24);background:repeating-linear-gradient(45deg,#d2a2486b,#d2a2486b 8px,#7e3e1d75 8px 16px)}.card-back--mini{width:24px;height:34px;border-radius:5px}.card-back--hand{width:74px;height:108px;border-radius:12px}.card-back--dealing{animation:dealIn .26s ease both}.table-center{width:min(560px,calc(100% - 40px));margin:90px auto 0;text-align:center}.table-center__message{margin:0 0 10px;color:#f6efe3e6}.table-center__cards{min-height:86px;display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:8px}.table-center__card-wrap{animation:cardDrop .32s ease both}.table-center__bottom{margin-top:10px}.table-center__actions{margin-top:12px;display:flex;justify-content:center;flex-wrap:wrap;gap:8px}.table-center__actions button{border-radius:12px;min-width:98px;padding:10px 16px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(140deg,#f0c96f,#cd8b2f);color:#261809;font-weight:700;cursor:pointer;transition:transform .16s ease,opacity .16s ease}.table-center__actions button:hover:not(:disabled){transform:translateY(-1px)}.table-center__actions button:disabled{opacity:.45;cursor:not-allowed}.table-center__actions .button-ghost{background:#ffffff1a!important;color:#f6efe3!important}.self-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.self-header span{color:#f6efe3db}.self-hand-row{display:flex;align-items:flex-end;gap:8px;min-height:132px;overflow-x:auto;padding-bottom:4px}.self-hand-card{flex:0 0 auto;animation:dealIn .32s ease both}.playing-card{width:74px;height:108px;border-radius:12px;border:1px solid rgba(13,20,18,.33);background:#fffef9;color:#111;display:flex;flex-direction:column;justify-content:space-between;padding:5px;box-shadow:0 8px 20px #00000042;cursor:pointer;transition:transform .12s ease}.playing-card--compact{width:56px;height:82px;border-radius:10px;padding:4px}.playing-card--selected{transform:translateY(-12px)}.playing-card:disabled{cursor:not-allowed;opacity:.86}.playing-card__corner{display:inline-flex;flex-direction:column;align-items:flex-start;font-weight:700;line-height:1;gap:1px}.playing-card__corner em{font-style:normal;font-size:.74rem}.playing-card__corner small{font-size:.68rem}.playing-card__corner--bottom{align-self:flex-end;transform:rotate(180deg)}.playing-card__center{position:relative;align-self:center;width:100%;min-height:46px;font-size:.95rem}.playing-card__pip{position:absolute;transform:translate(-50%,-50%);font-style:normal;line-height:1}.playing-card__pip--flip{transform:translate(-50%,-50%) rotate(180deg)}.playing-card__pip--tc{left:50%;top:17%}.playing-card__pip--mc{left:50%;top:50%}.playing-card__pip--bc{left:50%;top:83%}.playing-card__pip--tl{left:28%;top:21%}.playing-card__pip--tr{left:72%;top:21%}.playing-card__pip--ml{left:28%;top:50%}.playing-card__pip--mr{left:72%;top:50%}.playing-card__pip--c1{left:38%;top:66%}.playing-card__pip--c2{left:62%;top:34%}.playing-card__pip--bl{left:28%;top:79%}.playing-card__pip--br{left:72%;top:79%}.playing-card__center--face{display:flex;justify-content:center;align-items:center;font-size:1.2rem}.playing-card__center--red,.playing-card__corner--red{color:#c52828}.log-panel{margin-top:16px}.log-list{display:grid;gap:10px}.log-item,.empty-state{border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff0d}.log-item{padding:12px}.log-item span{display:inline-block;margin-bottom:6px;color:#e2b45ceb;font-size:.82rem}.log-item p,.empty-state p,.table-placeholder{margin:0;color:#f6efe3d6}.empty-state{min-height:80px;display:grid;place-items:center;padding:16px}@keyframes cardDrop{0%{opacity:0;transform:translateY(-12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes dealIn{0%{opacity:0;transform:translateY(20px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:1080px){.table-shell{min-height:760px}.table-center{margin-top:92px;width:min(560px,calc(100% - 40px))}.seat--self{left:12px;right:12px;bottom:12px}.seat--upper-left{top:58px;left:12px;width:min(220px,38%)}.seat--upper-right{top:58px;right:12px;width:min(220px,38%)}}@media(max-width:720px){.shell{width:min(100% - 14px,1240px);padding:12px 0 24px}.hero,.hero--single{grid-template-columns:1fr}.hero__content,.panel{padding:14px}.hero h1{font-size:1.8rem}}
