:root {
  --bg: #0d0d12;
  --panel: #14141b;
  --panel2: #1a1a24;
  --border: #2a2a35;
  --border2: #3a3a45;
  --text: #c8c0b4;
  --gold: #c9a44b;
  --dim: #6b6358;
  --dim-light: #8a8278;
  --red: #c0392b;
  --green: #4a8;
  --blue: #5a9fd4;
  --purple: #b07cd8;
  --orange: #e67e22;
  --pink: #e040a0;
  --tier-common: #aaa;
  --tier-fine: #5a8;
  --tier-rare: #5af;
  --tier-unique: #b0f;
  --tier-epic: #f80;

  /* Font Scale */
  --font-2xs: 8px;
  --font-xs: 9px;
  --font-sm: 10px;
  --font-base: 13px;
  --font-md: 16px;
  --font-lg: 20px;
  --font-xl: 26px;
  --font-2xl: 32px;

  /* Radius Scale */
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 10px;

  /* Transition Scale */
  --t-fast: 0.1s;
  --t-normal: 0.2s;
  --t-slow: 0.4s;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.6);
  --shadow-glow-gold: 0 0 12px rgba(201,164,75,0.15);
  --shadow-glow-red: 0 0 12px rgba(192,57,43,0.15);
}
* { margin:0; padding:0; box-sizing:border-box; }
/* Global focus-visible for keyboard accessibility */
:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }
:focus:not(:focus-visible) { outline: none; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", system-ui, sans-serif;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  background-image: radial-gradient(ellipse at 50% 0%, rgba(201,164,75,0.03) 0%, transparent 50%);
}
/* 标题使用衬线保持暗黑氛围 */
.story-box strong, .lobby-title, .boss-victory-title, .region-hub-title, .dungeon-name,
.char-info-name, .npc-name, .inv-header-title, .equip-detail-name {
  font-family: "Noto Serif SC", "Source Han Serif SC", "Songti SC", Georgia, serif;
}
#app { max-width:500px; margin:0 auto; min-height:100vh; display:flex; flex-direction:column; }

/* Top Bar */
.topbar {
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 10px; font-size:11px; color:var(--dim);
  border-bottom:1px solid var(--border);
  letter-spacing:1px; gap:8px;
  position: sticky; top: 0; z-index: 100; background: var(--bg);
}
.topbar a { color:var(--dim); text-decoration:none; font-size:10px; }

/* Main Content */
.main { flex:1; padding:10px 12px; overflow-y:auto; }
.main.fade-out { opacity: 0; transition: opacity 0.12s ease; }
.main.fade-in  { opacity: 1; transition: opacity 0.15s ease; }
.story-box {
  background:var(--panel); border:1px solid var(--border);
  border-radius:6px; padding:14px; margin-bottom:12px;
  font-size:14px; line-height:1.9; white-space:pre-wrap;
  min-height:80px;
}

/* Choices */
.choices { display:flex; flex-direction:column; gap:8px; }
.choice-btn {
  background:var(--panel); border:1px solid var(--border);
  border-radius:4px; padding:10px 12px;
  color:var(--text); font-size:13px; text-align:left;
  cursor:pointer; transition:border-color 0.15s, background 0.15s, transform 0.1s;
  font-family:inherit; letter-spacing:0.5px;
}
.choice-btn:hover { border-color: rgba(255,255,255,0.2); background: var(--panel2); }
.choice-btn:active { border-color:var(--gold); background:#1a1a24; transform: scale(0.98); }
.choice-btn.disabled { opacity:0.4; pointer-events:none; }
.choice-btn.skill-btn { border-color: rgba(90,159,212,0.4); }
.choice-btn.skill-btn:hover { border-color: rgba(90,159,212,0.7); }
.choice-btn.skill-btn:active { border-color: var(--blue); }

/* Continue Button */
.continue-btn {
  width:100%; padding:10px; background:rgba(201,164,75,0.08);
  border:1px solid rgba(201,164,75,0.2); border-radius:4px;
  color:var(--gold); font-size:13px; cursor:pointer;
  font-family:inherit; letter-spacing:1px; margin-top:10px;
  transition: background 0.15s, border-color 0.15s, transform 0.1s;
}
.continue-btn:hover { background:rgba(201,164,75,0.15); border-color: rgba(201,164,75,0.35); }
.continue-btn:active { background:rgba(201,164,75,0.2); transform: scale(0.98); }

/* Combat Panel */
.combat-box {
  background: linear-gradient(180deg, #14141b 0%, #0e0e16 100%);
  border:1px solid rgba(192,57,43,0.3);
  border-radius:8px; padding:12px 14px; margin-bottom:10px;
  font-size:13px; line-height:1.8;
  box-shadow: 0 0 20px rgba(192,57,43,0.05), inset 0 0 30px rgba(0,0,0,0.3);
}
.combat-hp { display:flex; justify-content:space-between; font-size:10px; margin-bottom:6px; }
.hp-bar {
  height:10px; background:#1a1a1a; border-radius:5px; margin:3px 0 8px; overflow:hidden;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.5);
}
.hp-fill {
  height:100%; background: linear-gradient(180deg, #e74c3c 0%, #c0392b 50%, #8b2020 100%);
  border-radius:5px; transition:width 0.4s;
  box-shadow: 0 0 8px rgba(192,57,43,0.4);
}
.hp-fill.player {
  background: linear-gradient(180deg, #5c8 0%, #4a8 50%, #3a7 100%);
  box-shadow: 0 0 8px rgba(68,170,136,0.4);
}
/* MP bar */
.mp-bar {
  height:6px; background:#1a1a1a; border-radius:3px; margin:3px 0 6px; overflow:hidden;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.5);
}
.mp-fill {
  height:100%; background: linear-gradient(180deg, #7ab8f0 0%, #5a9fd4 50%, #1a4a8a 100%);
  border-radius:3px; transition:width 0.4s;
  box-shadow: 0 0 6px rgba(90,159,212,0.35);
}

/* Region-themed combat backgrounds */
.combat-box.region-forest {
  box-shadow: 0 0 20px rgba(68,170,136,0.08), inset 0 0 40px rgba(20,60,30,0.15);
  border-color: rgba(68,170,136,0.25);
}
.combat-box.region-hetonmar {
  box-shadow: 0 0 20px rgba(176,124,216,0.08), inset 0 0 40px rgba(40,20,60,0.15);
  border-color: rgba(176,124,216,0.25);
}
.combat-box.region-sky_city {
  box-shadow: 0 0 20px rgba(90,159,212,0.08), inset 0 0 40px rgba(20,40,80,0.15);
  border-color: rgba(90,159,212,0.25);
}
.combat-box.region-boss {
  box-shadow: 0 0 30px rgba(192,57,43,0.12), 0 0 80px rgba(192,57,43,0.04), inset 0 0 50px rgba(30,5,5,0.2);
  border-color: rgba(192,57,43,0.4);
}

/* ===== Multiplayer Combat v2 ===== */
.cmb-round { display:flex; align-items:center; gap:6px; margin-bottom:8px; font-size:var(--font-sm); color:var(--dim); }
.cmb-round .rnd-num { color:var(--gold); font-weight:600; font-size:var(--font-base); }

/* Monster Zone */
.cmb-monster-zone { display:flex; gap:6px; margin-bottom:8px; }
.cmb-monster-card {
  flex:1; background:var(--panel); border:1px solid var(--border); border-radius:var(--radius-md);
  padding:8px; text-align:center; transition:border-color var(--t-fast);
}
.cmb-monster-card.boss {
  border-color:rgba(192,57,43,0.5); border-width:2px;
  box-shadow:0 0 16px rgba(192,57,43,0.08);
}
.cmb-monster-avatar { width:44px;height:44px;border-radius:var(--radius-sm);object-fit:cover;margin:0 auto 4px;background:#0a0a18;border:1px solid var(--border); }
.cmb-monster-name { font-size:var(--font-base);font-weight:700;line-height:1.3; }
.cmb-monster-lv { font-size:var(--font-2xs);color:var(--dim); }
.cmb-monster-hp-bar { height:5px;background:#1a1a1a;border-radius:3px;margin:4px 0 2px;overflow:hidden; }
.cmb-monster-hp-fill { height:100%;background:var(--red);border-radius:3px;transition:width 0.4s; }
.cmb-monster-hp-text { font-size:var(--font-2xs);color:var(--dim); }
.cmb-narrative { text-align:center;font-size:var(--font-xs);color:var(--dim);font-style:italic;padding:4px 0;border-top:1px solid var(--border);margin-top:6px; }

/* Party Row */
.cmb-party-zone { margin-bottom:8px; }
.cmb-party-label { font-size:var(--font-2xs);color:var(--dim);margin-bottom:6px;display:flex;align-items:center;gap:4px; }
.cmb-party-label .dot { width:5px;height:5px;border-radius:50%;display:inline-block; }
.cmb-party-row { display:flex;gap:5px; }
.cmb-player-card {
  flex:1;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);
  padding:6px;text-align:center;position:relative;transition:all var(--t-fast);
}
.cmb-player-card.active {
  border-color:var(--gold);border-width:2px;
  box-shadow:0 0 12px rgba(201,164,75,0.12);
}
.cmb-player-card.next { border-color:var(--dim-light); }
.cmb-player-card .active-badge {
  position:absolute;top:-8px;right:-4px;
  width:18px;height:18px;border-radius:50%;background:var(--gold);color:#000;
  font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;
}
.cmb-player-card .turn-label { font-size:var(--font-2xs);color:var(--dim);margin-bottom:1px; }
.cmb-player-avatar { width:34px;height:34px;border-radius:var(--radius-sm);object-fit:cover;margin:0 auto 3px;background:#0a0a18;border:1px solid var(--border); }
.cmb-player-name { font-size:11px;font-weight:600;line-height:1.2; }
.cmb-player-class { font-size:var(--font-2xs);color:var(--dim); }
.cmb-player-hp-bar { height:3px;background:#1a1a1a;border-radius:2px;margin:3px 0 1px; }
.cmb-player-hp-fill { height:100%;background:var(--green);border-radius:2px;transition:width 0.4s; }
.cmb-player-hp-fill.low { background:var(--red); }
.cmb-player-hp-fill.mid { background:var(--orange); }
.cmb-player-mp { font-size:var(--font-2xs);color:var(--blue); }

/* Action Panel */
.cmb-action-zone { background:var(--panel2);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 10px;margin-bottom:10px; }
.cmb-action-header { display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:var(--font-sm);color:var(--gold);font-weight:600; }
.cmb-action-header .dot { width:6px;height:6px;border-radius:50%;background:var(--gold);display:inline-block; }
.cmb-skill-grid { display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-bottom:6px; }
.cmb-skill-btn {
  background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:7px 5px;text-align:center;cursor:pointer;font-family:inherit;
  font-size:11px;font-weight:500;color:var(--text);transition:all var(--t-fast);
}
.cmb-skill-btn:hover { border-color:var(--gold); }
.cmb-skill-btn:active { transform:scale(0.96); }
.cmb-skill-btn .sk-name { display:block; }
.cmb-skill-btn .sk-info { display:block;font-size:var(--font-2xs);color:var(--dim);margin-top:1px; }
.cmb-skill-btn.locked { opacity:0.35;cursor:not-allowed; }
.cmb-skill-btn.locked:hover { border-color:var(--border); }
.cmb-skill-btn.cd { opacity:0.5;border-color:#555;cursor:not-allowed; }
.cmb-skill-btn.cd .sk-info { color:var(--blue); }
.cmb-skill-btn.nomp { opacity:0.4;cursor:not-allowed; }
.cmb-skill-btn.nomp .sk-info { color:var(--red); }
.cmb-action-row { display:flex;gap:5px;margin-bottom:4px; }
.cmb-action-btn {
  flex:1;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:7px 4px;text-align:center;cursor:pointer;font-family:inherit;
  font-size:11px;font-weight:500;color:var(--text);transition:all var(--t-fast);
}
.cmb-action-btn:hover { border-color:var(--gold); }
.cmb-action-btn:active { transform:scale(0.96); }
.cmb-action-btn.flee { color:var(--red);border-color:rgba(192,57,43,0.3); }
.cmb-action-btn.flee:hover { border-color:var(--red); }
.cmb-action-btn:disabled { opacity:0.35;pointer-events:none; }
.cmb-log { border-top:1px solid var(--border);padding-top:4px; }
.cmb-log-line { font-size:var(--font-sm);margin:1px 0;line-height:1.5; }

/* Responsive */
@media (max-width:350px) {
  .cmb-player-name { font-size:10px; }
  .cmb-player-avatar { width:28px;height:28px; }
  .cmb-monster-avatar { width:36px;height:36px; }
}
@media (min-width:768px) {
  .cmb-monster-avatar { width:54px;height:54px; }
  .cmb-player-avatar { width:42px;height:42px; }
}

/* ===== Epic 史诗掉落光效 ===== */
@keyframes epicFlash {
  0% { opacity: 0; }
  30% { opacity: 1; }
  100% { opacity: 0; }
}
.epic-drop-flash {
  position: fixed; top:0; left:0; width:100%; height:100%;
  background: radial-gradient(circle, rgba(255,170,0,0.12) 0%, transparent 70%);
  animation: epicFlash 0.7s ease-out forwards;
  pointer-events: none; z-index: 500;
}
@keyframes epicShimmer {
  0% { background-position: 200% 50%; }
  100% { background-position: -200% 50%; }
}
.epic-item-name {
  background: linear-gradient(90deg, #f80, #fc0, #f80, #fc0) !important;
  background-size: 200% 100% !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  animation: epicShimmer 1.5s linear infinite !important;
  font-weight: 900 !important;
}
.unique-item-name {
  background: linear-gradient(90deg, #b0f, #d8f, #b0f, #d8f) !important;
  background-size: 200% 100% !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  animation: epicShimmer 2s linear infinite !important;
  font-weight: 800 !important;
}

/* Bottom Status Bar */
.status-bar {
  display:flex; justify-content:space-between;
  padding:8px 10px; border-top:1px solid var(--border);
  font-size:10px; color:var(--dim); letter-spacing:1px;
  position: sticky; bottom: 0; z-index: 100; background: var(--bg);
}

/* Buttons */
.btn-row { display:flex; gap:8px; margin-top:10px; flex-wrap:wrap; }
.btn {
  flex:1; min-width:60px; padding:8px 4px; border-radius:4px; font-size:12px;
  cursor:pointer; font-family:inherit; letter-spacing:0.5px; text-align:center;
  border:1px solid var(--border); background:var(--panel); color:var(--text);
  transition: border-color 0.15s, background 0.15s, transform 0.15s;
}
.btn:hover { border-color: rgba(255,255,255,0.25); background: var(--panel2); }
.btn:active { border-color:var(--gold); transform: scale(0.96); }
.btn.danger { border-color:var(--red); color:var(--red); }
.btn.danger:hover { border-color: #e74c3c; background: rgba(192,57,43,0.08); }
.btn.blue { border-color:var(--blue); color:var(--blue); }
.btn.blue:hover { border-color: #7ab8f0; background: rgba(90,159,212,0.08); }
.btn:disabled { opacity:0.35; pointer-events:none; }

/* Skill Grid */
.skill-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
  margin-top: 10px;
}
.skill-slot {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 8px 4px; border-radius: 6px; cursor: pointer; font-family: inherit;
  border: 1px solid var(--border); background: var(--panel);
  color: var(--text); transition: border-color 0.15s, background 0.15s, transform 0.1s;
}
.skill-slot:hover { border-color: rgba(255,255,255,0.25); background: var(--panel2); }
.skill-slot:active { transform: scale(0.96); }
.skill-slot .skill-icon { font-size: 16px; line-height: 1; }
.skill-slot .skill-name { font-size: 12px; font-weight: 500; }
.skill-slot .skill-status { font-size: 10px; color: var(--dim); }
.skill-slot.cd { opacity: 0.5; border-color: #555; cursor: not-allowed; }
.skill-slot.cd .skill-status { color: #8af; }
.skill-slot.nomp { opacity: 0.4; cursor: not-allowed; }
.skill-slot.nomp .skill-status { color: var(--red); }
.skill-slot.locked { opacity: 0.35; cursor: not-allowed; background: var(--panel, #111); border-color: #333; }
.skill-slot:disabled { opacity: 0.35; pointer-events: none; }

/* ====== Awakening Sweep Cut-In v4 ====== */
.aw { position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999;pointer-events:none;overflow:hidden; }
.aw-bg { position:absolute;top:0;left:0;width:100%;height:100%;background:#000;animation:awBg 2.5s ease-out forwards; }

/* 文字层 — 先出场后消失 */
.aw-text { position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);text-align:center;z-index:5;animation:awTextLife 2.2s ease-out forwards; }
.aw-text .t1 { font-size:10px;letter-spacing:16px;margin-bottom:4px;animation:awT1In .4s ease-out forwards;opacity:0; }
.aw-text .t2 { font-size:30px;font-weight:900;letter-spacing:6px;white-space:nowrap;animation:awT2In .5s cubic-bezier(.16,1,.3,1) .15s forwards;opacity:0;transform:scale(2); }
.aw-text .t3 { font-size:10px;letter-spacing:10px;margin-top:6px;animation:awT3In .35s ease-out .4s forwards;opacity:0; }

/* 图像层 — 横扫 */
.aw-card { position:absolute;top:50%;left:50%;margin-left:-90px;margin-top:-120px;display:flex;flex-direction:column;align-items:center;animation:awSlide 2.2s cubic-bezier(.7,0,.15,1) .4s forwards;opacity:0; }
.aw-img { height:210px;width:auto;object-fit:contain;filter:drop-shadow(0 0 50px rgba(255,255,255,.3)); }

/* 速度线 */
.aw-sl { position:absolute;left:-10%;height:2px;width:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5) 20%,rgba(255,255,255,.35) 50%,transparent 80%);box-shadow:0 0 8px rgba(255,255,255,.3),0 0 20px rgba(255,255,255,.1);animation:awLine .7s ease-out forwards; }

/* 粒子 */
.aw-ps { position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none; }
.aw-p { position:absolute;border-radius:2px;animation:awPfly 2.8s ease-out forwards; }

/* Keyframes */
@keyframes awBg{0%{opacity:0}4%{opacity:.92}84%{opacity:.92}100%{opacity:0}}
@keyframes awTextLife{0%{opacity:1}55%{opacity:1}75%{opacity:0}100%{opacity:0}}
@keyframes awT1In{from{opacity:0;letter-spacing:24px;transform:translateY(-8px)}to{opacity:1;letter-spacing:16px;transform:translateY(0)}}
@keyframes awT2In{0%{opacity:0;transform:scale(2);filter:blur(4px)}60%{opacity:1;transform:scale(.92);filter:blur(0)}100%{opacity:1;transform:scale(1);filter:blur(0)}}
@keyframes awT3In{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes awSlide{0%{left:-500px;opacity:0;filter:blur(8px)}15%{left:50%;opacity:1;filter:blur(0)}50%{left:50%;opacity:1;filter:blur(0)}100%{left:calc(100% + 500px);opacity:0;filter:blur(8px)}}
@keyframes awLine{0%{width:0;left:0}45%{width:100%;opacity:1}100%{width:130%;left:15%;opacity:0}}
@keyframes awPfly{0%{transform:translate(0,0) rotate(0deg) scale(1);opacity:1}100%{transform:translate(var(--x),var(--y)) rotate(var(--r)) scale(0);opacity:0}}

/* Class colors */
.aw.ghost .t2{color:#aa55ff;text-shadow:0 0 30px rgba(170,85,255,.9),0 0 80px rgba(120,40,255,.5),0 4px 8px rgba(0,0,0,.9)}
.aw.ghost .t1,.aw.ghost .t3{color:#cc99ff}
.aw.sword .t2{color:#88ccff;text-shadow:0 0 30px rgba(136,200,255,.9),0 0 80px rgba(100,160,255,.5),0 4px 8px rgba(0,0,0,.9)}
.aw.sword .t1,.aw.sword .t3{color:#aaddff}
.aw.berserk .t2{color:#ff5544;text-shadow:0 0 30px rgba(255,85,68,.9),0 0 80px rgba(255,50,30,.5),0 4px 8px rgba(0,0,0,.9)}
.aw.berserk .t1,.aw.berserk .t3{color:#ff9988}
.aw.asura .t2{color:#ffaa33;text-shadow:0 0 30px rgba(255,170,51,.9),0 0 80px rgba(255,140,30,.5),0 4px 8px rgba(0,0,0,.9)}
.aw.asura .t1,.aw.asura .t3{color:#ffcc77}
.aw.ranger .t2{color:#ffdd44;text-shadow:0 0 30px rgba(255,221,68,.9),0 0 80px rgba(255,200,40,.5),0 4px 8px rgba(0,0,0,.9)}
.aw.ranger .t1,.aw.ranger .t3{color:#ffee88}
.aw.launcher .t2{color:#ff8833;text-shadow:0 0 30px rgba(255,136,51,.9),0 0 80px rgba(255,100,40,.5),0 4px 8px rgba(0,0,0,.9)}
.aw.launcher .t1,.aw.launcher .t3{color:#ffbb77}
.aw.crusader .t2{color:#ffddaa;text-shadow:0 0 30px rgba(255,221,170,.9),0 0 80px rgba(255,200,150,.5),0 4px 8px rgba(0,0,0,.9)}
.aw.crusader .t1,.aw.crusader .t3{color:#ffeecc}
.aw.monk .t2{color:#cc55ff;text-shadow:0 0 30px rgba(204,85,255,.9),0 0 80px rgba(180,40,255,.5),0 4px 8px rgba(0,0,0,.9)}
.aw.monk .t1,.aw.monk .t3{color:#dd99ff}

/* Combat Illustration */

/* Combat Illustration */
.combat-illust {
  display:flex; align-items:flex-end; justify-content:center; gap:0;
  padding:16px 6px 8px; min-height:175px; position:relative; overflow:hidden;
  background: radial-gradient(ellipse 220px 130px at 30% 70%, rgba(192,57,43,0.1) 0%, transparent 60%),
              radial-gradient(ellipse 220px 130px at 70% 70%, rgba(74,144,216,0.08) 0%, transparent 60%),
              linear-gradient(to bottom, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.4) 100%);
  border-radius:6px; margin-bottom:10px;
  border: 1px solid rgba(255,255,255,0.04);
}
.combat-illust .fighter-wrap {
  display:flex; flex-direction:column; align-items:center; width:120px; position:relative;
}
.combat-illust .fighter-wrap img {
  width:110px; height:130px; object-fit:contain;
  filter: drop-shadow(0 0 10px rgba(255,255,255,0.06)) drop-shadow(0 4px 16px rgba(0,0,0,0.6));
  transition:transform 0.2s, filter 0.2s;
  /* Blend into background - subtle glow to separate from dark bg */
  border-radius:2px;
}
/* Glow aura behind each fighter */
.combat-illust .fighter-wrap::before {
  content:''; position:absolute;
  width:80px; height:80px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,0.04) 0%, transparent 70%);
  bottom:10px; left:50%; transform:translateX(-50%);
  pointer-events:none; z-index:-1;
}
.combat-illust .fighter-wrap.monster-wrap::before {
  background:radial-gradient(circle, rgba(192,57,43,0.05) 0%, transparent 70%);
}
/* Ground shadow */
.combat-illust::after {
  content:''; position:absolute;
  bottom:12px; left:10%; width:80%; height:2px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.04),transparent);
  border-radius:50%; pointer-events:none;
}
.combat-illust .fighter-label {
  font-size:9px; color:var(--dim); margin-top:4px; letter-spacing:2px; text-align:center;
}
.combat-illust .fighter-wrap.player-wrap img { transform-origin:right center; }
.combat-illust .fighter-wrap.monster-wrap img { transform-origin:left center; }
.combat-illust .vs-zone {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  flex-shrink:0; padding:0 8px 20px 8px; width:56px; position:relative;
}
.combat-illust .vs-text {
  font-size:26px; font-weight:900; letter-spacing:4px; line-height:1;
  background:linear-gradient(180deg, #e74c3c 0%, rgba(231,76,60,0.4) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; filter:drop-shadow(0 0 12px rgba(192,57,43,0.25));
  font-family:'Georgia','Noto Serif SC','serif'; font-style:italic;
}
.combat-illust .vs-line {
  width:24px; height:1px; background:linear-gradient(90deg,transparent,rgba(192,57,43,0.3),transparent);
  margin-top:6px;
}
/* Shake & Hit - old-school RPG style, only the image shakes */
.combat-illust .shake img { animation: shake 0.35s ease; }
.combat-illust .hit-flash img { animation: hitFlash 0.3s ease; }
/* Projectile - flies from player area toward monster */
.projectile {
  position:absolute; pointer-events:none; z-index:20;
  top:40%; left:30px; opacity:0;
}
.projectile-attack {
  width:10px; height:10px;
  background:radial-gradient(circle,#fff 0%,var(--gold) 35%,transparent 70%);
  border-radius:50%; box-shadow:0 0 16px var(--gold), 0 0 32px rgba(201,164,75,0.3);
}
.projectile-skill {
  width:24px; height:24px;
  background:radial-gradient(circle,#fff 0%,#5a9fd4 30%,transparent 70%);
  border-radius:50%; box-shadow:0 0 24px var(--blue), 0 0 48px rgba(90,159,212,0.3);
}
.projectile-skill-burst {
  width:28px; height:28px;
  background:radial-gradient(circle,#fff 0%,var(--purple) 30%,transparent 70%);
  border-radius:50%; box-shadow:0 0 30px var(--purple), 0 0 60px rgba(176,124,216,0.3);
}
/* Hit burst on monster */
.hit-burst {
  position:absolute; pointer-events:none; z-index:15;
  top:35%; left:40%; width:40px; height:40px;
  background:radial-gradient(circle,#fff 0%,var(--gold) 20%,transparent 70%);
  border-radius:50%; opacity:0;
}
.hit-burst.show { animation: hitBurst 0.4s ease forwards; }
.hit-burst.show.skill { animation: hitBurstBig 0.5s ease forwards; }
@keyframes hitBurst {
  0% { opacity:1; transform:scale(0.3); }
  40% { opacity:1; transform:scale(2); }
  100% { opacity:0; transform:scale(3.5); }
}
@keyframes hitBurstBig {
  0% { opacity:1; transform:scale(0.2); border:2px solid #fff; }
  30% { opacity:0.9; transform:scale(2.5); border:1px solid rgba(255,255,255,0.5); }
  100% { opacity:0; transform:scale(5); border:0; }
}
@keyframes intenseShake {
  0%,100%{transform:translate(0,0)}
  8%{transform:translate(-8px,4px)} 16%{transform:translate(7px,-5px)}
  24%{transform:translate(-6px,-3px)} 32%{transform:translate(5px,3px)}
  40%{transform:translate(-4px,-2px)} 48%{transform:translate(3px,1px)}
  56%{transform:translate(-2px,0)} 64%{transform:translate(1px,-1px)}
  72%{transform:translate(-1px,0)} 100%{transform:translate(0,0)}
}
@keyframes shake {
  0%,100%{transform:translate(0,0)}
  15%{transform:translate(-6px,3px)}
  30%{transform:translate(5px,-2px)}
  45%{transform:translate(-4px,-4px)}
  60%{transform:translate(3px,2px)}
  75%{transform:translate(-2px,1px)}
}
@keyframes hitFlash {
  0%{filter:brightness(2.5) saturate(0.1) contrast(1.3)}
  30%{filter:brightness(1.8) saturate(0.3)}
  100%{filter:brightness(1) saturate(1)}
}
/* 受击白模剪影 - 重击瞬间全白 */
@keyframes hitSilhouette {
  0%{filter:brightness(5) saturate(0) contrast(2)}
  50%{filter:brightness(3) saturate(0.1)}
  100%{filter:brightness(1) saturate(1)}
}
@keyframes particleBurst {
  0% { opacity:1; transform:translate(0,0) scale(1); }
  100% { opacity:0; transform:translate(var(--px,25px),var(--py,-25px)) scale(0); }
}
/* 多层粒子爆发 */
@keyframes sparkBurst {
  0% { opacity:1; transform:translate(0,0) scale(1.5) rotate(0deg); }
  30% { opacity:0.8; }
  100% { opacity:0; transform:translate(var(--sx,40px),var(--sy,-40px)) scale(0) rotate(var(--sr,90deg)); }
}
@keyframes smokePuff {
  0% { opacity:0.6; transform:translate(0,0) scale(0.5); }
  100% { opacity:0; transform:translate(var(--smx,15px),var(--smy,-30px)) scale(2); }
}
@keyframes energyGather {
  0% { opacity:0; transform:translate(-50%,-50%) scale(0.3); }
  40% { opacity:0.7; transform:translate(-50%,-50%) scale(1.4); }
  100% { opacity:0; transform:translate(-50%,-50%) scale(2.5); }
}
@keyframes deathBurst {
  0% { opacity:0; transform:scale(0); }
  20% { opacity:1; transform:scale(1); }
  100% { opacity:0; transform:scale(4) rotate(20deg); }
}
@keyframes impactShockwave {
  0% { opacity:0.8; transform:scale(0.1); }
  100% { opacity:0; transform:scale(var(--is,3)); }
}
@keyframes screenShake {
  0%{transform:translate(0,0)} 10%{transform:translate(-6px,3px)}
  20%{transform:translate(5px,-4px)} 30%{transform:translate(-4px,-2px)}
  40%{transform:translate(3px,2px)} 50%{transform:translate(-2px,-1px)}
  60%{transform:translate(1px,0)} 100%{transform:translate(0,0)}
}
@keyframes powerPulse {
  0%,100%{box-shadow:0 0 10px var(--pc,#ffaa44),inset 0 0 5px var(--pc,#ffaa44)}
  50%{box-shadow:0 0 25px var(--pc,#ffaa44),inset 0 0 15px var(--pc,#ffaa44)}
}
@keyframes dmgFloat {
  0%{opacity:1;transform:translateY(0) scale(1)}
  20%{opacity:1;transform:translateY(-8px) scale(1.3)}
  100%{opacity:0;transform:translateY(-40px) scale(0.8)}
}
/* 更好的弹道发光 */
.projectile {
  position:absolute; top:42%; z-index:20; pointer-events:none;
  filter:drop-shadow(0 0 8px currentColor);
}

/* ===== Boss Room Entrance ===== */
.boss-room-intro {
  background: linear-gradient(180deg, rgba(30,5,5,0.95) 0%, rgba(15,2,2,0.98) 100%);
  border: 2px solid rgba(192,57,43,0.4);
  border-radius: 10px; padding: 24px 14px 16px;
  text-align: center; margin-bottom: 12px;
  animation: bossRoomPulse 1s ease-in-out;
  box-shadow: 0 0 40px rgba(192,57,43,0.08), inset 0 0 60px rgba(20,0,0,0.3);
}
@keyframes bossRoomPulse {
  0% { border-color: rgba(192,57,43,0.1); box-shadow: 0 0 10px rgba(192,57,43,0.02); }
  50% { border-color: rgba(192,57,43,0.7); box-shadow: 0 0 60px rgba(192,57,43,0.15); }
  100% { border-color: rgba(192,57,43,0.4); box-shadow: 0 0 40px rgba(192,57,43,0.08); }
}
.boss-room-skull {
  font-size: 48px; animation: bossSkullBeat 0.8s ease infinite alternate;
}
@keyframes bossSkullBeat {
  0% { transform: scale(1); opacity: 0.7; }
  100% { transform: scale(1.15); opacity: 1; }
}
.boss-room-title {
  font-size: 22px; font-weight: 900; color: var(--red);
  text-shadow: 0 0 20px rgba(192,57,43,0.5);
  margin: 6px 0; letter-spacing: 3px;
}
.boss-room-sub { font-size: 11px; color: var(--dim); margin-bottom: 6px; }
.boss-room-desc { font-size: 12px; color: var(--text); opacity: 0.7; }

/* ===== Boss Victory Panel ===== */
.boss-victory {
  position: relative;
  padding: 0;
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 12px;
}
.boss-victory-illust {
  background: radial-gradient(ellipse 300px 200px at 50% 80%, rgba(201,164,75,0.12) 0%, transparent 60%),
              linear-gradient(180deg, rgba(20,20,30,0.95) 0%, rgba(10,10,18,0.98) 100%);
  border: 2px solid rgba(201,164,75,0.3);
  border-radius: 10px;
  padding: 20px 10px 10px;
  text-align: center;
  position: relative;
  animation: bossVictoryGlow 2s ease-in-out infinite alternate;
}
.boss-victory-illust::after {
  content: ''; position: absolute;
  bottom: 0; left: 0; right: 0; height: 40%;
  background: linear-gradient(to top, rgba(0,0,0,0.6), transparent);
  pointer-events: none;
  border-radius: 0 0 10px 10px;
}
@keyframes bossVictoryGlow {
  0% { border-color: rgba(201,164,75,0.25); box-shadow: 0 0 30px rgba(201,164,75,0.06); }
  100% { border-color: rgba(201,164,75,0.5); box-shadow: 0 0 60px rgba(201,164,75,0.12), 0 0 120px rgba(255,165,0,0.04); }
}
.boss-victory-img {
  width: 130px; height: 150px;
  object-fit: contain;
  filter: brightness(0.7) saturate(0.6) drop-shadow(0 0 20px rgba(192,57,43,0.3));
  animation: bossDefeated 1.5s ease forwards;
  opacity: 0.55;
}
@keyframes bossDefeated {
  0% { transform: scale(1.1) translateY(-10px); filter: brightness(1.2) saturate(1) drop-shadow(0 0 30px rgba(192,57,43,0.6)); }
  30% { transform: scale(1.0) translateY(0); filter: brightness(0.8) saturate(0.8); }
  100% { transform: scale(0.95) translateY(8px); filter: brightness(0.6) saturate(0.5) drop-shadow(0 0 10px rgba(192,57,43,0.2)); }
}
.boss-victory-title {
  font-size: 18px; font-weight: bold;
  background: linear-gradient(180deg, var(--gold) 0%, #e8a020 50%, var(--gold) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  text-shadow: none;
  animation: titleShine 1.5s ease infinite;
}
@keyframes titleShine {
  0%,100% { filter: brightness(1); }
  50% { filter: brightness(1.3); }
}
.boss-victory-defeated {
  position: absolute;
  top: 38%; left: 50%;
  transform: translate(-50%, -50%) rotate(-12deg);
  font-size: 64px; font-weight: 900;
  color: rgba(220,40,30,0.55);
  pointer-events: none;
  letter-spacing: 10px;
  white-space: nowrap;
  font-family: "Georgia", "Times New Roman", serif;
  font-style: italic;
  text-shadow: 0 0 20px rgba(200,30,20,0.4), 0 0 60px rgba(180,20,10,0.2), 2px 2px 0 rgba(0,0,0,0.5);
  animation: defeatedStamp 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  z-index: 5;
}
@keyframes defeatedStamp {
  0% { opacity: 0; transform: translate(-50%, -50%) rotate(-12deg) scale(3); }
  60% { opacity: 1; transform: translate(-50%, -50%) rotate(-12deg) scale(0.9); }
  80% { transform: translate(-50%, -50%) rotate(-12deg) scale(1.05); }
  100% { opacity: 1; transform: translate(-50%, -50%) rotate(-12deg) scale(1); }
}

/* Boss插图上的毛笔X */
.boss-cross {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 100px; height: 100px;
  pointer-events: none;
  z-index: 4;
  opacity: 0;
  animation: crossDraw 0.5s 0.3s ease-out forwards;
}
.boss-cross svg { width: 100%; height: 100%; }
@keyframes crossStroke {
  to { stroke-dashoffset: 0; }
}
@keyframes crossDraw {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0.3) rotate(-20deg); }
  100% { opacity: 0.85; transform: translate(-50%, -50%) scale(1) rotate(-5deg); }
}

/* 通关奖励 — 文本+图标行 */
.boss-rewards {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  padding: 10px 14px;
  margin-top: 4px;
}
.boss-reward-item {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  font-weight: 600;
}
.boss-reward-item .ri-icon { font-size: 16px; }
.boss-reward-item .ri-val { color: var(--gold); }
.boss-reward-item.ri-exp .ri-val { color: var(--blue); }
.boss-reward-item.ri-hp .ri-val { color: var(--green); }
.boss-reward-item.ri-turn .ri-val { color: var(--dim); }

/* 隐藏旧的卡片样式 */
.boss-victory-stats { display: none; }
.boss-victory-actions {
  display: flex; flex-direction: column; gap: 6px; margin-top: 8px;
}
.boss-next-dung {
  border-color: rgba(201,164,75,0.3) !important;
  color: var(--gold) !important;
  font-size: 14px !important;
  text-align: center !important;
}
.boss-retry {
  border-color: rgba(90,159,212,0.3) !important;
  font-size: 13px !important;
  text-align: center !important;
}
.boss-return {
  font-size: 11px !important;
}

/* ===== Class-Specific Skill Effects (DNF Style) ===== */

/* 剑魂 - 拔刀斩：横向剑气从左侧横扫 */
.proj-sword-skill {
  width:140px; height:4px; border-radius:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(180,220,255,0.3) 20%,rgba(220,240,255,1) 50%,rgba(255,255,255,1) 70%,rgba(180,220,255,0.3) 100%);
  box-shadow:0 0 15px #fff, 0 0 40px rgba(150,200,255,0.6), 0 0 80px rgba(150,200,255,0.2);
  top:45% !important; left:5% !important;
  animation: swordSlashV3 0.4s ease-out forwards !important;
  transform-origin:left center;
}
@keyframes swordSlashV3{
  0%{opacity:0;width:0;filter:blur(4px)}
  12%{opacity:1;width:120px;filter:blur(0)}
  30%{opacity:1;width:240px}
  65%{opacity:0.8;width:300px}
  100%{opacity:0;width:340px;filter:blur(3px)}
}

/* 狂战士 - 崩山击：血爆从上方砸落 */
.proj-berserk-skill {
  width:60px; height:60px; border-radius:50%;
  background:radial-gradient(circle,rgba(255,60,20,0.9) 0%,rgba(200,20,10,0.6) 30%,rgba(255,100,30,0.3) 60%,transparent 100%);
  box-shadow:0 0 30px rgba(255,40,10,0.7), 0 0 80px rgba(200,20,0,0.3), 0 30px 60px rgba(255,20,0,0.2);
  top:-20% !important; left:55% !important;
  animation: berserkCrashV3 0.5s ease-in forwards !important;
}
@keyframes berserkCrashV3{
  0%{opacity:0;transform:translateY(0) scale(0.15)}
  18%{opacity:1;transform:translateY(55%) scale(0.5)}
  50%{opacity:1;transform:translateY(110%) scale(1.8)}
  75%{opacity:0.7;transform:translateY(115%) scale(2.3)}
  100%{opacity:0;transform:translateY(120%) scale(3)}
}

/* 鬼泣 - 鬼影闪：多层暗影斩击从不同方向 */
.proj-ghost-skill { display:none; } /* ghost uses DOM animation */
.ghost-slash-container { position:absolute; top:0; left:0; width:100%; height:100%; pointer-events:none; z-index:25; }
.ghost-slash {
  position:absolute; width:0px; height:3px;
  background:linear-gradient(90deg,transparent,rgba(80,20,140,0.9),rgba(140,60,200,0.5),transparent);
  border-radius:1px; opacity:0; transform-origin:left center;
}
.ghost-slash.show { animation: ghostSlashV3 0.5s ease forwards; }
.ghost-slash-skill {
  width:0px; height:6px;
  background:linear-gradient(90deg,transparent,rgba(150,40,220,0.95),rgba(200,100,255,0.4),transparent);
  box-shadow:0 0 20px rgba(150,40,220,0.4);
}
@keyframes ghostSlashV3{
  0%{opacity:0;width:0}
  12%{opacity:0.95;width:80px}
  35%{opacity:1;width:170px}
  65%{opacity:0.5;width:210px;transform:translateX(30px)}
  100%{opacity:0;width:230px;transform:translateX(40px)}
}

/* 阿修罗 - 波动爆发：地面扩散波 */
.proj-asura-skill {
  width:10px; height:20px; border-radius:50% 50% 0 0;
  background:linear-gradient(0deg,rgba(255,180,50,1),rgba(255,120,20,0.8),rgba(200,60,0,0.3),transparent);
  box-shadow:0 -10px 30px rgba(255,150,30,0.6), 0 -5px 15px rgba(255,200,80,0.3);
  bottom:5% !important; left:25% !important;
  animation: asuraWaveV3 0.5s ease-out forwards !important;
}
@keyframes asuraWaveV3{
  0%{opacity:0;transform:scaleX(0.08) scaleY(0.15)}
  22%{opacity:1;transform:scaleX(2) scaleY(0.6)}
  50%{opacity:0.9;transform:scaleX(5) scaleY(1.5)}
  75%{opacity:0.4;transform:scaleX(7) scaleY(3)}
  100%{opacity:0;transform:scaleX(8.5) scaleY(4.5) translateX(40px)}
}

/* 漫游 - 乱射弹幕：扇形散射 */
.proj-ranger-skill {
  width:8px; height:8px; border-radius:50%;
  background:radial-gradient(circle,#ffd700,#ff8800);
  box-shadow:0 0 8px #ffd700, 0 0 16px #ff8800;
  top:30% !important; left:10% !important;
  animation: rangerScatterV3 0.45s ease-out forwards !important;
}
@keyframes rangerScatterV3{
  0%{opacity:0;transform:translate(0,0) scale(0.3)}
  8%{opacity:1;transform:translate(45px,-10px) scale(1.2)}
  20%{opacity:1;transform:translate(100px,14px) scale(0.9)}
  40%{opacity:0.8;transform:translate(160px,-15px) scale(0.7)}
  60%{opacity:0.5;transform:translate(210px,8px) scale(0.5)}
  100%{opacity:0;transform:translate(280px,0) scale(0.15)}
}

/* 枪炮师 - 激光炮：粗光束+后坐力 */
.proj-launcher-skill {
  width:12px; height:100%; border-radius:6px;
  background:linear-gradient(90deg,rgba(255,200,50,0.1),rgba(255,150,20,0.3) 10%,rgba(255,100,10,1) 30%,rgba(255,200,50,1) 50%,rgba(255,100,10,0.8) 70%,transparent);
  box-shadow:0 0 30px rgba(255,150,20,0.9), 0 0 80px rgba(255,100,0,0.4), 10px 0 40px rgba(255,200,50,0.2);
  top:0 !important; left:5% !important; height:100% !important;
  animation: launcherBeamV3 0.4s ease-out forwards !important;
  transform-origin:left center;
}
@keyframes launcherBeamV3{
  0%{opacity:0;width:0}
  8%{opacity:1;width:120px}
  35%{opacity:1;width:280px}
  60%{opacity:0.7;width:330px}
  100%{opacity:0;width:360px}
}

/* 圣骑士 - 天降圣光：光柱从上方降下 */
.proj-crusader-skill {
  width:60px; height:8px; border-radius:2px;
  background:linear-gradient(180deg,rgba(255,255,255,1),rgba(255,240,180,0.9),rgba(255,215,0,0.3),transparent);
  box-shadow:0 0 30px rgba(255,255,200,0.8), 0 0 80px rgba(255,240,150,0.3);
  top:5% !important; left:50% !important; transform:translateX(-50%);
  animation: holyDescendV3 0.5s ease-in forwards !important;
}
@keyframes holyDescendV3{
  0%{opacity:0;height:8px;transform:translateX(-50%) translateY(0)}
  12%{opacity:1;height:50px;transform:translateX(-50%) translateY(25%)}
  45%{opacity:1;height:100px;transform:translateX(-50%) translateY(60%)}
  100%{opacity:0;height:140px;transform:translateX(-50%) translateY(110%)}
}

/* 混沌 - 崩拳：紫焰爆破+冲击波 */
.proj-monk-skill {
  width:50px; height:50px; border-radius:50%;
  background:radial-gradient(circle,rgba(200,100,255,0.9) 0%,rgba(150,40,220,0.6) 30%,rgba(80,20,140,0.3) 60%,transparent 100%);
  box-shadow:0 0 40px rgba(180,80,255,0.7), 0 0 100px rgba(120,40,200,0.3);
  top:35% !important; left:15% !important;
  animation: monkBurstV3 0.45s ease-out forwards !important;
}
@keyframes monkBurstV3{
  0%{opacity:0;transform:translate(0,0) scale(0.08)}
  22%{opacity:1;transform:translate(35px,0) scale(0.7)}
  50%{opacity:0.9;transform:translate(75px,0) scale(1.8)}
  75%{opacity:0.4;transform:translate(110px,0) scale(2.5)}
  100%{opacity:0;transform:translate(150px,0) scale(3.5)}
}

/* ===== Basic Attack Projectiles (simpler versions) ===== */
.proj-sword { width:40px; height:4px; border-radius:2px; background:linear-gradient(90deg,transparent,#fff,#fff,transparent); box-shadow:0 0 10px rgba(255,255,255,0.5); }
.proj-berserk { width:30px; height:30px; background:radial-gradient(circle,rgba(200,30,20,0.7),transparent 70%); border-radius:50%; }
.proj-asura { width:30px; height:15px; border-radius:50% 50% 0 0; background:linear-gradient(0deg,rgba(255,140,30,0.8),transparent); }
.proj-ranger { width:10px; height:4px; border-radius:50%; background:#ffd700; box-shadow:0 0 8px #ffaa00; }
.proj-launcher { width:14px; height:14px; border-radius:50%; background:radial-gradient(circle,#ff6600,#cc3300); }
.proj-crusader { width:20px; height:20px; border-radius:50%; background:radial-gradient(circle,#fff,#ffd700 70%,transparent); }
.proj-monk { width:25px; height:25px; border-radius:50%; background:radial-gradient(circle,rgba(180,80,255,0.8),transparent 70%); }

/* Basic animations */
@keyframes projectileFly { 0%{opacity:1;transform:translateX(0) scale(0.8);} 100%{opacity:0;transform:translateX(175px) scale(0.3);} }
@keyframes projFlyFast { 0%{opacity:1;transform:translateX(0) scale(0.8);} 100%{opacity:0;transform:translateX(200px) scale(0.2);} }
@keyframes projFlyGround { 0%{opacity:1;transform:translateX(0) scale(0.7) translateY(0);} 60%{transform:translateX(90px) scale(1) translateY(4px);} 100%{opacity:0;transform:translateX(175px) scale(0.3) translateY(0);} }
@keyframes monsterProjectileFly { 0%{opacity:1;transform:translateX(0);} 100%{opacity:0;transform:translateX(-175px);} }
@keyframes projFlySpin { 0%{opacity:1;transform:translateX(0) scale(0.6) rotate(0deg);} 100%{opacity:0;transform:translateX(180px) scale(0.2) rotate(540deg);} }

/* ===== Enhanced Skill Effects System ===== */

/* 技能名称大字显示 */
.skill-name-overlay {
  position: absolute; top: 15%; left: 50%; transform: translate(-50%, -50%);
  font-size: 28px; font-weight: 900; font-family: "Noto Serif SC", serif;
  color: #fff; text-shadow: 0 0 20px rgba(255,220,100,1), 0 0 60px rgba(255,150,20,0.8), 0 0 100px rgba(255,80,0,0.5), 0 4px 8px rgba(0,0,0,0.8);
  letter-spacing: 6px; z-index: 60; pointer-events: none; opacity: 0;
  animation: skillNamePop 0.8s ease-out forwards;
  white-space: nowrap;
}
@keyframes skillNamePop {
  0%   { opacity:0; transform:translate(-50%,-50%) scale(0.3) rotate(-8deg); }
  15%  { opacity:1; transform:translate(-50%,-50%) scale(1.3) rotate(2deg); }
  30%  { opacity:1; transform:translate(-50%,-50%) scale(1) rotate(0deg); }
  70%  { opacity:0.8; transform:translate(-50%,-80%) scale(0.95); }
  100% { opacity:0; transform:translate(-50%,-120%) scale(0.8); }
}

/* 蓄力光环 */
.charge-aura {
  position: absolute; border-radius: 50%;
  pointer-events: none; z-index: 45; opacity: 0;
  animation: chargePulse 0.5s ease-out forwards;
}
.charge-aura.sword  { width:100px;height:100px;left:10%;top:30%; background:radial-gradient(circle,rgba(180,220,255,0.6) 0%,rgba(100,160,255,0.3) 40%,transparent 70%); box-shadow:0 0 30px rgba(150,200,255,0.5); }
.charge-aura.berserk{ width:120px;height:120px;left:8%;top:25%; background:radial-gradient(circle,rgba(255,60,20,0.6) 0%,rgba(200,20,0,0.3) 40%,transparent 70%); box-shadow:0 0 40px rgba(255,30,0,0.6); }
.charge-aura.ghost  { width:110px;height:110px;left:10%;top:28%; background:radial-gradient(circle,rgba(140,40,220,0.6) 0%,rgba(80,20,140,0.3) 40%,transparent 70%); box-shadow:0 0 35px rgba(150,50,230,0.6); }
.charge-aura.asura  { width:105px;height:105px;left:10%;top:30%; background:radial-gradient(circle,rgba(255,180,60,0.6) 0%,rgba(255,100,20,0.3) 40%,transparent 70%); box-shadow:0 0 35px rgba(255,150,30,0.5); }
.charge-aura.ranger { width:90px;height:90px;left:12%;top:33%;  background:radial-gradient(circle,rgba(255,215,0,0.6) 0%,rgba(255,140,0,0.3) 40%,transparent 70%); box-shadow:0 0 30px rgba(255,200,0,0.5); }
.charge-aura.launcher{width:130px;height:130px;left:7%;top:24%;background:radial-gradient(circle,rgba(255,130,20,0.7) 0%,rgba(200,60,0,0.3) 40%,transparent 70%); box-shadow:0 0 50px rgba(255,80,0,0.6); }
.charge-aura.crusader{width:110px;height:110px;left:9%;top:27%;background:radial-gradient(circle,rgba(255,255,255,0.7) 0%,rgba(255,215,0,0.3) 40%,transparent 70%); box-shadow:0 0 40px rgba(255,240,150,0.7); }
.charge-aura.monk  { width:105px;height:105px;left:10%;top:28%;background:radial-gradient(circle,rgba(200,100,255,0.6) 0%,rgba(120,30,200,0.3) 40%,transparent 70%); box-shadow:0 0 35px rgba(170,70,255,0.6); }
@keyframes chargePulse {
  0%   { opacity:0; transform:scale(0.3); }
  30%  { opacity:1; transform:scale(1.2); }
  60%  { opacity:0.8; transform:scale(0.9); }
  100% { opacity:0; transform:scale(1.5); }
}

/* 全屏闪光增强 */
.screen-flash-heavy {
  position: fixed; top:0; left:0; width:100vw; height:100vh;
  pointer-events: none; z-index: 9999; opacity: 0;
  animation: flashHeavy 0.4s ease-out forwards;
}
@keyframes flashHeavy {
  0%   { opacity:0; }
  10%  { opacity:1; background:rgba(255,255,255,0.6); }
  30%  { opacity:0.5; background:rgba(255,255,255,0.2); }
  100% { opacity:0; background:transparent; }
}

/* 地面冲击波环 */
.impact-ring {
  position: absolute; border-radius: 50%;
  pointer-events: none; z-index: 55;
  border: 3px solid rgba(255,200,100,0.8);
  animation: impactExpand 0.6s ease-out forwards;
}
@keyframes impactExpand {
  0%   { width:10px; height:10px; opacity:1; border-width:6px; }
  100% { width:200px; height:200px; opacity:0; border-width:1px; transform:translate(-50%,-50%); }
}

/* 地面裂缝 */
.ground-crack {
  position: absolute; pointer-events: none; z-index: 50; opacity: 0;
  animation: crackAppear 0.7s ease-out forwards;
}
@keyframes crackAppear {
  0%   { opacity:0; transform:scale(0.3); }
  20%  { opacity:0.8; transform:scale(1); }
  100% { opacity:0; transform:scale(1.2); }
}

/* 冲击波粒子 */
.skill-particle {
  position: absolute; border-radius: 50%;
  pointer-events: none; z-index: 58;
  animation: skillParticleBurst 0.7s ease-out forwards;
}
@keyframes skillParticleBurst {
  0%   { opacity:1; transform:translate(0,0) scale(1); }
  100% { opacity:0; transform:translate(var(--px),var(--py)) scale(0); }
}

/* 能量条汇聚 */
.energy-stream {
  position: absolute; border-radius: 2px;
  pointer-events: none; z-index: 46; opacity: 0;
  animation: energyFlow 0.5s ease-out forwards;
}
@keyframes energyFlow {
  0%   { opacity:0.9; transform:scaleX(0); transform-origin: center; }
  100% { opacity:0; transform:scaleX(1); }
}

/* 残影拖尾 */
.afterimage {
  position: absolute; pointer-events: none; z-index: 35;
  opacity: 0.4; animation: afterimageFade 0.3s ease-out forwards;
}
@keyframes afterimageFade {
  0%   { opacity:0.5; transform:translateX(0) scale(1); }
  100% { opacity:0; transform:translateX(30px) scale(0.5); filter:blur(4px); }
}

/* Boss被击爆震特效 */
.boss-hit-quake {
  animation: bossQuake 0.3s ease-out;
}
@keyframes bossQuake {
  0%   { transform:translate(0,0); }
  15%  { transform:translate(-3px,3px); }
  30%  { transform:translate(3px,-2px); }
  45%  { transform:translate(-2px,-3px); }
  60%  { transform:translate(2px,2px); }
  75%  { transform:translate(-1px,-1px); }
  100% { transform:translate(0,0); }
}

/* ===== Dungeon & Fighter 风格技能动画增强 ===== */

/* 剑魂 - 极·拔刀斩：横向剑气劈裂空间 */
@keyframes swordSlashEnhanced {
  0%   { opacity:0; width:0; }
  8%   { opacity:1; width:160px; background:linear-gradient(90deg,transparent,rgba(180,220,255,0.3) 20%,rgba(220,240,255,1) 50%,rgba(255,255,255,1) 70%,rgba(180,220,255,0.3) 100%); }
  40%  { opacity:1; width:200px; background:linear-gradient(90deg,transparent,rgba(220,240,255,0.6) 20%,rgba(255,255,255,1) 50%,rgba(220,240,255,0.6) 80%,transparent); }
  80%  { opacity:0.5; width:240px; transform:translateX(10px) scaleY(2.5); }
  100% { opacity:0; width:280px; transform:translateX(20px) scaleY(3); }
}

/* 狂战士 - 血腥崩山击：巨大血爆从天而降 */
@keyframes berserkCrashEnhanced {
  0%   { opacity:0; transform:translateY(-100px) scale(0.2); }
  20%  { opacity:1; transform:translateY(0) scale(0.8); background:radial-gradient(circle,rgba(255,40,15,1) 0%,rgba(180,10,0,0.8) 30%,rgba(255,80,20,0.4) 60%,transparent 100%); }
  50%  { opacity:1; transform:translateY(10px) scale(1.6); box-shadow:0 0 60px rgba(255,20,0,0.9), 0 0 120px rgba(200,10,0,0.5); }
  100% { opacity:0; transform:translateY(30px) scale(2.5); }
}

/* 鬼泣 - 鬼神七闪：七道暗影斩击交错切割 */
@keyframes ghostSevenSlash {
  0%   { opacity:0; transform:rotate(-60deg) scale(0.3); }
  15%  { opacity:0.9; transform:rotate(-35deg) scale(1); }
  40%  { opacity:1; transform:rotate(-10deg) scale(1.5); box-shadow:0 0 30px rgba(150,40,220,0.8); }
  70%  { opacity:0.5; transform:rotate(5deg) scale(1.8); }
  100% { opacity:0; transform:rotate(20deg) scale(2.2); }
}

/* 阿修罗 - 波动眼·开眼：波动光轮扩散 */
@keyframes asuraWaveEnhanced {
  0%   { opacity:0; transform:scaleX(0.1) scaleY(0.3); box-shadow:0 0 20px rgba(255,140,30,0.8); }
  20%  { opacity:1; transform:scaleX(1.5) scaleY(0.5); background:linear-gradient(0deg,rgba(255,200,60,1),rgba(255,120,20,0.9),rgba(200,40,0,0.5),transparent); }
  50%  { opacity:0.9; transform:scaleX(3) scaleY(1.2); box-shadow:0 -15px 50px rgba(255,150,30,0.9), 0 -5px 30px rgba(255,200,80,0.5); }
  100% { opacity:0; transform:scaleX(6) scaleY(3) translateX(30px); }
}

/* 漫游 - 舞动枪花：弹幕散射+弹壳螺旋 */
@keyframes rangerScatterEnhanced {
  0%   { opacity:0; transform:translate(0,0) scale(0.3) rotate(0deg); }
  10%  { opacity:1; transform:translate(15px,-10px) scale(1.2) rotate(30deg); box-shadow:0 0 12px #ffd700, 0 0 25px #ff8800, 0 0 45px rgba(255,140,0,0.5); }
  35%  { opacity:1; transform:translate(60px,15px) scale(0.9) rotate(-15deg); }
  60%  { opacity:0.7; transform:translate(120px,-12px) scale(0.7) rotate(25deg); }
  85%  { opacity:0.3; transform:translate(180px,8px) scale(0.5) rotate(-10deg); }
  100% { opacity:0; transform:translate(220px,-5px) scale(0.3) rotate(45deg); }
}

/* 枪炮师 - 量子爆弹：超级粗光束+后坐力震屏 */
@keyframes launcherBeamEnhanced {
  0%   { opacity:0; width:0; }
  5%   { opacity:1; width:220px; background:linear-gradient(90deg,rgba(255,200,50,0.2),rgba(255,150,20,0.7) 10%,rgba(255,100,10,1) 30%,rgba(255,255,255,1) 50%,rgba(255,120,10,0.8) 70%,transparent); }
  30%  { opacity:1; width:260px; box-shadow:0 0 60px rgba(255,150,20,1), 0 0 150px rgba(255,80,0,0.6), -20px 0 60px rgba(255,200,50,0.4); }
  100% { opacity:0; width:300px; }
}

/* 圣骑士 - 天启之珠：神圣光柱从上方轰下 */
@keyframes holyDescendEnhanced {
  0%   { opacity:0; height:8px; transform:translateX(-50%) translateY(-20px); }
  10%  { opacity:1; height:60px; transform:translateX(-50%) translateY(10%); background:linear-gradient(180deg,rgba(255,255,255,1),rgba(255,240,180,1) 20%,rgba(255,215,0,0.8) 60%,rgba(255,200,100,0.3) 80%,transparent); }
  30%  { opacity:1; height:90px; transform:translateX(-50%) translateY(40%); box-shadow:0 0 40px rgba(255,255,200,0.9), 0 0 120px rgba(255,240,150,0.5), 0 -30px 80px rgba(255,255,255,0.3); }
  70%  { opacity:0.6; height:110px; transform:translateX(-50%) translateY(70%); }
  100% { opacity:0; height:130px; transform:translateX(-50%) translateY(90%); }
}

/* 混沌 - 混沌破晓拳：紫焰爆破+多层冲击波 */
@keyframes monkBurstEnhanced {
  0%   { opacity:0; transform:translate(0,0) scale(0.05); }
  15%  { opacity:1; transform:translate(20px,-5px) scale(0.7); background:radial-gradient(circle,rgba(220,120,255,1) 0%,rgba(150,40,220,0.8) 30%,rgba(80,20,140,0.4) 60%,transparent 100%); }
  40%  { opacity:1; transform:translate(70px,0) scale(1.6); box-shadow:0 0 60px rgba(200,100,255,0.9), 0 0 140px rgba(130,40,210,0.5); }
  80%  { opacity:0.5; transform:translate(140px,5px) scale(2.5); }
  100% { opacity:0; transform:translate(200px,10px) scale(4); }
}

/* 暴击特效增强 */
.crit-flash-overlay {
  position: fixed; top:0; left:0; width:100vw; height:100vh;
  pointer-events: none; z-index: 9998; opacity: 0;
  animation: critFlash 0.5s ease-out forwards;
}
@keyframes critFlash {
  0%   { opacity:0; }
  8%   { opacity:1; background:rgba(255,255,255,0.7); }
  25%  { opacity:0.4; background:rgba(255,220,100,0.3); }
  100% { opacity:0; background:transparent; }
}

/* 技能连击计数器弹出 */
.combo-counter {
  position: absolute; top: 5%; right: 10%;
  font-size: 22px; font-weight: 900; color: #ffd700;
  text-shadow: 0 0 15px rgba(255,200,0,0.8), 0 0 30px rgba(255,150,0,0.5);
  pointer-events: none; z-index: 61; opacity: 0;
  animation: comboPop 0.6s ease-out forwards;
}
@keyframes comboPop {
  0%   { opacity:0; transform:scale(0.5) translateY(10px); }
  20%  { opacity:1; transform:scale(1.4) translateY(0); }
  50%  { opacity:0.9; transform:scale(1) translateY(-5px); }
  100% { opacity:0; transform:scale(0.8) translateY(-20px); }
}

/* ===== Scrollbar ===== */
.main::-webkit-scrollbar { width: 5px; }
.main::-webkit-scrollbar-track { background: transparent; }
.main::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
.main::-webkit-scrollbar-thumb:hover { background: var(--border2); }

/* Toast */
.toast {
  position:fixed; top:12px; left:50%; transform:translateX(-50%);
  background:var(--panel); border:1px solid var(--gold);
  padding:6px 16px; border-radius:4px; font-size:12px; color:var(--gold);
  z-index:999; pointer-events:none; opacity:0; transition:opacity 0.3s;
  max-width:80%;
}
.toast.show { opacity:1; }

/* Class Select Grid */
.class-grid { display:flex; flex-direction:column; gap:6px; }
.class-card {
  background:var(--panel); border:1px solid var(--border);
  border-radius:5px; padding:10px 12px;
  cursor:pointer; font-family:inherit;
  text-align:left; width:100%;
  transition:border-color 0.15s;
}
.class-card:active { border-color:var(--gold); }
.class-card:hover { border-color: rgba(255,255,255,0.2); background: var(--panel2); }
.class-card.faction-ghost { border-left:3px solid var(--purple); }
.class-card.faction-gunner { border-left:3px solid var(--orange); }
.class-card.faction-knight { border-left:3px solid var(--gold); }
.class-name { font-size:14px; font-weight:700; color:#e0d8c8; }
.class-weapon { font-size:10px; color:var(--dim); margin-left:6px; }
.class-desc { font-size:11px; color:var(--dim); margin-top:3px; line-height:1.5; }
.class-skill-hint { font-size:10px; color:var(--blue); margin-top:4px; }
.faction-label {
  font-size:9px; color:var(--dim); letter-spacing:2px;
  margin:8px 0 4px; padding-left:2px;
}

/* EXP bar */
.exp-bar-wrap { margin:6px 0 2px; }
.exp-bar { height:3px; background:#333; border-radius:2px; overflow:hidden; }
.exp-fill { height:100%; background:var(--blue); transition:width 0.4s; }
.exp-label { font-size:9px; color:var(--dim); text-align:right; margin-top:2px; }

/* Save indicator */
.save-indicator {
  font-size:9px; color:var(--green); text-align:center;
  padding:4px; opacity:0; transition:opacity 0.3s;
}
.save-indicator.show { opacity:1; }

/* ===== LOBBY STYLES ===== */
.lobby-container { padding:6px 0; }
.lobby-title {
  text-align:center; font-size:20px; color:var(--gold); font-weight:700;
  letter-spacing:4px; margin-bottom:12px;
  text-shadow: 0 0 10px rgba(201,164,75,0.3);
}
.char-card {
  background:var(--panel); border:1px solid var(--border);
  border-radius:8px; padding:12px 14px; margin-bottom:10px;
  position: relative;
}
.char-card::before {
  content: ''; position: absolute;
  left: 0; top: 10%; height: 80%; width: 3px;
  border-radius: 0 3px 3px 0;
  background: var(--border);
}
.char-card.faction-ghost::before  { background: linear-gradient(180deg, var(--purple), rgba(176,124,216,0.2)); }
.char-card.faction-gunner::before { background: linear-gradient(180deg, var(--orange), rgba(230,126,34,0.2)); }
.char-card.faction-knight::before { background: linear-gradient(180deg, var(--gold), rgba(201,164,75,0.2)); }
.char-card-header {
  display:flex; align-items:center; gap:10px; margin-bottom:8px;
}
.char-portrait {
  width:48px; height:48px; border-radius:4px; border:1px solid var(--border2);
  object-fit:cover; background:var(--bg);
  box-shadow:0 0 8px rgba(0,0,0,0.5);
}
.char-info-name { font-size:15px; font-weight:700; color:#e0d8c8; }
.char-info-sub { font-size:10px; color:var(--dim); margin-top:2px; }
.hpmp-bars { margin:6px 0; }
.bar-row { display:flex; align-items:center; gap:6px; margin:3px 0; font-size:10px; }
.bar-label { width:28px; color:var(--dim); flex-shrink:0; }
.bar-track { flex:1; height:8px; background:#222; border-radius:4px; overflow:hidden; }
.bar-fill-hp { height:100%; background:linear-gradient(90deg,#8b2020,#c0392b); border-radius:4px; transition:width 0.4s; }
.bar-fill-mp { height:100%; background:linear-gradient(90deg,#1a4a8a,#5a9fd4); border-radius:4px; transition:width 0.4s; }
.bar-fill-exp { height:100%; background:linear-gradient(90deg,#2a6a3a,#4a8); border-radius:4px; transition:width 0.4s; }
.bar-text { width:50px; text-align:right; color:var(--dim); font-size:9px; flex-shrink:0; }
.char-stats {
  display:flex; flex-wrap:wrap; gap:8px; font-size:11px; margin-top:6px;
  padding-top:6px; border-top:1px solid var(--border);
}
.char-stat { display:flex; align-items:center; gap:3px; }
.char-stat-val { color:var(--gold); font-weight:600; }

/* Progress */
.lobby-progress {
  background:var(--panel); border:1px solid var(--border);
  border-radius:8px; padding:10px 14px; margin-bottom:10px;
  font-size:11px;
}
.progress-title { color:var(--dim); font-size:10px; margin-bottom:4px; letter-spacing:1px; }
.progress-region {
  display:flex; align-items:center; gap:6px; margin:3px 0;
}
.progress-dot {
  width:8px; height:8px; border-radius:50%; background:var(--border);
  flex-shrink:0;
}
.progress-dot.done { background:var(--green); }
.progress-dot.active { background:var(--gold); box-shadow:0 0 4px rgba(201,164,75,0.5); }
.progress-name { color:var(--text); font-size:11px; }
.progress-status { color:var(--dim); font-size:10px; margin-left:auto; }

/* Region Portals */
.region-portals { display:flex; flex-direction:column; gap:8px; margin-bottom:10px; }
.region-portal {
  background:var(--panel); border:1px solid var(--border);
  border-radius:6px; padding:10px 14px; cursor:pointer;
  font-family:inherit; text-align:left; transition:all 0.15s;
  position:relative; overflow:hidden;
}
.region-portal:hover { border-color: rgba(255,255,255,0.15); }
.region-portal:active { border-color:var(--gold); transform:scale(0.98); }
.region-portal.locked { opacity:0.4; pointer-events:none; }
.region-portal .rp-name { font-size:13px; color:#e0d8c8; font-weight:600; }
.region-portal .rp-lv { font-size:10px; color:var(--dim); margin-left:6px; }
.region-portal .rp-desc { font-size:10px; color:var(--dim); margin-top:3px; }
.region-portal .rp-lock { font-size:10px; color:var(--red); margin-top:3px; }
.rp-icon { font-size:16px; margin-right:6px; }

/* Lobby Bottom Buttons */
.lobby-bottom {
  display:flex; gap:8px; margin-top:10px;
}
.lobby-btn {
  flex:1; padding:10px 4px; border-radius:4px; font-size:12px;
  cursor:pointer; font-family:inherit; text-align:center;
  border:1px solid var(--border); background:var(--panel); color:var(--text);
  letter-spacing:0.5px;
  transition: border-color 0.15s, background 0.15s, transform 0.1s;
}
.lobby-btn:hover { border-color: rgba(255,255,255,0.2); background: var(--panel2); }
.lobby-btn:active { border-color:var(--gold); background:var(--panel2); transform: scale(0.96); }
.lobby-btn.primary {
  background:rgba(201,164,75,0.12); border-color:rgba(201,164,75,0.3);
  color:var(--gold); font-size:14px; font-weight:600;
}

/* ===== INVENTORY UI (DNF 60 Style) ===== */
.inv-overlay {
  background:var(--panel); border:1px solid var(--border);
  border-radius:8px; padding:12px; margin-bottom:10px;
}
.inv-header {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:10px; padding-bottom:8px; border-bottom:1px solid var(--border);
}
.inv-header-title { font-size:14px; color:var(--gold); font-weight:700; letter-spacing:1px; }
.inv-close {
  font-size:16px; color:var(--dim); cursor:pointer; padding:2px 8px;
  border:1px solid var(--border); border-radius:3px; background:var(--panel2);
  font-family:inherit; transition: border-color 0.15s, color 0.15s;
}
.inv-close:hover { border-color: var(--gold); color: var(--text); }
.inv-close:active { border-color:var(--gold); }
.inv-layout { display:flex; gap:10px; }
/* Paperdoll - Inset/Recessed Slots */
.paperdoll {
  width:140px; flex-shrink:0;
  display:grid;
  grid-template-columns: 40px 40px 40px;
  grid-template-rows: 40px 40px 40px 40px 40px 40px;
  gap:4px; align-content:start;
}
.equip-slot {
  width:40px; height:40px; border:1px solid var(--border);
  border-radius:4px;
  /* Recessed look: dark bg + inset shadow */
  background:#0a0a10;
  box-shadow:inset 0 1px 3px rgba(0,0,0,0.6), inset 0 0 8px rgba(0,0,0,0.3);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  cursor:pointer; font-size:9px; color:var(--dim);
  position:relative; transition:border-color 0.2s, box-shadow 0.2s, background 0.2s;
  padding:2px;
}
.equip-slot:empty-icon { background:transparent; }
.equip-slot:active { border-color:var(--gold); }
.equip-slot.has-item {
  border-color:var(--border2);
  /* When equipped: raised/glowing look */
  box-shadow:inset 0 1px 2px rgba(255,255,255,0.03), 0 0 6px rgba(255,255,255,0.04);
  background:var(--panel2);
}
.equip-slot .slot-icon { font-size:16px; line-height:1; margin-bottom:1px; filter:grayscale(0.3); }
.equip-slot .slot-label { font-size:7px; text-align:center; line-height:1.1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:36px; color:#444; }
.equip-slot .equipped-item {
  position:absolute; top:0; left:0; right:0; bottom:0;
  border-radius:3px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; font-size:9px;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  padding:2px; text-align:center; line-height:1.2;
  /* Glow effect on equipped items */
  text-shadow:0 0 8px currentColor;
  transition:box-shadow 0.2s;
}
.equip-slot .equipped-item .equip-icon { font-size:18px; line-height:1;}
.equip-slot .equipped-item .equip-label { font-size:7px; margin-top:1px; opacity:0.9; }
/* Grid Inventory - Recessed Slots */
.inv-grid-panel { flex:1; min-width:0; }
.inv-grid-scroll { max-height:420px; overflow-y:auto; border:1px solid var(--border); border-radius:6px; padding:4px; }
.inv-grid-scroll::-webkit-scrollbar { width:4px; }
.inv-grid-scroll::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }
.inv-grid {
  display:grid; grid-template-columns:repeat(5,1fr); gap:4px;
}
.inv-slot {
  aspect-ratio:1; border:1px solid var(--border);
  border-radius:4px;
  /* Recessed look */
  background:#0a0a10;
  box-shadow:inset 0 1px 3px rgba(0,0,0,0.6), inset 0 0 8px rgba(0,0,0,0.3);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  cursor:pointer; font-size:12px; color:var(--dim);
  padding:2px; text-align:center; overflow:hidden; position:relative;
  transition:border-color 0.15s, box-shadow 0.2s, background 0.2s; min-height:40px;
}
.inv-slot:active { border-color:var(--gold); }
.inv-slot.has-item {
  border-color:var(--border2);
  box-shadow: inset 0 1px 2px rgba(255,255,255,0.03), 0 0 4px rgba(255,255,255,0.03);
  background:var(--panel2);
}
.inv-slot .inv-icon { font-size:18px; line-height:1; }
.inv-slot .item-name {
  font-size:8px; line-height:1.2; margin-top:2px;
}

/* Inventory Portrait & Stats Row */
.inv-portrait-section {
  display:flex; align-items:center; gap:12px;
  padding:10px; background:var(--panel); border:1px solid var(--border);
  border-radius:6px; margin-bottom:10px;
}
.inv-portrait {
  width:72px; height:72px; border-radius:4px; object-fit:contain;
  border:1px solid var(--border2); background:var(--bg);
  flex-shrink:0;
}
.inv-portrait-info { flex:1; font-size:11px; display:flex; flex-wrap:wrap; gap:3px 10px; }
.inv-portrait-name { font-size:14px; font-weight:700; color:#e0d8c8; width:100%; margin-bottom:2px; }
.inv-portrait-stat { display:flex; gap:3px; align-items:center; }
.inv-portrait-stat-val { color:var(--gold); font-weight:600; font-size:11px; }
.inv-portrait-stat-bonus { color:var(--green); font-size:9px; }
.inv-stats {
  margin-top:10px; padding-top:8px; border-top:1px solid var(--border);
  font-size:10px; color:var(--dim);
}
.inv-stats-row { display:flex; flex-wrap:wrap; gap:10px; }
.inv-stat { display:flex; gap:3px; }
.inv-stat-val { color:var(--gold); font-weight:600; }

/* ===== Equipment Detail Modal ===== */
.equip-detail-overlay {
  position:fixed; top:0; left:0; right:0; bottom:0; z-index:100;
  background:rgba(0,0,0,0.7); display:flex; align-items:center; justify-content:center;
  animation:overlayFadeIn 0.2s ease;
}
@keyframes overlayFadeIn { from{opacity:0} to{opacity:1} }
.equip-detail-card {
  width:90%; max-width:360px; border-radius:10px; overflow:hidden;
  border:2px solid #333; box-shadow:0 8px 40px rgba(0,0,0,0.5);
  animation:cardSlideUp 0.3s ease;
  background:linear-gradient(180deg, #1a1a24 0%, #0d0d12 100%);
}
@keyframes cardSlideUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
.equip-detail-header {
  padding:14px 16px 10px; text-align:center; position:relative;
}
.equip-detail-icon { margin-bottom:4px; }
.equip-detail-icon .eq-icon-wrap { width:48px; height:48px; border-radius:6px; margin:0 auto; }
.equip-detail-icon .eq-icon-inner { font-size:28px; }
.equip-detail-icon .eq-tier-gem { font-size:14px; top:-6px; right:-6px; }
.equip-detail-name { font-size:18px; font-weight:700; letter-spacing:1px; }
.equip-detail-tier { font-size:11px; letter-spacing:3px; margin-top:2px; }
.equip-detail-body { padding:12px 16px; }
.equip-detail-stats { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.equip-detail-stat {
  flex:1; min-width:50px; text-align:center; padding:6px 4px;
  background:rgba(0,0,0,0.4); border-radius:6px; border:1px solid rgba(255,255,255,0.05);
}
.equip-detail-stat-label { font-size:9px; color:var(--dim); }
.equip-detail-stat-val { font-size:15px; font-weight:700; color:var(--gold); margin-top:2px; }
.equip-detail-effect {
  padding:10px 14px; margin-bottom:12px; border-radius:6px;
  font-size:12px; line-height:1.6; border:1px solid rgba(255,255,255,0.08);
  background:rgba(0,0,0,0.3);
}
.equip-detail-effect .eff-label { font-size:10px; color:var(--dim); margin-bottom:4px; letter-spacing:2px; }
.equip-detail-quote {
  padding:10px 14px; border-radius:6px; text-align:center;
  font-size:12px; font-style:italic; color:var(--dim); line-height:1.6;
  border-top:1px solid rgba(255,255,255,0.05); margin-bottom:8px;
}
.equip-detail-quote::before { content:'「'; font-size:18px; color:var(--gold); margin-right:2px; }
.equip-detail-quote::after { content:'」'; font-size:18px; color:var(--gold); margin-left:2px; }
.equip-detail-btns { display:flex; gap:8px; padding:0 16px 14px; }
.equip-detail-btn {
  flex:1; padding:10px; border-radius:6px; text-align:center;
  font-size:13px; cursor:pointer; font-family:inherit; letter-spacing:1px;
  border:1px solid var(--border); background:var(--panel); color:var(--text);
}
.equip-detail-btn.primary { border-color:var(--gold); color:var(--gold); }
.equip-detail-btn.danger { border-color:var(--red); color:var(--red); opacity:0.6; }
.equip-detail-close { position:absolute; top:8px; right:12px; font-size:18px; color:var(--dim); cursor:pointer; padding:4px 8px; }
/* Rare+ equipment glow */
.equip-slot.glow-rare { box-shadow:0 0 10px rgba(90,175,255,0.4); }
.equip-slot.glow-unique { box-shadow:0 0 14px rgba(176,124,216,0.5),0 0 28px rgba(176,124,216,0.2); animation:rarePulse 2s ease-in-out infinite; }
.equip-slot.glow-epic { box-shadow:0 0 18px rgba(248,136,0,0.6),0 0 36px rgba(248,136,0,0.3); animation:rarePulse 1.5s ease-in-out infinite; }
@keyframes rarePulse { 0%,100%{box-shadow:0 0 10px currentColor} 50%{box-shadow:0 0 22px currentColor} }
.inv-stat-bonus { color:var(--green); font-size:9px; }

/* Item color helpers */
.tier-common { color:var(--tier-common); }
.tier-fine { color:var(--tier-fine); }
.tier-rare { color:var(--tier-rare); }
.tier-unique { color:var(--tier-unique); }
.tier-epic { color:var(--tier-epic); }

/* Drop notification */
.drop-notify {
  position:fixed; bottom:60px; left:50%; transform:translateX(-50%);
  background:rgba(0,0,0,0.85); border:1px solid var(--gold);
  padding:8px 18px; border-radius:6px; font-size:13px;
  z-index:999; pointer-events:none; opacity:0; transition:opacity 0.3s;
  text-align:center; max-width:80%;
}
.drop-notify.show { opacity:1; }
.drop-notify .drop-item-name { font-weight:700; }

/* Region Hub */
.region-hub { padding:4px 0; }
.region-hub-title {
  text-align:center; font-size:18px; color:var(--gold); font-weight:700;
  letter-spacing:2px; margin-bottom:6px;
  text-shadow: 0 0 8px rgba(201,164,75,0.2);
}
.region-hub-desc { text-align:center; font-size:12px; color:var(--dim); margin-bottom:14px; line-height:1.6; }
.region-hub-section { margin-bottom:14px; }
.region-hub-section-title {
  font-size:11px; color:var(--dim); letter-spacing:2px; margin-bottom:8px;
  padding-bottom:4px; border-bottom:1px solid var(--border);
}
.npc-list { display:flex; flex-direction:column; gap:6px; }
.npc-card {
  background:var(--panel); border:1px solid var(--border);
  border-radius:6px; padding:10px 12px; cursor:pointer;
  display:flex; align-items:center; gap:10px;
  transition:border-color 0.15s, transform 0.1s;
  position: relative; overflow: hidden;
}
.npc-card-avatar { width:56px;height:56px;border-radius:8px;object-fit:cover;margin-bottom:4px;border:1px solid var(--border); }
.npc-card::before {
  content: ''; position: absolute;
  left: 0; top: 20%; height: 60%; width: 3px;
  border-radius: 0 2px 2px 0;
  background: linear-gradient(180deg, var(--gold), rgba(201,164,75,0.2));
  transition: height 0.2s, top 0.2s;
}
.npc-card:hover::before { top: 10%; height: 80%; }
.npc-card:hover { border-color: rgba(201,164,75,0.3); }
.npc-card:active { border-color:var(--gold); transform: scale(0.98); }
.npc-icon { font-size:24px; flex-shrink:0; width:36px; text-align:center; }
.npc-info { flex:1; min-width:0; }
.npc-name { font-size:13px; color:#e0d8c8; font-weight:600; }
.npc-line { font-size:11px; color:var(--dim); margin-top:2px; font-style:italic; }
.npc-gift-toast {
  position:fixed; top:40%; left:50%; transform:translate(-50%,-50%);
  background:var(--panel); border:1px solid var(--gold);
  padding:12px 20px; border-radius:8px; font-size:13px; color:var(--gold);
  z-index:999; pointer-events:none; opacity:0; transition:opacity 0.3s;
  text-align:center; max-width:80%;
}
.npc-gift-toast.show { opacity:1; }

/* Dungeon Select */
.dungeon-list { display:flex; flex-direction:column; gap:8px; }
.dungeon-card {
  background:var(--panel); border:1px solid var(--border);
  border-radius:6px; padding:10px 14px;
  transition:border-color 0.15s, transform 0.1s;
  position: relative; overflow: hidden;
}
.dungeon-card::before {
  content: ''; position: absolute;
  left: 0; top: 15%; height: 70%; width: 3px;
  border-radius: 0 2px 2px 0;
  background: linear-gradient(180deg, var(--red), rgba(192,57,43,0.15));
}
.dungeon-card:hover { border-color: rgba(255,255,255,0.15); }
.dungeon-card:hover::before { top: 8%; height: 84%; }
.dungeon-card.locked { opacity:0.45; }
.dungeon-card.locked::before { background: linear-gradient(180deg, var(--dim), transparent); }
.dungeon-card-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:4px;
}
.dungeon-name { font-size:13px; color:#e0d8c8; font-weight:600; }
.dungeon-lv { font-size:10px; color:var(--dim); }
.dungeon-lock { font-size:10px; color:var(--red); }
.dungeon-status { font-size:9px; margin-top:3px; }
.dungeon-btns { display:flex; gap:6px; margin-top:6px; }
.dungeon-btn {
  flex:1; padding:8px 6px; border-radius:4px; font-size:11px;
  cursor:pointer; font-family:inherit; text-align:center;
  border:1px solid var(--border); background:var(--panel2); color:var(--text);
  letter-spacing:0.5px; transition: border-color 0.15s, background 0.15s;
}
.dungeon-btn:hover { border-color: rgba(255,255,255,0.2); }
.dungeon-btn:active { border-color:var(--gold); }
.dungeon-btn.hell { border-color:rgba(192,57,43,0.4); color:var(--red); }
.dungeon-btn.hell:hover { border-color: rgba(192,57,43,0.7); background: rgba(192,57,43,0.05); }
.dungeon-btn.hell:active { border-color:var(--red); }
.dungeon-btn.done { border-color:var(--green); color:var(--green); opacity:0.7; }
.dungeon-diff-info { font-size:10px; color:var(--dim); margin-top:4px; text-align:center; }

/* Dungeon Room Progress System */
.dungeon-progress {
  display:flex; gap:4px; justify-content:center;
  margin-bottom:10px; padding:8px;
  background:var(--panel); border-radius:8px;
  border:1px solid var(--border);
}
.dungeon-room-badge {
  display:flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:20px;
  font-size:10px; color:var(--dim);
  background:var(--panel2); border:1px solid var(--border);
}
.dungeon-room-badge.active {
  border-color:var(--gold); color:var(--gold);
  background:rgba(201,164,75,0.08);
}
.dungeon-room-badge.cleared {
  border-color:var(--green); color:var(--green);
  background:rgba(68,170,136,0.08);
}
.dungeon-modifier-badge {
  padding:4px 10px; border-radius:12px; font-size:10px;
  border:1px solid var(--purple); color:var(--purple);
  display:inline-block; margin-bottom:6px;
}

/* Skip region hub */
.skip-hub-btn {
  width:100%; padding:8px; background:transparent;
  border:1px dashed var(--border); border-radius:4px;
  color:var(--dim); font-size:11px; cursor:pointer;
  font-family:inherit; letter-spacing:1px; margin-top:8px;
  transition: border-color 0.15s, color 0.15s;
}
.skip-hub-btn:hover { border-color: rgba(201,164,75,0.4); color: var(--gold); }
.skip-hub-btn:active { border-color:var(--gold); color:var(--gold); }

/* Epilogue skip hover */
.epilogue-skip:hover { color: var(--gold); }

/* Passive skill display */
.skill-info { font-size:11px; color: var(--dim); margin:2px 0; }

/* ===== Auth & Character UI ===== */
.auth-container {
  display:flex; align-items:center; justify-content:center;
  min-height:calc(100vh - 120px); padding:20px;
}
.auth-card {
  background: linear-gradient(180deg, rgba(20,20,30,0.97) 0%, rgba(12,12,20,0.98) 100%);
  border: 1px solid rgba(201,164,75,0.15);
  border-radius:12px; padding:32px 28px; width:100%; max-width:380px;
  box-shadow: 0 0 60px rgba(201,164,75,0.04);
  position: relative; overflow: hidden;
}
.auth-card::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0.4;
}
.auth-input {
  width:100%; padding:12px 14px; margin-bottom:12px;
  background:var(--panel2); border:1px solid var(--border);
  border-radius:8px; color:var(--text); font-size:14px;
  font-family:inherit; outline:none; box-sizing:border-box;
  transition:border-color 0.2s, box-shadow 0.2s;
}
.auth-input:focus { border-color:var(--gold); box-shadow: 0 0 12px rgba(201,164,75,0.1); }
.auth-btn {
  width:100%; padding:13px; background: linear-gradient(180deg, #dab44b 0%, #c9a44b 50%, #a88830 100%);
  color:#111; border:none; border-radius:8px; font-size:15px;
  font-weight:700; cursor:pointer; font-family:inherit;
  letter-spacing:2px; transition:background 0.2s, transform 0.1s;
  box-shadow: 0 2px 12px rgba(201,164,75,0.2);
}
.auth-btn:hover { background: linear-gradient(180deg, #e8c058 0%, #dab44b 50%, #b89838 100%); }
.auth-btn:active { transform: scale(0.97); }
.auth-switch-btn {
  background:none; border:none; color:var(--dim); cursor:pointer;
  font-size:12px; font-family:inherit; transition: color 0.2s;
}
.auth-switch-btn:hover { color:var(--gold); }

.char-list { display:flex; flex-direction:column; gap:8px; }
.char-list-item {
  display:flex; align-items:center; gap:12px;
  padding:12px 14px; background:var(--panel2); border:1px solid var(--border);
  border-radius:8px; cursor:pointer; transition:border-color 0.2s;
}
.char-list-item:hover { border-color:var(--gold); }
.char-del-btn {
  background:none; border:none; color:var(--red); font-size:14px;
  cursor:pointer; padding:4px 8px; opacity:0.5;
}
.char-del-btn:hover { opacity:1; }

.class-select-grid {
  display:grid; grid-template-columns:repeat(4, 1fr); gap:8px;
}
.class-select-item {
  padding:12px 6px; background:var(--panel2); border:1px solid var(--border);
  border-radius:8px; text-align:center; cursor:pointer; font-size:12px;
  transition:all 0.15s;
}
.class-select-item:hover { border-color:var(--gold); }

/* Weapon mismatch indicators */
.weapon-mismatch .equipped-item { border-color: var(--red) !important; }
.weapon-mismatch-grid { border-color: rgba(192,57,43,0.3) !important; }

/* BGM button */
#bgmBtn { transition: transform 0.15s; }
#bgmBtn:hover { transform: scale(1.2); }

/* ===== Equipment Icon Tiers ===== */
.eq-icon-wrap {
  display:inline-flex; align-items:center; justify-content:center;
  width:26px; height:26px; border-radius:4px; position:relative;
  flex-shrink:0;
}
.eq-icon-inner { font-size:14px; line-height:1; }
.eq-tier-common { background:#1a1a20; border:1px solid #333; }
.eq-tier-fine   { background:#152216; border:1px solid #5a8; }
.eq-tier-rare   { background:#161626; border:1px solid #49f; box-shadow:0 0 3px rgba(68,153,255,0.25); }
.eq-tier-unique { background:#221622; border:1px solid #c4f; box-shadow:0 0 5px rgba(204,68,255,0.35); }
.eq-tier-epic   { background:#262210; border:1px solid #fa0; box-shadow:0 0 6px rgba(255,170,0,0.4); }

.eq-icon-svg { width:50px; height:50px; padding:2px; }
.eq-svg-art { width:44px; height:44px; overflow:hidden; border-radius:4px; }
.eq-svg-art svg { width:100%; height:100%; display:block; }
.eq-epic-png { width:44px; height:44px; object-fit:contain; display:block; }
.equip-detail-icon .eq-epic-png { width:72px; height:72px; }
.equip-detail-icon .eq-icon-svg { width:80px; height:80px; padding:3px; }
.equip-detail-icon .eq-svg-art { width:72px; height:72px; }
.shop-epic-icon { width:56px; height:56px; padding:3px; background:#262210; border:2px solid #fa0; border-radius:6px; box-shadow:0 0 10px rgba(255,170,0,0.5),0 0 20px rgba(255,170,0,0.2); animation:epicShopGlow 2s ease-in-out infinite; }
.shop-epic-icon svg { width:100%; height:100%; display:block; }
@keyframes epicShopGlow { 0%,100% { box-shadow:0 0 10px rgba(255,170,0,0.5),0 0 20px rgba(255,170,0,0.2); } 50% { box-shadow:0 0 16px rgba(255,170,0,0.7),0 0 32px rgba(255,170,0,0.3); } }
.eq-tier-gem {
  position:absolute; top:-5px; right:-5px; font-size:9px;
  line-height:1; filter:drop-shadow(0 0 2px currentColor);
  animation: gemPulse 2s ease-in-out infinite;
}
@keyframes gemPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.25); }
}

/* Compact icon for equipped slots */
.equipped-item .eq-icon-wrap { width:22px; height:22px; }
.equipped-item .eq-icon-inner { font-size:12px; }
.equipped-item .eq-tier-gem { font-size:7px; top:-4px; right:-4px; }

/* Compact icon for inventory grid */
.inv-slot .eq-icon-wrap { width:20px; height:20px; border-radius:3px; }
.inv-slot .eq-icon-inner { font-size:11px; }
.inv-slot .eq-tier-gem { font-size:6px; top:-3px; right:-3px; }
.inv-qty {
  position:absolute; bottom:1px; left:2px; background:rgba(0,0,0,0.7);
  color:var(--gold); font-size:9px; font-weight:700; padding:0 3px; border-radius:2px;
  line-height:1.3;
}
.inv-sort-btn {
  font-size:10px; padding:2px 8px; background:var(--panel); border:1px solid var(--border);
  color:var(--dim); border-radius:4px; cursor:pointer; font-family:inherit;
}
.inv-sort-btn:hover { border-color:var(--gold); color:var(--gold); }

/* ===== NPC & Shop ===== */
.npc-section { margin:12px 0; }
.npc-row { display:flex; gap:8px; flex-wrap:wrap; }
.npc-card {
  flex:1; min-width:90px; max-width:120px; padding:12px 8px;
  background:var(--panel2); border:1px solid var(--border); border-radius:8px;
  text-align:center; cursor:pointer; transition:all 0.15s;
}
.npc-card:hover { border-color:var(--gold); background:#1a1a14; }
.npc-emoji { font-size:28px; margin-bottom:4px; }
.npc-name { color:var(--gold); font-size:12px; font-weight:600; }
.npc-title { color:var(--dim); font-size:10px; }

/* ===== Wandering Merchant ===== */
.merchant-card {
  border: 2px solid rgba(201,164,75,0.4) !important;
  border-radius: 10px !important;
  background: linear-gradient(180deg, rgba(30,25,10,0.97) 0%, rgba(20,15,5,0.98) 100%) !important;
  box-shadow: 0 0 30px rgba(201,164,75,0.08), inset 0 0 40px rgba(20,15,0,0.2);
  animation: merchantAppear 0.4s ease;
}
@keyframes merchantAppear {
  0% { opacity: 0; transform: translateY(20px); }
  100% { opacity: 1; transform: translateY(0); }
}
.merchant-item {
  border: 1px solid rgba(255,170,0,0.2) !important;
  border-radius: 8px !important; padding: 10px 12px !important;
  background: rgba(255,170,0,0.03) !important;
  transition: border-color 0.2s, background 0.2s;
  cursor: pointer;
}
.merchant-item:hover { border-color: var(--gold) !important; background: rgba(255,170,0,0.06) !important; }
.merchant-dice {
  border: 1px dashed rgba(224,64,160,0.4) !important;
  border-radius: 8px !important; padding: 10px 12px;
  background: rgba(224,64,160,0.03) !important;
}

.shop-container { max-width:500px; margin:0 auto; animation:fadeIn 0.3s ease; }
.shop-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; font-size:14px; color:var(--gold); }
.shop-npc-desc { color:var(--dim); font-size:11px; font-style:italic; margin-bottom:12px; text-align:center; }
.shop-grid { display:flex; flex-direction:column; gap:6px; }
.shop-item {
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  background:var(--panel2); border:1px solid var(--border); border-radius:6px;
  cursor:pointer; transition:border-color 0.15s;
}
.shop-item:hover { border-color:var(--gold); }
.shop-item-icon { font-size:22px; width:32px; text-align:center; }
.shop-item-info { flex:1; }
.shop-item-name { font-size:12px; color:var(--text); }
.shop-item-desc { font-size:10px; color:var(--dim); }
.shop-item-price { color:var(--gold); font-size:12px; font-weight:600; white-space:nowrap; }

.jar-item { border-color:rgba(255,170,0,0.2) !important; }
.jar-item:hover { border-color:var(--gold) !important; background:#1a1a12; }

.enhance-list { display:flex; flex-direction:column; gap:4px; }
.enhance-item {
  display:flex; align-items:center; gap:8px; padding:8px 12px;
  background:var(--panel2); border:1px solid var(--border); border-radius:6px;
  font-size:12px;
}
.enhance-btn {
  padding:4px 10px; background:var(--panel); border:1px solid var(--gold); border-radius:4px;
  color:var(--gold); font-size:10px; cursor:pointer; font-family:inherit; white-space:nowrap;
  transition:all 0.15s;
}
.enhance-btn:hover { background:#2a2a10; }

@keyframes jarShake {
  0%,100%{transform:rotate(0)}
  20%{transform:rotate(-10deg)}
  40%{transform:rotate(10deg)}
  60%{transform:rotate(-6deg)}
  80%{transform:rotate(6deg)}
}
.jar-shaking { animation: jarShake 0.5s ease 3; display:inline-block; }
.jar-dots { animation: blink 0.5s step-end infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
@keyframes hitStop {
  0%,100% { filter:brightness(1.5) saturate(0.5); }
}

/* ===== 区域结局滚动剧情 ===== */
.epilogue-overlay {
  position:fixed; top:0; left:0; right:0; bottom:0;
  background:rgba(0,0,0,0.92); z-index:1000;
  display:flex; flex-direction:column; align-items:center;
  justify-content:flex-start; overflow:hidden;
}
.epilogue-title {
  font-family:"Noto Serif SC",serif; font-size:22px;
  color:var(--gold); letter-spacing:3px; margin:40px 20px 0;
  text-align:center; opacity:0; animation:epiFadeIn 1.2s ease 0.3s forwards;
}
.epilogue-scroll {
  flex:1; overflow:hidden; width:100%; max-width:560px;
  padding:20px 24px 60px; box-sizing:border-box;
  position:relative; mask-image:linear-gradient(0deg,transparent 0,#000 60px,#000 calc(100%-60px),transparent 100%);
  -webkit-mask-image:linear-gradient(0deg,transparent 0,#000 60px,#000 calc(100%-60px),transparent 100%);
}
.epilogue-lines {
  animation:epiScroll 40s linear forwards;
  animation-play-state:running;
}
.epilogue-line {
  font-size:14px; line-height:2.4; color:#ccc;
  text-align:center; margin:0; opacity:0;
  animation:epiLineIn 1.2s ease forwards;
}
.epilogue-line.highlight {
  color:var(--gold); font-weight:600; font-size:15px;
}
.epilogue-line.sub {
  font-size:12px; color:var(--dim); font-style:italic;
}
.epilogue-skip {
  position:fixed; bottom:30px; left:50%; transform:translateX(-50%);
  color:var(--dim); font-size:12px; cursor:pointer;
  z-index:1010; animation:epiFadeIn 1s ease 5s forwards;
  opacity:0; letter-spacing:1px;
}
.epilogue-skip:active { color:var(--gold); }

@keyframes epiFadeIn { to { opacity:1; } }
@keyframes epiScroll { from { transform:translateY(0); } to { transform:translateY(-100%); } }
@keyframes epiLineIn {
  0% { opacity:0; transform:translateY(20px); }
  30% { opacity:1; transform:translateY(0); }
  100% { opacity:1; }
}

/* ===== 章节故事按钮 ===== */
.lobby-story-btn-wrapper {
  margin:12px 0;
}
.lobby-story-btn {
  width:100%; padding:14px; background:var(--panel2);
  border:1px solid var(--border); border-radius:8px;
  color:var(--gold); font-size:15px; cursor:pointer;
  font-family:"Noto Serif SC",serif; letter-spacing:2px;
  transition:all 0.2s;
}
.lobby-story-btn:hover { border-color:var(--gold); background:rgba(201,164,75,0.06); }
.lobby-story-btn:active { transform:scale(0.98); }

/* ===== 章节故事面板 ===== */
.chapter-stories-panel {
  padding:0 0 120px;
}
.chapter-stories-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 16px 12px; position:sticky; top:0;
  background:var(--bg); z-index:10; border-bottom:1px solid var(--border);
  color:var(--gold); font-size:16px; font-family:"Noto Serif SC",serif;
  letter-spacing:2px;
}
.ch-back-btn {
  background:transparent; border:none; color:var(--dim);
  font-size:14px; cursor:pointer; font-family:inherit;
  padding:4px 8px; transition: color var(--t-fast);
}
.ch-back-btn:hover { color: var(--dim-light); }
.ch-back-btn:active { color:var(--gold); }

.chapter-card {
  margin:20px 16px; padding:24px 20px;
  background:var(--panel2); border:1px solid var(--border);
  border-radius:10px;
}
.chapter-card-title {
  font-size:17px; color:var(--gold); font-family:"Noto Serif SC",serif;
  text-align:center; margin-bottom:20px; letter-spacing:2px;
}
.chapter-section { margin-bottom:16px; }
.chapter-section-label {
  font-size:12px; color:var(--dim); margin-bottom:10px;
  text-align:center; letter-spacing:1px;
}
.chapter-divider {
  text-align:center; color:var(--border); font-size:11px;
  margin:20px 0; letter-spacing:6px;
}
.chapter-text {
  font-size:14px; line-height:2.2; color:#ccc;
  text-align:left; padding:0 4px;
}
/* ===== NPC 对话面板 ===== */
.npc-dialogue-panel { padding:0 0 40px; }
.npc-dialogue-header { display:flex; align-items:center; justify-content:space-between; padding:16px; border-bottom:1px solid var(--border); position:sticky; top:0; background:var(--bg); z-index:10; }
.npc-dialogue-back { background:transparent; border:none; color:var(--dim); font-size:14px; cursor:pointer; font-family:inherit; transition: color var(--t-fast); }
.npc-dialogue-back:hover { color: var(--dim-light); }
.npc-dialogue-back:active { color:var(--gold); }
.npc-dialogue-name { color:var(--gold); font-size:16px; font-family:"Noto Serif SC",serif; letter-spacing:2px; }
.npc-dialogue-body { display:flex; flex-direction:column; align-items:center; padding:40px 20px 20px; }
.npc-dialogue-avatar { font-size:64px; margin-bottom:24px; }
.npc-dialogue-text { font-size:16px; color:#ddd; line-height:2; text-align:center; max-width:400px; font-family:"Noto Sans SC",sans-serif; }
.npc-dialogue-shop { display:block; width:200px; margin:30px auto 0; padding:14px; background:var(--panel2); border:1px solid var(--gold); border-radius:8px; color:var(--gold); font-size:15px; cursor:pointer; font-family:inherit; text-align:center; letter-spacing:1px; }
.npc-dialogue-shop:active { background:rgba(201,164,75,0.12); transform:scale(0.97); }

/* ===== 冒险笔记 ===== */
.notebook-panel { padding:0 0 120px; }
.note-card {
  margin:12px 16px; padding:16px;
  background:var(--panel2); border:1px solid var(--border);
  border-radius:8px;
}
.note-header { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.note-icon { font-size:24px; }
.note-title { font-size:14px; color:var(--gold); font-weight:600; }
.note-date { font-size:10px; color:var(--dim); }
.note-text { font-size:13px; line-height:1.9; color:#bbb; }

.quest-log-panel { padding:0 0 120px; }
.quest-card { margin:8px 16px; padding:12px 14px; background:var(--panel2); border:1px solid var(--border); border-radius:8px; }
.quest-card-hd { display:flex; justify-content:space-between; align-items:center; }
.quest-card-name { font-size:14px; color:var(--gold); }
.quest-card-prog { font-size:11px; color:var(--dim); }
.quest-card-bar { height:4px; background:var(--border); border-radius:2px; margin:8px 0; }
.quest-card-fill { height:100%; background:var(--gold); border-radius:2px; transition:width 0.5s; }
.quest-card-desc { font-size:11px; color:var(--dim); }
.npc-quests { margin:16px 0; }
.npc-quest-item { padding:12px; margin:8px 0; background:rgba(201,164,75,0.05); border:1px dashed var(--border); border-radius:6px; cursor:pointer; }
.npc-quest-item:active { border-color:var(--gold); background:rgba(201,164,75,0.1); }
.npc-quest-name { display:block; font-size:14px; color:var(--gold); margin-bottom:4px; }
.npc-quest-desc { display:block; font-size:11px; color:#aaa; margin-bottom:4px; line-height:1.5; }
.npc-quest-reward { display:block; font-size:10px; color:var(--dim); }
.active-quests-hint { margin:8px 0; padding:8px 12px; background:rgba(201,164,75,0.06); border:1px solid var(--border); border-radius:6px; font-size:13px; color:var(--gold); cursor:pointer; text-align:center; }
.active-quests-hint:active { border-color:var(--gold); }

/* ====== 觉醒 Cut-in 横扫镜头 ====== */
.awakening-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 9999; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  animation: awFadeIn 0.3s ease-out;
}
.awakening-overlay::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.7) 85%);
  pointer-events: none; z-index: 1;
}
.awakening-bg {
  position: absolute; inset: 0;
  background: radial-gradient(circle at 55% 45%, rgba(200,168,78,0.08), transparent 60%),
              radial-gradient(circle at 40% 55%, rgba(160,40,40,0.06), transparent 50%);
  z-index: 0;
}
.awakening-flash {
  position: absolute; inset: 0;
  background: rgba(255,255,255,0.15);
  z-index: 0;
  animation: awFlash 0.5s ease-out forwards;
}
.awakening-vignette {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,0.5) 70%);
  z-index: 0;
}
.aw-line {
  position: absolute; height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(200,168,78,0.3) 40%, rgba(200,168,78,0.5) 50%, rgba(200,168,78,0.3) 60%, transparent 100%);
  z-index: 2; pointer-events: none;
  animation: awLineScan 1.2s ease-out forwards;
}
.aw-particle {
  position: absolute; border-radius: 50%;
  background: radial-gradient(circle, rgba(200,168,78,0.9), rgba(200,168,78,0.1));
  z-index: 2; pointer-events: none;
  animation: awParticleBurst 1s ease-out forwards;
}
.awakening-portrait-wrap {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center;
  animation: awPortraitEnter 0.6s cubic-bezier(0.16,1,0.3,1);
}
.awakening-aura {
  position: absolute; width: 300px; height: 300px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,168,78,0.15) 0%, transparent 70%);
  top: 50%; left: 50%; transform: translate(-50%, -50%);
  animation: awAuraPulse 0.8s ease-in-out infinite alternate;
}
.awakening-portrait {
  width: 250px; height: auto; max-height: 60vh;
  object-fit: contain; border-radius: 8px;
  filter: drop-shadow(0 0 20px rgba(200,168,78,0.4)) drop-shadow(0 0 60px rgba(200,168,78,0.15));
  position: relative; z-index: 1;
}
.awakening-nameplate {
  margin-top: 8px; text-align: center;
  animation: awNameFadeIn 0.8s 0.3s ease-out both;
}
.awakening-subtitle {
  font-size: 10px; color: var(--gold); letter-spacing: 4px;
  text-transform: uppercase; margin-bottom: 4px;
}
.awakening-skill-name {
  font-size: 22px; font-weight: 900; color: #fff;
  text-shadow: 0 0 20px rgba(200,168,78,0.6), 0 0 40px rgba(200,168,78,0.3);
}

@keyframes awFadeIn { from { opacity: 0; } to { opacity: 1; } }

/* ===== Utility Classes (extracted from inline styles) ===== */
.bgm-btn {
  background: none; border: none; cursor: pointer;
  font-size: 14px; padding: 0;
}
.bgm-btn:hover { opacity: 0.7; }
.logout-btn {
  font-size: var(--font-sm); background: none; color: var(--dim);
  border: 1px solid var(--border); padding: 4px 10px;
  border-radius: var(--radius-sm); cursor: pointer;
  transition: border-color var(--t-fast), color var(--t-fast);
}
.logout-btn:hover { border-color: var(--gold); color: var(--gold); }
.logout-btn:active { transform: scale(0.96); }
.text-gold { color: var(--gold); }
.text-dim { color: var(--dim); }
.text-center { text-align: center; }
.mt-8 { margin-top: 8px; }
.mt-12 { margin-top: 12px; }
.mt-16 { margin-top: 16px; }
.mb-8 { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }

/* ===== Accessibility: Minimum touch targets ===== */
button, .choice-btn, .skill-slot, .npc-card, [onclick] {
  min-height: 44px;
}
.btn-sm, .char-del-btn, .auth-switch-btn, .ch-back-btn {
  min-height: 36px; min-width: 36px;
}

/* ===== Character Sprite System ===== */
.sprite-container {
  width: 120px; height: 160px; position: relative;
  display: flex; align-items: flex-end; justify-content: center;
  overflow: visible;
}
.sprite-img {
  width: 120px; height: 160px; object-fit: contain;
  transition: transform 0.15s ease, filter 0.15s ease, opacity 0.2s ease;
  image-rendering: auto;
}
.sprite-img.switching { opacity: 0.5; }
.sprite-container.hit .sprite-img { animation: spriteHitFlash 0.35s ease; }
.sprite-container.attack .sprite-img { animation: spriteLunge 0.4s ease; }
.sprite-container.skill .sprite-img { animation: spritePowerUp 0.6s ease; }
.sprite-container.defend .sprite-img { animation: spriteSteady 0.35s ease; }
.sprite-container.victory .sprite-img { animation: spriteBounce 0.6s ease infinite; }
.sprite-container.defeated .sprite-img { animation: spriteFall 0.5s ease forwards; }

@keyframes spriteHitFlash {
  0% { filter: brightness(2) saturate(0); transform: translateX(0); }
  20% { filter: brightness(3) saturate(0); transform: translateX(-12px); }
  60% { filter: brightness(1.5); transform: translateX(-4px); }
  100% { filter: brightness(1); transform: translateX(0); }
}
@keyframes spriteLunge {
  0% { transform: translateX(0) scale(1); }
  30% { transform: translateX(20px) scale(1.1); }
  70% { transform: translateX(5px) scale(1.02); }
  100% { transform: translateX(0) scale(1); }
}
@keyframes spritePowerUp {
  0% { transform: scale(1); filter: brightness(1); }
  30% { transform: scale(1.15); filter: brightness(1.5) drop-shadow(0 0 10px var(--gold)); }
  70% { transform: scale(1.05); filter: brightness(1.2); }
  100% { transform: scale(1); filter: brightness(1); }
}
@keyframes spriteSteady {
  0% { transform: translateX(0); }
  30% { transform: translateX(-4px); }
  60% { transform: translateX(2px); }
  100% { transform: translateX(0); }
}
@keyframes spriteBounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}
@keyframes spriteFall {
  0% { transform: rotate(0) scale(1); opacity: 1; }
  100% { transform: rotate(15deg) scale(0.8); opacity: 0.5; }
}

/* 精灵命中闪光（技能/重击时叠加） */
.sprite-hit-flash {
  position: absolute; top: 20%; left: 10%; width: 80%; height: 60%;
  border-radius: 50%; pointer-events: none; z-index: 5;
  background: radial-gradient(circle, rgba(255,255,255,0.3) 0%, transparent 70%);
  animation: hitBurst 0.5s ease forwards;
}

/* 精灵 aura 光环（蓄力时） */
.sprite-aura {
  position: absolute; top: 15%; left: 5%; width: 90%; height: 70%;
  border-radius: 50%; pointer-events: none; z-index: 2;
  opacity: 0; transition: opacity 0.3s;
}
.sprite-container.skill .sprite-aura {
  opacity: 1;
  background: radial-gradient(circle, rgba(200,168,78,0.2) 0%, transparent 70%);
  animation: spritePowerUp 0.6s ease;
}

/* ===== Responsive: Tablet (768px+) ===== */
@media (min-width: 768px) {
  #app { max-width: 680px; }
  .class-select-grid { grid-template-columns: repeat(4, 1fr); gap: 10px; }
  .paperdoll { width: 160px; }
  .combat-illust { min-height: 220px; padding: 20px 12px 10px; }
  .combat-illust .fighter-wrap img { width: 140px; height: 160px; }
  .story-box { padding: 18px; font-size: 15px; }
  .choice-btn { padding: 12px 16px; font-size: 14px; }
}

/* ===== Responsive: Small Phone (320px) ===== */
@media (max-width: 350px) {
  .class-select-grid { grid-template-columns: repeat(2, 1fr); }
  .btn-row .btn { font-size: 11px; padding: 8px 2px; }
  .combat-illust .fighter-wrap img { width: 80px; height: 100px; }
}
@keyframes awFlash {
  0% { opacity: 1; }
  70% { opacity: 0.3; }
  100% { opacity: 0; }
}
@keyframes awLineScan { 0% { opacity: 0; transform: scaleX(0.5); } 30% { opacity: 1; transform: scaleX(1); } 100% { opacity: 0; transform: scaleX(1.2); } }
@keyframes awParticleBurst { 0% { transform: translate(0,0) scale(1); opacity: 1; } 100% { transform: translate(var(--dx),var(--dy)) scale(0); opacity: 0; } }
@keyframes awPortraitEnter { from { transform: scale(0.8); opacity: 0; } to { transform: scale(1); opacity: 1; } }
@keyframes awAuraPulse { from { transform: translate(-50%,-50%) scale(1); opacity: 0.3; } to { transform: translate(-50%,-50%) scale(1.1); opacity: 0.6; } }
@keyframes awNameFadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes awShake { 0%,100% { transform: translateX(0); } 20% { transform: translateX(-8px); } 40% { transform: translateX(8px); } 60% { transform: translateX(-5px); } 80% { transform: translateX(5px); } }
