:root{--bg-0: #07080b;--bg-1: #0c0e12;--felt-hi: #1f5f4e;--felt-mid: #134237;--felt-lo: #0a241e;--felt-edge: #06140f;--gold-1: #f6e0a3;--gold-2: #e9c877;--gold-3: #b8862f;--ivory: #f8f5ec;--ink: #1b1b22;--card-w: 78px;--card-h: 112px;--radius: 10px;--shadow-card: 0 6px 14px rgba(0, 0, 0, .45), 0 1px 2px rgba(0, 0, 0, .5);--font-ui: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Cinzel", Georgia, serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{font-family:var(--font-ui);color:#e9e7df;background:radial-gradient(120% 120% at 50% -10%,var(--bg-1),var(--bg-0));overflow:hidden;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none}#app{height:100%;display:flex;flex-direction:column}.topbar{height:56px;flex:0 0 auto;display:flex;align-items:center;gap:14px;padding:0 22px;background:linear-gradient(180deg,#ffffff0a,#00000040);border-bottom:1px solid rgba(233,200,119,.18);position:relative;z-index:5}.brand{font-family:var(--font-display);font-weight:700;font-size:24px;letter-spacing:1px;background:linear-gradient(180deg,var(--gold-1),var(--gold-3));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.game-tag{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gold-2);border:1px solid rgba(233,200,119,.35);padding:3px 10px;border-radius:999px;opacity:.85}.btn-ghost{margin-left:auto;font-family:var(--font-ui);font-size:13px;font-weight:600;color:#f1ead6;background:#e9c8771a;border:1px solid rgba(233,200,119,.35);border-radius:999px;padding:8px 16px;cursor:pointer;transition:background .18s ease,transform .12s ease}.btn-ghost:hover{background:#e9c87733}.btn-ghost:active{transform:scale(.96)}.table{position:relative;flex:1 1 auto;overflow:hidden;background:radial-gradient(80% 70% at 50% 42%,var(--felt-hi),var(--felt-mid) 45%,var(--felt-lo) 78%,var(--felt-edge) 100%);box-shadow:inset 0 0 140px #000000b3}.table:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");opacity:.05;mix-blend-mode:overlay;pointer-events:none}.table:after{content:"";position:absolute;top:8%;right:8%;bottom:8%;left:8%;border-radius:50%/40%;border:1px solid rgba(233,200,119,.12);box-shadow:inset 0 0 60px #e9c8770d;pointer-events:none}.felt-logo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-size:clamp(40px,8vw,96px);font-weight:700;letter-spacing:6px;color:#e9c8770f;pointer-events:none;z-index:0}#deck-anchor{position:absolute;top:50%;left:50%;width:2px;height:2px;transform:translate(-50%,-50%);pointer-events:none}.seat{position:absolute;z-index:2}.seat--bottom{bottom:8px;left:50%;transform:translate(-50%)}.seat--top{top:14px;left:50%;transform:translate(-50%)}.seat--left{left:50px;top:50%;transform:translateY(-50%)}.seat--right{right:50px;top:50%;transform:translateY(-50%)}.seat__name{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:6px;font-size:12px;font-weight:600;letter-spacing:.4px;color:#d8d4c4;text-shadow:0 1px 3px rgba(0,0,0,.6)}.seat__name .dot{width:7px;height:7px;border-radius:50%;background:var(--gold-2);box-shadow:0 0 8px #e9c877b3}.seat--bottom .seat__name{color:#f5efda}.seat--left .hand{transform:rotate(90deg)}.seat--right .hand{transform:rotate(-90deg)}.seat--left .seat__name,.seat--right .seat__name{position:absolute;top:50%;width:max-content}.seat--left .seat__name{left:78px;transform:translateY(-50%)}.seat--right .seat__name{right:78px;transform:translateY(-50%)}.hand{display:flex;justify-content:center;align-items:flex-end}.hand--me .slot{margin:0 -22px}.hand--opp .slot{margin:0 -34px}.slot{transform:translateY(var(--ty, 0)) rotate(var(--rot, 0deg));transform-origin:bottom center;transition:transform .18s ease}.card{position:relative;width:var(--card-w);height:var(--card-h);border-radius:var(--radius);box-shadow:var(--shadow-card);will-change:transform,opacity;backface-visibility:hidden}.hand--opp .card{width:calc(var(--card-w) * .62);height:calc(var(--card-h) * .62);border-radius:7px}.card.is-interactive{cursor:pointer}.hand--me .slot:hover{transform:translateY(-22px) rotate(var(--rot, 0deg));z-index:30}.card--normal{background:linear-gradient(160deg,#ffffff 0%,var(--ivory) 60%,#efe9d8 100%);color:var(--suit, #1b1b22);border:1px solid rgba(0,0,0,.12)}.card--normal:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,#ffffff8c,#fff0 38%);pointer-events:none}.card--normal .corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:.92;font-weight:800}.card--normal .corner b{font-size:17px;letter-spacing:-.5px}.card--normal .corner i{font-style:normal;font-size:13px}.corner--tl{top:6px;left:7px}.corner--br{bottom:6px;right:7px;transform:rotate(180deg)}.card--normal .card__pip{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:38px;opacity:.92}.hand--opp .card--normal .corner b{font-size:11px}.hand--opp .card--normal .corner i{font-size:9px}.hand--opp .card--normal .card__pip{font-size:24px}.card--back{display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,#6e1322 0,#6e1322 8px,#5a0f1c 8px,#5a0f1c 16px),#5a0f1c;border:2px solid var(--gold-3)}.card--back:before{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border:1px solid rgba(233,200,119,.55);border-radius:6px}.card__back-mark{font-family:var(--font-display);font-weight:700;font-size:24px;background:linear-gradient(180deg,var(--gold-1),var(--gold-3));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;position:relative;z-index:1}.hand--opp .card__back-mark{font-size:16px}.card--special{display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:9px 6px;background:linear-gradient(165deg,#20242e,#14161d 60%,#0e0f15);border:1.5px solid var(--gold-3);color:var(--gold-1)}.card--special:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:1px solid rgba(233,200,119,.3);border-radius:7px;pointer-events:none}.special__name{font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.5px;text-align:center;position:relative;z-index:1}.special__art{flex:1;display:flex;align-items:center;justify-content:center;width:100%;position:relative;z-index:1}.special__art svg{width:56%;height:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.special__value{font-size:12px;font-weight:700;color:var(--gold-2);position:relative;z-index:1}.hand--opp .card--special .special__name{font-size:8px}.hand--opp .card--special .special__value{font-size:9px}.hud{position:absolute;top:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px;padding:7px 16px;background:#00000052;border:1px solid rgba(233,200,119,.22);border-radius:999px;z-index:4;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.score{display:flex;flex-direction:column;align-items:center;line-height:1.05}.score span{font-size:10px;letter-spacing:.4px;color:#cfcabb;text-transform:uppercase}.score b{font-size:19px}.score--us b{color:var(--gold-1)}.score--them b{color:#e3b9b9}.score__target{font-size:10px;color:#9a958a}.play-area{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:1;pointer-events:none}.play-cards{display:flex}.play-cards .slot,.play-cards .card.mini{margin:0}.card.mini{width:calc(var(--card-w) * .82);height:calc(var(--card-h) * .82);margin:0 -10px;box-shadow:0 8px 18px #00000080}.play-label{font-size:13px;font-weight:600;color:var(--gold-1);background:#0006;padding:4px 12px;border-radius:999px}.play-msg{font-size:14px;color:#d8d4c4;background:#0000004d;padding:6px 16px;border-radius:999px}.play-msg b,.seat--active .seat__name{color:var(--gold-1)}.seat--active .seat__name .dot{box-shadow:0 0 14px 3px #e9c877e6}.badge{font-size:9px;font-weight:700;letter-spacing:.5px;padding:2px 7px;border-radius:999px;margin-left:4px;vertical-align:middle}.badge--tichu{background:linear-gradient(180deg,var(--gold-1),var(--gold-3));color:#2a1d00}.badge--count{background:#ffffff1f;color:#e9e7df}.hand--me .slot.selected{transform:translateY(-30px) rotate(var(--rot, 0deg));z-index:40}.hand--me .slot.selected .card{box-shadow:0 0 0 2px var(--gold-2),0 14px 26px #0000008c}.controls{position:absolute;bottom:152px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;z-index:6;min-height:40px}.controls__info{font-size:13px;font-weight:600;color:#e9e7df;background:#0006;padding:8px 14px;border-radius:999px;min-width:180px;text-align:center}.controls__info.ok{color:var(--gold-1)}.controls__info.bad{color:#f0a9a9}.controls__wait{font-size:13px;color:#bdb9ac;font-style:italic}.btn{font-family:var(--font-ui);font-size:14px;font-weight:700;border:none;border-radius:999px;padding:10px 22px;cursor:pointer;transition:transform .12s ease,filter .15s ease,opacity .15s}.btn:active{transform:scale(.95)}.btn--gold{background:linear-gradient(180deg,var(--gold-1),var(--gold-3));color:#2a1d00}.btn--gold:disabled{opacity:.4;cursor:not-allowed}.btn--ghost{background:#ffffff14;color:#ece9df;border:1px solid rgba(255,255,255,.25)}.btn--tichu{background:linear-gradient(180deg,#e07be0,#9b2fb8);color:#fff;box-shadow:0 0 16px #e07be080}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000008c;z-index:20;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.overlay__card{background:linear-gradient(165deg,#20242e,#12141b);border:1.5px solid var(--gold-3);border-radius:18px;padding:26px 32px;min-width:300px;text-align:center;box-shadow:0 24px 60px #0009}.overlay__title{font-family:var(--font-display);font-size:22px;color:var(--gold-1);margin-bottom:14px}.overlay__dv{color:#e07be0;font-weight:700;margin-bottom:12px}.overlay__row{display:flex;justify-content:space-between;gap:30px;padding:5px 0;font-size:15px;color:#e9e7df}.overlay__row b{color:var(--gold-1)}.overlay__total{margin:12px 0 18px;font-size:13px;color:#b6b1a4;border-top:1px solid rgba(255,255,255,.12);padding-top:12px}@media(max-width:720px){:root{--card-w: 56px;--card-h: 80px}.hand--me .slot{margin:0 -16px}.controls{bottom:120px}}
