.site-preloader {
  position: fixed;
  inset: 0;
  z-index: 9999999;
  display: grid;
  place-items: center;
  overflow: hidden;
  padding: clamp(1rem, 3vw, 2rem);
  background: #030303;
  isolation: isolate;
  animation: sitePreloaderFailsafe 0.01s linear 5s forwards;
}

.site-preloader.is-complete {
  animation: none;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.65s ease,
    visibility 0.65s step-end;
}

.site-preloader__ambient,
.site-preloader__ambient::before,
.site-preloader__ambient::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.site-preloader__ambient {
  background:
    radial-gradient(circle at 50% 48%, rgba(212, 175, 55, 0.08), transparent 18rem),
    radial-gradient(circle at 24% 30%, rgba(125, 177, 209, 0.12), transparent 16rem),
    radial-gradient(circle at 78% 70%, rgba(212, 175, 55, 0.08), transparent 20rem);
}

.site-preloader__ambient::before {
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.038) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.038) 1px, transparent 1px);
  background-size: 4.75rem 4.75rem;
  opacity: 0.22;
  mask-image: radial-gradient(circle at center, #000 0%, #000 42%, transparent 78%);
}

.site-preloader__ambient::after {
  inset: 18% 20%;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.04);
  transform: scale(1.2);
  opacity: 0.3;
}

.site-preloader__content {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 1rem;
  width: min(100%, 42rem);
}

.site-preloader__eyebrow,
.site-preloader__caption {
  margin: 0;
  text-align: center;
}

.site-preloader__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(212, 175, 55, 0.9);
}

.site-preloader__stage {
  position: relative;
  width: min(100%, 28rem);
  aspect-ratio: 1;
}

.site-preloader__stage::before,
.site-preloader__stage::after {
  content: "";
  position: absolute;
  inset: 11%;
  border-radius: 50%;
  pointer-events: none;
}

.site-preloader__stage::before {
  border: 1px solid rgba(255, 255, 255, 0.06);
  opacity: 0.7;
}

.site-preloader__stage::after {
  inset: 22%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.07), transparent 68%);
  filter: blur(14px);
}

.site-preloader__grid,
.site-preloader__trace,
.site-preloader__shape {
  position: absolute;
  pointer-events: none;
}

.site-preloader__grid {
  inset: 14%;
  border-radius: 50%;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.042) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.042) 1px, transparent 1px);
  background-size: 2.4rem 2.4rem;
  mask-image: radial-gradient(circle at center, #000 38%, transparent 82%);
  opacity: 0.6;
}

.site-preloader__trace {
  left: 50%;
  top: 50%;
  transform-origin: center;
}

.site-preloader__trace--x {
  width: 64%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(212, 175, 55, 0.95), transparent);
  transform: translate(-50%, -50%);
  animation: sitePreloaderTraceX 2.4s ease-in-out infinite;
}

.site-preloader__trace--y {
  width: 1px;
  height: 64%;
  background: linear-gradient(180deg, transparent, rgba(125, 177, 209, 0.9), transparent);
  transform: translate(-50%, -50%);
  animation: sitePreloaderTraceY 2.8s ease-in-out infinite;
}

.site-preloader__trace--orbit {
  width: 72%;
  height: 72%;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  animation: sitePreloaderOrbit 6s linear infinite;
}

.site-preloader__shape {
  left: 50%;
  top: 50%;
  transition:
    transform 0.7s cubic-bezier(0.2, 0.8, 0.2, 1),
    width 0.7s cubic-bezier(0.2, 0.8, 0.2, 1),
    height 0.7s cubic-bezier(0.2, 0.8, 0.2, 1),
    border-radius 0.7s cubic-bezier(0.2, 0.8, 0.2, 1),
    background 0.7s ease,
    border-color 0.7s ease,
    opacity 0.7s ease,
    box-shadow 0.7s ease;
}

.site-preloader__shape--frame {
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.02);
}

.site-preloader__shape--plane {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.32), rgba(255, 255, 255, 0.05));
}

.site-preloader__shape--curve {
  border: 1px solid rgba(212, 175, 55, 0.36);
}

.site-preloader__shape--accent {
  background: linear-gradient(90deg, rgba(212, 175, 55, 0.9), rgba(125, 177, 209, 0.78));
}

.site-preloader__shape--pulse {
  border-radius: 9999px;
}

.site-preloader[data-preloader-state="image"] .site-preloader__shape--frame {
  width: 58%;
  height: 42%;
  border-radius: 1.35rem;
  transform: translate(-50%, -50%);
}

.site-preloader[data-preloader-state="image"] .site-preloader__shape--plane {
  width: 34%;
  height: 23%;
  border-radius: 0.95rem;
  background: linear-gradient(135deg, rgba(125, 177, 209, 0.72), rgba(212, 175, 55, 0.25));
  box-shadow: 0 0 30px rgba(125, 177, 209, 0.18);
  transform: translate(-16%, -22%) rotate(-9deg);
}

.site-preloader[data-preloader-state="image"] .site-preloader__shape--curve {
  width: 16%;
  height: 16%;
  border-radius: 9999px;
  transform: translate(56%, 8%);
}

.site-preloader[data-preloader-state="image"] .site-preloader__shape--accent {
  width: 46%;
  height: 2px;
  border-radius: 9999px;
  transform: translate(-50%, 240%);
}

.site-preloader[data-preloader-state="image"] .site-preloader__shape--pulse {
  width: 0.95rem;
  height: 0.95rem;
  background: #d4af37;
  box-shadow:
    0 0 0 0.5rem rgba(212, 175, 55, 0.12),
    0 0 26px rgba(212, 175, 55, 0.28);
  transform: translate(88%, -84%);
}

.site-preloader[data-preloader-state="layout"] .site-preloader__shape--frame {
  width: 40%;
  height: 60%;
  border-radius: 0.55rem;
  transform: translate(-50%, -50%);
}

.site-preloader[data-preloader-state="layout"] .site-preloader__shape--plane {
  width: 34%;
  height: 50%;
  border-radius: 0.3rem;
  background:
    linear-gradient(transparent 0 15%, rgba(255, 255, 255, 0.12) 15% 16%, transparent 16% 31%, rgba(255, 255, 255, 0.2) 31% 32%, transparent 32% 56%, rgba(212, 175, 55, 0.22) 56% 57%, transparent 57% 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.02));
  box-shadow: none;
  transform: translate(-50%, -50%);
}

.site-preloader[data-preloader-state="layout"] .site-preloader__shape--curve {
  width: 48%;
  height: 68%;
  border-radius: 0.8rem;
  border-color: rgba(255, 255, 255, 0.08);
  transform: translate(-50%, -50%) scale(0.86);
}

.site-preloader[data-preloader-state="layout"] .site-preloader__shape--accent {
  width: 50%;
  height: 1px;
  border-radius: 9999px;
  background: linear-gradient(90deg, transparent, rgba(212, 175, 55, 0.85), transparent);
  transform: translate(-50%, -520%);
}

.site-preloader[data-preloader-state="layout"] .site-preloader__shape--pulse {
  width: 0.68rem;
  height: 0.68rem;
  background: #7db1d1;
  box-shadow:
    0 0 0 0.38rem rgba(125, 177, 209, 0.12),
    0 0 20px rgba(125, 177, 209, 0.24);
  transform: translate(-210%, -188%);
}

.site-preloader[data-preloader-state="design"] .site-preloader__shape--frame {
  width: 27%;
  height: 27%;
  border-radius: 34% 66% 62% 38% / 40% 36% 64% 60%;
  border-color: rgba(212, 175, 55, 0.35);
  background: rgba(212, 175, 55, 0.08);
  transform: translate(-128%, -26%) rotate(-26deg);
}

.site-preloader[data-preloader-state="design"] .site-preloader__shape--plane {
  width: 34%;
  height: 34%;
  border-radius: 9999px;
  background: radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.48), rgba(125, 177, 209, 0.3) 44%, rgba(125, 177, 209, 0.03) 100%);
  box-shadow: 0 0 30px rgba(125, 177, 209, 0.16);
  transform: translate(56%, -40%);
}

.site-preloader[data-preloader-state="design"] .site-preloader__shape--curve {
  width: 42%;
  height: 14%;
  border-radius: 9999px;
  border-color: transparent;
  background: linear-gradient(90deg, rgba(212, 175, 55, 0.92), rgba(125, 177, 209, 0.72));
  transform: translate(-8%, 96%) rotate(-18deg);
}

.site-preloader[data-preloader-state="design"] .site-preloader__shape--accent {
  width: 18%;
  height: 50%;
  border-radius: 1.2rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.03));
  transform: translate(-18%, -16%) rotate(30deg);
}

.site-preloader[data-preloader-state="design"] .site-preloader__shape--pulse {
  width: 0.9rem;
  height: 0.9rem;
  background: #ffffff;
  box-shadow:
    0 0 0 0.55rem rgba(255, 255, 255, 0.08),
    0 0 24px rgba(255, 255, 255, 0.18);
  transform: translate(24%, 18%);
}

.site-preloader__caption {
  max-width: 26rem;
  color: rgba(255, 255, 255, 0.52);
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.site-preloader__words {
  display: grid;
  justify-items: center;
  gap: 0.4rem;
  width: min(100%, 26rem);
}

.site-preloader__word {
  color: rgba(255, 255, 255, 0.26);
  font-size: clamp(1rem, 2.8vw, 1.25rem);
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: -0.03em;
  text-align: center;
  transition:
    color 0.35s ease,
    opacity 0.35s ease,
    transform 0.35s ease;
}

.site-preloader__word.is-active {
  color: #ffffff;
  opacity: 1;
  transform: scale(1.04);
}

.site-preloader__word:not(.is-active) {
  opacity: 0.48;
}

@keyframes sitePreloaderTraceX {
  0%,
  100% {
    transform: translate(-50%, -50%) scaleX(0.45);
    opacity: 0.24;
  }

  50% {
    transform: translate(-50%, -50%) scaleX(1);
    opacity: 1;
  }
}

@keyframes sitePreloaderTraceY {
  0%,
  100% {
    transform: translate(-50%, -50%) scaleY(0.45);
    opacity: 0.24;
  }

  50% {
    transform: translate(-50%, -50%) scaleY(1);
    opacity: 1;
  }
}

@keyframes sitePreloaderOrbit {
  0% {
    transform: translate(-50%, -50%) rotate(0deg) scale(0.92);
    opacity: 0.28;
  }

  50% {
    transform: translate(-50%, -50%) rotate(180deg) scale(1);
    opacity: 0.62;
  }

  100% {
    transform: translate(-50%, -50%) rotate(360deg) scale(0.92);
    opacity: 0.28;
  }
}

@keyframes sitePreloaderFailsafe {
  to {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }
}

@media (max-width: 767px) {
  .site-preloader {
    padding: 1rem;
  }

  .site-preloader__content {
    gap: 0.85rem;
  }

  .site-preloader__stage {
    width: min(100%, 18rem);
  }

  .site-preloader__words {
    gap: 0.42rem;
  }

  .site-preloader__caption {
    font-size: 0.72rem;
    letter-spacing: 0.1em;
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-preloader__ambient::after,
  .site-preloader__trace,
  .site-preloader__shape,
  .site-preloader__word {
    animation: none !important;
    transition: none !important;
  }
}
