/* =====================================================================
   MOB MODAL V2 — Obsidian Codex (2026-05-30)
   Rediseño del modal de detalles de enemigos en zonas.
   Prefix: .mdm2-* (Mob Detail Modal v2)

   Layout:
   - Hero HORIZONTAL: imagen izq (framed) + info der (rarity pill + name + HP bar)
   - Estilo ornado: corner ornaments, gold borders, dashed inner frame
   - Boss = tint dorado / Common = tint arcane (violeta)
   ===================================================================== */
.mdm2-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(5,3,2,0.78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: grid; place-items: center;
  padding: 16px;
  overflow-y: auto;
}

.mdm2-modal {
  --mdm2-bg:        #0e0a07;
  --mdm2-bg-2:      #1a120a;
  --mdm2-border:    rgba(212,180,131,0.22);
  --mdm2-border-strong: rgba(212,180,131,0.45);
  --mdm2-gold:      #d4b483;
  --mdm2-gold-2:    #f4d896;
  --mdm2-gold-grad: linear-gradient(135deg,#f4d896 0%,#d4b483 45%,#a0793e 100%);
  --mdm2-text:      #ece2cd;
  --mdm2-text-soft: #b8a884;
  --mdm2-text-dim:  #7a6850;
  --mdm2-blood:     #ff4757;
  --mdm2-cyan:      #5fcfff;
  --mdm2-arcane:    #b884ff;
  --mdm2-ember:     #ff8a4c;

  /* Tinte default = common (arcane violeta) */
  --mdm2-rarity:    #b884ff;

  width: min(94vw, 520px);
  max-height: 92vh;
  display: flex; flex-direction: column;
  background:
    radial-gradient(120% 70% at 50% 0%, color-mix(in srgb, var(--mdm2-rarity) 8%, transparent) 0%, transparent 60%),
    linear-gradient(180deg, var(--mdm2-bg-2) 0%, var(--mdm2-bg) 100%);
  border: 1px solid var(--mdm2-border-strong);
  border-radius: 14px;
  box-shadow:
    0 40px 100px -24px rgba(0,0,0,0.75),
    inset 0 1px 0 rgba(255,255,255,0.04);
  color: var(--mdm2-text);
  font-family: 'Inter', system-ui, sans-serif;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.mdm2-modal.is-boss { --mdm2-rarity: #ffc857; }

/* Frame doble ornado: borde interior dashed siempre visible (acentúa el aspecto codex) */
.mdm2-modal::before {
  content: ''; position: absolute; inset: 7px;
  border: 1px dashed color-mix(in srgb, var(--mdm2-gold) 25%, transparent);
  border-radius: 9px; pointer-events: none;
  z-index: 0;
}

/* Corner ornaments (decorative gold corners) */
.mdm2-modal::after {
  content: ''; position: absolute; inset: 0;
  pointer-events: none; z-index: 0;
  background:
    /* top-left */
    linear-gradient(135deg, var(--mdm2-gold) 0%, transparent 12px) 0 0 / 22px 22px no-repeat,
    /* top-right */
    linear-gradient(225deg, var(--mdm2-gold) 0%, transparent 12px) 100% 0 / 22px 22px no-repeat,
    /* bottom-left */
    linear-gradient(45deg, var(--mdm2-gold) 0%, transparent 12px) 0 100% / 22px 22px no-repeat,
    /* bottom-right */
    linear-gradient(315deg, var(--mdm2-gold) 0%, transparent 12px) 100% 100% / 22px 22px no-repeat;
  opacity: 0.30;
  mix-blend-mode: screen;
}

.mdm2-close {
  position: absolute; top: 14px; right: 14px; z-index: 6;
  width: 34px; height: 34px; border-radius: 50%;
  background: rgba(0,0,0,0.55); border: 1px solid var(--mdm2-border-strong);
  color: var(--mdm2-text-soft); display: grid; place-items: center;
  font-size: 16px; cursor: pointer; transition: all .15s;
}
.mdm2-close:hover { color: var(--mdm2-rarity); border-color: var(--mdm2-rarity); }

/* ============== HERO HORIZONTAL ============== */
.mdm2-hero {
  position: relative; z-index: 2;
  display: flex; align-items: stretch; gap: 18px;
  padding: 22px 22px 16px;
}

/* Image side — ornate framed box */
.mdm2-hero-imgwrap {
  width: 130px; height: 130px;
  position: relative; flex-shrink: 0;
  border-radius: 10px;
  padding: 4px;
  background: linear-gradient(180deg, rgba(212,180,131,0.18) 0%, rgba(212,180,131,0.06) 100%);
  border: 1px solid color-mix(in srgb, var(--mdm2-gold) 45%, transparent);
  box-shadow:
    0 0 28px -6px color-mix(in srgb, var(--mdm2-rarity) 40%, transparent),
    inset 0 1px 0 rgba(255,255,255,0.06);
}
/* Halo amplio detrás del wrap */
.mdm2-hero-imgwrap::before {
  content: ''; position: absolute; inset: -20px;
  background: radial-gradient(circle, color-mix(in srgb, var(--mdm2-rarity) 28%, transparent) 0%, transparent 60%);
  filter: blur(18px);
  z-index: -1; pointer-events: none;
}
/* Inner cell con el sprite */
.mdm2-hero-imgcell {
  position: relative;
  width: 100%; height: 100%;
  border-radius: 7px; overflow: hidden;
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--mdm2-rarity) 20%, transparent) 0%, rgba(0,0,0,0.55) 70%);
}
.mdm2-hero-img {
  width: 100%; height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.mdm2-hero-fallback {
  width: 100%; height: 100%;
  display: grid; place-items: center;
  font-size: 64px;
  color: var(--mdm2-rarity);
  text-shadow: 0 0 24px color-mix(in srgb, var(--mdm2-rarity) 60%, transparent);
}

/* Pill nivel: pegado al borde inferior, centrado */
.mdm2-hero-lvl {
  position: absolute;
  left: 50%; bottom: -6px;
  transform: translateX(-50%);
  padding: 4px 14px; border-radius: 7px;
  background: linear-gradient(180deg, #2a1d12 0%, #160d06 100%);
  border: 1px solid color-mix(in srgb, var(--mdm2-gold) 55%, transparent);
  color: var(--mdm2-text); font-size: 11px;
  font-family: 'Cinzel', serif; font-weight: 700; letter-spacing: 0.08em;
  white-space: nowrap;
  box-shadow: 0 4px 10px -4px rgba(0,0,0,0.6);
}

/* Lado derecho del hero: rarity pill + nombre + HP */
.mdm2-hero-info {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column;
  justify-content: center; gap: 10px;
  padding-top: 4px;
}
.mdm2-hero-rarity {
  display: inline-flex; align-items: center; gap: 6px;
  align-self: flex-start;
  padding: 4px 14px; border-radius: 999px;
  font-family: 'Cinzel', serif; font-size: 10.5px;
  font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--mdm2-rarity);
  background: color-mix(in srgb, var(--mdm2-rarity) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--mdm2-rarity) 55%, transparent);
}
.mdm2-hero-rarity i { font-size: 11px; }

.mdm2-hero-name {
  font-family: 'Cinzel', serif; font-weight: 700;
  font-size: 22px; letter-spacing: 1.6px;
  color: var(--mdm2-rarity);
  text-shadow: 0 2px 14px color-mix(in srgb, var(--mdm2-rarity) 35%, transparent);
  line-height: 1.1;
  margin: 0;
}

/* Diamond separator (entre name y HP) */
.mdm2-hero-divider {
  display: flex; align-items: center; gap: 6px;
  height: 8px;
}
.mdm2-hero-divider::before,
.mdm2-hero-divider::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--mdm2-gold) 40%, transparent), transparent);
}
.mdm2-hero-divider i {
  color: var(--mdm2-gold);
  font-size: 8px;
  transform: rotate(45deg);
}

/* HP bar dentro del hero (al lado del nombre) */
.mdm2-hp-bar {
  height: 8px;
  border-radius: 999px;
  background: rgba(0,0,0,0.55);
  border: 1px solid rgba(0,0,0,0.6);
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.5);
}
.mdm2-hp-fill {
  height: 100%;
  background: linear-gradient(90deg, #ff5a8e 0%, #ff2e6a 60%, #b91f4d 100%);
  border-radius: 999px;
  box-shadow: 0 0 12px rgba(255,71,87,0.5);
}
.mdm2-hp-text {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; color: var(--mdm2-text-soft);
  letter-spacing: 0.5px;
  margin-top: 2px;
}

/* ============== BODY ============== */
.mdm2-body {
  flex: 1 1 auto; overflow-y: auto;
  padding: 6px 22px 14px;
  display: flex; flex-direction: column; gap: 12px;
  scrollbar-width: thin;
  scrollbar-color: var(--mdm2-border) transparent;
  position: relative; z-index: 2;
}
.mdm2-body::-webkit-scrollbar { width: 6px; }
.mdm2-body::-webkit-scrollbar-thumb { background: var(--mdm2-border); border-radius: 3px; }

/* Descripción (italic, dim) */
.mdm2-desc {
  margin: 0;
  font-style: italic;
  font-size: 12.5px;
  color: var(--mdm2-text-soft);
  line-height: 1.45;
  text-align: center;
  opacity: 0.85;
}

/* Section label con icono cuadrado + diamond divider derecha */
.mdm2-sec-label {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Cinzel', serif; font-size: 12px;
  font-weight: 800; letter-spacing: 0.30em; text-transform: uppercase;
  color: var(--mdm2-gold);
  text-shadow: 0 0 8px rgba(212,180,131,0.22);
  margin: 0 0 2px;
}
.mdm2-sec-label-ic {
  width: 22px; height: 22px;
  display: grid; place-items: center;
  border-radius: 4px;
  background: rgba(212,180,131,0.08);
  border: 1px solid var(--mdm2-border);
  color: var(--mdm2-gold);
  font-size: 12px;
}
.mdm2-sec-label-line {
  flex: 1;
  display: flex; align-items: center; gap: 5px;
}
.mdm2-sec-label-line::before {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--mdm2-gold) 40%, transparent), transparent);
}
.mdm2-sec-label-line i {
  color: var(--mdm2-gold);
  font-size: 7px;
  transform: rotate(45deg);
  margin-right: 2px;
}

/* Stats: rows compactos, full-width */
.mdm2-stats {
  display: grid; gap: 4px;
}
.mdm2-stat {
  display: grid;
  grid-template-columns: 26px 1fr auto;
  align-items: center; gap: 10px;
  padding: 11px 14px;
  background: linear-gradient(180deg, rgba(255,255,255,0.015), rgba(0,0,0,0.20));
  border: 1px solid rgba(212,180,131,0.10);
  border-radius: 8px;
}
.mdm2-stat i {
  color: var(--mdm2-gold);
  font-size: 16px;
  text-shadow: 0 0 6px rgba(212,180,131,0.25);
}
.mdm2-stat-lbl { color: var(--mdm2-text); font-size: 13px; }
.mdm2-stat-val {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px; font-weight: 700;
  color: var(--mdm2-text);
}
.mdm2-stat.is-xp { background: linear-gradient(180deg, rgba(95,207,255,0.05), rgba(0,0,0,0.20)); border-color: rgba(95,207,255,0.18); }
.mdm2-stat.is-xp i,
.mdm2-stat.is-xp .mdm2-stat-val { color: var(--mdm2-cyan); }
.mdm2-stat.is-maxed { opacity: 0.7; }
.mdm2-stat.is-maxed .mdm2-stat-val { color: #ff7b7b; }

/* Loot preview */
.mdm2-loot-grid {
  display: flex; gap: 10px; flex-wrap: wrap;
}
.mdm2-loot-item {
  width: 52px; height: 52px;
  border-radius: 8px;
  display: grid; place-items: center;
  background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(0,0,0,0.32));
  border: 1px solid rgba(212,180,131,0.18);
  font-size: 26px;
  transition: transform .12s, border-color .12s, box-shadow .12s;
}
.mdm2-loot-item:hover {
  transform: translateY(-1px);
  border-color: var(--mdm2-border-strong);
}
.mdm2-loot-item.r-common    { color: #b8a884; }
.mdm2-loot-item.r-uncommon  { color: #6fc26a; border-color: rgba(95,214,132,0.45); }
.mdm2-loot-item.r-rare      { color: #5fcfff; border-color: rgba(108,212,255,0.45); }
.mdm2-loot-item.r-epic      { color: #b97aff; border-color: rgba(184,132,255,0.5); }
.mdm2-loot-item.r-legendary {
  color: #ffd54a;
  border-color: rgba(255,200,87,0.55);
  box-shadow: 0 0 18px -6px rgba(255,200,87,0.6);
}
.mdm2-loot-item.r-mythic    {
  color: #ff5a8e;
  border-color: rgba(255,80,140,0.55);
  box-shadow: 0 0 18px -6px rgba(255,80,140,0.6);
}

.mdm2-loot-more {
  width: 100%;
  margin-top: 8px;
  padding: 10px 12px;
  background: linear-gradient(180deg, rgba(212,180,131,0.06), rgba(0,0,0,0.20));
  border: 1px solid color-mix(in srgb, var(--mdm2-gold) 25%, transparent);
  border-radius: 9px;
  color: var(--mdm2-gold);
  font-family: 'Cinzel', serif;
  font-size: 11.5px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  cursor: pointer; transition: all .15s;
}
.mdm2-loot-more i { font-size: 14px; }
.mdm2-loot-more:hover {
  color: #fff;
  border-color: color-mix(in srgb, var(--mdm2-gold) 65%, transparent);
  background: linear-gradient(180deg, rgba(212,180,131,0.12), rgba(0,0,0,0.20));
}

/* ============== FOOTER (ATTACK BUTTON) ============== */
.mdm2-footer {
  padding: 14px 22px 18px;
  position: relative; z-index: 2;
}

/* Ornate attack button: doble frame con gradient gold */
.mdm2-attack-btn {
  position: relative;
  width: 100%;
  height: 58px;
  padding: 0 18px;
  border: 1px solid color-mix(in srgb, var(--mdm2-gold) 55%, transparent);
  border-radius: 10px;
  background: var(--mdm2-gold-grad);
  color: #1a120a;
  font-family: 'Cinzel', serif; font-weight: 700; font-size: 14px;
  letter-spacing: 2px; text-transform: uppercase;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  box-shadow:
    0 12px 30px -10px rgba(212,180,131,0.6),
    inset 0 1px 0 rgba(255,255,255,0.45),
    inset 0 -2px 6px rgba(0,0,0,0.18);
  transition: filter .15s, transform .15s, box-shadow .15s;
}
/* Frame interior del botón */
.mdm2-attack-btn::before {
  content: ''; position: absolute; inset: 5px;
  border: 1px solid rgba(0,0,0,0.32);
  border-radius: 6px; pointer-events: none;
}
.mdm2-attack-btn i { font-size: 18px; }
.mdm2-attack-btn:not(:disabled):hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
}
.mdm2-attack-btn:disabled,
.mdm2-attack-btn.is-locked {
  background: rgba(60,40,28,0.5);
  color: var(--mdm2-text-dim);
  box-shadow: none;
  cursor: not-allowed;
}
.mdm2-attack-btn:disabled::before,
.mdm2-attack-btn.is-locked::before { border-color: rgba(255,255,255,0.05); }
.mdm2-attack-btn.is-overlevel {
  background: linear-gradient(135deg, #ffaa6a 0%, #c75a1f 100%);
  color: #1a0a05;
}
.mdm2-attack-btn.is-grind {
  background: linear-gradient(135deg, #9be095 0%, #3f8a3a 100%);
  color: #0a1a05;
}

.mdm2-attack-stam {
  position: absolute;
  right: 14px;
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,0.32);
  color: #fff5cc;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; font-weight: 700;
  letter-spacing: 0;
  border: 1px solid rgba(0,0,0,0.18);
}
.mdm2-attack-stam i { color: #ffd54a; font-size: 12px; }

/* ============== MOBILE (≤480px) ============== */
@media (max-width: 480px) {
  .mdm2-modal { width: 100%; max-height: 96vh; border-radius: 12px; }
  .mdm2-hero {
    padding: 18px 16px 14px;
    gap: 14px;
  }
  .mdm2-hero-imgwrap { width: 110px; height: 110px; }
  .mdm2-hero-name { font-size: 18px; letter-spacing: 1.2px; }
  .mdm2-hero-rarity { font-size: 10px; padding: 3px 11px; }
  .mdm2-body { padding: 6px 16px 12px; }
  .mdm2-footer { padding: 12px 16px 16px; }
  .mdm2-attack-btn { height: 52px; font-size: 13px; letter-spacing: 1.6px; }
  .mdm2-loot-item { width: 48px; height: 48px; font-size: 24px; }
}

/* Very small (<360px): stack hero vertical so name no se aprete */
@media (max-width: 360px) {
  .mdm2-hero {
    flex-direction: column; align-items: center;
    text-align: center;
  }
  .mdm2-hero-info { align-items: center; }
  .mdm2-hero-rarity { align-self: center; }
  .mdm2-hero-divider { display: none; }
  .mdm2-hp-text { text-align: center; }
}
