/* ============================================================
   PRISM — Case Opening Modal, Spinner, Won Overlay
   Clean professional design
   ============================================================ */

/* ============================================================
   SPINNER
   ============================================================ */
.case-opening {
  margin-bottom: 32px;
}

.spinner-container {
  position: relative;
  width: 100%;
  height: 160px;
  overflow: hidden;
  /* frame premium: profundidade interna + leve borda cyan da marca */
  background: linear-gradient(180deg, #0a0a14 0%, #06060b 100%);
  border: 1px solid color-mix(in srgb, var(--accent-cyan, #00e5ff) 16%, transparent);
  border-radius: var(--radius-lg);
  margin-bottom: 20px;
  box-shadow: inset 0 0 70px rgba(0, 0, 0, 0.6),
              inset 0 1px 0 rgba(255, 255, 255, 0.04),
              0 10px 34px rgba(0, 0, 0, 0.45);
}

/* fade nas laterais — os itens surgem/somem nas bordas (reel premium) */
.spinner-container::before,
.spinner-container::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 90px;
  z-index: 6;
  pointer-events: none;
}
.spinner-container::before {
  left: 0;
  background: linear-gradient(90deg, #07070d 0%, transparent 100%);
}
.spinner-container::after {
  right: 0;
  background: linear-gradient(270deg, #07070d 0%, transparent 100%);
}

/* Center marker — feixe prismático refratado */
.spinner-marker {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  background: var(--prism-gradient);
  box-shadow: 0 0 12px rgba(0, 229, 255, 0.5);
  z-index: 10;
}

/* Triangle arrows */
.spinner-marker::before,
.spinner-marker::after {
  content: '';
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
}

.spinner-marker::before {
  top: -1px;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 9px solid var(--accent-cyan);
}

.spinner-marker::after {
  bottom: -1px;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-bottom: 9px solid var(--accent-cyan);
}

/* Spinner track */
.spinner-track {
  display: flex;
  align-items: center;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  will-change: transform;
  transition: none;
}

.spinner-item {
  flex-shrink: 0;
  width: 160px;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 12px 8px;
  border-right: 1px solid rgba(255, 255, 255, 0.03);
  position: relative;
  /* glow sutil de raridade vindo da base — reel premium com cores passando */
  background: radial-gradient(78% 52% at 50% 100%, color-mix(in srgb, var(--rar, #5b9cf2) 15%, transparent) 0%, transparent 72%);
}

.spinner-item__img {
  width: 84px;
  height: 62px;
  object-fit: contain;
  margin-bottom: 8px;
  filter: brightness(0.92) drop-shadow(0 4px 10px color-mix(in srgb, var(--rar, #5b9cf2) 35%, transparent));
  transition: filter var(--duration-fast);
}

.spinner-item__name {
  font-size: 0.65rem;
  font-weight: 600;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 140px;
  color: var(--text-secondary);
}

/* Weapon type label for spinner */
.spinner-item__weapon {
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-muted);
  opacity: 0.5;
  margin-top: 2px;
}

/* Rarity bottom border (com brilho) */
.spinner-item::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--rar, #5b9cf2);
  box-shadow: 0 0 10px color-mix(in srgb, var(--rar, #5b9cf2) 55%, transparent);
}

.spinner-item[data-rarity="consumer"]::after   { background: var(--rarity-consumer); }
.spinner-item[data-rarity="industrial"]::after  { background: var(--rarity-industrial); }
.spinner-item[data-rarity="milspec"]::after     { background: var(--rarity-milspec); }
.spinner-item[data-rarity="restricted"]::after  { background: var(--rarity-restricted); }
.spinner-item[data-rarity="classified"]::after  { background: var(--rarity-classified); }
.spinner-item[data-rarity="covert"]::after      { background: var(--rarity-covert); }
.spinner-item[data-rarity="gold"]::after        { background: var(--rarity-gold); }

/* Winner highlight — SÓ após parar (a classe --winner NÃO pode ter visual,
   senão entrega o vencedor durante o giro). --winner é apenas um HOOK. */
.spinner-item--revealed {
  background: color-mix(in srgb, var(--rar, #00e5ff) 8%, transparent);
  z-index: 5;
}

/* Payoff: o vencedor BRILHA na cor da raridade ao parar */
.spinner-item--revealed::before {
  content: '';
  position: absolute;
  inset: 0;
  border: 1.5px solid color-mix(in srgb, var(--rar, #00e5ff) 70%, transparent);
  box-shadow: inset 0 0 24px color-mix(in srgb, var(--rar, #00e5ff) 32%, transparent),
              0 0 26px color-mix(in srgb, var(--rar, #00e5ff) 28%, transparent);
  pointer-events: none;
  animation: winnerReveal 0.45s var(--ease-out) both;
}

@keyframes winnerReveal {
  0%   { opacity: 0; transform: scale(1.06); }
  100% { opacity: 1; transform: scale(1); }
}

/* Cor da raridade por item (alimenta o glow do vencedor) */
.spinner-item[data-rarity="consumer"]   { --rar: var(--rarity-consumer); }
.spinner-item[data-rarity="industrial"] { --rar: var(--rarity-industrial); }
.spinner-item[data-rarity="milspec"]    { --rar: var(--rarity-milspec); }
.spinner-item[data-rarity="restricted"] { --rar: var(--rarity-restricted); }
.spinner-item[data-rarity="classified"] { --rar: var(--rarity-classified); }
.spinner-item[data-rarity="covert"]     { --rar: var(--rarity-covert); }
.spinner-item[data-rarity="gold"]       { --rar: var(--rarity-gold); }

.spinner-item--revealed .spinner-item__img {
  filter: brightness(1.15);
}

.spinner-item--revealed .spinner-item__name {
  color: var(--text-primary);
}

/* Rarity div inside spinner (kept hidden for clean look) */
.spinner-item__rarity {
  display: none;
}

/* ---- Actions ---- */
.case-opening__actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.btn--open {
  min-width: 260px;
}

/* ============================================================
   CASE ITEMS GRID (possible items)
   ============================================================ */
.case-items-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
}

.case-item {
  position: relative;
  /* Glow de raridade vindo de baixo (assinatura dos sites de CS) + leve volume */
  background:
    radial-gradient(118% 78% at 50% 112%, color-mix(in srgb, var(--rar, #5b9cf2) 26%, transparent) 0%, transparent 62%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(0, 0, 0, 0.18)),
    var(--bg-card);
  border: 1px solid color-mix(in srgb, var(--rar, #5b9cf2) 30%, transparent);
  border-radius: var(--radius-md);
  padding: 14px 8px 12px;
  text-align: center;
  overflow: hidden;
  transition: transform 0.18s var(--ease-out), box-shadow 0.25s ease, border-color 0.25s ease;
}

/* Barra de raridade na base, com brilho (substitui a linha fina do topo) */
.case-item::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background: var(--rar, #5b9cf2);
  box-shadow: 0 0 16px color-mix(in srgb, var(--rar, #5b9cf2) 75%, transparent);
}

.case-item:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--rar, #5b9cf2) 58%, transparent);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.5),
              0 0 26px color-mix(in srgb, var(--rar, #5b9cf2) 22%, transparent);
}

/* a linha do topo foi substituída pela barra+glow da base */
.case-item__rarity-line { display: none; }

.case-item__img {
  width: 80px;
  height: 58px;
  object-fit: contain;
  margin: 4px auto 9px;
  filter: drop-shadow(0 5px 12px color-mix(in srgb, var(--rar, #5b9cf2) 45%, transparent));
}

.case-item__name {
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  margin-bottom: 4px;
}

.case-item__chance {
  font-size: 0.6rem;
  color: var(--text-muted);
  margin-bottom: 2px;
}

.case-item__value {
  font-family: var(--font-body);
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--accent-gold);
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   CONFETTI (erupts from spinner)
   ============================================================ */
.confetti-holder {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: visible;
  z-index: 20;
}

@keyframes confettiBurst {
  0% {
    transform: translate(0, 0) rotate(0deg) scale(1);
    opacity: 1;
  }
  100% {
    transform: translate(var(--tx), var(--ty)) rotate(720deg) scale(0.3);
    opacity: 0;
  }
}

/* ============================================================
   INLINE WON RESULT (below spinner)
   ============================================================ */
.case-won-result {
  margin-top: 16px;
}

.won-result {
  position: relative;
  text-align: center;
  padding: 24px 18px;
  /* aura na cor da raridade do item ganho (premium "você ganhou") */
  background:
    radial-gradient(95% 130% at 50% -12%, color-mix(in srgb, var(--won-color, #00e5ff) 16%, transparent) 0%, transparent 58%),
    rgba(255, 255, 255, 0.015);
  border: 1px solid color-mix(in srgb, var(--won-color, #00e5ff) 35%, transparent);
  border-radius: var(--radius-lg);
  box-shadow: 0 0 40px color-mix(in srgb, var(--won-color, #00e5ff) 14%, transparent),
              inset 0 1px 0 rgba(255, 255, 255, 0.05);
  animation: fadeInUp 0.4s var(--ease-out);
}

.won-result--gold {
  border-color: rgba(255, 215, 0, 0.25);
  background: rgba(255, 215, 0, 0.03);
  animation: fadeInUp 0.4s var(--ease-out), goldPulse 2s ease-in-out infinite;
}

@keyframes goldPulse {
  0%, 100% { box-shadow: 0 0 20px rgba(255, 215, 0, 0.05), inset 0 0 20px rgba(255, 215, 0, 0.02); }
  50%      { box-shadow: 0 0 40px rgba(255, 215, 0, 0.12), inset 0 0 30px rgba(255, 215, 0, 0.04); }
}

.won-result__info {
  margin-bottom: 16px;
}

.won-result__name {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 1.2rem;
  margin-bottom: 4px;
}

.won-result__detail {
  font-size: 0.82rem;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.won-result__price {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--accent-gold);
}

.won-result__actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

/* Gold winner spinner item */
.spinner-item--gold {
  animation: goldWinnerGlow 1.5s ease-in-out infinite;
}

.spinner-item--gold::before {
  border-color: rgba(255, 215, 0, 0.4) !important;
}

@keyframes goldWinnerGlow {
  0%, 100% { background: rgba(255, 215, 0, 0.06); }
  50%      { background: rgba(255, 215, 0, 0.14); }
}

/* ============================================================
   WON OVERLAY (kept for upgrade/trade/battles)
   ============================================================ */
.won-overlay {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 32px;
  background: rgba(2, 2, 6, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.won-overlay.open {
  display: flex;
}

.won-overlay__content {
  position: relative;
  text-align: center;
  animation: scaleIn var(--duration-slow) var(--ease-spring);
}

/* Spinning rays behind won item */
.won-overlay__rays {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(0deg);
  width: 500px;
  height: 500px;
  background: conic-gradient(
    from 0deg,
    transparent,
    rgba(91, 156, 242, 0.04) 10%,
    transparent 20%,
    rgba(139, 92, 246, 0.04) 30%,
    transparent 40%,
    rgba(91, 156, 242, 0.03) 50%,
    transparent 60%,
    rgba(139, 92, 246, 0.03) 70%,
    transparent 80%,
    rgba(91, 156, 242, 0.04) 90%,
    transparent
  );
  border-radius: 50%;
  animation: raysSpin 15s linear infinite;
  pointer-events: none;
}

.won-overlay__item {
  position: relative;
  z-index: 1;
  margin-bottom: 32px;
}

.won-overlay__item-img {
  width: 200px;
  height: 150px;
  object-fit: contain;
  margin: 0 auto 16px;
  animation: wonGlow 2s ease-in-out infinite;
  border-radius: var(--radius-lg);
}

/* Won overlay fallback when image fails */
.won-overlay__item-img[data-failed] {
  display: none;
}

.won-overlay__weapon-fallback {
  width: 200px;
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
}

.won-overlay__weapon-fallback span {
  font-family: var(--font-body);
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: 4px;
  text-transform: uppercase;
  opacity: 0.15;
}

.won-overlay__item-skin {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.won-overlay__item-value {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 1.2rem;
  color: var(--accent-gold);
  font-variant-numeric: tabular-nums;
}

/* Won rarity — name color only, no tinted backgrounds */
.won-rarity--consumer   { color: var(--rarity-consumer); }
.won-rarity--industrial { color: var(--rarity-industrial); }
.won-rarity--milspec    { color: var(--rarity-milspec); }
.won-rarity--restricted { color: var(--rarity-restricted); }
.won-rarity--classified { color: var(--rarity-classified); }
.won-rarity--covert     { color: var(--rarity-covert); }
.won-rarity--gold       { color: var(--rarity-gold); }

/* Won actions */
.won-overlay__actions {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  .spinner-container {
    height: 130px;
  }

  .spinner-item {
    width: 120px;
  }

  .spinner-item__img {
    width: 60px;
    height: 45px;
  }

  .case-items-grid {
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 8px;
  }

  .won-overlay__rays {
    width: 300px;
    height: 300px;
  }

  .won-overlay__item-img {
    width: 150px;
    height: 112px;
  }

  .won-overlay__actions {
    flex-direction: column;
    gap: 8px;
  }

  .case-opening__actions {
    flex-direction: column;
  }
}

@media (max-width: 640px) {
  .case-items-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 480px) {
  .spinner-container {
    height: 110px;
  }

  .spinner-item {
    width: 100px;
  }

  .case-items-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
