/* =====================================================
   极速对决 大厅 · 全新电竞主题样式
   ===================================================== */
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
.lobby-body{margin:0;padding:0;background:#05060f;color:#e6ebff;font-family:"PingFang SC","Microsoft YaHei",Arial,sans-serif;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
button{cursor:pointer;font:inherit}
button:focus,input:focus,select:focus{outline:0}

.lobby-root{position:relative;min-height:100vh;padding-bottom:30px}

/* 背景 */
.lobby-bg{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;background:radial-gradient(ellipse at 50% -10%,rgba(106,76,255,.45),transparent 55%),linear-gradient(180deg,#05060f 0%,#0a0d24 50%,#05070f 100%)}
.lobby-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(108,99,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(108,99,255,.06) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse at center,#000,transparent 75%)}
.lobby-bg-glow{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;mix-blend-mode:screen}
.lobby-bg-glow-1{width:340px;height:340px;left:-90px;top:80px;background:radial-gradient(circle,#5b8dff,transparent 70%)}
.lobby-bg-glow-2{width:380px;height:380px;right:-100px;top:280px;background:radial-gradient(circle,#a855f7,transparent 70%)}
.lobby-bg-glow-3{width:300px;height:300px;left:30%;bottom:-80px;background:radial-gradient(circle,#22d3ee,transparent 70%)}
.lobby-particles{position:absolute;inset:0;overflow:hidden}
.lobby-particles span{position:absolute;top:-10px;width:3px;height:3px;border-radius:50%;background:linear-gradient(180deg,#7dd3fc,#a855f7);box-shadow:0 0 10px #a855f7;opacity:.7;animation:lobbyFloat linear infinite}
@keyframes lobbyFloat{0%{transform:translate3d(0,0,0) rotate(0);opacity:0}10%{opacity:.85}100%{transform:translate3d(40px,110vh,0) rotate(360deg);opacity:0}}

/* 顶栏 */
.lobby-topbar{position:relative;z-index:2;display:flex;align-items:center;gap:10px;max-width:520px;margin:0 auto;padding:14px 16px 8px}
.lobby-brand{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.lobby-logo{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;background:linear-gradient(135deg,#7c3aed 0%,#3b82f6 100%);box-shadow:0 6px 20px rgba(124,58,237,.45),inset 0 0 0 1px rgba(255,255,255,.15);position:relative}
.lobby-logo::after{content:'';position:absolute;inset:-2px;border-radius:14px;background:linear-gradient(135deg,#a855f7,#22d3ee);z-index:-1;opacity:.6;filter:blur(8px)}
.lobby-titles{min-width:0}
.lobby-title{font-size:17px;font-weight:900;color:#fff;letter-spacing:1px;line-height:1.1;background:linear-gradient(90deg,#a5b4fc,#fff,#22d3ee);-webkit-background-clip:text;background-clip:text;color:transparent}
.lobby-subtitle{font-size:9px;color:rgba(165,180,252,.65);letter-spacing:2px;font-weight:600;margin-top:2px}
.lobby-wallet{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,rgba(168,85,247,.18),rgba(34,211,238,.12));border:1px solid rgba(168,85,247,.3);padding:6px 11px 6px 8px;border-radius:14px;cursor:pointer;transition:all .2s}
.lobby-wallet:hover{transform:translateY(-1px);border-color:rgba(168,85,247,.55);box-shadow:0 6px 20px rgba(168,85,247,.25)}
.lobby-wallet-icon{font-size:18px;filter:drop-shadow(0 0 6px rgba(34,211,238,.7))}
.lobby-wallet-label{font-size:9px;color:rgba(165,180,252,.7);letter-spacing:1px}
.lobby-wallet-amount{font-size:14px;font-weight:900;color:#7dd3fc;line-height:1}
.lobby-icon-btn{border:0;width:38px;height:38px;border-radius:50%;background:rgba(124,58,237,.18);color:#c7d2fe;display:flex;align-items:center;justify-content:center;border:1px solid rgba(124,58,237,.32);transition:all .2s}
.lobby-icon-btn:hover{background:rgba(124,58,237,.35);color:#fff}

/* 登录注册 */
.lobby-auth-wrap{position:relative;z-index:2;max-width:420px;margin:0 auto;padding:30px 16px 20px}
.lobby-auth-hero{text-align:center;margin-bottom:24px}
.lobby-auth-emoji{font-size:60px;filter:drop-shadow(0 6px 24px rgba(168,85,247,.6));animation:lobbyBounce 2.4s ease-in-out infinite}
@keyframes lobbyBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.lobby-auth-headline{font-size:24px;font-weight:900;background:linear-gradient(90deg,#a5b4fc,#22d3ee,#a855f7);-webkit-background-clip:text;background-clip:text;color:transparent;margin-top:10px}
.lobby-auth-tagline{margin-top:6px;font-size:13px;color:rgba(165,180,252,.7);letter-spacing:1px}
.lobby-auth-card{background:linear-gradient(180deg,rgba(30,27,75,.8),rgba(15,23,42,.9));border:1px solid rgba(124,58,237,.28);border-radius:22px;padding:20px;backdrop-filter:blur(12px);box-shadow:0 20px 60px rgba(0,0,0,.6),inset 0 0 0 1px rgba(255,255,255,.04)}
.lobby-auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;padding:5px;background:rgba(10,13,36,.7);border-radius:14px;border:1px solid rgba(124,58,237,.18)}
.lobby-auth-tabs button{border:0;border-radius:11px;padding:11px;font-weight:900;font-size:14px;background:transparent;color:rgba(165,180,252,.55);transition:all .25s;letter-spacing:2px}
.lobby-auth-tabs button.active{background:linear-gradient(135deg,#7c3aed,#3b82f6);color:#fff;box-shadow:0 6px 18px rgba(124,58,237,.5)}

/* 表单通用 */
.lobby-form{display:grid;gap:12px}
.lobby-form label{display:grid;gap:5px}
.lobby-form label>span{font-size:12px;color:rgba(165,180,252,.7);font-weight:600;letter-spacing:1px}
.lobby-form input,.lobby-form select{border:1px solid rgba(124,58,237,.25);border-radius:11px;padding:11px 13px;background:rgba(10,13,36,.55);color:#e0e7ff;font-size:14px;transition:all .2s}
.lobby-form input:focus,.lobby-form select:focus{border-color:rgba(124,58,237,.6);box-shadow:0 0 0 3px rgba(124,58,237,.15);background:rgba(10,13,36,.85)}
.lobby-form-btn{margin-top:6px;border:0;border-radius:12px;padding:13px;font-size:15px;font-weight:900;color:#fff;background:linear-gradient(135deg,#a855f7 0%,#3b82f6 60%,#22d3ee 100%);box-shadow:0 8px 24px rgba(124,58,237,.45);letter-spacing:2px;transition:all .25s}
.lobby-form-btn:hover{transform:translateY(-1px);box-shadow:0 12px 32px rgba(124,58,237,.6)}
.lobby-form-btn:active{transform:translateY(0)}

/* 主体 */
.lobby-main{position:relative;z-index:2;max-width:520px;margin:0 auto;padding:6px 16px 0}

/* 用户卡 */
.lobby-user-card{display:flex;align-items:center;gap:12px;padding:14px;border-radius:18px;background:linear-gradient(135deg,rgba(124,58,237,.16),rgba(34,211,238,.08));border:1px solid rgba(124,58,237,.3);box-shadow:0 8px 28px rgba(0,0,0,.45),inset 0 0 0 1px rgba(255,255,255,.03);margin-bottom:14px;backdrop-filter:blur(8px)}
.lobby-avatar{width:50px;height:50px;border-radius:14px;background:linear-gradient(135deg,#f472b6,#a855f7,#3b82f6);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:#fff;flex-shrink:0;box-shadow:0 6px 16px rgba(168,85,247,.45);position:relative}
.lobby-avatar::after{content:'';position:absolute;inset:-2px;border-radius:16px;background:linear-gradient(135deg,#f472b6,#22d3ee);z-index:-1;opacity:.5;filter:blur(8px)}
.lobby-user-info{flex:1;min-width:0}
.lobby-user-name{font-size:16px;font-weight:900;color:#fff;display:flex;align-items:center;gap:6px}
.lobby-user-vip{display:inline-block;font-size:9px;font-weight:900;padding:2px 7px;border-radius:6px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#3b1607;letter-spacing:1px;box-shadow:0 2px 6px rgba(245,158,11,.45)}
.lobby-user-id{font-size:11px;color:rgba(165,180,252,.65);margin-top:3px}
.lobby-user-id b{color:#22d3ee;font-weight:700}
.lobby-quick-actions{display:flex;flex-direction:column;gap:6px}
.lobby-quick-actions button{display:flex;align-items:center;gap:5px;border:0;padding:7px 11px;border-radius:10px;font-size:11px;font-weight:700;letter-spacing:1px;color:#fff;cursor:pointer;transition:all .2s}
.lobby-quick-actions button span{font-size:14px}
.qa-recharge{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 12px rgba(34,197,94,.35)}
.qa-recharge:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(34,197,94,.5)}
.qa-withdraw{background:linear-gradient(135deg,#fb923c,#ea580c);box-shadow:0 4px 12px rgba(234,88,12,.35)}
.qa-withdraw:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(234,88,12,.5)}

/* 公告 */
.lobby-banner{display:flex;align-items:center;gap:12px;padding:14px;border-radius:16px;background:linear-gradient(135deg,#1e1b4b 0%,#581c87 50%,#0e7490 100%);border:1px solid rgba(168,85,247,.4);margin-bottom:18px;box-shadow:0 8px 28px rgba(91,33,182,.4),inset 0 0 0 1px rgba(255,255,255,.05);position:relative;overflow:hidden}
.lobby-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 90% 20%,rgba(34,211,238,.25),transparent 40%);pointer-events:none}
.lobby-banner-icon{font-size:34px;filter:drop-shadow(0 0 12px rgba(251,191,36,.7));animation:lobbyShake 3s ease-in-out infinite}
@keyframes lobbyShake{0%,90%,100%{transform:rotate(0)}93%{transform:rotate(-8deg)}96%{transform:rotate(8deg)}}
.lobby-banner-text{flex:1;min-width:0;position:relative;z-index:1}
.lobby-banner-title{font-size:14px;font-weight:900;color:#fff;margin-bottom:4px;letter-spacing:1px;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.lobby-banner-marquee{overflow:hidden;height:18px}
.lobby-banner-track{font-size:11px;color:rgba(255,255,255,.85);white-space:nowrap;animation:lobbyMarquee 18s linear infinite}
@keyframes lobbyMarquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* 标题 */
.lobby-section-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:900;color:#e6ebff;margin:18px 0 12px;letter-spacing:1px}
.lobby-section-title>span{font-size:18px;filter:drop-shadow(0 0 6px rgba(168,85,247,.6))}
.lobby-section-title>i{flex:1;height:1px;background:linear-gradient(90deg,rgba(168,85,247,.5),transparent)}

/* 游戏卡片 */
.lobby-games{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.lobby-game-card{position:relative;display:flex;flex-direction:column;gap:5px;padding:14px 12px 12px;border-radius:18px;background:linear-gradient(180deg,#1e1b4b 0%,#0a0d24 100%);border:1px solid rgba(124,58,237,.28);text-decoration:none;color:#e6ebff;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.4),inset 0 0 0 1px rgba(255,255,255,.03)}
.lobby-game-card:hover{transform:translateY(-4px) scale(1.015);border-color:rgba(168,85,247,.6);box-shadow:0 16px 36px rgba(124,58,237,.4),0 0 0 1px rgba(168,85,247,.4) inset}
.lobby-game-bg-decor{position:absolute;top:-50%;right:-30%;width:130%;height:130%;background:radial-gradient(circle,rgba(168,85,247,.16),transparent 60%);pointer-events:none;transition:opacity .3s}
.lobby-game-glory .lobby-game-bg-decor{background:radial-gradient(circle,rgba(251,191,36,.18) 0%,rgba(217,70,239,.18) 50%,transparent 75%)}
.lobby-game-speedpeak .lobby-game-bg-decor{background:radial-gradient(circle,rgba(34,197,94,.16),transparent 65%)}
.lobby-game-tsar .lobby-game-bg-decor{background:radial-gradient(circle,rgba(239,68,68,.18),transparent 65%)}
.lobby-game-baccarat .lobby-game-bg-decor{background:radial-gradient(circle,rgba(251,191,36,.22) 0%,rgba(220,38,38,.22) 55%,transparent 80%)}
.lobby-game-coming{opacity:.7;cursor:not-allowed}
.lobby-game-coming .lobby-game-bg-decor{background:radial-gradient(circle,rgba(100,116,139,.18),transparent 65%)}

.lobby-game-badge{position:absolute;top:8px;right:8px;padding:3px 8px;border-radius:7px;font-size:9px;font-weight:900;letter-spacing:1px;z-index:2;color:#fff;line-height:1}
.hot-badge{background:linear-gradient(135deg,#f97316,#dc2626);box-shadow:0 2px 8px rgba(220,38,38,.45);animation:hotPulse 1.6s ease-in-out infinite}
@keyframes hotPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.new-badge{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#3b1607;box-shadow:0 2px 8px rgba(245,158,11,.5)}
.fire-badge{background:linear-gradient(135deg,#ef4444,#b91c1c);box-shadow:0 2px 8px rgba(220,38,38,.5)}
.soon-badge{background:linear-gradient(135deg,#64748b,#475569);box-shadow:0 2px 6px rgba(0,0,0,.3)}

.lobby-game-icon-wrap{display:flex;align-items:center;justify-content:center;height:70px;margin:6px 0 4px;position:relative}
.lobby-game-icon{font-size:46px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.5));transition:transform .3s}
.lobby-game-card:hover .lobby-game-icon{transform:scale(1.1) rotate(-5deg)}
.lobby-game-name{font-size:15px;font-weight:900;text-align:center;color:#fff;letter-spacing:1px;text-shadow:0 0 8px rgba(168,85,247,.4)}
.lobby-game-glory .lobby-game-name{background:linear-gradient(90deg,#fbbf24,#fff,#f472b6);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:none}
.lobby-game-desc{font-size:10px;color:rgba(165,180,252,.65);text-align:center;line-height:1.4;min-height:28px;padding:0 4px}
.lobby-game-meta{display:flex;justify-content:space-between;font-size:9.5px;color:rgba(165,180,252,.55);padding:5px 0;border-top:1px solid rgba(124,58,237,.18);margin-top:3px}
.lobby-game-play{margin-top:6px;display:flex;align-items:center;justify-content:center;gap:5px;border-radius:10px;padding:8px;font-size:12px;font-weight:900;color:#fff;background:linear-gradient(135deg,#7c3aed,#3b82f6);box-shadow:0 4px 12px rgba(124,58,237,.4);transition:all .3s;letter-spacing:1px}
.lobby-game-glory .lobby-game-play{background:linear-gradient(135deg,#fbbf24,#f97316,#ec4899)}
.lobby-game-speedpeak .lobby-game-play{background:linear-gradient(135deg,#22c55e,#16a34a)}
.lobby-game-tsar .lobby-game-play{background:linear-gradient(135deg,#ef4444,#b91c1c)}
.lobby-game-baccarat .lobby-game-play{background:linear-gradient(135deg,#fbbf24,#dc2626)}
.lobby-game-baccarat .lobby-game-name{background:linear-gradient(90deg,#fbbf24,#fff,#dc2626);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:none}
.lobby-game-play.disabled{background:linear-gradient(135deg,#475569,#334155);cursor:not-allowed}
.lobby-game-card:hover .lobby-game-play:not(.disabled){box-shadow:0 8px 22px rgba(124,58,237,.6);transform:translateY(-1px)}
.lobby-game-play i{font-style:normal;font-size:10px}

/* 底部操作 */
.lobby-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}
.lobby-actions button,.lobby-action-link{display:flex;flex-direction:column;align-items:center;gap:4px;border:0;background:rgba(30,27,75,.55);color:rgba(165,180,252,.85);padding:11px 6px;border-radius:13px;font-size:11px;font-weight:700;text-decoration:none;text-align:center;border:1px solid rgba(124,58,237,.18);transition:all .2s}
.lobby-actions button>span,.lobby-action-link>span{font-size:18px}
.lobby-actions button:hover,.lobby-action-link:hover{background:rgba(124,58,237,.2);color:#e0e7ff;border-color:rgba(168,85,247,.4);transform:translateY(-1px)}
.lobby-footer{margin-top:24px;text-align:center;font-size:11px;color:rgba(165,180,252,.4);letter-spacing:1px}

/* Modal */
.lobby-modal-mask{position:fixed;inset:0;z-index:50;background:rgba(2,4,18,.78);backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center}
.lobby-bottom-sheet{width:100%;max-width:520px;max-height:84vh;overflow-y:auto;border-radius:24px 24px 0 0;background:linear-gradient(180deg,#161331 0%,#0a0d24 100%);border-top:1px solid rgba(168,85,247,.45);padding:18px 18px 26px;position:relative;box-shadow:0 -16px 48px rgba(0,0,0,.6)}
.lobby-bottom-sheet h3{margin:0 0 14px;font-size:16px;color:#fff;font-weight:900;letter-spacing:1px}
.lobby-close{position:absolute;top:10px;right:12px;width:32px;height:32px;border:0;border-radius:50%;background:rgba(124,58,237,.18);color:#c7d2fe;font-size:20px;line-height:1}
.lobby-menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.lobby-menu-grid button,.lobby-menu-link{display:flex;flex-direction:column;align-items:center;gap:6px;border:0;background:rgba(124,58,237,.12);color:#e0e7ff;padding:14px;border-radius:14px;font-size:12px;font-weight:700;text-decoration:none;border:1px solid rgba(124,58,237,.22)}
.lobby-menu-grid button>span,.lobby-menu-link>span{font-size:24px}
.lobby-logout-btn{width:100%;margin-top:14px;border:0;background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff;padding:12px;border-radius:12px;font-weight:900;letter-spacing:2px;box-shadow:0 4px 14px rgba(239,68,68,.35)}

.lobby-amount-presets{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:12px}
.lobby-amount-presets button{border:1px solid rgba(124,58,237,.3);background:rgba(124,58,237,.1);color:#c7d2fe;padding:7px 0;border-radius:9px;font-weight:700;font-size:11px}
.lobby-amount-presets button.active{background:linear-gradient(135deg,#a855f7,#3b82f6);color:#fff;border-color:transparent;box-shadow:0 3px 10px rgba(168,85,247,.4)}

.lobby-balance-tip{font-size:13px;color:rgba(165,180,252,.7);margin:0 0 10px}
.lobby-balance-tip b{color:#22d3ee;font-weight:900;font-size:15px}
.lobby-list-title{margin:14px 0 6px;font-size:12px;color:rgba(165,180,252,.6);font-weight:700;letter-spacing:1px}
.lobby-empty{text-align:center;padding:14px 0;color:rgba(165,180,252,.4);font-size:12px}
.lobby-history-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;background:rgba(10,13,36,.55);border:1px solid rgba(124,58,237,.15);border-radius:10px;font-size:12px;color:#c7d2fe;margin-bottom:5px}
.lobby-history-item .lobby-history-no,.lobby-history-item .lobby-history-time{color:rgba(165,180,252,.55);font-size:11px;flex:0 0 auto}
.lobby-history-item .lobby-history-amt,.lobby-history-item .lobby-history-bet{color:#e0e7ff}
.lobby-history-game{display:inline-block;padding:2px 7px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.5px}
.lhg-speedpeak{background:rgba(34,197,94,.16);color:#86efac}
.lhg-tsar{background:rgba(239,68,68,.16);color:#fca5a5}
.lhg-glory{background:rgba(251,191,36,.16);color:#fcd34d}
.lobby-st-pending{color:#fbbf24}
.lobby-st-approved{color:#22c55e}
.lobby-st-rejected{color:#ef4444}
.lobby-win{color:#22c55e;font-weight:900}
.lobby-lose{color:rgba(165,180,252,.5)}

.lobby-fade-enter-active,.lobby-fade-leave-active{transition:all .25s}
.lobby-fade-enter,.lobby-fade-leave-to{opacity:0}
.lobby-fade-enter .lobby-bottom-sheet,.lobby-fade-leave-to .lobby-bottom-sheet{transform:translateY(40px)}

/* Toast */
.lobby-toast{position:fixed;left:50%;bottom:60px;transform:translateX(-50%);z-index:99;padding:11px 22px;border-radius:14px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-weight:700;font-size:13px;letter-spacing:1px;box-shadow:0 10px 30px rgba(34,197,94,.4);animation:lobbyToastIn .25s ease-out}
.lobby-toast.error{background:linear-gradient(135deg,#ef4444,#b91c1c);box-shadow:0 10px 30px rgba(239,68,68,.4)}
@keyframes lobbyToastIn{0%{opacity:0;transform:translate(-50%,20px)}100%{opacity:1;transform:translate(-50%,0)}}

@media (max-width:360px){
  .lobby-games{grid-template-columns:1fr 1fr}
  .lobby-game-icon{font-size:38px}
  .lobby-game-name{font-size:14px}
}
