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.
- package/LICENSE +21 -0
- package/README.md +40 -0
- package/bin/relay.js +362 -0
- package/design-md/airbnb/DESIGN.md +545 -0
- package/design-md/airbnb/README.md +5 -0
- package/design-md/airtable/DESIGN.md +554 -0
- package/design-md/airtable/README.md +5 -0
- package/design-md/apple/DESIGN.md +562 -0
- package/design-md/apple/README.md +5 -0
- package/design-md/binance/DESIGN.md +634 -0
- package/design-md/binance/README.md +5 -0
- package/design-md/bmw/DESIGN.md +544 -0
- package/design-md/bmw/README.md +5 -0
- package/design-md/bmw-m/DESIGN.md +503 -0
- package/design-md/bmw-m/README.md +5 -0
- package/design-md/bugatti/DESIGN.md +454 -0
- package/design-md/bugatti/README.md +5 -0
- package/design-md/cal/DESIGN.md +542 -0
- package/design-md/cal/README.md +5 -0
- package/design-md/claude/DESIGN.md +589 -0
- package/design-md/claude/README.md +5 -0
- package/design-md/clay/DESIGN.md +541 -0
- package/design-md/clay/README.md +5 -0
- package/design-md/clickhouse/DESIGN.md +544 -0
- package/design-md/clickhouse/README.md +5 -0
- package/design-md/cohere/DESIGN.md +451 -0
- package/design-md/cohere/README.md +5 -0
- package/design-md/coinbase/DESIGN.md +570 -0
- package/design-md/coinbase/README.md +5 -0
- package/design-md/composio/DESIGN.md +506 -0
- package/design-md/composio/README.md +5 -0
- package/design-md/cursor/DESIGN.md +537 -0
- package/design-md/cursor/README.md +5 -0
- package/design-md/elevenlabs/DESIGN.md +504 -0
- package/design-md/elevenlabs/README.md +5 -0
- package/design-md/expo/DESIGN.md +526 -0
- package/design-md/expo/README.md +5 -0
- package/design-md/ferrari/DESIGN.md +531 -0
- package/design-md/ferrari/README.md +5 -0
- package/design-md/figma/DESIGN.md +578 -0
- package/design-md/figma/README.md +5 -0
- package/design-md/framer/DESIGN.md +544 -0
- package/design-md/framer/README.md +5 -0
- package/design-md/hashicorp/DESIGN.md +575 -0
- package/design-md/hashicorp/README.md +5 -0
- package/design-md/ibm/DESIGN.md +550 -0
- package/design-md/ibm/README.md +5 -0
- package/design-md/intercom/DESIGN.md +546 -0
- package/design-md/intercom/README.md +5 -0
- package/design-md/kraken/DESIGN.md +125 -0
- package/design-md/kraken/README.md +5 -0
- package/design-md/lamborghini/DESIGN.md +288 -0
- package/design-md/lamborghini/README.md +5 -0
- package/design-md/linear.app/DESIGN.md +548 -0
- package/design-md/linear.app/README.md +5 -0
- package/design-md/lovable/DESIGN.md +298 -0
- package/design-md/lovable/README.md +5 -0
- package/design-md/mastercard/DESIGN.md +365 -0
- package/design-md/mastercard/README.md +5 -0
- package/design-md/meta/DESIGN.md +683 -0
- package/design-md/meta/README.md +5 -0
- package/design-md/minimax/DESIGN.md +746 -0
- package/design-md/minimax/README.md +5 -0
- package/design-md/mintlify/DESIGN.md +852 -0
- package/design-md/mintlify/README.md +5 -0
- package/design-md/miro/DESIGN.md +825 -0
- package/design-md/miro/README.md +5 -0
- package/design-md/mistral.ai/DESIGN.md +773 -0
- package/design-md/mistral.ai/README.md +5 -0
- package/design-md/mongodb/DESIGN.md +767 -0
- package/design-md/mongodb/README.md +5 -0
- package/design-md/nike/DESIGN.md +575 -0
- package/design-md/nike/README.md +5 -0
- package/design-md/notion/DESIGN.md +821 -0
- package/design-md/notion/README.md +5 -0
- package/design-md/nvidia/DESIGN.md +640 -0
- package/design-md/nvidia/README.md +5 -0
- package/design-md/ollama/DESIGN.md +539 -0
- package/design-md/ollama/README.md +5 -0
- package/design-md/opencode.ai/DESIGN.md +521 -0
- package/design-md/opencode.ai/README.md +5 -0
- package/design-md/pinterest/DESIGN.md +597 -0
- package/design-md/pinterest/README.md +5 -0
- package/design-md/playstation/DESIGN.md +661 -0
- package/design-md/playstation/README.md +5 -0
- package/design-md/posthog/DESIGN.md +690 -0
- package/design-md/posthog/README.md +5 -0
- package/design-md/raycast/DESIGN.md +669 -0
- package/design-md/raycast/README.md +5 -0
- package/design-md/renault/DESIGN.md +589 -0
- package/design-md/renault/README.md +5 -0
- package/design-md/replicate/DESIGN.md +616 -0
- package/design-md/replicate/README.md +5 -0
- package/design-md/resend/DESIGN.md +585 -0
- package/design-md/resend/README.md +5 -0
- package/design-md/revolut/DESIGN.md +636 -0
- package/design-md/revolut/README.md +5 -0
- package/design-md/runwayml/DESIGN.md +244 -0
- package/design-md/runwayml/README.md +5 -0
- package/design-md/sanity/DESIGN.md +357 -0
- package/design-md/sanity/README.md +5 -0
- package/design-md/sentry/DESIGN.md +551 -0
- package/design-md/sentry/README.md +5 -0
- package/design-md/shopify/DESIGN.md +516 -0
- package/design-md/shopify/README.md +5 -0
- package/design-md/slack/DESIGN.md +482 -0
- package/design-md/spacex/DESIGN.md +363 -0
- package/design-md/spacex/README.md +5 -0
- package/design-md/spotify/DESIGN.md +246 -0
- package/design-md/spotify/README.md +5 -0
- package/design-md/starbucks/DESIGN.md +580 -0
- package/design-md/starbucks/README.md +5 -0
- package/design-md/stripe/DESIGN.md +487 -0
- package/design-md/stripe/README.md +5 -0
- package/design-md/supabase/DESIGN.md +462 -0
- package/design-md/supabase/README.md +5 -0
- package/design-md/superhuman/DESIGN.md +448 -0
- package/design-md/superhuman/README.md +5 -0
- package/design-md/tesla/DESIGN.md +286 -0
- package/design-md/tesla/README.md +5 -0
- package/design-md/theverge/DESIGN.md +339 -0
- package/design-md/theverge/README.md +5 -0
- package/design-md/together.ai/DESIGN.md +633 -0
- package/design-md/together.ai/README.md +5 -0
- package/design-md/uber/DESIGN.md +636 -0
- package/design-md/uber/README.md +5 -0
- package/design-md/vercel/DESIGN.md +736 -0
- package/design-md/vercel/README.md +5 -0
- package/design-md/vodafone/DESIGN.md +538 -0
- package/design-md/vodafone/README.md +5 -0
- package/design-md/voltagent/DESIGN.md +521 -0
- package/design-md/voltagent/README.md +5 -0
- package/design-md/warp/DESIGN.md +526 -0
- package/design-md/warp/README.md +5 -0
- package/design-md/webflow/DESIGN.md +588 -0
- package/design-md/webflow/README.md +5 -0
- package/design-md/wired/DESIGN.md +497 -0
- package/design-md/wired/README.md +5 -0
- package/design-md/wise/DESIGN.md +544 -0
- package/design-md/wise/README.md +5 -0
- package/design-md/x.ai/DESIGN.md +465 -0
- package/design-md/x.ai/README.md +5 -0
- package/design-md/zapier/DESIGN.md +537 -0
- package/design-md/zapier/README.md +5 -0
- 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.
|