html.no-scroll,
body.no-scroll {
  overflow: hidden;
}

/* Underlay naranja (debajo del preloader) */
#preloader-under {
  position: fixed;
  inset: 0;
  z-index: 999998;
  background: #ff6600;
  transform: translateY(0);
  will-change: transform;
  pointer-events: none;
}

/* Sale con delay para “acompañar” el barrido */
#preloader-under.is-done {
  animation: underlay-out 800ms cubic-bezier(0.7, 0, 0.2, 1) forwards;
  animation-delay: 220ms;
}

@keyframes underlay-out {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-100%);
  }
}

/* Preloader */
#preloader {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: grid;
  place-items: center;
  background: #f8f8f8;
  color: #3a3a39;
  overflow: hidden;
  transform: translateY(0);
  will-change: transform;
}

/* Fondos SVG (ojo con paths: si tus iframes están en subcarpetas, preferí /assets/... ) */
#preloader::before,
#preloader::after {
  content: "";
  position: absolute;
  pointer-events: none;
  z-index: 0;
  width: clamp(220px, 38vw, 560px);
  height: clamp(220px, 38vw, 560px);
  background-repeat: no-repeat;
  background-size: contain;
  opacity: 1;
}

#preloader::before {
  top: 0;
  right: 0;
  background-image: url("../img/preloader-bg-1.svg");
  background-position: top right;
}

#preloader::after {
  left: 0;
  bottom: 0;
  background-image: url("../img/preloader-bg-2.svg");
  background-position: bottom left;
}

/* Sweep */
.pl-sweep {
  position: absolute;
  left: 0;
  bottom: -25%;
  width: 100%;
  height: 25%;
  opacity: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    0deg,
    transparent,
    rgba(58, 58, 57, 0.1),
    transparent
  );
  will-change: transform, opacity;
}

.pl-inner {
  width: min(520px, 86vw);
  text-align: center;
  padding: 28px 22px;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 2;
}

/* Espaciados */
:root {
  --space-top: clamp(26px, 3.2vw, 38px);
  --space-bottom: clamp(20px, 2.6vw, 32px);
}

.pl-top,
.pl-bottom {
  font-family:
    "PP Telegraf",
    ui-sans-serif,
    system-ui,
    -apple-system,
    Segoe UI,
    Roboto,
    Arial;
  font-weight: 400;
  font-style: normal;
  font-size: 14px;
  line-height: 100%;
  text-align: center;
  letter-spacing: 0.5em; /* 50% aprox */
  text-transform: uppercase;
}

.pl-top {
  margin-bottom: var(--space-top);
}

.pl-percent {
  font-family:
    "PP Telegraf",
    ui-sans-serif,
    system-ui,
    -apple-system,
    Segoe UI,
    Roboto,
    Arial;
  font-weight: 800;
  font-style: normal;
  font-size: 70px;
  line-height: 90%;
  letter-spacing: 0;
  text-align: center;
  margin-bottom: var(--space-bottom);
}

/* Barrido (de abajo hacia arriba) */
#preloader.is-done {
  animation: preloader-out 900ms cubic-bezier(0.7, 0, 0.2, 1) forwards;
}

#preloader.is-done .pl-sweep {
  opacity: 1;
  animation: preloader-sweep 900ms cubic-bezier(0.7, 0, 0.2, 1) forwards;
}

@keyframes preloader-out {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-100%);
  }
}

@keyframes preloader-sweep {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-600%);
  }
}

@media (prefers-reduced-motion: reduce) {
  #preloader.is-done {
    animation: none;
    transform: translateY(-100%);
  }
  #preloader.is-done .pl-sweep {
    animation: none;
    opacity: 0;
  }

  #preloader-under.is-done {
    animation: none;
    transform: translateY(-100%);
  }
}

/* Fancybox: ocultar spinner/loader nativo */
.fancybox__spinner,
.fancybox__loading,
.f-spinner,
.is-loading .fancybox__spinner {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}
