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
141 lines
6.3 KiB
Markdown
141 lines
6.3 KiB
Markdown
# 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: 8px–12px 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 8–12px 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.55–1.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: 24px–32px
|
||
- 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**: 96–128px vertical between major sections; 64px on mobile.
|
||
- **Grid**: 12-column desktop, 4-column mobile, 24px gap.
|
||
|
||
## 6. Motion
|
||
|
||
- **Duration**: 150–220ms for hover; 280–360ms 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.
|