awesome-design-md 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +172 -0
- package/bin/cli.mjs +126 -0
- package/design-md/airbnb/DESIGN.md +246 -0
- package/design-md/airbnb/README.md +23 -0
- package/design-md/airbnb/preview-dark.html +234 -0
- package/design-md/airbnb/preview.html +233 -0
- package/design-md/airtable/DESIGN.md +89 -0
- package/design-md/airtable/README.md +23 -0
- package/design-md/airtable/preview-dark.html +165 -0
- package/design-md/airtable/preview.html +164 -0
- package/design-md/apple/DESIGN.md +313 -0
- package/design-md/apple/README.md +24 -0
- package/design-md/apple/preview-dark.html +422 -0
- package/design-md/apple/preview.html +416 -0
- package/design-md/bmw/DESIGN.md +180 -0
- package/design-md/bmw/README.md +23 -0
- package/design-md/bmw/preview-dark.html +211 -0
- package/design-md/bmw/preview.html +210 -0
- package/design-md/cal/DESIGN.md +259 -0
- package/design-md/cal/README.md +23 -0
- package/design-md/cal/preview-dark.html +449 -0
- package/design-md/cal/preview.html +575 -0
- package/design-md/claude/DESIGN.md +312 -0
- package/design-md/claude/README.md +24 -0
- package/design-md/claude/preview-dark.html +803 -0
- package/design-md/claude/preview.html +826 -0
- package/design-md/clay/DESIGN.md +304 -0
- package/design-md/clay/README.md +23 -0
- package/design-md/clay/preview-dark.html +318 -0
- package/design-md/clay/preview.html +317 -0
- package/design-md/clickhouse/DESIGN.md +281 -0
- package/design-md/clickhouse/README.md +24 -0
- package/design-md/clickhouse/preview-dark.html +834 -0
- package/design-md/clickhouse/preview.html +786 -0
- package/design-md/cohere/DESIGN.md +266 -0
- package/design-md/cohere/README.md +24 -0
- package/design-md/cohere/preview-dark.html +810 -0
- package/design-md/cohere/preview.html +814 -0
- package/design-md/coinbase/DESIGN.md +129 -0
- package/design-md/coinbase/README.md +23 -0
- package/design-md/coinbase/preview-dark.html +164 -0
- package/design-md/coinbase/preview.html +163 -0
- package/design-md/composio/DESIGN.md +307 -0
- package/design-md/composio/README.md +24 -0
- package/design-md/composio/preview-dark.html +958 -0
- package/design-md/composio/preview.html +933 -0
- package/design-md/cursor/DESIGN.md +309 -0
- package/design-md/cursor/README.md +24 -0
- package/design-md/cursor/preview-dark.html +395 -0
- package/design-md/cursor/preview.html +385 -0
- package/design-md/elevenlabs/DESIGN.md +265 -0
- package/design-md/elevenlabs/README.md +23 -0
- package/design-md/elevenlabs/preview-dark.html +254 -0
- package/design-md/elevenlabs/preview.html +253 -0
- package/design-md/expo/DESIGN.md +281 -0
- package/design-md/expo/README.md +24 -0
- package/design-md/expo/preview-dark.html +536 -0
- package/design-md/expo/preview.html +536 -0
- package/design-md/figma/DESIGN.md +220 -0
- package/design-md/figma/README.md +24 -0
- package/design-md/figma/preview-dark.html +831 -0
- package/design-md/figma/preview.html +841 -0
- package/design-md/framer/DESIGN.md +246 -0
- package/design-md/framer/README.md +23 -0
- package/design-md/framer/preview-dark.html +904 -0
- package/design-md/framer/preview.html +885 -0
- package/design-md/hashicorp/DESIGN.md +278 -0
- package/design-md/hashicorp/README.md +24 -0
- package/design-md/hashicorp/preview-dark.html +1206 -0
- package/design-md/hashicorp/preview.html +1195 -0
- package/design-md/ibm/DESIGN.md +332 -0
- package/design-md/ibm/README.md +24 -0
- package/design-md/ibm/preview-dark.html +445 -0
- package/design-md/ibm/preview.html +430 -0
- package/design-md/intercom/DESIGN.md +146 -0
- package/design-md/intercom/README.md +23 -0
- package/design-md/intercom/preview-dark.html +185 -0
- package/design-md/intercom/preview.html +184 -0
- package/design-md/kraken/DESIGN.md +125 -0
- package/design-md/kraken/README.md +23 -0
- package/design-md/kraken/preview-dark.html +169 -0
- package/design-md/kraken/preview.html +168 -0
- package/design-md/linear.app/DESIGN.md +367 -0
- package/design-md/linear.app/README.md +24 -0
- package/design-md/linear.app/preview-dark.html +385 -0
- package/design-md/linear.app/preview.html +375 -0
- package/design-md/lovable/DESIGN.md +298 -0
- package/design-md/lovable/README.md +24 -0
- package/design-md/lovable/preview-dark.html +351 -0
- package/design-md/lovable/preview.html +350 -0
- package/design-md/minimax/DESIGN.md +257 -0
- package/design-md/minimax/README.md +24 -0
- package/design-md/minimax/preview-dark.html +1267 -0
- package/design-md/minimax/preview.html +1253 -0
- package/design-md/mintlify/DESIGN.md +326 -0
- package/design-md/mintlify/README.md +24 -0
- package/design-md/mintlify/preview-dark.html +411 -0
- package/design-md/mintlify/preview.html +400 -0
- package/design-md/miro/DESIGN.md +108 -0
- package/design-md/miro/README.md +23 -0
- package/design-md/miro/preview-dark.html +174 -0
- package/design-md/miro/preview.html +173 -0
- package/design-md/mistral.ai/DESIGN.md +261 -0
- package/design-md/mistral.ai/README.md +24 -0
- package/design-md/mistral.ai/preview-dark.html +813 -0
- package/design-md/mistral.ai/preview.html +812 -0
- package/design-md/mongodb/DESIGN.md +266 -0
- package/design-md/mongodb/README.md +23 -0
- package/design-md/mongodb/preview-dark.html +262 -0
- package/design-md/mongodb/preview.html +261 -0
- package/design-md/notion/DESIGN.md +309 -0
- package/design-md/notion/README.md +24 -0
- package/design-md/notion/preview-dark.html +374 -0
- package/design-md/notion/preview.html +366 -0
- package/design-md/nvidia/DESIGN.md +293 -0
- package/design-md/nvidia/README.md +24 -0
- package/design-md/nvidia/preview-dark.html +376 -0
- package/design-md/nvidia/preview.html +368 -0
- package/design-md/ollama/DESIGN.md +267 -0
- package/design-md/ollama/README.md +24 -0
- package/design-md/ollama/preview-dark.html +678 -0
- package/design-md/ollama/preview.html +678 -0
- package/design-md/opencode.ai/DESIGN.md +281 -0
- package/design-md/opencode.ai/README.md +24 -0
- package/design-md/opencode.ai/preview-dark.html +368 -0
- package/design-md/opencode.ai/preview.html +359 -0
- package/design-md/pinterest/DESIGN.md +230 -0
- package/design-md/pinterest/README.md +23 -0
- package/design-md/pinterest/preview-dark.html +233 -0
- package/design-md/pinterest/preview.html +232 -0
- package/design-md/posthog/DESIGN.md +256 -0
- package/design-md/posthog/README.md +23 -0
- package/design-md/posthog/preview-dark.html +701 -0
- package/design-md/posthog/preview.html +751 -0
- package/design-md/raycast/DESIGN.md +268 -0
- package/design-md/raycast/README.md +23 -0
- package/design-md/raycast/preview-dark.html +608 -0
- package/design-md/raycast/preview.html +690 -0
- package/design-md/replicate/DESIGN.md +261 -0
- package/design-md/replicate/README.md +24 -0
- package/design-md/replicate/preview-dark.html +828 -0
- package/design-md/replicate/preview.html +831 -0
- package/design-md/resend/DESIGN.md +303 -0
- package/design-md/resend/README.md +23 -0
- package/design-md/resend/preview-dark.html +357 -0
- package/design-md/resend/preview.html +356 -0
- package/design-md/revolut/DESIGN.md +185 -0
- package/design-md/revolut/README.md +23 -0
- package/design-md/revolut/preview-dark.html +234 -0
- package/design-md/revolut/preview.html +233 -0
- package/design-md/runwayml/DESIGN.md +244 -0
- package/design-md/runwayml/README.md +24 -0
- package/design-md/runwayml/preview-dark.html +664 -0
- package/design-md/runwayml/preview.html +665 -0
- package/design-md/sanity/DESIGN.md +357 -0
- package/design-md/sanity/README.md +24 -0
- package/design-md/sanity/preview-dark.html +995 -0
- package/design-md/sanity/preview.html +1140 -0
- package/design-md/sentry/DESIGN.md +262 -0
- package/design-md/sentry/README.md +24 -0
- package/design-md/sentry/preview-dark.html +628 -0
- package/design-md/sentry/preview.html +953 -0
- package/design-md/spacex/DESIGN.md +194 -0
- package/design-md/spacex/README.md +23 -0
- package/design-md/spacex/preview-dark.html +223 -0
- package/design-md/spacex/preview.html +222 -0
- package/design-md/spotify/DESIGN.md +246 -0
- package/design-md/spotify/README.md +23 -0
- package/design-md/spotify/preview-dark.html +231 -0
- package/design-md/spotify/preview.html +230 -0
- package/design-md/stripe/DESIGN.md +322 -0
- package/design-md/stripe/README.md +24 -0
- package/design-md/stripe/preview-dark.html +430 -0
- package/design-md/stripe/preview.html +421 -0
- package/design-md/supabase/DESIGN.md +255 -0
- package/design-md/supabase/README.md +24 -0
- package/design-md/supabase/preview-dark.html +977 -0
- package/design-md/supabase/preview.html +955 -0
- package/design-md/superhuman/DESIGN.md +252 -0
- package/design-md/superhuman/README.md +23 -0
- package/design-md/superhuman/preview-dark.html +975 -0
- package/design-md/superhuman/preview.html +953 -0
- package/design-md/together.ai/DESIGN.md +263 -0
- package/design-md/together.ai/README.md +24 -0
- package/design-md/together.ai/preview-dark.html +892 -0
- package/design-md/together.ai/preview.html +897 -0
- package/design-md/uber/DESIGN.md +295 -0
- package/design-md/uber/README.md +24 -0
- package/design-md/uber/preview-dark.html +1164 -0
- package/design-md/uber/preview.html +1163 -0
- package/design-md/vercel/DESIGN.md +310 -0
- package/design-md/vercel/README.md +24 -0
- package/design-md/vercel/preview-dark.html +370 -0
- package/design-md/vercel/preview.html +369 -0
- package/design-md/voltagent/DESIGN.md +323 -0
- package/design-md/voltagent/README.md +24 -0
- package/design-md/voltagent/preview-dark.html +487 -0
- package/design-md/voltagent/preview.html +766 -0
- package/design-md/warp/DESIGN.md +253 -0
- package/design-md/warp/README.md +23 -0
- package/design-md/warp/preview-dark.html +502 -0
- package/design-md/warp/preview.html +535 -0
- package/design-md/webflow/DESIGN.md +92 -0
- package/design-md/webflow/README.md +23 -0
- package/design-md/webflow/preview-dark.html +147 -0
- package/design-md/webflow/preview.html +146 -0
- package/design-md/wise/DESIGN.md +173 -0
- package/design-md/wise/README.md +23 -0
- package/design-md/wise/preview-dark.html +230 -0
- package/design-md/wise/preview.html +229 -0
- package/design-md/x.ai/DESIGN.md +257 -0
- package/design-md/x.ai/README.md +24 -0
- package/design-md/x.ai/preview-dark.html +358 -0
- package/design-md/x.ai/preview.html +409 -0
- package/design-md/zapier/DESIGN.md +328 -0
- package/design-md/zapier/README.md +24 -0
- package/design-md/zapier/preview-dark.html +382 -0
- package/design-md/zapier/preview.html +374 -0
- package/package.json +33 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2026 VoltAgent
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
<a href="https://github.com/VoltAgent/voltagent">
|
|
2
|
+
<img width="1500" height="801" alt="claude-skills" src="https://github.com/user-attachments/assets/d012a0d2-cec3-4630-ba5e-acc339dbe6cf" />
|
|
3
|
+
</a>
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
<br/>
|
|
7
|
+
<br/>
|
|
8
|
+
|
|
9
|
+
<div align="center">
|
|
10
|
+
<strong>Curated collection of DESIGN.md files inspired by developer focused websites.</strong>
|
|
11
|
+
<br />
|
|
12
|
+
<br />
|
|
13
|
+
|
|
14
|
+
</div>
|
|
15
|
+
|
|
16
|
+
<div align="center">
|
|
17
|
+
|
|
18
|
+
[](https://awesome.re)
|
|
19
|
+

|
|
20
|
+
[](https://github.com/VoltAgent/awesome-design-md)
|
|
21
|
+
[](https://s.voltagent.dev/discord)
|
|
22
|
+
|
|
23
|
+
</div>
|
|
24
|
+
</div>
|
|
25
|
+
|
|
26
|
+
# Awesome DESIGN.md
|
|
27
|
+
|
|
28
|
+
Copy a DESIGN.md into your project, tell your AI agent "build me a page that looks like this" and get pixel-perfect UI that actually matches.
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
## What is DESIGN.md?
|
|
32
|
+
|
|
33
|
+
[DESIGN.md](https://stitch.withgoogle.com/docs/design-md/overview/) is a new concept introduced by Google Stitch. A plain-text design system document that AI agents read to generate consistent UI.
|
|
34
|
+
|
|
35
|
+
It's just a markdown file. No Figma exports, no JSON schemas, no special tooling. Drop it into your project root and any AI coding agent or Google Stitch instantly understands how your UI should look. Markdown is the format LLMs read best, so there's nothing to parse or configure.
|
|
36
|
+
|
|
37
|
+
| File | Who reads it | What it defines |
|
|
38
|
+
|------|-------------|-----------------|
|
|
39
|
+
| `AGENTS.md` | Coding agents | How to build the project |
|
|
40
|
+
| `DESIGN.md` | Design agents | How the project should look and feel |
|
|
41
|
+
|
|
42
|
+
**This repo provides ready-to-use DESIGN.md files** extracted from real websites.
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
## What's Inside Each DESIGN.md
|
|
47
|
+
|
|
48
|
+
Every file follows the [Stitch DESIGN.md format](https://stitch.withgoogle.com/docs/design-md/format/) with extended sections:
|
|
49
|
+
|
|
50
|
+
| # | Section | What it captures |
|
|
51
|
+
|---|---------|-----------------|
|
|
52
|
+
| 1 | Visual Theme & Atmosphere | Mood, density, design philosophy |
|
|
53
|
+
| 2 | Color Palette & Roles | Semantic name + hex + functional role |
|
|
54
|
+
| 3 | Typography Rules | Font families, full hierarchy table |
|
|
55
|
+
| 4 | Component Stylings | Buttons, cards, inputs, navigation with states |
|
|
56
|
+
| 5 | Layout Principles | Spacing scale, grid, whitespace philosophy |
|
|
57
|
+
| 6 | Depth & Elevation | Shadow system, surface hierarchy |
|
|
58
|
+
| 7 | Do's and Don'ts | Design guardrails and anti-patterns |
|
|
59
|
+
| 8 | Responsive Behavior | Breakpoints, touch targets, collapsing strategy |
|
|
60
|
+
| 9 | Agent Prompt Guide | Quick color reference, ready-to-use prompts |
|
|
61
|
+
|
|
62
|
+
Each site includes:
|
|
63
|
+
|
|
64
|
+
| File | Purpose |
|
|
65
|
+
|------|---------|
|
|
66
|
+
| `DESIGN.md` | The design system (what agents read) |
|
|
67
|
+
| `preview.html` | Visual catalog showing color swatches, type scale, buttons, cards |
|
|
68
|
+
| `preview-dark.html` | Same catalog with dark surfaces |
|
|
69
|
+
|
|
70
|
+
### How to Use
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
1. Copy a site's `DESIGN.md` into your project root
|
|
74
|
+
2. Tell your AI agent to use it.
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
## Request a DESIGN.md
|
|
78
|
+
|
|
79
|
+
[Open a GitHub issue with this template](https://github.com/VoltAgent/awesome-design-md/issues/new?template=design-md-request.yml) to request a DESIGN.md generation for a website.
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
## Collection
|
|
83
|
+
|
|
84
|
+
### AI & Machine Learning
|
|
85
|
+
|
|
86
|
+
- [**Claude**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/claude/) - Anthropic's AI assistant. Warm terracotta accent, clean editorial layout
|
|
87
|
+
- [**Cohere**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/cohere/) - Enterprise AI platform. Vibrant gradients, data-rich dashboard aesthetic
|
|
88
|
+
- [**ElevenLabs**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/elevenlabs/) - AI voice platform. Dark cinematic UI, audio-waveform aesthetics
|
|
89
|
+
- [**Minimax**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/minimax/) - AI model provider. Bold dark interface with neon accents
|
|
90
|
+
- [**Mistral AI**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/mistral.ai/) - Open-weight LLM provider. French-engineered minimalism, purple-toned
|
|
91
|
+
- [**Ollama**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/ollama/) - Run LLMs locally. Terminal-first, monochrome simplicity
|
|
92
|
+
- [**OpenCode AI**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/opencode.ai/) - AI coding platform. Developer-centric dark theme
|
|
93
|
+
- [**Replicate**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/replicate/) - Run ML models via API. Clean white canvas, code-forward
|
|
94
|
+
- [**RunwayML**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/runwayml/) - AI video generation. Cinematic dark UI, media-rich layout
|
|
95
|
+
- [**Together AI**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/together.ai/) - Open-source AI infrastructure. Technical, blueprint-style design
|
|
96
|
+
- [**VoltAgent**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/voltagent/) - AI agent framework. Void-black canvas, emerald accent, terminal-native
|
|
97
|
+
- [**xAI**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/x.ai/) - Elon Musk's AI lab. Stark monochrome, futuristic minimalism
|
|
98
|
+
|
|
99
|
+
### Developer Tools & Platforms
|
|
100
|
+
|
|
101
|
+
- [**Cursor**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/cursor/) - AI-first code editor. Sleek dark interface, gradient accents
|
|
102
|
+
- [**Expo**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/expo/) - React Native platform. Dark theme, tight letter-spacing, code-centric
|
|
103
|
+
- [**Linear**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/linear.app/) - Project management for engineers. Ultra-minimal, precise, purple accent
|
|
104
|
+
- [**Lovable**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/lovable/) - AI full-stack builder. Playful gradients, friendly dev aesthetic
|
|
105
|
+
- [**Mintlify**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/mintlify/) - Documentation platform. Clean, green-accented, reading-optimized
|
|
106
|
+
- [**PostHog**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/posthog/) - Product analytics. Playful hedgehog branding, developer-friendly dark UI
|
|
107
|
+
- [**Raycast**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/raycast/) - Productivity launcher. Sleek dark chrome, vibrant gradient accents
|
|
108
|
+
- [**Resend**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/resend/) - Email API for developers. Minimal dark theme, monospace accents
|
|
109
|
+
- [**Sentry**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/sentry/) - Error monitoring. Dark dashboard, data-dense, pink-purple accent
|
|
110
|
+
- [**Supabase**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/supabase/) - Open-source Firebase alternative. Dark emerald theme, code-first
|
|
111
|
+
- [**Superhuman**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/superhuman/) - Fast email client. Premium dark UI, keyboard-first, purple glow
|
|
112
|
+
- [**Vercel**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/vercel/) - Frontend deployment platform. Black and white precision, Geist font
|
|
113
|
+
- [**Warp**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/warp/) - Modern terminal. Dark IDE-like interface, block-based command UI
|
|
114
|
+
- [**Zapier**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/zapier/) - Automation platform. Warm orange, friendly illustration-driven
|
|
115
|
+
|
|
116
|
+
### Infrastructure & Cloud
|
|
117
|
+
|
|
118
|
+
- [**ClickHouse**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/clickhouse/) - Fast analytics database. Yellow-accented, technical documentation style
|
|
119
|
+
- [**Composio**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/composio/) - Tool integration platform. Modern dark with colorful integration icons
|
|
120
|
+
- [**HashiCorp**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/hashicorp/) - Infrastructure automation. Enterprise-clean, black and white
|
|
121
|
+
- [**MongoDB**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/mongodb/) - Document database. Green leaf branding, developer documentation focus
|
|
122
|
+
- [**Sanity**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/sanity/) - Headless CMS. Red accent, content-first editorial layout
|
|
123
|
+
- [**Stripe**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/stripe/) - Payment infrastructure. Signature purple gradients, weight-300 elegance
|
|
124
|
+
|
|
125
|
+
### Design & Productivity
|
|
126
|
+
|
|
127
|
+
- [**Airtable**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/airtable/) - Spreadsheet-database hybrid. Colorful, friendly, structured data aesthetic
|
|
128
|
+
- [**Cal.com**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/cal/) - Open-source scheduling. Clean neutral UI, developer-oriented simplicity
|
|
129
|
+
- [**Clay**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/clay/) - Creative agency. Organic shapes, soft gradients, art-directed layout
|
|
130
|
+
- [**Figma**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/figma/) - Collaborative design tool. Vibrant multi-color, playful yet professional
|
|
131
|
+
- [**Framer**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/framer/) - Website builder. Bold black and blue, motion-first, design-forward
|
|
132
|
+
- [**Intercom**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/intercom/) - Customer messaging. Friendly blue palette, conversational UI patterns
|
|
133
|
+
- [**Miro**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/miro/) - Visual collaboration. Bright yellow accent, infinite canvas aesthetic
|
|
134
|
+
- [**Notion**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/notion/) - All-in-one workspace. Warm minimalism, serif headings, soft surfaces
|
|
135
|
+
- [**Pinterest**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/pinterest/) - Visual discovery platform. Red accent, masonry grid, image-first
|
|
136
|
+
- [**Webflow**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/webflow/) - Visual web builder. Blue-accented, polished marketing site aesthetic
|
|
137
|
+
|
|
138
|
+
### Fintech & Crypto
|
|
139
|
+
|
|
140
|
+
- [**Coinbase**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/coinbase/) - Crypto exchange. Clean blue identity, trust-focused, institutional feel
|
|
141
|
+
- [**Kraken**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/kraken/) - Crypto trading platform. Purple-accented dark UI, data-dense dashboards
|
|
142
|
+
- [**Revolut**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/revolut/) - Digital banking. Sleek dark interface, gradient cards, fintech precision
|
|
143
|
+
- [**Wise**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/wise/) - International money transfer. Bright green accent, friendly and clear
|
|
144
|
+
|
|
145
|
+
### Enterprise & Consumer
|
|
146
|
+
|
|
147
|
+
- [**Airbnb**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/airbnb/) - Travel marketplace. Warm coral accent, photography-driven, rounded UI
|
|
148
|
+
- [**Apple**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/apple/) - Consumer electronics. Premium white space, SF Pro, cinematic imagery
|
|
149
|
+
- [**BMW**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/bmw/) - Luxury automotive. Dark premium surfaces, precise German engineering aesthetic
|
|
150
|
+
- [**IBM**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/ibm/) - Enterprise technology. Carbon design system, structured blue palette
|
|
151
|
+
- [**NVIDIA**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/nvidia/) - GPU computing. Green-black energy, technical power aesthetic
|
|
152
|
+
- [**SpaceX**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/spacex/) - Space technology. Stark black and white, full-bleed imagery, futuristic
|
|
153
|
+
- [**Spotify**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/spotify/) - Music streaming. Vibrant green on dark, bold type, album-art-driven
|
|
154
|
+
- [**Uber**](https://github.com/VoltAgent/awesome-design-md/tree/main/design-md/uber/) - Mobility platform. Bold black and white, tight type, urban energy
|
|
155
|
+
|
|
156
|
+
|
|
157
|
+
|
|
158
|
+
## Contributing
|
|
159
|
+
|
|
160
|
+
See [CONTRIBUTING.md](CONTRIBUTING.md) for guidelines.
|
|
161
|
+
|
|
162
|
+
- **Improve existing files**: Fix wrong colors, missing tokens, weak descriptions
|
|
163
|
+
- **Report issues**: Let us know if something looks off
|
|
164
|
+
|
|
165
|
+
Before opening a PR, please [open an issue](https://github.com/VoltAgent/awesome-design-md/issues) first to discuss your idea and get feedback from maintainers.
|
|
166
|
+
|
|
167
|
+
|
|
168
|
+
## License
|
|
169
|
+
|
|
170
|
+
MIT License - see [LICENSE](LICENSE)
|
|
171
|
+
|
|
172
|
+
This repository is a curated collection of design system documents extracted from public websites. All DESIGN.md files are provided "as is" without warranty. The extracted design tokens represent publicly visible CSS values. We do not claim ownership of any site's visual identity. These documents exist to help AI agents generate consistent UI.
|
package/bin/cli.mjs
ADDED
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
import { readdir, readFile, copyFile, access } from "node:fs/promises";
|
|
4
|
+
import { resolve, dirname, join } from "node:path";
|
|
5
|
+
import { fileURLToPath } from "node:url";
|
|
6
|
+
import searchPrompt from "@inquirer/search";
|
|
7
|
+
|
|
8
|
+
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
9
|
+
const designsDir = resolve(__dirname, "..", "design-md");
|
|
10
|
+
const cwd = process.cwd();
|
|
11
|
+
|
|
12
|
+
const LABELS = {
|
|
13
|
+
airbnb: "Airbnb",
|
|
14
|
+
airtable: "Airtable",
|
|
15
|
+
apple: "Apple",
|
|
16
|
+
bmw: "BMW",
|
|
17
|
+
cal: "Cal.com",
|
|
18
|
+
claude: "Claude",
|
|
19
|
+
clay: "Clay",
|
|
20
|
+
clickhouse: "ClickHouse",
|
|
21
|
+
cohere: "Cohere",
|
|
22
|
+
coinbase: "Coinbase",
|
|
23
|
+
composio: "Composio",
|
|
24
|
+
cursor: "Cursor",
|
|
25
|
+
elevenlabs: "ElevenLabs",
|
|
26
|
+
expo: "Expo",
|
|
27
|
+
figma: "Figma",
|
|
28
|
+
framer: "Framer",
|
|
29
|
+
hashicorp: "HashiCorp",
|
|
30
|
+
ibm: "IBM",
|
|
31
|
+
intercom: "Intercom",
|
|
32
|
+
kraken: "Kraken",
|
|
33
|
+
"linear.app": "Linear",
|
|
34
|
+
lovable: "Lovable",
|
|
35
|
+
minimax: "Minimax",
|
|
36
|
+
mintlify: "Mintlify",
|
|
37
|
+
miro: "Miro",
|
|
38
|
+
"mistral.ai": "Mistral AI",
|
|
39
|
+
mongodb: "MongoDB",
|
|
40
|
+
notion: "Notion",
|
|
41
|
+
nvidia: "NVIDIA",
|
|
42
|
+
ollama: "Ollama",
|
|
43
|
+
"opencode.ai": "OpenCode AI",
|
|
44
|
+
pinterest: "Pinterest",
|
|
45
|
+
posthog: "PostHog",
|
|
46
|
+
raycast: "Raycast",
|
|
47
|
+
replicate: "Replicate",
|
|
48
|
+
resend: "Resend",
|
|
49
|
+
revolut: "Revolut",
|
|
50
|
+
runwayml: "RunwayML",
|
|
51
|
+
sanity: "Sanity",
|
|
52
|
+
sentry: "Sentry",
|
|
53
|
+
spacex: "SpaceX",
|
|
54
|
+
spotify: "Spotify",
|
|
55
|
+
stripe: "Stripe",
|
|
56
|
+
supabase: "Supabase",
|
|
57
|
+
superhuman: "Superhuman",
|
|
58
|
+
"together.ai": "Together AI",
|
|
59
|
+
uber: "Uber",
|
|
60
|
+
vercel: "Vercel",
|
|
61
|
+
voltagent: "VoltAgent",
|
|
62
|
+
warp: "Warp",
|
|
63
|
+
webflow: "Webflow",
|
|
64
|
+
wise: "Wise",
|
|
65
|
+
"x.ai": "xAI",
|
|
66
|
+
zapier: "Zapier",
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
async function main() {
|
|
70
|
+
console.log("\n awesome-design-md\n");
|
|
71
|
+
console.log(" Pick a design system and copy its DESIGN.md to your project.\n");
|
|
72
|
+
|
|
73
|
+
const dirs = (await readdir(designsDir, { withFileTypes: true }))
|
|
74
|
+
.filter((d) => d.isDirectory())
|
|
75
|
+
.map((d) => d.name)
|
|
76
|
+
.sort();
|
|
77
|
+
|
|
78
|
+
const choices = dirs.map((dir) => ({
|
|
79
|
+
name: LABELS[dir] || dir,
|
|
80
|
+
value: dir,
|
|
81
|
+
}));
|
|
82
|
+
|
|
83
|
+
const selected = await searchPrompt({
|
|
84
|
+
message: "Search and select a design:",
|
|
85
|
+
source: (input) => {
|
|
86
|
+
if (!input) return choices;
|
|
87
|
+
const term = input.toLowerCase();
|
|
88
|
+
return choices.filter(
|
|
89
|
+
(c) =>
|
|
90
|
+
c.name.toLowerCase().includes(term) ||
|
|
91
|
+
c.value.toLowerCase().includes(term)
|
|
92
|
+
);
|
|
93
|
+
},
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
const srcDesign = join(designsDir, selected, "DESIGN.md");
|
|
97
|
+
const destDesign = join(cwd, "DESIGN.md");
|
|
98
|
+
|
|
99
|
+
// Check if DESIGN.md already exists
|
|
100
|
+
try {
|
|
101
|
+
await access(destDesign);
|
|
102
|
+
const { default: confirm } = await import("@inquirer/confirm");
|
|
103
|
+
const overwrite = await confirm({
|
|
104
|
+
message: "DESIGN.md already exists. Overwrite?",
|
|
105
|
+
default: false,
|
|
106
|
+
});
|
|
107
|
+
if (!overwrite) {
|
|
108
|
+
console.log("\n Cancelled. No files were changed.\n");
|
|
109
|
+
process.exit(0);
|
|
110
|
+
}
|
|
111
|
+
} catch {
|
|
112
|
+
// File doesn't exist, proceed
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
await copyFile(srcDesign, destDesign);
|
|
116
|
+
console.log(`\n Copied ${LABELS[selected] || selected} DESIGN.md to your project root.`);
|
|
117
|
+
console.log(" Tell your AI agent: \"build me a page using DESIGN.md\"\n");
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
main().catch((err) => {
|
|
121
|
+
if (err.name === "ExitPromptError") {
|
|
122
|
+
process.exit(0);
|
|
123
|
+
}
|
|
124
|
+
console.error(err);
|
|
125
|
+
process.exit(1);
|
|
126
|
+
});
|
|
@@ -0,0 +1,246 @@
|
|
|
1
|
+
# Design System: Airbnb
|
|
2
|
+
|
|
3
|
+
## 1. Visual Theme & Atmosphere
|
|
4
|
+
|
|
5
|
+
Airbnb's website is a warm, photography-forward marketplace that feels like flipping through a travel magazine where every page invites you to book. The design operates on a foundation of pure white (`#ffffff`) with the iconic Rausch Red (`#ff385c`) — named after Airbnb's first street address — serving as the singular brand accent. The result is a clean, airy canvas where listing photography, category icons, and the red CTA button are the only sources of color.
|
|
6
|
+
|
|
7
|
+
The typography uses Airbnb Cereal VF — a custom variable font that's warm and approachable, with rounded terminals that echo the brand's "belong anywhere" philosophy. The font operates in a tight weight range: 500 (medium) for most UI, 600 (semibold) for emphasis, and 700 (bold) for primary headings. Slight negative letter-spacing (-0.18px to -0.44px) on headings creates a cozy, intimate reading experience rather than the compressed efficiency of tech companies.
|
|
8
|
+
|
|
9
|
+
What distinguishes Airbnb is its palette-based token system (`--palette-*`) and multi-layered shadow approach. The primary card shadow uses a three-layer stack (`rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px`) that creates a subtle, warm lift. Combined with generous border-radius (8px–32px), circular navigation controls (50%), and a category pill bar with horizontal scrolling, the interface feels tactile and inviting — designed for browsing, not commanding.
|
|
10
|
+
|
|
11
|
+
**Key Characteristics:**
|
|
12
|
+
- Pure white canvas with Rausch Red (`#ff385c`) as singular brand accent
|
|
13
|
+
- Airbnb Cereal VF — custom variable font with warm, rounded terminals
|
|
14
|
+
- Palette-based token system (`--palette-*`) for systematic color management
|
|
15
|
+
- Three-layer card shadows: border ring + soft blur + stronger blur
|
|
16
|
+
- Generous border-radius: 8px buttons, 14px badges, 20px cards, 32px large elements
|
|
17
|
+
- Circular navigation controls (50% radius)
|
|
18
|
+
- Photography-first listing cards — images are the hero content
|
|
19
|
+
- Near-black text (`#222222`) — warm, not cold
|
|
20
|
+
- Luxe Purple (`#460479`) and Plus Magenta (`#92174d`) for premium tiers
|
|
21
|
+
|
|
22
|
+
## 2. Color Palette & Roles
|
|
23
|
+
|
|
24
|
+
### Primary Brand
|
|
25
|
+
- **Rausch Red** (`#ff385c`): `--palette-bg-primary-core`, primary CTA, brand accent, active states
|
|
26
|
+
- **Deep Rausch** (`#e00b41`): `--palette-bg-tertiary-core`, pressed/dark variant of brand red
|
|
27
|
+
- **Error Red** (`#c13515`): `--palette-text-primary-error`, error text on light
|
|
28
|
+
- **Error Dark** (`#b32505`): `--palette-text-secondary-error-hover`, error hover
|
|
29
|
+
|
|
30
|
+
### Premium Tiers
|
|
31
|
+
- **Luxe Purple** (`#460479`): `--palette-bg-primary-luxe`, Airbnb Luxe tier branding
|
|
32
|
+
- **Plus Magenta** (`#92174d`): `--palette-bg-primary-plus`, Airbnb Plus tier branding
|
|
33
|
+
|
|
34
|
+
### Text Scale
|
|
35
|
+
- **Near Black** (`#222222`): `--palette-text-primary`, primary text — warm, not cold
|
|
36
|
+
- **Focused Gray** (`#3f3f3f`): `--palette-text-focused`, focused state text
|
|
37
|
+
- **Secondary Gray** (`#6a6a6a`): Secondary text, descriptions
|
|
38
|
+
- **Disabled** (`rgba(0,0,0,0.24)`): `--palette-text-material-disabled`, disabled state
|
|
39
|
+
- **Link Disabled** (`#929292`): `--palette-text-link-disabled`, disabled links
|
|
40
|
+
|
|
41
|
+
### Interactive
|
|
42
|
+
- **Legal Blue** (`#428bff`): `--palette-text-legal`, legal links, informational
|
|
43
|
+
- **Border Gray** (`#c1c1c1`): Border color for cards and dividers
|
|
44
|
+
- **Light Surface** (`#f2f2f2`): Circular navigation buttons, secondary surfaces
|
|
45
|
+
|
|
46
|
+
### Surface & Shadows
|
|
47
|
+
- **Pure White** (`#ffffff`): Page background, card surfaces
|
|
48
|
+
- **Card Shadow** (`rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px`): Three-layer warm lift
|
|
49
|
+
- **Hover Shadow** (`rgba(0,0,0,0.08) 0px 4px 12px`): Button hover elevation
|
|
50
|
+
|
|
51
|
+
## 3. Typography Rules
|
|
52
|
+
|
|
53
|
+
### Font Family
|
|
54
|
+
- **Primary**: `Airbnb Cereal VF`, fallbacks: `Circular, -apple-system, system-ui, Roboto, Helvetica Neue`
|
|
55
|
+
- **OpenType Features**: `"salt"` (stylistic alternates) on specific caption elements
|
|
56
|
+
|
|
57
|
+
### Hierarchy
|
|
58
|
+
|
|
59
|
+
| Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
|
|
60
|
+
|------|------|------|--------|-------------|----------------|-------|
|
|
61
|
+
| Section Heading | Airbnb Cereal VF | 28px (1.75rem) | 700 | 1.43 | normal | Primary headings |
|
|
62
|
+
| Card Heading | Airbnb Cereal VF | 22px (1.38rem) | 600 | 1.18 (tight) | -0.44px | Category/card titles |
|
|
63
|
+
| Card Heading Medium | Airbnb Cereal VF | 22px (1.38rem) | 500 | 1.18 (tight) | -0.44px | Lighter variant |
|
|
64
|
+
| Sub-heading | Airbnb Cereal VF | 21px (1.31rem) | 700 | 1.43 | normal | Bold sub-headings |
|
|
65
|
+
| Feature Title | Airbnb Cereal VF | 20px (1.25rem) | 600 | 1.20 (tight) | -0.18px | Feature headings |
|
|
66
|
+
| UI Medium | Airbnb Cereal VF | 16px (1.00rem) | 500 | 1.25 (tight) | normal | Nav, emphasized text |
|
|
67
|
+
| UI Semibold | Airbnb Cereal VF | 16px (1.00rem) | 600 | 1.25 (tight) | normal | Strong emphasis |
|
|
68
|
+
| Button | Airbnb Cereal VF | 16px (1.00rem) | 500 | 1.25 (tight) | normal | Button labels |
|
|
69
|
+
| Body / Link | Airbnb Cereal VF | 14px (0.88rem) | 400 | 1.43 | normal | Standard body |
|
|
70
|
+
| Body Medium | Airbnb Cereal VF | 14px (0.88rem) | 500 | 1.29 (tight) | normal | Medium body |
|
|
71
|
+
| Caption Salt | Airbnb Cereal VF | 14px (0.88rem) | 600 | 1.43 | normal | `"salt"` feature |
|
|
72
|
+
| Small | Airbnb Cereal VF | 13px (0.81rem) | 400 | 1.23 (tight) | normal | Descriptions |
|
|
73
|
+
| Tag | Airbnb Cereal VF | 12px (0.75rem) | 400–700 | 1.33 | normal | Tags, prices |
|
|
74
|
+
| Badge | Airbnb Cereal VF | 11px (0.69rem) | 600 | 1.18 (tight) | normal | `"salt"` feature |
|
|
75
|
+
| Micro Uppercase | Airbnb Cereal VF | 8px (0.50rem) | 700 | 1.25 (tight) | 0.32px | `text-transform: uppercase` |
|
|
76
|
+
|
|
77
|
+
### Principles
|
|
78
|
+
- **Warm weight range**: 500–700 dominate. No weight 300 or 400 for headings — Airbnb's type is always at least medium weight, creating a warm, confident voice.
|
|
79
|
+
- **Negative tracking on headings**: -0.18px to -0.44px letter-spacing on display creates intimate, cozy headings rather than cold, compressed ones.
|
|
80
|
+
- **"salt" OpenType feature**: Stylistic alternates on specific UI elements (badges, captions) create subtle glyph variations that add visual interest.
|
|
81
|
+
- **Variable font precision**: Cereal VF enables continuous weight interpolation, though the design system uses discrete stops at 500, 600, and 700.
|
|
82
|
+
|
|
83
|
+
## 4. Component Stylings
|
|
84
|
+
|
|
85
|
+
### Buttons
|
|
86
|
+
|
|
87
|
+
**Primary Dark**
|
|
88
|
+
- Background: `#222222` (near-black, not pure black)
|
|
89
|
+
- Text: `#ffffff`
|
|
90
|
+
- Padding: 0px 24px
|
|
91
|
+
- Radius: 8px
|
|
92
|
+
- Hover: transitions to error/brand accent via `var(--accent-bg-error)`
|
|
93
|
+
- Focus: `0 0 0 2px var(--palette-grey1000)` ring + scale(0.92)
|
|
94
|
+
|
|
95
|
+
**Circular Nav**
|
|
96
|
+
- Background: `#f2f2f2`
|
|
97
|
+
- Text: `#222222`
|
|
98
|
+
- Radius: 50% (circle)
|
|
99
|
+
- Hover: shadow `rgba(0,0,0,0.08) 0px 4px 12px` + translateX(50%)
|
|
100
|
+
- Active: 4px white border ring + focus shadow
|
|
101
|
+
- Focus: scale(0.92) shrink animation
|
|
102
|
+
|
|
103
|
+
### Cards & Containers
|
|
104
|
+
- Background: `#ffffff`
|
|
105
|
+
- Radius: 14px (badges), 20px (cards/buttons), 32px (large)
|
|
106
|
+
- Shadow: `rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px` (three-layer)
|
|
107
|
+
- Listing cards: full-width photography on top, details below
|
|
108
|
+
- Carousel controls: circular 50% buttons
|
|
109
|
+
|
|
110
|
+
### Inputs
|
|
111
|
+
- Search: `#222222` text
|
|
112
|
+
- Focus: `var(--palette-bg-primary-error)` background tint + `0 0 0 2px` ring
|
|
113
|
+
- Radius: depends on context (search bar uses pill-like rounding)
|
|
114
|
+
|
|
115
|
+
### Navigation
|
|
116
|
+
- White sticky header with search bar centered
|
|
117
|
+
- Airbnb logo (Rausch Red) left-aligned
|
|
118
|
+
- Category filter pills: horizontal scroll below search
|
|
119
|
+
- Circular nav controls for carousel navigation
|
|
120
|
+
- "Become a Host" text link, avatar/menu right-aligned
|
|
121
|
+
|
|
122
|
+
### Image Treatment
|
|
123
|
+
- Listing photography fills card top with generous height
|
|
124
|
+
- Image carousel with dot indicators
|
|
125
|
+
- Heart/wishlist icon overlay on images
|
|
126
|
+
- 8px–14px radius on contained images
|
|
127
|
+
|
|
128
|
+
## 5. Layout Principles
|
|
129
|
+
|
|
130
|
+
### Spacing System
|
|
131
|
+
- Base unit: 8px
|
|
132
|
+
- Scale: 2px, 3px, 4px, 6px, 8px, 10px, 11px, 12px, 15px, 16px, 22px, 24px, 32px
|
|
133
|
+
|
|
134
|
+
### Grid & Container
|
|
135
|
+
- Full-width header with centered search
|
|
136
|
+
- Category pill bar: horizontal scrollable row
|
|
137
|
+
- Listing grid: responsive multi-column (3–5 columns on desktop)
|
|
138
|
+
- Full-width footer with link columns
|
|
139
|
+
|
|
140
|
+
### Whitespace Philosophy
|
|
141
|
+
- **Travel-magazine spacing**: Generous vertical padding between sections creates a leisurely browsing pace — you're meant to scroll slowly, like browsing a magazine.
|
|
142
|
+
- **Photography density**: Listing cards are packed relatively tightly, but each image is large enough to feel immersive.
|
|
143
|
+
- **Search bar prominence**: The search bar gets maximum vertical space in the header — finding your destination is the primary action.
|
|
144
|
+
|
|
145
|
+
### Border Radius Scale
|
|
146
|
+
- Subtle (4px): Small links
|
|
147
|
+
- Standard (8px): Buttons, tabs, search elements
|
|
148
|
+
- Badge (14px): Status badges, labels
|
|
149
|
+
- Card (20px): Feature cards, large buttons
|
|
150
|
+
- Large (32px): Large containers, hero elements
|
|
151
|
+
- Circle (50%): Nav controls, avatars, icons
|
|
152
|
+
|
|
153
|
+
## 6. Depth & Elevation
|
|
154
|
+
|
|
155
|
+
| Level | Treatment | Use |
|
|
156
|
+
|-------|-----------|-----|
|
|
157
|
+
| Flat (Level 0) | No shadow | Page background, text blocks |
|
|
158
|
+
| Card (Level 1) | `rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px` | Listing cards, search bar |
|
|
159
|
+
| Hover (Level 2) | `rgba(0,0,0,0.08) 0px 4px 12px` | Button hover, interactive lift |
|
|
160
|
+
| Active Focus (Level 3) | `rgb(255,255,255) 0px 0px 0px 4px` + focus ring | Active/focused elements |
|
|
161
|
+
|
|
162
|
+
**Shadow Philosophy**: Airbnb's three-layer shadow system creates a warm, natural lift. Layer 1 (`0px 0px 0px 1px` at 0.02 opacity) is an ultra-subtle border. Layer 2 (`0px 2px 6px` at 0.04) provides soft ambient shadow. Layer 3 (`0px 4px 8px` at 0.1) adds the primary lift. This graduated approach creates shadows that feel like natural light rather than CSS effects.
|
|
163
|
+
|
|
164
|
+
## 7. Do's and Don'ts
|
|
165
|
+
|
|
166
|
+
### Do
|
|
167
|
+
- Use `#222222` (warm near-black) for text — never pure `#000000`
|
|
168
|
+
- Apply Rausch Red (`#ff385c`) only for primary CTAs and brand moments — it's the singular accent
|
|
169
|
+
- Use Airbnb Cereal VF at weight 500–700 — the warm weight range is intentional
|
|
170
|
+
- Apply the three-layer card shadow for all elevated surfaces
|
|
171
|
+
- Use generous border-radius: 8px for buttons, 20px for cards, 50% for controls
|
|
172
|
+
- Use photography as the primary visual content — listings are image-first
|
|
173
|
+
- Apply negative letter-spacing (-0.18px to -0.44px) on headings for intimacy
|
|
174
|
+
- Use circular (50%) buttons for carousel/navigation controls
|
|
175
|
+
|
|
176
|
+
### Don't
|
|
177
|
+
- Don't use pure black (`#000000`) for text — always `#222222` (warm)
|
|
178
|
+
- Don't apply Rausch Red to backgrounds or large surfaces — it's an accent only
|
|
179
|
+
- Don't use thin font weights (300, 400) for headings — 500 minimum
|
|
180
|
+
- Don't use heavy shadows (>0.1 opacity as primary layer) — keep them warm and graduated
|
|
181
|
+
- Don't use sharp corners (0–4px) on cards — the generous rounding (20px+) is core
|
|
182
|
+
- Don't introduce additional brand colors beyond the Rausch/Luxe/Plus system
|
|
183
|
+
- Don't override the palette token system — use `--palette-*` variables consistently
|
|
184
|
+
|
|
185
|
+
## 8. Responsive Behavior
|
|
186
|
+
|
|
187
|
+
### Breakpoints
|
|
188
|
+
| Name | Width | Key Changes |
|
|
189
|
+
|------|-------|-------------|
|
|
190
|
+
| Mobile Small | <375px | Single column, compact search |
|
|
191
|
+
| Mobile | 375–550px | Standard mobile listing grid |
|
|
192
|
+
| Tablet Small | 550–744px | 2-column listings |
|
|
193
|
+
| Tablet | 744–950px | Search bar expansion |
|
|
194
|
+
| Desktop Small | 950–1128px | 3-column listings |
|
|
195
|
+
| Desktop | 1128–1440px | 4-column grid, full header |
|
|
196
|
+
| Large Desktop | 1440–1920px | 5-column grid |
|
|
197
|
+
| Ultra-wide | >1920px | Maximum grid width |
|
|
198
|
+
|
|
199
|
+
*Note: Airbnb has 61 detected breakpoints — one of the most granular responsive systems observed, reflecting their obsession with layout at every possible screen size.*
|
|
200
|
+
|
|
201
|
+
### Touch Targets
|
|
202
|
+
- Circular nav buttons: adequate 50% radius sizing
|
|
203
|
+
- Listing cards: full-card tap target on mobile
|
|
204
|
+
- Search bar: prominently sized for thumb interaction
|
|
205
|
+
- Category pills: horizontally scrollable with generous padding
|
|
206
|
+
|
|
207
|
+
### Collapsing Strategy
|
|
208
|
+
- Listing grid: 5 → 4 → 3 → 2 → 1 columns
|
|
209
|
+
- Search: expanded bar → compact bar → overlay
|
|
210
|
+
- Category pills: horizontal scroll at all sizes
|
|
211
|
+
- Navigation: full header → mobile simplified
|
|
212
|
+
- Map: side panel → overlay/toggle
|
|
213
|
+
|
|
214
|
+
### Image Behavior
|
|
215
|
+
- Listing photos: carousel with swipe on mobile
|
|
216
|
+
- Responsive image sizing with aspect ratio maintained
|
|
217
|
+
- Heart overlay positioned consistently across sizes
|
|
218
|
+
- Photo quality adjusts based on viewport
|
|
219
|
+
|
|
220
|
+
## 9. Agent Prompt Guide
|
|
221
|
+
|
|
222
|
+
### Quick Color Reference
|
|
223
|
+
- Background: Pure White (`#ffffff`)
|
|
224
|
+
- Text: Near Black (`#222222`)
|
|
225
|
+
- Brand accent: Rausch Red (`#ff385c`)
|
|
226
|
+
- Secondary text: `#6a6a6a`
|
|
227
|
+
- Disabled: `rgba(0,0,0,0.24)`
|
|
228
|
+
- Card border: `rgba(0,0,0,0.02) 0px 0px 0px 1px`
|
|
229
|
+
- Card shadow: full three-layer stack
|
|
230
|
+
- Button surface: `#f2f2f2`
|
|
231
|
+
|
|
232
|
+
### Example Component Prompts
|
|
233
|
+
- "Create a listing card: white background, 20px radius. Three-layer shadow: rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px. Photo area on top (16:10 ratio), details below: 16px Airbnb Cereal VF weight 600 title, 14px weight 400 description in #6a6a6a."
|
|
234
|
+
- "Design search bar: white background, full card shadow, 32px radius on container. Search text at 14px Cereal VF weight 400. Red search button (#ff385c, 50% radius, white icon)."
|
|
235
|
+
- "Build category pill bar: horizontal scrollable row. Each pill: 14px Cereal VF weight 600, #222222 text, bottom border on active. Circular prev/next arrows (#f2f2f2 bg, 50% radius)."
|
|
236
|
+
- "Create a CTA button: #222222 background, white text, 8px radius, 16px Cereal VF weight 500, 0px 24px padding. Hover: brand red accent."
|
|
237
|
+
- "Design a heart/wishlist button: transparent background, 50% radius, white heart icon with dark shadow outline."
|
|
238
|
+
|
|
239
|
+
### Iteration Guide
|
|
240
|
+
1. Start with white — the photography provides all the color
|
|
241
|
+
2. Rausch Red (#ff385c) is the singular accent — use sparingly for CTAs only
|
|
242
|
+
3. Near-black (#222222) for text — the warmth matters
|
|
243
|
+
4. Three-layer shadows create natural, warm lift — always use all three layers
|
|
244
|
+
5. Generous radius: 8px buttons, 20px cards, 50% controls
|
|
245
|
+
6. Cereal VF at 500–700 weight — no thin weights for any heading
|
|
246
|
+
7. Photography is hero — every listing card is image-first
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
# Airbnb Inspired Design System
|
|
2
|
+
|
|
3
|
+
[DESIGN.md](https://github.com/VoltAgent/awesome-design-md/blob/main/design-md/airbnb/DESIGN.md) extracted from the public [airbnb](https://airbnb.com/) 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.
|
|
4
|
+
|
|
5
|
+
## Files
|
|
6
|
+
|
|
7
|
+
| File | Description |
|
|
8
|
+
|------|-------------|
|
|
9
|
+
| `DESIGN.md` | Complete design system documentation (9 sections) |
|
|
10
|
+
| `preview.html` | Interactive design token catalog (light) |
|
|
11
|
+
| `preview-dark.html` | Interactive design token catalog (dark) |
|
|
12
|
+
|
|
13
|
+
Use [DESIGN.md](https://github.com/VoltAgent/awesome-design-md/blob/main/design-md/airbnb/DESIGN.md) to use as a reference for AI agents (Claude, Cursor, Stitch) to generate UI that looks like the Airbnb design language.
|
|
14
|
+
|
|
15
|
+
## Preview
|
|
16
|
+
|
|
17
|
+
A sample landing page built with DESIGN.md. It shows the actual colors, typography, buttons, cards, spacing, and elevation, all in one page.
|
|
18
|
+
|
|
19
|
+
### Dark Mode
|
|
20
|
+

|
|
21
|
+
|
|
22
|
+
### Light Mode
|
|
23
|
+

|