*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--table-green: #1a472a;--table-felt: #2d5a3d;--table-border: #0f2d1a;--card-white: #fefefe;--card-shadow: rgba(0, 0, 0, .3);--card-red: #c41e3a;--card-black: #1a1a1a;--gold-accent: #d4af37;--drawer-bg: rgba(30, 30, 40, .95);--drawer-glass: rgba(255, 255, 255, .1);--button-primary: #4a90d9;--button-danger: #d94a4a;--button-success: #4ad94a;--glow-active: rgba(74, 144, 217, .6);--toast-bg: rgba(0, 0, 0, .85);--card-width: 70px;--card-height: 100px;--card-radius: 8px;--drawer-height: 280px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;width:100%;overflow:hidden;font-family:Segoe UI,system-ui,-apple-system,sans-serif}.game-container{display:flex;flex-direction:column;height:100vh;width:100vw;background:linear-gradient(135deg,var(--table-green) 0%,var(--table-felt) 50%,var(--table-green) 100%);position:relative}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#0000004d;color:#fff;position:relative;z-index:10}.game-logo{height:40px;width:auto}.score-panel{display:flex;gap:20px}.score-item{display:flex;flex-direction:column;align-items:center}.score-name{font-size:.75rem;opacity:.8}.score-value{font-size:1.1rem;font-weight:600}.settings-button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;transition:var(--transition-fast)}.settings-button:hover{background:#fff3}.table-area{flex:1;width:100%;position:relative;overflow:visible}.player-well{display:flex;flex-direction:column;align-items:center;padding:12px;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:12px;min-width:110px;transition:var(--transition-normal);position:relative;border:1px solid rgba(255,255,255,.1)}.player-well.active{box-shadow:0 0 20px var(--glow-active),0 0 40px var(--glow-active);border-color:var(--button-primary);background:#0009}.player-well.active:before{content:"";position:absolute;inset:-2px;border-radius:14px;border:2px solid var(--button-primary);animation:pulse-glow 1.5s infinite}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.5}}.player-avatar-container{width:60px;height:72px;border-radius:8px;background:#0000004d;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 4px 8px #0000004d;border:2px solid rgba(255,255,255,.2)}.player-avatar-image{width:100%;height:100%;object-fit:cover;object-position:top center}.player-avatar-fallback{font-size:1.8rem;color:#fff}.player-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:1rem;color:#fff;box-shadow:0 4px 8px #0000004d;border:2px solid rgba(255,255,255,.2)}.player-card-count{color:#ffffffb3;font-size:.75rem;margin-top:4px}.player-name{color:#fff;font-weight:600;font-size:.85rem;text-shadow:0 1px 2px black;margin-top:2px}.center-table{display:flex;gap:60px;align-items:center}.pile-label{text-align:center;color:#fffc;margin-top:15px;font-size:.85rem;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.5);background:#0000004d;padding:2px 8px;border-radius:10px}.empty-slot{width:70px;height:100px;display:flex;align-items:center;justify-content:center;color:#ffffff4d;font-size:.8rem;font-weight:600;letter-spacing:1px}.stock-pile{position:relative;cursor:pointer;transition:var(--transition-fast)}.stock-pile:hover{transform:translateY(-5px)}.stock-pile .card{position:absolute}.stock-pile .card:nth-child(1){top:0;left:0}.stock-pile .card:nth-child(2){top:2px;left:2px}.stock-pile .card:nth-child(3){top:4px;left:4px}.stock-count{position:absolute;top:-15px;right:-10px;background:var(--button-primary);color:#fff;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;font-weight:700;box-shadow:0 2px 4px #0000004d;border:1px solid rgba(255,255,255,.3);z-index:5}.discard-pile{position:relative;min-width:var(--card-width);min-height:var(--card-height);cursor:pointer;transition:var(--transition-fast)}.discard-pile:hover{transform:translateY(-5px)}.discard-pile.empty{border:2px dashed rgba(255,255,255,.2);border-radius:var(--card-radius);background:#0000001a}.discard-count{position:absolute;top:-15px;right:-10px;background:var(--button-primary);color:#fff;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;font-weight:700;box-shadow:0 2px 4px #0000004d;border:1px solid rgba(255,255,255,.3);z-index:5}.card{width:var(--card-width);height:var(--card-height);border-radius:var(--card-radius);box-shadow:0 4px 8px var(--card-shadow);transition:var(--transition-fast);-webkit-user-select:none;user-select:none;position:relative}.card-face{width:100%;height:100%;background:var(--card-white);border-radius:var(--card-radius);display:flex;flex-direction:column;padding:6px;position:relative}.card-back{width:100%;height:100%;background:linear-gradient(135deg,#1e3a5f,#2d5a8a,#1e3a5f);border-radius:var(--card-radius);border:3px solid #c9a227;display:flex;align-items:center;justify-content:center}.card-back:after{content:"♠♥♦♣";font-size:1rem;color:#ffffff4d;letter-spacing:2px}.card-rank{font-size:1.1rem;font-weight:700;line-height:1}.card-suit{font-size:.9rem;line-height:1}.card-center-suit{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem}.card.red{color:var(--card-red)}.card.black{color:var(--card-black)}.card.wild{background:linear-gradient(135deg,#ff6b6b,#feca57,#48dbfb)}.card.joker .card-face{background:var(--card-white);color:#a855f7}.card.joker .card-center-suit{font-size:2.5rem}.card.selected{transform:translateY(-15px);box-shadow:0 8px 16px var(--card-shadow),0 0 15px var(--glow-active)}.card.required{box-shadow:0 0 12px 4px #fc0c,0 4px 8px var(--card-shadow);animation:required-pulse 1.5s infinite}.card.required:after{content:"";position:absolute;inset:-3px;border:3px solid #ffcc00;border-radius:calc(var(--card-radius) + 2px);pointer-events:none}@keyframes required-pulse{0%,to{box-shadow:0 0 12px 4px #fc0c,0 4px 8px var(--card-shadow)}50%{box-shadow:0 0 20px 8px #fc09,0 4px 8px var(--card-shadow)}}.card.card-small .card-face{padding:3px}.card.card-small .card-rank{font-size:.8rem}.card.card-small .card-suit{font-size:.7rem}.card.card-small .card-center-suit{display:none}.card.card-small.joker .card-rank{font-size:.5rem;letter-spacing:-.5px}.card.dragging{opacity:.8;transform:scale(1.05)}.table-melds{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;padding:20px;width:100%;max-width:900px}.meld{display:flex;gap:-20px;padding:10px;background:#00000026;border-radius:12px}.meld .card{margin-left:-20px}.meld .card:first-child{margin-left:0}.meld-label{position:absolute;top:-20px;left:50%;transform:translate(-50%);background:#0009;color:#fff;padding:2px 8px;border-radius:8px;font-size:.7rem;white-space:nowrap}.bottom-drawer{position:fixed;bottom:0;left:0;right:0;background:var(--drawer-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--drawer-glass);z-index:100;display:flex;flex-direction:column}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;background:#0003;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.drawer-melds{display:flex;justify-content:center;padding:24px 10px 8px;background:#00000026;border-bottom:1px solid rgba(255,255,255,.05);overflow-x:auto;flex-shrink:0}.drawer-melds .table-melds{padding:5px;gap:8px}.drawer-handle{height:40px;min-height:40px;display:flex;align-items:center;justify-content:center;cursor:ns-resize;-webkit-user-select:none;user-select:none;flex-shrink:0}.drawer-handle-bar{width:50px;height:5px;background:#ffffff4d;border-radius:3px;transition:var(--transition-fast)}.drawer-handle:hover .drawer-handle-bar{background:#ffffff80}.drawer-tabs{display:flex;gap:0;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.drawer-tab{padding:10px 20px;color:#fff9;background:none;border:none;cursor:pointer;font-size:.9rem;transition:var(--transition-fast);position:relative}.drawer-tab:hover{color:#fffc}.drawer-tab.active{color:#fff}.drawer-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--button-primary)}.drawer-content{padding:15px 20px;flex:1;overflow-x:auto;overflow-y:hidden;min-height:0}.hand-view{display:flex;gap:8px;padding-top:15px;padding-bottom:10px}.hand-view .card{flex-shrink:0;cursor:pointer}.hand-view .card:hover{transform:translateY(-10px)}.action-bar{display:flex;gap:10px;padding:10px 20px;background:#0000004d;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0;flex-wrap:wrap;align-items:center}.action-button{padding:10px 20px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:var(--transition-fast);font-size:.9rem}.action-button:disabled{opacity:.5;cursor:not-allowed}.action-button.primary{background:var(--button-primary);color:#fff}.action-button.primary:hover:not(:disabled){background:#3a80c9}.action-button.danger{background:var(--button-danger);color:#fff}.action-button.danger:hover:not(:disabled){background:#c93a3a}.action-button.success{background:var(--button-success);color:#fff}.action-button.success:hover:not(:disabled){background:#3ac93a}.action-button.secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.action-button.secondary:hover:not(:disabled){background:#fff3}.action-button.warning{background:#e67e22;color:#fff}.action-button.warning:hover:not(:disabled){background:#d35400}.action-button.special{background:#9b59b6;color:#fff}.action-button.special:hover:not(:disabled){background:#8e44ad}.header-button{padding:4px 8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fffc;font-size:.75rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:4px;transition:var(--transition-fast)}.header-button:hover{background:#fff3;color:#fff}.header-button-text{display:inline}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--toast-bg);color:#fff;padding:12px 24px;border-radius:8px;font-size:.95rem;z-index:1000;animation:toast-slide-up .3s ease}@keyframes toast-slide-up{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.turn-indicator{position:absolute;top:50%;left:20px;transform:translateY(-50%);background:#0009;color:#fff;padding:10px 20px;border-radius:8px;font-size:.9rem}.turn-phase{color:var(--gold-accent);font-weight:600}.start-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,var(--table-green) 0%,var(--table-felt) 50%,var(--table-green) 100%);color:#fff}.start-title{font-size:3rem;font-weight:700;color:var(--gold-accent);text-shadow:3px 3px 6px rgba(0,0,0,.5);margin-bottom:40px}.start-options{display:flex;flex-direction:column;gap:15px;min-width:250px}.start-button{padding:15px 30px;font-size:1.1rem;border:none;border-radius:10px;cursor:pointer;transition:var(--transition-fast);font-weight:600}.start-button.primary{background:var(--button-primary);color:#fff}.start-button.primary:hover{background:#3a80c9;transform:translateY(-2px)}.start-settings-row{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.start-setting-group{text-align:center}@media(min-width:768px){.start-settings-row{flex-direction:row;gap:40px;align-items:flex-start;justify-content:center}.start-setting-group{min-width:200px}}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:40px;border-radius:20px;color:#fff;text-align:center;min-width:300px;box-shadow:0 20px 60px #00000080}.modal-title{font-size:2rem;color:var(--gold-accent);margin-bottom:20px}.modal-content{margin-bottom:30px}.stats-modal-scroll{scrollbar-width:thin;scrollbar-color:rgba(74,144,217,.5) rgba(22,33,62,.8)}.stats-modal-scroll::-webkit-scrollbar{width:8px}.stats-modal-scroll::-webkit-scrollbar-track{background:#16213ecc;border-radius:4px}.stats-modal-scroll::-webkit-scrollbar-thumb{background:#4a90d980;border-radius:4px}.stats-modal-scroll::-webkit-scrollbar-thumb:hover{background:#4a90d9b3}.settings-modal{min-width:400px;position:relative}.modal-close-x{position:absolute;top:12px;right:12px;background:none;border:none;color:#fff9;font-size:1.5rem;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s}.modal-close-x:hover{color:#fff}.settings-option{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.1)}.settings-label{font-size:.95rem}.toggle-switch{width:50px;height:26px;background:#fff3;border-radius:13px;position:relative;cursor:pointer;transition:var(--transition-fast)}.toggle-switch.active{background:var(--button-primary)}.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:var(--transition-fast)}.toggle-switch.active:after{left:27px}.chat-bubble-portal{pointer-events:none}.chat-bubble-content{position:relative;background:#fff;color:#1a1a1a;padding:10px 14px;border-radius:16px;font-size:.85rem;font-weight:500;line-height:1.4;box-shadow:0 4px 16px #00000040;min-width:80px;max-width:200px;width:max-content;text-align:left;word-wrap:break-word;white-space:normal}.chat-bubble-tail{position:absolute;bottom:-8px;left:25px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:10px solid white}@media(max-width:768px){:root{--card-width: 55px;--card-height: 80px;--drawer-height: 240px}.top-bar{padding:8px 12px}.game-logo{height:32px}.score-panel{gap:10px}.ai-players{gap:15px}.player-well{padding:8px;min-width:70px}.player-avatar-container{width:50px;height:60px}.player-avatar-fallback{font-size:1.4rem}.player-avatar{width:28px;height:28px;font-size:.9rem}.center-table{gap:30px}.action-button{padding:8px 14px;font-size:.85rem}}@media(max-width:768px){:root{--card-width: 50px;--card-height: 72px;--card-radius: 6px;--mobile-card-small-width: 30px;--mobile-card-small-height: 43px}.top-bar{padding:6px 10px;flex-wrap:nowrap}.game-logo{height:28px}.score-panel{display:none}.settings-button{padding:6px 10px;font-size:.8rem}.table-area{padding-top:0}.player-well{padding:6px;min-width:60px;border-radius:8px}.player-avatar-container{width:40px;height:48px;border-radius:6px}.player-avatar-fallback{font-size:1.2rem}.player-name{font-size:.7rem;max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-card-count{font-size:.65rem}.mobile-ai-row{display:flex;justify-content:center;gap:8px;padding:8px 4px;position:absolute;top:0;left:0;right:0;z-index:10}.mobile-ai-column{display:flex;flex-direction:column;align-items:center;max-width:80px}.mobile-melds-row{display:flex;gap:4px;margin-top:4px;justify-content:center;flex-wrap:wrap;max-width:100%}.mobile-meld{display:flex;background:#0003;border-radius:4px;padding:2px}.mobile-meld .card{width:var(--mobile-card-small-width);height:var(--mobile-card-small-height);margin-left:-12px}.mobile-meld .card:first-child{margin-left:0}.center-table{gap:30px}.stock-pile,.discard-pile{transform:scale(.9)}.pile-label{font-size:.7rem;padding:2px 6px;margin-top:8px}.stock-count,.discard-count{width:20px;height:20px;font-size:.65rem}.empty-slot{width:var(--card-width);height:var(--card-height);font-size:.7rem}.turn-indicator{display:none}.bottom-drawer{max-height:75vh;transition:max-height .3s ease}.bottom-drawer.collapsed{max-height:50px}.drawer-header{padding:6px 10px;flex-wrap:wrap;gap:6px}.drawer-header.clickable{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.drawer-header.clickable:active{background:#ffffff0d}.drawer-expand-indicator{display:flex;align-items:center;justify-content:center;padding:6px 12px;background:#4a90d94d;border:1px solid rgba(74,144,217,.5);border-radius:50%}.drawer-expand-indicator .expand-chevron{color:#4a90d9;font-size:1rem;transition:transform .3s ease}.drawer-expand-indicator .expand-chevron.expanded{transform:rotate(180deg)}.drawer-header>div:first-child{gap:8px!important}.drawer-header .player-avatar{width:28px!important;height:28px!important;font-size:.9rem!important}.drawer-header>div:nth-child(2){font-size:.75rem!important;padding:3px 8px!important;order:3;width:100%;text-align:center}.drawer-header>div:last-child:not(.drawer-expand-indicator){font-size:.7rem!important;display:none}.drawer-expand-indicator{display:flex!important}.header-button{padding:3px 6px}.header-button-text{display:none}.drawer-melds{padding:6px 8px}.drawer-melds .table-melds{gap:6px;padding:3px}.drawer-content{padding:10px 8px;overflow-x:hidden;overflow-y:auto}.hand-view{flex-wrap:wrap;gap:8px;justify-content:center;padding-top:15px;padding-bottom:8px}.hand-view .card{width:var(--card-width);height:var(--card-height)}.hand-view .card:hover{transform:translateY(-8px)}.hand-view .card.selected{transform:translateY(-12px)}.action-bar{padding:8px 10px;gap:6px;justify-content:center}.action-button{padding:10px 12px;font-size:.8rem;flex:1;max-width:100px;min-width:auto}.action-button.primary,.action-button.danger,.action-button.secondary{min-height:44px}.action-button .button-text{display:none}.card{width:var(--card-width);height:var(--card-height)}.card-face{padding:4px}.card-back:after{content:"♠♥";font-size:.8rem;letter-spacing:1px}.card-rank{font-size:.95rem}.card-suit{font-size:.8rem}.card-center-suit{font-size:1.5rem}.card.card-small{width:var(--mobile-card-small-width);height:var(--mobile-card-small-height)}.card.card-small .card-face{padding:2px}.card.card-small .card-rank{font-size:.6rem}.card.card-small .card-suit{font-size:.5rem}.card.card-small.joker .card-rank{font-size:.4rem}.toast{bottom:60%;padding:10px 18px;font-size:.85rem;max-width:90vw;text-align:center}.chat-bubble-content{font-size:.75rem;padding:6px 10px;max-width:120px;min-width:60px}.mobile-scoreboard-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#0006;border:1px solid rgba(255,255,255,.2);border-radius:20px;cursor:pointer}.mobile-scoreboard-pill .trophy{font-size:.9rem}.mobile-scoreboard-pill .leader-name{color:#fff;font-size:.75rem;font-weight:600;max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-scoreboard-pill .leader-score{color:#d4af37;font-size:.8rem;font-weight:700}.scoreboard-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999}.scoreboard-modal{background:linear-gradient(145deg,#1a3d1a,#0d260d);border:2px solid rgba(212,175,55,.4);border-radius:16px;padding:16px;width:90%;max-width:320px;box-shadow:0 10px 40px #00000080}.scoreboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.scoreboard-header>span:first-child{color:#d4af37;font-size:1.1rem;font-weight:700}.scoreboard-header .target-score{color:#fff9;font-size:.75rem}.scoreboard-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.scoreboard-row{position:relative;display:flex;align-items:center;gap:10px;padding:10px 12px;background:#0000004d;border-radius:8px;overflow:hidden}.scoreboard-row .progress-bar{position:absolute;left:0;bottom:0;height:3px;background:linear-gradient(90deg,#4a90d9,#6bb3f0);border-radius:0 3px 3px 0;transition:width .3s ease}.scoreboard-row.leader{background:#d4af3726;border:1px solid rgba(212,175,55,.3)}.scoreboard-row.leader .progress-bar{background:linear-gradient(90deg,#d4af37,#f0d878)}.scoreboard-row.you{border:1px solid rgba(74,144,217,.4)}.scoreboard-row .rank{color:#ffffff80;font-size:.75rem;font-weight:600;width:18px}.scoreboard-row.leader .rank{color:#d4af37}.scoreboard-row .name{flex:1;color:#fff;font-size:.85rem;font-weight:500}.scoreboard-row .score{color:#d4af37;font-size:.9rem;font-weight:700}.scoreboard-close{width:100%;padding:12px;background:#4a90d933;border:1px solid rgba(74,144,217,.4);border-radius:8px;color:#4a90d9;font-size:.85rem;font-weight:600;cursor:pointer}.scoreboard-close:active{background:#4a90d94d}.start-screen{padding:20px}.start-screen .game-logo,.start-screen img{max-width:200px;height:auto}.start-options{min-width:auto;width:100%;max-width:280px}.start-button{padding:14px 24px;font-size:1rem}.modal{padding:24px 20px;margin:16px;min-width:auto;max-width:calc(100vw - 32px)}.modal-title{font-size:1.5rem}.settings-modal{min-width:auto;width:calc(100vw - 32px)}.settings-option{padding:12px 0}.settings-label{font-size:.85rem}.card.required:after{inset:-2px;border-width:2px}}@media(max-width:400px){:root{--card-width: 45px;--card-height: 65px;--mobile-card-small-width: 26px;--mobile-card-small-height: 38px}.player-well{padding:4px;min-width:50px}.player-avatar-container{width:32px;height:38px}.player-name{font-size:.6rem;max-width:50px}.center-table{gap:20px}.action-button{padding:8px;font-size:.75rem}.drawer-header>div:first-child span{font-size:.75rem!important}}@media(max-width:768px)and (max-height:500px){.bottom-drawer{max-height:55vh}.drawer-header{padding:4px 10px}.drawer-content{padding:6px 8px}.action-bar{padding:6px 10px}.player-well{padding:4px}.player-avatar-container{width:36px;height:44px}}
