Skip to main content

Design language comparison

Contra vs Obsidian OS

Both Contra and Obsidian OS commit to a light-canvas approach, and they pair different display families (GT Standard M vs sans-serif). Beyond surface, motion divides them — Contra is expressive, Obsidian OS is moderate.

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 · light

Obsidian OS

Full Page

#000000

foreground

#ffffff

background

#0000ee

brand

#1d1d1d

foreground

#ff5700

accent

#0d0d10

foreground

#67d243

accent

#383838

background

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 · light

Obsidian OS

Full Page

Display
Ivory LL TT Light
Body
sans-serif
Weights
300

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 · light

Obsidian OS

Full Page

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

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 · light

Obsidian OS

Full Page

Level
moderate
Libraries
Framer Motion

Durations

0.1s

Easings

cubic-bezier(0.4, 0, 0.2, 1)ease-outease

Palette & spacing overlap

Their palettes share 10% 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, 6, 8, 10, 12 px shared) — a rhythm any agent can transfer between the two systems with minimal recalibration.

Shared swatches (2)

#ffffff#000000

Curator verdict

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

Full Contra brief →Full Obsidian OS 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.