@media (min-width: 1500px) {
  :root {
    --max: 1360px;
  }

  .gallery {
    grid-auto-rows: 420px;
  }
}

@media (max-width: 1080px) {
  .header-cta {
    display: none;
  }

  .hero-grid,
  .showcase-grid,
  .process-grid,
  .split-grid,
  .quote-grid,
  .faq-grid {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: auto;
  }

  .hero-media {
    max-width: 620px;
    width: 100%;
    height: 560px;
  }

  .trust-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .trust-grid p {
    grid-column: 1 / -1;
  }

  .service-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .gallery {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-auto-rows: 320px;
  }

  .gallery-item,
  .gallery-item.tall,
  .gallery-item.wide {
    grid-column: span 2;
  }

  .video-frame {
    max-width: 520px;
  }
}

@media (max-width: 760px) {
  :root {
    --pad: 18px;
  }

  .header-shell {
    min-height: 70px;
  }

  .brand img {
    width: 48px;
    height: 48px;
  }

  .brand small {
    display: none;
  }

  .nav-toggle {
    position: relative;
    z-index: 60;
    display: inline-grid;
    width: 44px;
    height: 44px;
    place-items: center;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.06);
  }

  .nav-toggle span {
    width: 18px;
    height: 2px;
    background: var(--white);
    transition: transform 220ms var(--ease);
  }

  .nav-toggle span + span {
    margin-top: -12px;
  }

  .nav-toggle[aria-expanded="true"] span:first-child {
    transform: translateY(5px) rotate(45deg);
  }

  .nav-toggle[aria-expanded="true"] span:last-child {
    transform: translateY(-5px) rotate(-45deg);
  }

  .main-nav {
    position: absolute;
    top: calc(100% + 10px);
    right: var(--pad);
    left: var(--pad);
    display: grid;
    align-content: start;
    justify-items: stretch;
    gap: 10px;
    max-height: calc(100svh - 92px);
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    visibility: hidden;
    opacity: 0;
    transform: translateY(-10px);
    color: var(--white);
    background: rgba(5, 5, 5, 0.98);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
    overflow: auto;
    transition: opacity 220ms ease, transform 220ms ease, visibility 220ms ease;
  }

  .main-nav.is-open {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
  }

  .main-nav a {
    display: flex;
    min-height: 48px;
    align-items: center;
    padding-inline: 14px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius);
    font-size: 1rem;
  }

  .hero {
    padding-block: 104px 36px;
  }

  .hero-copy h1 {
    font-size: clamp(2.42rem, 12vw, 4.35rem);
  }

  .hero-actions,
  .footer-grid {
    flex-direction: column;
  }

  .btn {
    width: 100%;
  }

  .proof-strip {
    grid-template-columns: 1fr;
    margin-top: 32px;
  }

  .hero-media {
    height: 520px;
  }

  .trust-grid,
  .service-grid,
  .gallery {
    grid-template-columns: 1fr;
  }

  .trust-grid span {
    justify-content: flex-start;
    border-radius: var(--radius);
  }

  .service-card,
  .service-card-wide,
  .gallery-item,
  .gallery-item.tall,
  .gallery-item.wide {
    grid-column: auto;
    grid-row: auto;
  }

  .service-card {
    min-height: 230px;
  }

  .service-card h3 {
    margin-top: 44px;
  }

  .gallery {
    grid-auto-rows: auto;
  }

  .gallery-item {
    grid-column: auto;
    aspect-ratio: 4 / 5;
  }

  .gallery-item.tall,
  .gallery-item.wide {
    grid-column: auto;
    grid-row: auto;
  }

  .step {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .step p {
    grid-column: 1;
  }

  .quote-form {
    grid-template-columns: 1fr;
  }

  .quote-form label:nth-child(1),
  .quote-form label:nth-child(2),
  .quote-form label:nth-child(3),
  .quote-form label:nth-child(4) {
    grid-column: 1 / -1;
  }

  .final-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 430px) {
  .section {
    padding-block: 64px;
  }

  .hero-lead,
  .section-heading p:not(.eyebrow),
  .split-copy p,
  .quote-copy p {
    font-size: 1rem;
  }

  .hero-media {
    height: 430px;
  }

  .media-badge {
    inset: auto 12px 12px;
    padding: 14px;
  }

  .featured-media div {
    position: static;
    border: 0;
    border-radius: 0;
    background: var(--black);
  }
}
