/* ═══════════════════════════════════════════════════════════════
 *  battlePass.css — Pase de Batalla
 * ═══════════════════════════════════════════════════════════════ */

/* ─── Header ────────────────────────────────────────────────── */
.pass-header {
  position: relative;
  text-align: center;
  padding: 1.4rem 1.2rem 1.2rem;
  margin-bottom: 1rem;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,215,0,.16) 0%, transparent 60%),
    linear-gradient(180deg, #1a0a2a 0%, #0a0510 100%);
  border-radius: 16px;
  border: 1px solid rgba(255,215,0,.22);
  overflow: hidden;
}
.pass-header-bg {
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1.5px 1.5px at 12% 28%, rgba(255,215,0,.55), transparent),
    radial-gradient(1px 1px at 78% 18%, rgba(255,255,255,.45), transparent),
    radial-gradient(1.5px 1.5px at 35% 75%, rgba(255,215,0,.45), transparent),
    radial-gradient(1px 1px at 88% 82%, rgba(255,255,255,.35), transparent);
  opacity: .55;
  pointer-events: none;
}
.pass-header-title {
  font-family: 'Cinzel', serif;
  font-size: 2rem;
  font-weight: bold;
  color: #ffd700;
  text-shadow: 0 0 18px rgba(255,215,0,.55), 0 2px 6px rgba(0,0,0,.6);
  letter-spacing: 2px;
  position: relative;
}
.pass-header-icon {
  font-size: 2.2rem;
  margin-right: .5rem;
  filter: drop-shadow(0 0 10px #ffd700);
}
.pass-header-sub {
  color: #cfc4ad;
  font-size: .92rem;
  margin-top: .35rem;
  font-style: italic;
  position: relative;
}

/* ─── Barra de progreso ─────────────────────────────────────── */
.pass-progress-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 1rem;
  position: relative;
}
.pass-level-chip {
  flex: 0 0 auto;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: radial-gradient(circle at center, #3a2a6a 0%, #1a0a3a 70%, #0a0510 100%);
  border: 2px solid #ffd700;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow:
    0 0 14px rgba(255,215,0,.35),
    inset 0 0 12px rgba(255,215,0,.15);
}
.pass-level-num {
  font-family: 'Cinzel', serif;
  font-size: 1.4rem;
  font-weight: bold;
  color: #ffd700;
  line-height: 1;
}
.pass-level-label {
  font-size: .55rem;
  color: #cfc4ad;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.pass-progress-wrap { flex: 1; }
.pass-progress-track {
  position: relative;
  height: 22px;
  background: #110a1a;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #3a2a6a;
  box-shadow: inset 0 0 8px rgba(0,0,0,.6);
}
.pass-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #ffd700 0%, #ff8800 50%, #ff4400 100%);
  background-size: 200% 100%;
  border-radius: 11px;
  width: 0%;
  transition: width .5s cubic-bezier(.2,.8,.4,1);
  box-shadow: 0 0 12px rgba(255,140,0,.6);
  animation: pass-progress-shimmer 3s linear infinite;
}
@keyframes pass-progress-shimmer {
  0%   { background-position: 0% 0%; }
  100% { background-position: 200% 0%; }
}
.pass-progress-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: .78rem;
  font-weight: bold;
  color: #fff;
  text-shadow: 0 1px 3px rgba(0,0,0,.9);
  letter-spacing: .5px;
}
.pass-progress-stats {
  margin-top: .4rem;
  font-size: .78rem;
  color: #a89b8c;
  text-align: center;
}
.pass-progress-stats strong { color: #ffd700; }

/* ─── Unlock row ────────────────────────────────────────────── */
.pass-unlock-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1rem;
  padding: .7rem 1rem;
  background: rgba(0,0,0,.4);
  border-radius: 10px;
  border: 1px solid rgba(255,215,0,.2);
  position: relative;
  flex-wrap: wrap;
}
.pass-unlock-status {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .9rem;
  color: #e8e0d0;
}
.pass-lock-icon { font-size: 1.2rem; }
.pass-unlock-btn-icon { margin-right: .3rem; }
.pass-unlock-row.unlocked {
  background: linear-gradient(90deg, rgba(255,215,0,.15) 0%, rgba(0,255,0,.08) 100%);
  border-color: #44ff88;
}
.pass-unlock-row.unlocked .pass-lock-icon { filter: hue-rotate(80deg); }
.pass-unlock-row.unlocked #pass-unlock-btn { display: none; }

/* ─── Track de niveles ──────────────────────────────────────── */
.pass-track-wrap {
  margin-top: 1rem;
  padding: 1rem .5rem;
  background: linear-gradient(180deg, rgba(20,12,38,.5) 0%, rgba(10,5,20,.3) 100%);
  border-radius: 12px;
  border: 1px solid rgba(255,215,0,.12);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.pass-track {
  display: flex;
  gap: .6rem;
  padding: .5rem 0;
  min-width: max-content;
}

/* Cada nivel = card vertical */
.pass-level {
  flex: 0 0 130px;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(58,26,106,.45) 0%, transparent 70%),
    linear-gradient(180deg, #1a0a2a 0%, #0a0510 100%);
  border: 1px solid #3a2a6a;
  border-radius: 12px;
  padding: .6rem .5rem .55rem;
  text-align: center;
  position: relative;
  transition: all .25s cubic-bezier(.2,.9,.3,1.4);
}
.pass-level-header {
  font-family: 'Cinzel', serif;
  font-size: .72rem;
  color: #a89b8c;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: .35rem;
}
.pass-level-num-big {
  font-family: 'Cinzel', serif;
  font-size: 1.25rem;
  font-weight: bold;
  color: #ffd700;
  margin-bottom: .35rem;
  line-height: 1;
}

/* Estado de cada nivel */
.pass-level.reached {
  border-color: #ffd700;
  box-shadow: 0 0 14px rgba(255,215,0,.25);
}
.pass-level.claimed {
  border-color: #44ff88;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(68,255,136,.25) 0%, transparent 70%),
    linear-gradient(180deg, #0f1a14 0%, #050a08 100%);
  box-shadow: 0 0 14px rgba(68,255,136,.2);
  opacity: .85;
}
.pass-level.unreached {
  opacity: .55;
  filter: grayscale(.5);
}
.pass-level.claimable {
  border-color: #ffd700;
  box-shadow: 0 0 18px rgba(255,215,0,.45);
  animation: pass-level-claim-pulse 1.5s ease-in-out infinite;
}
@keyframes pass-level-claim-pulse {
  0%, 100% { box-shadow: 0 0 18px rgba(255,215,0,.45); }
  50%      { box-shadow: 0 0 28px rgba(255,215,0,.75); }
}

/* Reward icon dentro de la card */
.pass-reward-art {
  width: 64px;
  height: 64px;
  margin: 0 auto .4rem;
  border-radius: 50%;
  background: radial-gradient(ellipse, #1a1024 0%, #060008 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  border: 1px solid #2a1a4a;
  box-shadow: inset 0 0 10px rgba(0,0,0,.6);
}
.pass-reward-emoji {
  font-size: 1.7rem;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.7));
}
.pass-reward-coin-amount {
  font-family: 'Cinzel', serif;
  font-size: .9rem;
  font-weight: bold;
  color: #ffd700;
  margin-top: -.2rem;
}
.pass-reward-name {
  font-size: .7rem;
  color: #e8e0d0;
  line-height: 1.15;
  min-height: 2.4em;
  margin-bottom: .35rem;
}
.pass-reward-rarity {
  font-size: .58rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: bold;
  padding: .12rem .35rem;
  border-radius: 6px;
  display: inline-block;
  margin-bottom: .3rem;
}
.pass-reward-rarity.rarity-common    { color:#ddd;    background:#44444433; }
.pass-reward-rarity.rarity-rare      { color:#5cbdfd; background:#3498db33; }
.pass-reward-rarity.rarity-epic      { color:#c79bfd; background:#9b59b633; }
.pass-reward-rarity.rarity-legendary { color:#ffe066; background:#f1c40f33; }
.pass-reward-rarity.rarity-mythic    { color:#ff8cff; background:#ff44ff33; }

/* Botón de reclamar */
.pass-claim-btn {
  width: 100%;
  padding: .35rem 0;
  border-radius: 6px;
  font-size: .7rem;
  font-weight: bold;
  cursor: pointer;
  transition: all .2s;
  text-transform: uppercase;
  letter-spacing: 1px;
  border: 1px solid transparent;
  margin-top: .15rem;
}
.pass-claim-btn.btn-claim {
  background: linear-gradient(135deg, #ffd700 0%, #ff8800 100%);
  color: #1a0a00;
  border-color: #ffd700;
  box-shadow: 0 0 10px rgba(255,215,0,.6);
}
.pass-claim-btn.btn-claim:hover {
  filter: brightness(1.15);
  transform: translateY(-1px);
}
.pass-claim-btn.btn-claimed {
  background: rgba(68,255,136,.15);
  color: #44ff88;
  border-color: #44ff88;
  cursor: default;
}
.pass-claim-btn.btn-locked {
  background: rgba(0,0,0,.45);
  color: #666;
  border-color: #3a2a4a;
  cursor: not-allowed;
}

/* Cosméticos preview dentro de level cards */
.pass-reward-art .platform-bronze,
.pass-reward-art .platform-silver,
.pass-reward-art .platform-gold,
.pass-reward-art .platform-lava,
.pass-reward-art .platform-iron {
  position: absolute;
  bottom: 6px;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 14px;
  border-radius: 50%;
}

/* ─── Capstone (nivel 50) ───────────────────────────────────── */
.pass-level.capstone {
  flex: 0 0 180px;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,68,255,.35) 0%, transparent 70%),
    linear-gradient(180deg, #2a0a3a 0%, #0a0510 100%);
  border: 2px solid #ff44ff;
  box-shadow: 0 0 22px rgba(255,68,255,.4);
}
.pass-level.capstone .pass-level-num-big {
  color: #ff44ff;
  font-size: 1.6rem;
}
.pass-level.capstone .pass-reward-art {
  width: 80px;
  height: 80px;
}
.pass-level.capstone .pass-reward-emoji {
  font-size: 2.4rem;
}

/* ─── Notificación de claim ─────────────────────────────────── */
.pass-claim-toast {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%) translateY(100px);
  background: linear-gradient(135deg, #1a0a2a 0%, #3a1a6a 100%);
  border: 2px solid #ffd700;
  border-radius: 14px;
  padding: 1rem 1.5rem;
  color: #fff;
  z-index: 9999;
  box-shadow: 0 0 28px rgba(255,215,0,.55);
  opacity: 0;
  transition: all .4s cubic-bezier(.2,.9,.3,1.4);
  text-align: center;
  min-width: 240px;
}
.pass-claim-toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.pass-claim-toast-title {
  font-family: 'Cinzel', serif;
  font-weight: bold;
  color: #ffd700;
  font-size: 1rem;
  margin-bottom: .35rem;
}
.pass-claim-toast-items {
  display: flex;
  justify-content: center;
  gap: .5rem;
  flex-wrap: wrap;
  font-size: .9rem;
}
