Diff

v0 vs Hashnode

74 token-level differences between these two design systems.

Role tokens
Background
#fafafa #0f1117
Text
#262626 #ffffff
Brand
#000000 #2962ff
Border
rgba(0, 0, 0, 0.078) rgba(255, 255, 255, 0.08)
Display font
GeistSans Inter
Body size
14px 16px
colors 63 changed
~ bg #fafafa #0f1117
~ surface #f2f2f2 #161a23
~ text #262626 #ffffff
~ text-strong #000000 #ffffff
~ text-muted #7c7c7c #6b7280
~ text-soft #bababa #a8b1bf
~ text-faint #cfcfcf #4b5563
~ brand #000000 #2962ff
~ brand-deep #000000 #1e40af
~ brand-soft rgba(0, 0, 0, 0.08) rgba(41, 98, 255, 0.12)
~ link #000000 #2962ff
~ link-hover #525252 #3b82f6
~ border rgba(0, 0, 0, 0.078) rgba(255, 255, 255, 0.08)
~ border-strong rgba(0, 0, 0, 0.14) rgba(255, 255, 255, 0.15)
+ bg-soft #0a0c12
+ bg-elev-1 #161a23
+ bg-elev-2 #1f2937
+ bg-elev-3 #252b3a
+ surface-light #ffffff
+ text-body #e5e7eb
+ brand-hover #1d4ed8
+ brand-glow rgba(41, 98, 255, 0.32)
+ brand-tint rgba(41, 98, 255, 0.08)
+ cta-bg #2962ff
+ cta-text #ffffff
+ selected #2962ff
+ border-soft rgba(255, 255, 255, 0.04)
+ border-brand rgba(41, 98, 255, 0.40)
+ shadow-soft rgba(0, 0, 0, 0.20)
+ shadow-elev rgba(0, 0, 0, 0.40)
+ shadow-deep rgba(0, 0, 0, 0.60)
+ shadow-glow rgba(41, 98, 255, 0.15)
+ scrim rgba(15, 17, 23, 0.80)
+ success #10b981
+ success-soft rgba(16, 185, 129, 0.12)
+ warning #f59e0b
+ warning-soft rgba(245, 158, 11, 0.12)
+ danger #ef4444
+ danger-soft rgba(239, 68, 68, 0.12)
+ info #2962ff
+ info-soft rgba(41, 98, 255, 0.12)
+ syntax-keyword #c084fc
+ syntax-string #86efac
+ syntax-number #fbbf24
+ syntax-comment #6b7280
+ syntax-fn #60a5fa
bg-pure #ffffff
surface-soft #f0f0f0
surface-strong #e6e6e6
text-medium #525252
text-deep #969696
selected-bg #f2f2f2
disabled #bababa
border-subtle rgba(0, 0, 0, 0.05)
border-focus #000000
success-bg #f0f7f1
success-text #1f6b3e
warning-bg #fef6e4
warning-text #7a5a14
danger-bg #fbebec
danger-text #9a2c34
info-bg #f2f2f2
info-text #262626
typography 5 changed
~ display {"family":"GeistSans","size":48} {"family":"Inter","size":72}
~ h1 {"family":"GeistSans","size":32} {"family":"Inter","size":40}
~ h2 {"family":"GeistSans","size":24} {"family":"Inter","size":32}
~ body {"family":"GeistSans","size":14} {"family":"Inter","size":16}
~ label {"family":"GeistMono","size":12} {"family":"JetBrains Mono","size":12}
radius 1 changed
~ button 6px 8px
spacing 5 changed
~ xs 1px 4px
~ sm 2px 8px
~ md 6px 16px
~ lg 12px 32px
~ xl 20px 48px
↻ Swap direction · Hashnode → v0