.contact_me {
  display: flex;              /* attiva Flexbox per affiancare foto e testo */
  font-family: 'Poppins', sans-serif;
  flex-wrap: wrap;            /* permette agli elementi di andare a capo se lo spazio non basta */
  gap: 30px;                  /* distanza orizzontale/verticale tra i due blocchi = 20px */
  max-width: 1100px;          /* larghezza massima del contenitore = 1100px */
  margin: 0 auto;             /* margini: 0 sopra/sotto, auto a sinistra/destra → centrato */
  padding-top: 145px;         /* spazio extra sopra il contenuto => 140px */
  align-items: flex-end;      /* allinea i contenuti in basso */
  flex-direction: row-reverse; /* - flex-direction: row-reverse → immagine a sinistra, testo a destra */
}

/* TITOLO */
.contact-title {
  position: relative;
  font-weight: 600;
}

.contact-title::after {
  content: "";
  display: block;
  width: 40px;
  height: 3px;
  background-color: darkslategray;
  margin-top: 5px;
  margin-bottom: 24px;
  border-radius: 2px;
}

/* TESTO (contenitore) */
.contact_text {
  flex: 2 1 400px;            /* cresce, si restringe, base 400px */
  display: flex; 
  flex-direction: column; 
  justify-content: flex-end; /* spinge il contenuto verso il basso */
  color: darkslategray;
  margin-bottom: 7px;  
}

/* BLOCCO INTERNO TESTO */ 
.contact-section { 
  padding-left: 5px; 
  padding-right: 5px; 
}

/* SOTTOTITOLI */
.contact-subtitle-en {
  font-size: 14px;
  font-weight: 500;
  margin: 0 0 14px 0;
  line-height: 19px;
  text-align: justify;
}

.contact-subtitle-it {
  font-size: 14px;
  font-weight: 400;
  font-style: italic;
  margin: 0 0 30px 0;
  line-height: 19px;
  text-align: justify;
}

/* FORM */
.contact-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.form-group label {
  font-size: 14px;
  font-weight: 400;
  margin-bottom: 5px;
  display: block;
}

.form-group input,
.form-group textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 14px;
  font-family: inherit;
  transition: border-color 0.2s ease;
}

.form-group input:focus,
.form-group textarea:focus {
  border-color: darkslategray;
  outline: none;
}

.contact-btn {
  padding: 12px 20px;
  background-color: transparent;
  color: darkslategray;
  border: 2px solid darkslategray; /* bordo darkslategray */
  border-radius: 6px;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.contact-btn:hover {
  background-color: transparent; /* sfondo arancione */ 
  color: orange; /* testo bianco */ 
  border-color: orange; /* bordo arancione */
}

.contact_img {
  flex: 1 1 500px;            /* cresce, si restringe, base 300px */
}

.contact_img img {
  width: 100%;                /* l’immagine occupa il 100% della larghezza del contenitore */
  height: auto;               /* altezza proporzionata automaticamente */
  border-radius: 8px;         /* angoli arrotondati = 8px */
  object-fit: cover;          /* mantiene proporzioni ritagliando se necessario */
}

/* RESPONSIVE: TESTO SOPRA, FOTO SOTTO */ 
@media (max-width: 900px) { 
  .contact_me { 
    flex-direction: column; 
    align-items: stretch; 
    padding: 145px 10px 20px; /* ← margini laterali su mobile */
  } 
  
  .contact_text, 
  .contact_img { 
    flex: 1 1 100%; 
  } 
}


