/*
 * loader.css — vòng tròn tải trang + trạng thái tải ảnh (fade-in mượt + spinner).
 * Dùng chung cho cả 3 trang. Đi kèm loader.js.
 */

/* ===== Overlay "đang tải" toàn trang ===== */
#page-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at center, #3a0709, #1a0405);
  transition: opacity 0.5s ease, visibility 0.5s ease;
}

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

.pl-spinner {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  border: 4px solid rgba(242, 201, 76, 0.25);
  border-top-color: #f2c94c;
  animation: ld-spin 0.8s linear infinite;
}

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

/* ===== Ảnh: hiện dần (fade-in) + spinner chờ ===== */
/* Bọc quanh ảnh để định vị spinner (JS tự thêm class này). */
.img-host {
  position: relative;
}

img.img-lazy {
  opacity: 0;
  transition: opacity 0.5s ease;
}

img.img-lazy.is-loaded {
  opacity: 1;
}

/* Vòng tròn nhỏ hiện trong khung ảnh trong lúc ảnh đang tải. */
.img-spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 30px;
  height: 30px;
  margin: -15px 0 0 -15px;
  border-radius: 50%;
  border: 3px solid rgba(176, 22, 34, 0.25);
  border-top-color: var(--red, #b01622);
  animation: ld-spin 0.7s linear infinite;
  pointer-events: none;
  z-index: 1;
}

/* Tôn trọng người dùng tắt hiệu ứng chuyển động. */
@media (prefers-reduced-motion: reduce) {
  .pl-spinner,
  .img-spinner {
    animation-duration: 1.6s;
  }
  img.img-lazy {
    transition: none;
  }
}
