body {
    overflow: hidden;
    background-color: #ffffff;
}

/* Nasconde tutto il contenuto del body tranne il pageloader
   SOLO se il pageloader NON è già stato completato */
body:not(.pageloader-done)::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #ffffff;
    z-index: 9998; /* Appena sotto il pageloader (9999) */
    pointer-events: none;
    opacity: 1;
    transition: opacity 0.5s ease;
}

/* Quando il pageloader ha finito, l'overlay scompare */
body.pageloader-done::before {
    opacity: 0;
}

#pageloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #ffffff;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    transform: translateY(-100%);
    transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

#pageloader::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #ffffff;
    transform: translateY(-100%);
    transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
    -webkit-transform: translateY(-100%);
    -moz-transform: translateY(-100%);
    -ms-transform: translateY(-100%);
    -o-transform: translateY(-100%);
}

#pageloader.entering,
#pageloader.entering::before {
    transform: translateY(0);
}

#pageloader.loaded,
#pageloader.loaded::before {
    transform: translateY(-100%);
    pointer-events: none;
}

#pageloader svg {
    position: relative;
    z-index: 10;
    width: 200px;
    height: 200px;
    opacity: 0;
    transform: scale(0.9);
    transition: 
        opacity 1.5s cubic-bezier(0.4, 0, 0.2, 1),
        transform 1.5s cubic-bezier(0.4, 0, 0.2, 1);
}

#pageloader.entering svg {
    opacity: 1;
    transform: scale(1);
}

#pageloader.loaded svg {
    opacity: 0;
    transform: scale(0.9) translateY(-30%);
}


#pageloader .cls-2 {
  fill: #1f414f;
  stroke: none;
  /* il clipPath si occupa dell'animazione */
}

#pageloader .cls-1 {
  fill: #d1664e;
  fill-opacity: 0;
  transform: scale(0.5);
  animation: showOrange 0.8s cubic-bezier(0.45,0,0.55,1) forwards;
  animation-delay: 1s; /* parte subito dopo che il blu è completo */
}

@keyframes showOrange {
  0% {
    transform: scale(0.5);
    fill-opacity: 0;
  }
  100% {
    transform: scale(1);
    fill-opacity: 1;
  }
}