/* =============================================================================
   CSS Custom Properties
   ============================================================================= */

:root {
  /* Colors */
  --color-orange:     #f58220;
  --color-orange-900: #ea7b22;
  --color-orange-100: #fdf2e9;

  --color-purple:     #642978;
  --color-purple-900: #55276a;
  --color-purple-100: #eee9f0;

  --color-blue:       #0380f7;
  --color-beige:      #f0ece5;

  --color-black:      #000000;
  --color-black-700:  #333231;
  --color-black-300:  #dcdcdc;

  --color-white:      #ffffff;
}

/* =============================================================================
   Footer
   ============================================================================= */

.footer {
  background-color: var(--color-white);
  padding: 4rem 1rem;
  border-radius: 1rem 1rem 0 0;
  border: 1px solid var(--color-black-300);
}

@media (min-width: 768px) {
  .footer {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }
}

/* Container */

.footer__container {
  margin-inline: auto;
}

@media (min-width: 768px) {
	.footer__container {
	  max-width: calc(100% - 40px);
	}
}

/* Grid */

.footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}

@media (min-width: 768px) {
  .footer__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 5rem;
  }
}

@media (min-width: 1024px) {
  .footer__grid {
    display: flex;
  }
}

/* Brand column */

.footer__brand {
  flex: 2;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  color: var(--color-black);
}

.footer__logo {
  display: block;
  line-height: 0;
}

.footer__tagline {
  font-size: 1rem;
  line-height: 2rem;
}

@media (min-width: 1024px) {
  .footer__tagline {
    font-size: 1.125rem;
  }
}

@media (min-width: 1280px) {
  .footer__tagline {
    font-size: 1.25rem;
  }
}

/* Newsletter box */

.footer__newsletter {
  padding: 1rem;
  background-color: var(--color-beige);
  border-radius: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.footer__newsletter h3 {
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.2;
}

.footer__newsletter-sub {
  font-size: 1rem;
  line-height: 2rem;
}

@media (min-width: 1024px) {
  .footer__newsletter-sub {
    font-size: 1.125rem;
  }
}

@media (min-width: 1280px) {
  .footer__newsletter-sub {
    font-size: 1.25rem;
  }
}

/* Nav columns */

.footer__nav {
  flex: 1;
  color: var(--color-black);
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.footer__nav-title {
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1;
}

@media (min-width: 1280px) {
  .footer__nav-title {
    font-size: 1.25rem;
  }
}

.footer__nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.footer__nav-link {
  color: var(--color-black);
  text-decoration: none;
}

.footer__nav-link:hover,
.footer__nav-link:focus-visible {
  text-decoration: underline;
}