.contact {
  background-color: var(--primary-color);
  color: var(--text-color-inverse);
  font-size: 18px;
  border-radius: 14px;
  padding: 25px;

  display: grid;
  gap: 25px; /*separacion*/
 }

 .contact p,
 .contact h2,
 .contact ul {
  margin: 0;
  padding: 0;
 }

 .contact-title {
	font-size: 30px;
	font-weight: 500;
	text-align: left;
	text-transform: uppercase;
 }

 .contact-details,
 .contact-form {
display: grid;
gap: 20px;

 }

 .contact-details-group,
 .contact-form-group {
  display: grid;
  gap: 3px;

 }

 .contact-label {
  text-transform: uppercase;
  font-weight: 500;
 }

 .contact-form input,
 .contact-form textarea {
  border-radius: 7px;
  border: none;
  height: 30px;
  padding: 5px 10px;
 } 

 .contact-form textarea {
  height: auto;
  resize: vertical;
 }

 .contact-form-submit {
  width: 100%;
  height: 50px;

  background-color: var(--text-color);
  border-radius: 7px;
  color: var(--text-color-inverse);
  border: 1px solid var(--theme-color);
  cursor: pointer;
 }

 .contact-form-submit:hover {
  box-shadow: 0 0 14px var(--secondary-color);
 }

 .social-list {
  list-style: none;
  display: flex; /*elementos horizontal*/
  gap: 25px;
  justify-content: center;
 }

 .social-list img {
  height: 25px;
 }

 .social-list img:hover {
  filter: drop-shadow(0 0 5px var(--secondary-color) );
 }

 @media (min-width: 950px){
  .contact {
    font-size: 20px;
    padding: 70px;

    max-width: 980px;
    margin: 0 auto;

    box-sizing: border-box;
   }

    .contact-title {
    font-size: 35px;
    text-align: left;
   }

   .social-list {
     justify-content: flex-start;
   }
  
   .social-list img {
    height: 35px;
   }
  
   .contact-title {
    grid-area: title;
   }

   .contact-details {
    grid-area: details;
   }

   .contact-form {
    grid-area: form;
   }

   .social {
    grid-area: social;
   }

   .contact {
    display: grid;
    grid:
    "title      form"
    "details    form"
    "social     form" /
    1fr         1fr


   }
 }
