getrelay 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 (145) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +40 -0
  3. package/bin/relay.js +362 -0
  4. package/design-md/airbnb/DESIGN.md +545 -0
  5. package/design-md/airbnb/README.md +5 -0
  6. package/design-md/airtable/DESIGN.md +554 -0
  7. package/design-md/airtable/README.md +5 -0
  8. package/design-md/apple/DESIGN.md +562 -0
  9. package/design-md/apple/README.md +5 -0
  10. package/design-md/binance/DESIGN.md +634 -0
  11. package/design-md/binance/README.md +5 -0
  12. package/design-md/bmw/DESIGN.md +544 -0
  13. package/design-md/bmw/README.md +5 -0
  14. package/design-md/bmw-m/DESIGN.md +503 -0
  15. package/design-md/bmw-m/README.md +5 -0
  16. package/design-md/bugatti/DESIGN.md +454 -0
  17. package/design-md/bugatti/README.md +5 -0
  18. package/design-md/cal/DESIGN.md +542 -0
  19. package/design-md/cal/README.md +5 -0
  20. package/design-md/claude/DESIGN.md +589 -0
  21. package/design-md/claude/README.md +5 -0
  22. package/design-md/clay/DESIGN.md +541 -0
  23. package/design-md/clay/README.md +5 -0
  24. package/design-md/clickhouse/DESIGN.md +544 -0
  25. package/design-md/clickhouse/README.md +5 -0
  26. package/design-md/cohere/DESIGN.md +451 -0
  27. package/design-md/cohere/README.md +5 -0
  28. package/design-md/coinbase/DESIGN.md +570 -0
  29. package/design-md/coinbase/README.md +5 -0
  30. package/design-md/composio/DESIGN.md +506 -0
  31. package/design-md/composio/README.md +5 -0
  32. package/design-md/cursor/DESIGN.md +537 -0
  33. package/design-md/cursor/README.md +5 -0
  34. package/design-md/elevenlabs/DESIGN.md +504 -0
  35. package/design-md/elevenlabs/README.md +5 -0
  36. package/design-md/expo/DESIGN.md +526 -0
  37. package/design-md/expo/README.md +5 -0
  38. package/design-md/ferrari/DESIGN.md +531 -0
  39. package/design-md/ferrari/README.md +5 -0
  40. package/design-md/figma/DESIGN.md +578 -0
  41. package/design-md/figma/README.md +5 -0
  42. package/design-md/framer/DESIGN.md +544 -0
  43. package/design-md/framer/README.md +5 -0
  44. package/design-md/hashicorp/DESIGN.md +575 -0
  45. package/design-md/hashicorp/README.md +5 -0
  46. package/design-md/ibm/DESIGN.md +550 -0
  47. package/design-md/ibm/README.md +5 -0
  48. package/design-md/intercom/DESIGN.md +546 -0
  49. package/design-md/intercom/README.md +5 -0
  50. package/design-md/kraken/DESIGN.md +125 -0
  51. package/design-md/kraken/README.md +5 -0
  52. package/design-md/lamborghini/DESIGN.md +288 -0
  53. package/design-md/lamborghini/README.md +5 -0
  54. package/design-md/linear.app/DESIGN.md +548 -0
  55. package/design-md/linear.app/README.md +5 -0
  56. package/design-md/lovable/DESIGN.md +298 -0
  57. package/design-md/lovable/README.md +5 -0
  58. package/design-md/mastercard/DESIGN.md +365 -0
  59. package/design-md/mastercard/README.md +5 -0
  60. package/design-md/meta/DESIGN.md +683 -0
  61. package/design-md/meta/README.md +5 -0
  62. package/design-md/minimax/DESIGN.md +746 -0
  63. package/design-md/minimax/README.md +5 -0
  64. package/design-md/mintlify/DESIGN.md +852 -0
  65. package/design-md/mintlify/README.md +5 -0
  66. package/design-md/miro/DESIGN.md +825 -0
  67. package/design-md/miro/README.md +5 -0
  68. package/design-md/mistral.ai/DESIGN.md +773 -0
  69. package/design-md/mistral.ai/README.md +5 -0
  70. package/design-md/mongodb/DESIGN.md +767 -0
  71. package/design-md/mongodb/README.md +5 -0
  72. package/design-md/nike/DESIGN.md +575 -0
  73. package/design-md/nike/README.md +5 -0
  74. package/design-md/notion/DESIGN.md +821 -0
  75. package/design-md/notion/README.md +5 -0
  76. package/design-md/nvidia/DESIGN.md +640 -0
  77. package/design-md/nvidia/README.md +5 -0
  78. package/design-md/ollama/DESIGN.md +539 -0
  79. package/design-md/ollama/README.md +5 -0
  80. package/design-md/opencode.ai/DESIGN.md +521 -0
  81. package/design-md/opencode.ai/README.md +5 -0
  82. package/design-md/pinterest/DESIGN.md +597 -0
  83. package/design-md/pinterest/README.md +5 -0
  84. package/design-md/playstation/DESIGN.md +661 -0
  85. package/design-md/playstation/README.md +5 -0
  86. package/design-md/posthog/DESIGN.md +690 -0
  87. package/design-md/posthog/README.md +5 -0
  88. package/design-md/raycast/DESIGN.md +669 -0
  89. package/design-md/raycast/README.md +5 -0
  90. package/design-md/renault/DESIGN.md +589 -0
  91. package/design-md/renault/README.md +5 -0
  92. package/design-md/replicate/DESIGN.md +616 -0
  93. package/design-md/replicate/README.md +5 -0
  94. package/design-md/resend/DESIGN.md +585 -0
  95. package/design-md/resend/README.md +5 -0
  96. package/design-md/revolut/DESIGN.md +636 -0
  97. package/design-md/revolut/README.md +5 -0
  98. package/design-md/runwayml/DESIGN.md +244 -0
  99. package/design-md/runwayml/README.md +5 -0
  100. package/design-md/sanity/DESIGN.md +357 -0
  101. package/design-md/sanity/README.md +5 -0
  102. package/design-md/sentry/DESIGN.md +551 -0
  103. package/design-md/sentry/README.md +5 -0
  104. package/design-md/shopify/DESIGN.md +516 -0
  105. package/design-md/shopify/README.md +5 -0
  106. package/design-md/slack/DESIGN.md +482 -0
  107. package/design-md/spacex/DESIGN.md +363 -0
  108. package/design-md/spacex/README.md +5 -0
  109. package/design-md/spotify/DESIGN.md +246 -0
  110. package/design-md/spotify/README.md +5 -0
  111. package/design-md/starbucks/DESIGN.md +580 -0
  112. package/design-md/starbucks/README.md +5 -0
  113. package/design-md/stripe/DESIGN.md +487 -0
  114. package/design-md/stripe/README.md +5 -0
  115. package/design-md/supabase/DESIGN.md +462 -0
  116. package/design-md/supabase/README.md +5 -0
  117. package/design-md/superhuman/DESIGN.md +448 -0
  118. package/design-md/superhuman/README.md +5 -0
  119. package/design-md/tesla/DESIGN.md +286 -0
  120. package/design-md/tesla/README.md +5 -0
  121. package/design-md/theverge/DESIGN.md +339 -0
  122. package/design-md/theverge/README.md +5 -0
  123. package/design-md/together.ai/DESIGN.md +633 -0
  124. package/design-md/together.ai/README.md +5 -0
  125. package/design-md/uber/DESIGN.md +636 -0
  126. package/design-md/uber/README.md +5 -0
  127. package/design-md/vercel/DESIGN.md +736 -0
  128. package/design-md/vercel/README.md +5 -0
  129. package/design-md/vodafone/DESIGN.md +538 -0
  130. package/design-md/vodafone/README.md +5 -0
  131. package/design-md/voltagent/DESIGN.md +521 -0
  132. package/design-md/voltagent/README.md +5 -0
  133. package/design-md/warp/DESIGN.md +526 -0
  134. package/design-md/warp/README.md +5 -0
  135. package/design-md/webflow/DESIGN.md +588 -0
  136. package/design-md/webflow/README.md +5 -0
  137. package/design-md/wired/DESIGN.md +497 -0
  138. package/design-md/wired/README.md +5 -0
  139. package/design-md/wise/DESIGN.md +544 -0
  140. package/design-md/wise/README.md +5 -0
  141. package/design-md/x.ai/DESIGN.md +465 -0
  142. package/design-md/x.ai/README.md +5 -0
  143. package/design-md/zapier/DESIGN.md +537 -0
  144. package/design-md/zapier/README.md +5 -0
  145. package/package.json +31 -0
@@ -0,0 +1,736 @@
1
+ ---
2
+ version: alpha
3
+ name: Vercel Inspired
4
+ description: An inspired interpretation of Vercel's design language — a developer-platform brand whose surface is a stark black-and-ink duet on near-white canvas, broken at hero scale by a multi-color mesh gradient (cyan / blue / magenta / amber) that acts as the entire decorative system, paired with a custom geometric sans for headlines and a monospaced caption face for technical labels.
5
+
6
+ colors:
7
+ primary: "#171717"
8
+ on-primary: "#ffffff"
9
+ ink: "#171717"
10
+ body: "#4d4d4d"
11
+ mute: "#888888"
12
+ hairline: "#ebebeb"
13
+ hairline-strong: "#a1a1a1"
14
+ canvas: "#ffffff"
15
+ canvas-soft: "#fafafa"
16
+ canvas-soft-2: "#f5f5f5"
17
+ link: "#0070f3"
18
+ link-deep: "#0761d1"
19
+ link-bg-soft: "#d3e5ff"
20
+ success: "#0070f3"
21
+ error: "#ee0000"
22
+ error-soft: "#f7d4d6"
23
+ error-deep: "#c50000"
24
+ warning: "#f5a623"
25
+ warning-soft: "#ffefcf"
26
+ warning-deep: "#ab570a"
27
+ violet: "#7928ca"
28
+ violet-soft: "#d8ccf1"
29
+ violet-deep: "#4c2889"
30
+ cyan: "#50e3c2"
31
+ cyan-soft: "#aaffec"
32
+ cyan-deep: "#29bc9b"
33
+ highlight-pink: "#ff0080"
34
+ highlight-magenta: "#eb367f"
35
+ gradient-develop-start: "#007cf0"
36
+ gradient-develop-end: "#00dfd8"
37
+ gradient-preview-start: "#7928ca"
38
+ gradient-preview-end: "#ff0080"
39
+ gradient-ship-start: "#ff4d4d"
40
+ gradient-ship-end: "#f9cb28"
41
+ selection-bg: "#171717"
42
+ selection-fg: "#f2f2f2"
43
+
44
+ typography:
45
+ display-xl:
46
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
47
+ fontSize: 48px
48
+ fontWeight: 600
49
+ lineHeight: 48px
50
+ letterSpacing: -2.4px
51
+ display-lg:
52
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
53
+ fontSize: 32px
54
+ fontWeight: 600
55
+ lineHeight: 40px
56
+ letterSpacing: -1.28px
57
+ display-md:
58
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
59
+ fontSize: 24px
60
+ fontWeight: 600
61
+ lineHeight: 32px
62
+ letterSpacing: -0.96px
63
+ display-sm:
64
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
65
+ fontSize: 20px
66
+ fontWeight: 600
67
+ lineHeight: 28px
68
+ letterSpacing: -0.6px
69
+ body-lg:
70
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
71
+ fontSize: 18px
72
+ fontWeight: 400
73
+ lineHeight: 28px
74
+ letterSpacing: 0px
75
+ body-md:
76
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
77
+ fontSize: 16px
78
+ fontWeight: 400
79
+ lineHeight: 24px
80
+ body-md-strong:
81
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
82
+ fontSize: 16px
83
+ fontWeight: 500
84
+ lineHeight: 24px
85
+ body-sm:
86
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
87
+ fontSize: 14px
88
+ fontWeight: 400
89
+ lineHeight: 20px
90
+ letterSpacing: -0.28px
91
+ body-sm-strong:
92
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
93
+ fontSize: 14px
94
+ fontWeight: 500
95
+ lineHeight: 20px
96
+ letterSpacing: -0.28px
97
+ caption:
98
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
99
+ fontSize: 12px
100
+ fontWeight: 400
101
+ lineHeight: 16px
102
+ caption-mono:
103
+ fontFamily: Geist Mono, ui-monospace, SFMono-Regular, Menlo, Monaco, monospace
104
+ fontSize: 12px
105
+ fontWeight: 400
106
+ lineHeight: 16px
107
+ code:
108
+ fontFamily: Geist Mono, ui-monospace, SFMono-Regular, Menlo, Monaco, monospace
109
+ fontSize: 13px
110
+ fontWeight: 400
111
+ lineHeight: 20px
112
+ button-md:
113
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
114
+ fontSize: 14px
115
+ fontWeight: 500
116
+ lineHeight: 20px
117
+ button-lg:
118
+ fontFamily: Geist, Inter, system-ui, -apple-system, sans-serif
119
+ fontSize: 16px
120
+ fontWeight: 500
121
+ lineHeight: 24px
122
+
123
+ rounded:
124
+ none: 0px
125
+ xs: 4px
126
+ sm: 6px
127
+ md: 8px
128
+ lg: 12px
129
+ xl: 16px
130
+ pill-sm: 64px
131
+ pill: 100px
132
+ full: 9999px
133
+
134
+ spacing:
135
+ xxs: 4px
136
+ xs: 8px
137
+ sm: 12px
138
+ md: 16px
139
+ lg: 24px
140
+ xl: 32px
141
+ 2xl: 40px
142
+ 3xl: 48px
143
+ 4xl: 64px
144
+ 5xl: 96px
145
+ 6xl: 128px
146
+ section: 192px
147
+
148
+ components:
149
+ nav-bar:
150
+ backgroundColor: "{colors.canvas}"
151
+ textColor: "{colors.ink}"
152
+ typography: "{typography.body-sm}"
153
+ height: 64px
154
+ padding: "{spacing.sm} {spacing.lg}"
155
+ nav-link:
156
+ textColor: "{colors.body}"
157
+ typography: "{typography.body-sm}"
158
+ rounded: "{rounded.full}"
159
+ padding: "{spacing.xs} {spacing.sm}"
160
+ nav-cta-signup:
161
+ backgroundColor: "{colors.primary}"
162
+ textColor: "{colors.on-primary}"
163
+ typography: "{typography.body-sm-strong}"
164
+ rounded: "{rounded.sm}"
165
+ padding: "0px {spacing.xs}"
166
+ height: 28px
167
+ nav-cta-login:
168
+ backgroundColor: "{colors.canvas}"
169
+ textColor: "{colors.ink}"
170
+ typography: "{typography.body-sm-strong}"
171
+ rounded: "{rounded.sm}"
172
+ padding: "0px {spacing.xs}"
173
+ height: 28px
174
+ nav-cta-ask-ai:
175
+ backgroundColor: "{colors.canvas}"
176
+ textColor: "{colors.ink}"
177
+ borderColor: "{colors.hairline}"
178
+ typography: "{typography.body-sm-strong}"
179
+ rounded: "{rounded.sm}"
180
+ padding: "0px {spacing.xs}"
181
+ height: 28px
182
+ button-primary:
183
+ backgroundColor: "{colors.primary}"
184
+ textColor: "{colors.on-primary}"
185
+ typography: "{typography.button-lg}"
186
+ rounded: "{rounded.pill}"
187
+ padding: "0px {spacing.sm}"
188
+ button-secondary:
189
+ backgroundColor: "{colors.canvas}"
190
+ textColor: "{colors.ink}"
191
+ typography: "{typography.button-lg}"
192
+ rounded: "{rounded.pill}"
193
+ padding: "0px {spacing.sm}"
194
+ button-primary-sm:
195
+ backgroundColor: "{colors.primary}"
196
+ textColor: "{colors.on-primary}"
197
+ typography: "{typography.button-md}"
198
+ rounded: "{rounded.pill}"
199
+ padding: "0px {spacing.xs}"
200
+ button-secondary-sm:
201
+ backgroundColor: "{colors.canvas}"
202
+ textColor: "{colors.ink}"
203
+ typography: "{typography.button-md}"
204
+ rounded: "{rounded.pill}"
205
+ padding: "0px {spacing.xs}"
206
+ tab-ghost:
207
+ backgroundColor: "{colors.canvas}"
208
+ textColor: "{colors.ink}"
209
+ typography: "{typography.body-sm}"
210
+ rounded: "{rounded.pill-sm}"
211
+ padding: "0px {spacing.md}"
212
+ icon-button-circular:
213
+ backgroundColor: "{colors.canvas}"
214
+ textColor: "{colors.ink}"
215
+ borderColor: "{colors.hairline}"
216
+ rounded: "{rounded.full}"
217
+ card-marketing:
218
+ backgroundColor: "{colors.canvas}"
219
+ textColor: "{colors.ink}"
220
+ typography: "{typography.body-md}"
221
+ rounded: "{rounded.md}"
222
+ padding: "{spacing.lg}"
223
+ card-marketing-large:
224
+ backgroundColor: "{colors.canvas}"
225
+ textColor: "{colors.ink}"
226
+ typography: "{typography.body-md}"
227
+ rounded: "{rounded.lg}"
228
+ padding: "{spacing.xl}"
229
+ card-soft:
230
+ backgroundColor: "{colors.canvas-soft}"
231
+ textColor: "{colors.ink}"
232
+ typography: "{typography.body-md}"
233
+ rounded: "{rounded.md}"
234
+ padding: "{spacing.lg}"
235
+ template-card:
236
+ backgroundColor: "{colors.canvas}"
237
+ textColor: "{colors.ink}"
238
+ typography: "{typography.body-md}"
239
+ rounded: "{rounded.md}"
240
+ padding: "{spacing.md}"
241
+ code-editor-mockup:
242
+ backgroundColor: "{colors.primary}"
243
+ textColor: "{colors.on-primary}"
244
+ typography: "{typography.code}"
245
+ rounded: "{rounded.md}"
246
+ padding: "{spacing.lg}"
247
+ form-input:
248
+ backgroundColor: "{colors.canvas}"
249
+ textColor: "{colors.ink}"
250
+ borderColor: "{colors.hairline}"
251
+ typography: "{typography.body-sm}"
252
+ rounded: "{rounded.sm}"
253
+ padding: "0px {spacing.sm}"
254
+ height: 40px
255
+ form-input-sm:
256
+ backgroundColor: "{colors.canvas}"
257
+ textColor: "{colors.ink}"
258
+ borderColor: "{colors.hairline}"
259
+ typography: "{typography.body-sm}"
260
+ rounded: "{rounded.sm}"
261
+ padding: "0px {spacing.sm}"
262
+ height: 32px
263
+ form-input-lg:
264
+ backgroundColor: "{colors.canvas}"
265
+ textColor: "{colors.ink}"
266
+ borderColor: "{colors.hairline}"
267
+ typography: "{typography.body-md}"
268
+ rounded: "{rounded.sm}"
269
+ padding: "0px {spacing.sm}"
270
+ height: 48px
271
+ badge-secondary:
272
+ backgroundColor: "{colors.canvas-soft}"
273
+ textColor: "{colors.body}"
274
+ typography: "{typography.caption}"
275
+ rounded: "{rounded.full}"
276
+ padding: "0px {spacing.xs}"
277
+ pricing-card:
278
+ backgroundColor: "{colors.canvas}"
279
+ textColor: "{colors.ink}"
280
+ typography: "{typography.body-md}"
281
+ rounded: "{rounded.lg}"
282
+ padding: "{spacing.xl}"
283
+ pricing-card-featured:
284
+ backgroundColor: "{colors.primary}"
285
+ textColor: "{colors.on-primary}"
286
+ typography: "{typography.body-md}"
287
+ rounded: "{rounded.lg}"
288
+ padding: "{spacing.xl}"
289
+ logo-strip:
290
+ backgroundColor: "{colors.canvas}"
291
+ textColor: "{colors.body}"
292
+ typography: "{typography.body-sm}"
293
+ padding: "{spacing.lg} {spacing.xl}"
294
+ hero-band:
295
+ backgroundColor: "{colors.canvas}"
296
+ textColor: "{colors.ink}"
297
+ typography: "{typography.display-xl}"
298
+ padding: "{spacing.4xl} {spacing.lg}"
299
+ feature-mesh-band:
300
+ backgroundColor: "{colors.canvas}"
301
+ textColor: "{colors.ink}"
302
+ typography: "{typography.display-lg}"
303
+ padding: "{spacing.5xl} {spacing.lg}"
304
+ showcase-band-light:
305
+ backgroundColor: "{colors.canvas-soft}"
306
+ textColor: "{colors.ink}"
307
+ typography: "{typography.display-lg}"
308
+ padding: "{spacing.5xl} {spacing.lg}"
309
+ showcase-band-dark:
310
+ backgroundColor: "{colors.primary}"
311
+ textColor: "{colors.on-primary}"
312
+ typography: "{typography.display-lg}"
313
+ padding: "{spacing.5xl} {spacing.lg}"
314
+ footer:
315
+ backgroundColor: "{colors.canvas}"
316
+ textColor: "{colors.body}"
317
+ typography: "{typography.body-sm}"
318
+ padding: "{spacing.4xl} {spacing.lg}"
319
+ link-inline:
320
+ textColor: "{colors.link}"
321
+ typography: "{typography.body-md}"
322
+ banner-marketing:
323
+ backgroundColor: "{colors.canvas-soft}"
324
+ textColor: "{colors.body}"
325
+ typography: "{typography.body-sm}"
326
+ rounded: "{rounded.full}"
327
+ padding: "{spacing.xs} {spacing.sm}"
328
+
329
+ # ─── Examples (illustrative) — auto-derived; resolve any TO_FILL markers below ───
330
+ ex-pricing-tier:
331
+ description: "Default tier card. Mirrors pricing-card chrome on canvas-soft surface with a hairline border."
332
+ backgroundColor: "{colors.canvas-soft}"
333
+ textColor: "{colors.ink}"
334
+ borderColor: "{colors.hairline}"
335
+ rounded: "{rounded.lg}"
336
+ padding: "{spacing.xl}"
337
+ ex-pricing-tier-featured:
338
+ description: "Featured tier — polarity-flipped to ink primary with white text and white CTA."
339
+ backgroundColor: "{colors.ink}"
340
+ textColor: "{colors.on-primary}"
341
+ rounded: "{rounded.lg}"
342
+ padding: "{spacing.xl}"
343
+ ex-product-selector:
344
+ description: "What's Included summary card — repurposed for the brand's GPU / inference / Pro feature tiers."
345
+ backgroundColor: "{colors.canvas-soft}"
346
+ rounded: "{rounded.md}"
347
+ padding: "{spacing.lg}"
348
+ ex-cart-drawer:
349
+ description: "Subscription summary — line items per add-on (NOT a literal e-commerce cart)."
350
+ backgroundColor: "{colors.canvas}"
351
+ rounded: "{rounded.md}"
352
+ padding: "{spacing.lg}"
353
+ item-divider: "{colors.hairline}"
354
+ ex-app-shell-row:
355
+ description: "Sidebar nav row. Active state uses brand primary as a left-edge indicator bar."
356
+ backgroundColor: "{colors.canvas}"
357
+ activeIndicator: "{colors.primary}"
358
+ rounded: "{rounded.sm}"
359
+ padding: "{spacing.xs} {spacing.sm}"
360
+ ex-data-table-cell:
361
+ description: "Mirrors the brand's table chrome. Header uses caption-mono uppercase mono; body uses body-sm."
362
+ headerBackground: "{colors.canvas-soft}"
363
+ headerTypography: "{typography.caption-mono}"
364
+ bodyTypography: "{typography.body-sm}"
365
+ cellPadding: "{spacing.xs} {spacing.sm}"
366
+ rowBorder: "{colors.hairline}"
367
+ ex-auth-form-card:
368
+ description: "Sign-in / sign-up card. Mirrors card-marketing-large chrome with form-input primitives inside."
369
+ backgroundColor: "{colors.canvas-soft}"
370
+ rounded: "{rounded.lg}"
371
+ padding: "{spacing.xl}"
372
+ ex-modal-card:
373
+ description: "Modal dialog surface — same chrome as card-marketing-large with Level 5 modal shadow."
374
+ backgroundColor: "{colors.canvas}"
375
+ rounded: "{rounded.lg}"
376
+ padding: "{spacing.xl}"
377
+ ex-empty-state-card:
378
+ description: "Empty-state illustration frame. Generous padding on canvas-soft."
379
+ backgroundColor: "{colors.canvas-soft}"
380
+ rounded: "{rounded.lg}"
381
+ padding: "{spacing.3xl}"
382
+ captionTypography: "{typography.body-md}"
383
+ ex-toast:
384
+ description: "Toast notification surface — flat-cornered card-marketing chrome with Level 4 shadow."
385
+ backgroundColor: "{colors.canvas}"
386
+ rounded: "{rounded.md}"
387
+ padding: "{spacing.sm} {spacing.md}"
388
+ typography: "{typography.body-sm}"
389
+
390
+ ---
391
+
392
+
393
+ ## Overview
394
+
395
+ Vercel is a developer-platform brand — the page is a deployment dashboard's marketing surface, written for engineers who already know the syntax. It earns that posture with one of the cleanest stark systems on the web: near-white `{colors.canvas-soft}` body background, ink-near-black `{colors.ink}` text, a 200-step gray scale that gives every divider, border, and disabled state its own deliberate step. The only place the brand introduces colour at marketing scale is the multi-stop mesh gradient (`{colors.gradient-develop-start}` → `{colors.gradient-preview-end}` → `{colors.gradient-ship-start}` → cyan / magenta / amber) that floats in atmospheric backdrops, never miniaturised to a swatch. That gradient is the entire decoration system.
396
+
397
+ Type is the second decisive voice. The brand's own custom geometric sans (Geist) carries display, body, button — everything narrative — at weight 600 for display, 500 for buttons, 400 for body. A matching monospaced face (Geist Mono) carries technical labels: terminal mockups, code blocks, sometimes filename captions. Headlines are sentence-case with aggressive negative letter-spacing (`-2.4px` at 48 px hero) — the brand never letter-spaces positively, never goes uppercase outside of mono labels.
398
+
399
+ Surfaces use a four-step ladder: `{colors.canvas}` (pure white for cards), `{colors.canvas-soft}` 98% (the page body), `{colors.canvas-soft-2}` 95% (occasional inset region), `{colors.primary}` (the deep ink-near-black used as the polarity-flipped band when a section needs the dark mode treatment). Shadows are exceptionally subtle — every elevated card carries a stacked shadow built from `0px 1px 1px #00000005` + `0px 2px 2px #0000000a` + an inset border. Cards never float on heavy drop-shadow; they sit on the page held by hairline + soft glow.
400
+
401
+ **Key Characteristics:**
402
+ - A single black-ink primary CTA `{colors.primary}` carries every conversion target, paired with white-on-white `button-secondary` for the secondary action. The brand uses 100 px pill shape for marketing CTAs and a tight 6 px square shape for in-app nav buttons.
403
+ - A multi-stop mesh gradient (cyan-blue-magenta-amber) is the only decorative chrome — used at hero scale and inside feature-band atmospheric backdrops. It is the brand.
404
+ - Every section eyebrow and small label uses the monospace face `{typography.caption-mono}` or `{typography.code}`; everything else is in the geometric sans.
405
+ - Subtle stacked-shadow elevation — three offsets layered with 4-12 % black opacity — never a single heavy drop-shadow.
406
+ - A complete 100–1000 gray + blue + red + amber + green + teal + purple + pink colour scale exists as a system token set, but the marketing surface uses only the `100`, `1000`, and `700`-level tones; the rest stay in the design-system tokens for in-product surfaces.
407
+ - An "Active CPU" pricing rhythm: `pricing-card` lays out 3-up on the pricing page with `pricing-card-featured` (Pro tier) polarity-flipped to `{colors.primary}` against white-card siblings.
408
+
409
+ ## Colors
410
+
411
+ ### Brand & Accent
412
+ - **Ink** (`{colors.primary}` — `#171717`): The single primary CTA color. Black-near-pure ink that carries every Sign Up pill, every footer CTA, the dark-band polarity-flip. Used as text color throughout the page on light surfaces. (Resolved from `--ds-gray-1000`.)
413
+ - **Cyan** (`{colors.cyan}` — `#50e3c2`): A signature mint-cyan used in the brand gradient and inside Geist-system spotlight tokens. Visible inside the hero gradient stops.
414
+ - **Highlight Pink** (`{colors.highlight-pink}` — `#ff0080`): The brand's highlight magenta, used as the high-saturation stop in the preview-gradient pair.
415
+ - **Violet** (`{colors.violet}` — `#7928ca`): The deep purple used as the start of the preview-gradient and inside developer-console highlights.
416
+ - **Link Blue** (`{colors.link}` — `#0070f3`): The brand's primary link color and the legacy `--geist-success` semantic.
417
+
418
+ ### Surface
419
+ - **Canvas** (`{colors.canvas}` — `#ffffff`): The pure-white card / dialog / modal surface.
420
+ - **Canvas Soft** (`{colors.canvas-soft}` — `#fafafa`): The default page background — 98 % white. Almost every section sits on this tone.
421
+ - **Canvas Soft 2** (`{colors.canvas-soft-2}` — `#f5f5f5`): A slightly deeper inset surface for "code editor inner background", template-card hover states, and dropdown menus.
422
+ - **Hairline** (`{colors.hairline}` — `#ebebeb`): 1 px dividers — table rows, card borders, input borders.
423
+ - **Hairline Strong** (`{colors.hairline-strong}` — `#a1a1a1`): The 500-level gray, used as the slightly-stronger divider on light bands and as the deemphasised text color.
424
+
425
+ ### Text
426
+ - **Ink** (`{colors.ink}` — `#171717`): Every heading and body paragraph on light surfaces.
427
+ - **Body** (`{colors.body}` — `#4d4d4d`): Secondary text — sub-headings, body captions, nav-link inactive text, footer column body.
428
+ - **Mute** (`{colors.mute}` — `#888888`): Lowest-priority text — placeholder text, fine print, low-key labels.
429
+ - **On Primary** (`{colors.on-primary}` — `#ffffff`): All text on `{colors.primary}` surfaces.
430
+
431
+ ### Semantic
432
+ - **Success / Link** (`{colors.success}` — `#0070f3`): The brand's legacy success indicator doubles as the primary link color. Visible underline-on-hover for inline body links.
433
+ - **Link Deep** (`{colors.link-deep}` — `#0761d1`): The pressed / visited tone for inline links.
434
+ - **Link Bg Soft** (`{colors.link-bg-soft}` — `#d3e5ff`): Soft pastel blue fill for "what's new" pill banners and informational badges.
435
+ - **Error** (`{colors.error}` — `#ee0000`): Validation red for destructive actions and form errors.
436
+ - **Error Soft** (`{colors.error-soft}` — `#f7d4d6`): Soft pastel red for destructive-state backgrounds.
437
+ - **Error Deep** (`{colors.error-deep}` — `#c50000`): Pressed / deep destructive state.
438
+ - **Warning** (`{colors.warning}` — `#f5a623`): Caution / pending status indicator.
439
+ - **Warning Soft** (`{colors.warning-soft}` — `#ffefcf`) / **Warning Deep** (`{colors.warning-deep}` — `#ab570a`): Background + pressed variants.
440
+
441
+ ### Brand Gradient
442
+ The brand's signature decoration is a three-pair gradient stack:
443
+ - **Develop** (`{colors.gradient-develop-start}` `#007cf0` → `{colors.gradient-develop-end}` `#00dfd8`) — the blue-to-teal pair used to mark the "deploy" / "develop" rhythm.
444
+ - **Preview** (`{colors.gradient-preview-start}` `#7928ca` → `{colors.gradient-preview-end}` `#ff0080`) — the violet-to-pink pair used for "preview" surfaces.
445
+ - **Ship** (`{colors.gradient-ship-start}` `#ff4d4d` → `{colors.gradient-ship-end}` `#f9cb28`) — the coral-to-amber pair used for "ship" surfaces.
446
+
447
+ The three pairs collapse into a single multi-color mesh gradient when used as the hero atmospheric backdrop. Treat the gradient as one unified object — do not crop down to a single colour, do not reorder the stops, and do not miniaturise. Used at hero scale only.
448
+
449
+ ## Typography
450
+
451
+ ### Font Family
452
+ Two custom faces carry the entire system:
453
+
454
+ 1. **A custom geometric sans** (extracted as `Geist`) for every display, body, button, link, and label. Weights 400 / 500 / 600 are the working set; the face never appears in 700 or heavier. Display sizes are tracked aggressively negative (`-2.4 px` at 48 px hero, `-1.28 px` at 32 px section); body stays at neutral or slightly-negative tracking.
455
+ 2. **A custom monospaced face** (extracted as `Geist Mono`) for terminal mockups, code blocks, and small mono-caption labels — anything that wants to signal "technical." Weight 400 only at 12 – 13 px. Tracking neutral.
456
+
457
+ A condensed display sans (`Space Grotesk`) is loaded as a third face for occasional editorial moments but does not render as the primary face anywhere in the captured surfaces.
458
+
459
+ ### Hierarchy
460
+
461
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
462
+ |---|---|---|---|---|---|
463
+ | `{typography.display-xl}` | 48px | 600 | 48px | -2.4px | Hero headline ("Build and deploy on the AI Cloud."). |
464
+ | `{typography.display-lg}` | 32px | 600 | 40px | -1.28px | Section headlines ("Your frontend, delivered.", "A compute model for all workloads."). |
465
+ | `{typography.display-md}` | 24px | 600 | 32px | -0.96px | Card-cluster headlines, pricing-tier names. |
466
+ | `{typography.display-sm}` | 20px | 600 | 28px | -0.6px | Inline display micro-headings. |
467
+ | `{typography.body-lg}` | 18px | 400 | 28px | 0 | Lead paragraphs under section headlines. |
468
+ | `{typography.body-md}` | 16px | 400 | 24px | 0 | Default body paragraph. |
469
+ | `{typography.body-md-strong}` | 16px | 500 | 24px | 0 | Bolded inline body. |
470
+ | `{typography.body-sm}` | 14px | 400 | 20px | -0.28px | Secondary body, nav-link text, button-md labels. |
471
+ | `{typography.body-sm-strong}` | 14px | 500 | 20px | -0.28px | Nav CTA labels, table-row emphasis. |
472
+ | `{typography.caption}` | 12px | 400 | 16px | 0 | Footer secondary lines, badge labels. |
473
+ | `{typography.caption-mono}` | 12px | 400 | 16px | 0 | Section eyebrows and label captions that want a technical voice. |
474
+ | `{typography.code}` | 13px | 400 | 20px | 0 | Inline code, terminal mockups, command snippets. |
475
+ | `{typography.button-md}` | 14px | 500 | 20px | 0 | Small / nav-scale button labels. |
476
+ | `{typography.button-lg}` | 16px | 500 | 24px | 0 | Marketing-scale pill button labels. |
477
+
478
+ ### Principles
479
+ - **Negative tracking is part of the voice.** Display sizes use aggressive `-2.4` to `-0.6` px tracking. Reverting to default tracking breaks the brand.
480
+ - **Sentence-case headlines, period-terminated.** Headlines like "Build and deploy on the AI Cloud." end with a deliberate period — that punctuation is part of the brand's voice.
481
+ - **Mono for the technical layer only.** Section eyebrows, code blocks, terminal mockups. Body paragraphs never set in mono.
482
+ - **Weight 600 is the display ceiling.** The geometric sans never appears at 700 / 800. The brand reads as a calmer system because of this.
483
+
484
+ ### Note on Font Substitutes
485
+ The two primary faces are proprietary (custom-cut for the brand). Open-source substitutes:
486
+ - **Geometric sans** — *Inter* (400 / 500 / 600) is the closest stylistic match; `font-feature-settings: "ss01", "ss02"` enables the geometric alternates. *Satoshi* is a passable second choice.
487
+ - **Monospace** — *JetBrains Mono* (400) at 12 – 13 px matches the technical voice. *IBM Plex Mono* is the second-best option.
488
+
489
+ ## Layout
490
+
491
+ ### Spacing System
492
+ - **Base unit**: 4 px. The brand's `--geist-space` token is exactly 4 px and every captured value is a multiple of 4.
493
+ - **Tokens**: `{spacing.xxs}` 4 px · `{spacing.xs}` 8 px · `{spacing.sm}` 12 px · `{spacing.md}` 16 px · `{spacing.lg}` 24 px · `{spacing.xl}` 32 px · `{spacing.2xl}` 40 px · `{spacing.3xl}` 48 px · `{spacing.4xl}` 64 px · `{spacing.5xl}` 96 px · `{spacing.6xl}` 128 px · `{spacing.section}` 192 px.
494
+ - **Section padding**: marketing bands use `{spacing.4xl}` to `{spacing.5xl}` top/bottom. Hero bands stretch to `{spacing.section}` to give the mesh gradient room to breathe.
495
+ - **Card interior padding**: marketing cards sit at `{spacing.lg}` to `{spacing.xl}`; template-grid cards stay tighter at `{spacing.md}` because they sit in a denser grid.
496
+ - **Inline gap**: button rows, nav rows, and chip rows use `{spacing.sm}` to `{spacing.md}` between siblings. The brand's `--geist-gap` is exactly 24 px.
497
+
498
+ ### Grid & Container
499
+ - **Max width**: ~1400 px (`--ds-page-width`); the legacy `--geist-page-width` is 1200 px and still appears on some marketing surfaces. Content centres with horizontal gutters of `{spacing.lg}` 24 px on desktop, `{spacing.md}` 16 px on mobile.
500
+ - **Column patterns**:
501
+ - Three-feature row: 3-up at desktop, 1-up at mobile (rows like "Web Apps / Composable Commerce / Multi-tenant Platforms").
502
+ - Tab pill row: 5-up centred row of `tab-ghost` pills.
503
+ - Template-grid cluster: 5-up at desktop, scaling to 1-up at mobile.
504
+ - Pricing tier grid: 3-up at desktop with the middle tier polarity-flipped.
505
+ - Logo strip: ~5 logos wide, single row.
506
+
507
+ ### Whitespace Philosophy
508
+ The mesh gradient does most of the heavy decorative lifting; whitespace separates the bands. Section spacing is generous — `{spacing.4xl}` to `{spacing.5xl}` between bands lets the gradient breathe. Inside a card, the headline/paragraph stack is tight (`{spacing.xs}` 8 px gap), then a wider gap before the CTA cluster. The page reads as engineered — large gaps + tight interior, never the other way around.
509
+
510
+ ### Responsive Strategy
511
+
512
+ #### Breakpoints
513
+
514
+ | Name | Width | Key Changes |
515
+ |---|---|---|
516
+ | Mobile | < 600px | Hero stacks; nav collapses to hamburger; 3-up feature grids drop to 1-up; tab pill row enables horizontal scroll. |
517
+ | Tablet | 600–959px | 3-up grids drop to 2-up; nav still horizontal. |
518
+ | Desktop | 960–1199px | Full 3-up grids; pricing 3-up. |
519
+ | Wide | 1200–1399px | Container caps at 1400 px content width. |
520
+ | Ultra-wide | ≥ 1400px | Content stays centred at 1400 px; bands stretch edge-to-edge in colour but content holds the max-width. |
521
+
522
+ #### Touch Targets
523
+ The `button-primary` pill renders at ~32 px tall in nav and ~48 px tall in marketing contexts. Marketing CTAs comfortably meet WCAG AAA at all breakpoints; nav buttons inflate touch area through `{spacing.xs}` padding on mobile to meet the 44 × 44 px floor.
524
+
525
+ #### Collapsing Strategy
526
+ - **Nav**: full link row + Ask AI / Log In / Sign Up pills at desktop. Collapses to logo + hamburger at mobile with the menu opening as a full-overlay.
527
+ - **Hero**: mesh gradient stays centred; headline + body stack vertically at all breakpoints (the brand doesn't use a split-hero pattern).
528
+ - **Three-feature row**: 3-up → 2-up → 1-up at the breakpoints above; cards keep their `{rounded.md}` 8 px shape across all viewports.
529
+ - **Pricing card grid**: 3-up at desktop, vertical stack at mobile with `pricing-card-featured` always sitting in the middle.
530
+ - **Template grid**: 5-up → 3-up → 2-up → 1-up. Each `template-card` keeps its 16:9 aspect on the image.
531
+
532
+ #### Image Behavior
533
+ - **Mesh gradient**: rendered as inline SVG or canvas-painted gradient; scales fluidly with the hero container; never crops, never tiles.
534
+ - **Customer logos**: rendered as monochrome SVGs in the logo strip; consistent 24 px height.
535
+ - **Code editor mockup**: dark `{colors.primary}` rectangle with mono text rendered inside; treated as an image at the layout level.
536
+ - **Template thumbnails**: 16:9 landscape inside `{rounded.md}` card chrome; lazy-loaded; consistent grayscale palette in the placeholder state.
537
+
538
+ ## Elevation & Depth
539
+
540
+ | Level | Treatment | Use |
541
+ |---|---|---|
542
+ | Level 0 — Flat | No shadow, no border. | Full-bleed hero bands and the polarity-flipped dark sections. |
543
+ | Level 1 — Inset Hairline | `0 0 0 1px #00000014` inset 1 px border. | Default card chrome — the brand's universal "you can see this card" cue. |
544
+ | Level 2 — Subtle Drop | `0px 1px 1px #00000005, 0px 2px 2px #0000000a` plus inset hairline. | Slightly elevated cards (template-grid, marketing-card). |
545
+ | Level 3 — Soft Stack | `0px 2px 2px #0000000a, 0px 8px 8px -8px #0000000a` plus inset hairline. | The "medium" elevation — feature-grid cards. |
546
+ | Level 4 — Float Stack | `0px 2px 2px #0000000a, 0px 8px 16px -4px #0000000a` plus inset hairline. | "Large" elevation — pricing cards, callout panels. |
547
+ | Level 5 — Modal | `0px 1px 1px #00000005, 0px 8px 16px -4px #0000000a, 0px 24px 32px -8px #0000000f` plus inset hairline. | Modal / dialog surfaces and dropdown menus. |
548
+
549
+ The brand uses STACKED shadows — multiple small offsets layered to fake natural light — never a single 8-px-blur generic drop. Inset hairline rings are always added so the card edge stays crisp.
550
+
551
+ ### Decorative Depth
552
+ - **Mesh gradient as atmospheric depth**: the hero's multi-stop gradient is the brand's only "atmospheric" effect — applied as a flat 2-D backdrop rather than a 3-D illustration.
553
+ - **Polarity-flipped dark band as section-depth**: switching the surface from `{colors.canvas-soft}` to `{colors.primary}` (the deep ink) is the brand's chief depth cue between bands.
554
+ - **Inset-shadow + drop-shadow combo**: the cards' combination of an inset 1 px ring and a multi-stop drop produces a "card sits on the page" effect without ever feeling material-heavy.
555
+
556
+ ## Shapes
557
+
558
+ ### Border Radius Scale
559
+
560
+ | Token | Value | Use |
561
+ |---|---|---|
562
+ | `{rounded.none}` | 0px | Full-bleed hero / footer bands. |
563
+ | `{rounded.xs}` | 4px | Tightest inline pill — the `nav-cta-signup` 6-px-radius button (mapped to `xs/sm`). |
564
+ | `{rounded.sm}` | 6px | The brand's `--geist-radius` token — base UI radius for in-app buttons, form inputs, dropdown menus. |
565
+ | `{rounded.md}` | 8px | The brand's `--geist-marketing-radius` token — feature cards, template cards. |
566
+ | `{rounded.lg}` | 12px | Slightly larger card chrome (pricing-card variants). |
567
+ | `{rounded.xl}` | 16px | Largest card chrome — when a card hosts a hero image cap. |
568
+ | `{rounded.pill-sm}` | 64px | Tab-ghost pills inside the "AI Apps / Web Apps / Ecommerce / Marketing / Platforms" row. |
569
+ | `{rounded.pill}` | 100px | The marketing CTA pill — `button-primary`, `button-secondary`, "Start Deploying" pill. |
570
+ | `{rounded.full}` | 9999px | Icon-button circular containers, nav-link ghost pills. |
571
+
572
+ ### Photography Geometry
573
+ - **Mesh gradient**: full-bleed 2-D atmospheric backdrop, never cropped to a frame; treated as the page's wallpaper.
574
+ - **Customer logos**: monochrome SVG, consistent 24 px height in a flex row.
575
+ - **Code editor mockup**: 16:10 dark rectangle, `{rounded.md}` corners.
576
+ - **Template thumbnails**: 16:9 landscape inside `{rounded.md}` chrome.
577
+ - **Showcase imagery**: 2:1 or 16:9 inside `{rounded.lg}` to `{rounded.xl}` chrome with a stacked shadow.
578
+
579
+ ## Components
580
+
581
+ ### Buttons
582
+
583
+ **`button-primary`** — the canonical 100-px-radius black pill, marketing scale.
584
+ - Background `{colors.primary}`, text `{colors.on-primary}`, label set in `{typography.button-lg}`, padding `0px {spacing.sm}` 12 px, shape `{rounded.pill}` 100 px. Renders ~48 px tall when paired with the marketing flex layout.
585
+
586
+ **`button-secondary`** — the white pill paired with the black primary inside marketing bands.
587
+ - Background `{colors.canvas}`, text `{colors.ink}`, same typography + padding as `button-primary`, shape `{rounded.pill}`.
588
+
589
+ **`button-primary-sm`** — the smaller-scale primary pill used inside nav and pricing-card CTAs.
590
+ - Background `{colors.primary}`, text `{colors.on-primary}`, label set in `{typography.button-md}` (14 px / 500), shape `{rounded.pill}`.
591
+
592
+ **`button-secondary-sm`** — the smaller-scale white pill paired with `button-primary-sm`.
593
+ - Background `{colors.canvas}`, text `{colors.ink}`, same typography + shape as `button-primary-sm`.
594
+
595
+ **`tab-ghost`** — the centred-row tab pill ("AI Apps / Web Apps / Ecommerce / Marketing / Platforms").
596
+ - Background `{colors.canvas}`, text `{colors.ink}`, label set in `{typography.body-sm}`, padding `0px {spacing.md}`, shape `{rounded.pill-sm}` 64 px.
597
+
598
+ **`icon-button-circular`** — the circular icon container (often a "?" or arrow inside).
599
+ - Background `{colors.canvas}`, dark icon, 1 px solid hairline border, shape `{rounded.full}`.
600
+
601
+ **Nav CTAs:**
602
+
603
+ **`nav-cta-signup`** — the small black "Sign Up" button in the nav row.
604
+ - Background `{colors.primary}`, text `{colors.on-primary}`, label `{typography.body-sm-strong}`, padding `0px {spacing.xs}`, height 28 px, shape `{rounded.sm}` 6 px (the brand's `--geist-radius`).
605
+
606
+ **`nav-cta-login`** — the white "Log In" button in the nav.
607
+ - Background `{colors.canvas}`, text `{colors.ink}`, same typography / height / shape as `nav-cta-signup`.
608
+
609
+ **`nav-cta-ask-ai`** — the small "Ask AI" button with a faint border.
610
+ - Background `{colors.canvas}`, text `{colors.ink}`, 1 px solid `{colors.hairline}` border (extracted as `0px solid rgb(235, 235, 235)`), same typography / height / shape.
611
+
612
+ ### Cards & Containers
613
+
614
+ **`card-marketing`** — the canonical marketing feature card (3-up section cards).
615
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.lg}` 24 px, shape `{rounded.md}` 8 px (the `--geist-marketing-radius`). Carries Level 3 soft-stack shadow.
616
+
617
+ **`card-marketing-large`** — the larger marketing card used for "compute model" / "AI Gateway" callouts.
618
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.xl}`, shape `{rounded.lg}` 12 px. Carries Level 4 float-stack shadow.
619
+
620
+ **`card-soft`** — the soft-tinted card used inside cluster groups (lighter than canvas-soft).
621
+ - Background `{colors.canvas-soft}`, text `{colors.ink}`, padding `{spacing.lg}`, shape `{rounded.md}`.
622
+
623
+ **`template-card`** — the deploy-template card in the "Deploy your first app" grid.
624
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.md}` 16 px, shape `{rounded.md}` 8 px. Hosts a 16:9 thumbnail at the top.
625
+
626
+ **`code-editor-mockup`** — the dark code-preview surface inside marketing bands.
627
+ - Background `{colors.primary}`, text `{colors.on-primary}`, body in `{typography.code}` (13 px / Geist Mono), padding `{spacing.lg}` 24 px, shape `{rounded.md}` 8 px.
628
+
629
+ **`pricing-card`** — the default pricing-tier card.
630
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.xl}` 32 px, shape `{rounded.lg}` 12 px. Inside: tier name in `{typography.display-md}`, price in `{typography.display-xl}`, feature list in `{typography.body-md}` rows, CTA at the bottom.
631
+
632
+ **`pricing-card-featured`** — the polarity-flipped "Pro" tier card.
633
+ - Background `{colors.primary}`, text `{colors.on-primary}`, same shape + padding as `pricing-card`. CTA inverts to `button-secondary-sm` (white pill on black card).
634
+
635
+ ### Inputs & Forms
636
+
637
+ **`form-input`** — the canonical text input.
638
+ - Background `{colors.canvas}`, text `{colors.ink}`, 1 px solid `{colors.hairline}` border, body in `{typography.body-sm}` (14 px), padding `0px {spacing.sm}`, height 40 px (the brand's `--geist-form-height`), shape `{rounded.sm}` 6 px.
639
+
640
+ **`form-input-sm`** — small-height variant (32 px tall) for tight forms.
641
+ - Same as `form-input` but height 32 px (the `--geist-form-small-height`).
642
+
643
+ **`form-input-lg`** — large-height variant (48 px tall) for hero CTAs.
644
+ - Same as `form-input` but height 48 px (the `--geist-form-large-height`); body in `{typography.body-md}` 16 px.
645
+
646
+ ### Navigation
647
+
648
+ **`nav-bar`** — the sticky top nav.
649
+ - Background `{colors.canvas}`, text `{colors.ink}`, height 64 px (the brand's `--header-height`), padding `{spacing.sm} {spacing.lg}`. Layout: logo left, link row centre, "Ask AI / Log In / Sign Up" cluster right.
650
+
651
+ **`nav-link`** — the centred link row inside `nav-bar`.
652
+ - Text `{colors.body}`, set in `{typography.body-sm}`, padding `{spacing.xs} {spacing.sm}`, shape `{rounded.full}` (ghost pill — visible only on hover or active, but the radius is documented).
653
+
654
+ **`footer`** — the bottom 4-column nav.
655
+ - Background `{colors.canvas}`, text `{colors.body}`, padding `{spacing.4xl} {spacing.lg}`. Eyebrow column labels in `{typography.caption-mono}` (uppercase mono effect); link rows in `{typography.body-sm}`.
656
+
657
+ ### Signature Components
658
+
659
+ **`hero-band`** — the white hero with the mesh gradient backdrop.
660
+ - Background `{colors.canvas}` (or `{colors.canvas-soft}` on some surfaces), text `{colors.ink}`, padding `{spacing.4xl} {spacing.lg}`. Inside: a small mono badge above the headline, the headline in `{typography.display-xl}` (sentence-case, period-terminated), a body lead in `{typography.body-lg}`, then a CTA row with `button-primary` + `button-secondary`. The mesh gradient sits behind, scaled to occupy roughly the top half of the band.
661
+
662
+ **`feature-mesh-band`** — the secondary section that hosts a mesh-gradient atmospheric backdrop with feature copy on top.
663
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.5xl} {spacing.lg}`. Section headline in `{typography.display-lg}`; supporting body in `{typography.body-md}`.
664
+
665
+ **`showcase-band-light`** — a soft-canvas section ("Deploy your first app in seconds").
666
+ - Background `{colors.canvas-soft}`, text `{colors.ink}`, padding `{spacing.5xl} {spacing.lg}`.
667
+
668
+ **`showcase-band-dark`** — the polarity-flipped dark band ("A compute model for all workloads").
669
+ - Background `{colors.primary}`, text `{colors.on-primary}`, padding `{spacing.5xl} {spacing.lg}`. Section headline in `{typography.display-lg}` (white on black). Often contains a `code-editor-mockup` flush with the band.
670
+
671
+ **`logo-strip`** — the customer-logo wrapping row near the top of the page.
672
+ - Background `{colors.canvas}`, text `{colors.body}`, padding `{spacing.lg} {spacing.xl}`. Logos rendered as monochrome SVGs at consistent height.
673
+
674
+ **`badge-secondary`** — the small inline metadata pill ("New", "Beta", "Live").
675
+ - Background `{colors.canvas-soft}`, text `{colors.body}`, body in `{typography.caption}`, padding `0px {spacing.xs}`, shape `{rounded.full}`.
676
+
677
+ **`banner-marketing`** — the "Introducing X" announcement pill at the top of pages.
678
+ - Background `{colors.canvas-soft}`, text `{colors.body}`, body in `{typography.body-sm}`, padding `{spacing.xs} {spacing.sm}`, shape `{rounded.full}`.
679
+
680
+ **`link-inline`** — body-copy inline links.
681
+ - Text `{colors.link}` (`#0070f3`), body in `{typography.body-md}`, underlined.
682
+
683
+ ### Examples (illustrative)
684
+
685
+ > Auto-derived kit-mirror demonstration surfaces (`scripts/derive-examples-block.mjs`). Each `ex-*` entry references brand-native primitives so downstream consumers (`/preview-design`, `/generate-kit`) re-skin the same 10 surfaces consistently. `TO_FILL` markers indicate missing primitives — resolve in the LLM judgment pass.
686
+
687
+ **`ex-pricing-tier`** — Default Pricing tier card. Re-uses feature-card chrome with brand canvas-soft surface.
688
+ - Properties: `backgroundColor`, `textColor`, `borderColor`, `rounded`, `padding`
689
+
690
+ **`ex-pricing-tier-featured`** — Featured/highlighted tier — polarity-flipped surface (dark fill + light text in light mode, light fill + dark text in dark mode).
691
+ - Properties: `backgroundColor`, `textColor`, `rounded`, `padding`
692
+
693
+ **`ex-product-selector`** — What's Included summary card — re-purposed for SaaS / B2B verticals (NOT a literal product gallery).
694
+ - Properties: `backgroundColor`, `rounded`, `padding`
695
+
696
+ **`ex-cart-drawer`** — Subscription summary — re-purposed for SaaS / B2B (line items per add-on, not literal cart).
697
+ - Properties: `backgroundColor`, `rounded`, `padding`, `item-divider`
698
+
699
+ **`ex-app-shell-row`** — Sidebar nav row inside the App Shell example. Active state uses brand primary as the indicator.
700
+ - Properties: `backgroundColor`, `activeIndicator`, `rounded`, `padding`
701
+
702
+ **`ex-data-table-cell`** — Default data-table th + td chrome. Header uses mono-caps eyebrow typography; body uses body-sm.
703
+ - Properties: `headerBackground`, `headerTypography`, `bodyTypography`, `cellPadding`, `rowBorder`
704
+
705
+ **`ex-auth-form-card`** — Sign-in / sign-up card. Re-uses feature-card chrome with text-input primitives inside.
706
+ - Properties: `backgroundColor`, `rounded`, `padding`
707
+
708
+ **`ex-modal-card`** — Modal dialog surface — same chrome as feature-card with elevated shadow.
709
+ - Properties: `backgroundColor`, `rounded`, `padding`
710
+
711
+ **`ex-empty-state-card`** — Empty-state illustration frame.
712
+ - Properties: `backgroundColor`, `rounded`, `padding`, `captionTypography`
713
+
714
+ **`ex-toast`** — Toast notification surface — feature-card shape + medium shadow.
715
+ - Properties: `backgroundColor`, `rounded`, `padding`, `typography`
716
+
717
+
718
+ ## Do's and Don'ts
719
+
720
+ ### Do
721
+ - Reserve `{colors.primary}` (`#171717`) for primary CTAs across the page. Black ink IS the conversion target.
722
+ - Use `{rounded.pill}` 100 px for every marketing-scale CTA and `{rounded.sm}` 6 px for nav-scale buttons. The two pill scales coexist deliberately.
723
+ - Set every headline in `{typography.display-*}` weight 600, sentence-case, often period-terminated. Aggressive negative tracking is part of the voice.
724
+ - Use the brand mesh gradient as atmospheric decoration at hero scale only — never miniaturise it to an icon, never reduce to a single colour.
725
+ - Layer stacked shadows (multiple small offsets with inset hairline) rather than single heavy drops. The brand's elevation is calmer than Material.
726
+ - Cycle page surfaces in `{colors.canvas-soft}` → `{colors.canvas}` → `{colors.primary}` polarity-flipped bands; the dark band IS the depth cue.
727
+ - Set every code block and technical eyebrow in `{typography.code}` / `{typography.caption-mono}`. Mono is the voice of the platform.
728
+
729
+ ### Don't
730
+ - Don't introduce a sixth accent colour. The brand operates with ink + gray + the four-pair gradient palette; new accents flatten the voice.
731
+ - Don't render headlines in all-caps. Sentence-case + negative tracking is non-negotiable.
732
+ - Don't drop a single heavy drop-shadow on cards. The brand's elevation is built from stacked small offsets + inset hairline rings.
733
+ - Don't render the brand gradient at icon scale or in a single-colour reduced form. The gradient lives at hero scale only.
734
+ - Don't promote the geometric sans to weight 700. The brand's display ceiling is 600.
735
+ - Don't pair the marketing 100-px pill CTA shape with the 6-px nav radius on the same screen — pick a scale and stay there.
736
+ - Don't set body paragraphs in the mono face. The mono is for code + technical labels only.