/* 8-bit Ragnarok Idle - styles */
:root{
  --bg:#0e0820;
  --bg2:#1a1030;
  --panel:#221842;
  --panel2:#2c1f54;
  --ink:#e9e3ff;
  --ink-dim:#9a8fc9;
  --gold:#f5c542;
  --gem:#7ff5e7;
  --hp:#e5455e;
  --sp:#3aa9ff;
  --exp:#9af542;
  --bd:#000;
  --accent:#b072ff;
  --accent2:#ff8c2b;
  --pixel: 'Press Start 2P','Courier New',monospace;
}
*{box-sizing:border-box;margin:0;padding:0;font-family:var(--pixel);image-rendering:pixelated}
html,body{height:100%;background:var(--bg);color:var(--ink);overflow:hidden;-webkit-tap-highlight-color:transparent;user-select:none}
button{font-family:var(--pixel);cursor:pointer}
.hidden{display:none!important}

#app{display:flex;flex-direction:column;height:100vh;max-width:640px;margin:0 auto;background:var(--bg2);box-shadow:0 0 24px #000;overflow-x:hidden}

/* TOPBAR */
#topbar{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:linear-gradient(180deg,#382080,#1a0f44);border-bottom:3px solid #000;font-size:11px}
.hero-info{display:flex;flex-direction:column;gap:4px}
#hero-name{font-size:14px;color:var(--gold);text-shadow:1px 1px 0 #000}
.badge{display:inline-block;background:#000;color:var(--ink);padding:2px 6px;font-size:10px;border:1px solid var(--accent)}
.badge.lvl{color:var(--exp);border-color:var(--exp)}
.badge.diff{margin-left:6px;color:var(--accent2);border-color:var(--accent2)}
.resources{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.res{display:flex;gap:6px;align-items:center;font-size:11px}
.res.zeny i{display:inline-block;width:10px;height:10px;background:var(--gold);box-shadow:inset -2px -2px 0 #8c6b00;border:1px solid #000}
.res.gem i{display:inline-block;width:10px;height:10px;background:var(--gem);transform:rotate(45deg);border:1px solid #000}

/* SCREEN HOST */
#screen-host{flex:1;overflow-y:auto;padding:10px;-webkit-overflow-scrolling:touch}
.screen{display:flex;flex-direction:column;gap:10px}
h2{font-size:16px;color:var(--gold);text-shadow:1px 1px 0 #000;margin:6px 0}
h3{font-size:13px;color:var(--ink-dim);margin:8px 0 4px}
.hint{color:var(--ink-dim);font-size:10px;margin-left:6px}

/* CARD */
.card{background:var(--panel);border:2px solid #000;box-shadow:0 3px 0 #000, inset 0 0 0 2px var(--panel2);padding:8px;display:flex;flex-direction:column;gap:4px}
.row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;border-bottom:1px dashed #3a2a6a}
.row:last-child{border-bottom:none}
.row span{color:var(--ink-dim)}
.row b{color:var(--ink)}

/* BATTLE */
.stage-header{display:flex;justify-content:space-between;background:var(--panel);border:2px solid #000;padding:6px 8px;align-items:center}
.stage-title{font-size:13px;color:var(--gold)}
.stage-sub{font-size:10px;color:var(--ink-dim);margin-top:2px}
.stage-actions{display:flex;gap:4px}

.arena{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;overflow:hidden;background:linear-gradient(180deg,#1f1648 0%,#3a2473 70%,#1a0f44 100%);border:2px solid #000;padding:18px 10px;height:360px;position:relative}
.arena::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent 0,transparent 12px,rgba(255,255,255,0.02) 12px,rgba(255,255,255,0.02) 13px);pointer-events:none}
.combatant{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;z-index:1}
.vs{font-size:10px;color:var(--accent2);text-shadow:1px 1px 0 #000;z-index:1;flex-shrink:0}
/* Mobs area: fixed height, no wrapping. Slots are pre-allocated per difficulty.
   data-slots="N" controls the layout via attribute selectors. */
.mobs-area{display:flex;flex-wrap:nowrap;align-items:center;justify-content:center;gap:4px;z-index:1;height:100%;overflow:hidden}
.mobs-area .mob-slot{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1 1 0;min-width:0}
/* Sprite + bar sizes based on slot count */
.mobs-area[data-slots="1"] .mob-slot .sprite{width:180px;height:260px}
.mobs-area[data-slots="1"] .mob-slot .bar{width:160px}
.mobs-area[data-slots="2"] .mob-slot .sprite{width:140px;height:220px}
.mobs-area[data-slots="2"] .mob-slot .bar{width:125px}
.mobs-area[data-slots="3"] .mob-slot .sprite{width:110px;height:190px}
.mobs-area[data-slots="3"] .mob-slot .bar{width:100px}
.mobs-area[data-slots="4"] .mob-slot .sprite{width:88px;height:160px}
.mobs-area[data-slots="4"] .mob-slot .bar{width:82px}
.mobs-area[data-slots="5"] .mob-slot .sprite{width:74px;height:140px}
.mobs-area[data-slots="5"] .mob-slot .bar{width:68px}
.mobs-area[data-slots="6"] .mob-slot .sprite{width:64px;height:120px}
.mobs-area[data-slots="6"] .mob-slot .bar{width:60px}
/* Sprite box grew to 180x200 so tall mobs + crowned heads don't clip at the top.
   Canvases set an intrinsic size in JS — we allow them to display at full size
   (up to 220px) rather than scaling down to the container. */
.sprite{width:180px;height:200px;background:transparent;border:none;image-rendering:pixelated;position:relative;background-size:contain;background-repeat:no-repeat;background-position:center;display:flex;align-items:center;justify-content:center;overflow:hidden}
/* Hero sprite may overflow slightly upward for tall headgear — visible; mob is clipped. */
.combatant:first-child .sprite{overflow:visible}
.sprite canvas, .sprite img{image-rendering:pixelated;max-width:180px;max-height:200px}
/* fallback hint when no sprite yet */
.sprite.no-sprite::before{content:'?';color:#3a2a6a;font-size:32px;opacity:.5}
.combatant.hit{animation:hit .25s}
.combatant.attack{animation:attack .2s}
@keyframes hit{0%,100%{transform:translateX(0);filter:none}25%{transform:translateX(-4px);filter:brightness(2) saturate(0)}75%{transform:translateX(4px)}}
@keyframes attack{0%{transform:translateY(0)}50%{transform:translateY(-6px)}100%{transform:translateY(0)}}
.dmg-popup{position:absolute;top:-4px;left:50%;font-size:14px;color:#fff;text-shadow:2px 2px 0 #000,1px 1px 0 var(--hp);animation:rise 1s forwards;pointer-events:none;z-index:5}
.dmg-popup.crit{color:var(--gold);font-size:18px}
.dmg-popup.miss{color:#aaa}
.dmg-popup.heal{color:var(--exp)}
/* GRF sprite-based damage numbers — canvas child, no text styling needed */
.dmg-popup.dmg-sprite{font-size:0;text-shadow:none;line-height:0}
.dmg-popup.dmg-sprite canvas{display:block;image-rendering:pixelated}
/* HP/SP regen floats — green for HP, blue for SP; stagger horizontally so they don't overlap. */
.dmg-popup.regen-hp{color:#5cff8c;font-size:11px;text-shadow:1px 1px 0 #000}
.dmg-popup.regen-sp{color:#6cc8ff;font-size:11px;left:62%;text-shadow:1px 1px 0 #000}
@keyframes rise{0%{transform:translate(-50%,0);opacity:1}100%{transform:translate(-50%,-44px);opacity:0}}

/* ── Cast bar — appears above the hero sprite during skill cast window ── */
.cast-bar-wrap{position:absolute;top:0;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:2px;width:96px;pointer-events:none;z-index:10}
.cast-bar-label{font-size:8px;color:#ffd97d;text-shadow:0 0 4px #c8a000,1px 1px 0 #000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:96px;text-align:center;font-weight:bold;letter-spacing:.5px;background:rgba(0,0,0,.55);border-radius:3px;padding:0 3px}
.cast-bar-track{width:96px;height:8px;background:rgba(0,0,0,.7);border:1px solid #666;border-radius:4px;overflow:hidden;position:relative}
.cast-bar-fill{height:100%;width:0%;border-radius:4px;transition:width .08s linear,background .2s;background:linear-gradient(90deg,#ff9f00,#ffe066)}
.cast-bar-fill.acd{background:linear-gradient(90deg,#4466aa,#7aadff)}

/* Buff bar — left edge of arena, stacked vertically from top. */
.buff-bar{position:absolute;top:6px;left:4px;display:flex;flex-direction:column;gap:3px;z-index:4;pointer-events:none}
.buff-icon{display:flex;flex-direction:column;align-items:center;background:rgba(0,0,0,0.8);border:1px solid var(--gold);padding:2px 4px;min-width:36px}
.buff-icon .bi{font-size:11px;line-height:1;color:var(--gold)}
.buff-icon .bt{font-size:7px;color:#fff;margin-top:1px;white-space:nowrap}

.bar{position:relative;width:80px;height:10px;background:#000;border:1px solid #555;overflow:hidden}
.bar span{display:block;height:100%;transition:width .2s}
.bar.hp span{background:linear-gradient(180deg,#ff7a8b,var(--hp))}
.bar.sp span{background:linear-gradient(180deg,#80c5ff,var(--sp))}
.bar.exp span{background:linear-gradient(180deg,#cdfd80,var(--exp))}
.bar.jexp span{background:linear-gradient(180deg,#80c5ff,var(--sp))}
.bar b{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:7px;color:#fff;text-shadow:1px 1px 0 #000}
.exp-row{display:flex;flex-direction:column;gap:3px}
.exp-row .bar{width:100%;height:9px}
.exp-row .bar b{font-size:7px}

/* HOTBAR */
.hotbar{display:grid;grid-template-columns:1fr 1fr auto;gap:6px;background:var(--panel);border:2px solid #000;padding:6px;align-items:center}
.hot-slots{display:flex;gap:4px;flex-wrap:wrap}
.hot-slot{position:relative;width:36px;height:36px;background:#000;border:2px solid #444;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--gold);cursor:pointer;user-select:none}
.hot-slot.empty{color:#444;font-size:8px}
.hot-slot.armed{border-color:var(--gold);box-shadow:0 0 4px var(--gold)}
.hot-slot.cooldown{filter:grayscale(.8) brightness(.5)}
.hot-slot .hcd{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;text-shadow:1px 1px 0 #000;background:rgba(0,0,0,.5)}
.hot-slot .hqty{position:absolute;right:1px;bottom:0;font-size:7px;color:#fff;text-shadow:1px 1px 0 #000;background:rgba(0,0,0,.6);padding:0 2px}
/* Skill enabled/disabled toggle — tiny dot in top-left corner of skill slots */
.hot-slot .htog{position:absolute;top:1px;left:1px;width:8px;height:8px;border-radius:50%;border:1px solid #000;cursor:pointer;z-index:3}
.hot-slot .htog.on{background:#4cff4c;box-shadow:0 0 3px #4cff4c}
.hot-slot .htog.off{background:#802020}
.hot-actions{display:flex;flex-direction:column;gap:4px}
.hot-actions .btn{padding:5px 6px;font-size:7px;line-height:1.1}
#hot-auto.on{background:linear-gradient(180deg,#5cd65c,#1f7a1f)}

/* hotbar config modal */
.hcfg-list{display:flex;flex-direction:column;gap:4px;max-height:50vh;overflow-y:auto;margin-top:6px}
.hcfg-item{display:grid;grid-template-columns:30px 1fr auto;gap:6px;align-items:center;background:#000;border:1px solid #333;padding:4px;font-size:9px;cursor:pointer}
.hcfg-item.expanded{border-color:var(--accent);background:#180e38}
.hcfg-item.sel{border-color:var(--gold)}
/* Level picker strip shown beneath an expanded skill row */
.hcfg-lvpicker{display:flex;flex-wrap:wrap;gap:3px;padding:4px 6px 6px 36px;background:#180e38;border:1px solid var(--accent);border-top:none;margin-top:-4px}
.hcfg-lvpicker .btn.on{background:var(--accent);color:#000;border-color:var(--accent)}
.hcfg-item .ic{width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:14px;border:1px solid #333}
.hcfg-tabs{display:flex;border-bottom:1px solid #333;margin-top:4px}
.hcfg-tabs .t{flex:1;background:#1a0f44;color:var(--ink-dim);border:none;padding:6px;font-size:8px;border-right:1px solid #000}
.hcfg-tabs .t.active{background:var(--panel);color:var(--gold)}

.mob-name{font-size:11px;color:var(--ink);margin-top:2px}
.mlv{font-size:9px;color:var(--ink-dim);margin-left:4px}

/* PvP */
.pvp-header{display:flex;flex-direction:column;gap:4px;padding:8px 0}
.pvp-stat-row{display:flex;align-items:center;gap:12px;font-size:12px}
.pvp-rank-badge{font-weight:bold;font-size:13px;text-shadow:0 0 6px currentColor}
.pvp-rating-lbl{color:var(--ink-dim)}
.pvp-wl{margin-left:auto;font-weight:bold}
.pvp-arena{
  height:320px !important;margin-bottom:6px;
  /* PvP Menu backdrop — drop a replacement at img/bg/pvp_menu.jpg.
     Solid colour is the fallback shown if the image is missing. */
  background:#160a2e url('../img/bg/pvp_menu.jpg') center/cover no-repeat;
}
.pvp-arena .combatant{gap:3px}
.l-miss{color:#888}

/* ── PvP Battle Replay Overlay ───────────────────────────────────────────── */
#pvp-battle-overlay{
  position:fixed;inset:0;z-index:8000;
  background:rgba(8,4,22,.97);
  display:none;flex-direction:column;align-items:stretch;
  font-family:var(--pixel);color:var(--ink);
}
#pvp-battle-overlay.active{display:flex}
.pvpb-header{
  text-align:center;padding:8px 12px 4px;font-size:11px;
  color:var(--gold);letter-spacing:2px;border-bottom:1px solid var(--panel2);
  display:flex;align-items:center;justify-content:space-between;
}
.pvpb-arena{
  display:flex;align-items:flex-end;justify-content:space-around;
  padding:12px 8px 0;flex-shrink:0;height:320px;
  position:relative;
  /* PvP Battle backdrop — drop a replacement at img/bg/pvp_battle.jpg.
     Solid colour is the fallback shown if the image is missing.
     Full-width stretch anchored to the bottom so the arena floor (where the
     fighters stand at flex-end) stays in view; cover guarantees no gaps. */
  background:#160a2e url('../img/bg/pvp_battle.jpg') center/cover no-repeat;
}
.pvpb-fighter{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  width:220px;position:relative;
}
.pvpb-fighter-name{font-size:9px;color:var(--gold);text-align:center;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pvpb-fighter-sub{font-size:8px;color:var(--ink-dim);text-align:center}
.pvpb-hp-wrap{width:190px}
.pvpb-hp-bar{height:10px;background:#1a0a1a;border:1px solid #555;border-radius:2px;overflow:hidden;width:100%}
.pvpb-hp-fill{height:100%;background:var(--hp);transition:width .2s ease}
.pvpb-sp-bar{height:6px;background:#1a0a1a;border:1px solid #333;border-radius:2px;overflow:hidden;width:100%;margin-top:2px}
.pvpb-sp-fill{height:100%;background:var(--sp);transition:width .3s ease}
.pvpb-hp-text{font-size:8px;color:var(--ink-dim);text-align:center}
.pvpb-sprite-wrap{position:relative;width:180px;height:220px;display:flex;align-items:flex-end;justify-content:center}
.pvpb-sprite-wrap .sprite{width:180px;height:220px}
.pvpb-skill-flash{
  position:absolute;top:-22px;left:50%;transform:translateX(-50%);
  font-size:8px;color:#d4aaff;white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .1s;
}
.pvpb-skill-flash.show{opacity:1}
.pvpb-cast-bar-wrap{position:absolute;bottom:228px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:1px;width:120px;pointer-events:none;z-index:60}
.pvpb-cast-bar-label{font-size:8px;color:#ffd97d;text-shadow:0 0 4px #c8a000,1px 1px 0 #000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px;text-align:center;font-weight:bold;background:rgba(0,0,0,.6);border-radius:3px;padding:0 3px}
.pvpb-cast-bar-track{width:110px;height:6px;background:rgba(0,0,0,.7);border:1px solid #666;border-radius:3px;overflow:hidden}
.pvpb-cast-bar-fill{height:100%;width:0%;border-radius:3px;background:linear-gradient(90deg,#ff9f00,#ffe066);transition:width .08s linear}
.pvpb-dmg-layer{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.pvpb-dmg-num{
  position:absolute;font-size:11px;font-weight:bold;pointer-events:none;
  animation:pvpbDmgFloat .9s ease-out forwards;
}
@keyframes pvpbDmgFloat{
  0%  {opacity:1;transform:translateY(0) scale(1)}
  30% {opacity:1;transform:translateY(-28px) scale(1.3)}
  100%{opacity:0;transform:translateY(-60px) scale(.8)}
}
.pvpb-vs{
  font-size:20px;color:var(--gold);align-self:center;
  padding:0 4px;text-shadow:0 0 12px var(--gold);
}
.pvpb-log{
  flex:1;overflow-y:auto;padding:6px 12px;
  font-size:9px;line-height:1.7;border-top:1px solid var(--panel2);
  display:flex;flex-direction:column;gap:1px;
  min-height:80px;max-height:180px;
}
.pvpb-log-line{animation:pvpbFadeIn .2s ease}
@keyframes pvpbFadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.pvpb-controls{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:6px 8px;border-top:1px solid var(--panel2);
}
.pvpb-result{
  display:none;flex-direction:column;align-items:center;gap:8px;
  padding:14px;border-top:2px solid var(--gold);
  font-size:10px;text-align:center;
}
.pvpb-result.show{display:flex}
.pvpb-result-title{font-size:14px;letter-spacing:2px}
.pvpb-rating-row{display:flex;gap:24px;font-size:9px}
.pvpb-result-actions{display:flex;gap:8px;margin-top:4px}

/* PvP tabs */
.pvp-tabs{display:flex;gap:0;border-bottom:2px solid #2c1f54;margin-bottom:6px}
.pvp-tab{flex:1;background:#1a0f44;color:var(--ink-dim);border:none;padding:7px 4px;font-size:11px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s}
.pvp-tab:hover{color:var(--ink)}
.pvp-tab.active{color:var(--gold);border-bottom-color:var(--gold);background:var(--panel)}
.pvp-tab-panel{display:flex;flex-direction:column;gap:4px}
.pvp-tab-panel.hidden{display:none}

/* Ladder */
.pvp-season-bar{display:flex;align-items:center;gap:8px;padding:4px 0 6px;font-size:12px}
.pvp-my-rank{background:#1a0f44;border:1px solid var(--gold);border-radius:4px;padding:5px 8px;font-size:11px;color:var(--gold);text-align:center}
.pvp-reward-preview{background:#1f1040;border:1px solid #4a3080;border-radius:4px;padding:5px 8px;font-size:11px;color:var(--ink)}
.pvp-ladder-list{display:flex;flex-direction:column;gap:2px;max-height:260px;overflow-y:auto}
/* PvP Ladder: make the list the ONLY scroll region (no outer #screen-host bar).
   The PvP screen fills the host height; header/tabs/season/your-rank stay fixed
   and the ladder list flex-grows + scrolls internally. Scoped to PvP only. */
.screen[data-screen="pvp"]{height:100%;min-height:0}
.screen[data-screen="pvp"]>#pvp-root{display:flex;flex-direction:column;height:100%;min-height:0;gap:6px}
#pvp-panel-ladder{flex:1 1 auto;min-height:0}
#pvp-ladder-list{flex:1 1 auto;min-height:0;max-height:none}
.pvp-ladder-row{display:flex;align-items:center;gap:6px;padding:5px 6px;background:#150c30;border-radius:3px;font-size:11px}
.pvp-ladder-me{background:#2a1a55;border:1px solid var(--gold)}
.pvp-ldr-rank{min-width:28px;font-weight:bold;color:var(--gold);text-align:center}
.pvp-ldr-name{flex:1;display:flex;flex-direction:column;gap:1px}
.pvp-ldr-rating{text-align:right;font-weight:bold;color:#7ff5e7;white-space:nowrap}

/* Reward tiers */
.pvp-reward-tiers{display:flex;flex-direction:column;gap:2px}
/* Rewards tab layout: the Reward Tiers list sizes to its content (no inner
   scrollbar — all tiers visible), while "Your Past Rewards" takes the
   remaining height and scrolls internally once entries pile up. */
#pvp-panel-rewards:not(.hidden){flex:1 1 auto;min-height:0;display:flex;flex-direction:column}
#pvp-panel-rewards .pvp-reward-tiers{flex:0 0 auto;overflow:visible}
#pvp-panel-rewards #pvp-past-rewards{flex:1 1 auto;min-height:80px;max-height:none}

/* Battle: make the screen fill the host so there's no outer #screen-host
   scrollbar. The chat/battle log panel flex-grows and is the only scroll
   region (its combat-log scrolls internally); arena/exp/hotbar stay fixed.
   Scoped to the battle screen only. */
.screen[data-screen="battle"]{height:100%;min-height:0}
.screen[data-screen="battle"] .log-panel{flex:1 1 auto;min-height:80px}
.screen[data-screen="battle"] .log-panel .combat-log{flex:1 1 auto;height:auto;min-height:0}
.pvp-tier-row{display:grid;grid-template-columns:auto 40px 1fr;align-items:center;gap:6px;padding:5px 8px;background:#150c30;border-radius:3px;font-size:11px}
.pvp-tier-current{background:#1f1050;border:1px solid currentColor;box-shadow:0 0 6px currentColor22}
.pvp-tier-label{font-weight:bold;text-shadow:0 0 4px currentColor}
.pvp-tier-rating{color:var(--ink-dim);font-size:9px}
.pvp-tier-prizes{text-align:right;color:#7ff5e7;white-space:nowrap}

.combat-log{background:#000;border:2px solid #2c1f54;padding:6px;height:100px;overflow-y:auto;font-size:10px;line-height:1.5;color:var(--ink-dim);font-family:'Courier New',monospace}
.log-panel{display:flex;flex-direction:column}
.log-tabs{display:flex;gap:2px}
.log-tab{background:#1a1438;border:2px solid #2c1f54;border-bottom:none;color:var(--ink-dim);padding:3px 10px;font-size:10px;cursor:pointer;font-family:'Courier New',monospace}
.log-tab.active{background:#000;color:var(--gold)}
.log-tab .badge-unread{display:inline-block;margin-left:4px;background:#c33;color:#fff;border-radius:6px;padding:0 4px;font-size:9px;line-height:1.2}
.log-input-row{display:flex;gap:4px;margin-top:2px}
.log-input-row input{flex:1;background:#000;color:#eee;border:2px solid #2c1f54;padding:4px 6px;font-size:11px;font-family:'Courier New',monospace}
.combat-log.hidden{display:none}
/* Hide the PvP result log box until a match populates it (no empty black box). */
#pvp-result.combat-log:empty{display:none}
.res-currency{display:flex;flex-direction:column;align-items:flex-end;gap:2px;margin-right:6px}
.top-icon-grid{display:grid;grid-template-columns:repeat(3,32px);grid-auto-rows:32px;gap:3px}
.top-icon{width:32px;height:32px;padding:0;font-size:16px;display:flex;align-items:center;justify-content:center}
.vip-badge{display:inline-flex;align-items:center;gap:2px;background:linear-gradient(180deg,#d4af37,#8b6914);color:#1a1438;border:1px solid #5a440b;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:bold;cursor:pointer;font-family:'Courier New',monospace;letter-spacing:.5px}
.vip-badge:hover{filter:brightness(1.15)}
.vip-badge.hidden{display:none}
.vip-badge.tier-0{background:#444;color:#aaa;border-color:#222}
.vip-badge.tier-1{background:linear-gradient(180deg,#cd7f32,#8b4513);color:#fff}
.vip-badge.tier-2{background:linear-gradient(180deg,#c0c0c0,#808080);color:#222}
.vip-badge.tier-3{background:linear-gradient(180deg,#ffd700,#b8860b);color:#1a1438}
.vip-badge.tier-4{background:linear-gradient(180deg,#e5e4e2,#a8a8b0);color:#222}
.vip-badge.tier-5{background:linear-gradient(180deg,#b9f2ff,#5d9ea6);color:#1a1438}
.vip-table{width:100%;border-collapse:collapse;font-size:11px;font-family:'Courier New',monospace}
.vip-table th,.vip-table td{padding:4px 6px;border-bottom:1px solid #2c1f54;text-align:right}
.vip-table th:first-child,.vip-table td:first-child{text-align:left}
.vip-table thead th{background:#1a1438;color:var(--gold);position:sticky;top:0}
.vip-table tr.cur td{background:#241a4a;color:var(--gold);font-weight:bold}
.cs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;padding:8px 4px}
.cs-slot{background:#1a1438;border:2px solid #2c1f54;padding:10px;border-radius:4px;min-height:110px;display:flex;flex-direction:column;justify-content:space-between}
.cs-slot.filled{border-color:var(--gold)}
.cs-slot.empty{border-style:dashed;opacity:.8;cursor:pointer;align-items:center;justify-content:center;text-align:center}
.cs-slot.empty:hover{opacity:1;background:#241a4a}
.cs-num{color:var(--ink-dim);font-size:10px}
.cs-name{color:var(--gold);font-size:14px;font-weight:bold}
.cs-sub{opacity:.8;font-size:11px;margin-top:2px}
.cs-empty{color:var(--gold);font-size:14px}
.cs-play{margin-top:6px;width:100%}
.combat-log .l-chat{color:#cfd}
.combat-log .l-chat .l-name{color:#9cf;font-weight:bold}
.combat-log .l-chat .l-sys{color:#fa6;font-style:italic}
.combat-log .l-dmg{color:#ff8a8a}
.combat-log .l-crit{color:var(--gold)}
.combat-log .l-drop{color:var(--exp)}
.combat-log .l-skill{color:var(--accent)}
.combat-log .l-lvup{color:var(--gold);font-weight:bold}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.stat{display:flex;align-items:center;justify-content:space-between;background:var(--panel);border:2px solid #000;padding:8px;font-size:11px}
.stat b{color:var(--gold)}
.stat span{flex:1;text-align:center;color:var(--ink)}

/* SKILL TREE */
#skill-tree{display:flex;flex-direction:column;gap:6px}
.skill{background:var(--panel);border:2px solid #000;padding:6px;display:grid;grid-template-columns:36px 1fr auto;gap:8px;align-items:center}
.skill.locked{opacity:.45}
.skill .icon{width:36px;height:36px;background:linear-gradient(180deg,#5a3acc,#2e1a7a);border:2px solid #000;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--gold)}
.skill .info{font-size:11px}
.skill .name{color:var(--gold);font-size:12px}
.skill .desc{color:var(--ink-dim);font-size:10px;margin-top:2px;line-height:1.3}
.skill .lvl{font-size:10px;color:var(--ink)}

/* TABS */
.tabs{display:flex;border-bottom:2px solid #000}
.tab{flex:1;background:#1a0f44;color:var(--ink-dim);border:none;padding:8px;font-size:11px;border-right:2px solid #000}
.tab:last-child{border-right:none}
.tab.active{background:var(--panel);color:var(--gold)}

/* INVENTORY */
.equip-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin:6px 0}
.eslot{background:var(--panel);border:2px dashed #5a4a9a;min-height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:9px;color:var(--ink-dim);padding:6px;text-align:center;cursor:pointer;transition:border-color .15s;gap:2px}
.eslot:active{background:var(--panel2)}
.eslot.filled{color:var(--gold);border-style:solid}
.eslot .qn{font-size:9px;color:var(--ink-dim)}
.eslot.q1{border-color:#888}
.eslot.q2{border-color:#5cd65c}
.eslot.q3{border-color:#5c8cff}
.eslot.q4{border-color:#b072ff}
.eslot.q5{border-color:#ff8c2b}
.eslot.q6{border-color:#ff5050;box-shadow:0 0 6px #ff5050}

#inv-list{display:flex;flex-direction:column;gap:5px}
.invitem{display:grid;grid-template-columns:40px 1fr auto;gap:8px;background:var(--panel);border:2px solid #000;padding:8px;font-size:11px;align-items:center}
.invitem .ic{width:36px;height:36px;background:#000;border:1px solid #444;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--gold)}
.invitem.q1 .ic{border-color:#888}
.invitem.q2 .ic{border-color:#5cd65c;color:#5cd65c}
.invitem.q3 .ic{border-color:#5c8cff;color:#5c8cff}
.invitem.q4 .ic{border-color:#b072ff;color:#b072ff}
.invitem.q5 .ic{border-color:#ff8c2b;color:#ff8c2b}
.invitem.q6 .ic{border-color:#ff5050;color:#ff5050;box-shadow:0 0 6px #ff5050}
.invitem .nm{color:var(--ink)}
.invitem .sub{color:var(--ink-dim);font-size:9px;margin-top:2px}

/* BUTTONS */
.btn{background:linear-gradient(180deg,var(--accent),#5e2faf);color:#fff;border:2px solid #000;box-shadow:0 3px 0 #000;padding:8px 12px;font-size:11px;text-shadow:1px 1px 0 #000}
.btn:active{transform:translateY(2px);box-shadow:0 1px 0 #000}
.btn.small{padding:5px 8px;font-size:8px}
.btn.tiny{padding:3px 6px;font-size:8px;box-shadow:0 2px 0 #000}
.btn.big{padding:14px;font-size:11px;width:100%;margin-top:8px}
.btn.help-btn{width:22px;height:22px;padding:0;border-radius:50%;font-size:12px;font-weight:bold;line-height:1;text-align:center;background:linear-gradient(180deg,#3a8fd6,#2a5f9f)}
.btn.primary{background:linear-gradient(180deg,#ffb13a,#c46a00)}
.btn.danger{background:linear-gradient(180deg,#ff5252,#9a1414)}
.btn.success{background:linear-gradient(180deg,#5cd65c,#1f7a1f)}
.btn:disabled{opacity:.4;cursor:not-allowed;filter:saturate(.3)}

/* JOB CHANGE */
.jobchange{background:var(--panel);border:2px solid var(--gold);padding:8px;display:flex;flex-direction:column;gap:6px}
.jobchange .desc{font-size:8px;color:var(--ink-dim);line-height:1.4}
.joblist{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.joblist .btn{padding:6px;font-size:9px}

/* SHOP */
.shopitem{display:grid;grid-template-columns:36px 1fr auto;gap:8px;background:var(--panel);border:2px solid #000;padding:6px;font-size:9px;align-items:center}
.shopitem .ic{width:36px;height:36px;background:#000;border:1px solid #444;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--gold)}
.shopitem .price{font-size:9px;color:var(--gold);margin-bottom:4px}

/* BOTTOM NAV */
#bottombar{display:flex;background:linear-gradient(0deg,#100828,#23154e);border-top:3px solid #000;height:60px}
.navbtn{flex:1;background:transparent;border:none;color:var(--ink-dim);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:7px;border-right:1px solid #000}
.navbtn:last-child{border-right:none}
.navbtn i{font-style:normal;font-size:18px;color:var(--ink-dim)}
.navbtn.active{background:var(--panel);color:var(--gold)}
.navbtn.active i{color:var(--gold)}

/* TOAST */
#toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:#000;color:var(--gold);border:2px solid var(--gold);padding:8px 14px;font-size:9px;z-index:99;opacity:0;pointer-events:none;transition:opacity .3s;max-width:80%}
#toast.show{opacity:1}

/* MODAL */
#modal{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-card{background:var(--panel);border:3px solid var(--gold);padding:14px;max-width:90%;width:340px;max-height:80vh;overflow-y:auto;overflow-x:hidden}
.modal-card.wide{width:640px;max-width:95%}
.modal-card h3{color:var(--gold);font-size:11px;margin-bottom:8px}
.modal-card .actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.modal-card .actions .btn{flex:1;min-width:70px}

@media (max-width:380px){
  .sprite{width:120px;height:140px}
  .bar{width:70px}
}

/* FX overlays (skill effects). CSS-animated circles/flashes. */
.fx{position:absolute;inset:-20%;pointer-events:none;z-index:2}
.fx-slash{background:radial-gradient(circle at 50% 50%,rgba(255,230,100,.0),rgba(255,230,100,0) 40%,rgba(255,230,100,.8) 48%,rgba(255,230,100,0) 56%);animation:fxSlash .35s ease-out forwards}
.fx-magic{background:radial-gradient(circle at 50% 50%,rgba(120,170,255,.7),rgba(120,170,255,0) 60%);animation:fxMagic .55s ease-out forwards}
.fx-heal{background:radial-gradient(circle at 50% 50%,rgba(120,255,150,.8),rgba(120,255,150,0) 60%);animation:fxMagic .5s ease-out forwards}
/* Element-specific skill FX — inspired by casual-ragnarok.github.io/ro-effects */
.fx-fire{background:radial-gradient(circle at 50% 60%,rgba(255,140,40,.9),rgba(255,60,20,.7) 35%,rgba(200,0,0,0) 60%);animation:fxFire .6s ease-out forwards;filter:blur(1px)}
.fx-water{background:radial-gradient(circle at 50% 50%,rgba(120,220,255,.9),rgba(40,120,255,.6) 40%,rgba(0,30,120,0) 65%);animation:fxMagic .55s ease-out forwards}
.fx-wind{background:conic-gradient(from 0deg at 50% 50%,rgba(180,255,180,0),rgba(180,255,180,.7),rgba(180,255,180,0));animation:fxWind .45s linear forwards}
.fx-earth{background:radial-gradient(ellipse at 50% 80%,rgba(180,140,80,.8),rgba(140,90,40,.5) 50%,rgba(0,0,0,0) 70%);animation:fxQuake .55s ease-out forwards}
.fx-holy{background:radial-gradient(circle at 50% 40%,rgba(255,255,200,1),rgba(255,240,150,.6) 35%,rgba(255,200,0,0) 65%);animation:fxHoly .7s ease-out forwards}
.fx-dark{background:radial-gradient(circle at 50% 50%,rgba(90,30,140,.9),rgba(40,0,80,.6) 40%,rgba(0,0,0,0) 65%);animation:fxMagic .55s ease-out forwards}
.fx-poison{background:radial-gradient(circle at 50% 50%,rgba(120,220,60,.8),rgba(80,140,20,.5) 45%,rgba(30,80,0,0) 65%);animation:fxMagic .5s ease-out forwards}
.fx-ghost{background:radial-gradient(ellipse at 50% 50%,rgba(200,230,255,.85),rgba(140,180,220,.5) 45%,rgba(80,100,140,0) 70%);animation:fxGhost .55s ease-out forwards;filter:blur(0.5px)}
@keyframes fxSlash{ 0%{transform:scale(.5) rotate(-15deg);opacity:.9} 100%{transform:scale(1.4) rotate(20deg);opacity:0} }
@keyframes fxMagic{ 0%{transform:scale(.4);opacity:.9} 100%{transform:scale(1.6);opacity:0} }
@keyframes fxFire { 0%{transform:translateY(6px) scale(.6);opacity:.95} 60%{transform:translateY(-6px) scale(1.3);opacity:.8} 100%{transform:translateY(-16px) scale(1.7);opacity:0} }
@keyframes fxWind { 0%{transform:rotate(0deg) scale(.7);opacity:.9} 100%{transform:rotate(360deg) scale(1.4);opacity:0} }
@keyframes fxQuake{ 0%,100%{transform:translateX(0) scale(1);opacity:.9} 25%{transform:translateX(-3px) scale(1.05)} 75%{transform:translateX(3px) scale(1.05)} }
@keyframes fxHoly { 0%{transform:scale(.3);opacity:1;filter:brightness(2)} 100%{transform:scale(1.8);opacity:0;filter:brightness(1)} }
@keyframes fxGhost{ 0%{transform:scale(.5) skewX(-6deg);opacity:.9} 60%{transform:scale(1.3) skewX(6deg);opacity:.7} 100%{transform:scale(1.7) skewX(0);opacity:0} }

/* Options modal */
.modal-head{color:var(--gold);font-size:11px;margin-bottom:8px;text-align:center}
.opt-row{display:flex;align-items:center;gap:8px;margin:8px 0}
.opt-row label{flex:1;display:flex;align-items:center;gap:6px;color:var(--ink)}
.opt-row input[type=range]{flex:1}
.opt-row b{min-width:36px;text-align:right;color:var(--gold)}
.modal-actions{display:flex;gap:6px;margin-top:10px;justify-content:flex-end}

/* Active toggle buttons */
.btn.active{background:var(--gold);color:#000}
.btn.tiny{padding:2px 6px;font-size:8px}
