Skip to main content

Design language comparison

Contra vs Vercel

Contra runs a light-canvas system while Vercel chose both, and they pair different display families (GT Standard M vs Geist). Beyond surface, motion levels are both expressive.

Palette · side by side

Up to 8 dominant swatches each

Side A · light

Contra

Full Page

#14171f

foreground

#ffffff

background

#677084

foreground

#373f51

foreground

#d0d4dc

foreground

#000000

foreground

#9ba2b0

foreground

#e5e7eb

neutral

Side B · both

Vercel

Full Page

#171717

foreground

#4d4d4d

foreground

#ffffff

background

#666666

foreground

#808080

foreground

#000000

foreground

#ebebeb

background

#a8a8a8

neutral

Typography · side by side

Primary family + weight ladder + sample

Side A · light

Contra

Full Page

Display
GT Standard L
Body
GT Standard M
Weights
400 · 500 · 600

Sample

The quick brown fox jumps over the lazy dog.

1234567890 — Body sample renders in the captured family if your browser has it; otherwise system fallback signals the weight ladder.

Side B · both

Vercel

Full Page

Display
Geist
Body
Geist Mono
Mono
Geist Mono
Weights
400 · 500 · 600

Sample

The quick brown fox jumps over the lazy dog.

1234567890 — Body sample renders in the captured family if your browser has it; otherwise system fallback signals the weight ladder.

Spacing scale · side by side

Base unit + first 8 scale values

Side A · light

Contra

Full Page

Base unit
4 px
Container max
1848 px
2px
4px
6px
8px
10px
12px
16px
20px

Side B · both

Vercel

Full Page

Base unit
4 px
Container max
1080 px
2px
4px
6px
8px
10px
12px
14px
16px

Motion vocabulary · side by side

Level + durations + easings

Side A · light

Contra

Full Page

Level
expressive
Libraries

Durations

0.17s0.2s0.3s0.32s0.35s

Easings

easeease-in-outease-out

Side B · both

Vercel

Full Page

Level
expressive
Libraries

Durations

0.09s0.1s0.15s0.2s0.4s

Easings

easeease-in-outcubic-bezier(0.33, 0.12, …cubic-bezier(0.4, 0, 0.2, 1)

Palette & spacing overlap

Their palettes share 15% of swatches at the dominant tier — a quiet signal both teams drew from the same neutral library before applying brand accents. Their spacing scales overlap by 83% (2, 4, 6, 8, 10 px shared) — a rhythm any agent can transfer between the two systems with minimal recalibration.

Shared swatches (3)

#ffffff#000000#666666

Curator verdict

Pick a side. Mixing Contra's light-first canvas with Vercel's expressive motion vocabulary produces visual whiplash. Adopt one system as your primary, study the other for individual technique transfers (e.g. Contra's spacing, Vercel's shadow).

Full Contra brief →Full Vercel brief →Back to gallery

AI2 Design counts anonymous traffic always — no cookies, no identifiers, no fingerprinting. For optional session insights (PostHog, EU region) — page funnel, performance — turn on opt-in analytics below. Cookie policy.