Diff

Semafor vs Modal

92 token-level differences between these two design systems.

Role tokens
Background
#f8f5d7 #0c0c0c
Text
#1f1d1a #ffffff
Brand
#3a6d78 #7fee64
Border
#d8d0a8 rgba(255, 255, 255, 0.1)
Display font
FeatureFlatHeadline Söhne
Body size
18px 16px
colors 80 changed
~ bg #f8f5d7 #0c0c0c
~ text #1f1d1a #ffffff
~ text-strong #000000 #ffffff
~ text-muted #5a5651 #737373
~ text-soft #7a756f #a3a3a3
~ text-faint #a39e96 #525252
~ brand #3a6d78 #7fee64
~ brand-hover #2d5a64 #6dd954
~ brand-active #1f4750 #5cc548
~ on-brand #ffffff #0c0c0c
~ border #d8d0a8 rgba(255, 255, 255, 0.1)
~ border-strong #7a756f rgba(255, 255, 255, 0.2)
~ success #2a8a4f #7fee64
~ warning #cc7a00 #fbbf24
~ danger #a62d2d #f87171
~ info #3a6d78 #60a5fa
+ bg-elev-1 #141414
+ bg-elev-2 #1c1c1c
+ bg-elev-3 #262626
+ bg-elev-4 #333333
+ bg-overlay rgba(0, 0, 0, 0.78)
+ text-on-brand #0c0c0c
+ brand-tint rgba(127, 238, 100, 0.12)
+ brand-tint-strong rgba(127, 238, 100, 0.2)
+ brand-glow rgba(127, 238, 100, 0.4)
+ accent-output #7fee64
+ accent-prompt #a3eb8e
+ accent-syntax-keyword #7fee64
+ accent-syntax-string #fbbf24
+ accent-syntax-comment #737373
+ accent-syntax-fn #a3eb8e
+ border-subtle rgba(255, 255, 255, 0.05)
+ border-brand rgba(127, 238, 100, 0.4)
+ border-focus #7fee64
+ success-bg rgba(127, 238, 100, 0.12)
+ warning-bg rgba(251, 191, 36, 0.12)
+ danger-bg rgba(248, 113, 113, 0.12)
+ info-bg rgba(96, 165, 250, 0.12)
+ on-bg #ffffff
+ on-surface #ffffff
+ on-warning #0c0c0c
+ on-danger #ffffff
bg-section #f8f5d7
bg-section-flagship #f8f5d7
bg-section-africa #f8f5d7
bg-dark #1f1d1a
bg-darkest #0d0c0a
surface #f8f5d7
surface-paper #ffffff
surface-soft #f5f1c9
surface-strong #e8e3b5
surface-quote #fefbe8
surface-card-elevated #fcfae0
text-on-teal #ffffff
text-on-dark #f8f5d7
brand-soft #cce0e4
brand-deep #1a3a44
link #3a6d78
link-hover #2d5a64
link-visited #7a756f
on-dark #f8f5d7
border-soft #e8e2c2
border-rule #1f1d1a
border-teal #3a6d78
shadow-card rgba(31,29,26,0.06)
shadow-elev rgba(31,29,26,0.1)
shadow-modal rgba(31,29,26,0.3)
scrim rgba(31,29,26,0.6)
success-soft #dff0e7
warning-soft #fde9cc
danger-soft #f0d4d4
info-soft #cce0e4
flag-flagship #3a6d78
flag-africa #c46b3a
flag-principals #3a6d78
flag-net-zero #2a8a4f
flag-tech #5a4a8a
flag-business #3a6d78
flag-media #a62d2d
flag-gulf #c46b3a
typography 5 changed
~ display {"family":"FeatureFlatHeadline","size":72} {"family":"Söhne","size":88}
~ h1 {"family":"FeatureFlatHeadline","size":28} {"family":"Söhne","size":56}
~ h2 {"family":"FeatureFlatHeadline","size":22} {"family":"Söhne","size":36}
~ body {"family":"FeatureFlatText","size":18} {"family":"Söhne","size":16}
~ label {"family":"Courier New","size":11} {"family":"Modal Mono","size":11}
radius 2 changed
~ button 4px 6px
~ card 6px 12px
spacing 5 changed
~ xs 2px 0px
~ sm 4px 2px
~ md 12px 8px
~ lg 24px 20px
~ xl 40px 32px
↻ Swap direction · Modal → Semafor