← all systems vercel
edit →

Design System Inspired by Vercel

1. Visual Theme & Atmosphere

Vercel’s website is the visual thesis of developer infrastructure made invisible — a design system so restrained it borders on philosophical. The page is overwhelmingly white (#ffffff) with near-black (#171717) text, creating a gallery-like emptiness where every element earns its pixel. This isn’t minimalism as decoration; it’s minimalism as engineering principle. The Geist design system treats the interface like a compiler treats code — every unnecessary token is stripped away until only structure remains.

The custom Geist font family is the crown jewel. Geist Sans uses aggressive negative letter-spacing (-2.4px to -2.88px at display sizes), creating headlines that feel compressed, urgent, and engineered — like code that’s been minified for production. At body sizes, the tracking relaxes but the geometric precision persists. Geist Mono completes the system as the monospace companion for code, terminal output, and technical labels. Both fonts enable OpenType "liga" (ligatures) globally, adding a layer of typographic sophistication that rewards close reading.

What distinguishes Vercel from other monochrome design systems is its shadow-as-border philosophy. Instead of traditional CSS borders, Vercel uses box-shadow: 0px 0px 0px 1px rgba(0,0,0,0.08) — a zero-offset, zero-blur, 1px-spread shadow that creates a border-like line without the box model implications. This technique allows borders to exist in the shadow layer, enabling smoother transitions, rounded corners without clipping, and a subtler visual weight than traditional borders. The entire depth system is built on layered, multi-value shadow stacks where each layer serves a specific purpose: one for the border, one for soft elevation, one for ambient depth.

Key Characteristics:

2. Color Palette & Roles

Primary

Workflow Accent Colors

Console / Code Colors

Interactive

Neutral Scale

Surface & Overlay

Shadows & Depth

3. Typography Rules

Font Family

Hierarchy

RoleFontSizeWeightLine HeightLetter SpacingNotes
Display HeroGeist48px (3.00rem)6001.00–1.17 (tight)-2.4px to -2.88pxMaximum compression, billboard impact
Section HeadingGeist40px (2.50rem)6001.20 (tight)-2.4pxFeature section titles
Sub-heading LargeGeist32px (2.00rem)6001.25 (tight)-1.28pxCard headings, sub-sections
Sub-headingGeist32px (2.00rem)4001.50-1.28pxLighter sub-headings
Card TitleGeist24px (1.50rem)6001.33-0.96pxFeature cards
Card Title LightGeist24px (1.50rem)5001.33-0.96pxSecondary card headings
Body LargeGeist20px (1.25rem)4001.80 (relaxed)normalIntroductions, feature descriptions
BodyGeist18px (1.13rem)4001.56normalStandard reading text
Body SmallGeist16px (1.00rem)4001.50normalStandard UI text
Body MediumGeist16px (1.00rem)5001.50normalNavigation, emphasized text
Body SemiboldGeist16px (1.00rem)6001.50-0.32pxStrong labels, active states
Button / LinkGeist14px (0.88rem)5001.43normalButtons, links, captions
Button SmallGeist14px (0.88rem)4001.00 (tight)normalCompact buttons
CaptionGeist12px (0.75rem)400–5001.33normalMetadata, tags
Mono BodyGeist Mono16px (1.00rem)4001.50normalCode blocks
Mono CaptionGeist Mono13px (0.81rem)5001.54normalCode labels
Mono SmallGeist Mono12px (0.75rem)5001.00 (tight)normaltext-transform: uppercase, technical labels
Micro BadgeGeist7px (0.44rem)7001.00 (tight)normaltext-transform: uppercase, tiny badges

Principles

4. Component Stylings

Buttons

Primary White (Shadow-bordered)

Primary Dark (Inferred from Geist system)

Pill Button / Badge

Large Pill (Navigation)

Cards & Containers

Inputs & Forms

Image Treatment

Distinctive Components

Workflow Pipeline

Trust Bar / Logo Grid

Metric Cards

5. Layout Principles

Spacing System

Grid & Container

Whitespace Philosophy

Border Radius Scale

6. Depth & Elevation

LevelTreatmentUse
Flat (Level 0)No shadowPage background, text blocks
Ring (Level 1)rgba(0,0,0,0.08) 0px 0px 0px 1pxShadow-as-border for most elements
Light Ring (Level 1b)rgb(235,235,235) 0px 0px 0px 1pxLighter ring for tabs, images
Subtle Card (Level 2)Ring + rgba(0,0,0,0.04) 0px 2px 2pxStandard cards with minimal lift
Full Card (Level 3)Ring + Subtle + rgba(0,0,0,0.04) 0px 8px 8px -8px + inner #fafafa ringFeatured cards, highlighted panels
Focus (Accessibility)2px solid hsla(212, 100%, 48%, 1) outlineKeyboard focus on all interactive elements

Shadow Philosophy: Vercel has arguably the most sophisticated shadow system in modern web design. Rather than using shadows for elevation in the traditional Material Design sense, Vercel uses multi-value shadow stacks where each layer has a distinct architectural purpose: one creates the “border” (0px spread, 1px), another adds ambient softness (2px blur), another handles depth at distance (8px blur with negative spread), and an inner ring (#fafafa) creates the subtle highlight that makes the card “glow” from within. This layered approach means cards feel built, not floating.

Decorative Depth

7. Do’s and Don’ts

Do

Don’t

8. Responsive Behavior

Breakpoints

NameWidthKey Changes
Mobile Small<400pxTight single column, minimal padding
Mobile400–600pxStandard mobile, stacked layout
Tablet Small600–768px2-column grids begin
Tablet768–1024pxFull card grids, expanded padding
Desktop Small1024–1200pxStandard desktop layout
Desktop1200–1400pxFull layout, maximum content width
Large Desktop>1400pxCentered, generous margins

Touch Targets

Collapsing Strategy

Image Behavior

9. Agent Prompt Guide

Quick Color Reference

Example Component Prompts

Iteration Guide

  1. Always use shadow-as-border instead of CSS border — 0px 0px 0px 1px rgba(0,0,0,0.08) is the foundation
  2. Letter-spacing scales with font size: -2.4px at 48px, -1.28px at 32px, -0.96px at 24px, normal at 14px
  3. Three weights only: 400 (read), 500 (interact), 600 (announce)
  4. Color is functional, never decorative — workflow colors (Red/Pink/Blue) mark pipeline stages only
  5. The inner #fafafa ring in card shadows is what gives Vercel cards their subtle inner glow
  6. Geist Mono uppercase for technical labels, Geist Sans for everything else