@media (max-width: 1023px) {
  .grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hero__layout,
  .grid-2,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: auto;
  }

  .hero__visual {
    order: 2;
  }

  .steps-grid {
    grid-template-columns: 1fr;
    gap: var(--space-24);
  }

  .step-card:not(:last-child)::after {
    display: none;
  }
}

@media (max-width: 767px) {
  :root {
    --container-padding: var(--space-16);
  }

  .section {
    padding-block: var(--space-64);
  }

  .grid-3,
  .grid-2 {
    grid-template-columns: 1fr;
  }

  .nav-links {
    display: none;
  }

  .mobile-nav-toggle {
    display: inline-flex;
  }

  .hero__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .button {
    width: 100%;
  }

  .phone-mockup {
    width: min(100%, 320px);
  }

  .phone-mockup__screen {
    min-height: 560px;
  }
}
