.frame-image-loading-host {
  position: relative;
}

.frame-image-loading-img {
  opacity: 0;
  transition: opacity 260ms ease;
}

.frame-image-loading-host.is-loaded > .frame-image-loading-img {
  opacity: 1;
}

.frame-image-loading-indicator {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    linear-gradient(135deg, rgba(11, 18, 14, 0.78), rgba(24, 36, 28, 0.9)),
    radial-gradient(circle at 30% 25%, rgba(90, 211, 154, 0.12), transparent 55%);
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 220ms ease, visibility 220ms ease;
}

.frame-image-loading-indicator.is-active {
  opacity: 1;
  visibility: visible;
}

.frame-image-loading-host.is-loaded > .frame-image-loading-indicator {
  opacity: 0;
  visibility: hidden;
}

.frame-image-loading-core {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}

.frame-image-loading-lottie {
  width: 72px;
  height: 72px;
  max-width: 46%;
  max-height: 46%;
  pointer-events: none;
}

.frame-image-loading-text {
  font-size: 8px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #c6f8dd;
}

.frame-image-loading-host.is-failed > .frame-image-loading-indicator {
  opacity: 1;
  visibility: visible;
  background:
    linear-gradient(135deg, rgba(40, 10, 10, 0.82), rgba(30, 14, 14, 0.88));
}

.frame-image-loading-host.is-failed .frame-image-loading-text {
  color: #ffdad6;
}
