@layer base {
  html {
    font-size: 100%;
    scroll-behavior: smooth;
  }

  body {
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--color-text);
    background-color: var(--color-white);
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
  }

  h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-dark);
  }

  h1 { font-size: var(--text-4xl); }
  h2 { font-size: var(--text-3xl); }
  h3 { font-size: var(--text-2xl); }
  h4 { font-size: var(--text-xl); }
  h5 { font-size: var(--text-lg); }
  h6 { font-size: var(--text-base); }

  p { max-inline-size: 70ch; }
  p + p { margin-block-start: var(--space-sm); }

  a {
    color: var(--color-primary);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
    transition: color var(--fast) var(--ease);
  }
  a:hover { color: var(--color-primary-lt); }

  strong { font-weight: 600; }
  em { font-style: italic; }

  abbr[title] {
    text-decoration: underline dotted;
    cursor: help;
  }

  mark {
    background-color: var(--color-accent-lt);
    padding-inline: 0.15em;
    border-radius: 2px;
  }

  blockquote {
    border-inline-start: 4px solid var(--color-accent);
    padding-inline-start: var(--space-md);
    margin-block: var(--space-lg);
    font-style: italic;
    color: var(--color-muted);
  }
  blockquote cite {
    display: block;
    margin-block-start: var(--space-xs);
    font-size: var(--text-sm);
    font-style: normal;
    font-weight: 600;
    color: var(--color-text);
  }

  address { font-style: normal; }

  ul, ol { padding-inline-start: 1.5em; }
  ul { list-style: disc; }
  ol { list-style: decimal; }

  li + li { margin-block-start: var(--space-xs); }

  dl dt {
    font-weight: 700;
    font-family: var(--font-heading);
  }
  dl dd { margin-inline-start: 0; color: var(--color-muted); }

  table {
    inline-size: 100%;
    overflow-x: auto;
    display: block;
  }
  thead { background-color: var(--color-surface-2); }
  th, td {
    padding: var(--space-sm) var(--space-md);
    text-align: start;
    border-block-end: 1px solid var(--color-border);
  }
  th { font-family: var(--font-heading); font-weight: 700; font-size: var(--text-sm); }

  details {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
  }
  details + details { margin-block-start: var(--space-sm); }
  summary {
    padding: var(--space-md);
    font-family: var(--font-heading);
    font-weight: 600;
    cursor: pointer;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-sm);
    background-color: var(--color-surface);
  }
  summary::-webkit-details-marker { display: none; }
  summary::after {
    content: '+';
    font-size: var(--text-xl);
    color: var(--color-primary);
    flex-shrink: 0;
    transition: transform var(--normal) var(--ease);
  }
  details[open] > summary::after { transform: rotate(45deg); }
  details[open] > summary { color: var(--color-primary); background-color: var(--color-surface-2); }
  .details-body { padding: var(--space-md); }
  .details-body > *:first-child { margin-block-start: 0; }

  img { height: auto; }
  figure { margin: 0; }
  figcaption { font-size: var(--text-sm); color: var(--color-muted); margin-block-start: var(--space-xs); }

  time { font-variant-numeric: tabular-nums; }

  :focus-visible {
    outline: 3px solid var(--color-accent);
    outline-offset: 3px;
    border-radius: var(--radius-sm);
  }

  ::selection {
    background-color: var(--color-accent-lt);
    color: var(--color-dark);
  }
}
