/* Full-screen preload gate */

.site-loader {
  --loader-bg: #111;
  --loader-gold: #c9a96e;
  --loader-text: rgba(255, 255, 255, 0.72);

  position: fixed;
  inset: 0;
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--loader-bg);
  color: var(--loader-text);
  transition:
    opacity 0.55s ease,
    visibility 0.55s ease;
}

.site-loader.is-hiding {
  opacity: 0;
  visibility: hidden;
}

.site-loader.is-hidden {
  display: none;
}

.site-loader__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1rem, 2.5vh, 1.35rem);
  width: min(16rem, 72vw);
  text-align: center;
}

.site-loader__mark {
  display: block;
  width: clamp(2.75rem, 8vw, 3.25rem);
  height: auto;
  object-fit: contain;
  opacity: 0.92;
}

.site-loader__label {
  margin: 0;
  font-family: var(--font-primary, "Open Sans", Arial, sans-serif);
  font-size: clamp(0.72rem, 1.6vw, 0.82rem);
  font-weight: 400;
  letter-spacing: 0.28em;
  color: rgba(255, 255, 255, 0.55);
}

.site-loader__track {
  position: relative;
  width: 100%;
  height: 1px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.14);
}

.site-loader__fill {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--loader-gold);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.35s ease;
  will-change: transform;
}

html.is-loading {
  overflow: hidden;
}

html.is-loading .site-app {
  opacity: 0;
  pointer-events: none;
}

html:not(.is-loading) .site-app {
  opacity: 1;
  transition: opacity 0.45s ease 0.05s;
}

@media (prefers-reduced-motion: reduce) {
  .site-loader,
  .site-loader__fill,
  html:not(.is-loading) .site-app {
    transition: none;
  }
}
