@layer components {
  .prose {
    --prose-body-size: var(--text-18);
    --prose-line-height: 1.65;
    --prose-block-gap: var(--space-5);
    --prose-heading-margin: var(--space-8);
    --prose-h1-size: var(--text-40);
    --prose-h2-size: var(--text-28);
    --prose-h3-size: var(--text-24);
    --prose-h4-size: var(--text-20);
    --prose-h5-size: var(--text-18);
    --prose-h6-size: var(--text-16);
    --prose-list-gap: var(--space-2);
    --prose-blockquote-padding: var(--space-2) var(--space-6);
    --prose-code-padding: var(--space-1) var(--space-2);
    --prose-pre-padding: var(--space-5) var(--space-6);
    --prose-pre-radius: var(--radius-md);
    --prose-pre-line-height: 1.6;
    --prose-hr-margin: var(--space-4);
    --prose-img-radius: var(--radius-md);
    --prose-table-radius: var(--radius-md);
    --prose-table-size: var(--text-16);
    --prose-cell-padding: var(--space-3) var(--space-4);

    font-family: var(--font-serif);
    font-size: var(--prose-body-size);
    line-height: var(--prose-line-height);
    color: var(--color-ink);
    display: flex;
    flex-direction: column;
    gap: var(--prose-block-gap);
  }

  .prose--compact {
    --prose-body-size: var(--text-16);
    --prose-line-height: 1.6;
    --prose-block-gap: var(--space-4);
    --prose-heading-margin: var(--space-5);
    --prose-h1-size: var(--text-28);
    --prose-h2-size: var(--text-24);
    --prose-h3-size: var(--text-20);
    --prose-h4-size: var(--text-18);
    --prose-h5-size: var(--text-16);
    --prose-h6-size: var(--text-14);
    --prose-list-gap: var(--space-1);
    --prose-blockquote-padding: var(--space-1) var(--space-5);
    --prose-code-padding: var(--space-1) var(--space-2);
    --prose-pre-padding: var(--space-4) var(--space-5);
    --prose-pre-radius: var(--radius-sm);
    --prose-pre-line-height: 1.55;
    --prose-hr-margin: var(--space-3);
    --prose-img-radius: var(--radius-sm);
    --prose-table-radius: var(--radius-sm);
    --prose-table-size: var(--text-14);
    --prose-cell-padding: var(--space-2) var(--space-3);
  }

  .prose > :first-child { margin-block-start: 0; }
  .prose > :last-child  { margin-block-end: 0; }

  .prose-empty {
    margin: 0;
    color: var(--color-ink-subtle);
    font-family: var(--font-sans);
    font-style: italic;
    font-size: var(--text-14);
  }

  .prose h1,
  .prose h2,
  .prose h3,
  .prose h4,
  .prose h5,
  .prose h6 {
    font-family: var(--font-serif);
    font-weight: 600;
    color: var(--color-ink);
    letter-spacing: -0.01em;
    line-height: 1.2;
    margin: var(--prose-heading-margin) 0 0;
  }

  .prose h1 { font-size: var(--prose-h1-size); letter-spacing: -0.02em; }
  .prose h2 { font-size: var(--prose-h2-size); letter-spacing: -0.015em; }
  .prose h3 { font-size: var(--prose-h3-size); }
  .prose h4 { font-size: var(--prose-h4-size); }
  .prose h5 { font-size: var(--prose-h5-size); }
  .prose h6 { font-size: var(--prose-h6-size); color: var(--color-ink-muted); }

  .prose p { margin: 0; }

  .prose a {
    color: var(--color-accent);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
  }

  @media (any-hover: hover) {
    .prose a:hover {
      color: var(--color-accent-hover);
    }
  }

  .prose strong { font-weight: 600; }
  .prose em     { font-style: italic; }
  .prose del,
  .prose s      { color: var(--color-ink-muted); }

  .prose ul,
  .prose ol {
    margin: 0;
    padding-inline-start: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--prose-list-gap);
  }

  .prose li > ul,
  .prose li > ol {
    margin-block-start: var(--prose-list-gap);
  }

  .prose li input[type="checkbox"] {
    margin-inline-end: var(--space-2);
    transform: translateY(1px);
  }

  .prose blockquote {
    margin: 0;
    padding: var(--prose-blockquote-padding);
    border-inline-start: 3px solid var(--color-chalk-accent);
    color: var(--color-ink-muted);
    font-style: italic;
  }

  .prose blockquote > :first-child { margin-block-start: 0; }
  .prose blockquote > :last-child  { margin-block-end: 0; }

  .prose code {
    font-family: var(--font-mono);
    font-size: 0.9em;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: var(--prose-code-padding);
  }

  .prose pre {
    margin: 0;
    padding: var(--prose-pre-padding);
    background: var(--color-ink);
    color: var(--color-ink-inverted);
    border-radius: var(--prose-pre-radius);
    overflow-x: auto;
    font-size: var(--text-14);
    line-height: var(--prose-pre-line-height);
  }

  .prose pre code {
    background: transparent;
    border: 0;
    padding: 0;
    font-size: inherit;
    color: inherit;
    border-radius: 0;
  }

  .prose hr {
    border: 0;
    border-block-start: 1px solid var(--color-border);
    margin: var(--prose-hr-margin) 0;
  }

  .prose img {
    max-inline-size: 100%;
    block-size: auto;
    border-radius: var(--prose-img-radius);
    background: var(--color-surface);
  }

  .prose table {
    inline-size: 100%;
    border-collapse: collapse;
    border: 1px solid var(--color-border);
    border-radius: var(--prose-table-radius);
    overflow: hidden;
    font-size: var(--prose-table-size);
  }

  .prose th,
  .prose td {
    padding: var(--prose-cell-padding);
    text-align: start;
    border-block-start: 1px solid var(--color-border);
  }

  .prose thead th {
    background: var(--color-surface);
    font-weight: 600;
    border-block-start: 0;
  }
}
