/* ============================================================
   SODOMA — Lootbox / Chaves (animação de abertura)
   ============================================================ */

.crate {
  max-width: 860px;
  margin-inline: auto;
}

/* Aviso de demonstração interativa */
.crate__notice {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  max-width: 860px;
  margin: 0 auto var(--sp-5);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--r-md);
  background: rgba(74, 163, 255, 0.08);
  border: 1px solid rgba(74, 163, 255, 0.28);
  color: var(--text-200);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.crate__notice i { color: var(--info); font-size: 1.1rem; margin-top: 2px; flex-shrink: 0; }
.crate__notice strong { color: var(--text-100); }

.crate__viewport {
  position: relative;
  overflow: hidden;
  border-radius: var(--r-lg);
  border: 1px solid var(--border-strong);
  background:
    radial-gradient(circle at 50% 50%, rgba(226,59,78,0.1), transparent 70%),
    var(--bg-800);
  padding: var(--sp-5) 0;
  box-shadow: var(--shadow-lg), inset 0 0 60px rgba(0,0,0,0.6);
}
/* Marcador central (ponteiro) */
.crate__viewport::before,
.crate__viewport::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 3px;
  background: var(--accent-bright);
  box-shadow: 0 0 12px var(--accent-glow);
  z-index: 3;
}
.crate__viewport::before { top: 0; height: 18px; }
.crate__viewport::after { bottom: 0; height: 18px; }
/* Máscara de bordas */
.crate__viewport .crate__fade {
  position: absolute;
  top: 0; bottom: 0; width: 22%;
  z-index: 2; pointer-events: none;
}
.crate__fade--l { left: 0; background: linear-gradient(90deg, var(--bg-800), transparent); }
.crate__fade--r { right: 0; background: linear-gradient(270deg, var(--bg-800), transparent); }

.crate__track {
  display: flex;
  gap: 12px;
  padding-inline: var(--sp-4);
  will-change: transform;
}
.crate__cell {
  flex: 0 0 96px;
  height: 96px;
  display: grid;
  place-items: center;
  border-radius: var(--r-md);
  background: var(--bg-600);
  border: 1px solid var(--border);
  position: relative;
}
.crate__cell img {
  width: 56px; height: 56px;
  image-rendering: pixelated;
  object-fit: contain;
}

/* Raridades */
.rarity-common    { box-shadow: inset 0 0 0 1px rgba(255,255,255,0.1); }
.rarity-uncommon  { border-color: #3ad07a; box-shadow: 0 0 14px rgba(58,208,122,0.25); }
.rarity-rare      { border-color: #4aa3ff; box-shadow: 0 0 16px rgba(74,163,255,0.3); }
.rarity-legendary { border-color: var(--gold); box-shadow: 0 0 20px rgba(242,181,41,0.4); }
.rarity-text-common { color: var(--text-300); }
.rarity-text-uncommon { color: var(--success); }
.rarity-text-rare { color: var(--info); }
.rarity-text-legendary { color: var(--gold-soft); }

.crate__controls {
  display: flex;
  justify-content: center;
  gap: var(--sp-4);
  margin-top: var(--sp-6);
}

.crate__result {
  margin-top: var(--sp-6);
  display: grid;
  place-items: center;
  opacity: 0;
  transform: translateY(14px) scale(0.96);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.crate__result.is-shown { opacity: 1; transform: none; }
.crate__won {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  padding: var(--sp-5) var(--sp-6);
  border-radius: var(--r-lg);
  background: var(--grad-surface);
  border: 1px solid var(--border-strong);
}
.crate__won img { width: 72px; height: 72px; image-rendering: pixelated; }
.crate__won-label { display: block; font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.16em; color: var(--text-400); }
.crate__won-name { display: block; font-family: var(--font-head); font-size: var(--fs-xl); color: var(--text-100); }
.crate__won-rarity { display: inline-block; margin-top: 2px; font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.12em; }

@media (max-width: 540px) {
  .crate__cell { flex-basis: 76px; height: 76px; }
  .crate__cell img { width: 44px; height: 44px; }
}
