oh-my-design-cli 0.1.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.
Files changed (317) hide show
  1. package/LICENSE +21 -0
  2. package/README.ja.md +145 -0
  3. package/README.ko.md +245 -0
  4. package/README.md +245 -0
  5. package/README.zh-TW.md +145 -0
  6. package/data/reference-tags.md +104 -0
  7. package/data/synonyms.json +79 -0
  8. package/data/vocabulary.json +516 -0
  9. package/dist/bin/oh-my-design.js +858 -0
  10. package/dist/bin/oh-my-design.js.map +1 -0
  11. package/dist/chunk-6YNSV3VY.js +35 -0
  12. package/dist/chunk-6YNSV3VY.js.map +1 -0
  13. package/dist/chunk-MHFYGZSO.js +337 -0
  14. package/dist/chunk-MHFYGZSO.js.map +1 -0
  15. package/dist/chunk-N2JG6N4Q.js +264 -0
  16. package/dist/chunk-N2JG6N4Q.js.map +1 -0
  17. package/dist/chunk-OOQQEUGX.js +46 -0
  18. package/dist/chunk-OOQQEUGX.js.map +1 -0
  19. package/dist/chunk-OR5DHENY.js +250 -0
  20. package/dist/chunk-OR5DHENY.js.map +1 -0
  21. package/dist/customizer-CM76752R.js +8 -0
  22. package/dist/customizer-CM76752R.js.map +1 -0
  23. package/dist/index.d.ts +559 -0
  24. package/dist/index.js +3113 -0
  25. package/dist/index.js.map +1 -0
  26. package/dist/init-STACB7E5.js +635 -0
  27. package/dist/init-STACB7E5.js.map +1 -0
  28. package/dist/install-skills-CM6VXFZJ.js +152 -0
  29. package/dist/install-skills-CM6VXFZJ.js.map +1 -0
  30. package/dist/learn-33LHKEJA.js +140 -0
  31. package/dist/learn-33LHKEJA.js.map +1 -0
  32. package/dist/reference-YMNAOXJQ.js +47 -0
  33. package/dist/reference-YMNAOXJQ.js.map +1 -0
  34. package/dist/reference-parser-TM3CJPNE.js +10 -0
  35. package/dist/reference-parser-TM3CJPNE.js.map +1 -0
  36. package/dist/remember-UAFA5B2O.js +78 -0
  37. package/dist/remember-UAFA5B2O.js.map +1 -0
  38. package/dist/sync-P7X4S2DK.js +404 -0
  39. package/dist/sync-P7X4S2DK.js.map +1 -0
  40. package/dist/templates/templates/design-md.hbs +44 -0
  41. package/dist/templates/templates/partials/agent-prompt-guide.hbs +28 -0
  42. package/dist/templates/templates/partials/color-palette.hbs +49 -0
  43. package/dist/templates/templates/partials/component-stylings.hbs +28 -0
  44. package/dist/templates/templates/partials/depth-elevation.hbs +31 -0
  45. package/dist/templates/templates/partials/dos-donts.hbs +13 -0
  46. package/dist/templates/templates/partials/layout.hbs +30 -0
  47. package/dist/templates/templates/partials/responsive.hbs +25 -0
  48. package/dist/templates/templates/partials/shadcn-tokens.hbs +64 -0
  49. package/dist/templates/templates/partials/typography.hbs +43 -0
  50. package/dist/templates/templates/partials/visual-theme.hbs +26 -0
  51. package/package.json +68 -0
  52. package/references/Claude-Design-Sys-Prompt.txt +421 -0
  53. package/references/airbnb/DESIGN.md +427 -0
  54. package/references/airbnb/README.md +23 -0
  55. package/references/airbnb/preview-dark.html +234 -0
  56. package/references/airbnb/preview.html +233 -0
  57. package/references/airtable/DESIGN.md +107 -0
  58. package/references/airtable/README.md +23 -0
  59. package/references/airtable/preview-dark.html +165 -0
  60. package/references/airtable/preview.html +164 -0
  61. package/references/apple/DESIGN.md +496 -0
  62. package/references/apple/README.md +24 -0
  63. package/references/apple/preview-dark.html +420 -0
  64. package/references/apple/preview.html +414 -0
  65. package/references/baemin/DESIGN.md +260 -0
  66. package/references/baemin/README.md +19 -0
  67. package/references/bmw/DESIGN.md +180 -0
  68. package/references/bmw/README.md +23 -0
  69. package/references/bmw/preview-dark.html +211 -0
  70. package/references/bmw/preview.html +210 -0
  71. package/references/cal/DESIGN.md +259 -0
  72. package/references/cal/README.md +23 -0
  73. package/references/cal/preview-dark.html +449 -0
  74. package/references/cal/preview.html +575 -0
  75. package/references/claude/DESIGN.md +455 -0
  76. package/references/claude/README.md +24 -0
  77. package/references/claude/preview-dark.html +803 -0
  78. package/references/claude/preview.html +826 -0
  79. package/references/clay/DESIGN.md +304 -0
  80. package/references/clay/README.md +23 -0
  81. package/references/clay/preview-dark.html +316 -0
  82. package/references/clay/preview.html +315 -0
  83. package/references/clickhouse/DESIGN.md +281 -0
  84. package/references/clickhouse/README.md +24 -0
  85. package/references/clickhouse/preview-dark.html +834 -0
  86. package/references/clickhouse/preview.html +786 -0
  87. package/references/cohere/DESIGN.md +266 -0
  88. package/references/cohere/README.md +24 -0
  89. package/references/cohere/preview-dark.html +803 -0
  90. package/references/cohere/preview.html +807 -0
  91. package/references/coinbase/DESIGN.md +129 -0
  92. package/references/coinbase/README.md +23 -0
  93. package/references/coinbase/preview-dark.html +164 -0
  94. package/references/coinbase/preview.html +163 -0
  95. package/references/composio/DESIGN.md +307 -0
  96. package/references/composio/README.md +24 -0
  97. package/references/composio/preview-dark.html +958 -0
  98. package/references/composio/preview.html +933 -0
  99. package/references/cursor/DESIGN.md +322 -0
  100. package/references/cursor/README.md +24 -0
  101. package/references/cursor/preview-dark.html +393 -0
  102. package/references/cursor/preview.html +383 -0
  103. package/references/dcard/DESIGN.md +302 -0
  104. package/references/dcard/README.md +12 -0
  105. package/references/dcard/_research/forum-1440px.png +0 -0
  106. package/references/dcard/_research.md +77 -0
  107. package/references/elevenlabs/DESIGN.md +265 -0
  108. package/references/elevenlabs/README.md +23 -0
  109. package/references/elevenlabs/preview-dark.html +252 -0
  110. package/references/elevenlabs/preview.html +251 -0
  111. package/references/expo/DESIGN.md +281 -0
  112. package/references/expo/README.md +24 -0
  113. package/references/expo/preview-dark.html +533 -0
  114. package/references/expo/preview.html +533 -0
  115. package/references/ferrari/DESIGN.md +314 -0
  116. package/references/ferrari/README.md +23 -0
  117. package/references/ferrari/preview-dark.html +1162 -0
  118. package/references/ferrari/preview.html +1122 -0
  119. package/references/figma/DESIGN.md +399 -0
  120. package/references/figma/README.md +24 -0
  121. package/references/figma/preview-dark.html +822 -0
  122. package/references/figma/preview.html +832 -0
  123. package/references/framer/DESIGN.md +246 -0
  124. package/references/framer/README.md +23 -0
  125. package/references/framer/preview-dark.html +902 -0
  126. package/references/framer/preview.html +883 -0
  127. package/references/freee/DESIGN.md +308 -0
  128. package/references/freee/README.md +12 -0
  129. package/references/freee/_research/vibes-storybook-1440px.png +0 -0
  130. package/references/freee/_research.md +77 -0
  131. package/references/hashicorp/DESIGN.md +278 -0
  132. package/references/hashicorp/README.md +24 -0
  133. package/references/hashicorp/preview-dark.html +1202 -0
  134. package/references/hashicorp/preview.html +1193 -0
  135. package/references/ibm/DESIGN.md +332 -0
  136. package/references/ibm/README.md +24 -0
  137. package/references/ibm/preview-dark.html +443 -0
  138. package/references/ibm/preview.html +428 -0
  139. package/references/intercom/DESIGN.md +146 -0
  140. package/references/intercom/README.md +23 -0
  141. package/references/intercom/preview-dark.html +185 -0
  142. package/references/intercom/preview.html +184 -0
  143. package/references/kakao/DESIGN.md +261 -0
  144. package/references/kakao/README.md +18 -0
  145. package/references/karrot/DESIGN.md +252 -0
  146. package/references/karrot/README.md +18 -0
  147. package/references/kraken/DESIGN.md +146 -0
  148. package/references/kraken/README.md +23 -0
  149. package/references/kraken/preview-dark.html +169 -0
  150. package/references/kraken/preview.html +168 -0
  151. package/references/lamborghini/DESIGN.md +288 -0
  152. package/references/lamborghini/README.md +23 -0
  153. package/references/lamborghini/preview-dark.html +303 -0
  154. package/references/lamborghini/preview.html +381 -0
  155. package/references/line/DESIGN.md +375 -0
  156. package/references/line/README.md +12 -0
  157. package/references/line/_research/home-1440px.png +0 -0
  158. package/references/line/_research.md +65 -0
  159. package/references/linear.app/DESIGN.md +526 -0
  160. package/references/linear.app/README.md +24 -0
  161. package/references/linear.app/preview-dark.html +383 -0
  162. package/references/linear.app/preview.html +373 -0
  163. package/references/lovable/DESIGN.md +298 -0
  164. package/references/lovable/README.md +24 -0
  165. package/references/lovable/preview-dark.html +349 -0
  166. package/references/lovable/preview.html +348 -0
  167. package/references/mercari/DESIGN.md +294 -0
  168. package/references/mercari/README.md +12 -0
  169. package/references/mercari/_research/home-1440px.png +0 -0
  170. package/references/mercari/_research.md +77 -0
  171. package/references/minimax/DESIGN.md +257 -0
  172. package/references/minimax/README.md +24 -0
  173. package/references/minimax/preview-dark.html +1262 -0
  174. package/references/minimax/preview.html +1248 -0
  175. package/references/mintlify/DESIGN.md +341 -0
  176. package/references/mintlify/README.md +24 -0
  177. package/references/mintlify/preview-dark.html +409 -0
  178. package/references/mintlify/preview.html +398 -0
  179. package/references/miro/DESIGN.md +108 -0
  180. package/references/miro/README.md +23 -0
  181. package/references/miro/preview-dark.html +174 -0
  182. package/references/miro/preview.html +173 -0
  183. package/references/mistral.ai/DESIGN.md +261 -0
  184. package/references/mistral.ai/README.md +24 -0
  185. package/references/mistral.ai/preview-dark.html +806 -0
  186. package/references/mistral.ai/preview.html +805 -0
  187. package/references/mongodb/DESIGN.md +266 -0
  188. package/references/mongodb/README.md +23 -0
  189. package/references/mongodb/preview-dark.html +260 -0
  190. package/references/mongodb/preview.html +259 -0
  191. package/references/notion/DESIGN.md +492 -0
  192. package/references/notion/README.md +24 -0
  193. package/references/notion/preview-dark.html +372 -0
  194. package/references/notion/preview.html +364 -0
  195. package/references/nvidia/DESIGN.md +308 -0
  196. package/references/nvidia/README.md +24 -0
  197. package/references/nvidia/preview-dark.html +374 -0
  198. package/references/nvidia/preview.html +366 -0
  199. package/references/ollama/DESIGN.md +267 -0
  200. package/references/ollama/README.md +24 -0
  201. package/references/ollama/preview-dark.html +678 -0
  202. package/references/ollama/preview.html +678 -0
  203. package/references/opencode.ai/DESIGN.md +295 -0
  204. package/references/opencode.ai/README.md +24 -0
  205. package/references/opencode.ai/preview-dark.html +366 -0
  206. package/references/opencode.ai/preview.html +357 -0
  207. package/references/pinkoi/DESIGN.md +309 -0
  208. package/references/pinkoi/README.md +12 -0
  209. package/references/pinkoi/_research/browse-1440px.png +0 -0
  210. package/references/pinkoi/_research.md +115 -0
  211. package/references/pinterest/DESIGN.md +230 -0
  212. package/references/pinterest/README.md +23 -0
  213. package/references/pinterest/preview-dark.html +233 -0
  214. package/references/pinterest/preview.html +232 -0
  215. package/references/posthog/DESIGN.md +256 -0
  216. package/references/posthog/README.md +23 -0
  217. package/references/posthog/preview-dark.html +699 -0
  218. package/references/posthog/preview.html +749 -0
  219. package/references/raycast/DESIGN.md +268 -0
  220. package/references/raycast/README.md +23 -0
  221. package/references/raycast/preview-dark.html +606 -0
  222. package/references/raycast/preview.html +688 -0
  223. package/references/renault/DESIGN.md +311 -0
  224. package/references/renault/README.md +23 -0
  225. package/references/renault/preview-dark.html +406 -0
  226. package/references/renault/preview.html +606 -0
  227. package/references/replicate/DESIGN.md +261 -0
  228. package/references/replicate/README.md +24 -0
  229. package/references/replicate/preview-dark.html +828 -0
  230. package/references/replicate/preview.html +831 -0
  231. package/references/resend/DESIGN.md +303 -0
  232. package/references/resend/README.md +23 -0
  233. package/references/resend/preview-dark.html +355 -0
  234. package/references/resend/preview.html +354 -0
  235. package/references/revolut/DESIGN.md +185 -0
  236. package/references/revolut/README.md +23 -0
  237. package/references/revolut/preview-dark.html +234 -0
  238. package/references/revolut/preview.html +233 -0
  239. package/references/runwayml/DESIGN.md +244 -0
  240. package/references/runwayml/README.md +24 -0
  241. package/references/runwayml/preview-dark.html +664 -0
  242. package/references/runwayml/preview.html +665 -0
  243. package/references/sanity/DESIGN.md +357 -0
  244. package/references/sanity/README.md +24 -0
  245. package/references/sanity/preview-dark.html +990 -0
  246. package/references/sanity/preview.html +1135 -0
  247. package/references/sentry/DESIGN.md +262 -0
  248. package/references/sentry/README.md +24 -0
  249. package/references/sentry/preview-dark.html +626 -0
  250. package/references/sentry/preview.html +951 -0
  251. package/references/spacex/DESIGN.md +205 -0
  252. package/references/spacex/README.md +23 -0
  253. package/references/spacex/preview-dark.html +221 -0
  254. package/references/spacex/preview.html +220 -0
  255. package/references/spotify/DESIGN.md +246 -0
  256. package/references/spotify/README.md +23 -0
  257. package/references/spotify/preview-dark.html +231 -0
  258. package/references/spotify/preview.html +230 -0
  259. package/references/stripe/DESIGN.md +473 -0
  260. package/references/stripe/README.md +24 -0
  261. package/references/stripe/preview-dark.html +428 -0
  262. package/references/stripe/preview.html +419 -0
  263. package/references/supabase/DESIGN.md +255 -0
  264. package/references/supabase/README.md +24 -0
  265. package/references/supabase/preview-dark.html +977 -0
  266. package/references/supabase/preview.html +955 -0
  267. package/references/superhuman/DESIGN.md +252 -0
  268. package/references/superhuman/README.md +23 -0
  269. package/references/superhuman/preview-dark.html +973 -0
  270. package/references/superhuman/preview.html +951 -0
  271. package/references/tesla/DESIGN.md +286 -0
  272. package/references/tesla/README.md +23 -0
  273. package/references/tesla/preview-dark.html +947 -0
  274. package/references/tesla/preview.html +925 -0
  275. package/references/together.ai/DESIGN.md +263 -0
  276. package/references/together.ai/README.md +24 -0
  277. package/references/together.ai/preview-dark.html +892 -0
  278. package/references/together.ai/preview.html +897 -0
  279. package/references/toss/DESIGN.md +387 -0
  280. package/references/toss/README.md +19 -0
  281. package/references/uber/DESIGN.md +295 -0
  282. package/references/uber/README.md +24 -0
  283. package/references/uber/preview-dark.html +1120 -0
  284. package/references/uber/preview.html +1119 -0
  285. package/references/vercel/DESIGN.md +456 -0
  286. package/references/vercel/README.md +24 -0
  287. package/references/vercel/preview-dark.html +368 -0
  288. package/references/vercel/preview.html +367 -0
  289. package/references/voltagent/DESIGN.md +323 -0
  290. package/references/voltagent/README.md +24 -0
  291. package/references/voltagent/preview-dark.html +487 -0
  292. package/references/voltagent/preview.html +766 -0
  293. package/references/warp/DESIGN.md +253 -0
  294. package/references/warp/README.md +23 -0
  295. package/references/warp/preview-dark.html +500 -0
  296. package/references/warp/preview.html +533 -0
  297. package/references/webflow/DESIGN.md +109 -0
  298. package/references/webflow/README.md +23 -0
  299. package/references/webflow/preview-dark.html +147 -0
  300. package/references/webflow/preview.html +146 -0
  301. package/references/wise/DESIGN.md +173 -0
  302. package/references/wise/README.md +23 -0
  303. package/references/wise/preview-dark.html +230 -0
  304. package/references/wise/preview.html +229 -0
  305. package/references/x.ai/DESIGN.md +267 -0
  306. package/references/x.ai/README.md +24 -0
  307. package/references/x.ai/preview-dark.html +356 -0
  308. package/references/x.ai/preview.html +407 -0
  309. package/references/zapier/DESIGN.md +328 -0
  310. package/references/zapier/README.md +24 -0
  311. package/references/zapier/preview-dark.html +380 -0
  312. package/references/zapier/preview.html +372 -0
  313. package/skills/omd-apply/SKILL.md +85 -0
  314. package/skills/omd-init/SKILL.md +167 -0
  315. package/skills/omd-learn/SKILL.md +81 -0
  316. package/skills/omd-remember/SKILL.md +44 -0
  317. package/skills/omd-sync/SKILL.md +38 -0
@@ -0,0 +1,456 @@
1
+ ---
2
+ omd: 0.1
3
+ brand: Vercel
4
+ ---
5
+
6
+ # Design System Inspiration of Vercel
7
+
8
+ ## 1. Visual Theme & Atmosphere
9
+
10
+ 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.
11
+
12
+ 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.
13
+
14
+ 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.
15
+
16
+ **Key Characteristics:**
17
+ - Geist Sans with extreme negative letter-spacing (-2.4px to -2.88px at display) — text as compressed infrastructure
18
+ - Geist Mono for code and technical labels with OpenType `"liga"` globally
19
+ - Shadow-as-border technique: `box-shadow 0px 0px 0px 1px` replaces traditional borders throughout
20
+ - Multi-layer shadow stacks for nuanced depth (border + elevation + ambient in single declarations)
21
+ - Near-pure white canvas with `#171717` text — not quite black, creating micro-contrast softness
22
+ - Workflow-specific accent colors: Ship Red (`#ff5b4f`), Preview Pink (`#de1d8d`), Develop Blue (`#0a72ef`)
23
+ - Focus ring system using `hsla(212, 100%, 48%, 1)` — a saturated blue for accessibility
24
+ - Pill badges (9999px) with tinted backgrounds for status indicators
25
+
26
+ ## 2. Color Palette & Roles
27
+
28
+ ### Primary
29
+ - **Vercel Black** (`#171717`): Primary text, headings, dark surface backgrounds. Not pure black — the slight warmth prevents harshness.
30
+ - **Pure White** (`#ffffff`): Page background, card surfaces, button text on dark.
31
+ - **True Black** (`#000000`): Secondary use, `--geist-console-text-color-default`, used in specific console/code contexts.
32
+
33
+ ### Workflow Accent Colors
34
+ - **Ship Red** (`#ff5b4f`): `--ship-text`, the "ship to production" workflow step — warm, urgent coral-red.
35
+ - **Preview Pink** (`#de1d8d`): `--preview-text`, the preview deployment workflow — vivid magenta-pink.
36
+ - **Develop Blue** (`#0a72ef`): `--develop-text`, the development workflow — bright, focused blue.
37
+
38
+ ### Console / Code Colors
39
+ - **Console Blue** (`#0070f3`): `--geist-console-text-color-blue`, syntax highlighting blue.
40
+ - **Console Purple** (`#7928ca`): `--geist-console-text-color-purple`, syntax highlighting purple.
41
+ - **Console Pink** (`#eb367f`): `--geist-console-text-color-pink`, syntax highlighting pink.
42
+
43
+ ### Interactive
44
+ - **Link Blue** (`#0072f5`): Primary link color with underline decoration.
45
+ - **Focus Blue** (`hsla(212, 100%, 48%, 1)`): `--ds-focus-color`, focus ring on interactive elements.
46
+ - **Ring Blue** (`rgba(147, 197, 253, 0.5)`): `--tw-ring-color`, Tailwind ring utility.
47
+
48
+ ### Neutral Scale
49
+ - **Gray 900** (`#171717`): Primary text, headings, nav text.
50
+ - **Gray 600** (`#4d4d4d`): Secondary text, description copy.
51
+ - **Gray 500** (`#666666`): Tertiary text, muted links.
52
+ - **Gray 400** (`#808080`): Placeholder text, disabled states.
53
+ - **Gray 100** (`#ebebeb`): Borders, card outlines, dividers.
54
+ - **Gray 50** (`#fafafa`): Subtle surface tint, inner shadow highlight.
55
+
56
+ ### Surface & Overlay
57
+ - **Overlay Backdrop** (`hsla(0, 0%, 98%, 1)`): `--ds-overlay-backdrop-color`, modal/dialog backdrop.
58
+ - **Selection Text** (`hsla(0, 0%, 95%, 1)`): `--geist-selection-text-color`, text selection highlight.
59
+ - **Badge Blue Bg** (`#ebf5ff`): Pill badge background, tinted blue surface.
60
+ - **Badge Blue Text** (`#0068d6`): Pill badge text, darker blue for readability.
61
+
62
+ ### Shadows & Depth
63
+ - **Border Shadow** (`rgba(0, 0, 0, 0.08) 0px 0px 0px 1px`): The signature — replaces traditional borders.
64
+ - **Subtle Elevation** (`rgba(0, 0, 0, 0.04) 0px 2px 2px`): Minimal lift for cards.
65
+ - **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.
66
+ - **Ring Border** (`rgb(235, 235, 235) 0px 0px 0px 1px`): Light gray ring-border for tabs and images.
67
+
68
+ ## 3. Typography Rules
69
+
70
+ ### Font Family
71
+ - **Primary**: `Geist`, with fallbacks: `Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol`
72
+ - **Monospace**: `Geist Mono`, with fallbacks: `ui-monospace, SFMono-Regular, Roboto Mono, Menlo, Monaco, Liberation Mono, DejaVu Sans Mono, Courier New`
73
+ - **OpenType Features**: `"liga"` enabled globally on all Geist text; `"tnum"` for tabular numbers on specific captions.
74
+
75
+ ### Hierarchy
76
+
77
+ | Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
78
+ |------|------|------|--------|-------------|----------------|-------|
79
+ | Display Hero | Geist | 48px (3.00rem) | 600 | 1.00–1.17 (tight) | -2.4px to -2.88px | Maximum compression, billboard impact |
80
+ | Section Heading | Geist | 40px (2.50rem) | 600 | 1.20 (tight) | -2.4px | Feature section titles |
81
+ | Sub-heading Large | Geist | 32px (2.00rem) | 600 | 1.25 (tight) | -1.28px | Card headings, sub-sections |
82
+ | Sub-heading | Geist | 32px (2.00rem) | 400 | 1.50 | -1.28px | Lighter sub-headings |
83
+ | Card Title | Geist | 24px (1.50rem) | 600 | 1.33 | -0.96px | Feature cards |
84
+ | Card Title Light | Geist | 24px (1.50rem) | 500 | 1.33 | -0.96px | Secondary card headings |
85
+ | Body Large | Geist | 20px (1.25rem) | 400 | 1.80 (relaxed) | normal | Introductions, feature descriptions |
86
+ | Body | Geist | 18px (1.13rem) | 400 | 1.56 | normal | Standard reading text |
87
+ | Body Small | Geist | 16px (1.00rem) | 400 | 1.50 | normal | Standard UI text |
88
+ | Body Medium | Geist | 16px (1.00rem) | 500 | 1.50 | normal | Navigation, emphasized text |
89
+ | Body Semibold | Geist | 16px (1.00rem) | 600 | 1.50 | -0.32px | Strong labels, active states |
90
+ | Button / Link | Geist | 14px (0.88rem) | 500 | 1.43 | normal | Buttons, links, captions |
91
+ | Button Small | Geist | 14px (0.88rem) | 400 | 1.00 (tight) | normal | Compact buttons |
92
+ | Caption | Geist | 12px (0.75rem) | 400–500 | 1.33 | normal | Metadata, tags |
93
+ | Mono Body | Geist Mono | 16px (1.00rem) | 400 | 1.50 | normal | Code blocks |
94
+ | Mono Caption | Geist Mono | 13px (0.81rem) | 500 | 1.54 | normal | Code labels |
95
+ | Mono Small | Geist Mono | 12px (0.75rem) | 500 | 1.00 (tight) | normal | `text-transform: uppercase`, technical labels |
96
+ | Micro Badge | Geist | 7px (0.44rem) | 700 | 1.00 (tight) | normal | `text-transform: uppercase`, tiny badges |
97
+
98
+ ### Principles
99
+ - **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.
100
+ - **Ligatures everywhere**: Every Geist text element enables OpenType `"liga"`. Ligatures aren't decorative — they're structural, creating tighter, more efficient glyph combinations.
101
+ - **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.
102
+ - **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.
103
+
104
+ ## 4. Component Stylings
105
+
106
+ ### Buttons
107
+
108
+ **Primary White (Shadow-bordered)**
109
+ - Background: `#ffffff`
110
+ - Text: `#171717`
111
+ - Padding: 0px 6px (minimal — content-driven width)
112
+ - Radius: 6px (subtly rounded)
113
+ - Shadow: `rgb(235, 235, 235) 0px 0px 0px 1px` (ring-border)
114
+ - Hover: background shifts to `var(--ds-gray-1000)` (dark)
115
+ - Focus: `2px solid var(--ds-focus-color)` outline + `var(--ds-focus-ring)` shadow
116
+ - Use: Standard secondary button
117
+
118
+ **Primary Dark (Inferred from Geist system)**
119
+ - Background: `#171717`
120
+ - Text: `#ffffff`
121
+ - Padding: 8px 16px
122
+ - Radius: 6px
123
+ - Use: Primary CTA ("Start Deploying", "Get Started")
124
+
125
+ **Pill Button / Badge**
126
+ - Background: `#ebf5ff` (tinted blue)
127
+ - Text: `#0068d6`
128
+ - Padding: 0px 10px
129
+ - Radius: 9999px (full pill)
130
+ - Font: 12px weight 500
131
+ - Use: Status badges, tags, feature labels
132
+
133
+ **Large Pill (Navigation)**
134
+ - Background: transparent or `#171717`
135
+ - Radius: 64px–100px
136
+ - Use: Tab navigation, section selectors
137
+
138
+ ### Cards & Containers
139
+ - Background: `#ffffff`
140
+ - Border: via shadow — `rgba(0, 0, 0, 0.08) 0px 0px 0px 1px`
141
+ - Radius: 8px (standard), 12px (featured/image cards)
142
+ - 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`
143
+ - Image cards: `1px solid #ebebeb` with 12px top radius
144
+ - Hover: subtle shadow intensification
145
+
146
+ ### Inputs & Forms
147
+ - Radio: standard styling with focus `var(--ds-gray-200)` background
148
+ - Focus shadow: `1px 0 0 0 var(--ds-gray-alpha-600)`
149
+ - Focus outline: `2px solid var(--ds-focus-color)` — consistent blue focus ring
150
+ - Border: via shadow technique, not traditional border
151
+
152
+ ### Navigation
153
+ - Clean horizontal nav on white, sticky
154
+ - Vercel logotype left-aligned, 262x52px
155
+ - Links: Geist 14px weight 500, `#171717` text
156
+ - Active: weight 600 or underline
157
+ - CTA: dark pill buttons ("Start Deploying", "Contact Sales")
158
+ - Mobile: hamburger menu collapse
159
+ - Product dropdowns with multi-level menus
160
+
161
+ ### Image Treatment
162
+ - Product screenshots with `1px solid #ebebeb` border
163
+ - Top-rounded images: `12px 12px 0px 0px` radius
164
+ - Dashboard/code preview screenshots dominate feature sections
165
+ - Soft gradient backgrounds behind hero images (pastel multi-color)
166
+
167
+ ### Distinctive Components
168
+
169
+ **Workflow Pipeline**
170
+ - Three-step horizontal pipeline: Develop → Preview → Ship
171
+ - Each step has its own accent color: Blue → Pink → Red
172
+ - Connected with lines/arrows
173
+ - The visual metaphor for Vercel's core value proposition
174
+
175
+ **Trust Bar / Logo Grid**
176
+ - Company logos (Perplexity, ChatGPT, Cursor, etc.) in grayscale
177
+ - Horizontal scroll or grid layout
178
+ - Subtle `#ebebeb` border separation
179
+
180
+ **Metric Cards**
181
+ - Large number display (e.g., "10x faster")
182
+ - Geist 48px weight 600 for the metric
183
+ - Description below in gray body text
184
+ - Shadow-bordered card container
185
+
186
+ ## 5. Layout Principles
187
+
188
+ ### Spacing System
189
+ - Base unit: 8px
190
+ - Scale: 1px, 2px, 3px, 4px, 5px, 6px, 8px, 10px, 12px, 14px, 16px, 32px, 36px, 40px
191
+ - Notable gap: jumps from 16px to 32px — no 20px or 24px in primary scale
192
+
193
+ ### Grid & Container
194
+ - Max content width: approximately 1200px
195
+ - Hero: centered single-column with generous top padding
196
+ - Feature sections: 2–3 column grids for cards
197
+ - Full-width dividers using `border-bottom: 1px solid #171717`
198
+ - Code/dashboard screenshots as full-width or contained with border
199
+
200
+ ### Whitespace Philosophy
201
+ - **Gallery emptiness**: Massive vertical padding between sections (80px–120px+). The white space IS the design — it communicates that Vercel has nothing to prove and nothing to hide.
202
+ - **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.
203
+ - **Section rhythm**: White sections alternate with white sections — there's no color variation between sections. Separation comes from borders (shadow-borders) and spacing alone.
204
+
205
+ ### Border Radius Scale
206
+ - Micro (2px): Inline code snippets, small spans
207
+ - Subtle (4px): Small containers
208
+ - Standard (6px): Buttons, links, functional elements
209
+ - Comfortable (8px): Cards, list items
210
+ - Image (12px): Featured cards, image containers (top-rounded)
211
+ - Large (64px): Tab navigation pills
212
+ - XL (100px): Large navigation links
213
+ - Full Pill (9999px): Badges, status pills, tags
214
+ - Circle (50%): Menu toggle, avatar containers
215
+
216
+ ## 6. Depth & Elevation
217
+
218
+ | Level | Treatment | Use |
219
+ |-------|-----------|-----|
220
+ | Flat (Level 0) | No shadow | Page background, text blocks |
221
+ | Ring (Level 1) | `rgba(0,0,0,0.08) 0px 0px 0px 1px` | Shadow-as-border for most elements |
222
+ | Light Ring (Level 1b) | `rgb(235,235,235) 0px 0px 0px 1px` | Lighter ring for tabs, images |
223
+ | Subtle Card (Level 2) | Ring + `rgba(0,0,0,0.04) 0px 2px 2px` | Standard cards with minimal lift |
224
+ | Full Card (Level 3) | Ring + Subtle + `rgba(0,0,0,0.04) 0px 8px 8px -8px` + inner `#fafafa` ring | Featured cards, highlighted panels |
225
+ | Focus (Accessibility) | `2px solid hsla(212, 100%, 48%, 1)` outline | Keyboard focus on all interactive elements |
226
+
227
+ **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.
228
+
229
+ ### Decorative Depth
230
+ - Hero gradient: soft, pastel multi-color gradient wash behind hero content (barely visible, atmospheric)
231
+ - Section borders: `1px solid #171717` (full dark line) between major sections
232
+ - No background color variation — depth comes entirely from shadow layering and border contrast
233
+
234
+ ## 7. Do's and Don'ts
235
+
236
+ ### Do
237
+ - Use Geist Sans with aggressive negative letter-spacing at display sizes (-2.4px to -2.88px at 48px)
238
+ - Use shadow-as-border (`0px 0px 0px 1px rgba(0,0,0,0.08)`) instead of traditional CSS borders
239
+ - Enable `"liga"` on all Geist text — ligatures are structural, not optional
240
+ - Use the three-weight system: 400 (body), 500 (UI), 600 (headings)
241
+ - Apply workflow accent colors (Red/Pink/Blue) only in their workflow context
242
+ - Use multi-layer shadow stacks for cards (border + elevation + ambient + inner highlight)
243
+ - Keep the color palette achromatic — grays from `#171717` to `#ffffff` are the system
244
+ - Use `#171717` instead of `#000000` for primary text — the micro-warmth matters
245
+
246
+ ### Don't
247
+ - Don't use positive letter-spacing on Geist Sans — it's always negative or zero
248
+ - Don't use weight 700 (bold) on body text — 600 is the maximum, used only for headings
249
+ - Don't use traditional CSS `border` on cards — use the shadow-border technique
250
+ - Don't introduce warm colors (oranges, yellows, greens) into the UI chrome
251
+ - Don't apply the workflow accent colors (Ship Red, Preview Pink, Develop Blue) decoratively
252
+ - Don't use heavy shadows (> 0.1 opacity) — the shadow system is whisper-level
253
+ - Don't increase body text letter-spacing — Geist is designed to run tight
254
+ - Don't use pill radius (9999px) on primary action buttons — pills are for badges/tags only
255
+ - Don't skip the inner `#fafafa` ring in card shadows — it's the glow that makes the system work
256
+
257
+ ## 8. Responsive Behavior
258
+
259
+ ### Breakpoints
260
+ | Name | Width | Key Changes |
261
+ |------|-------|-------------|
262
+ | Mobile Small | <400px | Tight single column, minimal padding |
263
+ | Mobile | 400–600px | Standard mobile, stacked layout |
264
+ | Tablet Small | 600–768px | 2-column grids begin |
265
+ | Tablet | 768–1024px | Full card grids, expanded padding |
266
+ | Desktop Small | 1024–1200px | Standard desktop layout |
267
+ | Desktop | 1200–1400px | Full layout, maximum content width |
268
+ | Large Desktop | >1400px | Centered, generous margins |
269
+
270
+ ### Touch Targets
271
+ - Buttons use comfortable padding (8px–16px vertical)
272
+ - Navigation links at 14px with adequate spacing
273
+ - Pill badges have 10px horizontal padding for tap targets
274
+ - Mobile menu toggle uses 50% radius circular button
275
+
276
+ ### Collapsing Strategy
277
+ - Hero: display 48px → scales down, maintains negative tracking proportionally
278
+ - Navigation: horizontal links + CTAs → hamburger menu
279
+ - Feature cards: 3-column → 2-column → single column stacked
280
+ - Code screenshots: maintain aspect ratio, may horizontally scroll
281
+ - Trust bar logos: grid → horizontal scroll
282
+ - Footer: multi-column → stacked single column
283
+ - Section spacing: 80px+ → 48px on mobile
284
+
285
+ ### Image Behavior
286
+ - Dashboard screenshots maintain border treatment at all sizes
287
+ - Hero gradient softens/simplifies on mobile
288
+ - Product screenshots use responsive images with consistent border radius
289
+ - Full-width sections maintain edge-to-edge treatment
290
+
291
+ ## 9. Agent Prompt Guide
292
+
293
+ ### Quick Color Reference
294
+ - Primary CTA: Vercel Black (`#171717`)
295
+ - Background: Pure White (`#ffffff`)
296
+ - Heading text: Vercel Black (`#171717`)
297
+ - Body text: Gray 600 (`#4d4d4d`)
298
+ - Border (shadow): `rgba(0, 0, 0, 0.08) 0px 0px 0px 1px`
299
+ - Link: Link Blue (`#0072f5`)
300
+ - Focus ring: Focus Blue (`hsla(212, 100%, 48%, 1)`)
301
+
302
+ ### Example Component Prompts
303
+ - "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)."
304
+ - "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."
305
+ - "Build a pill badge: #ebf5ff background, #0068d6 text, 9999px radius, 0px 10px padding, 12px Geist weight 500."
306
+ - "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."
307
+ - "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."
308
+
309
+ ### Iteration Guide
310
+ 1. Always use shadow-as-border instead of CSS border — `0px 0px 0px 1px rgba(0,0,0,0.08)` is the foundation
311
+ 2. Letter-spacing scales with font size: -2.4px at 48px, -1.28px at 32px, -0.96px at 24px, normal at 14px
312
+ 3. Three weights only: 400 (read), 500 (interact), 600 (announce)
313
+ 4. Color is functional, never decorative — workflow colors (Red/Pink/Blue) mark pipeline stages only
314
+ 5. The inner `#fafafa` ring in card shadows is what gives Vercel cards their subtle inner glow
315
+ 6. Geist Mono uppercase for technical labels, Geist Sans for everything else
316
+
317
+ ---
318
+
319
+ ## 10. Voice & Tone
320
+
321
+ Vercel's voice is engineer-terse, confident, and quietly clever. Headlines are short and declarative — *"Your product, delivered"*, *"Deploy once, deliver everywhere"*, *"Previews for every push"* — mirroring the compressed typography they sit in. Marketing copy reads like a well-written README: precise verbs, specific nouns, no adjective stacking. Performance claims, when made, are numeric (*"95% reduction in page load times"*, *"24x faster builds"*), not adjectival ("blazingly fast"). The Vercel Design team describes its posture as *"stewards of the Vercel Brand and Geist Design System"* — the steward word is earned by the discipline visible in every pixel and comma.
322
+
323
+ | Context | Tone |
324
+ |---|---|
325
+ | Hero headlines | Short, declarative, 4–7 words. "Build and deploy the best web experiences." |
326
+ | Product feature copy | Verb + object, concrete. "Ship fast. Stay fast." |
327
+ | CTAs | Imperative, 2–3 words. "Start Deploying", "Talk to Sales", "View Docs". |
328
+ | Error messages (dashboard, CLI) | Developer-readable: error type + specific cause + next action. |
329
+ | Docs | Terse paragraphs, heavy code examples, zero tutorial-speak. |
330
+ | Changelog / blog / "Ship" posts | Ship-proud, dated, technical. "We did X. Here's how it works." |
331
+ | Marketing enterprise | Confident but numeric; case studies over superlatives. |
332
+ | Blog / social voice | Wry, developer-insider, occasional wordplay — the brand page explicitly calls out "delightful wordplay" as part of the register. |
333
+
334
+ **Forbidden phrases.** "Blazingly fast" and "lightning-fast" as marketing adjectives — "fast" without the lightning is preferred. "Revolutionary", "game-changing", "unleash", "supercharge". Marketing toast strings like "You did it! 🎉". Emoji on product surfaces (dashboard, settings, billing) — Vercel does not toast-spam. Decorative "sparkle" language around AI features (✨ prefix on "AI Cloud" etc. is not Vercel's register, even when AI is the subject).
335
+
336
+ ## 11. Brand Narrative
337
+
338
+ Vercel was founded in 2015 by Guillermo Rauch and originally called **ZEIT**; the company renamed to Vercel in April 2020, the same moment it raised its Series A to build the cloud infrastructure underneath Next.js, the open-source React framework it had shepherded since 2016. Vercel's founding thesis is that frontend developers should not have to think about infrastructure: the framework and the deployment target should be one cognitive object, not two.
339
+
340
+ The visual language — white canvas, near-black text (`#171717`), Geist Sans with aggressive negative letter-spacing, shadow-as-border throughout — is a design statement that mirrors the product thesis. It is **minimalism as engineering principle**, not minimalism as style choice. Every element on a Vercel marketing page has been through the same "does this justify its bytes?" discipline that a well-written Next.js component goes through. The Vercel Design team puts this explicitly: *"We design systems and systemize designs. Imbuing our work with care and craft as stewards of the Vercel Brand and Geist Design System."*
341
+
342
+ What Vercel refuses: the "enterprise dev-tools dark dashboard" visual default, decorative illustrations of cloud icons and laptops, typography that wastes tracking, marketing language with adjective stacks ("blazingly fast, enterprise-grade, battle-tested"). What it embraces: Geist as a **developer-first typeface** (*"Specifically designed for developers and designers"*, per the Geist page), the Develop / Preview / Ship pipeline as a visual motif (three workflow colors), and the shadow-as-border technique as a constant reminder that the craft is in the details most teams don't ship.
343
+
344
+ ## 12. Principles
345
+
346
+ 1. **Minimalism as engineering principle, not style.** Every element justifies its bytes. A drop shadow, a background gradient, a decorative icon — each is weighed against what it adds to understanding. The Vercel Design team states this explicitly: *"We design systems and systemize designs."*
347
+ 2. **Shadow-as-border is a craft signal.** The `box-shadow: 0px 0px 0px 1px rgba(0,0,0,0.08)` technique is a technical choice with no marketing benefit — it exists because it's cleaner than `1px solid` on rounded corners. Readers of code recognize it. That recognition IS the brand.
348
+ 3. **Type is compression.** Display headlines at -2.4px to -2.88px letter-spacing make the text feel minified, engineered, urgent. Generous tracking on display text would read as consumer-brand; Vercel reads as infrastructure.
349
+ 4. **Workflow colors are semantic, not decorative.** Ship Red, Preview Pink, and Develop Blue each correspond to a specific stage in the product pipeline. Using them anywhere else — a decorative gradient, a generic CTA — breaks the pipeline metaphor.
350
+ 5. **Three weights, no more.** 400 (read), 500 (interact), 600 (announce). Vercel does not use 700 / bold in Geist Sans. The narrow weight range forces hierarchy through size and tracking.
351
+ 6. **Performance claims are numeric.** *"95% reduction in page load times"*, *"24x faster builds"* — not "blazingly fast". Developers are the audience; developers want numbers.
352
+ 7. **Consistency is the product.** The same shadow stack, the same pill-badge treatment, the same Geist Mono uppercase labels appear across the marketing site, the dashboard, the docs, and the CLI output. Consistency is how an infrastructure brand earns trust.
353
+ 8. **"Delightful wordplay" is the one license.** The Vercel Design page explicitly notes *"meticulous interactions, delightful wordplay"*. Occasional wit is allowed — but only in voice, never in visuals. The visuals stay austere.
354
+
355
+ ## 13. Personas
356
+
357
+ *Personas below are fictional archetypes informed by publicly observable Vercel user segments (frontend developers, founding engineers, DevOps engineers, engineering managers at Next.js-heavy teams), not individual people.*
358
+
359
+ **Aarav Nair, 26, Bengaluru.** Frontend developer at a Series-A startup. Deploys to Vercel 8–12 times a day via `git push`. Reads the Vercel dashboard the way he reads a terminal — eyes scanning for non-zero values. Would never use a CI product whose dashboard required mouse navigation for common tasks. Appreciates that Vercel's docs have code-first examples above paragraph explanations.
360
+
361
+ **Priya Shah, 34, Toronto.** Staff engineer at a media company. Migrated the company's React site to Next.js on Vercel two years ago. Lives in the Deployments view. Values preview URLs per PR more than any other single feature. Cares that Geist Mono renders the same in the dashboard as it does in her terminal — that visual consistency is a subtle trust signal.
362
+
363
+ **Daniel Hwang, 41, Seoul.** Engineering manager with a team of 9 frontend engineers. Uses Vercel's analytics + speed insights in weekly team syncs. Picks infrastructure partners based on dashboard clarity and docs quality, not on pricing-page calculators. Views Vercel's design restraint as a credibility signal — a dashboard that is not trying to sell him is a dashboard he trusts with production.
364
+
365
+ **Elena Romano, 28, Milan.** Founder + sole engineer of an indie SaaS. Uses Vercel because it's the shortest path from `npx create-next-app` to a live URL. Reads the Vercel blog for release notes and the occasional "how we built it" post. Finds Vercel's voice closer to how her engineer friends talk about software than how marketing teams talk about software — which is why she trusts it.
366
+
367
+ ## 14. States
368
+
369
+ | State | Treatment |
370
+ |---|---|
371
+ | **Empty (no projects)** | White canvas (`#ffffff`). Single line of Gray 900 (`#171717`) text at 18px Geist weight 500: "No projects yet." One dark pill CTA: "Add New...". No illustration, no onboarding tour. |
372
+ | **Empty (deployments list, new project)** | Gray 500 (`#666666`) caption at 14px: "Your first deployment will appear here after you push to connected Git." Single link ("Connect a repository") in Link Blue. |
373
+ | **Loading (dashboard first paint)** | Shadow-bordered skeleton blocks at Gray 100 (`#ebebeb`). 1.2s shimmer. Skeleton keeps the same `0px 0px 0px 1px` shadow-as-border as real content — geometry matches exactly on paint-in. |
374
+ | **Loading (deployment in progress)** | Status pill with Develop Blue (`#0a72ef`) text + spinning icon at 14px Geist Mono uppercase. Deployment row remains interactive; the build log is accessible during build. |
375
+ | **Error (build failed)** | Status pill in Ship Red (`#ff5b4f`). Inline expandable log shows the exact failure output. No modal. No sanitized "Build failed. Contact support." — the failure is the developer's problem to solve and the tool shows them the problem, verbatim. |
376
+ | **Error (form validation, dashboard)** | Field-level. Shadow-border switches from subtle to Ship Red at the same 1px spread. 13px caption below in Ship Red describes what is invalid and what would be valid. |
377
+ | **Error (API / runtime, serverless function)** | Dedicated error surface with the full stack trace, request ID, timestamp, region. Vercel treats runtime errors as first-class content, not toast dismissals. |
378
+ | **Success (deployment ready)** | Status pill in subtle green tint with "Ready" label in 12px Geist Mono uppercase. Deployment URL is instantly copyable. No celebratory animation. |
379
+ | **Success (action saved)** | 3s auto-dismiss toast at bottom-right. Geist weight 400, sentence case, past tense: "Settings updated." No emoji, no exclamation. |
380
+ | **Skeleton** | Shadow-bordered blocks at exact final dimensions. Gray 100 (`#ebebeb`) fill. 1.2s shimmer in Gray 50 (`#fafafa`). Never uses a different color for skeleton — stays in the monochrome palette. |
381
+ | **Disabled** | Opacity reduced on text and shadow-border together. Disabled dark buttons become `rgba(23,23,23,0.4)` fill. Geometry stable for re-enablement. |
382
+ | **Cold-start / preview latency** | Subtle banner in Gray 50 with Gray 600 text acknowledging the current cold-start cost. Transparent honesty; Vercel knows developers care about this specific latency. |
383
+
384
+ ## 15. Motion & Easing
385
+
386
+ **Durations**:
387
+
388
+ | Token | Value | Use |
389
+ |---|---|---|
390
+ | `motion-instant` | 0ms | State commits, selection, toggle |
391
+ | `motion-fast` | 120ms | Hover, focus, button press |
392
+ | `motion-standard` | 200ms | Dropdown, popover, sheet, tab switch |
393
+ | `motion-slow` | 320ms | Section reveals on marketing surfaces |
394
+
395
+ **Easings**:
396
+
397
+ | Token | Curve | Use |
398
+ |---|---|---|
399
+ | `ease-enter` | `cubic-bezier(0.2, 0.6, 0.25, 1)` | Arriving — sheets, popovers, dropdowns |
400
+ | `ease-exit` | `cubic-bezier(0.4, 0.0, 1, 1)` | Dismissals |
401
+ | `ease-standard` | `cubic-bezier(0.25, 0.1, 0.25, 1)` | Two-way transitions |
402
+
403
+ **Explicitly forbidden.** No spring, no bounce, no overshoot. No `cubic-bezier` with middle control values above `1.0`. Vercel's motion matches its typography — compressed, deliberate, no playful excess. A bouncing modal would read as consumer app; Vercel is infrastructure.
404
+
405
+ **Signature motions.**
406
+
407
+ 1. **Deployment status transition.** When a deployment moves from "Building" (Develop Blue) to "Ready" (green) on the dashboard, the status pill transitions color over `motion-standard` with `ease-standard`. No scale, no flash. The single color change is the entire animation — minimalism even in state transitions.
408
+ 2. **Shadow-border hover lift.** On hover over a card, the shadow stack intensifies from the base `rgba(0,0,0,0.08) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 2px` to include a deeper second layer over `motion-fast`. The element itself does not translate; the shadow grows. The card appears to "press outward from the page" without moving.
409
+ 3. **Develop → Preview → Ship ambient.** The three-color workflow accent on marketing hero sections cycles at slow 12-second intervals using `linear` easing. This is the one ambient motion on the marketing site — and it is functional: it illustrates the pipeline concept the text describes rather than decorating.
410
+ 4. **Reduce motion.** Under `prefers-reduced-motion: reduce`, all `motion-*` tokens collapse to `motion-instant`. The ambient Develop/Preview/Ship animation stops. Shadow-border hover lifts become instant. The dashboard remains fully functional.
411
+
412
+ <!--
413
+ OmD v0.1 Sources — Philosophy Layer (sections 10–15)
414
+
415
+ Direct verification via WebFetch (2026-04-19):
416
+ - https://vercel.com/ — confirms current marketing positioning:
417
+ "Build and deploy the best web experiences with the AI Cloud"
418
+ "Vercel provides the developer tools and cloud infrastructure to build,
419
+ scale, and secure a faster, more personalized web."
420
+ Confirms marketing voice register — terse, declarative headlines ("Your
421
+ product, delivered", "Deploy once, deliver everywhere", "Previews for every
422
+ push") and numeric performance claims ("95% reduction in page load times",
423
+ "24x faster builds").
424
+ - https://vercel.com/design — confirms the Vercel Design team's own
425
+ self-description (verbatim):
426
+ "We design systems and systemize designs. Imbuing our work with care
427
+ and craft as stewards of the Vercel Brand and Geist Design System."
428
+ Also mentions "meticulous interactions, delightful wordplay" as explicit
429
+ tone register.
430
+ - https://vercel.com/geist/introduction — confirms Geist Design System's
431
+ tagline ("Vercel design system for building consistent web experiences")
432
+ and the Geist Sans / Geist Mono typefaces as "Specifically designed for
433
+ developers and designers".
434
+
435
+ Base DESIGN.md (sections 1–9) is the source for all token-level claims
436
+ (Vercel Black #171717, Geist Sans/Mono fonts, shadow-as-border technique,
437
+ workflow accent colors Ship Red #ff5b4f / Preview Pink #de1d8d / Develop
438
+ Blue #0a72ef, multi-layer shadow stacks, three-weight system 400/500/600).
439
+
440
+ Not independently verified via WebFetch — widely documented public facts used:
441
+ - Vercel was founded in 2015 by Guillermo Rauch.
442
+ - The company was originally named ZEIT and renamed to Vercel in April 2020.
443
+ - Vercel is the primary maintainer of Next.js, the open-source React framework.
444
+ - Next.js has existed as an open-source project since 2016.
445
+
446
+ Personas (§13) are fictional archetypes informed by publicly observable
447
+ Vercel user segments (frontend developers, staff engineers, engineering
448
+ managers, founding engineers of Next.js-heavy teams). Names are illustrative;
449
+ they do not refer to real people.
450
+
451
+ Interpretive claims (e.g., "shadow-as-border is a craft signal", "type is
452
+ compression", "developers are the audience; developers want numbers") are
453
+ editorial readings connecting Vercel's stated design posture to the design
454
+ system, not directly sourced Vercel statements.
455
+ -->
456
+
@@ -0,0 +1,24 @@
1
+ # Vercel Inspired Design System
2
+
3
+ [DESIGN.md](https://github.com/VoltAgent/awesome-design-md/blob/main/design-md/vercel/DESIGN.md) extracted from the public [Vercel](https://vercel.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
+
14
+ Use [DESIGN.md](https://github.com/VoltAgent/awesome-design-md/blob/main/design-md/vercel/DESIGN.md) to use as a reference for AI agents (Claude, Cursor, Stitch) to generate UI that looks like the Vercel design language.
15
+
16
+ ## Preview
17
+
18
+ A sample landing page built with DESIGN.md. It shows the actual colors, typography, buttons, cards, spacing, and elevation, all in one page.
19
+
20
+ ### Dark Mode
21
+ ![Vercel Design System — Dark Mode](https://pub-2e4ecbcbc9b24e7b93f1a6ab5b2bc71f.r2.dev/designs/vercel/preview-dark-screenshot.png)
22
+
23
+ ### Light Mode
24
+ ![Vercel Design System — Light Mode](https://pub-2e4ecbcbc9b24e7b93f1a6ab5b2bc71f.r2.dev/designs/vercel/preview-screenshot.png)