footer {
  position: relative;
  color: var(--color-background);
  background-color: var(--color-green-dark);
}

footer * {
  color: var(--color-background);
}

footer > div {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  gap: var(--padding);
  padding: calc(var(--padding) * 4) calc(var(--padding) * 2);
  width: 100%;
  max-width: var(--main-width);
  margin: 0 auto;
}

footer img {
  height: 3.25rem;
}

.home footer .shapes {
  display: block;
  position: absolute;
  height: unset;
  top: 0;
  z-index: -1;
  transform: translate(-40%, -40%);
  max-height: 48rem;
}

footer .shapes {
  display: none;
}

footer h2 {
  font-size: 1.5rem;
  margin-top: 2rem;
}

footer .contact {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

footer .contact p {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

footer .contact p > span {
  font-size: 1.1rem;
  font-weight: 500;
}

footer .contact p a {
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

footer .contact p a:hover {
  text-decoration: underline;
}

footer .contact p a img {
  width: 1.5rem;
  height: 1.5rem;
  color: white;
}
