Caraway vs Substack
57 token-level differences between these two design systems.
Background
#fcfcf9 → #ffffff Text
#1f3438 → #363737 Brand
#1f3438 → #ff6719 Border
#e4e2da → rgba(0, 0, 0, 0.10) Display font
Suisse Works → Cahuenga Body size
16px → 19px colors 46 changed
~
bg #fcfcf9 → #ffffff ~
bg-soft #f7f7f4 → #f6f6f3 ~
brand #1f3438 → #ff6719 ~
text #1f3438 → #363737 ~
text-strong #16282b → #1a1a1a ~
text-muted #5b6f72 → #878787 ~
text-faint #8a999b → #a8a8a8 ~
border #e4e2da → rgba(0, 0, 0, 0.10) ~
border-strong #1f3438 → rgba(0, 0, 0, 0.20) ~
border-soft #efeee7 → rgba(0, 0, 0, 0.06) ~
success #3a7a52 → #0d8050 ~
warning #c8861a → #d97706 ~
danger #b04a3a → #dc2626 ~
info #33524f → #2563eb +
bg-elev #fafaf7 +
bg-cream #fbf9f4 +
surface-warm #fafaf7 +
text-soft #666c70 +
text-link #363737 +
brand-hover #e85412 +
brand-deep #cc4a0e +
brand-tint rgba(255, 103, 25, 0.10) +
brand-tint-strong rgba(255, 103, 25, 0.18) +
border-warm rgba(0, 0, 0, 0.08) +
selection-bg rgba(255, 103, 25, 0.20) +
shadow-soft rgba(0, 0, 0, 0.06) +
shadow-medium rgba(0, 0, 0, 0.10) +
reading-rule rgba(0, 0, 0, 0.08) −
bg-deeper #f0efe9 −
hero-plate #1f3438 −
surface-soft #f7f7f4 −
brand-soft #33524f −
colorway-cream #f3ead9 −
colorway-sage #b9c4ad −
colorway-navy #2b3a52 −
colorway-terracotta #c97b58 −
colorway-marigold #e9b949 −
cta-bg #1f3438 −
cta-text #ffffff −
cta-bg-hover #33524f −
on-cta-hover #ffffff −
cta-secondary-bg #f7f7f4 −
cta-secondary-text #1f3438 −
text-on-brand #ffffff −
link #1f3438 −
link-hover #33524f typography 5 changed
~
display {"family":"Suisse Works","size":64} → {"family":"Cahuenga","size":56} ~
h1 {"family":"Suisse Works","size":48} → {"family":"Cahuenga","size":40} ~
h2 {"family":"Suisse Works","size":20} → {"family":"Cahuenga","size":32} ~
body {"family":"Moderat","size":16} → {"family":"Spectral","size":19} ~
label {"family":"SFMono-Regular","size":13} → {"family":"Monaco","size":13} radius 2 changed
~
button 8px → 6px ~
pill 40px → 9999px spacing 4 changed
~
xs 0px → 4px ~
sm 4px → 8px ~
md 12px → 16px ~
xl 64px → 48px