:root{--primary-color: #4CAF50;--primary-dark: #388E3C;--secondary-color: #2196F3;--secondary-dark: #1976D2;--danger-color: #f44336;--danger-dark: #d32f2f;--success-color: #8BC34A;--warning-color: #FF9800;--bg-color: #1a1a2e;--bg-light: #16213e;--bg-card: #0f3460;--text-color: #e6e6e6;--text-light: #ffffff;--text-muted: #a0a0a0;--border-color: #333;--shadow: 0 4px 6px rgba(0, 0, 0, .3);--radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Microsoft YaHei,sans-serif;background:linear-gradient(135deg,var(--bg-color) 0%,var(--bg-light) 100%);color:var(--text-color);min-height:100vh;overflow-x:hidden}.page{display:none;width:100%;min-height:100vh}.page.active{display:flex;justify-content:center;align-items:center}.btn{padding:10px 20px;border:none;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;outline:none}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--secondary-color);color:#fff}.btn-secondary:hover{background:var(--secondary-dark)}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover{background:var(--danger-dark)}.btn-success{background:var(--success-color);color:#fff}.btn-outline{background:transparent;border:2px solid var(--primary-color);color:var(--primary-color)}.btn-outline:hover{background:var(--primary-color);color:#fff}.btn-small{padding:6px 12px;font-size:12px}.btn-action{padding:12px 24px;font-size:16px;font-weight:700;min-width:80px}.btn-hu{background:var(--danger-color);font-size:18px}.btn-pon{background:var(--warning-color)}.btn-kan{background:#9c27b0}.btn-pass{background:#666}input[type=text],textarea{width:100%;padding:10px 14px;border:2px solid var(--border-color);border-radius:var(--radius);background:#ffffff1a;color:var(--text-color);font-size:14px;transition:border-color .3s;margin-bottom:10px}input[type=text]:focus,textarea:focus{outline:none;border-color:var(--primary-color)}input[type=text]::placeholder,textarea::placeholder{color:var(--text-muted)}.lobby-container{text-align:center;padding:40px;max-width:1000px;width:100%}.title{font-size:48px;font-weight:700;color:var(--text-light);margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.subtitle{font-size:18px;color:var(--text-muted);margin-bottom:40px}.lobby-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}.action-card{background:var(--bg-card);border-radius:var(--radius);padding:30px;text-align:center;box-shadow:var(--shadow);transition:transform .3s}.action-card:hover{transform:translateY(-5px)}.action-card h3{font-size:20px;margin-bottom:10px;color:var(--text-light)}.action-card p{color:var(--text-muted);margin-bottom:20px;font-size:14px}.connection-status{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;color:var(--text-muted)}.status-dot{width:10px;height:10px;border-radius:50%;background:#666}.status-dot.connected{background:var(--success-color);box-shadow:0 0 10px var(--success-color)}.status-dot.connecting{background:var(--warning-color);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.room-container{padding:30px;max-width:600px;width:100%}.room-container h2{text-align:center;margin-bottom:20px;color:var(--text-light)}.room-info{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:30px;padding:15px;background:var(--bg-card);border-radius:var(--radius)}.room-id{font-family:monospace;font-size:18px;font-weight:700;color:var(--primary-color);letter-spacing:2px}.players-list{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;margin-bottom:30px}.player-slot{background:var(--bg-card);border-radius:var(--radius);padding:20px;text-align:center;border:2px solid var(--border-color);transition:all .3s}.player-slot.occupied{border-color:var(--primary-color)}.player-slot.ready{border-color:var(--success-color);background:#8bc34a1a}.player-name{display:block;font-size:16px;font-weight:500;margin-bottom:5px}.player-status{font-size:12px;color:var(--text-muted)}.room-actions{display:flex;gap:10px;justify-content:center;margin-bottom:30px}.chat-area{background:var(--bg-card);border-radius:var(--radius);overflow:hidden}.chat-messages{height:200px;overflow-y:auto;padding:15px;font-size:14px}.chat-messages .message{margin-bottom:8px;line-height:1.4}.chat-messages .message .sender{font-weight:700;color:var(--primary-color)}.chat-messages .message.system{color:var(--text-muted);font-style:italic}.chat-input{display:flex;border-top:1px solid var(--border-color)}.chat-input input{flex:1;margin:0;border:none;border-radius:0}.chat-input .btn{border-radius:0}.game-container{width:100%;height:100vh;display:flex;flex-direction:row;position:relative}#game-canvas-wrapper{display:flex;justify-content:center;align-items:center;flex:1;background:#1a1a2e;background-image:radial-gradient(ellipse at center,#1e2a3a,#1a1a2e 40%,#112)}.history-panel{width:490px;min-width:490px;background:#000000b3;border-left:2px solid #333;padding:12px;overflow-y:auto;font-size:12px;color:#ccc;display:flex;flex-direction:column;gap:8px}.history-panel h4{color:#d4a843;font-size:14px;margin:0 0 6px;text-align:center}#history-list{flex:1;overflow-y:auto}.history-entry{padding:6px 8px;margin-bottom:4px;background:#ffffff0d;border-radius:4px;border-left:3px solid #666}.history-entry.win{border-left-color:#f44336}.history-entry.draw{border-left-color:#ff9800}.history-entry .round-title{font-weight:700;color:#fff;margin-bottom:2px;display:flex;justify-content:space-between;align-items:center}.history-entry .joker-badge{color:#f0d878;font-size:10px;font-weight:400;background:#f0d8781f;border:1px solid rgba(240,216,120,.3);border-radius:3px;padding:1px 6px;white-space:nowrap;flex-shrink:0}.history-entry .fan-detail{font-size:11px;color:#aaa}.history-entry .score-change{display:flex;justify-content:space-between;margin-top:2px;font-size:11px}.history-entry .score-change .pos{color:#8bc34a}.history-entry .score-change .neg{color:#f44336}.win-tiles{display:flex;align-items:center;flex-wrap:wrap;gap:0;margin:4px 0;padding:4px 0;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);min-height:36px}.tile-group{display:flex;align-items:center;gap:2px;flex-shrink:0}.meld-group{gap:6px}.meld-set{display:flex;gap:1px;background:#ffffff0a;border-radius:2px;padding:1px 2px}.tile-thumb{width:28px;height:34px;object-fit:contain;border-radius:2px;background:#ffffff0f}.tile-thumb.tile-win{border:2px solid #f0d878;border-radius:3px;box-shadow:0 0 6px #f0d87866}.tile-spacer{color:#fff3;font-size:16px;margin:0 4px;-webkit-user-select:none;user-select:none}.hand-group{gap:1px}.win-tile-group{gap:0}.total-scores{border-top:1px solid #444;padding-top:8px}.total-scores .score-row{display:flex;justify-content:space-between;padding:3px 0;font-size:13px}.total-scores .score-row .name{color:#fff}.total-scores .score-row .pts{color:#d4a843;font-weight:700}.pagination{display:flex;justify-content:center;align-items:center;gap:12px;padding:8px 0;margin-top:4px;border-top:1px solid rgba(255,255,255,.08)}.pagination .page-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#ccc;padding:4px 12px;border-radius:3px;cursor:pointer;font-size:11px;transition:all .2s}.pagination .page-btn:hover:not(:disabled){background:#ffffff26;color:#fff}.pagination .page-btn:disabled{opacity:.35;cursor:not-allowed}.pagination .page-info{color:#d4a843;font-size:12px;font-weight:700;min-width:40px;text-align:center}#game-canvas{display:block;border-radius:4px;box-shadow:0 0 40px #00000080,0 0 80px #0003}.action-bar{position:absolute;z-index:20;background:#000000d9;border-radius:var(--radius);box-shadow:var(--shadow);padding:8px 12px;display:flex;flex-direction:row;align-items:center;gap:8px;border:1px solid rgba(255,215,0,.3)}.action-bar.hidden{display:none!important}.action-countdown{font-size:18px;font-weight:700;color:#f44336;min-width:24px;text-align:center;font-family:Consolas,Courier New,monospace}.action-buttons{display:flex;flex-direction:row;gap:8px}.panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);border-radius:var(--radius);padding:30px;min-width:400px;box-shadow:var(--shadow);z-index:30;text-align:center}.panel.hidden{display:none}.panel h3{margin-bottom:20px;color:var(--text-light);font-size:24px}.panel-countdown{position:absolute;top:10px;right:15px;font-size:14px;color:var(--warning-color);font-weight:700}.score-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);border-radius:var(--radius);padding:30px;min-width:400px;box-shadow:var(--shadow);z-index:30;text-align:center}.score-panel.hidden{display:none}.score-panel h3{margin-bottom:20px;color:var(--text-light);font-size:24px}.draw-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);border-radius:var(--radius);padding:40px 30px;min-width:380px;box-shadow:var(--shadow);z-index:30;text-align:center}.draw-panel.hidden{display:none}.draw-panel h3{margin-bottom:10px;color:var(--warning-color);font-size:28px}.draw-panel .draw-message{color:var(--text-color);font-size:16px;margin-bottom:20px}#score-details{margin-bottom:20px;text-align:left}.score-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-color)}.score-item .fan-name{color:var(--text-color)}.score-item .fan-value{color:var(--primary-color);font-weight:700}.total-score{display:flex;justify-content:space-between;padding:15px 0;margin-top:10px;border-top:2px solid var(--primary-color);font-size:18px;font-weight:700}.player-scores{border-top:1px solid var(--border-color);padding-top:15px}.player-scores h4{margin-bottom:10px;color:var(--text-light)}.positive{color:var(--success-color);font-weight:700}.negative{color:var(--danger-color);font-weight:700}.score-list{max-height:200px;overflow-y:auto}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:100}.modal.hidden{display:none}.modal-content{background:var(--bg-card);border-radius:var(--radius);padding:30px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto}.modal-content h3{text-align:center;margin-bottom:20px;color:var(--text-light)}.manual-connect-steps{margin-bottom:20px}.step{margin-bottom:20px;padding:15px;background:#0000004d;border-radius:var(--radius)}.step h4{margin-bottom:10px;color:var(--primary-color)}.step p{color:var(--text-muted);margin-bottom:10px;font-size:14px}.code-area{height:100px;font-family:monospace;font-size:12px;resize:none}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0003}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 768px){.title{font-size:32px}.lobby-actions,.players-list{grid-template-columns:1fr}.action-bar{padding:8px 5px;gap:4px}.btn-action{padding:8px 16px;font-size:14px;min-width:60px}.action-countdown{font-size:16px}}.tenpai-tooltip{position:fixed;z-index:1000;background:#0a0a0aeb;border:2px solid #f0d878;border-radius:8px;padding:8px 12px;pointer-events:none;font-size:13px;color:#f0d878;white-space:nowrap;box-shadow:0 4px 16px #0009;font-family:Microsoft YaHei,sans-serif}.tenpai-tooltip.hidden{display:none}
