/* ============================================================
   Base reset + document shell
   Depends on tokens.css
   ============================================================ */

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: var(--font-sans);
  background: var(--color-bg);
  color: var(--color-text);
  line-height: var(--leading-prose);
}

.content {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-8) var(--space-6) var(--space-12);
}

/* ---- Typography ------------------------------------------- */
h1 {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-text-strong);
  letter-spacing: -0.03em;
  margin-bottom: var(--space-1);
}

h2 {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text-strong);
  margin: 2.5rem 0 var(--space-3);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border-soft);
}
h2:first-of-type { border-top: none; padding-top: 0; }

h3 {
  font-size: var(--text-md);
  font-weight: 600;
  color: #e5e5e5;
  margin: var(--space-6) 0 var(--space-2);
}

h4 {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin: var(--space-4) 0 0.4rem;
}

p {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}

ul, ol { padding-left: var(--space-5); margin-bottom: var(--space-4); }
li { font-size: 0.88rem; color: var(--color-text-muted); margin-bottom: 0.35rem; }
strong { color: #e5e5e5; }

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

/* ---- Subtitle (under h1) ---------------------------------- */
.subtitle {
  font-size: var(--text-base);
  color: var(--color-text-dim);
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border-soft);
}

/* ---- Code ------------------------------------------------- */
code {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 0.1rem 0.35rem;
  color: var(--color-text);
}

pre {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-3) 0 var(--space-5);
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  line-height: 1.6;
  color: var(--color-text-muted);
}
pre code { background: none; border: none; padding: 0; }

/* ---- Footer mark (page) ----------------------------------- */
.footer {
  margin-top: var(--space-12);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border-soft);
  font-size: var(--text-xs);
  color: #404040;
  font-family: var(--font-mono);
}

/* ---- Mobile ----------------------------------------------- */
@media (max-width: 768px) {
  .content { padding: var(--space-6) var(--space-4) var(--space-12); }
  pre { font-size: 0.72rem; padding: var(--space-3); }
}
