.newsletter-banner {
  background: var(--color-primary-500);
  color: var(--color-text-inverse);
}

.newsletter-banner__inner {
  display: grid;
  gap: var(--space-6);
  padding-block: var(--space-10);
}

.newsletter-banner__title {
  color: var(--color-text-inverse);
  font-size: var(--font-size-xl);
}

.newsletter-banner__body {
  margin: var(--space-2) 0 0;
  font-size: var(--font-size-sm);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.8);
}

.newsletter-banner__form {
  display: grid;
  gap: var(--space-3);
}

.newsletter-banner__form .button,
.newsletter-banner__form button[type="submit"] {
  background: var(--color-accent-500);
  color: var(--color-text);
  border: none;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color var(--transition-base);
}

.newsletter-banner__form .button:hover,
.newsletter-banner__form button[type="submit"]:hover {
  background: var(--color-accent-600);
}

@media (min-width: 1024px) {
  .newsletter-banner__inner {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    align-items: center;
  }

  .newsletter-banner__form {
    grid-template-columns: repeat(2, minmax(0, 1fr)) auto;
  }
}
