.footer {
  border-top: 1px solid var(--color-tan);
  background-color: var(--color-white);

  padding: 1rem var(--page-margin);
}

.footer.primary {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.footer>*:not(:last-child) {
  margin-top: 0;
  margin-bottom: 1rem;
}

.footer .main {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1rem;
}

.footer .secondary {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.footer .main-links {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

@media (min-width: 600px) {
  .footer.primary {
    padding-top: 3rem;
    padding-bottom: 2.5rem;
  }

  .footer .main {
    flex-direction: row;
  }

  .footer .secondary {
    flex-direction: row;
    gap: 1rem;
  }

  .footer .main-links {
    flex-direction: row;
    gap: 1.5rem;
  }
}

@media (min-width: 1200px) {
  .footer .main-links {
    gap: 2.5rem;
  }
}
