/*
 * Vom Honigdorf — Luxury preload loader
 */

.fo-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--fo-bg-cream, #F5F5F0);
  color: var(--fo-text-dark, #111111);
  pointer-events: none;
  overflow: hidden;
}

.fo-loader__bg {
  position: absolute;
  inset: 0;
  background-color: var(--fo-bg-cream, #F5F5F0);
  background-image: var(--fo-loader-texture, none);
  background-size: cover;
  background-position: center;
  opacity: 0.35;
  filter: saturate(0.65) contrast(0.95);
}

.fo-loader__comb {
  position: absolute;
  width: min(96vw, 900px);
  height: auto;
  opacity: 1;
  transform: scale(1);
  transition: opacity 0.55s ease, transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.fo-loader__hex {
  fill: none;
  stroke: url(#fo-loader-gold);
  stroke-width: 1.5;
  vector-effect: non-scaling-stroke;
  stroke-dasharray: 180;
  stroke-dashoffset: 180;
  opacity: 0;
  transform-box: fill-box;
  transform-origin: center;
  transition:
    stroke-dashoffset 0.7s ease,
    opacity 0.45s ease,
    transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}

.fo-loader__hex--c {
  stroke-width: 2;
}

.fo-loader__honey-flow {
  opacity: 0;
  transform: translateY(-12%);
  transition: opacity 0.6s ease, transform 1.1s ease;
}

.fo-loader__stage {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 1.5rem;
  max-width: 28rem;
}

.fo-loader__logo-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(5.5rem, 18vw, 7.5rem);
  height: clamp(5.5rem, 18vw, 7.5rem);
  margin-bottom: 1.25rem;
  opacity: 0;
  transform: scale(0.88);
  transition: opacity 0.5s ease, transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

.fo-loader__logo,
.fo-loader__wordmark {
  position: relative;
  z-index: 2;
}

.fo-loader__logo-img {
  display: block;
  width: 100%;
  height: auto;
  max-height: clamp(5rem, 16vw, 7rem);
  object-fit: contain;
}

.fo-loader__wordmark {
  margin: 0;
  font-family: var(--fo-font-serif, 'Cormorant Garamond', Georgia, serif);
  font-size: clamp(1.35rem, 4.5vw, 1.75rem);
  font-weight: 500;
  letter-spacing: 0.14em;
  line-height: 1.15;
  color: var(--fo-text-dark, #111111);
}

.fo-loader__shine {
  position: absolute;
  inset: -20% -40%;
  z-index: 3;
  background: linear-gradient(
    105deg,
    transparent 35%,
    rgba(255, 255, 255, 0.55) 50%,
    transparent 65%
  );
  opacity: 0;
  transform: translateX(-120%);
  pointer-events: none;
}

.fo-loader__title {
  margin: 0 0 0.35rem;
  font-family: var(--fo-font-serif, 'Cormorant Garamond', Georgia, serif);
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.45s ease 0.1s, transform 0.45s ease 0.1s;
}

.fo-loader__subtitle {
  margin: 0 0 1.5rem;
  font-family: var(--fo-font-sans, 'Inter', system-ui, sans-serif);
  font-size: clamp(0.72rem, 2.2vw, 0.82rem);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fo-text-muted-cream, #6B655C);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.45s ease 0.18s, transform 0.45s ease 0.18s;
}

.fo-loader__progress {
  width: min(12rem, 52vw);
  height: 1px;
  background: rgba(17, 17, 17, 0.12);
  overflow: hidden;
  opacity: 0;
  transition: opacity 0.35s ease 0.25s;
}

.fo-loader__progress-fill {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--fo-gold-gradient, linear-gradient(135deg, #BF953F, #FCF6BA, #B38728, #AA771C));
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}

/* ── Active timeline states (JS-driven) ── */
.fo-loader--active .fo-loader__hex {
  stroke-dashoffset: 0;
  opacity: 1;
}

.fo-loader--active .fo-loader__hex--c {
  transform: scale(1);
}

.fo-loader--active .fo-loader__honey-flow {
  opacity: 0.45;
  transform: translateY(8%);
}

.fo-loader--active .fo-loader__logo-wrap {
  opacity: 1;
  transform: scale(1);
}

.fo-loader--active .fo-loader__title,
.fo-loader--active .fo-loader__subtitle {
  opacity: 1;
  transform: translateY(0);
}

.fo-loader--active .fo-loader__progress {
  opacity: 1;
}

.fo-loader--active .fo-loader__progress-fill {
  transform: scaleX(1);
}

.fo-loader--shine .fo-loader__shine {
  opacity: 1;
  transform: translateX(120%);
  transition: transform 0.85s ease, opacity 0.35s ease;
}

.fo-loader--expand .fo-loader__hex--c {
  transform: scale(8);
  opacity: 0.35;
}

.fo-loader--exit .fo-loader__comb {
  opacity: 0;
  transform: scale(1.12);
}

.fo-loader--exit .fo-loader__hex:not(.fo-loader__hex--c) {
  opacity: 0;
  transform: scale(1.35);
}

.fo-loader--exit .fo-loader__hex--c {
  opacity: 0;
  transform: scale(10);
}

.fo-loader--exit .fo-loader__stage {
  opacity: 0;
  transform: scale(0.98);
  transition: opacity 0.4s ease, transform 0.45s ease;
}

.fo-loader--exit {
  opacity: 0;
  transition: opacity 0.45s ease 0.15s;
}

.fo-loader--flip [data-fo-loader-flip] {
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.45s ease;
}

body.fo-loader-done {
  overflow: auto;
}

body.fo-loader-pending {
  overflow: hidden;
}

body.fo-loader-pending:not(.fo-loader-done) .fo-header__logo-img,
body.fo-loader-pending:not(.fo-loader-done) .fo-header__name {
  opacity: 0;
}

@media (prefers-reduced-motion: reduce) {
  .fo-loader,
  .fo-loader * {
    animation: none !important;
    transition: none !important;
  }
}

html.fo-a11y-reduce-motion .fo-loader,
html.fo-a11y-reduce-motion .fo-loader * {
  animation: none !important;
  transition: none !important;
}
