@media (max-width: 1024px) {
  .pillar-grid,
  .awards-row {
    grid-template-columns: 1fr;
    max-width: 420px;
    margin-inline: auto;
  }

  .news-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .featured-cx__panel,
  .case-slide,
  .tab-panel__grid {
    grid-template-columns: 1fr;
  }

  .case-slide__visual,
  .featured-cx__visual {
    order: -1;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }

  .carousel-btn--prev { left: 0; }
  .carousel-btn--next { right: 0; }
}

@media (max-width: 767px) {
  .utility-bar { display: none; }

  .site-header { top: 0; }

  .hero {
    min-height: auto;
    padding-top: calc(var(--header-height) + 2rem);
    padding-bottom: 3rem;
  }

  .site-nav__links,
  .site-nav .btn--primary,
  .site-nav .btn--secondary {
    display: none;
  }

  .nav-toggle { display: flex; }

  .site-nav.is-open .site-nav__links {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: var(--header-height);
    left: 0;
    right: 0;
    bottom: 0;
    background: #fff;
    padding: 2rem;
    gap: 1.25rem;
    z-index: 99;
  }

  .site-nav.is-open .site-nav__link { color: var(--color-text); }

  .site-nav.is-open .btn--primary {
    display: inline-flex;
    width: 100%;
    justify-content: center;
  }

  .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) { opacity: 0; }

  .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }

  .news-grid { grid-template-columns: 1fr; }

  .case-tabs {
    gap: 0.5rem 1.25rem;
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 0.5rem;
  }

  .footer-grid { grid-template-columns: 1fr; }

  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }
}

@media (max-width: 480px) {
  .hero__actions,
  .cta-band__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .hero__actions .btn { width: 100%; }

  .tab-list { flex-direction: column; }
  .tab-btn { text-align: center; }
}
