.baumans-regular {
  font-family: "Baumans", system-ui;
  font-weight: 400;
  font-style: normal;
}

/* Stile generale del body e font */
html, body {
  margin: 0; /* Rimuove margini di default */
  font-family: 'Baumans', sans-serif; /* Usa font Baumans importato */
  background-color: #ffffff; /* Sfondo bianco */
  color: #333333; /* Colore testo grigio scuro */
  height: 100%;
  padding: 0;
}

.page-wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh; /* altezza minima = altezza viewport */
}

/* Contenitore centrale per logo e icone */
.container {
  max-width: 1100px; /* Larghezza massima contenuto */
  margin: 0 auto; /* Centra orizzontalmente */
  padding: 0 0; /* Padding laterale */
  display: flex; /* Disposizione elementi in orizzontale */
  justify-content: space-between; /* Spazio tra logo e icone */
  align-items: center; /* Allinea verticalmente */
}

/* Header superiore con sfondo e bordi */
.site-header {
  background-color: #32938D; /* Verde */
  padding: 15px 0; /* Spazio verticale */
  width: 100%; /* Occupa tutta la larghezza */
  border-bottom: 5px solid #E89C09; /* Riga gialla sotto header */
  position: sticky;
  top: 0;
  z-index: 100; /* Assicura che resti sopra gli altri elementi */
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); /* Optional: effetto ombra */
}

/* --------------------------- */
/* ---------- Logo  ---------- */
/* --------------------------- */

.logo img {
  height: 80px;
}

/* --------------------------------------------------------------- */
/* ---------- Sezione icone (soocial + ricerca + menu)  ---------- */
/* --------------------------------------------------------------- */

.header-icons {
  display: flex;
  align-items: center;
}

/* ----------------------------------- */
/* ---------- Icone social  ---------- */
/* ----------------------------------- */

.social {
  display: flex;
  gap: 10px; /* Spaziatura tra icone */
  align-items: center;
}

/* Dimensione e stile icone social */
.social img {
  width: 30px;
  height: 30px;
  display: block;
  cursor: pointer;
  transition: filter 0.5s ease-in-out, transform 0.5s ease-in-out;
}

.social img:hover {
  filter: brightness(0) saturate(100%) invert(70%) sepia(25%) saturate(6110%) hue-rotate(5deg) brightness(99%) contrast(93%);
  transform: scale(1.2);
}

/* Margine a destra tra social e ricerca */
.header-icons > .social {
  margin-right: 50px;
}

/* Margine a destra tra ricerca e menu */
.header-icons > #search-button {
  margin-right: 50px;
}

/* --------------------------------------------- */
/* ---------- Bottoni ricerca e menu  ---------- */
/* --------------------------------------------- */

#search-button {
    background: none; /* Nessun background */
    border: none; /* Nessun bordo */
    padding: 0; /* Azzerato */
    margin: 0; /* Azzerato */
    cursor: pointer; /* Cursore a mano */
    display: flex;
    align-items: center;
    justify-content: center; /* Centra icona */
    width: 30px;
    height: 30px;
    overflow: hidden;
    position: relative; /* Per z-index */
}

#menu-toggle {
    background: none; /* Nessun background */
    border: none; /* Nessun bordo */
    padding: 0; /* Azzerato */
    margin: 0; /* Azzerato */
    cursor: pointer; /* Cursore a mano */
    display: flex;
    align-items: center;
    justify-content: center; /* Centra icona */
    width: 30px;
    height: 30px;
    z-index: 10000; /* Sopra la sidebar */
    position: relative; /* Per z-index */
    transform: translateZ(0); /* AGGIUNGI QUESTA RIGA */
}

/* Icone dentro i bottoni */
#search-button img,
#menu-toggle img {
    width: 100%;
    height: 100%;
    display: block;
    pointer-events: none; /* Evento click passa al bottone */
}

/* Transizione per rotazione dell'icona */
#menu-icon {
    transition: transform 0.4s ease-in-out;
    z-index: 9999;
    position: relative;
}

/* Quando la sidebar è aperta, ruota l'icona di 180 gradi */
#menu-toggle.open #menu-icon {
    transform: rotate(180deg);
}

/* ---------------------------------- */
/* ---------- Sidebar Menu ---------- */
/* ---------------------------------- */

/* Stile base della sidebar */
.sidebar-menu {
  position: fixed; /* Rimane fisso nella finestra */
  top: 0; /* Allineato in alto */
  left: 100%; /* Inizialmente nascosta fuori dallo schermo a destra */
  height: 100vh; /* Altezza uguale alla finestra */
  background-color: #E89C09; /* Giallo birra */
  padding: 120px 15px; /* Spaziatura interna */
  transition: left 0.3s ease-in-out; /* Animazione scorrimento */
  z-index: 900; /* Sta sotto i bottoni */
  width: 0; /* Larghezza zero inizialmente */
  overflow-y: auto; /* Scroll verticale se contenuto grande */
}

/* Lista dentro la sidebar */
.sidebar-menu ul {
  list-style: none; /* Niente pallini */
  padding: 0;
  margin: 0;
}

/* Singoli elementi della lista */
.sidebar-menu li {
  margin-bottom: 15px; /* Spazio tra link */
}

/* Link della sidebar */
.sidebar-menu li a {
  color: rgb(0, 0, 0);
  text-decoration: none;
  font-size: 1.2rem;
}

/* Effetto hover sui link */
.sidebar-menu li a:hover {
    font-weight: bold;
    cursor: pointer;            /* Cambia il cursore per indicare che è cliccabile */
}

/* Quando la sidebar ha classe 'open' */
.sidebar-menu.open {
  width: auto; /* Larghezza gestita da JS */
}

/* ----------------------------------- */
/* ---------- Overlay scuro ---------- */
/* ----------------------------------- */

/* Overlay semi-trasparente scuro per scurire la pagina */
#overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.6s ease, visibility 0.6s ease;
  z-index: 200;
  pointer-events: none; /* Evita clic quando invisibile */
}

/* Overlay visibile */
#overlay.visible-sidebar,
#overlay.visible-popup,
#overlay.visible-speaker {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

/* ---------------------------------------------------- */
/* ---------- Banner informativo - Subheader ---------- */
/* ---------------------------------------------------- */

/* Banner giallo sotto l'header */
.event-banner {
    background-color: #E89C09; /* Giallo birra */
    padding: 5px 0;
    text-align: center;
    font-family: 'Baumans', sans-serif;
}

/* Contenitore link banner */
.banner-links {
    display: flex;
    justify-content: space-between; /* link distribuiti tra sinistra, centro, destra */
    justify-content: center;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
    box-sizing: border-box;
}

/* Stile link banner */
.banner-links a {
    color: #000; /* Testo nero */
    text-decoration: none;
    font-size: 1.1rem;
    transition: color 0.2s ease-in-out;
    flex-basis: 30%;      /* ogni link occupa circa il 30% dello spazio */
    padding: 5px 15px;   /* padding interno per area cliccabile */
    box-sizing: border-box;
}

.banner-links a:hover {
    font-weight: bold;
    cursor: pointer;            /* Cambia il cursore per indicare che è cliccabile */
}

/* ------------------------------------- */
/* ---------- Prossimo Evento ---------- */
/* ------------------------------------- */

.event-image-section {
  position: relative;
  overflow: hidden;
  width: 100vw;
  /* altezza non fissa: la prenderà dalla img nitida */
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Immagine sfuocata dietro */
.background-blur {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100vw;              /* tutta la larghezza */
  transform: translateY(-50%); /* centrare verticalmente */
  height: auto;              /* altezza dinamica in base alla proporzione */
  min-height: 100%;          /* almeno tutta altezza del contenitore */
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;    /* ingrandisci ritagliando */
  filter: blur(12px);
  opacity: 0.5;
  z-index: 0;
}

/* Contenitore immagine nitida */
.event-image-wrapper {
  position: relative;
  max-width: 600px;
  width: 100%;
  z-index: 1;
}

/* Immagine nitida */
.event-image-wrapper img {
  width: 100%;         /* piena larghezza contenitore */
  height: auto;        /* mantiene proporzioni */
  object-fit: contain; /* no ritaglio, proporzioni mantenute */
  cursor: pointer;
  display: block;
  transition: transform 0.5s ease-in-out;
}

/* Effetto zoom quando si passa il mouse */
.event-image-wrapper img:hover {
  transform: scale(1.05);
}

/* ------------------------------------------------------------------------- */
/* ---------- Popups (RSVP prossimo evento, Nuovo Speaker, Ko-Fi) ---------- */
/* ------------------------------------------------------------------------- */

/* Stile modale (popup) */
#popup {
  display: none; 
  position: fixed; 
  top: 50%; 
  left: 50%; 
  transform: translate(-50%, -50%);
  background: #fff; 
  padding: 10px; 
  border-radius: 8px; 
  box-shadow: 0 0 10px rgba(0,0,0,0.5);
  width: 620px; 
  height: 420px; 
  overflow: hidden; 
  z-index: 1000;
}

#speakerPopup {
  display: none; 
  position: fixed; 
  top: 50%; 
  left: 50%; 
  transform: translate(-50%, -50%);
  background: #fff; 
  padding: 10px; 
  border-radius: 8px; 
  box-shadow: 0 0 10px rgba(0,0,0,0.5);
  width: 620px; 
  height: 620px; 
  overflow: hidden; 
  z-index: 1000;
}

#kofiPopup {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  padding: 10px;
  border-radius: 8px;
  box-shadow: 0 0 10px rgba(0,0,0,0.5);
  width: 450px;
  height: 580px;
  overflow: hidden;
  z-index: 1000;
}

/* Bottone chiusura modale */
#closePopup,
#closeSpeakerPopup,
#closeKofi {
  position: absolute;
  top: 5px;
  right: 5px;
  font-size: 40px;
  cursor: pointer;
  background: none;
  border: none;
  color: #444; /* colore bottone chiaro */
  line-height: 1;
  padding: 0;
  user-select: none;
}

/* ------------------------------------------- */
/* ---------- Banner Nuovi Speakker ---------- */
/* ------------------------------------------- */

/* Contenitore banner con sfondo giallo e testo centrato */
.speaker-banner {
  background-color: #E89C09;            /* Giallo birra */
  color: #000;                          /* Testo nero per contrasto */
  text-align: center;                   /* Centra il testo */
  padding: 10px;                        /* Spaziatura interna */
  font-family: 'Baumans', cursive;      /* Font coerente con il resto del sito */
  font-size: 1.2rem;                    /* Testo leggibile */
  width: 100%;
  box-sizing: border-box;
  text-align: center;
}

/* Evidenziazione della parola chiave */
.speaker-banner strong {
  color: #000000;                       /* Giallo più scuro */
  font-weight: bold;
}

/* Stile del link per candidarsi */
.speaker-banner a {
  display: inline-block;               /* Per padding e animazione */
  margin-top: 10px;
  font-weight: bold;
  color: #000;
  text-decoration: none;
  background: #fff;                    /* Sfondo bianco sul giallo */
  padding: 8px 16px;
  border-radius: 6px;
  transition: background 0.4s ease-in-out, transform 0.4s ease-in-out;
}

/* Effetto al passaggio del mouse */
.speaker-banner a:hover {
  background: #32938D;                 /* Giallo più chiaro */
  transform: scale(1.05);              /* Leggero ingrandimento */
  color: #ffffff;
}

/* ------------------------------------------------- */
/* ---------- Format due colonne Homepage ---------- */
/* ------------------------------------------------- */

/* Contenitore principale con due colonne affiancate */
.two-columns-section {
  display: flex;
  gap: 24px;
  margin: 40px auto;              /* margini verticali e centrato */
  max-width: 1100px;               /* larghezza massima */
  padding: 0 16px;                /* un po' di padding laterale */
  flex-wrap: nowrap;                /* impilabile su schermi piccoli */
  box-sizing: border-box;
  align-items: stretch; /* <-- le colonne avranno la stessa altezza */
}

/* Colonna 1/3 */
.column-narrow {
  flex: 0 0 359px; /* circa un terzo considerando gap */
  min-width: 280px;      /* Larghezza minima per evitare colonne troppo strette */
  box-sizing: border-box;
  gap: 20px;            /* Spazio verticale tra i box */
  display: flex;
  flex-direction: column;
}

/* Box generici nella colonna narrow */
.join-us-box,
.support-box,
.mailing-list-box {
  background: #fff;
  padding: 5px 10px;
  border-radius: 8px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.5);
  font-family: 'Baumans', sans-serif;
  width: 100%;
  box-sizing: border-box;
}

/* Colonna 2/3 */
.column-wide {
  flex: 0 0 717px; /* circa due terzi */
  min-width: 320px;      /* Larghezza minima per evitare colonne troppo strette */
  box-sizing: border-box;
  display: flex;       /* per poter usare flex-direction */
  flex-direction: column;
}

/* --------------------------------------------------- */
/* ---------- Mailchimp form - mailing list ---------- */
/* --------------------------------------------------- */

#mc_embed_signup {
  background: #fff;
  font-size: 14px;
  width: 100%;
  font-family: 'Baumans', sans-serif;
}

/* Bottone personalizzato */
#mc_embed_signup .button {
  background-color: #f1c40f; /* giallo birra */
  color: #000;
  padding: 12px 20px;
  border: none;
  border-radius: 8px;
  font-weight: bold;
  font-size: 1rem;
  cursor: pointer;
  transition: background 0.4s ease-in-out, transform 0.4s ease-in-out;
  width: 100%;
}

#mc_embed_signup .indicates-required {
  text-align: right;
  font-size: 0.6rem;
  margin-bottom: 10px;
  color: #555;
}

#mc_embed_signup .button:hover {
  background-color: #32938D;
  transform: scale(1.05);              /* Leggero ingrandimento */
  color: #fff;
}

.mc-custom input[type="email"],
.mc-custom input[type="text"] {
  width: 100%;
  padding: 10px;
  margin-top: 6px;
  margin-bottom: 12px;
  border: 1px solid #ccc;
  border-radius: 6px;
  box-sizing: border-box;
}

/* ------------------------------------------------- */
/* ---------- Unisciti a Noi - Supportaci ---------- */
/* ------------------------------------------------- */

/* Link azione */
.action-link {
  display: inline-block;
  margin-top: 10px;
  color: #32938D;
  font-weight: bold;
  text-decoration: none;
  transition: color 0.3s ease;
}

.action-link:hover {
  color: #206b67;
  text-decoration: underline;
}


/* ------------------------------ */
/* ---------- Talk Box ---------- */
/* ------------------------------ */

/* Riga singola per evento */
.event-row {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid #ccc; /* linea divisoria */
  padding-bottom: 5px; /* spazio sotto il contenuto prima della linea */
  margin-bottom: 5px;  /* spazio sotto la linea */
}

/* Stile thumbnail */
.thumbnail-box {
  flex: 0 0 220px;
  height: 200px;     
  border-radius: 10px;
  box-shadow: 0 4px 10px rgba(0,0,0,1);
}

.event-thumbnail {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
}

/* Dettagli talk */
.event-info-box {
  flex: 1 auto;
  height: 220px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* Testi */
.talk-date {
  font-size: 0.85rem;
  color: #777;
  margin-bottom: 4px;
}

.talk-title {
  font-size: 1.25rem;
  font-weight: bold;
  margin: 6px 0;
}

.talk-speaker {
  margin: 0;
  font-weight: 500;
}

.talk-quote {
  font-style: italic;
  margin-top: 8px;
  margin-bottom: 4px;
  color: #333;
}

.more-link {
  display: inline-block;
  margin-top: 0px;
  color: #32938D;
  text-decoration: underline;
}

/* Box link eventi passati */
.event-link-box {
  display: flex;
  height: 40px; /* o auto, se preferisci */
  border-bottom: 1px solid #ccc; /* linea divisoria */
  padding-bottom: 5px; /* spazio sotto il contenuto prima della linea */
  margin-bottom: 5px;  /* spazio sotto la linea */
}

/* Stile coerente per il link */
.all-events-link {
  color: #000;
  font-weight: bold;
  font-size: 1.4rem;
  text-decoration: none;
  margin-top: auto;
  margin-bottom: auto; /* centrare verticalmente */
  transition: all 0.3s ease-in-out;
}

.all-events-link:hover {
  color: #E89C09;
  text-decoration: underline;
}

/* Placeholder per mantenere spazio thumbnail */
.event-link-box .thumbnail-placeholder {
  width: 0px;
  height: 1px; /* invisibile ma occupa lo spazio */
}


/* ---------------------------- */
/* ---------- Footer ---------- */
/* ---------------------------- */

.site-footer {
  background-color: #000; /* sfondo scuro */
  color: #eee;           /* testo chiaro */
  padding: 24px 16px;
  width: 100%;
  border-top: 5px solid #E89C09; /* linea sopra per separare */
  margin-top: auto;
}

.footer-container {
  max-width: 1100px; /* Larghezza massima contenuto */
  margin: 0 auto;
  padding: 0 20px; /* Padding laterale */
  display: flex; /* Disposizione elementi in orizzontale */
  justify-content: space-between; /* Spazio tra logo e icone */
  align-items: center; /* Allinea verticalmente */
  flex-wrap: wrap;
}

.footer-left {
  flex: 0 0 auto;
}

.footer-logo {
  height: 100px;
  width: auto;
}

.footer-nav {
  flex: 1 1 auto;
  text-align: center;
}

.footer-menu {
  list-style: none;
  padding: 0;
  margin: 0;
  display: inline-flex;
  gap: 24px;
  flex-wrap: wrap;
  justify-content: center;
}

.footer-menu li a {
  color: #eee;
  text-decoration: none;
  font-weight: bold;
  transition: color 0.3s ease;
}

.footer-menu li a:hover {
  color: #f1c40f;
  text-decoration: underline;
}

.footer-right {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
}

.footer-right img {
  width: 24px;
  height: 24px;
  transition: filter 0.5s ease-in-out, transform 0.5s ease-in-out;
  cursor: pointer;
}

.footer-right img:hover {
  filter: brightness(0) saturate(100%) invert(70%) sepia(25%) saturate(6110%) hue-rotate(5deg) brightness(99%) contrast(93%);
  transform: scale(1.2);
}

.footer-description {
  font-size: 0.9rem;
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.4;
  color: #ccc;
  text-align: center;
}




/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */


/* ----------------------------------------- */
/* ---------- Calendario completo ---------- */
/* ----------------------------------------- */

.calendar-wrapper {
  max-width: 1100px;
  width: 100%;
  margin: 2rem auto;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  font-family: 'Baumans', cursive, sans-serif;
}

.calendar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem;
  background: #E89C09;
  color: white;
  border-radius: 12px 12px 0 0;
}

.calendar-header span {
  font-size: 1.2rem;
  font-weight: bold;
}

.calendar-header button {
  background: none;
  border: none;
  color: white;
  font-size: 1.5rem;
  cursor: pointer;
}

.calendar-table {
  width: 100%;
  border-collapse: collapse;
  text-align: center;
}

.calendar-table th {
  background: #e7f0ef;
  padding: 10px;
  text-transform: uppercase;
}

.calendar-table td {
  height: 80px;
  border: 1px solid #eee;
  vertical-align: top;
  cursor: pointer;
}

.calendar-table td.empty {
  background: #f9f9f9;
  color: #ccc;
  cursor: default;
}

.calendar-table td.today {
  background-color: #1abc9c;      /* verde acqua */
  color: white;                   /* testo bianco */
  font-weight: bold;              /* testo in grassetto */
  border: 3px solid #16a085;      /* bordo spesso e tono verde più scuro */
  box-shadow: 0 0 8px #16a085;   /* leggera ombra verde */
  padding: 5px 8px;              /* un po’ di spazio intorno al numero */
  text-align: center;
  user-select: none;             /* impedisce la selezione del testo, più "pulito" */
  transition: background-color 0.3s ease, transform 0.2s ease;
}

.calendar-table td.event {
  background: #E89C09;
  color: white;
  font-weight: bold;
}

.calendar-table td.today.event {
  background-color: #f1c40f;     /* giallo birra */
  color: #6e4b00;                /* testo marrone scuro per contrasto */
  font-weight: bold;
  border: 3px solid #d4ac0d;    /* bordo giallo scuro */
  box-shadow: 0 0 10px #d4ac0d; /* ombra gialla */
  padding: 5px 8px;
  user-select: none;
  text-align: center;
  transition: background-color 0.3s ease, transform 0.2s ease;
}

/* ----------------------------------------------------------- */
/* ---------- Dettagli evento - Calendario completo ---------- */
/* ----------------------------------------------------------- */

/* Contenitore dei dettagli evento, inizialmente nascosto */
#event-details {
  display: none;                    /* Nasconde l'elemento finché non viene mostrato tramite JS */
  margin: 20px auto 0 auto;         /* Margine sopra di 20px, orizzontalmente centrato (auto) */
  padding: 10px 20px;               /* Spaziatura interna: 10px sopra/sotto, 20px a destra/sinistra */
  border: 2px solid #ccc;         /* Bordo grigio chiaro sottile intorno al box */
  border-radius: 12px;               /* Angoli arrotondati con raggio 8px */
  background: #f9f9f9;            /* Sfondo leggermente grigio chiaro */
  max-width: 1100px;                 /* Larghezza massima di 900 pixel per non diventare troppo largo */
  width: 100%;
  text-align: center;               /* Testo centrato orizzontalmente dentro il box */
  box-shadow: 0 2px 8px rgba(0,0,0,0.1); /* Ombra delicata sotto il box per dare profondità */
  font-family: 'Baumans', cursive;  /* Font speciale, stile corsivo/curvy */
}

/* Stile per il titolo h3 all’interno del contenitore dettagli */
#event-details h3 {
    margin-top: 0;                  /* Elimino il margine sopra al titolo per evitare spazi extra */
    color: #b58900;               /* Colore giallo "birra" un po' scuro per evidenziare il titolo */
    line-height: 1;       /* altezza riga, più grande = più spazio tra le righe */
}

/* Stile per il paragrafo all’interno del contenitore dettagli */
#event-details p {
    margin-top: -10px;    /* Elimino il margine sopra al titolo per evitare spazi extra */
    line-height: 1;       /* altezza riga, più grande = più spazio tra le righe */
}




/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */


/* ---------------------------------- */
/* ---------- Biografia SO ---------- */
/* ---------------------------------- */

/* Container generale */
.bio-section .container {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap; /* per gestire il responsive */
}

/* Parte testo */
.bio-content {
  flex: 1 1 600px; /* prende lo spazio necessario, almeno 600px */
  color: #333;
  line-height: 1,5;
}

/* Titoli */
.bio-content h1, 
.bio-content h2 {
  color: #32938D; /* colore azzurro/scuro per i titoli */
  margin-top: 1em;
  margin-bottom: 0.2em;
  font-weight: 700;
}

.bio-content h1 {
  font-size: 2.4rem;
}

.bio-content h2 {
  font-size: 1.8rem;
}

/* Foto e didascalie */
.bio-photos {
  flex: 0 0 300px; /* larghezza fissa per le foto */
  display: flex;
  flex-direction: column;
  gap: 50px;
}

.bio-photos figure {
  margin: 0;
  text-align: center;
}

.bio-photos img {
  width: 90%;
  height: auto;
  border-radius: 8px;
  box-shadow: 0 4px 8px rgb(0 0 0 / 0.1);
}

.bio-photos figcaption {
  margin-top: 0.5em;
  font-size: 0.9rem;
  color: #555;
  font-style: italic;
}

/* ------------------------------------ */
/* ---------- I Numeri di SO ---------- */
/* ------------------------------------ */

/* Wrapper opzionale per padding ai numeri */
.stats-wrapper {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

/* RIGA dei box numerici (già pronta ma aggiungiamo max-width locale) */
.stats-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  max-width: 100%;
}

/* Singolo box numerico */
.stat-card {
  flex: 1 1 150px; /* si adatta bene su desktop */
  min-width: 120px;
  background: #fff;
  border-radius: 1rem;
  padding: 1rem;
  text-align: center;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
}

.stat-card .icon {
  font-size: 2rem;
  margin-bottom: 0.5rem;
  display: block;
}

.stat-card h3 {
  font-size: 1.6rem;
  margin: 0;
}

.stat-card p {
  font-size: 0.9rem;
  color: #555;
}




/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */


/* ------------------------------ */
/* ---------- Contatti ---------- */
/* ------------------------------ */

.contacts-section {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2em 1em;
}

.contacts-section h1,
.contacts-section h2 {
  color: #E89C09;
}

.contacts-section p {
  font-size: 1.1rem;
  line-height: 1.25;
  color: #333;
}

.contacts-section a {
  color: #32938D;
  text-decoration: none;
}

.contacts-section a:hover {
  text-decoration: underline;
}

.social-links {
  list-style: none;
  padding: 0;
  display: flex;
  gap: 1.5em;
  margin-top: 1em;
}

.social-links li {
  display: flex;
  align-items: center;
}

.social-links a {
  color: #32938D;
  display: flex;
  align-items: center;
  gap: 8px; /* distanza tra icona e testo */
  text-decoration: none;
}

.social-links img {
  width: 24px;
  margin-right: 8px;
}

.map-embed {
  margin-top: 1.5em;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}




/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */


/* ---------------------------- */
/* ---------- Eventi ---------- */
/* ---------------------------- */

/* Container generale */
.events-section .container {
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 0;      /* Match con .container */
  text-align: left;       /* Allinea testo a sinistra */
  display: block;         /* Evita effetti da grid/flex genitori */
}

.events-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start; /* Allinea in alto */
  flex-wrap: wrap;
  gap: 2em;
}

.events-text {
  flex: 1;
  min-width: 280px;
}

.events-text h1 {
  font-size: 2.4rem;
  color: #E89C09;
  margin: 0.3em 0 0.3em 0;  /* Elimina margine sopra */
  display: flex;
  flex-wrap: wrap;
}

.events-text p {
  margin: 0;
  color: #444;
  font-size: 1rem;
  max-width: 600px;
}

/* Stile per il link "Indietro" */
a.events-back-link {
    font-size: 1.3rem;
    color: #000;
    font-weight: 300;
    text-decoration: none;
    margin-top: .5em;
    display: inline-block;
}

/* Effetto hover per il link "Indietro" */
.events-back-link:hover {
    font-weight: 700;
    text-decoration: underline;
    cursor: pointer;
}

.event-seasons-links {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.event-seasons-links h2 {
  font-size: 1.6rem;
  color: #32938D;
  display: flex;
  flex-wrap: wrap;
  margin: 0.75em 0 0.5em 0;  /* 🔹 Elimina margine in alto */
}

.event-seasons-links ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 0.8em;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.event-seasons-links li a {
  display: inline-block; /* <-- Aggiungi questa riga */
  color: #32938D;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid #32938D;
  padding: 0.3em 0.8em;
  border-radius: 5px;
  cursor: pointer;
  transition:
    background-color 0.3s ease-in-out,
    color 0.3s ease-in-out,
    border-color 0.3s ease-in-out,
    transform 0.3s ease-in-out;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

.event-seasons-links li a:hover {
  background-color: #E89C09;
  color: #fff;
  border-color: #000; /* Cambia anche il colore del bordo */
  transform: scale(1.1);
}

/* ------------------------------------ */
/* ---------- Griglia eventi ---------- */
/* ------------------------------------ */

.event-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 2em;
  margin-top: 2em;
  margin-bottom: 2em;
}

.event-card {
  border: 1px solid #eee;
  border-radius: 10px;
  overflow: hidden;
  background-color: #fff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  transition: transform 0.2s;
}

.event-card:hover {
  transform: scale(1.02);
}

.event-card img {
  width: 100%;
  height: auto;
  display: block;
}

.event-card .card-content {
  padding: 1em;
}

.event-card h2 {
  font-size: 1.2rem;
  color: #32938D;
  margin-bottom: 0.5em;
}

/* Stile per il nome dello speaker */
.event-card .event-speaker {
    font-size: 1rem;
    color: #555;
    margin-top: 0;
    margin-bottom: 0.1em; /* Avvicina l'affiliazione */
}

/* Stile per l'affiliazione, più piccola e in corsivo */
.event-card .event-affiliation {
    font-size: 0.8rem; /* Dimensione del font come la data */
    color: #777;
    margin-top: 0;
    font-style: italic; /* Opzionale: rende il testo in corsivo */
    display: block; /* Necessario per applicare correttamente i margini */
}

/* Stile per i metadati (data e luogo) */
.event-card .event-meta {
    font-size: 0.8rem; /* Stessa dimensione dell'affiliazione */
    color: #666;
    margin-top: 0.8em; /* Aumentato il margine per separare dall'affiliazione */
    margin-bottom: 1em;
}

.event-card .event-links a {
  text-decoration: none;
  color: #32938D;
  font-weight: 600;
  margin-right: 1em;
}

.event-card .event-links a:hover {
  text-decoration: underline;
}


/* ------------------------------------------- */
/* ---------- Widget Ko-Fi (pagina) ---------- */
/* ------------------------------------------- */

/* Stile per il widget Ko-Fi nella pagina Sostienici */
.contacts-section .kofi-widget {
    display: block;               /* Centra l'iframe */
    margin: 2em auto;             /* Spaziatura verticale e centratura */
    width: 100%;                  /* Larghezza massima disponibile */
    max-width: 450px;             /* Limite massimo di larghezza */
    height: 712px;                /* Altezza fissa come da widget */
    border: none;                 /* Rimuove il bordo */
    box-shadow: 0 4px 12px rgba(0,0,0,0.2); /* Ombra leggera */
    border-radius: 8px;           /* Angoli arrotondati */
    padding: 15px;
}


/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------------------------------------------------- */

/* -------------------------------------------- */
/* ---------- Visualizzazione mobile ---------- */
/* -------------------------------------------- */


@media (max-width: 768px) {
  /* Imposta il box-sizing a border-box per tutti gli elementi */
  html, body {
    box-sizing: border-box;
  }
  *, *:before, *:after {
    box-sizing: inherit;
  }

  .site-header .container {
    padding: 0 10px; /* Riduci il padding per guadagnare spazio */
    justify-content: space-between;  /* Allinea gli elementi con spazio tra di loro, senza overflow */
  }

  .logo img {
    height: 13vw; /* L'altezza del logo è l'8% della larghezza dello schermo */
    width: auto;
  }

  /* Contenitore delle icone con gap per la spaziatura */
  .header-icons {
    display: flex;
    align-items: center;
    gap: 8px; /* Spaziatura tra le icone */
  }

  /* Riduci le dimensioni di tutte le icone dell'header */
  .social img,
  #search-button img,
  #menu-toggle img {
    width: 6vw; /* La larghezza delle icone è il 5% della larghezza dello schermo */
    height: 6vw;
  }

  /* Rimuovi i margini specifici che possono causare problemi di spazio */
  .header-icons > .social,
  .header-icons > #search-button {
    margin-right: 0;
  }

  .header-icons {
    gap: 10px; /* Riduci lo spazio tra le icone */
  }

  /* Riduci il margine a destra tra gli elementi */
  .header-icons > .social {
    margin-right: 5px;
  }

  .header-icons > #search-button {
    margin-right: 5px;
  }

  /* ---------------------------------------------------------------------------- */
  /* ---------------------------------------------------------------------------- */

  .banner-links a {
    font-size: 0.9rem;
    padding: 5px 8px;
  }

  /* ---------------------------------------------------------------------------- */
  /* ---------------------------------------------------------------------------- */

  #popup,
  #speakerPopup,
  #kofiPopup {
    width: 90%; /* Occupa il 90% della larghezza dello schermo */
    height: auto; /* L'altezza si adatta al contenuto */
    padding: 20px 10px;
  }

  /* Rendi gli iframe al loro interno responsive */
  #popup iframe,
  #speakerPopup iframe,
  #kofiPopup iframe {
    width: 100%; /* L'iframe occupa l'intera larghezza del popup */
    height: 400px; /* Imposta un'altezza fissa o 'auto' a seconda del contenuto */
  }

  /* ---------------------------------------------------------------------------- */
  /* ---------------------------------------------------------------------------- */

  .sidebar-menu {
    left: 100%; /* Inizialmente nascosta fuori dallo schermo a destra */
    /*... altri stili ...*/
  }

  /* ---------------------------------------------------------------------------- */
  /* ---------------------------------------------------------------------------- */

  /* Impila le colonne una sopra l'altra */
  .two-columns-section {
    flex-direction: column;
    gap: 0; /* Rimuovi lo spazio orizzontale tra le colonne */
  }

  /* Impila le righe degli eventi una sopra l'altra */
  .event-row {
    flex-direction: column;
    height: auto;
  }

  /* Riduci l'altezza delle immagini per gli eventi su mobile */
  .thumbnail-box {
    height: 200px;
    width: 100%;
    margin-top: 20px;
  }

  /* ---------------------------------------------------------------------------- */
  /* ---------------------------------------------------------------------------- */  

  .calendar-wrapper {
    padding: 0 20px;
  }

  /* Aggiunge padding ai contenitori per evitare che il contenuto si attacchi ai bordi */
  .calendar-table {
    padding: 0 10px; /* Un po' di spazio per le celle */
    box-sizing: border-box;
  }

  /* Riduci la dimensione del testo per i giorni della settimana */
  .calendar-table th {
    font-size: 0.75rem;
    padding: 5px;
  }

  /* Riduci l'altezza e il padding delle celle per farle stare dentro lo schermo */
  .calendar-table td {
    height: 60px;
    padding: 5px;
  }

  #event-details {
    padding: 0 0px;
  }

  /* ---------------------------------------------------------------------------- */
  /* ---------------------------------------------------------------------------- */

  /* Adatta l'altezza dei dettagli degli eventi */
  .event-info-box {
    height: auto;
    width: 100%;
  }

  /* ---------------------------------------------------------------------------- */
  /* ---------------------------------------------------------------------------- */

  /* Rende il footer un contenitore flex */
  .footer-container {
      flex-direction: column; /* Impila gli elementi verticalmente */
      align-items: center; /* Centra gli elementi orizzontalmente */
      text-align: center; /* Centra anche il testo */
  }

  /* Centra il logo, i link e le icone social */
  .footer-left,
  .footer-nav,
  .footer-right {
      width: 100%; /* Ogni elemento occupa la piena larghezza */
      margin-bottom: 15px; /* Aggiunge spazio tra gli elementi */
  }

  /* Centra il menu del footer */
  .footer-menu {
      display: flex;
      flex-direction: column;
      align-items: center;
      padding: 0;
  }

  /* Rimuovi il margine a sinistra delle icone social per centrarle */
  .footer-right a {
      margin-left: 0 !important; /* Forza la rimozione del margine */
  }

  /* Aggiunge spaziatura tra le icone social */
  .footer-right {
      display: flex;
      justify-content: center;
      gap: 20px; /* Aggiunge spazio tra le icone */
  }

  /* ---------------------------------------------------------------------------- */
  /* ---------------------------------------------------------------------------- */

  /* Container generale */
  .bio-section .container {
    padding: 0 20px; /* Aggiunge un padding orizzontale di 20px, che sarà visibile solo su schermi piccoli */
  }

  /* Impila le schede dei numeri una sopra l'altra */
  .stats-row {
    flex-direction: column;
  }

  /* ---------------------------------------------------------------------------- */
  /* ---------------------------------------------------------------------------- */

  .events-section .container {
    padding: 0 20px;
  }
}