Linear vs shadcn/ui
75 token-level differences between these two design systems.
Background
#08090a → #ffffff Text
#f7f8f8 → #0a0a0a Brand
#5e6ad2 → #0a0a0a Border
#23252a → #e4e4e7 Display font
Inter Variable → Geist Body size
15px → 16px colors 64 changed
~
bg #08090a → #ffffff ~
surface #0f1011 → #fafafa ~
surface-strong #141516 → #f4f4f5 ~
text #f7f8f8 → #0a0a0a ~
text-strong #ffffff → #000000 ~
text-secondary #d0d6e0 → #3f3f46 ~
brand #5e6ad2 → #0a0a0a ~
brand-hover #7170ff → #1a1a1a ~
link #828fff → #0a0a0a ~
link-hover #a3acff → #3f3f46 ~
border #23252a → #e4e4e7 ~
border-strong #34343a → #d4d4d8 ~
success #4cb782 → #10b981 ~
warning #f2c94c → #f59e0b ~
info #5e6ad2 → #3b82f6 ~
on-brand #ffffff → #fafafa +
surface-muted #f4f4f5 +
surface-accent #f4f4f5 +
surface-elevated #ffffff +
text-muted #71717a +
text-faint #a1a1aa +
brand-active #27272a +
destructive #ef4444 +
destructive-hover #dc2626 +
destructive-foreground #fafafa +
border-soft #f4f4f5 +
input #e4e4e7 +
input-border #e4e4e7 +
ring #0a0a0a +
selection-bg rgba(10, 10, 10, 0.1) +
shadow-color rgba(0, 0, 0, 0.05) +
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 −
bg-marketing #010102 −
bg-level-1 #0f1011 −
bg-level-2 #141516 −
bg-level-3 #1a1b1d −
bg-overlay rgba(8,9,10,0.72) −
surface-tinted-brand rgba(94,106,210,0.08) −
text-tertiary #8a8f98 −
text-quaternary #62666d −
text-disabled #3d3f44 −
brand-press #4a55c1 −
brand-soft rgba(94,106,210,0.16) −
accent #7170ff −
border-subtle rgba(255,255,255,0.06) −
border-brand #5e6ad2 −
cta-fill #e5e5e6 −
cta-fill-hover #f3f3f4 −
cta-fill-press #cfcfd1 −
cta-text #08090a −
success-bg rgba(76,183,130,0.12) −
warning-bg rgba(242,201,76,0.12) −
danger #eb5757 −
danger-bg rgba(235,87,87,0.12) −
info-bg rgba(94,106,210,0.12) −
chip-bg #1a1b1d −
chip-text #d0d6e0 −
chip-border #34343a typography 5 changed
~
display {"family":"Inter Variable","size":80} → {"family":"Geist","size":56} ~
h1 {"family":"Inter Variable","size":48} → {"family":"Geist","size":40} ~
h2 {"family":"Inter Variable","size":32} → {"family":"Geist","size":32} ~
body {"family":"Inter Variable","size":15} → {"family":"Geist","size":16} ~
label {"family":"Berkeley Mono","size":12} → {"family":"Geist Mono","size":14} radius 1 changed
~
card 24px → 12px spacing 5 changed
~
xs 0px → 4px ~
sm 2px → 8px ~
md 6px → 16px ~
lg 16px → 32px ~
xl 24px → 48px