/* Aggiungiamo qui eventuali stili personalizzati che potrebbero essere necessari */
html {
    font-family: 'Inter', sans-serif;
}
body {
    overflow-x: hidden; 
}
html, body {
    font-family: 'Inter', sans-serif;
}
body.modal-open {
    overflow: hidden;
}
#main-title, .font-brand {
    font-family: "all-round-gothic", sans-serif;
}
.font-inter {
    font-family: 'Inter', sans-serif;
}
.smooth-transition {
    transition: all 0.3s ease-in-out;
}
.lang-active {
    font-weight: 700;
    color: var(--color-text-primary); /* Utilizza il colore del testo primario del tema */
}

/* Nuova classe per aurea/kleomene nel menu mobile */
.font-brand-black {
    font-family: "all-round-gothic", sans-serif;
    color: #000000; /* Colore nero */
    font-size: 1.25rem; /* Raddoppia la dimensione del testo, equivalente a 36px */
}

/* Assicurati che in modalità dark il colore sia comunque leggibile */
html.dark .font-brand-black {
    color: var(--color-text-primary); /* Assicurati che sia leggibile in dark mode */
}

/* Stili per l'effetto Ripple */
.ripple-container {
    position: relative; /* Necessario per posizionare il ripple */
    overflow: hidden; /* Nasconde il ripple oltre i bordi del pulsante */
    transform: translate3d(0, 0, 0); /* Forza l'accelerazione hardware per animazioni più fluide */
}

.ripple-effect {
    display: block;
    position: absolute;
    background: var(--color-ripple-effect); /* Ora usa la variabile dinamica */
    border-radius: 50%;
    transform: scale(0);
    animation: ripple-animation 0.4s linear; /* Durata e tipo di animazione */
}

@keyframes ripple-animation {
    to {
        transform: scale(2.5); /* Scala il ripple per coprire il pulsante */
        opacity: 0; /* Scompare gradualmente */
    }
}

/* Modifiche per la modalità dark */
html.dark {
    --color-primary-bg: #202124; /* Sfondo principale, come da screenshot */
    --color-secondary-bg: #2a2a2a; /* Sfondo elementi secondari (es. card, form) */
    --color-text-primary: #ffffff; /* Testo principale bianco */
    --color-text-secondary: #a0a0a0; /* Testo secondario/descrittivo */
    --color-border: #444444; /* Bordi */
    --color-link-hover: #ffffff; /* Colore link al hover bianco */
    --color-button-bg: #3a3a3a; /* Sfondo bottoni, più scuro per contrasto */
    --color-button-text: #ffffff; /* Testo bottoni bianco */
    --color-button-hover-bg: #555555; /* Sfondo bottoni al hover */
    --color-input-bg: #333333; /* Sfondo input */
    --color-input-border: #555555; /* Bordo input */
    --color-error-bg: #4b0000; /* Sfondo errore */
    --color-error-text: #ff8080; /* Testo errore */
    --color-success-bg: #0a4b0a; /* Sfondo successo */
    --color-success-text: #80ff80; /* Testo successo */
    --color-ripple-effect: rgba(255, 255, 255, 0.4); /* Ripple chiaro su sfondo scuro */
}

html:not(.dark) {
--color-primary-bg: #ffffff;   /* CORREZIONE: Ripristinato a bianco */
--color-secondary-bg: #e5e7eb;
--color-text-primary: #111827;
--color-text-secondary: #6b7280;
--color-border: #d1d5db;
--color-link-hover: #111827; /* CORREZIONE: Impostato a nero per l'hover in light mode */
--color-button-bg: #ffffff;
--color-button-text: #111827;
--color-button-hover-bg: #f3f4f6;
--color-input-bg: #ffffff;
--color-input-border: #d1d5db;
--color-error-bg: #fee2e2;
--color-error-text: #ef4444;
--color-success-bg: #d1fae5;
--color-success-text: #059669;
--color-ripple-effect: rgba(0, 0, 0, 0.4); /* Ripple scuro su sfondo chiaro */
}

body {
    background-color: var(--color-primary-bg);
    color: var(--color-text-primary);
}

/* NOTA: Regola modificata per ridurre l'altezza di input e select */
.form-input, .form-select {
    width: 100%;
    padding-top: 0.25rem;    /* Spessore verticale ulteriormente ridotto (equivale a py-1) */
    padding-bottom: 0.25rem; /* Spessore verticale ulteriormente ridotto (equivale a py-1) */
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    border: 0px solid var(--color-input-border);
    border-radius: 0.5rem;
    background-color: var(--color-input-bg);
    transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
/* NOTA: Nuova regola per mantenere l'altezza originale del solo textarea */
.form-textarea {
    width: 100%;
    padding-top: 0.5rem;    /* Padding originale mantenuto */
    padding-bottom: 0.5rem; /* Padding originale mantenuto */
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    border: 0px solid var(--color-input-border);
    border-radius: 0.5rem;
    background-color: var(--color-input-bg);
    transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.4);
}
.form-input.border-red-500, .form-select.border-red-500, .form-textarea.border-red-500 {
    border-color: #ef4444;
}
.form-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23a0a0a0' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 2.5rem;
}
.modal-base {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color-secondary-bg); /* Sfondo pieno */
    z-index: 1000;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}
.modal-base:not(.open) {
    z-index: -1;
}
.modal-base.open {
    opacity: 1;
    visibility: visible;
}
.gallery-content {
width: 90%;
max-width: 900px; /* Larghezza massima della galleria */
height: 80%; /* Altezza della galleria rispetto allo schermo */
background-color: transparent;
display: flex; /* Fondamentale per disporre le immagini in riga */
overflow-x: auto; /* Abilita lo scorrimento orizzontale */
scroll-snap-type: x mandatory; /* Fa sì che lo scorrimento si "agganci" a un'immagine */
}

.gallery-content::-webkit-scrollbar {
display: none; /* Nasconde la barra di scorrimento per un look più pulito */
}


.modal-nav.prev { left: 20px; }
.modal-nav.next { right: 20px; }

.gallery-nav {
    top: 50%;
    font-size: 2.5rem;
}

.gallery-counter {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    color: var(--color-text-primary); /* Colore contatore galleria */
    font-size: 1rem;
    background-color: var(--color-secondary-bg); /* Sfondo contatore galleria */
    padding: 5px 15px;
    border-radius: 5px;
}
.clickable-title, .clickable-image {
    cursor: pointer;
}
.clickable-title {
    display: inline-block;
    transition: color 0.2s ease;
}
.clickable-title:hover {
    color: var(--color-link-hover);
}
.clickable-image > img {
    transition: transform 0.3s ease;
}
.clickable-image:hover > img {
    transform: scale(1.05);
}
#itinerary-result, #itinerary-result * {
    color: var(--color-text-primary); /* Testo itinerario */
}
#itinerary-result h3 {
    font-size: 1.5rem;
    font-weight: bold;
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
}
#itinerary-result h4 {
    font-size: 1.2rem;
    font-weight: bold;
    margin-top: 1rem;
    margin-bottom: 0.5rem;
}
 #itinerary-result ul {
    list-style-type: disc;
    margin-left: 1.5rem;
    margin-bottom: 1rem;
}
.calendar-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 95%;
    max-width: 400px;
    overflow: hidden; /* Aggiunto */
}
.calendar-content {
    width: 100%;
    color: var(--color-text-primary); /* Testo calendario */
    border: 1px solid var(--color-border); /* Bordo calendario */
    margin-top: 1rem;
    border-radius: 0.5rem;
    background-color: var(--color-secondary-bg); /* Sfondo calendario */
    overflow: hidden; /* Aggiunto */
}
.calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    color: var(--color-text-primary); /* Testo header calendario */
}
.calendar-header button {
    display: none; /* Modificato */
}
.calendar-header h3 {
    flex-grow: 1;
    text-align: center;
}
/* Stili per lo scroll orizzontale */
.calendar-months-wrapper {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; /* Abilita lo scorrimento inerziale su iOS */
    scroll-behavior: smooth;
}
/* Nasconde la barra di scorrimento */
.calendar-months-wrapper::-webkit-scrollbar {
    display: none;
}
.calendar-months-wrapper {
    scrollbar-width: none; /* Per Firefox */
}
.calendar-month-instance {
    flex: 0 0 100%;
    scroll-snap-align: center;
    width: 100%;
}
.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    padding: 1rem;
}
.calendar-day, .calendar-dow {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 40px;
    text-align: center;
}
.calendar-dow {
    font-weight: bold;
}
.calendar-day.unavailable {
    text-decoration: line-through;
    color: var(--color-text-secondary); /* Testo giorni non disponibili */
    cursor: not-allowed;
    background-color: var(--color-secondary-bg); /* Sfondo giorni non disponibili */
}
 .calendar-day.other-month {
    color: var(--color-text-secondary);
}

.review-content {
    width: 90%;
    max-width: 600px;
    height: 90%; /* Ulteriormente aumentato per maggiore ampiezza verticale */
    max-height: 90vh; /* Ulteriormente aumentato e reso relativo per migliore adattabilità */
    display: flex;
    flex-direction: column;
    padding: 2rem;
    overflow: hidden;
    background-color: var(--color-secondary-bg); /* Sfondo contenuto recensione */
}
.reviews-container {
    flex: 1 1 0; /* <-- ATTO DI CORREZIONE */
    overflow-y: auto;
    position: relative;
    padding-right: 1rem;
    max-height: calc(100vh - 200px); /* NUOVA RIGA AGGIUNTA */
}
.review-slide {
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--color-border);
}
.review-slide:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}
.review-slide p {
    font-style: italic;
    color: var(--color-text-primary);
    text-align: center; /* Stile lapidario: testo giustificato al centro */
}
.reviews-container::-webkit-scrollbar { width: 8px; }
.reviews-container::-webkit-scrollbar-track { background: var(--color-secondary-bg); border-radius: 10px; }
.reviews-container::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: 10px; }
.reviews-container::-webkit-scrollbar-thumb:hover { background: var(--color-text-secondary); }

/* Regole per il logo dinamico in base al tema */
#header-logo {
    /* Aggiunge una transizione sull'opacità per un effetto di dissolvenza.
       L'attributo 'src' di un'immagine non è direttamente animabile tramite CSS. */
    transition: opacity 0.3s ease-in-out;
}

/* Questa regola CSS per html.dark #header-logo non è più necessaria,
   poiché la gestione dell'attributo 'src' è ora affidata a JavaScript. */
/* html.dark #header-logo {
    content: url('logo-home-ortigia-siracusa.white.png');
} */
/* Stili per l'icona dinamica */
.light-mode-icon circle,
.dark-mode-icon circle {
transition: fill 0.3s ease, stroke 0.3s ease; /* Transizione per colori */
}

/* Quando il tema è dark */
html.dark .light-mode-icon circle {
    fill: var(--color-text-primary); /* Il pallino "light" è scuro in modalità dark */
    stroke: none; /* Rimuove il bordo per il pallino "light" in modalità dark */
}

html.dark .dark-mode-icon circle {
    fill: var(--color-primary-bg); /* Il pallino "dark" è bianco/chiaro in modalità dark */
    stroke: var(--color-text-primary); /* Bordo del pallino "dark" in modalità dark */
}

/* Quando il tema è light */
html:not(.dark) .light-mode-icon circle {
    fill: var(--color-primary-bg); /* Il pallino "light" è bianco/chiaro in modalità light */
    stroke: var(--color-text-primary); /* Bordo del pallino "light" in modalità light */
}

html:not(.dark) .dark-mode-icon circle {
    fill: var(--color-text-primary); /* Il pallino "dark" è scuro in modalità light */
    stroke: none; /* Rimuove il bordo per il pallino "dark" in modalità light */
}


/* Colori specifici per i link del menu desktop in modalità light */
html:not(.dark) #main-menu-container .main-menu-item {
color: var(--color-text-primary); /* Testo nero in Light Mode */
}

html:not(.dark) #main-menu-container .main-menu-item:hover {
    color: #111827; /* Nero al passaggio del mouse per i link del menu desktop */
}

/* Stili per i Dropdown Menu (mobile e lingua) per transizioni fluide */
#main-menu-dropdown, #lang-menu-dropdown {
    transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}

/* --- BLOCCO EMENDATO PER TRANSIZIONE LOGO SU APERTURA PAGINA --- */

/* 1. Stato iniziale del logo: completamente trasparente. */
#header-logo {
    opacity: 0;
    /* 2. Definizione della transizione: durata 3 secondi sulla proprietà 'opacity'.
       La curva di timing è la stessa della hero-section per una perfetta sincronia. */
    transition: opacity 5.0s cubic-bezier(0.165, 0.84, 0.44, 1);
    will-change: opacity;
}

/* 3. Stato finale del logo, attivato via JavaScript. */
#header-logo.logo-visible {
    opacity: 1;
}

/* --- FINE BLOCCO EMENDATO --- */

/* Filtro per colorare il logo (nero) con la cromia di Aurea */
.logo-color-aurea {
filter: invert(83%) sepia(26%) saturate(1217%) hue-rotate(345deg) brightness(88%) contrast(90%);
}

/* Filtro per colorare il logo (nero) con la cromia di Kleomene */
.logo-color-kleomene {
filter: invert(52%) sepia(51%) saturate(464%) hue-rotate(356deg) brightness(91%) contrast(88%);
}

/* Filtro per colorare il logo (bianco) con la cromia di Aurea in tema scuro */
html.dark .logo-color-aurea {
/* Converte il bianco in nero, poi applica il filtro colore */
filter: brightness(0) invert(83%) sepia(26%) saturate(1217%) hue-rotate(345deg) brightness(88%) contrast(90%);
}

/* Filtro per colorare il logo (bianco) con la cromia di Kleomene in tema scuro */
html.dark .logo-color-kleomene {
/* Converte il bianco in nero, poi applica il filtro colore */
filter: brightness(0) invert(52%) sepia(51%) saturate(464%) hue-rotate(356deg) brightness(91%) contrast(88%);
}
/* --- INIZIO BLOCCO NORME PER TRANSIZIONE LOGO SU "ORTIGIA" --- */

/* Filtro per trasformare il logo (nero) in bianco in tema light */
.logo-color-ortigia {
    filter: brightness(0) invert(1);
}

/* Filtro per trasformare il logo (bianco) in nero in tema dark */
html.dark .logo-color-ortigia {
    filter: brightness(0);
}

/* --- FINE BLOCCO NORME --- */
.info-hub-fullscreen {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: 900;
background-color: var(--color-primary-bg);
overflow-y: auto;
padding-top: 100px;
padding-bottom: 2rem;
}
.submenu, .content-card {
max-height: calc(100vh - 180px); /* Altezza massima calcolata dinamicamente */
overflow-y: auto; /* Abilita lo scroll verticale interno */
overscroll-behavior-y: contain; /* Impedisce la propagazione dello scroll alla pagina */
}
/* === INIZIO BLOCCO CODICE PER SCROLL REVEAL === */
.reveal-on-scroll {
    opacity: 0;
    transform: translateY(80px); /* Allineato a hero-initial-state */
    transition: transform 3.0s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 3.0s cubic-bezier(0.165, 0.84, 0.44, 1); /* Allineato a hero-initial-state */
    will-change: opacity, transform;
}

.reveal-on-scroll.visible {
opacity: 1;
transform: translateY(0); /* L'elemento torna alla sua posizione originale */
}
/* === NUOVA CLASSE PER L'EFFETTO DA DESTRA === */ .reveal-from-right {
opacity: 0;
transform: translateX(30vw);
transition: opacity 1.2s cubic-bezier(0.25, 0.1, 0.25, 1.0),
transform 1.2s cubic-bezier(0.25, 0.1, 0.25, 1.0); will-change: opacity, transform;
}
.reveal-from-right.visible { opacity: 1;
         transform: translateX(0);
     }
/* === NUOVA CLASSE PER L'EFFETTO DA SINISTRA === */ .reveal-from-left {
opacity: 0;
transform: translateX(-30vw);
transition: opacity 1.2s cubic-bezier(0.25, 0.1, 0.25, 1.0),
transform 1.2s cubic-bezier(0.25, 0.1, 0.25, 1.0); will-change: opacity, transform;
}
.reveal-from-left.visible { opacity: 1;
         transform: translateX(0);
     }

/* === NUOVA CLASSE PER L'EFFETTO DA DESTRA === */
.reveal-from-right {
    opacity: 0;
    transform: translateX(30vw); 
    transition: opacity 1.2s cubic-bezier(0.25, 0.1, 0.25, 1.0), 
                transform 1.2s cubic-bezier(0.25, 0.1, 0.25, 1.0);
    will-change: opacity, transform;
}

.reveal-from-right.visible {
    opacity: 1;
    transform: translateX(0);
}

/* === NUOVA CLASSE PER L'EFFETTO DA SINISTRA === */
.reveal-from-left {
    opacity: 0;
    transform: translateX(-30vw); 
    transition: opacity 1.2s cubic-bezier(0.25, 0.1, 0.25, 1.0), 
                transform 1.2s cubic-bezier(0.25, 0.1, 0.25, 1.0);
    will-change: opacity, transform;
}

.reveal-from-left.visible {
    opacity: 1;
    transform: translateX(0);
}
@media (max-width: 639.98px) {
    footer p {
        font-size: 0.75rem; /* Equivalente alla classe `text-xs` di Tailwind CSS */
        line-height: 1rem;  /* Aggiustamento dell'interlinea per coerenza */
    }
}

/* --- INIZIO BLOCCO EFFETTO HOVER PERSONALIZZATO PER PULSANTI (SOLUZIONE DEFINITIVA) --- */

/* Selettore unificato per tutti i pulsanti customizzati.
   Questa regola imposta lo stato di base e la transizione, centralizzando lo stile.
*/
.custom-btn {
    background-color: var(--color-secondary-bg);
    color: var(--color-button-text);
    /* Dichiarazione della transizione per le proprietà che cambieranno. */
    transition: background-color 0.3s ease-in-out, font-weight 0.3s ease-in-out, color 0.3s ease-in-out;
}

/* --- Regola Hover per TEMA LIGHT --- */
html:not(.dark) .custom-btn:hover {
    background-color: var(--color-primary-bg); /* Lo sfondo del pulsante si uniforma a quello della pagina (bianco) */
    color: var(--color-text-primary); /* Il testo diventa nero per mantenere la leggibilità */
}

/* --- Regola Hover per TEMA DARK --- */
html.dark .custom-btn:hover {
    background-color: var(--color-primary-bg); /* Lo sfondo del pulsante si uniforma a quello della pagina (grigio scuro) */
    color: var(--color-text-primary); /* Il testo resta bianco per mantenere la leggibilità */
}

/* Media Query per applicare l'effetto di grassetto solo su schermi di dimensioni desktop.
   Il breakpoint a 768px corrisponde allo standard 'md' di Tailwind CSS.
*/
@media (min-width: 768px) {
    .custom-btn:hover {
        font-weight: 700; /* Applica il grassetto al testo */
    }

/* --- FINE BLOCCO EFFETTO HOVER --- */
}

/* --- INTERVENTO DI FORZATURA DEL RENDERING PER STONDATURA IMMAGINI --- */
/*
  Questa soluzione utilizza proprietà avanzate per creare un nuovo contesto di
  stacking e un nuovo layer di rendering per il contenitore dell'immagine.
  Questo atto forza il browser a ricalcolare e ad applicare correttamente
  le proprietà di `overflow` e `border-radius`, risolvendo i bug di rendering
  che possono verificarsi in layout complessi come Flexbox.
*/
.gallery-modal .gallery-content > div {
    /* Crea un nuovo contesto di stacking per isolare l'elemento. */
    isolation: isolate;
    
    /* Forza la maschera di ritaglio con la massima priorità. */
    overflow: hidden !important;
    border-radius: 0.75rem !important;
    
    /* "Hack" per promuovere l'elemento a un nuovo layer di rendering sulla GPU. */
    transform: translateZ(0);
}

/* Regola ridondante sull'immagine per massima compatibilità. */
.gallery-modal .gallery-content img {
    border-radius: 0.75rem !important;
}
/* --- INIZIO BLOCCO NORME PER TRANSIZIONE HERO SECTION --- */

/*
  Stato Iniziale:
  - Sposta il contenitore di 40 pixel verso il basso.
  - Lo rende completamente trasparente.
  - Prepara le proprietà 'transform' e 'opacity' per una transizione.
*/
.hero-initial-state {
    transform: translateY(80px);
    opacity: 0;
    transition: transform 3.0s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 3.0s cubic-bezier(0.165, 0.84, 0.44, 1);
    will-change: transform, opacity;
}

/*
  Stato Finale:
  - Riporta il contenitore alla sua posizione originale (nessuna traslazione).
  - Lo rende completamente opaco.
*/
.hero-final-state {
    transform: translateY(0);
    opacity: 1;
}

/* --- FINE BLOCCO NORME --- */
