Sonos vs Substack
57 token-level differences between these two design systems.
Background
#000000 → #ffffff Text
#ffffff → #363737 Brand
#ffffff → #ff6719 Border
#333333 → rgba(0, 0, 0, 0.10) Display font
Inter → Cahuenga Body size
16px → 19px colors 51 changed
~
bg #000000 → #ffffff ~
bg-elev #0a0a0a → #fafaf7 ~
bg-cream #f5f1ec → #fbf9f4 ~
surface #1a1a1a → #ffffff ~
text #ffffff → #363737 ~
text-strong #ffffff → #1a1a1a ~
text-muted #cccccc → #878787 ~
text-soft #999999 → #666c70 ~
brand #ffffff → #ff6719 ~
brand-hover #e5e5e5 → #e85412 ~
on-brand #000000 → #ffffff ~
border #333333 → rgba(0, 0, 0, 0.10) ~
border-soft #1f1f1f → rgba(0, 0, 0, 0.06) ~
border-strong #4d4d4d → rgba(0, 0, 0, 0.20) ~
success #4ade80 → #0d8050 ~
warning #facc15 → #d97706 ~
danger #ef4444 → #dc2626 ~
info #ffffff → #2563eb +
bg-soft #f6f6f3 +
surface-warm #fafaf7 +
text-faint #a8a8a8 +
text-link #363737 +
brand-deep #cc4a0e +
brand-tint rgba(255, 103, 25, 0.10) +
brand-tint-strong rgba(255, 103, 25, 0.18) +
border-warm rgba(0, 0, 0, 0.08) +
selection-bg rgba(255, 103, 25, 0.20) +
shadow-soft rgba(0, 0, 0, 0.06) +
shadow-medium rgba(0, 0, 0, 0.10) +
reading-rule rgba(0, 0, 0, 0.08) −
bg-alt #111111 −
bg-light #ffffff −
surface-hover #262626 −
surface-light #fafafa −
text-inverse #000000 −
text-inverse-muted #666666 −
brand-on-light #000000 −
brand-active #cccccc −
border-on-light #e5e5e5 −
border-on-light-strong #cccccc −
ring #ffffff −
ring-on-light #000000 −
link #ffffff −
link-hover #cccccc −
cta-secondary transparent −
cta-secondary-border #ffffff −
product-shadow rgba(0,0,0,0.4) −
product-shadow-light rgba(0,0,0,0.08) −
audio-glow rgba(255,255,255,0.05) −
trade-up-amber #d4a574 −
app-tile-purple #4c3b8a typography 5 changed
~
display {"family":"Inter","size":80} → {"family":"Cahuenga","size":56} ~
h1 {"family":"Inter","size":40} → {"family":"Cahuenga","size":40} ~
h2 {"family":"Inter","size":32} → {"family":"Cahuenga","size":32} ~
body {"family":"Inter","size":16} → {"family":"Spectral","size":19} ~
label {"family":"JetBrains Mono","size":11} → {"family":"Monaco","size":13} radius 1 changed
~
card 8px → 12px spacing identical
No differences.