/**
 * Overlay global de carregamento (logo + escurecimento da tela).
 * Prefixo jt- evita conflito com estilos das páginas.
 */

#jt-loading-overlay.jt-loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  background: rgba(15, 23, 42, 0.52);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.22s ease, visibility 0.22s ease;
}

#jt-loading-overlay.jt-loading-overlay.jt-loading-overlay--visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

#jt-loading-overlay .jt-loading-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

/* Container do logo + réplicas de profundidade */
#jt-loading-overlay .jt-logo-spin {
  position: relative;
  width: 80px;
  height: 118px;
  transform-origin: 50% 55%;
}

#jt-loading-overlay .jt-logo-scale {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

#jt-loading-overlay .jt-logo-bounce {
  display: flex;
  align-items: center;
  justify-content: center;
}

#jt-loading-overlay .jt-logo-loading {
  display: block;
  width: 80px;
  height: 118px;
  flex-shrink: 0;
  overflow: visible;
}

/*
 * Stagger por camadas (esquema 4): picos com platô — todas usam o mesmo “máximo” no intervalo forte,
 * para não parecer que só a primeira subida chega na cor plena (ponto único no keyframe).
 */
@keyframes jt-stagger1 {
  0%,
  100% {
    opacity: 0.1;
    transform: translateY(0);
    filter: brightness(1) saturate(1) contrast(1);
  }
  17%,
  23% {
    opacity: 1;
    transform: translateY(-6px);
    filter: brightness(1.45) saturate(1.2) contrast(1.04);
  }
}

@keyframes jt-stagger2 {
  0%,
  15%,
  100% {
    opacity: 0.1;
    transform: translateY(0);
    filter: brightness(1) saturate(1) contrast(1);
  }
  32%,
  38% {
    opacity: 1;
    transform: translateY(-6px);
    filter: brightness(1.45) saturate(1.2) contrast(1.04);
  }
}

@keyframes jt-stagger3 {
  0%,
  30%,
  100% {
    opacity: 0.1;
    transform: translateY(0);
    filter: brightness(1) saturate(1) contrast(1);
  }
  47%,
  53% {
    opacity: 1;
    transform: translateY(-6px);
    filter: brightness(1.45) saturate(1.2) contrast(1.04);
  }
}

@keyframes jt-stagger4 {
  0%,
  45%,
  100% {
    opacity: 0.1;
    transform: translateY(0);
    filter: brightness(1) saturate(1) contrast(1);
  }
  62%,
  68% {
    opacity: 1;
    transform: translateY(-6px);
    filter: brightness(1.45) saturate(1.2) contrast(1.04);
  }
}

@keyframes jt-stagger5 {
  0%,
  60%,
  100% {
    opacity: 0.1;
    transform: translateY(0);
    filter: brightness(1) saturate(1) contrast(1);
  }
  77%,
  83% {
    opacity: 1;
    transform: translateY(-6px);
    filter: brightness(1.45) saturate(1.2) contrast(1.04);
  }
}

#jt-loading-overlay .jt-stagger-s1 g.jt-p1,
#jt-loading-overlay .jt-stagger-s1 g.jt-p2,
#jt-loading-overlay .jt-stagger-s1 g.jt-p3,
#jt-loading-overlay .jt-stagger-s1 g.jt-p4,
#jt-loading-overlay .jt-stagger-s1 g.jt-p5 {
  transform-box: fill-box;
  transform-origin: center;
  opacity: 0.1;
  filter: brightness(1) saturate(1) contrast(1);
  animation-fill-mode: backwards;
}

#jt-loading-overlay .jt-stagger-s1 .jt-p1 {
  animation: jt-stagger1 2s ease-in-out infinite;
}

#jt-loading-overlay .jt-stagger-s1 .jt-p2 {
  animation: jt-stagger2 2s ease-in-out infinite;
}

#jt-loading-overlay .jt-stagger-s1 .jt-p3 {
  animation: jt-stagger3 2s ease-in-out infinite;
}

#jt-loading-overlay .jt-stagger-s1 .jt-p4 {
  animation: jt-stagger4 2s ease-in-out infinite;
}

#jt-loading-overlay .jt-stagger-s1 .jt-p5 {
  animation: jt-stagger5 2s ease-in-out infinite;
}

/* Cópias estáticas atrás do logo principal */
#jt-loading-overlay .jt-logo-layer {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

#jt-loading-overlay .jt-logo-layer svg {
  width: 80px;
  height: 118px;
}

#jt-loading-overlay .jt-logo-layer--1 svg {
  opacity: 0.22;
}

#jt-loading-overlay .jt-logo-layer--2 svg {
  opacity: 0.12;
}

#jt-loading-overlay .jt-lg-str0 {
  stroke: #fff;
  stroke-width: 1.98;
  stroke-miterlimit: 22.9256;
}

#jt-loading-overlay .jt-lg-fil0 {
  fill: #fff;
}

#jt-loading-overlay .jt-lg-fil1 {
  fill: #1159b5;
}

#jt-loading-overlay .jt-lg-fil2 {
  fill: #1cacda;
}

#jt-loading-overlay .jt-lg-fil3 {
  fill: #1b92ce;
}

#jt-loading-overlay .jt-lg-fil4 {
  fill: #1b94d3;
}

#jt-loading-overlay .jt-lg-fil5 {
  fill: #146dba;
}

@media (prefers-reduced-motion: reduce) {
  #jt-loading-overlay .jt-stagger-s1 .jt-p1,
  #jt-loading-overlay .jt-stagger-s1 .jt-p2,
  #jt-loading-overlay .jt-stagger-s1 .jt-p3,
  #jt-loading-overlay .jt-stagger-s1 .jt-p4,
  #jt-loading-overlay .jt-stagger-s1 .jt-p5 {
    animation: none !important;
    opacity: 1;
    transform: none;
    filter: none;
  }
}
