@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--bg-color:#0b0f19;--felt-green:#073b22;--felt-inner-glow:radial-gradient(circle, #0e5e39 0%, #06341d 80%, #032111 100%);--gold-accent:#f59e0b;--gold-glow:0 0 15px #f59e0b66;--text-primary:#f8fafc;--text-secondary:#94a3b8;--card-bg:#1e293bb3;--card-border:#ffffff1a;--accent-color:#3b82f6;--accent-hover:#2563eb;--suit-Spades:#1e293b;--suit-Clubs:#334155;--suit-Hearts:#ef4444;--suit-Diamonds:#f87171}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);background-image:radial-gradient(at 0 0,#100f15 0,#0000 50%),radial-gradient(at 100% 0,#13192b 0,#0000 50%),radial-gradient(at 50% 100%,#260d16 0,#0000 50%);min-height:100vh;font-family:Outfit,sans-serif;display:flex;overflow:hidden}#root{width:100%;height:100vh;display:flex}.app-container{width:100%;height:100vh;display:flex;overflow:hidden}.sidebar{border-right:1px solid var(--card-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:#0f172acc;flex-direction:column;gap:16px;width:320px;min-width:320px;height:100%;padding:20px;display:flex;overflow-y:auto;box-shadow:4px 0 20px #00000080}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:#ffffff0d;border-radius:2px}.sidebar-header{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;padding-bottom:15px;display:flex}.sidebar-header h1{letter-spacing:2px;background:linear-gradient(90deg,#60a5fa,#c084fc);-webkit-text-fill-color:transparent;text-shadow:0 2px 10px #60a5fa33;-webkit-background-clip:text;font-size:1.6rem;font-weight:800}.btn-toggle-debug{border:1px solid var(--card-border);color:var(--text-secondary);cursor:pointer;background:#ffffff0d;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:.8rem;transition:all .2s}.btn-toggle-debug:hover{color:var(--text-primary);background:#ffffff1a}.debug-presets-drawer{background:#1e293b66;border:1px solid #f59e0b33;border-radius:12px;padding:12px;animation:.3s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.debug-presets-drawer h4{color:var(--gold-accent);margin-bottom:8px;font-size:.9rem;font-weight:600}.presets-buttons-stack{flex-direction:column;gap:8px;display:flex}.btn-preset{color:var(--text-primary);text-align:left;cursor:pointer;background:#0f172a99;border:1px solid #ffffff14;border-radius:6px;padding:8px 12px;font-family:inherit;font-size:.85rem;transition:all .2s}.btn-preset:hover{border-color:var(--gold-accent);background:#f59e0b26;transform:translate(4px)}.presets-footer-hint{color:var(--text-secondary);margin-top:8px;font-size:.75rem;line-height:1.3}.contract-box{border:1px solid var(--card-border);background:#1e293b4d;border-radius:12px;padding:15px}.contract-box h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;font-size:1rem;font-weight:600}.contract-details{flex-direction:column;gap:6px;font-size:.95rem;display:flex}.highlighted{color:var(--gold-accent);font-weight:700}.no-contract-yet{color:var(--text-secondary);font-size:.85rem;font-style:italic}.tricks-scoreboard{border-top:1px solid var(--card-border);flex-direction:column;gap:4px;margin-top:12px;padding-top:10px;display:flex}.score-row{color:var(--text-primary);justify-content:space-between;font-size:.9rem;display:flex}.game-logs-container{border:1px solid var(--card-border);background:#0f172a66;border-radius:12px;flex-direction:column;flex:1;padding:15px;display:flex;overflow:hidden}.game-logs-container h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:1rem;font-weight:600}.logs-scroller{color:#cbd5e1;flex-direction:column;flex:1;gap:6px;padding-right:5px;font-size:.82rem;line-height:1.4;display:flex;overflow-y:auto}.logs-scroller::-webkit-scrollbar{width:4px}.logs-scroller::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.log-line{align-items:flex-start;gap:6px;display:flex}.log-bullet{color:var(--gold-accent);margin-top:1px;font-size:.7rem}.main-content{flex-direction:column;flex:1;height:100%;display:flex;position:relative;overflow:hidden}.main-header{z-index:5;justify-content:center;padding:16px 24px;display:flex}.message-box{color:#bfdbfe;text-align:center;background:#1e293b99;border:1px solid #60a5fa33;border-radius:24px;padding:10px 24px;font-size:1.1rem;font-weight:500;box-shadow:0 4px 20px #0000004d}.table-board-container{flex:1;justify-content:center;align-items:center;padding:20px;display:flex;overflow:hidden}.game-board-felt{background:var(--felt-inner-glow);border:16px solid #1e1b4b;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:900px;height:900px;display:flex;position:relative;box-shadow:0 10px 50px #000c,inset 0 10px 40px #000000e6,inset 0 0 100px #000000b3}.player-area{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;border:1px solid #ffffff0f;border-radius:20px;flex-direction:column;align-items:center;gap:12px;padding:12px 18px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute}.player-area.active{background:#3b82f61f;border-color:#3b82f680;transform:scale(1.03);box-shadow:0 0 20px #3b82f64d,inset 0 0 10px #3b82f61a}.player-info-badge{text-align:center;border:1px solid var(--card-border);background:#0f172acc;border-radius:12px;padding:4px 12px}.player-name{color:#fff;font-size:.95rem;font-weight:700}.player-tricks{color:var(--text-secondary);font-size:.75rem}.player-bottom{z-index:120;max-width:850px;bottom:12px;left:50%;transform:translate(-50%)}.player-bottom.active{transform:translate(-50%)scale(1.03)}.player-top{top:24px;left:50%;transform:translate(-50%)}.player-top.active{transform:translate(-50%)scale(1.03)}.player-left{top:50%;left:24px;transform:translateY(-50%)}.player-left.active{transform:translateY(-50%)scale(1.03)}.player-right{top:50%;right:24px;transform:translateY(-50%)}.player-right.active{transform:translateY(-50%)scale(1.03)}.hand-horizontal{justify-content:center;padding-left:25px;display:flex}.hand-horizontal .playing-card{margin-left:-25px}.hand-vertical{flex-direction:column;align-items:center;padding-top:35px;display:flex}.hand-vertical .playing-card{margin-top:-45px}.playing-card{cursor:pointer;-webkit-user-select:none;user-select:none;background:#f8fafc;border:1px solid #00000026;border-radius:8px;flex-direction:column;justify-content:space-between;width:76px;height:110px;padding:6px;font-size:1.1rem;font-weight:800;transition:transform .2s cubic-bezier(.175,.885,.32,1.275),box-shadow .2s,z-index .2s;display:flex;position:relative;box-shadow:0 4px 10px #0006,inset 0 0 4px #0000001a}.playing-card:hover{transform:translateY(-20px)scale(1.12);box-shadow:0 12px 24px #0009;z-index:100!important}.hand-vertical .playing-card:hover{transform:translate(-20px)scale(1.12)}.playing-card.disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.6)brightness(.8)}.game-status-bidding .human-player .playing-card.disabled,.game-status-selecting_trump_partner .human-player .playing-card.disabled,.game-status-troela_announcement .human-player .playing-card.disabled,.game-status-troela_selecting_trump .human-player .playing-card.disabled{opacity:.85;filter:grayscale(.15)brightness(.95);cursor:default}.playing-card.disabled:hover{transform:none;box-shadow:0 4px 10px #0006}.card-top-left{flex-direction:column;align-self:flex-start;align-items:center;line-height:1;display:flex}.card-center{align-self:center;font-size:2.1rem;line-height:1}.card-bottom-right{flex-direction:column;align-self:flex-end;align-items:center;line-height:1;display:flex;transform:rotate(180deg)}.suit-Spades{color:var(--suit-Spades)}.suit-Clubs{color:var(--suit-Clubs)}.suit-Hearts{color:var(--suit-Hearts)}.suit-Diamonds{color:var(--suit-Diamonds)}.playing-card.card-back{cursor:default;background:linear-gradient(135deg,#1e1b4b 0%,#312e81 100%);border:2px solid #f59e0b4d;box-shadow:0 4px 8px #00000080}.playing-card.card-back:hover{transform:none;box-shadow:0 4px 8px #00000080}.card-back-pattern{border:1px dashed #f59e0b33;border-radius:4px;justify-content:center;align-items:center;gap:1px;width:100%;height:100%;display:flex}.card-back-pattern span{color:#f59e0b40;text-shadow:0 0 4px #f59e0b33;font-size:1.4rem;font-weight:800}.flipped-e{display:inline-block;transform:scaleX(-1)}.playing-card.tabled-revealed{border:1.5px solid #3b82f666;box-shadow:0 2px 6px #3b82f64d}.trick-area{background:#00000040;border:2px solid #ffffff08;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:260px;height:260px;display:flex;position:relative;box-shadow:inset 0 0 30px #0009}.trick-cards{width:120px;height:120px;position:relative}.trick-card-container{animation:.3s cubic-bezier(.175,.885,.32,1.275) forwards popIn;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.trick-pos-0{z-index:10;transform:translate(-50%,-5%)rotate(-5deg)}.trick-pos-1{z-index:8;transform:translate(-105%,-55%)rotate(-85deg)}.trick-pos-2{z-index:6;transform:translate(-50%,-105%)rotate(-175deg)}.trick-pos-3{z-index:9;transform:translate(5%,-55%)rotate(95deg)}@keyframes popIn{0%{opacity:0;transform:translate(-50%,-50%)scale(0)rotate(-60deg)}to{opacity:1}}.controls{z-index:50;justify-content:center;margin-top:15px;display:flex}.btn-primary{background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border:1px solid #ffffff26}.btn-primary:hover{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%)}.btn-confirm{background:linear-gradient(135deg,#10b981 0%,#047857 100%);border:1px solid #ffffff26;width:100%;margin-top:20px}.btn-confirm:hover{background:linear-gradient(135deg,#34d399 0%,#059669 100%)}.btn{color:#fff;cursor:pointer;border-radius:9999px;padding:10px 24px;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000004d}.btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0006}.btn:active{transform:translateY(0)}.bidding-overlay,.selection-overlay{-webkit-backdrop-filter:blur(16px);z-index:100;background:#0f172ad9;border:2px solid #ffffff14;border-radius:24px;flex-direction:column;align-items:center;width:680px;padding:24px;animation:.3s cubic-bezier(.34,1.56,.64,1) overlayScaleIn;display:flex;position:absolute;top:38%;left:50%;transform:translate(-50%,-38%);box-shadow:0 20px 50px #000000e6}@keyframes overlayScaleIn{0%{opacity:0;transform:translate(-50%,-38%)scale(.9)}to{opacity:1;transform:translate(-50%,-38%)scale(1)}}.bidding-overlay h2,.selection-overlay h2{letter-spacing:1px;color:#fff;margin-bottom:12px;font-size:1.5rem;font-weight:800}.subtitle{color:var(--text-secondary);text-align:center;margin-bottom:16px;font-size:.95rem}.bidding-status{background:#0003;border-radius:12px;justify-content:space-between;width:100%;margin-bottom:16px;padding:8px 16px;font-size:.9rem;display:flex}.bid-badge{border:1px solid var(--gold-accent);color:var(--gold-accent);background:#f59e0b26;border-radius:6px;padding:2px 8px;font-weight:700}.bids-history-grid{grid-template-columns:repeat(4,1fr);gap:12px;width:100%;margin-bottom:20px;display:grid}.player-bid-status{text-align:center;background:#1e293b80;border:1px solid #ffffff0a;border-radius:12px;padding:8px}.player-bid-status.passed{opacity:.5;border-color:#ef444433}.player-bid-status .p-name{color:var(--text-secondary);font-size:.75rem;font-weight:500}.player-bid-status .p-bid{color:#fff;margin-top:4px;font-size:.95rem;font-weight:700}.human-bidding-panel{border-top:1px solid var(--card-border);width:100%;padding-top:16px}.human-bidding-panel h3{color:var(--text-secondary);text-align:center;margin-bottom:12px;font-size:1rem}.troela-alert{color:#fef08a;text-align:center;background:#f59e0b1f;border:1px solid #f59e0b4d;border-radius:8px;margin-bottom:12px;padding:8px;font-size:.85rem}.bidding-buttons-grid{grid-template-columns:repeat(4,1fr);gap:8px;width:100%;display:grid}.btn-bid{color:#fff;cursor:pointer;text-align:center;background:#1e293bcc;border:1px solid #ffffff14;border-radius:8px;padding:8px 4px;font-family:inherit;font-size:.82rem;font-weight:600;transition:all .2s}.btn-bid.active:hover{background:var(--accent-color);border-color:#60a5fa;transform:translateY(-2px);box-shadow:0 4px 10px #3b82f64d}.btn-bid.pass-btn{background:#64748b33;border-color:#64748b66}.btn-bid.pass-btn.active:hover{background:#64748b;border-color:#94a3b8}.btn-bid.troela-glow.active{border-color:var(--gold-accent);box-shadow:var(--gold-glow);animation:2s infinite pulseGold}@keyframes pulseGold{0%{box-shadow:0 0 #f59e0b80}70%{box-shadow:0 0 0 10px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}.btn-bid.disabled{opacity:.25;cursor:not-allowed;background:#0f172a4d}.ai-bidding-thinking{color:var(--text-secondary);align-items:center;gap:10px;margin:15px 0;font-size:.95rem;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.selection-columns{gap:20px;width:100%;margin-top:10px;display:flex}.selection-card{background:#00000040;border:1px solid #ffffff0a;border-radius:16px;flex-direction:column;flex:1;align-items:center;padding:16px;display:flex}.selection-card h3{color:#fff;margin-bottom:12px;font-size:1rem}.trump-suits-buttons{grid-template-columns:repeat(2,1fr);gap:10px;width:100%;display:grid}.center-grid{grid-template-columns:repeat(3,1fr);width:90%;margin:10px auto}.btn-suit{color:#fff;cursor:pointer;background:#1e293bb3;border:1px solid #ffffff0f;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:10px;font-family:inherit;font-size:.9rem;font-weight:700;transition:all .2s;display:flex}.btn-suit:hover{background:#ffffff14;border-color:#fff3}.btn-suit.selected{background:var(--accent-color);border-color:#60a5fa;box-shadow:0 0 12px #3b82f666}.suit-sym{font-size:1.3rem}.fixed-trump-banner{color:#fca5a5;text-align:center;background:#ef44441f;border:1px solid #ef444433;border-radius:12px;padding:10px 16px;font-size:.9rem}.partner-cards-list{justify-content:center;gap:10px;display:flex}.partner-card-select-btn{cursor:pointer;border:2px solid #0000;border-radius:10px;padding:2px;transition:all .2s}.partner-card-select-btn.selected{border-color:var(--gold-accent);box-shadow:var(--gold-glow);transform:scale(1.05)}.hint-text{color:var(--text-secondary);text-align:center;margin-bottom:12px;font-size:.75rem;line-height:1.3}.select-trump-prompt{color:var(--text-secondary);margin:20px 0;font-size:.85rem;font-style:italic}.text-troela{background:linear-gradient(90deg,#fbbf24,#f59e0b,#d97706);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.8rem!important}.troela-announcement-card{background:#f59e0b14;border:1px solid #f59e0b33;border-radius:16px;flex-direction:column;gap:10px;margin-top:15px;padding:20px 40px;display:flex}.lead-text{font-size:1.1rem}.divider{background:#ffffff14;width:100%;height:1px}.thinking-text{color:var(--text-secondary);margin-top:10px;font-size:.85rem;font-style:italic}.player-bot-memory{color:#fff;text-align:left;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#0f172ad9;border:1px solid #ffffff14;border-radius:12px;width:100%;max-width:190px;margin-top:8px;padding:8px;font-size:.72rem;box-shadow:0 4px 15px #0006}.memory-title{text-transform:uppercase;letter-spacing:.8px;color:#60a5fa;text-align:center;border-bottom:1px solid #ffffff0d;margin-bottom:6px;padding-bottom:4px;font-size:.65rem;font-weight:800}.memory-tabs{gap:3px;margin-bottom:6px;display:flex}.memory-tab-btn{color:#94a3b8;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff0d;border-radius:4px;flex:1;padding:2px 0;font-size:.62rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1)}.memory-tab-btn:hover{color:#fff;background:#ffffff14}.memory-tab-btn.active{color:#fff;background:#3b82f640;border-color:#3b82f680;font-weight:700}.memory-details{flex-direction:column;gap:4px;display:flex}.memory-row{justify-content:space-between;align-items:center;min-height:18px;display:flex}.row-label{color:#94a3b8;font-weight:500}.row-value{flex-wrap:wrap;justify-content:flex-end;gap:2px;font-weight:600;display:flex}.suit-indicator{justify-content:center;align-items:center;width:14px;height:14px;font-size:.8rem;display:inline-flex}.max-ranks-list,.known-cards-list{justify-content:flex-end;max-width:110px}.max-rank-tag,.known-card-tag{background:#ffffff14;border-radius:3px;align-items:center;padding:1px 4px;font-size:.65rem;line-height:1;display:inline-flex}.none-text{color:#64748b;font-size:.65rem;font-style:italic}.memory-inference-msg{color:#10b981;border-top:1px solid #ffffff0f;margin-top:6px;padding-top:5px;font-size:.62rem;font-style:italic;line-height:1.2}.bot-logic-dialogue{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:1000;background:#0f172ad9;border:1px solid #3b82f640;border-radius:16px;flex-direction:column;width:380px;max-height:380px;transition:all .3s cubic-bezier(.4,0,.2,1);animation:.3s cubic-bezier(.4,0,.2,1) slideInUp;display:flex;position:absolute;bottom:24px;right:24px;overflow:hidden;box-shadow:0 10px 30px #00000080,0 0 20px #3b82f61a}.dialogue-header{color:#fff;letter-spacing:.5px;background:#1e293b99;border-bottom:1px solid #3b82f626;align-items:center;gap:8px;padding:12px 16px;font-size:.78rem;font-weight:800;display:flex}.pulse-dot{background:#10b981;border-radius:50%;width:7px;height:7px;animation:1.8s infinite pulse-active;box-shadow:0 0 8px #10b981}.clear-btn{color:#f87171;cursor:pointer;background:0 0;border:1px solid #ef44444d;border-radius:6px;margin-left:auto;padding:3px 8px;font-size:.68rem;font-weight:600;transition:all .2s}.clear-btn:hover{color:#fff;background:#ef44441a;border-color:#ef4444}.dialogue-body{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.dialogue-body::-webkit-scrollbar{width:6px}.dialogue-body::-webkit-scrollbar-track{background:0 0}.dialogue-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.dialogue-body::-webkit-scrollbar-thumb:hover{background:#fff3}.empty-thoughts-placeholder{text-align:center;color:#64748b;padding:40px 20px;font-size:.72rem;font-style:italic;line-height:1.5}.thought-cycle-card{background:#1e293b4d;border:1px solid #ffffff0a;border-radius:10px;padding:8px 12px;transition:all .2s}.thought-cycle-card:hover{background:#1e293b73;border-color:#3b82f640}.thought-cycle-header{border-bottom:1px solid #ffffff0a;align-items:center;gap:8px;margin-bottom:6px;padding-bottom:4px;display:flex}.bot-name{color:#60a5fa;font-size:.74rem;font-weight:700}.played-card-badge{color:#e2e8f0;background:#ffffff0f;border-radius:4px;padding:1px 6px;font-size:.68rem}.timestamp{color:#64748b;margin-left:auto;font-size:.62rem}.thought-steps{flex-direction:column;gap:3px;display:flex}.thought-step-line{color:#cbd5e1;align-items:flex-start;gap:4px;font-size:.68rem;line-height:1.35;display:flex}.thought-step-line .arrow{color:#3b82f6;font-weight:800}@keyframes pulse-active{0%{box-shadow:0 0 #10b981b3}70%{box-shadow:0 0 0 6px #10b98100}to{box-shadow:0 0 #10b98100}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.bot-player{z-index:5}.bot-player .playing-card{border-radius:5px!important;width:50px!important;height:72px!important;padding:4px!important;font-size:.8rem!important;box-shadow:0 2px 6px #0006!important}.bot-player .card-top-left{font-size:.75rem!important}.bot-player .card-center{font-size:1.2rem!important}.bot-player .card-bottom-right{font-size:.75rem!important}.bot-player .hand-vertical{padding-top:15px!important}.bot-player .hand-vertical .playing-card{margin-top:-48px!important}.bot-player .hand-vertical .playing-card:hover{transform:translate(-15px)scale(1.15)!important}.bot-player .hand-horizontal{padding-left:15px!important}.bot-player .hand-horizontal .playing-card{margin-left:-32px!important}.bot-player .hand-horizontal .playing-card:hover{transform:translateY(-15px)scale(1.15)!important}.bot-player .playing-card.card-back{border-width:1px!important}.bot-player .card-back-pattern span{font-size:.95rem!important}.human-player{z-index:120!important}.human-player .playing-card{width:82px!important;height:118px!important;padding:8px!important;font-size:1.15rem!important;box-shadow:0 5px 12px #00000080!important}.human-player .card-center{font-size:2.3rem!important}.human-player .hand-horizontal{padding-left:20px!important}.human-player .hand-horizontal .playing-card{margin-left:-20px}.score-hint-pill{z-index:1001;-webkit-backdrop-filter:blur(12px);color:#f8fafc;cursor:pointer;background:#1e293ba6;border:1px solid #ffffff1a;border-radius:50px;align-items:center;gap:6px;padding:8px 14px;font-family:Inter,system-ui,sans-serif;font-size:.8rem;font-weight:700;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;position:fixed;top:16px;left:16px;box-shadow:0 4px 15px #00000080,inset 0 1px 1px #ffffff1a}.score-hint-pill.active{color:#fbbf24;background:#0f172ad9;border-color:#fbbf2473;box-shadow:0 0 15px #fbbf2440,0 4px 15px #00000080}.score-hint-pill:hover{background:#1e293bd9;border-color:#ffffff40;transform:translateY(-2px)}.score-hint-pill kbd{color:#cbd5e1;background:#ffffff1f;border:1px solid #fff3;border-radius:5px;margin-left:2px;padding:2px 6px;font-size:.7rem;font-weight:800;line-height:1;display:inline-block;box-shadow:0 1px #0000004d}.score-hint-pill.active kbd{color:#fbbf24;background:#fbbf2433;border-color:#fbbf2466}.coin-bounce{animation:2.5s ease-in-out infinite coinBounce;display:inline-block}@keyframes coinBounce{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-4px)rotate(15deg)}}.carrying-score-ledger{-webkit-backdrop-filter:blur(25px);z-index:1000;background:#0a0c16ed;border-right:2px solid #fbbf2433;flex-direction:column;width:270px;padding:76px 20px 20px;transition:transform .45s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:10px 0 50px #000000d9}.carrying-score-ledger.visible{transform:translate(0)}.ledger-header{border-bottom:1px solid #ffffff0d;padding-bottom:14px}.ledger-header h3{color:#fbbf24;letter-spacing:.05em;text-shadow:0 0 10px #fbbf2433;margin:0;font-size:1.15rem;font-weight:900}.ledger-sub{color:#64748b;text-transform:uppercase;letter-spacing:.12em;margin:4px 0 0;font-size:.65rem;font-weight:700}.ledger-body{flex-direction:column;flex-grow:1;gap:12px;margin-top:24px;display:flex}.ledger-player-row{background:#1e293b4d;border:1px solid #ffffff08;border-radius:16px;justify-content:space-between;align-items:center;padding:12px 14px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.ledger-player-row:hover{background:#1e293b8c;border-color:#ffffff14;transform:translate(6px)}.ledger-player-row.human{background:#3b82f614;border-color:#3b82f640}.ledger-player-row.human:hover{background:#3b82f61f}.ledger-player-row.leader{border-color:#fbbf2459;box-shadow:0 0 12px #fbbf2414}.ledger-player-info{align-items:center;gap:10px;display:flex}.player-avatar{filter:drop-shadow(0 2px 4px #0000004d);font-size:1.25rem}.player-meta{flex-direction:column;display:flex}.ledger-player-row .player-name{color:#f1f5f9;font-size:.85rem;font-weight:700}.ledger-player-row.leader .player-name{color:#fbbf24}.player-status{color:#64748b;font-size:.65rem;font-weight:500}.ledger-player-row.human .player-status{color:#60a5fa}.ledger-player-coins{align-items:center;gap:4px;display:flex}.ledger-player-coins .coin-icon{filter:drop-shadow(0 1px 3px #fbbf2480);font-size:.95rem}.ledger-player-coins .coin-value{color:#f8fafc;font-size:1.05rem;font-weight:900}.ledger-player-row.leader .coin-value{color:#fbbf24;text-shadow:0 0 8px #fbbf244d}.ledger-footer{text-align:center;border-top:1px solid #ffffff0d;padding-top:14px}.ledger-footer .keyboard-shortcut{color:#475569;font-size:.7rem;font-weight:600}.ledger-footer .keyboard-shortcut kbd{color:#94a3b8;background:#ffffff14;border:1px solid #ffffff26;border-radius:3px;padding:1px 4px}.coin-animation-overlay{pointer-events:none;z-index:500;border-radius:50%;position:absolute;inset:0;overflow:hidden}.animated-coin{pointer-events:none;z-index:550;filter:drop-shadow(0 2px 8px #fbbf24b3)drop-shadow(0 0 4px #fbbf2466);opacity:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.6rem;animation:1.25s cubic-bezier(.25,1,.5,1) both flyCoin;display:flex;position:absolute}@keyframes flyCoin{0%{left:var(--from-x);top:var(--from-y);opacity:0;transform:translate(-50%,-50%)scale(.3)rotate(0)}15%{opacity:1;transform:translate(-50%,-50%)scale(1.4)rotate(90deg)}85%{opacity:1;transform:translate(-50%,-50%)scale(1.1)rotate(270deg)}to{left:var(--to-x);top:var(--to-y);opacity:0;transform:translate(-50%,-50%)scale(.4)rotate(360deg)}}.round-results-modal-overlay{-webkit-backdrop-filter:blur(16px);z-index:1000;box-sizing:border-box;background:#080a18c7;border-radius:50%;justify-content:center;align-items:center;padding:40px;display:flex;position:absolute;inset:-16px}.round-results-modal{background:#0f172ad9;border:2px solid #fbbf2459;border-radius:28px;flex-direction:column;align-items:stretch;width:86%;max-width:650px;padding:28px 32px;animation:.4s cubic-bezier(.34,1.56,.64,1) both modalScaleIn;display:flex;box-shadow:0 25px 60px #000000f2,inset 0 0 30px #fbbf240a,0 0 30px #fbbf2426}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.round-results-header{text-align:center}.round-results-header h2{color:#fbbf24;letter-spacing:.05em;text-shadow:0 0 15px #fbbf2466;margin:0;font-family:Outfit,Inter,system-ui,sans-serif;font-size:1.8rem;font-weight:900}.round-contract-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin:4px 0 0;font-size:.8rem;font-weight:700}.round-contract-label strong{color:#e2e8f0}.round-results-status{text-align:center;margin:12px 0}.badge-success{color:#34d399;letter-spacing:.1em;background:#10b9811f;border:1px solid #10b98166;border-radius:50px;padding:5px 16px;font-size:.85rem;font-weight:800;display:inline-block;box-shadow:0 0 15px #10b98133}.badge-failed{color:#f87171;letter-spacing:.1em;background:#ef44441f;border:1px solid #ef444466;border-radius:50px;padding:5px 16px;font-size:.85rem;font-weight:800;display:inline-block;box-shadow:0 0 15px #ef444433}.round-results-summary{text-align:center;color:#cbd5e1;max-width:520px;margin:8px auto 16px;font-size:.9rem;font-weight:500;line-height:1.45}.round-details-grid{grid-template-columns:1.15fr .85fr;gap:16px;margin:14px 0 20px;display:grid}.round-results-section{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;background:#0a0c1699;border:1px solid #ffffff0a;border-radius:20px;flex-direction:column;gap:10px;height:220px;padding:16px;display:flex;overflow-y:auto}.round-results-section::-webkit-scrollbar{width:4px}.round-results-section::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.round-results-section h4{color:#fbbf24;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid #ffffff0d;margin:0 0 4px;padding-bottom:6px;font-size:.8rem;font-weight:800}.transaction-list{flex-direction:column;gap:8px;display:flex}.transaction-row{background:#1e293b40;border:1px solid #ffffff05;border-left:3px solid #fbbf24;border-radius:12px;padding:8px 10px}.tx-details{color:#f1f5f9;flex-wrap:wrap;align-items:center;gap:3px;font-size:.78rem;font-weight:600;display:flex}.tx-arrow{color:#fbbf24;margin-right:2px;font-size:.65rem}.tx-amount{color:#34d399;font-weight:900}.tx-reason{color:#64748b;margin-top:3px;font-size:.68rem;font-style:italic;line-height:1.3}.no-transactions{color:#475569;text-align:center;padding:40px 0;font-size:.75rem;font-weight:600}.standings-list{flex-direction:column;gap:8px;display:flex}.standing-player-card{background:#1e293b40;border:1px solid #ffffff05;border-radius:14px;justify-content:space-between;align-items:center;padding:8px 12px;transition:all .2s;display:flex}.standing-player-card.human{background:#3b82f60f;border-color:#3b82f62e}.standing-player-card.leader{border-color:#fbbf2438}.standing-player-info{align-items:center;gap:6px;display:flex}.standing-avatar{font-size:.95rem}.standing-name{color:#e2e8f0;font-size:.72rem;font-weight:700}.standing-player-card.leader .standing-name{color:#fbbf24}.standing-player-score{align-items:center;gap:4px;font-size:.72rem;display:flex}.standing-prev{color:#475569;font-weight:500;text-decoration:line-through}.standing-arrow{color:#334155;font-size:.6rem}.standing-curr{color:#f8fafc;font-weight:800}.standing-player-card.leader .standing-curr{color:#fbbf24}.standing-delta{text-align:center;border-radius:6px;min-width:26px;padding:2px 5px;font-size:.65rem;font-weight:900}.standing-delta.positive{color:#34d399;background:#10b9811f}.standing-delta.negative{color:#f87171;background:#ef44441f}.round-results-actions{text-align:center;margin-top:10px}.btn-deal-next{color:#0f172a;cursor:pointer;background:linear-gradient(135deg,#fbbf24 0%,#d97706 100%);border:none;border-radius:14px;align-items:center;gap:8px;padding:11px 32px;font-family:Outfit,Inter,system-ui,sans-serif;font-size:.95rem;font-weight:800;transition:all .25s cubic-bezier(.25,.8,.25,1);display:inline-flex;box-shadow:0 4px 15px #fbbf2459,inset 0 1px #ffffff4d}.btn-deal-next:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 6px 20px #fbbf2480}.btn-deal-next:active{transform:translateY(0)}.sidebar-test-mode-container{background:#1e293b40;border:1px solid #3b82f626;border-radius:12px;flex-direction:column;gap:12px;padding:12px;display:flex;box-shadow:0 4px 20px #0000004d}.sidebar-section-header{color:#3b82f6;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid #3b82f633;margin-bottom:2px;padding-bottom:6px;font-size:.8rem;font-weight:800}.sidebar-bot-memory-box{background:#0f172a99;border:1px solid #ffffff0a;border-radius:10px;flex-direction:column;gap:8px;padding:10px;display:flex}.memory-owner-select{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding-bottom:6px;display:flex}.memory-owner-select .select-label{color:#94a3b8;font-size:.72rem;font-weight:700}.owner-tabs{gap:4px;display:flex}.owner-tab-btn{color:#94a3b8;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:4px;padding:2px 8px;font-family:inherit;font-size:.68rem;font-weight:700;transition:all .2s}.owner-tab-btn:hover{color:#fff;background:#3b82f626}.owner-tab-btn.active{color:#fff;background:#3b82f6;border-color:#60a5fa;box-shadow:0 0 10px #3b82f666}.memory-details-container{flex-direction:column;gap:6px;display:flex}.sidebar-bot-logic-dialogue{background:#0f172a99;border:1px solid #3b82f626;border-radius:10px;flex-direction:column;max-height:220px;padding:10px;display:flex;overflow:hidden}.sidebar-bot-logic-dialogue .dialogue-header{color:#fff;border-bottom:1px solid #3b82f626;align-items:center;gap:6px;padding:4px 0 8px;font-size:.72rem;font-weight:800;display:flex}.sidebar-bot-logic-dialogue .dialogue-body{flex-direction:column;flex:1;gap:6px;padding:8px 0 0;display:flex;overflow-y:auto}.sidebar-bot-logic-dialogue .dialogue-body::-webkit-scrollbar{width:4px}.sidebar-bot-logic-dialogue .dialogue-body::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.sidebar-bot-logic-dialogue .empty-thoughts-placeholder{color:#64748b;text-align:center;padding:10px 0;font-size:.7rem;font-style:italic}.sidebar-bot-logic-dialogue .thoughts-scroller{flex-direction:column;gap:8px;display:flex}.sidebar-bot-logic-dialogue .thought-cycle-card{background:#1e293b66;border:1px solid #ffffff0a;border-radius:6px;padding:6px}.sidebar-bot-logic-dialogue .thought-cycle-header{color:#94a3b8;border-bottom:1px dashed #ffffff0a;justify-content:space-between;align-items:center;margin-bottom:4px;padding-bottom:3px;font-size:.68rem;font-weight:700;display:flex}.sidebar-bot-logic-dialogue .bot-name{color:#60a5fa}.sidebar-bot-logic-dialogue .played-card-badge{color:#cbd5e1;font-size:.62rem}.sidebar-bot-logic-dialogue .thought-steps{flex-direction:column;gap:2px;display:flex}.sidebar-bot-logic-dialogue .thought-step-line{color:#cbd5e1;font-size:.64rem;line-height:1.3}.sidebar-bot-logic-dialogue .thought-step-line .arrow{color:#3b82f6;margin-right:2px;font-weight:800}.player-bid-badge-inline{vertical-align:middle;text-transform:uppercase;letter-spacing:.5px;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:.65rem;font-weight:800;animation:.3s cubic-bezier(.34,1.56,.64,1) modalScaleIn;display:inline-block}.player-bid-badge-inline.declarer{border:1px solid var(--gold-accent);color:var(--gold-accent);background:#f59e0b26;box-shadow:0 0 8px #f59e0b33}.player-bid-badge-inline.partner{color:#93c5fd;background:#3b82f626;border:1px solid #60a5fa;box-shadow:0 0 8px #3b82f633}.btn-auto-play-inline{color:#e2e8f0;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;border:1px solid #fff3;border-radius:6px;align-items:center;gap:4px;margin-left:10px;padding:2px 8px;font-size:.68rem;font-weight:700;transition:all .2s;display:inline-flex}.btn-auto-play-inline:hover{color:#00e5ff;background:#00e5ff2e;border-color:#00e5ff73;transform:translateY(-1px);box-shadow:0 0 8px #00e5ff40}.btn-auto-play-inline:active{transform:translateY(0)}@media (width<=1024px){body{width:100%;height:100%;position:fixed;overflow:hidden}#root,.app-container{width:100%;height:100%;overflow:hidden}.main-content{width:100%;height:100%;padding-bottom:120px}.table-board-container{align-items:flex-start;height:calc(100% - 70px);margin-top:0;padding:0 10px}.game-board-felt{transform-origin:top;border-width:8px!important;box-shadow:0 5px 25px #0009!important}.sidebar{z-index:300;visibility:hidden;background:#0a0f1ef2;border-right:1px solid #ffffff14;flex-direction:column;width:290px;min-width:290px;height:100vh;padding:16px;transition:left .3s cubic-bezier(.25,.8,.25,1),visibility .3s;display:flex;position:fixed;top:0;bottom:0;left:-320px;box-shadow:15px 0 40px #000c}.sidebar.mobile-open{visibility:visible;left:0}.sidebar-backdrop{-webkit-backdrop-filter:blur(5px);z-index:299;background:#0009;animation:.25s ease-out fadeIn;position:fixed;inset:0}.main-header{z-index:200;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:12px 16px;display:flex}.message-box{white-space:nowrap;text-overflow:ellipsis;border-radius:16px;max-width:60%;padding:6px 16px;font-size:.9rem;overflow:hidden}.mobile-menu-toggle{color:#f8fafc;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ad9;border:1px solid #ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;padding:0;font-size:1.35rem;line-height:1;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 12px #0000004d}.mobile-menu-toggle:active{background:#1e293bf2;border-color:#ffffff40;transform:scale(.92)}.player-bottom .hand-horizontal{display:none!important}.player-bottom{bottom:160px!important}.mobile-hand-dock{padding:10px 8px env(safe-area-inset-bottom,24px) 8px;-webkit-backdrop-filter:blur(14px);z-index:180;background:linear-gradient(#090d1700 0%,#090d17cc 15%,#090d17f2 50%,#090d17fa 100%);border-top:1px solid #ffffff0f;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 30px #000000b3}.mobile-hand-cards{scrollbar-width:none;-webkit-overflow-scrolling:touch;justify-content:center;align-items:flex-end;width:100%;margin-top:-30px;padding:40px 10px 10px;display:flex;overflow:auto visible}.mobile-hand-cards::-webkit-scrollbar{display:none}.mobile-hand-cards .playing-card{flex-shrink:0;width:68px;height:98px;margin-left:-32px;padding:5px;font-size:.95rem;transition:transform .2s cubic-bezier(.175,.885,.32,1.25),box-shadow .2s;box-shadow:-4px 0 10px #0000004d,0 4px 8px #0000004d}.mobile-hand-cards .playing-card:first-child{margin-left:0}.mobile-hand-cards .playing-card:hover{transform:none}.playing-card.selected-mobile-card{animation:.2s cubic-bezier(.175,.885,.32,1.275) bounceCard;z-index:250!important;border:1.5px solid var(--gold-accent)!important;transform:translateY(-38px)scale(1.22)!important;box-shadow:0 12px 28px #f59e0b73,0 0 20px #f59e0b4d,-8px 0 15px #0006!important}@keyframes bounceCard{0%{transform:translateY(0)scale(1)}to{transform:translateY(-38px)scale(1.22)}}.mobile-confirm-play-container{flex-direction:column;align-items:center;gap:4px;width:100%;margin-top:-10px;animation:.25s cubic-bezier(.175,.885,.32,1.275) forwards slideConfirmUp;display:flex}@keyframes slideConfirmUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.mobile-confirm-btn{color:#fff;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:1px solid #ffffff40;border-radius:9999px;width:auto;padding:8px 30px;font-size:.9rem;font-weight:700;box-shadow:0 4px 15px #10b98166,inset 0 2px 4px #fff3}.mobile-swipe-hint{color:#fff6;text-transform:uppercase;letter-spacing:1.2px;text-align:center;font-size:.65rem}.bidding-overlay,.selection-overlay{bottom:calc(115px + env(safe-area-inset-bottom,24px));z-index:220;background:#0d1321f2;border:1px solid #ffffff14;border-radius:20px;width:92%;max-height:80vh;padding:20px 14px;animation:.32s cubic-bezier(.25,.8,.25,1) forwards slideUpBottom;position:fixed;top:auto;left:4%;right:4%;box-shadow:0 10px 40px #000000d9;transform:none!important}@keyframes slideUpBottom{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.bidding-overlay h2,.selection-overlay h2{text-shadow:0 0 10px #ffffff26;margin-bottom:8px;font-size:1.25rem}.subtitle{margin-bottom:12px;font-size:.82rem}.bidding-status{margin-bottom:12px;padding:6px 12px;font-size:.8rem}.bids-history-grid{grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:14px}.player-bid-status{border-radius:8px;padding:6px 4px}.player-bid-status .p-name{font-size:.65rem}.player-bid-status .p-bid{margin-top:2px;font-size:.8rem}.human-bidding-panel{padding-top:12px}.human-bidding-panel h3{margin-bottom:8px;font-size:.85rem}.troela-alert{margin-bottom:8px;padding:6px;font-size:.78rem}.bidding-buttons-grid{gap:6px;grid-template-columns:repeat(3,1fr)!important}.btn-bid{border-radius:10px;justify-content:center;align-items:center;height:42px;padding:10px 4px;font-size:.78rem;display:flex}.btn-bid.pass-btn{grid-column:span 3;margin-top:2px}.selection-columns{flex-direction:column;gap:12px;width:100%;max-height:40vh;margin-bottom:12px;display:flex;overflow-y:auto}.selection-card{border-radius:14px;padding:10px}.selection-card h3{margin-bottom:6px;font-size:.85rem}.trump-suits-buttons{gap:6px;grid-template-columns:repeat(4,1fr)!important}.btn-suit{border-radius:8px!important;flex-direction:column!important;gap:2px!important;padding:8px 4px!important;font-size:.72rem!important}.btn-suit .suit-sym{font-size:1.1rem!important}.partner-cards-list{gap:8px}.partner-card-select-btn{padding:4px}.partner-card-select-btn .playing-card{width:50px!important;height:70px!important;padding:4px!important;font-size:.8rem!important}.btn-confirm{margin-top:10px;padding:10px;font-size:.9rem}.fixed-trump-banner{padding:6px;font-size:.8rem}.select-trump-prompt{padding:10px;font-size:.8rem}.carrying-score-ledger{z-index:290;width:280px}.score-hint-pill{display:none!important}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseGlow{0%,to{opacity:.4;text-shadow:0 0 2px #ffffff1a}50%{opacity:.85;text-shadow:0 0 8px #fff6}}.setup-container{color:#f8fafc;z-index:1;background-color:#08090b;background-image:radial-gradient(circle at 15% 20%,#05ffa10b 0%,#0000 45%),radial-gradient(circle at 85% 80%,#d4af370e 0%,#0000 45%);flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;padding:32px 24px;font-family:Outfit,sans-serif;display:flex;position:relative;overflow:hidden auto}.bg-decorative-cards{pointer-events:none;z-index:-1;width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden}.floating-card{filter:blur(5px);opacity:.14;background:#ffffff03;border:1.5px solid #ffffff06;border-radius:24px;justify-content:center;align-items:center;width:180px;height:260px;animation:28s ease-in-out infinite alternate floatCard;display:flex;position:absolute;box-shadow:inset 0 0 20px #ffffff05,0 15px 35px #0009}.floating-card .suit-symbol{color:#ffffff12;font-size:6rem;font-weight:800}.card-spade{--r:-15deg;border-color:#05ffa112;animation-delay:0s;top:12%;left:8%;transform:rotate(-15deg);box-shadow:0 0 50px #05ffa108}.card-heart{--r:20deg;border-color:#d4af3712;animation-delay:-7s;bottom:10%;left:12%;transform:rotate(20deg);box-shadow:0 0 50px #d4af3708}.card-diamond{--r:25deg;border-color:#d4af3712;animation-delay:-14s;top:8%;right:10%;transform:rotate(25deg);box-shadow:0 0 50px #d4af3708}.card-club{--r:-25deg;border-color:#05ffa112;animation-delay:-21s;bottom:12%;right:6%;transform:rotate(-25deg);box-shadow:0 0 50px #05ffa108}@keyframes floatCard{0%{transform:translateY(0) rotate(var(--r,12deg)) scale(1)}50%{transform:translateY(-28px) rotate(calc(var(--r,12deg) + 8deg)) scale(1.03)}to{transform:translateY(0) rotate(var(--r,12deg)) scale(1)}}.setup-header{text-align:center;z-index:2;margin-bottom:44px}.main-logo-text{letter-spacing:14px;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;margin-bottom:8px;font-size:4rem;font-weight:900;display:flex}.logo-part-gold{background:linear-gradient(135deg,#fff3c3 0%,#d4af37 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 12px #d4af3740);-webkit-background-clip:text}.logo-part-green{background:linear-gradient(135deg,#ccffdb 0%,#05ffa1 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 12px #05ffa140);-webkit-background-clip:text}.setup-subtitle{color:#94a3b8;letter-spacing:6px;text-transform:uppercase;-webkit-user-select:none;user-select:none;font-size:.82rem;font-weight:600}.menu-container{z-index:2;flex-direction:column;align-items:center;gap:36px;width:100%;max-width:820px;display:flex}.nickname-pill-container{flex-direction:column;align-items:center;gap:12px;width:100%;max-width:420px;display:flex}.nickname-pill-label{color:#ffffff59;letter-spacing:3px;text-transform:uppercase;font-size:.72rem;font-weight:800}.nickname-input-wrapper{width:100%;position:relative}.nickname-input-wrapper input{color:#f8fafc;text-align:center;letter-spacing:2px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0e111699;border:1px solid #ffffff0d;border-radius:9999px;outline:none;width:100%;padding:15px 30px;font-family:inherit;font-size:1.05rem;font-weight:600;transition:all .3s;box-shadow:inset 0 4px 12px #00000080}.nickname-input-wrapper input:focus{background:#0e1116cc;border-color:#ffffff1f;box-shadow:inset 0 4px 12px #0009,0 0 25px #ffffff09}.nickname-input-wrapper input::placeholder{color:#fff3;letter-spacing:2px}.input-glow-bar{pointer-events:none;background:linear-gradient(90deg,#0000,#05ffa166,#d4af3766,#0000);width:40%;height:1.5px;transition:all .3s;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.nickname-input-wrapper input:focus~.input-glow-bar{width:75%}.setup-modes-grid{grid-template-columns:repeat(3,1fr);gap:32px;width:100%;display:grid}.mode-glass-card{text-align:center;cursor:pointer;-webkit-backdrop-filter:blur(25px);background:#11131773;border:1px solid #ffffff0a;border-radius:28px;flex-direction:column;align-items:center;padding:48px 36px;transition:all .4s cubic-bezier(.25,1,.5,1);display:flex;position:relative;overflow:hidden;box-shadow:0 30px 60px -15px #0009,inset 0 1px #ffffff0a}.card-ambient-glow{pointer-events:none;opacity:0;z-index:0;width:200%;height:200%;transition:opacity .6s;position:absolute;top:-50%;left:-50%}.offline-card .card-ambient-glow{background:radial-gradient(circle,#05ffa111 0%,#0000 60%)}.multiplayer-card .card-ambient-glow{background:radial-gradient(circle,#d4af3711 0%,#0000 60%)}.local-card .card-ambient-glow{background:radial-gradient(circle,#06b6d411 0%,#0000 60%)}.mode-glass-card:hover{background:#14171c99;transform:translateY(-8px)}.mode-glass-card:hover .card-ambient-glow{opacity:1}.offline-card:hover{border-color:#05ffa140;box-shadow:0 30px 60px -15px #000000b3,0 0 35px #05ffa11f,inset 0 1px #ffffff0d}.multiplayer-card:hover{border-color:#d4af3740;box-shadow:0 30px 60px -15px #000000b3,0 0 35px #d4af371f,inset 0 1px #ffffff0d}.local-card:hover{border-color:#06b6d440;box-shadow:0 30px 60px -15px #000000b3,0 0 35px #06b6d41f,inset 0 1px #ffffff0d}.card-badge{z-index:1;letter-spacing:2px;-webkit-user-select:none;user-select:none;border:1px solid;border-radius:999px;margin-bottom:24px;padding:6px 16px;font-size:.65rem;font-weight:800;position:relative}.offline-card .card-badge{color:#05ffa1;background:#05ffa10d;border-color:#05ffa126}.multiplayer-card .card-badge{color:#f59e0b;background:#f59e0b0d;border-color:#f59e0b26}.local-card .card-badge{color:#06b6d4;background:#06b6d40d;border-color:#06b6d426}.card-icon{z-index:1;filter:drop-shadow(0 8px 16px #0000004d);-webkit-user-select:none;user-select:none;margin-bottom:20px;font-size:3.5rem;transition:transform .4s;position:relative}.mode-glass-card:hover .card-icon{transform:scale(1.1)}.card-title{z-index:1;color:#fff;letter-spacing:.5px;-webkit-user-select:none;user-select:none;margin-bottom:12px;font-size:1.7rem;font-weight:700;position:relative}.card-desc{z-index:1;color:#94a3b8;flex-grow:1;margin-bottom:32px;font-size:.9rem;line-height:1.6;position:relative}.card-action-btn{z-index:1;letter-spacing:2px;-webkit-user-select:none;user-select:none;border:1px solid;border-radius:14px;justify-content:center;align-items:center;gap:12px;width:100%;padding:14px 28px;font-size:.8rem;font-weight:800;transition:all .3s;display:flex;position:relative}.offline-card .card-action-btn{color:#08090b;background:#05ffa1;border-color:#05ffa1;box-shadow:0 4px 14px #05ffa140}.offline-card:hover .card-action-btn{background:#00ff8c;box-shadow:0 6px 20px #05ffa173}.multiplayer-card .card-action-btn{color:#08090b;background:gold;border-color:gold;box-shadow:0 4px 14px #d4af3740}.multiplayer-card:hover .card-action-btn{background:#ffdf33;box-shadow:0 6px 20px #d4af3773}.local-card .card-action-btn{color:#08090b;background:#06b6d4;border-color:#06b6d4;box-shadow:0 4px 14px #06b6d440}.local-card:hover .card-action-btn{background:#22d3ee;box-shadow:0 6px 20px #06b6d473}.arrow-icon{font-size:1.1rem;line-height:1;transition:transform .3s}.mode-glass-card:hover .arrow-icon{transform:translate(4px)}.back-navigation-pill{color:#cbd5e1;letter-spacing:2px;cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff08;border:1px solid #ffffff0f;border-radius:9999px;align-self:flex-start;align-items:center;gap:8px;padding:10px 24px;font-family:inherit;font-size:.72rem;font-weight:800;transition:all .3s;display:flex;box-shadow:0 4px 12px #0003}.back-navigation-pill:hover{color:#fff;background:#ffffff14;transform:translate(-4px)}.multiplayer-submenu-grid{grid-template-columns:1fr 1fr;gap:32px;width:100%;display:grid}.submenu-glass-panel{-webkit-backdrop-filter:blur(25px);background:#11131773;border:1px solid #ffffff0a;border-radius:28px;flex-direction:column;padding:40px;display:flex;box-shadow:0 30px 60px -15px #0009,inset 0 1px #ffffff0a}.panel-header{align-items:center;gap:16px;margin-bottom:18px;display:flex}.panel-number{color:#ffffff26;-webkit-user-select:none;user-select:none;border-bottom:2px solid;padding-bottom:4px;font-size:1rem;font-weight:900}.host-panel .panel-number{color:#05ffa140;border-color:#05ffa1}.join-panel .panel-number{color:#d4af3740;border-color:gold}.panel-header h3{color:#fff;font-size:1.35rem;font-weight:700}.panel-desc{color:#94a3b8;flex-grow:1;margin-bottom:36px;font-size:.85rem;line-height:1.6}.btn-menu-host{color:#05ffa1;letter-spacing:2px;cursor:pointer;text-transform:uppercase;-webkit-user-select:none;user-select:none;background:#05ffa108;border:1.5px solid #05ffa133;border-radius:14px;width:100%;padding:16px;font-family:inherit;font-size:.85rem;font-weight:800;transition:all .3s cubic-bezier(.25,1,.5,1)}.btn-menu-host:hover{color:#08090b;background:#05ffa1;border-color:#05ffa1;transform:translateY(-2px);box-shadow:0 0 25px #05ffa159}.join-controls-wrapper{gap:12px;width:100%;display:flex}.join-controls-wrapper input{color:#fff;text-align:center;letter-spacing:4px;background:#0e111680;border:1px solid #ffffff0d;border-radius:12px;outline:none;width:115px;padding:14px;font-family:inherit;font-size:1.05rem;font-weight:700;transition:all .3s}.join-controls-wrapper input:focus{background:#0e1116cc;border-color:#d4af3759;box-shadow:0 0 20px #d4af3714}.join-controls-wrapper input::placeholder{color:#ffffff26;letter-spacing:1px}.btn-menu-join{color:gold;letter-spacing:2px;cursor:pointer;-webkit-user-select:none;user-select:none;background:#d4af3708;border:1.5px solid #d4af3733;border-radius:12px;flex:1;padding:14px;font-family:inherit;font-size:.85rem;font-weight:800;transition:all .3s cubic-bezier(.25,1,.5,1)}.btn-menu-join:hover:not(:disabled){color:#08090b;background:gold;border-color:gold;transform:translateY(-2px);box-shadow:0 0 25px #d4af3759}.btn-menu-join:disabled{opacity:.3;cursor:not-allowed}.error-spacing{width:100%;margin-top:16px}@media (width<=820px){.setup-modes-grid,.multiplayer-submenu-grid{grid-template-columns:1fr;gap:24px}.main-logo-text{letter-spacing:8px;font-size:2.8rem}.mode-glass-card{padding:36px 24px}.submenu-glass-panel{padding:28px}.floating-card{width:130px;height:190px}.floating-card .suit-symbol{font-size:4rem}}.lobby-card{flex-direction:column;gap:36px;width:100%;max-width:900px;padding:40px;display:flex}.lobby-room-code-section{text-align:center;background:#00000040;border:1px dashed #ffffff0f;border-radius:20px;flex-direction:column;align-items:center;padding:20px;display:flex}.code-label{color:var(--text-secondary);letter-spacing:2px;margin-bottom:10px;font-size:.8rem;font-weight:700}.code-badge-container{align-items:center;gap:12px;margin-bottom:12px;display:flex}.code-badge{letter-spacing:6px;color:var(--gold-accent);text-shadow:0 0 10px #f59e0b4d;background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:12px;padding:6px 20px;font-size:2.2rem;font-weight:900}.btn-copy{background:#ffffff0d!important;border:1px solid #ffffff1a!important;padding:8px 16px!important;font-size:.85rem!important}.btn-copy:hover{background:#ffffff1a!important}.code-hint{color:var(--text-secondary);font-size:.85rem}.lobby-seating-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.lobby-seat-card{text-align:center;border:1px solid #ffffff0d;border-radius:18px;flex-direction:column;gap:16px;padding:20px;transition:all .3s;display:flex}.lobby-seat-card.empty{background:#0f172a33;border-style:dashed}.lobby-seat-card.occupied{background:#1e293b66;border-color:#ffffff1a;box-shadow:0 4px 20px #00000040}.lobby-seat-card.you{background:#3b82f614;border-color:#60a5fa66}.seat-status-header{justify-content:space-between;align-items:center;display:flex}.seat-number{color:var(--text-secondary);letter-spacing:.5px;font-size:.75rem;font-weight:700}.host-badge{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:800}.you-badge{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:800}.seat-body{flex-direction:column;align-items:center;gap:8px;padding:12px 0;display:flex}.seat-body .player-icon{font-size:2.2rem}.seat-body .player-icon.pulsing{opacity:.6;animation:2s ease-in-out infinite pulseAvatar}@keyframes pulseAvatar{0%{opacity:.4;transform:scale(1)}50%{opacity:.75;transform:scale(1.1)}to{opacity:.4;transform:scale(1)}}.player-name-text{color:#fff;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:1.1rem;font-weight:700;overflow:hidden}.player-name-text.empty-placeholder{color:var(--text-secondary);font-style:italic;font-weight:500}.status-sub{color:var(--text-secondary);font-size:.75rem}.lobby-footer{border-top:1px solid #ffffff14;justify-content:space-between;align-items:center;padding-top:24px;display:flex}.btn-leave{color:#fca5a5!important;background:#ef444426!important;border:1px solid #ef44444d!important}.btn-leave:hover{color:#fff!important;background:#ef4444!important}.btn-start-match{padding:12px 36px!important;font-size:1.1rem!important}.waiting-for-host{color:var(--text-secondary);align-items:center;gap:12px;font-size:.95rem;display:flex}.spinner{border:2px solid #ffffff1a;border-top-color:#60a5fa;border-radius:50%;width:20px;height:20px;animation:1s linear infinite spin}.connection-error{color:#fca5a5;text-align:center;background:#ef44441f;border:1px solid #ef44444d;border-radius:12px;padding:12px;font-size:.9rem}.turn-timer-badge{color:#fff;white-space:nowrap;background:linear-gradient(135deg,#ef4444 0%,#b91c1c 100%);border:1.5px solid #ffffff40;border-radius:10px;align-items:center;gap:4px;margin-bottom:6px;padding:2px 8px;font-size:.72rem;font-weight:800;animation:.5s ease-in-out infinite alternate pulseTimer;display:inline-flex;position:absolute;top:-16px;left:50%;transform:translate(-50%);box-shadow:0 0 12px #ef444499}@keyframes pulseTimer{0%{transform:translate(-50%)scale(.96);box-shadow:0 0 4px #ef444466}to{transform:translate(-50%)scale(1.05);box-shadow:0 0 16px #ef4444d9}}.player-info-badge{margin-top:8px;position:relative}.animate-fade-in{animation:.4s ease-out forwards fadeIn}.btn-confirm.animate-pulse{animation:2s infinite pulseGreenButton}@keyframes pulseGreenButton{0%{box-shadow:0 0 #10b981b3}70%{box-shadow:0 0 0 12px #10b98100}to{box-shadow:0 0 #10b98100}}.btn-setup-settings{color:#94a3b8;letter-spacing:2px;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;border:1px solid #ffffff14;border-radius:9999px;margin-top:16px;padding:8px 20px;font-family:inherit;font-size:.75rem;font-weight:700;transition:all .3s}.btn-setup-settings:hover{color:gold;background:#d4af370f;border-color:#d4af374d;transform:translateY(-2px);box-shadow:0 4px 15px #d4af371a}.btn-sidebar-options{color:#94a3b8;cursor:pointer;background:#ffffff05;border:1px solid #ffffff0f;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:.8rem;font-weight:600;transition:all .3s}.btn-sidebar-options:hover{color:#fff;background:#ffffff0f;border-color:#ffffff26}.options-modal-overlay{-webkit-backdrop-filter:blur(15px);z-index:2000;background:#08090bb3;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.3s ease-out modalOverlayFade;display:flex;position:fixed;top:0;left:0}.options-modal-content{border-radius:28px;width:100%;max-width:520px;padding:36px;animation:.3s cubic-bezier(.34,1.56,.64,1) modalScaleIn;background:#121418d9!important;border:1.5px solid #d4af372e!important;box-shadow:0 25px 60px #000c!important}@keyframes modalOverlayFade{0%{opacity:0}to{opacity:1}}.options-modal-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:20px;display:flex}.options-modal-header h2{color:#fff;font-size:1.4rem;font-weight:800}.btn-close-options{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:4px;font-size:2rem;line-height:1;transition:color .2s}.btn-close-options:hover{color:#fff}.options-modal-body{flex-direction:column;gap:24px;display:flex}.option-row{border-bottom:1.5px solid #ffffff08;justify-content:space-between;align-items:center;gap:20px;padding-bottom:20px;display:flex}.option-row:last-child{border-bottom:none;padding-bottom:0}.option-info{flex-direction:column;flex:1;gap:6px;display:flex}.option-label{color:#fff;font-size:1rem;font-weight:700}.option-desc{color:#94a3b8;font-size:.8rem;line-height:1.5}.switch{flex-shrink:0;width:50px;height:28px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#ffffff14;border:1px solid #ffffff14;border-radius:34px;transition:all .3s;position:absolute;inset:0}.slider:before{content:"";background-color:#f8fafc;border-radius:50%;width:20px;height:20px;transition:all .3s;position:absolute;bottom:3px;left:3px;box-shadow:0 2px 4px #0006}input:checked+.slider{background-color:#05ffa126;border-color:#05ffa166}input:checked+.slider:before{background-color:#05ffa1;transform:translate(22px);box-shadow:0 0 10px #05ffa166}.options-modal-footer{border-top:1px solid #ffffff0f;justify-content:flex-end;margin-top:28px;padding-top:20px;display:flex}.last-trick-pill{-webkit-backdrop-filter:blur(12px);color:#cbd5e1;letter-spacing:1.5px;cursor:pointer;z-index:100;background:#0e1116b3;border:1px solid #ffffff14;border-radius:9999px;align-items:center;gap:8px;padding:10px 24px;font-family:inherit;font-size:.75rem;font-weight:800;transition:all .3s cubic-bezier(.25,1,.5,1);display:inline-flex;position:fixed;bottom:24px;right:344px;box-shadow:0 10px 30px #00000080,inset 0 1px #ffffff0a}.last-trick-pill:hover{color:#fff;background:#14171cd9;border-color:#fff3;transform:translateY(-3px);box-shadow:0 15px 35px #0009,0 0 15px #ffffff0d}.last-trick-overlay-container{-webkit-backdrop-filter:blur(12px);z-index:1500;background:#08090b99;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.3s ease-out modalOverlayFade;display:flex;position:fixed;top:0;left:0}.last-trick-modal-content{border-radius:28px;width:100%;max-width:580px;padding:36px;animation:.3s cubic-bezier(.34,1.56,.64,1) modalScaleIn;background:#0e1116d9!important;border:1.5px solid #ffffff14!important;box-shadow:0 25px 60px #000c!important}.last-trick-modal-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.last-trick-modal-header h3{color:#fff;font-size:1.25rem;font-weight:800}.btn-close-last-trick{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:4px;font-size:1.8rem;line-height:1;transition:color .2s}.btn-close-last-trick:hover{color:#fff}.last-trick-cards-grid{grid-template-columns:repeat(4,1fr);justify-items:center;gap:16px;width:100%;display:grid}.last-trick-card-box{background:#ffffff05;border:1px solid #ffffff0a;border-radius:16px;flex-direction:column;align-items:center;gap:12px;width:100%;padding:16px;transition:all .3s;display:flex}.last-trick-card-box.winner-glow{background:#d4af370a;border-color:#d4af3759;box-shadow:0 0 20px #d4af3714,inset 0 0 10px #d4af3708}.last-trick-player-name{color:#cbd5e1;text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.8rem;font-weight:700;overflow:hidden}.winner-glow .last-trick-player-name{color:gold;text-shadow:0 0 10px #d4af374d}.last-trick-card-box .playing-card{cursor:default!important;width:66px!important;height:96px!important;padding:4px!important;font-size:.95rem!important}.last-trick-card-box .playing-card:hover{transform:none!important;box-shadow:0 4px 10px #0006!important}@media (width<=1024px){.last-trick-pill{bottom:16px;right:16px}}.diagnostic-console{text-align:left;box-sizing:border-box;background:#0a0f14f2;border:1px dashed #06b6d466;border-radius:12px;width:100%;max-height:250px;margin-top:24px;padding:16px;font-family:Courier New,Courier,monospace;overflow-y:auto;box-shadow:0 4px 20px #06b6d426}.console-header{border-bottom:1px solid #06b6d440;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;display:flex}.console-title{color:#06b6d4;letter-spacing:.1em;align-items:center;gap:8px;font-size:.85rem;font-weight:700;display:flex}.console-title:before{content:"";background-color:#22c55e;border-radius:50%;width:8px;height:8px;animation:1.5s infinite alternate pulse-green;display:inline-block}@keyframes pulse-green{0%{transform:scale(.85);box-shadow:0 0 #22c55eb3}to{transform:scale(1.15);box-shadow:0 0 8px 2px #22c55eb3}}.console-btn-clear{color:#06b6d4;cursor:pointer;background:0 0;border:1px solid #06b6d466;border-radius:6px;padding:4px 8px;font-size:.75rem;transition:all .2s}.console-btn-clear:hover{background:#06b6d41a;border-color:#06b6d4}.console-logs{color:#a5f3fc;font-size:.78rem;line-height:1.4}.console-log-entry{word-break:break-all;margin-bottom:6px}.console-log-entry.error{color:#fca5a5}.console-log-entry.success{color:#4ade80}.console-log-entry.info{color:#38bdf8}
