/* ===== 미드나잇 리퍼 — 망령의 추수 ===== */
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#0a0a16; --bg2:#12101f; --ink:#e8e6f5; --dim:#9a96b8;
  --gold:#ffd23f; --blood:#e0345a; --moon:#a9c7ff; --soul:#7be0c8;
  --line:rgba(255,255,255,.10); --panel:#15131f;
  --pixel:'Courier New',ui-monospace,monospace;
}
html,body{margin:0;height:100%;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Apple SD Gothic Neo",system-ui,sans-serif;
  overflow:hidden;overscroll-behavior:none;user-select:none}
body{display:flex;flex-direction:column}
.hidden{display:none!important}
b{font-weight:800}

/* topbar */
#topbar{flex:0 0 auto;display:flex;align-items:center;gap:10px;height:42px;padding:0 12px;
  background:linear-gradient(180deg,#100e1c,#0a0a16);border-bottom:1px solid var(--line);
  font-size:13px;z-index:30}
#topbar .back{color:var(--dim);text-decoration:none;font-weight:700}
#topbar .back:hover{color:#fff}
#topbar .brand{font-weight:800;letter-spacing:-.01em}
#topbar .hs{margin-left:auto;color:var(--dim);font-size:12px}
#topbar .hs b{color:var(--gold)}

/* stage */
#stage{position:relative;flex:1 1 auto;overflow:hidden}
#game{position:absolute;inset:0;width:100%;height:100%;display:block;
  image-rendering:pixelated;image-rendering:crisp-edges;background:#06060e;touch-action:none}

/* ===== in-game HUD ===== */
#hud{position:absolute;inset:0;pointer-events:none;z-index:10;
  font-family:var(--pixel);font-weight:700}
#xpbar{position:absolute;top:0;left:0;right:0;height:14px;background:#0c0b18;
  border-bottom:1px solid #2a2740}
#xpfill{height:100%;width:0;background:linear-gradient(90deg,#4f7bff,#8ad0ff);
  transition:width .15s ease;box-shadow:0 0 8px #4f7bff}
#xptext{position:absolute;top:0;left:50%;transform:translateX(-50%);font-size:10px;
  line-height:14px;color:#dfe8ff;text-shadow:0 1px 2px #000;letter-spacing:1px}
#topstats{position:absolute;top:18px;left:8px;right:8px;display:flex;align-items:center;gap:8px;
  font-size:13px;text-shadow:0 1px 3px #000}
#topstats .stat{background:rgba(8,8,18,.55);padding:3px 8px;border-radius:8px;border:1px solid var(--line)}
#sTime{color:#fff;letter-spacing:1px}
#sKills{color:#ff97ad}
#sGold{color:var(--gold)}
#topstats .iconbtn{margin-left:0}
#topstats #pauseBtn{margin-left:auto}
.iconbtn{pointer-events:auto;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);
  background:rgba(8,8,18,.6);color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.iconbtn:active{transform:scale(.92)}
#hpwrap{position:absolute;left:8px;bottom:8px;width:min(46%,220px);height:18px;background:#1a0b12;
  border:1px solid #4a1f2c;border-radius:9px;overflow:hidden}
#hpfill{height:100%;width:100%;background:linear-gradient(90deg,#e0345a,#ff6f8b);
  transition:width .12s linear;box-shadow:inset 0 0 6px rgba(0,0,0,.4)}
#hptext{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:11px;color:#fff;text-shadow:0 1px 2px #000;letter-spacing:.5px}
#weaponDock{position:absolute;right:8px;bottom:8px;display:flex;flex-wrap:wrap;gap:4px;
  max-width:54%;justify-content:flex-end}
.wslot{width:30px;height:30px;border-radius:7px;background:rgba(8,8,18,.6);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:16px;position:relative}
.wslot.passive{border-color:rgba(123,224,200,.4)}
.wslot small{position:absolute;right:-2px;bottom:-3px;font-size:9px;background:#000;color:var(--gold);
  border-radius:5px;padding:0 3px;line-height:12px;border:1px solid var(--line)}
.wslot.max{border-color:var(--gold);box-shadow:0 0 7px rgba(255,210,63,.4)}

/* joystick */
#stick{position:absolute;inset:0;z-index:9;pointer-events:none}
#stickbase{position:absolute;width:108px;height:108px;border-radius:50%;
  background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.18);display:none}
#sticknub{position:absolute;left:50%;top:50%;width:46px;height:46px;margin:-23px 0 0 -23px;
  border-radius:50%;background:rgba(169,199,255,.32);border:1.5px solid rgba(169,199,255,.6)}

/* ===== screens ===== */
.screen{position:absolute;inset:0;z-index:20;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:20px;text-align:center;overflow:auto}
.screen:not(.overlayscreen){background:
  radial-gradient(120% 80% at 50% 0%,#161227 0%,#0a0a16 60%,#06060e 100%)}
.overlayscreen{background:rgba(5,5,12,.82);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}

.menu-card{max-width:460px;width:100%;background:linear-gradient(180deg,#16131f,#100e1a);
  border:1px solid var(--line);border-radius:20px;padding:26px 22px;
  box-shadow:0 24px 70px rgba(0,0,0,.6)}
.logo{font-size:54px;filter:drop-shadow(0 0 18px rgba(169,199,255,.45));margin-bottom:4px}
h1{margin:0 0 6px;font-size:30px;font-weight:900;letter-spacing:-.02em;line-height:1.05}
h1 small{display:block;font-size:13px;font-weight:700;color:var(--moon);letter-spacing:.18em;margin-top:6px}
.tag{color:var(--dim);font-size:13.5px;line-height:1.7;margin:8px 0 16px}
.tag b{color:var(--soul)}
.feats{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-bottom:18px}
.feats span{font-size:11.5px;color:#cfd0e8;background:rgba(255,255,255,.05);
  border:1px solid var(--line);border-radius:20px;padding:5px 11px}
.btn{display:block;width:100%;margin:8px 0 0;padding:13px 18px;border-radius:12px;border:0;
  font-weight:800;font-size:15px;cursor:pointer;transition:transform .12s,filter .2s;
  font-family:inherit;color:#0a0a16;background:linear-gradient(180deg,#a9c7ff,#6f9bff)}
.btn:active{transform:translateY(1px) scale(.99)}
.btn:hover{filter:brightness(1.06)}
.btn.big{font-size:17px;padding:15px;box-shadow:0 8px 22px rgba(111,155,255,.32)}
.btn.ghost{background:rgba(255,255,255,.06);color:var(--ink);border:1px solid var(--line)}
.btn.sm{width:auto;padding:9px 18px;margin:14px auto 0;font-size:13px}
.hint{margin:16px 0 0;font-size:11px;color:#6f6b8c;line-height:1.6}
.hint b{color:#9a96b8}

.selhead{font-size:24px;font-weight:900;margin:0 0 4px;letter-spacing:-.01em}

/* character select */
.charrow{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;
  width:100%;max-width:680px;margin:14px 0}
.charpick{background:linear-gradient(180deg,#181426,#110f1c);border:1px solid var(--line);
  border-radius:16px;padding:16px 13px;cursor:pointer;color:var(--ink);text-align:center;
  transition:transform .12s,border-color .2s;font-family:inherit;position:relative;overflow:hidden}
.charpick:hover{transform:translateY(-3px);border-color:rgba(169,199,255,.5)}
.charpick.locked{opacity:.55;cursor:not-allowed}
.charpick .cav{width:64px;height:64px;margin:0 auto 8px;image-rendering:pixelated}
.charpick h3{margin:0 0 3px;font-size:17px;font-weight:800}
.charpick .crole{font-size:11px;color:var(--moon);margin-bottom:7px;letter-spacing:.05em}
.charpick .cdesc{font-size:11.5px;color:var(--dim);line-height:1.55;min-height:48px}
.charpick .cstats{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;margin-top:9px}
.charpick .cstats span{font-size:10px;background:rgba(255,255,255,.06);border-radius:10px;
  padding:3px 7px;color:#cdd0e6}
.charpick .lockbadge{position:absolute;inset:0;display:flex;flex-direction:column;gap:6px;
  align-items:center;justify-content:center;background:rgba(8,8,16,.7);font-size:13px;font-weight:800}
.charpick .lockbadge .pr{color:var(--gold)}

/* altar */
.altartop{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;justify-content:center}
.altargold{font-size:14px;color:var(--dim)}.altargold b{color:var(--gold)}
.altarsub{color:var(--dim);font-size:12.5px;margin:6px 0 14px;max-width:520px}
.altargrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;
  width:100%;max-width:720px}
.altaritem{background:linear-gradient(180deg,#181426,#110f1c);border:1px solid var(--line);
  border-radius:14px;padding:13px;text-align:left}
.altaritem h4{margin:0 0 4px;font-size:14px;display:flex;align-items:center;gap:6px}
.altaritem p{margin:0 0 8px;font-size:11px;color:var(--dim);line-height:1.5}
.altaritem .pips{display:flex;gap:3px;margin-bottom:9px}
.altaritem .pip{width:14px;height:6px;border-radius:3px;background:#2a2740}
.altaritem .pip.on{background:var(--soul);box-shadow:0 0 5px var(--soul)}
.altaritem .buy{width:100%;padding:8px;border-radius:9px;border:0;font-weight:800;cursor:pointer;
  font-family:inherit;font-size:12.5px;background:linear-gradient(180deg,#ffe27a,#ffc83f);color:#241a00}
.altaritem .buy:disabled{background:#2a2740;color:#6f6b8c;cursor:default}
.altaritem .buy.maxed{background:rgba(123,224,200,.18);color:var(--soul)}

/* level up */
.levelpanel{max-width:640px;width:100%;background:linear-gradient(180deg,#16131f,#100e1a);
  border:1px solid var(--line);border-radius:20px;padding:22px 18px;box-shadow:0 24px 70px rgba(0,0,0,.6)}
.levelpanel h2{margin:0 0 14px;font-size:24px;font-weight:900;color:var(--gold);
  text-shadow:0 0 18px rgba(255,210,63,.4)}
.levelcards{display:grid;grid-template-columns:1fr;gap:10px}
.lvcard{display:flex;align-items:center;gap:13px;text-align:left;background:linear-gradient(90deg,#1b1729,#141121);
  border:1px solid var(--line);border-radius:14px;padding:12px 14px;cursor:pointer;
  transition:transform .1s,border-color .15s;color:var(--ink);font-family:inherit}
.lvcard:hover{transform:translateX(3px);border-color:rgba(169,199,255,.5)}
.lvcard .lvico{width:44px;height:44px;flex:0 0 44px;border-radius:11px;display:flex;align-items:center;
  justify-content:center;font-size:24px;background:rgba(255,255,255,.05);border:1px solid var(--line)}
.lvcard.evolve .lvico{background:linear-gradient(180deg,#ffd23f,#ff8a3f);border-color:var(--gold);
  box-shadow:0 0 14px rgba(255,170,63,.5)}
.lvcard .lvbody{flex:1;min-width:0}
.lvcard .lvname{font-size:15px;font-weight:800;display:flex;align-items:center;gap:7px}
.lvcard .lvlv{font-size:10px;font-weight:800;padding:1px 6px;border-radius:8px;background:rgba(255,255,255,.08);color:var(--moon)}
.lvcard.evolve .lvlv{background:var(--gold);color:#241a00}
.lvcard.isnew .lvlv{background:var(--soul);color:#04201a}
.lvcard .lvdesc{font-size:11.5px;color:var(--dim);line-height:1.5;margin-top:3px}
.levelextra{display:flex;gap:8px;justify-content:center;margin-top:13px}
.levelextra .xbtn{flex:1;max-width:160px;padding:9px;border-radius:10px;border:1px solid var(--line);
  background:rgba(255,255,255,.05);color:var(--ink);font-weight:700;cursor:pointer;font-family:inherit;font-size:12.5px}
.levelextra .xbtn:disabled{opacity:.4;cursor:default}
.levelextra .xbtn b{color:var(--gold)}

.chestbody{font-size:14px;line-height:2;margin:10px 0 18px;min-height:80px}
.chestbody .ci{display:flex;align-items:center;gap:10px;justify-content:center}
.chestbody .ci .e{font-size:22px}

.pausestats,.overstats{font-size:13px;color:var(--dim);line-height:1.9;margin:6px 0 14px}
.pausestats b,.overstats b{color:var(--ink)}
#overScoreWrap{margin:6px 0 16px}
#overScoreWrap span{display:block;font-size:12px;color:var(--dim);letter-spacing:.1em}
#overScoreWrap b{font-size:42px;color:var(--gold);font-weight:900;text-shadow:0 0 20px rgba(255,210,63,.4)}

#toast{position:absolute;left:50%;top:54px;transform:translateX(-50%);z-index:40;
  background:rgba(10,10,20,.92);border:1px solid var(--line);border-radius:11px;
  padding:9px 16px;font-size:13px;font-weight:700;pointer-events:none;
  box-shadow:0 8px 24px rgba(0,0,0,.5);transition:opacity .25s}

@media(max-width:560px){
  h1{font-size:26px}.logo{font-size:46px}
  .levelcards{grid-template-columns:1fr}
}
@media(min-width:620px){ .levelcards{grid-template-columns:1fr 1fr} }
