OpenAI vs Base
57 token-level differences between these two design systems.
Background
#ffffff → #ffffff Text
#000000 → #000000 Brand
#000000 → #0000ff Border
rgba(0,0,0,0.1) → #e0e0e0 Display font
OpenAI Sans → coinbaseSans Body size
16px → 16px colors 50 changed
~
surface #fafafa → #f5f5f5 ~
text-muted #5d5d5d → #666666 ~
text-faint #b4b4b4 → #999999 ~
text-on-dark #ededed → #ffffff ~
brand #000000 → #0000ff ~
brand-hover #1a1a1a → #0000cc ~
brand-active #2c2c2c → #000099 ~
link #000000 → #0000ff ~
link-hover #5d5d5d → #0000cc ~
border rgba(0,0,0,0.1) → #e0e0e0 ~
border-soft rgba(0,0,0,0.08) → #ededed ~
border-strong rgba(0,0,0,0.16) → #999999 ~
success #10a37f → #10b981 ~
warning #d97706 → #f59e0b ~
danger #cc2525 → #ef4444 ~
info #3a3a3a → #0000ff +
bg-elevated #fafafa +
bg-blue #0000ff +
bg-cream #f5f5f0 +
bg-dark #000000 +
surface-soft #fafafa +
surface-strong #e8e8e8 +
surface-on-blue #0000cc +
text-body #1a1a1a +
text-on-blue #ffffff +
brand-soft #e6e6ff +
brand-deep #000033 +
accent-cream #f5f5f0 +
accent-yellow #ffd000 +
accent-pink #ff5599 +
border-on-blue #3333ff +
ring #0000ff −
bg-soft #f1f1f1 −
bg-section #f7f7f7 −
surface-card #ffffff −
surface-hover rgba(0,0,0,0.04) −
surface-press rgba(0,0,0,0.08) −
text-subtle #8e8e8e −
text-on-brand #ffffff −
brand-on-dark #ffffff −
accent #10a37f −
accent-hover #0d8a6b −
accent-soft #d6f3e8 −
link-visited #000000 −
scrim rgba(0,0,0,0.5) −
shadow-card rgba(0,0,0,0.06) −
shadow-elev rgba(0,0,0,0.10) −
shadow-modal rgba(0,0,0,0.20) −
warning-soft #fdf3e7 −
danger-soft #fae5e5 typography 5 changed
~
display {"family":"OpenAI Sans","size":48} → {"family":"coinbaseSans","size":72} ~
h1 {"family":"OpenAI Sans","size":40} → {"family":"coinbaseSans","size":40} ~
h2 {"family":"OpenAI Sans","size":32} → {"family":"coinbaseSans","size":32} ~
body {"family":"OpenAI Sans","size":16} → {"family":"coinbaseDisplay","size":16} ~
label {"family":"OpenAI Sans Mono","size":12} → {"family":"coinbaseMono","size":11} radius identical
No differences.
spacing 2 changed
~
lg 32px → 48px ~
xl 48px → 96px