/* Quiet Light — shared page loader & reveal */

html.is-loading main,
html.is-loading #root > main {
  opacity: 0;
}

html.is-ready main,
html.is-ready #root > main {
  opacity: 1;
  transition: opacity 0.75s ease 0.15s;
}

.site-loader {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #FAFAF7;
  transition: opacity 0.55s ease, visibility 0.55s ease;
}

.site-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.site-loader-glow {
  position: absolute;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(250, 248, 240, 0.95) 0%, transparent 70%);
  animation: loader-breathe 3.2s ease-in-out infinite;
  pointer-events: none;
}

@keyframes loader-breathe {
  0%, 100% { opacity: 0.35; transform: scale(0.9); }
  50% { opacity: 0.9; transform: scale(1.1); }
}

.site-loader-ring {
  width: 44px;
  height: 44px;
  border: 4px solid #E8E8E5;
  border-top-color: #1A1A1A;
  border-radius: 50%;
  animation: loader-spin 1.1s linear infinite;
  margin-bottom: 20px;
  position: relative;
  z-index: 1;
}

@keyframes loader-spin {
  to { transform: rotate(360deg); }
}

.site-loader-text {
  position: relative;
  z-index: 1;
  margin: 0;
  font-size: 1.05rem;
  color: #8A8A8A;
  letter-spacing: 0.02em;
  transition: opacity 0.35s ease;
}

.site-loader-text.is-changing {
  opacity: 0;
}

@media (prefers-reduced-motion: reduce) {
  .site-loader-glow { animation: none; opacity: 0.6; }
  .site-loader-ring { animation: none; border-top-color: #8A8A8A; }
  html.is-ready main,
  html.is-ready #root > main {
    transition: none;
  }
}