/* ═══════════════════════════════════════════════════════════════
   Responsive — phones, tablets, laptops, ultrawide, landscape
   ═══════════════════════════════════════════════════════════════ */

/* ── Global ── */
.page-content.info-page {
  padding-bottom: calc(2rem + var(--safe-bottom));
}

@media (max-width: 1023px) {
  .page-content.info-page {
    padding-bottom: calc(8rem + var(--safe-bottom));
  }
}

a,
button,
.simple-button,
.info-nav a,
.pdf-option,
.pdf-btn,
.menu-btn {
  -webkit-tap-highlight-color: transparent;
}

@media (pointer: coarse) {
  .simple-button,
  .menu-btn,
  .info-nav a,
  .pdf-fab,
  .pdf-btn,
  .pdf-option,
  .mobile-menu nav a,
  .mobile-menu nav button.mobile-pdf-trigger {
    min-height: 4.4rem;
  }
}

/* Long emails / URLs */
.site-footer .footer-center > a,
.footer-phone {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* ── Header ── */
.site-header {
  padding-top: calc(clamp(1.6rem, 3vw, 3.8rem) + var(--safe-top));
}

@media (max-width: 1023px) {
  .site-header .header-inner {
    min-height: clamp(7.5rem, 20vw, 11rem);
    justify-content: flex-end;
  }

  .logo-link img {
    height: clamp(6.4rem, 18vw, 10rem);
    max-width: min(78vw, 40rem);
  }
}

@media (max-width: 479px) {
  .site-header {
    padding-bottom: 1.2rem;
  }

  .site-header .header-inner {
    min-height: 6.8rem;
  }

  .logo-link img {
    height: clamp(5.2rem, 22vw, 7.2rem);
    max-width: 72vw;
  }

  .menu-btn {
    width: 8.4rem;
    height: 4.4rem;
  }

  .menu-btn p {
    font-size: 1.6rem;
  }
}

@media (min-width: 1024px) and (max-width: 1279px) {
  .logo-link img {
    height: clamp(9rem, 12vw, 12rem);
  }
}

@media (min-width: 1440px) {
  .logo-link img {
    height: clamp(11rem, 10vw, 14rem);
  }
}

/* ── Mobile menu ── */
@media (max-width: 1023px) {
  .mobile-menu {
    padding-top: var(--safe-top);
    padding-bottom: calc(2.4rem + var(--safe-bottom));
  }

  .mobile-menu nav {
    padding-top: min(28vh, 14rem);
    gap: clamp(3.2rem, 8vh, 6.4rem);
  }

  .mobile-menu nav a,
  .mobile-menu nav button.mobile-pdf-trigger {
    font-size: clamp(2.4rem, 6vw, 3rem);
    line-height: 1.15;
    text-align: center;
    max-width: 90vw;
  }

  .mobile-menu .socials {
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.6rem 2.4rem;
    padding-inline: var(--container-padding-xs);
  }
}

@media (max-width: 479px) {
  .mobile-menu nav {
    padding-top: min(22vh, 10rem);
    gap: 2.8rem;
  }

  .mobile-menu nav a,
  .mobile-menu nav button.mobile-pdf-trigger {
    font-size: 2.2rem;
  }
}

@media (max-height: 500px) and (orientation: landscape) and (max-width: 1023px) {
  .mobile-menu {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .mobile-menu nav {
    padding-top: 6rem;
    gap: 2.4rem;
  }

  .mobile-menu nav a,
  .mobile-menu nav button.mobile-pdf-trigger {
    font-size: 2rem;
  }
}

/* ── Intro & sections ── */
@media (max-width: 1023px) {
  .info-intro {
    padding-top: 1rem;
  }

  .info-intro--brand {
    padding-top: clamp(3rem, 5vw, 4rem);
  }

  .intro-grid {
    gap: clamp(2.8rem, 5vw, 5rem);
  }

  .intro-secondary {
    gap: 2.8rem;
    padding-top: 0;
    border-left: none;
    padding-left: 0;
  }

  .info-prose,
  #what-we-do .info-prose,
  #mb-who .info-prose {
    margin-left: 0;
    margin-right: 0;
    max-width: 100%;
    padding-left: 0;
  }

  .vision-block {
    padding-left: 0;
    margin-left: 0;
    max-width: 100%;
    border-left: none;
  }

  .section-header {
    max-width: 100%;
  }

  .info-headline {
    max-width: 100%;
  }
}

@media (max-width: 767px) {
  .info-section {
    padding: clamp(4.5rem, 12vw, 8rem) 0;
  }

  .section-title {
    font-size: clamp(2.6rem, 7vw, 4rem);
  }

  .section-label {
    font-size: 1.1rem;
    letter-spacing: 0.18em;
    margin-bottom: 1.6rem;
  }

  .info-nav {
    gap: 0.6rem;
  }

  .info-nav a {
    font-size: 1.3rem;
    padding: 0.75rem 1.2rem;
  }

  .info-lead--emphasis {
    padding-top: 1.8rem;
  }

  .studio-disciplines {
    gap: 0.8rem;
  }

  .studio-disciplines li {
    font-size: 1.35rem;
    padding: 0.8rem 1.2rem;
  }
}

@media (max-width: 479px) {
  .info-headline {
    font-size: clamp(2.8rem, 9vw, 3.6rem);
    letter-spacing: -0.03em;
  }

  .info-lead p,
  .info-prose p,
  .approach-lead {
    font-size: 1.6rem;
    line-height: 1.6;
  }

  .info-lead--emphasis {
    font-size: 1.65rem !important;
  }

  .expertise-card h3 {
    font-size: 2rem;
    max-width: 100%;
    padding-right: 3.5rem;
  }

  .tag-grid li {
    font-size: 1.25rem;
    padding: 0.5rem 1rem;
  }
}

/* Tablet: 2-col tech, single intro column already */
@media (min-width: 768px) and (max-width: 1023px) {
  .tech-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.6rem;
  }

  .tech-group {
    padding: 2.2rem 2.4rem;
  }

  .approach-pillars {
    grid-template-columns: repeat(2, 1fr);
  }

  .card-columns {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }
}

/* Large desktop / ultrawide */
@media (min-width: 1280px) {
  .info-headline {
    max-width: 12ch;
  }
}

@media (min-width: 1600px) {
  :root {
    --section-space: clamp(10rem, 8vw, 16rem);
  }

  .intro-grid {
    gap: clamp(6rem, 6vw, 12rem);
  }
}

/* ── Expertise cards ── */
@media (max-width: 767px) {
  .expertise-stack {
    gap: 1.6rem;
  }

  .expertise-card {
    padding: 2rem 1.6rem 2rem 2rem;
  }

  .card-index {
    font-size: 3.8rem;
    top: 1rem;
    right: 1rem;
  }

  .info-quote {
    padding: 2rem 1.6rem;
  }

  .info-quote p {
    font-size: 1.85rem;
    padding-left: 1.2rem;
  }

  .vision-closing {
    font-size: clamp(2rem, 5.5vw, 2.8rem) !important;
  }
}

/* ── Footer ── */
@media (max-width: 1023px) {
  .site-footer--static {
    padding-top: clamp(5rem, 10vw, 8rem);
    gap: 3.5rem;
  }

  .footer-shell {
    gap: 3.5rem;
  }

  .footer-logo-wrap {
    height: clamp(14rem, 28vw, 18rem);
    margin: 2rem 0;
  }
}

@media (max-width: 767px) {
  .site-footer .footer-center > a:not(.footer-phone) {
    font-size: clamp(2rem, 6vw, 3.2rem);
    line-height: 1.2;
    padding-inline: 0.5rem;
  }

  .footer-phone {
    font-size: clamp(1.8rem, 5vw, 2.4rem) !important;
  }

  .site-footer .socials-row {
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.6rem 2.8rem;
    width: 100%;
  }

  .site-footer .footer-bottom a {
    font-size: 1.6rem;
  }
}

@media (max-width: 479px) {
  .site-footer .footer-tagline {
    font-size: 1.45rem;
    line-height: 1.45;
    padding-inline: 0.5rem;
  }

  .footer-logo-wrap {
    height: 12rem;
  }
}

/* ── PDF FAB hidden on desktop header duplicate — FAB spacing ── */
@media (max-width: 380px) {
  /* Icon-only FAB on very narrow phones */
  .pdf-fab {
    right: max(1rem, var(--safe-right));
    bottom: max(1rem, var(--safe-bottom));
    padding: 1rem;
    gap: 0;
    max-width: calc(100vw - 2rem);
    font-size: 0;
  }

  .pdf-fab svg {
    width: 2.2rem;
    height: 2.2rem;
    margin: 0;
  }
}

/* Hover only where supported */
@media (hover: none) {
  .expertise-card:hover,
  .simple-button:hover,
  .pdf-option:hover,
  .pdf-fab:hover {
    transform: none;
  }

  .approach-pillars li span:hover {
    transform: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .reveal {
    opacity: 1;
    transform: none;
  }

  html {
    scroll-behavior: auto;
  }
}
