/* Stile per la sezione e i div principali */
section.intro {
    background-color: lightgrey;
    margin-top:30px;
    margin-bottom:30px;
    font-size: 1.2em;
}

section.nobkgd {
    background-color: none;
    margin-top:30px;
    margin-bottom:30px;
    font-size: 1.2em;
}

.intro-container {
    margin-bottom: 40px;
}


.intro .content {
    padding-bottom: 50px;
}

.gen-container {
    margin-bottom: 0px;
}


section.benefici {
  width: 90%;
  margin: 0 auto;
  
}
.flex-container {
    flex: 0 0 100%;
    max-width: 100%;
}
.main-div {
  display: flex; /* per affiancare i due div interni */
  flex-wrap:wrap;
  align-items: flex-start;
  text-align: left;
  margin-bottom: 30px;
}
/* Rimuove il margine inferiore dall'ultimo div */
.main-div:last-child {
  margin-bottom: 0;
}
/* Primo div a sinistra */
.left-even, .left-odd {
  flex: 0 0 25%;
  color: white;
  text-align: center;
}
.left-even h1,.left-odd h1 {
    color: white;
    font-size: 115px;
    background-color: #8cbe26;
    padding: 50px;
    margin-block-start: 0em;
    margin-block-end: 0em;
}
.left-odd h1 {
  background-color: #e84815;
}

/* Secondo div a destra */
.right {
    flex: 0 0 70%;
    max-width: 70%;
    font-size: 1.2em;
  color: black;
  padding: 0px 10px 0px 10px;
  /* Consente un po' di spazio interno per il testo */
}
/* Stile per il titolo all'interno del div destro */
.right h2 {
  margin-top: 0;
}

@media (max-width: 768px) {
    .flex-container {
        display: block;
    }
    .main-div {
        display: block;
    }
    .left-even, .left-odd {
        display: block;
    }
    .left-even h1, .left-odd h1 {
        font-size: 3em;
        padding: 20px;
    }
    .right {
        display: block;
        max-width: 100%;
        font-size: 1rem;
    }
    .right h2 {
        font-size: 1.5rem;
        text-align: center;
    }
}
