/* =============================================================================
   BRUXÃO MENU — Cards de produto: reflexo premium global + destaque CS2 PRO
   HTML: components/package-card.html · sem JS
============================================================================= */

/* -----------------------------------------------------------------------------
   GLOBAL — todos os cards (.package)
----------------------------------------------------------------------------- */

a.package {
  position: relative;
  isolation: isolate;
}

a.package:not(.pkg-featured-card) {
  transition:
    border-color 0.38s ease,
    box-shadow 0.38s ease,
    transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Vidro / brilho suave no hover (sobre o card inteiro) */
a.package:not(.pkg-featured-card)::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 6;
  opacity: 0;
  background: linear-gradient(
    145deg,
    hsl(var(--primary) / 0.06) 0%,
    transparent 42%,
    rgba(255, 255, 255, 0.06) 50%,
    transparent 58%,
    hsl(var(--primary) / 0.05) 100%
  );
  background-size: 200% 200%;
  transition: opacity 0.4s ease;
}

a.package:not(.pkg-featured-card):hover::before {
  opacity: 1;
  transition-duration: 0.35s;
}

a.package:not(.pkg-featured-card):hover {
  border-color: hsl(var(--primary) / 0.35);
  box-shadow:
    0 0 0 1px hsl(var(--primary) / 0.08) inset,
    0 10px 36px hsl(0 0% 0% / 0.28),
    0 0 24px hsl(var(--primary) / 0.12);
}

.pkg-card-media {
  position: relative;
  overflow: hidden;
}

.pkg-card-shine {
  position: absolute;
  inset: -40% -65%;
  width: 52%;
  pointer-events: none;
  z-index: 4;
  background: linear-gradient(
    118deg,
    transparent 0%,
    rgba(255, 255, 255, 0) 40%,
    rgba(255, 255, 255, 0.09) 49%,
    rgba(230, 215, 255, 0.14) 50.2%,
    rgba(255, 255, 255, 0.08) 51.5%,
    transparent 64%
  );
  transform: translateX(-145%) skewX(-13deg);
  opacity: 0;
}

a.package:hover .pkg-card-shine {
  animation: pkg-card-shine-sweep 0.82s cubic-bezier(0.38, 0, 0.2, 1) forwards;
}

@keyframes pkg-card-shine-sweep {
  0% {
    transform: translateX(-145%) skewX(-13deg);
    opacity: 0;
  }
  14% {
    opacity: 1;
  }
  100% {
    transform: translateX(210%) skewX(-13deg);
    opacity: 0;
  }
}

.pkg-card-img {
  transition:
    transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.4s ease;
}

a.package:not(.pkg-featured-card):hover .pkg-card-img {
  transform: scale(1.03);
  filter: saturate(1.05) brightness(1.03);
}

@media (max-width: 639px) {
  a.package:not(.pkg-featured-card):hover .pkg-card-img {
    transform: scale(1.018);
    filter: saturate(1.03) brightness(1.02);
  }

  a.package:hover .pkg-card-shine {
    animation-duration: 0.68s;
  }
}

/* -----------------------------------------------------------------------------
   Produtos em destaque — CS2 PRO, Netflix (shell, badge, glow, reflexo)
----------------------------------------------------------------------------- */

.pkg-featured-shell {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  border-radius: 0.75rem;
  padding: 2px;
  isolation: isolate;
  background: linear-gradient(
    125deg,
    hsl(var(--primary) / 0.42),
    rgba(88, 28, 135, 0.38),
    hsl(var(--primary) / 0.4),
    rgba(124, 58, 237, 0.36),
    hsl(var(--primary) / 0.44)
  );
  background-size: 220% 220%;
  animation: pkg-feat-border-flow 8s ease-in-out infinite;
  box-shadow:
    0 0 0 1px hsl(var(--primary) / 0.22),
    0 0 18px hsl(var(--primary) / 0.16),
    0 0 40px hsl(var(--primary) / 0.1);
  transition: box-shadow 0.45s ease;
}

.pkg-featured-shell:has(.pkg-featured-card:hover) {
  box-shadow:
    0 0 0 1px hsl(var(--primary) / 0.32),
    0 0 28px hsl(var(--primary) / 0.28),
    0 0 56px hsl(var(--primary) / 0.16);
}

.pkg-featured-shell::after {
  content: '';
  position: absolute;
  inset: -6px;
  border-radius: inherit;
  z-index: -1;
  pointer-events: none;
  background: transparent;
  box-shadow:
    0 0 26px hsl(var(--primary) / 0.26),
    0 0 52px hsl(var(--primary) / 0.12);
  opacity: 0.55;
  filter: blur(0);
  animation: pkg-feat-glow-pulse 4s ease-in-out infinite;
  transition: opacity 0.45s ease;
}

.pkg-featured-shell:has(.pkg-featured-card:hover)::after {
  opacity: 0.82;
}

@keyframes pkg-feat-border-flow {
  0%,
  100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

@keyframes pkg-feat-glow-pulse {
  0%,
  100% {
    opacity: 0.48;
    filter: blur(0);
  }
  50% {
    opacity: 0.78;
    filter: blur(0.5px);
  }
}

.pkg-featured-badge {
  position: absolute;
  left: 50%;
  top: 0;
  z-index: 8;
  transform: translate(-50%, -48%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.28rem;
  padding: 0.38rem 0.65rem 0.42rem;
  border-radius: 9999px;
  font-family: 'Geist', system-ui, sans-serif;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  white-space: nowrap;
  color: rgba(252, 250, 255, 0.96);
  background: linear-gradient(
    145deg,
    hsl(var(--primary) / 0.92) 0%,
    rgba(88, 28, 135, 0.88) 50%,
    hsl(var(--primary) / 0.85) 100%
  );
  border: 1px solid hsl(var(--primary) / 0.55);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.06) inset,
    0 2px 12px hsl(0 0% 0% / 0.35),
    0 0 18px hsl(var(--primary) / 0.45);
  backdrop-filter: blur(10px) saturate(1.3);
  -webkit-backdrop-filter: blur(10px) saturate(1.3);
  text-shadow: 0 1px 8px hsl(0 0% 0% / 0.35);
}

@media (min-width: 640px) {
  .pkg-featured-badge {
    font-size: 0.62rem;
    padding: 0.42rem 0.75rem 0.46rem;
    letter-spacing: 0.12em;
  }
}

.pkg-featured-shell .pkg-featured-card {
  position: relative;
  z-index: 4;
  height: 100%;
  border-radius: calc(0.75rem - 2px);
  overflow: hidden;
  border-color: hsl(var(--primary) / 0.28);
  box-shadow:
    0 0 0 1px hsl(0 0% 100% / 0.05) inset,
    0 12px 32px hsl(0 0% 0% / 0.28);
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.45s ease,
    box-shadow 0.45s ease;
}

.pkg-featured-shell .pkg-featured-card:hover {
  transform: scale(1.022);
  border-color: hsl(var(--primary) / 0.58);
  box-shadow:
    0 0 0 1px hsl(var(--primary) / 0.14) inset,
    0 18px 48px hsl(0 0% 0% / 0.4),
    0 0 36px hsl(var(--primary) / 0.32),
    0 0 52px hsl(var(--primary) / 0.14);
}

.pkg-featured-media {
  position: relative;
  overflow: hidden;
}

/* Reflexo hero: um pouco mais intenso que o global */
.pkg-featured-shell .pkg-card-shine {
  background: linear-gradient(
    118deg,
    transparent 0%,
    rgba(255, 255, 255, 0) 38%,
    rgba(255, 255, 255, 0.12) 48.5%,
    rgba(235, 220, 255, 0.2) 50%,
    rgba(255, 255, 255, 0.11) 52%,
    transparent 65%
  );
}

.pkg-featured-shell .pkg-featured-card:hover .pkg-card-shine {
  animation: pkg-card-shine-sweep 0.92s cubic-bezier(0.38, 0, 0.2, 1) forwards;
}

.pkg-featured-img {
  transition:
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.45s ease;
}

.pkg-featured-shell .pkg-featured-card:hover .pkg-featured-img {
  transform: scale(1.045);
  filter: saturate(1.1) brightness(1.05);
}

/* Slider similares */
.pkg-featured-shell--compact {
  border-radius: 0.65rem;
  padding: 2px;
  animation-duration: 10s;
  box-shadow:
    0 0 0 1px hsl(var(--primary) / 0.18),
    0 0 12px hsl(var(--primary) / 0.12);
}

.pkg-featured-shell--compact::after {
  inset: -3px;
  opacity: 0.4;
  animation: none;
}

.pkg-featured-shell--compact .pkg-featured-badge {
  font-size: 0.52rem;
  padding: 0.3rem 0.5rem 0.34rem;
  letter-spacing: 0.08em;
  transform: translate(-50%, -42%);
}

.pkg-featured-shell--compact .pkg-featured-card {
  border-radius: calc(0.65rem - 2px);
}

.pkg-featured-shell--compact .pkg-featured-card:hover {
  transform: scale(1.012);
}

.pkg-featured-shell--compact .pkg-featured-card:hover .pkg-featured-img {
  transform: scale(1.03);
}

.pkg-featured-shell--compact .pkg-featured-card:hover .pkg-card-shine {
  animation: pkg-card-shine-sweep 0.72s cubic-bezier(0.38, 0, 0.2, 1) forwards;
}

@media (max-width: 639px) {
  .pkg-featured-shell::after {
    inset: -3px;
    opacity: 0.38;
    box-shadow: 0 0 18px hsl(var(--primary) / 0.18);
  }

  .pkg-featured-shell {
    box-shadow:
      0 0 0 1px hsl(var(--primary) / 0.18),
      0 0 12px hsl(var(--primary) / 0.12);
  }

  .pkg-featured-shell .pkg-featured-card:hover {
    transform: scale(1.014);
  }

  .pkg-featured-shell .pkg-featured-card:hover .pkg-featured-img {
    transform: scale(1.028);
  }

}

@media (prefers-reduced-motion: reduce) {
  a.package:hover .pkg-card-shine,
  .pkg-featured-shell .pkg-featured-card:hover .pkg-card-shine {
    animation: none;
    opacity: 0;
  }

  .pkg-featured-shell,
  .pkg-featured-shell::after {
    animation: none !important;
  }

  .pkg-featured-shell {
    background-position: 50% 50%;
  }

  a.package:not(.pkg-featured-card):hover .pkg-card-img,
  .pkg-featured-shell .pkg-featured-card:hover .pkg-featured-img {
    transform: none;
    filter: none;
  }

  a.package:not(.pkg-featured-card):hover::before {
    opacity: 0;
  }

  .pkg-featured-shell .pkg-featured-card:hover {
    transform: none;
  }
}
