/* Final typography layer for all inner-page content. */
body:not(#dsch-typography-standard) .page-content h1 {
  font-size: var(--dsch-font-size-h1) !important;
}

body:not(#dsch-typography-standard) .page-content h2 {
  font-size: var(--dsch-font-size-h2) !important;
}

body:not(#dsch-typography-standard) .page-content h3 {
  font-size: var(--dsch-font-size-h3) !important;
}

body:not(#dsch-typography-standard) .page-content p {
  font-size: var(--dsch-font-size-p) !important;
}

/* Form paragraphs are layout wrappers; their visible text is styled by child controls. */
body:not(#dsch-typography-standard) .page-content .admission-contact__form p {
  font-size: 0 !important;
}

body:not(#dsch-typography-standard) .page-content--ib .ib-profile-card__copy,
body:not(#dsch-typography-standard) .page-content--ib .ib-profile-card__copy p {
  font-size: 0.94rem !important;
}

@media (max-width: 760px) {
  body:not(#dsch-typography-standard) .page-content .page-title {
    width: 100%;
    max-width: 100%;
    font-size: clamp(1.75rem, 7vw, 2.4rem) !important;
    line-height: 1.08;
    white-space: normal;
    overflow-wrap: normal;
    text-wrap: balance;
  }

  body:not(#dsch-typography-standard) .page-content .history-hero h1,
  body:not(#dsch-typography-standard) .page-content .history-hero .page-title,
  body:not(#dsch-typography-standard) .page-content .history-title,
  body:not(#dsch-typography-standard) .page-content .project-hero h1,
  body:not(#dsch-typography-standard) .page-content .project-hero .page-title,
  body:not(#dsch-typography-standard) .page-content .project-title {
    font-size: clamp(1.75rem, 6.5vw, 2.35rem) !important;
    letter-spacing: -0.02em;
  }
}

@media (max-width: 380px) {
  body:not(#dsch-typography-standard) .page-content .page-title {
    font-size: 1.75rem !important;
  }
}
