:root{--gold: #f5c451;--gold-deep: #d99e2b;--felt-1: #138a63;--felt-2: #0a5e44;--ink: #0f172a;--panel: #182338;--panel-2: #1f2c46;--text: #eef2f9;--muted: #9fb0c9;--primary: #2f7df6;--primary-deep: #1b5fd0;--danger: #e2574c;--radius: 14px;--shadow: 0 10px 30px rgba(0, 0, 0, .35);font-synthesis:none}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;width:100%}body{font-family:PingFang SC,Microsoft YaHei,Segoe UI,system-ui,sans-serif;color:var(--text);background:radial-gradient(1200px 800px at 50% -10%,#21304e,#0b1322 60%);-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none}#root{display:flex}.btn{border:none;border-radius:999px;padding:10px 22px;font-size:15px;font-weight:600;cursor:pointer;color:#fff;background:#33415c;transition:transform .08s ease,filter .15s ease,opacity .15s}.btn:hover{filter:brightness(1.08)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed;filter:none}.btn--primary{background:linear-gradient(180deg,var(--primary),var(--primary-deep));box-shadow:0 6px 16px #2f7df659}.btn--ghost{background:#ffffff1a;border:1px solid rgba(255,255,255,.16)}.btn--lg{padding:14px 40px;font-size:17px}.btn--sm{padding:7px 14px;font-size:13px}.btn--xs{padding:4px 10px;font-size:12px}.hint{color:var(--muted);font-size:14px;margin:6px 0}.lobby{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:24px}.lobby__panel{width:min(460px,94vw);background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid rgba(255,255,255,.08);border-radius:20px;box-shadow:var(--shadow);padding:26px}.lobby__brand{display:flex;align-items:baseline;gap:10px;margin-bottom:18px}.lobby__logo{font-size:26px;font-weight:800;background:linear-gradient(90deg,var(--gold),#fff3cf);-webkit-background-clip:text;background-clip:text;color:transparent}.lobby__sub{color:var(--muted);letter-spacing:2px;font-size:13px}.lobby__footer{color:var(--muted);font-size:12px}.lobby__error{margin-top:12px;color:var(--danger);font-size:14px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field__label{font-size:13px;color:var(--muted)}.field__input{background:#00000040;border:1px solid rgba(255,255,255,.14);border-radius:10px;color:#fff;padding:11px 14px;font-size:16px;outline:none}.field__input:focus{border-color:var(--primary)}.games{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}.game-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--text);cursor:pointer;transition:all .15s}.game-card__emoji{font-size:26px}.game-card__name{font-size:13px;font-weight:700}.game-card__desc{font-size:11px;color:var(--muted)}.game-card--active{border-color:var(--gold);background:#f5c4511f;box-shadow:0 0 0 1px var(--gold) inset}.game-card--soon{opacity:.5;cursor:not-allowed}.modes__tabs{display:flex;gap:6px;background:#00000040;padding:5px;border-radius:12px;margin-bottom:14px}.tab{flex:1;border:none;background:transparent;color:var(--muted);padding:9px;border-radius:9px;font-size:15px;font-weight:600;cursor:pointer}.tab--active{background:#ffffff1f;color:#fff}.modes__body{display:flex;flex-direction:column;gap:10px}.join{display:flex;gap:8px}.join__input{flex:1;text-transform:uppercase;letter-spacing:3px;text-align:center;font-weight:700}.ddz-game{flex:1;width:100%;height:100%;min-height:0;display:flex;flex-direction:column;--card-w: clamp(60px, 20vw, 82px);--card-h: calc(var(--card-w) * 1.40625);--card-hand-w: clamp(74px, 28vw, 104px);--card-hand-h: calc(var(--card-hand-w) * 1.40625);--card-play-w: clamp(64px, 24vw, 92px);--card-play-h: calc(var(--card-play-w) * 1.40625);--card-sm-w: calc(var(--card-w) * .625);--card-sm-h: calc(var(--card-h) * .622);--card-lift: calc(var(--card-w) * .344);--card-sm-overlap: calc(var(--card-sm-w) * .55);--hand-h: calc(var(--card-hand-h) * 1.35);--hud-h: calc(var(--card-w) * .8125);--seat-top: calc(var(--card-w) * 1.25);--play-top: calc(var(--card-hand-w) * 2.1);--play-bottom: calc(var(--card-hand-h) * 2.1 + 72px);--bottom-cards-top: var(--card-w);--safe-bottom: env(safe-area-inset-bottom, 0px)}.table{position:relative;flex:1;height:100%;overflow:hidden;background:radial-gradient(900px 600px at 50% 38%,var(--felt-1),var(--felt-2) 70%,#073322 100%)}.table--loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--muted)}.spinner{width:38px;height:38px;border-radius:50%;border:4px solid rgba(255,255,255,.2);border-top-color:var(--gold);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.hud{position:absolute;inset:0 0 auto 0;height:var(--hud-h);display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:linear-gradient(180deg,rgba(0,0,0,.35),transparent);z-index:5}.hud__left{display:flex;align-items:center;gap:8px}.hud__voice-wrap{display:flex;align-items:center;gap:4px}.hud__voice{min-width:40px;padding-inline:10px}.hud__voice-select{max-width:108px;padding:5px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.16);background:#00000059;color:#fff;font-size:11px;outline:none}.hud__voice-select:focus{border-color:var(--primary)}.hud__center{display:flex;gap:10px;align-items:center}.hud__room{color:#fff;font-size:14px}.hud__room b{letter-spacing:2px;color:var(--gold)}.hud__chip{background:#0000004d;border:1px solid rgba(255,255,255,.15);padding:5px 12px;border-radius:999px;font-size:13px}.hud__chip--gold{color:var(--ink);background:linear-gradient(180deg,var(--gold),var(--gold-deep));border:none;font-weight:800}.hud__scores{display:flex;gap:12px;font-size:12px;color:var(--muted)}.seat{position:absolute;top:var(--seat-top);display:flex;align-items:center;gap:10px;padding:8px 12px;background:#00000047;border-radius:14px;border:1px solid rgba(255,255,255,.08)}.seat--left{left:20px}.seat--right{right:20px;flex-direction:row-reverse}.seat--active{box-shadow:0 0 0 2px var(--gold),0 0 20px #f5c45166}.avatar{position:relative;width:52px;height:52px;border-radius:50%;background:linear-gradient(180deg,#38507c,#20304e);display:flex;align-items:center;justify-content:center;font-size:26px;border:2px solid rgba(255,255,255,.18)}.avatar__off{position:absolute;bottom:-8px;font-size:10px;background:var(--danger);border-radius:6px;padding:1px 5px}.seat__name{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600}.seat__count{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:5px}.card-back-mini{display:inline-block;width:14px;height:19px;border-radius:3px;background:linear-gradient(135deg,#3a5db0,#213a73);border:1px solid rgba(255,255,255,.3)}.role{font-size:11px;padding:1px 7px;border-radius:6px;font-weight:700}.role--landlord{background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:var(--ink)}.role--farmer{background:#ffffff29;color:#fff}.turn-dot{width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold);animation:pulse 1s infinite}@keyframes pulse{50%{opacity:.35}}.bottom-cards{position:absolute;top:var(--bottom-cards-top);left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:4}.play-zone{position:absolute;inset:var(--play-top) 0 var(--play-bottom) 0}.play{position:absolute;min-height:60px;display:flex;align-items:center;justify-content:center}.play--self{left:50%;bottom:0;transform:translate(-50%)}.play--left{left:60px;top:30px}.play--right{right:60px;top:30px}.play__cards{display:flex;--card-w: var(--card-play-w);--card-sm-w: var(--card-play-w);--card-sm-h: var(--card-play-h);--card-sm-overlap: calc(var(--card-play-w) * .52)}.play__cards .card--sm:not(:first-child){margin-left:calc(var(--card-sm-overlap) * -1)}.play__pass{color:#ffd98a;font-size:clamp(18px,5vw,24px);font-weight:800;text-shadow:0 2px 6px rgba(0,0,0,.5)}.self{position:absolute;inset:auto 0 0 0;padding:6px 12px calc(14px + var(--safe-bottom));display:flex;flex-direction:column;align-items:center;gap:6px}.self__role{display:flex;align-items:center;gap:8px;font-size:14px}.self__name{font-weight:700}.hand{display:flex;justify-content:center;align-items:flex-end;height:var(--hand-h);padding-top:calc(var(--card-hand-w) * .344);--card-w: var(--card-hand-w);--card-h: var(--card-hand-h);--card-lift: calc(var(--card-hand-w) * .344)}.hand__slot{transition:transform .12s ease}.card{position:relative;width:var(--card-w);height:var(--card-h);background:#fff;border-radius:calc(var(--card-w) * .125);box-shadow:0 3px 8px #00000059;border:1px solid #d5d9e0;cursor:pointer;flex:none}.card--sm{width:var(--card-sm-w);height:var(--card-sm-h);border-radius:calc(var(--card-w) * .078);cursor:default}.card--selected{transform:translateY(calc(var(--card-lift) * -1));box-shadow:0 10px 18px #00000073}.card--dim{opacity:.5}.card--red{color:#e53935}.card--black{color:#1c2230}.card__corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1}.card__corner--tl{top:5px;left:6px}.card__rank{font-size:calc(var(--card-w) * .34);font-weight:800}.card--sm .card__rank,.card__suit{font-size:calc(var(--card-w) * .26)}.card--sm .card__suit{font-size:calc(var(--card-w) * .19)}.card__center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:calc(var(--card-w) * .56);opacity:.9}.card--sm .card__center{font-size:calc(var(--card-w) * .36)}.card--back{background:linear-gradient(135deg,#3a5db0,#213a73);border:1px solid rgba(255,255,255,.3)}.card--back:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:5px;border:1px dashed rgba(255,255,255,.35)}.card__joker{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:flex-start;padding:5px 6px}.card__joker-text{writing-mode:vertical-rl;font-size:calc(var(--card-w) * .18);font-weight:800;letter-spacing:1px}.card--sm .card__joker-text{font-size:calc(var(--card-w) * .13)}.card__joker-label{position:absolute;right:6px;bottom:5px;font-size:calc(var(--card-w) * .32);font-weight:900}.card--joker-big{color:#e53935}.card--joker-small{color:#1c2230}.actionbar{display:flex;gap:14px;justify-content:center;align-items:center;min-height:48px}.actionbar--wait{color:var(--muted);font-size:14px}.ddz-game .actionbar .btn{font-size:clamp(14px,3.6vw,16px)}@media(max-width:768px){.ddz-game .hud__scores{display:none}.ddz-game .hud__voice-select{max-width:76px}.ddz-game .actionbar .btn{min-height:44px;padding:10px 18px}.ddz-game .chat-panel{width:min(290px,calc(100vw - 36px));right:12px}}.waiting{position:relative;flex:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(900px 600px at 50% 30%,var(--felt-1),var(--felt-2) 70%,#073322 100%)}.waiting__panel{position:relative;width:min(440px,94vw);background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:28px;box-shadow:var(--shadow);text-align:center}.waiting__leave{position:absolute;left:16px;top:16px}.waiting__title{margin:6px 0 14px}.waiting__room{color:var(--muted);margin-bottom:18px;display:flex;align-items:center;justify-content:center;gap:10px}.waiting__code{font-size:26px;letter-spacing:6px;font-weight:800;color:var(--gold)}.waiting__seats{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.seat-slot{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08)}.seat-slot--empty{opacity:.55;border-style:dashed}.seat-slot__face{font-size:24px}.seat-slot__name{flex:1;text-align:left;font-weight:600}.waiting__actions{display:flex;gap:12px;justify-content:center;align-items:center}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:20;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.result{width:min(380px,92vw);background:linear-gradient(180deg,var(--panel),var(--panel-2));border-radius:20px;padding:26px;text-align:center;border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow)}.result__title{font-size:34px;font-weight:900}.result__title--win{color:var(--gold)}.result__title--lose{color:#9fb0c9}.result__sub{color:var(--muted);margin:6px 0 16px}.result__deltas{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.result__row{display:flex;justify-content:space-between;padding:8px 14px;background:#ffffff0d;border-radius:10px}.pos{color:#4ade80;font-weight:700}.neg{color:#f87171;font-weight:700}.result__you{font-size:20px;font-weight:800;margin-bottom:18px}.result__actions{display:flex;gap:12px;justify-content:center;align-items:center}.chat-fab{position:absolute;right:18px;bottom:150px;width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:#0006;color:#fff;font-size:22px;cursor:pointer;z-index:15;transition:transform .1s}.chat-fab:hover{transform:scale(1.08)}.chat-panel{position:absolute;right:18px;bottom:206px;width:290px;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid rgba(255,255,255,.12);border-radius:14px;box-shadow:var(--shadow);padding:12px;z-index:16}.chat-panel__head{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--muted);margin-bottom:10px}.chat-panel__emojis{display:flex;gap:6px;margin-bottom:8px}.emoji-btn{flex:1;font-size:20px;padding:6px 0;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;cursor:pointer}.emoji-btn:hover{background:#ffffff1f}.chat-panel__phrases{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}.phrase-btn{font-size:12px;padding:7px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text);cursor:pointer;text-align:center}.phrase-btn:hover{background:#ffffff1f}.chat-panel__input{display:flex;gap:6px}.chat-panel__input .field__input{flex:1;padding:8px 10px;font-size:14px}.chat-bubble{position:absolute;max-width:200px;background:#fff;color:#1c2230;padding:8px 12px;border-radius:12px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #0000004d;z-index:14;animation:fadein .18s ease}.chat-bubble:after{content:"";position:absolute;width:0;height:0;border:7px solid transparent}.chat-bubble--self{left:50%;bottom:178px;transform:translate(-50%)}.chat-bubble--self:after{bottom:-12px;left:50%;transform:translate(-50%);border-top-color:#fff}.chat-bubble--left{left:90px;top:138px}.chat-bubble--left:after{top:-12px;left:24px;border-bottom-color:#fff}.chat-bubble--right{right:90px;top:138px}.chat-bubble--right:after{top:-12px;right:24px;border-bottom-color:#fff}.toast{position:absolute;top:64px;left:50%;transform:translate(-50%);background:#000000c7;color:#fff;padding:10px 20px;border-radius:999px;font-size:14px;z-index:30;animation:fadein .2s ease}@keyframes fadein{0%{opacity:0;transform:translate(-50%,-6px)}}
