@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&display=swap";#root{width:100%;min-height:100vh}body{margin:0}.lobby{background:radial-gradient(#151530 0%,#080810 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.lobby-card{background:#12122a;border:1px solid #2a2a50;border-radius:24px;width:100%;max-width:420px;padding:32px;font-family:Nunito,Segoe UI,sans-serif;box-shadow:0 16px 48px #00000080}.lobby-title{text-align:center;color:#fbbf24;text-shadow:0 0 30px #fbbf244d;justify-content:center;align-items:center;gap:8px;margin-bottom:4px;font-size:2em;font-weight:900;display:flex}.lobby-logo{border-radius:.25em;width:1.4em;height:1.4em}.lobby-subtitle{text-align:center;color:#94a3b8;margin-bottom:24px;font-size:.9em}.lobby-field{margin-bottom:12px}.lobby-field label{color:#94a3b8;margin-bottom:4px;font-size:.85em;font-weight:700;display:block}.lobby-field input,.lobby-field select{box-sizing:border-box;color:#e2e8f0;background:#1a1a3a;border:2px solid #2a2a50;border-radius:12px;width:100%;padding:10px 14px;font-family:Nunito,Segoe UI,sans-serif;font-size:1em;transition:border-color .15s}.lobby-field input:focus,.lobby-field select:focus{border-color:#fbbf24;outline:none}.lobby-error{color:#f87171;text-align:center;margin-bottom:8px;font-size:.85em;font-weight:700}.lobby-section{margin-bottom:16px}.lobby-section-title{color:#e2e8f0;margin-bottom:8px;font-size:.95em;font-weight:800}.lobby-toggle{margin-bottom:12px}.lobby-toggle label{color:#94a3b8;cursor:pointer;align-items:center;gap:8px;font-size:.9em;font-weight:600;display:flex}.lobby-toggle input[type=checkbox]{accent-color:#fbbf24;width:18px;height:18px}.lobby-btn{cursor:pointer;border:none;border-radius:14px;width:100%;padding:12px;font-family:Nunito,Segoe UI,sans-serif;font-size:1em;font-weight:800;transition:all .15s}.lobby-btn-create{color:#1a1a2e;background:linear-gradient(135deg,#b45309 0%,#d97706 50%,#f59e0b 100%);box-shadow:0 4px 16px #f59e0b4d}.lobby-btn-create:hover{transform:translateY(-2px);box-shadow:0 6px 24px #f59e0b80}.lobby-btn-join{color:#fff;background:linear-gradient(135deg,#065f46 0%,#059669 100%);box-shadow:0 4px 12px #0596694d}.lobby-btn-join:hover{transform:translateY(-2px);box-shadow:0 6px 16px #05966966}.lobby-divider{text-align:center;color:#4a4a6a;margin:16px 0;font-size:.85em;font-weight:700;position:relative}.lobby-divider:before,.lobby-divider:after{content:"";background:#2a2a50;width:40%;height:1px;position:absolute;top:50%}.lobby-divider:before{left:0}.lobby-divider:after{right:0}.lobby-sections-row{display:contents}.lobby-divider-vertical{display:none}.lobby-auth-section{margin-bottom:16px}.lobby-google-btn{justify-content:center;margin-bottom:8px;display:flex}.lobby-auth-info{background:#1a1a3a;border:1px solid #2a2a50;border-radius:12px;align-items:center;gap:10px;margin-bottom:16px;padding:10px 12px;display:flex}.lobby-avatar{border:2px solid #fbbf24;border-radius:50%;width:36px;height:36px}.lobby-auth-details{flex:1;min-width:0}.lobby-auth-name{color:#e2e8f0;text-overflow:ellipsis;white-space:nowrap;font-size:.9em;font-weight:800;overflow:hidden}.lobby-auth-email{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;font-size:.75em;overflow:hidden}.lobby-auth-logout{color:#94a3b8;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #4a4a6a;border-radius:8px;padding:4px 10px;font-family:Nunito,Segoe UI,sans-serif;font-size:.75em;font-weight:700;transition:all .15s}.lobby-auth-logout:hover{color:#f87171;border-color:#f87171}.lobby-auth-loading{text-align:center;color:#94a3b8;margin-bottom:8px;font-size:.85em}.lobby-signin-gate{text-align:center}.lobby-signin-prompt{color:#e2e8f0;margin-bottom:16px;font-size:1.1em;font-weight:800}.dev-login{width:100%;max-width:300px;margin-top:12px}.dev-login-divider{text-align:center;color:#64748b;margin-bottom:10px;font-size:.85em}.dev-login-row{gap:8px;display:flex}.dev-login-row input{color:#e2e8f0;background:#ffffff0f;border:1px solid #334155;border-radius:10px;outline:none;flex:1;padding:10px 12px;font-family:Nunito,Segoe UI,sans-serif;font-size:.95em}.dev-login-row input:focus{border-color:#f59e0b}.dev-login-row .lobby-btn{white-space:nowrap;padding:10px 16px}.mygames-drawer{z-index:200;background:#0c0c1ef7;border-right:1px solid #2a2a50;flex-direction:column;width:300px;height:100vh;font-family:Nunito,Segoe UI,sans-serif;transition:transform .3s;display:flex;position:fixed;top:0;left:0;overflow:visible;transform:translate(0);box-shadow:4px 0 30px #0009}.mygames-drawer-collapsed{transform:translate(-300px)}.mygames-tab{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;-webkit-user-select:none;user-select:none;z-index:201;background:linear-gradient(#7c3aed59 0%,#8b5cf659 100%);border-radius:0 12px 12px 0;justify-content:center;align-items:center;width:48px;height:160px;transition:background .15s;display:flex;position:absolute;top:50%;right:-48px;overflow:hidden;transform:translateY(-50%);box-shadow:4px 0 16px #0006}.mygames-tab:hover{background:linear-gradient(#8b5cf68c 0%,#a78bfa8c 100%)}.mygames-tab-icon{writing-mode:vertical-rl;text-orientation:mixed;color:#c4b5fd;letter-spacing:1.5px;white-space:nowrap;font-size:.75em;font-weight:800}.mygames-header{color:#c4b5fd;text-shadow:0 0 20px #8b5cf64d;border-bottom:1px solid #2a2a50;padding:20px 20px 12px;font-size:1.1em;font-weight:900}.mygames-list{flex-direction:column;flex:1;gap:8px;padding:12px 14px;display:flex;overflow:hidden auto}.mygames-backdrop{z-index:199;background:#0006;position:fixed;inset:0}.lobby-game-card{box-sizing:border-box;background:#1a1a3a;border:1px solid #2a2a50;border-radius:12px;align-items:center;gap:10px;max-width:100%;padding:10px 12px;transition:border-color .15s;display:flex}.lobby-game-card:hover{border-color:#fbbf24}.lobby-game-info{flex:1;min-width:0}.lobby-game-header{align-items:center;gap:8px;display:flex}.lobby-game-room-id{color:#f59e0b;letter-spacing:.08em;font-size:.8em;font-weight:800}.lobby-game-online{color:#4ade80;font-size:.75em;font-weight:700}.lobby-game-players{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:.8em;overflow:hidden}.lobby-btn-resume{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#7c3aed 0%,#8b5cf6 100%);border:none;border-radius:10px;padding:6px 14px;font-family:Nunito,Segoe UI,sans-serif;font-size:.85em;font-weight:800;transition:all .15s}.lobby-btn-resume:hover{transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.lobby-game-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.lobby-btn-delete{cursor:pointer;background:0 0;border:1px solid #4a4a6a;border-radius:8px;padding:6px 8px;font-size:.9em;line-height:1;transition:all .15s}.lobby-btn-delete:hover{background:#f871711a;border-color:#f87171}@media (width<=900px){.lobby-card{border-radius:20px;padding:24px}.mygames-drawer{width:260px}.mygames-drawer-collapsed{transform:translate(-260px)}.mygames-tab{width:42px;height:140px;right:-42px}.mygames-tab-icon{font-size:.65em}.mygames-header{padding:14px 14px 10px;font-size:.95em}.mygames-list{gap:6px;padding:8px 10px}.lobby-game-card{flex-direction:column;align-items:stretch;gap:8px;padding:8px 10px}.lobby-game-actions{justify-content:flex-end}}@media (width<=900px) and (orientation:landscape){.lobby{min-height:unset;align-items:center;height:100dvh;padding:8px;overflow:hidden}.lobby-card{max-width:600px;max-height:100%;padding:10px 18px;overflow:hidden}.lobby-title{margin-bottom:0;font-size:1.1em}.lobby-subtitle{display:none}.lobby-auth-info{gap:6px;margin-bottom:6px;padding:4px 8px}.lobby-auth-info .lobby-avatar{width:24px;height:24px}.lobby-auth-name{font-size:.75em}.lobby-auth-email{display:none}.lobby-auth-logout{padding:2px 8px;font-size:.7em}.lobby-error,.lobby-auth-loading{margin-bottom:4px;font-size:.75em}.lobby-sections-row{align-items:stretch;gap:0;display:flex}.lobby-sections-row>.lobby-section{flex-direction:column;flex:1;gap:6px;margin-bottom:0;display:flex}.lobby-divider-vertical{background:#2a2a50;align-self:stretch;width:1px;margin:0 14px;display:block}.lobby-divider{display:none}.lobby-field{margin-bottom:0}.lobby-field label{margin-bottom:1px;font-size:.72em}.lobby-field input,.lobby-field select{border-radius:8px;padding:5px 8px;font-size:.82em}.lobby-section-title{margin-bottom:0;font-size:.8em}.lobby-toggle label{font-size:.75em}.lobby-toggle{margin-bottom:0}.lobby-btn{border-radius:10px;margin-top:auto;padding:6px;font-size:.82em}}.activity-drawer{z-index:200;background:#0c0c1ef7;border-left:1px solid #2a2a50;flex-direction:column;width:300px;height:100vh;font-family:Nunito,Segoe UI,sans-serif;transition:transform .3s;display:flex;position:fixed;top:0;right:0;overflow:visible;transform:translate(0);box-shadow:-4px 0 30px #0009}.activity-drawer-collapsed{transform:translate(300px)}.activity-tab{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;-webkit-user-select:none;user-select:none;z-index:201;background:linear-gradient(#10b98159 0%,#34d39959 100%);border-radius:12px 0 0 12px;justify-content:center;align-items:center;width:48px;height:160px;transition:background .15s;display:flex;position:absolute;top:50%;left:-48px;overflow:hidden;transform:translateY(-50%);box-shadow:-4px 0 16px #0006}.activity-tab:hover{background:linear-gradient(#34d3998c 0%,#6ee7b78c 100%)}.activity-tab-icon{writing-mode:vertical-rl;text-orientation:mixed;color:#6ee7b7;letter-spacing:1.5px;white-space:nowrap;font-size:.75em;font-weight:800}.activity-header{color:#6ee7b7;text-shadow:0 0 20px #10b9814d;border-bottom:1px solid #2a2a50;align-items:center;gap:10px;padding:20px 20px 12px;font-size:1.1em;font-weight:900;display:flex}.activity-online-badge{color:#1a1a2e;letter-spacing:0;background:#4ade80;border-radius:10px;padding:2px 8px;font-size:.65em;font-weight:700}.activity-list{flex-direction:column;flex:1;gap:10px;padding:12px 14px;display:flex;overflow:hidden auto}.activity-empty{text-align:center;color:#64748b;padding:40px 0;font-size:.9em}.activity-room{background:#1a1a3a;border:1px solid #2a2a50;border-radius:12px;padding:10px 12px;transition:border-color .15s}.activity-room:hover{border-color:#34d399}.activity-room-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.activity-room-id{color:#f59e0b;letter-spacing:.08em;font-size:.8em;font-weight:800}.activity-room-phase{border-radius:8px;padding:1px 8px;font-size:.7em;font-weight:700}.phase-waiting{color:#fbbf24;background:#fbbf2426}.phase-playing{color:#4ade80;background:#4ade8026}.phase-paused{color:#f87171;background:#f8717126}.activity-room-count{color:#94a3b8;margin-left:auto;font-size:.75em;font-weight:700}.activity-room-players{flex-direction:column;gap:3px;display:flex}.activity-player{color:#cbd5e1;font-size:.8em}.activity-player.offline{color:#64748b}.activity-room-delete{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #4a4a6a;border-radius:8px;width:100%;margin-top:8px;padding:4px 10px;font-family:Nunito,sans-serif;font-size:.75em;font-weight:700;transition:all .15s}.activity-room-delete:hover{color:#f87171;background:#f871711a;border-color:#f87171}.activity-backdrop{z-index:199;background:#0006;position:fixed;inset:0}@media (width<=900px){.activity-drawer{width:260px}.activity-drawer-collapsed{transform:translate(260px)}.activity-tab{width:42px;height:140px;left:-42px}.activity-tab-icon{font-size:.65em}.activity-header{padding:14px 14px 10px;font-size:.95em}.activity-list{gap:6px;padding:8px 10px}}.card{cursor:pointer;-webkit-user-select:none;user-select:none;background:#f8f8f0;border:2px solid #3a3a50;border-radius:8px;flex-direction:column;justify-content:space-between;width:70px;height:100px;font-family:Nunito,Segoe UI,sans-serif;transition:transform .15s,box-shadow .15s;display:flex;position:relative;box-shadow:0 2px 8px #0006}.card:hover:not(.card-disabled){transform:translateY(-8px);box-shadow:0 8px 24px #00000080,0 0 12px #fbbf2433}.card-selected{border-color:#fbbf24;transform:translateY(-20px)!important;box-shadow:0 12px 32px #fbbf2466,0 0 20px #fbbf244d!important}.card-disabled{opacity:.35;cursor:not-allowed}.card-small{width:50px;height:72px;font-size:.8em}.card-back{cursor:default;background:linear-gradient(135deg,#1a1a4a 0%,#2a1a50 50%,#1a1040 100%);border-color:#3a2a60;justify-content:center;align-items:center;display:flex}.card-back-pattern{opacity:.5;font-size:2em}.card-corner{padding:3px 5px;font-size:.75em;line-height:1}.card-corner-top{text-align:left}.card-corner-bottom{text-align:right;transform:rotate(180deg)}.card-rank{font-size:1.1em;font-weight:800}.card-suit{font-size:.9em}.card-center{font-size:1.8em;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@media (width<=900px){.card{border-width:1.5px;border-radius:6px;width:48px;height:68px}.card:hover:not(.card-disabled){transform:translateY(-4px)}.card-selected{transform:translateY(-10px)!important}.card-corner{padding:2px 3px;font-size:.65em}.card-rank{font-size:.95em}.card-suit{font-size:.75em}.card-center{font-size:1.3em}.card-small{width:36px;height:52px;font-size:.7em}}@media (width<=900px) and (orientation:landscape){.card{width:38px;height:54px}.card-center{font-size:1.1em}.card-small{width:30px;height:44px}}.speech-bubble{color:#fde68a;text-align:center;z-index:30;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fbbf2426;border:1px solid #fbbf2466;border-radius:16px;max-width:200px;padding:8px 14px;font-family:Nunito,Segoe UI,sans-serif;font-size:.85em;font-weight:700;transition:opacity .5s;animation:.3s ease-out bubbleIn;position:relative;box-shadow:0 4px 16px #0000004d}.speech-fading{opacity:0}@keyframes bubbleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.speech-bubble:after{content:"";width:0;height:0;position:absolute}.speech-bubble-top:after{border-top:8px solid #fbbf2466;border-left:8px solid #0000;border-right:8px solid #0000;bottom:-8px;left:50%;transform:translate(-50%)}.speech-bubble-bottom:after{border-bottom:8px solid #fbbf2466;border-left:8px solid #0000;border-right:8px solid #0000;top:-8px;left:50%;transform:translate(-50%)}.speech-bubble-left:after{border-top:8px solid #0000;border-bottom:8px solid #0000;border-left:8px solid #fbbf2466;top:50%;right:-8px;transform:translateY(-50%)}.speech-bubble-right:after{border-top:8px solid #0000;border-bottom:8px solid #0000;border-right:8px solid #fbbf2466;top:50%;left:-8px;transform:translateY(-50%)}.speech-bubble-player{color:#e2e8f0;z-index:32;background:#93c5fd1f;border-color:#93c5fd59;font-weight:600;animation:.25s ease-out bubbleSlideIn}.speech-bubble-player.speech-bubble-top:after{border-top-color:#93c5fd59}.speech-bubble-player.speech-bubble-bottom:after{border-bottom-color:#93c5fd59}.speech-bubble-player.speech-bubble-left:after{border-left-color:#93c5fd59}.speech-bubble-player.speech-bubble-right:after{border-right-color:#93c5fd59}@keyframes bubbleSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-toggle{z-index:25;flex-direction:column;align-items:flex-start;gap:6px;display:flex;position:absolute;bottom:12px;left:52px}.chat-btn{cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#93c5fd1a;border:1px solid #93c5fd4d;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2em;transition:transform .15s,background .15s;display:flex}.chat-btn:active{transform:scale(.9)}.chat-cooldown{opacity:.5}.chat-panel{flex-direction:column;gap:6px;animation:.2s ease-out chatPanelIn;display:flex}@keyframes chatPanelIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-reactions{gap:4px;display:flex}.chat-reaction-btn{cursor:pointer;background:#93c5fd1a;border:1px solid #93c5fd40;border-radius:10px;width:40px;height:40px;font-size:1.2em;transition:transform .1s,background .1s}.chat-reaction-btn:active{background:#93c5fd40;transform:scale(.9)}.chat-reaction-btn:disabled{opacity:.4;cursor:default}.chat-input-row{align-items:center;gap:4px;display:flex}.chat-input{color:#e2e8f0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172acc;border:1px solid #93c5fd4d;border-radius:18px;outline:none;flex:1;width:clamp(140px,45vw,220px);min-width:0;height:36px;padding:0 12px;font-family:Nunito,Segoe UI,sans-serif;font-size:16px}.chat-input::placeholder{color:#93c5fd80}.chat-input:focus{border-color:#93c5fd99}.chat-input:disabled{opacity:.4}.chat-send-btn{color:#93c5fd;cursor:pointer;background:#93c5fd26;border:1px solid #93c5fd4d;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1em;transition:transform .1s,background .1s;display:flex}.chat-send-btn:active{transform:scale(.9)}.chat-send-btn:disabled{opacity:.3;cursor:default}.table{background:radial-gradient(#1a5c35 0%,#0d3a1f 60%,#082816 100%);border:3px solid #2a7a4a;border-radius:24px;flex:auto;width:100%;min-height:300px;margin:0 auto;position:relative;box-shadow:inset 0 4px 30px #0006,0 8px 40px #00000080,0 0 80px #1a5c3526}.table-info{color:#e2e8f0;z-index:10;background:#0009;border:1px solid #2a7a4a;border-radius:10px;align-items:center;gap:10px;max-width:60%;padding:5px 14px;font-size:.82em;font-weight:600;display:flex;position:absolute;top:10px;left:12px}.trump-suit{font-size:1.2em}.over-under{border-radius:8px;padding:2px 10px;font-size:.85em;font-weight:800}.over-under.over{color:#fca5a5;background:#dc262633;border:1px solid #dc262666}.over-under.under{color:#93c5fd;background:#3b82f633;border:1px solid #3b82f666}.player-position{flex-direction:column;align-items:center;gap:4px;display:flex;position:absolute}.player-active .player-info{animation:1.5s ease-in-out infinite turnGlow;border-color:#fbbf24!important;box-shadow:0 0 20px #fbbf2499,0 0 40px #fbbf244d,inset 0 0 15px #fbbf241a!important}.player-active .player-name:after{content:" ⭐"}@keyframes turnGlow{0%,to{border-color:#fbbf24;box-shadow:0 0 20px #fbbf2499,0 0 40px #fbbf244d,inset 0 0 15px #fbbf241a}50%{border-color:#fde68a;box-shadow:0 0 30px #fbbf24cc,0 0 60px #fbbf2466,inset 0 0 20px #fbbf2426}}.player-top{top:46px;left:50%;transform:translate(-50%)}.player-bottom{bottom:8px;left:50%;transform:translate(-50%)}.player-left{top:50%;left:16px;transform:translateY(-50%)}.player-right{top:50%;right:16px;transform:translateY(-50%)}.player-info{text-align:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;border:2px solid #2a4a3a;border-radius:12px;min-width:110px;padding:8px 16px;transition:all .3s;box-shadow:0 4px 12px #0000004d}.player-name{color:#e2e8f0;font-size:.95em;font-weight:800}.player-bid,.player-cards-count{color:#94a3b8;font-size:.78em;font-weight:600}.online-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:5px;display:inline-block}.online-dot.online{background:#22c55e;box-shadow:0 0 6px #22c55e99}.online-dot.offline{background:#ef4444;animation:2s ease-in-out infinite offlinePulse;box-shadow:0 0 6px #ef444499}@keyframes offlinePulse{0%,to{opacity:1}50%{opacity:.3}}.player-offline .player-info{opacity:.5}.turn-timer{color:#fbbf24;font-variant-numeric:tabular-nums;margin-top:2px;font-size:.8em;font-weight:800}.turn-timer.timer-urgent{color:#ef4444;animation:.8s ease-in-out infinite timerUrgentPulse}@keyframes timerUrgentPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.table-paused-overlay{z-index:25;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;border-radius:24px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.table-paused-message{text-align:center;color:#fbbf24;text-shadow:0 0 20px #fbbf2466;font-size:1.3em;font-weight:900}.table-paused-reason{color:#94a3b8;margin-top:6px;font-size:.55em;font-weight:600}.player-trick-card{margin-top:4px}.center-talk{z-index:20;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.player-bid-status{margin-top:2px;font-size:.82em;font-weight:700}.bid-status-thinking{color:#fbbf24;animation:1.2s ease-in-out infinite thinkingPulse}@keyframes thinkingPulse{0%,to{opacity:.5}50%{opacity:1}}.bid-status-waiting{color:#64748b;font-style:italic}.bid-action-pass{color:#f87171;text-transform:uppercase;letter-spacing:.5px}.bid-action-bid{color:#4ade80;font-size:1.05em}.bid-action-contract{color:#93c5fd;font-weight:800}.phase-label{color:#fbbf24;text-transform:uppercase;letter-spacing:.5px;font-size:.9em;font-weight:800}.bid-history-log{z-index:15;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border:1px solid #fbbf2433;border-radius:12px;flex-direction:column;gap:3px;min-width:140px;max-height:160px;padding:8px 14px;display:flex;position:absolute;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%)}.bid-history-entry{border-bottom:1px solid #ffffff0f;justify-content:space-between;gap:12px;padding:2px 0;font-size:.8em;font-weight:600;display:flex}.bid-history-entry:last-child{border-bottom:none}.bid-history-name{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;max-width:80px;overflow:hidden}.entry-pass .bid-history-action{color:#f87171}.entry-bid .bid-history-action{color:#4ade80;font-weight:800}@media (width<=900px){.table{border-width:2px;border-radius:12px;flex:auto;min-height:200px}.table-info{border-radius:8px;gap:8px;padding:3px 10px;font-size:.72em}.player-info{border-radius:8px;min-width:70px;padding:4px 8px}.player-name{font-size:.75em}.player-bid,.player-cards-count{font-size:.65em}.player-bid-status{font-size:.68em}.player-top{top:54px}.player-bottom{bottom:4px}.player-left{left:6px}.player-right{right:6px}.bid-history-log{gap:2px;min-width:110px;max-height:120px;padding:6px 10px;font-size:.72em}.bid-history-name{max-width:55px}.online-dot{width:6px;height:6px;margin-right:3px}.turn-timer{font-size:.68em}.table-paused-message{font-size:1em}.table-paused-overlay{border-radius:12px}}@media (width<=480px){.table-info{gap:6px;max-width:55%;padding:4px 10px;font-size:.75em}.player-top{top:50px}}@media (width<=900px) and (orientation:landscape){.table{min-height:120px}}.hand{flex-direction:column;flex-shrink:0;align-items:center;gap:8px;padding:8px 0;display:flex}.hand-cards-desktop{justify-content:center;align-items:flex-end;min-height:120px;padding:0 30px;display:flex;position:relative}.hand-cards-mobile{display:none}.hand-card-wrapper{transform-origin:bottom;cursor:grab;margin-left:-20px;transition:transform .2s,margin-left .2s,opacity .15s}.hand-card-wrapper:first-child{margin-left:0}.hand-card-suit-break{border-left:2px solid #fbbf2440;padding-left:8px;margin-left:8px!important}.hand-card-suit-break:first-child{border-left:none;padding-left:0;margin-left:0!important}.hand-card-dragging{opacity:.35;cursor:grabbing}.hand-card-dragover{border-left:3px solid #fbbf24;padding-left:4px}.play-button{color:#1a1a2e;cursor:pointer;background:linear-gradient(135deg,#b45309 0%,#d97706 50%,#f59e0b 100%);border:none;border-radius:20px;padding:10px 28px;font-family:Nunito,Segoe UI,sans-serif;font-size:1em;font-weight:700;transition:transform .1s,box-shadow .1s;box-shadow:0 4px 16px #f59e0b66}.play-button:hover{transform:scale(1.05);box-shadow:0 6px 20px #f59e0b99}.play-button:active{transform:scale(.98)}@media (width<=900px){.hand{gap:4px;padding-bottom:0}.hand-cards-desktop{display:none}.hand-cards-mobile{flex-direction:column;gap:0;width:100%;padding:0 8px;display:flex}.hand-suit-row{background:#0003;border-left:3px solid #fbbf244d;border-radius:8px;justify-content:center;gap:0;margin-top:-20px;padding:2px 4px;display:flex;position:relative}.hand-suit-row:first-child{margin-top:0}.hand-card-wrapper-mobile{margin-left:-12px;transition:transform .15s}.hand-card-wrapper-mobile:first-child{margin-left:0}.play-button{border-radius:16px;padding:8px 24px;font-size:.9em}}@media (width<=900px) and (orientation:landscape){.hand{gap:2px;padding:2px 0}.hand-cards-desktop{min-height:60px;padding:0 20px;display:flex}.hand-cards-mobile{display:none}.hand-card-wrapper{margin-left:-18px}.play-button{padding:4px 16px;font-size:.8em}}.bid-panel{background:#0c0c1ef2;border:1px solid #2a2a50;border-radius:20px;max-width:500px;margin:12px auto;padding:20px;font-family:Nunito,Segoe UI,sans-serif;box-shadow:0 8px 32px #0006}.bid-panel-title{text-align:center;color:#fbbf24;margin-bottom:8px;font-size:1.1em;font-weight:800}.current-bid{text-align:center;color:#94a3b8;margin-bottom:12px;font-size:.85em;font-weight:600}.bid-section{margin-bottom:12px}.bid-label{color:#94a3b8;margin-bottom:6px;font-size:.85em;font-weight:700}.bid-buttons{flex-wrap:wrap;gap:6px;display:flex}.contract-buttons{justify-content:center}.bid-btn{color:#e2e8f0;cursor:pointer;background:#1a1a3a;border:2px solid #2a2a50;border-radius:10px;width:44px;height:40px;font-family:Nunito,Segoe UI,sans-serif;font-size:.95em;font-weight:700;transition:all .1s}.bid-btn:hover:not(:disabled){background:#fbbf2426;border-color:#fbbf24}.bid-btn-selected{box-shadow:0 0 12px #fbbf244d;color:#1a1a2e!important;background:#d97706!important;border-color:#fbbf24!important}.bid-btn:disabled{opacity:.25;cursor:not-allowed}.bid-btn-forbidden{text-decoration:line-through;color:#f87171!important;background:#dc262626!important;border-color:#dc262666!important}.bid-suit-btn{width:52px;font-size:1.2em}.forbidden-notice{text-align:center;color:#f87171;margin-bottom:8px;font-size:.8em;font-weight:600}.bid-actions{justify-content:center;gap:12px;display:flex}.bid-action-btn{cursor:pointer;border:none;border-radius:16px;padding:10px 32px;font-family:Nunito,Segoe UI,sans-serif;font-size:1em;font-weight:800;transition:all .1s}.bid-pass{color:#94a3b8;background:#1a1a3a;border:2px solid #2a2a50}.bid-pass:hover{background:#2a2a4a;border-color:#94a3b8}.bid-confirm{color:#1a1a2e;background:linear-gradient(135deg,#b45309 0%,#d97706 50%,#f59e0b 100%);box-shadow:0 4px 16px #f59e0b4d}.bid-confirm:hover:not(:disabled){transform:scale(1.03);box-shadow:0 6px 20px #f59e0b80}.bid-confirm:disabled{opacity:.4;cursor:not-allowed}@media (width<=900px){.bid-panel{border-radius:12px;margin:4px 8px;padding:10px}.bid-panel-title{margin-bottom:4px;font-size:.9em}.current-bid{margin-bottom:6px;font-size:.75em}.bid-section{margin-bottom:8px}.bid-label{margin-bottom:3px;font-size:.75em}.bid-btn{border-radius:8px;width:36px;height:34px;font-size:.8em}.bid-suit-btn{width:44px;font-size:1em}.bid-actions{gap:8px}.bid-action-btn{border-radius:12px;padding:8px 20px;font-size:.85em}}@media (width<=900px) and (orientation:landscape){.bid-panel{border-radius:10px;flex-wrap:wrap;align-items:center;gap:6px;max-width:100%;margin:2px auto;padding:6px 10px;display:flex}.bid-panel-title{white-space:nowrap;margin-bottom:0;margin-right:8px;font-size:.75em}.current-bid{margin-bottom:0;margin-right:8px;font-size:.7em}.bid-section{align-items:center;gap:4px;margin-bottom:0;display:flex}.bid-label{white-space:nowrap;margin-bottom:0;margin-right:4px;font-size:.68em}.bid-buttons{gap:3px}.bid-btn{border-width:1px;border-radius:6px;width:30px;height:28px;font-size:.72em}.bid-suit-btn{width:36px;font-size:.9em}.bid-actions{gap:6px;margin-left:auto}.bid-action-btn{border-radius:8px;padding:5px 14px;font-size:.75em}.forbidden-notice{margin-bottom:0;font-size:.68em}}.scoreboard{z-index:200;background:#0c0c1ef7;border-right:1px solid #2a2a50;flex-direction:column;width:300px;height:100vh;font-family:Nunito,Segoe UI,sans-serif;transition:transform .3s;display:flex;position:fixed;top:0;left:0;overflow:visible;transform:translate(0);box-shadow:4px 0 30px #0009}.scoreboard-collapsed{transform:translate(-300px)}.scoreboard-tab{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;-webkit-user-select:none;user-select:none;z-index:201;background:linear-gradient(#b4530959 0%,#d9770659 100%);border-radius:0 12px 12px 0;justify-content:center;align-items:center;width:40px;height:90px;transition:background .15s;display:flex;position:absolute;top:50%;right:-40px;transform:translateY(-50%);box-shadow:4px 0 16px #0006}.scoreboard-tab:hover{background:linear-gradient(#d977068c 0%,#f59e0b8c 100%)}.scoreboard-tab-icon{writing-mode:vertical-rl;text-orientation:mixed;color:#1a1a2e;letter-spacing:1px;font-size:.8em;font-weight:800}.scoreboard-header{color:#1a1a2e;background:linear-gradient(135deg,#b45309 0%,#d97706 100%);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.scoreboard-title{font-size:1em;font-weight:800}.scoreboard-target{opacity:.9;font-size:.8em}.scoreboard-body{flex:1;padding:12px;overflow:hidden auto}.score-table{border-collapse:collapse;width:100%;font-size:.9em}.score-table th{text-align:left;color:#94a3b8;border-bottom:2px solid #2a2a50;padding:6px 10px;font-size:.85em;font-weight:700}.score-table td{color:#e2e8f0;border-bottom:1px solid #1a1a3a;padding:8px 10px}.score-leader{background:#fbbf241a}.score-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-weight:700;overflow:hidden}.score-total{color:#fbbf24;font-size:1.05em;font-weight:800}.score-positive{color:#4ade80;font-weight:700}.score-negative{color:#f87171;font-weight:700}.scoreboard-backdrop{z-index:199;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;position:fixed;inset:0}.scoreboard-inline{width:100%;margin-bottom:16px}.scoreboard-inline .score-table{border-collapse:collapse;width:100%;font-size:.9em}.scoreboard-inline .score-table th{text-align:left;color:#94a3b8;border-bottom:2px solid #2a2a50;padding:6px 10px;font-size:.85em;font-weight:700}.scoreboard-inline .score-table td{color:#e2e8f0;border-bottom:1px solid #1a1a3a;padding:8px 10px}@media (width<=900px){.scoreboard{width:260px}.scoreboard-collapsed{transform:translate(-260px)}}.gamemenu{z-index:200;background:#0c0c1ef7;border-left:1px solid #2a2a50;flex-direction:column;width:280px;height:100vh;font-family:Nunito,Segoe UI,sans-serif;transition:transform .3s;display:flex;position:fixed;top:0;right:0;overflow:visible;transform:translate(0);box-shadow:-4px 0 30px #0009}.gamemenu-collapsed{transform:translate(280px)}.gamemenu-tab{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;-webkit-user-select:none;user-select:none;z-index:201;background:linear-gradient(#1e40af59 0%,#3b82f659 100%);border-radius:12px 0 0 12px;justify-content:center;align-items:center;width:40px;height:90px;transition:background .15s;display:flex;position:absolute;top:50%;left:-40px;transform:translateY(-50%);box-shadow:-4px 0 16px #0006}.gamemenu-tab:hover{background:linear-gradient(#3b82f68c 0%,#60a5fa8c 100%)}.gamemenu-tab-icon{writing-mode:vertical-rl;text-orientation:mixed;color:#fff;letter-spacing:1px;font-size:.8em;font-weight:800}.gamemenu-backdrop{z-index:199;background:#0006;position:fixed;inset:0}.gamemenu-header{color:#fff;background:linear-gradient(135deg,#1e40af 0%,#3b82f6 100%);flex-shrink:0;align-items:center;padding:14px 16px;display:flex}.gamemenu-title{font-size:1em;font-weight:800}.gamemenu-body{flex-direction:column;flex:1;gap:16px;padding:16px;display:flex;overflow-y:auto}.gamemenu-section{flex-direction:column;gap:4px;display:flex}.gamemenu-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;font-size:.75em;font-weight:700}.gamemenu-value{color:#e2e8f0;font-size:1.1em;font-weight:800}.gamemenu-pin-row{align-items:center;gap:10px;display:flex}.gamemenu-pin{color:#fbbf24;letter-spacing:3px;font-family:monospace;font-size:1.4em;font-weight:900}.gamemenu-copy-btn{color:#94a3b8;cursor:pointer;background:#1a1a3a;border:1px solid #2a2a50;border-radius:8px;padding:4px 12px;font-family:Nunito,Segoe UI,sans-serif;font-size:.8em;font-weight:700;transition:all .15s}.gamemenu-copy-btn:hover{color:#e2e8f0;border-color:#3b82f6}.gamemenu-players{flex-direction:column;gap:6px;display:flex}.gamemenu-player{background:#1a1a3a;border:1px solid #2a2a50;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;font-size:.85em;display:flex}.gamemenu-player-icon{font-size:1em}.gamemenu-player-name{color:#e2e8f0;text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:700;overflow:hidden}.gamemenu-player-score{color:#fbbf24;font-weight:800}.gamemenu-divider{background:#2a2a50;height:1px}.gamemenu-leave-btn{color:#f87171;cursor:pointer;text-align:center;background:#1a1a3a;border:2px solid #dc2626;border-radius:12px;padding:12px;font-family:Nunito,Segoe UI,sans-serif;font-size:.95em;font-weight:800;transition:all .15s}.gamemenu-leave-btn:hover{background:#dc262626}.gamemenu-leave-confirm{color:#fca5a5;background:#dc262633;border-color:#f87171;animation:.8s infinite alternate pulse-red}@keyframes pulse-red{0%{box-shadow:0 0 #dc262600}to{box-shadow:0 0 16px #dc26264d}}*{box-sizing:border-box;margin:0;padding:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0003;border-radius:4px}::-webkit-scrollbar-thumb{background:linear-gradient(#d97706,#b45309);border:1px solid #0000004d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(#f59e0b,#d97706)}::-webkit-scrollbar-corner{background:0 0}*{scrollbar-width:thin;scrollbar-color:#b45309 #0003}body{color:#e2e8f0;background:#080810;min-height:100vh;font-family:Nunito,Segoe UI,sans-serif}.waiting-room{background:radial-gradient(#151530 0%,#080810 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.waiting-card{text-align:center;background:#12122a;border:1px solid #2a2a50;border-radius:24px;width:100%;max-width:400px;padding:32px;box-shadow:0 16px 48px #00000080}.waiting-title{color:#fbbf24;margin-bottom:4px;font-size:1.5em;font-weight:900}.waiting-subtitle{color:#94a3b8;margin-bottom:12px;font-size:.9em}.waiting-share{margin-bottom:20px}.copy-link-btn{color:#e2e8f0;cursor:pointer;background:linear-gradient(135deg,#1e3a5f 0%,#2563eb 100%);border:1px solid #3b82f6;border-radius:10px;padding:8px 20px;font-family:Nunito,Segoe UI,sans-serif;font-size:.85em;font-weight:700;transition:all .15s}.copy-link-btn:hover{background:linear-gradient(135deg,#2563eb 0%,#3b82f6 100%);transform:translateY(-1px);box-shadow:0 3px 12px #3b82f666}.waiting-players{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.waiting-player{color:#e2e8f0;background:#1a1a3a;border:1px solid #2a2a50;border-radius:12px;padding:10px 16px;font-weight:700}.start-btn{color:#1a1a2e;cursor:pointer;background:linear-gradient(135deg,#b45309 0%,#d97706 50%,#f59e0b 100%);border:none;border-radius:16px;padding:14px 32px;font-family:Nunito,Segoe UI,sans-serif;font-size:1.1em;font-weight:800;transition:all .15s;box-shadow:0 4px 16px #f59e0b66}.start-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #f59e0b99}.start-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.leave-btn{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #334155;border-radius:12px;margin-top:4px;padding:10px 24px;font-family:Nunito,Segoe UI,sans-serif;font-size:.9em;font-weight:600;transition:all .15s}.leave-btn:hover{color:#ef4444;border-color:#ef4444}.waiting-actions{flex-direction:column;align-items:center;gap:10px;width:100%;display:flex}.rejoin-banner{z-index:1000;color:#e2e8f0;background:linear-gradient(135deg,#1e3a5f 0%,#1a2744 100%);border-bottom:2px solid #f59e0b;justify-content:center;align-items:center;gap:12px;padding:12px 20px;font-family:Nunito,Segoe UI,sans-serif;font-size:.95em;font-weight:600;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 20px #0006}.rejoin-btn{color:#1a1a2e;cursor:pointer;background:linear-gradient(135deg,#b45309 0%,#d97706 50%,#f59e0b 100%);border:none;border-radius:10px;padding:6px 18px;font-family:Nunito,Segoe UI,sans-serif;font-size:.9em;font-weight:800;transition:all .15s}.rejoin-btn:hover{transform:translateY(-1px);box-shadow:0 3px 12px #f59e0b80}.rejoin-dismiss{color:#64748b;cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:1.2em;line-height:1;transition:color .15s}.rejoin-dismiss:hover{color:#ef4444}.waiting-status{text-align:center;color:#94a3b8;margin-bottom:8px;font-size:.9em;font-weight:600}.game-screen{background:radial-gradient(at top,#0f1628 0%,#080810 60%);min-height:100vh;padding:12px;overflow:hidden}.game-layout{flex-direction:column;gap:12px;max-width:1600px;height:calc(100vh - 24px);margin:0 auto;display:flex}.game-main{flex-direction:column;flex:1;gap:12px;min-width:0;min-height:0;display:flex}@media (width<=900px){.game-screen{min-height:unset;flex-direction:column;padding:4px;display:flex;position:fixed;inset:0;overflow:hidden}.game-layout{flex:1;gap:6px;width:100%;height:auto}.game-main{flex:1;gap:2px;min-height:0;overflow:hidden}.scoring-overlay{padding:12px}.scoring-card{border-radius:16px;padding:16px}.scoring-card h2{margin-bottom:10px;font-size:1.1em}.start-btn{padding:10px 24px;font-size:.95em}}@media (width<=900px) and (orientation:landscape){.waiting-room{min-height:unset;align-items:center;height:100dvh;padding:8px;overflow:hidden}.waiting-card{padding:10px 16px}.waiting-title{font-size:1em}.waiting-subtitle{margin-bottom:6px;font-size:.75em}.waiting-players{gap:3px;margin-bottom:6px}.waiting-player{border-radius:8px;padding:4px 10px;font-size:.8em}.start-btn{padding:6px 18px;font-size:.85em}}.scoring-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.scoring-card{text-align:center;background:#12122a;border:1px solid #fbbf24;border-radius:24px;width:100%;max-width:500px;padding:28px;box-shadow:0 16px 48px #00000080,0 0 40px #fbbf241a}.scoring-card h2{color:#fbbf24;margin-bottom:16px;font-size:1.4em}.scoring-card .scoreboard{max-width:100%;margin-bottom:16px}.game-over-card{border:2px solid #fbbf24;box-shadow:0 0 60px #fbbf2433,0 16px 48px #00000080}.game-over-winner{color:#fbbf24;text-shadow:0 0 20px #fbbf2480;margin-top:12px;font-size:1.3em;font-weight:900}@media (width<=900px){.game-layout{flex-direction:column;height:auto}.game-sidebar{flex:none}}.idle-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.idle-popup{text-align:center;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);border:2px solid #f59e0b;border-radius:20px;width:90vw;max-width:380px;padding:40px 48px;animation:.3s popIn;box-shadow:0 20px 60px #0009,0 0 30px #f59e0b26}.idle-icon{margin-bottom:12px;font-size:3em}.idle-popup h2{color:#f1f5f9;margin-bottom:8px;font-family:Nunito,sans-serif;font-size:1.4em;font-weight:800}.idle-popup p{color:#94a3b8;margin-bottom:24px;font-family:Nunito,sans-serif;font-size:.95em;line-height:1.5}.idle-popup p strong{color:#f59e0b;font-size:1.1em}.idle-btn{color:#1a1a2e;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#b45309 0%,#d97706 50%,#f59e0b 100%);border:none;border-radius:12px;padding:12px 36px;font-family:Nunito,sans-serif;font-size:1.1em;font-weight:800;transition:all .15s}.idle-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b80}.idle-btn:active{transform:translateY(0)}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.disconnect-banner{z-index:9999;color:#fff;text-align:center;background:linear-gradient(90deg,#dc2626,#b91c1c);justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:.9em;font-weight:700;animation:.3s ease-out slideDown;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 12px #dc262680}.disconnect-icon{font-size:1.2em;animation:1.5s ease-in-out infinite disconnectPulse}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes disconnectPulse{0%,to{opacity:1}50%{opacity:.4}}
