:root {
  /* Es una pseuda raiz para colocar las paletas de colores */

  --fuenteHeading: "PT Sans", sans-serif;
  --fuenteParrafos: "Open Sans", sans-serif;

  --primario: #784d3c;
  --blanco: #ffffff;
  --negro: #000000;
  --gris: #e1e1e1;
}

html {
  font-size: 62.5%; /* Par poder usar el modulo de 1rem = 10px */
  box-sizing: border-box;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

body {
  font-family: var(--fuenteParrafos);
  font-size: 1.6rem;
  line-height: 2; /* Al ser un Blog el interlineado mejor hacerlo un poco mas grande */
}

/* Globales */

.contenedor {
  /* Es una nueva propiedad min() aplica el menor de los dos valores */
  width: min(90%, 120rem);
  margin: 0 auto;
}

a {
  text-decoration: none;
}

h1,
h2,
h3,
h4 {
  font-family: var(--fuenteHeading);
  line-height: 1.2;
}

h1 {
  font-size: 4.8rem;
}
h2 {
  font-size: 4rem;
}
h3 {
  font-size: 3.2rem;
}
h4 {
  font-size: 2.8rem;
}
img {
  max-width: 100%;
}

/* Utilidades */

.no-margin {
  margin: 0;
}
F .no-padding {
  padding: 0;
}
.centrar-texto {
  text-align: center;
}

/* Header */

.webp
.header {
  background-image: url(../img/banner.webp);
}
.no-webp
.header {
  background-image: url(../img/banner.jpg);
}
.header {
  height: 60rem;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.header__texto {
  text-align: center;
  color: var(--blanco);
  margin-top: 5rem;
}
@media (min-width: 768px) {
  .header__texto {
    margin-top: 10rem;
  }
}
.barra {
  padding-top: 4rem;
}
/* Usamos flex para acomodar elementos dentro de un contenedor */
@media (min-width: 768px) {
  .barra {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}

.logo {
  color: var(--blanco);
}
.logo__nombre {
  font-weight: 400;
}
.logo__bold {
  font-weight: 700;
}

@media (min-width: 768px) {
  .navegacion {
    display: flex;
    gap: 2rem;
  }
}

.navegacion_enlace {
  display: block; /* Colocamos los elemento uno debajo del otro y no al lado */
  text-align: center;
  font-size: 1.8rem;
  color: var(--blanco);
}

@media (min-width: 768px) {
  .contenido-principal {
    display: grid;
    grid-template-columns: 2fr 1fr;
    column-gap: 4rem;
  }
}

.entrada {
  border-bottom: 1px solid var(--gris);
  margin-bottom: 2rem;
}

.entrada:last-of-type {
  border: none;
  margin-bottom: 0;
}

.boton {
  display: block;
  font-family: var(--fuenteHeading);
  color: var(--blanco);
  text-align: center;
  padding: 1rem 3rem;
  font-size: 1.8rem;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 2rem;
  border: none;
}
/* los display:inline son inmunes a los width y a los margin
  no los tiene en cuenta, si queremos tenerlo en cuenta usamos inline-block
  pero no podemos colocarle nada seguido al elemento debido al requisito block */

@media (min-width: 768px) {
  .boton {
    display: inline-block;
  }
}
.boton:hover {
  cursor: pointer;
}
.boton--primario {
  background-color: var(--negro);
}
.boton--secundario {
  background-color: var(--primario);
}
.noticias {
  list-style-type: none;
}
.widget-noticia {
  border-bottom: 1px solid var(--gris);
  margin-bottom: 2rem;
}
.widget-noticia,
.noticia:last-of-type {
  border: none;
  margin-bottom: 0;
}
.widget-noticia__label,
.noticia__label {
  font-family: var(--fuenteHeading);
  font-weight: bold;
}
.widget-noticia__info,
.noticia__info {
  font-weight: normal;
}

.widget-noticia__label,
.widget-noticia__info,
.noticia__info,
.noticia__label {
  font-size: 2rem;
}

.footer {
  background-color: var(--negro);
  padding-bottom: 3rem;
  margin-top: 4rem;
}

/* Sobre Nosotros */
/* necesitamos esta linea para prepara un gap de 1rem con Flex 
@media (min-width: 748px) {
  .sobre-nosotros {
    display: flex;
    justify-content: space-between;   necesitamos esto para crear un gap en Flex 
  } 
   .sobre-nosotros__imagen,
    .sobre-nosotros__texto {
    flex-basis: calc(50% - 1rem);
  }  
} */

/* Podriamos reolver lo mismo que flex-basis usando GRID */
@media (min-width: 768px) {
  .sobre-nosotros {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 2rem;
  }
}

.noticia {
  padding: 3rem 0;
  border-bottom: 1px solid var(--gris);
}

@media (min-width: 768px) {
  .noticia {
    display: grid;
    grid-template-columns: 1fr 2fr;
    column-gap: 2rem;
  }
}
.noticia:last-of-type {
  border: none;
}

.contacto-bg {
  background-image: url(../img/contacto.jpg);
  height: 40rem;
  background-size: cover;
  background-repeat: no-repeat;
}

.formulario {
  background-color: var(--blanco);
  margin: -5rem auto 0 auto;
  width: 95%;
  padding: 5rem;
}
.campo {
  display: flex;
  margin-bottom: 2rem;
  gap: 2rem;
}
/* flex: 0 crecimiento 0  */
.campo__label {
  flex: 0 0 9rem;
  text-align: right;
  /*  padding-right: 2rem; pordemos colocar el gap en el padre o el paddin-right en el hijo*/
}
.campo__field {
  flex: 1;
  border: 1px solid var(--gris);
}
.campo__field--textarea {
  height: 20rem;
}
