/* ═══════════════════════════════════════════════════════════

       PAGE LOADER
       Moon-phase animation plays while fonts/assets load.
    ═══════════════════════════════════════════════════════════ */
#page-loader {
  position: fixed;
  inset: 0;
  background: var(--color-black);
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .7s ease, visibility .7s ease;
  animation: anim-loader-bg 4s ease-in-out forwards;
}

#page-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

body.is-loading>*:not(#smoke-bg):not(#page-loader) {
  opacity: 0;
  pointer-events: none;
}

body>*:not(#smoke-bg):not(#page-loader):not(.nav__mobile-menu) {
  /* Smooth transition to re-appear the page to simulate smoke dissipating */
  transition: opacity 2s ease-in-out;
}

.loader-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.2rem;
}

.loader-wordmark {
  font-family: var(--font-display);
  font-size: 2.6rem;
  letter-spacing: .25em;
  color: var(--color-white);
  display: flex;
  overflow: hidden;
}

.loader-wordmark span {
  display: inline-block;
  animation: anim-loader-char .55s cubic-bezier(.77, 0, .18, 1) both;
}

.loader-logo {
  width: 220px;
  max-width: 80vw;
  animation: anim-logo-smooth 1.6s cubic-bezier(0.22, 1, 0.36, 1) both;
  display: block;
}

.loader-phases {
  display: flex;
  align-items: center;
  gap: 18px;
}

.loader-phases svg {
  animation: anim-phase-pulse 1.4s ease-in-out infinite;
}

/* Sequential delay for left-to-right lunar sweep */
.loader-phases svg:nth-child(1) {
  animation-delay: 0s;
}

.loader-phases svg:nth-child(2) {
  animation-delay: .2s;
}

.loader-phases svg:nth-child(3) {
  animation-delay: .4s;
}

.loader-phases svg:nth-child(4) {
  animation-delay: .6s;
}

.loader-phases svg:nth-child(5) {
  animation-delay: .8s;
}

@keyframes anim-phase-pulse {

  0%,
  100% {
    opacity: .22;
    transform: scale(.82);
  }

  50% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes anim-loader-char {
  from {
    transform: translateY(105%);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes anim-logo-smooth {
  from {
    transform: translateY(15px);
    opacity: 1;
    filter: blur(0);
  }

  to {
    transform: translateY(0);
    opacity: 1;
    filter: blur(0);
  }
}

@keyframes anim-loader-bg {
  0% {
    background-color: var(--color-black);
  }

  100% {
    background-color: transparent;
  }
}