Diff

Vercel vs Motion

78 token-level differences between these two design systems.

Role tokens
Background
#fafafa #ffffff
Text
#171717 #0d1117
Brand
#0070f3 #16a34a
Border
hsla(0, 0%, 90%, 1) #e2e8e5
Display font
Geist Inter Display
Body size
16px 16px
colors 71 changed
~ bg #fafafa #ffffff
~ bg-elev #f5f5f5 #ffffff
~ surface #ffffff #f8faf9
~ text #171717 #0d1117
~ text-faint #a3a3a3 #8d97a3
~ brand #0070f3 #16a34a
~ brand-hover #0061d5 #138a3f
~ brand-deep #0050b3 #0f6e34
~ brand-soft rgba(0, 112, 243, 0.10) #dcf2e3
~ link #0070f3 #1d4ed8
~ link-hover #0070f3 #1e40af
~ border hsla(0, 0%, 90%, 1) #e2e8e5
~ border-soft hsla(0, 0%, 95%, 1) #eef2ee
~ border-strong hsla(0, 0%, 80%, 1) #c1cdc6
~ shadow-deep rgba(0, 0, 0, 0.10) rgba(13, 17, 23, 0.16)
~ success #0070f3 #16a34a
~ warning #f5a623 #d97706
~ warning-soft rgba(245, 166, 35, 0.10) #fef3c7
~ danger #e00 #dc2626
~ danger-soft rgba(238, 0, 0, 0.10) #fee2e2
~ info #0070f3 #1d4ed8
+ bg-soft #f8faf9
+ bg-strong #eef2ee
+ bg-dark #0d1117
+ bg-dark-elev #161b22
+ text-body #1f2937
+ text-muted #56636e
+ brand-active #0f6e34
+ ai-purple #7c3aed
+ ai-purple-hover #6d28d9
+ ai-purple-active #5b21b6
+ ai-soft #ede9fe
+ on-dark #f8faf9
+ gradient-stop-1 #16a34a
+ gradient-stop-2 #7c3aed
+ gradient-hero linear-gradient(105deg, #16a34a 0%, #4f46e5 50%, #7c3aed 100%)
+ pastel-mint #dcf2e3
+ pastel-lavender #ede9fe
+ pastel-sky #dbeafe
+ pastel-peach #fde6d3
+ pastel-butter #fef3c7
+ shadow-tint rgba(13, 17, 23, 0.06)
+ selection rgba(22, 163, 74, 0.18)
+ ring-brand rgba(22, 163, 74, 0.45)
+ ring-ai rgba(124, 58, 237, 0.45)
bg-pure #ffffff
bg-deeper #ededed
bg-ink #0a0a0a
bg-pure-black #000000
surface-elev #fafafa
text-pure #000000
text-secondary #525252
text-tertiary #737373
text-on-dark #ededed
text-on-dark-soft #a3a3a3
brand-tint rgba(0, 112, 243, 0.06)
focus hsla(212, 100%, 48%, 1)
cta-bg #171717
cta-text #ffffff
cta-bg-secondary #ffffff
cta-text-secondary #171717
border-deep hsla(0, 0%, 70%, 1)
shadow-ambient rgba(0, 0, 0, 0.04)
shadow-card rgba(0, 0, 0, 0.04)
shadow-elev rgba(0, 0, 0, 0.06)
scrim rgba(0, 0, 0, 0.40)
gradient-conic conic-gradient(from 230deg at 50% 50%, #0070f3, #00b8ff, #7928ca, #ff0080, #0070f3)
gradient-blue linear-gradient(135deg, #0070f3 0%, #00b8ff 100%)
gradient-edge linear-gradient(180deg, transparent 0%, rgba(0, 112, 243, 0.20) 100%)
success-soft rgba(0, 112, 243, 0.10)
info-soft rgba(0, 112, 243, 0.10)
typography 5 changed
~ display {"family":"Geist","size":72} {"family":"Inter Display","size":80}
~ h1 {"family":"Geist","size":40} {"family":"Inter Display","size":40}
~ h2 {"family":"Geist","size":32} {"family":"Inter Display","size":32}
~ body {"family":"Geist","size":16} {"family":"Inter","size":16}
~ label {"family":"Geist Mono","size":11} {"family":"JetBrains Mono","size":16}
radius 2 changed
~ button 6px 10px
~ card 8px 14px
spacing identical
No differences.
↻ Swap direction · Motion → Vercel