body.no-scroll {
  overflow: hidden;
}

#preloader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
  pointer-events: auto;
  transition: opacity 1400ms ease;
}

html.skip-preloader #preloader {
  opacity: 0;
  pointer-events: none;
}

#preloader.fade-out {
  opacity: 0;
  pointer-events: none;
}

.loader-content {
  width: min(480px, 86vw);
  text-align: center;
  padding: 24px 16px;
  opacity: 0;
  transition: opacity 500ms ease;
}

.loader-content.ready {
  opacity: 1;
}

.loading-logo {
  display: block;
  margin: 0 auto 12px;
  width: 80px;
  height: 80px;
  opacity: 0;
  filter: drop-shadow(0 2px 10px rgba(0, 0, 0, .05));
  background: url("../imgs/louvre80.png") no-repeat top center;
}

.loader-content.ready .loading-logo {
  animation: logo-in 1200ms ease-out both;
}

@keyframes logo-in {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

.progress {
  --track: #e5e7eb;
  --fill: #0b2a6f;
  width: min(100px, 60vw);
  height: 6px;
  margin: 8px auto 0;
  background: var(--track);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .03);
}

.progress .bar {
  height: 100%;
  width: 0%;
  background: var(--fill);
  transition: width 400ms ease;
}

.loading-label {
  font-size: 13px;
  color: #374151;
  margin-top: 10px;
  letter-spacing: .02em;
  font-weight: 600;
}

@media (prefers-reduced-motion: reduce) {
  #preloader {
    transition: none
  }

  .loader-content {
    transition: none;
    opacity: 1
  }

  .loader-content .loading-logo {
    animation: none;
    opacity: 1
  }

  .progress .bar {
    transition: none
  }
}