Apple Music vs Windsurf
60 token-level differences between these two design systems.
Background
#000000 → #f6eede Text
#ffffff → #0b100f Brand
#fa233b → #34e8bb Border
rgba(255,255,255,0.10) → #c0c1c6 Display font
SF Pro → tomatoGrotesk Body size
17px → 16px colors 51 changed
~
bg #000000 → #f6eede ~
bg-soft #1a1a1c → #fbf7ee ~
surface #1d1d1f → #ffffff ~
brand #fa233b → #34e8bb ~
brand-deep #cc1729 → #0fbf97 ~
text #ffffff → #0b100f ~
text-faint rgba(255,255,255,0.56) → #8a8f8b ~
on-brand #ffffff → #003326 ~
border rgba(255,255,255,0.10) → #c0c1c6 ~
border-soft rgba(255,255,255,0.06) → #e3e0d6 ~
link #fa233b → #0b100f ~
link-hover #ff4d63 → #0fbf97 ~
success #3aaa50 → #0fbf97 ~
warning #ff9f0a → #c08a2e ~
danger #ff453a → #d8413f ~
info #0a84ff → #4380b4 +
surface-dark #0b100f +
surface-dark-soft #141a18 +
text-on-dark #ffffff +
text-body #3a423f +
text-muted #5a615d +
text-on-dark-muted rgba(255, 255, 255, 0.7) +
border-dark rgba(255, 255, 255, 0.12) +
ring rgba(67, 128, 180, 0.5) +
shadow-tint rgba(11, 16, 15, 0.10) −
bg-panel #1d1d1f −
bg-elev #2a2a2c −
bg-page #000000 −
surface-glass rgba(29,29,31,0.72) −
surface-glass-light rgba(255,255,255,0.08) −
surface-elev #2a2a2c −
brand-hover #e51e34 −
brand-active #c8172c −
brand-soft rgba(250,35,59,0.16) −
brand-glow rgba(250,35,59,0.40) −
brand-gradient-start #fa233b −
brand-gradient-end #ff7b00 −
brand-gradient-radial-end #ff007a −
text-strong #ffffff −
text-soft rgba(255,255,255,0.78) −
text-disabled rgba(255,255,255,0.32) −
text-on-brand #ffffff −
border-strong rgba(255,255,255,0.18) −
selected rgba(250,35,59,0.16) −
scrim rgba(0,0,0,0.72) −
scrim-light rgba(0,0,0,0.40) −
shadow-card rgba(0,0,0,0.40) −
shadow-elev rgba(0,0,0,0.60) −
shadow-modal rgba(0,0,0,0.80) −
shadow-album rgba(0,0,0,0.50) −
vibrancy-overlay rgba(255,255,255,0.04) typography 5 changed
~
display {"family":"SF Pro","size":80} → {"family":"tomatoGrotesk","size":72} ~
h1 {"family":"SF Pro","size":40} → {"family":"tomatoGrotesk","size":48} ~
h2 {"family":"SF Pro","size":32} → {"family":"tomatoGrotesk","size":40} ~
body {"family":"SF Pro","size":17} → {"family":"Inter","size":16} ~
label {"family":"JetBrains Mono","size":13} → {"family":"SFMono-Regular","size":13} radius identical
No differences.
spacing 4 changed
~
xs 4px → 0px ~
sm 8px → 4px ~
md 16px → 12px ~
xl 48px → 64px