@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@700;900&family=Rajdhani:wght@500;700&display=swap');
:root{
  --bg:#050614; --bg2:#0a0f24; --panel:#0f1530; --panel2:#161e3d;
  --primary:#4d9fff; --accent:#b366ff; --gold:#ffd24d; --danger:#f33555;
  --success:#4dffaa; --text:#e0e8ff; --muted:#6b7a99;
  --border:#2a3560; --border2:#3a4880;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:'Rajdhani',sans-serif;user-select:none;-webkit-user-select:none}
body{background:radial-gradient(ellipse at 50% 0%, #15193a 0%, #050614 60%, #02030a 100%)}
button{font-family:inherit;border:none;cursor:pointer;color:inherit;background:none;outline:none}
input{font-family:inherit;outline:none;border:none}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:#0a0e1f}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#3a4880,#2a3560);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#4d9fff,#3a4880)}

.app{position:relative;width:100vw;height:100vh;display:flex;flex-direction:column}

/* ============== HUD ============== */
.hud{
  position:fixed;top:0;left:0;right:0;height:78px;z-index:50;
  background:linear-gradient(180deg,rgba(15,21,48,0.96),rgba(15,21,48,0.86));
  border-bottom:2px solid var(--border2);
  box-shadow:0 2px 6px rgba(0,0,0,0.35),0 0 30px rgba(77,159,255,0.1);
  display:flex;align-items:center;padding:0 18px;gap:14px;
}
.hud-portrait{
  width:58px;height:58px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #4d9fff 0%, #2a3560 60%, #0f1530 100%);
  border:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;box-shadow:0 0 18px rgba(255,210,77,0.4),inset 0 0 10px rgba(0,0,0,0.4);
  flex-shrink:0;
}
.hud-info{display:flex;flex-direction:column;gap:2px;min-width:140px}
.hud-name{font-family:'Cinzel',serif;font-weight:900;font-size:16px;color:var(--gold);letter-spacing:0.05em;text-shadow:0 0 8px rgba(255,210,77,0.5);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}
.hud-class{font-size:12px;color:var(--accent);font-weight:700;letter-spacing:0.1em;text-transform:uppercase}
.hud-bars{flex:1;display:flex;flex-direction:column;gap:3px;max-width:360px}
.bar{position:relative;height:14px;background:#0a0e1f;border:1px solid var(--border);border-radius:7px;overflow:hidden}
.bar-fill{position:absolute;left:0;top:0;bottom:0;border-radius:6px;transition:width 0.3s ease}
.bar-fill.hp{background:linear-gradient(90deg,#7a1530 0%,#f33555 50%,#ff6680 100%);box-shadow:0 0 8px rgba(243,53,85,0.5)}
.bar-fill.mp{background:linear-gradient(90deg,#1a3a7a 0%,#4d9fff 50%,#80c4ff 100%);box-shadow:0 0 8px rgba(77,159,255,0.5)}
.bar-fill.xp{background:linear-gradient(90deg,#7a5a15 0%,#ffd24d 50%,#fff099 100%);box-shadow:0 0 8px rgba(255,210,77,0.5)}
.bar-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,0.9);letter-spacing:0.05em;z-index:2}
.hud-stats{display:flex;gap:10px;align-items:center}
.hud-lvl{font-family:'Cinzel',serif;font-weight:900;font-size:22px;color:var(--gold);text-shadow:0 0 10px rgba(255,210,77,0.6);min-width:60px;text-align:center}
.hud-gold{display:flex;align-items:center;gap:4px;color:var(--gold);font-weight:700;font-size:15px;background:rgba(255,210,77,0.08);padding:4px 10px;border-radius:14px;border:1px solid rgba(255,210,77,0.3)}
.hud-minions{display:flex;align-items:center;gap:4px;color:#b366ff;font-weight:700;font-size:15px;background:rgba(179,102,255,0.1);padding:4px 10px;border-radius:14px;border:1px solid rgba(179,102,255,0.4)}
.hud-diff{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;border:1px solid;animation:diffPulse 2s ease-in-out infinite}
.hud-diff.easy{background:rgba(77,255,170,0.12);color:var(--success);border-color:var(--success)}
.hud-diff.hard{background:rgba(255,210,77,0.12);color:var(--gold);border-color:var(--gold)}
.hud-diff.impossible{background:rgba(243,53,85,0.15);color:var(--danger);border-color:var(--danger)}
@keyframes diffPulse{0%,100%{box-shadow:0 0 4px currentColor}50%{box-shadow:0 0 14px currentColor}}

/* ============== VIEW ============== */
.view{position:absolute;top:78px;bottom:0;left:0;right:0;overflow:hidden}
.map,.arena{position:absolute;inset:0;display:none;isolation:isolate;z-index:1}
.map.active,.arena.active{display:block}

/* ============== MAP ============== */
.map{
  background:#1a2510;
}
.biome-bg{
  position:absolute;inset:0;width:100%;height:100%;
  z-index:0;pointer-events:none;
}
.decor{position:absolute;transform:translate(-50%,-100%);pointer-events:none}
.loc-marker{
  position:absolute;transform:translate(-50%,-100%);cursor:pointer;
  width:54px;height:54px;display:flex;align-items:center;justify-content:center;
  font-size:34px;border-radius:50%;
  background:transparent;
  border:none;
  text-shadow:0 0 8px rgba(0,0,0,0.85),0 0 14px rgba(77,159,255,0.55),0 2px 4px rgba(0,0,0,0.7);
  transition:transform 0.2s,text-shadow 0.2s;
}
.loc-marker.dungeon{text-shadow:0 0 8px rgba(0,0,0,0.85),0 0 14px rgba(179,102,255,0.7),0 2px 4px rgba(0,0,0,0.7)}
.loc-marker.village{text-shadow:0 0 8px rgba(0,0,0,0.85),0 0 14px rgba(255,210,77,0.75),0 2px 4px rgba(0,0,0,0.7)}
.loc-marker.locked{filter:grayscale(1) brightness(0.6)}
.loc-marker.near{transform:translate(-50%,-100%) scale(1.18);text-shadow:0 0 12px rgba(0,0,0,0.9),0 0 24px var(--gold),0 2px 6px rgba(0,0,0,0.8)}
.loc-label{
  position:absolute;transform:translate(-50%,8px);
  font-family:'Cinzel',serif;font-weight:700;font-size:11px;color:var(--text);
  text-shadow:0 0 4px #000,0 0 8px rgba(77,159,255,0.6);
  letter-spacing:0.08em;text-transform:uppercase;white-space:nowrap;
  pointer-events:none;
}
.loc-rank{
  display:inline-block;padding:1px 6px;margin-left:4px;border-radius:8px;
  font-size:10px;font-weight:900;background:var(--accent);color:#fff;
}
.loc-rank.F{background:#666}.loc-rank.D{background:#888}.loc-rank.C{background:#4d9fff}
.loc-rank.B{background:#b366ff}.loc-rank.S{background:#ffd24d;color:#000}
.loc-rank.SS{background:#ff6680}.loc-rank.EX{background:#f33555}.loc-rank.GOD{background:linear-gradient(90deg,#ffd24d,#fff099,#ffd24d);color:#000;animation:godGlow 2s infinite}
@keyframes godGlow{0%,100%{box-shadow:0 0 4px #ffd24d}50%{box-shadow:0 0 14px #fff099}}

.player-marker{
  position:absolute;width:44px;height:44px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #80c4ff 0%, #4d9fff 40%, #b366ff 100%);
  border:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;font-size:22px;
  box-shadow:0 0 20px rgba(77,159,255,0.7),0 4px 8px rgba(0,0,0,0.7);
  transform:translate(-50%,-50%);z-index:20;
  will-change:left,top;
  transition:box-shadow 0.2s;
}
.player-marker.moving{box-shadow:0 0 30px rgba(255,210,77,0.8),0 4px 10px rgba(0,0,0,0.8)}
.prompt-action{
  position:absolute;transform:translate(-50%,16px);
  background:linear-gradient(180deg,rgba(255,210,77,0.95),rgba(255,175,30,0.95));
  color:#000;padding:6px 14px;border-radius:14px;white-space:nowrap;
  font-family:'Cinzel',serif;font-weight:900;font-size:11px;letter-spacing:0.12em;
  border:2px solid #fff;box-shadow:0 0 18px rgba(255,210,77,0.75),0 3px 6px rgba(0,0,0,0.5);
  z-index:25;animation:promptBob 1s ease-in-out infinite;
  pointer-events:none;
}
@keyframes promptBob{0%,100%{transform:translate(-50%,16px)}50%{transform:translate(-50%,20px)}}
.hint-controls{
  position:fixed;bottom:14px;right:14px;z-index:30;
  background:rgba(15,21,48,0.78);border:1px solid var(--border);
  color:var(--muted);font-size:11px;padding:6px 12px;border-radius:14px;
  letter-spacing:0.05em;font-weight:700;pointer-events:none;
}
.hint-controls b{color:var(--gold);letter-spacing:0.1em}

/* ============== ARENA ============== */
.arena{
  background:
    radial-gradient(ellipse at 50% 40%, rgba(122,167,80,0.18) 0%, transparent 60%),
    radial-gradient(ellipse at 50% 50%, #2a3d22 0%, #182012 60%, #0a0f08 100%);
  overflow:hidden;
}
.arena::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    radial-gradient(2px 2px at 18% 32%, rgba(140,180,90,0.35) 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 64% 71%, rgba(170,140,80,0.3) 50%, transparent 100%),
    radial-gradient(1px 1px at 82% 24%, rgba(100,80,50,0.5) 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 38% 84%, rgba(180,150,100,0.3) 50%, transparent 100%),
    radial-gradient(1px 1px at 8% 60%, rgba(120,100,60,0.45) 50%, transparent 100%);
  background-size:140px 140px,180px 180px,90px 90px,160px 160px,110px 110px;
}
.arena::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(ellipse at 50% 50%, transparent 0%, transparent 55%, rgba(0,0,0,0.4) 100%);
}
.arena.dungeon{
  background:
    radial-gradient(ellipse at 50% 50%, #2a2240 0%, #1a1430 55%, #0a0816 100%);
}
.arena.dungeon::before{
  background-image:
    linear-gradient(90deg, rgba(0,0,0,0.45) 0 1px, transparent 1px 100%),
    linear-gradient(0deg, rgba(0,0,0,0.45) 0 1px, transparent 1px 100%),
    radial-gradient(2px 2px at 22% 38%, rgba(180,160,200,0.18) 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 78% 62%, rgba(120,80,160,0.2) 50%, transparent 100%);
  background-size:64px 64px,64px 64px,160px 160px,140px 140px;
}
.arena.dungeon::after{
  background:
    radial-gradient(ellipse at 50% 50%, transparent 0%, transparent 45%, rgba(0,0,0,0.7) 100%),
    radial-gradient(circle 110px at 8% 10%, rgba(255,160,60,0.25) 0%, transparent 100%),
    radial-gradient(circle 110px at 92% 10%, rgba(255,160,60,0.25) 0%, transparent 100%),
    radial-gradient(circle 110px at 8% 90%, rgba(255,160,60,0.22) 0%, transparent 100%),
    radial-gradient(circle 110px at 92% 90%, rgba(255,160,60,0.22) 0%, transparent 100%);
  animation:torchFlicker 2.4s ease-in-out infinite;
}
.arena.boss-lit::after{
  background:
    radial-gradient(ellipse at 50% 50%, rgba(255,210,140,0.18) 0%, rgba(255,160,60,0.08) 50%, transparent 100%),
    radial-gradient(circle 220px at 12% 14%, rgba(255,180,80,0.45) 0%, transparent 100%),
    radial-gradient(circle 220px at 88% 14%, rgba(255,180,80,0.45) 0%, transparent 100%),
    radial-gradient(circle 220px at 12% 86%, rgba(255,180,80,0.4) 0%, transparent 100%),
    radial-gradient(circle 220px at 88% 86%, rgba(255,180,80,0.4) 0%, transparent 100%);
  animation:torchFlicker 2.4s ease-in-out infinite;
}
@keyframes torchFlicker{0%,100%{opacity:1}50%{opacity:0.85}}
.arena-decor{position:absolute;pointer-events:none;will-change:auto;opacity:0.92}
.arena-decor.front{z-index:5}
.arena-decor.back{z-index:0}
.arena-frozen > *:not(.arena-decor):not(.arena-veil){display:none!important}
.arena.village::before{
  background-image:
    radial-gradient(2px 2px at 28% 42%, rgba(180,150,90,0.4) 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 64% 71%, rgba(200,170,110,0.35) 50%, transparent 100%),
    radial-gradient(1px 1px at 82% 24%, rgba(160,130,80,0.45) 50%, transparent 100%),
    radial-gradient(2px 2px at 38% 84%, rgba(200,180,120,0.35) 50%, transparent 100%);
  background-size:100px 100px,140px 140px,80px 80px,160px 160px;
}
.arena.village::after{
  background:
    radial-gradient(ellipse at 50% 25%, rgba(255,230,170,0.22) 0%, transparent 65%),
    radial-gradient(ellipse at 50% 50%, transparent 0%, transparent 70%, rgba(0,0,0,0.32) 100%);
}
.arena.village{background:
  radial-gradient(ellipse at 50% 35%, #c4a875 0%, #8a6f48 35%, #5a4525 70%, #3a2d18 100%)
}
.arena.village .arena-decor{opacity:1;filter:drop-shadow(0 4px 6px rgba(0,0,0,0.55))}
.npc-sprite{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;pointer-events:none;will-change:auto}
.npc-sprite .npc-body{width:52px;height:52px;border-radius:50%;background:radial-gradient(circle at 35% 30%, #d9bd8a 0%, #8a6a4a 60%, #3a2510 100%);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 0 14px rgba(255,210,77,0.4),0 4px 8px rgba(0,0,0,0.6)}
.npc-sprite.near .npc-body{box-shadow:0 0 22px var(--gold),0 0 30px rgba(255,210,77,0.7);transform:scale(1.08)}
.npc-name-tag{font-family:'Cinzel',serif;font-weight:700;font-size:11px;color:#fff;background:rgba(15,21,48,0.85);border:1px solid var(--border);padding:2px 8px;border-radius:10px;margin-bottom:4px;white-space:nowrap;letter-spacing:0.05em;text-shadow:0 0 4px #000}
.npc-name-tag.reward{border-color:var(--gold);color:var(--gold);box-shadow:0 0 10px rgba(255,210,77,0.5)}
.npc-name-tag.locked{opacity:0.55}
.npc-quest-dot{display:inline-block;background:var(--gold);color:#000;padding:0 5px;border-radius:8px;font-weight:900;margin-left:3px;animation:questDot 1.2s ease-in-out infinite}
@keyframes questDot{0%,100%{transform:scale(1)}50%{transform:scale(1.18)}}
.arena-veil{position:absolute;inset:0;z-index:99;background:linear-gradient(180deg,rgba(8,4,18,0.96),rgba(0,0,0,0.99));pointer-events:none}
.fog{
  position:absolute;inset:0;pointer-events:none;z-index:15;display:none;
  background:radial-gradient(circle 360px at 50% 50%, transparent 0%, transparent 65%, rgba(0,0,0,0.78) 100%);
}
.fog.on{display:block}
.player-sprite,.enemy-sprite,.minion-sprite{
  position:absolute;transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;
  will-change:left,top;
  pointer-events:none;
}
.sprite-body{width:60px;height:60px;display:flex;align-items:center;justify-content:center;font-size:38px;filter:drop-shadow(0 4px 6px rgba(0,0,0,0.7))}
.player-sprite .sprite-body{
  background:radial-gradient(circle at 35% 30%, #80c4ff 0%, #4d9fff 50%, #2a3560 100%);
  border-radius:50%;border:2px solid var(--gold);
  box-shadow:0 0 16px rgba(77,159,255,0.6),0 4px 8px rgba(0,0,0,0.7);
  width:52px;height:52px;font-size:26px;
}
.player-sprite.hit .sprite-body{animation:hitFlash 0.2s ease-out}
@keyframes hitFlash{0%{filter:brightness(2.5) drop-shadow(0 0 20px var(--danger))}100%{filter:none}}
.minion-sprite .sprite-body{
  background:radial-gradient(circle at 50% 40%, #4a2080 0%, #1a0830 100%);
  border-radius:50%;border:2px solid var(--accent);
  width:46px;height:46px;font-size:22px;
  box-shadow:0 0 12px rgba(179,102,255,0.6);
}
.enemy-sprite svg{width:60px;height:60px;filter:drop-shadow(0 4px 6px rgba(0,0,0,0.7))}
.enemy-sprite.boss svg{width:96px;height:96px}
.enemy-sprite.elite svg{width:74px;height:74px}
.sprite-hp{
  width:32px;height:3px;background:rgba(0,0,0,0.7);border-radius:2px;margin-top:3px;
  overflow:hidden;border:1px solid #000;
}
.enemy-sprite.boss .sprite-hp{display:none}
.sprite-hp-fill{height:100%;background:linear-gradient(90deg,#f33555,#ff6680);transition:width 0.2s}
.minion-sprite .sprite-hp-fill{background:linear-gradient(90deg,#b366ff,#d9a3ff)}
.player-sprite .sprite-hp-fill{background:linear-gradient(90deg,#4dffaa,#80ffc4)}
.sprite-vision{display:none}
.enemy-sprite.engaged .sprite-body,.enemy-sprite.engaged svg{filter:drop-shadow(0 0 12px rgba(243,53,85,0.8)) drop-shadow(0 4px 6px rgba(0,0,0,0.7))}
.dot-icons{position:absolute;top:-22px;left:50%;transform:translateX(-50%);display:flex;gap:2px;font-size:11px;animation:dotPulse 0.8s ease-in-out infinite}
@keyframes dotPulse{0%,100%{transform:translateX(-50%) scale(1)}50%{transform:translateX(-50%) scale(1.2)}}
.crown{position:absolute;top:-14px;left:50%;transform:translateX(-50%);font-size:18px;filter:drop-shadow(0 2px 3px rgba(0,0,0,0.8))}

.boss-hp-bar{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:min(70vw,520px);z-index:80;
  text-align:center;
}
.boss-hp-name{
  font-family:'Cinzel',serif;font-weight:900;font-size:18px;color:var(--gold);
  letter-spacing:0.18em;text-shadow:0 0 10px rgba(255,210,77,0.7),0 2px 4px #000;
  margin-bottom:4px;text-transform:uppercase;
}
.boss-hp-track{
  position:relative;height:16px;background:#000;border:2px solid var(--danger);
  border-radius:10px;overflow:hidden;
  box-shadow:0 0 20px rgba(243,53,85,0.6),inset 0 0 8px rgba(0,0,0,0.8);
}
.boss-hp-fill{
  position:absolute;left:0;top:0;bottom:0;
  background:linear-gradient(90deg,#7a0a20 0%,#f33555 50%,#ff6680 100%);
  transition:width 0.25s ease-out;box-shadow:0 0 12px rgba(243,53,85,0.7);
}
.boss-hp-tick{
  position:absolute;top:0;bottom:0;width:1px;background:rgba(0,0,0,0.85);z-index:3;
}
.boss-hp-count{font-size:12px;color:var(--text);margin-top:3px;font-weight:700;letter-spacing:0.1em;text-shadow:0 1px 2px #000}

.cine-overlay{
  position:absolute;inset:0;z-index:70;pointer-events:none;
  background:radial-gradient(ellipse at 50% 50%, rgba(0,0,0,0) 0%, rgba(0,0,0,0.85) 80%);
  opacity:0;transition:opacity 1.2s;
}
.cine-overlay.on{opacity:1}
.cine-text{
  position:absolute;left:50%;bottom:24%;transform:translateX(-50%);
  font-family:'Cinzel',serif;font-style:italic;font-size:18px;color:var(--text);
  text-shadow:0 0 12px #000,0 0 24px rgba(179,102,255,0.6);letter-spacing:0.1em;
  opacity:0;transition:opacity 0.6s;text-align:center;
}
.cine-text.on{opacity:1}
.cine-text.boss-name{font-size:38px;font-style:normal;font-weight:900;color:var(--danger);text-shadow:0 0 16px rgba(243,53,85,0.9),0 0 32px rgba(243,53,85,0.5),0 2px 6px #000;letter-spacing:0.25em}
@keyframes cineShake{0%,100%{transform:translate(0,0)}10%{transform:translate(-4px,-2px)}20%{transform:translate(4px,2px)}30%{transform:translate(-3px,3px)}40%{transform:translate(3px,-3px)}50%{transform:translate(-5px,0)}60%{transform:translate(5px,1px)}70%{transform:translate(-2px,-3px)}80%{transform:translate(2px,3px)}90%{transform:translate(-3px,-1px)}}
.arena.shake{animation:cineShake 0.4s linear infinite}
.boss-awakening{
  opacity:0;transform:translate(-50%,-50%) scale(0.3);filter:blur(3px);
  transition:opacity 1.2s,transform 1.2s,filter 1.2s;
}
.boss-awakening.appear{opacity:1;transform:translate(-50%,-50%) scale(1);filter:blur(0)}
.boss-awakening.roar svg{transform:scale(1.4);filter:drop-shadow(0 0 20px rgba(243,53,85,0.9)) brightness(1.6);transition:transform 0.5s,filter 0.5s}

.dmg-num{
  position:absolute;font-family:'Cinzel',serif;font-weight:900;font-size:18px;
  pointer-events:none;z-index:50;text-shadow:0 0 4px #000,0 2px 4px #000;
  animation:dmgFloat 1s ease-out forwards;
}
.dmg-num.normal{color:#fff}
.dmg-num.crit{color:var(--gold);font-size:24px;text-shadow:0 0 8px var(--gold),0 0 14px rgba(255,210,77,0.5),0 2px 4px #000}
.dmg-num.heal{color:var(--success);text-shadow:0 0 8px var(--success),0 2px 4px #000}
.dmg-num.xp{color:var(--primary);font-size:14px;text-shadow:0 0 6px var(--primary),0 2px 4px #000}
.dmg-num.miss{color:var(--muted);font-style:italic;font-size:14px}
@keyframes dmgFloat{0%{opacity:0;transform:translate(-50%,0) scale(0.7)}20%{opacity:1;transform:translate(-50%,-12px) scale(1.1)}100%{opacity:0;transform:translate(-50%,-60px) scale(0.9)}}

.proj{position:absolute;width:14px;height:14px;border-radius:50%;pointer-events:none;z-index:40;will-change:left,top;transform:translate(-50%,-50%)}
.proj.fire{background:radial-gradient(circle,#fff,#ffaa33,#ff3300);box-shadow:0 0 14px #ff6600,0 0 24px rgba(255,102,0,0.5)}
.proj.frost{background:radial-gradient(circle,#fff,#aaddff,#3388ff);box-shadow:0 0 14px #66bbff,0 0 24px rgba(102,187,255,0.5)}
.proj.shock{background:radial-gradient(circle,#fff,#ffff99,#ffdd33);box-shadow:0 0 14px #ffee44,0 0 24px rgba(255,238,68,0.5)}
.proj.shadow{background:radial-gradient(circle,#b366ff,#4a2080,#1a0830);box-shadow:0 0 14px var(--accent),0 0 24px rgba(179,102,255,0.5)}
.proj.arrow{width:18px;height:4px;background:linear-gradient(90deg,#8b5a2b,#d9a574);border-radius:2px}
.proj.web{width:12px;height:12px;background:radial-gradient(circle,#e0e0e0,#909090);opacity:0.7;border-radius:50%}
.proj.poison{background:radial-gradient(circle,#aaff66,#4dff00,#00aa00);box-shadow:0 0 12px #66ff33}
.proj.holy{background:radial-gradient(circle,#fff,#fff099,#ffd24d);box-shadow:0 0 16px #fff099}
.proj.dark{background:radial-gradient(circle,#1a0830,#000);box-shadow:0 0 14px #4a2080}
.beam-fx{position:absolute;height:3px;transform-origin:0 50%;pointer-events:none;z-index:38;border-radius:2px;will-change:opacity;animation:beamFlash 0.28s ease-out forwards}
.beam-fx.fire{background:linear-gradient(90deg,#fff,#ffaa33,#ff3300);box-shadow:0 0 14px #ff6600}
.beam-fx.frost{background:linear-gradient(90deg,#fff,#aaddff,#3388ff);box-shadow:0 0 14px #66bbff}
.beam-fx.shock{background:linear-gradient(90deg,#ffffff,#ffff99,#ffdd33);box-shadow:0 0 16px #ffee44;height:4px}
.beam-fx.shadow{background:linear-gradient(90deg,#e0c0ff,#b366ff,#4a2080);box-shadow:0 0 14px #b366ff}
.beam-fx.arrow{background:linear-gradient(90deg,#d9a574,#8b5a2b);height:2px;box-shadow:0 0 4px #aa8855}
.beam-fx.poison{background:linear-gradient(90deg,#aaff66,#4dff00,#00aa00);box-shadow:0 0 10px #66ff33}
.beam-fx.holy{background:linear-gradient(90deg,#fff,#fff099,#ffd24d);box-shadow:0 0 14px #fff099}
.beam-fx.dark{background:linear-gradient(90deg,#9966cc,#4a2080,#1a0830);box-shadow:0 0 12px #4a2080}
.hit-flash{position:absolute;width:36px;height:36px;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:42;will-change:transform,opacity;animation:hitFlashAnim 0.32s ease-out forwards}
.hit-flash.fire{background:radial-gradient(circle,#fff099 0%,#ff6600 50%,transparent 75%);box-shadow:0 0 22px #ff6600}
.hit-flash.frost{background:radial-gradient(circle,#fff 0%,#3388ff 50%,transparent 75%);box-shadow:0 0 18px #66ccff}
.hit-flash.shock{background:radial-gradient(circle,#ffffff 0%,#ffee44 50%,transparent 75%);box-shadow:0 0 24px #ffffff}
.hit-flash.shadow{background:radial-gradient(circle,#e0c0ff 0%,#5520aa 50%,transparent 75%);box-shadow:0 0 18px #b366ff}
.hit-flash.arrow{background:radial-gradient(circle,#fff 0%,#888 50%,transparent 75%);box-shadow:0 0 8px #aaa}
.hit-flash.poison{background:radial-gradient(circle,#ccff66 0%,#449900 50%,transparent 75%);box-shadow:0 0 14px #88ff00}
.hit-flash.holy{background:radial-gradient(circle,#ffffff 0%,#ffd24d 50%,transparent 75%);box-shadow:0 0 26px #fff099}
.hit-flash.dark{background:radial-gradient(circle,#9966cc 0%,#220033 50%,transparent 75%);box-shadow:0 0 16px #5510aa}
@keyframes beamFlash{0%{opacity:1}80%{opacity:0.4}100%{opacity:0;height:1px}}
@keyframes hitFlashAnim{0%{transform:translate(-50%,-50%) scale(0.4);opacity:1}100%{transform:translate(-50%,-50%) scale(1.8);opacity:0}}

.aoe-ring{position:absolute;border-radius:50%;pointer-events:none;z-index:35;transform:translate(-50%,-50%);animation:aoeRing 0.6s ease-out forwards}
.aoe-ring.fire{border:3px solid #ff6600;box-shadow:0 0 20px #ff6600 inset,0 0 30px rgba(255,102,0,0.6)}
.aoe-ring.frost{border:3px solid #66bbff;box-shadow:0 0 20px #66bbff inset,0 0 30px rgba(102,187,255,0.6)}
.aoe-ring.shock{border:3px solid #ffee44;box-shadow:0 0 20px #ffee44 inset,0 0 30px rgba(255,238,68,0.6)}
.aoe-ring.shadow{border:3px solid var(--accent);box-shadow:0 0 20px var(--accent) inset,0 0 30px rgba(179,102,255,0.6)}
.aoe-ring.holy{border:3px solid #fff099;box-shadow:0 0 20px #fff099 inset,0 0 30px rgba(255,240,153,0.7)}
@keyframes aoeRing{0%{opacity:0.9;transform:translate(-50%,-50%) scale(0.2)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.4)}}
.aoe-fullscreen{position:absolute;inset:0;pointer-events:none;z-index:36;animation:aoeFs 0.7s ease-out forwards;mix-blend-mode:screen}
.aoe-fullscreen.fire{background:radial-gradient(ellipse at 50% 50%, rgba(255,200,80,0.55) 0%, rgba(255,80,0,0.4) 50%, rgba(120,20,0,0.15) 100%);box-shadow:inset 0 0 80px rgba(255,140,40,0.6)}
.aoe-fullscreen.frost{background:radial-gradient(ellipse at 50% 50%, rgba(200,235,255,0.5) 0%, rgba(102,187,255,0.4) 50%, rgba(40,80,140,0.15) 100%);box-shadow:inset 0 0 80px rgba(150,200,255,0.6)}
.aoe-fullscreen.shock{background:radial-gradient(ellipse at 50% 50%, rgba(255,255,200,0.7) 0%, rgba(255,238,68,0.4) 50%, rgba(120,80,0,0.15) 100%);box-shadow:inset 0 0 100px rgba(255,255,150,0.7)}
.aoe-fullscreen.shadow{background:radial-gradient(ellipse at 50% 50%, rgba(220,160,255,0.55) 0%, rgba(120,40,200,0.45) 50%, rgba(30,8,60,0.2) 100%);box-shadow:inset 0 0 90px rgba(179,102,255,0.6)}
.aoe-fullscreen.holy{background:radial-gradient(ellipse at 50% 50%, rgba(255,255,255,0.7) 0%, rgba(255,240,153,0.45) 50%, rgba(200,140,40,0.15) 100%);box-shadow:inset 0 0 100px rgba(255,250,200,0.75)}
.aoe-fullscreen.dark{background:radial-gradient(ellipse at 50% 50%, rgba(150,80,200,0.55) 0%, rgba(50,20,80,0.45) 50%, rgba(10,4,20,0.25) 100%);box-shadow:inset 0 0 80px rgba(80,40,140,0.6)}
@keyframes aoeFs{0%{opacity:0;transform:scale(0.8)}30%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.05)}}

.slash-fx{position:absolute;width:64px;height:64px;pointer-events:none;z-index:38;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,255,255,0.6),transparent 60%);animation:slashFx 0.25s ease-out forwards}
@keyframes slashFx{0%{opacity:1;transform:translate(-50%,-50%) scale(0.4) rotate(0deg)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.3) rotate(40deg)}}

.stair{position:absolute;width:64px;height:64px;display:flex;align-items:center;justify-content:center;font-size:42px;transform:translate(-50%,-50%);filter:drop-shadow(0 0 18px rgba(255,210,77,0.8));z-index:25;cursor:pointer;animation:stairPulse 1.5s ease-in-out infinite}
@keyframes stairPulse{0%,100%{filter:drop-shadow(0 0 14px rgba(255,210,77,0.6))}50%{filter:drop-shadow(0 0 26px rgba(255,210,77,1))}}

/* ============== TABS ============== */
.tabs{
  position:fixed;bottom:14px;left:50%;transform:translateX(-50%);z-index:50;
  display:flex;gap:8px;background:rgba(15,21,48,0.92);padding:8px 14px;border-radius:24px;
  border:1px solid var(--border2);box-shadow:0 4px 18px rgba(0,0,0,0.7),0 0 18px rgba(77,159,255,0.15);
}
.tabs.hidden{display:none}
.battle-ctrls{position:fixed;top:90px;left:14px;z-index:55;display:flex;gap:8px;flex-direction:column;align-items:flex-start}
.battle-ctrls .btn{padding:14px 26px;font-size:16px;letter-spacing:0.14em;box-shadow:0 6px 18px rgba(0,0,0,0.7),inset 0 1px 0 rgba(255,255,255,0.25)}
.battle-ctrls .btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(243,53,85,0.55),inset 0 1px 0 rgba(255,255,255,0.3)}
#btnFuir{background:linear-gradient(180deg,var(--danger),#aa1530);border:2px solid rgba(255,255,255,0.25)}
.tab-btn{
  padding:8px 18px;border-radius:18px;font-family:'Cinzel',serif;font-weight:700;font-size:13px;
  color:var(--text);letter-spacing:0.12em;text-transform:uppercase;
  background:linear-gradient(180deg,rgba(77,159,255,0.15),rgba(77,159,255,0.05));
  border:1px solid var(--border);transition:all 0.2s;
}
.tab-btn:hover{background:linear-gradient(180deg,rgba(77,159,255,0.3),rgba(179,102,255,0.2));border-color:var(--primary);box-shadow:0 0 12px rgba(77,159,255,0.4)}
.spell-slots{position:fixed;bottom:14px;right:14px;display:flex;gap:6px;z-index:50}
.spell-slots.hidden{display:none}
.spell-slot{
  width:54px;height:54px;border-radius:10px;
  background:linear-gradient(180deg,rgba(15,21,48,0.9),rgba(15,21,48,0.7));
  border:2px solid var(--border2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;font-size:22px;cursor:pointer;
}
.spell-slot.ready{border-color:var(--gold);box-shadow:0 0 12px rgba(255,210,77,0.4)}
.spell-slot.disabled{opacity:0.4;filter:grayscale(1)}
.spell-key{position:absolute;bottom:2px;right:3px;font-size:9px;color:var(--gold);font-weight:700;background:rgba(0,0,0,0.7);padding:1px 4px;border-radius:4px}
.spell-cd{position:absolute;inset:0;background:rgba(0,0,0,0.75);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px}
.spell-cd.empty{display:none}

/* ============== MODALS ============== */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:100;display:none;align-items:center;justify-content:center;backdrop-filter:blur(14px) saturate(0.7) brightness(0.6);-webkit-backdrop-filter:blur(14px) saturate(0.7) brightness(0.6);padding:20px}
body.modal-open .map .loc-marker,
body.modal-open .map .loc-label,
body.modal-open .map .decor,
body.modal-open .map .player-marker{opacity:0;transition:opacity 0.18s}
body.modal-open .prompt-action,body.modal-open .hint-controls{display:none!important}
.modal-bg.on{display:flex;animation:fadeIn 0.2s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{
  background:linear-gradient(180deg,#161e3d 0%,#0f1530 100%);
  border:2px solid var(--border2);border-radius:14px;
  box-shadow:0 0 50px rgba(77,159,255,0.3),0 20px 50px rgba(0,0,0,0.8);
  max-width:680px;width:95vw;max-height:90vh;overflow-y:auto;
  padding:24px;
}
.modal.wide{max-width:1100px}
.modal h2{font-family:'Cinzel',serif;font-weight:900;font-size:24px;color:var(--gold);letter-spacing:0.12em;text-align:center;margin-bottom:16px;text-shadow:0 0 12px rgba(255,210,77,0.4);text-transform:uppercase}
.modal h3{font-family:'Cinzel',serif;font-weight:700;font-size:16px;color:var(--primary);letter-spacing:0.1em;margin:10px 0 6px;text-transform:uppercase}
.modal p{margin:6px 0;line-height:1.5}
.modal .row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn{
  padding:10px 16px;font-family:'Cinzel',serif;font-weight:700;font-size:13px;
  letter-spacing:0.1em;text-transform:uppercase;border-radius:8px;
  background:linear-gradient(180deg,var(--primary),var(--accent));
  color:#fff;border:1px solid rgba(255,255,255,0.2);transition:all 0.15s;
  box-shadow:0 2px 8px rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.2);
}
.btn:hover{box-shadow:0 4px 16px rgba(77,159,255,0.6),inset 0 1px 0 rgba(255,255,255,0.3);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.gold{background:linear-gradient(180deg,var(--gold),#cc9933);color:#1a0d00}
.btn.gold:hover{box-shadow:0 4px 16px rgba(255,210,77,0.6),inset 0 1px 0 rgba(255,255,255,0.3)}
.btn.danger{background:linear-gradient(180deg,var(--danger),#aa1530)}
.btn.danger:hover{box-shadow:0 4px 16px rgba(243,53,85,0.6),inset 0 1px 0 rgba(255,255,255,0.3)}
.btn.small{padding:6px 12px;font-size:11px}
.btn.full{width:100%;display:block}
.btn:disabled{opacity:0.4;cursor:not-allowed;transform:none}

.input,.txt{
  background:#0a0e1f;color:var(--text);font-size:14px;padding:10px 14px;
  border:1px solid var(--border2);border-radius:8px;width:100%;
}
.input:focus,.txt:focus{border-color:var(--primary);box-shadow:0 0 12px rgba(77,159,255,0.4)}
.cls-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:14px 0}
.cls-card{
  padding:12px;border-radius:10px;border:2px solid var(--border);cursor:pointer;
  background:linear-gradient(180deg,rgba(77,159,255,0.05),rgba(179,102,255,0.05));
  transition:all 0.2s;text-align:center;
}
.cls-card:hover{border-color:var(--primary);box-shadow:0 0 14px rgba(77,159,255,0.4)}
.cls-card.sel{border-color:var(--gold);background:linear-gradient(180deg,rgba(255,210,77,0.15),rgba(179,102,255,0.1));box-shadow:0 0 18px rgba(255,210,77,0.5)}
.cls-card.secret{border-color:var(--gold);background:linear-gradient(180deg,rgba(255,210,77,0.1),rgba(179,102,255,0.18));box-shadow:0 0 18px rgba(255,210,77,0.45);animation:secretGlow 2.4s ease-in-out infinite}
.cls-card.secret .cls-name{background:linear-gradient(90deg,#ffd24d,#fff099,#ffd24d);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 6px rgba(255,210,77,0.5)}
@keyframes secretGlow{0%,100%{box-shadow:0 0 12px rgba(255,210,77,0.4)}50%{box-shadow:0 0 26px rgba(255,210,77,0.75),0 0 8px rgba(179,102,255,0.6)}}
.cls-icon{font-size:38px;margin-bottom:4px}
.cls-name{font-family:'Cinzel',serif;font-weight:700;font-size:13px;color:var(--gold);letter-spacing:0.08em}
.cls-desc{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.3}

.diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:10px 0}
.diff-card{padding:10px;border-radius:8px;border:2px solid var(--border);cursor:pointer;text-align:center;font-family:'Cinzel',serif;font-weight:700;font-size:13px;letter-spacing:0.1em;transition:all 0.2s}
.diff-card.easy{color:var(--success)}.diff-card.hard{color:var(--gold)}.diff-card.impossible{color:var(--danger)}
.diff-card:hover{box-shadow:0 0 14px currentColor}
.diff-card.sel{border-color:currentColor;box-shadow:0 0 18px currentColor}

/* MARKET 3 colonnes */
.mk-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;align-items:start;margin-top:10px}
.mk-col{display:flex;flex-direction:column;min-width:0}
.mk-col h3{margin-bottom:6px;text-align:center}
.mk-col-list{max-height:55vh;overflow-y:auto;display:flex;flex-direction:column;gap:4px;padding-right:4px}
.mk-col-list::-webkit-scrollbar{width:6px}
@media(max-width:900px){.mk-cols{grid-template-columns:1fr}.mk-col-list{max-height:30vh}}
.mk-item{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:7px 10px;border-radius:6px;border:1px solid var(--border);
  background:rgba(77,159,255,0.04);font-size:12px;
}
.mk-item.rare{border-color:#4d9fff;background:rgba(77,159,255,0.1)}
.mk-item.epic{border-color:var(--accent);background:rgba(179,102,255,0.12)}
.mk-item.legendary{border-color:var(--gold);background:rgba(255,210,77,0.12);box-shadow:0 0 8px rgba(255,210,77,0.2)}
.mk-item-info{flex:1;min-width:0}
.mk-item-name{font-weight:700;color:var(--text);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mk-item-stat{font-size:10px;color:var(--muted)}
.mk-item-price{color:var(--gold);font-weight:700;white-space:nowrap;font-size:11px}
.mk-buy{padding:4px 10px;font-size:10px;border-radius:6px;background:linear-gradient(180deg,var(--success),#2a8866);color:#000;font-weight:700;border:none;cursor:pointer}
.mk-buy:disabled{opacity:0.3;cursor:not-allowed}

.inv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:10px}
.inv-item{padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:rgba(77,159,255,0.06);display:flex;justify-content:space-between;align-items:center;font-size:12px;gap:8px}
.inv-item.rare{border-color:#4d9fff}.inv-item.epic{border-color:var(--accent)}.inv-item.legendary{border-color:var(--gold)}
.inv-item.eq{box-shadow:0 0 0 2px var(--success);background:rgba(77,255,170,0.08)}
.skill-card{padding:10px 14px;border-radius:8px;border:1px solid var(--border);background:rgba(179,102,255,0.06);margin:6px 0}
.skill-card.locked{opacity:0.4;filter:grayscale(0.8)}
.skill-name{font-family:'Cinzel',serif;font-weight:700;color:var(--accent);font-size:14px;letter-spacing:0.08em}
.skill-desc{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.4}
.stats-table{width:100%;border-collapse:collapse;margin:6px 0}
.stats-table td{padding:4px 8px;font-size:13px;border-bottom:1px solid var(--border)}
.stats-table td:first-child{color:var(--muted);font-weight:700}
.stats-table td:last-child{text-align:right;color:var(--gold);font-weight:700}
.stat-row{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border);border-radius:6px;margin:4px 0}
.stat-label{flex:1;font-weight:700}
.stat-pts{min-width:36px;text-align:right;color:var(--gold);font-weight:900;font-size:14px;letter-spacing:0.04em}
.stat-val{min-width:54px;text-align:right;color:var(--text);font-weight:900;font-size:14px;letter-spacing:0.04em}
.stat-plus{padding:4px 10px;background:var(--success);color:#000;border-radius:4px;font-weight:900;cursor:pointer}
.stat-plus:disabled{opacity:0.3;cursor:not-allowed}
.rank-box{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px;margin:10px 0;border:2px solid var(--border2);border-radius:12px;background:linear-gradient(180deg,rgba(255,210,77,0.08),rgba(179,102,255,0.06))}
.rank-label{font-family:'Cinzel',serif;font-size:11px;color:var(--muted);letter-spacing:0.15em;text-transform:uppercase}
.rank-sub{font-size:11px;color:var(--muted)}
.rank-big{font-family:'Cinzel',serif;font-weight:900;font-size:42px;padding:4px 22px;border-radius:10px;letter-spacing:0.12em;line-height:1;text-shadow:0 0 12px currentColor}
.rank-big.F{background:#666;color:#fff}.rank-big.D{background:#888;color:#fff}.rank-big.C{background:#4d9fff;color:#fff}
.rank-big.B{background:#b366ff;color:#fff}.rank-big.S{background:#ffd24d;color:#000}
.rank-big.SS{background:#ff6680;color:#fff}.rank-big.EX{background:#f33555;color:#fff}
.rank-big.GOD{background:linear-gradient(90deg,#ffd24d,#fff099,#ffd24d);color:#000}
.loc-list{display:flex;flex-direction:column;gap:4px;margin:6px 0 10px}
.loc-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;border-radius:6px;background:rgba(15,21,48,0.5);border:1px solid var(--border);font-size:12px}
.loc-row-name{display:flex;align-items:center;gap:6px;font-weight:700}
.loc-row-status{font-size:11px}
.loc-prev-info{display:flex;flex-direction:column;gap:6px;padding:12px;margin:8px 0;border:1px solid var(--border);border-radius:8px;background:rgba(15,21,48,0.5)}
.loc-prev-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}
.loc-prev-row span{color:var(--muted);letter-spacing:0.06em}
.loc-prev-row b{font-weight:900;font-size:14px}
.loc-prev-desc{font-size:11px;color:var(--muted);font-style:italic;text-align:center;margin-top:4px}
.mon-list{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0}
.mon-pill{padding:5px 12px;border-radius:14px;background:rgba(77,159,255,0.1);border:1px solid var(--border);font-size:12px;font-weight:700;display:flex;align-items:center;gap:4px}
.mon-pill.chief{background:rgba(255,210,77,0.12);border-color:var(--gold);color:var(--gold)}
.mon-pill.boss{background:rgba(243,53,85,0.15);border-color:var(--danger);color:var(--danger);font-weight:900;letter-spacing:0.08em}
.dgn-recap{padding:14px;margin:8px 0;border:2px solid var(--gold);border-radius:10px;background:linear-gradient(180deg,rgba(255,210,77,0.08),rgba(179,102,255,0.05));display:flex;flex-direction:column;gap:6px}
.dgn-recap-name{text-align:center;font-family:'Cinzel',serif;font-weight:900;font-size:18px;color:var(--gold);letter-spacing:0.08em;padding-bottom:6px;border-bottom:1px solid var(--border);margin-bottom:6px}
.dgn-recap-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}
.dgn-recap-row span{color:var(--muted)}
.dgn-loot-list{display:flex;flex-direction:column;gap:5px;margin:6px 0}
.dgn-loot-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;background:rgba(255,210,77,0.08);border:1px solid rgba(255,210,77,0.3);font-size:13px;font-weight:700}
.dgn-loot-item span:first-child{font-size:20px}
.dgn-loot-item span:nth-child(2){flex:1}
.evo-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 0}
.evo-card{padding:14px;border-radius:10px;border:2px solid var(--border);cursor:pointer;background:linear-gradient(180deg,rgba(179,102,255,0.06),rgba(77,159,255,0.04));transition:all 0.2s}
.evo-card:hover{border-color:var(--accent);box-shadow:0 0 18px rgba(179,102,255,0.4)}
.evo-name{font-family:'Cinzel',serif;font-weight:900;color:var(--gold);font-size:16px;letter-spacing:0.1em;text-align:center}
.evo-desc{font-size:12px;color:var(--text);margin-top:6px;line-height:1.4}
.npc-row{display:flex;align-items:center;gap:10px;padding:10px;border-radius:8px;border:1px solid var(--border);margin:6px 0;cursor:pointer;background:rgba(77,159,255,0.05);transition:all 0.15s}
.npc-row:hover{border-color:var(--primary);background:rgba(77,159,255,0.1)}
.npc-icon{font-size:30px;width:46px;text-align:center}
.npc-info{flex:1}
.npc-name{font-weight:700;color:var(--gold);font-size:14px;font-family:'Cinzel',serif;letter-spacing:0.08em}
.npc-state{font-size:11px;color:var(--muted);margin-top:2px}
.npc-state.todo{color:var(--gold)}.npc-state.doing{color:var(--primary)}.npc-state.reward{color:var(--success)}.npc-state.locked{color:var(--danger)}
.minion-card{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid var(--accent);background:rgba(179,102,255,0.08);border-radius:8px;margin:4px 0}
.minion-card .minion-info{flex:1;font-size:12px}

.notif-stack{position:fixed;top:90px;left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:6px;align-items:center;pointer-events:none}
.notif{
  padding:8px 18px;border-radius:18px;font-family:'Cinzel',serif;font-weight:700;
  font-size:13px;letter-spacing:0.1em;color:#fff;
  background:linear-gradient(90deg,rgba(77,159,255,0.95),rgba(179,102,255,0.95));
  box-shadow:0 4px 16px rgba(77,159,255,0.5),0 2px 6px rgba(0,0,0,0.5);
  border:1px solid rgba(255,255,255,0.2);
  animation:notifIn 0.3s ease-out,notifOut 0.5s ease-in 1.7s forwards;
}
.notif.gold{background:linear-gradient(90deg,rgba(255,210,77,0.95),rgba(204,153,51,0.95));color:#1a0d00}
.notif.danger{background:linear-gradient(90deg,rgba(243,53,85,0.95),rgba(170,21,48,0.95))}
.notif.success{background:linear-gradient(90deg,rgba(77,255,170,0.95),rgba(42,136,102,0.95));color:#001a0d}
@keyframes notifIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@keyframes notifOut{to{opacity:0;transform:translateY(-12px)}}

.save-hint{font-size:12px;color:var(--muted);margin-top:6px;text-align:center;font-style:italic;min-height:18px}
.save-hint.success{color:var(--success);font-style:normal;font-weight:700}
.save-hint.gold{color:var(--gold);font-style:normal;font-weight:700}
.code-input{
  font-size:18px;letter-spacing:0.3em;text-align:center;font-weight:700;
  background:#0a0e1f;color:var(--gold);font-family:'Cinzel',serif;
  padding:10px;border:2px solid var(--border2);border-radius:8px;width:100%;
}
.code-input:focus{border-color:var(--gold);box-shadow:0 0 14px rgba(255,210,77,0.4)}

.story-text{font-style:italic;line-height:1.7;color:#cdd6ee;font-size:14px;padding:14px;border-left:3px solid var(--accent);background:rgba(179,102,255,0.05);border-radius:0 8px 8px 0;margin:10px 0}
.story-title{font-family:'Cinzel',serif;font-weight:900;font-size:20px;color:var(--gold);text-align:center;letter-spacing:0.15em;text-shadow:0 0 12px rgba(255,210,77,0.5);margin-bottom:10px}

.loot-card{display:flex;align-items:center;gap:10px;padding:10px;border-radius:8px;border:1px solid var(--gold);background:rgba(255,210,77,0.08);margin:6px 0}
.loot-icon{font-size:28px;width:42px;text-align:center}

/* ============== SPRITE STATE MACHINE ============== */
.enemy-sprite svg{transform-origin:50% 80%;will-change:transform,filter;animation:spIdle 1.6s ease-in-out infinite}
.enemy-sprite.moving svg{animation:spWalk 0.42s ease-in-out infinite}
.enemy-sprite.attacking svg{animation:spAttack 0.32s ease-out 1}
.enemy-sprite.hit-anim svg{animation:spHit 0.18s ease-out 1;filter:brightness(2.6) drop-shadow(0 0 14px #fff) drop-shadow(0 0 8px var(--danger)) !important}
.enemy-sprite.dying svg{animation:spDeath 0.55s ease-in forwards;pointer-events:none}
.enemy-sprite.dying{pointer-events:none}
.enemy-sprite.dying .sprite-hp,.enemy-sprite.dying .sprite-vision,.enemy-sprite.dying .dot-icons{display:none}
.minion-sprite.dying{animation:minionDie 0.45s ease-in forwards;pointer-events:none}
@keyframes minionDie{0%{opacity:1}100%{opacity:0;transform:translate(-50%,-30%) scale(0.5)}}
.enemy-sprite-flip{display:inline-block;line-height:0;transform-origin:50% 50%;transition:transform 0.15s ease-out}
.enemy-sprite.face-l .enemy-sprite-flip{transform:scaleX(-1)}
@keyframes spIdle{0%,100%{transform:scaleY(1) scaleX(1) translateY(0)}50%{transform:scaleY(1.04) scaleX(0.97) translateY(-1px)}}
@keyframes spWalk{0%,100%{transform:translateY(0) rotate(-1.5deg)}50%{transform:translateY(-2.5px) rotate(1.5deg)}}
@keyframes spAttack{0%{transform:rotate(0deg) scale(1)}25%{transform:rotate(-14deg) scale(1.05) translateX(-4px)}55%{transform:rotate(18deg) scale(1.18) translateX(7px)}100%{transform:rotate(0deg) scale(1)}}
@keyframes spHit{0%{transform:translateX(0) scale(1)}25%{transform:translateX(-5px) scale(1.12)}55%{transform:translateX(5px) scale(1.08)}100%{transform:translateX(0) scale(1)}}
@keyframes spDeath{0%{opacity:1;transform:scale(1) rotate(0deg)}40%{opacity:1;transform:scale(0.92) rotate(-8deg) translateY(4px)}100%{opacity:0;transform:scale(0.4) rotate(28deg) translateY(18px)}}

/* dynamic status glows */
.enemy-sprite.engaged{filter:drop-shadow(0 0 14px rgba(243,53,85,0.55))}
.enemy-sprite.frozen svg{filter:drop-shadow(0 0 10px #66bbff) drop-shadow(0 0 18px rgba(102,187,255,0.6)) hue-rotate(170deg) brightness(0.9) saturate(0.7) !important;animation:frozenShimmer 1.4s ease-in-out infinite !important}
.enemy-sprite.burning svg{filter:drop-shadow(0 0 8px #ff6600) drop-shadow(0 0 18px rgba(255,102,0,0.55)) brightness(1.15) !important}
.enemy-sprite.poisoned svg{filter:drop-shadow(0 0 8px #66ff33) drop-shadow(0 0 14px rgba(102,255,51,0.5)) hue-rotate(60deg) saturate(1.2) !important}
.enemy-sprite.shocked svg{filter:drop-shadow(0 0 8px #ffee44) brightness(1.4) !important;animation:shockJitter 0.18s linear infinite !important}
.enemy-sprite.boss{filter:drop-shadow(0 0 22px rgba(255,210,77,0.55))}
.enemy-sprite.boss.engaged{filter:drop-shadow(0 0 26px rgba(243,53,85,0.75)) drop-shadow(0 0 14px rgba(255,80,80,0.5))}
@keyframes frozenShimmer{0%,100%{filter:drop-shadow(0 0 10px #66bbff) hue-rotate(170deg) brightness(0.9) saturate(0.7)}50%{filter:drop-shadow(0 0 18px #aaddff) hue-rotate(170deg) brightness(1.05) saturate(0.9)}}
@keyframes shockJitter{0%{transform:translate(0,0)}25%{transform:translate(-1px,1px)}50%{transform:translate(1px,-1px)}75%{transform:translate(-1px,-1px)}100%{transform:translate(0,0)}}
.enemy-sprite.burning::after{content:'';position:absolute;left:50%;top:35%;width:36px;height:36px;transform:translate(-50%,-50%);pointer-events:none;background:radial-gradient(circle,rgba(255,180,60,0.45) 0%,rgba(255,80,0,0.2) 50%,transparent 80%);border-radius:50%;animation:burnPulse 0.55s ease-in-out infinite;mix-blend-mode:screen}
@keyframes burnPulse{0%,100%{opacity:0.6;transform:translate(-50%,-50%) scale(0.85)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}}

/* blood particles */
.blood{position:absolute;width:5px;height:5px;border-radius:50%;pointer-events:none;z-index:44;will-change:left,top,opacity;transform:translate(-50%,-50%);background:radial-gradient(circle,#ff3344 0%,#aa0a18 60%,#5a040a 100%);box-shadow:0 0 3px rgba(170,10,24,0.6)}
.blood-splat{position:absolute;pointer-events:none;z-index:14;transform:translate(-50%,-50%);width:36px;height:18px;border-radius:50%;background:radial-gradient(ellipse,rgba(140,8,18,0.85) 0%,rgba(90,4,10,0.6) 55%,transparent 80%);filter:blur(0.5px);animation:bloodSplatFade 3s ease-out forwards;mix-blend-mode:multiply}
@keyframes bloodSplatFade{0%{opacity:0;transform:translate(-50%,-50%) scale(0.4)}15%{opacity:0.9;transform:translate(-50%,-50%) scale(1)}80%{opacity:0.85}100%{opacity:0;transform:translate(-50%,-50%) scale(1)}}

/* projectile trails */
.proj-trail{position:absolute;pointer-events:none;z-index:39;transform:translate(-50%,-50%);will-change:opacity;animation:trailFade 0.28s linear forwards}
@keyframes trailFade{0%{opacity:0.65}100%{opacity:0}}

/* local arena shake (entity sprites only) */
.arena.shake-local .enemy-sprite,.arena.shake-local .minion-sprite,.arena.shake-local .player-sprite{animation:localShake 0.2s linear 1}
.arena.shake-local-big .enemy-sprite,.arena.shake-local-big .minion-sprite,.arena.shake-local-big .player-sprite{animation:localShakeBig 0.4s linear 1}
@keyframes localShake{0%,100%{transform:translate(-50%,-50%)}25%{transform:translate(calc(-50% - 4px),calc(-50% + 2px))}50%{transform:translate(calc(-50% + 3px),calc(-50% - 2px))}75%{transform:translate(calc(-50% - 2px),calc(-50% + 3px))}}
@keyframes localShakeBig{0%,100%{transform:translate(-50%,-50%)}15%{transform:translate(calc(-50% - 12px),calc(-50% + 6px))}30%{transform:translate(calc(-50% + 10px),calc(-50% - 7px))}50%{transform:translate(calc(-50% - 8px),calc(-50% + 9px))}70%{transform:translate(calc(-50% + 9px),calc(-50% - 5px))}85%{transform:translate(calc(-50% - 4px),calc(-50% + 3px))}}

/* dmg num variants (DoT + stacked) */
.dmg-num.burn{color:#ff7733;text-shadow:0 0 6px #ff6600,0 0 12px rgba(255,102,0,0.55),0 2px 4px #000}
.dmg-num.freeze{color:#aaddff;text-shadow:0 0 6px #66bbff,0 0 12px rgba(102,187,255,0.55),0 2px 4px #000}
.dmg-num.poison{color:#88ff55;text-shadow:0 0 6px #66ff33,0 0 12px rgba(102,255,51,0.55),0 2px 4px #000}
.dmg-num.shock{color:#ffee44;text-shadow:0 0 6px #ffee44,0 0 12px rgba(255,238,68,0.55),0 2px 4px #000}
.dmg-num.bleed{color:#ff5566;text-shadow:0 0 6px #cc1122,0 0 12px rgba(204,17,34,0.55),0 2px 4px #000}
.dmg-num.curse{color:#cc99ff;text-shadow:0 0 6px #aa66ff,0 0 12px rgba(170,102,255,0.55),0 2px 4px #000}
.dmg-num.plague{color:#aacc33;text-shadow:0 0 6px #88aa22,0 0 12px rgba(136,170,34,0.55),0 2px 4px #000}
.dmg-num.crit{animation:dmgCrit 1s ease-out forwards;font-size:26px;color:#ff3355;text-shadow:0 0 8px #ff3355,0 0 16px rgba(255,51,85,0.6),0 2px 4px #000}
@keyframes dmgCrit{0%{opacity:0;transform:translate(-50%,0) scale(0.5) rotate(-6deg)}15%{opacity:1;transform:translate(-50%,-14px) scale(1.35) rotate(4deg)}100%{opacity:0;transform:translate(-50%,-72px) scale(1.05) rotate(-2deg)}}
.dmg-stack{position:absolute;font-family:'Cinzel',serif;font-weight:900;font-size:11px;top:-8px;right:-16px;color:#ffd24d;text-shadow:0 0 4px #000,0 1px 2px #000}

/* ============== BOSS CINEMATIC ============== */
.cine-root{position:absolute;inset:0;z-index:90;pointer-events:none;overflow:hidden}
.cine-tension{position:absolute;inset:0;background:#000;opacity:0;transition:opacity 1.2s ease-in;z-index:91}
.cine-tension.on{opacity:0.93}
.cine-redglow{position:absolute;left:50%;top:50%;width:60px;height:60px;border-radius:50%;transform:translate(-50%,-50%);z-index:92;pointer-events:none;opacity:0;transition:width 1.5s ease-out,height 1.5s ease-out,opacity 1.2s,filter 0.5s;filter:blur(0)}
.cine-redglow.on{width:720px;height:720px;opacity:1;animation:redGlowPulse 0.9s ease-in-out infinite alternate}
@keyframes redGlowPulse{0%{filter:blur(2px) brightness(1)}100%{filter:blur(8px) brightness(1.35)}}
.cine-flash{position:absolute;inset:0;background:#fff;opacity:0;z-index:96;pointer-events:none;mix-blend-mode:screen}
.cine-flash.on{animation:cineFlash 0.32s ease-out forwards}
@keyframes cineFlash{0%{opacity:1}100%{opacity:0}}
.cine-shockwave{position:absolute;left:50%;top:50%;width:60px;height:60px;border-radius:50%;border:8px solid #fff;box-shadow:0 0 30px rgba(255,255,255,0.9),0 0 80px rgba(255,200,200,0.65);transform:translate(-50%,-50%) scale(0.1);opacity:0;z-index:95;pointer-events:none}
.cine-shockwave.on{animation:cineShock 0.8s ease-out forwards}
@keyframes cineShock{0%{transform:translate(-50%,-50%) scale(0.1);opacity:1;border-width:10px}40%{opacity:0.9}100%{transform:translate(-50%,-50%) scale(40);opacity:0;border-width:1px}}
.cine-dust{position:absolute;width:4px;height:4px;background:radial-gradient(circle,#999 0%,#222 70%,transparent 100%);border-radius:50%;pointer-events:none;z-index:93;opacity:0;transform:translate(-50%,-50%)}
.cine-dust.on{animation:dustRise 2.6s linear forwards}
@keyframes dustRise{0%{opacity:0;transform:translate(-50%,-50%) translateY(0)}20%{opacity:0.7}100%{opacity:0;transform:translate(-50%,-50%) translateY(-200px)}}
.cine-particles{position:absolute;inset:0;pointer-events:none;z-index:94;overflow:hidden}
.cine-particle{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--bossColor,#f33555);box-shadow:0 0 6px var(--bossColor,#f33555);pointer-events:none;will-change:transform,opacity,left,top;transform:translate(-50%,-50%)}
.cine-tinytext{position:absolute;left:50%;bottom:18%;transform:translateX(-50%);color:#888;font-family:'Cinzel',serif;font-style:italic;font-size:24px;letter-spacing:0.6em;z-index:97;text-shadow:0 1px 4px #000;opacity:0;transition:opacity 0.4s;pointer-events:none}
.cine-tinytext.on{opacity:1}
.cine-typewriter{position:absolute;left:50%;bottom:28%;transform:translateX(-50%);color:#cdd6ee;font-family:'Cinzel',serif;font-style:italic;font-size:clamp(18px,2.4vw,26px);letter-spacing:0.12em;z-index:97;text-shadow:0 0 10px #000,0 2px 4px #000;opacity:0;transition:opacity 0.3s;max-width:80vw;text-align:center;pointer-events:none}
.cine-typewriter.on{opacity:1}
.cine-bossname{position:absolute;left:50%;top:34%;transform:translate(-50%,-50%) scale(3);color:var(--bossColor,#f33555);font-family:'Cinzel',serif;font-weight:900;font-size:clamp(42px,7.5vw,76px);letter-spacing:0.36em;z-index:98;opacity:0;text-align:center;text-transform:uppercase;white-space:nowrap;pointer-events:none}
.cine-bossname.on{animation:bossNameIn 0.6s cubic-bezier(0.2,0.8,0.4,1.1) forwards}
@keyframes bossNameIn{0%{opacity:0;transform:translate(-50%,-50%) scale(3);text-shadow:0 0 0 var(--bossColor,#f33555),0 0 0 #000}60%{opacity:1;transform:translate(-50%,-50%) scale(0.95);text-shadow:0 0 30px var(--bossColor,#f33555),0 0 60px rgba(0,0,0,0.9),0 4px 8px #000}100%{opacity:1;transform:translate(-50%,-50%) scale(1);text-shadow:0 0 24px var(--bossColor,#f33555),0 0 50px rgba(0,0,0,0.85),0 4px 8px #000}}
.cine-bossname.out{animation:bossNameOut 0.5s ease-in forwards}
@keyframes bossNameOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(0.7)}}
.cine-bosslv{position:absolute;left:50%;top:44%;transform:translateX(-50%);color:#ffd24d;font-family:'Cinzel',serif;font-weight:700;font-size:22px;letter-spacing:0.3em;z-index:98;opacity:0;transition:opacity 0.4s;text-shadow:0 0 14px rgba(255,210,77,0.75),0 2px 4px #000;pointer-events:none}
.cine-bosslv.on{opacity:1}
.cine-bosstitle{position:absolute;left:50%;top:50%;transform:translateX(-50%);color:var(--bossColor,#f33555);font-family:'Cinzel',serif;font-weight:700;font-style:italic;font-size:18px;letter-spacing:0.28em;z-index:98;opacity:0;transition:opacity 0.5s;text-shadow:0 0 12px var(--bossColor,#f33555),0 2px 4px #000;pointer-events:none;text-transform:uppercase;white-space:nowrap}
.cine-bosstitle.on{opacity:1}
.cine-bossquote{position:absolute;left:50%;top:34%;transform:translate(-50%,-50%);color:#e5dabb;font-family:'Cinzel',serif;font-style:italic;font-size:clamp(20px,2.6vw,30px);letter-spacing:0.1em;z-index:98;opacity:0;transition:opacity 0.4s;text-shadow:0 0 16px #000,0 2px 6px #000;max-width:88vw;text-align:center;pointer-events:none}
.cine-bossquote.on{opacity:1}
.cine-combat{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(4) rotate(-15deg);color:#f33555;font-family:'Cinzel',serif;font-weight:900;font-size:clamp(68px,11vw,148px);letter-spacing:0.3em;z-index:99;opacity:0;text-shadow:0 0 40px #f33555,0 0 80px rgba(243,53,85,0.7),0 0 14px #000,0 4px 14px #000;text-align:center;pointer-events:none}
.cine-combat.on{animation:combatIn 0.5s cubic-bezier(0.3,0.9,0.4,1.05) forwards}
@keyframes combatIn{0%{opacity:0;transform:translate(-50%,-50%) scale(4) rotate(-15deg)}100%{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(0deg)}}
.cine-combat.out{animation:combatOut 0.4s ease-in forwards}
@keyframes combatOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(0deg)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.6) rotate(8deg)}}
.cine-skip{position:absolute;right:18px;bottom:18px;z-index:99;padding:8px 18px;border-radius:18px;font-family:'Cinzel',serif;font-weight:700;font-size:12px;letter-spacing:0.14em;color:rgba(255,255,255,0.78);background:rgba(0,0,0,0.55);border:1px solid rgba(255,255,255,0.3);cursor:pointer;pointer-events:auto;opacity:0;transition:opacity 0.4s,color 0.2s,background 0.2s;text-transform:uppercase}
.cine-skip.on{opacity:0.85}
.cine-skip:hover{opacity:1;color:#fff;background:rgba(40,40,40,0.85);border-color:rgba(255,255,255,0.55)}

.enemy-sprite.boss-cine-in{opacity:0;transform:translate(-50%,-50%) scale(0.1);transition:opacity 0.85s ease-out,transform 0.95s cubic-bezier(0.2,0.6,0.3,1.4)}
.enemy-sprite.boss-cine-in.appear{opacity:1;transform:translate(-50%,-50%) scale(1.25)}
.enemy-sprite.boss-cine-in.pose{transform:translate(-50%,-50%) scale(1.4)}
.enemy-sprite.boss-aura{animation:bossAuraPulse 1.6s ease-in-out infinite}
@keyframes bossAuraPulse{0%,100%{filter:drop-shadow(0 0 22px var(--bossColor,#f33555))}50%{filter:drop-shadow(0 0 40px var(--bossColor,#f33555)) drop-shadow(0 0 70px var(--bossColor,#f33555))}}

.boss-hp-bar.cine-enter{transform:translateX(-50%) translateY(60px);opacity:0;transition:opacity 0.6s,transform 0.6s cubic-bezier(0.3,0.8,0.4,1.1)}
.boss-hp-bar.cine-enter.in{transform:translateX(-50%) translateY(0);opacity:1}

/* ============== BOSS VICTORY CINEMATIC ============== */
.cine-tension.victory{background:radial-gradient(ellipse at center,rgba(30,16,4,0.85) 0%,rgba(0,0,0,0.95) 75%)}
.cine-victoryglow{position:absolute;left:50%;top:50%;width:60px;height:60px;border-radius:50%;transform:translate(-50%,-50%);z-index:92;pointer-events:none;opacity:0;transition:width 1.2s ease-out,height 1.2s ease-out,opacity 1s;background:radial-gradient(circle,#fff8e0 0%,#ffd24daa 28%,#aa770044 58%,transparent 85%)}
.cine-victoryglow.on{width:760px;height:760px;opacity:0.95;animation:victoryGlowPulse 1.4s ease-in-out infinite alternate}
@keyframes victoryGlowPulse{0%{filter:blur(2px) brightness(1)}100%{filter:blur(7px) brightness(1.3)}}
.cine-flash.gold{background:radial-gradient(ellipse,#fff8d0 0%,#ffe066 50%,#ffd24d 80%,transparent 100%);mix-blend-mode:screen}
.cine-shockwave.gold{border-color:#ffd24d;box-shadow:0 0 38px rgba(255,210,77,0.95),0 0 100px rgba(255,210,77,0.65)}
.cine-vainqu{position:absolute;left:50%;top:42%;transform:translate(-50%,-50%) scale(4) rotate(-22deg);color:#f33555;font-family:'Cinzel',serif;font-weight:900;font-size:clamp(64px,11vw,140px);letter-spacing:0.16em;z-index:98;opacity:0;text-align:center;text-shadow:0 0 34px #ff3355,0 0 80px rgba(243,53,85,0.65),0 0 14px #000,0 4px 16px #000;pointer-events:none;text-transform:uppercase}
.cine-vainqu.on{animation:vainquIn 0.55s cubic-bezier(0.2,0.9,0.3,1.1) forwards}
@keyframes vainquIn{0%{opacity:0;transform:translate(-50%,-50%) scale(4) rotate(-22deg)}60%{opacity:1;transform:translate(-50%,-50%) scale(0.95) rotate(-6deg)}100%{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(-8deg)}}
.cine-vainqu.out{animation:vainquOut 0.45s ease-in forwards}
@keyframes vainquOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(-8deg)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.5) rotate(2deg)}}
.cine-bossname.victory{top:28%;color:#bbb;letter-spacing:0.32em;text-shadow:0 0 18px rgba(170,170,170,0.6),0 0 12px #000,0 2px 6px #000;text-decoration:line-through;text-decoration-color:#f33555;text-decoration-thickness:0.08em}
.cine-typewriter.victory{bottom:auto;top:58%;color:#ccc;font-size:clamp(18px,2.3vw,24px)}
.cine-victoire{position:absolute;left:50%;top:42%;transform:translate(-50%,-50%) scale(4);color:#ffd24d;font-family:'Cinzel',serif;font-weight:900;font-size:clamp(68px,12vw,156px);letter-spacing:0.32em;z-index:99;opacity:0;text-align:center;text-shadow:0 0 42px #ffd24d,0 0 100px rgba(255,210,77,0.75),0 0 18px #000,0 4px 20px #000;pointer-events:none;text-transform:uppercase;white-space:nowrap}
.cine-victoire.on{animation:victoireIn 0.6s cubic-bezier(0.25,0.85,0.35,1.1) forwards}
@keyframes victoireIn{0%{opacity:0;transform:translate(-50%,-50%) scale(4)}55%{opacity:1;transform:translate(-50%,-50%) scale(0.9)}100%{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.cine-victoire.out{animation:victoireOut 0.5s ease-in forwards}
@keyframes victoireOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(0.65)}}
.cine-loctitle{position:absolute;left:50%;top:56%;transform:translateX(-50%);color:#fff099;font-family:'Cinzel',serif;font-weight:700;font-style:italic;font-size:clamp(18px,2.4vw,26px);letter-spacing:0.28em;z-index:99;opacity:0;transition:opacity 0.5s;text-shadow:0 0 14px rgba(255,240,153,0.8),0 2px 6px #000;pointer-events:none;text-transform:uppercase;max-width:90vw;text-align:center}
.cine-loctitle.on{opacity:1}
.cine-loctitle.out{opacity:0}
.enemy-sprite.boss-victory-glow{filter:drop-shadow(0 0 36px #ffd24d) drop-shadow(0 0 80px rgba(255,210,77,0.75)) brightness(1.4) !important;animation:bossVictoryHalo 1.3s ease-in-out infinite alternate}
@keyframes bossVictoryHalo{0%{filter:drop-shadow(0 0 24px #ffd24d) drop-shadow(0 0 60px rgba(255,210,77,0.55)) brightness(1.2)}100%{filter:drop-shadow(0 0 44px #fff8d0) drop-shadow(0 0 100px rgba(255,210,77,0.9)) brightness(1.6)}}
