Substack vs Klarna
57 token-level differences between these two design systems.
Background
#ffffff → #ffffff Text
#363737 → #0b051d Brand
#ff6719 → #ffa8cd Border
rgba(0, 0, 0, 0.10) → #e4e2e8 Display font
Cahuenga → Klarna Title Body size
19px → 16px colors 49 changed
~
bg-soft #f6f6f3 → #f7f7f8 ~
surface #ffffff → #0b051d ~
text #363737 → #0b051d ~
text-muted #878787 → #4a4458 ~
brand #ff6719 → #ffa8cd ~
brand-deep #cc4a0e → #eb6f9e ~
on-brand #ffffff → #0b051d ~
border rgba(0, 0, 0, 0.10) → #e4e2e8 ~
border-strong rgba(0, 0, 0, 0.20) → #0b051d ~
shadow-soft rgba(0, 0, 0, 0.06) → rgba(11, 5, 29, 0.10) +
bg-pink-wash #fff0f6 +
surface-card #0b051d +
surface-light #ffffff +
text-on-dark #ffffff +
text-subtle #76707f +
brand-strong #ffb3c7 +
brand-soft #ffe2ee +
cta-dark #0b051d +
cta-dark-hover #1c1430 +
on-cta-dark #ffffff +
link #0b051d +
link-hover #eb6f9e +
border-pink #ffa8cd +
semantic-success #1f8a4c +
semantic-warning #b8740f +
semantic-danger #d23c3c +
semantic-info #0b051d +
focus-ring #0b051d +
shadow-ambient rgba(11, 5, 29, 0.06) +
shadow-strong rgba(11, 5, 29, 0.16) −
bg-elev #fafaf7 −
bg-cream #fbf9f4 −
surface-warm #fafaf7 −
text-strong #1a1a1a −
text-soft #666c70 −
text-faint #a8a8a8 −
text-link #363737 −
brand-hover #e85412 −
brand-tint rgba(255, 103, 25, 0.10) −
brand-tint-strong rgba(255, 103, 25, 0.18) −
border-soft rgba(0, 0, 0, 0.06) −
border-warm rgba(0, 0, 0, 0.08) −
selection-bg rgba(255, 103, 25, 0.20) −
success #0d8050 −
warning #d97706 −
danger #dc2626 −
info #2563eb −
shadow-medium rgba(0, 0, 0, 0.10) −
reading-rule rgba(0, 0, 0, 0.08) typography 5 changed
~
display {"family":"Cahuenga","size":56} → {"family":"Klarna Title","size":96} ~
h1 {"family":"Cahuenga","size":40} → {"family":"Klarna Title","size":56} ~
h2 {"family":"Cahuenga","size":32} → {"family":"Klarna Title","size":40} ~
body {"family":"Spectral","size":19} → {"family":"Klarna Title","size":16} ~
label {"family":"Monaco","size":13} → {"family":"SFMono-Regular","size":13} radius 2 changed
~
button 6px → 8px ~
card 12px → 24px spacing 1 changed
~
xl 48px → 64px