: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;z-index:2;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;justify-content:flex-end;overflow:visible;gap:0}.opponent__card-slot{margin-left:-16px;width:12px;border-radius:4px}.opponent__card-slot:first-child{margin-left:0}.opponent__card-slot--tail{width:24px;border-radius:5px}.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{position:relative;z-index:5;width:min(560px,calc(100% - 40px));margin:90px auto 0;text-align:center;padding-bottom:164px}.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:cardThrow .3s cubic-bezier(.22,1,.36,1) both}.table-center__bottom{margin-top:10px}.table-center__actions{position:relative;z-index:8;margin-top:12px;display:flex;justify-content:center;flex-wrap:wrap;gap:8px}.bid-actions{z-index:9}.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:0;min-height:132px;overflow-x:auto;padding-bottom:4px;padding-right:28px}.self-hand-card{flex:0 0 auto;margin-left:-58px;animation:dealIn .34s cubic-bezier(.22,1,.36,1) both;transition:transform .12s ease,margin .12s ease}.self-hand-card:first-child{margin-left:0}.self-hand-card--selected{transform:translate(-4px,-18px);margin-left:-52px;margin-right:6px}.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--entering{animation:popCard .26s ease both}.playing-card--compact{width:56px;height:82px;border-radius:10px;padding:4px}.playing-card--selected{transform:none}.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:50px;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:15%}.playing-card__pip--mc{left:50%;top:50%}.playing-card__pip--bc{left:50%;top:85%}.playing-card__pip--tl{left:26%;top:18%}.playing-card__pip--tr{left:74%;top:18%}.playing-card__pip--tml{left:40%;top:25%}.playing-card__pip--tmr{left:60%;top:25%}.playing-card__pip--ml{left:27%;top:50%}.playing-card__pip--mr{left:73%;top:50%}.playing-card__pip--bl{left:26%;top:82%}.playing-card__pip--br{left:74%;top:82%}.playing-card__pip--bml{left:40%;top:75%}.playing-card__pip--bmr{left:60%;top:75%}.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-toggle{min-width:84px}.log-collapsed-hint{border-radius:14px;border:1px dashed rgba(255,255,255,.16);background:#ffffff0a;color:#f6efe3c7;padding:12px}.table-back-home{position:absolute;left:16px;bottom:16px;z-index:9;border-radius:12px;min-width:102px;padding:10px 14px;border:1px solid rgba(255,255,255,.2);cursor:pointer}.action-feedback{position:fixed;right:16px;top:14px;z-index:60;border-radius:12px;padding:10px 14px;border:1px solid rgba(255,255,255,.24);background:#091711e0;color:#f4f0e9;box-shadow:0 10px 26px #00000042;animation:feedbackPop .18s ease}.action-feedback--ok{border-color:#6fe19f66}.action-feedback--warn{border-color:#f3787873;background:#381212e6}.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 cardThrow{0%{opacity:0;transform:translateY(-18px) rotate(-5deg) scale(.94)}to{opacity:1;transform:translateY(0) rotate(0) scale(1)}}@keyframes dealIn{0%{opacity:0;transform:translateY(24px) scale(.92) rotate(-2deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}@keyframes popCard{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes feedbackPop{0%{opacity:0;transform:translateY(-8px) scale(.98)}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));padding-bottom:170px}.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}.self-hand-card{margin-left:-62px}.self-hand-card--selected{margin-left:-56px;margin-right:4px}.table-back-home{left:12px;bottom:12px}.action-feedback{right:10px;top:10px;max-width:calc(100vw - 20px)}}
