*,
*::before,
*::after {
  margin: 0;
  padding: 0;

  box-sizing: border-box;
}

/* --- */

html {
  font-size: 16px;
}

body {
  font-family: sans-serif;
}

/* --- */

#container {
  padding: 1rem;
  min-height: 100vh;

  background-color: bisque;

  display: flex;
  flex-direction: column;
}

#container > h1 {
  padding: 2rem 2rem 0rem 2rem;
  text-align: center;
  font-size: 3rem;
}
#container > h2 {
  padding: 0rem 1rem 1rem 1rem;
  text-align: center;
  padding: 1rem;
  font-size: 2rem;
}

#container > .enlace {
  padding: 1rem;
  background-color: green;
  border-radius: 1rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: box-shadow 0.5s;
}
#container .enlaces {
  padding: 1rem;
  border-radius: 1rem;
  background-color: brown;
  gap: 1rem;
  display: flex;
}

#container .enlace img {
  height: 8rem;
  width: 12rem;
  border-radius: 1rem;
  box-shadow: 0.2rem 0.2rem 0.4rem rgb(0, 0, 0, 0.5);
}

#container .enlace .info {
  background-color: forestgreen;

  flex: auto;
  border-radius: 1rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  padding: 1rem;
}

#container .enlace:hover {
  box-shadow: 0.2rem 0.2rem 0.2rem rgb(0, 0, 0, 0.5);
}

#container .enlace .info h2 {
  font-size: 2rem;
  text-shadow: 0.1rem 0.1rem 0.2rem rgb(0, 0, 0, 0.5);
  color: chocolate;
}
#container .enlace .info a {
  font-size: 0.8rem;
}
#container .enlace .info p {
  font-size: 1.2rem;
  overflow: hidden;
}
/* --- */
