/* ========================================== */
/*  TYPOGRAPHY SYSTEM                         */
/*  Clases tipográficas y sistema de texto    */
/* ========================================== */

/* ------------------------------------------ */
/*  DISPLAY & HEADLINE CLASSES                */
/* ------------------------------------------ */

.display-large {
  font-family: var(--font-display);
  font-weight: var(--title-weight, 100);
  font-size: clamp(3rem, 0.4286rem + 11.4286vw, 10rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  transition: font-weight 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  font-variation-settings: 'wght' var(--title-weight, 300);
  hyphens: auto;
  word-wrap: break-word;
}

.headline-xxl {
  font-family: var(--font-headline);
  font-weight: var(--title-weight, 300);
  font-size: clamp(2.5rem, 0.6633rem + 8.1633vw, 7.5rem);
  line-height: 1;
  letter-spacing: -0.02em;
}

.headline-xl {
  font-family: var(--font-headline);
  font-weight: var(--title-weight, 300);
  font-size: clamp(2rem, 0.898rem + 4.898vw, 5rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.headline-lg {
  font-family: var(--font-headline);
  font-weight: var(--title-weight, 300);
  font-size: clamp(1.5rem, 1.1327rem + 1.6327vw, 2.5rem);
  line-height: 1.1;
  letter-spacing: -0.01em;
}

.headline-md {
  font-family: var(--font-headline);
  font-weight: var(--title-weight, 300);
  font-size: clamp(1.5rem, 1.3163rem + 0.8163vw, 2rem);
  letter-spacing: -0.01em;
}

.headline-sm {
  font-family: var(--font-headline);
  font-weight: var(--title-weight, 300);
  font-size: clamp(1.5rem, 1.3929rem + 0.4762vw, 1.75rem);
  letter-spacing: -0.01em;
}

.headline-xs {
  font-family: var(--font-headline);
  font-weight: var(--title-weight, 300);
  font-size: clamp(1.25rem, 1.1429rem + 0.4762vw, 1.5rem);
  letter-spacing: -0.01em;
}

.headline-xxs {
  font-family: var(--font-headline);
  font-weight: var(--title-weight, 300);
  font-size: clamp(1rem, 0.8296rem + 0.6568vw, 1.25rem);
  letter-spacing: -0.01em;
}

/* ------------------------------------------ */
/*  TECHNICAL & BODY TEXT                     */
/* ------------------------------------------ */

.text-technical {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--color-text-secondary);
  font-weight: var(--title-weight, 300);
}

p,
li,
figcaption,
blockquote {
  line-height: 1.6;
  max-width: var(--p-max-width, 70ch);
  text-wrap: pretty;
  font-size: clamp(1.25rem, 1.1429rem + 0.4762vw, 1.5rem);

  *+& {
    margin-top: 1lh;
  }

  &+* {
    margin-top: 1lh;
  }
}

.text-balanced {
  text-wrap: balance;

  @media (width >=1024px) {
    max-width: 900px;
  }
}