/*
 * Base styles for HTML elements.
 * Builds on reset.css with your app's defaults.
 */
@layer base {
  /* Root and body */
  html {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

  body {
    background: var(--color-background);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    line-height: var(--line-normal);
  }

  /* Typography */
  h1, h2, h3, h4, h5, h6 {
    color: var(--color-text);
    line-height: var(--line-tight);
    font-weight: 600;
  }

  h1 {
    font-size: var(--text-5xl);
    margin-block-end: var(--space-lg);
  }

  h2 {
    font-size: var(--text-4xl);
    margin-block-end: var(--space-md);
  }

  h3 {
    font-size: var(--text-3xl);
    margin-block-end: var(--space-md);
  }

  h4 {
    font-size: var(--text-2xl);
    margin-block-end: var(--space-sm);
  }

  h5 {
    font-size: var(--text-xl);
    margin-block-end: var(--space-sm);
  }

  h6 {
    font-size: var(--text-lg);
    margin-block-end: var(--space-sm);
  }

  p {
    margin-block-end: var(--space-md);
  }

  /* Links */
  a {
    color: var(--color-link);
    text-decoration: none;
    text-decoration-skip-ink: auto;
    transition: color 0.2s var(--ease-out);
  }

  a:hover {
    color: var(--color-link-hover);
    text-decoration: underline;
  }

  /* Focus styles */
  :focus-visible {
    outline: none;
    box-shadow: var(--focus-ring);
    outline-offset: var(--focus-ring-offset);
  }

  /* Lists */
  ul, ol {
    padding-inline-start: var(--space-lg);
    margin-block-end: var(--space-md);
  }

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

  /* Code */
  code, pre {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
  }

  code {
    background: var(--color-background-elevated);
    padding-inline: var(--space-2xs);
    padding-block: var(--space-3xs);
    border-radius: var(--radius-sm);
  }

  pre {
    background: var(--color-background-elevated);
    padding: var(--space-md);
    border-radius: var(--radius-md);
    overflow-x: auto;
    margin-block-end: var(--space-md);
  }

  pre code {
    background: none;
    padding: 0;
  }

  /* Horizontal rule */
  hr {
    border: none;
    border-block-start: var(--border-width) solid var(--color-border);
    margin-block: var(--space-xl);
  }

  /* Blockquote */
  blockquote {
    border-inline-start: var(--border-width-lg) solid var(--color-accent);
    padding-inline-start: var(--space-md);
    margin-inline-start: 0;
    margin-block-end: var(--space-md);
    color: var(--color-text-secondary);
    font-style: italic;
  }

  /* Images */
  img {
    max-inline-size: 100%;
    block-size: auto;
  }

  /* Tables */
  table {
    inline-size: 100%;
    border-collapse: collapse;
    margin-block-end: var(--space-md);
  }

  th, td {
    padding: var(--space-sm);
    text-align: start;
    border-block-end: var(--border-width) solid var(--color-border);
  }

  th {
    font-weight: 600;
    color: var(--color-text);
  }

  /* Form elements - basic reset */
  input, textarea, select, button {
    font: inherit;
    color: inherit;
  }
}
