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,504 @@
1
+ ---
2
+ version: alpha
3
+ name: ElevenLabs
4
+ description: A voice-AI brand whose marketing surfaces read like a quietly editorial print magazine. The base canvas is off-white (`#f5f5f5`) holding warm near-black ink (`#292524`); the brand voltage is photographic, not chromatic — soft pastel atmospheric gradient orbs (mint → peach → lavender → sky) drift through the page as the only "color" moments. Display runs Waldenburg Light at weight 300 — the editorial signature. Inter carries body, navigation, captions. CTAs are subtle: a near-black ink pill is the primary, a transparent outline is the secondary. The brand trusts atmospheric photography and modest type weights to do all of the brand work; there is no neon accent, no saturated CTA color, no developer-tools dark canvas.
5
+
6
+ colors:
7
+ primary: "#292524"
8
+ primary-active: "#0c0a09"
9
+ ink: "#0c0a09"
10
+ body: "#4e4e4e"
11
+ body-strong: "#292524"
12
+ muted: "#777169"
13
+ muted-soft: "#a8a29e"
14
+ hairline: "#e7e5e4"
15
+ hairline-soft: "#f0efed"
16
+ hairline-strong: "#d6d3d1"
17
+ canvas: "#f5f5f5"
18
+ canvas-soft: "#fafafa"
19
+ canvas-deep: "#0c0a09"
20
+ surface-card: "#ffffff"
21
+ surface-strong: "#f0efed"
22
+ surface-dark: "#0c0a09"
23
+ surface-dark-elevated: "#1c1917"
24
+ on-primary: "#ffffff"
25
+ on-dark: "#ffffff"
26
+ on-dark-soft: "#a8a29e"
27
+ gradient-mint: "#a7e5d3"
28
+ gradient-peach: "#f4c5a8"
29
+ gradient-lavender: "#c8b8e0"
30
+ gradient-sky: "#a8c8e8"
31
+ gradient-rose: "#e8b8c4"
32
+ semantic-error: "#dc2626"
33
+ semantic-success: "#16a34a"
34
+
35
+ typography:
36
+ display-mega:
37
+ fontFamily: "'Waldenburg', 'Times New Roman', serif"
38
+ fontSize: 64px
39
+ fontWeight: 300
40
+ lineHeight: 1.05
41
+ letterSpacing: -1.92px
42
+ display-xl:
43
+ fontFamily: "'Waldenburg', serif"
44
+ fontSize: 48px
45
+ fontWeight: 300
46
+ lineHeight: 1.08
47
+ letterSpacing: -0.96px
48
+ display-lg:
49
+ fontFamily: "'Waldenburg', serif"
50
+ fontSize: 36px
51
+ fontWeight: 300
52
+ lineHeight: 1.17
53
+ letterSpacing: -0.36px
54
+ display-md:
55
+ fontFamily: "'Waldenburg', serif"
56
+ fontSize: 32px
57
+ fontWeight: 300
58
+ lineHeight: 1.13
59
+ letterSpacing: -0.32px
60
+ display-sm:
61
+ fontFamily: "'Waldenburg', serif"
62
+ fontSize: 24px
63
+ fontWeight: 300
64
+ lineHeight: 1.2
65
+ letterSpacing: 0
66
+ title-md:
67
+ fontFamily: "'Inter', sans-serif"
68
+ fontSize: 20px
69
+ fontWeight: 500
70
+ lineHeight: 1.35
71
+ letterSpacing: 0
72
+ title-sm:
73
+ fontFamily: "'Inter', sans-serif"
74
+ fontSize: 18px
75
+ fontWeight: 500
76
+ lineHeight: 1.44
77
+ letterSpacing: 0.18px
78
+ body-md:
79
+ fontFamily: "'Inter', sans-serif"
80
+ fontSize: 16px
81
+ fontWeight: 400
82
+ lineHeight: 1.5
83
+ letterSpacing: 0.16px
84
+ body-strong:
85
+ fontFamily: "'Inter', sans-serif"
86
+ fontSize: 16px
87
+ fontWeight: 500
88
+ lineHeight: 1.5
89
+ letterSpacing: 0.16px
90
+ body-sm:
91
+ fontFamily: "'Inter', sans-serif"
92
+ fontSize: 15px
93
+ fontWeight: 400
94
+ lineHeight: 1.47
95
+ letterSpacing: 0.15px
96
+ caption:
97
+ fontFamily: "'Inter', sans-serif"
98
+ fontSize: 14px
99
+ fontWeight: 400
100
+ lineHeight: 1.5
101
+ letterSpacing: 0
102
+ caption-uppercase:
103
+ fontFamily: "'Inter', sans-serif"
104
+ fontSize: 12px
105
+ fontWeight: 600
106
+ lineHeight: 1.4
107
+ letterSpacing: 0.96px
108
+ textTransform: uppercase
109
+ button:
110
+ fontFamily: "'Inter', sans-serif"
111
+ fontSize: 15px
112
+ fontWeight: 500
113
+ lineHeight: 1.0
114
+ letterSpacing: 0
115
+ nav-link:
116
+ fontFamily: "'Inter', sans-serif"
117
+ fontSize: 15px
118
+ fontWeight: 500
119
+ lineHeight: 1.4
120
+ letterSpacing: 0
121
+
122
+ rounded:
123
+ none: 0px
124
+ xs: 4px
125
+ sm: 6px
126
+ md: 8px
127
+ lg: 12px
128
+ xl: 16px
129
+ xxl: 24px
130
+ pill: 9999px
131
+ full: 9999px
132
+
133
+ spacing:
134
+ xxs: 4px
135
+ xs: 8px
136
+ sm: 12px
137
+ base: 16px
138
+ md: 20px
139
+ lg: 24px
140
+ xl: 32px
141
+ xxl: 48px
142
+ section: 96px
143
+
144
+ components:
145
+ top-nav:
146
+ backgroundColor: "{colors.canvas}"
147
+ textColor: "{colors.ink}"
148
+ typography: "{typography.nav-link}"
149
+ height: 64px
150
+ button-primary:
151
+ backgroundColor: "{colors.primary}"
152
+ textColor: "{colors.on-primary}"
153
+ typography: "{typography.button}"
154
+ rounded: "{rounded.pill}"
155
+ padding: 10px 20px
156
+ height: 40px
157
+ button-primary-active:
158
+ backgroundColor: "{colors.primary-active}"
159
+ textColor: "{colors.on-primary}"
160
+ rounded: "{rounded.pill}"
161
+ button-outline:
162
+ backgroundColor: transparent
163
+ textColor: "{colors.ink}"
164
+ typography: "{typography.button}"
165
+ rounded: "{rounded.pill}"
166
+ padding: 9px 19px
167
+ height: 40px
168
+ button-tertiary-text:
169
+ backgroundColor: transparent
170
+ textColor: "{colors.ink}"
171
+ typography: "{typography.button}"
172
+ hero-band:
173
+ backgroundColor: "{colors.canvas}"
174
+ textColor: "{colors.ink}"
175
+ typography: "{typography.display-mega}"
176
+ padding: 96px
177
+ gradient-orb-card:
178
+ backgroundColor: "{colors.canvas-soft}"
179
+ textColor: "{colors.ink}"
180
+ rounded: "{rounded.xxl}"
181
+ padding: 32px
182
+ feature-card:
183
+ backgroundColor: "{colors.surface-card}"
184
+ textColor: "{colors.ink}"
185
+ typography: "{typography.title-md}"
186
+ rounded: "{rounded.xl}"
187
+ padding: 24px
188
+ product-card-stack:
189
+ backgroundColor: "{colors.surface-card}"
190
+ textColor: "{colors.ink}"
191
+ typography: "{typography.body-md}"
192
+ rounded: "{rounded.xl}"
193
+ padding: 0
194
+ voice-row:
195
+ backgroundColor: transparent
196
+ textColor: "{colors.ink}"
197
+ typography: "{typography.body-md}"
198
+ padding: 12px 0
199
+ voice-icon-circular:
200
+ backgroundColor: "{colors.surface-strong}"
201
+ rounded: "{rounded.full}"
202
+ size: 32px
203
+ pricing-tier-card:
204
+ backgroundColor: "{colors.surface-card}"
205
+ textColor: "{colors.ink}"
206
+ typography: "{typography.body-md}"
207
+ rounded: "{rounded.xl}"
208
+ padding: 32px
209
+ pricing-tier-featured:
210
+ backgroundColor: "{colors.surface-dark}"
211
+ textColor: "{colors.on-dark}"
212
+ typography: "{typography.body-md}"
213
+ rounded: "{rounded.xl}"
214
+ padding: 32px
215
+ text-input:
216
+ backgroundColor: "{colors.surface-card}"
217
+ textColor: "{colors.ink}"
218
+ typography: "{typography.body-md}"
219
+ rounded: "{rounded.md}"
220
+ padding: 12px 16px
221
+ height: 44px
222
+ badge-pill:
223
+ backgroundColor: "{colors.surface-strong}"
224
+ textColor: "{colors.ink}"
225
+ typography: "{typography.caption-uppercase}"
226
+ rounded: "{rounded.pill}"
227
+ padding: 4px 10px
228
+ cta-band:
229
+ backgroundColor: "{colors.canvas}"
230
+ textColor: "{colors.ink}"
231
+ typography: "{typography.display-lg}"
232
+ padding: 96px
233
+ testimonial-card:
234
+ backgroundColor: "{colors.surface-card}"
235
+ textColor: "{colors.body}"
236
+ typography: "{typography.body-md}"
237
+ rounded: "{rounded.xl}"
238
+ padding: 32px
239
+ audio-waveform-card:
240
+ backgroundColor: "{colors.surface-card}"
241
+ textColor: "{colors.ink}"
242
+ rounded: "{rounded.xl}"
243
+ padding: 24px
244
+ footer:
245
+ backgroundColor: "{colors.canvas}"
246
+ textColor: "{colors.body}"
247
+ typography: "{typography.body-sm}"
248
+ padding: 64px 48px
249
+ footer-link:
250
+ backgroundColor: transparent
251
+ textColor: "{colors.body}"
252
+ typography: "{typography.body-sm}"
253
+ ---
254
+
255
+ ## Overview
256
+
257
+ ElevenLabs reads like a quietly editorial print magazine that happens to be a voice-AI product. The base canvas is off-white `{colors.canvas}` (#f5f5f5) holding warm near-black ink `{colors.ink}` (#0c0a09). The brand voltage is **photographic, not chromatic**: soft pastel atmospheric gradient orbs (mint, peach, lavender, sky, rose) drift through the page as the only "color" moments. There is no neon accent, no saturated CTA color, no dark-canvas dev-tools atmosphere.
258
+
259
+ Type pairs **Waldenburg Light** (custom serif at weight 300) for display with **Inter** for body, navigation, captions. The display weight at 300 is the editorial signature — never bold, never heavy.
260
+
261
+ CTAs are subtle: a near-black ink pill (`{component.button-primary}`) is the primary, a transparent outline (`{component.button-outline}`) is the secondary. The brand trusts atmospheric photography and modest type weights to carry brand work.
262
+
263
+ **Key Characteristics:**
264
+ - Off-white canvas, warm near-black ink. No saturated CTA color.
265
+ - Single primary action: ink pill at `{rounded.pill}`. Atmospheric gradients carry visual brand voltage.
266
+ - Display runs Waldenburg Light at weight 300 — editorial magazine voice.
267
+ - Body runs Inter at 400 with subtle letter-spacing (+0.15-0.18px).
268
+ - Pastel gradient orbs (5 tokens: mint, peach, lavender, sky, rose) used as atmospheric brand decoration only.
269
+ - Soft pill geometry (`{rounded.pill}` for CTAs, `{rounded.xl}` for cards).
270
+ - 96px section rhythm.
271
+
272
+ ## Colors
273
+
274
+ ### Brand & Accent
275
+ - **Ink Primary** (`{colors.primary}` — #292524): The primary action color — warm near-black pill. Used scarcely.
276
+ - **Ink Primary Active** (`{colors.primary-active}` — #0c0a09): Press state.
277
+
278
+ ### Surface
279
+ - **Canvas** (`{colors.canvas}` — #f5f5f5): Off-white page floor.
280
+ - **Canvas Soft** (`{colors.canvas-soft}` — #fafafa): Lighter band for subtle alternating sections.
281
+ - **Canvas Deep** (`{colors.canvas-deep}` — #0c0a09): Same as ink — used for the rare dark-mode hero (Agents page).
282
+ - **Surface Card** (`{colors.surface-card}` — #ffffff): Pure white card.
283
+ - **Surface Strong** (`{colors.surface-strong}` — #f0efed): Badges, voice-icon plates.
284
+ - **Surface Dark** (`{colors.surface-dark}` — #0c0a09): Dark hero/CTA band canvas.
285
+ - **Surface Dark Elevated** (`{colors.surface-dark-elevated}` — #1c1917): Cards on dark canvas.
286
+
287
+ ### Hairlines
288
+ - **Hairline** (`{colors.hairline}` — #e7e5e4): Default 1px divider.
289
+ - **Hairline Soft** (`{colors.hairline-soft}` — #f0efed): Lighter divider.
290
+ - **Hairline Strong** (`{colors.hairline-strong}` — #d6d3d1): Stronger panel outline.
291
+
292
+ ### Text
293
+ - **Ink** (`{colors.ink}` — #0c0a09): Display, primary text.
294
+ - **Body** (`{colors.body}` — #4e4e4e): Default running-text.
295
+ - **Body Strong** (`{colors.body-strong}` — #292524): Same as primary — emphasis.
296
+ - **Muted** (`{colors.muted}` — #777169): Sub-titles.
297
+ - **Muted Soft** (`{colors.muted-soft}` — #a8a29e): Disabled text.
298
+ - **On Primary** (`{colors.on-primary}` — #ffffff): White text on ink pill.
299
+ - **On Dark** (`{colors.on-dark}` — #ffffff): White text on dark hero.
300
+ - **On Dark Soft** (`{colors.on-dark-soft}` — #a8a29e): Muted off-white on dark.
301
+
302
+ ### Atmospheric Gradient Stops (signature)
303
+ - **Gradient Mint** (`{colors.gradient-mint}` — #a7e5d3): Mint green orb.
304
+ - **Gradient Peach** (`{colors.gradient-peach}` — #f4c5a8): Peach orb.
305
+ - **Gradient Lavender** (`{colors.gradient-lavender}` — #c8b8e0): Lavender orb.
306
+ - **Gradient Sky** (`{colors.gradient-sky}` — #a8c8e8): Sky-blue orb.
307
+ - **Gradient Rose** (`{colors.gradient-rose}` — #e8b8c4): Rose orb.
308
+
309
+ These appear ONLY as soft radial-gradient atmospheric orbs inside `{component.gradient-orb-card}` and as background atmospheric blooms behind hero copy. Never as button fills, never as text colors.
310
+
311
+ ### Semantic
312
+ - **Success** (`{colors.semantic-success}` — #16a34a): Confirmation.
313
+ - **Error** (`{colors.semantic-error}` — #dc2626): Validation errors.
314
+
315
+ ## Typography
316
+
317
+ ### Font Family
318
+ **Waldenburg Light** is the licensed display serif at weight 300. **Inter** carries body, navigation, captions, and buttons. Fallback: `'Times New Roman', serif` for Waldenburg, `sans-serif` for Inter.
319
+
320
+ ### Hierarchy
321
+
322
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
323
+ |---|---|---|---|---|---|
324
+ | `{typography.display-mega}` | 64px | 300 | 1.05 | -1.92px | Homepage hero h1 |
325
+ | `{typography.display-xl}` | 48px | 300 | 1.08 | -0.96px | Subsidiary heroes |
326
+ | `{typography.display-lg}` | 36px | 300 | 1.17 | -0.36px | Section heads |
327
+ | `{typography.display-md}` | 32px | 300 | 1.13 | -0.32px | Sub-section heads |
328
+ | `{typography.display-sm}` | 24px | 300 | 1.2 | 0 | Card group titles |
329
+ | `{typography.title-md}` | 20px | 500 | 1.35 | 0 | Component titles — Inter |
330
+ | `{typography.title-sm}` | 18px | 500 | 1.44 | 0.18px | List labels |
331
+ | `{typography.body-md}` | 16px | 400 | 1.5 | 0.16px | Default body — Inter |
332
+ | `{typography.body-strong}` | 16px | 500 | 1.5 | 0.16px | Emphasized body |
333
+ | `{typography.body-sm}` | 15px | 400 | 1.47 | 0.15px | Footer body |
334
+ | `{typography.caption}` | 14px | 400 | 1.5 | 0 | Photo captions |
335
+ | `{typography.caption-uppercase}` | 12px | 600 | 1.4 | 0.96px | Section labels, badges |
336
+ | `{typography.button}` | 15px | 500 | 1.0 | 0 | CTA pill |
337
+ | `{typography.nav-link}` | 15px | 500 | 1.4 | 0 | Top-nav menu |
338
+
339
+ ### Principles
340
+ - **Display weight stays at 300.** Waldenburg Light is the editorial signature. Never bold display copy.
341
+ - **Subtle letter-spacing on body.** Inter at +0.15-0.18px tracking — slightly looser than default Inter for a more editorial feel.
342
+ - **Negative letter-spacing on display.** Waldenburg pulls -0.32px to -1.92px tighter on display sizes.
343
+
344
+ ### Note on Font Substitutes
345
+ Waldenburg is licensed. Open-source substitute: **EB Garamond** at weight 300 (slightly more humanist) or **GT Sectra** (closer to Waldenburg's modernity). Use Inter directly for body — it's the same family ElevenLabs uses.
346
+
347
+ ## Layout
348
+
349
+ ### Spacing System
350
+ - **Base unit:** 4px.
351
+ - **Tokens:** `{spacing.xxs}` 4px · `{spacing.xs}` 8px · `{spacing.sm}` 12px · `{spacing.base}` 16px · `{spacing.md}` 20px · `{spacing.lg}` 24px · `{spacing.xl}` 32px · `{spacing.xxl}` 48px · `{spacing.section}` 96px.
352
+ - **Section padding:** 96px.
353
+
354
+ ### Grid & Container
355
+ - Max content width: ~1200px.
356
+ - Editorial body: 12-column grid.
357
+ - Feature card grids: 2-up at desktop for hero splits, 3-up for benefit grids.
358
+ - Footer: 5-column at desktop.
359
+
360
+ ### Whitespace Philosophy
361
+ Generous editorial pacing — print-magazine feel. 96px between bands; cards inside bands sit close (16-24px gap). The atmospheric gradient orbs occupy generous breathing space without competing with copy.
362
+
363
+ ## Elevation & Depth
364
+
365
+ The system uses **hairline + soft drop**. Cards float above the off-white canvas via 1px hairlines and a single subtle shadow tier. Atmospheric depth comes from gradient orbs.
366
+
367
+ | Level | Treatment | Use |
368
+ |---|---|---|
369
+ | Flat (canvas) | `{colors.canvas}` (#f5f5f5) | Body bands, footer |
370
+ | Card | `{colors.surface-card}` (#ffffff) | Content cards |
371
+ | Hairline border | 1px `{colors.hairline}` | Card outlines |
372
+ | Soft drop | `0 4px 16px rgba(0, 0, 0, 0.04)` | Hovered cards (single shadow tier) |
373
+ | Gradient orb | Radial gradient with one of `{colors.gradient-*}` | Atmospheric depth — never a card surface |
374
+
375
+ ### Decorative Depth
376
+ - **Pastel gradient orbs** are the brand's strongest atmospheric pattern. Soft radial blooms in mint, peach, lavender, sky, or rose drift through hero bands and feature sections without containing any content — they are pure atmosphere.
377
+
378
+ ## Shapes
379
+
380
+ ### Border Radius Scale
381
+
382
+ | Token | Value | Use |
383
+ |---|---|---|
384
+ | `{rounded.none}` | 0px | Reserved |
385
+ | `{rounded.xs}` | 4px | Inline tags |
386
+ | `{rounded.sm}` | 6px | Compact rows |
387
+ | `{rounded.md}` | 8px | Form inputs |
388
+ | `{rounded.lg}` | 12px | Compact cards |
389
+ | `{rounded.xl}` | 16px | Feature cards, pricing tiers |
390
+ | `{rounded.xxl}` | 24px | Gradient orb cards (extra-soft) |
391
+ | `{rounded.pill}` | 9999px | All CTA buttons, badges |
392
+ | `{rounded.full}` | 9999px | Voice icon circles, avatars |
393
+
394
+ ## Components
395
+
396
+ ### Top Navigation
397
+
398
+ **`top-nav`** — Background `{colors.canvas}`, text `{colors.ink}`, height 64px. Layout: ElevenLabs wordmark left, primary horizontal menu (Creative / Agents / Video / Pricing / Enterprise / Docs), Sign In + "Try free" primary CTA right.
399
+
400
+ ### Buttons
401
+
402
+ **`button-primary`** — Near-black ink pill. Background `{colors.primary}`, text `{colors.on-primary}`, type `{typography.button}` (15px / 500), padding 10px × 20px, height 40px, rounded `{rounded.pill}`.
403
+
404
+ **`button-primary-active`** — Press state. Background `{colors.primary-active}`.
405
+
406
+ **`button-outline`** — Transparent pill with 1px ink border. Background transparent, text `{colors.ink}`, 1px `{colors.hairline-strong}` border.
407
+
408
+ **`button-tertiary-text`** — Inline ink text link.
409
+
410
+ ### Hero & Atmospheric
411
+
412
+ **`hero-band`** — Background `{colors.canvas}`, full-width display headline in `{typography.display-mega}` (64px / 300 / -1.92px), subhead in `{typography.body-md}`, two CTAs, and an atmospheric gradient orb behind the centered headline.
413
+
414
+ **`gradient-orb-card`** — A large card with a soft radial-gradient orb behind centered display copy. Background `{colors.canvas-soft}`, rounded `{rounded.xxl}` (24px), padding 32px. Each variant uses one of the five gradient tokens (`gradient-mint`, `gradient-peach`, `gradient-lavender`, `gradient-sky`, `gradient-rose`).
415
+
416
+ **`audio-waveform-card`** — A waveform visualization card. Background `{colors.surface-card}`, rounded `{rounded.xl}`, padding 24px. Holds a play button + waveform glyph + voice metadata.
417
+
418
+ ### Cards
419
+
420
+ **`feature-card`** — 2-up or 3-up grids. Background `{colors.surface-card}`, text `{colors.ink}`, rounded `{rounded.xl}`, padding 24px, 1px hairline border.
421
+
422
+ **`product-card-stack`** — Stacked product preview cards. Background `{colors.surface-card}`, rounded `{rounded.xl}`, no padding (children fill the card edge-to-edge).
423
+
424
+ **`testimonial-card`** — Quote card. Background `{colors.surface-card}`, text `{colors.body}`, rounded `{rounded.xl}`, padding 32px.
425
+
426
+ ### Voice Library
427
+
428
+ **`voice-row`** — Horizontal row in voice list. Background transparent, 1px hairline divider. Layout: 32px circular voice icon (`{component.voice-icon-circular}`) left, voice name + accent stack, optional preview button right.
429
+
430
+ **`voice-icon-circular`** — Background `{colors.surface-strong}`, rounded `{rounded.full}`, 32px diameter. Holds initials or voice glyph.
431
+
432
+ ### Pricing
433
+
434
+ **`pricing-tier-card`** — Background `{colors.surface-card}`, rounded `{rounded.xl}`, padding 32px, 1px hairline border.
435
+
436
+ **`pricing-tier-featured`** — Featured tier inverts. Background `{colors.surface-dark}`, text `{colors.on-dark}`. Same shape, dark inversion.
437
+
438
+ ### Forms & Tags
439
+
440
+ **`text-input`** — Background `{colors.surface-card}`, text `{colors.ink}`, rounded `{rounded.md}` (8px), padding 12px × 16px, height 44px, 1px `{colors.hairline-strong}` border. On focus, border thickens to 2px ink.
441
+
442
+ **`badge-pill`** — Background `{colors.surface-strong}`, text `{colors.ink}`, type `{typography.caption-uppercase}`, rounded `{rounded.pill}`, padding 4px × 10px.
443
+
444
+ ### CTA / Footer
445
+
446
+ **`cta-band`** — Pre-footer. Background `{colors.canvas}`, centered display headline in `{typography.display-lg}`, single ink pill CTA. 96px padding.
447
+
448
+ **`footer`** — Closing footer. Background `{colors.canvas}`, text `{colors.body}`. 5-column link list. 64×48px padding.
449
+
450
+ **`footer-link`** — Background transparent, text `{colors.body}`, type `{typography.body-sm}`.
451
+
452
+ ## Do's and Don'ts
453
+
454
+ ### Do
455
+ - Reserve `{colors.primary}` (ink pill) for primary CTAs.
456
+ - Use Waldenburg Light at weight 300 for every display headline. Never bold.
457
+ - Use Inter at +0.15-0.18px tracking for body — the editorial dialect.
458
+ - Use atmospheric gradient orbs (mint/peach/lavender/sky/rose) as decoration only.
459
+ - Use the pill shape for every CTA and badge.
460
+
461
+ ### Don't
462
+ - Don't introduce a saturated brand action color. Ink pill is the only CTA color.
463
+ - Don't bold display copy. Display sits at weight 300 — bolding shifts the brand voice from editorial to consumer-marketing.
464
+ - Don't use gradient orbs as button fills, text colors, or component backgrounds. They are pure atmosphere.
465
+ - Don't use sharp `{rounded.none}` (0px) on CTAs. Pill geometry is the brand button.
466
+ - Don't drop body Inter to weight 300 to match Waldenburg — body stays at 400/500 for legibility.
467
+ - Don't extract a CTA color from a third-party widget (cookie consent, OneTrust). The brand's CTA color is what appears on actual product CTAs.
468
+
469
+ ## Responsive Behavior
470
+
471
+ ### Breakpoints
472
+
473
+ | Name | Width | Key Changes |
474
+ |---|---|---|
475
+ | Mobile | < 640px | Hero h1 64→32px; feature cards 1-up; nav hamburger; gradient orbs shrink. |
476
+ | Tablet | 640–1024px | Hero h1 48px; feature cards 2-up. |
477
+ | Desktop | 1024–1280px | Full hero h1 64px; feature cards 3-up. |
478
+ | Wide | > 1280px | Content caps at 1200px. |
479
+
480
+ ### Touch Targets
481
+ - Primary pill at 40px height — at WCAG AA, padded for AAA.
482
+ - Voice icon circles 32px — padded row creates effective 48px tap zone.
483
+
484
+ ### Collapsing Strategy
485
+ - Top nav switches to hamburger below 768px.
486
+ - Feature grid: 3-up → 2-up → 1-up.
487
+ - Gradient orbs reduce diameter at every breakpoint but never disappear.
488
+
489
+ ## Iteration Guide
490
+
491
+ 1. Focus on a single component at a time.
492
+ 2. CTAs default to `{rounded.pill}`. Cards use `{rounded.xl}` (16px).
493
+ 3. Variants live as separate entries.
494
+ 4. Use `{token.refs}` everywhere — never inline hex.
495
+ 5. Hover state never documented.
496
+ 6. Waldenburg 300 for display, Inter 400/500 for body.
497
+ 7. Gradient orbs scoped to atmospheric decoration.
498
+
499
+ ## Known Gaps
500
+
501
+ - Waldenburg is a licensed typeface; EB Garamond / GT Sectra are documented substitutes.
502
+ - Animation timings (orb drift, waveform pulse, hero entrance) out of scope.
503
+ - In-product surfaces (voice library editor, agent playground) only partially captured via marketing mockups.
504
+ - Form validation states beyond focus not visible on captured surfaces.
@@ -0,0 +1,5 @@
1
+ # Elevenlabs Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/elevenlabs/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.