/* ========================================================================
   BRINCADEIRAS ARTÍSTICAS COM AZUL — ELEMENTOS DECORATIVOS
   ======================================================================== */

/* ----- Burst AZUL sticker ----- */
.blue-burst-text {
  position: absolute;
  display: inline-block;
  background: var(--blue);
  color: var(--yellow);
  padding: 6px 16px;
  font-family: var(--font-display);
  font-size: 0.95rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 800;
  transform: rotate(-8deg);
  box-shadow: 4px 4px 0 var(--black);
  z-index: 3;
  pointer-events: none;
  font-style: italic;
  animation: blue-bounce 3.5s ease-in-out infinite;
}
@keyframes blue-bounce {
  0%, 100% { transform: rotate(-8deg) translateY(0); }
  50% { transform: rotate(-8deg) translateY(-10px); }
}
.blue-burst-text.rotate-pos {
  transform: rotate(6deg);
  animation: blue-bounce-pos 3.5s ease-in-out infinite;
}
@keyframes blue-bounce-pos {
  0%, 100% { transform: rotate(6deg) translateY(0); }
  50% { transform: rotate(6deg) translateY(-10px); }
}

/* ----- Cross / + decorativos azuis ----- */
.blue-cross {
  position: absolute;
  width: 28px;
  height: 28px;
  pointer-events: none;
  z-index: 2;
  animation: cross-spin-blue 10s linear infinite;
}
.blue-cross::before, .blue-cross::after {
  content: '';
  position: absolute;
  background: var(--blue);
  box-shadow: 0 0 15px var(--blue);
}
.blue-cross::before {
  top: 50%; left: 0; right: 0; height: 3px;
  transform: translateY(-50%);
}
.blue-cross::after {
  left: 50%; top: 0; bottom: 0; width: 3px;
  transform: translateX(-50%);
}
.blue-cross.small { width: 16px; height: 16px; }
@keyframes cross-spin-blue {
  to { transform: rotate(360deg); }
}

/* ----- Círculos pulsantes azuis ----- */
.blue-circle {
  position: absolute;
  width: 100px;
  height: 100px;
  border: 2px solid var(--blue);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  animation: blue-circle-pulse 4s ease-in-out infinite;
  box-shadow: 0 0 40px rgba(6, 31, 255, 0.35), inset 0 0 30px rgba(6, 31, 255, 0.1);
}
.blue-circle::after {
  content: '';
  position: absolute;
  inset: 10px;
  border: 1px solid var(--blue);
  border-radius: 50%;
  opacity: 0.5;
}
@keyframes blue-circle-pulse {
  0%, 100% { transform: scale(1); opacity: 0.7; }
  50% { transform: scale(1.12); opacity: 1; }
}

/* ----- Estrela azul giratória ----- */
.blue-star {
  position: absolute;
  font-family: var(--font-display);
  font-size: 2.5rem;
  color: var(--blue);
  pointer-events: none;
  z-index: 2;
  text-shadow: 0 0 20px var(--blue);
  animation: star-spin-blue 7s linear infinite;
  font-style: italic;
  font-weight: 900;
}
@keyframes star-spin-blue {
  to { transform: rotate(360deg); }
}

/* ----- Linhas/equalizer azul ----- */
.blue-lines {
  position: absolute;
  display: flex;
  align-items: flex-end;
  gap: 6px;
  pointer-events: none;
  z-index: 2;
  height: 70px;
}
.blue-lines span {
  display: block;
  width: 4px;
  background: var(--blue);
  box-shadow: 0 0 10px var(--blue);
  border-radius: 2px;
  animation: blue-line-grow 1.5s ease-in-out infinite;
}
.blue-lines span:nth-child(1) { animation-delay: 0s; height: 40%; }
.blue-lines span:nth-child(2) { animation-delay: 0.15s; height: 80%; }
.blue-lines span:nth-child(3) { animation-delay: 0.3s; height: 50%; }
.blue-lines span:nth-child(4) { animation-delay: 0.45s; height: 90%; }
.blue-lines span:nth-child(5) { animation-delay: 0.6s; height: 60%; }
.blue-lines span:nth-child(6) { animation-delay: 0.75s; height: 75%; }
@keyframes blue-line-grow {
  0%, 100% { transform: scaleY(0.5); opacity: 0.6; }
  50% { transform: scaleY(1); opacity: 1; }
}

/* ----- Diagonal stripes azul ----- */
.blue-stripes {
  position: absolute;
  width: 180px;
  height: 80px;
  background: repeating-linear-gradient(
    45deg,
    var(--blue) 0px, var(--blue) 6px,
    transparent 6px, transparent 18px
  );
  pointer-events: none;
  z-index: 2;
  opacity: 0.65;
}

/* ----- Dots line azul ----- */
.blue-dots {
  position: absolute;
  display: flex;
  gap: 14px;
  pointer-events: none;
  z-index: 2;
}
.blue-dots span {
  width: 12px;
  height: 12px;
  background: var(--blue);
  border-radius: 50%;
  box-shadow: 0 0 15px var(--blue);
  animation: blue-dot-pulse 2s ease-in-out infinite;
}
.blue-dots span:nth-child(2) { animation-delay: 0.2s; }
.blue-dots span:nth-child(3) { animation-delay: 0.4s; }
.blue-dots span:nth-child(4) { animation-delay: 0.6s; }
.blue-dots span:nth-child(5) { animation-delay: 0.8s; }
@keyframes blue-dot-pulse {
  0%, 100% { transform: scale(0.6); opacity: 0.5; }
  50% { transform: scale(1.3); opacity: 1; }
}

/* ----- Outline "ROCK" gigante azul atrás ----- */
.bg-text-rock {
  position: absolute;
  font-family: var(--font-display);
  font-size: clamp(8rem, 18vw, 18rem);
  -webkit-text-stroke: 2px rgba(6, 31, 255, 0.18);
  color: transparent;
  letter-spacing: 0.05em;
  pointer-events: none;
  z-index: 1;
  font-style: italic;
  user-select: none;
  line-height: 0.85;
}

/* ----- Speech bubble azul ----- */
.blue-bubble {
  position: absolute;
  background: var(--blue);
  color: var(--yellow);
  padding: 14px 24px;
  font-family: var(--font-display);
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
  z-index: 3;
  pointer-events: none;
  font-style: italic;
  box-shadow: 4px 4px 0 var(--black);
  animation: bubble-wobble 5s ease-in-out infinite;
}
@keyframes bubble-wobble {
  0%, 100% { transform: rotate(-5deg) scale(1); }
  50% { transform: rotate(5deg) scale(1.04); }
}

/* ----- Posicionamentos hero ----- */
.hero-blue-burst-1 { top: 38%; right: 14%; }
.hero-blue-burst-2 { bottom: 32%; left: 16%; }
.hero-blue-cross-1 { top: 20%; left: 24%; }
.hero-blue-cross-2 { top: 50%; right: 28%; animation-delay: 2s; }
.hero-blue-cross-3 { bottom: 22%; right: 35%; animation-delay: 4s; }
.hero-blue-circle { top: 22%; right: 24%; }
.hero-blue-lines { bottom: 22%; right: 10%; }
.hero-blue-star-1 { top: 62%; left: 20%; font-size: 1.8rem; animation-delay: 1s; }
.hero-blue-star-2 { top: 30%; left: 8%; font-size: 1.3rem; animation-delay: 3s; }

/* ----- Posicionamentos events section ----- */
.events-blue-cross-1 { top: 100px; right: 8%; }
.events-blue-stripes { top: 60px; left: 5%; transform: rotate(-15deg); }
.events-blue-dots { bottom: 30px; right: 12%; }
.events-blue-star { top: 55%; left: 4%; font-size: 2rem; }
.events-blue-circle { top: 30%; right: -50px; width: 140px; height: 140px; }

/* ----- About section ----- */
.about-blue-bubble { top: 18%; right: 6%; }
.about-blue-circle-deco { bottom: 8%; left: -50px; width: 140px; height: 140px; }
.about-blue-cross { top: 60%; right: 10%; }

/* ----- Background tint azul nas seções ----- */
.events-section { position: relative; overflow: hidden; }
.events-section::after {
  content: '';
  position: absolute;
  top: -150px;
  right: -150px;
  width: 700px;
  height: 700px;
  background: radial-gradient(circle, rgba(6, 31, 255, 0.07) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.events-section > * { position: relative; z-index: 2; }

/* ----- Empty teaser card destaque azul ----- */
.event-card-empty {
  border: 1px dashed rgba(6, 31, 255, 0.4) !important;
  position: relative;
  overflow: hidden;
}
.event-card-empty::before {
  content: '';
  position: absolute;
  top: -30px;
  right: -30px;
  width: 120px;
  height: 120px;
  background: var(--blue);
  border-radius: 50%;
  opacity: 0.12;
  filter: blur(20px);
  animation: blue-circle-pulse 3s ease-in-out infinite;
}
.event-card-empty::after {
  content: '?';
  position: absolute;
  bottom: 20px;
  right: 24px;
  font-family: var(--font-display);
  font-size: 5rem;
  color: var(--blue);
  text-shadow: 0 0 20px var(--blue);
  opacity: 0.4;
  z-index: 1;
  pointer-events: none;
  animation: question-pulse 2s ease-in-out infinite;
}
@keyframes question-pulse {
  0%, 100% { opacity: 0.4; transform: scale(1) rotate(0); }
  50% { opacity: 0.8; transform: scale(1.1) rotate(-5deg); }
}
.event-card-empty:hover { border-color: var(--blue) !important; }
.event-card-empty:hover::before { opacity: 0.25; }
.event-card-empty:hover::after { opacity: 0.9; }
.event-card-empty .event-card-status {
  background: var(--blue) !important;
  color: var(--yellow) !important;
  border: none;
  box-shadow: 3px 3px 0 var(--black);
}
.event-card-empty .event-card-body { min-height: 180px; }

/* ----- Responsive ----- */
@media (max-width: 1024px) {
  .blue-circle { width: 70px; height: 70px; }
  .blue-burst-text { font-size: 0.75rem; padding: 4px 10px; }
  .blue-bubble { font-size: 1rem; padding: 10px 18px; }
  .events-blue-circle { width: 100px; height: 100px; }
}
@media (max-width: 768px) {
  .hero-blue-burst-1, .hero-blue-burst-2,
  .hero-blue-cross-1, .hero-blue-cross-2, .hero-blue-cross-3,
  .hero-blue-circle, .hero-blue-lines,
  .hero-blue-star-1, .hero-blue-star-2,
  .events-blue-stripes, .events-blue-star, .events-blue-dots,
  .events-blue-cross-1, .events-blue-circle,
  .about-blue-bubble, .about-blue-circle-deco, .about-blue-cross { display: none; }
}
