shadcn/ui vs Todoist
72 token-level differences between these two design systems.
Background
#ffffff → #fefdfc Text
#0a0a0a → #25221e Brand
#0a0a0a → #e44432 Border
#e4e4e7 → #eae9e8 Display font
Geist → Graphik Body size
16px → 16px colors 63 changed
~
bg #ffffff → #fefdfc ~
surface #fafafa → #ffffff ~
text #0a0a0a → #25221e ~
text-muted #71717a → #565656 ~
text-faint #a1a1aa → #c1c0c0 ~
brand #0a0a0a → #e44432 ~
brand-hover #1a1a1a → #ee5244 ~
brand-active #27272a → #d1453b ~
on-brand #fafafa → #ffffff ~
border #e4e4e7 → #eae9e8 ~
border-soft #f4f4f5 → #f1f0ef ~
border-strong #d4d4d8 → #dadad9 ~
shadow-color rgba(0, 0, 0, 0.05) → rgba(0, 0, 0, 0.24) ~
success #10b981 → #3a7400 ~
warning #f59e0b → #f7b84f ~
info #3b82f6 → #316fea +
bg-warm #fcf8f3 +
surface-card #fcfcfc +
surface-cream #fff9f3 +
surface-cream-mid #fff5eb +
surface-peach #fae8d6 +
text-soft #8c8b8b +
brand-tint-100 #fef6ef +
brand-tint-200 #fdf0e4 +
brand-tint-300 #fbe8d7 +
brand-deep #9a3b00 +
accent-yellow #ffc93e +
accent-green #6b8767 +
accent-pink #ffada4 +
accent-blue #316fea +
ghost-bg #25221e12 +
prio-1 #ffd6d3 +
prio-2 #fbe7ce +
prio-3 #dde6f9 +
prio-4 #f2efed +
scrim rgba(34, 40, 41, 0.80) +
success-soft #f6f9f7 +
warning-soft #fff9f0 +
danger #de483a +
danger-soft #fdf5f0 +
info-soft #f1f7fe −
surface-strong #f4f4f5 −
surface-muted #f4f4f5 −
surface-accent #f4f4f5 −
surface-elevated #ffffff −
text-strong #000000 −
text-secondary #3f3f46 −
link #0a0a0a −
link-hover #3f3f46 −
destructive #ef4444 −
destructive-hover #dc2626 −
destructive-foreground #fafafa −
input #e4e4e7 −
input-border #e4e4e7 −
ring #0a0a0a −
selection-bg rgba(10, 10, 10, 0.1) −
shadow-color-md rgba(0, 0, 0, 0.1) −
shadow-color-lg rgba(0, 0, 0, 0.15) −
chart-1 #e76e50 −
chart-2 #2a9d90 −
chart-3 #274754 −
chart-4 #e8c468 −
chart-5 #f4a462 typography 5 changed
~
display {"family":"Geist","size":56} → {"family":"Graphik","size":80} ~
h1 {"family":"Geist","size":40} → {"family":"Graphik","size":55} ~
h2 {"family":"Geist","size":32} → {"family":"Graphik","size":38} ~
body {"family":"Geist","size":16} → {"family":"Graphik","size":16} ~
label {"family":"Geist Mono","size":14} → {"family":"SFMono-Regular","size":13} radius identical
No differences.
spacing 4 changed
~
xs 4px → 0px ~
sm 8px → 4px ~
md 16px → 12px ~
xl 48px → 64px