/* ── Preloader overlay ───────────────────────────────────────────────────── */
.glidy-preloader {
  width: 100%;
  height: 100%;
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}

.glidy-preloader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* ── Spinner ─────────────────────────────────────────────────────────────── */
.glidy-preloader__spinner {
  width: 60px;
  height: 60px;
  border: 4px solid rgba(0, 0, 0, 0.12);
  border-top-color: #000;
  border-radius: 50%;
  animation: glidy-spin 0.8s linear infinite;
}

/* ── Dual Ring ───────────────────────────────────────────────────────────── */
.glidy-preloader__dual-ring {
  width: 60px;
  height: 60px;
  border: 4px solid transparent;
  border-top-color: #000;
  border-bottom-color: #000;
  border-radius: 50%;
  animation: glidy-spin 0.9s linear infinite;
}

/* ── Pulse ───────────────────────────────────────────────────────────────── */
.glidy-preloader__pulse {
  width: 60px;
  height: 60px;
  background-color: #000;
  border-radius: 50%;
  animation: glidy-pulse 1.2s ease-in-out infinite;
}

/* ── Dots ────────────────────────────────────────────────────────────────── */
.glidy-preloader__dots {
  display: flex;
  gap: 10px;
  align-items: center;
}

.glidy-preloader__dots span {
  display: block;
  width: 14px;
  height: 14px;
  background-color: #000;
  border-radius: 50%;
  animation: glidy-bounce 1.2s ease-in-out infinite;
}

.glidy-preloader__dots span:nth-child(1) {
  animation-delay: 0s;
}

.glidy-preloader__dots span:nth-child(2) {
  animation-delay: 0.2s;
}

.glidy-preloader__dots span:nth-child(3) {
  animation-delay: 0.4s;
}

/* ── Bar ─────────────────────────────────────────────────────────────────── */
.glidy-preloader__bar {
  width: 120px;
  height: 6px;
  background-color: rgba(0, 0, 0, 0.12);
  border-radius: 3px;
  overflow: hidden;
}

.glidy-preloader__bar::after {
  content: '';
  display: block;
  height: 100%;
  width: 40%;
  background-color: #000;
  border-radius: 3px;
  animation: glidy-bar 1.2s ease-in-out infinite;
}

/* ── Keyframes ───────────────────────────────────────────────────────────── */
@keyframes glidy-spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes glidy-pulse {

  0%,
  100% {
    transform: scale(0);
    opacity: 1;
  }

  50% {
    transform: scale(1);
    opacity: 0.6;
  }
}

@keyframes glidy-bounce {

  0%,
  80%,
  100% {
    transform: scale(0.6);
    opacity: 0.4;
  }

  40% {
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes glidy-bar {
  0% {
    transform: translateX(-100%);
  }

  100% {
    transform: translateX(350%);
  }
}