  #page-loader {
    display: none;
    position: fixed; inset: 0; z-index: 99999;
    background: #05060E;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    transition: opacity 0.6s ease, visibility 0.6s ease;
  }
  #page-loader.hidden {
    opacity: 0; visibility: hidden; pointer-events: none;
  }

  /* Wordmark */
  .loader-wordmark {
    font-family: 'Almarai', sans-serif;
    font-size: 28px; font-weight: 800;
    color: #fff; letter-spacing: 1px;
    margin-bottom: 8px;
    opacity: 0;
    animation: loaderFadeUp 0.7s ease 0.2s forwards;
  }
  .loader-wordmark span { color: #D4A843; }
  .loader-subrole {
    font-family: 'Almarai', sans-serif;
    font-size: 13px; font-weight: 400;
    color: rgba(255,255,255,0.45);
    margin-bottom: 44px;
    opacity: 0;
    animation: loaderFadeUp 0.7s ease 0.35s forwards;
  }

  /* Ring spinner */
  .loader-ring {
    width: 64px; height: 64px;
    position: relative; margin-bottom: 40px;
    opacity: 0;
    animation: loaderFadeUp 0.7s ease 0.4s forwards;
  }
  .loader-ring svg {
    width: 100%; height: 100%;
    animation: loaderSpin 1.4s linear infinite;
  }
  .loader-ring svg circle {
    fill: none;
    stroke-width: 3;
    stroke-linecap: round;
    stroke-dasharray: 120;
    stroke-dashoffset: 80;
  }
  .loader-ring svg circle.track { stroke: rgba(255,255,255,0.08); stroke-dasharray: unset; stroke-dashoffset: unset; }
  .loader-ring svg circle.spin  { stroke: #D4A843; }

  /* Progress bar */
  .loader-bar-wrap {
    width: 220px; height: 2px;
    background: rgba(255,255,255,0.08);
    border-radius: 99px; overflow: hidden;
    opacity: 0;
    animation: loaderFadeUp 0.7s ease 0.5s forwards;
  }
  .loader-bar {
    height: 100%; width: 0%;
    background: linear-gradient(90deg, #BE1622, #D4A843);
    border-radius: 99px;
    transition: width 0.3s ease;
  }

  /* Label */
  .loader-label {
    margin-top: 16px;
    font-family: 'Almarai', sans-serif;
    font-size: 13px; color: rgba(255,255,255,0.4);
    letter-spacing: 1px;
    opacity: 0;
    animation: loaderFadeUp 0.7s ease 0.6s forwards;
  }

  @keyframes loaderFadeUp {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
  }
  @keyframes loaderSpin {
    to { transform: rotate(360deg); }
  }
