/* Event lobby — festive party visuals */
.screen-lobby--event .lobby-screen {
  position: relative;
  overflow: hidden;
}

.event-lobby-name {
  font-size: clamp(1.75rem, 7vw, 3rem);
  font-weight: 900;
  text-align: center;
  margin: 0 0 0.5rem;
  color: #fff;
  text-shadow:
    0 0 12px var(--event-accent, #ff2d95),
    0 0 28px var(--event-accent, #ff2d95),
    0 2px 8px rgba(0, 0, 0, 0.45);
  animation: event-lobby-name-glow 2.2s ease-in-out infinite alternate;
  line-height: 1.15;
  max-width: 100%;
  word-break: break-word;
}

@keyframes event-lobby-name-glow {
  from {
    filter: brightness(1);
    transform: scale(1);
  }
  to {
    filter: brightness(1.12);
    transform: scale(1.02);
  }
}

.screen--event-party {
  position: relative;
  overflow: hidden;
}

.screen--event-party .landing-bg,
.screen--event-party .game-bg {
  position: relative;
  z-index: 0;
}

.screen--event-party .event-party-lights,
.screen--event-party .event-confetti-layer,
.screen--event-party .event-particles-canvas {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}

.screen--event-party .screen-content {
  position: relative;
  z-index: 2;
}

#screen-game.screen--event-party .game-bg {
  opacity: 0.85;
}

.event-party-lights {
  opacity: 0.55;
  background:
    radial-gradient(ellipse 40% 30% at 20% 30%, rgba(255, 45, 149, 0.45), transparent 70%),
    radial-gradient(ellipse 35% 25% at 80% 20%, rgba(0, 229, 255, 0.4), transparent 70%),
    radial-gradient(ellipse 45% 35% at 50% 80%, rgba(255, 215, 0, 0.35), transparent 70%);
  animation: party-lights 8s ease-in-out infinite alternate;
}

@keyframes party-lights {
  0% {
    transform: scale(1) rotate(0deg);
    filter: hue-rotate(0deg);
  }
  50% {
    transform: scale(1.05) rotate(2deg);
    filter: hue-rotate(40deg);
  }
  100% {
    transform: scale(1.02) rotate(-2deg);
    filter: hue-rotate(-30deg);
  }
}

.event-confetti-layer {
  background-image:
    radial-gradient(circle, rgba(255, 255, 255, 0.9) 1px, transparent 1px),
    radial-gradient(circle, rgba(253, 224, 71, 0.85) 1.5px, transparent 1.5px),
    radial-gradient(circle, rgba(244, 114, 182, 0.85) 1px, transparent 1px);
  background-size: 80px 80px, 120px 120px, 60px 60px;
  background-position: 0 0, 40px 60px, 20px 30px;
  animation: confetti-drift 12s linear infinite;
  opacity: 0.35;
}

@keyframes confetti-drift {
  from { background-position: 0 0, 40px 60px, 20px 30px; }
  to { background-position: 0 200px, 40px 260px, 20px 230px; }
}

.event-particles-canvas {
  width: 100%;
  height: 100%;
}

#event-lobby-panel {
  border: 2px solid var(--event-accent, #ff2d95);
  box-shadow: 0 0 24px rgba(255, 45, 149, 0.25);
}

.event-banner {
  font-size: clamp(1.5rem, 6vw, 2.25rem);
  font-weight: 900;
  text-align: center;
  color: #fff;
  margin: 0 0 0.75rem;
  text-shadow: 0 0 16px var(--event-accent, #ff2d95);
  animation: event-banner-pulse 1.8s ease-in-out infinite;
}

@keyframes event-banner-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.03); opacity: 0.92; }
}

.event-playlist-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.event-playlist-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 0.55rem;
  border-radius: 0.5rem;
  background: rgba(0, 0, 0, 0.12);
}

.event-playlist-item__num {
  font-weight: 800;
  color: var(--event-accent, #fde047);
  min-width: 1.25rem;
}

.event-playlist-item__emoji {
  font-size: 1.1rem;
}

.event-playlist-item__name {
  font-weight: 700;
  color: #4c1d95;
}

.player-slots--event .player-slot {
  min-height: 4.5rem;
  padding: 0.35rem;
}

.player-slots--event .player-slot__avatar {
  font-size: 1.5rem;
}

.player-slots--event .player-slot__name {
  font-size: 0.65rem;
  max-width: 4.5rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Event themes */
body.theme-neon-party .landing-bg,
body.theme-neon-party .game-bg {
  background: var(--event-bg-gradient) !important;
}

body.theme-space-disco .landing-bg,
body.theme-space-disco .game-bg {
  background: var(--event-bg-gradient) !important;
}

body.theme-golden-tournament .landing-bg,
body.theme-golden-tournament .game-bg {
  background: var(--event-bg-gradient) !important;
}

body.theme-neon-party .btn-juicy--primary,
body.theme-space-disco .btn-juicy--primary,
body.theme-golden-tournament .btn-juicy--primary {
  box-shadow: 0 4px 0 rgba(0, 0, 0, 0.2), 0 0 12px var(--event-accent);
}
