/* ============================================================
   1. RESET E VARIABILI 
   ============================================================ */
   :root {
    --granata: rgba(91, 19, 19, 1);
    --marrone-chiaro: rgba(181, 141, 130, 1);
    --beige-bg: rgba(237, 226, 208, 1);
    --testo-scuro: #3d1f1f;
    --font-principale: 'Athene', 'Georgia', serif;
}

*, *::before, *::after {
    box-sizing: border-box;
}

body {
    background-color: var(--beige-bg);
    margin: 0;
    padding: 0;
    font-family: var(--font-principale);
    overflow-x: hidden; /* Fondamentale: impedisce al sito di ballare a destra e sinistra */
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* ============================================================
   2. LAYOUT GENERALE (L'ancora di salvezza)
   ============================================================ */
.container {
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
}

/* ============================================================
   3. MENU E LOGO (Basta margini infiniti!)
   ============================================================ */
.menu {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 5%;
    width: 100%;
    background: transparent;
}

.logoIvano {
    height: 80px;
}

.titoletti {
    display: flex;
    gap: 30px;
}

.titoletti p {
    font-size: 1.2rem;
    cursor: pointer;
    position: relative;
    color: var(--granata);
    margin: 0;
    transition: color 0.3s;
}

/* Effetto sottolineatura hover */
.titoletti div::after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--granata);
    transition: width 0.3s;
}

.titoletti div:hover::after {
    width: 100%;
}

/* ============================================================
   4. CAROUSEL E HERO
   ============================================================ */
.carousel-container {
    width: 100%;
    height: 60vh; /* Altezza basata sulla vista, non pixel fissi */
    overflow: hidden;
    position: relative;
}

.slide {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: opacity 1s;
}

.slide.active {
    opacity: 1;
}

/* Foto Torino e Rettangolo */
.fotoPrincipale {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 80px 20px;
    position: relative;
}
.fotoTorino {
    width: 100%;
    max-width: 800px; /* Mantieni la dimensione che preferisci */
    border-radius: 10px;
    position: relative; /* Necessario per lo z-index */
    z-index: 3;         /* PORTA LA FOTO SOPRA */
}

.rettangolo {
    background-color: var(--granata);
    color: white;
    padding: 60px 40px; /* Aumentato il padding per dare respiro */
    text-align: center;
    border-radius: 10px;
    
    /* LARGHEZZA */
    width: 95%;          /* Occupa quasi tutto lo spazio disponibile */
    max-width: 1100px;   /* Diventa più largo di prima (era 900px) */
    
    /* POSIZIONAMENTO E SOVRAPPOSIZIONE */
    margin-top: -150px;  /* VALORE NEGATIVO PIÙ ALTO: lo sposta molto più su */
    position: relative;  /* Necessario per lo z-index */
    z-index: 2;          /* RESTA SOTTO LA FOTO (perché la foto ha 3) */
    
    box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}
/* ============================================================
   5. SEZIONE CHI SIAMO (Home)
   ============================================================ */
.contenitoreWrapper {
    padding: 100px 0;
}

.contenitoreRettangoli {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    padding: 40px;
}

.rettangoloMarrone {
    background-color: var(--marrone-chiaro);
    padding: 40px;
    border-radius: 15px;
    max-width: 700px;
    z-index: 2;
}

.testoRettangoloSus {
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--testo-scuro);
}

.immagineToro {
    margin-top: 40px;
    display: flex;
    justify-content: center;
}

.fotoCiao {
    height: 150px;
}

/* ============================================================
   6. SERVIZI (Flexbox a prova di bomba)
   ============================================================ */
.rettangoloCiao {
    background-color: var(--marrone-chiaro);
    padding: 60px 20px;
    margin: 50px auto;
    border-radius: 40px;
    max-width: 1000px;
    text-align: center;
}

.serviziWrapper {
    display: flex;
    justify-content: center;
    flex-wrap: wrap; /* Fondamentale per il mobile! */
    gap: 40px;
    margin-top: 40px;
}

.servizio {
    flex: 1;
    min-width: 200px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.iconaCerchio {
    width: 120px;
    height: 120px;
    background-color: var(--beige-bg);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 15px;
}
.Wi-Fi,.Cucina_arredata,.Manutenzione_assistenza{
    width: 80px;
}

/* ============================================================
   7. SEZIONE APPARTAMENTI (Verticale e Ordinata)
   ============================================================ */
.testo { margin: 100px 0; text-align: center; }
.testoCiao { font-size: 4rem; margin: 0; }

.rettangoloSfondo {
    background-color: var(--granata);
    padding: 100px 0;
    width: 50%; /* Occupa la metà destra su desktop */
    display: flex;
    flex-direction: column;
    gap: 150px;
    margin-left: auto; 
    position: relative;
}

.contenitoreAnimato, .contenitoreAnimato2, .contenitoreAnimato3, .contenitoreAnimato4 {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    width: 100%;
}

/* Titoli: spinti a sinistra nell'area beige */
.titoloCasaDora, .titoloCasaDora2, .titoloCasaDora3, .titoloCasaDora4 {
    font-size: 3.5rem;
    color: var(--testo-scuro);
    border-bottom: 2px solid var(--testo-scuro);
    position: absolute;
    left: -80%; 
    top: 50px;
    z-index: 5;
    white-space: nowrap;
}

/* Pulsanti con Ombra */
.pulsanteWrapper, .pulsanteWrapper2, .pulsanteWrapper3, .pulsanteWrapper4 {
    position: absolute;
    left: -80%;
    top: 300px;
    z-index: 5;
    display: inline-block; /* Avvolge il bottone */
}

.pulsanteSfumato, .pulsanteSfumato2, .pulsanteSfumato3, .pulsanteSfumato4 {
    background: var(--marrone-chiaro);
    width: 100%;
    height: 100%;
    border-radius: 50px;
    position: absolute;
    top: 8px; /* Spostamento ombra */
    left: 8px;
    z-index: -1;
}

.pulsanteCasaDora, .pulsanteCasaDora2, .pulsanteCasaDora3, .pulsanteCasaDora4 {
    background: var(--granata);
    color: var(--beige-bg);
    border: none;
    padding: 15px 40px;
    font-size: 1.1rem;
    border-radius: 50px;
    cursor: pointer;
    font-family: var(--font-principale);
    font-weight: bold;
    position: relative;
}

/* Foto sovrapposte */
.fotoStack {
    position: relative;
    width: 100%;
    max-width: 500px;
    height: 450px;
    margin-top: 50px;
}

.fotoAnimata,.fotoAnimataBallatoio{
    width: 350px;
    border-radius: 15px;
    position: absolute;
    box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}

.fotoAnimata:first-child,
.fotoAnimataBallatoio:first-child {
    top: 0;
    left: -100px; /* Esce a sinistra dal rettangolo granata */
    z-index: 2;
}


.fotoSovrapposta {
    top: 150px;
    left: 50px;
    z-index: 3;
}

/* ============================================================
   8. FOOTER (Finalmente in fondo!)
   ============================================================ */


/* --- ANIMAZIONE PULSANTI "SCOPRI DI PIÙ" --- */
.pulsanteCasaDora, .pulsanteCasaDora2, .pulsanteCasaDora3, .pulsanteCasaDora4 {
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
}

.pulsanteSfumato, .pulsanteSfumato2, .pulsanteSfumato3, .pulsanteSfumato4 {
    transition: all 0.4s ease !important;
}

/* Effetto Hover: Il pulsante si alza e l'ombra si espande */
.pulsanteWrapper:hover .pulsanteCasaDora, 
.pulsanteWrapper2:hover .pulsanteCasaDora2, 
.pulsanteWrapper3:hover .pulsanteCasaDora3, 
.pulsanteWrapper4:hover .pulsanteCasaDora4 {
    transform: translateY(-5px);
    background-color: var(--marrone-chiaro) !important;
    color: var(--testo-scuro) !important;
}

.pulsanteWrapper:hover .pulsanteSfumato, 
.pulsanteWrapper2:hover .pulsanteSfumato2, 
.pulsanteWrapper3:hover .pulsanteSfumato3, 
.pulsanteWrapper4:hover .pulsanteSfumato4 {
    transform: translate(12px, 12px) scale(1.05);
    opacity: 0.6;
}

/* --- NUOVO STYLE FOOTER INDEX --- */
.footer-content {
    max-width: 800px;
    margin: 0 auto;
}

.footer-titolo {
    font-size: 2rem;
    color: var(--beige-bg);
    margin-bottom: 15px;
    font-family: var(--font-principale);
}

.footer-sottotitolo {
    font-size: 1.1rem;
    color: var(--beige-bg);
    opacity: 0.8;
    margin-bottom: 35px;
    line-height: 1.6;
}

.footer-contatti {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-bottom: 40px;
}

.contatto-item {
    color: var(--beige-bg);
    text-decoration: none;
    font-size: 1.3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    transition: transform 0.3s ease;
}

.contatto-item:hover {
    transform: scale(1.05);
}

.icona-footer {
    width: 25px;
    height: auto;
}




.rettangoloFinale, .rettangoloFinaleDora {
    background: var(--granata);
    padding: 60px 5%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.testoFinale {
    font-size: 1.5rem;
    color: var(--beige-bg);
    line-height: 1.5;
}

.contenitoreFinale, .contenitoreFinaleDora {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 30px;
    flex-wrap: wrap;
}

.instagram, .facebook, .whatsapp, .messanger, .airbnb {
    background: var(--marrone-chiaro);
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    /* Transizione fluida per l'animazione */
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), background-color 0.3s ease;
}
.instagram:hover, 
.facebook:hover, 
.whatsapp:hover, 
.messanger:hover, 
.airbnb:hover {
    transform: scale(1.15); /* Vengono in avanti di un 15% */
    background-color: #d2c5b0; /* Un leggero cambio di colore opzionale per feedback visivo */
}

.instagramFoto,.facebookFoto,.whatsappFoto,.messangerFoto,.airbnbFoto{
    width: 40px;
    height: auto;
}
/* ============================================================
   9. PAGINA CHI SIAMO (Dettagli)
   ============================================================ */
.rettangoloPrincipaleChiSiamo {
    background-color: var(--granata);
    padding: 80px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}

.rettangoloTestoChiSiamo, .rettangoloTestoChiSiamo2, .rettangoloTestoChiSiamo3, .rettangoloTestoChiSiamo4 {
    background: var(--marrone-chiaro);
    padding: 30px;
    border-radius: 20px;
    max-width: 800px;
    width: 100%;
}
/* ============================================================
   10. MEDIA QUERIES (Fix per Smartphone)
   ============================================================ */
 /* ============================================================
   FIX TOTALE PER SMARTPHONE (Media Query 768px)
   ============================================================ */
   
@media screen and (max-width: 768px) {
    /* 1. Manteniamo il rettangolo a destra (larghezza 60% per dare un po' più di respiro alle foto) */
    .rettangoloSfondo {
    width: 65% !important;
    margin-left: auto !important;
    padding: 40px 0;
    gap: 80px;
    }



    
   /* 1. Stack verticale: testo sopra, logo sotto */
   .contenitoreRettangoli {
    flex-direction: column !important; 
    align-items: center !important;
    gap: 30px; /* Spazio tra il blocco marrone e il logo */
    padding: 40px 20px !important;
}

/* 2. Il rettangolo marrone riprende la sua forma naturale */
.rettangoloMarrone {
    width: 100% !important; /* Occupa tutta la larghezza disponibile */
    max-width: 450px; /* Evita che diventi troppo largo su tablet piccoli */
    padding: 30px 20px !important;
    border-radius: 20px !important;
}

/* 3. Testo più leggibile e centrato */
.testoRettangoloSus {
    font-size: 1rem !important;
    line-height: 1.6 !important;
    text-align: center !important; /* Centrare il testo aiuta l'equilibrio mobile */
    margin: 0;
}

/* 4. Il logo (Toro) viene centrato sotto il testo */
.immagineToro {
    margin-top: 0 !important;
    display: flex;
    justify-content: center;
    width: 100%;
}

.fotoCiao {
    height: 120px !important; /* Dimensione bilanciata per lo schermo del telefono */
    width: auto;
    /* Rimuoviamo eventuali effetti di fusione se sporcano l'immagine */
    mix-blend-mode: normal !important; 
}




    .instagram, .facebook, .whatsapp, .messanger, .airbnb {
        background: var(--marrone-chiaro);
        width: 50px !important;
        height: 50px !important;
        border-radius: 50%;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    /* 2. Titoli: riduciamo la dimensione e regoliamo lo spostamento a sinistra */
    .titoloCasaDora, .titoloCasaDora2, .titoloCasaDora3, .titoloCasaDora4 {
    font-size: 1.4rem !important; /* Molto più piccolo per non farlo uscire dallo schermo */
    left: -50% !important; /* Spostamento ridotto per la larghezza mobile */
    top: 30px !important;
    color: var(--testo-scuro) !important;
    width: fit-content !important;
    white-space: normal; /* Permette di andare a capo se il nome è lungo */
    width: 120px; /* Limita la larghezza per non coprire le foto */
    }
    
    /* 3. Pulsanti: Fix per il ritaglio e dimensioni */
    .pulsanteWrapper, .pulsanteWrapper2, .pulsanteWrapper3, .pulsanteWrapper4 {
    left: -50% !important;
    top: 150px !important;
    }
    
    .pulsanteCasaDora, .pulsanteCasaDora2, .pulsanteCasaDora3, .pulsanteCasaDora4 {
    padding: 10px 20px !important; /* Padding ridotto */
    font-size: 0.8rem !important; /* Font più piccolo */
    width: auto !important; /* RESET: così non viene tagliato */
    height: auto !important; /* RESET: così non viene tagliato */
    }
    
    .pulsanteSfumato, .pulsanteSfumato2, .pulsanteSfumato3, .pulsanteSfumato4 {
    width: 100% !important;
    height: 100% !important;
    top: 5px !important;
    left: 5px !important;
    }
    
    /* 4. Foto: rimpicciolite per stare nel rettangolo granata senza sparire */
    .fotoStack {
    width: 100%;
    height: 250px; /* Altezza ridotta per il mobile */
    margin-top: 20px;
    margin-left: 40%;
    }
    
    .fotoAnimata, .fotoAnimataBallatoio {
    width: 140px !important; /* Dimensione ridotta per non coprire tutto */
    }
    
    .fotoAnimata:first-child, .fotoAnimataBallatoio:first-child {
    left: -30% !important; /* Esce meno rispetto al desktop */
    top: 0;
    }
    
    .fotoSovrapposta {
    top: 80px !important;
    left: 20px !important;
    }
    .testoCiao{
        font-size: 2rem;
    }
}
/*ciao
/* ============================================================
   IL MOTORE DELLE ANIMAZIONI (Pulito e Fluido)
   ============================================================ */

/* 1. Stato iniziale per tutti gli elementi con .animate-on-scroll */
.animate-on-scroll {
    opacity: 0;
    transform: translateY(30px); /* Parte leggermente più in basso */
    transition: opacity 1s ease-out, transform 1s ease-out;
    will-change: opacity, transform; /* Aiuta il browser a essere fluido */
}

/* 2. Stato quando l'elemento diventa visibile (attivato dal tuo JS) */
.animate-on-scroll.visible {
    opacity: 1;
    transform: translateY(0);
}

/* 3. Animazioni specifiche per le tue foto sovrapposte */
@keyframes slideInRight {
    from { opacity: 0; transform: translateX(50px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes slideInLeft {
    from { opacity: 0; transform: translateX(-50px); }
    to { opacity: 1; transform: translateX(0); }
}

/* Applichiamo animazioni diverse a seconda del tipo di oggetto */
.fotoTorino {
    animation: slideInLeft 1.5s ease-out forwards;
}

.testoRettangolo {
    margin-top: 140px;
    animation: slideInRight 1.5s ease-out forwards;
    animation-delay: 0.5s;
}

/* 4. Effetto "Ingresso" per le icone dei servizi */
.iconaCerchio {
    opacity: 0;
    transform: scale(0.5);
    transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.visible .iconaCerchio {
    opacity: 1;
    transform: scale(1);
}

/* Delay per le icone (una dopo l'altra) */
.servizio:nth-child(1) .iconaCerchio { transition-delay: 0.1s; }
.servizio:nth-child(2) .iconaCerchio { transition-delay: 0.3s; }
.servizio:nth-child(3) .iconaCerchio { transition-delay: 0.5s; }

/* 5. Fix per le foto sovrapposte di Casa Dora */
.fotoStack .fotoAnimata .fotoAnimataBallatoio{
    opacity: 0;
    transition: opacity 0.8s ease;
}
.fotoAnimata.visible  .fotoAnimataBallatoio.visible{ 
    opacity: 1;
    transform: translateY(0);
}
.visible .fotoSovrapposta {
    /* Mantiene lo spostamento che abbiamo deciso nel layout */
    transform: translate(40px, 40px) !important; 
    transition-delay: 0.4s;
}
/* ============================================================
   IL TUO MENU CON L'ANIMAZIONE RIPRISTINATA
   ============================================================ */

   .titoletti {
    display: flex;
    gap: 30px;
    align-items: center;
}

/* Selettore unico per tutti i contenitori dei link */
.appartamenti, .chiSiamo, .contattaci {
    position: relative; /* Necessario per posizionare la linea */
    cursor: pointer;
    padding: 5px 0; /* Spazio per la linea */
}

/* Le scritte vere e proprie */
.appartamentiTestoDora, 
.chiSiamoTestoDora, 
.contattaciTestoDora {
    font-family: 'Athene', serif;
    font-size: 1.2rem;
    color: var(--granata);
    margin: 0;
    display: inline-block;
}

/* Creiamo la "striscia" (stato iniziale: invisibile al centro) */
.appartamenti::after, 
.chiSiamo::after, 
.contattaci::after {
    content: '';
    position: absolute;
    left: 50%; /* Parte dal centro */
    bottom: 0;
    width: 0; /* Larghezza zero */
    height: 2px; /* Spessore della linea */
    background-color: var(--granata);
    transition: width 0.3s ease, left 0.3s ease; /* L'animazione fluida */
}

/* Quando passi sopra col mouse (Hover) */
.appartamenti:hover::after, 
.chiSiamo:hover::after, 
.contattaci:hover::after {
    width: 100%; /* Si allunga su tutta la parola */
    left: 0;     /* Si sposta a sinistra per coprire tutto */
}

/* --- FIX SMARTPHONE PER IL MENU --- */
@media screen and (max-width: 768px) {
    .titoletti {
        flex-direction: row; /* Li teniamo in riga */
        flex-wrap: wrap;     /* Se non ci stanno, vanno a capo */
        justify-content: center;
        gap: 15px;
        width: 100%;
    }
    
    .appartamentiTestoDora, 
    .chiSiamoTestoDora, 
    .contattaciTestoDora {
        font-size: 0.8rem !important; /* Scritte un po' più piccole su telefono */
    }
}

/* --- FIX SMARTPHONE PER IL MENU --- */
@media screen and (max-width: 768px) {
   

    .titoletti {
        flex-direction: row; /* Li teniamo in riga */
        flex-wrap: wrap;     /* Se non ci stanno, vanno a capo */
        justify-content: center;
        gap: 15px;
        width: 100%;
    }
    
    .appartamentiTestoDora, 
    .chiSiamoTestoDora, 
    .contattaciTestoDora {
        font-size: 1rem; /* Scritte un po' più piccole su telefono */
    }
}

/* --- LAYOUT POSIZIONAMENTO --- */
.contenitoreRettangoli {
    position: relative; /* Fondamentale per contenere i figli */
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 40px 20px;
}

.rettangoloMarrone {
    position: relative;
    background-color: var(--marrone-chiaro);
    padding: 40px;
    border-radius: 30px;
    max-width: 700px;
    z-index: 2; /* Sopra il grigio */
}
/* Animazione per il Rettangolo (da sinistra) */
.rettangoloMarrone.animate-on-scroll {
    opacity: 0;
    transform: translateX(-50px); /* Parte leggermente a sinistra */
    transition: all 1s ease-out;
}

/* Animazione per l'Immagine (da destra) */
.immagineToro.animate-on-scroll {
    opacity: 0;
    transform: translateX(50px); /* Parte leggermente a destra */
    transition: all 1s ease-out;
}

/* Quando diventano visibili (grazie al JavaScript) */
.rettangoloMarrone.animate-on-scroll.visible,
.immagineToro.animate-on-scroll.visible {
    opacity: 1;
    transform: translateX(0);
}

/*APPARTAMENTI CASA DORA*/
/* ============================================================
   LAYOUT PAGINA DETTAGLIO APPARTAMENTO (Casa Dora)
   ============================================================ */

/* 1. Header della pagina */
.rettangoloHomeDora {
    background-color: var(--granata);
    height: 150px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding-left: 10%;
    margin-top: 50px;
}

.testoRettangoloHomeDora {
    color: var(--beige-bg);
    font-size: 3rem;
    font-family: var(--font-principale);
    margin: 0;
}

/* 2. Il contenitore split (Testo a sinistra, Fascia Granata a destra) */
.bloccoDora {
    display: flex;
    position: relative;
    width: 100%;
}

/* Fascia granata verticale sulla destra */
.rettangoloPrincipaleDora {
    background-color: var(--granata);
    width: 40%; /* La fascia occupa il 40% a destra */
    position: absolute;
    right: 0;
    top: -140px;
    bottom: 0;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 50px;
    gap: 100px; /* Spazio tra le foto nella colonna */
}

/* Area del testo sulla sinistra */
.contenitoreTestoPaginaDoraPrimoBlocco {
    width: 60%; /* Il testo occupa il 60% a sinistra */
    padding: 100px 10% 100px 10%;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 250px; /* Allinea i blocchi di testo alle foto */
}

/* Stile dei paragrafi di testo */
.testoPaginaDoraPrimoBloccoFoto, 
.testoPaginaDoraSecondoBloccoFoto, 
.testoPaginaDoraTerzoBloccoFoto, 
.testoPaginaDoraQuartoBloccoFoto {
    font-size: 1.4rem;
    line-height: 1.8;
    color: var(--testo-scuro);
    margin: 0;
}

/* 3. Le Foto nella fascia granata */
.fotoAnimataPaginaDora,
.fotoAnimataPaginaAurora2, 
.fotoAnimataPaginaDora2, 
.fotoAnimataPaginaDora3, 
.fotoAnimataPaginaDora4, 
.fotoAnimataPaginaDora5, 
.fotoAnimataPaginaDora6,
.fotoAnimataPaginaDora6Vittoria {
    width: 240px;
    border-radius: 10px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.3);
    transition: all 0.8s ease-out;
    position: relative;
    z-index: 3;
}

/* Effetto sovrapposizione: alcune foto escono un po' a sinistra nel beige */
.fotoAnimataPaginaDora, .fotoAnimataPaginaDora3, .fotoAnimataPaginaDora5 {
    margin-left: -150px; /* Esce dalla fascia granata */
}

/* 4. Footer specifico della pagina appartamento */
.rettangoloFinaleDora {
    background-color: var(--granata);
    padding: 60px 10%;
    display: flex;
    flex-direction: column;
    align-items: center;
    color: var(--beige-bg);
}

.rettangoloFinaleDora .testoFinale {
    color: var(--beige-bg);
}

/* ============================================================
   RESPONSIVE PER MOBILE
   ============================================================ */
@media screen and (max-width: 768px) {
   

    .rettangoloPrincipaleDora {
        background-color: var(--granata);
        width: 40%; /* La fascia occupa il 40% a destra */
        position: absolute;
        right: 0;
        top: -100px;
        bottom: 0;
        z-index: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        padding-top: 50px;   
        padding: 40px 20px;
        gap:200px
    }

    .contenitoreTestoPaginaDoraPrimoBlocco {
        width: 50%;
        padding: 40px 20px;
        gap: 200px;
    }

 

    .testoRettangoloHomeDora {
        font-size: 1.4rem;
    }
    .testoPaginaDoraPrimoBloccoFoto, 
.testoPaginaDoraSecondoBloccoFoto, 
.testoPaginaDoraTerzoBloccoFoto, 
.testoPaginaDoraQuartoBloccoFoto {
    font-size: 0.8rem;
    line-height: 1.6;
    color: var(--testo-scuro);
    margin: 0;
}

}


/* ============================================================
   PAGINA CHI SIAMO - LAYOUT A STRISCIA
   ============================================================ */

/* 1. Header Titolo */
.rettangoloHomeChisiamo {
    background-color: var(--granata);
    height: 150px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 50px;
}

.testoRettangoloChiSiamo {
    color: var(--beige-bg);
    font-size: 3rem;
    margin: 0;
}

/* 2. La Striscia Centrale Granata */
.rettangoloPrincipaleChiSiamo {
    background-color: var(--granata);
    width: 500px; /* Larghezza della striscia verticale */
    margin: 0 auto; /* Centra la striscia nella pagina */
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    padding: 100px 0;
    gap: 120px; /* Spazio verticale tra i riquadri */
    min-height: 1500px;
}

/* 3. I Riquadri di Testo */
.rettangoloTestoChiSiamo, 
.rettangoloTestoChiSiamo2, 
.rettangoloTestoChiSiamo3,
.rettangoloTestoChiSiamo4 {
    background-color: var(--marrone-chiaro);
    width: 500px; /* Larghezza dei box di testo */
    padding: 40px;
    border-radius: 40px;
    position: relative;
    z-index: 2;
    box-shadow: 0 10px 30px rgba(0,0,0,0.2);
}

/* Posizionamento Alternato (Staggered) */

/* Box 1: Esce a Sinistra */
.rettangoloTestoChiSiamo {
    margin-right: 500px; /* Sposta il box a sinistra della striscia */
}

/* Box 2: Esce a Destra */
.rettangoloTestoChiSiamo2 {
    margin-left: 500px; /* Sposta il box a destra della striscia */
}

/* Box 3: Esce a Sinistra */
.rettangoloTestoChiSiamo3 {
    margin-right: 500px;
}
.rettangoloTestoChiSiamo4{
    margin-left: 500px;
}

/* Stile del testo interno */
.testoDentroRettangoloTestoChiSiamo {
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--testo-scuro);
    margin: 0;
}

/* --- FOOTER PAGINA CHI SIAMO --- */
.rettangoloFinaleDoraChiSiamo {
    background-color: var(--granata);
    padding: 80px 5%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-top: 0; /* Elimina spazi tra striscia e footer */
    position: relative;
    z-index: 5;
}

.rettangoloFinaleDoraChiSiamo .testoFinale {
    font-size: 1.5rem;
    color: var(--beige-bg);
    line-height: 1.6;
    margin-bottom: 40px;
}

.contenitoreFinaleDora {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

.instagram, .facebook, .whatsapp, .messanger, .airbnb {
    background: var(--marrone-chiaro);
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: transform 0.3s ease;
}

.instagram:hover { transform: scale(1.1); }

.instagramFoto, .facebookFoto, .whatsappFoto, .messangerFoto, .airbnbFoto {
    width: 35px;
    height: auto;
}
/* ============================================================
   RESPONSIVE PER MOBILE (Chi Siamo)
   ============================================================ */
@media screen and (max-width: 1024px) {
    /* Riduciamo lo spostamento per tablet */
    .rettangoloTestoChiSiamo { margin-right: 350px; width: 400px; }
    .rettangoloTestoChiSiamo2 { margin-left: 350px; width: 400px; }
    .rettangoloTestoChiSiamo3 { margin-right: 350px; width: 400px; }
    .rettangoloTestoChiSiamo4{margin-right: 350px; width: 400px;}
}

@media screen and (max-width: 768px) {
    /* Su mobile la striscia scompare o diventa lo sfondo */
    
    .rettangoloPrincipaleChiSiamo {
        width: 50%;
        padding: 40px 20px;
        gap: 40px;
    }
    .instagramFoto, .facebookFoto, .whatsappFoto, .messangerFoto, .airbnbFoto {
        width: 35px;
        height: auto;
    }
    .rettangoloTestoChiSiamo, 
    .rettangoloTestoChiSiamo2, 
    .rettangoloTestoChiSiamo3,
    .rettangoloTestoChiSiamo4 {
        width: 100%;
        border-radius: 20px;
        padding: 25px;
    }
    
    .testoRettangoloChiSiamo {
        font-size: 2rem;
    }
}
/* --- ANIMAZIONI CHI SIAMO --- */

/* Stato iniziale: Box che arrivano da sinistra */
.rettangoloTestoChiSiamo.animate-on-scroll,
.rettangoloTestoChiSiamo3.animate-on-scroll,
rettangoloTestoChiSiamo4.animate-on-scroll {
    opacity: 0;
    transform: translateX(-80px); /* Parte da sinistra */
    transition: all 1s ease-out;
}

/* Stato iniziale: Box che arriva da destra (il secondo) */
.rettangoloTestoChiSiamo2.animate-on-scroll {
    opacity: 0;
    transform: translateX(80px); /* Parte da destra */
    transition: all 1s ease-out;
}

/* Quando diventano visibili */
.rettangoloTestoChiSiamo.animate-on-scroll.visible,
.rettangoloTestoChiSiamo2.animate-on-scroll.visible,
.rettangoloTestoChiSiamo3.animate-on-scroll.visible ,
.rettangoloTestoChiSiamo4.animate-on-scroll.visible{
    opacity: 1;
    transform: translateX(0); /* Tornano in posizione */
}

/*rullino*/
/* --- LIGHTBOX MODERNA --- */
.lightbox {
    display: none; /* Nascosto di default */
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.9); /* Sfondo scuro */
    backdrop-filter: blur(8px); /* Effetto sfocato moderno */
    justify-content: center;
    align-items: center;
}

.lightbox.active {
    display: flex;
    animation: fadeIn 0.3s ease;
}

.lightbox-content {
    max-width: 80%;
    max-height: 80%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.lightbox-content img {
    max-width: 100%;
    max-height: 90vh;
    border-radius: 8px;
    box-shadow: 0 0 30px rgba(0,0,0,0.5);
    object-fit: contain;
}

/* Pulsanti di navigazione */
.close-lightbox, .prev-btn, .next-btn {
    position: absolute;
    color: white;
    font-size: 40px;
    cursor: pointer;
    background: none;
    border: none;
    transition: transform 0.2s ease;
    user-select: none;
}

.close-lightbox { top: 30px; right: 40px; font-weight: bold; }
.prev-btn { left: 30px; top: 50%; transform: translateY(-50%); }
.next-btn { right: 30px; top: 50%; transform: translateY(-50%); }

.close-lightbox:hover, .prev-btn:hover, .next-btn:hover {
    transform: scale(1.2);
    color: var(--marrone-chiaro);
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* Fix per le immagini cliccabili */
.rettangoloPrincipaleDora img {
    cursor: pointer;
}

/* --- ANIMAZIONE HOVER FOTO (Home e Appartamenti) --- */

/* Applichiamo la transizione a tutte le classi di foto che hai elencato */
.fotoAnimata, 
.fotoAnimataBallatoio, 
.fotoAnimataPaginaDora,
.fotoAnimataPaginaDora2,
.fotoAnimataPaginaDora3,
.fotoAnimataPaginaDora4,
.fotoAnimataPaginaDora5,
.fotoAnimataPaginaDora6 {
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), box-shadow 0.4s ease !important;
    cursor: pointer;
}

/* Effetto ingrandimento per le foto normali */
.fotoAnimata:hover, 
.fotoAnimataBallatoio:hover,
.fotoAnimataPaginaDora:hover,
.fotoAnimataPaginaDora2:hover,
.fotoAnimataPaginaDora3:hover,
.fotoAnimataPaginaDora4:hover,
.fotoAnimataPaginaDora5:hover,
.fotoAnimataPaginaAurora2:hover,
.fotoAnimataPaginaDora6Vittoria,
.fotoAnimataPaginaDora6:hover {
    transform: scale(1.05) !important; /* Si ingrandisce del 5% */
    z-index: 20 !important; /* Viene in primo piano rispetto alle altre */
    box-shadow: 0 15px 40px rgba(0,0,0,0.4) !important; /* Ombra più profonda */
}

/* Effetto specifico per le foto sovrapposte (mantiene lo spostamento laterale) */
.fotoStack .fotoSovrapposta:hover {
    /* Manteniamo il translate(40px, 40px) che avevi prima aggiungendo lo scale */
    transform: translate(40px, 40px) scale(1.05) !important;
}/* --- FIX LOGO DEFINITIVO SENZA ALONI --- */

.logoIvano {
    /* 1. Forza la fusione: elimina matematicamente i bianchi/chiari */
    mix-blend-mode: multiply; 
    
    /* 2. Filtro di pulizia: aumenta il contrasto per rendere i grigi chiari 
       totalmente trasparenti con il multiply */
    filter: contrast(1.1) brightness(1.05);

    background-color: transparent !important;
    display: block;
    transition: transform 0.3s ease, filter 0.3s ease;
    cursor: pointer;
    max-width: 100%;
}

.logoIvano:hover {
    transform: scale(1.1);
    /* ATTENZIONE: Se l'immagine ha ancora un bordo, il drop-shadow 
       lo evidenzierà. Se vedi ancora il rettangolo, commenta la riga sotto */
       filter: contrast(1.1) brightness(1.1) drop-shadow(0px 8px 15px rgba(0,0,0,0.1)); 
    }

.logo {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important; /* Rimuove eventuali ombre del contenitore */
}




/* --- NUOVO BLOCCO PRENOTAZIONE DIRETTA --- */

.contenitorePrenota {
    margin-top: 50px;
    display: flex;
    flex-direction: column;
    align-items: flex-start; /* Allineato al testo a sinistra */
    gap: 15px;
}

.messaggioMigliorPrezzo {
    font-family: var(--font-principale);
    font-size: 1.3rem;
    color: var(--granata);
    font-style: italic;
    margin: 0;
    opacity: 0.9;
    letter-spacing: 0.5px;
}

.pulsanteContattaci {
    background-color: var(--granata);
    color: var(--beige-bg);
    border: 2px solid var(--granata);
    padding: 16px 40px;
    font-size: 1.1rem;
    border-radius: 50px;
    text-decoration: none;
    font-family: var(--font-principale);
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    display: inline-block;
    box-shadow: 0 8px 20px rgba(91, 19, 19, 0.15);
}

.pulsanteContattaci:hover {
    background-color: transparent;
    color: var(--granata);
    transform: translateY(-5px);
    box-shadow: 0 12px 25px rgba(91, 19, 19, 0.25);
}

/* Fix per Mobile */
@media screen and (max-width: 768px) {
    .contenitorePrenota {
        align-items: center; /* Lo centriamo su smartphone */
        text-align: center;
    }
    
    .messaggioMigliorPrezzo {
        font-size: 0.9rem;
    }
    
    .pulsanteContattaci {
        padding: 12px 30px;
        font-size: 0.9rem;
    }
}



.footer-titolo {
    font-size: 1.8rem;
    margin-bottom: 10px;
    color: var(--beige-bg);
}

.footer-sottotitolo {
    font-size: 1.1rem;
    margin-bottom: 30px;
    opacity: 0.9;
}

.footer-contatti {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-bottom: 40px;
}

.contatto-item {
    color: var(--beige-bg);
    text-decoration: none;
    font-size: 1.2rem;
    transition: opacity 0.3s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.contatto-item:hover {
    opacity: 0.7;
}

.icona-footer {
    width: 20px;
    height: auto;
}

.whatsapp-float {
    position: fixed;
    width: 60px;
    height: 60px;
    bottom: 40px;
    right: 40px;
    background-color: #25d366;
    color: #FFF;
    border-radius: 50px;
    text-align: center;
    font-size: 30px;
    box-shadow: 2px 2px 10px rgba(0,0,0,0.2);
    z-index: 1000;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: transform 0.3s ease;
}

.whatsapp-float img {
    width: 35px;
}

.whatsapp-float:hover {
    transform: scale(1.1);
}

@media screen and (max-width: 768px) {
    .pulsantePrenota{
        font-size: 0.7rem;
        padding: 10px 30px;
    }
}

@media screen and (max-width: 768px) {
    /* 1. Riduciamo il gap: 200px era troppo per il mobile */
    .rettangoloPrincipaleDora {
        gap: 110px !important; /* Molto più compatto */
        padding-bottom: 80px !important; /* Dà spazio all'ultima foto prima del footer */
        top: -100px;
    }

    /* 2. Allineiamo il testo di conseguenza */
    .contenitoreTestoPaginaDoraPrimoBlocco {
        gap: 180px !important; /* Regola questo valore per allineare testo e foto */
        padding-bottom: 80px;
    }

    /* 3. Riduciamo lo spostamento delle foto sovrapposte */
    /* Se la foto scende di 80px, esce dal bordo: portiamola a 40px */
    .fotoSovrapposta {
        top: 40px !important; 
        left: 15px !important;
    }

    /* 4. Il trucco finale: diamo un'altezza minima al blocco */
    .bloccoDora {
        min-height: 1600px; /* Assicura che il granata non finisca prima delle foto */
    }
}






/* --- SEZIONE RECENSIONI --- */


.titoloRecensioni {
    font-size: 2.5rem;
    color: var(--granata);
    margin-bottom: 50px;
    font-family: var(--font-principale);
}

.contenitoreRecensioni {
    display: flex;
    justify-content: center;
    gap: 30px;
    flex-wrap: wrap; /* Per il mobile */
}

.recensioneCard {
    background-color: white;
    padding: 40px 30px;
    border-radius: 20px;
    flex: 1;
    min-width: 300px;
    max-width: 350px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.05);
    border-bottom: 4px solid var(--marrone-chiaro);
    transition: transform 0.3s ease;
}

.recensioneCard:hover {
    transform: translateY(-10px);
}

.stelle {
    color: #f1c40f; /* Giallo stelle */
    font-size: 1.2rem;
    margin-bottom: 20px;
}

.testoRecensione {
    font-size: 1rem;
    line-height: 1.6;
    color: var(--testo-scuro);
    font-style: italic;
    margin-bottom: 20px;
}

.autoreRecensione {
    font-weight: bold;
    color: var(--granata);
    font-size: 0.9rem;
}
.linkTutteRecensioni {
    margin-top: 60px;
    display: flex;
    justify-content: center; /* Centratura perfetta */
}

.linkTutteRecensioni a {
    color: var(--granata);
    text-decoration: none;
    font-weight: bold;
    font-family: var(--font-principale);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    font-size: 0.9rem;
    padding: 12px 30px;
    border: 1px solid var(--granata);
    border-radius: 50px;
    transition: all 0.3s ease;
}

.linkTutteRecensioni a:hover {
    background-color: var(--granata);
    color: var(--beige-bg);
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(91, 19, 19, 0.2);
}

/* Fix Mobile */
@media screen and (max-width: 768px) {
    .titoloRecensioni { font-size: 1.8rem; }
    .recensioneCard { max-width: 100%; }
}



.sezioneRecensioni {
    position: relative; /* Necessario per posizionare la curva */
    padding-bottom: 150px !important; /* Spazio extra per la curva */
    overflow: hidden;
}

.divisore-curvo {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
    transform: rotate(180deg); /* La giriamo per farla scendere verso il basso */
}

.divisore-curvo svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 100px; /* Altezza della curva */
}

.divisore-curvo .shape-fill {
    fill: var(--granata); /* Lo stesso colore del footer! */
}

/* EFFETTO OVERLAP: Facciamo galleggiare le card sulla curva */
.contenitoreRecensioni {
    position: relative;
    z-index: 5;
    margin-bottom: -50px; /* Le card "entrano" visivamente nella zona della curva */
}




.slider-container {
    position: relative;
    display: flex;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 50px;
}

.slider-wrapper {
    overflow: hidden; /* Nasconde le card che "escono" */
    width: 100%;
}

.contenitoreRecensioni-track {
    display: flex;
    gap: 30px;
    transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    padding: 20px 0;
}

.slider-btn {
    background: none;
    border: none;
    font-size: 2.5rem;
    color: var(--granata);
    cursor: pointer;
    position: absolute;
    z-index: 10;
    transition: transform 0.2s;
}

.slider-btn.prev { left: 0; }
.slider-btn.next { right: 0; }

.slider-btn:hover { transform: scale(1.2); }

/* Le card ora hanno una larghezza fissa nello slider */
.recensioneCard {
    min-width: calc(33.333% - 20px); /* 3 card per riga su PC */
    flex-shrink: 0;
}

@media screen and (max-width: 1024px) {
    .recensioneCard { min-width: calc(50% - 15px); } /* 2 card su tablet */
}

@media screen and (max-width: 768px) {
    .recensioneCard { min-width: 100%; } /* 1 card su smartphone */
    .slider-container { padding: 0 30px; }
}
@media screen and (max-width: 768px) {
    /* 1. Riduciamo il padding laterale per dare più spazio alle card */
    .slider-container {
        padding: 0 40px !important;
    }

    /* 2. Rendiamo le card belle grandi e leggibili */
    .recensioneCard {
        min-width: 100% !important; /* Una sola card alla volta */
        padding: 30px 20px !important; /* Più respiro interno */
        margin-bottom: 10px;
    }

    /* 3. Piccoli aggiustamenti alle frecce su mobile */
    .slider-btn {
        font-size: 2rem !important; /* Leggermente più piccole per non ingombrare */
    }

    .slider-btn.prev { left: 5px !important; }
    .slider-btn.next { right: 5px !important; }

    /* 4. Il titolo della sezione più armonioso */
    .titoloRecensioni {
        font-size: 1.8rem !important;
        margin-bottom: 30px !important;
    }
}


/* --- FIX GLOBALE --- */
html, body {
    overflow-x: hidden; /* Impedisce alla pagina di scivolare lateralmente */
    width: 100%;
}

/* --- FIX RECENSIONI MOBILE --- */
@media screen and (max-width: 768px) {
    .sezioneRecensioni {
        width: 100vw !important; /* Forza a tutta larghezza */
        margin-left: 0 !important;
        padding-left: 5% !important;
        padding-right: 5% !important;
    }

    /* FIX BOTTONE: Se la scritta è troppo lunga, la mandiamo a capo */
    .linkTutteRecensioni a {
        font-size: 0.8rem !important; 
        padding: 10px 20px !important;
        display: inline-block;
        white-space: normal !important; /* Fondamentale per non spingere la pagina */
        max-width: 90%; 
        line-height: 1.4;
        text-align: center;
    }

    /* Riduciamo leggermente l'altezza della curva su mobile per non coprire il footer */
    .divisore-curvo svg {
        height: 60px !important;
    }
}



/* --- BOTTONE MAPPA CHI SIAMO --- */
.contenitoreMappaChiSiamo {
    margin-top: 30px;
    display: flex;
    justify-content: flex-start; /* Lo allinea a sinistra sotto il testo */
}

.pulsanteMappa {
    background-color: var(--granata);
    color: var(--beige-bg);
    border: 2px solid var(--granata);
    padding: 12px 30px;
    font-size: 1rem;
    border-radius: 50px;
    text-decoration: none;
    font-family: var(--font-principale);
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: all 0.4s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px; /* Spazio tra il pin 📍 e il testo */
    box-shadow: 0 5px 15px rgba(91, 19, 19, 0.1);
}

.pulsanteMappa:hover {
    background-color: transparent;
    color: var(--granata);
    transform: translateY(-3px);
    box-shadow: 0 10px 20px rgba(91, 19, 19, 0.2);
}

/* Centratura perfetta su smartphone */
@media screen and (max-width: 768px) {
    .contenitoreMappaChiSiamo {
        justify-content: center;
    }
}

.mappaContenitore {
    width: 100%;
    max-width: 800px; /* Stessa larghezza dei tuoi riquadri di testo */
    margin: 60px auto 0 auto; /* Spazio dal testo sopra */
    border-radius: 30px; /* Angoli belli curvi come il resto del sito */
    overflow: hidden; /* Taglia via gli angoli quadrati di Google Maps */
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.2);
    border: 4px solid var(--marrone-chiaro); /* La incorniciamo con il tuo colore */
    background-color: var(--marrone-chiaro);
    z-index: 2;
    position: relative;
}

.mappaContenitore iframe {
    display: block; /* Toglie lo spazietto bianco fastidioso sotto le immagini/iframe */
    width: 100%;
}

/* Fix per Mobile: la rendiamo un po' più bassa per non occupare tutto lo schermo */
@media screen and (max-width: 768px) {
    .mappaContenitore {
        width: 90%;
        border-radius: 20px;
        margin-top: 40px;
    }
    
    .mappaContenitore iframe {
        height: 300px; 
    }
}

@media screen and (max-width: 768px) {
    /* 1. Il contenitore principale torna a tutta larghezza e si svuota della "striscia" fissa */
    .rettangoloPrincipaleChiSiamo {
        width: 50% !important;
        padding: 40px 5% !important; /* Padding laterale percentuale per non toccare i bordi */
        gap: 30px !important; /* Spazio ridotto tra i box */
        min-height: auto !important;
    }

   /* 2. I box di testo mantengono l'effetto sfalsato ma proporzionato per mobile */
   .rettangoloTestoChiSiamo, 
   .rettangoloTestoChiSiamo2, 
   .rettangoloTestoChiSiamo3 {
       width: 100% !important;
       max-width: 100% !important;
       border-radius: 20px !important;
       padding: 25px 20px !important;
       box-sizing: border-box !important;
       margin: 0 !important; /* Resettiamo eventuali margini vecchi */
   }

   /* Primo: un pelino a sinistra */
   .rettangoloTestoChiSiamo {
       transform: translateX(-95px) !important;
   }

   /* Secondo: un pelino a destra */
   .rettangoloTestoChiSiamo2 {
       transform: translateX(95px) !important;
   }

   /* Terzo: un pelino a destra (come richiesto) */
   .rettangoloTestoChiSiamo3 {
       transform: translateX(5px) !important;
   }
    /* 3. Adeguiamo il testo interno per renderlo leggibile su schermi piccoli */
    .testoDentroRettangoloTestoChiSiamo {
        font-size: 0.7rem !important;
        line-height: 1.5 !important;
        text-align: center; /* Centrare il testo su mobile di solito aiuta l'equilibrio */
    }
    
    .testoRettangoloChiSiamo {
        font-size: 2rem !important;
    }

    /* 4. Fix del pulsante Mappa per non farlo uscire */
    .contenitoreMappaChiSiamo {
        justify-content: center !important;
        width: 100%;
    }

    .pulsanteMappa {
        font-size: 0.8rem !important;
        padding: 10px 20px !important;
        white-space: normal !important;
        text-align: center;
    }

    /* 5. Fix della mappetta per non toccare i bordi */
    .mappaContenitore {
        width: 100% !important;
        margin: 40px 0 0 0 !important;
        border-radius: 20px !important;
    }
}