### lab.css

```css
/* ============================================================
   FILE: /gest/lab/lab.css
   STILE UNIFICATO 2025-10 PER GENITORI E MINORI
   ============================================================ */

.page-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 25px;
  box-sizing: border-box;
}

/* ============================================================
   GENITORI – STRUTTURA A DUE COLONNE
   ============================================================ */
.genitori-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(480px, 1fr));
  gap: 25px;
}

.col-genitore {
  background: #fafafa;
  border-radius: 10px;
  border: 1px solid #ddd;
  padding: 22px 25px;
  box-sizing: border-box;
}

.col-genitore h4 {
  color: #1f3a93;
  margin: 0 0 15px 0;
}

/* ============================================================
   FORM GENITORI (Madre / Padre)
   ============================================================ */
.genitore-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.genitore-form .campo {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  width: 100%;
}

.genitore-form label {
  flex: 0 0 140px;
  font-weight: 600;
  color: #333;
  text-align: left;
  white-space: nowrap;
}

.genitore-form input[type="text"],
.genitore-form input[type="email"],
.genitore-form input[type="date"],
.genitore-form select {
  flex: 1;
  width: 100%;
  height: 38px;
  padding: 6px 10px;
  font-size: 15px;
  border: 1px solid #ccc;
  border-radius: 6px;
  box-sizing: border-box;
}

.genitore-form .riga-doppia {
  display: flex;
  gap: 12px;
  align-items: center;
}

.genitore-form .riga-doppia .campo {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
}

/* ============================================================
   MINORI – STESSA GRAFICA GENITORI
   ============================================================ */
.minori-grid-2col {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(480px, 1fr));
  gap: 25px;
}

.minore-block {
  background: #fafafa;
  border: 1px solid #ddd;
  border-radius: 10px;
  padding: 22px 25px;
  box-sizing: border-box;
}

.minore-block h4 {
  color: #1f3a93;
  margin-bottom: 15px;
}

.minore-block .form-row {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  margin-bottom: 10px;
}

.minore-block .form-row label {
  flex: 0 0 140px;
  font-weight: 600;
  color: #333;
  text-align: left;
  white-space: nowrap;
}

.minore-block .form-row input,
.minore-block .form-row select {
  flex: 1;
  width: 100%;
  height: 38px;
  padding: 6px 10px;
  font-size: 15px;
  border: 1px solid #ccc;
  border-radius: 6px;
  box-sizing: border-box;
}

.minore-block textarea {
  width: 100%;
  min-height: 60px;
  padding: 6px 10px;
  font-size: 15px;
  border: 1px solid #ccc;
  border-radius: 6px;
  box-sizing: border-box;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  .genitore-form .campo,
  .minore-block .form-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .genitore-form label,
  .minore-block label {
    width: 100%;
    margin-bottom: 4px;
  }

  .genitore-form .riga-doppia {
    flex-direction: column;
    gap: 10px;
  }
}

/* ============================================================
   SOVRASCRITTURA SPECIFICA PER RIGA DATA + CELLULARE
   ============================================================ */
.genitore-form .riga-doppia .campo {
  flex: 0 1 auto;
}

.genitore-form .riga-doppia .campo input {
  flex-grow: 0;
  width: auto;
}

.genitore-form .riga-doppia input[type="date"] {
  width: 160px;
}

.genitore-form .riga-doppia input[name*="cellulare"] {
  width: 15ch;
}

/* ============================================================
   FIX: Allineamento Checkbox Legge 104
   ============================================================ */
.legge104-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.legge104-row label {
  flex: 0 0 140px;
  font-weight: 600;
  color: #333;
  white-space: nowrap;
  line-height: 20px;
}

.legge104-row input[type="checkbox"] {
  flex: none;
  width: 30px;
  height: 30px;
  margin-left: 8px;
  margin-top: 2px;
}

/* Input compatti per minori */
.minore-block input[name*="cellulare"] {
  width: 15ch;
}

.minore-block input[name*="patologie"],
.minore-block input[name*="allergie"] {
  max-width: 320px;
}

/* ============================================================
   PATCH: rendere i form autosufficienti su smartphone
   ============================================================ */
@media (max-width: 768px) {
  .page-wrap {
    padding-left: 12px;
    padding-right: 12px;
  }

  /* Permetti alle righe di andare a capo senza overflow */
  .genitore-form .campo,
  .minore-block .form-row,
  .form-row {
    flex-wrap: wrap;
    gap: 8px;
  }

  /* Etichette occupano tutta la larghezza e non costringono la riga */
  .genitore-form label,
  .minore-block .form-row label,
  .form-row label {
    flex: 0 0 100%;
    width: 100%;
    margin-bottom: 6px;
    text-align: left;
  }

  /* Input e textarea si estendono al 100% della colonna disponibile */
  .genitore-form input[type="text"],
  .genitore-form input[type="email"],
  .genitore-form input[type="date"],
  .genitore-form select,
  .minore-block .form-row input,
  .minore-block .form-row select,
  .minore-block textarea,
  .form-row input,
  .form-row select,
  .form-row textarea {
    flex: 1 1 100%;
    width: 100%;
    min-width: 0;
  }

  /* Rimuove larghezze fisse che possono forzare overflow */
  .genitore-form .riga-doppia input[type="date"],
  .genitore-form .riga-doppia input[name*="cellulare"],
  .minore-block input[name*="cellulare"] {
    width: 100%;
  }

  /* Bottone Aggiungi/Invia centrati e a piena larghezza per comodità mobile */
  .add-minore-cell .btn,
  .actions-right .btn {
    width: 100%;
    box-sizing: border-box;
  }

  /* Assicura che i blocchi dei genitori si impilino verticalmente (no colonna larga) */
  .genitori-grid {
    grid-template-columns: 1fr;
  }

  /* Sistema eventuali margini/padding che causano overflow */
  .minore-block,
  .col-genitore {
    padding-left: 14px;
    padding-right: 14px;
  }

  /* Evita overflow orizzontale dell'intero wrapper */
  body, .page-wrap {
    overflow-x: hidden;
  }
}

/* ============================================================
   PATCH: minori più stretti su smartphone
   ============================================================ */
@media (max-width: 768px) {
  .minori-grid-2col {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 14px;
  }

  .minore-block {
    width: 100%;
    max-width: 520px;
    padding: 14px 16px;
    box-sizing: border-box;
  }

  /* versione più compatta alternativa (decommenta per test) */
  /*
  .minore-block {
    max-width: 460px;
  }
  */
}
```