/* ==========================================================================
   LyricBingo — Branded page loader
   ========================================================================== */

#bd-page-loader {
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(139, 92, 246, 0.22), transparent 55%),
    #07060e !important;
}

.bd-page-loader-scene {
  position: relative;
  text-align: center;
  width: min(100%, 18rem);
}

.bd-page-loader-orbs {
  position: absolute;
  inset: -4rem -3rem;
  pointer-events: none;
}

.bd-page-loader-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(40px);
  opacity: 0.5;
  animation: bd-loader-orb 4s ease-in-out infinite alternate;
}

.bd-page-loader-orb--1 {
  width: 8rem;
  height: 8rem;
  top: 0;
  left: 10%;
  background: rgba(139, 92, 246, 0.5);
}

.bd-page-loader-orb--2 {
  width: 6rem;
  height: 6rem;
  bottom: 10%;
  right: 5%;
  background: rgba(45, 212, 191, 0.35);
  animation-delay: -2s;
}

@keyframes bd-loader-orb {
  from { transform: translate(0, 0); }
  to { transform: translate(12px, -10px); }
}

.bd-page-loader-floats {
  position: absolute;
  inset: -2rem;
  pointer-events: none;
}

.bd-page-loader-note {
  position: absolute;
  font-size: 1.25rem;
  opacity: 0.4;
  animation: bd-loader-note 3s ease-in-out infinite;
}

.bd-page-loader-note--1 { top: 5%; left: 0; animation-delay: 0s; }
.bd-page-loader-note--2 { top: 20%; right: -5%; animation-delay: -1s; }
.bd-page-loader-note--3 { bottom: 15%; left: 5%; animation-delay: -2s; }

@keyframes bd-loader-note {
  0%, 100% { transform: translateY(0) rotate(-8deg); opacity: 0.35; }
  50% { transform: translateY(-10px) rotate(8deg); opacity: 0.6; }
}

.bd-page-loader-balls {
  display: flex;
  justify-content: center;
  gap: 0.35rem;
  margin-bottom: 1rem;
}

.bd-page-loader-ball {
  width: 1.65rem;
  height: 1.65rem;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: "Bebas Neue", impact, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  color: #1a1028;
  animation: bd-loader-ball 1.2s ease-in-out infinite;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.bd-page-loader-ball:nth-child(1) { background: linear-gradient(145deg, #ff6b9d, #ff2d95); animation-delay: 0s; }
.bd-page-loader-ball:nth-child(2) { background: linear-gradient(145deg, #a78bfa, #7c3aed); animation-delay: 0.1s; color: #fff; }
.bd-page-loader-ball:nth-child(3) { background: linear-gradient(145deg, #5eead4, #14b8a6); animation-delay: 0.2s; }
.bd-page-loader-ball:nth-child(4) { background: linear-gradient(145deg, #fde047, #fbbf24); animation-delay: 0.3s; }
.bd-page-loader-ball:nth-child(5) { background: linear-gradient(145deg, #c6ff4a, #84cc16); animation-delay: 0.4s; }

@keyframes bd-loader-ball {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-6px) scale(1.08); }
}

.bd-page-loader-logo {
  position: relative;
  z-index: 1;
  animation: bd-loader-logo-pulse 2s ease-in-out infinite;
}

@keyframes bd-loader-logo-pulse {
  0%, 100% { transform: scale(1); filter: drop-shadow(0 0 0 transparent); }
  50% { transform: scale(1.02); filter: drop-shadow(0 0 16px rgba(139, 92, 246, 0.35)); }
}

.bd-page-loader-eq {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 4px;
  height: 32px;
  margin: 1rem auto 0.75rem;
}

.bd-page-loader-eq span {
  width: 5px;
  border-radius: 3px;
  background: linear-gradient(180deg, #2dd4bf, #8b5cf6);
  animation: bd-loader-eq 0.75s ease-in-out infinite;
}

.bd-page-loader-eq span:nth-child(1) { height: 12px; animation-delay: 0s; }
.bd-page-loader-eq span:nth-child(2) { height: 22px; animation-delay: 0.08s; }
.bd-page-loader-eq span:nth-child(3) { height: 16px; animation-delay: 0.16s; }
.bd-page-loader-eq span:nth-child(4) { height: 28px; animation-delay: 0.12s; }
.bd-page-loader-eq span:nth-child(5) { height: 18px; animation-delay: 0.2s; }
.bd-page-loader-eq span:nth-child(6) { height: 24px; animation-delay: 0.04s; }
.bd-page-loader-eq span:nth-child(7) { height: 14px; animation-delay: 0.24s; }

@keyframes bd-loader-eq {
  0%, 100% { transform: scaleY(0.35); }
  50% { transform: scaleY(1); }
}

.bd-page-loader-text {
  position: relative;
  z-index: 1;
  font-size: 0.75rem !important;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #a39cc4 !important;
}

.bd-page-loader-bar {
  display: none !important;
}

@media (prefers-reduced-motion: reduce) {
  .bd-page-loader-orb,
  .bd-page-loader-note,
  .bd-page-loader-ball,
  .bd-page-loader-logo,
  .bd-page-loader-eq span {
    animation: none !important;
  }
}

/* V2 branded loader */
.lb-v2 .v2-branded-loader { position: relative; }
.lb-v2 .v2-loader-balls {
  display: flex;
  justify-content: center;
  gap: 0.35rem;
  margin-bottom: 1rem;
}
.lb-v2 .v2-loader-balls span {
  width: 1.65rem;
  height: 1.65rem;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: "Bebas Neue", impact, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  color: #1a1028;
  animation: bd-loader-ball 1.2s ease-in-out infinite;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}
.lb-v2 .v2-loader-balls span:nth-child(1) { background: linear-gradient(145deg, #ff6b9d, #ff2d95); }
.lb-v2 .v2-loader-balls span:nth-child(2) { background: linear-gradient(145deg, #a78bfa, #7c3aed); animation-delay: 0.1s; color: #fff; }
.lb-v2 .v2-loader-balls span:nth-child(3) { background: linear-gradient(145deg, #5eead4, #14b8a6); animation-delay: 0.2s; }
.lb-v2 .v2-loader-balls span:nth-child(4) { background: linear-gradient(145deg, #fde047, #fbbf24); animation-delay: 0.3s; }
.lb-v2 .v2-loader-balls span:nth-child(5) { background: linear-gradient(145deg, #c6ff4a, #84cc16); animation-delay: 0.4s; }
.lb-v2 .v2-loader-logo {
  width: min(200px, 62vw);
  height: auto;
  margin: 0 auto 0.75rem;
  display: block;
  animation: bd-loader-logo-pulse 2s ease-in-out infinite;
}
.lb-v2 .v2-loader-eq {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 4px;
  height: 32px;
  margin: 0 auto 0.85rem;
}
.lb-v2 .v2-loader-eq span {
  width: 5px;
  border-radius: 3px;
  background: linear-gradient(180deg, #2dd4bf, #8b5cf6);
  animation: bd-loader-eq 0.75s ease-in-out infinite;
}
.lb-v2 .v2-loader-eq span:nth-child(1) { height: 12px; }
.lb-v2 .v2-loader-eq span:nth-child(2) { height: 22px; animation-delay: 0.08s; }
.lb-v2 .v2-loader-eq span:nth-child(3) { height: 16px; animation-delay: 0.16s; }
.lb-v2 .v2-loader-eq span:nth-child(4) { height: 28px; animation-delay: 0.12s; }
.lb-v2 .v2-loader-eq span:nth-child(5) { height: 18px; animation-delay: 0.2s; }
.lb-v2 .v2-loader-eq span:nth-child(6) { height: 24px; animation-delay: 0.04s; }
.lb-v2 .v2-loader-eq span:nth-child(7) { height: 14px; animation-delay: 0.24s; }
