/* Sfondo nero per l'intera pagina durante il caricamento */
#page-loader-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: #000; /* Sfondo nero */
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}

/* Loader */
.loader {
  width: 50px;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(farthest-side, #000 98%, #0000) 55% 20%/8px 8px no-repeat,  
    #ffcc00; /* Colore di sfondo principale del loader */
  box-shadow: 2px -6px 12px 0px inset rgba(0, 0, 0, 0.7);
  animation: l4 .5s infinite steps(5) alternate;
}

@keyframes l4 { 
    0% { clip-path: polygon(50% 50%, 100% 0, 100% 0, 0 0, 0 100%, 100% 100%, 100% 100%) }
  100% { clip-path: polygon(50% 50%, 100% 65%, 100% 0, 0 0, 0 100%, 100% 100%, 100% 35%) }
}

/* Nasconde l'overlay con una dissolvenza */
body.loaded #page-loader-overlay {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.5s ease; /* Aggiunge la dissolvenza */
}
