
#maincontainer {
    max-width: 1200px;
    margin: auto;
    padding: 20px;
    background: transparent;
  }

.titolo {
  text-align: center;
  font-size: 30px;
  font-weight: bold;
}

.titolo_vario {
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}

.tabella{
	display: table; 
	width: 40%; 
}

.riga{ 
	display: table-row; 
}

.colonna{
	display: table-cell;
	border: 1px solid grey;
	padding: 0.5em 0 0.5em 0.5em;
}


/* Stili per la tabella */
table {
    width: 100%;
    border-collapse: collapse; /* Rimuove i doppi bordi */
    text-align: left;
    font-size: 0.9em;
}

/* Stili per le intestazioni (ORA e ATTIVITÀ) */
th {
    background-color: #000080; /* Blu scuro (simile all'immagine) */
    color: white;
    padding: 10px 15px;
    border-right: 1px solid #000066; /* Bordo tra le intestazioni */
    font-weight: bold;
    text-transform: uppercase;
    font-size: 1em;
}

/* Larghezza della colonna 'ORA' */
th.ora {
    width: 25%;
    text-align: center;
}

/* Larghezza della colonna 'ATTIVITÀ' */
th.attivita {
    width: 75%;
}

/* Stili per le celle dati */
td {
    padding: 10px 15px;
    border: 1px solid #ccc; /* Bordi chiari */
    vertical-align: top;
    line-height: 1.4;
}

/* Stili per le celle della colonna 'ORA' */
td.ora-cell {
    background-color: #f9f9f9; /* Sfondo leggermente grigio per la colonna ORA */
    text-align: center;
    font-weight: bold;
    color: #333;
}

/* Allineamento specifico per singola riga ORA (08.50) */
td.ora-single {
    padding-top: 20px; /* Aumenta lo spazio superiore se necessario */
    padding-bottom: 20px; /* Aumenta lo spazio inferiore se necessario */
}

/* Stili per le righe/celle vuote (per replicare lo spazio) */
td.empty-cell {
    height: 30px; /* Aumenta l'altezza per lo spazio vuoto */
    border: 1px solid #ccc; /* Mantiene i bordi */
    background-color: white;
}

/* Rimuove il bordo per l'ultima riga */
tr:last-child td {
    border-bottom: 1px solid #ccc;
}









.texttrim{
    overflow: hidden!important;    
    text-overflow: ellipsis!important;
    background-color:black!important;
}

 .scopribtn {
    width: 100%;
    background-color: red;
    color: white;
    border-radius: 25px;
 }
  
  .spacer100 {
    clear:both!important;
    margin-bottom:100px!important;
  }

  header {
    text-align: center;
    margin-bottom: 30px;
  }
  
  .grid-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
  }
  
  .card {
    flex: 1 1 300px;
    background: #eaeaea;
    padding: 15px;
    border-radius: 8px;
    text-align: center;
  }
  
  .card img {
    width: 100%!important;
    border-radius: 5px!important;
    display: block!important;
    margin: auto!important;
  }
  
  .video-player {
    margin: 40px 0;
  }
  
  .gallery-grid {
    display: flex;
    /*display: grid;*/
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 55px;
    width: 50%;
    margin: auto;
  }
  
  .gallery-grid img {
    width: 100%;
    border-radius: 5px;
  }
  
 
  
  .map-section {
    margin: 40px 0;
    text-align: center;
  }
  
  #leaflet-map {
    width: 100%;
    height: 400px;
    border-radius: 8px;
    box-shadow: 0 0 10px rgba(0,0,0,0.1);
  }
  
  .flipcard-section {
    margin: 40px 0;
    text-align: center;
  }
  
  .flipcard-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
  }
  
  .flipcard {
    background: transparent;
    width: 300px;
    height: 200px;
    perspective: 1000px;
  }
  
  .flipcard-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.6s;
    transform-style: preserve-3d;
  }
  
  .flipcard:hover .flipcard-inner {
    transform: rotateY(180deg);
  }
  
  .flipcard-front,
  .flipcard-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  
  .flipcard-front {
    background: #fff;
  }
  
  .flipcard-front img {
    width: 100%;
    height: auto;
  }
  
  .flipcard-back {
    background: black;
    color: white;
    transform: rotateY(180deg);
    padding: 20px;
  }
  
  
   /* Mobile adjustments */
   @media (max-width: 600px) {
    .grid-cards {
      flex-direction: column;
      align-items: center;
    }  
  
  /* Image Grid adjustments */  
.gallery-grid 
{
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    grid-column: auto;
    gap: 10px;
    align-content: space-around;
}

.flipcard-grid {
  flex-direction: column;
  align-items: center;
}

}
  
  /* Desktop override */
  @media (min-width: 768px) {
    #sideMenu {
      width: 250px;
    }
  
    #menuToggle {
      font-size: 18px;
    }
  }
  
  .pulse:hover {
              
              
              background-color: #3498db;
              
              animation: pulse 2s infinite;
          }
  
  
  @keyframes pulse {
              0% {
                  transform: scale(1);
              }
              50% {
                  transform: scale(1.1);
              }
              100% {
                  transform: scale(1);
              }
          }
  