Cal.com vs Strava
64 token-level differences between these two design systems.
Background
#f4f4f4 → #ffffff Text
#111111 → #242428 Brand
#111111 → #fc4c02 Border
rgba(0, 0, 0, 0.08) → #dfdfe4 Display font
Cal Sans → Inter Body size
16px → 16px colors 57 changed
~
bg #f4f4f4 → #ffffff ~
surface-soft #f8f9fa → #f7f7fa ~
surface-strong #e5e7eb → #eeeeee ~
text #111111 → #242428 ~
text-strong #000000 → #0e0e10 ~
text-soft #6b7280 → #9a9aa3 ~
text-muted #898989 → #6d6d78 ~
brand #111111 → #fc4c02 ~
brand-active #242424 → #c33b00 ~
link #0000ee → #242428 ~
link-hover #0000aa → #fc4c02 ~
border rgba(0, 0, 0, 0.08) → #dfdfe4 ~
border-soft #f3f4f6 → #eeeeef ~
border-strong #e5e7eb → #c8c8d0 +
bg-strong #f7f7fa +
surface-elev #ffffff +
brand-hover #e04401 +
brand-pale #fde6d9 +
brand-deep #7d2600 +
brand-soft #fff1ea +
text-on-orange #ffffff +
border-input #9a9aa3 +
kudos-orange #fc4c02 +
segment-crown-gold #fdb515 +
pr-record #fc4c02 +
achievement-gold #fdb515 +
achievement-silver #c0c0c0 +
achievement-bronze #cd7f32 +
map-route #fc4c02 +
map-route-shadow rgba(0,0,0,0.4) +
scrim rgba(36,36,40,0.6) +
shadow-card rgba(0,0,0,0.08) +
shadow-elev rgba(0,0,0,0.16) +
success #1cb350 +
warning #fdb515 +
warning-soft #fff7e6 +
danger #d22d2d +
info #1e6dd8 −
surface-card #f5f5f5 −
surface-dark #101010 −
surface-dark-elev #1a1a1a −
text-body #374151 −
text-faint #9ca3af −
brand-disabled #e5e7eb −
on-brand #ffffff −
on-dark #ffffff −
on-dark-soft #a1a1aa −
link-visited #551a8b −
brand-accent #3b82f6 −
badge-orange #fb923c −
badge-pink #ec4899 −
badge-violet #8b5cf6 −
badge-emerald #34d399 −
semantic-success #10b981 −
semantic-warning #f59e0b −
semantic-danger #ef4444 −
semantic-info #3b82f6 typography 4 changed
~
display {"family":"Cal Sans","size":64} → {"family":"Inter","size":72} ~
h1 {"family":"Cal Sans","size":36} → {"family":"Inter","size":40} ~
h2 {"family":"Cal Sans","size":28} → {"family":"Inter","size":32} ~
label {"family":"JetBrains Mono","size":11} → {"family":"Inter","size":11} radius 1 changed
~
card 20px → 12px spacing 2 changed
~
lg 48px → 32px ~
xl 96px → 48px