/* ============================================================
   POLISH — V3.6
   Microinteracciones y animaciones sutiles (CSS-only salvo
   count-up y scroll-to-top, que están en polish.js).
   Reglas ADITIVAS: cargan DESPUÉS de style.css y solo refuerzan
   lo existente. Todo con transform/opacity (GPU). Sin librerías.
   ============================================================ */

/* ── Scroll suave en anchors internos (#herramientas, #home-sorteos…) ── */
html { scroll-behavior: smooth; }

/* ════════════════════════════════════════════════════════════
   1. HERO — animación de entrada (una vez al cargar la home)
   fade-in + slide-up con stagger. Solo afecta a .bf-hero, que
   únicamente existe en la home.
   ════════════════════════════════════════════════════════════ */
@keyframes bf-fade-up {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
.bf-hero__title,
.bf-hero__sub,
.bf-hero__actions {
  opacity: 0;
  animation: bf-fade-up 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
.bf-hero__title   { animation-delay: 0.05s; }
.bf-hero__sub     { animation-delay: 0.22s; }
.bf-hero__actions { animation-delay: 0.38s; }
/* La imagen/arte de la derecha entra suave también, sin desplazar layout */
.bf-hero__visual {
  opacity: 0;
  animation: bf-fade-up 0.7s cubic-bezier(0.4, 0, 0.2, 1) 0.15s forwards;
}

/* ════════════════════════════════════════════════════════════
   3. CARDS "Todo lo que necesitas" — refuerzo del glow gold.
   El lift (-4px) y el borde gold ya existen en style.css; aquí
   solo intensificamos el glow al hover (0.08 → 0.15).
   ════════════════════════════════════════════════════════════ */
@media (hover: hover) {
  .bf-card:hover,
  .bf-card:focus-visible {
    box-shadow: 0 14px 34px rgba(0,0,0,0.35),
                0 0 0 1px rgba(245,197,24,0.25),
                0 8px 28px rgba(245,197,24,0.15);
  }
}

/* ════════════════════════════════════════════════════════════
   4. TIENDA (Mirage/Normal) — items en grid + hover scale.
   Cada columna de tienda (.bf-shop-col) ocupa media anchura en
   desktop, así que el grid de items va a 2 columnas por tienda
   (≈4 items por fila en la sección). En móvil, .bf-shop-cols ya
   colapsa a 1 columna, así que cada tienda ocupa todo el ancho.
   Solo CSS — el HTML del template no se toca.
   ════════════════════════════════════════════════════════════ */
.bf-shop-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.6rem;
}
.bf-shop-item {
  /* mantiene el layout interno img | nombre | precio */
  background: var(--bf-bg-alt);
  border: 1px solid var(--bf-border);
  padding: 0.55rem 0.65rem;
  transition: transform 0.2s ease,
              border-color 0.2s ease,
              box-shadow 0.2s ease,
              background-color 0.2s ease;
  will-change: transform;
}
@media (hover: hover) {
  .bf-shop-item:hover {
    transform: scale(1.03);
    background: var(--bf-bg-alt);
    border-color: rgba(245,197,24,0.45);
    box-shadow: 0 6px 18px rgba(0,0,0,0.35),
                0 0 14px rgba(245,197,24,0.12);
  }
}
/* En pantallas muy estrechas, 1 item por fila para que no se aprieten */
@media (max-width: 380px) {
  .bf-shop-list { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   7. BOTONES PRIMARY — scale sutil + glow al hover, press al click.
   El translateY(-2px) de .bf-btn--lg ya existe; lo fusionamos con
   un scale para no pisar la propiedad transform.
   ════════════════════════════════════════════════════════════ */
@media (hover: hover) {
  .bf-btn--primary:hover,
  .bf-btn--primary:focus-visible {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 8px 22px rgba(245,197,24,0.28);
  }
}
.bf-btn--primary:active { transform: scale(0.98); }

/* ════════════════════════════════════════════════════════════
   8. VÍDEOS — framing sutil (sombra base + lift/glow al hover).
   El border-radius, el border gold y el lift ya existen; añadimos
   una sombra base y reforzamos al hover.
   ════════════════════════════════════════════════════════════ */
.bf-video-card {
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
}
@media (hover: hover) {
  .bf-video-card:hover {
    box-shadow: 0 14px 32px rgba(0,0,0,0.4),
                0 0 16px rgba(245,197,24,0.10);
  }
}

/* ════════════════════════════════════════════════════════════
   6. SCROLL-TO-TOP — botón flotante (markup lo crea polish.js)
   ════════════════════════════════════════════════════════════ */
.bloxy-scrolltop {
  position: fixed;
  right: 1.25rem;
  bottom: 1.5rem;
  width: 46px;
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(245,197,24,0.35);
  border-radius: 50%;
  background: rgba(17,17,24,0.92);
  color: var(--bf-gold);
  cursor: pointer;
  z-index: 9997;
  padding: 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s, background-color 0.2s ease;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.45);
}
.bloxy-scrolltop.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.bloxy-scrolltop:hover { background: rgba(26,26,37,0.96); }
.bloxy-scrolltop svg { width: 20px; height: 20px; }

/* Eleva el botón por encima del banner de cookies cuando está visible
   (el banner ocupa z-index 9998 abajo del todo). :has() está soportado
   en todos los navegadores actuales; si no, el botón queda en su sitio. */
body:has(.bloxy-consent-bar.is-visible) .bloxy-scrolltop { bottom: calc(1.5rem + 78px); }

@media (max-width: 600px) {
  .bloxy-scrolltop { width: 38px; height: 38px; right: 0.9rem; bottom: 1rem; }
  .bloxy-scrolltop svg { width: 17px; height: 17px; }
  body:has(.bloxy-consent-bar.is-visible) .bloxy-scrolltop { bottom: calc(1rem + 120px); }
}

/* ════════════════════════════════════════════════════════════
   prefers-reduced-motion — respeta la preferencia del usuario.
   Desactiva animaciones de entrada y deja el contenido visible.
   ════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .bf-hero__title,
  .bf-hero__sub,
  .bf-hero__actions,
  .bf-hero__visual { opacity: 1 !important; transform: none !important; }
}
