@charset "utf-8";

* { box-sizing: border-box; margin: 0px; padding: 0px; -webkit-tap-highlight-color: transparent; }

:root { --bg: #06060e; --c1: #0e0e1a; --c2: #161628; --c3: #1e1e38; --border: rgba(255,255,255,0.06); --text: #e8e6f0; --dim: #706e88; --accent: #ff6b35; --accent2: #ff9f1c; --red: #ff4444; --green: #2dd4bf; --gold: #ffd700; --blue: #64b5f6; --purple: #b388ff; --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', sans-serif; --title: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', sans-serif; --impact: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', sans-serif; --fz-xs: 0.5rem; --fz-sm: 0.56rem; --fz-md: 0.62rem; --fz-lg: 0.72rem; --fz-xl: 0.9rem; --fz-2xl: 1.08rem; --space-xs: 0.18rem; --space-sm: 0.3rem; --space-md: 0.45rem; --space-lg: 0.6rem; --space-xl: 0.8rem; --radius-sm: 0.5rem; --radius-md: 0.8rem; --radius-lg: 1rem; --btn-h-sm: 1.72rem; --btn-h-md: 2rem; --btn-h-lg: 2.28rem; }

html, body { height: 100%; overflow: hidden; background: var(--bg); color: var(--text); font-family: var(--font); font-size: 16px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }

.hub-body,
#gacha,
.formation-scene,
.result-scene,
.r-scroll,
#charDetail,
.syn-detail-box {
  scrollbar-width: none;
  -ms-overflow-style: none;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

.hub-body::-webkit-scrollbar,
#gacha::-webkit-scrollbar,
.formation-scene::-webkit-scrollbar,
.result-scene::-webkit-scrollbar,
.r-scroll::-webkit-scrollbar,
#charDetail::-webkit-scrollbar,
.syn-detail-box::-webkit-scrollbar {
  width: 0;
  height: 0;
  display: none;
}

#game-wrapper { position: relative; width: 100%; height: 100%; margin: 0 auto; overflow: hidden; }

@media (min-width: 600px) {
  body { display: flex; justify-content: center; align-items: center; background: #020208; }
  #game-wrapper { max-width: 480px; max-height: 100vh; height: 100%; border-left: 1px solid rgba(255,255,255,0.06); border-right: 1px solid rgba(255,255,255,0.06); background: var(--bg); box-shadow: 0 0 36px rgba(0,0,0,0.22); }
  html { font-size: 16px; }
}
@media (min-width: 900px) {
  #game-wrapper { max-width: 520px; }
  html { font-size: 17px; }
}
@media (min-width: 1200px) {
  #game-wrapper { max-width: 560px; }
  html { font-size: 18px; }
}
@media (min-width: 1600px) {
  #game-wrapper { max-width: 600px; }
  html { font-size: 19px; }
}

button { font-family: var(--font); border: none; outline: none; cursor: pointer; }

img { display: block; }

.screen { position: absolute; inset: 0px; display: none; flex-direction: column; overflow: hidden; }

.screen.active { display: flex; }

@keyframes fadeIn {
  0% { opacity: 0; }
  100% { opacity: 1; }
}

@keyframes starBurst { 0% { transform: scale(0.3); opacity: 0; } 50% { transform: scale(1.2); opacity: 1; } 100% { transform: scale(1); opacity: 1; } }
@keyframes awakenBurst { 0% { transform: scale(0.2); opacity: 0; } 30% { transform: scale(1.15); opacity: 1; } 50% { transform: scale(0.95); } 70% { transform: scale(1.05); } 100% { transform: scale(1); opacity: 1; } }
@keyframes awakenPortrait { 0% { transform: scale(0) rotate(-180deg); box-shadow: 0 0 0 #ff6b35; } 50% { transform: scale(1.3) rotate(10deg); box-shadow: 0 0 60px #ff6b35; } 100% { transform: scale(1) rotate(0deg); box-shadow: 0 0 40px #ff6b35,0 0 80px #ff6b3550; } }
@keyframes awakenRing { 0% { transform: scale(0.5); opacity: 0; border-width: 6px; } 50% { transform: scale(1.8); opacity: 1; } 100% { transform: scale(2.5); opacity: 0; border-width: 1px; } }
@keyframes awakenGlow { 0% { opacity: 0; transform: translateY(20px); } 40% { opacity: 1; transform: translateY(-5px); } 100% { opacity: 1; transform: translateY(0); } }

@keyframes glowPulse { 
  0%, 100% { box-shadow: rgba(255, 107, 53, 0.3) 0px 0px 8px; }
  50% { box-shadow: rgba(255, 107, 53, 0.7) 0px 0px 22px; }
}

@keyframes mainlineBreath {
  0%, 100% { box-shadow: 0 12px 28px rgba(0,0,0,0.2), 0 0 0 rgba(255,168,92,0); }
  50% { box-shadow: 0 12px 28px rgba(0,0,0,0.2), 0 0 8px rgba(255,168,92,0.08); }
}

@keyframes mainlineGlow {
  0%, 100% { opacity: 0.72; }
  50% { opacity: 1; }
}

@keyframes mainlineBorderBreath {
  0%, 100% { border-color: rgba(255,152,74,0.24); }
  50% { border-color: rgba(255,202,138,0.44); }
}

@keyframes mainlineBorderAura {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,184,110,0); opacity: 0.4; }
  50% { box-shadow: 0 0 0 3px rgba(255,184,110,0.08), 0 0 14px rgba(255,184,110,0.12); opacity: 0.9; }
}

@keyframes mainlineSweep {
  0% { transform: translateX(-160%) skewX(-20deg); opacity: 0; }
  18% { opacity: 0.0; }
  32% { opacity: 0.22; }
  52% { opacity: 0.08; }
  100% { transform: translateX(220%) skewX(-20deg); opacity: 0; }
}

.star-up-badge { position: absolute; top: 2px; right: 2px; background: linear-gradient(135deg, rgb(255, 215, 0), rgb(255, 159, 28)); color: rgb(0, 0, 0); font-size: 0.38rem; font-weight: 900; padding: 1px 4px; border-radius: 6px; animation: 1.5s ease 0s infinite normal none running glowPulse; z-index: 2; }

@keyframes popIn { 
  0% { transform: scale(0.5); opacity: 0; }
  60% { transform: scale(1.15); }
  100% { transform: scale(1); opacity: 1; }
}

@keyframes hitShake { 
  0%, 100% { transform: translateX(0px); }
  25% { transform: translateX(-5px); }
  75% { transform: translateX(5px); }
}

@keyframes rageGlow {
  0%, 100% { filter: brightness(1); }
  50% { filter: brightness(1.5); }
}
@keyframes pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(255,107,107,0.4); }
  50% { transform: scale(1.05); box-shadow: 0 0 12px 4px rgba(255,107,107,0.3); }
}

@keyframes ultFlash { 
  0% { opacity: 0; }
  15% { opacity: 1; }
  100% { opacity: 0; }
}

@keyframes ssrShimmer { 
  0% { left: -100%; }
  100% { left: 200%; }
}

@keyframes floatDmg { 
  0% { opacity: 1; transform: translateY(0px) scale(0.8); }
  10% { transform: translateY(-5px) scale(1.4); }
  60% { opacity: 0.9; }
  100% { opacity: 0; transform: translateY(-70px) scale(1); }
}

@keyframes floatHeal { 
  0% { opacity: 1; transform: translateY(0px) scale(0.8); }
  100% { opacity: 0; transform: translateY(-40px) scale(1.1); }
}

@keyframes dashAtk { 
  0% { transform: translate(0px, 0px); }
  40% { transform: translate(var(--dx),var(--dy)); }
  60% { transform: translate(var(--dx),var(--dy)); }
  100% { transform: translate(0px, 0px); }
}

@keyframes skillBurst { 
  0% { transform: scale(0); opacity: 1; }
  50% { transform: scale(2); opacity: 0.5; }
  100% { transform: scale(3.5); opacity: 0; }
}

@keyframes screenShake { 
  0%, 100% { transform: translate(0px); }
  10% { transform: translate(-6px, 3px); }
  30% { transform: translate(6px, -3px); }
  50% { transform: translate(-4px, 5px); }
  70% { transform: translate(4px, -5px); }
  90% { transform: translate(-2px, 2px); }
}

@keyframes impactRing { 
  0% { transform: scale(0); opacity: 0.9; border-width: 4px; }
  100% { transform: scale(3.5); opacity: 0; border-width: 1px; }
}

@keyframes slashFx { 
  0% { transform: scaleX(0) rotate(-25deg); opacity: 1; }
  50% { transform: scaleX(1) rotate(-25deg); opacity: 0.7; }
  100% { transform: scaleX(1.5) rotate(-25deg); opacity: 0; }
}

@keyframes battleStart { 
  0% { transform: scale(2) rotate(-5deg); opacity: 0; }
  25% { transform: scale(1) rotate(0deg); opacity: 1; }
  75% { opacity: 1; }
  100% { transform: scale(0.8); opacity: 0; }
}

@keyframes skillBannerIn { 
  0% { transform: translateX(-120%) scaleY(0.2); opacity: 0; }
  15% { transform: translateX(0px) scaleY(1); opacity: 1; }
  80% { opacity: 1; }
  100% { transform: translateX(120%) scaleY(0.2); opacity: 0; }
}

@keyframes ultGlow { 
  0% { transform: translate(-50%, -50%) scale(0); opacity: 0; }
  30% { transform: translate(-50%, -50%) scale(1.5); opacity: 1; }
  100% { transform: translate(-50%, -50%) scale(2.5); opacity: 0; }
}

@keyframes rageBorder { 
  0%, 100% { opacity: 0.3; }
  50% { opacity: 1; }
}

@keyframes gachaReveal { 
  0% { transform: scale(0) rotate(-180deg); opacity: 0; }
  60% { transform: scale(1.2) rotate(10deg); }
  100% { transform: scale(1) rotate(0deg); opacity: 1; }
}

.anim-in { animation: 0.3s ease 0s 1 normal none running fadeIn; }

#title { background: radial-gradient(ellipse at 50% 20%,rgba(255,107,53,0.14),transparent 55%),radial-gradient(ellipse at 50% 82%,rgba(100,181,246,0.08),transparent 42%),var(--bg); align-items: center; justify-content: center; text-align: center; gap: 1rem; padding: 1.6rem; overflow:hidden; }
.auto-entering #title { opacity: 0.96; }
.auto-entering .t-btn { opacity: 0.7; pointer-events: none; }

.t-stage { font-size: 0.56rem; letter-spacing: 0.22em; color: var(--gold); text-transform: uppercase; }

.t-logo-wrap { display:grid; gap:0.18rem; justify-items:center; }

.t-logo-mark { display:inline-flex; align-items:center; min-height:0.9rem; padding:0 0.38rem; border-radius:999px; border:1px solid rgba(255,255,255,0.08); background:rgba(255,255,255,0.03); color:#d9c08e; font-size:0.38rem; font-weight:700; letter-spacing:0.12em; }

.t-logo { font-family: var(--font); font-size: 2.6rem; line-height: 1.04; letter-spacing: 0.06em; font-weight: 900; background: linear-gradient(135deg, rgb(255, 250, 236), rgb(255, 186, 96), rgb(255, 215, 0)) text; -webkit-text-fill-color: transparent; filter: drop-shadow(rgba(255, 107, 53, 0.2) 0px 3px 8px); }

.t-sub { font-size: 0.7rem; color: #b4c1d8; letter-spacing: 0.16em; max-width: 16rem; line-height: 1.8; }

.t-world { width:100%; max-width:22rem; padding:0.85rem; border-radius:1rem; border:1px solid rgba(255,255,255,0.08); background:linear-gradient(180deg,rgba(10,13,22,0.9),rgba(14,14,26,0.94)); box-shadow:0 10px 26px rgba(0,0,0,0.22); position:relative; overflow:hidden; }
.t-world::before { content:""; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,215,0,0.04),transparent 38%,rgba(100,181,246,0.04)); pointer-events:none; }
.t-world-top { display:flex; align-items:center; justify-content:space-between; gap:0.6rem; position:relative; z-index:1; }
.t-world-name { font-size:0.95rem; font-weight:900; color:#fff5dc; }
.t-world-desc { font-size:0.46rem; color:var(--dim); margin-top:0.12rem; }
.t-world-badge { padding:0.2rem 0.5rem; border-radius:999px; background:rgba(255,215,0,0.12); color:var(--gold); font-size:0.46rem; font-weight:800; }
.t-chars { display: flex; gap: 0.45rem; justify-content: center; flex-wrap: wrap; max-width: 320px; margin-top:0.8rem; position:relative; z-index:1; }

.t-char-img { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(255,255,255,0.1); opacity: 0.88; box-shadow:0 4px 10px rgba(0,0,0,0.18); }

.t-btn { background: linear-gradient(135deg,var(--accent),#e85d04); color: rgb(255, 255, 255); font-size: 1rem; font-weight: 800; padding: 0.9rem 3.2rem; border-radius: 50px; animation: 2s ease 0s infinite normal none running glowPulse; margin-top: 0.4rem; box-shadow:0 8px 18px rgba(255,107,53,0.2); }
.t-enter-tip { font-size:0.46rem; color:var(--dim); letter-spacing:0.08em; }

#hub { background: var(--bg); }
.hub-shell { display:flex; flex-direction:column; min-height:100%; }
.hub-hero { padding:0.54rem 0.68rem 0.42rem; background:linear-gradient(180deg,rgba(20,20,34,0.96),rgba(11,11,20,0.95)); border-bottom:1px solid var(--border); position:relative; overflow:hidden; }
.hub-hero::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 20% 0%,rgba(255,215,0,0.04),transparent 26%),radial-gradient(circle at 82% 0%,rgba(100,181,246,0.05),transparent 24%); pointer-events:none; }
.hub-hero-top { display:flex; justify-content:space-between; align-items:center; gap:0.5rem; position:relative; z-index:1; }
.hub-stage-wrap { min-width:0; }
.hub-stage-label { font-size:0.46rem; color:var(--gold); letter-spacing:0.2em; text-transform:uppercase; }
.hub-stage { font-family: var(--font); font-size: 0.98rem; font-weight:900; color: #fff4dd; margin-top:0.08rem; }
.hub-stage-sub { font-size:0.46rem; color:#9fb0c8; margin-top:0.12rem; }
.hub-res { display:flex; align-items:center; justify-content:flex-end; gap:0.18rem; font-size:0.5rem; font-weight:800; text-align:right; flex:0 0 auto; }
.hub-res span { display:inline-flex; align-items:center; justify-content:center; gap:0.16rem; min-width:2.52rem; padding:0.18rem 0.34rem; border-radius:999px; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.05); }
.hub-res b { font-size:0.5rem; line-height:1; color:#fff3dd; font-weight:900; }
.hub-currency-icon { display:inline-flex; align-items:center; justify-content:center; width:0.66rem; height:0.66rem; color:currentColor; }
.hub-currency-icon svg { width:100%; height:100%; stroke:currentColor; fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.hub-currency-icon img { width:100%; height:100%; display:block; object-fit:contain; }
.hub-currency-icon.gold { color:#ffcb54; }
.hub-currency-icon.gem { color:#7fd8ff; }
.hub-currency-icon.yuanbao { width:0.72rem; height:0.72rem; }
.hub-quick { display:grid; grid-template-columns:repeat(3,1fr); gap:0.35rem; margin-top:0.6rem; position:relative; z-index:1; }
.hub-quick-card { padding:0.5rem 0.42rem; border-radius:var(--radius-md); background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.02)); border:1px solid rgba(255,255,255,0.06); text-align:center; }
.hub-quick-value { font-size:0.58rem; font-weight:900; color:#fff; }
.hub-quick-label { font-size:0.48rem; color:var(--dim); margin-top:0.06rem; }
.hub-body { flex: 1 1 0%; overflow-y: auto; overflow-x: hidden; padding: 0.54rem 0.54rem 6.8rem; background:linear-gradient(180deg,rgba(7,7,13,0.75),transparent 20%); }
.hub-subnav { display:flex; gap:0.35rem; padding:0.35rem 0.5rem 0.15rem; background:rgba(10,10,18,0.92); overflow-x:auto; }
.hub-subbtn { flex:0 0 auto; padding:0.34rem 0.62rem; border-radius:999px; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.03); color:var(--dim); font-size:0.5rem; font-weight:700; }
.hub-subbtn.active { color:#fff6e4; border-color:rgba(255,215,0,0.2); background:rgba(255,215,0,0.08); }
.hub-bottom-nav { position:absolute; left:0; right:0; bottom:0; z-index:8; display:grid; grid-template-columns:repeat(5,1fr); gap:0; padding:0.16rem 0 calc(0.2rem + env(safe-area-inset-bottom)); background:linear-gradient(180deg,rgba(15,15,24,0.96),rgba(8,8,14,0.99)); border-top:1px solid rgba(255,255,255,0.08); box-shadow:0 -8px 20px rgba(0,0,0,0.28); }
.hub-nav-item { min-width:0; padding:0.18rem 0.08rem 0.12rem; text-align:center; color:#8d8ba5; background:transparent; border:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.18rem; position:relative; }
.hub-nav-item.active { color:#fff4dd; }
.hub-nav-item.active::before { content:""; position:absolute; top:0; left:50%; width:1.45rem; height:2px; transform:translateX(-50%); border-radius:999px; background:#ffb14a; }
.hub-nav-icon { display:grid; place-items:center; width:1.5rem; height:1.5rem; margin:0 auto; color:currentColor; }
.hub-nav-icon svg { width:1.26rem; height:1.26rem; stroke:currentColor; fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round; }
.hub-nav-icon svg circle { stroke:currentColor; fill:none; }
.hub-nav-item.active .hub-nav-icon { color:#ffb14a; }
.hub-nav-label { display:block; margin-top:0; font-size:0.62rem; font-weight:900; line-height:1.15; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; letter-spacing:0.01em; }
.feature-scene-banner { margin-bottom:0.38rem; }
.feature-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.38rem; }
.feature-panel { padding:0.42rem; }
.feature-card { width:100%; text-align:left; padding:0.72rem; border-radius:0.52rem; border:1px solid rgba(255,255,255,0.06); background:linear-gradient(180deg,rgba(22,22,34,0.98),rgba(11,11,18,0.99)); color:var(--text); display:flex; align-items:center; box-shadow:0 8px 20px rgba(0,0,0,0.16); position:relative; overflow:hidden; }
.feature-card::before { content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(circle at 100% 0%,rgba(255,177,74,0.12),transparent 30%); opacity:0.9; }
.feature-card-alert-dot { position:absolute; top:0.28rem; right:0.28rem; width:0.56rem; height:0.56rem; border-radius:50%; background:radial-gradient(circle at 32% 28%,#ffd4d4 0%,#ff7777 26%,#ff3b3b 58%,#d91717 100%); border:2px solid #fff4e8; box-shadow:0 0 0 2px rgba(255,70,70,0.12),0 4px 12px rgba(90,0,0,0.3); z-index:2; animation:alertDotPulse 1.9s ease-in-out infinite; }
.feature-card-alert-dot::after { content:''; position:absolute; top:0.08rem; left:0.11rem; width:0.18rem; height:0.11rem; border-radius:999px; background:rgba(255,255,255,0.84); transform:rotate(-18deg); }
.feature-card-alert-dot::before { content:''; position:absolute; inset:-0.08rem; border-radius:50%; border:1px solid rgba(255,144,144,0.48); opacity:0; animation:alertDotRing 1.9s ease-out infinite; }
.feature-card.is-arena { border-color:rgba(88,176,255,0.16); background:linear-gradient(180deg,rgba(18,26,42,0.98),rgba(10,14,24,0.99)); }
.feature-card.is-arena::before { background:radial-gradient(circle at 100% 0%,rgba(88,176,255,0.16),transparent 34%); }
.feature-card.is-boss { border-color:rgba(255,122,72,0.18); background:linear-gradient(180deg,rgba(35,19,18,0.98),rgba(17,10,10,0.99)); }
.feature-card.is-boss::before { background:radial-gradient(circle at 100% 0%,rgba(255,122,72,0.18),transparent 34%); }
.feature-card.is-mainline { border-color:rgba(255,152,74,0.2); background:linear-gradient(180deg,rgba(39,23,17,0.98),rgba(18,12,10,0.99)); }
.feature-card.is-mainline::before { background:radial-gradient(circle at 100% 0%,rgba(255,152,74,0.18),transparent 34%); }
.feature-card.is-signin { border-color:rgba(255,206,101,0.18); background:linear-gradient(180deg,rgba(38,30,16,0.98),rgba(18,14,8,0.99)); }
.feature-card.is-signin::before { background:radial-gradient(circle at 100% 0%,rgba(255,206,101,0.16),transparent 34%); }
.feature-card.is-daily { border-color:rgba(73,206,158,0.18); background:linear-gradient(180deg,rgba(16,31,26,0.98),rgba(9,17,15,0.99)); }
.feature-card.is-daily::before { background:radial-gradient(circle at 100% 0%,rgba(73,206,158,0.16),transparent 34%); }
.feature-card.is-trial { border-color:rgba(103,198,255,0.18); background:linear-gradient(180deg,rgba(15,27,38,0.98),rgba(9,15,22,0.99)); }
.feature-card.is-trial::before { background:radial-gradient(circle at 100% 0%,rgba(103,198,255,0.16),transparent 34%); }
.feature-card.is-rank { border-color:rgba(126,154,255,0.16); background:linear-gradient(180deg,rgba(20,22,40,0.98),rgba(11,13,24,0.99)); }
.feature-card.is-rank::before { background:radial-gradient(circle at 100% 0%,rgba(126,154,255,0.16),transparent 34%); }
.feature-card.is-vip { border-color:rgba(255,210,106,0.18); background:linear-gradient(180deg,rgba(39,29,15,0.98),rgba(18,13,8,0.99)); }
.feature-card.is-vip::before { background:radial-gradient(circle at 100% 0%,rgba(255,210,106,0.18),transparent 34%); }
.feature-card.is-system::before { background:radial-gradient(circle at 100% 0%,rgba(138,166,255,0.12),transparent 32%); }
.feature-card-main { position:relative; z-index:1; display:flex; align-items:center; gap:0.5rem; width:100%; min-width:0; }
.feature-card-icon { width:2.1rem; height:2.1rem; display:grid; place-items:center; border-radius:0.48rem; background:linear-gradient(180deg,rgba(255,177,74,0.14),rgba(255,255,255,0.02)); color:#ffb14a; border:1px solid rgba(255,177,74,0.14); }
.feature-card.is-arena .feature-card-icon { background:linear-gradient(180deg,rgba(88,176,255,0.16),rgba(255,255,255,0.02)); color:#66b7ff; border-color:rgba(88,176,255,0.18); }
.feature-card.is-boss .feature-card-icon { background:linear-gradient(180deg,rgba(255,122,72,0.18),rgba(255,255,255,0.02)); color:#ff9a62; border-color:rgba(255,122,72,0.2); }
.feature-card.is-mainline .feature-card-icon { background:linear-gradient(180deg,rgba(255,152,74,0.18),rgba(255,255,255,0.02)); color:#ffb067; border-color:rgba(255,152,74,0.2); }
.feature-card.is-signin .feature-card-icon { background:linear-gradient(180deg,rgba(255,206,101,0.18),rgba(255,255,255,0.02)); color:#ffd26c; border-color:rgba(255,206,101,0.2); }
.feature-card.is-rank .feature-card-icon { background:linear-gradient(180deg,rgba(126,154,255,0.16),rgba(255,255,255,0.02)); color:#9eb6ff; border-color:rgba(126,154,255,0.18); }
.feature-card.is-vip .feature-card-icon { background:linear-gradient(180deg,rgba(255,210,106,0.18),rgba(255,255,255,0.02)); color:#ffd46f; border-color:rgba(255,210,106,0.2); }
.feature-card.is-daily .feature-card-icon { background:linear-gradient(180deg,rgba(73,206,158,0.18),rgba(255,255,255,0.02)); color:#63e2b4; border-color:rgba(73,206,158,0.2); }
.feature-card.is-trial .feature-card-icon { background:linear-gradient(180deg,rgba(103,198,255,0.18),rgba(255,255,255,0.02)); color:#74d5ff; border-color:rgba(103,198,255,0.2); }
.feature-card-icon svg { width:1.28rem; height:1.28rem; stroke:currentColor; fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round; }
.feature-card-copy { min-width:0; flex:1 1 auto; }
.feature-card-top { display:flex; align-items:center; gap:0.24rem; min-width:0; }
.feature-card-title { font-size:0.84rem; font-weight:900; color:#fff6e4; line-height:1.15; margin-top:0.04rem; }
.feature-card-tag { flex:0 0 auto; padding:0.12rem 0.3rem; border-radius:999px; background:rgba(255,177,74,0.12); color:#ffb14a; font-size:0.48rem; font-weight:800; }
.feature-card.is-arena .feature-card-tag { background:rgba(88,176,255,0.14); color:#72beff; }
.feature-card.is-boss .feature-card-tag { background:rgba(255,122,72,0.14); color:#ff9b67; }
.feature-card.is-mainline .feature-card-tag { background:rgba(255,152,74,0.14); color:#ffbe7c; }
.feature-card.is-signin .feature-card-tag { background:rgba(255,206,101,0.14); color:#ffe08f; }
.feature-card.is-rank .feature-card-tag { background:rgba(126,154,255,0.14); color:#b3c3ff; }
.feature-card.is-vip .feature-card-tag { background:rgba(255,210,106,0.14); color:#ffd979; }
.feature-card.is-daily .feature-card-tag { background:rgba(73,206,158,0.14); color:#7ef2c5; }
.feature-card.is-trial .feature-card-tag { background:rgba(103,198,255,0.14); color:#9be4ff; }
.feature-card-sub { margin-top:0.12rem; font-size:0.52rem; color:#b1bfd3; line-height:1.45; }
.feature-card-go { flex:0 0 auto; padding:0.16rem 0.34rem; border-radius:999px; background:rgba(255,255,255,0.05); font-size:0.6rem; font-weight:800; color:#fff2d8; white-space:nowrap; }
.feature-card.is-arena .feature-card-go { background:rgba(88,176,255,0.12); color:#dff1ff; }
.feature-card.is-boss .feature-card-go { background:rgba(255,122,72,0.12); color:#fff0e4; }
.feature-card.is-mainline .feature-card-go { background:rgba(255,152,74,0.12); color:#fff1e3; }
.feature-card.is-signin .feature-card-go { background:rgba(255,206,101,0.12); color:#fff7dd; }
.feature-card.is-rank .feature-card-go { background:rgba(126,154,255,0.12); color:#eef2ff; }
.feature-card.is-vip .feature-card-go { background:rgba(255,210,106,0.12); color:#fff4d0; }
.feature-card.is-daily .feature-card-go { background:rgba(73,206,158,0.12); color:#effff8; }
.feature-card.is-trial .feature-card-go { background:rgba(103,198,255,0.12); color:#eefaff; }

.daily-panel { padding:0.42rem; display:grid; gap:0.42rem; }
.daily-summary { padding:0.65rem 0.7rem; border-radius:0.56rem; border:1px solid rgba(73,206,158,0.14); background:linear-gradient(180deg,rgba(18,35,31,0.96),rgba(10,18,17,0.98)); }
.daily-summary-main { display:flex; align-items:flex-end; justify-content:space-between; gap:0.5rem; }
.daily-summary-label { font-size:0.5rem; color:#90ceb9; letter-spacing:0.08em; }
.daily-summary-value { font-size:1.1rem; font-weight:900; color:#f1fff9; }
.daily-summary-value span { font-size:0.54rem; color:#84baa8; margin-left:0.08rem; }
.daily-summary-sub { margin-top:0.16rem; font-size:0.5rem; color:#9fb0c8; line-height:1.5; }
.daily-activity-track { display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:0.24rem; }
.daily-activity-node { padding:0.34rem 0.28rem; border-radius:0.46rem; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.02); }
.daily-activity-node.reached { border-color:rgba(255,196,90,0.2); background:linear-gradient(180deg,rgba(48,35,19,0.96),rgba(20,15,10,0.98)); }
.daily-activity-node.claimed { border-color:rgba(73,206,158,0.18); background:linear-gradient(180deg,rgba(17,35,29,0.96),rgba(9,18,16,0.98)); }
.daily-activity-node-top { display:flex; align-items:center; justify-content:space-between; gap:0.24rem; }
.daily-activity-node-top strong { font-size:0.7rem; color:#fff2d5; }
.daily-activity-state { font-size:0.46rem; color:#a8b2c8; }
.daily-activity-state.claimed { color:#74e7bd; font-weight:800; }
.daily-activity-state.locked { color:#cdb27a; font-weight:800; }
.daily-activity-reward { margin-top:0.14rem; display:grid; gap:0.08rem; font-size:0.45rem; color:#aeb9cd; line-height:1.35; }
.daily-section-title { font-size:0.64rem; font-weight:900; color:#fff0d9; }
.daily-task-list { display:grid; gap:0.28rem; }
.daily-task-row { display:flex; align-items:center; gap:0.34rem; padding:0.48rem 0.5rem; border-radius:0.52rem; border:1px solid rgba(255,255,255,0.06); background:linear-gradient(180deg,rgba(20,20,32,0.98),rgba(11,11,18,0.99)); }
.daily-task-row.ready { border-color:rgba(255,196,90,0.18); background:linear-gradient(180deg,rgba(34,28,18,0.98),rgba(16,13,10,0.99)); }
.daily-task-row.claimed { border-color:rgba(73,206,158,0.18); background:linear-gradient(180deg,rgba(17,31,27,0.98),rgba(10,17,15,0.99)); }
.daily-task-main { flex:1 1 auto; min-width:0; }
.daily-task-title { display:flex; align-items:center; gap:0.22rem; flex-wrap:wrap; font-size:0.7rem; font-weight:900; color:#fff6e4; }
.daily-task-point { display:inline-flex; align-items:center; padding:0.1rem 0.24rem; border-radius:999px; background:rgba(255,196,90,0.12); color:#ffcb75; font-size:0.44rem; font-weight:800; }
.daily-task-desc { margin-top:0.08rem; font-size:0.5rem; color:#aab8cc; line-height:1.45; }
.daily-task-progress { margin-top:0.18rem; height:0.22rem; border-radius:999px; background:rgba(255,255,255,0.05); overflow:hidden; }
.daily-task-progress-fill { height:100%; border-radius:999px; background:linear-gradient(90deg,#61dfb3,#ffcc74); }
.daily-task-side { flex:0 0 auto; display:grid; gap:0.16rem; justify-items:end; }
.daily-task-state { min-width:2.3rem; text-align:center; padding:0.22rem 0.38rem; border-radius:999px; background:rgba(255,255,255,0.05); color:#d9e0ee; font-size:0.5rem; font-weight:800; }
.daily-task-state.claimed { background:rgba(73,206,158,0.14); color:#7cf0c5; }
.daily-claim-btn, .daily-go-btn { min-width:2.3rem; padding:0.24rem 0.42rem; border-radius:999px; font-size:0.5rem; font-weight:900; }
.daily-claim-btn { background:linear-gradient(135deg,#ffb34b,#ff8b2d); color:#fff8ea; }
.daily-go-btn { background:rgba(255,255,255,0.06); color:#e3e9f6; }

.signin-panel { padding:0.42rem; display:grid; gap:0.42rem; }
.signin-summary { padding:0.65rem 0.7rem; border-radius:0.56rem; border:1px solid rgba(255,206,101,0.14); background:linear-gradient(180deg,rgba(38,31,17,0.96),rgba(16,13,9,0.98)); }
.signin-summary-main { display:flex; align-items:flex-end; justify-content:space-between; gap:0.5rem; }
.signin-summary-title { font-size:0.5rem; color:#e9c77b; letter-spacing:0.08em; }
.signin-summary-day { font-size:1.1rem; font-weight:900; color:#fff8e6; }
.signin-summary-sub { margin-top:0.16rem; font-size:0.5rem; color:#b6c1d4; line-height:1.55; }
.signin-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.24rem; }
.signin-day-card { padding:0.44rem 0.46rem; border-radius:0.5rem; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.03); }
.signin-day-card.today { border-color:rgba(255,206,101,0.24); background:linear-gradient(180deg,rgba(48,38,19,0.98),rgba(22,17,10,0.99)); }
.signin-day-card.claimed { border-color:rgba(73,206,158,0.18); background:linear-gradient(180deg,rgba(17,35,29,0.98),rgba(9,18,16,0.99)); }
.signin-day-top { display:flex; align-items:center; justify-content:space-between; gap:0.24rem; }
.signin-day-top strong { font-size:0.64rem; color:#fff2d7; }
.signin-day-top span { font-size:0.44rem; color:#c4cfe0; font-weight:800; }
.signin-day-card.today .signin-day-top span { color:#ffd98a; }
.signin-day-card.claimed .signin-day-top span { color:#79ebc1; }
.signin-day-rewards { margin-top:0.14rem; display:grid; gap:0.08rem; font-size:0.46rem; color:#aebad0; line-height:1.4; }
.signin-claim-btn { min-height:1.86rem; border-radius:999px; background:linear-gradient(135deg,#ffcf69,#ff9d32); color:#201305; font-size:0.62rem; font-weight:900; box-shadow:0 10px 18px rgba(255,157,50,0.18); }
.signin-claim-btn.is-disabled { background:rgba(255,255,255,0.08); color:#8d9cb0; box-shadow:none; }

.battle-center-panel { padding:0.42rem; }
.battle-center-summary-strip { position:relative; z-index:1; display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:0.2rem; margin-top:0.42rem; }
.battle-center-summary-chip { padding:0.3rem 0.34rem; border-radius:0.42rem; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.05); }
.battle-center-summary-chip span { display:block; font-size:0.42rem; color:#a88b77; }
.battle-center-summary-chip strong { display:block; margin-top:0.08rem; font-size:0.56rem; font-weight:900; color:#fff4e7; }
.battle-center-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.38rem; }
.battle-center-card { min-height:5.2rem; }
.battle-center-card.is-wide { grid-column:1 / -1; min-height:5rem; }
.battle-center-card.is-mainline { padding:0.86rem 0.78rem; background:linear-gradient(135deg,rgba(52,28,18,0.98),rgba(20,13,11,0.99)); border-color:rgba(255,152,74,0.26); box-shadow:0 12px 28px rgba(0,0,0,0.2); animation:mainlineBreath 3.2s ease-in-out infinite, mainlineBorderBreath 3.2s ease-in-out infinite; }
.battle-center-card.is-mainline::before { background:radial-gradient(circle at 100% 0%,rgba(255,166,92,0.16),transparent 36%),linear-gradient(90deg,rgba(255,183,94,0.04),transparent 42%); animation:mainlineGlow 3.2s ease-in-out infinite; }
.battle-center-card.is-mainline::after { content:""; position:absolute; inset:-1px; border-radius:0.58rem; pointer-events:none; box-shadow:0 0 0 0 rgba(255,184,110,0); animation:mainlineBorderAura 3.2s ease-in-out infinite; }
.battle-center-card.is-mainline .feature-card-main::after { content:""; position:absolute; top:-18%; bottom:-18%; left:0; width:24%; pointer-events:none; background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,244,214,0.28),rgba(255,255,255,0)); mix-blend-mode:screen; filter:blur(1px); transform:translateX(-160%) skewX(-20deg); animation:mainlineSweep 4.6s ease-in-out infinite; }
.battle-center-card.is-mainline .feature-card-main { align-items:center; gap:0.7rem; }
.battle-center-card.is-mainline .feature-card-icon { width:2.45rem; height:2.45rem; border-radius:0.56rem; }
.battle-center-card.is-mainline .feature-card-icon svg { width:1.42rem; height:1.42rem; }
.battle-center-card.is-mainline .feature-card-title { font-size:0.96rem; }
.battle-center-card.is-mainline .feature-card-sub { margin-top:0.14rem; font-size:0.56rem; color:#d5c6bc; }
.battle-center-card.is-mainline .feature-card-go { padding:0.22rem 0.46rem; font-size:0.62rem; }

.feature-system-summary { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:0.22rem; margin-bottom:0.36rem; }
.feature-system-summary-chip { padding:0.34rem 0.38rem; border-radius:0.5rem; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.03); }
.feature-system-summary-chip span { display:block; font-size:0.44rem; color:#97a7be; }
.feature-system-summary-chip strong { display:block; margin-top:0.08rem; font-size:0.58rem; font-weight:900; color:#f4f7fb; }

.trial-panel { padding:0.42rem; display:grid; gap:0.42rem; }
.trial-summary { padding:0.62rem 0.68rem; border-radius:0.56rem; border:1px solid rgba(103,198,255,0.14); background:linear-gradient(180deg,rgba(18,31,40,0.96),rgba(10,17,23,0.98)); }
.trial-summary-head { display:flex; align-items:flex-start; justify-content:space-between; gap:0.5rem; }
.trial-summary-title { font-size:0.76rem; font-weight:900; color:#f2fbff; }
.trial-summary-sub { margin-top:0.12rem; font-size:0.5rem; color:#a7bdd1; line-height:1.6; }
.trial-summary-count { min-width:4rem; padding:0.34rem 0.42rem; border-radius:0.5rem; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06); text-align:center; }
.trial-summary-count strong { display:block; font-size:1rem; font-weight:900; color:#f6fbff; }
.trial-summary-count span { display:block; margin-top:0.06rem; font-size:0.46rem; color:#9cb2c8; }
.trial-summary-strip { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:0.22rem; margin-top:0.28rem; }
.trial-summary-chip { padding:0.32rem 0.36rem; border-radius:0.44rem; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.05); }
.trial-summary-chip span { display:block; font-size:0.44rem; color:#8ea5bc; }
.trial-summary-chip strong { display:block; margin-top:0.08rem; font-size:0.58rem; font-weight:900; color:#edf8ff; }
.trial-grid { display:grid; gap:0.28rem; }
.trial-card { padding:0.5rem 0.54rem; border-radius:0.54rem; border:1px solid rgba(255,255,255,0.06); background:linear-gradient(180deg,rgba(20,20,32,0.98),rgba(11,11,18,0.99)); }
.trial-gold { border-color:rgba(255,203,99,0.18); background:linear-gradient(180deg,rgba(39,30,16,0.98),rgba(17,13,9,0.99)); }
.trial-exp { border-color:rgba(105,214,255,0.18); background:linear-gradient(180deg,rgba(16,29,39,0.98),rgba(9,14,21,0.99)); }
.trial-shard { border-color:rgba(157,241,195,0.18); background:linear-gradient(180deg,rgba(16,31,25,0.98),rgba(9,16,14,0.99)); }
.trial-card-head { display:flex; align-items:center; gap:0.42rem; }
.trial-card-icon { width:1.9rem; height:1.9rem; display:grid; place-items:center; border-radius:0.48rem; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.08); color:#ffe3a4; flex:0 0 auto; }
.trial-exp .trial-card-icon { color:#82deff; }
.trial-shard .trial-card-icon { color:#9df1c3; }
.trial-card-icon svg { width:1.16rem; height:1.16rem; stroke:currentColor; fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round; }
.trial-card-copy { min-width:0; flex:1 1 auto; }
.trial-card-title { display:flex; align-items:center; gap:0.18rem; flex-wrap:wrap; font-size:0.72rem; font-weight:900; color:#fff5e4; }
.trial-card-label { display:inline-flex; align-items:center; padding:0.08rem 0.24rem; border-radius:999px; background:rgba(255,255,255,0.07); font-size:0.42rem; color:#dfefff; font-weight:800; }
.trial-card-desc { margin-top:0.08rem; font-size:0.5rem; color:#aab7cb; line-height:1.5; }
.trial-card-count { flex:0 0 auto; min-width:2.1rem; text-align:center; padding:0.22rem 0.34rem; border-radius:999px; background:rgba(255,255,255,0.06); color:#f7f8fb; font-size:0.54rem; font-weight:900; }
.trial-meta-row { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.18rem; margin-top:0.22rem; }
.trial-meta-chip { padding:0.28rem 0.34rem; border-radius:0.42rem; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.05); }
.trial-meta-chip span { display:block; font-size:0.42rem; color:#8da6bc; }
.trial-meta-chip strong { display:block; margin-top:0.06rem; font-size:0.56rem; font-weight:900; color:#eef8ff; }
.trial-reward-line { margin-top:0.22rem; padding:0.3rem 0.38rem; border-radius:0.42rem; background:rgba(255,255,255,0.04); color:#eef6ff; font-size:0.52rem; font-weight:800; }
.trial-card-foot { margin-top:0.24rem; display:flex; align-items:center; justify-content:space-between; gap:0.38rem; }
.trial-card-note { font-size:0.46rem; color:#93a8bf; line-height:1.55; }
.trial-go-btn { flex:0 0 auto; min-width:4.2rem; min-height:1.7rem; padding:0.26rem 0.7rem; border-radius:999px; background:linear-gradient(135deg,#5ebeff,#2a7fff); color:#fff; font-size:0.56rem; font-weight:900; box-shadow:0 8px 16px rgba(42,127,255,0.18); }
.trial-go-btn:disabled { background:rgba(255,255,255,0.08); color:#8d9cb0; box-shadow:none; cursor:default; }

@media (max-width: 520px) {
  .daily-activity-track { grid-template-columns:repeat(5,minmax(0,1fr)); }
  .daily-task-row { align-items:flex-start; }
  .signin-grid { grid-template-columns:1fr; }
  .battle-center-grid { grid-template-columns:1fr; }
  .battle-center-card { min-height:0; }
  .battle-center-card.is-mainline { padding:0.76rem 0.68rem; }
  .trial-summary-head { flex-direction:column; }
  .trial-summary-count { width:100%; min-width:0; }
  .trial-summary-strip { grid-template-columns:1fr; }
  .trial-card-foot { align-items:flex-start; flex-direction:column; }
  .trial-go-btn { width:100%; min-width:0; }
}
.feature-card.is-wide { grid-column:1 / -1; }
.hub-player-card { margin-top:0.58rem; padding:0.56rem; border-radius:0.92rem; display:flex; align-items:center; justify-content:space-between; gap:0.5rem; background:linear-gradient(180deg,rgba(255,255,255,0.04),rgba(255,255,255,0.02)); border:1px solid rgba(255,255,255,0.06); position:relative; z-index:1; }
.hub-player-main { display:flex; align-items:center; gap:0.34rem; min-width:0; flex:1 1 auto; }
.hub-avatar { width:1.92rem; height:1.92rem; border-radius:0.48rem; display:grid; place-items:center; font-size:0.92rem; font-weight:900; color:#fff4dd; background:linear-gradient(180deg,rgba(255,107,53,0.24),rgba(100,181,246,0.16)); border:1px solid rgba(255,255,255,0.08); box-shadow:0 6px 14px rgba(0,0,0,0.16); overflow:hidden; }
.hub-avatar-img { width:100%; height:100%; object-fit:cover; }
.hub-avatar-mark { display:grid; place-items:center; width:100%; height:100%; }
.hub-player-copy { min-width:0; }
.hub-player-name { font-size:0.74rem; font-weight:900; color:#fff7ea; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; line-height:1.08; }
.hub-player-meta { margin-top:0.1rem; font-size:0.48rem; color:#a7b7ce; display:flex; align-items:center; gap:0.16rem; flex-wrap:wrap; }
.hub-player-badge { padding:0.12rem 0.3rem; border-radius:999px; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.06); }
.hub-player-divider { display:none; }
.hub-player-power-inline { display:inline-flex; align-items:center; padding:0.12rem 0.3rem; border-radius:999px; background:rgba(255,177,74,0.08); border:1px solid rgba(255,177,74,0.12); font-weight:900; color:#fff1d1; }
.hub-questbar { margin:0.28rem 0.5rem 0; padding:0.56rem 0.6rem; border-radius:0.92rem; display:flex; align-items:center; justify-content:space-between; gap:0.5rem; background:linear-gradient(180deg,rgba(255,107,53,0.1),rgba(255,215,0,0.04)); border:1px solid rgba(255,215,0,0.1); }
.hub-quest-copy { min-width:0; }
.hub-quest-kicker { font-size:0.48rem; color:var(--gold); letter-spacing:0.12em; text-transform:uppercase; }
.hub-quest-title { margin-top:0.06rem; font-size:var(--fz-md); font-weight:900; color:#fff7ea; }
.hub-quest-desc { margin-top:0.08rem; font-size:0.5rem; color:#afbdd2; line-height:1.65; }
.hub-quest-cta { flex:0 0 auto; padding:0.28rem 0.56rem; border-radius:999px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.08); color:#fff; font-size:0.46rem; font-weight:800; }
.module-shell { display:grid; gap:0.5rem; }
.module-hero { padding:0.78rem; border-radius:var(--radius-sm); border:1px solid rgba(255,255,255,0.07); background:linear-gradient(135deg,rgba(255,255,255,0.05),rgba(255,255,255,0.02)); position:relative; overflow:hidden; }
.module-hero::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 0% 0%,rgba(255,215,0,0.03),transparent 30%),radial-gradient(circle at 100% 0%,rgba(100,181,246,0.04),transparent 24%); pointer-events:none; }
.module-kicker { position:relative; z-index:1; font-size:0.5rem; letter-spacing:0.14em; color:var(--gold); text-transform:uppercase; }
.module-title { position:relative; z-index:1; font-family:var(--font); font-size:var(--fz-2xl); font-weight:900; color:#fff3dd; margin-top:0.08rem; }
.module-sub { position:relative; z-index:1; font-size:0.5rem; color:#a7b7ce; margin-top:0.14rem; line-height:1.7; }
.module-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:0.35rem; }
.module-stat { padding:0.46rem 0.36rem; border-radius:0.84rem; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05); text-align:center; }
.module-stat-value { font-size:var(--fz-md); font-weight:900; color:#fff; }
.module-stat-label { font-size:0.48rem; color:var(--dim); margin-top:0.08rem; }
.module-card { padding:0.62rem; border-radius:0.5rem; border:1px solid rgba(255,255,255,0.06); background:linear-gradient(180deg,rgba(17,17,28,0.88),rgba(11,11,20,0.92)); box-shadow:0 10px 24px rgba(0,0,0,0.12); }
.scene-banner { position:relative; padding:0.88rem; border-radius:var(--radius-sm); overflow:hidden; border:1px solid rgba(255,255,255,0.08); background:linear-gradient(180deg,rgba(255,255,255,0.045),rgba(255,255,255,0.02)); }
.scene-banner::before { content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(circle at 0% 0%,rgba(255,255,255,0.04),transparent 26%),radial-gradient(circle at 100% 100%,rgba(255,255,255,0.02),transparent 22%); }
.scene-banner.fire::before { background:radial-gradient(circle at 0% 0%,rgba(255,107,53,0.12),transparent 28%),radial-gradient(circle at 100% 100%,rgba(255,215,0,0.06),transparent 24%); }
.scene-banner.blue::before { background:radial-gradient(circle at 0% 0%,rgba(93,175,255,0.1),transparent 28%),radial-gradient(circle at 100% 100%,rgba(87,124,255,0.05),transparent 24%); }
.scene-banner.red::before { background:radial-gradient(circle at 0% 0%,rgba(255,68,68,0.12),transparent 28%),radial-gradient(circle at 100% 100%,rgba(255,159,28,0.06),transparent 24%); }
.scene-head { position:relative; z-index:1; display:flex; align-items:flex-start; justify-content:space-between; gap:0.7rem; }
.scene-title { font-family:var(--font); font-size:1.12rem; font-weight:900; color:#fff4dd; line-height:1.15; }
.scene-sub { margin-top:0.14rem; font-size:0.52rem; color:#a7b7ce; line-height:1.72; }
.scene-badge { flex:0 0 auto; padding:0.24rem 0.56rem; border-radius:999px; font-size:0.52rem; font-weight:800; }
.scene-badge.fire { background:rgba(255,107,53,0.16); color:#ffd0bf; }
.scene-badge.blue { background:rgba(93,175,255,0.16); color:#d7eaff; }
.scene-badge.red { background:rgba(255,68,68,0.18); color:#ffe0e0; }
.scene-return-btn { flex:0 0 auto; min-height:1.5rem; padding:0.18rem 0.58rem; border-radius:999px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.08); color:#fff3df; font-size:0.48rem; font-weight:800; }
.scene-meta { position:relative; z-index:1; display:grid; grid-template-columns:repeat(3,1fr); gap:0.36rem; margin-top:0.58rem; }
.scene-chip { padding:0.4rem 0.32rem; border-radius:0.84rem; text-align:center; background:rgba(0,0,0,0.18); border:1px solid rgba(255,255,255,0.05); }
.scene-chip-value { font-size:var(--fz-md); font-weight:900; color:#fff; }
.scene-chip-label { margin-top:0.06rem; font-size:0.49rem; color:var(--dim); }
.scene-action-row { display:flex; justify-content:center; gap:0.36rem; flex-wrap:wrap; margin-top:0.48rem; }
.reward-chip { display:inline-flex; align-items:center; gap:0.18rem; padding:0.19rem 0.46rem; border-radius:999px; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06); font-size:0.52rem; color:#d8e6ff; }
.train-panel { display:grid; gap:0.42rem; }
.train-scene-meta { grid-template-columns:repeat(4,1fr); margin-top:0.52rem; }
.train-scene-meta .scene-chip { padding:0.38rem 0.26rem; border-radius:0.48rem; background:rgba(10,12,18,0.28); border-color:rgba(255,255,255,0.06); }
.train-scene-meta .scene-chip-value { font-size:0.7rem; color:#fff8ef; }
.train-scene-meta .scene-chip-label { font-size:0.44rem; color:#99abc2; }
.train-shortcuts { display:flex; gap:0.22rem; flex-wrap:wrap; justify-content:flex-end; }
.train-shortcut-btn { min-height:1.55rem; padding:0.18rem 0.56rem; border-radius:999px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.08); color:#fff3df; font-size:0.48rem; font-weight:800; }
.train-shortcut-btn.is-codex { background:linear-gradient(180deg,rgba(255,214,92,0.16),rgba(255,180,52,0.08)); border-color:rgba(255,214,92,0.24); color:#ffe8ab; box-shadow:0 8px 18px rgba(255,190,64,0.12); }
.train-shortcut-btn.is-synergy { background:linear-gradient(180deg,rgba(122,146,255,0.16),rgba(88,102,255,0.08)); border-color:rgba(122,146,255,0.24); color:#dfe6ff; box-shadow:0 8px 18px rgba(88,102,255,0.12); }
.train-summary { display:grid; grid-template-columns:repeat(3,1fr); gap:0.3rem; }
.train-summary-card { padding:0.42rem 0.3rem; border-radius:0.86rem; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05); text-align:center; }
.train-summary-value { font-size:0.68rem; font-weight:900; color:#fff7ea; }
.train-summary-label { margin-top:0.08rem; font-size:0.46rem; color:#9db0c6; }
.train-rebirth { display:flex; align-items:center; justify-content:space-between; gap:0.45rem; padding:0.46rem 0.5rem; border-radius:0.95rem; background:linear-gradient(180deg,rgba(24,24,40,0.94),rgba(18,18,30,0.98)); border:1px solid rgba(255,107,107,0.16); }
.train-rebirth-ready { border-color:rgba(255,107,107,0.3); box-shadow:0 0 0 1px rgba(255,107,107,0.08) inset; }
.train-rebirth-copy { min-width:0; flex:1 1 auto; }
.train-rebirth-title { font-size:0.6rem; font-weight:900; color:#fff2de; }
.train-rebirth-sub { margin-top:0.08rem; font-size:0.46rem; color:#a6b6cb; line-height:1.6; }
.train-rebirth-btn { flex:0 0 auto; min-height:1.55rem; padding:0.24rem 0.7rem; border-radius:0.8rem; background:linear-gradient(135deg,#ff6b6b,#ee5a24); color:#fff; font-size:0.52rem; font-weight:900; animation:pulse 1.5s infinite; }
.train-group-head { display:flex; align-items:center; justify-content:space-between; gap:0.4rem; margin-top:0.08rem; }
.train-group-head-muted { margin-top:0.18rem; }
.train-group-title { display:inline-flex; align-items:center; min-height:1rem; padding:0 0.02rem 0.14rem; border-bottom:1px solid rgba(255,255,255,0.12); font-size:0.8rem; font-weight:900; }
.train-group-title-muted { color:#8f98ab; border-color:rgba(255,255,255,0.08); }
.train-group-count { font-size:0.6rem; color:#9cadc2; font-weight:700; }
.summon-panel { display:grid; gap:0.42rem; }
.summon-featured,
.summon-pool-card { padding:0.5rem; border-radius:0.5rem; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05); }
.summon-banner-metrics { position:relative; z-index:1; display:grid; grid-template-columns:1.2fr 1fr; gap:0.34rem; margin-top:0.42rem; }
.summon-banner-progress,
.summon-banner-rate { padding:0.38rem 0.42rem; border-radius:0.5rem; background:rgba(10,12,18,0.28); border:1px solid rgba(255,255,255,0.06); }
.summon-banner-line { display:flex; align-items:center; justify-content:space-between; gap:0.3rem; }
.summon-banner-kicker { font-size:0.46rem; font-weight:800; color:#fff3df; }
.summon-banner-value { font-size:0.62rem; font-weight:900; color:var(--gold); }
.summon-banner-tip { margin-top:0.12rem; font-size:0.42rem; line-height:1.55; color:#99a8bd; }
.summon-section-head { display:flex; align-items:flex-start; justify-content:space-between; gap:0.35rem; margin-bottom:0.28rem; }
.summon-section-title { font-size:0.62rem; font-weight:900; color:#fff6e4; }
.summon-section-sub { font-size:0.46rem; color:#9fb0c8; text-align:right; line-height:1.5; }
.summon-featured-list { display:grid; grid-template-columns:repeat(6,1fr); gap:0.34rem; }
.summon-featured-card { text-align:center; padding:0.24rem 0.12rem; border-radius:0.8rem; background:rgba(255,255,255,0.03); border:1px solid rgba(255,215,0,0.08); }
.summon-featured-card img { width:3rem; height:3rem; margin:0 auto; border-radius:0.76rem; object-fit:cover; border:2px solid rgba(255,215,0,0.42); box-shadow:0 0 10px rgba(255,215,0,0.12); }
.summon-featured-name { margin-top:0.14rem; font-size:0.46rem; font-weight:800; color:#fff3df; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.summon-featured-meta { margin-top:0.05rem; font-size:0.4rem; color:var(--gold); }
.summon-pity-bar { width:100% !important; margin:0 !important; height:0.34rem; }
.summon-hot-rate { color:#ff9f1c; font-weight:800; }
.summon-rate-row { display:flex; gap:0.28rem; justify-content:center; flex-wrap:wrap; }
.summon-rate-badge { display:inline-flex; align-items:center; gap:0.12rem; padding:0.14rem 0.32rem; border-radius:999px; font-size:0.48rem; font-weight:800; }
.summon-rate-badge b { font-size:0.58rem; }
.summon-rate-badge.ssr { background:rgba(255,215,0,0.08); color:#ffd700; }
.summon-rate-badge.ss { background:rgba(0,188,212,0.08); color:#00bcd4; }
.summon-rate-badge.sr { background:rgba(179,136,255,0.08); color:#b388ff; }
.summon-rate-bar { display:flex; height:0.38rem; border-radius:999px; overflow:hidden; margin-top:0.18rem; background:rgba(255,255,255,0.04); }
.summon-rate-fill { height:100%; transition:width 0.3s; }
.summon-rate-fill.ssr { background:linear-gradient(90deg,#ffd700,#ff9f1c); }
.summon-rate-fill.ss { background:linear-gradient(90deg,#00bcd4,#0097a7); }
.summon-rate-fill.sr { background:linear-gradient(90deg,#b388ff,#7c4dff); }
.summon-pool-list { display:flex; gap:0.14rem; flex-wrap:wrap; justify-content:center; }
.summon-pool-avatar { width:1.62rem; height:1.62rem; border-radius:50%; object-fit:cover; border:2px solid var(--border); background:var(--c3); }
.summon-select-wrap { text-align:center; margin-top:0.08rem; }
.summon-select-wrap-top { margin-top:0.34rem; }
.summon-select-btn { min-height:2rem; padding:0.46rem 1rem; border-radius:999px; background:linear-gradient(135deg,#ffd700,#ff9f1c); color:#111; font-size:0.66rem; font-weight:900; animation:glowPulse 1.5s infinite; }
.summon-action-bar { display:flex; gap:0.34rem; justify-content:center; align-items:center; margin-top:0.06rem; flex-wrap:wrap; }
.summon-action-bar-top { position:relative; z-index:1; margin-top:0.28rem; }
.summon-gem-count { display:inline-flex; align-items:center; justify-content:center; min-height:1.8rem; padding:0.2rem 0.7rem; border-radius:999px; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06); font-size:0.62rem; font-weight:900; color:#fff1d2; }
.summon-action-bar-top .summon-btn { flex:0 1 4.4rem; min-width:4.4rem; max-width:4.8rem; }
.summon-btn { font-size:0.72rem !important; min-height:1.9rem; padding:0.64rem 1rem !important; }
@media (min-width: 769px) {
  .summon-action-bar-top { gap:0.42rem; }
  .summon-action-bar-top .summon-btn { flex:0 0 6.4rem; min-width:6.4rem; max-width:6.4rem; min-height:2.05rem; }
}
.arena-panel { padding:0.4rem; }
.battle-center-card.is-rift { border-color:rgba(126,171,255,0.14); background:linear-gradient(180deg,rgba(18,24,39,0.98),rgba(10,13,22,0.99)); }
.battle-center-card.is-rift .feature-card-icon { color:#8bc5ff; }
.battle-center-card.is-rift.is-event-choice { min-height:4.6rem; }
.rift-choice-list { display:grid; gap:0.34rem; margin-top:0.18rem; }
.rift-scene-banner { position:relative; overflow:hidden; }
.rift-scene-banner::after { content:""; position:absolute; right:-10%; bottom:-35%; width:8rem; height:8rem; border-radius:50%; background:radial-gradient(circle,rgba(111,166,255,0.18),transparent 68%); pointer-events:none; }
.rift-panel { padding:0.42rem; background:linear-gradient(180deg,rgba(12,16,26,0.98),rgba(8,11,19,0.99)); border-color:rgba(118,156,255,0.12); }
.rift-overview-card { display:flex; align-items:flex-start; justify-content:space-between; gap:0.5rem; margin-top:0.42rem; padding:0.56rem 0.6rem; border-radius:0.8rem; border:1px solid rgba(126,171,255,0.12); background:linear-gradient(135deg,rgba(17,24,38,0.98),rgba(9,13,23,0.98)); box-shadow:inset 0 1px 0 rgba(255,255,255,0.03); }
.rift-overview-card.is-finished { border-color:rgba(255,206,118,0.14); background:linear-gradient(135deg,rgba(27,23,18,0.98),rgba(13,11,9,0.99)); }
.rift-overview-card.is-cleared { border-color:rgba(255,214,132,0.22); background:linear-gradient(135deg,rgba(36,28,16,0.985),rgba(18,13,9,0.995)); box-shadow:inset 0 1px 0 rgba(255,255,255,0.04),0 0 24px rgba(255,192,84,0.06); }
.rift-overview-main { min-width:0; flex:1; }
.rift-overview-kicker { font-size:0.4rem; letter-spacing:0.08em; text-transform:uppercase; color:#81b7ff; }
.rift-overview-card.is-finished .rift-overview-kicker { color:#d5b57c; }
.rift-overview-card.is-cleared .rift-overview-kicker { color:#ffd78b; }
.rift-overview-title { margin-top:0.08rem; font-size:0.88rem; font-weight:900; color:#f4f8ff; }
.rift-overview-card.is-finished .rift-overview-title { color:#f5e4c5; }
.rift-overview-card.is-cleared .rift-overview-title { color:#fff0cb; text-shadow:0 0 18px rgba(255,196,72,0.12); }
.rift-overview-sub { margin-top:0.12rem; font-size:0.48rem; line-height:1.55; color:#adc0db; }
.rift-overview-card.is-finished .rift-overview-sub { color:#cbbba0; }
.rift-overview-card.is-cleared .rift-overview-sub { color:#e0cfaf; }
.rift-overview-side { display:grid; justify-items:end; gap:0.16rem; min-width:3.8rem; }
.rift-overview-reward { font-size:0.42rem; line-height:1.45; color:#d6e5ff; text-align:right; }
.rift-overview-card.is-finished .rift-overview-reward { color:#bba88b; }
.rift-overview-card.is-cleared .rift-overview-reward { color:#e3cfaa; }
.rift-node-badge { display:inline-flex; align-items:center; justify-content:center; min-height:1rem; padding:0.16rem 0.42rem; border-radius:999px; border:1px solid rgba(126,171,255,0.18); background:rgba(98,154,255,0.12); color:#edf5ff; font-size:0.42rem; font-weight:800; letter-spacing:0.04em; }
.rift-node-badge.is-boss { border-color:rgba(255,165,98,0.24); background:rgba(255,149,76,0.12); color:#fff0df; }
.rift-node-badge.is-finished { border-color:rgba(255,206,118,0.18); background:rgba(255,196,72,0.1); color:#f4e8ce; }
.rift-node-badge.is-cleared { border-color:rgba(255,219,126,0.28); background:linear-gradient(180deg,rgba(255,223,133,0.16),rgba(255,177,58,0.08)); color:#fff3d1; box-shadow:0 0 14px rgba(255,195,61,0.08); }
.rift-progress-strip { display:grid; grid-template-columns:repeat(auto-fit,minmax(2rem,1fr)); gap:0.24rem; margin-top:0.42rem; }
.rift-progress-node { position:relative; display:grid; gap:0.06rem; padding:0.34rem 0.24rem; border-radius:0.62rem; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.03); text-align:center; opacity:0.72; }
.rift-progress-node.is-cleared { border-color:rgba(97,204,141,0.16); background:linear-gradient(180deg,rgba(24,58,43,0.72),rgba(10,18,15,0.78)); opacity:0.88; }
.rift-progress-node.is-current { border-color:rgba(126,171,255,0.24); background:linear-gradient(180deg,rgba(24,34,57,0.92),rgba(10,15,28,0.94)); box-shadow:0 0 0 1px rgba(126,171,255,0.12),0 12px 30px rgba(45,77,138,0.2); opacity:1; }
.rift-progress-node.is-boss { box-shadow:inset 0 0 0 1px rgba(255,156,92,0.1); }
.rift-progress-floor { font-size:0.58rem; font-weight:900; color:#fff6ea; }
.rift-progress-type { font-size:0.38rem; color:#9fb2cb; }
.rift-bonus-strip { display:flex; gap:0.16rem; flex-wrap:wrap; margin-top:0.42rem; }
.rift-bonus-item { display:inline-flex; align-items:center; min-height:0.92rem; padding:0.14rem 0.34rem; border-radius:999px; border:1px solid rgba(126,171,255,0.12); background:rgba(98,154,255,0.08); color:#eaf3ff; font-size:0.42rem; font-weight:700; }
.rift-build-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.34rem; margin-top:0.42rem; }
.rift-build-card { min-height:100%; }
.rift-effect-chip { display:inline-flex; align-items:center; gap:0.18rem; min-height:0.98rem; padding:0.14rem 0.32rem; border-radius:999px; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.04); color:#dbe7f7; font-size:0.42rem; }
.rift-effect-chip em { font-style:normal; color:#aebfd8; }
.rift-effect-chip b { color:#fff6ea; font-size:0.44rem; font-weight:900; }
.rift-action-card { margin-top:0.42rem; padding:0.56rem 0.6rem; border-radius:0.8rem; border:1px solid rgba(126,171,255,0.12); background:linear-gradient(180deg,rgba(16,22,36,0.98),rgba(9,13,23,0.98)); }
.rift-action-head { display:flex; align-items:center; gap:0.22rem; color:#d9e6f9; font-size:0.48rem; }
.rift-action-title { margin-top:0.18rem; font-size:0.76rem; font-weight:900; color:#f6f9ff; }
.rift-action-sub { margin-top:0.12rem; font-size:0.46rem; line-height:1.55; color:#aabbd3; }
.rift-action-reward { margin-top:0.18rem; font-size:0.44rem; color:#e4efff; }
.rift-event-outcome { display:grid; gap:0.08rem; margin-top:0.22rem; padding:0.24rem 0.28rem; border-radius:0.62rem; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.03); }
.rift-event-outcome-tag { font-size:0.38rem; color:#a8bddb; }
.rift-event-outcome b { font-size:0.46rem; color:#f3f8ff; font-weight:800; }
.rift-event-outcome.coins { border-color:rgba(255,196,92,0.16); background:rgba(255,186,76,0.08); }
.rift-event-outcome.gems { border-color:rgba(100,213,255,0.16); background:rgba(85,196,255,0.08); }
.rift-event-outcome.blessing { border-color:rgba(126,171,255,0.18); background:rgba(98,154,255,0.09); }
.rift-event-outcome.relic { border-color:rgba(178,133,255,0.18); background:rgba(146,109,255,0.09); }
.rift-event-outcome.bundle { border-color:rgba(255,155,96,0.18); background:rgba(255,139,74,0.08); }
.rift-action-buttons { display:flex; gap:0.24rem; margin-top:0.34rem; }
.rift-empty-card { display:grid; justify-items:center; gap:0.18rem; margin-top:0.42rem; padding:0.88rem 0.7rem; border-radius:0.8rem; border:1px dashed rgba(126,171,255,0.18); background:linear-gradient(180deg,rgba(15,22,38,0.92),rgba(8,12,20,0.96)); text-align:center; }
.rift-empty-icon { display:flex; align-items:center; justify-content:center; width:2rem; height:2rem; border-radius:50%; background:radial-gradient(circle at 30% 30%,rgba(145,191,255,0.34),rgba(73,115,211,0.22)); color:#f5f9ff; font-size:0.52rem; font-weight:900; letter-spacing:0.08em; }
.rift-empty-title { font-size:0.72rem; font-weight:900; color:#f4f8ff; }
.rift-empty-sub { max-width:11rem; font-size:0.46rem; line-height:1.55; color:#aebfd8; }
.rift-empty-card.is-finished { border-color:rgba(255,206,118,0.16); background:linear-gradient(180deg,rgba(25,22,17,0.94),rgba(12,10,8,0.98)); }
.rift-empty-card.is-finished .rift-empty-icon { background:radial-gradient(circle at 30% 30%,rgba(255,218,132,0.3),rgba(171,126,52,0.2)); color:#fff1d2; }
.rift-empty-card.is-finished .rift-empty-title { color:#f5e4c5; }
.rift-empty-card.is-finished .rift-empty-sub { color:#cbbba0; }
.rift-empty-card.is-cleared { border-color:rgba(255,214,132,0.24); background:linear-gradient(180deg,rgba(34,28,18,0.96),rgba(16,12,8,0.99)); box-shadow:0 0 24px rgba(255,192,84,0.06); }
.rift-empty-card.is-cleared .rift-empty-icon { background:radial-gradient(circle at 30% 30%,rgba(255,232,168,0.34),rgba(192,142,54,0.22)); color:#fff4d8; }
.rift-empty-card.is-cleared .rift-empty-title { color:#fff0cb; text-shadow:0 0 18px rgba(255,196,72,0.12); }
.rift-empty-card.is-cleared .rift-empty-sub { color:#e0cfaf; }
.rift-abandon-wrap { margin-top:0.6rem; }
.rift-shop-entry { margin-top:0.42rem; padding:0.58rem 0.62rem; display:flex; align-items:center; justify-content:space-between; gap:0.46rem; border-color:rgba(126,171,255,0.14); background:linear-gradient(180deg,rgba(16,24,38,0.96),rgba(9,13,22,0.98)); }
.rift-shop-entry-copy { min-width:0; display:grid; gap:0.08rem; }
.rift-shop-entry-title { font-size:0.64rem; font-weight:900; color:#f4f8ff; }
.rift-shop-entry-sub { font-size:0.44rem; line-height:1.55; color:#aebfd8; }
.battle-go.rift-shop-open-btn { flex:0 0 auto; min-width:3.5rem; display:grid; gap:0.04rem; justify-items:center; background:linear-gradient(135deg,#4f7cff,#2f5bdb); box-shadow:0 10px 22px rgba(53,94,214,0.26); }
.battle-go.rift-shop-open-btn:hover { filter:brightness(1.04); }
.battle-go.rift-shop-open-btn:active { transform:translateY(1px); box-shadow:0 6px 14px rgba(53,94,214,0.22); }
.battle-go.rift-shop-open-btn span { font-size:0.4rem; font-weight:700; color:rgba(255,255,255,0.78); }
.rift-shop-panel { margin-top:0.42rem; }
.rift-shop-grid { margin-top:0.24rem; }
.rift-shop-card { border-color:rgba(126,171,255,0.14); background:linear-gradient(180deg,rgba(17,24,37,0.96),rgba(10,13,20,0.98)); }
.rift-shop-card .vip-shop-badge { background:rgba(98,154,255,0.12); color:#dcebff; }
.rift-shop-card .vip-shop-head { align-items:flex-start; }
.rift-shop-card .vip-shop-badge { white-space:nowrap; }
.auto-next-btn.rift-shop-btn { min-width:3.6rem; min-height:1.78rem; padding:0.22rem 0.5rem !important; border-radius:0.46rem; background:linear-gradient(180deg,#5ba6ff,#2f6dff) !important; border:1px solid rgba(123,181,255,0.34) !important; color:#f7fbff !important; font-size:0.5rem !important; font-weight:900; line-height:1.25; box-shadow:0 10px 22px rgba(47,109,255,0.24) !important; }
.auto-next-btn.rift-shop-btn:hover { filter:brightness(1.04); }
.auto-next-btn.rift-shop-btn:active { transform:translateY(1px); box-shadow:0 6px 14px rgba(47,109,255,0.2) !important; }
.auto-next-btn.rift-shop-btn.is-disabled,
.auto-next-btn.rift-shop-btn:disabled { opacity:0.5; cursor:not-allowed; background:rgba(255,255,255,0.08) !important; border-color:rgba(255,255,255,0.08) !important; color:#8e9ab0 !important; box-shadow:none !important; }
.rift-shop-dialog-overlay { position:fixed; inset:0; z-index:54; background:rgba(3,5,12,0.78); backdrop-filter:blur(8px); }
.rift-shop-dialog { position:fixed; left:50%; top:50%; transform:translate(-50%,-50%); z-index:55; width:calc(100vw - 0.72rem); max-width:none; height:auto; max-height:calc(100vh - 0.72rem); overflow-x:hidden; overflow-y:auto; padding:0.82rem; border-radius:0.62rem; border:1px solid rgba(126,171,255,0.16); background:linear-gradient(180deg,rgba(12,17,29,0.985),rgba(8,11,20,0.995)); box-shadow:0 22px 56px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.04); display:grid; gap:0.52rem; scrollbar-width:none; -ms-overflow-style:none; }
.rift-shop-dialog::-webkit-scrollbar { width:0; height:0; display:none; }
.rift-shop-dialog-head { display:flex; align-items:flex-start; justify-content:space-between; gap:0.42rem; }
.rift-shop-dialog-title { font-size:0.8rem; font-weight:900; color:#f5f9ff; }
.rift-shop-dialog-sub { margin-top:0.08rem; font-size:0.46rem; line-height:1.6; color:#aebfd8; }
.rift-shop-dialog-close { flex:0 0 auto; min-height:1.46rem; padding:0.18rem 0.5rem; border-radius:0.42rem; border:1px solid rgba(255,255,255,0.08); background:rgba(255,255,255,0.04); color:#d9e3f0; font-size:0.48rem; font-weight:800; }
.rift-shop-dialog-currency { display:flex; align-items:center; justify-content:space-between; gap:0.4rem; padding:0.34rem 0.42rem; border-radius:0.44rem; border:1px solid rgba(126,171,255,0.12); background:rgba(98,154,255,0.08); }
.rift-shop-dialog-currency span { font-size:0.8rem; color:#aebfd8; }
.rift-shop-dialog-currency strong { display:inline-flex; align-items:center; gap:0.14rem; font-size:0.62rem; font-weight:900; color:#f5f0cf; }
.rift-shop-dialog .rift-shop-panel { margin-top:0; padding:0; border:none; background:transparent; box-shadow:none; }
.rift-shop-dialog .trial-head { margin-bottom:0.1rem; }
.rift-shop-dialog .vip-shop-grid { grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.44rem; }
.rift-shop-dialog .rift-shop-card { padding:0.62rem; gap:0.34rem; }
.rift-shop-dialog .vip-shop-title { font-size:0.66rem; }
.rift-shop-dialog .vip-shop-sub { font-size:0.42rem; line-height:1.5; }
.rift-shop-dialog .vip-shop-meta { font-size:0.44rem; }
.rift-shop-dialog .shop-offer-rewards { gap:0.2rem; }
.rift-shop-dialog .vip-shop-foot { align-items:center; }
.rift-shop-dialog .rift-shop-btn { min-width:4rem; }
.reward-chip.dim { color:#92a1b8; }
.result-banner.rift { border-color:rgba(126,171,255,0.18); background:linear-gradient(180deg,rgba(15,22,36,0.98),rgba(10,14,24,0.98)); box-shadow:inset 0 1px 0 rgba(255,255,255,0.03),0 10px 24px rgba(0,0,0,0.24); }
.result-banner.rift::before { content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(circle at 50% 0%,rgba(98,154,255,0.16),transparent 34%),radial-gradient(circle at 100% 100%,rgba(85,128,255,0.06),transparent 26%); }
.result-banner.rift .result-back-btn { border-color:rgba(126,171,255,0.22); background:rgba(98,154,255,0.1); color:#edf4ff; }
.result-banner.rift .result-badge { background:rgba(98,154,255,0.14); border:1px solid rgba(126,171,255,0.22); color:#eef5ff; }
.result-banner.rift .result-title { color:#f3f8ff; text-shadow:0 0 18px rgba(98,154,255,0.16); }
.result-banner.rift .result-sub { color:#b4c7df; }
.result-banner.rift.rift-clear { border-color:rgba(255,210,104,0.28); background:linear-gradient(180deg,rgba(34,25,14,0.985),rgba(18,13,8,0.995)); box-shadow:inset 0 1px 0 rgba(255,255,255,0.05),0 14px 34px rgba(0,0,0,0.3),0 0 28px rgba(255,191,73,0.08); }
.result-banner.rift.rift-clear::before { background:radial-gradient(circle at 50% 0%,rgba(255,214,120,0.24),transparent 38%),radial-gradient(circle at 18% 18%,rgba(255,240,196,0.09),transparent 18%),radial-gradient(circle at 82% 20%,rgba(255,220,134,0.08),transparent 20%),radial-gradient(circle at 100% 100%,rgba(255,168,68,0.08),transparent 26%); }
.result-banner.rift.rift-clear::after { content:"CLEAR"; position:absolute; left:50%; top:0.82rem; transform:translateX(-50%); font-size:1.46rem; font-weight:900; letter-spacing:0.18em; color:rgba(255,238,198,0.06); pointer-events:none; }
.result-banner.rift.rift-clear .result-back-btn { border-color:rgba(255,216,128,0.3); background:rgba(255,196,72,0.1); color:#fff3d6; }
.result-banner.rift.rift-clear .result-badge { background:linear-gradient(180deg,rgba(255,223,133,0.16),rgba(255,177,58,0.08)); border:1px solid rgba(255,219,126,0.28); color:#fff3d1; box-shadow:0 0 14px rgba(255,195,61,0.08); }
.result-banner.rift.rift-clear .result-title { color:#fff2cf; text-shadow:0 0 24px rgba(255,196,74,0.18); }
.result-banner.rift.rift-clear .result-sub { color:#dbc7a6; }
.result-banner.rift.rift-clear .reward-chip { background:rgba(255,224,155,0.08); border-color:rgba(255,219,126,0.14); color:#fbecc9; }
.result-banner.rift.rift-clear .rift-bonus-item { background:rgba(255,224,155,0.08); border-color:rgba(255,219,126,0.14); color:#f7e4ba; }
.result-banner.rift.rift-clear .result-summary-rewards { border-top-color:rgba(255,216,128,0.14); }
.result-banner.rift.rift-clear .result-reward-card { background:linear-gradient(180deg,rgba(36,28,16,0.88),rgba(18,13,9,0.94)); border-color:rgba(255,216,128,0.12); }
.rift-result-bonus { display:flex; flex-wrap:wrap; gap:0.16rem; margin-top:0.32rem; }
.rift-run-summary { display:flex; flex-wrap:wrap; gap:0.16rem; margin-top:0.22rem; }
.result-banner.rift .result-summary-rewards { border-top-color:rgba(126,171,255,0.12); }
.result-banner.rift .result-reward-card { background:linear-gradient(180deg,rgba(17,24,37,0.84),rgba(10,13,22,0.9)); border-color:rgba(126,171,255,0.08); }
@media (max-width: 768px) {
  .rift-overview-card { display:grid; grid-template-columns:1fr; }
  .rift-overview-side { justify-items:start; min-width:0; }
  .rift-overview-reward { text-align:left; }
  .rift-build-grid { grid-template-columns:1fr; }
  .rift-progress-strip { grid-template-columns:repeat(3,minmax(0,1fr)); }
  .rift-shop-entry { display:grid; grid-template-columns:1fr; }
  .battle-go.rift-shop-open-btn { width:100%; }
  .rift-shop-dialog { width:calc(100vw - 0.72rem); padding:0.68rem; }
  .rift-shop-dialog .vip-shop-grid { grid-template-columns:1fr; }
}

@media (min-width: 600px) {
  .rift-shop-dialog { width:min(calc(100vw - 0.72rem), 480px); }
}

@media (min-width: 900px) {
  .rift-shop-dialog { width:min(calc(100vw - 0.72rem), 520px); }
}

@media (min-width: 1200px) {
  .rift-shop-dialog { width:min(calc(100vw - 0.72rem), 560px); }
}

@media (min-width: 1600px) {
  .rift-shop-dialog { width:min(calc(100vw - 0.72rem), 600px); }
}
.arena-stage { display:grid; gap:0.42rem; }
.arena-rank-hero { text-align:center; padding:0.2rem 0 0.1rem; }
.arena-rank-icon { width:2.12rem; height:2.12rem; margin:0 auto 0.08rem; display:flex; align-items:center; justify-content:center; }
.arena-rank-icon img { width:100%; height:100%; display:block; object-fit:contain; }
.arena-rank-name { font-size:1.24rem; font-weight:900; }
.arena-rank-sub { margin-top:0.08rem; font-size:0.46rem; color:var(--dim); }
.arena-progress-card,
.arena-section-card { padding:0.5rem; border-radius:0.92rem; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05); }
.arena-progress-head { display:flex; justify-content:space-between; align-items:center; gap:0.4rem; margin-bottom:0.24rem; }
.arena-progress-score { font-size:0.86rem; font-weight:900; }
.arena-progress-unit { font-size:0.48rem; color:var(--dim); margin-left:0.08rem; }
.arena-progress-next { font-size:0.46rem; color:var(--dim); text-align:right; }
.arena-progress-track { height:0.48rem; background:var(--c3); border-radius:999px; overflow:hidden; }
.arena-progress-fill { height:100%; border-radius:999px; transition:width 0.3s; }
.arena-tier-strip { display:flex; justify-content:space-around; gap:0.15rem; margin-top:0.26rem; flex-wrap:wrap; }
.arena-tier-strip-item { font-size:0.38rem; }
.arena-stat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0.3rem; }
.arena-stat-card { padding:0.42rem 0.26rem; border-radius:0.86rem; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05); text-align:center; }
.arena-stat-label { font-size:0.42rem; color:var(--dim); }
.arena-stat-value { margin-top:0.08rem; font-size:0.76rem; font-weight:900; color:var(--text); }
.arena-stat-value span { font-size:0.44rem; color:var(--dim); margin-left:0.02rem; margin-right:0.08rem; }
.arena-stat-value.reward { font-size:0.58rem; color:var(--gold); }
.arena-stat-sub { margin-top:0.05rem; font-size:0.38rem; color:var(--dim); }
.arena-action-box { text-align:center; padding:0.1rem 0; }
.arena-action-count { font-size:0.56rem; font-weight:800; margin-bottom:0.14rem; }
.arena-go { font-size:0.9rem; padding:0.76rem 2.2rem; border-radius:1rem; }
.arena-auto-wrap { margin-top:0.16rem; }
.arena-section-title { font-size:0.62rem; font-weight:900; color:#fff3df; margin-bottom:0.08rem; }
.arena-section-sub { font-size:0.42rem; color:var(--dim); margin-bottom:0.22rem; }
.arena-milestone-row,
.arena-tier-row { display:flex; align-items:center; justify-content:space-between; gap:0.28rem; padding:0.22rem 0.34rem; border-radius:0.76rem; border:1px solid var(--border); margin-bottom:0.16rem; background:rgba(255,255,255,0.02); }
.arena-milestone-row.reached { background:rgba(255,107,53,0.06); }
.arena-milestone-info,
.arena-tier-info { display:flex; align-items:center; gap:0.2rem; min-width:0; }
.arena-milestone-battle { font-size:0.5rem; font-weight:900; }
.arena-milestone-reward,
.arena-tier-reward { display:flex; align-items:center; justify-content:flex-end; gap:0.12rem; font-size:0.4rem; color:var(--gold); }
.arena-milestone-reward b,
.arena-tier-reward b { font-size:0.4rem; font-weight:900; line-height:1; }
.arena-reward-currency { width:0.42rem; height:0.42rem; display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; }
.arena-reward-currency img { width:100%; height:100%; display:block; object-fit:contain; }
.arena-reward-currency-gold { margin-left:0.06rem; }
.arena-milestone-state { font-size:0.55rem; }
.arena-milestone-state.claimed { color:var(--green); }
.arena-milestone-state.locked { color:var(--dim); }
.arena-claim-btn { min-height:1.2rem; padding:0.14rem 0.42rem; border-radius:0.55rem; background:linear-gradient(135deg,#3b82f6,#2563eb); color:#fff; font-size:0.42rem; font-weight:800; }
.arena-tier-row.current { background:rgba(255,107,53,0.08); border-color:rgba(255,107,53,0.2); }
.arena-tier-icon { width:0.96rem; height:0.96rem; display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; }
.arena-tier-icon img { width:100%; height:100%; display:block; object-fit:contain; }
.arena-tier-name { font-size:0.5rem; font-weight:900; }
.arena-tier-threshold { font-size:0.38rem; color:var(--dim); }
.boss-panel { display:grid; gap:0.32rem; }
.boss-kicker { font-size:0.46rem; color:var(--dim); margin-bottom:0.08rem; }
.boss-avatar { display:block; margin:0.1rem auto; width:4rem; height:4rem; border-radius:50%; border:3px solid #ff4444; object-fit:cover; }
.boss-sub { font-size:0.42rem; color:var(--dim); margin-top:0.06rem; }
.boss-summary-card { display:flex; justify-content:space-between; align-items:center; gap:0.4rem; padding:0.3rem 0.42rem; background:rgba(255,50,50,0.08); border-radius:0.8rem; }
.boss-summary-label { font-size:0.38rem; color:var(--dim); }
.boss-summary-value { font-size:0.68rem; font-weight:900; color:#ff4444; }
.boss-summary-tier { font-size:0.36rem; margin-top:0.04rem; }
.boss-summary-side { text-align:right; }
.boss-summary-time { font-size:0.5rem; font-weight:700; color:var(--accent); }
.boss-section-title { font-size:0.56rem; font-weight:900; color:var(--text); margin:0.08rem 0 0.04rem; }
.boss-tier-label { width:1.82rem; font-size:0.5rem; font-weight:800; }
.boss-tier-threshold { font-size:0.42rem; font-weight:700; }
.boss-tier-reward { flex:1; display:flex; align-items:center; justify-content:flex-end; gap:0.16rem; text-align:right; font-size:0.42rem; }
.boss-tier-reward b { font-size:0.46rem; font-weight:900; line-height:1; }
.boss-tier-currency { width:0.48rem; height:0.48rem; display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; }
.boss-tier-currency img { width:100%; height:100%; display:block; object-fit:contain; }
.boss-tier-currency-gold { margin-left:0.08rem; }
.boss-tier-state { font-size:0.42rem; }
.boss-note { font-size:0.36rem; color:var(--dim); margin:0.08rem 0; text-align:center; }
.boss-attempts { text-align:center; font-size:0.4rem; color:var(--dim); margin:0.08rem 0; }
.boss-action-wrap { text-align:center; padding:0.16rem 0 0.08rem; }
.boss-challenge-btn { background:linear-gradient(135deg,#ff4444,#cc0000); color:#fff; border:none; padding:0.34rem 1.2rem; border-radius:0.8rem; font-size:0.58rem; font-weight:900; box-shadow:0 4px 15px rgba(255,0,0,0.3); }
.codex-panel { display:grid; gap:0.42rem; }
.codex-panel .codex-group:first-of-type { margin-top:0.06rem; }
.codex-summary-card { padding:0.54rem; border-radius:0.95rem; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05); }
.codex-summary-title { font-size:0.66rem; font-weight:900; color:var(--gold); margin-bottom:0.28rem; }
.codex-summary-list { display:grid; gap:0.14rem; }
.codex-summary-row { display:flex; justify-content:space-between; align-items:center; gap:0.3rem; font-size:0.48rem; color:var(--dim); }
.codex-summary-row b { font-size:0.5rem; color:var(--text); }
.codex-summary-row b.ssr { color:rgba(255,215,0,0.9); }
.codex-summary-row b.ss { color:rgba(0,188,212,0.9); }
.codex-summary-row b.sr { color:rgba(179,136,255,0.9); }
.codex-bonus-box { margin-top:0.26rem; background:rgba(255,215,0,0.08); border:1px solid rgba(255,215,0,0.2); border-radius:0.8rem; padding:0.34rem; text-align:center; }
.codex-bonus-box-top { margin-top:0; }
.codex-bonus-value { font-size:0.8rem; color:var(--gold); font-weight:900; }
.codex-bonus-value span { font-size:0.5rem; color:var(--dim); }
.codex-bonus-sub { margin-top:0.08rem; font-size:0.5rem; color:var(--dim); line-height:1.5; }
.codex-group { margin-bottom:0.42rem; }
.codex-group-title { font-size:0.8rem; font-weight:900; margin-bottom:0.22rem; }
.codex-grid { display:flex; flex-wrap:wrap; gap:0.22rem; }
.codex-char { width:3.2rem; text-align:center; }
.codex-char-portrait { width:2.8rem; height:2.8rem; margin:0 auto; border-radius:0.76rem; border:2px solid var(--border); overflow:hidden; background:var(--c2); }
.codex-char-portrait img { width:100%; height:100%; object-fit:cover; }
.codex-char-name { font-size:0.34rem; color:var(--text); margin-top:0.08rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.codex-char-star { font-size:0.3rem; color:var(--gold); margin-top:0.04rem; }
.codex-char-empty { font-size:0.3rem; color:var(--dim); margin-top:0.04rem; }
.settings-panel { padding:0.64rem; }
.vip-panel { padding:0.64rem; display:grid; gap:0.46rem; }
.vip-progress-card { padding:0.58rem; border-radius:0.5rem; border:1px solid rgba(255,214,117,0.14); background:linear-gradient(180deg,rgba(41,30,14,0.92),rgba(18,14,9,0.96)); }
.vip-progress-top { display:flex; align-items:flex-start; justify-content:space-between; gap:0.4rem; }
.vip-progress-title { font-size:0.7rem; font-weight:900; color:#fff4d9; }
.vip-progress-sub { margin-top:0.12rem; font-size:0.5rem; color:#b9ae91; line-height:1.5; }
.vip-progress-level { flex:0 0 auto; font-size:0.72rem; color:#ffd873; font-weight:900; }
.vip-progress-bar { height:0.42rem; margin-top:0.4rem; border-radius:999px; background:rgba(255,255,255,0.06); overflow:hidden; }
.vip-progress-fill { height:100%; border-radius:999px; background:linear-gradient(90deg,#ffbf47,#ffe18e); box-shadow:0 0 14px rgba(255,195,73,0.22); }
.vip-progress-scale { margin-top:0.16rem; display:flex; align-items:center; justify-content:space-between; font-size:0.46rem; color:#9e9378; }
.vip-status-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.36rem; }
.vip-status-card { padding:0.48rem 0.5rem; border-radius:0.5rem; border:1px solid rgba(255,255,255,0.06); background:linear-gradient(180deg,rgba(33,24,12,0.82),rgba(16,12,8,0.9)); }
.vip-status-card.is-blue { background:linear-gradient(180deg,rgba(17,24,37,0.88),rgba(10,13,20,0.92)); border-color:rgba(106,183,255,0.14); }
.vip-status-card.is-gold { background:linear-gradient(180deg,rgba(45,35,18,0.9),rgba(18,14,9,0.94)); border-color:rgba(255,210,106,0.14); }
.vip-status-kicker { font-size:0.44rem; color:#b59c73; font-weight:800; }
.vip-status-main { margin-top:0.1rem; font-size:0.7rem; color:#fff4dc; font-weight:900; }
.vip-status-sub { margin-top:0.1rem; font-size:0.46rem; color:#aab4c4; line-height:1.45; }
.vip-benefit-grid { display:grid; grid-template-columns:repeat(1,minmax(0,1fr)); gap:0.38rem; }
.vip-benefit-card { padding:0.54rem; border-radius:0.5rem; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.03); display:grid; gap:0.38rem; }
.vip-benefit-head { display:flex; align-items:flex-start; justify-content:space-between; gap:0.36rem; }
.vip-benefit-title { font-size:0.64rem; font-weight:900; color:#fff3df; }
.vip-benefit-sub { margin-top:0.1rem; font-size:0.48rem; color:#acb6c8; line-height:1.55; }
.vip-benefit-state { flex:0 0 auto; padding:0.12rem 0.3rem; border-radius:999px; background:rgba(255,210,106,0.1); color:#ffd976; font-size:0.44rem; font-weight:800; }
.vip-action-btn { width:100%; min-height:1.88rem; border-radius:0.46rem; background:linear-gradient(180deg,#ffd870,#f0ad24); color:#402500; font-size:0.58rem; font-weight:900; box-shadow:inset 0 1px 0 rgba(255,255,255,0.35); }
.vip-action-btn.is-disabled,
.vip-action-btn:disabled { background:rgba(255,255,255,0.06); color:#7e7b8e; box-shadow:none; cursor:default; }
.vip-section-title { font-size:0.62rem; font-weight:900; color:#fff1d4; }
.vip-priv-card { padding:0.56rem; border-radius:0.5rem; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.03); display:grid; gap:0.28rem; }
.vip-priv-head,
.vip-priv-row { display:grid; grid-template-columns:minmax(0,1.5fr) minmax(0,0.8fr) minmax(0,0.8fr); gap:0.22rem; align-items:center; }
.vip-priv-head { padding:0 0.08rem 0.14rem; font-size:0.44rem; color:#92876e; font-weight:800; }
.vip-priv-list { display:grid; gap:0.14rem; }
.vip-priv-row { padding:0.28rem 0.34rem; border-radius:0.38rem; background:rgba(255,255,255,0.03); }
.vip-priv-label { font-size:0.5rem; color:#f4ecd9; font-weight:700; }
.vip-priv-value { font-size:0.46rem; font-weight:800; }
.vip-priv-value.current { color:#ffd977; }
.vip-priv-value.next { color:#8bc5ff; }
.vip-shop-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.38rem; }
.vip-shop-card { width:100%; padding:0.56rem; border-radius:0.5rem; border:1px solid rgba(255,209,105,0.12); background:linear-gradient(180deg,rgba(33,24,12,0.96),rgba(16,12,8,0.98)); color:var(--text); text-align:left; display:grid; gap:0.3rem; }
.vip-shop-card.is-card { border-color:rgba(106,183,255,0.14); background:linear-gradient(180deg,rgba(17,24,37,0.96),rgba(10,13,20,0.98)); }
.vip-shop-card.is-frag { border-color:rgba(179,136,255,0.14); background:linear-gradient(180deg,rgba(31,20,43,0.96),rgba(14,10,22,0.98)); }
.vip-shop-head { display:flex; align-items:flex-start; justify-content:space-between; gap:0.32rem; }
.vip-shop-title { font-size:0.66rem; font-weight:900; color:#fff6e4; }
.vip-shop-sub { margin-top:0.08rem; font-size:0.47rem; color:#adb7c9; line-height:1.45; }
.vip-shop-badge { flex:0 0 auto; padding:0.12rem 0.28rem; border-radius:999px; background:rgba(255,210,106,0.1); color:#ffd773; font-size:0.42rem; font-weight:800; }
.vip-shop-card.is-card .vip-shop-badge { background:rgba(106,183,255,0.12); color:#8dc7ff; }
.vip-shop-card.is-frag .vip-shop-badge { background:rgba(179,136,255,0.14); color:#d6bcff; }
.vip-shop-meta { display:grid; gap:0.1rem; font-size:0.47rem; color:#d4dfef; }
.shop-offer-cost { display:flex; align-items:center; flex-wrap:wrap; gap:0.24rem; font-size:0.48rem; color:#ffe7ba; }
.shop-offer-cost img { width:0.72rem; height:0.72rem; object-fit:contain; display:block; }
.shop-offer-cost b { font-size:0.56rem; color:#fff6de; }
.shop-cost-sep { width:0.18rem; height:0.18rem; border-radius:50%; background:rgba(255,255,255,0.12); }
.shop-offer-rewards { display:flex; flex-wrap:wrap; gap:0.24rem; }
.shop-reward-item { display:inline-flex; align-items:center; gap:0.18rem; padding:0.16rem 0.24rem; border-radius:999px; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06); }
.shop-reward-item img,
.shop-reward-item .idle-toast-card-icon-exp { width:0.66rem; height:0.66rem; display:inline-flex; align-items:center; justify-content:center; object-fit:contain; }
.shop-reward-item b { font-size:0.52rem; color:#fff6de; }
.shop-reward-item em { font-style:normal; font-size:0.42rem; color:#9fb0c7; }
.vip-shop-foot { display:flex; align-items:flex-end; justify-content:space-between; gap:0.3rem; padding-top:0.08rem; }
.vip-shop-foot strong { font-size:0.84rem; color:#ffd97e; font-weight:900; }
.vip-shop-foot span { font-size:0.48rem; color:#bba989; font-weight:700; }
.leaderboard-panel { padding:0.64rem; display:grid; gap:0.42rem; }
.leaderboard-tabs { margin-top:0.42rem; display:flex; gap:0.24rem; flex-wrap:wrap; }
.leaderboard-tab { min-height:1.48rem; padding:0.18rem 0.6rem; border-radius:999px; background:rgba(255,255,255,0.04); color:#9facbf; border:1px solid rgba(255,255,255,0.06); font-size:0.5rem; font-weight:800; }
.leaderboard-tab.active { background:rgba(126,154,255,0.12); color:#eef2ff; border-color:rgba(126,154,255,0.22); }
.leaderboard-panel-head { display:flex; align-items:center; justify-content:space-between; gap:0.4rem; }
.leaderboard-panel-title { font-size:0.72rem; font-weight:900; color:#fff5df; }
.leaderboard-refresh { min-height:1.46rem; padding:0.16rem 0.56rem; border-radius:999px; background:rgba(255,255,255,0.04); color:#d7e1ef; border:1px solid rgba(255,255,255,0.06); font-size:0.48rem; font-weight:800; }
.leaderboard-self-card { display:grid; gap:0.18rem; }
.leaderboard-self-head { font-size:0.48rem; color:#8f9db2; font-weight:800; }
.leaderboard-hero { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:0.34rem; align-items:end; padding-top:0.18rem; }
.leaderboard-podium { position:relative; min-height:6.2rem; padding:0.46rem 0.3rem 0.72rem; border-radius:0.56rem; background:
linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.02)),
radial-gradient(circle at top,rgba(255,255,255,0.12),transparent 52%);
 border:1px solid rgba(255,255,255,0.06); text-align:center; display:grid; grid-template-rows:auto auto 1fr; align-content:start; gap:0.18rem; overflow:hidden; }
.leaderboard-podium::after { content:""; position:absolute; left:0.62rem; right:0.62rem; bottom:0.86rem; height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent); }
.leaderboard-podium::before { content:""; position:absolute; left:50%; bottom:0.72rem; width:2.7rem; height:0.42rem; transform:translateX(-50%); border-radius:999px; background:radial-gradient(circle,rgba(255,255,255,0.14),rgba(255,255,255,0)); pointer-events:none; }
.leaderboard-podium.first { min-height:7.2rem; padding-top:0.66rem; padding-bottom:0.82rem; background:linear-gradient(180deg,rgba(255,215,0,0.22),rgba(255,215,0,0.06)); border-color:rgba(255,215,0,0.3); box-shadow:0 12px 28px rgba(255,215,0,0.08); transform:translateY(-0.22rem); }
.leaderboard-podium.first .leaderboard-podium-rank::before { content:"♛"; display:block; font-size:0.82rem; line-height:1; color:#ffe892; margin-bottom:0.08rem; text-shadow:0 2px 8px rgba(255,215,0,0.26); }
.leaderboard-podium.first .leaderboard-podium-avatar::after { content:""; position:absolute; inset:-0.22rem; border-radius:0.8rem; border:1px solid rgba(255,236,171,0.3); box-shadow:0 0 0 0.08rem rgba(255,215,0,0.08); pointer-events:none; }
.leaderboard-podium.second { min-height:6.05rem; background:linear-gradient(180deg,rgba(180,196,220,0.14),rgba(180,196,220,0.05)); border-color:rgba(180,196,220,0.22); }
.leaderboard-podium.third { min-height:5.8rem; background:linear-gradient(180deg,rgba(255,173,92,0.16),rgba(255,173,92,0.05)); border-color:rgba(255,173,92,0.24); }
.leaderboard-podium-rank { font-size:0.42rem; font-weight:900; color:#fff0cb; letter-spacing:0.08em; text-shadow:0 1px 3px rgba(0,0,0,0.28); }
.leaderboard-podium.second .leaderboard-podium-rank { color:#eef4ff; }
.leaderboard-podium.third .leaderboard-podium-rank { color:#fff0de; }
.leaderboard-podium-avatar { position:relative; width:2.7rem; height:2.7rem; margin:0.04rem auto 0; border-radius:0.62rem; overflow:hidden; border:1px solid rgba(255,255,255,0.1); background:linear-gradient(180deg,rgba(255,107,53,0.18),rgba(100,181,246,0.12)); display:grid; place-items:center; box-shadow:0 8px 18px rgba(0,0,0,0.18); }
.leaderboard-podium-name { position:relative; width:100%; min-height:0.66rem; margin-top:0.04rem; padding:0 0.18rem; display:flex; align-items:center; justify-content:center; font-size:0.56rem; font-weight:900; color:#fff5e6; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; line-height:1.08; text-shadow:0 1px 2px rgba(0,0,0,0.26); z-index:3; }
.leaderboard-podium-progress { position:relative; min-height:0.48rem; margin-top:0.02rem; font-size:0.42rem; font-weight:800; color:#d6e6ff; letter-spacing:0.03em; z-index:2; }
.leaderboard-podium-meta { position:absolute; right:0.12rem; bottom:0.12rem; min-width:1rem; height:0.48rem; padding:0 0.15rem; border-radius:999px; display:flex; align-items:center; justify-content:center; background:rgba(7,10,20,0.78); border:1px solid rgba(255,255,255,0.14); font-size:0.3rem; font-weight:900; color:#f5f8ff; letter-spacing:0.01em; box-shadow:0 0.08rem 0.2rem rgba(0,0,0,0.22); z-index:3; }
.leaderboard-podium-stage { position:relative; width:100%; min-height:0.74rem; margin-top:auto; padding-bottom:0.02rem; z-index:2; pointer-events:none; display:flex; align-items:flex-end; justify-content:center; }
.leaderboard-podium-value { position:relative; text-align:center; font-size:0.6rem; font-weight:900; color:#ffe08a; line-height:1; text-shadow:0 1px 2px rgba(0,0,0,0.24); font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1; }
.leaderboard-podium-value-stage { display:inline-flex; align-items:center; justify-content:center; min-width:2.4rem; min-height:0.86rem; padding:0 0.34rem; border-radius:999px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.1); color:#fff4d2; }
.leaderboard-podium.first .leaderboard-podium-avatar { width:3.1rem; height:3.1rem; border-radius:0.68rem; box-shadow:0 10px 22px rgba(255,215,0,0.16); }
.leaderboard-podium.first .leaderboard-podium-name { min-height:0.72rem; font-size:0.62rem; }
.leaderboard-podium.first .leaderboard-podium-meta { right:0.14rem; bottom:0.14rem; min-width:1.1rem; height:0.54rem; font-size:0.32rem; }
.leaderboard-podium.first .leaderboard-podium-stage { min-height:0.84rem; }
.leaderboard-podium.first .leaderboard-podium-value { font-size:0.68rem; color:#fff2aa; }
.leaderboard-list { display:grid; gap:0.18rem; }
.leaderboard-row { width:100%; display:grid; grid-template-columns:1.1rem 1.7rem minmax(0,1fr) auto; align-items:center; gap:0.34rem; padding:0.34rem 0.38rem; border-radius:0.48rem; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05); text-align:left; }
.leaderboard-row.is-self { border-color:rgba(126,154,255,0.24); background:rgba(126,154,255,0.08); }
.leaderboard-row.top-1 { border-color:rgba(255,215,0,0.28); background:rgba(255,215,0,0.08); }
.leaderboard-row.top-2 { border-color:rgba(180,196,220,0.24); background:rgba(180,196,220,0.08); }
.leaderboard-row.top-3 { border-color:rgba(255,173,92,0.24); background:rgba(255,173,92,0.08); }
.leaderboard-rank { font-size:0.7rem; font-weight:900; color:#fff3d9; text-align:center; }
.leaderboard-avatar { width:1.7rem; height:1.7rem; border-radius:0.44rem; overflow:hidden; border:1px solid rgba(255,255,255,0.08); background:linear-gradient(180deg,rgba(255,107,53,0.18),rgba(100,181,246,0.12)); display:grid; place-items:center; }
.leaderboard-main { min-width:0; }
.leaderboard-name { font-size:0.58rem; font-weight:900; color:#fff5e4; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.leaderboard-self-tag { margin-left:0.22rem; padding:0.08rem 0.22rem; border-radius:999px; background:rgba(126,154,255,0.14); color:#c8d5ff; font-size:0.38rem; font-weight:800; vertical-align:middle; }
.leaderboard-meta { margin-top:0.06rem; font-size:0.44rem; color:#96a5bb; }
.leaderboard-side { text-align:right; }
.leaderboard-value { font-size:0.6rem; font-weight:900; color:#ffe08a; text-align:right; }
.leaderboard-value-stage { display:inline-flex; align-items:center; justify-content:center; min-width:2.1rem; min-height:0.82rem; padding:0 0.3rem; border-radius:999px; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08); color:#fff0ce; }
.leaderboard-view { margin-top:0.06rem; font-size:0.4rem; color:#9db3ff; font-weight:800; }
.leaderboard-empty { padding:1rem 0.4rem; text-align:center; font-size:0.56rem; color:#98a8bf; }
.leaderboard-player-overlay { position:fixed; inset:0; z-index:50; background:rgba(3,5,12,0.76); backdrop-filter:blur(6px); }
.leaderboard-player-dialog { position:fixed; left:50%; top:50%; transform:translate(-50%,-50%); z-index:51; width:min(calc(100vw - 0.8rem), 16rem); height:auto; max-height:calc(100vh - 0.8rem); overflow-x:hidden; overflow-y:auto; padding:0.72rem; border-radius:0.56rem; border:1px solid rgba(255,255,255,0.08); background:linear-gradient(180deg,rgba(12,14,24,0.98),rgba(8,10,18,0.99)); box-shadow:0 20px 48px rgba(0,0,0,0.32); display:grid; gap:0.56rem; scrollbar-width:none; -ms-overflow-style:none; }
.leaderboard-player-dialog::-webkit-scrollbar { width:0; height:0; display:none; }
.leaderboard-player-head { display:flex; align-items:flex-start; justify-content:space-between; gap:0.4rem; }
.leaderboard-player-profile { display:flex; align-items:center; gap:0.42rem; min-width:0; }
.leaderboard-player-avatar { width:2.4rem; height:2.4rem; border-radius:0.56rem; overflow:hidden; border:1px solid rgba(255,255,255,0.08); background:linear-gradient(180deg,rgba(255,107,53,0.18),rgba(100,181,246,0.12)); display:grid; place-items:center; }
.leaderboard-player-copy { min-width:0; }
.leaderboard-player-name { font-size:0.72rem; font-weight:900; color:#fff5e4; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.leaderboard-player-meta { margin-top:0.08rem; font-size:0.46rem; color:#a9b7cb; line-height:1.5; }
.leaderboard-player-close { flex:0 0 auto; min-height:1.46rem; padding:0.18rem 0.5rem; border-radius:0.42rem; border:1px solid rgba(255,255,255,0.08); background:rgba(255,255,255,0.04); color:#d9e3f0; font-size:0.48rem; font-weight:800; }
.leaderboard-player-section { display:grid; gap:0.26rem; }
.leaderboard-player-title { font-size:0.58rem; font-weight:900; color:#fff3dc; }
.leaderboard-formation-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:0.26rem; }
.leaderboard-formation-slot { padding:0.3rem 0.26rem 0.28rem; border-radius:0.46rem; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06); display:grid; justify-items:center; align-content:start; gap:0.14rem; min-width:0; text-align:center; }
.leaderboard-formation-slot.empty { display:flex; justify-content:center; align-items:center; min-height:4.2rem; color:#7f8aa0; font-size:0.5rem; }
.leaderboard-formation-slot.ssr { border-color:rgba(255,215,0,0.18); }
.leaderboard-formation-slot.ss { border-color:rgba(0,188,212,0.18); }
.leaderboard-formation-slot.sr { border-color:rgba(179,136,255,0.18); }
.leaderboard-formation-art { position:relative; width:100%; aspect-ratio:1 / 1; border-radius:0.42rem; overflow:hidden; background:var(--c2); }
.leaderboard-formation-art img { width:100%; height:100%; object-fit:cover; }
.leaderboard-formation-copy { min-width:0; width:100%; }
.leaderboard-formation-name { font-size:0.54rem; font-weight:900; color:#fff5e4; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.leaderboard-formation-meta { margin-top:0.08rem; display:flex; align-items:center; justify-content:center; gap:0.16rem; flex-wrap:wrap; font-size:0.42rem; color:#9aa8bd; }
.leaderboard-formation-stars { position:absolute; left:0.16rem; bottom:0.16rem; padding:0.08rem 0.14rem; border-radius:0.22rem; background:linear-gradient(180deg,rgba(0,0,0,0.46),rgba(0,0,0,0.24)); font-size:0.46rem; color:#ffd86d; letter-spacing:0.04em; line-height:1; text-shadow:0 1px 2px rgba(0,0,0,0.45); }
.settings-stack { display:flex; flex-direction:column; gap:0.48rem; align-items:stretch; width:100%; max-width:none; margin:0 auto; }
.settings-group { padding:0.56rem; border-radius:0.5rem; border:1px solid rgba(255,255,255,0.06); background:linear-gradient(180deg,rgba(15,15,24,0.94),rgba(9,9,16,0.96)); display:grid; gap:0.38rem; }
.settings-group-title { font-size:0.64rem; font-weight:900; color:#fff5df; }
.settings-field { display:grid; gap:0.16rem; }
.settings-label { font-size:0.48rem; color:#aebbd0; font-weight:700; }
.settings-inline-field { display:flex; align-items:center; gap:0.32rem; }
.settings-inline-label { flex:0 0 auto; font-size:0.52rem; color:#aebbd0; font-weight:700; white-space:nowrap; }
.settings-input-inline { flex:1 1 auto; min-width:0; }
.settings-input { width:100%; min-height:1.78rem; padding:0.36rem 0.46rem; border-radius:0.42rem; border:1px solid rgba(255,255,255,0.08); background:rgba(255,255,255,0.04); color:#fff4de; font-size:0.58rem; }
.settings-input:focus { outline:none; border-color:rgba(255,177,74,0.34); box-shadow:0 0 0 2px rgba(255,177,74,0.08); }
.settings-row { width:100%; padding:0.48rem 0.5rem; border-radius:0.48rem; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.03); color:var(--text); display:flex; align-items:center; justify-content:space-between; gap:0.36rem; text-align:left; }
.settings-row-main { min-width:0; display:grid; gap:0.1rem; }
.settings-row-label { font-size:0.58rem; font-weight:800; color:#fff4de; }
.settings-row-value { font-size:0.46rem; color:#aebbd0; line-height:1.5; }
.settings-row-action { flex:0 0 auto; padding:0.14rem 0.34rem; border-radius:999px; background:rgba(255,177,74,0.1); color:#ffcf84; font-size:0.46rem; font-weight:800; }
.settings-avatar-upload-preview { width:4.2rem; height:4.2rem; margin:0 auto 0.1rem; border-radius:0.7rem; overflow:hidden; border:1px solid rgba(255,255,255,0.08); background:linear-gradient(180deg,rgba(255,107,53,0.18),rgba(100,181,246,0.12)); display:grid; place-items:center; box-shadow:0 10px 24px rgba(0,0,0,0.18); }
.settings-file-input { width:100%; padding:0.38rem 0.42rem; border-radius:0.42rem; border:1px dashed rgba(255,255,255,0.14); background:rgba(255,255,255,0.03); color:#dbe5f2; font-size:0.54rem; }
.settings-file-input::file-selector-button { margin-right:0.42rem; min-height:1.5rem; padding:0.16rem 0.5rem; border:none; border-radius:0.36rem; background:linear-gradient(135deg,#3b82f6,#2563eb); color:#fff; font-size:0.5rem; font-weight:800; cursor:pointer; }
.settings-save-btn,
.settings-logout-btn { width:100%; min-height:var(--btn-h-md); padding:0.58rem 0.8rem; border:none; border-radius:var(--radius-sm); font-size:0.66rem; font-weight:900; letter-spacing:0.04em; text-decoration:none; display:block; text-align:center; color:#fff; }
.settings-save-btn { background:linear-gradient(135deg,#3b82f6,#2563eb); box-shadow:0 10px 22px rgba(37,99,235,0.22); }
.settings-save-btn-alt { background:linear-gradient(135deg,#6d5dfc,#4f46e5); box-shadow:0 10px 22px rgba(79,70,229,0.22); }
.settings-logout-btn { background:linear-gradient(135deg,#ff6b35,#e85d04); box-shadow:0 10px 22px rgba(232,93,4,0.24); }
.settings-dialog-overlay { position:fixed; inset:0; z-index:40; background:rgba(3,5,12,0.72); backdrop-filter:blur(6px); }
.settings-dialog { position:fixed; left:50%; top:50%; z-index:41; width:min(calc(100vw - 0.9rem), 14rem); transform:translate(-50%,-50%); height:auto; max-height:calc(100vh - 0.9rem); overflow-x:hidden; overflow-y:auto; padding:0.7rem; border-radius:0.56rem; border:1px solid rgba(255,255,255,0.08); background:linear-gradient(180deg,rgba(12,14,24,0.98),rgba(8,10,18,0.99)); box-shadow:0 20px 48px rgba(0,0,0,0.28); display:grid; gap:0.48rem; scrollbar-width:none; -ms-overflow-style:none; }
.settings-dialog::-webkit-scrollbar { width:0; height:0; display:none; }
.settings-dialog-head { display:flex; align-items:flex-start; justify-content:space-between; gap:0.4rem; }
.settings-dialog-title { font-size:0.82rem; font-weight:900; color:#fff4de; }
.settings-dialog-sub { margin-top:0.1rem; font-size:0.5rem; line-height:1.66; color:#aebbd0; }
.settings-dialog-close { flex:0 0 auto; min-height:1.46rem; padding:0.18rem 0.5rem; border-radius:0.42rem; border:1px solid rgba(255,255,255,0.08); background:rgba(255,255,255,0.04); color:#d9e3f0; font-size:0.48rem; font-weight:800; }

@media (max-width: 768px) {
  .settings-dialog { width:min(calc(100vw - 0.72rem), 14.8rem); padding:0.74rem; }
  .settings-group { padding:0.62rem; }
  .leaderboard-row { grid-template-columns:0.9rem 1.5rem minmax(0,1fr) auto; }
  .settings-input { min-height:1.92rem; font-size:0.62rem; }
  .settings-inline-field { gap:0.24rem; }
  .settings-inline-label { font-size:0.54rem; }
}

.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.48rem 0.38rem; }

.tc { background: transparent; border: 0; padding: 0.08rem; text-align: center; position: relative; overflow: visible; }

.tc.ssr .tc-iw { border-color: rgba(255, 215, 0, 0.66); box-shadow: rgba(255, 215, 0, 0.14) 0px 0px 10px; background: linear-gradient(180deg, rgba(255,215,0,0.1), rgba(0,0,0,0.05)); }

.tc.sr .tc-iw { border-color: rgba(179, 136, 255, 0.6); background: linear-gradient(180deg, rgba(179,136,255,0.08), rgba(0,0,0,0.04)); }

.tc.ss .tc-iw { border-color: rgba(0, 188, 212, 0.62); box-shadow: rgba(0, 188, 212, 0.12) 0px 0px 10px; background: linear-gradient(180deg, rgba(0,188,212,0.08), rgba(0,0,0,0.04)); }

.tc.empty { opacity: 0.78; min-height: auto; font-size: 0.5rem; color: var(--dim); }

.tc-iw { position: relative; border-radius: 0.52rem; overflow: hidden; border: 2px solid var(--border); background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(0,0,0,0.03)); aspect-ratio: 1 / 1; box-shadow: 0 5px 12px rgba(0,0,0,0.14); }
.tc-iw::before { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(255,255,255,0.015), transparent 30%, rgba(0,0,0,0.16)); pointer-events:none; z-index:1; }

.tc img { width: 100%; height: 100%; object-fit: cover; background: var(--c3); transform: scale(1.02); }

.tc-r { position: absolute; left: 0.14rem; bottom: 0.92rem; font-size: 1.02rem; font-weight: 900; font-style: italic; line-height: 1; text-shadow: rgba(0, 0, 0, 0.88) 0px 1px 3px; z-index: 2; letter-spacing: -0.05em; }

.tc-r.ssr { color: rgb(255, 215, 0); }

.tc-r.sr { color: rgb(179, 136, 255); }

.tc-r.ss { color: rgb(0, 188, 212); }

.tc-elem-badge { position: absolute; top: 0.14rem; left: 0.14rem; width: 1.12rem; height: 1.12rem; border-radius: 0.22rem; display: inline-flex; align-items: center; justify-content: center; padding: 0; background: rgba(10, 12, 16, 0.9); color: #f7f1df; font-size: 0.44rem; font-weight: 900; line-height: 1; letter-spacing: 0; text-align: center; box-shadow: 0 2px 6px rgba(0,0,0,0.28); z-index: 3; border: 1px solid rgba(255,255,255,0.16); text-shadow: none; }
.tc-level-badge { position: absolute; top: 0.16rem; right: 0.16rem; min-width: 1.38rem; padding: 0.06rem 0.22rem; border-radius: 0.38rem; background: rgba(0, 0, 0, 0.62); color: #fff5df; font-size: 0.46rem; font-weight: 900; line-height: 1.2; z-index: 2; }
.tc-stars { position: absolute; left: 0.14rem; bottom: 0.16rem; transform: none; display:flex; align-items:center; gap:0.04rem; padding: 0; white-space: nowrap; z-index: 3; }
.tc-star-icon { width:0.7rem; height:0.7rem; display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; }
.tc-star-icon svg { width:100%; height:100%; stroke-width:1.2; }
.tc-star-icon.is-on svg { fill:#ffd54f; stroke:#fff7c8; filter:drop-shadow(0 1px 1px rgba(120,72,0,0.42)) drop-shadow(0 0 5px rgba(255,215,92,0.58)); }
.tc-star-icon.is-off svg { fill:rgba(255,255,255,0.18); stroke:rgba(255,245,215,0.42); filter:none; }
.tc-form-tag { position: absolute; right: 0.14rem; bottom: 0.16rem; padding: 0.07rem 0.24rem; border-radius: 0.3rem; background: rgba(255, 107, 53, 0.92); color: #fff; font-size: 0.42rem; font-weight: 900; line-height: 1.15; z-index: 2; box-shadow: 0 1px 4px rgba(0,0,0,0.14); }
.tc-alert-dot { position: absolute; top: 0.04rem; right: 0.04rem; width: 0.58rem; height: 0.58rem; border-radius: 50%; background: radial-gradient(circle at 32% 28%, #ffb6b6 0%, #ff6666 24%, #ff3434 58%, #d91616 100%); border: 2px solid #fff4e6; box-shadow: 0 0 0 2px rgba(255,67,67,0.2), 0 3px 8px rgba(103, 0, 0, 0.28); z-index: 5; animation: alertDotPulse 1.9s ease-in-out infinite; }
.tc-alert-dot::after { content: ''; position: absolute; top: 0.08rem; left: 0.11rem; width: 0.2rem; height: 0.12rem; border-radius: 999px; background: rgba(255,255,255,0.82); transform: rotate(-18deg); }
.tc-alert-dot::before { content: ''; position: absolute; inset: -0.09rem; border-radius: 50%; border: 1px solid rgba(255, 124, 124, 0.5); opacity: 0; animation: alertDotRing 1.9s ease-out infinite; }
@keyframes alertDotPulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 2px rgba(255,67,67,0.18), 0 3px 8px rgba(103,0,0,0.24); }
  50% { transform: scale(1.08); box-shadow: 0 0 0 3px rgba(255,67,67,0.22), 0 4px 10px rgba(103,0,0,0.32); }
}
@keyframes alertDotRing {
  0% { transform: scale(0.88); opacity: 0; }
  30% { opacity: 0.38; }
  100% { transform: scale(1.18); opacity: 0; }
}

.tc-name-row { display:flex; align-items:center; justify-content:center; gap:0.12rem; margin-top:0.18rem; min-height:0.74rem; }
.tc-nm { font-size: 0.68rem; font-weight: 900; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: #fff4de; line-height: 1.08; max-width: calc(100% - 1.58rem); letter-spacing: 0.01em; }
.tc-name-row .job-badge { flex:0 0 auto; font-size: 0.5rem; padding: 0.04rem 0.18rem; border-radius: 0.28rem; }
.tc-nm-empty { opacity: 0.5; }
.tc-job-dim { opacity: 0.42; }
.tc-iw-empty { opacity: 0.26; filter: grayscale(0.16); }

.empty-state-card { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.24rem; padding:0.9rem 0.7rem; border:1px solid rgba(255,255,255,0.08); border-radius:0.46rem; background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(0,0,0,0.05)); text-align:center; }
.empty-state-title { font-size:0.62rem; font-weight:900; color:#fff4de; line-height:1.2; }
.empty-state-copy { max-width:8rem; font-size:0.42rem; line-height:1.7; color:rgba(255,244,222,0.72); }

@media (max-width: 768px) {
  .train-scene-meta { grid-template-columns:repeat(4,1fr); }
  .summon-banner-metrics { grid-template-columns:1fr; }
  .summon-action-bar-top { gap:0.26rem; }
  .summon-action-bar-top .summon-btn { flex:1 1 calc(50% - 0.13rem); min-width:0; max-width:none; }
  .feature-grid { grid-template-columns:1fr; }
  .feature-card.is-wide { grid-column:auto; }
  .formation-scene-meta { grid-template-columns:repeat(2,1fr); }
  .battle-action-wrap { gap:0.22rem; }
  .battle-go { min-width:0; width:100%; }
}

.tc.ssr .tc-iw::after { content: ""; position: absolute; top: 0px; left: -100%; width: 50%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 215, 0, 0.1), transparent); animation: 3s ease 0s infinite normal none running ssrShimmer; }

.tc.ss .tc-iw::after { content: ""; position: absolute; top: 0px; left: -100%; width: 50%; height: 100%; background: linear-gradient(90deg, transparent, rgba(0, 188, 212, 0.1), transparent); animation: 3s ease 0s infinite normal none running ssrShimmer; }

.tr-c { background: var(--c1); border: 1px solid var(--border); border-radius: 10px; padding: 0.45rem; margin-bottom: 0.35rem; display: flex; gap: 0.45rem; overflow: hidden; }

.tr-c.ssr { border-color: rgba(255, 215, 0, 0.2); }

.tr-c.sr { border-color: rgba(179, 136, 255, 0.2); }

.tr-c.ss { border-color: rgba(0, 188, 212, 0.2); }

.tr-iw { position: relative; flex-shrink: 0; }

.tr-c img { width: 50px; height: 50px; border-radius: 8px; object-fit: cover; background: var(--c3); }

.tr-rb { position: absolute; bottom: -1px; left: 50%; transform: translateX(-50%); font-size: 0.4rem; font-weight: 900; padding: 0px 4px; border-radius: 3px; }

.tr-rb.ssr { background: linear-gradient(135deg, rgb(255, 215, 0), rgb(255, 159, 28)); color: rgb(0, 0, 0); }

.tr-rb.sr { background: linear-gradient(135deg, rgb(179, 136, 255), rgb(124, 77, 255)); color: rgb(255, 255, 255); }

.tr-rb.ss { background: linear-gradient(135deg, rgb(0, 188, 212), rgb(0, 151, 167)); color: rgb(255, 255, 255); }

.tr-info { flex: 1 1 0%; min-width: 0px; }

.tr-nm { font-weight: 900; font-size: 0.75rem; }

.tr-st { color: var(--gold); font-size: 0.5rem; letter-spacing: 1px; }

.tr-exp { width: 100%; height: 4px; background: var(--c3); border-radius: 2px; overflow: hidden; margin: 2px 0px; }

.tr-exp-f { height: 100%; border-radius: 2px; background: linear-gradient(90deg, rgb(59, 130, 246), rgb(96, 165, 250)); transition: width 0.3s; }

.tr-sub { font-size: 0.45rem; color: var(--dim); }

.tr-btns { display: flex; gap: 0.25rem; margin-top: 2px; flex-wrap: wrap; }

.tr-btn { min-height: var(--btn-h-sm); padding: 0.24rem 0.46rem; border-radius: 0.55rem; font-size: 0.5rem; font-weight: 700; color: rgb(255, 255, 255); display:inline-flex; align-items:center; justify-content:center; }

.tr-btn.lv { background: linear-gradient(135deg, rgb(59, 130, 246), rgb(37, 99, 235)); }

.tr-btn.star { background: linear-gradient(135deg, rgb(255, 215, 0), rgb(232, 160, 0)); color: rgb(0, 0, 0); }

.tr-btn.eq { background: linear-gradient(135deg, rgb(16, 185, 129), rgb(5, 150, 105)); }

.tr-btn:disabled { opacity: 0.2; }

.tr-eq { display: flex; gap: 0.2rem; margin-top: 2px; }

.tr-eq-s { flex: 1 1 0%; background: var(--c2); border: 1px solid var(--border); border-radius: 4px; padding: 2px; font-size: 0.44rem; text-align: center; line-height: 1.3; }

.tr-eq-s .eq-i { font-size: 0.55rem; }

.tr-eq-s .eq-l { color: var(--accent); font-weight: 700; }

#gacha { background: radial-gradient(ellipse at 50% 25%,rgba(255,215,0,0.12),transparent 55%),radial-gradient(ellipse at 30% 70%,rgba(179,136,255,0.06),transparent 50%),var(--bg); padding: 0.8rem; align-items: center; gap: 0.5rem; overflow-y: auto; overflow-x: hidden; }

.gacha-title { font-family: var(--font); font-size: 1.55rem; font-weight:900; background: linear-gradient(135deg, rgb(255, 215, 0), rgb(255, 159, 28), rgb(255, 215, 0)) text; -webkit-text-fill-color: transparent; filter: drop-shadow(rgba(255, 215, 0, 0.12) 0px 2px 4px); }

.gacha-pool { display: flex; gap: 0.3rem; flex-wrap: wrap; justify-content: center; }

.gacha-pool img { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; border: 2px solid var(--c3); opacity: 0.35; }

.gacha-res { min-height: 180px; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 0.4rem; }

.gc { text-align: center; animation: 0.7s ease 0s 1 normal none running gachaReveal; }

.gc img { width: 115px; height: 115px; border-radius: 14px; object-fit: cover; border: 3px solid var(--gold); box-shadow: rgba(255, 215, 0, 0.3) 0px 0px 35px; }

.gc.ssr-rev img { box-shadow: rgba(255, 215, 0, 0.4) 0px 0px 50px, rgba(255, 215, 0, 0.12) 0px 0px 100px; }

.gc.sr-rev img { border-color: rgb(179, 136, 255); box-shadow: rgba(179, 136, 255, 0.35) 0px 0px 35px; }

.gc.ss-rev img { border-color: rgb(0, 188, 212); box-shadow: rgba(0, 188, 212, 0.35) 0px 0px 35px; }

.gc-r { font-size: 0.7rem; font-weight: 900; margin-top: 0.25rem; letter-spacing: 0.1em; }

.gc-r.ssr { color: rgb(255, 215, 0); text-shadow: rgba(255, 215, 0, 0.5) 0px 0px 10px; }

.gc-r.sr { color: rgb(179, 136, 255); }

.gc-r.ss { color: rgb(0, 188, 212); }

.gc-nm { font-weight: 900; font-size: 1.05rem; margin-top: 0.1rem; }

.gc-info { font-size: 0.65rem; color: var(--dim); }

.gc-sub { font-size: 0.65rem; margin-top: 0.15rem; }

.g-btns { display: flex; gap: 0.5rem; }

.g-btn { min-height: var(--btn-h-lg); padding: 0.68rem 1.2rem; border-radius: 0.8rem; font-size: 0.8rem; font-weight: 700; color: rgb(255, 255, 255); box-shadow: rgba(0, 0, 0, 0.16) 0px 3px 10px; }

.g-btn.p1 { background: linear-gradient(135deg,var(--gold),#e8a000); }

.g-btn.p10 { background: linear-gradient(135deg, rgb(255, 107, 53), rgb(232, 93, 4)); }

.g-btn:disabled { opacity: 0.2; }

.g-back { font-size: 0.65rem; color: var(--dim); background: var(--c2); padding: 0.35rem 1rem; border-radius: 8px; }

#formation { background: var(--bg); padding: 0.5rem; gap: 0.35rem; }

.form-title { font-family: var(--font); font-size: 1rem; font-weight:900; color: var(--accent); text-align: center; }

.form-field { background: var(--c1); border: 1px solid var(--border); border-radius: 10px; padding: 0.4rem; flex: 1 1 0%; display: flex; flex-direction: column; gap: 0.25rem; }

.form-rl { font-size: 0.5rem; color: var(--dim); font-weight: 700; }

.form-row { display: flex; gap: 0.35rem; justify-content: center; }

.f-slot { width: 56px; height: 62px; background: var(--c2); border: 2px dashed var(--border); border-radius: 8px; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: 0.4rem; color: var(--dim); position: relative; }

.f-slot.filled { border-style: solid; }

.f-slot.ssr { border-color: rgba(255, 215, 0, 0.4); }

.f-slot.sr { border-color: rgba(179, 136, 255, 0.4); }

.f-slot.ss { border-color: rgba(0, 188, 212, 0.4); }

.f-slot img { width: 40px; height: 40px; border-radius: 6px; object-fit: cover; }

.f-slot .fn { font-size: 0.4rem; font-weight: 700; margin-top: 1px; }

.f-slot .fx { position: absolute; top: -3px; right: -3px; width: 13px; height: 13px; background: var(--red); color: rgb(255, 255, 255); font-size: 0.4rem; font-weight: 700; border-radius: 50%; display: flex; align-items: center; justify-content: center; }

.f-bench { display: flex; gap: 0.3rem; flex-wrap: wrap; justify-content: center; padding: 0.15rem 0px; }

.fb { width: 46px; text-align: center; opacity: 0.5; }

.fb.av { opacity: 1; }

.fb img { width: 38px; height: 38px; border-radius: 6px; object-fit: cover; border: 2px solid var(--border); }

.fb .fbn { font-size: 0.44rem; font-weight: 700; margin-top: 1px; }

.f-go { width: 100%; min-height: var(--btn-h-lg); padding: 0.68rem 0.8rem; border-radius: 0.8rem; font-size: 0.9rem; font-weight: 700; color: rgb(255, 255, 255); background: linear-gradient(135deg, rgb(220, 38, 38), rgb(234, 88, 12)); }

.f-go:disabled { opacity: 0.2; }

.f-back { text-align: center; font-size: 0.6rem; color: var(--dim); padding: 0.2rem; background: none; }

.syn-row { display: flex; gap: 0.2rem; justify-content: center; flex-wrap: wrap; }

.syn-tag { font-size: 0.4rem; padding: 1px 5px; border-radius: 10px; background: rgba(255, 215, 0, 0.08); color: var(--gold); font-weight: 700; border: 1px solid rgba(255, 215, 0, 0.1); cursor: pointer; transition: 0.2s; }
.syn-tag:active { background: rgba(255, 215, 0, 0.2); }
.syn-detail-popup { position:absolute; inset:0; z-index:200; display:flex; align-items:center; justify-content:center; background:rgba(0,0,0,0.7); }
.syn-detail-box { background:var(--c1); border:1px solid var(--border); border-radius:14px; padding:0.5rem; width:85%; max-width:350px; height:auto; max-height:calc(100vh - 1.2rem); overflow-x:hidden; overflow-y:auto; scrollbar-width:none; -ms-overflow-style:none; }
.syn-detail-box::-webkit-scrollbar { width:0; height:0; display:none; }
.syn-detail-header { font-size:0.6rem; font-weight:900; color:var(--gold); text-align:center; margin-bottom:0.2rem; }
.syn-detail-desc { font-size:0.46rem; color:var(--dim); text-align:center; margin-bottom:0.2rem; }
.syn-detail-bonus { font-size:0.48rem; color:#22c55e; font-weight:700; text-align:center; padding:0.2rem; background:rgba(34,197,94,0.08); border-radius:8px; margin:0.2rem 0; }
.syn-detail-members { display:flex; gap:6px; flex-wrap:wrap; justify-content:center; margin:0.2rem 0; }
.syn-detail-member { display:flex; flex-direction:column; align-items:center; gap:2px; font-size:0.4rem; width:50px; }
.syn-detail-member img { width:36px; height:36px; border-radius:50%; object-fit:cover; border:2px solid var(--border); }
.syn-detail-member.in-form img { border-color:#22c55e; }
.syn-detail-member.owned img { border-color:var(--gold); }
.syn-detail-member.missing img { opacity:0.35; border-color:rgba(255,255,255,0.1); }
.team-syn-section { margin:0.15rem 0; }
.team-syn-list { display:flex; flex-direction:column; gap:0.15rem; margin-top:0.1rem; }
.team-syn-item { display:flex; align-items:center; gap:0.2rem; padding:0.18rem 0.25rem; background:rgba(255,215,0,0.06); border:1px solid rgba(255,215,0,0.15); border-radius:8px; cursor:pointer; transition:0.2s; }
.team-syn-item:active { background:rgba(255,215,0,0.12); }
.team-syn-icon { font-size:0.6rem; }
.team-syn-name { font-size:0.6rem; font-weight:800; color:var(--gold); }
.team-syn-bonus { font-size:0.6rem; color:#22c55e; flex:1; text-align:right; }

#battle { background: var(--bg); padding: 0px; overflow: hidden; position: relative; }

.b-hdr { display:flex; align-items:center; justify-content:space-between; gap:0.4rem; padding:0.44rem 0.56rem; background:linear-gradient(180deg,rgba(6,8,14,0.88),rgba(6,8,14,0.38),transparent); position:relative; z-index:5; }
.b-back,
.b-spd,
.b-turn-chip { min-height:1.28rem; padding:0.16rem 0.42rem; border-radius:0.36rem; border:1px solid rgba(255,255,255,0.1); background:rgba(255,255,255,0.05); color:#f5efe0; font-size:0.48rem; font-weight:800; }
.b-back { flex:0 0 auto; }
.b-stage-wrap { min-width:0; flex:1 1 auto; text-align:center; }
.b-stage-mode { font-size:0.38rem; letter-spacing:0.08em; text-transform:uppercase; color:#ffb48d; font-weight:800; }
.b-stage { margin-top:0.04rem; font-size:0.62rem; color:#fff8ee; font-weight:900; text-shadow:rgba(0,0,0,0.5) 0 1px 3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.b-hud-actions { display:flex; align-items:center; gap:0.18rem; flex:0 0 auto; }
.b-turn-chip { display:inline-flex; align-items:center; gap:0.1rem; color:#ffe4a3; }
.b-turn-chip span { color:#ffd45f; font-size:0.52rem; font-weight:900; }
.b-spd { color:var(--accent); border-color:rgba(255,107,53,0.22); background:rgba(255,107,53,0.12); }
.b-spd.is-limited { position:relative; padding-right:0.56rem; }
.b-spd.is-limited::after { content:""; position:absolute; right:0.16rem; top:0.18rem; width:0.28rem; height:0.28rem; border-radius:50%; background:#ff6262; box-shadow:0 0 0.12rem rgba(255,98,98,0.58); }

.b-field { flex: 1 1 0%; display: flex; flex-direction: column; justify-content: space-between; position: relative; overflow: hidden; background: radial-gradient(at 50% 45%, rgba(30, 30, 80, 0.5), transparent 70%), linear-gradient(rgb(8, 8, 24) 0%, rgb(14, 22, 48) 25%, rgb(26, 14, 48) 50%, rgb(14, 22, 48) 75%, rgb(8, 8, 24) 100%); }

.b-field::before { content: ""; position: absolute; inset: 0px; background: repeating-linear-gradient(0deg, transparent, transparent 50px, rgba(255, 255, 255, 0.008) 50px, rgba(255, 255, 255, 0.008) 51px), repeating-linear-gradient(90deg, transparent, transparent 50px, rgba(255, 255, 255, 0.008) 50px, rgba(255, 255, 255, 0.008) 51px); pointer-events: none; }

#b-particles { position: absolute; inset: 0px; pointer-events: none; z-index: 0; opacity: 0.45; }

.b-side { position: relative; z-index: 2; padding: 0.6rem 0px; }

.b-row { display: flex; justify-content: center; gap: 0.35rem; padding: 0.25rem 0px; }

.b-unit { width: 64px; display: flex; flex-direction: column; align-items: center; gap: 3px; position: relative; transition: transform 0.15s, opacity 0.3s, filter 0.3s; }

.b-unit.dead { opacity: 0.1; filter: grayscale(1) blur(1px); transform: scale(0.8); }

.b-frame { position: relative; width: 56px; height: 56px; border-radius: 12px; overflow: hidden; border: 2px solid rgba(255, 255, 255, 0.12); box-shadow: rgba(0, 0, 0, 0.5) 0px 3px 12px; }

.b-unit[data-e="火"] .b-frame { border-color: rgba(255, 77, 42, 0.55); }

.b-unit[data-e="风"] .b-frame { border-color: rgba(52, 211, 153, 0.55); }

.b-unit[data-e="岩"] .b-frame { border-color: rgba(245, 158, 11, 0.55); }

.b-unit[data-e="雷"] .b-frame { border-color: rgba(168, 85, 247, 0.55); }

.b-unit[data-e="暗"] .b-frame { border-color: rgba(139, 92, 246, 0.55); }

.b-unit[data-e="光"] .b-frame { border-color: rgba(251, 191, 36, 0.55); }

.b-unit.ssr .b-frame { box-shadow: rgba(255, 215, 0, 0.2) 0px 0px 12px, rgba(0, 0, 0, 0.5) 0px 3px 12px; }

.b-frame img { width: 100%; height: 100%; object-fit: cover; background: var(--c3); }

.b-frame .b-elem { position: absolute; top: 2px; left: 2px; font-size: 0.42rem; background: rgba(0, 0, 0, 0.62); border-radius: 3px; padding: 0px 3px; }

.b-frame .b-rdot { position: absolute; bottom: 1px; right: 1px; font-size: 0.36rem; font-weight: 900; padding: 0px 2px; border-radius: 2px; }

.b-rdot.ssr { background: rgba(255, 215, 0, 0.7); color: rgb(0, 0, 0); }

.b-rdot.sr { background: rgba(179, 136, 255, 0.7); color: rgb(255, 255, 255); }

.b-rdot.ss { background: rgba(0, 188, 212, 0.7); color: rgb(255, 255, 255); }

.b-meta { width:64px; display:flex; align-items:center; justify-content:space-between; gap:0.12rem; }
.b-nm { min-width:0; font-size: 0.46rem; font-weight: 800; white-space: nowrap; overflow:hidden; text-overflow:ellipsis; text-shadow: rgba(0, 0, 0, 0.9) 0px 1px 3px; }
.b-hp-text { flex:0 0 auto; font-size:0.34rem; font-weight:800; color:#d5dbe6; }

.b-bars { width: 64px; display: flex; flex-direction: column; gap: 2px; }

.b-hp { width: 100%; height: 5px; background: rgba(0, 0, 0, 0.5); border-radius: 2px; overflow: hidden; }

.b-hp-f { height: 100%; border-radius: 2px; transition: width 0.4s; }

.b-unit.ally .b-hp-f { background: linear-gradient(90deg, rgb(16, 185, 129), rgb(45, 212, 191)); }

.b-unit.foe .b-hp-f { background: linear-gradient(90deg, rgb(220, 38, 38), rgb(255, 68, 68)); }

.b-rage { width: 100%; height: 3px; background: rgba(0, 0, 0, 0.4); border-radius: 2px; overflow: hidden; }

.b-rage-f { height: 100%; border-radius: 2px; background: linear-gradient(90deg, rgb(249, 115, 22), rgb(251, 191, 36)); transition: width 0.3s; }

.b-unit.rage-full .b-frame { animation: 0.8s ease 0s infinite normal none running rageGlow; box-shadow: rgba(255, 200, 0, 0.5) 0px 0px 20px !important; }

.b-unit.rage-full .b-frame::after { content: ""; position: absolute; inset: 0px; border: 2px solid rgba(255, 215, 0, 0.5); border-radius: 8px; animation: 0.8s ease 0s infinite normal none running rageBorder; }

.b-unit.acting { z-index: 10; }

.b-unit.acting .b-frame { box-shadow: rgba(255, 255, 255, 0.4) 0px 0px 26px, rgba(255, 107, 53, 0.3) 0px 0px 45px !important; transform: scale(1.12); }

.b-vs { text-align: center; font-size: 0.72rem; font-weight: 900; color: var(--accent); text-shadow: rgba(255, 107, 53, 0.4) 0px 0px 8px; padding: 0.05rem; position: relative; z-index: 2; }

.b-vs::before, .b-vs::after { content: ""; display: inline-block; width: 35px; height: 1px; background: linear-gradient(90deg, transparent, rgba(255, 107, 53, 0.25), transparent); vertical-align: middle; margin: 0px 0.3rem; }

.b-syn { display: flex; gap: 0.2rem; justify-content: center; flex-wrap: wrap; padding: 0.15rem 0.4rem; background: linear-gradient(0deg, rgba(0, 0, 0, 0.6), transparent); position: relative; z-index: 5; }

.float-dmg { position: absolute; font-family: var(--impact); font-weight: 800; pointer-events: none; z-index: 20; text-shadow: rgba(0, 0, 0, 0.95) 0px 2px 6px, rgba(0,0,0,0.7) 0px 0px 12px, currentcolor 0px 0px 18px; animation: 2.5s ease-out 0s 1 normal forwards running floatDmg; font-size: 1.3rem; letter-spacing: 0.5px; -webkit-text-stroke: 0.5px rgba(0,0,0,0.3); }

.float-dmg.big { font-size: 2rem; }

.float-dmg.heal { color: var(--green); animation: 2s ease-out 0s 1 normal forwards running floatHeal; font-size: 1.15rem; }

.impact-ring { position: absolute; width: 34px; height: 34px; border-radius: 50%; border: 3px solid; pointer-events: none; z-index: 15; animation: 0.5s ease-out 0s 1 normal forwards running impactRing; }

.slash-fx { position: absolute; width: 50px; height: 3px; border-radius: 2px; pointer-events: none; z-index: 15; animation: 0.35s ease-out 0s 1 normal forwards running slashFx; transform-origin: left center; }

.skill-burst { position: absolute; width: 65px; height: 65px; border-radius: 50%; pointer-events: none; z-index: 15; animation: 0.7s ease-out 0s 1 normal forwards running skillBurst; }

.b-flash { position: absolute; inset: 0px; pointer-events: none; z-index: 50; opacity: 0; transition: opacity 0.1s; }

.b-start { position: absolute; inset: 0px; display: flex; align-items: center; justify-content: center; z-index: 60; background: rgba(0, 0, 0, 0.7); pointer-events: none; }

.b-start-t { font-family: var(--title); font-size: 2.6rem; color: rgb(255, 255, 255); text-shadow: 0 0 28px var(--accent),0 0 55px rgba(255,107,53,0.4); animation: 1.2s ease 0s 1 normal forwards running battleStart; }

.skill-banner { position: absolute; top: 38%; left: 0px; right: 0px; z-index: 55; display: flex; align-items: center; justify-content: center; pointer-events: none; animation: 1.1s ease 0s 1 normal forwards running skillBannerIn; }

.skill-banner-in { padding: 0.45rem 1.6rem; font-family: var(--title); font-size: 1.1rem; color: rgb(255, 255, 255); text-shadow: rgba(0, 0, 0, 0.9) 0px 2px 8px; position: relative; white-space: nowrap; }

.skill-banner-in::before { content: ""; position: absolute; inset: 0px; background: linear-gradient(90deg,transparent,var(--bc,rgba(255,107,53,0.55)),transparent); border-top: 1px solid rgba(255, 255, 255, 0.15); border-bottom: 1px solid rgba(255, 255, 255, 0.15); z-index: -1; }

.sk-sub { font-size: 0.6rem; color: rgba(255, 255, 255, 0.6); display: block; text-align: center; font-family: var(--font); }

#result { background: var(--bg); align-items: stretch; justify-content: flex-start; text-align: center; padding: 0px; overflow: hidden; }

.r-scroll { flex: 1 1 0%; overflow-y: auto; padding: 1rem 0.6rem 1.5rem; }

.r-banner { display: flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.8rem 0px 0.5rem; }

.r-ico { font-size: 2.4rem; }

.r-title { font-family: var(--font); font-size: 1.55rem; font-weight:900; }

.r-title.win { background-image: ; background-position-x: ; background-position-y: ; background-size: ; background-repeat: ; background-attachment: ; background-origin: ; background-color: ; background-clip: text; -webkit-text-fill-color: transparent; }

.r-title.lose { background-image: ; background-position-x: ; background-position-y: ; background-size: ; background-repeat: ; background-attachment: ; background-origin: ; background-color: ; background-clip: text; -webkit-text-fill-color: transparent; }

.r-section { margin: 0.4rem 0px; }

.r-section-title { font-size: 0.6rem; font-weight: 900; color: var(--dim); letter-spacing: 0.2em; padding: 0.3rem 0px; border-bottom: 1px solid var(--border); margin-bottom: 0.3rem; display: flex; align-items: center; justify-content: center; gap: 0.3rem; }

.r-section-title::before, .r-section-title::after { content: ""; display: inline-block; width: 30px; height: 1px; background: var(--border); }

.r-stat-card { display: flex; align-items: center; gap: 0.3rem; background: var(--c1); border: 1px solid var(--border); border-radius: 0.4rem; padding: 0.28rem 0.34rem; margin-bottom: 0.16rem; position: relative; overflow: hidden; }

.r-stat-card.dead-card { opacity: 0.45; }

.r-stat-card.mvp-card { border-color: rgba(255, 215, 0, 0.42); box-shadow: rgba(255, 215, 0, 0.12) 0px 0px 10px; }

.r-stat-portrait { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border); flex-shrink: 0; }

.r-stat-portrait.dead-portrait { filter: grayscale(1); }

.r-stat-info { flex: 1 1 0%; min-width: 0px; }

.r-stat-top { display:flex; align-items:center; justify-content:space-between; gap:0.32rem; }

.r-stat-name { font-size: 0.5rem; font-weight: 800; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: flex; align-items: center; gap: 4px; }
.r-stat-mvp { display:inline-flex; align-items:center; padding:0.02rem 0.16rem; border-radius:999px; background:rgba(255,215,0,0.14); color:var(--gold); font-size:0.32rem; font-weight:900; line-height:1.2; }

.r-stat-share { flex:0 0 auto; font-size:0.36rem; font-weight:800; color:#d8deea; }

.r-stat-name .skull { font-size: 0.5rem; opacity: 0.6; }

.r-stat-mainline { display:flex; align-items:end; justify-content:space-between; gap:0.24rem; margin-top:0.04rem; }

.r-stat-mainlabel { font-size:0.34rem; color:#98a6bb; font-weight:700; }

.r-stat-mainvalue { font-size:0.58rem; font-weight:900; color:#fff5de; }

.r-stat-bar { margin-top:0.1rem; height:0.18rem; background:rgba(255,255,255,0.08); border-radius:999px; overflow:hidden; }

.r-stat-bar-fill { height:100%; border-radius:999px; }

.r-stat-row { display: flex; gap: 0.18rem; margin-top: 0.12rem; flex-wrap: wrap; }

.r-stat-item { font-size: 0.38rem; font-weight: 700; display: flex; align-items: center; gap: 2px; }

.r-stat-item.dmg { color: rgb(255, 107, 107); }

.r-stat-item.taken { color: rgb(255, 169, 77); }

.r-stat-item.heal-s { color: rgb(105, 219, 124); }

.r-stat-item.cc-s { color: rgb(116, 192, 252); }

.r-rew { font-size: 0.8rem; color: var(--gold); font-weight: 700; margin: 0.5rem 0px 0.3rem; }

.r-btn-wrap { padding: 0.2rem 0px 0.3rem; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 0.3rem; }

.auto-next-btn { background: var(--c2); border: 1px solid var(--border); color: var(--dim); min-height: var(--btn-h-md); padding: 0.46rem 1.2rem; border-radius: 20px; font-size: 0.7rem; font-weight: 600; cursor: pointer; transition: 0.2s; }

.auto-next-btn.active { background: rgba(34, 197, 94, 0.15); border-color: rgba(34, 197, 94, 0.4); color: rgb(34, 197, 94); }

.auto-next-btn.r-auto { margin-bottom: 0.2rem; }

.r-btn { background: linear-gradient(135deg,var(--accent),#e85d04); color: rgb(255, 255, 255); min-height: var(--btn-h-lg); padding: 0.56rem 1.8rem; border-radius: 50px; font-size: 0.75rem; font-weight: 700; }

.r-det { font-size: 0.55rem; color: var(--dim); margin: 0.2rem 0px; }

.f-bench-c { display:inline-flex; flex-direction:column; align-items:center; width:52px; margin:3px; cursor:pointer; opacity:0.7; transition:opacity 0.2s; text-align:center; }

.f-bench-c:hover, .f-bench-c:active { opacity:1; }

.f-bench-c img { width:40px; height:40px; border-radius:8px; object-fit:cover; border:2px solid var(--border); flex:0 0 auto; }

.f-bench-c div { font-size:0.4rem; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:52px; text-align:center; }

.f-slot-nm { font-size: 0.44rem; font-weight: 700; white-space: nowrap; }

.f-slot-lv { font-size: 0.4rem; color: var(--dim); }

.f-slot-x { position: absolute; top: -4px; right: -4px; width: 16px; height: 16px; background: var(--red); color: rgb(255, 255, 255); font-size: 0.5rem; font-weight: 700; border-radius: 50%; display: flex; align-items: center; justify-content: center; border: none; padding: 0px; line-height: 1; }
.formation-scene { flex:1; overflow-y:auto; padding:0.5rem 0.5rem 0.9rem; background:radial-gradient(circle at 50% 0%,rgba(255,107,53,0.12),transparent 32%),linear-gradient(180deg,#090912,#06060e); }
.formation-shell { display:grid; gap:0.36rem; }
.formation-scene-meta { grid-template-columns:repeat(4,1fr); }
.formation-tags .reward-chip { color:#dbe7fb; }
.formation-board { padding:0.68rem 0.7rem 0.78rem; border-radius:var(--radius-lg); border:1px solid rgba(255,255,255,0.08); background:linear-gradient(180deg,rgba(15,18,30,0.96),rgba(10,10,18,0.95)); position:relative; overflow:hidden; }
.formation-board::before { content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(circle at 50% 0%,rgba(255,215,0,0.04),transparent 30%),radial-gradient(circle at 100% 100%,rgba(100,181,246,0.04),transparent 24%); }
.formation-board-top { position:relative; z-index:1; margin-bottom:0.4rem; padding:0.36rem 0.42rem; border-radius:0.64rem; border:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.03); }
.formation-board-kicker { font-size:0.4rem; font-weight:800; letter-spacing:0.08em; color:#7fa2d9; text-transform:uppercase; }
.formation-board-title { margin-top:0.08rem; font-size:0.66rem; font-weight:900; color:#f6f7fb; line-height:1.3; }
.formation-board-hint { margin-top:0.12rem; font-size:0.46rem; line-height:1.6; color:#9fb0c8; }
.formation-lines { position:relative; z-index:1; display:grid; gap:0.55rem; }
.formation-lane { padding:0.42rem; border-radius:0.72rem; border:1px solid rgba(255,255,255,0.05); background:rgba(255,255,255,0.02); }
.formation-lane-label { display:flex; align-items:center; justify-content:space-between; margin-bottom:0.35rem; font-size:0.48rem; color:#c8d5ea; font-weight:800; }
.formation-lane-sub { color:var(--dim); font-size:0.48rem; font-weight:600; }
.formation-summary { display:grid; grid-template-columns:repeat(3,1fr); gap:0.35rem; }
.formation-summary-card { padding:0.42rem 0.34rem; text-align:center; border-radius:0.82rem; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05); }
.formation-summary-value { font-size:var(--fz-md); font-weight:900; color:#fff; }
.formation-summary-label { margin-top:0.06rem; font-size:0.48rem; color:var(--dim); }
.formation-synergy-box { padding:0.45rem; border-radius:0.9rem; background:linear-gradient(180deg,rgba(255,215,0,0.05),rgba(255,107,53,0.03)); border:1px solid rgba(255,215,0,0.1); }
.formation-synergy-title { font-size:0.54rem; font-weight:900; color:#fff5dc; margin-bottom:0.18rem; }
.formation-job-summary { display:flex; gap:0.22rem; flex-wrap:wrap; margin-bottom:0.16rem; }
.formation-syn-row { justify-content:flex-start; }
.formation-muted-note { opacity:0.58; font-size:0.42rem; color:#c7d0df; }
.formation-tip { font-size:0.5rem; color:#a7b7ce; line-height:1.7; }
.formation-bench-panel { padding:0.6rem; border-radius:0.95rem; border:1px solid rgba(255,255,255,0.06); background:linear-gradient(180deg,rgba(17,17,28,0.9),rgba(10,10,18,0.95)); }
.formation-bench-title { font-size:0.58rem; font-weight:900; color:#fff4dd; display:flex; align-items:center; justify-content:space-between; margin-bottom:0.18rem; }
.formation-bench-sub { font-size:0.5rem; color:var(--dim); }
.formation-cta { display:grid; gap:0.28rem; }
.formation-cta .f-go { border-radius:0.95rem; box-shadow:0 14px 26px rgba(220,38,38,0.2); }
.formation-cta .f-back { padding:0.45rem; border-radius:0.95rem; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06); color:#c6d3e7; }
.result-scene { flex:1; overflow-y:auto; padding:0.5rem 0.5rem 0.9rem; background:radial-gradient(circle at 50% 0%,rgba(255,215,0,0.08),transparent 34%),linear-gradient(180deg,#080811,#06060e); }
.result-shell { display:grid; gap:0.45rem; }
.result-banner { position:relative; overflow:hidden; padding:0.9rem 0.82rem; border-radius:var(--radius-lg); border:1px solid rgba(255,255,255,0.08); background:linear-gradient(180deg,rgba(19,20,31,0.96),rgba(11,12,20,0.98)); text-align:center; }
.result-summary { padding-bottom:0.55rem; }
.result-banner.win::before, .result-banner.lose::before, .result-banner.boss::before { content:""; position:absolute; inset:0; pointer-events:none; }
.result-banner.win { border-color:rgba(103,166,255,0.18); background:linear-gradient(180deg,rgba(15,20,34,0.98),rgba(10,13,24,0.98)); box-shadow:inset 0 1px 0 rgba(255,255,255,0.03),0 10px 24px rgba(0,0,0,0.22); }
.result-banner.win::before { background:radial-gradient(circle at 50% 0%,rgba(84,152,255,0.18),transparent 34%),radial-gradient(circle at 50% 18%,rgba(255,215,110,0.08),transparent 24%),radial-gradient(circle at 100% 100%,rgba(81,133,255,0.06),transparent 28%); }
.result-banner.lose { border-color:rgba(255,96,96,0.16); background:linear-gradient(180deg,rgba(30,16,20,0.98),rgba(18,11,16,0.98)); box-shadow:inset 0 1px 0 rgba(255,255,255,0.02),0 10px 24px rgba(0,0,0,0.24); }
.result-banner.lose::before { background:radial-gradient(circle at 50% 0%,rgba(255,84,84,0.16),transparent 34%),radial-gradient(circle at 100% 100%,rgba(255,124,84,0.05),transparent 26%); }
.result-banner.boss { border-color:rgba(255,150,84,0.2); background:linear-gradient(180deg,rgba(35,20,16,0.98),rgba(21,13,12,0.98)); box-shadow:inset 0 1px 0 rgba(255,255,255,0.03),0 10px 24px rgba(0,0,0,0.24); }
.result-banner.boss::before { background:radial-gradient(circle at 50% 0%,rgba(255,159,28,0.16),transparent 34%),radial-gradient(circle at 100% 100%,rgba(255,68,68,0.06),transparent 26%); }
.result-back-btn { position:absolute; top:0.42rem; right:0.42rem; z-index:2; min-height:1.2rem; padding:0.12rem 0.38rem; border-radius:999px; border:1px solid rgba(255,255,255,0.12); background:rgba(255,255,255,0.05); color:#fff4e6; font-size:0.44rem; font-weight:800; }
.result-banner.win .result-back-btn { border-color:rgba(112,160,255,0.24); background:rgba(84,126,220,0.12); color:#edf4ff; }
.result-banner.lose .result-back-btn { border-color:rgba(255,112,112,0.18); background:rgba(255,96,96,0.08); color:#ffe7e7; }
.result-banner.boss .result-back-btn { border-color:rgba(255,170,110,0.2); background:rgba(255,153,51,0.1); color:#fff1df; }
.result-badge { position:relative; z-index:1; display:inline-flex; align-items:center; gap:0.22rem; padding:0.18rem 0.42rem; border-radius:999px; background:rgba(255,255,255,0.06); font-size:0.5rem; font-weight:800; color:#fff6e4; }
.result-banner.win .result-badge { background:rgba(88,132,230,0.16); border:1px solid rgba(118,170,255,0.22); color:#f4f8ff; }
.result-banner.lose .result-badge { background:rgba(255,92,92,0.1); border:1px solid rgba(255,110,110,0.18); color:#ffe9e9; }
.result-banner.boss .result-badge { background:rgba(255,153,51,0.12); border:1px solid rgba(255,180,92,0.18); color:#fff2e2; }
.result-title { position:relative; z-index:1; margin-top:0.18rem; font-family:var(--font); font-size:1.18rem; font-weight:900; color:#fff7ea; }
.result-banner.win .result-title { color:#f4f8ff; text-shadow:0 0 18px rgba(84,152,255,0.16); }
.result-banner.lose .result-title { color:#fff0f0; text-shadow:0 0 18px rgba(255,84,84,0.14); }
.result-banner.boss .result-title { color:#fff4e6; text-shadow:0 0 18px rgba(255,153,51,0.16); }
.result-sub { position:relative; z-index:1; margin-top:0.12rem; font-size:0.5rem; color:#b7c5d8; line-height:1.7; }
.result-banner.win .result-sub { color:#afbed8; }
.result-banner.lose .result-sub { color:#c7acb2; }
.result-banner.boss .result-sub { color:#cbb3a2; }
.result-banner.trial .result-sub { color:#bfe0f1; }
.result-summary-rewards { position:relative; z-index:1; margin-top:0.52rem; padding-top:0.42rem; border-top:1px solid rgba(255,255,255,0.08); }
.result-banner.win .result-summary-rewards { border-top-color:rgba(112,160,255,0.12); }
.result-banner.lose .result-summary-rewards { border-top-color:rgba(255,108,108,0.12); }
.result-banner.boss .result-summary-rewards { border-top-color:rgba(255,170,92,0.12); }
.result-banner.trial .result-summary-rewards { border-top-color:rgba(103,198,255,0.12); }
.result-reward-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(4.2rem,1fr)); gap:0.35rem; }
.result-reward-card { position:relative; overflow:hidden; padding:0.5rem 0.32rem 0.42rem; text-align:center; border-radius:0.52rem; background:linear-gradient(180deg,rgba(17,17,28,0.72),rgba(11,11,20,0.82)); border:1px solid rgba(255,255,255,0.06); }
.result-reward-card::before { content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(circle at 50% 0%,rgba(255,255,255,0.06),transparent 52%); }
.result-banner.win .result-reward-card { background:linear-gradient(180deg,rgba(18,22,36,0.84),rgba(11,14,24,0.9)); border-color:rgba(106,154,255,0.08); }
.result-banner.lose .result-reward-card { background:linear-gradient(180deg,rgba(28,18,24,0.82),rgba(18,12,18,0.9)); border-color:rgba(255,108,108,0.06); }
.result-banner.boss .result-reward-card { background:linear-gradient(180deg,rgba(31,20,17,0.84),rgba(20,14,13,0.9)); border-color:rgba(255,170,92,0.08); }
.result-banner.trial .result-reward-card { background:linear-gradient(180deg,rgba(16,25,37,0.84),rgba(10,15,22,0.9)); border-color:rgba(103,198,255,0.08); }
.result-reward-card.extra::before { background:radial-gradient(circle at 50% 0%,rgba(103,198,255,0.16),transparent 52%); }
.result-reward-card.exp::before { background:radial-gradient(circle at 50% 0%,rgba(255,215,90,0.16),transparent 52%); }
.result-reward-card.gold::before { background:radial-gradient(circle at 50% 0%,rgba(255,184,77,0.16),transparent 52%); }
.result-reward-card.gem::before { background:radial-gradient(circle at 50% 0%,rgba(88,198,255,0.16),transparent 52%); }
.result-reward-icon { position:relative; z-index:1; width:1.2rem; height:1.2rem; margin:0 auto; display:grid; place-items:center; border-radius:50%; background:rgba(255,255,255,0.05); font-size:0.6rem; }
.result-reward-icon img { width:0.78rem; height:0.78rem; display:block; object-fit:contain; }
.result-reward-icon-exp { font-size:0.34rem; font-weight:900; letter-spacing:0.04em; }
.result-reward-card.exp .result-reward-icon { color:#ffd85a; background:rgba(255,216,90,0.12); }
.result-reward-card.gold .result-reward-icon { color:#ffb84d; background:rgba(255,184,77,0.12); }
.result-reward-card.gem .result-reward-icon { color:#58c6ff; background:rgba(88,198,255,0.12); }
.result-reward-card.extra .result-reward-icon { color:#8ee1ff; background:rgba(103,198,255,0.12); }
.result-reward-value { position:relative; z-index:1; margin-top:0.16rem; font-size:0.78rem; font-weight:900; color:#fff; }
.result-reward-label { position:relative; z-index:1; margin-top:0.06rem; font-size:0.46rem; color:var(--dim); }
.result-team-grid { display:grid; gap:0.35rem; }
.result-section-card { padding:0.6rem; border-radius:0.95rem; border:1px solid rgba(255,255,255,0.06); background:linear-gradient(180deg,rgba(17,17,28,0.9),rgba(10,10,18,0.95)); }
.result-section-head { display:flex; align-items:center; justify-content:space-between; gap:0.35rem; margin-bottom:0.25rem; }
.result-section-title { font-size:var(--fz-md); font-weight:900; color:#fff4dd; }
.result-section-sub { font-size:0.48rem; color:var(--dim); }
.result-bottom-actions { display:grid; gap:0.3rem; }
.result-bottom-actions .r-btn { width:100%; padding:0.62rem 1rem; border-radius:0.95rem; box-shadow:0 8px 18px rgba(255,107,53,0.16); }

.form-btns { display: flex; flex-direction: column; gap: 0.3rem; margin-top: 0.3rem; }

.battle-tab { padding: 0.34rem 0.24rem 0.16rem; display:grid; gap:0.28rem; }
.battle-banner-idle { position:relative; z-index:1; margin-top:0.42rem; padding:0.42rem; border-radius:0.5rem; border:1px solid rgba(255,200,70,0.18); background:linear-gradient(180deg,rgba(35,28,20,0.78),rgba(24,20,16,0.88)); }
.battle-banner-idle-head { display:flex; align-items:center; justify-content:space-between; gap:0.4rem; }
.battle-banner-idle-title { font-size:0.6rem; font-weight:900; color:#ffd25a; }
.battle-banner-idle-sub { margin-top:0.08rem; font-size:0.46rem; color:#b8a17e; line-height:1.45; }
.battle-banner-idle-claim { min-width:2.9rem; min-height:1.36rem; padding:0.16rem 0.54rem; border-radius:999px; background:linear-gradient(135deg,#ffd84a,#ffb300); color:#2c1a00; font-size:0.48rem; font-weight:900; }
.battle-banner-idle-pending { font-size:0.46rem; font-weight:800; color:#cab48c; }
.battle-banner-idle-metrics { margin-top:0.24rem; display:grid; grid-template-columns:repeat(3,1fr); gap:0.22rem; }
.battle-banner-idle-chip { padding:0.24rem 0.22rem; border-radius:0.42rem; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.05); text-align:center; }
.battle-banner-idle-chip span { display:block; font-size:0.42rem; color:#a38f71; }
.battle-banner-idle-chip b { display:block; margin-top:0.08rem; font-size:0.62rem; font-weight:900; color:#ffe07c; }
.battle-banner-idle-rate { margin-top:0.2rem; display:flex; flex-wrap:wrap; gap:0.16rem; justify-content:center; }
.battle-banner-idle-rate span { padding:0.12rem 0.24rem; border-radius:999px; background:rgba(255,255,255,0.05); font-size:0.42rem; color:#cab48c; }
.battle-stage-card { padding:0.44rem 0.4rem 0.4rem; border-radius:0.5rem; background:linear-gradient(180deg,rgba(33,18,18,0.9),rgba(18,16,22,0.96)); border:1px solid rgba(255,92,64,0.22); box-shadow:inset 0 1px 0 rgba(255,255,255,0.03); }
.battle-stage-kicker { font-size:0.42rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:#ffb38d; position:relative; }
.battle-stage-progress { display:flex; align-items:center; gap:0.28rem; justify-content:center; margin-top:0.2rem; position:relative; }
.battle-stage-progress-text { font-size:0.46rem; color:#8b8796; min-width:2rem; text-align:center; font-weight:700; }
.battle-stage-bottom { margin-top:0.26rem; padding-top:0.3rem; border-top:1px solid rgba(255,255,255,0.06); }
.battle-stage-tip { text-align:center; padding:0 0 0.12rem; font-size:0.46rem; color:#9b94a5; }
.battle-action-wrap { display:flex; justify-content:center; align-items:center; gap:0.3rem; flex-wrap:wrap; padding:0.16rem 0 0.02rem; }
.battle-go { background: linear-gradient(135deg, var(--stage-accent, rgb(220, 38, 38)), var(--stage-accent-strong, rgb(234, 88, 12))); color: rgb(255, 255, 255); min-height: var(--btn-h-lg); min-width:13rem; max-width:100%; padding: 0.74rem 1.8rem; border-radius: 1rem; font-size: 0.8rem; font-weight: 900; letter-spacing:0.02em; box-shadow:0 10px 22px rgba(255,86,48,0.22); }
.battle-auto-btn { font-size:0.48rem !important; padding:0.24rem 0.78rem !important; }
.ch-header { text-align:center; padding:0.52rem 0.36rem 0.38rem; background:linear-gradient(180deg,rgba(255,107,53,0.09),rgba(255,255,255,0.02)); border-radius:0.9rem; margin-bottom:0.3rem; position:relative; overflow:hidden; border:1px solid rgba(255,107,53,0.16); }
.ch-header::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 50% 0%, rgba(255,107,53,0.1), transparent 70%); }
.ch-title { font-family:var(--font); font-size:0.9rem; font-weight:900; color:var(--stage-accent, var(--accent)); position:relative; }
.ch-sub { font-size:0.56rem; color:#b5bfce; margin-top:0.08rem; position:relative; }
.ch-progress { height:0.34rem; flex:1; max-width:60%; background:rgba(255,255,255,0.06); border-radius:999px; margin:0.02rem 0 0.02rem; overflow:hidden; }
.ch-progress-fill { height:100%; background:linear-gradient(90deg,var(--stage-accent, #22c55e),var(--stage-accent-strong, #4ade80)); border-radius:999px; transition:width 0.4s; }
.stage-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:0.26rem; margin:0.3rem 0 0.2rem; }
.stage-node { position:relative; display:flex; flex-direction:column; align-items:center; justify-content:space-between; padding:0.28rem 0.12rem; border-radius:0.6rem; cursor:default; transition:0.2s; min-height:3rem; background:rgba(255,255,255,0.02); border:1px solid rgba(255,255,255,0.05); }
.stage-node.cleared { background:rgba(34,197,94,0.08); border:1px solid rgba(34,197,94,0.2); }
.stage-node.current { background:rgba(255,107,53,0.15); border:1px solid rgba(255,107,53,0.5); animation:currentPulse 1.5s infinite; cursor:pointer; }
.stage-node.locked { opacity:0.42; }
.stage-state { font-size:0.38rem; font-weight:800; color:#c5cad3; line-height:1.2; }
.stage-core { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.1rem; min-height:1.2rem; }
.stage-num { font-size:0.58rem; font-weight:900; line-height:1; }
.stage-node.cleared .stage-num { color:#22c55e; }
.stage-node.current .stage-num { color:var(--accent); }
.stage-node.locked .stage-num { color:var(--dim); }
.stage-badge { padding:0.05rem 0.2rem; border-radius:999px; background:rgba(255,107,53,0.14); color:#ffb08c; font-size:0.34rem; font-weight:800; line-height:1.2; }
.boss-node { box-shadow:inset 0 0 0 1px rgba(255,148,104,0.08); }
.stage-reward { font-size:0.36rem; color:#a19aaf; line-height:1.2; white-space:nowrap; font-weight:700; }
.stage-reward.done { color:#ffd88d; }
.stage-reward.muted { color:#7f7b88; }
.ch-nav { display:flex; align-items:center; justify-content:center; gap:0.5rem; margin-bottom:0.2rem; }
.ch-nav-btn { background:none; border:1px solid rgba(255,255,255,0.15); color:var(--text); width:1.2rem; height:1.2rem; border-radius:50%; font-size:0.5rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:0.2s; }
.ch-nav-btn:active { background:rgba(255,255,255,0.1); }
.ch-nav-btn:disabled { opacity:0.2; cursor:default; }
@keyframes currentPulse { 0%,100%{box-shadow:0 0 6px rgba(255,107,53,0.2)} 50%{box-shadow:0 0 14px rgba(255,107,53,0.45)} }
.stage-node.boss-node { border-width:2px; }
.stage-node.boss-node.cleared { background:rgba(255,215,0,0.08); border-color:rgba(255,215,0,0.25); }
.stage-node.boss-node.current { background:rgba(255,50,50,0.15); border-color:rgba(255,50,50,0.5); }
.syn-page { padding:0.2rem; display:grid; gap:0.22rem; }
.syn-card { background:var(--c2); border:1px solid var(--border); border-radius:0.9rem; padding:0.36rem; transition:0.2s; }
.syn-card.active { border-color:rgba(255,215,0,0.4); background:rgba(255,215,0,0.05); }
.syn-card-head { display:flex; align-items:center; justify-content:space-between; gap:0.3rem; }
.syn-card-name { font-size:0.54rem; font-weight:800; color:var(--accent); }
.syn-card-state { font-size:0.36rem; color:var(--dim); font-weight:700; padding:0.08rem 0.32rem; border-radius:999px; background:rgba(255,255,255,0.03); }
.syn-card-state.active { color:#22c55e; background:rgba(34,197,94,0.1); }
.syn-card-desc { font-size:0.48rem; color:var(--dim); margin:0.1rem 0; }
.syn-card-bonus { font-size:0.48rem; color:#22c55e; font-weight:600; }
.syn-card-members { display:flex; gap:4px; flex-wrap:wrap; margin-top:0.15rem; }
.syn-member { display:flex; align-items:center; gap:4px; background:rgba(255,255,255,0.04); border-radius:0.46rem; padding:0.12rem 0.34rem; font-size:0.46rem; }
.syn-member img { width:20px; height:20px; border-radius:50%; object-fit:cover; }
.syn-member.owned { color:var(--text); }
.syn-member.missing { color:var(--dim); opacity:0.5; }
.syn-member.in-form { border:1px solid rgba(34,197,94,0.4); }
.syn-member-state { font-size:0.34rem; color:var(--dim); }

.gacha-gems { font-size: 1.1rem; font-weight: 700; color: var(--gold); margin: 0.3rem 0px; }

.gacha-pool-img { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; border: 2px solid var(--c3); opacity: 0.35; }

.tr-frag-info { font-size: 0.48rem; color: var(--gold); font-weight: 700; }

.r-icon { font-size: 3rem; }

.r-char-img { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; border: 2px solid var(--gold); }

.foe-side { padding-top: 0.5rem; }

.ally-side { padding-bottom: 0.5rem; }

#charDetail { background: var(--bg); overflow-y: auto; overflow-x: hidden; scroll-behavior: smooth; }

.cd-portrait { position: relative; width: 100%; height: 40vh; min-height: 200px; max-height: 350px; overflow: hidden; }

.cd-portrait img { width: 100%; height: 100%; object-fit: cover; }

.cd-portrait::after { content: ""; position: absolute; bottom: 0px; left: 0px; right: 0px; height: 50%; background: linear-gradient(transparent,var(--bg)); }

.cd-top { position: absolute; bottom: 1rem; left: 1rem; z-index: 2; }

.cd-name { font-family: var(--font); font-size: 1.45rem; font-weight:900; color: rgb(255, 255, 255); text-shadow: rgba(0, 0, 0, 0.55) 0px 2px 6px; }

.cd-rarity { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 0.6rem; font-weight: 900; margin-bottom: 4px; }

.cd-rarity.ssr { background: linear-gradient(135deg, rgb(255, 215, 0), rgb(255, 159, 28)); color: rgb(0, 0, 0); }

.cd-rarity.sr { background: linear-gradient(135deg, rgb(179, 136, 255), rgb(124, 77, 255)); color: rgb(255, 255, 255); }

.cd-rarity.ss { background: linear-gradient(135deg, rgb(0, 188, 212), rgb(0, 151, 167)); color: rgb(255, 255, 255); }

.cd-elem { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 0.6rem; font-weight: 700; margin-left: 6px; }

.cd-stars { color: var(--gold); font-size: 0.8rem; letter-spacing: 2px; margin-top: 2px; }

.cd-close { position: absolute; top: 0.8rem; right: 0.8rem; width: 32px; height: 32px; background: rgba(0, 0, 0, 0.6); color: rgb(255, 255, 255); border-radius: 50%; font-size: 1rem; display: flex; align-items: center; justify-content: center; z-index: 5; border: none; }

.cd-tabs { display: flex; background: var(--c1); border-bottom: 1px solid var(--border); }

.cd-tab { flex: 1 1 0%; padding: 0.5rem; text-align: center; font-size: var(--fz-lg); font-weight: 700; color: var(--dim); border-bottom: 2px solid transparent; cursor: pointer; }

.cd-tab.active { color: var(--accent); border-color: var(--accent); }

.cd-body { padding: 0.8rem; min-height: 40vh; }

.cd-stats-panel {
  margin-bottom: 0.55rem;
  padding: 0.65rem 0.7rem;
  border-radius: 0.8rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
}

.cd-stats-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
  margin-bottom: 0.4rem;
}

.cd-stats-level {
  font-size: 0.75rem;
  font-weight: 800;
  color: var(--text);
}

.cd-stats-rebirth {
  flex: 0 0 auto;
  padding: 0.16rem 0.38rem;
  border-radius: 999px;
  font-size: 0.5rem;
  font-weight: 800;
  color: #ff8a8a;
  background: rgba(255,107,107,0.08);
  border: 1px solid rgba(255,107,107,0.16);
}

.cd-exp-row { margin: 0; }

.cd-exp-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
  margin-bottom: 0.16rem;
  font-size: 0.52rem;
  color: var(--dim);
}

.cd-exp-meta strong {
  font-size: 0.56rem;
  color: rgba(255,255,255,0.82);
}

.cd-exp-bar { width: 100%; height: 0.34rem; background: var(--c3); border-radius: 999px; overflow: hidden; }

.cd-exp-fill { height: 100%; background: linear-gradient(90deg, rgb(59, 130, 246), rgb(96, 165, 250)); border-radius: inherit; }

.cd-stat-row {
  margin-bottom: 0.38rem;
  padding: 0.58rem 0.65rem;
  border-radius: 0.78rem;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.06);
}

.cd-stat-main {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
}

.cd-stat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
}

.cd-stat-label { font-size: 0.62rem; font-weight: 700; color: var(--dim); }

.cd-stat-bar { width: 100%; height: 0.38rem; background: var(--c3); border-radius: 999px; overflow: hidden; }

.cd-stat-fill { height: 100%; border-radius: inherit; transition: width 0.5s; }

.cd-stat-val { font-size: 0.74rem; font-weight: 900; color: var(--text); }

.cd-stat-sub {
  margin-top: 0.22rem;
  font-size: 0.5rem;
  color: rgba(255,255,255,0.58);
}

.cd-skill-card { background: var(--c1); border: 1px solid var(--border); border-radius: 0.75rem; padding: 0.7rem; margin-bottom: 0.5rem; }

.cd-skill-card.locked { opacity: 0.4; }

.cd-skill-name { font-weight: 900; font-size: 0.85rem; color: var(--accent); }

.cd-skill-type { font-size: var(--fz-md); color: var(--dim); margin-left: 6px; }

.cd-skill-desc { font-size: 0.7rem; color: var(--text); margin-top: 4px; line-height: 1.4; }

.cd-skill-mult { font-size: 0.6rem; color: var(--gold); margin-top: 2px; }

.cd-eq-slot { background: var(--c1); border: 1px solid var(--border); border-radius: 0.75rem; padding: 0.6rem; margin-bottom: 0.4rem; display: flex; justify-content: space-between; align-items: center; }

.cd-eq-info { flex: 1 1 0%; }

.cd-eq-name { font-weight: 700; font-size: 0.8rem; }

.cd-eq-bonus { font-size: var(--fz-md); color: var(--green); }

.cd-eq-btn { min-height: var(--btn-h-md); padding: 0.36rem 0.9rem; border-radius: 0.6rem; font-size: 0.65rem; font-weight: 700; color: rgb(255, 255, 255); background: linear-gradient(135deg, rgb(16, 185, 129), rgb(5, 150, 105)); border: none; cursor: pointer; }

.cd-eq-btn:disabled { opacity: 0.3; }

.cd-star-info { text-align: center; padding: 1rem; }

.cd-star-btn { width: 100%; min-height: var(--btn-h-lg); padding: 0.58rem 1.5rem; border-radius: 0.72rem; font-size: 0.8rem; font-weight: 700; color: rgb(0, 0, 0); background: linear-gradient(135deg, rgb(255, 215, 0), rgb(232, 160, 0)); margin-top: 0.42rem; border: none; cursor: pointer; }

.cd-star-btn:disabled { opacity: 0.3; }

.cd-star-actions {
  margin-top: 0.55rem;
  padding: 0.55rem;
  border-radius: 0.82rem;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.08);
}

.cd-star-cost {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  font-size: 0.6rem;
  color: var(--dim);
}

.cd-star-cost-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 0.82rem;
  height: 0.82rem;
  overflow: hidden;
  border-radius: 0.24rem;
  border: 1px solid rgba(255,215,0,0.38);
  box-shadow: 0 0.12rem 0.35rem rgba(255,215,0,0.16);
}

.cd-star-cost-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cd-star-cost strong {
  font-size: 0.66rem;
  color: var(--gold);
}

.cd-star-cost span {
  color: rgba(255,255,255,0.72);
}

.cd-star-preview {
  margin-top: 0.6rem;
  padding: 0.62rem 0.68rem;
  border-radius: 0.78rem;
  text-align: left;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
}

.cd-star-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.45rem;
  margin-bottom: 0.42rem;
}

.cd-star-preview-title {
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--text);
}

.cd-star-preview-stage {
  flex: 0 0 auto;
  padding: 0.12rem 0.34rem;
  border-radius: 999px;
  font-size: 0.6rem;
  font-weight: 800;
  color: var(--gold);
  background: rgba(255,215,0,0.08);
  border: 1px solid rgba(255,215,0,0.14);
}

.cd-star-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.28rem 0.45rem;
}

.cd-star-preview-item {
  display: flex;
  align-items: center;
  gap: 0.16rem;
  min-width: 0;
  padding: 0.32rem 0.42rem;
  border-radius: 0.58rem;
  background: rgba(0,0,0,0.16);
}

.cd-star-preview-label {
  flex: 0 0 auto;
  min-width: 1.3rem;
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--dim);
}

.cd-star-preview-cur {
  flex: 0 1 auto;
  min-width: 0;
  font-size: 0.6rem;
  font-weight: 700;
  color: rgba(255,255,255,0.72);
}

.cd-star-preview-arrow {
  flex: 0 0 auto;
  font-size: 0.52rem;
  color: var(--dim);
}

.cd-star-preview-next {
  flex: 0 1 auto;
  min-width: 0;
  font-size: 0.62rem;
  font-weight: 800;
  color: var(--gold);
}

.cd-star-preview-delta {
  margin-left: auto;
  flex: 0 0 auto;
  font-size: 0.5rem;
  font-weight: 800;
  color: var(--green);
}

.cd-star-preview-note {
  margin-top: 0.42rem;
  font-size: 0.5rem;
  font-weight: 700;
  color: var(--gold);
}

@media (max-width: 640px) {
  .cd-star-preview-grid { grid-template-columns: 1fr; }
  .cd-star-cost { flex-wrap: wrap; }
}

.gacha-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0.4rem; width: 100%; padding: 0.4rem; }

.gc-card { background: var(--c1); border-radius: 10px; padding: 0.2rem; text-align: center; animation: 0.5s ease 0s 1 normal backwards running gachaReveal; border: 2px solid var(--border); overflow: hidden; }

.gc-card.ssr-card { border-color: rgba(255, 215, 0, 0.6); box-shadow: rgba(255, 215, 0, 0.3) 0px 0px 20px, rgba(255, 215, 0, 0.1) 0px 0px 40px; position: relative; }

.gc-card.ssr-card::before { content: ""; position: absolute; inset: 0px; background: radial-gradient(at 50% 30%, rgba(255, 215, 0, 0.15), transparent 70%); pointer-events: none; z-index: 1; }

.gc-card.ssr-card::after { content: ""; position: absolute; top: 0px; left: -100%; width: 50%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 215, 0, 0.2), transparent); animation: 2s ease 0s infinite normal none running ssrShimmer; z-index: 1; }

.gc-card.sr-card { border-color: rgba(179, 136, 255, 0.4); }

.gc-card.ss-card { border-color: rgba(0, 188, 212, 0.3); box-shadow: rgba(0, 188, 212, 0.15) 0px 0px 8px; }

.gc-card img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 6px; background: var(--c3); }

.gc-card .gc-card-r { font-size: 0.5rem; font-weight: 900; margin-top: 2px; }

.gc-card .gc-card-r.ssr { color: rgb(255, 215, 0); }

.gc-card .gc-card-r.sr { color: rgb(179, 136, 255); }

.gc-card .gc-card-r.ss { color: rgb(0, 188, 212); }

.gc-card .gc-card-nm { font-size: 0.5rem; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.gc-card .gc-card-sub { font-size: 0.46rem; color: var(--green); }

.gc-card .gc-card-sub.dupe { color: var(--gold); }

.job-badge { display: inline-block; font-size: 0.44rem; font-weight: 900; padding: 1px 4px; border-radius: 3px; letter-spacing: 0.5px; }

.job-badge.tank { background: rgba(59, 130, 246, 0.25); color: rgb(96, 165, 250); }
.job-badge.warrior { background: rgba(239, 68, 68, 0.25); color: rgb(248, 113, 113); }
.job-badge.mage { background: rgba(179, 136, 255, 0.25); color: rgb(179, 136, 255); }
.job-badge.assassin { background: rgba(255, 159, 28, 0.25); color: rgb(255, 159, 28); }
.job-badge.support { background: rgba(52, 211, 153, 0.25); color: rgb(52, 211, 153); }

.form-field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.3rem; }

.form-section { background: var(--c1); border: 1px solid var(--border); border-radius: 10px; padding: 0.35rem; }

.form-section-title { font-size: var(--fz-sm); font-weight: 900; margin-bottom: 0.2rem; display: flex; align-items: center; gap: 4px; }

.form-slot-row { display: flex; gap: 0.25rem; flex-wrap: wrap; justify-content: center; }

.f-slot img { width: 36px; height: 36px; }

.f-bench-filter { display: flex; gap: 0.2rem; flex-wrap: wrap; justify-content: center; margin-bottom: 0.3rem; }

.f-bench-filter-btn { font-size: 0.5rem; padding: 2px 6px; border-radius: 10px; background: var(--c2); color: var(--dim); font-weight: 700; border: 1px solid var(--border); cursor: pointer; }

.f-bench-filter-btn.active { color: var(--accent); border-color: var(--accent); background: rgba(255, 107, 53, 0.1); }

.gacha-pity { font-size: var(--fz-md); color: var(--dim); margin: 0.2rem 0px; }

.gacha-pity b { color: var(--gold); }

.gacha-pity-bar { width: 200px; height: 6px; background: var(--c3); border-radius: 3px; overflow: hidden; margin: 4px auto; }

.gacha-pity-fill { height: 100%; border-radius: 3px; background: linear-gradient(90deg, rgb(255, 215, 0), rgb(255, 107, 53)); transition: width 0.3s; }

.job-spec { font-size: 0.48rem; color: var(--dim); line-height: 1.35; }

.tc-job { margin-top: 1px; }

.b-status { display: flex; gap: 2px; justify-content: center; flex-wrap: wrap; max-width: 72px; margin-top: 2px; }

.b-st-icon { font-size: 0.46rem; padding: 0px 2px; border-radius: 2px; font-weight: 700; line-height: 1.3; animation: 0.3s ease 0s 1 normal none running fadeIn; }

.b-st-icon.buff { background: rgba(52, 211, 153, 0.3); color: rgb(52, 211, 153); border: 1px solid rgba(52, 211, 153, 0.4); }

.b-st-icon.debuff { background: rgba(239, 68, 68, 0.3); color: rgb(248, 113, 113); border: 1px solid rgba(239, 68, 68, 0.4); }

.b-st-icon.shield-st { background: rgba(96, 165, 250, 0.3); color: rgb(96, 165, 250); border: 1px solid rgba(96, 165, 250, 0.4); }

.b-st-icon.taunt-st { background: rgba(251, 191, 36, 0.3); color: rgb(251, 191, 36); border: 1px solid rgba(251, 191, 36, 0.4); }

.b-shield { width: 100%; height: 3px; background: transparent; border-radius: 2px; overflow: hidden; margin-top: 1px; }

.b-shield-f { height: 100%; border-radius: 2px; background: linear-gradient(90deg, rgb(59, 130, 246), rgb(96, 165, 250)); transition: width 0.3s; }

@keyframes burnGlow { 
  0%, 100% { box-shadow: rgba(255, 77, 42, 0.3) 0px 0px 4px; }
  50% { box-shadow: rgba(255, 77, 42, 0.7) 0px 0px 12px; }
}

@keyframes freezeGlow { 
  0%, 100% { box-shadow: rgba(59, 130, 246, 0.3) 0px 0px 4px; }
  50% { box-shadow: rgba(59, 130, 246, 0.7) 0px 0px 12px; }
}

@keyframes stunSpin { 
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

@keyframes buffPulse { 
  0%, 100% { opacity: 0.6; }
  50% { opacity: 1; }
}

@keyframes poisonDrip { 
  0% { opacity: 0.4; }
  50% { opacity: 1; }
  100% { opacity: 0.4; }
}

.b-unit.burning .b-frame { animation: 1s ease 0s infinite normal none running burnGlow !important; }

.b-unit.frozen .b-frame { filter: brightness(1.2) saturate(0.5); animation: 1s ease 0s infinite normal none running freezeGlow !important; }

.b-unit.stunned .b-frame { filter: brightness(0.7); }

.b-unit.weakened { opacity: 0.65; }

.b-unit.shielded .b-frame { box-shadow: rgba(96, 165, 250, 0.5) 0px 0px 10px !important; }

.b-unit.taunting .b-frame { box-shadow: rgba(251, 191, 36, 0.5) 0px 0px 10px !important; }

.float-buff { position: absolute; font-family: var(--impact); font-size: 0.6rem; font-weight: 700; pointer-events: none; z-index: 20; color: rgb(52, 211, 153); text-shadow: rgba(0, 0, 0, 0.8) 0px 1px 4px; animation: 1.2s ease-out 0s 1 normal forwards running floatHeal; white-space: nowrap; }

.float-debuff { position: absolute; font-family: var(--impact); font-size: 0.6rem; font-weight: 700; pointer-events: none; z-index: 20; color: rgb(248, 113, 113); text-shadow: rgba(0, 0, 0, 0.8) 0px 1px 4px; animation: 2.5s ease-out 0s 1 normal forwards running floatDmg; white-space: nowrap; }

@keyframes healAura { 
  0% { transform: scale(0.5); opacity: 0.8; }
  100% { transform: scale(2.5); opacity: 0; }
}

@keyframes shieldPop { 
  0% { transform: scale(0); opacity: 1; }
  50% { transform: scale(1.5); opacity: 0.6; }
  100% { transform: scale(2); opacity: 0; }
}

@keyframes buffRise { 
  0% { transform: translateY(0px) scale(1); opacity: 1; }
  100% { transform: translateY(-30px) scale(0.5); opacity: 0; }
}

.heal-aura { position: absolute; width: 50px; height: 50px; border-radius: 50%; border: 2px solid rgb(52, 211, 153); pointer-events: none; z-index: 15; animation: 0.8s ease-out 0s 1 normal forwards running healAura; }

.shield-pop { position: absolute; width: 50px; height: 50px; border-radius: 50%; background: radial-gradient(circle, rgba(96, 165, 250, 0.4) 0%, transparent 70%); border: 2px solid rgba(96, 165, 250, 0.6); pointer-events: none; z-index: 15; animation: 0.6s ease-out 0s 1 normal forwards running shieldPop; }

.buff-particle { position: absolute; width: 6px; height: 6px; border-radius: 50%; pointer-events: none; z-index: 15; animation: 0.8s ease-out 0s 1 normal forwards running buffRise; }
.boss-hp-wrap{display:none}
.boss-hp-outer{display:none}
.boss-hp-fill{display:none}
.boss-hp-txt{display:none}
.boss-dmg-banner{display:flex;justify-content:center;padding:0.12rem 0 0.08rem}
.boss-dmg-total{min-width:4.8rem;padding:0.18rem 0.42rem 0.22rem;border-radius:999px;display:flex;align-items:center;gap:0.22rem;background:linear-gradient(180deg,rgba(255,186,92,0.18),rgba(255,122,61,0.08));border:1px solid rgba(255,173,92,0.24);box-shadow:0 0.12rem 0.34rem rgba(0,0,0,0.24), inset 0 1px 0 rgba(255,255,255,0.08)}
.boss-dmg-label{font-size:0.4rem;font-weight:800;letter-spacing:0.04em;color:#ffd7a1;white-space:nowrap}
.boss-dmg-value{font-size:0.68rem;line-height:1;font-weight:900;color:#fff4d6;text-shadow:0 1px 2px rgba(0,0,0,0.22)}
.boss-info{text-align:center;padding:0.55rem;background:linear-gradient(180deg,rgba(255,50,50,0.12),rgba(200,0,0,0.04));border-radius:12px;margin:0.35rem 0}
.boss-name{font-size:var(--fz-lg);font-weight:900;color:#ff4444;text-shadow:0 0 6px rgba(255,50,50,0.22)}
.boss-tier-row{display:flex;align-items:center;gap:0.3rem;padding:0.2rem 0.3rem;border-radius:8px;margin:0.15rem 0;background:rgba(255,255,255,0.03)}
.boss-tier-row.reached{background:rgba(255,215,0,0.08);border:1px solid rgba(255,215,0,0.2)}
.boss-countdown{font-size:0.5rem;color:var(--accent);text-align:center;padding:0.2rem}
.game-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:300;width:min(90vw,11.2rem);height:auto;max-height:calc(100vh - 0.72rem);overflow-x:hidden;overflow-y:auto;padding:0.78rem 0.76rem 0.64rem;border-radius:16px;border:1px solid rgba(255,214,125,0.16);background:linear-gradient(180deg,rgba(23,18,12,0.985),rgba(12,10,8,0.995));text-align:center;box-shadow:0 18px 42px rgba(0,0,0,0.52),inset 0 1px 0 rgba(255,255,255,0.04);animation:toastIn 0.25s ease;scrollbar-width:none;-ms-overflow-style:none}
.game-toast::-webkit-scrollbar{width:0;height:0;display:none}
.game-toast::before{content:"";position:absolute;left:0.26rem;right:0.26rem;top:0.22rem;height:0.4rem;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,0.18),rgba(255,255,255,0));pointer-events:none}
.game-toast-title{font-size:0.78rem;font-weight:900;color:#ffe3a1;margin-bottom:0.2rem;letter-spacing:0.01em}
.game-toast-body{font-size:0.54rem;color:#f2e7d8;line-height:1.72;white-space:pre-line}
.game-toast-btn{position:relative;width:100%;min-height:1.08rem;margin-top:0.42rem;background:linear-gradient(180deg,#ffe28a 0%,#ffc83d 52%,#f0a91a 100%);color:#402400;border:1px solid rgba(255,223,129,0.58);padding:0.25rem 1.2rem;border-radius:11px;font-size:0.56rem;font-weight:900;letter-spacing:0.04em;cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,0.45),inset 0 -2px 0 rgba(122,67,0,0.22),0 8px 18px rgba(0,0,0,0.28);text-shadow:0 1px 0 rgba(255,247,214,0.4)}
.game-toast-btn::before{content:'';position:absolute;left:0.16rem;right:0.16rem;top:0.12rem;height:0.28rem;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,0.42),rgba(255,255,255,0))}
.game-toast-btn:hover{filter:brightness(1.03)}
.game-toast-btn:active{transform:translateY(1px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.38),inset 0 -1px 0 rgba(122,67,0,0.18),0 5px 12px rgba(0,0,0,0.24)}
.game-toast.game-toast-reward{width:calc(100vw - 0.72rem);max-width:none;padding:0.68rem 0.64rem 0.56rem;border-radius:12px;background:linear-gradient(180deg,rgba(36,28,18,0.98),rgba(20,17,12,0.99));border-color:rgba(255,208,92,0.24);box-shadow:0 14px 30px rgba(0,0,0,0.46)}
.game-toast.game-toast-reward .game-toast-title{margin-bottom:0.22rem;font-size:0.68rem;letter-spacing:0.01em;color:#ffe094}
.game-toast.game-toast-reward .game-toast-body{font-size:0.54rem;color:#f4ead7;white-space:normal}
.reward-toast-summary{padding:0.28rem 0.32rem;border-radius:10px;background:linear-gradient(90deg,rgba(255,219,109,0.12),rgba(255,184,0,0.06));border:1px solid rgba(255,214,92,0.14);text-align:left;line-height:1.55;color:#fff0cd}
.reward-toast-grid{margin-top:0.34rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.22rem}
.reward-toast-item{padding:0.32rem 0.2rem 0.28rem;border-radius:10px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.04);text-align:center}
.reward-toast-item-icon{width:0.74rem;height:0.74rem;margin:0 auto 0.12rem;display:flex;align-items:center;justify-content:center}
.reward-toast-item-icon img{width:100%;height:100%;display:block;object-fit:contain}
.reward-toast-item-label{display:block;font-size:0.4rem;font-weight:700;color:#b7a27c;letter-spacing:0.02em}
.reward-toast-item-value{display:block;margin-top:0.08rem;font-size:0.6rem;font-weight:900;color:#fff7e2;line-height:1.2}
.game-toast.game-toast-reward .game-toast-btn{position:relative;width:100%;min-height:1.08rem;margin-top:0.42rem;border-radius:11px;font-size:0.58rem;font-weight:900;letter-spacing:0.04em;color:#402400;background:linear-gradient(180deg,#ffe28a 0%,#ffc83d 52%,#f0a91a 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,0.45),inset 0 -2px 0 rgba(122,67,0,0.22),0 8px 18px rgba(0,0,0,0.28);border:1px solid rgba(255,223,129,0.58);text-shadow:0 1px 0 rgba(255,247,214,0.4)}
.game-toast.game-toast-reward .game-toast-btn:hover{filter:brightness(1.03)}
.game-toast.game-toast-reward .game-toast-btn:active{transform:translateY(1px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.38),inset 0 -1px 0 rgba(122,67,0,0.18),0 5px 12px rgba(0,0,0,0.24)}
.game-toast.game-toast-reward .game-toast-btn::before{content:'';position:absolute;left:0.16rem;right:0.16rem;top:0.12rem;height:0.28rem;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,0.42),rgba(255,255,255,0))}
.game-toast-overlay{position:fixed;inset:0;z-index:299;background:rgba(3,5,12,0.62);backdrop-filter:blur(6px)}
.game-toast.game-toast-idle{width:calc(100vw - 0.72rem);max-width:none;padding:0.64rem 0.62rem 0.54rem;border-radius:12px;background:linear-gradient(180deg,rgba(28,24,18,0.98),rgba(20,18,14,0.98));border-color:rgba(255,208,92,0.22);box-shadow:0 12px 28px rgba(0,0,0,0.45)}
.game-toast.game-toast-idle .game-toast-title{margin-bottom:0.22rem;font-size:0.66rem;letter-spacing:0.01em}
.game-toast.game-toast-idle .game-toast-body{white-space:normal}
.game-toast.game-toast-idle .game-toast-btn{position:relative;width:100%;min-height:1.08rem;margin-top:0.4rem;border-radius:11px;font-size:0.56rem;font-weight:900;letter-spacing:0.04em;color:#402400;background:linear-gradient(180deg,#ffe28a 0%,#ffc83d 52%,#f0a91a 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,0.45),inset 0 -2px 0 rgba(122,67,0,0.22),0 8px 18px rgba(0,0,0,0.28);border:1px solid rgba(255,223,129,0.58);text-shadow:0 1px 0 rgba(255,247,214,0.4)}
.game-toast.game-toast-idle .game-toast-btn:hover{filter:brightness(1.03)}
.game-toast.game-toast-idle .game-toast-btn:active{transform:translateY(1px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.38),inset 0 -1px 0 rgba(122,67,0,0.18),0 5px 12px rgba(0,0,0,0.24)}
.game-toast.game-toast-idle .game-toast-btn::before{content:'';position:absolute;left:0.16rem;right:0.16rem;top:0.12rem;height:0.28rem;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,0.42),rgba(255,255,255,0))}
.game-toast.game-toast-unlock{width:calc(100vw - 0.72rem);max-width:none;padding:0.8rem 0.76rem 0.62rem;border-radius:14px;background:linear-gradient(180deg,rgba(25,28,46,0.98),rgba(13,15,26,0.99));border-color:rgba(126,154,255,0.28);box-shadow:0 16px 34px rgba(0,0,0,0.52)}
.game-toast.game-toast-unlock .game-toast-title{margin-bottom:0.24rem;font-size:0.82rem;color:#eef3ff;letter-spacing:0.02em}
.game-toast.game-toast-unlock .game-toast-body{font-size:0.58rem;color:#e4ebfb;white-space:normal}
.unlock-toast-panel{padding:0.34rem 0.36rem;border-radius:12px;background:linear-gradient(180deg,rgba(126,154,255,0.14),rgba(126,154,255,0.05));border:1px solid rgba(126,154,255,0.16);text-align:left}
.unlock-toast-kicker{font-size:0.38rem;font-weight:900;letter-spacing:0.08em;color:#9fb7ff;text-transform:uppercase}
.unlock-toast-summary{margin-top:0.14rem;font-size:0.62rem;line-height:1.6;color:#f6f8ff;font-weight:800}
.game-toast.game-toast-unlock .game-toast-btn{position:relative;width:100%;min-height:1.12rem;margin-top:0.46rem;border-radius:11px;font-size:0.58rem;font-weight:900;letter-spacing:0.04em;color:#1f2847;background:linear-gradient(180deg,#d3e2ff 0%,#a7c1ff 54%,#6f95ff 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,0.45),inset 0 -2px 0 rgba(44,66,132,0.28),0 8px 18px rgba(0,0,0,0.28);border:1px solid rgba(191,212,255,0.58);text-shadow:0 1px 0 rgba(255,255,255,0.32)}
.game-toast.game-toast-unlock .game-toast-btn::before{content:'';position:absolute;left:0.16rem;right:0.16rem;top:0.12rem;height:0.28rem;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,0.42),rgba(255,255,255,0))}
.idle-toast-banner{display:flex;align-items:center;justify-content:space-between;gap:0.28rem;padding:0.22rem 0.28rem;border-radius:10px;background:linear-gradient(90deg,rgba(255,219,109,0.18),rgba(255,184,0,0.08));border:1px solid rgba(255,214,92,0.18);text-align:left}
.idle-toast-banner span{font-size:0.38rem;font-weight:800;letter-spacing:0.08em;color:#b8964c}
.idle-toast-banner strong{font-size:0.5rem;font-weight:900;color:#fff2c6;line-height:1.2}
.idle-toast-top{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0.22rem;text-align:left}
.idle-toast-top{margin-top:0.24rem}
.idle-toast-time,.idle-toast-source{padding:0.26rem 0.28rem;border-radius:10px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06)}
.idle-toast-time span,.idle-toast-source span{display:block;font-size:0.38rem;font-weight:700;color:#9f8c6c;letter-spacing:0.02em}
.idle-toast-time strong,.idle-toast-source strong{display:block;margin-top:0.08rem;font-size:0.52rem;font-weight:900;line-height:1.25;color:#f7f1df}
.idle-toast-source strong{color:#ffd778}
.idle-toast-grid{margin-top:0.34rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.22rem}
.idle-toast-card{padding:0.3rem 0.18rem 0.26rem;border-radius:10px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.04)}
.idle-toast-card.is-gold{background:linear-gradient(180deg,rgba(255,214,92,0.14),rgba(255,214,92,0.06));border-color:rgba(255,214,92,0.2)}
.idle-toast-card.is-exp{background:linear-gradient(180deg,rgba(106,214,255,0.14),rgba(106,214,255,0.06));border-color:rgba(106,214,255,0.2)}
.idle-toast-card.is-gem{background:linear-gradient(180deg,rgba(139,122,255,0.16),rgba(139,122,255,0.06));border-color:rgba(139,122,255,0.22)}
.idle-toast-card-icon{width:0.8rem;height:0.8rem;margin:0 auto 0.12rem;display:flex;align-items:center;justify-content:center}
.idle-toast-card-icon img{width:100%;height:100%;display:block;object-fit:contain}
.idle-toast-card-icon-exp{font-size:0.34rem;font-weight:900;letter-spacing:0.04em;color:#b9f4ff}
.idle-toast-label{display:block;font-size:0.4rem;font-weight:700;color:#b7a27c;letter-spacing:0.02em}
.idle-toast-value{display:block;margin-top:0.08rem;font-size:0.58rem;font-weight:900;color:#fff;line-height:1.2}
.idle-toast-note{margin-top:0.28rem;font-size:0.42rem;color:#9f8c6c;line-height:1.45}
@media (max-width: 520px){
  .game-toast{width:min(calc(100vw - 0.72rem),11.2rem);padding:0.74rem 0.66rem 0.58rem}
  .idle-toast-banner{align-items:flex-start;flex-direction:column}
  .idle-toast-top{grid-template-columns:1fr}
  .reward-toast-grid{grid-template-columns:1fr}
}

@media (min-width: 600px){
  .game-toast.game-toast-reward,
  .game-toast.game-toast-idle,
  .game-toast.game-toast-unlock{width:min(calc(100vw - 0.72rem),480px)}
}

@media (min-width: 900px){
  .game-toast.game-toast-reward,
  .game-toast.game-toast-idle,
  .game-toast.game-toast-unlock{width:min(calc(100vw - 0.72rem),520px)}
}

@media (min-width: 1200px){
  .game-toast.game-toast-reward,
  .game-toast.game-toast-idle,
  .game-toast.game-toast-unlock{width:min(calc(100vw - 0.72rem),560px)}
}

@media (min-width: 1600px){
  .game-toast.game-toast-reward,
  .game-toast.game-toast-idle,
  .game-toast.game-toast-unlock{width:min(calc(100vw - 0.72rem),600px)}
}

@keyframes toastIn{from{opacity:0;transform:translate(-50%,-50%) scale(0.85)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
