/* ===== Loading overlay ===== */
.site-loader {
  position: fixed;
  inset: 0;
  z-index: 6000; /* ヘッダー/ドロワーより前面 */
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff; /* 必要なら #000 に変更可 */
  opacity: 1;
  visibility: visible;
  transition: opacity 0.45s ease, visibility 0.45s ease;
  pointer-events: all;
}

.site-loader__inner img {
  width: 120px; /* お好みで */
  height: auto;
  display: block;
}

.site-loader__sr {
  display: block;
  font-family: "Alata", "Noto Sans JP", sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.05em;
  color: #111; /* 背景に合わせて変更可 */
  margin-top: 8px;
  text-align: center;
  animation: fadeBlink 1.5s ease-in-out infinite;
}

@keyframes fadeBlink {
  0%,
  100% {
    opacity: 0.3;
  }
  50% {
    opacity: 1;
  }
}

/* フェードアウト後に非表示へ */
html.site-loaded .site-loader {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* ローダー中はスクロール抑止（任意） */
html.site-lock {
  overflow: hidden;
}

/* 低モーション配慮 */
@media (prefers-reduced-motion: reduce) {
  .site-loader {
    transition: none;
  }
  html.site-loaded .site-loader {
    opacity: 0;
    visibility: hidden;
  }
}

.site-loader__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.2rem;
}

.site-loader__text {
  font-family: "Alata", "Noto Sans JP", sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.05em;
  color: #111;
}
