Same channels. Cream ground.
This page ships under data-theme="light" so the generated
light palette is visible at rest, not just behind a toggle. Every value
here is emitted from tokens.json into the
[data-theme="light"] block and gated by
scripts/check-contrast.mjs (LIGHT) for WCAG AA. The
color channels are unchanged: copper is identity, cyan is interaction,
plasma is peak affect only.
Color channels
Meaning before hue — on cream.
Surface / #F3EDE2
Brand / #C8682A
Interactive / #0C6B7A
Peak only / #FF2E88
The interactive channel steps to cyan-700 and the brand eyebrow to copper-600 on a light ground so small text clears AA — see 02 — Color System.
Typography
The numbers still carry the brand.
Controls
One primary action per surface.
Class sections
Segments read by label, tinted by role.
Warm-up
Climb
Sprint
Recovery
Cool-down
Provider connection
Every provider state is explicit.
Spotify connected
Reconnecting…
Disconnected
Session expired
Provider error
Intensity
Zone + bars + label + color.
03
The Marble Has a Beat
Z3 · Attack
132BPM
Class shape