Diff

Hashnode vs Vercel

72 token-level differences between these two design systems.

Role tokens
Background
#0f1117 #fafafa
Text
#ffffff #171717
Brand
#2962ff #0070f3
Border
rgba(255, 255, 255, 0.08) hsla(0, 0%, 90%, 1)
Display font
Inter Geist
Body size
16px 16px
colors 65 changed
~ bg #0f1117 #fafafa
~ surface #161a23 #ffffff
~ text #ffffff #171717
~ text-faint #4b5563 #a3a3a3
~ brand #2962ff #0070f3
~ brand-hover #1d4ed8 #0061d5
~ brand-deep #1e40af #0050b3
~ brand-soft rgba(41, 98, 255, 0.12) rgba(0, 112, 243, 0.10)
~ brand-tint rgba(41, 98, 255, 0.08) rgba(0, 112, 243, 0.06)
~ link #2962ff #0070f3
~ link-hover #3b82f6 #0070f3
~ cta-bg #2962ff #171717
~ border rgba(255, 255, 255, 0.08) hsla(0, 0%, 90%, 1)
~ border-soft rgba(255, 255, 255, 0.04) hsla(0, 0%, 95%, 1)
~ border-strong rgba(255, 255, 255, 0.15) hsla(0, 0%, 80%, 1)
~ shadow-elev rgba(0, 0, 0, 0.40) rgba(0, 0, 0, 0.06)
~ shadow-deep rgba(0, 0, 0, 0.60) rgba(0, 0, 0, 0.10)
~ scrim rgba(15, 17, 23, 0.80) rgba(0, 0, 0, 0.40)
~ success #10b981 #0070f3
~ success-soft rgba(16, 185, 129, 0.12) rgba(0, 112, 243, 0.10)
~ warning #f59e0b #f5a623
~ warning-soft rgba(245, 158, 11, 0.12) rgba(245, 166, 35, 0.10)
~ danger #ef4444 #e00
~ danger-soft rgba(239, 68, 68, 0.12) rgba(238, 0, 0, 0.10)
~ info #2962ff #0070f3
~ info-soft rgba(41, 98, 255, 0.12) rgba(0, 112, 243, 0.10)
+ bg-pure #ffffff
+ bg-elev #f5f5f5
+ 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
+ focus hsla(212, 100%, 48%, 1)
+ 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)
+ 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%)
bg-soft #0a0c12
bg-elev-1 #161a23
bg-elev-2 #1f2937
bg-elev-3 #252b3a
surface-light #ffffff
text-strong #ffffff
text-body #e5e7eb
text-soft #a8b1bf
text-muted #6b7280
brand-glow rgba(41, 98, 255, 0.32)
selected #2962ff
border-brand rgba(41, 98, 255, 0.40)
shadow-soft rgba(0, 0, 0, 0.20)
shadow-glow rgba(41, 98, 255, 0.15)
syntax-keyword #c084fc
syntax-string #86efac
syntax-number #fbbf24
syntax-comment #6b7280
syntax-fn #60a5fa
typography 5 changed
~ display {"family":"Inter","size":72} {"family":"Geist","size":72}
~ h1 {"family":"Inter","size":40} {"family":"Geist","size":40}
~ h2 {"family":"Inter","size":32} {"family":"Geist","size":32}
~ body {"family":"Inter","size":16} {"family":"Geist","size":16}
~ label {"family":"JetBrains Mono","size":12} {"family":"Geist Mono","size":11}
radius 2 changed
~ button 8px 6px
~ card 12px 8px
spacing identical
No differences.
↻ Swap direction · Vercel → Hashnode