/* Variables de color */
:root{
      --negro: #1A1A1A;       
      --blanco: #F5F4EF;     
      --morado:  #6A0DAD;    
      --moradooscuro: #3A1F40;      
    }

.sobremi {
  display: flex;            
  flex-direction: row;     
  align-items: center;      
  gap: 2rem;                
  border-radius: 10px;  
  padding: 20px;            
  background-color: var(--moradooscuro); 
  flex-wrap: nowrap; /* Evita desbordes en pantallas pequeñas */
  margin: auto
}

.sobremi img {
  max-width: 280px;         
  width: 100%;              
  border-radius: 10px; 
  flex-shrink: 0; /* Evita que se deforme en móviles */
}

.sobremi .texto {
  display: inline;
  white-space: pre-line;  
  font-size: 16px;
  line-height: 1.8;       
  color: var(--blanco);     
  text-align: justify;
}

.sobremi img:hover {
transform: scale(1.1)
}

h2 {
  text-align: center;
  color: var(--blanco);
  margin-top: 30px;
}

 /* === CARDS === */
.card-container {
  display: flex;
  flex-wrap: wrap; 
  gap: 20px;
  justify-content: center;
  padding: 20px;
}

.card {
  flex: 1 1 250px; /* Se ajusta automáticamente en filas */
  max-width: 280px;
  border: 1px solid var(--blanco);
  border-radius: 12px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
  background: var(--blanco);
  transition: transform 0.6s;
  text-align: center;
}

.card:hover {
transform: scale(1.1)
}

.card img, 
.card svg {
  margin: auto;
  display: block;
  width: 165px;
  height: 165px;
  object-fit: cover;
}

.card-content {
  padding: 5px;
}

.card-content h3 {
  margin: 10px 0;
  font-size: 18px;
  color: var(--negro);
}

.card-content p {
  display: inline;
  font-size: 14px;
  color: var(--negro);
}

/* === RESPONSIVE === */

/* Tablets */
@media (max-width: 900px) {
  .sobremi {
    flex-direction: column; /* Imagen arriba, texto abajo */
    text-align: center;
  }

  .sobremi img {
    max-width: 250px;
  }
.card:hover {
  transform: none;
}
  .sobremi .texto {
    text-align: center;
    padding-top: 0;
  }

  .card-container {
    gap: 15px;
  }

  h1,h2,h3,h4{
  text-align: center;
}
}

/* Móviles */
@media (max-width: 600px) {
  .sobremi {
    padding: 15px;
    gap: 1rem;
  }

  .sobremi img {
    max-width: 200px;
  }

  .sobremi .texto {
    font-size: 18px;
    line-height: 1.6;
  }

  h1,h2,h3,h4{
  text-align: center;
  font-size: 22px;
}

  .card {
    flex: 1 1 100%; /* Una por fila */
    max-width: 100%;
  }

  .card-content h3 {
    font-size: 16px;
  }

  .card-content p {
    font-size: 18px;
  }
}