body[data-section="write"] {
  --color-accent: var(--color-write);
  --color-accent-strong: var(--color-write-strong);
}

body[data-section="build"] {
  --color-accent: var(--color-build);
  --color-accent-strong: var(--color-build-strong);
}

body[data-section="capture"] {
  --color-accent: var(--color-capture);
  --color-accent-strong: var(--color-capture-strong);
}

body[data-section="personal"] {
  --color-accent: var(--color-personal);
  --color-accent-strong: var(--color-personal-strong);
}

:root {
  --color-bg: #f8f9fb;
  --color-surface: rgba(255, 255, 255, 0.9);
  --color-surface-strong: #ffffff;
  --color-surface-soft: rgba(255, 255, 255, 0.84);
  --color-surface-hover: rgba(255, 255, 255, 0.98);
  --color-surface-overlay: rgba(255, 255, 255, 0.92);
  --color-surface-muted: rgba(255, 255, 255, 0.72);
  --color-surface-panel: linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(249, 251, 254, 0.92));
  --color-surface-panel-soft: linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 253, 0.92));
  --color-text: #1b1d21;
  --color-muted: #5d6470;
  --color-accent: #2f5f86;
  --color-accent-strong: #1d4668;
  --color-write: #2f5f86;
  --color-write-strong: #1d4668;
  --color-build: #c96a2a;
  --color-build-strong: #9e4f18;
  --color-capture: #4a7a32;
  --color-capture-strong: #335420;
  --color-personal: #9c4f6a;
  --color-personal-strong: #7a3450;
  --color-border: rgba(27, 29, 33, 0.1);
  --shadow-soft: 0 18px 48px rgba(22, 28, 38, 0.08);
  --radius-card: 1.5rem;
  --radius-pill: 999px;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --space-8: 4rem;
  --container-width: 72rem;
  --container-narrow: 46rem;
  --font-display: "Georgia", "Iowan Old Style", serif;
  --font-body: "Avenir Next", "Segoe UI", sans-serif;
  --font-size-base: 1.0625rem;
  --font-size-sm: 0.95rem;
  --font-size-md: 1.0625rem;
  --font-size-lg: 1.14rem;
}
