.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{background:var(--bg-secondary);border-radius:16px;padding:40px 32px;width:100%;max-width:400px}.auth-card h1{text-align:center;font-size:28px;margin-bottom:8px;color:var(--accent)}.auth-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px}.auth-field{margin-bottom:16px}.auth-error{background:#ff475726;color:var(--error);padding:10px 14px;border-radius:var(--border-radius);margin-bottom:16px;font-size:14px}.auth-card button{margin-top:8px}.auth-link{text-align:center;margin-top:20px;color:var(--text-secondary);font-size:14px}.home-page{min-height:100vh;display:flex;flex-direction:column}.home-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--input-border)}.home-header h1{font-size:20px;color:var(--accent)}.home-user{display:flex;align-items:center;gap:12px;color:var(--text-secondary)}.btn-logout{width:auto;padding:8px 16px;font-size:14px;background:transparent;border:1px solid var(--input-border);color:var(--text-secondary)}.btn-logout:hover{border-color:var(--accent);color:var(--accent);background:transparent}.home-nav{display:flex;justify-content:center;padding:12px 24px 0;gap:12px}.btn-nav{width:auto;padding:8px 20px;font-size:14px;background:transparent;border:1px solid var(--input-border);color:var(--text-secondary)}.btn-nav:hover{border-color:var(--accent);color:var(--accent);background:transparent}.home-main{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:32px 20px}.lobby-container{width:100%;max-width:500px;display:flex;flex-direction:column;gap:24px}.lobby-card{background:var(--bg-secondary);border-radius:16px;padding:24px}.lobby-card h2{font-size:18px;margin-bottom:16px}.join-row{display:flex;gap:12px}.join-row input{flex:1;text-transform:uppercase;letter-spacing:4px;text-align:center;font-size:20px;font-weight:700}.btn-join{width:auto;padding:12px 24px;white-space:nowrap}.lobby-error{background:#ff475726;color:var(--error);padding:8px 12px;border-radius:var(--border-radius);margin-top:12px;font-size:14px}.form-field{margin-bottom:12px}.form-field label{display:block;color:var(--text-secondary);font-size:13px;margin-bottom:6px}.form-row{display:flex;gap:12px}.form-row .form-field{flex:1}select{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--border-radius);color:var(--text-primary);padding:12px 16px;font-size:16px;width:100%;outline:none}select:focus{border-color:var(--accent)}.form-actions{display:flex;gap:12px;margin-top:16px}.form-actions button{flex:1}.btn-cancel{background:transparent;border:1px solid var(--input-border);color:var(--text-secondary)}.btn-cancel:hover{border-color:var(--accent);color:var(--accent);background:transparent}.room-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.room-loading{text-align:center;padding-top:40vh;color:var(--text-secondary)}.room-error-card{margin:auto;background:var(--bg-secondary);padding:32px;border-radius:16px;text-align:center;max-width:400px}.room-error-card h2{margin-bottom:12px}.room-error-card p{color:var(--text-secondary);margin-bottom:20px}.room-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--input-border)}.room-info{text-align:center}.room-name{display:block;font-weight:700;font-size:16px}.room-code{display:block;font-size:12px;color:var(--text-secondary);cursor:pointer;margin-top:2px}.room-code:hover{color:var(--accent)}.room-header-right{text-align:right;display:flex;align-items:center;gap:8px}.room-blinds{font-size:14px;color:var(--text-secondary)}.room-timer{font-size:13px;color:var(--success);font-variant-numeric:tabular-nums}.timer-warning{color:var(--error);font-weight:700}.btn-sound{width:auto;padding:4px 8px;font-size:16px;background:transparent;border:none;cursor:pointer;line-height:1}.btn-sound:hover{opacity:.7;background:transparent}.room-toast{position:fixed;top:80px;left:50%;transform:translate(-50%);background:#ff4757e6;color:#fff;padding:10px 20px;border-radius:var(--border-radius);z-index:100;font-size:14px;animation:toastIn .3s ease-out}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.table-container{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;min-height:0}.poker-table{position:relative;width:100%;max-width:600px;aspect-ratio:1.4 / 1;background:radial-gradient(ellipse,#1a6b3c,#0d4d2b 60%,#0a3d22);border-radius:50%;border:6px solid #2a1a0a;box-shadow:0 0 30px #00000080,inset 0 0 20px #0000004d}.table-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.table-label{color:#ffffff4d;font-size:16px;font-weight:700}.table-blinds{color:#fff3;font-size:14px}.community-cards{display:flex;gap:4px;justify-content:center;margin-bottom:8px}.pot-display{color:gold;font-size:16px;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.5)}.card{display:inline-flex;align-items:center;justify-content:center;width:36px;height:50px;background:#fff;border-radius:4px;font-size:14px;font-weight:700;box-shadow:0 1px 3px #0000004d}.card-red{color:#e74c3c}.card-black{color:#2c3e50}.card-back{background:linear-gradient(135deg,#2c3e50,#3498db);width:36px;height:50px;border-radius:4px;box-shadow:0 1px 3px #0000004d}.card-enter{animation:cardFlip .4s ease-out both}@keyframes cardFlip{0%{transform:scale(.3) rotateY(90deg);opacity:0}60%{transform:scale(1.1) rotateY(0);opacity:1}to{transform:scale(1) rotateY(0);opacity:1}}.seat{position:absolute;transform:translate(-50%,-50%);width:80px;text-align:center;cursor:pointer;transition:transform .2s,opacity .3s}.seat:hover{transform:translate(-50%,-50%) scale(1.05)}.seat-empty .seat-empty-label{background:#ffffff1a;border:2px dashed rgba(255,255,255,.2);border-radius:12px;padding:16px 8px;color:var(--text-secondary);font-size:13px}.seat-empty:hover .seat-empty-label{border-color:var(--accent);color:var(--accent)}.seat-occupied{cursor:default}.seat-folded{opacity:.4}.seat-active{transform:translate(-50%,-50%) scale(1.08)}.seat-active .seat-avatar{animation:pulse 1s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.seat-avatar{font-size:28px;position:relative}.dealer-btn{position:absolute;top:-6px;left:-6px;width:20px;height:20px;background:gold;color:#000;border-radius:50%;font-size:11px;font-weight:700;line-height:20px;text-align:center;z-index:2}.seat-name{font-size:12px;color:#fff;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.seat-chips{font-size:12px;color:var(--success);background:#00000080;border-radius:10px;padding:2px 8px;display:inline-block;margin-top:2px}.seat-me .seat-name{color:var(--accent);font-weight:700}.seat-bet{font-size:11px;color:gold;margin-top:2px}.seat-allin{font-size:10px;color:#fff;background:var(--error);border-radius:4px;padding:1px 4px;margin-top:2px;font-weight:700;animation:allInPulse .6s ease-out}@keyframes allInPulse{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.3)}to{transform:scale(1);opacity:1}}.seat-cards{display:flex;gap:2px;justify-content:center;margin-top:4px}.seat-cards .card{width:28px;height:38px;font-size:11px}.seat-timer{font-size:12px;color:gold;font-weight:700;margin-top:2px}.timer-critical{color:var(--error);animation:blink .5s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.winner-badge{position:absolute;top:-20px;left:50%;transform:translate(-50%);background:#ffd700e6;color:#000;padding:2px 8px;border-radius:8px;font-size:12px;font-weight:700;white-space:nowrap;z-index:10}.winner-animate{animation:winnerPop .5s ease-out}@keyframes winnerPop{0%{transform:translate(-50%) scale(0) translateY(10px);opacity:0}60%{transform:translate(-50%) scale(1.2) translateY(-5px)}to{transform:translate(-50%) scale(1) translateY(0);opacity:1}}.winner-hand{font-size:10px;font-weight:400}.my-cards{display:flex;gap:8px;justify-content:center;padding:8px 0}.my-cards .card{width:48px;height:66px;font-size:18px}.room-actions{padding:12px 16px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.room-actions button{width:auto;padding:12px 24px}.btn-stand{background:transparent;border:1px solid var(--input-border);color:var(--text-secondary)}.btn-stand:hover{border-color:var(--accent);color:var(--accent);background:transparent}.btn-start{background:var(--success)}.btn-start:hover{background:#26c968}.action-panel{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center;width:100%}.action-panel button{padding:10px 16px;font-size:14px;border-radius:8px;font-weight:700}.btn-fold{background:#7f8c8d;color:#fff}.btn-fold:hover{background:#95a5a6}.btn-check{background:#3498db;color:#fff}.btn-check:hover{background:#5dade2}.btn-call{background:#27ae60;color:#fff}.btn-call:hover{background:#2ecc71}.btn-raise{background:#e67e22;color:#fff}.btn-raise:hover{background:#f39c12}.btn-allin{background:var(--error);color:#fff}.btn-allin:hover{background:#ff6b6b}.raise-group{display:flex;gap:4px;align-items:center}.raise-input{width:100px;padding:8px;font-size:14px;border-radius:8px;border:1px solid var(--input-border);background:var(--bg-secondary);color:var(--text-primary)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-secondary);border-radius:16px;padding:24px;width:90%;max-width:360px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-card h3{margin-bottom:8px}.modal-range{color:var(--text-secondary);font-size:13px;margin-bottom:12px}.modal-card input{margin-bottom:16px}.modal-actions{display:flex;gap:12px}.modal-actions button{flex:1}.chat-toggle{position:fixed;bottom:16px;right:16px;width:48px;height:48px;border-radius:50%;background:var(--accent);border:none;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:50;box-shadow:0 2px 8px #0000004d;padding:0}.chat-toggle:hover{background:var(--accent-hover)}.chat-unread{position:absolute;top:-4px;right:-4px;background:var(--success);color:#000;font-size:11px;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.chat-panel{position:fixed;bottom:72px;right:16px;width:300px;max-height:400px;background:var(--bg-secondary);border-radius:12px;display:flex;flex-direction:column;z-index:50;box-shadow:0 4px 16px #0006;animation:slideUp .2s ease-out;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--input-border);font-weight:700;font-size:14px}.chat-close{width:auto;padding:4px 8px;font-size:14px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer}.chat-close:hover{color:var(--accent);background:transparent}.chat-messages{flex:1;overflow-y:auto;padding:8px 14px;max-height:280px;min-height:100px}.chat-msg{margin-bottom:6px;font-size:13px;line-height:1.4}.chat-msg-me .chat-author{color:var(--accent)}.chat-author{color:var(--text-secondary);font-weight:700;margin-right:6px}.chat-text{color:var(--text-primary);word-break:break-word}.chat-input-row{display:flex;gap:6px;padding:8px;border-top:1px solid var(--input-border)}.chat-input-row input{flex:1;padding:8px 10px;font-size:13px;border-radius:6px}.chat-input-row button{width:auto;padding:8px 14px;font-size:13px;border-radius:6px}@media(max-width:480px){.chat-panel{right:8px;left:8px;width:auto;bottom:68px}}.history-page{min-height:100vh;display:flex;flex-direction:column;max-width:600px;margin:0 auto;padding:0 16px}.history-header{display:flex;align-items:center;gap:12px;padding:16px 0}.history-header h1{font-size:20px}.btn-back{width:auto;padding:8px 16px;font-size:14px;background:transparent;border:1px solid var(--input-border);color:var(--text-secondary)}.btn-back:hover{border-color:var(--accent);color:var(--accent);background:transparent}.history-loading,.history-error,.history-empty{text-align:center;padding:48px 0;color:var(--text-secondary);font-size:16px}.history-error{color:var(--error)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.stat-card{background:var(--bg-secondary);border-radius:12px;padding:16px 8px;text-align:center}.stat-value{font-size:22px;font-weight:700;margin-bottom:4px}.stat-label{font-size:12px;color:var(--text-secondary)}.session-list{display:flex;flex-direction:column;gap:12px;padding-bottom:24px}.session-card{background:var(--bg-secondary);border-radius:12px;padding:16px;cursor:pointer;transition:background .2s}.session-card:hover{background:var(--bg-card)}.session-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.session-name{font-size:16px;font-weight:500}.session-profit{font-size:18px;font-weight:700}.session-meta{display:flex;gap:16px;font-size:13px;color:var(--text-secondary)}@media(max-width:480px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:18px}}.detail-page{min-height:100vh;display:flex;flex-direction:column;max-width:600px;margin:0 auto;padding:0 16px 24px}.detail-header{display:flex;align-items:center;gap:12px;padding:16px 0}.detail-header h1{font-size:20px}.detail-loading,.detail-error,.detail-empty{text-align:center;padding:48px 0;color:var(--text-secondary)}.detail-error{color:var(--error)}.detail-info{display:flex;gap:16px;font-size:14px;color:var(--text-secondary);margin-bottom:20px}.detail-section{margin-bottom:24px}.detail-section h2{font-size:16px;margin-bottom:12px;color:var(--text-secondary)}.player-ranking{background:var(--bg-secondary);border-radius:12px;overflow:hidden}.ranking-row{display:flex;align-items:center;padding:12px 16px;gap:12px;border-bottom:1px solid rgba(255,255,255,.05)}.ranking-row:last-child{border-bottom:none}.ranking-pos{color:var(--text-secondary);font-size:14px;width:30px}.ranking-name{flex:1;font-weight:500}.ranking-stats{font-size:13px;color:var(--text-secondary)}.ranking-profit{font-weight:700;min-width:60px;text-align:right}.hands-list{display:flex;flex-direction:column;gap:8px}.hand-item{background:var(--bg-secondary);border-radius:12px;overflow:hidden}.hand-summary{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .2s}.hand-summary:hover{background:var(--bg-card)}.hand-number{color:var(--text-secondary);font-size:14px;min-width:36px}.community-cards{display:flex;gap:4px;flex:1}.no-cards{flex:1;font-size:13px;color:var(--text-secondary)}.card-display{font-size:14px;font-weight:700;padding:2px 4px;background:#ffffff14;border-radius:4px}.hand-winner{font-size:13px;color:var(--success)}.hand-expand{color:var(--text-secondary);font-size:12px}.hand-replay{padding:0 16px 16px;border-top:1px solid rgba(255,255,255,.05)}.replay-players{display:flex;flex-wrap:wrap;gap:8px;padding:12px 0}.replay-player{display:flex;align-items:center;gap:8px;background:#ffffff0d;border-radius:8px;padding:8px 12px;font-size:13px}.rp-name{font-weight:500}.rp-cards{display:flex;gap:4px}.rp-delta{font-weight:700}.replay-phase{margin-top:12px}.phase-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.phase-name{font-size:13px;font-weight:700;color:var(--accent)}.phase-actions{padding-left:12px;border-left:2px solid rgba(255,255,255,.1)}.action-line{display:flex;gap:8px;padding:3px 0;font-size:13px}.action-player{color:var(--text-secondary);min-width:60px}.action-name{color:var(--text-primary)}.action-amount{color:var(--accent);font-weight:700}.replay-result{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.winner-line{display:flex;align-items:center;gap:8px;font-size:14px}.winner-name{font-weight:500}.winner-amount{color:var(--success);font-weight:700}.winner-hand{font-size:12px;color:var(--text-secondary);background:#ffffff14;padding:2px 8px;border-radius:4px}.profit-pos{color:var(--success)}.profit-neg{color:var(--error)}:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-card: #0f3460;--text-primary: #e8e8e8;--text-secondary: #a0a0a0;--accent: #e94560;--accent-hover: #ff6b81;--success: #2ed573;--error: #ff4757;--input-bg: #16213e;--input-border: #333;--border-radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh}input{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--border-radius);color:var(--text-primary);padding:12px 16px;font-size:16px;width:100%;outline:none;transition:border-color .2s}input:focus{border-color:var(--accent)}button{background:var(--accent);color:#fff;border:none;border-radius:var(--border-radius);padding:12px 24px;font-size:16px;cursor:pointer;width:100%;transition:background .2s}button:hover{background:var(--accent-hover)}button:disabled{opacity:.5;cursor:not-allowed}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
