:root{--felt-green: #1a472a;--felt-light: #1e5631;--felt-dark: #0f2d1a;--gold: #d4af37;--gold-light: #f0d060;--gold-dark: #b8960c;--wood: #2c1810;--wood-light: #4a2c1a;--card-white: #f5f0e8;--card-back: #c0392b;--bg-dark: #0a0e0a;--bg-card: rgba(255, 255, 255, .05);--text-primary: #f0e6d3;--text-secondary: #a89a82;--text-muted: #6b5f4f;--red: #e74c3c;--green: #27ae60;--blue: #3498db;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 40px;--spacing-xxl: 64px;--font-display: "Playfair Display", Georgia, serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--border-gold: 1px solid var(--gold);--border-subtle: 1px solid rgba(212, 175, 55, .2);--shadow-card: 0 4px 24px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px rgba(212, 175, 55, .3);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-round: 50%}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-body);background-color:var(--bg-dark);color:var(--text-primary);min-height:100vh;overflow-x:hidden;background-image:radial-gradient(ellipse at center,var(--felt-dark) 0%,var(--bg-dark) 70%)}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none;transition:all .2s ease}input{font-family:var(--font-body);outline:none;border:none}#app{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.hidden{display:none!important}.text-gold{color:var(--gold)}.text-red{color:var(--red)}.text-green{color:var(--green)}.btn{padding:12px 28px;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;transition:all .25s ease}.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--wood);box-shadow:0 4px 15px #d4af374d}.btn-primary:hover{background:linear-gradient(135deg,var(--gold-light),var(--gold));box-shadow:0 6px 20px #d4af3780;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:transparent;color:var(--gold);border:2px solid var(--gold)}.btn-secondary:hover{background:#d4af371a;box-shadow:var(--shadow-glow)}.btn-danger{background:linear-gradient(135deg,var(--red),#c0392b);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#ff6b6b,var(--red));transform:translateY(-2px)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.btn-small{padding:8px 16px;font-size:.85rem}.btn-icon{background:none;color:var(--gold);font-size:1.2rem;padding:4px 8px}.btn-icon:hover{transform:scale(1.2)}.input{padding:12px 16px;background:#0000004d;border:1px solid rgba(212,175,55,.3);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1rem;transition:border-color .2s ease}.input:focus{border-color:var(--gold);box-shadow:0 0 0 3px #d4af371a}.input::placeholder{color:var(--text-muted)}.login-input-group{position:relative;width:100%;margin-top:20px}.login-input-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--gold);font-size:1.2rem;pointer-events:none;opacity:.7;transition:opacity .3s ease}.login-input{width:100%;padding:16px 16px 16px 48px;background:#0006;border:2px solid rgba(212,175,55,.2);border-radius:var(--radius-md);color:var(--text-primary);font-size:1.1rem;letter-spacing:1px;transition:all .3s ease;box-shadow:inset 0 2px 10px #00000080}.login-input:focus{border-color:var(--gold);background:#0009;box-shadow:0 0 15px #d4af3733,inset 0 2px 10px #00000080;outline:none}.login-input:focus+.login-input-icon{opacity:1;text-shadow:0 0 8px rgba(212,175,55,.5)}.login-input::placeholder{color:#5a5a5a;letter-spacing:normal}.panel{background:#0f2d1acc;border:var(--border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-card)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes glow{0%,to{box-shadow:0 0 8px var(--gold)}50%{box-shadow:0 0 25px var(--gold-light)}}@keyframes dealCard{0%{opacity:0;transform:translateY(-40px) rotateY(90deg)}to{opacity:1;transform:translateY(0) rotateY(0)}}.animate-fade-in{animation:fadeIn .4s ease-out}.animate-slide-in{animation:slideIn .3s ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-deal{animation:dealCard .4s ease-out both}.lobby-container{text-align:center;max-width:480px;width:90%}.lobby-decoration{font-size:2.5rem;margin-bottom:var(--spacing-sm);letter-spacing:8px}.lobby-title{font-size:2.8rem;color:var(--gold);margin-bottom:var(--spacing-xs);text-shadow:0 2px 10px rgba(212,175,55,.3)}.lobby-subtitle{color:var(--text-secondary);font-size:1.1rem;margin-bottom:var(--spacing-xl)}.lobby-form{margin-bottom:var(--spacing-lg)}.lobby-form .form-group{margin-bottom:var(--spacing-lg);text-align:left}.lobby-form .form-group label{display:block;color:var(--text-secondary);font-size:.85rem;margin-bottom:var(--spacing-xs);text-transform:uppercase;letter-spacing:1px}.lobby-form .input{width:100%}.lobby-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.lobby-actions .btn{flex:1;min-width:140px}.join-section{margin-top:var(--spacing-lg);animation:fadeIn .3s ease-out}.error-message{color:var(--red);margin-top:var(--spacing-md);font-size:.9rem;padding:8px;background:#e74c3c1a;border-radius:var(--radius-sm)}.lobby-footer{color:var(--text-muted);font-size:.8rem;margin-top:var(--spacing-lg)}.room-container{max-width:600px;width:95%}.room-header{text-align:center;margin-bottom:var(--spacing-lg)}.room-title{color:var(--gold);margin-bottom:var(--spacing-md)}.room-code-display{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);background:#0000004d;padding:12px 24px;border-radius:var(--radius-md);border:var(--border-subtle)}.room-code-label{color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:2px}.room-code-value{font-family:var(--font-display);font-size:2rem;color:var(--gold);letter-spacing:6px;font-weight:700}.room-body{margin-bottom:var(--spacing-md)}.players-section h3{color:var(--text-secondary);margin-bottom:var(--spacing-md);font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.player-list{display:grid;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.player-card{display:flex;align-items:center;gap:var(--spacing-md);padding:12px 16px;background:#0003;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.05)}.player-card.is-host{border-color:#d4af374d}.player-card.disconnected{opacity:.5}.player-avatar{font-size:1.5rem}.player-info{flex:1;display:flex;flex-direction:column}.player-name{font-weight:600}.player-chips{color:var(--text-secondary);font-size:.85rem}.player-status{font-size:.75rem;font-weight:600}.host-controls{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-lg)}.chat-section{border-top:var(--border-subtle);padding-top:var(--spacing-md)}.chat-section .chat-messages{max-height:150px;overflow-y:auto;margin-bottom:var(--spacing-sm);padding:var(--spacing-sm);background:#0003;border-radius:var(--radius-sm);min-height:60px}.chat-section .chat-msg{font-size:.85rem;padding:4px 0}.chat-input-row{display:flex;gap:var(--spacing-sm);align-items:stretch}.chat-input{flex:1;padding:8px 12px}.game-container{width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden;position:relative}.game-topbar{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background:#00000080;z-index:10;position:relative}.game-room-code{color:var(--text-muted);font-size:.8rem}.game-phase{color:var(--gold);font-weight:600;text-transform:uppercase;letter-spacing:2px;position:absolute;left:50%;transform:translate(-50%)}.topbar-right{display:flex;align-items:center;gap:8px}.table-wrapper{flex:1;display:flex;align-items:center;justify-content:center;position:relative;padding:20px}.poker-table{position:relative;width:90vw;max-width:900px;height:50vh;max-height:500px}.table-felt{position:absolute;top:15%;left:10%;width:80%;height:70%;background:radial-gradient(ellipse,var(--felt-light) 0%,var(--felt-green) 50%,var(--felt-dark) 100%);border-radius:50%;border:8px solid var(--wood);box-shadow:0 0 0 4px var(--gold-dark),inset 0 0 40px #0000004d,0 10px 40px #00000080}.community-cards{position:absolute;top:25%;left:50%;transform:translate(-50%);display:flex;gap:8px}.card-placeholder{width:52px;height:72px;border:2px dashed rgba(255,255,255,.15);border-radius:6px}.pot-display{position:absolute;top:60%;left:50%;transform:translate(-50%);text-align:center}.pot-label{display:block;color:var(--text-muted);font-size:.65rem;text-transform:uppercase;letter-spacing:2px}.pot-amount{color:var(--gold);font-family:var(--font-display);font-size:1.3rem;font-weight:700}.player-seats{position:absolute;top:0;right:0;bottom:0;left:0}.seat{position:absolute;left:var(--seat-x);top:var(--seat-y);transform:translate(-50%,-50%);text-align:center;background:#0009;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:8px 14px;min-width:90px;transition:all .3s ease;z-index:2}.seat.active-turn{border-color:var(--gold);animation:glow 1.5s ease-in-out infinite}.seat.folded{opacity:.4}.seat.is-me{border-color:var(--blue)}.seat-avatar{font-size:1.5rem}.seat-name{font-size:.75rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.seat-chips{font-size:.7rem;color:var(--gold)}.seat-bet{position:absolute;bottom:-22px;left:50%;transform:translate(-50%);background:var(--gold-dark);color:var(--wood);font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:10px;white-space:nowrap}.seat-allin{position:absolute;top:-18px;left:50%;transform:translate(-50%);background:var(--red);color:#fff;font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:8px}.seat-folded{position:absolute;top:-18px;left:50%;transform:translate(-50%);background:#000000b3;color:var(--text-muted);font-size:.6rem;padding:2px 6px;border-radius:8px}.dealer-btn{position:absolute;top:-12px;right:-8px;width:22px;height:22px;background:#fff;color:#333;font-size:.65rem;font-weight:800;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0006;z-index:3}.seat-hand{display:flex;gap:2px;justify-content:center;margin-top:4px}.card{width:52px;height:72px;background:var(--card-white);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d;position:relative;font-weight:700}.card-large{width:70px;height:96px;font-size:1.2rem}.card-mini{width:28px;height:38px;font-size:.6rem;display:inline-flex;padding:2px;gap:0}.card-face{background:#fff}.card-rank{font-size:inherit;line-height:1}.card-suit{font-size:1.4em;line-height:1}.card-red{color:#d32f2f}.card-black{color:#212121}.card-mini.card-red{color:#d32f2f;background:#fff;border-radius:3px}.card-mini.card-black{color:#212121;background:#fff;border-radius:3px}.bottom-section{display:flex;flex-direction:column;align-items:center;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(212,175,55,.2);z-index:20}.my-hand{display:flex;gap:12px;justify-content:center;padding:10px 0 4px}.action-panel{width:100%;padding:8px 20px 12px;min-height:140px;transition:opacity .15s ease}.action-panel-hidden{visibility:hidden;pointer-events:none;opacity:0}.action-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.action-btn{min-width:80px;padding:10px 18px;font-size:.9rem}.allin-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.allin-btn:hover{background:linear-gradient(135deg,#ff6b6b,#e74c3c)}.raise-controls{display:flex;align-items:center;gap:12px;justify-content:center;margin-top:10px;flex-wrap:wrap}.raise-slider{flex:1;max-width:200px;accent-color:var(--gold)}.raise-input{width:70px;padding:6px 4px;background:#0006;border:1px solid rgba(212,175,55,.4);color:var(--gold);border-radius:var(--radius-sm);font-family:var(--font-display);font-size:1.1rem;font-weight:700;text-align:center;outline:none;transition:border-color var(--transition-fast)}.raise-input:focus{border-color:var(--gold);box-shadow:0 0 0 2px #d4af3733}.raise-input::-webkit-outer-spin-button,.raise-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.raise-input[type=number]{-moz-appearance:textfield}.raise-value{color:var(--gold);font-weight:700;min-width:40px;text-align:center}.raise-presets{display:flex;gap:6px}.raise-preset{padding:4px 10px;font-size:.75rem;background:#d4af3726;color:var(--gold);border:1px solid rgba(212,175,55,.3);border-radius:4px;cursor:pointer}.raise-preset:hover{background:#d4af374d}.turn-timer{margin-top:8px;display:flex;align-items:center;gap:10px;justify-content:center}.timer-bar{height:4px;background:var(--green);border-radius:2px;transition:width .1s linear;width:100%;max-width:200px}.timer-warn{background:orange}.timer-danger{background:var(--red)}.timer-text{color:var(--text-secondary);font-size:.8rem;min-width:30px}.game-result-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100}.result-panel{max-width:450px;width:90%;text-align:center}.result-title{color:var(--gold);margin-bottom:var(--spacing-lg);font-size:1.4rem}.result-winner{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1)}.result-name{font-weight:600}.result-hand-name{color:var(--text-secondary);font-size:.85rem}.result-amount{font-weight:700}.result-divider{height:1px;background:#d4af3733;margin:12px 0}.result-hand-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:.85rem}.result-cards{display:flex;gap:4px}.toast{position:fixed;top:60px;right:20px;background:#000c;color:var(--text-primary);padding:10px 16px;border-radius:var(--radius-sm);font-size:.85rem;z-index:200;border:1px solid rgba(212,175,55,.2);animation:fadeIn .3s ease-out}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:300}.modal-panel{max-width:420px;width:92%;max-height:85vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.modal-header h2{font-size:1.3rem;margin:0}.modal-close{font-size:1.5rem;color:var(--text-muted);background:none;padding:4px 8px}.modal-close:hover{color:var(--text-primary)}.hand-rankings-list{display:flex;flex-direction:column;gap:6px}.ranking-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#0000004d;border-radius:var(--radius-sm);border-left:3px solid var(--gold);transition:background .2s}.ranking-item:hover{background:#d4af3714}.ranking-num{color:var(--gold);font-weight:700;font-size:.85rem;min-width:22px;text-align:center}.ranking-name{font-weight:600;color:var(--text-primary);min-width:100px}.ranking-desc{color:var(--text-secondary);font-size:.85rem}.ranking-footer{margin-top:var(--spacing-md);color:var(--text-muted);font-size:.8rem;text-align:center}@media (max-width: 768px){.poker-table{width:95vw;height:45vh}.seat{padding:6px 8px;min-width:70px;font-size:.8rem}.seat-avatar{font-size:1.2rem}.card{width:40px;height:56px;font-size:.8rem}.card-placeholder{width:40px;height:56px}.card-large{width:56px;height:78px}.card-suit{font-size:1.2em}.lobby-title{font-size:2rem}.room-code-value{font-size:1.5rem}.action-btn{min-width:65px;padding:8px 12px;font-size:.8rem}.chat-fab{top:65px;transform:none;width:44px;height:44px;font-size:20px}}.chat-fab{position:fixed;right:20px;top:50%;transform:translateY(-50%);width:50px;height:50px;background:var(--bg-card);border:2px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1000;font-size:24px;box-shadow:0 4px 6px #00000080;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.chat-fab:hover{transform:translateY(-50%) scale(1.1);box-shadow:0 0 15px #d4af3766}.unread-badge{position:absolute;top:-5px;right:-5px;background:var(--red);color:#fff;font-size:12px;font-weight:700;padding:2px 6px;border-radius:10px}.chat-drawer{position:fixed;bottom:80px;right:20px;width:320px;height:450px;background:#0f0f12fa;border:1px solid var(--gold);border-radius:12px;display:flex;flex-direction:column;z-index:2000;box-shadow:0 10px 30px #000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;transform:translateY(20px) scale(.95);pointer-events:none;visibility:hidden;transition:opacity .2s ease,transform .2s cubic-bezier(.175,.885,.32,1.275),visibility 0s linear .2s}.chat-drawer.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;visibility:visible;transition-delay:0s}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#0006;border-bottom:1px solid var(--border-color);border-top-left-radius:12px;border-top-right-radius:12px;flex-shrink:0}.chat-header h3{margin:0;color:var(--gold);font-family:var(--font-display);font-size:1.1rem}.chat-header button{background:transparent;border:none;color:var(--text-muted);font-size:28px;cursor:pointer;line-height:1;transition:color var(--transition-fast)}.chat-header button:hover{color:var(--red)}.chat-messages{flex-grow:1;min-height:0;overflow-y:auto;padding:15px;list-style:none;margin:0;display:block}.chat-msg{padding:10px 14px;border-radius:12px;background:var(--bg-light);font-size:.9rem;word-break:break-word;line-height:1.4;border:1px solid rgba(255,255,255,.05);animation:slideInChat .2s ease-out;margin-bottom:12px}.chat-msg span.author{font-weight:700;color:var(--gold);margin-right:6px;font-family:var(--font-display)}.sys-log{text-align:center;font-size:.8rem;color:var(--text-muted);font-style:italic;background:transparent;padding:4px;animation:fadeIn .3s ease-in;margin-bottom:12px}.quick-replies{display:flex;overflow-x:auto;padding:12px 15px;gap:10px;border-top:1px solid var(--border-color);background:#0003;flex-shrink:0}.quick-replies::-webkit-scrollbar{display:none}.quick-replies{-ms-overflow-style:none;scrollbar-width:none}.quick-reply-btn{background:var(--bg-light);border:1px solid var(--border-color);color:var(--text-main);font-size:.8rem;padding:6px 12px;border-radius:16px;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.quick-reply-btn:hover{background:var(--gold);color:var(--bg-dark);border-color:var(--gold);transform:translateY(-2px)}.chat-input-area{display:flex;padding:12px;background:#0006;gap:8px;border-bottom-left-radius:12px;border-bottom-right-radius:12px;flex-shrink:0}.chat-input-area input{flex:1;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-main);padding:10px 15px;border-radius:20px;outline:none;font-family:var(--font-main);transition:border-color var(--transition-fast)}.chat-input-area input:focus{border-color:var(--gold)}.chat-input-area button{background:var(--gold);color:var(--bg-dark);border:none;padding:0 16px;border-radius:20px;font-weight:700;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.chat-input-area button:hover{background:#f1c40f;transform:scale(1.05)}@keyframes slideInChat{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
