Files
Zakaria a46764fb1b
ci / Validate workspace (push) Has been cancelled
landing-page-ci / Validate landing page (push) Has been cancelled
landing-page-deploy / Deploy landing page (push) Has been cancelled
github-metrics / Generate repository metrics SVG (push) Has been cancelled
refresh-contributors-wall / Refresh contributors wall cache bust (push) Waiting to run
first-commit
2026-05-04 14:58:14 -04:00

6.3 KiB
Raw Permalink Blame History

Design System Inspired by OpenAI

Category: AI & LLM Calm, near-monochrome system anchored in deep teal-black with generous white space and editorial typography.

1. Visual Theme & Atmosphere

OpenAI's product surface reads like a research lab dressed for the public — clinical, restrained, deliberately quiet. The page background is a true white (#ffffff) layered against a near-black ink (#0d0d0d) with a subtle teal undertone, so even the text feels slightly cooled rather than aggressively dark. The result is a chromatic neutrality that puts model output, code, and prose front and center, not the chrome around them.

The signature move is the use of Söhne (or its system stand-in inter) at restrained weights — 400 for body, 500 for nav and labels, 600 for emphasis — paired with Signifier, a contemporary serif used for editorial display. Where most AI brands lean futuristic, OpenAI's serif headlines give the product a quietly literary tone, as if every announcement is an essay.

The shape system is uniformly soft: 8px12px radii, 9999px pills for tags and chips, no harsh corners anywhere. Section transitions are denoted by whitespace rather than dividers; when borders appear they are #e5e5e5 hairlines that read as the absence of color rather than its presence.

Key Characteristics:

  • True white canvas (#ffffff) with deep teal-black ink (#0d0d0d)
  • Söhne / Inter at modest weights (400, 500, 600) — restraint over assertion
  • Signifier serif for editorial display headlines
  • Soft 812px radii everywhere; 9999px pills for chips
  • Hairline borders (#e5e5e5) used sparingly; whitespace as primary divider
  • Single-color illustrations in deep teal — no gradients in marks
  • Generous line-height (1.551.65) and tracking near zero

2. Color Palette & Roles

Primary

  • Pure White (#ffffff): Primary background, card surface, button background.
  • Ink Black (#0d0d0d): Primary text, brand mark, primary CTA.
  • Soft Black (#1a1a1a): Secondary heading, alternative ink for non-critical text.

Surface & Background

  • Mist (#fafafa): Section break background, footer surface.
  • Pearl (#f5f5f5): Card surface, elevated panel.
  • Cloud (#ececec): Disabled background, divider tint.

Brand Accent

  • OpenAI Teal (#10a37f): Brand primary, link, highlight badge — the lone color in an otherwise neutral system.
  • Teal Deep (#0a7a5e): Hover and pressed state for the brand color.
  • Teal Soft (#e8f5f0): Surface tint for success badges, highlight callouts.

Neutrals & Text

  • Graphite (#3c3c3c): Body text, default reading color.
  • Slate (#6e6e6e): Secondary text, captions, metadata.
  • Ash (#9b9b9b): Tertiary text, placeholder, disabled label.
  • Stone (#c4c4c4): Decorative dividers, faint icons.

Semantic & Border

  • Border Hairline (#e5e5e5): Standard hairline separator.
  • Border Soft (#ededed): Card outline on white surface.
  • Error (#ef4146): Validation, destructive action.
  • Warning (#f5a623): Soft amber for advisory states.
  • Info (#2563eb): Informational link tone (used sparingly; teal still wins).

3. Typography Rules

Font Family

  • Display / Editorial: Signifier, with fallback: 'Source Serif Pro', Georgia, serif
  • Body / UI: Söhne, with fallback: Inter, system-ui, -apple-system, 'Segoe UI', sans-serif
  • Code / Mono: Söhne Mono, with fallback: ui-monospace, 'JetBrains Mono', Menlo, Consolas, monospace

Hierarchy

Role Font Size Weight Line Height Letter Spacing Notes
Display Signifier 56px (3.5rem) 400 1.08 -0.02em Editorial hero, announcement titles
H1 Söhne 40px (2.5rem) 600 1.15 -0.01em Page heading
H2 Söhne 28px (1.75rem) 600 1.2 -0.005em Section heading
H3 Söhne 20px (1.25rem) 600 1.3 normal Sub-section
Body Large Söhne 18px (1.125rem) 400 1.6 normal Lede paragraphs
Body Söhne 16px (1rem) 400 1.65 normal Standard reading text
Body Small Söhne 14px (0.875rem) 400 1.55 normal Card body, dense UI
Caption Söhne 13px (0.8125rem) 500 1.4 0.01em Metadata, badges
Label Söhne 12px (0.75rem) 500 1.3 0.04em Eyebrow, uppercase nav links
Code Söhne Mono 14px (0.875rem) 400 1.55 normal Code blocks, terminal output

Principles

  • Restraint as identity: weights cap at 600; 700+ feels off-brand. Hierarchy comes from size and color, not weight.
  • Serif for soul, sans for system: Signifier appears only in editorial display moments. The product UI is sans-only.
  • Negative tracking on display: -0.02em on display sizes; tracking returns to zero by 16px.

4. Component Stylings

Buttons

Primary

  • Background: #0d0d0d
  • Text: #ffffff
  • Padding: 10px 18px
  • Radius: 9999px (full pill) on chips, 12px on rectangular CTAs
  • Hover: #1a1a1a background
  • Use: Primary CTA, "Try ChatGPT", "Sign in"

Secondary

  • Background: #ffffff
  • Text: #0d0d0d
  • Border: 1px solid #e5e5e5
  • Padding: 10px 18px
  • Radius: 12px
  • Hover: background #fafafa, border #d4d4d4

Brand Accent

  • Background: #10a37f
  • Text: #ffffff
  • Padding: 10px 18px
  • Radius: 12px
  • Hover: #0a7a5e
  • Use: Highlighted upgrade CTA, success path

Cards

  • Background: #ffffff
  • Border: 1px solid #ededed
  • Radius: 16px
  • Padding: 24px32px
  • Shadow: none by default; on hover 0 4px 16px rgba(13,13,13,0.06)

Inputs

  • Background: #ffffff
  • Border: 1px solid #e5e5e5
  • Radius: 12px
  • Padding: 12px 14px
  • Focus: border #10a37f, ring 0 0 0 3px rgba(16,163,127,0.12)

Pills & Tags

  • Background: #f5f5f5
  • Text: #3c3c3c
  • Padding: 4px 10px
  • Radius: 9999px
  • Font: 12px / 500

5. Spacing & Layout

  • Base unit: 4px. Scale: 4, 8, 12, 16, 24, 32, 48, 64, 96, 128.
  • Container: max-width 1200px, 24px gutter on mobile, 48px on desktop.
  • Section rhythm: 96128px vertical between major sections; 64px on mobile.
  • Grid: 12-column desktop, 4-column mobile, 24px gap.

6. Motion

  • Duration: 150220ms for hover; 280360ms for layout transitions.
  • Easing: cubic-bezier(0.16, 1, 0.3, 1) (smooth out) for entrances.
  • Restraint: no parallax, no scroll-jacking. Subtle fade and translate only.