first commit

This commit is contained in:
necatiozmen
2026-03-31 19:37:25 +03:00
commit 1145c998a1
128 changed files with 51549 additions and 0 deletions

310
design-md/vercel/DESIGN.md Normal file
View File

@@ -0,0 +1,310 @@
# Design System: 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:**
- Geist Sans with extreme negative letter-spacing (-2.4px to -2.88px at display) — text as compressed infrastructure
- Geist Mono for code and technical labels with OpenType `"liga"` globally
- Shadow-as-border technique: `box-shadow 0px 0px 0px 1px` replaces traditional borders throughout
- Multi-layer shadow stacks for nuanced depth (border + elevation + ambient in single declarations)
- Near-pure white canvas with `#171717` text — not quite black, creating micro-contrast softness
- Workflow-specific accent colors: Ship Red (`#ff5b4f`), Preview Pink (`#de1d8d`), Develop Blue (`#0a72ef`)
- Focus ring system using `hsla(212, 100%, 48%, 1)` — a saturated blue for accessibility
- Pill badges (9999px) with tinted backgrounds for status indicators
## 2. Color Palette & Roles
### Primary
- **Vercel Black** (`#171717`): Primary text, headings, dark surface backgrounds. Not pure black — the slight warmth prevents harshness.
- **Pure White** (`#ffffff`): Page background, card surfaces, button text on dark.
- **True Black** (`#000000`): Secondary use, `--geist-console-text-color-default`, used in specific console/code contexts.
### Workflow Accent Colors
- **Ship Red** (`#ff5b4f`): `--ship-text`, the "ship to production" workflow step — warm, urgent coral-red.
- **Preview Pink** (`#de1d8d`): `--preview-text`, the preview deployment workflow — vivid magenta-pink.
- **Develop Blue** (`#0a72ef`): `--develop-text`, the development workflow — bright, focused blue.
### Console / Code Colors
- **Console Blue** (`#0070f3`): `--geist-console-text-color-blue`, syntax highlighting blue.
- **Console Purple** (`#7928ca`): `--geist-console-text-color-purple`, syntax highlighting purple.
- **Console Pink** (`#eb367f`): `--geist-console-text-color-pink`, syntax highlighting pink.
### Interactive
- **Link Blue** (`#0072f5`): Primary link color with underline decoration.
- **Focus Blue** (`hsla(212, 100%, 48%, 1)`): `--ds-focus-color`, focus ring on interactive elements.
- **Ring Blue** (`rgba(147, 197, 253, 0.5)`): `--tw-ring-color`, Tailwind ring utility.
### Neutral Scale
- **Gray 900** (`#171717`): Primary text, headings, nav text.
- **Gray 600** (`#4d4d4d`): Secondary text, description copy.
- **Gray 500** (`#666666`): Tertiary text, muted links.
- **Gray 400** (`#808080`): Placeholder text, disabled states.
- **Gray 100** (`#ebebeb`): Borders, card outlines, dividers.
- **Gray 50** (`#fafafa`): Subtle surface tint, inner shadow highlight.
### Surface & Overlay
- **Overlay Backdrop** (`hsla(0, 0%, 98%, 1)`): `--ds-overlay-backdrop-color`, modal/dialog backdrop.
- **Selection Text** (`hsla(0, 0%, 95%, 1)`): `--geist-selection-text-color`, text selection highlight.
- **Badge Blue Bg** (`#ebf5ff`): Pill badge background, tinted blue surface.
- **Badge Blue Text** (`#0068d6`): Pill badge text, darker blue for readability.
### Shadows & Depth
- **Border Shadow** (`rgba(0, 0, 0, 0.08) 0px 0px 0px 1px`): The signature — replaces traditional borders.
- **Subtle Elevation** (`rgba(0, 0, 0, 0.04) 0px 2px 2px`): Minimal lift for cards.
- **Card Stack** (`rgba(0,0,0,0.08) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 2px, rgba(0,0,0,0.04) 0px 8px 8px -8px, #fafafa 0px 0px 0px 1px`): Full multi-layer card shadow.
- **Ring Border** (`rgb(235, 235, 235) 0px 0px 0px 1px`): Light gray ring-border for tabs and images.
## 3. Typography Rules
### Font Family
- **Primary**: `Geist`, with fallbacks: `Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol`
- **Monospace**: `Geist Mono`, with fallbacks: `ui-monospace, SFMono-Regular, Roboto Mono, Menlo, Monaco, Liberation Mono, DejaVu Sans Mono, Courier New`
- **OpenType Features**: `"liga"` enabled globally on all Geist text; `"tnum"` for tabular numbers on specific captions.
### Hierarchy
| Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
|------|------|------|--------|-------------|----------------|-------|
| Display Hero | Geist | 48px (3.00rem) | 600 | 1.001.17 (tight) | -2.4px to -2.88px | Maximum compression, billboard impact |
| Section Heading | Geist | 40px (2.50rem) | 600 | 1.20 (tight) | -2.4px | Feature section titles |
| Sub-heading Large | Geist | 32px (2.00rem) | 600 | 1.25 (tight) | -1.28px | Card headings, sub-sections |
| Sub-heading | Geist | 32px (2.00rem) | 400 | 1.50 | -1.28px | Lighter sub-headings |
| Card Title | Geist | 24px (1.50rem) | 600 | 1.33 | -0.96px | Feature cards |
| Card Title Light | Geist | 24px (1.50rem) | 500 | 1.33 | -0.96px | Secondary card headings |
| Body Large | Geist | 20px (1.25rem) | 400 | 1.80 (relaxed) | normal | Introductions, feature descriptions |
| Body | Geist | 18px (1.13rem) | 400 | 1.56 | normal | Standard reading text |
| Body Small | Geist | 16px (1.00rem) | 400 | 1.50 | normal | Standard UI text |
| Body Medium | Geist | 16px (1.00rem) | 500 | 1.50 | normal | Navigation, emphasized text |
| Body Semibold | Geist | 16px (1.00rem) | 600 | 1.50 | -0.32px | Strong labels, active states |
| Button / Link | Geist | 14px (0.88rem) | 500 | 1.43 | normal | Buttons, links, captions |
| Button Small | Geist | 14px (0.88rem) | 400 | 1.00 (tight) | normal | Compact buttons |
| Caption | Geist | 12px (0.75rem) | 400500 | 1.33 | normal | Metadata, tags |
| Mono Body | Geist Mono | 16px (1.00rem) | 400 | 1.50 | normal | Code blocks |
| Mono Caption | Geist Mono | 13px (0.81rem) | 500 | 1.54 | normal | Code labels |
| Mono Small | Geist Mono | 12px (0.75rem) | 500 | 1.00 (tight) | normal | `text-transform: uppercase`, technical labels |
| Micro Badge | Geist | 7px (0.44rem) | 700 | 1.00 (tight) | normal | `text-transform: uppercase`, tiny badges |
### Principles
- **Compression as identity**: Geist Sans at display sizes uses -2.4px to -2.88px letter-spacing — the most aggressive negative tracking of any major design system. This creates text that feels _minified_, like code optimized for production. The tracking progressively relaxes as size decreases: -1.28px at 32px, -0.96px at 24px, -0.32px at 16px, and normal at 14px.
- **Ligatures everywhere**: Every Geist text element enables OpenType `"liga"`. Ligatures aren't decorative — they're structural, creating tighter, more efficient glyph combinations.
- **Three weights, strict roles**: 400 (body/reading), 500 (UI/interactive), 600 (headings/emphasis). No bold (700) except for tiny micro-badges. This narrow weight range creates hierarchy through size and tracking, not weight.
- **Mono for identity**: Geist Mono in uppercase with `"tnum"` or `"liga"` serves as the "developer console" voice — compact technical labels that connect the marketing site to the product.
## 4. Component Stylings
### Buttons
**Primary White (Shadow-bordered)**
- Background: `#ffffff`
- Text: `#171717`
- Padding: 0px 6px (minimal — content-driven width)
- Radius: 6px (subtly rounded)
- Shadow: `rgb(235, 235, 235) 0px 0px 0px 1px` (ring-border)
- Hover: background shifts to `var(--ds-gray-1000)` (dark)
- Focus: `2px solid var(--ds-focus-color)` outline + `var(--ds-focus-ring)` shadow
- Use: Standard secondary button
**Primary Dark (Inferred from Geist system)**
- Background: `#171717`
- Text: `#ffffff`
- Padding: 8px 16px
- Radius: 6px
- Use: Primary CTA ("Start Deploying", "Get Started")
**Pill Button / Badge**
- Background: `#ebf5ff` (tinted blue)
- Text: `#0068d6`
- Padding: 0px 10px
- Radius: 9999px (full pill)
- Font: 12px weight 500
- Use: Status badges, tags, feature labels
**Large Pill (Navigation)**
- Background: transparent or `#171717`
- Radius: 64px100px
- Use: Tab navigation, section selectors
### Cards & Containers
- Background: `#ffffff`
- Border: via shadow — `rgba(0, 0, 0, 0.08) 0px 0px 0px 1px`
- Radius: 8px (standard), 12px (featured/image cards)
- Shadow stack: `rgba(0,0,0,0.08) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 2px, #fafafa 0px 0px 0px 1px`
- Image cards: `1px solid #ebebeb` with 12px top radius
- Hover: subtle shadow intensification
### Inputs & Forms
- Radio: standard styling with focus `var(--ds-gray-200)` background
- Focus shadow: `1px 0 0 0 var(--ds-gray-alpha-600)`
- Focus outline: `2px solid var(--ds-focus-color)` — consistent blue focus ring
- Border: via shadow technique, not traditional border
### Navigation
- Clean horizontal nav on white, sticky
- Vercel logotype left-aligned, 262x52px
- Links: Geist 14px weight 500, `#171717` text
- Active: weight 600 or underline
- CTA: dark pill buttons ("Start Deploying", "Contact Sales")
- Mobile: hamburger menu collapse
- Product dropdowns with multi-level menus
### Image Treatment
- Product screenshots with `1px solid #ebebeb` border
- Top-rounded images: `12px 12px 0px 0px` radius
- Dashboard/code preview screenshots dominate feature sections
- Soft gradient backgrounds behind hero images (pastel multi-color)
### Distinctive Components
**Workflow Pipeline**
- Three-step horizontal pipeline: Develop → Preview → Ship
- Each step has its own accent color: Blue → Pink → Red
- Connected with lines/arrows
- The visual metaphor for Vercel's core value proposition
**Trust Bar / Logo Grid**
- Company logos (Perplexity, ChatGPT, Cursor, etc.) in grayscale
- Horizontal scroll or grid layout
- Subtle `#ebebeb` border separation
**Metric Cards**
- Large number display (e.g., "10x faster")
- Geist 48px weight 600 for the metric
- Description below in gray body text
- Shadow-bordered card container
## 5. Layout Principles
### Spacing System
- Base unit: 8px
- Scale: 1px, 2px, 3px, 4px, 5px, 6px, 8px, 10px, 12px, 14px, 16px, 32px, 36px, 40px
- Notable gap: jumps from 16px to 32px — no 20px or 24px in primary scale
### Grid & Container
- Max content width: approximately 1200px
- Hero: centered single-column with generous top padding
- Feature sections: 23 column grids for cards
- Full-width dividers using `border-bottom: 1px solid #171717`
- Code/dashboard screenshots as full-width or contained with border
### Whitespace Philosophy
- **Gallery emptiness**: Massive vertical padding between sections (80px120px+). The white space IS the design — it communicates that Vercel has nothing to prove and nothing to hide.
- **Compressed text, expanded space**: The aggressive negative letter-spacing on headlines is counterbalanced by generous surrounding whitespace. The text is dense; the space around it is vast.
- **Section rhythm**: White sections alternate with white sections — there's no color variation between sections. Separation comes from borders (shadow-borders) and spacing alone.
### Border Radius Scale
- Micro (2px): Inline code snippets, small spans
- Subtle (4px): Small containers
- Standard (6px): Buttons, links, functional elements
- Comfortable (8px): Cards, list items
- Image (12px): Featured cards, image containers (top-rounded)
- Large (64px): Tab navigation pills
- XL (100px): Large navigation links
- Full Pill (9999px): Badges, status pills, tags
- Circle (50%): Menu toggle, avatar containers
## 6. Depth & Elevation
| Level | Treatment | Use |
|-------|-----------|-----|
| Flat (Level 0) | No shadow | Page background, text blocks |
| Ring (Level 1) | `rgba(0,0,0,0.08) 0px 0px 0px 1px` | Shadow-as-border for most elements |
| Light Ring (Level 1b) | `rgb(235,235,235) 0px 0px 0px 1px` | Lighter ring for tabs, images |
| Subtle Card (Level 2) | Ring + `rgba(0,0,0,0.04) 0px 2px 2px` | Standard cards with minimal lift |
| Full Card (Level 3) | Ring + Subtle + `rgba(0,0,0,0.04) 0px 8px 8px -8px` + inner `#fafafa` ring | Featured cards, highlighted panels |
| Focus (Accessibility) | `2px solid hsla(212, 100%, 48%, 1)` outline | Keyboard 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
- Hero gradient: soft, pastel multi-color gradient wash behind hero content (barely visible, atmospheric)
- Section borders: `1px solid #171717` (full dark line) between major sections
- No background color variation — depth comes entirely from shadow layering and border contrast
## 7. Do's and Don'ts
### Do
- Use Geist Sans with aggressive negative letter-spacing at display sizes (-2.4px to -2.88px at 48px)
- Use shadow-as-border (`0px 0px 0px 1px rgba(0,0,0,0.08)`) instead of traditional CSS borders
- Enable `"liga"` on all Geist text — ligatures are structural, not optional
- Use the three-weight system: 400 (body), 500 (UI), 600 (headings)
- Apply workflow accent colors (Red/Pink/Blue) only in their workflow context
- Use multi-layer shadow stacks for cards (border + elevation + ambient + inner highlight)
- Keep the color palette achromatic — grays from `#171717` to `#ffffff` are the system
- Use `#171717` instead of `#000000` for primary text — the micro-warmth matters
### Don't
- Don't use positive letter-spacing on Geist Sans — it's always negative or zero
- Don't use weight 700 (bold) on body text — 600 is the maximum, used only for headings
- Don't use traditional CSS `border` on cards — use the shadow-border technique
- Don't introduce warm colors (oranges, yellows, greens) into the UI chrome
- Don't apply the workflow accent colors (Ship Red, Preview Pink, Develop Blue) decoratively
- Don't use heavy shadows (> 0.1 opacity) — the shadow system is whisper-level
- Don't increase body text letter-spacing — Geist is designed to run tight
- Don't use pill radius (9999px) on primary action buttons — pills are for badges/tags only
- Don't skip the inner `#fafafa` ring in card shadows — it's the glow that makes the system work
## 8. Responsive Behavior
### Breakpoints
| Name | Width | Key Changes |
|------|-------|-------------|
| Mobile Small | <400px | Tight single column, minimal padding |
| Mobile | 400600px | Standard mobile, stacked layout |
| Tablet Small | 600768px | 2-column grids begin |
| Tablet | 7681024px | Full card grids, expanded padding |
| Desktop Small | 10241200px | Standard desktop layout |
| Desktop | 12001400px | Full layout, maximum content width |
| Large Desktop | >1400px | Centered, generous margins |
### Touch Targets
- Buttons use comfortable padding (8px16px vertical)
- Navigation links at 14px with adequate spacing
- Pill badges have 10px horizontal padding for tap targets
- Mobile menu toggle uses 50% radius circular button
### Collapsing Strategy
- Hero: display 48px → scales down, maintains negative tracking proportionally
- Navigation: horizontal links + CTAs → hamburger menu
- Feature cards: 3-column → 2-column → single column stacked
- Code screenshots: maintain aspect ratio, may horizontally scroll
- Trust bar logos: grid → horizontal scroll
- Footer: multi-column → stacked single column
- Section spacing: 80px+ → 48px on mobile
### Image Behavior
- Dashboard screenshots maintain border treatment at all sizes
- Hero gradient softens/simplifies on mobile
- Product screenshots use responsive images with consistent border radius
- Full-width sections maintain edge-to-edge treatment
## 9. Agent Prompt Guide
### Quick Color Reference
- Primary CTA: Vercel Black (`#171717`)
- Background: Pure White (`#ffffff`)
- Heading text: Vercel Black (`#171717`)
- Body text: Gray 600 (`#4d4d4d`)
- Border (shadow): `rgba(0, 0, 0, 0.08) 0px 0px 0px 1px`
- Link: Link Blue (`#0072f5`)
- Focus ring: Focus Blue (`hsla(212, 100%, 48%, 1)`)
### Example Component Prompts
- "Create a hero section on white background. Headline at 48px Geist weight 600, line-height 1.00, letter-spacing -2.4px, color #171717. Subtitle at 20px Geist weight 400, line-height 1.80, color #4d4d4d. Dark CTA button (#171717, 6px radius, 8px 16px padding) and ghost button (white, shadow-border rgba(0,0,0,0.08) 0px 0px 0px 1px, 6px radius)."
- "Design a card: white background, no CSS border. Use shadow stack: rgba(0,0,0,0.08) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 2px, #fafafa 0px 0px 0px 1px. Radius 8px. Title at 24px Geist weight 600, letter-spacing -0.96px. Body at 16px weight 400, #4d4d4d."
- "Build a pill badge: #ebf5ff background, #0068d6 text, 9999px radius, 0px 10px padding, 12px Geist weight 500."
- "Create navigation: white sticky header. Geist 14px weight 500 for links, #171717 text. Dark pill CTA 'Start Deploying' right-aligned. Shadow-border on bottom: rgba(0,0,0,0.08) 0px 0px 0px 1px."
- "Design a workflow section showing three steps: Develop (text color #0a72ef), Preview (#de1d8d), Ship (#ff5b4f). Each step: 14px Geist Mono uppercase label + 24px Geist weight 600 title + 16px weight 400 description in #4d4d4d."
### 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

View File

@@ -0,0 +1,25 @@
# Vercel — Design System
> Design.md extracted from the public [vercel](https://vercel.dev/) website. This is not the official design system. Colors, fonts, and spacing may not be 100% accurate. But it's a good starting point for building something similar.
## Files
| File | Description |
|------|-------------|
| `DESIGN.md` | Complete design system documentation (9 sections) |
| `preview.html` | Interactive design token catalog (light) |
| `preview-dark.html` | Interactive design token catalog (dark) |
## Usage
Open `DESIGN.md` to use as a reference for AI agents (Claude, Cursor, Stitch) to generate UI that matches the Vercel design language.
## Preview
A sample landing page built with DESIGN.md. It shows the actual colors, typography, buttons, cards, spacing, and elevation, all in one page.
### Dark Mode
![Vercel Design System — Dark Mode](https://pub-2e4ecbcbc9b24e7b93f1a6ab5b2bc71f.r2.dev/designs/vercel/preview-dark-screenshot.png)
### Light Mode
![Vercel Design System — Light Mode](https://pub-2e4ecbcbc9b24e7b93f1a6ab5b2bc71f.r2.dev/designs/vercel/preview-screenshot.png)

View File

@@ -0,0 +1,370 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Design System Preview: Vercel (Dark)</title>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700&family=Geist+Mono:wght@400;500;600&display=swap" rel="stylesheet">
<style>
:root {
--black: #ededed;
--white: #0a0a0a;
--gray-50: #111111;
--gray-100: #2a2a2a;
--gray-400: #666666;
--gray-500: #808080;
--gray-600: #a0a0a0;
--link-blue: #0072f5;
--focus-blue: hsl(212,100%,48%);
--ship-red: #ff5b4f;
--preview-pink: #de1d8d;
--develop-blue: #0a72ef;
--console-blue: #0070f3;
--console-purple: #7928ca;
--console-pink: #eb367f;
--badge-bg: #ebf5ff;
--badge-text: #0068d6;
--shadow-ring: rgba(255,255,255,0.1) 0px 0px 0px 1px;
--shadow-ring-light: rgba(255,255,255,0.08) 0px 0px 0px 1px;
--shadow-subtle: rgba(0,0,0,0.04) 0px 2px 2px 0px;
--shadow-card: rgba(255,255,255,0.1) 0px 0px 0px 1px, rgba(0,0,0,0.2) 0px 2px 2px 0px, rgba(255,255,255,0.03) 0px 0px 0px 1px;
--shadow-card-full: rgba(255,255,255,0.12) 0px 0px 0px 1px, rgba(0,0,0,0.3) 0px 2px 2px 0px, rgba(0,0,0,0.2) 0px 8px 8px -8px, rgba(255,255,255,0.04) 0px 0px 0px 1px;
--font-sans: 'Geist', system-ui, -apple-system, Arial, sans-serif;
--font-mono: 'Geist Mono', ui-monospace, SFMono-Regular, 'Roboto Mono', Menlo, monospace;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body {
background: var(--white);
color: var(--black);
font-family: var(--font-sans);
font-size: 16px; font-weight: 400; line-height: 1.50;
font-feature-settings: "liga" 1;
-webkit-font-smoothing: antialiased;
}
/* NAV */
.nav {
position: sticky; top: 0; z-index: 100;
display: flex; align-items: center; justify-content: space-between;
padding: 12px 32px;
background: rgba(10,10,10,0.88);
backdrop-filter: blur(12px);
box-shadow: var(--shadow-ring);
}
.nav-brand { font-size: 14px; font-weight: 600; color: var(--black); text-decoration: none; letter-spacing: -0.28px; }
.nav-links { display: flex; gap: 24px; list-style: none; }
.nav-links a { font-size: 14px; font-weight: 500; color: var(--gray-600); text-decoration: none; transition: color 0.15s; }
.nav-links a:hover { color: var(--black); }
.nav-cta {
display: inline-block; background: var(--white); color: var(--black);
padding: 8px 16px; border-radius: 6px; font-size: 14px; font-weight: 500;
text-decoration: none; transition: opacity 0.15s;
}
.nav-cta:hover { opacity: 0.85; }
/* HERO */
.hero { padding: 96px 32px 80px; text-align: center; }
.hero h1 {
font-size: 48px; font-weight: 600; line-height: 1.00;
letter-spacing: -2.4px; color: var(--black); margin-bottom: 16px;
}
.hero p { font-size: 20px; font-weight: 400; line-height: 1.80; color: var(--gray-600); max-width: 600px; margin: 0 auto 32px; }
.hero-buttons { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.btn-dark {
display: inline-block; background: var(--white); color: var(--black);
padding: 10px 20px; border-radius: 6px; border: none;
font-family: var(--font-sans); font-size: 14px; font-weight: 500;
text-decoration: none; cursor: pointer; transition: opacity 0.15s;
}
.btn-dark:hover { opacity: 0.85; }
.btn-ghost {
display: inline-block; background: var(--white); color: var(--black);
padding: 10px 20px; border-radius: 6px; border: none;
font-family: var(--font-sans); font-size: 14px; font-weight: 500;
text-decoration: none; cursor: pointer;
box-shadow: var(--shadow-ring-light); transition: box-shadow 0.15s;
}
.btn-ghost:hover { box-shadow: var(--shadow-ring); }
/* SECTIONS */
.section { padding: 64px 32px; max-width: 1200px; margin: 0 auto; }
.section-label { font-family: var(--font-mono); font-size: 12px; font-weight: 500; color: var(--gray-400); text-transform: uppercase; margin-bottom: 8px; letter-spacing: 0.5px; }
.section-title { font-size: 32px; font-weight: 600; line-height: 1.25; letter-spacing: -1.28px; margin-bottom: 32px; }
.section-divider { border: none; border-top: 1px solid #2a2a2a; margin: 0; }
/* COLORS */
.color-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(155px, 1fr)); gap: 12px; margin-bottom: 24px; }
.color-swatch { border-radius: 8px; overflow: hidden; box-shadow: var(--shadow-ring); }
.color-swatch-block { height: 72px; width: 100%; }
.color-swatch-info { padding: 10px 12px; }
.color-swatch-name { font-size: 13px; font-weight: 600; margin-bottom: 2px; letter-spacing: -0.26px; }
.color-swatch-hex { font-size: 12px; color: var(--gray-500); font-family: var(--font-mono); }
.color-swatch-role { font-size: 11px; color: var(--gray-400); margin-top: 3px; }
.color-group-label { font-size: 14px; font-weight: 600; color: var(--gray-600); letter-spacing: -0.28px; margin: 24px 0 10px; }
/* TYPOGRAPHY */
.type-sample { margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid var(--gray-100); }
.type-sample:last-child { border-bottom: none; }
.type-meta { font-family: var(--font-mono); font-size: 12px; font-weight: 500; color: var(--gray-400); margin-top: 8px; }
/* BUTTONS */
.button-row { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.button-item { text-align: center; }
.button-label { font-size: 12px; font-weight: 500; color: var(--gray-400); margin-top: 8px; }
.btn-pill { display: inline-block; background: var(--badge-bg); color: var(--badge-text); padding: 4px 10px; border-radius: 9999px; font-size: 12px; font-weight: 500; text-decoration: none; }
/* CARDS */
.card-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 20px; }
.card { background: var(--white); border-radius: 8px; padding: 24px; box-shadow: var(--shadow-card); transition: box-shadow 0.2s; }
.card:hover { box-shadow: var(--shadow-card-full); }
.card h3 { font-size: 20px; font-weight: 600; letter-spacing: -0.8px; margin-bottom: 8px; }
.card p { font-size: 14px; color: var(--gray-600); line-height: 1.50; }
.card-badge { display: inline-block; font-family: var(--font-mono); font-size: 12px; font-weight: 500; text-transform: uppercase; padding: 2px 8px; border-radius: 9999px; margin-bottom: 12px; }
/* FORMS */
.form-group { margin-bottom: 20px; max-width: 400px; }
.form-label { display: block; font-size: 14px; font-weight: 500; color: var(--black); margin-bottom: 6px; }
.form-input {
width: 100%; background: var(--white); color: var(--black);
border: none; padding: 10px 12px; border-radius: 6px;
font-family: var(--font-sans); font-size: 14px; outline: none;
box-shadow: var(--shadow-ring); transition: box-shadow 0.15s;
}
.form-input:focus { box-shadow: 0 0 0 2px var(--focus-blue); }
.form-input--focus { box-shadow: 0 0 0 2px var(--focus-blue); }
.form-input--error { box-shadow: 0 0 0 2px var(--ship-red); }
.form-textarea {
width: 100%; min-height: 80px; background: var(--white); color: var(--black);
border: none; padding: 10px 12px; border-radius: 6px;
font-family: var(--font-sans); font-size: 14px; resize: vertical; outline: none;
box-shadow: var(--shadow-ring);
}
.form-state-label { font-size: 11px; color: var(--gray-400); margin-top: 4px; }
/* SPACING */
.spacing-row { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; margin-bottom: 24px; }
.spacing-item { text-align: center; }
.spacing-block { background: var(--black); border-radius: 3px; margin-bottom: 6px; height: 28px; }
.spacing-value { font-family: var(--font-mono); font-size: 11px; font-weight: 500; color: var(--gray-400); }
/* RADIUS */
.radius-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.radius-item { text-align: center; }
.radius-box { width: 64px; height: 64px; background: var(--black); margin-bottom: 6px; }
.radius-label { font-family: var(--font-mono); font-size: 11px; font-weight: 500; color: var(--gray-400); }
.radius-context { font-size: 10px; color: var(--gray-400); }
/* ELEVATION */
.elevation-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; }
.elevation-card { background: var(--white); border-radius: 8px; padding: 20px; text-align: center; }
.elevation-label { font-size: 14px; font-weight: 600; letter-spacing: -0.28px; margin-bottom: 4px; }
.elevation-desc { font-family: var(--font-mono); font-size: 11px; color: var(--gray-400); }
/* FOOTER */
.footer { padding: 32px; text-align: center; border-top: 1px solid #2a2a2a; font-size: 13px; color: var(--gray-500); }
.footer a { color: var(--link-blue); text-decoration: underline; }
@media (max-width: 768px) {
.hero h1 { font-size: 36px; letter-spacing: -1.8px; }
.nav-links { display: none; }
.section { padding: 48px 20px; }
.card-grid { grid-template-columns: 1fr; }
}
</style>
</head>
<body>
<nav class="nav">
<a class="nav-brand" href="#">awesome-design-md</a>
<ul class="nav-links">
<li><a href="#colors">Colors</a></li>
<li><a href="#typography">Typography</a></li>
<li><a href="#buttons">Buttons</a></li>
<li><a href="#cards">Cards</a></li>
<li><a href="#forms">Forms</a></li>
<li><a href="#spacing">Spacing</a></li>
</ul>
<a class="nav-cta" href="#">Start Deploying</a>
</nav>
<div style="position:fixed;top:16px;right:16px;z-index:200;background:#ededed;color:#0a0a0a;font-size:11px;font-weight:600;padding:4px 10px;border-radius:6px;">Dark Mode</div>
<section class="hero">
<h1>Design System<br>Inspired by Vercel</h1>
<p>A design token catalog generated from DESIGN.md. Every color, font, component, and spacing value — visualized.</p>
<div class="hero-buttons">
<a class="btn-dark" href="#">Start Deploying</a>
<a class="btn-ghost" href="#">View Documentation</a>
</div>
</section>
<hr class="section-divider">
<section class="section" id="colors">
<div class="section-label">01 / Colors</div>
<h2 class="section-title">Color Palette</h2>
<div class="color-group-label">Primary</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#171717"></div><div class="color-swatch-info"><div class="color-swatch-name">Vercel Black</div><div class="color-swatch-hex">#171717</div><div class="color-swatch-role">Primary text, headings</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#0a0a0a; border-bottom:1px solid #2a2a2a"></div><div class="color-swatch-info"><div class="color-swatch-name">Pure White</div><div class="color-swatch-hex">#ffffff</div><div class="color-swatch-role">Page background</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#000000"></div><div class="color-swatch-info"><div class="color-swatch-name">True Black</div><div class="color-swatch-hex">#000000</div><div class="color-swatch-role">Console text default</div></div></div>
</div>
<div class="color-group-label">Workflow Accents</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#0a72ef"></div><div class="color-swatch-info"><div class="color-swatch-name">Develop Blue</div><div class="color-swatch-hex">#0a72ef</div><div class="color-swatch-role">Development workflow</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#de1d8d"></div><div class="color-swatch-info"><div class="color-swatch-name">Preview Pink</div><div class="color-swatch-hex">#de1d8d</div><div class="color-swatch-role">Preview deployments</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#ff5b4f"></div><div class="color-swatch-info"><div class="color-swatch-name">Ship Red</div><div class="color-swatch-hex">#ff5b4f</div><div class="color-swatch-role">Ship to production</div></div></div>
</div>
<div class="color-group-label">Console Colors</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#0070f3"></div><div class="color-swatch-info"><div class="color-swatch-name">Console Blue</div><div class="color-swatch-hex">#0070f3</div><div class="color-swatch-role">Syntax blue</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#7928ca"></div><div class="color-swatch-info"><div class="color-swatch-name">Console Purple</div><div class="color-swatch-hex">#7928ca</div><div class="color-swatch-role">Syntax purple</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#eb367f"></div><div class="color-swatch-info"><div class="color-swatch-name">Console Pink</div><div class="color-swatch-hex">#eb367f</div><div class="color-swatch-role">Syntax pink</div></div></div>
</div>
<div class="color-group-label">Neutral Scale</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#4d4d4d"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 600</div><div class="color-swatch-hex">#4d4d4d</div><div class="color-swatch-role">Secondary text</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#666666"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 500</div><div class="color-swatch-hex">#666666</div><div class="color-swatch-role">Tertiary text</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#808080"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 400</div><div class="color-swatch-hex">#808080</div><div class="color-swatch-role">Placeholders</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#ebebeb"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 100</div><div class="color-swatch-hex">#ebebeb</div><div class="color-swatch-role">Borders, dividers</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#fafafa; border-bottom:1px solid #ebebeb"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 50</div><div class="color-swatch-hex">#fafafa</div><div class="color-swatch-role">Subtle surface tint</div></div></div>
</div>
<div class="color-group-label">Interactive</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#0072f5"></div><div class="color-swatch-info"><div class="color-swatch-name">Link Blue</div><div class="color-swatch-hex">#0072f5</div><div class="color-swatch-role">Links</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:hsl(212,100%,48%)"></div><div class="color-swatch-info"><div class="color-swatch-name">Focus Blue</div><div class="color-swatch-hex">hsl(212,100%,48%)</div><div class="color-swatch-role">Focus ring</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#ebf5ff"></div><div class="color-swatch-info"><div class="color-swatch-name">Badge Bg</div><div class="color-swatch-hex">#ebf5ff</div><div class="color-swatch-role">Pill badge surface</div></div></div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="typography">
<div class="section-label">02 / Typography</div>
<h2 class="section-title">Typography Scale</h2>
<div class="type-sample"><div style="font-size:48px; font-weight:600; line-height:1.00; letter-spacing:-2.4px;">Display Hero</div><div class="type-meta">Display Hero — 48px / 600 / 1.00 / -2.4px / Geist</div></div>
<div class="type-sample"><div style="font-size:40px; font-weight:600; line-height:1.20; letter-spacing:-2.4px;">Section Heading</div><div class="type-meta">Section Heading — 40px / 600 / 1.20 / -2.4px / Geist</div></div>
<div class="type-sample"><div style="font-size:32px; font-weight:600; line-height:1.25; letter-spacing:-1.28px;">Sub-heading Large</div><div class="type-meta">Sub-heading — 32px / 600 / 1.25 / -1.28px / Geist</div></div>
<div class="type-sample"><div style="font-size:24px; font-weight:600; line-height:1.33; letter-spacing:-0.96px;">Card Title</div><div class="type-meta">Card Title — 24px / 600 / 1.33 / -0.96px / Geist</div></div>
<div class="type-sample"><div style="font-size:24px; font-weight:500; line-height:1.33; letter-spacing:-0.96px;">Card Title Light</div><div class="type-meta">Card Title Light — 24px / 500 / 1.33 / -0.96px / Geist</div></div>
<div class="type-sample"><div style="font-size:20px; font-weight:400; line-height:1.80;">Body Large — Build and deploy on the AI Cloud. Vercel provides tools for developers to ship fast.</div><div class="type-meta">Body Large — 20px / 400 / 1.80 / normal / Geist</div></div>
<div class="type-sample"><div style="font-size:16px; font-weight:500; line-height:1.50;">Body Medium — Navigation and emphasized text</div><div class="type-meta">Body Medium — 16px / 500 / 1.50 / Geist</div></div>
<div class="type-sample"><div style="font-size:16px; font-weight:600; line-height:1.50; letter-spacing:-0.32px;">Body Semibold — Active states</div><div class="type-meta">Body Semibold — 16px / 600 / 1.50 / -0.32px / Geist</div></div>
<div class="type-sample"><div style="font-size:14px; font-weight:500; line-height:1.43;">Button / Link</div><div class="type-meta">Button / Link — 14px / 500 / 1.43 / Geist</div></div>
<div class="type-sample"><div style="font-size:12px; font-weight:500; line-height:1.33;">Caption — Metadata and small labels</div><div class="type-meta">Caption — 12px / 500 / 1.33 / Geist</div></div>
<div class="type-sample"><div style="font-family:var(--font-mono); font-size:16px; font-weight:400; line-height:1.50;">const app = await deploy('next-app');</div><div class="type-meta">Mono Body — 16px / 400 / 1.50 / Geist Mono</div></div>
<div class="type-sample"><div style="font-family:var(--font-mono); font-size:12px; font-weight:500; line-height:1.00; text-transform:uppercase;">DEPLOYMENT STATUS</div><div class="type-meta">Mono Label — 12px / 500 / uppercase / Geist Mono</div></div>
<div class="type-sample"><div style="font-size:7px; font-weight:700; line-height:1.00; text-transform:uppercase; background:var(--badge-bg); color:var(--badge-text); display:inline-block; padding:2px 6px; border-radius:9999px;">NEW</div><div class="type-meta">Micro Badge — 7px / 700 / uppercase / Geist</div></div>
</section>
<hr class="section-divider">
<section class="section" id="buttons">
<div class="section-label">03 / Buttons</div>
<h2 class="section-title">Button Variants</h2>
<div class="button-row">
<div class="button-item"><a class="btn-dark" href="#">Start Deploying</a><div class="button-label">Primary Dark</div></div>
<div class="button-item"><a class="btn-ghost" href="#">Documentation</a><div class="button-label">Ghost / Shadow</div></div>
<div class="button-item"><a class="btn-pill" href="#">AI Optimized</a><div class="button-label">Pill Badge</div></div>
<div class="button-item"><span style="display:inline-block; background:var(--develop-blue); color:#fff; padding:4px 10px; border-radius:9999px; font-size:12px; font-weight:500;">Develop</span><div class="button-label">Workflow Pill</div></div>
<div class="button-item"><span style="display:inline-block; background:var(--preview-pink); color:#fff; padding:4px 10px; border-radius:9999px; font-size:12px; font-weight:500;">Preview</span><div class="button-label">Workflow Pill</div></div>
<div class="button-item"><span style="display:inline-block; background:var(--ship-red); color:#fff; padding:4px 10px; border-radius:9999px; font-size:12px; font-weight:500;">Ship</span><div class="button-label">Workflow Pill</div></div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="cards">
<div class="section-label">04 / Cards</div>
<h2 class="section-title">Card Examples</h2>
<div class="card-grid">
<div class="card">
<div class="card-badge" style="background:var(--badge-bg); color:var(--badge-text);">Framework</div>
<h3>Next.js Integration</h3>
<p>Zero-config deployments for Next.js applications. Automatic optimizations, edge rendering, and instant rollbacks.</p>
</div>
<div class="card" style="box-shadow: var(--shadow-card-full);">
<div class="card-badge" style="background:rgba(255,91,79,0.1); color:var(--ship-red);">Elevated</div>
<h3>Edge Functions</h3>
<p>Run serverless functions at the edge with sub-millisecond cold starts. Card shown with full shadow stack.</p>
</div>
<div class="card">
<div class="card-badge" style="background:rgba(10,114,239,0.1); color:var(--develop-blue);">AI</div>
<h3>v0 by Vercel</h3>
<p>Generate UI with AI. Describe what you want and v0 creates the code using shadcn/ui and Tailwind CSS.</p>
</div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="forms">
<div class="section-label">05 / Forms</div>
<h2 class="section-title">Form Elements</h2>
<div class="form-group"><label class="form-label">Project Name</label><input class="form-input" type="text" placeholder="my-next-app"><div class="form-state-label">Default (shadow-border)</div></div>
<div class="form-group"><label class="form-label">Repository</label><input class="form-input form-input--focus" type="text" value="vercel/next.js"><div class="form-state-label">Focus (blue ring)</div></div>
<div class="form-group"><label class="form-label">Domain</label><input class="form-input form-input--error" type="text" value="invalid domain"><div class="form-state-label">Error (red ring)</div></div>
<div class="form-group"><label class="form-label">Environment Variables</label><textarea class="form-textarea" placeholder="KEY=value"></textarea></div>
</section>
<hr class="section-divider">
<section class="section" id="spacing">
<div class="section-label">06 / Spacing</div>
<h2 class="section-title">Spacing Scale</h2>
<div class="spacing-row">
<div class="spacing-item"><div class="spacing-block" style="width:2px"></div><div class="spacing-value">2</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:4px"></div><div class="spacing-value">4</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:6px"></div><div class="spacing-value">6</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:8px"></div><div class="spacing-value">8</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:12px"></div><div class="spacing-value">12</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:16px"></div><div class="spacing-value">16</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:32px"></div><div class="spacing-value">32</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:40px"></div><div class="spacing-value">40</div></div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="radius">
<div class="section-label">07 / Radius</div>
<h2 class="section-title">Border Radius Scale</h2>
<div class="radius-row">
<div class="radius-item"><div class="radius-box" style="border-radius:2px"></div><div class="radius-label">2px</div><div class="radius-context">Code spans</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:4px"></div><div class="radius-label">4px</div><div class="radius-context">Small</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:6px"></div><div class="radius-label">6px</div><div class="radius-context">Buttons</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:8px"></div><div class="radius-label">8px</div><div class="radius-context">Cards</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:12px"></div><div class="radius-label">12px</div><div class="radius-context">Images</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:64px"></div><div class="radius-label">64px</div><div class="radius-context">Tabs</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:9999px"></div><div class="radius-label">9999px</div><div class="radius-context">Badges</div></div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="elevation">
<div class="section-label">08 / Elevation</div>
<h2 class="section-title">Elevation &amp; Depth</h2>
<div class="elevation-grid">
<div class="elevation-card" style="border: 1px solid var(--gray-100);"><div class="elevation-label">Level 0: Flat</div><div class="elevation-desc">No shadow</div></div>
<div class="elevation-card" style="box-shadow: rgba(0,0,0,0.08) 0px 0px 0px 1px;"><div class="elevation-label">Level 1: Ring</div><div class="elevation-desc">Shadow-as-border</div></div>
<div class="elevation-card" style="box-shadow: rgb(235,235,235) 0px 0px 0px 1px;"><div class="elevation-label">Level 1b: Light Ring</div><div class="elevation-desc">Lighter ring</div></div>
<div class="elevation-card" style="box-shadow: var(--shadow-card);"><div class="elevation-label">Level 2: Card</div><div class="elevation-desc">Ring + subtle lift</div></div>
<div class="elevation-card" style="box-shadow: var(--shadow-card-full);"><div class="elevation-label">Level 3: Full Card</div><div class="elevation-desc">Ring + lift + ambient + glow</div></div>
<div class="elevation-card" style="box-shadow: 0 0 0 2px hsl(212,100%,48%);"><div class="elevation-label">Focus</div><div class="elevation-desc">Accessibility ring</div></div>
</div>
</section>
<footer class="footer">
Generated from <a href="https://vercel.com/">vercel.com</a> DESIGN.md — awesome-design-md
</footer>
</body>
</html>

View File

@@ -0,0 +1,369 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Design System Preview: Vercel (Light)</title>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700&family=Geist+Mono:wght@400;500;600&display=swap" rel="stylesheet">
<style>
:root {
--black: #171717;
--white: #ffffff;
--gray-50: #fafafa;
--gray-100: #ebebeb;
--gray-400: #808080;
--gray-500: #666666;
--gray-600: #4d4d4d;
--link-blue: #0072f5;
--focus-blue: hsl(212,100%,48%);
--ship-red: #ff5b4f;
--preview-pink: #de1d8d;
--develop-blue: #0a72ef;
--console-blue: #0070f3;
--console-purple: #7928ca;
--console-pink: #eb367f;
--badge-bg: #ebf5ff;
--badge-text: #0068d6;
--shadow-ring: rgba(0,0,0,0.08) 0px 0px 0px 1px;
--shadow-ring-light: rgb(235,235,235) 0px 0px 0px 1px;
--shadow-subtle: rgba(0,0,0,0.04) 0px 2px 2px 0px;
--shadow-card: rgba(0,0,0,0.08) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 2px 0px, rgb(250,250,250) 0px 0px 0px 1px;
--shadow-card-full: rgba(0,0,0,0.08) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 2px 0px, rgba(0,0,0,0.04) 0px 8px 8px -8px, rgb(250,250,250) 0px 0px 0px 1px;
--font-sans: 'Geist', system-ui, -apple-system, Arial, sans-serif;
--font-mono: 'Geist Mono', ui-monospace, SFMono-Regular, 'Roboto Mono', Menlo, monospace;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body {
background: var(--white);
color: var(--black);
font-family: var(--font-sans);
font-size: 16px; font-weight: 400; line-height: 1.50;
font-feature-settings: "liga" 1;
-webkit-font-smoothing: antialiased;
}
/* NAV */
.nav {
position: sticky; top: 0; z-index: 100;
display: flex; align-items: center; justify-content: space-between;
padding: 12px 32px;
background: rgba(255,255,255,0.85);
backdrop-filter: blur(12px);
box-shadow: var(--shadow-ring);
}
.nav-brand { font-size: 14px; font-weight: 600; color: var(--black); text-decoration: none; letter-spacing: -0.28px; }
.nav-links { display: flex; gap: 24px; list-style: none; }
.nav-links a { font-size: 14px; font-weight: 500; color: var(--gray-600); text-decoration: none; transition: color 0.15s; }
.nav-links a:hover { color: var(--black); }
.nav-cta {
display: inline-block; background: var(--black); color: var(--white);
padding: 8px 16px; border-radius: 6px; font-size: 14px; font-weight: 500;
text-decoration: none; transition: opacity 0.15s;
}
.nav-cta:hover { opacity: 0.85; }
/* HERO */
.hero { padding: 96px 32px 80px; text-align: center; }
.hero h1 {
font-size: 48px; font-weight: 600; line-height: 1.00;
letter-spacing: -2.4px; color: var(--black); margin-bottom: 16px;
}
.hero p { font-size: 20px; font-weight: 400; line-height: 1.80; color: var(--gray-600); max-width: 600px; margin: 0 auto 32px; }
.hero-buttons { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.btn-dark {
display: inline-block; background: var(--black); color: var(--white);
padding: 10px 20px; border-radius: 6px; border: none;
font-family: var(--font-sans); font-size: 14px; font-weight: 500;
text-decoration: none; cursor: pointer; transition: opacity 0.15s;
}
.btn-dark:hover { opacity: 0.85; }
.btn-ghost {
display: inline-block; background: var(--white); color: var(--black);
padding: 10px 20px; border-radius: 6px; border: none;
font-family: var(--font-sans); font-size: 14px; font-weight: 500;
text-decoration: none; cursor: pointer;
box-shadow: var(--shadow-ring-light); transition: box-shadow 0.15s;
}
.btn-ghost:hover { box-shadow: var(--shadow-ring); }
/* SECTIONS */
.section { padding: 64px 32px; max-width: 1200px; margin: 0 auto; }
.section-label { font-family: var(--font-mono); font-size: 12px; font-weight: 500; color: var(--gray-400); text-transform: uppercase; margin-bottom: 8px; letter-spacing: 0.5px; }
.section-title { font-size: 32px; font-weight: 600; line-height: 1.25; letter-spacing: -1.28px; margin-bottom: 32px; }
.section-divider { border: none; border-top: 1px solid var(--gray-100); margin: 0; }
/* COLORS */
.color-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(155px, 1fr)); gap: 12px; margin-bottom: 24px; }
.color-swatch { border-radius: 8px; overflow: hidden; box-shadow: var(--shadow-ring); }
.color-swatch-block { height: 72px; width: 100%; }
.color-swatch-info { padding: 10px 12px; }
.color-swatch-name { font-size: 13px; font-weight: 600; margin-bottom: 2px; letter-spacing: -0.26px; }
.color-swatch-hex { font-size: 12px; color: var(--gray-500); font-family: var(--font-mono); }
.color-swatch-role { font-size: 11px; color: var(--gray-400); margin-top: 3px; }
.color-group-label { font-size: 14px; font-weight: 600; color: var(--gray-600); letter-spacing: -0.28px; margin: 24px 0 10px; }
/* TYPOGRAPHY */
.type-sample { margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid var(--gray-100); }
.type-sample:last-child { border-bottom: none; }
.type-meta { font-family: var(--font-mono); font-size: 12px; font-weight: 500; color: var(--gray-400); margin-top: 8px; }
/* BUTTONS */
.button-row { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.button-item { text-align: center; }
.button-label { font-size: 12px; font-weight: 500; color: var(--gray-400); margin-top: 8px; }
.btn-pill { display: inline-block; background: var(--badge-bg); color: var(--badge-text); padding: 4px 10px; border-radius: 9999px; font-size: 12px; font-weight: 500; text-decoration: none; }
/* CARDS */
.card-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 20px; }
.card { background: var(--white); border-radius: 8px; padding: 24px; box-shadow: var(--shadow-card); transition: box-shadow 0.2s; }
.card:hover { box-shadow: var(--shadow-card-full); }
.card h3 { font-size: 20px; font-weight: 600; letter-spacing: -0.8px; margin-bottom: 8px; }
.card p { font-size: 14px; color: var(--gray-600); line-height: 1.50; }
.card-badge { display: inline-block; font-family: var(--font-mono); font-size: 12px; font-weight: 500; text-transform: uppercase; padding: 2px 8px; border-radius: 9999px; margin-bottom: 12px; }
/* FORMS */
.form-group { margin-bottom: 20px; max-width: 400px; }
.form-label { display: block; font-size: 14px; font-weight: 500; color: var(--black); margin-bottom: 6px; }
.form-input {
width: 100%; background: var(--white); color: var(--black);
border: none; padding: 10px 12px; border-radius: 6px;
font-family: var(--font-sans); font-size: 14px; outline: none;
box-shadow: var(--shadow-ring); transition: box-shadow 0.15s;
}
.form-input:focus { box-shadow: 0 0 0 2px var(--focus-blue); }
.form-input--focus { box-shadow: 0 0 0 2px var(--focus-blue); }
.form-input--error { box-shadow: 0 0 0 2px var(--ship-red); }
.form-textarea {
width: 100%; min-height: 80px; background: var(--white); color: var(--black);
border: none; padding: 10px 12px; border-radius: 6px;
font-family: var(--font-sans); font-size: 14px; resize: vertical; outline: none;
box-shadow: var(--shadow-ring);
}
.form-state-label { font-size: 11px; color: var(--gray-400); margin-top: 4px; }
/* SPACING */
.spacing-row { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; margin-bottom: 24px; }
.spacing-item { text-align: center; }
.spacing-block { background: var(--black); border-radius: 3px; margin-bottom: 6px; height: 28px; }
.spacing-value { font-family: var(--font-mono); font-size: 11px; font-weight: 500; color: var(--gray-400); }
/* RADIUS */
.radius-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.radius-item { text-align: center; }
.radius-box { width: 64px; height: 64px; background: var(--black); margin-bottom: 6px; }
.radius-label { font-family: var(--font-mono); font-size: 11px; font-weight: 500; color: var(--gray-400); }
.radius-context { font-size: 10px; color: var(--gray-400); }
/* ELEVATION */
.elevation-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; }
.elevation-card { background: var(--white); border-radius: 8px; padding: 20px; text-align: center; }
.elevation-label { font-size: 14px; font-weight: 600; letter-spacing: -0.28px; margin-bottom: 4px; }
.elevation-desc { font-family: var(--font-mono); font-size: 11px; color: var(--gray-400); }
/* FOOTER */
.footer { padding: 32px; text-align: center; border-top: 1px solid var(--gray-100); font-size: 13px; color: var(--gray-500); }
.footer a { color: var(--link-blue); text-decoration: underline; }
@media (max-width: 768px) {
.hero h1 { font-size: 36px; letter-spacing: -1.8px; }
.nav-links { display: none; }
.section { padding: 48px 20px; }
.card-grid { grid-template-columns: 1fr; }
}
</style>
</head>
<body>
<nav class="nav">
<a class="nav-brand" href="#">awesome-design-md</a>
<ul class="nav-links">
<li><a href="#colors">Colors</a></li>
<li><a href="#typography">Typography</a></li>
<li><a href="#buttons">Buttons</a></li>
<li><a href="#cards">Cards</a></li>
<li><a href="#forms">Forms</a></li>
<li><a href="#spacing">Spacing</a></li>
</ul>
<a class="nav-cta" href="#">Start Deploying</a>
</nav>
<section class="hero">
<h1>Design System<br>Inspired by Vercel</h1>
<p>A design token catalog generated from DESIGN.md. Every color, font, component, and spacing value — visualized.</p>
<div class="hero-buttons">
<a class="btn-dark" href="#">Start Deploying</a>
<a class="btn-ghost" href="#">View Documentation</a>
</div>
</section>
<hr class="section-divider">
<section class="section" id="colors">
<div class="section-label">01 / Colors</div>
<h2 class="section-title">Color Palette</h2>
<div class="color-group-label">Primary</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#171717"></div><div class="color-swatch-info"><div class="color-swatch-name">Vercel Black</div><div class="color-swatch-hex">#171717</div><div class="color-swatch-role">Primary text, headings</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#ffffff; border-bottom:1px solid #ebebeb"></div><div class="color-swatch-info"><div class="color-swatch-name">Pure White</div><div class="color-swatch-hex">#ffffff</div><div class="color-swatch-role">Page background</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#000000"></div><div class="color-swatch-info"><div class="color-swatch-name">True Black</div><div class="color-swatch-hex">#000000</div><div class="color-swatch-role">Console text default</div></div></div>
</div>
<div class="color-group-label">Workflow Accents</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#0a72ef"></div><div class="color-swatch-info"><div class="color-swatch-name">Develop Blue</div><div class="color-swatch-hex">#0a72ef</div><div class="color-swatch-role">Development workflow</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#de1d8d"></div><div class="color-swatch-info"><div class="color-swatch-name">Preview Pink</div><div class="color-swatch-hex">#de1d8d</div><div class="color-swatch-role">Preview deployments</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#ff5b4f"></div><div class="color-swatch-info"><div class="color-swatch-name">Ship Red</div><div class="color-swatch-hex">#ff5b4f</div><div class="color-swatch-role">Ship to production</div></div></div>
</div>
<div class="color-group-label">Console Colors</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#0070f3"></div><div class="color-swatch-info"><div class="color-swatch-name">Console Blue</div><div class="color-swatch-hex">#0070f3</div><div class="color-swatch-role">Syntax blue</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#7928ca"></div><div class="color-swatch-info"><div class="color-swatch-name">Console Purple</div><div class="color-swatch-hex">#7928ca</div><div class="color-swatch-role">Syntax purple</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#eb367f"></div><div class="color-swatch-info"><div class="color-swatch-name">Console Pink</div><div class="color-swatch-hex">#eb367f</div><div class="color-swatch-role">Syntax pink</div></div></div>
</div>
<div class="color-group-label">Neutral Scale</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#4d4d4d"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 600</div><div class="color-swatch-hex">#4d4d4d</div><div class="color-swatch-role">Secondary text</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#666666"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 500</div><div class="color-swatch-hex">#666666</div><div class="color-swatch-role">Tertiary text</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#808080"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 400</div><div class="color-swatch-hex">#808080</div><div class="color-swatch-role">Placeholders</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#ebebeb"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 100</div><div class="color-swatch-hex">#ebebeb</div><div class="color-swatch-role">Borders, dividers</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#fafafa; border-bottom:1px solid #ebebeb"></div><div class="color-swatch-info"><div class="color-swatch-name">Gray 50</div><div class="color-swatch-hex">#fafafa</div><div class="color-swatch-role">Subtle surface tint</div></div></div>
</div>
<div class="color-group-label">Interactive</div>
<div class="color-grid">
<div class="color-swatch"><div class="color-swatch-block" style="background:#0072f5"></div><div class="color-swatch-info"><div class="color-swatch-name">Link Blue</div><div class="color-swatch-hex">#0072f5</div><div class="color-swatch-role">Links</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:hsl(212,100%,48%)"></div><div class="color-swatch-info"><div class="color-swatch-name">Focus Blue</div><div class="color-swatch-hex">hsl(212,100%,48%)</div><div class="color-swatch-role">Focus ring</div></div></div>
<div class="color-swatch"><div class="color-swatch-block" style="background:#ebf5ff"></div><div class="color-swatch-info"><div class="color-swatch-name">Badge Bg</div><div class="color-swatch-hex">#ebf5ff</div><div class="color-swatch-role">Pill badge surface</div></div></div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="typography">
<div class="section-label">02 / Typography</div>
<h2 class="section-title">Typography Scale</h2>
<div class="type-sample"><div style="font-size:48px; font-weight:600; line-height:1.00; letter-spacing:-2.4px;">Display Hero</div><div class="type-meta">Display Hero — 48px / 600 / 1.00 / -2.4px / Geist</div></div>
<div class="type-sample"><div style="font-size:40px; font-weight:600; line-height:1.20; letter-spacing:-2.4px;">Section Heading</div><div class="type-meta">Section Heading — 40px / 600 / 1.20 / -2.4px / Geist</div></div>
<div class="type-sample"><div style="font-size:32px; font-weight:600; line-height:1.25; letter-spacing:-1.28px;">Sub-heading Large</div><div class="type-meta">Sub-heading — 32px / 600 / 1.25 / -1.28px / Geist</div></div>
<div class="type-sample"><div style="font-size:24px; font-weight:600; line-height:1.33; letter-spacing:-0.96px;">Card Title</div><div class="type-meta">Card Title — 24px / 600 / 1.33 / -0.96px / Geist</div></div>
<div class="type-sample"><div style="font-size:24px; font-weight:500; line-height:1.33; letter-spacing:-0.96px;">Card Title Light</div><div class="type-meta">Card Title Light — 24px / 500 / 1.33 / -0.96px / Geist</div></div>
<div class="type-sample"><div style="font-size:20px; font-weight:400; line-height:1.80;">Body Large — Build and deploy on the AI Cloud. Vercel provides tools for developers to ship fast.</div><div class="type-meta">Body Large — 20px / 400 / 1.80 / normal / Geist</div></div>
<div class="type-sample"><div style="font-size:16px; font-weight:500; line-height:1.50;">Body Medium — Navigation and emphasized text</div><div class="type-meta">Body Medium — 16px / 500 / 1.50 / Geist</div></div>
<div class="type-sample"><div style="font-size:16px; font-weight:600; line-height:1.50; letter-spacing:-0.32px;">Body Semibold — Active states</div><div class="type-meta">Body Semibold — 16px / 600 / 1.50 / -0.32px / Geist</div></div>
<div class="type-sample"><div style="font-size:14px; font-weight:500; line-height:1.43;">Button / Link</div><div class="type-meta">Button / Link — 14px / 500 / 1.43 / Geist</div></div>
<div class="type-sample"><div style="font-size:12px; font-weight:500; line-height:1.33;">Caption — Metadata and small labels</div><div class="type-meta">Caption — 12px / 500 / 1.33 / Geist</div></div>
<div class="type-sample"><div style="font-family:var(--font-mono); font-size:16px; font-weight:400; line-height:1.50;">const app = await deploy('next-app');</div><div class="type-meta">Mono Body — 16px / 400 / 1.50 / Geist Mono</div></div>
<div class="type-sample"><div style="font-family:var(--font-mono); font-size:12px; font-weight:500; line-height:1.00; text-transform:uppercase;">DEPLOYMENT STATUS</div><div class="type-meta">Mono Label — 12px / 500 / uppercase / Geist Mono</div></div>
<div class="type-sample"><div style="font-size:7px; font-weight:700; line-height:1.00; text-transform:uppercase; background:var(--badge-bg); color:var(--badge-text); display:inline-block; padding:2px 6px; border-radius:9999px;">NEW</div><div class="type-meta">Micro Badge — 7px / 700 / uppercase / Geist</div></div>
</section>
<hr class="section-divider">
<section class="section" id="buttons">
<div class="section-label">03 / Buttons</div>
<h2 class="section-title">Button Variants</h2>
<div class="button-row">
<div class="button-item"><a class="btn-dark" href="#">Start Deploying</a><div class="button-label">Primary Dark</div></div>
<div class="button-item"><a class="btn-ghost" href="#">Documentation</a><div class="button-label">Ghost / Shadow</div></div>
<div class="button-item"><a class="btn-pill" href="#">AI Optimized</a><div class="button-label">Pill Badge</div></div>
<div class="button-item"><span style="display:inline-block; background:var(--develop-blue); color:#fff; padding:4px 10px; border-radius:9999px; font-size:12px; font-weight:500;">Develop</span><div class="button-label">Workflow Pill</div></div>
<div class="button-item"><span style="display:inline-block; background:var(--preview-pink); color:#fff; padding:4px 10px; border-radius:9999px; font-size:12px; font-weight:500;">Preview</span><div class="button-label">Workflow Pill</div></div>
<div class="button-item"><span style="display:inline-block; background:var(--ship-red); color:#fff; padding:4px 10px; border-radius:9999px; font-size:12px; font-weight:500;">Ship</span><div class="button-label">Workflow Pill</div></div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="cards">
<div class="section-label">04 / Cards</div>
<h2 class="section-title">Card Examples</h2>
<div class="card-grid">
<div class="card">
<div class="card-badge" style="background:var(--badge-bg); color:var(--badge-text);">Framework</div>
<h3>Next.js Integration</h3>
<p>Zero-config deployments for Next.js applications. Automatic optimizations, edge rendering, and instant rollbacks.</p>
</div>
<div class="card" style="box-shadow: var(--shadow-card-full);">
<div class="card-badge" style="background:rgba(255,91,79,0.1); color:var(--ship-red);">Elevated</div>
<h3>Edge Functions</h3>
<p>Run serverless functions at the edge with sub-millisecond cold starts. Card shown with full shadow stack.</p>
</div>
<div class="card">
<div class="card-badge" style="background:rgba(10,114,239,0.1); color:var(--develop-blue);">AI</div>
<h3>v0 by Vercel</h3>
<p>Generate UI with AI. Describe what you want and v0 creates the code using shadcn/ui and Tailwind CSS.</p>
</div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="forms">
<div class="section-label">05 / Forms</div>
<h2 class="section-title">Form Elements</h2>
<div class="form-group"><label class="form-label">Project Name</label><input class="form-input" type="text" placeholder="my-next-app"><div class="form-state-label">Default (shadow-border)</div></div>
<div class="form-group"><label class="form-label">Repository</label><input class="form-input form-input--focus" type="text" value="vercel/next.js"><div class="form-state-label">Focus (blue ring)</div></div>
<div class="form-group"><label class="form-label">Domain</label><input class="form-input form-input--error" type="text" value="invalid domain"><div class="form-state-label">Error (red ring)</div></div>
<div class="form-group"><label class="form-label">Environment Variables</label><textarea class="form-textarea" placeholder="KEY=value"></textarea></div>
</section>
<hr class="section-divider">
<section class="section" id="spacing">
<div class="section-label">06 / Spacing</div>
<h2 class="section-title">Spacing Scale</h2>
<div class="spacing-row">
<div class="spacing-item"><div class="spacing-block" style="width:2px"></div><div class="spacing-value">2</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:4px"></div><div class="spacing-value">4</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:6px"></div><div class="spacing-value">6</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:8px"></div><div class="spacing-value">8</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:12px"></div><div class="spacing-value">12</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:16px"></div><div class="spacing-value">16</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:32px"></div><div class="spacing-value">32</div></div>
<div class="spacing-item"><div class="spacing-block" style="width:40px"></div><div class="spacing-value">40</div></div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="radius">
<div class="section-label">07 / Radius</div>
<h2 class="section-title">Border Radius Scale</h2>
<div class="radius-row">
<div class="radius-item"><div class="radius-box" style="border-radius:2px"></div><div class="radius-label">2px</div><div class="radius-context">Code spans</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:4px"></div><div class="radius-label">4px</div><div class="radius-context">Small</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:6px"></div><div class="radius-label">6px</div><div class="radius-context">Buttons</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:8px"></div><div class="radius-label">8px</div><div class="radius-context">Cards</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:12px"></div><div class="radius-label">12px</div><div class="radius-context">Images</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:64px"></div><div class="radius-label">64px</div><div class="radius-context">Tabs</div></div>
<div class="radius-item"><div class="radius-box" style="border-radius:9999px"></div><div class="radius-label">9999px</div><div class="radius-context">Badges</div></div>
</div>
</section>
<hr class="section-divider">
<section class="section" id="elevation">
<div class="section-label">08 / Elevation</div>
<h2 class="section-title">Elevation &amp; Depth</h2>
<div class="elevation-grid">
<div class="elevation-card" style="border: 1px solid var(--gray-100);"><div class="elevation-label">Level 0: Flat</div><div class="elevation-desc">No shadow</div></div>
<div class="elevation-card" style="box-shadow: rgba(0,0,0,0.08) 0px 0px 0px 1px;"><div class="elevation-label">Level 1: Ring</div><div class="elevation-desc">Shadow-as-border</div></div>
<div class="elevation-card" style="box-shadow: rgb(235,235,235) 0px 0px 0px 1px;"><div class="elevation-label">Level 1b: Light Ring</div><div class="elevation-desc">Lighter ring</div></div>
<div class="elevation-card" style="box-shadow: var(--shadow-card);"><div class="elevation-label">Level 2: Card</div><div class="elevation-desc">Ring + subtle lift</div></div>
<div class="elevation-card" style="box-shadow: var(--shadow-card-full);"><div class="elevation-label">Level 3: Full Card</div><div class="elevation-desc">Ring + lift + ambient + glow</div></div>
<div class="elevation-card" style="box-shadow: 0 0 0 2px hsl(212,100%,48%);"><div class="elevation-label">Focus</div><div class="elevation-desc">Accessibility ring</div></div>
</div>
</section>
<footer class="footer">
Generated from <a href="https://vercel.com/">vercel.com</a> DESIGN.md — awesome-design-md
</footer>
</body>
</html>