/* ============================================================
   CASUALIZZE — base reset & primitives
   Imported last so tokens are available. Kept intentionally light.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font: var(--text-body);
  color: var(--text-primary);
  background: var(--surface-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Display headings default to the personality font */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  color: var(--text-primary);
  letter-spacing: var(--ls-tight);
  margin: 0;
}

p { margin: 0; }

a { color: inherit; text-decoration: none; }

img { display: block; max-width: 100%; }

::selection { background: var(--c-ink); color: var(--c-paper); }

:focus-visible { outline: 2px solid var(--c-ink); outline-offset: 2px; }

/* ---- Utility text roles (handy in cards / kits) ---- */
.cz-eyebrow {
  font-family: var(--font-text);
  font-size: var(--fs-2xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--text-secondary);
}
.cz-display { font: var(--text-display); letter-spacing: var(--ls-tightest); }
.cz-title   { font: var(--text-title); }
.cz-muted   { color: var(--text-secondary); }
