/* === Tokens globais de loading ========================================= */
:root {
  --fp-loading-overlay-bg: rgba(13, 17, 23, 0.82);
  --fp-loading-overlay-blur: 12px;
  --fp-loading-bar-width: 0.55rem;
  --fp-loading-bar-gap: 0.45rem;
  --fp-loading-bar-height: 2.75rem;
  --fp-loading-bar-radius: 0.45rem;
  --fp-loading-bar-color: var(--color-primary, #0d6efd);
  --fp-loading-bar-fade: rgba(255, 255, 255, 0.12);
  --fp-loading-bar-duration: 1.05s;
  --fp-loading-text-color: var(--color-text-muted, #9ba1b0);
  --fp-orbital-size: 5.75rem;
  --fp-orbital-core-size: 2.85rem;
}

.app-root.theme-dark {
  --fp-loading-overlay-bg: rgba(13, 17, 23, 0.82);
}

.app-root.theme-light {
  --fp-loading-overlay-bg: rgba(245, 247, 251, 0.86);
  --fp-loading-bar-fade: rgba(13, 17, 23, 0.12);
}

@supports (color: color-mix(in srgb, black, white)) {
  .app-root {
    --fp-loading-overlay-bg: color-mix(
      in srgb,
      var(--color-bg-body, #0d1117) 88%,
      transparent
    );
  }
}

/* === Overlay global controlado pelo corpo ============================== */
.global-loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
}

.global-loading-overlay::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: var(--fp-loading-overlay-bg);
  backdrop-filter: blur(var(--fp-loading-overlay-blur));
  -webkit-backdrop-filter: blur(var(--fp-loading-overlay-blur));
}

body.global-loading--visible {
  cursor: progress;
  overflow: hidden;
  padding-right: var(--fp-scrollbar-compensation, calc(100vw - 100%));
}

@supports (scrollbar-gutter: stable both-edges) {
  body {
    --fp-scrollbar-compensation: 0px;
    scrollbar-gutter: stable both-edges;
  }

  body.global-loading--visible {
    padding-right: var(--fp-scrollbar-compensation);
  }
}

body.global-loading--visible .global-loading-overlay,
body.global-loading--visible .global-loading > .dash-loading-overlay {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.fp-spinner {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 1.25rem;
  padding: 1.65rem;
  border-radius: 1.5rem;
  color: var(--color-text, #f8f9fa);
  text-align: center;
  background: linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.08),
      rgba(0, 0, 0, 0.24)
    ),
    rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow:
    0 24px 48px rgba(5, 8, 17, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.fp-spinner-text {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fp-loading-text-color);
}

.fp-orbital {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--fp-orbital-size);
  height: var(--fp-orbital-size);
  filter: drop-shadow(0 12px 28px rgba(13, 17, 23, 0.45));
}

.fp-orbital-core {
  position: relative;
  width: var(--fp-orbital-core-size);
  height: var(--fp-orbital-core-size);
  border-radius: 999px;
  background:
    radial-gradient(circle at 25% 25%, rgba(255, 255, 255, 0.45), transparent 60%),
    linear-gradient(135deg, var(--fp-loading-bar-color), rgba(255, 255, 255, 0.08));
  box-shadow:
    0 0 22px rgba(13, 110, 253, 0.32),
    0 0 42px rgba(13, 110, 253, 0.18),
    inset 0 0 18px rgba(255, 255, 255, 0.18);
  animation: fp-orbital-core-pulse 2.4s ease-in-out infinite;
}

.fp-orbital-core::after {
  content: "";
  position: absolute;
  inset: 14%;
  border-radius: inherit;
  background: radial-gradient(circle at 70% 30%, rgba(255, 255, 255, 0.65), transparent 70%);
  mix-blend-mode: screen;
}

.fp-orbital-ring {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  padding: 0.22rem;
  background:
    conic-gradient(
      from 0deg,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.25) 12%,
      rgba(13, 110, 253, 0.6) 38%,
      rgba(13, 110, 253, 0.2) 52%,
      rgba(255, 255, 255, 0.3) 72%,
      rgba(255, 255, 255, 0) 100%
    );
  animation: fp-orbital-spin 2.6s linear infinite;
}

.fp-orbital-ring::before {
  content: "";
  position: absolute;
  inset: 0.28rem;
  border-radius: inherit;
  background:
    radial-gradient(circle, rgba(13, 17, 23, 0.65) 0%, rgba(13, 17, 23, 0.35) 60%, transparent 100%);
  box-shadow:
    inset 0 0 18px rgba(5, 8, 17, 0.6),
    inset 0 0 2px rgba(255, 255, 255, 0.08);
  filter: blur(0.1px);
}

.fp-orbital-ring::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle, rgba(13, 110, 253, 0.25), transparent 70%);
  opacity: 0.6;
  filter: blur(14px);
}

.fp-orbital-spark {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0.95rem;
  height: 0.95rem;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.7), transparent 65%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.5), rgba(13, 110, 253, 0.85));
  box-shadow:
    0 0 16px rgba(13, 110, 253, 0.5),
    0 0 32px rgba(13, 110, 253, 0.35);
  transform: translate(-50%, -50%) rotate(0deg)
    translateX(calc(var(--fp-orbital-size) / 2.2));
  transform-origin: center;
  animation: fp-orbital-spark 1.9s linear infinite;
}

.fp-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.fp-loading-bars,
.dash-spinner {
  display: inline-flex;
  align-items: flex-end;
  justify-content: center;
  gap: var(--fp-loading-bar-gap);
  min-height: var(--fp-loading-bar-height);
}

.fp-loading-bar,
.dash-spinner .dash-bar {
  width: var(--fp-loading-bar-width);
  height: 100%;
  border-radius: var(--fp-loading-bar-radius);
  background: linear-gradient(
    180deg,
    var(--fp-loading-bar-color) 0%,
    var(--fp-loading-bar-color) 65%,
    var(--fp-loading-bar-fade) 100%
  );
  animation: fp-loading-bars var(--fp-loading-bar-duration) ease-in-out infinite;
  transform-origin: center bottom;
  box-shadow: 0 6px 16px rgba(13, 17, 23, 0.25);
}

.fp-loading-bar-1,
.dash-spinner .dash-bar-1 {
  animation-delay: calc(var(--fp-loading-bar-duration) * -0.45);
}

.fp-loading-bar-2,
.dash-spinner .dash-bar-2 {
  animation-delay: calc(var(--fp-loading-bar-duration) * -0.3);
}

.fp-loading-bar-3,
.dash-spinner .dash-bar-3 {
  animation-delay: calc(var(--fp-loading-bar-duration) * -0.15);
}

@keyframes fp-loading-bars {
  0%,
  45%,
  100% {
    transform: scaleY(0.4);
    opacity: 0.45;
  }
  20% {
    transform: scaleY(1);
    opacity: 1;
  }
}

@keyframes fp-orbital-spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes fp-orbital-spark {
  to {
    transform: translate(-50%, -50%) rotate(360deg)
      translateX(calc(var(--fp-orbital-size) / 2.2));
  }
}

@keyframes fp-orbital-core-pulse {
  0%,
  100% {
    transform: scale(0.98);
    box-shadow:
      0 0 18px rgba(13, 110, 253, 0.25),
      0 0 34px rgba(13, 110, 253, 0.16),
      inset 0 0 18px rgba(255, 255, 255, 0.16);
  }
  45% {
    transform: scale(1.04);
    box-shadow:
      0 0 24px rgba(13, 110, 253, 0.45),
      0 0 46px rgba(13, 110, 253, 0.28),
      inset 0 0 24px rgba(255, 255, 255, 0.22);
  }
}

/* === Ajustes de componentes Dash ====================================== */
/* Evitar que o Dash esconda conteúdos ou altere opacidades durante o loading */
[data-dash-is-loading="true"],
[data-dash-is-loading="true"] * {
  visibility: visible !important;
  opacity: 1 !important;
  filter: none !important;
}

/* Container padrão dos spinners internos */
.dash-spinner {
  position: relative;
  width: auto;
  height: var(--fp-loading-bar-height);
  color: var(--fp-loading-bar-color);
}

.dash-spinner::after {
  display: none;
}

/* Fullscreen ou overlays do dcc.Loading */
.global-loading {
  position: relative;
}

.global-loading > .dash-loading-output {
  min-height: 100vh;
  background: var(--color-bg-body, #0d1117);
}

.global-loading > .dash-loading-overlay,
.dash-spinner-container {
  position: fixed;
  inset: 0;
  z-index: 99990;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: auto;
  background: var(--fp-loading-overlay-bg);
  backdrop-filter: blur(var(--fp-loading-overlay-blur));
  -webkit-backdrop-filter: blur(var(--fp-loading-overlay-blur));
}

.global-loading > .dash-loading-overlay .loading,
.global-loading > .dash-loading-overlay .dash-spinner,
.dash-spinner-container .dash-spinner {
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 1.75rem 2rem;
  border-radius: 1.25rem;
  background: rgba(0, 0, 0, 0.12);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.22);
  height: auto;
}

.global-loading > .dash-loading-overlay .loading::after,
.global-loading > .dash-loading-overlay .dash-spinner::after,
.dash-spinner-container .dash-spinner::after {
  content: "Carregando…";
  display: block;
  margin-top: 0.5rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--fp-loading-text-color);
  letter-spacing: 0.02em;
}

.app-root.theme-light .fp-spinner,
.app-root.theme-light .dash-spinner-container .dash-spinner,
.app-root.theme-light .global-loading > .dash-loading-overlay .loading,
.app-root.theme-light .global-loading > .dash-loading-overlay .dash-spinner {
  background: linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.94),
      rgba(232, 238, 252, 0.85)
    ),
    rgba(255, 255, 255, 0.92);
  box-shadow:
    0 18px 40px rgba(15, 23, 42, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.65);
  color: var(--color-text, #0d1117);
}

.app-root.theme-light .fp-loading-bar,
.app-root.theme-light .dash-spinner .dash-bar,
.app-root.theme-light .global-loading > .dash-loading-overlay .dash-bar {
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.16);
}

/* Garantir tema escuro consistente */
html,
body,
#_dash-app-content,
#react-entry-point,
.bg-dark {
  background-color: var(--color-bg-body, #0d1117) !important;
}
