Things vs Sonos
64 token-level differences between these two design systems.
Background
#f2f5f7 → #000000 Text
#303336 → #ffffff Brand
#5c9cf5 → #ffffff Border
#26344a1a → #333333 Display font
Inter → Inter Body size
17px → 16px colors 57 changed
~
bg #f2f5f7 → #000000 ~
surface #e8ecef → #1a1a1a ~
text #303336 → #ffffff ~
text-strong #0a1320 → #ffffff ~
text-muted #26344a80 → #cccccc ~
text-soft #000f24a3 → #999999 ~
brand #5c9cf5 → #ffffff ~
brand-hover #4385e0 → #e5e5e5 ~
on-brand #ffffff → #000000 ~
border #26344a1a → #333333 ~
border-soft #26344a10 → #1f1f1f ~
border-strong #26344a2e → #4d4d4d ~
success #34a853 → #4ade80 ~
warning #f59e0b → #facc15 ~
danger #dc3545 → #ef4444 ~
info #5c9cf5 → #ffffff +
bg-elev #0a0a0a +
bg-alt #111111 +
bg-light #ffffff +
bg-cream #f5f1ec +
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 −
bg-soft #ffffff −
surface-elev #dde2e6 −
surface-card #ffffff −
text-body #3f454d −
text-faint #26344a40 −
brand-soft #dceaff −
brand-softer #eaf2ff −
brand-deep #2c6dbf −
cta-bg #1a1a1f −
cta-text #ffffff −
shadow-icon rgba(20,30,50,0.08) −
shadow-card rgba(20,30,50,0.04) −
shadow-elev rgba(20,30,50,0.10) −
scrim rgba(10,19,32,0.50) −
success-soft #e6f4ea −
warning-soft #fff8e1 −
danger-soft #fde7ea −
info-soft #dceaff typography 3 changed
~
display {"family":"Inter","size":56} → {"family":"Inter","size":80} ~
body {"family":"Inter","size":17} → {"family":"Inter","size":16} ~
label {"family":"SFMono-Regular","size":12} → {"family":"JetBrains Mono","size":11} radius 2 changed
~
button 8px → 6px ~
card 12px → 8px spacing 2 changed
~
lg 48px → 32px ~
xl 96px → 48px