/**
 * Loader plein écran - Armoirie + message informatif
 */

#page-loader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.4s ease, visibility 0.4s ease;
  background: rgba(8, 22, 14, 0.26);
  backdrop-filter: blur(9px);
  -webkit-backdrop-filter: blur(9px);
}

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

#page-loader .loader-inner {
  width: min(560px, calc(100% - 32px));
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.9rem;
  text-align: center;
  padding: 20px 18px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(255, 255, 255, 0.7);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.15);
}

#page-loader .loader-logo {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  overflow: hidden;
  background: #fff;
  padding: 4px;
  box-shadow: 0 4px 24px rgba(34, 139, 34, 0.2), 0 0 0 3px rgba(34, 139, 34, 0.15);
  animation: loader-pulse 1.2s ease-in-out infinite;
}

#page-loader .loader-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

#page-loader .loader-title {
  margin: 2px 0 0;
  font-size: clamp(1rem, 2vw, 1.25rem);
  line-height: 1.35;
  font-weight: 700;
  color: #0e3b1d;
}

#page-loader .loader-subtitle {
  margin: 0;
  font-size: clamp(0.85rem, 1.6vw, 0.98rem);
  line-height: 1.35;
  color: #2e4a37;
}

#page-loader .loader-bar {
  width: min(240px, 80%);
  height: 4px;
  background: rgba(34, 139, 34, 0.2);
  border-radius: 2px;
  overflow: hidden;
}

#page-loader .loader-bar::after {
  content: '';
  display: block;
  width: 40%;
  height: 100%;
  background: #228b22;
  border-radius: 2px;
  animation: loader-progress 1s ease-in-out infinite;
}

@keyframes loader-pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 4px 24px rgba(34, 139, 34, 0.2), 0 0 0 3px rgba(34, 139, 34, 0.15); }
  50% { transform: scale(1.03); box-shadow: 0 6px 28px rgba(34, 139, 34, 0.25), 0 0 0 4px rgba(34, 139, 34, 0.2); }
}

@keyframes loader-progress {
  0% { transform: translateX(-100%); }
  50% { transform: translateX(150%); }
  100% { transform: translateX(-100%); }
}

@media (max-width: 576px) {
  #page-loader .loader-inner {
    width: calc(100% - 20px);
    padding: 16px 12px;
    border-radius: 12px;
  }

  #page-loader .loader-logo {
    width: 74px;
    height: 74px;
  }
}
