:root{--felt-dark: #0d3b2e;--felt-mid: #1a5e44;--felt-light: #237755;--bg-frame: #0a0a0a;--bg-vignette: rgba(0, 0, 0, .55);--text-primary: var(--tg-theme-text-color, #f5f5f5);--text-secondary: var(--tg-theme-hint-color, #c0c0c0);--text-dim: #8a9a8a;--text-gold: var(--tg-theme-accent-text-color, #f5c842);--gold-glow: #ffe57f;--tg-button: var(--tg-theme-button-color, #c0392b);--tg-button-text: var(--tg-theme-button-text-color, #ffffff);--accent-red: #c0392b;--accent-red-hi: #e74c3c;--accent-green: #27ae60;--accent-green-hi: #2ecc71;--accent-orange: #e67e22;--accent-purple: #8e44ad;--card-w: 52px;--card-h: 74px;--card-mini-w: 42px;--card-mini-h: 60px;--card-radius: 5px;--card-shadow: 0 2px 5px rgba(0, 0, 0, .5);--suit-red: #c41e1e;--suit-black: #1a1a1a;--back-red: #8b1a1a;--back-red-hi: #c0392b;--back-pattern: #ffd700;--transition-fast: .15s ease;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}@media(max-width:380px){:root{--card-w: 48px;--card-h: 68px;--card-mini-w: 38px;--card-mini-h: 54px}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;height:100dvh;width:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;-webkit-text-size-adjust:100%;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}button{font-family:inherit;cursor:pointer;border:none;outline:none;-webkit-tap-highlight-color:transparent}.game-board{display:grid;grid-template-rows:auto auto 1fr auto auto auto;height:var(--tg-viewport-stable-height, 100dvh);width:100%;max-width:540px;margin:0 auto;position:relative;overflow:hidden;background:radial-gradient(ellipse at center,var(--felt-light) 0%,var(--felt-mid) 40%,var(--felt-dark) 75%,var(--bg-frame) 100%);padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);box-shadow:0 0 40px #0009}.game-board:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(45deg,transparent 0,transparent 2px,rgba(0,0,0,.025) 2px,rgba(0,0,0,.025) 3px),repeating-linear-gradient(-45deg,transparent 0,transparent 2px,rgba(255,255,255,.015) 2px,rgba(255,255,255,.015) 3px);pointer-events:none;z-index:0}.player-info{display:flex;align-items:center;gap:10px;padding:8px 14px;position:relative;z-index:3}.player-info-top{border-bottom:1px solid rgba(0,0,0,.25);background:linear-gradient(180deg,rgba(0,0,0,.3) 0%,transparent 100%)}.player-info-bottom{border-top:1px solid rgba(0,0,0,.25);background:linear-gradient(0deg,rgba(0,0,0,.3) 0%,transparent 100%)}.avatar-wrapper{position:relative;width:42px;height:42px;flex-shrink:0}.avatar{width:100%;height:100%;border-radius:50%;background:linear-gradient(145deg,#555,#2a2a2a);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--text-primary);border:2px solid rgba(255,255,255,.15);box-shadow:0 2px 4px #0006,inset 0 1px #ffffff1a;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.player-info.active .avatar{border-color:var(--text-gold);box-shadow:0 0 0 2px var(--text-gold),0 0 16px #f5c84280}.turn-pulse{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;border:2px solid var(--text-gold);opacity:0;animation:pulse 1.4s ease-out infinite;pointer-events:none}@keyframes pulse{0%{transform:scale(1);opacity:.8}to{transform:scale(1.35);opacity:0}}.player-meta{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.player-name{font-size:13px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-role{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-weight:600;min-height:12px}.player-info.active .player-role{color:var(--text-gold)}.card-count-badge{display:flex;align-items:center;gap:4px;background:#0006;border-radius:12px;padding:4px 10px;border:1px solid rgba(255,255,255,.08)}.card-icon{font-size:14px;color:var(--text-secondary)}.card-count-num{font-size:13px;font-weight:700;color:var(--text-primary)}.opponent-hand{display:flex;justify-content:center;align-items:flex-start;padding:8px 12px 4px;min-height:40px;position:relative;z-index:2}.opponent-card{width:28px;height:40px;margin-left:-10px;border-radius:4px;background:radial-gradient(circle at center,var(--back-red-hi) 0%,var(--back-red) 70%,#5a0d0d 100%);border:1px solid #3a0808;box-shadow:inset 0 0 0 1.5px #ffd70059,inset 0 0 0 2.5px #0003,0 1px 3px #0006;position:relative;transform-origin:bottom center}.opponent-card:first-child{margin-left:0}.opponent-card:after{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border:.5px solid rgba(255,215,0,.3);border-radius:2px;background:repeating-linear-gradient(45deg,transparent 0 3px,rgba(255,215,0,.06) 3px 4px)}.play-area{position:relative;display:flex;align-items:center;justify-content:center;min-height:0;padding:8px 12px;z-index:1}.table-area{flex:1;display:flex;flex-wrap:wrap;justify-content:center;align-content:center;gap:8px;padding:0 16px;min-height:100%;align-items:center}.table-slot{position:relative;width:calc(var(--card-mini-w) + 18px);height:calc(var(--card-mini-h) + 22px)}.table-slot .attack-card{position:absolute;top:0;left:0;transform:rotate(-6deg);transform-origin:bottom right}.table-slot .defense-card{position:absolute;top:18px;left:14px;transform:rotate(8deg);transform-origin:top left;box-shadow:-2px 2px 6px #0006}.table-slot.can-defend{outline:2px dashed var(--accent-green-hi);outline-offset:4px;border-radius:var(--card-radius);animation:glow 1s ease-in-out infinite alternate}@keyframes glow{0%{box-shadow:0 0 4px #2ecc7166}to{box-shadow:0 0 16px #2ecc71cc}}.table-empty-hint{color:var(--text-dim);font-size:13px;font-style:italic}.deck-area{position:absolute;left:8px;top:50%;transform:translateY(-50%);z-index:5}.deck-stack{position:relative;width:calc(var(--card-h) + 8px);height:var(--card-h)}.deck-trump-rotated{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(90deg);transform-origin:center;z-index:0}.deck-back-card{position:absolute;left:0;top:50%;transform:translateY(-50%);width:var(--card-mini-w);height:var(--card-mini-h);border-radius:var(--card-radius);background:radial-gradient(circle at center,var(--back-red-hi) 0%,var(--back-red) 70%,#5a0d0d 100%);border:1px solid #3a0808;box-shadow:var(--card-shadow),inset 0 0 0 2px #ffd70066;z-index:2}.deck-back-pattern{position:absolute;top:5px;right:5px;bottom:5px;left:5px;border:1px solid rgba(255,215,0,.5);border-radius:3px;background:radial-gradient(circle at center,transparent 30%,rgba(0,0,0,.2) 70%),repeating-linear-gradient(45deg,transparent 0 4px,rgba(255,215,0,.08) 4px 5px),repeating-linear-gradient(-45deg,transparent 0 4px,rgba(255,215,0,.08) 4px 5px)}.deck-back-pattern:before{content:"♣";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#ffd70099;font-size:18px}.deck-count-badge{position:absolute;top:-8px;right:-8px;background:var(--accent-red-hi);color:#fff;font-size:11px;font-weight:800;min-width:22px;height:22px;border-radius:11px;display:flex;align-items:center;justify-content:center;padding:0 5px;z-index:10;box-shadow:0 1px 4px #00000080;border:1.5px solid white}.trump-only{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px}.trump-only-suit{width:44px;height:44px;border-radius:50%;background:#ffffff14;border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:24px;line-height:1}.trump-only.red .trump-only-suit{color:var(--suit-red)}.trump-only.black .trump-only-suit{color:var(--text-primary)}.trump-only-label{font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-weight:600}.card{width:var(--card-w);height:var(--card-h);background:linear-gradient(160deg,#fff,#f0f0f0);border-radius:var(--card-radius);border:1px solid #999;box-shadow:var(--card-shadow);position:relative;font-weight:800;flex-shrink:0;overflow:hidden}.card.red{color:var(--suit-red)}.card.black{color:var(--suit-black)}.card-tl{position:absolute;top:3px;left:4px;display:flex;flex-direction:column;align-items:center;line-height:1;z-index:2}.card-br{position:absolute;bottom:3px;right:4px;display:flex;flex-direction:column;align-items:center;line-height:1;transform:rotate(180deg);z-index:2}.card-rank{font-size:11px;font-weight:800;letter-spacing:-.5px}.card-suit-small{font-size:9px;margin-top:0}.card-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;gap:1px;z-index:1}.center-rank{font-size:20px;font-weight:900;letter-spacing:-1px}.center-suit{font-size:16px;line-height:1}.card.mini{width:var(--card-mini-w);height:var(--card-mini-h)}.card.mini .card-tl{top:2px;left:3px}.card.mini .card-br{bottom:2px;right:3px}.card.mini .card-rank{font-size:10px}.card.mini .card-suit-small{font-size:8px}.card.mini .center-rank{font-size:16px}.card.mini .center-suit{font-size:13px}.player-hand-area{padding:0 0 12px;position:relative;z-index:4}.player-hand{display:flex;justify-content:center;align-items:flex-end;padding:0 12px;min-height:var(--card-h)}.hand-card-wrapper{margin-left:calc(var(--card-w) * -.4);cursor:pointer;transition:transform var(--transition-fast);position:relative;filter:drop-shadow(0 3px 4px rgba(0,0,0,.4))}.hand-card-wrapper:first-child{margin-left:0}.hand-card-wrapper.selected{transform:translateY(-18px);z-index:10}.hand-card-wrapper.playable{opacity:1}.hand-card-wrapper:not(.playable){pointer-events:none}.hand-card-wrapper:not(.playable):after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;border-radius:var(--card-radius);pointer-events:none;box-shadow:inset 0 0 0 1px #0000004d}.action-bar{display:flex;justify-content:center;gap:8px;padding:6px 16px 8px;position:relative;z-index:4;min-height:36px}.action-btn{padding:9px 22px;border-radius:22px;font-size:13px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:1px;transition:all var(--transition-fast);min-width:80px;box-shadow:0 2px 6px #0006,inset 0 1px #fff3;border:1px solid rgba(0,0,0,.2)}.action-btn.pass{background:linear-gradient(180deg,var(--accent-green-hi) 0%,var(--accent-green) 100%)}.action-btn.pickup{background:linear-gradient(180deg,var(--accent-orange) 0%,#d35400 100%)}.action-btn.transfer{background:linear-gradient(180deg,var(--accent-purple) 0%,#6c3483 100%)}.action-btn:disabled{opacity:.35;cursor:not-allowed;filter:grayscale(.5)}.action-btn:not(:disabled):active{transform:scale(.96) translateY(1px);box-shadow:0 1px 3px #0006}.error-toast{position:absolute;bottom:150px;left:50%;transform:translate(-50%);background:#c0392bf2;color:#fff;padding:8px 18px;border-radius:20px;font-size:12px;font-weight:600;z-index:50;box-shadow:0 2px 8px #0006}.game-status-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:center;align-items:center;background:#000000d9;z-index:100;gap:14px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.game-status-overlay h2{font-size:34px;color:var(--text-gold);text-shadow:0 0 16px rgba(245,200,66,.5);letter-spacing:2px}.game-status-overlay .result-text{font-size:16px;color:var(--text-secondary)}.game-status-overlay .play-again-btn{padding:14px 40px;border-radius:28px;background:linear-gradient(180deg,var(--accent-red-hi),var(--accent-red));color:#fff;font-size:16px;font-weight:700;margin-top:10px;text-transform:uppercase;letter-spacing:2px;box-shadow:0 4px 12px #c0392b80}.game-status-overlay .play-again-btn:active{transform:scale(.96)}.menu-screen{display:flex;flex-direction:column;height:var(--tg-viewport-stable-height, 100dvh);max-width:540px;margin:0 auto;padding:0 20px;background:radial-gradient(ellipse at center,var(--felt-light) 0%,var(--felt-mid) 40%,var(--felt-dark) 75%,var(--bg-frame) 100%);position:relative;overflow:hidden;box-shadow:0 0 40px #0009}.menu-top-bar{display:flex;justify-content:flex-end;padding:12px 0;position:relative;z-index:2}.menu-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;padding-bottom:32px;position:relative;z-index:1}.section{width:100%;max-width:380px;display:flex;flex-direction:column;gap:8px;align-items:center}.section-label{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);font-weight:700}.bet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%}.bet-btn{padding:12px 8px;border-radius:10px;background:#00000059;color:var(--text-primary);font-size:13px;font-weight:700;border:2px solid rgba(255,255,255,.08);transition:all var(--transition-fast)}.bet-btn.active{border-color:var(--text-gold);background:#f5c84226;color:var(--text-gold);box-shadow:0 0 12px #f5c8424d}.bet-btn.free.active{border-color:var(--accent-green-hi);background:#2ecc7126;color:var(--accent-green-hi);box-shadow:0 0 12px #2ecc714d}.bet-info{font-size:12px;color:var(--text-secondary);margin-top:4px}.bet-win{color:var(--text-gold);font-weight:700}.bet-rake-note{color:var(--text-dim);font-size:11px}.wallet-warning{font-size:12px;color:var(--accent-orange);padding:8px 14px;background:#e67e221f;border:1px solid rgba(230,126,34,.3);border-radius:10px;text-align:center;max-width:380px}.wallet-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:16px;background:#0006;color:var(--text-primary);border:1px solid rgba(255,255,255,.12);font-size:12px;font-weight:600}.wallet-pill.connected{border-color:#2ecc7166}.wallet-pill .wallet-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-green-hi);box-shadow:0 0 6px var(--accent-green-hi)}.start-btn:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.6);transform:none}.queue-card{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;background:#00000059;border-radius:18px;border:1px solid rgba(255,255,255,.08);min-width:280px;position:relative;z-index:1}.queue-spinner{width:56px;height:56px;border:4px solid rgba(245,200,66,.2);border-top-color:var(--text-gold);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.queue-title{font-size:18px;font-weight:700;color:var(--text-primary);text-align:center}.queue-meta{display:flex;flex-direction:column;gap:4px;text-align:center;color:var(--text-secondary);font-size:13px}.queue-timer{font-variant-numeric:tabular-nums;color:var(--text-gold);font-weight:700;font-size:20px}.cancel-btn{margin-top:12px;padding:12px 32px;border-radius:24px;background:#ffffff1a;color:var(--text-primary);font-size:14px;font-weight:600;border:1px solid rgba(255,255,255,.15);transition:all var(--transition-fast);position:relative;z-index:1}.cancel-btn:active{transform:scale(.96)}.menu-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(45deg,transparent 0,transparent 2px,rgba(0,0,0,.025) 2px,rgba(0,0,0,.025) 3px);pointer-events:none}.menu-screen h1{font-size:48px;font-weight:900;color:var(--text-gold);text-shadow:0 0 20px rgba(245,200,66,.4),0 2px 8px rgba(0,0,0,.6);letter-spacing:8px;position:relative;z-index:1}.menu-screen .subtitle{color:var(--text-secondary);font-size:13px;letter-spacing:2px;text-transform:uppercase;margin-top:-12px;position:relative;z-index:1}.variant-selector{display:flex;gap:10px;position:relative;z-index:1}.variant-btn{padding:12px 22px;border-radius:12px;background:#00000059;color:var(--text-primary);font-size:13px;font-weight:600;border:2px solid rgba(255,255,255,.1);transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:1px}.variant-btn.active{border-color:var(--text-gold);background:#f5c84226;color:var(--text-gold);box-shadow:0 0 12px #f5c8424d}.start-btn{padding:16px 56px;border-radius:28px;background:linear-gradient(180deg,var(--accent-red-hi),var(--accent-red));color:#fff;font-size:18px;font-weight:800;letter-spacing:3px;text-transform:uppercase;transition:all var(--transition-fast);box-shadow:0 4px 14px #c0392b80,inset 0 1px #fff3;position:relative;z-index:1}.start-btn:active{transform:scale(.97) translateY(1px);box-shadow:0 2px 8px #c0392b66}
