Turbo vs Peloton
68 token-level differences between these two design systems.
Background
#000000 → #0d0d0d Text
#ffffff → #ffffff Brand
#ff1e56 → #cb1e4e Border
rgba(255, 255, 255, 0.08) → #333333 Display font
Geist → Inter Body size
16px → 16px colors 58 changed
~
bg #000000 → #0d0d0d ~
surface #111111 → #1a1a1a ~
surface-strong #1a1a1a → #333333 ~
text-muted #a1a1a1 → #b3b3b3 ~
text-soft #666666 → #8a8a8a ~
text-faint #444444 → #666666 ~
brand #ff1e56 → #cb1e4e ~
brand-soft rgba(255, 30, 86, 0.12) → #1f0a10 ~
border rgba(255, 255, 255, 0.08) → #333333 ~
border-strong rgba(255, 255, 255, 0.15) → #4d4d4d ~
success #0cce6b → #1cb350 ~
warning #f5a623 → #ffa726 ~
info #0096ff → #3b82f6 +
bg-strong #000000 +
bg-elev #1a1a1a +
bg-elev-strong #262626 +
surface-soft #262626 +
surface-light #f5f5f5 +
brand-hover #a51840 +
brand-active #841234 +
brand-pale #f8d9e2 +
brand-deep #5e0a23 +
link #ffffff +
link-hover #cb1e4e +
border-soft #262626 +
border-input #666666 +
live-red #cb1e4e +
leaderboard-gold #ffc300 +
leaderboard-silver #c0c0c0 +
leaderboard-bronze #cd7f32 +
pr-record #ffc300 +
scrim rgba(0,0,0,0.7) +
shadow-card rgba(0,0,0,0.4) +
shadow-elev rgba(0,0,0,0.6) −
bg-soft #0a0a0a −
surface-elevated #202020 −
bg-overlay rgba(0, 0, 0, 0.72) −
brand-strong #e6164a −
accent #0096ff −
accent-strong #0078cc −
accent-soft rgba(0, 150, 255, 0.12) −
gradient-from #ff1e56 −
gradient-via #9b56b3 −
gradient-to #0096ff −
glow-magenta rgba(255, 30, 86, 0.4) −
glow-blue rgba(0, 150, 255, 0.35) −
glow-soft rgba(255, 30, 86, 0.2) −
border-subtle rgba(255, 255, 255, 0.05) −
border-brand rgba(255, 30, 86, 0.4) −
border-focus #ff1e56 −
success-bg rgba(12, 206, 107, 0.1) −
warning-bg rgba(245, 166, 35, 0.1) −
danger-bg rgba(255, 77, 79, 0.1) −
info-bg rgba(0, 150, 255, 0.1) −
on-brand #ffffff −
on-accent #ffffff −
on-surface #ffffff −
on-bg #ffffff typography 5 changed
~
display {"family":"Geist","size":96} → {"family":"Inter","size":72} ~
h1 {"family":"Geist","size":64} → {"family":"Inter","size":40} ~
h2 {"family":"Geist","size":48} → {"family":"Inter","size":32} ~
body {"family":"Geist","size":16} → {"family":"Inter","size":16} ~
label {"family":"Geist Mono","size":12} → {"family":"Inter","size":11} radius identical
No differences.
spacing 5 changed
~
xs 0px → 4px ~
sm 2px → 8px ~
md 8px → 16px ~
lg 20px → 32px ~
xl 32px → 48px