/* ============================================
   Responsive — Mobile-first overrides
   ============================================ */

/* Tablet & below (< 1024px) */
@media (max-width: 1023px) {
  .navbar__inner {
    gap: var(--space-3);
  }
  .navbar__links {
    gap: var(--space-4);
  }
  .navbar__actions .btn {
    display: none;
  }
  .theme-toggle {
    width: 36px;
    height: 36px;
  }
  .grid--3 {
    grid-template-columns: repeat(2, 1fr);
  }
  .grid--4 {
    grid-template-columns: repeat(2, 1fr);
  }
  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }
  .split {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }
  .split--reverse {
    direction: ltr;
  }
  .process::before {
    display: none;
  }
}

/* Mobile (< 768px) */
@media (max-width: 767px) {
  :root {
    --container-padding: var(--space-4);
    --nav-height: 60px;
  }

  .hero {
    min-height: auto;
    padding-top: calc(var(--nav-height) + var(--space-8));
    padding-bottom: var(--space-8);
  }

  .section {
    padding: var(--space-12) 0;
  }

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

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

  .trust-bar {
    gap: var(--space-4);
  }

  .hero__actions {
    flex-direction: column;
  }

  .hero__actions .btn {
    width: 100%;
    justify-content: center;
  }

  /* Navbar mobile */
  .navbar__links {
    display: none;
  }

  .navbar__burger {
    display: flex;
  }

  .navbar__actions .btn {
    display: none;
  }

  .theme-toggle--mobile {
    width: 40px;
    height: 40px;
  }

  /* Footer mobile */
  .footer__grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .footer__bottom {
    flex-direction: column;
    gap: var(--space-4);
    text-align: center;
  }

  /* Metrics */
  .metrics-bar {
    gap: var(--space-2);
  }

  .metric-pill {
    font-size: var(--text-xs);
    padding: var(--space-1) var(--space-3);
  }

  .cta-section {
    padding: var(--space-12) 0;
  }
}

/* Small mobile (< 480px) */
@media (max-width: 479px) {
  h1 { font-size: clamp(1.75rem, 7vw, 2.25rem); }
  h2 { font-size: clamp(1.5rem, 6vw, 2rem); }

  .card {
    padding: var(--space-6);
  }

  .card--case .card__body {
    padding: var(--space-4) var(--space-6);
  }
}
