/* Heading Component */

/* Semantic headings with consistent sizing and spacing */

@layer components {
  .heading {
    /* Base heading styles */
    font-family: var(--font-sans);
    font-weight: var(--font-weight-semibold);
    line-height: var(--line-height-tight);
    color: var(--color-dark);
    margin: 0;
  }

  /* Size variants */
  .heading--xl,
  .heading--h1 {
    font-size: var(--font-size-heading-xl);
    font-weight: var(--font-weight-bold);
    line-height: 1.1;
  }

  .heading--lg,
  .heading--h2 {
    font-size: var(--font-size-heading-lg);
  }

  .heading--md,
  .heading--h3 {
    font-size: var(--font-size-heading-md);
  }

  .heading--sm,
  .heading--h4,
  .heading--h5,
  .heading--h6 {
    font-size: var(--font-size-heading-sm);
  }

  /* Weight modifiers */
  .heading--weight-normal {
    font-weight: var(--font-weight-normal);
  }

  .heading--weight-medium {
    font-weight: var(--font-weight-medium);
  }

  .heading--weight-semibold {
    font-weight: var(--font-weight-semibold);
  }

  .heading--weight-bold {
    font-weight: var(--font-weight-bold);
  }

  /* Spacing utilities for headings */
  .heading + p,
  .heading + ul,
  .heading + ol {
    margin-top: var(--space-md);
  }

  .heading + .heading {
    margin-top: var(--space-lg);
  }
}
