
                /* --- INIZIO DEFINIZIONI FONT @font-face --- */


        @font-face {
            font-family: 'Special_Gothic_Expanded_One';
            src: url('fonts/special-gothic-expanded-one-latin-400-normal.eot?#iefix') format('embedded-opentype'),
                url('fonts/special-gothic-expanded-one-latin-400-normal.woff2') format('woff2'),
                url('fonts/special-gothic-expanded-one-latin-400-normal.woff') format('woff');
            font-weight: normal;
            font-style: normal;
            font-display: swap;
        }

        @font-face {
            font-family: 'OldStyle 1';
            src: url('fonts/OldStyle1HPLHS.eot');
            src: url('fonts/OldStyle1HPLHS.eot?#iefix') format('embedded-opentype'),
                url('fonts/OldStyle1HPLHS.woff2') format('woff2'),
                url('fonts/OldStyle1HPLHS.woff') format('woff'),
                url('fonts/OldStyle1HPLHS.ttf') format('truetype');
            font-weight: normal;
            font-style: normal;
            font-display: swap;
        }

        @font-face {
            font-family: 'Oldstyle'; /* Nota: questo è il font italic */
            src: url('fonts/OldstyleItalicHPLHS.eot');
            src: url('fonts/OldstyleItalicHPLHS.eot?#iefix') format('embedded-opentype'),
                url('fonts/OldstyleItalicHPLHS.woff2') format('woff2'),
                url('fonts/OldstyleItalicHPLHS.woff') format('woff'),
                url('fonts/OldstyleItalicHPLHS.ttf') format('truetype');
            font-weight: normal;
            font-style: italic;
            font-display: swap;
        }
        /* --- FINE DEFINIZIONI FONT @font-face --- */
        
        
   /* --- CSS Tipografia Responsiva --- */

/* 1. Imposta una dimensione del font base sul tag HTML usando PX per controllare REM */
/* Questa sarà la base per tutti gli altri font definiti in REM */
html {
    font-size: 16px; /* Dimensione base su desktop (1rem = 16px) */
    line-height: 1.6; /* Altezza di linea predefinita per una buona leggibilità */
    color: #333; /* Colore del testo generale per buon contrasto */
    font-family: 'OldStyle 1', serif; /* Font principale, con fallback generico */
}

/* 2. Media Queries per adattare la dimensione base del font su dispositivi più piccoli */
@media (max-width: 1024px) { /* Per laptop più piccoli e tablet in orizzontale */
    html {
        font-size: 15px; /* 1rem = 15px */
    }
}

@media (max-width: 768px) { /* Per tablet in verticale e schermi più piccoli */
    html {
        font-size: 14px; /* 1rem = 14px */
    }
}

@media (max-width: 480px) { /* Per smartphone */
    html {
        font-size: 13px; /* 1rem = 13px */
    }

    .title {
    font-size: 5vmin !important;
}

span.close {
    font-size: 13vw;
    top: -6vw;
    right: 3vw;
}

}


@media (hover: none) {
  a:hover {
    all: unset;
  }
}
@media (hover: hover) {
  .lightbox-trigger:hover:after {
    width: 100%;
  }
}

html, body {
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
}

h1 {
    /* Fallback per browser che non supportano clamp() */
    font-size: 3rem; /* 48px su desktop base */
    /* clamp(min-size, fluid-size, max-size) */
    /* Il titolo H1 sarà tra 2.5rem (min) e 5rem (max), scalando con la larghezza del viewport */
    font-size: clamp(2.5rem, 6vw + 1rem, 5rem);
    line-height: 1.2;
    margin-bottom: 0.5em; /* Spazio sotto il titolo, proporzionale alla sua dimensione */
    font-family: 'Special_Gothic_Expanded_One', sans-serif;
    color: #222;
}

h2 {
    font-size: clamp(2rem, 4vw + 0.5rem, 3.5rem);
    line-height: 1.3;
    margin-bottom: 0.4em;
    font-family: 'Special_Gothic_Expanded_One', sans-serif;
    color: #222;
}

h3 {
    font-size: clamp(1.5rem, 3vw + 0.5rem, 2.5rem);
    line-height: 1.4;
    margin-bottom: 0.3em;
    font-family: 'Special_Gothic_Expanded_One', sans-serif;
    color: #222;
}

h4 {
    font-size: 4vmin;
    line-height: 1.4;
    margin-bottom: 0.3em;
    font-family: sans-serif;
    color: #222;
}


p {
    font-size: 1rem; /* Uguale al font-size di html per il corpo del testo */
    line-height: 1.7; /* Altezza di linea leggermente maggiore per la leggibilità del paragrafo */
    margin-bottom: 1em;
}

a {
    color: initial;
}

.lightbox-modal a {
    font-size: 1rem; /* Mantiene la stessa dimensione del testo del paragrafo */
    color: #007bff; /* Colore link */
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

ul, ol {
    font-size: 1rem;
    line-height: 1.7;
    margin-bottom: 1em;
    padding-left: 1.5em; /* Spazio per i punti elenco */
}

li {
    margin-bottom: 0.5em;
}

/* Considerazioni aggiuntive per la leggibilità: */
/* Assicurati che ci sia sempre un buon contrasto tra testo e sfondo. */
/* Utilizza font-weight (es. 400 per normale, 700 per bold) per la gerarchia visiva. */
/* Le tue definizioni @font-face esistenti sono corrette per includere i font personalizzati. */     
        
        
        
        
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        body {
           height: 17600px; /* totalFrames * Scroll Duration */
            background-color: #FFFFFF;
        }
        
        body.no-scroll {
    overflow: hidden;
}

        .pin-container {
            position: relative;
            height: 100vh;
            display: flex;
            justify-content: center;
            align-items: center;
        }

        .image-sequence {
            position: relative;
            width: 100vmin;
            height: 100vmin;
        }

        @media (orientation: landscape) {
            .image-sequence {
                width: 100vh;
                height: 100vh;
            }
        }

        @media (orientation: portrait) {
            .image-sequence {
                width: 100vw;
                height: 100vw;
            }
        }

        .image-sequence img {
            position: absolute;
            width: 100%;
            height: 100%;
            object-fit: cover;
            display: none;
        }

        /* Forza la prima immagine e le immagini con classe .active a mostrarsi */
        .image-sequence img.active,
        .image-sequence img:first-of-type {
            display: block;
        }

        .element {
            position: absolute;
            opacity: 0;
            transition: transform 0.5s ease, opacity 0.2s ease, scale 1s ease, visibility 2s ease;

            z-index: 3;
            font-size: 3.7vmin;
            /* min-width: 30vw; */
            padding: 2px 4px;
            font-family: 'OldStyle';
            line-height: 3.9vmin;
            min-width: max-content;
        }

        .element.lightbox-trigger {

                    background: #ffffffa8;
        }
        

        .element.lightbox-trigger {

            cursor: pointer;
        }
        
        span.name {
            font-size: 7vmin;
        }

        span.name, span.job {
            font-family: 'Special_Gothic_Expanded_One';
            color: #FFF;
            background: #000;
            padding: 0 0.2em;
        }
        span.job {
            font-size: 2.5vmin;

        }
        
        .element.moving {
            transition: left 0.5s ease, top 0.5s ease;
        }

        .element.visible {
            opacity: 1;
        }

        .element.frombottom {
            transform: translateY(20px);
        }

       /*.element.frombottom.visible {
            transform: translateY(0);
        }
            */

        .element.text-right{
    transform: translateX(-100%) translateY(-100%) translateZ(50px);
    text-align: right;
    }

            .element.text-center{
    transform: translateX(-50%) translateY(-100%) translateZ(50px);
    text-align: center;
    }

    .hidden, .goingup {
                    visibility: hidden;
             pointer-events: none;
    } 
        .element.frombottom.hidden {
            transform: translateY(8vmin);

        }

        .element.frombottom.goingup {
            transform: translateY(-17vmin);



        }
        
        .element.twoseven {
            font-size: 1.8vw;
            width: 100%;
            text-align: center;
        }
        
        .title {
            width:100%;
            text-align:center;
        }
        
        .onezero span, .zeroone span, .zerotwo span, .twozero span, .threezero span, .fourzero span, .fivezero span a {
            background: black;
            color: white;
            padding: 1vmin;
            font-family: 'Special_Gothic_Expanded_One';
            font-size: 6vmin;
        }
        
.zerotwo span, .fivezero span a{
    font-size: 4vmin;
    background: #eeff00;
    color: #1d1d1d;
}

        .threeseven{font-size: 1.5vmin}
        .zerozero, .zerozerob{
            color: beige;
            width: 100%;
            text-align: center;
        }
        
        .zerozero{
            font-size: 4vw;
        }

        .zerotwo{
            transform: rotate(352deg) !important;
        }

        .debug-info {
            position: fixed;
            bottom: 10px;
            left: 10px;
            background: rgba(0, 0, 0, 0.7);
            color: white;
            padding: 10px;
            border-radius: 5px;
            font-family: Arial, sans-serif;
            font-size: 14px;
            z-index: 10;
        }
        
        .noise::before{
            position: fixed;
            top: 0;
            left: 0;
            width: 100vw;
            height: 100vh;
            content: "";
            opacity: .05;
            z-index: 1000;
            pointer-events: none;
            background: url(../content/noise.gif) ;
          }
        
        /* Scritte interattive */
        .lightbox-trigger {
          /* color: blue; */
          text-decoration: underline;
          /* background: red; */
          z-index: 9;
          padding: 0.2em;
          /* border-left: 5px solid; */
          /* position: relative; */
          /* text-decoration: none; */
          color: #444;
          box-sizing: border-box;
          -moz-box-sizing: border-box;
          -webkit-box-sizing: border-box;
        }



.lightbox-trigger:after {
    content: "";
    height: 100%;
    left: 0;
    top: 0;
    width: 0px;
    position: absolute;
    -webkit-transition: all 0.2s ease 0s;
    z-index: -1;
    background: #ffff00c9;
}


      .lightbox-trigger:hover:after{ 
        width: 100%;
    }

        
        /* --- Stili Lightbox Modale (AGGIORNATI per immagine di sfondo e box testo) --- */
.lightbox-modal {
    display: none; /* Viene sovrascritto da flex via JS quando si apre */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000000fa; /* */
    background-size: cover; /* */
    background-position: center; /* */
    background-repeat: no-repeat; /* */
    z-index: 1000; /* */
    
    /* Abilita lo scroll verticale sul finto schermo del modale */
    overflow-y: auto; /* */
    -webkit-overflow-scrolling: touch; /* */
    
    /* Usiamo il display flex qui per attivare il calcolo dei margini automatici del figlio */
    display: none; 
    flex-direction: column;
}

.modal-content {
    background-color: transparent; /* */
    padding: 0; /* */
    text-align: center; /* */
    max-width: 900px; /* */
    width: 90%; /* */
    display: flex; /* */
    flex-direction: column; /* */
    align-items: center; /* */
    justify-content: center; /* */
    position: relative; /* */

    /* IL SEGRETO: margin auto su tutti i lati con un padding di sicurezza */
    margin: auto;
    padding-top: 40px;   /* Evita che il contenuto tocchi il bordo superiore se lungo */
    padding-bottom: 40px;/* Evita che il contenuto tocchi il bordo inferiore se lungo */
    
    min-height: fit-content; /* */
}

p {}

#modalConsulenze p {
    color: #FFF;
    margin: 2% 15%;
}

/* Nuovo contenitore per il titolo e il testo con sfondo scuro */
.modal-info-box {
    background-color: rgba(0, 0, 0, 0.7); /* Sfondo scuro semitrasparente */
    padding: 30px; /* Spazio interno al box */
    border-radius: 10px;
    width: 100%; /* Occupa tutta la larghezza del modal-content */
    display: flex;
    flex-direction: column; /* Titolo e testo impilati */
    align-items: center; /* Centra orizzontalmente titolo e testo */
    text-align: center; /* Centra il testo */
    gap: 15px; /* Spazio tra titolo e modal-text */
}

.modal-info-box h2, .modal-content h2 {
    margin-bottom: 0; /* Già gestito sopra, ma ribadito */
    color: #FFF; /* Titoli del modale sempre bianchi */
}

.modal-text {
    /* Questo div contiene i paragrafi e il divider */
    width: 100%; /* Occupa tutta la larghezza disponibile all'interno di modal-info-box */
    color: #FFF; /* Paragrafi del modale sempre bianchi */
}

.modal-text p {
    margin-bottom: 1em;
}

.modal-text .divider {
    display: block;
    width: 50px;
    height: 2px;
    background-color: #CCC;
    margin: 20px auto; /* Centra il divider */
}

/* Pulsante di chiusura */
.close {
    position: absolute;
    top: 2vmin;
    right: 2vmin;
    color: white;
    font-size: 5vmin;
    font-weight: bold;
    cursor: pointer;
    z-index: 1001;
    text-shadow: 2px 2px 6px black;
}

.close:hover {
    color: red;
}
        

/* Contenitore principale dei libri */
.libri-container {
  display: flex;
  flex-wrap: wrap; /* Permette il passaggio riga su schermi piccoli */
  gap: 30px;      /* Spazio tra un libro e l'altro */
  justify-content: center;
  align-items: flex-start;
  margin-top: 20px;
}

/* Singolo blocco libro */
.libro-item {
  flex: 1;          /* I libri occupano spazio uguale */
  min-width: 250px; /* Impedisce che diventino troppo stretti */
  max-width: 350px; /* Evita che diventino giganti su schermi enormi */
  text-align: center;
}

/* Stile immagini */
.libro-item img {
  width: 100%;      /* L'immagine occupa tutto il contenitore del libro */
  height: auto;
  border-radius: 8px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
  margin-bottom: 15px;
}

/* Stile testo */
.libro-item p {
  font-size: 1.2rem
  line-height: 1.5;
  color: #CCC;
  text-align: left; /* Opzionale: giustificato o a sinistra per leggibilità */
}

/* Media Query per Mobile (sotto i 768px) */
@media (max-width: 768px) {
  .libri-container {
    flex-direction: column; /* Forza la disposizione verticale */
    align-items: center;
  }
  
  .libro-item {
    max-width: 70%; /* Su mobile usa tutto lo spazio disponibile */
    margin-bottom: 40px;
  }
}
             

/* Media Query per schermi più grandi e/o orizzontali */
@media (min-width: 768px) and (orientation: landscape),
       (min-width: 1024px) {
    
    .lightbox-modal {
        padding: 40px;
    }

    .modal-content {
        max-width: 1000px; /* Adatta la larghezza massima del box contenitore */
        width: 80%; /* Percentuale del viewport */
    }

    .modal-info-box {
        padding: 40px 60px; /* Più padding sui lati per schermi grandi */
    }

    .modal-info-box h2 {
        /* Se vuoi un allineamento diverso del titolo su desktop, puoi sovrascrivere qui */
        /* Es: text-align: left; */
    }

    .modal-text {
        /* Se vuoi un allineamento diverso del testo su desktop, puoi sovrascrivere qui */
        /* Es: text-align: left; */
    }

    .modal-text .divider {
        margin: 20px auto; /* Mantieni centrato o allinea a left se modal-text è text-align: left; */
    }
}
    
        
.scroll-to {
    width: 100%;
    height: 57%;

    cursor: pointer;
    /* z-index: 3; */
    /* background-repeat: no-repeat; */
    display: flex;
    flex-direction: column;
    align-items: center;    /* Centra orizzontalmente */
    justify-content: flex-end; /* Spinge il contenuto in basso */
    /* height: 100vh; */          /* Altezza di tutto lo schermo */
}

video {
    width: 11vw;
}
        
        .scroll-to.goingup {
            transform: translateY(-5vmax);
            transition: transform 0.5s ease, opacity 0.5s ease;
                         visibility: hidden;

}
        
        
    span.divider {
    height: 20px;
    display: block;
}

p {
    line-height: 1.4;
}




#preloader {

    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #FFFFFF; /* Colore di sfondo del preloader */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999; /* Assicurati che sia sopra tutto il resto */
    flex-direction: column;
    pointer-events: auto; /* Questa riga è FONDAMENTALE */
    transition: opacity 1s ease-out; /* Assicurati che questa transizione sia nel CSS o aggiunta via JS all'inizio */
}
.preloader-content h4, #progress {
    color: #777;
     font-family: 'Special_Gothic_Expanded_One';


}

.preloader-content {
    text-align: center;

}

.preloader-content p {
    margin-bottom: 10px;
    font-size: 2vmin;
    
}

#progress {
    font-size: 25.5vmin;
    font-weight: bold;
    position: relative;
    z-index: 1;
}

.progress-bar {
    width: 100vw;
    height: 100vh;
    background-color: #FFF;
    position: absolute;
    top: 0;
    left: 0;
}

.progress-fill {
    height: 100%;
    width: 0%;
    background-color: #000; /* Colore della barra di progresso */
    
    /* Regola per il movimento costante: transizione brevissima e lineare */
    transition: width 0.2s linear; 
    will-change: width; /* Dice al browser di ottimizzare la barra tramite la scheda video */
}


 


/* 1. Il contenitore principale deve creare lo spazio 3D */
.pin-container {
    perspective: 1200px;
    transform-style: preserve-3d; /* Fondamentale! */
    position: relative;
    transition: transform 0.2s ease-out;
}

/* 2. ANCHE il contenitore della sequenza deve preservare il 3D, 
      altrimenti "schiaccia" gli elementi al suo interno */
.image-sequence {
    transform-style: preserve-3d;
    inset: 0;
    z-index: 2;
}


/* 4. Gli elementi devono avere un distacco netto per essere visibili */
.element, .scroll-to {
    /* Prova un valore alto per testare: 100px rendono l'effetto evidentissimo */
    transform: translateZ(50px); 
    will-change: transform;
}

/* Puoi differenziare ulteriormente per un effetto "nuvola" */
.element.title { transform: translateZ(40px); }
.lightbox-trigger { transform: translateZ(50px); }

div#debug-info {
    display:none;
}
        
