*{box-sizing:border-box}body{color:#fff;background:#1a3a1a;min-height:100vh;margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow-x:hidden}.app{flex-direction:column;min-height:100vh;display:flex}.login-card{color:#111;text-align:center;background:#fff;border-radius:16px;max-width:380px;margin:auto;padding:32px;box-shadow:0 8px 32px #0000004d}.login-card h1{color:#1a5c1a;margin:0 0 20px;font-size:32px}.login-card label{text-align:left;margin:16px 0 6px;font-size:14px;font-weight:600;display:block}.login-card input,.login-card select{border:2px solid #ddd;border-radius:8px;outline:none;width:100%;padding:12px;font-size:16px}.login-card input:focus,.login-card select:focus{border-color:#2a8a2a}button{cursor:pointer;border:none;border-radius:8px;padding:10px 18px;font-size:15px;transition:all .2s}.btn-primary{color:#fff;background:#2a8a2a;font-weight:600}.btn-primary:hover{background:#34a034;transform:translateY(-1px)}.btn-small{color:#fff;background:#ffffff26;padding:6px 12px;font-size:13px}.btn-small:hover{background:#ffffff40}.lobby{max-width:800px;margin:0 auto;padding:20px}.lobby-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.lobby-header h1{margin:0;font-size:28px}.rooms-list{flex-direction:column;gap:10px;display:flex}.room-card{background:#ffffff1a;border-radius:12px;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.room-card b{margin-right:12px;font-size:18px}.room-card span{color:#ccc}.empty{text-align:center;color:#aaa;padding:40px}.game{width:100%;max-width:1100px;margin:0 auto;padding:8px 16px 16px}.game-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.room-info{font-size:16px;font-weight:600}.conn{font-size:14px}.conn.ok{color:#4caf50}.conn.bad{color:#f44336}.score-bar{justify-content:center;gap:24px;margin-bottom:8px;display:flex}.team-score{text-align:center;background:#0000004d;border-radius:10px;min-width:100px;padding:8px 20px}.team-score b{color:#ccc;font-size:13px;display:block}.team-score span{font-size:24px;font-weight:700}.team-score small{color:#aaa;font-size:11px}.table-area{background:#0d5c0d;border-radius:20px;flex-direction:column;gap:12px;min-height:520px;padding:16px;display:flex;box-shadow:inset 0 0 40px #0000004d}.player-info{background:#00000040;border-radius:10px;align-items:center;gap:8px;padding:6px 12px;display:flex}.player-info.active-turn{background:#ffd70026;outline:2px solid gold}.avatar{background:#555;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;font-weight:700;display:flex}.avatar.me{background:#2a8a2a}.pinfo{flex-direction:column;font-size:12px;display:flex}.pinfo b{font-size:14px}.bid-info{color:#ccc}.badge{border-radius:8px;width:fit-content;padding:2px 6px;font-size:10px;font-weight:700}.badge.warn{color:#000;background:#ff9800}.badge.info{color:#fff;background:#2196f3}.player-top{flex-direction:column;align-items:center;gap:6px;display:flex}.hand-back{justify-content:center;gap:4px;display:flex}.table-middle{flex:1;justify-content:space-between;align-items:center;gap:16px;display:flex}.player-left,.player-right{flex-direction:column;align-items:center;gap:6px;min-width:100px;display:flex}.hand-back-vertical{flex-direction:column;gap:2px;display:flex}.card-back-small{background:repeating-linear-gradient(45deg,#b71c1c,#b71c1c 4px,#d32f2f 4px 8px);border:1px solid #8b0000;border-radius:4px;width:32px;height:44px}.table-center{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;min-height:200px;display:flex}.message-box{text-align:center;background:#0006;border-radius:8px;max-width:300px;padding:8px 16px;font-size:14px}.trick-area{width:220px;height:220px;position:relative}.trick-pos{position:absolute}.trick-pos.top{top:0;left:50%;transform:translate(-50%)}.trick-pos.left{top:50%;left:0;transform:translateY(-50%)}.trick-pos.right{top:50%;right:0;transform:translateY(-50%)}.trick-pos.bottom{bottom:0;left:50%;transform:translate(-50%)}.card{cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #999;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;width:56px;height:80px;transition:transform .15s;display:flex;box-shadow:0 2px 6px #0000004d}.card:hover:not(.disabled):not(.face-down){transform:translateY(-8px)}.card.selected{outline:3px solid gold;transform:translateY(-12px)}.card.disabled{opacity:.5;cursor:not-allowed}.card.face-down{cursor:default;background:repeating-linear-gradient(45deg,#b71c1c,#b71c1c 6px,#d32f2f 6px 12px);border:2px solid #8b0000}.card-rank{font-size:18px;font-weight:700;line-height:1}.card-suit{font-size:28px;line-height:1}.red{color:#d32f2f}.black{color:#212121}.bid-panel{color:#111;text-align:center;background:#ffffc8f2;border-radius:12px;padding:16px;box-shadow:0 4px 16px #0000004d}.bid-title{margin-bottom:10px;font-size:16px;font-weight:700}.bid-buttons{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.bid-btn{background:#fff;border:2px solid #333;border-radius:6px;width:36px;height:36px;padding:0;font-size:15px;font-weight:700}.bid-btn:hover{color:#fff;background:#2a8a2a;border-color:#2a8a2a}.bid-help{color:#555;margin-top:8px;font-size:12px}.turn-indicator{color:gold;font-size:18px;font-weight:700;animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.waiting-controls{gap:12px;display:flex}.player-bottom{flex-direction:column;align-items:center;gap:8px;display:flex}.my-hand{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.play-controls{align-items:center;gap:10px;margin-top:8px;display:flex}.btn-play{color:#111;background:gold;border-radius:8px;padding:10px 24px;font-size:16px;font-weight:700}.btn-play:hover{background:#ffeb3b}.btn-cancel{color:#fff;background:#fff3;padding:8px 16px;font-size:14px}.btn-cancel:hover{background:#ffffff4d}.select-hint{color:#ccc;font-size:14px}.toast{color:#fff;text-align:center;background:#c62828;border-radius:8px;margin-bottom:8px;padding:10px 16px;animation:.3s fadein}@keyframes fadein{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
