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,5 @@
1
+ # Vercel Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/vercel/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.
@@ -0,0 +1,538 @@
1
+ ---
2
+ version: alpha
3
+ name: Vodafone Inspired
4
+ description: An inspired interpretation of Vodafone's design language — a telecom super-brand whose web surface alternates between editorial photography hero bands with massive uppercase display headlines and clean white content bands, anchored by the company's signature scarlet red CTA and the proprietary Vodafone display sans set at impossibly heavy 800 weight.
5
+
6
+ colors:
7
+ primary: "#e60000"
8
+ on-primary: "#ffffff"
9
+ ink: "#25282b"
10
+ body: "#7e7e7e"
11
+ mute: "#bebebe"
12
+ canvas: "#ffffff"
13
+ canvas-soft: "#f2f2f2"
14
+ on-dark: "#ffffff"
15
+
16
+ typography:
17
+ display-hero:
18
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
19
+ fontSize: 144px
20
+ fontWeight: 800
21
+ lineHeight: 114px
22
+ letterSpacing: -1px
23
+ display-xxl:
24
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
25
+ fontSize: 126px
26
+ fontWeight: 800
27
+ lineHeight: 113px
28
+ letterSpacing: -1px
29
+ display-xl:
30
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
31
+ fontSize: 90px
32
+ fontWeight: 800
33
+ lineHeight: 84px
34
+ display-lg:
35
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
36
+ fontSize: 48px
37
+ fontWeight: 300
38
+ lineHeight: 52px
39
+ display-md:
40
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
41
+ fontSize: 40px
42
+ fontWeight: 300
43
+ lineHeight: 44px
44
+ display-sm:
45
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
46
+ fontSize: 32px
47
+ fontWeight: 700
48
+ lineHeight: 40px
49
+ display-xs:
50
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
51
+ fontSize: 24px
52
+ fontWeight: 700
53
+ lineHeight: 24px
54
+ eyebrow-uppercase:
55
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
56
+ fontSize: 16px
57
+ fontWeight: 800
58
+ lineHeight: 24px
59
+ body-lg:
60
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
61
+ fontSize: 22px
62
+ fontWeight: 400
63
+ lineHeight: 24px
64
+ body-md:
65
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
66
+ fontSize: 18px
67
+ fontWeight: 400
68
+ lineHeight: 28px
69
+ body-md-strong:
70
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
71
+ fontSize: 18px
72
+ fontWeight: 600
73
+ lineHeight: 28px
74
+ body-sm:
75
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
76
+ fontSize: 16px
77
+ fontWeight: 400
78
+ lineHeight: 20px
79
+ body-sm-strong:
80
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
81
+ fontSize: 16px
82
+ fontWeight: 700
83
+ lineHeight: 22px
84
+ caption:
85
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
86
+ fontSize: 14px
87
+ fontWeight: 400
88
+ lineHeight: 16px
89
+ caption-strong:
90
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
91
+ fontSize: 14px
92
+ fontWeight: 700
93
+ lineHeight: 21px
94
+ caption-uppercase:
95
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
96
+ fontSize: 12px
97
+ fontWeight: 600
98
+ lineHeight: 16px
99
+ letterSpacing: 0.5691px
100
+ button-md:
101
+ fontFamily: Vodafone, Vodafone Rg, Helvetica Neue, Arial, sans-serif
102
+ fontSize: 18px
103
+ fontWeight: 400
104
+ lineHeight: 28px
105
+
106
+ rounded:
107
+ none: 0px
108
+ xs: 1px
109
+ sm: 6px
110
+ card: 6px
111
+ pill-md: 32px
112
+ pill-lg: 60px
113
+ full: 9999px
114
+
115
+ spacing:
116
+ xxs: 2px
117
+ xs: 4px
118
+ sm: 8px
119
+ md: 12px
120
+ lg: 16px
121
+ xl: 20px
122
+ 2xl: 24px
123
+ 3xl: 32px
124
+
125
+ components:
126
+ nav-bar:
127
+ backgroundColor: "{colors.ink}"
128
+ textColor: "{colors.on-dark}"
129
+ typography: "{typography.body-sm}"
130
+ padding: "{spacing.lg} {spacing.3xl}"
131
+ nav-link:
132
+ textColor: "{colors.on-dark}"
133
+ typography: "{typography.body-sm}"
134
+ button-primary:
135
+ backgroundColor: "{colors.primary}"
136
+ textColor: "{colors.on-primary}"
137
+ borderColor: "{colors.primary}"
138
+ typography: "{typography.button-md}"
139
+ rounded: "{rounded.pill-lg}"
140
+ padding: "{spacing.md} {spacing.2xl}"
141
+ button-outline-red:
142
+ backgroundColor: "{colors.canvas}"
143
+ textColor: "{colors.primary}"
144
+ borderColor: "{colors.primary}"
145
+ typography: "{typography.button-md}"
146
+ rounded: "{rounded.pill-lg}"
147
+ padding: "{spacing.md} {spacing.2xl}"
148
+ button-outline-dark:
149
+ backgroundColor: "{colors.canvas}"
150
+ textColor: "{colors.ink}"
151
+ borderColor: "{colors.ink}"
152
+ typography: "{typography.button-md}"
153
+ rounded: "{rounded.pill-lg}"
154
+ padding: "{spacing.md} {spacing.2xl}"
155
+ button-icon-circular:
156
+ backgroundColor: "{colors.canvas}"
157
+ textColor: "{colors.ink}"
158
+ borderColor: "{colors.canvas}"
159
+ rounded: "{rounded.full}"
160
+ text-input:
161
+ backgroundColor: "{colors.canvas}"
162
+ textColor: "{colors.ink}"
163
+ borderColor: "{colors.ink}"
164
+ typography: "{typography.body-sm}"
165
+ rounded: "{rounded.sm}"
166
+ padding: "{spacing.md} {spacing.lg}"
167
+ badge-chip:
168
+ backgroundColor: "{colors.canvas-soft}"
169
+ textColor: "{colors.ink}"
170
+ typography: "{typography.caption-strong}"
171
+ rounded: "{rounded.pill-md}"
172
+ padding: "{spacing.xs} {spacing.md}"
173
+ card-content:
174
+ backgroundColor: "{colors.canvas}"
175
+ textColor: "{colors.ink}"
176
+ typography: "{typography.body-md}"
177
+ rounded: "{rounded.card}"
178
+ padding: "{spacing.lg}"
179
+ card-hero:
180
+ backgroundColor: "{colors.canvas}"
181
+ textColor: "{colors.ink}"
182
+ typography: "{typography.display-sm}"
183
+ rounded: "{rounded.card}"
184
+ padding: "{spacing.lg}"
185
+ hero-band-dark:
186
+ backgroundColor: "{colors.ink}"
187
+ textColor: "{colors.on-dark}"
188
+ typography: "{typography.display-hero}"
189
+ padding: "{spacing.3xl} {spacing.3xl}"
190
+ hero-band-red:
191
+ backgroundColor: "{colors.primary}"
192
+ textColor: "{colors.on-primary}"
193
+ typography: "{typography.display-xl}"
194
+ padding: "{spacing.3xl} {spacing.3xl}"
195
+ content-band-light:
196
+ backgroundColor: "{colors.canvas}"
197
+ textColor: "{colors.ink}"
198
+ typography: "{typography.display-md}"
199
+ padding: "{spacing.3xl} {spacing.3xl}"
200
+ speechmark-logo-orb:
201
+ backgroundColor: "{colors.primary}"
202
+ textColor: "{colors.on-primary}"
203
+ rounded: "{rounded.sm}"
204
+ divider-on-dark:
205
+ borderColor: "{colors.on-dark}"
206
+ footer:
207
+ backgroundColor: "{colors.ink}"
208
+ textColor: "{colors.on-dark}"
209
+ typography: "{typography.body-sm}"
210
+ padding: "{spacing.3xl} {spacing.3xl}"
211
+
212
+ # ─── Examples (illustrative) — auto-derived; resolve any TO_FILL markers below ───
213
+ ex-pricing-tier:
214
+ description: "Default tier card. Mirrors card-content chrome with canvas-soft surface and a hairline border."
215
+ backgroundColor: "{colors.canvas-soft}"
216
+ textColor: "{colors.ink}"
217
+ borderColor: "{colors.mute}"
218
+ rounded: "{rounded.card}"
219
+ padding: "{spacing.lg}"
220
+ ex-pricing-tier-featured:
221
+ description: "Featured tier — polarity-flipped to ink with white text and white pill CTA inside."
222
+ backgroundColor: "{colors.ink}"
223
+ textColor: "{colors.on-primary}"
224
+ rounded: "{rounded.card}"
225
+ padding: "{spacing.lg}"
226
+ ex-product-selector:
227
+ description: "Tariff-tier picker — repurposed as the brand's plan selector with badge-chip chips inside the frame."
228
+ backgroundColor: "{colors.canvas-soft}"
229
+ rounded: "{rounded.card}"
230
+ padding: "{spacing.lg}"
231
+ ex-cart-drawer:
232
+ description: "Subscription summary — line items per tariff add-on, light hairline dividers."
233
+ backgroundColor: "{colors.canvas}"
234
+ rounded: "{rounded.card}"
235
+ padding: "{spacing.lg}"
236
+ item-divider: "{colors.mute}"
237
+ ex-app-shell-row:
238
+ description: "Sidebar nav row. Active state uses brand primary as a left-edge indicator bar."
239
+ backgroundColor: "{colors.canvas}"
240
+ activeIndicator: "{colors.primary}"
241
+ rounded: "{rounded.sm}"
242
+ padding: "{spacing.md} {spacing.lg}"
243
+ ex-data-table-cell:
244
+ description: "Default data-table cell chrome. Header uses caption-uppercase mono-style eyebrow; body uses body-sm."
245
+ headerBackground: "{colors.canvas-soft}"
246
+ headerTypography: "{typography.caption-uppercase}"
247
+ bodyTypography: "{typography.body-sm}"
248
+ cellPadding: "{spacing.md} {spacing.lg}"
249
+ rowBorder: "{colors.mute}"
250
+ ex-auth-form-card:
251
+ description: "Sign-in / sign-up card. Mirrors card-content chrome with text-input primitives inside."
252
+ backgroundColor: "{colors.canvas-soft}"
253
+ rounded: "{rounded.card}"
254
+ padding: "{spacing.lg}"
255
+ ex-modal-card:
256
+ description: "Modal dialog surface — same chrome as card-content; brand uses scrim, not card shadow."
257
+ backgroundColor: "{colors.canvas}"
258
+ rounded: "{rounded.card}"
259
+ padding: "{spacing.lg}"
260
+ ex-empty-state-card:
261
+ description: "Empty-state illustration frame on canvas-soft with generous interior padding."
262
+ backgroundColor: "{colors.canvas-soft}"
263
+ rounded: "{rounded.card}"
264
+ padding: "{spacing.3xl}"
265
+ captionTypography: "{typography.body-md}"
266
+ ex-toast:
267
+ description: "Toast notification surface — card-content shape with caption-strong body."
268
+ backgroundColor: "{colors.canvas}"
269
+ rounded: "{rounded.sm}"
270
+ padding: "{spacing.md} {spacing.lg}"
271
+ typography: "{typography.body-sm}"
272
+
273
+ ---
274
+
275
+
276
+ ## Overview
277
+
278
+ Vodafone is a global telecom super-brand and its web surface delivers exactly that posture: heroic editorial photography, occasionally cropping a portrait so tight only an eye line and a phone hand are visible, with a single colossal uppercase headline floating on top in the brand's proprietary heavy display weight. The page reads like a campaign poster more than a corporate site, then breaks into a calmer content rhythm of light-canvas story cards and a single red marker (the iconic speechmark logo) drawing the eye to the brand's centre of gravity. There is no second accent colour competing — the entire decorative palette is `{colors.primary}` Vodafone red, near-black `{colors.ink}`, and the surrounding white and grayscale neutrals.
279
+
280
+ Type is the second decisive voice. Vodafone's custom display sans (extracted as `Vodafone`) carries every headline at impossibly heavy weight 800 in upper case for hero scale (`{typography.display-hero}` 144 px, `{typography.display-xxl}` 126 px) and at lighter weight 300 for the sub-displays that follow. Body text stays in the same family at weight 400 with neutral tracking. The contrast between display weight 800 and display weight 300 IS the brand's typographic story: a shout, then a calm sentence.
281
+
282
+ Every interactive CTA renders as a generously rounded pill (`{rounded.pill-lg}` 60 px) — Vodafone has never used a square button on its marketing surface in years, and the brand's pill scale ladder runs from 32 px (badge pills) through 60 px (CTA pills) up to 9999 px (icon circular containers). Cards stay gentler at `{rounded.card}` 6 px.
283
+
284
+ **Key Characteristics:**
285
+ - A single primary CTA color `{colors.primary}` (`#e60000`) — Vodafone Red. Pill-filled for primary, pill-outline for secondary. No third button variant.
286
+ - Massive uppercase display weight 800 (`{typography.display-hero}` and siblings) is the brand's signature. The 300-weight headline siblings (`{typography.display-lg}` / `{typography.display-md}`) handle calmer secondary moments.
287
+ - The `speechmark-logo-orb` — a red square hosting Vodafone's quotation-mark icon — is the only piece of decorative chrome that's not a CTA. It anchors the brand's centre of every page.
288
+ - Pill geometry on every interactive shape — `{rounded.pill-lg}` 60 px for buttons, `{rounded.pill-md}` 32 px for inline badges. Card chrome stays at `{rounded.card}` 6 px.
289
+ - A two-band page rhythm — `{colors.ink}` dark hero / `{colors.canvas}` light content. No mid-band greys; the brand uses surface contrast, not soft neutrals, for elevation.
290
+ - Editorial photography (real portraits, real cities, real cabling) is the only consistent decorative system — no illustration, no atmospheric gradients.
291
+
292
+ ## Colors
293
+
294
+ ### Brand & Accent
295
+ - **Vodafone Red** (`{colors.primary}` — `#e60000`): The single brand accent. Every primary CTA pill, every speechmark logo, every conversion target. The most iconic red in telecom — never desaturated, never used at scale for body fills (reserved for high-attention surfaces).
296
+
297
+ ### Surface
298
+ - **Canvas** (`{colors.canvas}` — `#ffffff`): The default light content background.
299
+ - **Canvas Soft** (`{colors.canvas-soft}` — `#f2f2f2`): A near-white tint used as the badge-chip background.
300
+ - **Ink** (`{colors.ink}` — `#25282b`): The brand's near-black surface — used as the dark hero band, the nav background, and the footer fill. Doubles as the primary text color on light surfaces.
301
+
302
+ ### Text
303
+ - **Ink** (`{colors.ink}` — `#25282b`): Every heading and body paragraph on light surfaces.
304
+ - **Body** (`{colors.body}` — `#7e7e7e`): Secondary body text on light surfaces — captions, metadata, supporting copy.
305
+ - **Mute** (`{colors.mute}` — `#bebebe`): The lowest-priority text color — placeholder text, low-key footer links.
306
+ - **On Dark** (`{colors.on-dark}` — `#ffffff`): All text on `{colors.ink}` surfaces (hero, footer, nav).
307
+
308
+ ### Semantic
309
+ The brand does not maintain a separate semantic palette. The primary red doubles as validation / destructive signal when needed; success / warning use are reserved for in-product contexts and are not part of the documented marketing system.
310
+
311
+ ## Typography
312
+
313
+ ### Font Family
314
+ A single custom face carries the entire system: **Vodafone**, the brand's proprietary display sans. The face spans weights 300 (light), 400 (regular), 600, 700, and 800 — every role in the system pulls from this one family. There is no mono companion; technical labels (rare on the marketing surface) borrow the same face at smaller sizes.
315
+
316
+ The icomoon icon-font is loaded for proprietary glyphs but does not render as a typographic role.
317
+
318
+ ### Hierarchy
319
+
320
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
321
+ |---|---|---|---|---|---|
322
+ | `{typography.display-hero}` | 144px | 800 | 114px | -1px | The hero stencil (`"STAY CONNECTED"`) — uppercase, ultra-tight tracking, brand's signature size. |
323
+ | `{typography.display-xxl}` | 126px | 800 | 113px | -1px | Slightly smaller hero variant. |
324
+ | `{typography.display-xl}` | 90px | 800 | 84px | 0 | Mid-hero scale. |
325
+ | `{typography.display-lg}` | 48px | 300 | 52px | 0 | Section-headline sub-display in the lighter weight. |
326
+ | `{typography.display-md}` | 40px | 300 | 44px | 0 | Sub-section displays. |
327
+ | `{typography.display-sm}` | 32px | 700 | 40px | 0 | Card headings, story-card titles. |
328
+ | `{typography.display-xs}` | 24px | 700 | 24px | 0 | Inline display micro-headings. |
329
+ | `{typography.eyebrow-uppercase}` | 16px | 800 | 24px | 0 | Uppercase eyebrow tags above section headlines. |
330
+ | `{typography.body-lg}` | 22px | 400 | 24px | 0 | Lead body paragraphs. |
331
+ | `{typography.body-md}` | 18px | 400 | 28px | 0 | Default paragraph body. |
332
+ | `{typography.body-md-strong}` | 18px | 600 | 28px | 0 | Bolded inline body. |
333
+ | `{typography.body-sm}` | 16px | 400 | 20px | 0 | Secondary body. |
334
+ | `{typography.body-sm-strong}` | 16px | 700 | 22px | 0 | Bolded short body. |
335
+ | `{typography.caption}` | 14px | 400 | 16px | 0 | Captions, fine print. |
336
+ | `{typography.caption-strong}` | 14px | 700 | 21px | 0 | Bold captions, badge labels. |
337
+ | `{typography.caption-uppercase}` | 12px | 600 | 16px | 0.57px | Uppercase metadata, footer eyebrows. |
338
+ | `{typography.button-md}` | 18px | 400 | 28px | 0 | Default button label. |
339
+
340
+ ### Principles
341
+ - **Weight 800 + uppercase = hero voice.** This is the entire reason the brand reads as a billboard rather than a tech site.
342
+ - **Weight 300 = the calmer secondary voice.** Used at 40 – 48 px for sub-displays; never below 24 px to keep legibility.
343
+ - **Single family throughout.** The brand never mixes a serif or a mono into the typographic system. Consistency is the calm.
344
+ - **Tracking stays tight at display sizes.** `-1px` at 144 px is the brand's calibration; reverting to neutral tracking softens the stencil look.
345
+
346
+ ### Note on Font Substitutes
347
+ The Vodafone display sans is proprietary. Open-source substitutes:
348
+ - **Display sans** — *Inter* weight 800 at hero scale with `letter-spacing: -1px` is the closest free match. *Geist* weight 700–800 is the second-best.
349
+ - **Lighter display weight (300)** — *Inter* weight 300 holds its line-height well at 48 px display sizes.
350
+
351
+ ## Layout
352
+
353
+ ### Spacing System
354
+ - **Base unit**: 4 px (mostly multiples of 4; a few 5/7 px appear inside icon-padding compensation).
355
+ - **Tokens**: `{spacing.xxs}` 2 px · `{spacing.xs}` 4 px · `{spacing.sm}` 8 px · `{spacing.md}` 12 px · `{spacing.lg}` 16 px · `{spacing.xl}` 20 px · `{spacing.2xl}` 24 px · `{spacing.3xl}` 32 px.
356
+ - **Section padding**: hero bands and content bands use `{spacing.3xl}` 32 px gutters; vertical spacing inside hero is fluid (fill-the-band).
357
+ - **Card interior padding**: story cards use `{spacing.lg}` 16 px around image + headline.
358
+ - **Inline gap**: button rows and chip rows use `{spacing.md}` 12 px between siblings.
359
+
360
+ ### Grid & Container
361
+ - Marketing content uses a wide container (effectively edge-to-edge with `{spacing.3xl}` gutters on desktop, shrinking on mobile).
362
+ - Story-card grids: 2-up at desktop, 1-up at mobile.
363
+ - Hero photography fills the viewport; the headline overlays at the top-left.
364
+
365
+ ### Whitespace Philosophy
366
+ The hero's massive display headline owns the whole top of the page; whitespace below is generous to let the second band breathe. Inside content cards, headline and copy hug close (`{spacing.sm}` 8 px gap), then a wider gap (`{spacing.3xl}`) before the next card. The footer band is dark and dense.
367
+
368
+ ### Responsive Strategy
369
+
370
+ #### Breakpoints
371
+
372
+ | Name | Width | Key Changes |
373
+ |---|---|---|
374
+ | Mobile | < 600px | Hero display scales down to ~64 px; story-card grid drops to 1-up; nav collapses to hamburger. |
375
+ | Tablet | 600–1023px | Story-card grid 2-up; display headlines drop to 90 – 110 px. |
376
+ | Desktop | 1024–1399px | Full display headline at 126 – 144 px; 2-up story grid. |
377
+ | Ultra-wide | ≥ 1400px | Container caps at ~1400 px; bands stay edge-to-edge in colour. |
378
+
379
+ #### Touch Targets
380
+ The `button-primary` pill renders at ~52 px tall (12 px vertical padding + 28 px line-height). All buttons comfortably meet WCAG AAA at every breakpoint.
381
+
382
+ #### Collapsing Strategy
383
+ - **Nav**: full link row at desktop. Collapses to a hamburger menu at mobile; the menu opens as a dark overlay with the same link list stacked.
384
+ - **Hero**: the massive display headline scales fluidly. At mobile, the photography crop tightens to the figure's face only.
385
+ - **Story-card grid**: 2-up → 1-up at the breakpoint above.
386
+ - **Speechmark logo orb**: stays at consistent size relative to surrounding content; never shrinks below ~48 px.
387
+
388
+ #### Image Behavior
389
+ - **Hero photography**: full-bleed 16:9 or 4:3 portraits at desktop; tighter crops at mobile.
390
+ - **Story-card thumbnails**: 16:9 landscape inside `{rounded.card}` 6 px chrome.
391
+ - **Speechmark orb**: always rendered as the red SVG quote-mark icon, never substituted.
392
+ - **Logo bar (if present on partner pages)**: monochrome SVGs at consistent height.
393
+
394
+ ## Elevation & Depth
395
+
396
+ | Level | Treatment | Use |
397
+ |---|---|---|
398
+ | Level 0 — Flat | No shadow, no border. | Default for most cards and panels — surface contrast does the elevation work. |
399
+ | Level 1 — Hairline | 1 px solid `{colors.ink}` border. | Form inputs, the `divider-on-dark` between footer columns. |
400
+ | Level 2 — Border on Dark | 1 px solid `{colors.on-dark}` border on `{colors.ink}` surfaces. | Outline buttons sitting on the dark hero band. |
401
+
402
+ The brand does not use soft drop shadows; depth comes from polarity-flip between `{colors.ink}` and `{colors.canvas}` bands.
403
+
404
+ ### Decorative Depth
405
+ - **Editorial photography**: the hero photo (real-person portrait or environment shot) is the brand's only true atmospheric effect.
406
+ - **Speechmark logo orb as visual anchor**: the red orb hosting the quote-mark icon acts as a single point of focal-depth in the centre of the otherwise-flat content rhythm.
407
+
408
+ ## Shapes
409
+
410
+ ### Border Radius Scale
411
+
412
+ | Token | Value | Use |
413
+ |---|---|---|
414
+ | `{rounded.none}` | 0px | Full-bleed hero bands, footer, banner strips. |
415
+ | `{rounded.xs}` | 1px | Tightest inline indicator (rarely used). |
416
+ | `{rounded.sm}` | 6px | The brand's canonical content radius — applied to images and inputs. |
417
+ | `{rounded.card}` | 6px | Card chrome and image frames (alias for `sm`). |
418
+ | `{rounded.pill-md}` | 32px | Badge / chip pills. |
419
+ | `{rounded.pill-lg}` | 60px | The brand's signature CTA pill — every primary and secondary button. |
420
+ | `{rounded.full}` | 9999px | Circular icon containers (e.g., video play/pause). |
421
+
422
+ ### Photography Geometry
423
+ - Hero portraits: edge-to-edge 16:9 or 4:3 with no internal frame.
424
+ - Story-card thumbnails: 16:9 landscape inside `{rounded.card}` chrome.
425
+ - Speechmark logo orb: square with `{rounded.sm}` corners (visually a tilted-square mark; the SVG mark itself fills the orb).
426
+
427
+ ## Components
428
+
429
+ ### Buttons
430
+
431
+ **`button-primary`** — the red pill CTA, brand's primary conversion target.
432
+ - Background `{colors.primary}`, text `{colors.on-primary}`, 1 px solid `{colors.primary}` border, label set in `{typography.button-md}`, padding `{spacing.md} {spacing.2xl}`, shape `{rounded.pill-lg}` 60 px.
433
+
434
+ **`button-outline-red`** — the secondary pill, red-text-on-white with red border.
435
+ - Background `{colors.canvas}`, text `{colors.primary}`, 1 px solid `{colors.primary}` border, same label / padding / shape as `button-primary`.
436
+
437
+ **`button-outline-dark`** — the tertiary pill, ink-text-on-white with ink border.
438
+ - Background `{colors.canvas}`, text `{colors.ink}`, 1 px solid `{colors.ink}` border, same label / padding / shape.
439
+
440
+ **`button-icon-circular`** — the round white icon button (video play / pause / chevron).
441
+ - Background `{colors.canvas}`, ink icon, 1 px solid `{colors.canvas}` outline (effectively borderless), shape `{rounded.full}`.
442
+
443
+ ### Cards & Containers
444
+
445
+ **`card-content`** — the default story-card chrome.
446
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.lg}`, shape `{rounded.card}` 6 px. Hosts a 16:9 thumbnail at the top + headline + caption.
447
+
448
+ **`card-hero`** — the slightly larger card variant used as the lead story.
449
+ - Same chrome as `card-content` but headline scales to `{typography.display-sm}`.
450
+
451
+ ### Inputs & Forms
452
+
453
+ **`text-input`** — the canonical text input.
454
+ - Background `{colors.canvas}`, text `{colors.ink}`, 1 px solid `{colors.ink}` border, body in `{typography.body-sm}`, padding `{spacing.md} {spacing.lg}`, shape `{rounded.sm}` 6 px.
455
+
456
+ ### Navigation
457
+
458
+ **`nav-bar`** — the dark top nav, fixed to the page top.
459
+ - Background `{colors.ink}`, text `{colors.on-dark}`, padding `{spacing.lg} {spacing.3xl}`. Layout: logo left, link row right with login / search affordances.
460
+
461
+ **`nav-link`** — the link items inside `nav-bar`.
462
+ - Text `{colors.on-dark}`, set in `{typography.body-sm}`.
463
+
464
+ **`footer`** — the dark footer band.
465
+ - Background `{colors.ink}`, text `{colors.on-dark}`, padding `{spacing.3xl} {spacing.3xl}`. Body in `{typography.body-sm}`; column eyebrows in `{typography.caption-uppercase}`.
466
+
467
+ ### Signature Components
468
+
469
+ **`hero-band-dark`** — the dark navy/ink hero band hosting the massive display headline.
470
+ - Background `{colors.ink}` with full-bleed editorial photography overlay at reduced opacity; text `{colors.on-dark}`; padding `{spacing.3xl} {spacing.3xl}`. Headline in `{typography.display-hero}` (uppercase, weight 800).
471
+
472
+ **`hero-band-red`** — the rare full-bleed red hero used on signature campaigns.
473
+ - Background `{colors.primary}`, text `{colors.on-primary}`, padding `{spacing.3xl} {spacing.3xl}`. Headline in `{typography.display-xl}`.
474
+
475
+ **`content-band-light`** — the white content band that follows every hero.
476
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.3xl} {spacing.3xl}`. Section headline in `{typography.display-md}` or `{typography.display-lg}` (weight 300).
477
+
478
+ **`speechmark-logo-orb`** — the red square hosting Vodafone's quotation-mark icon. The brand's visual anchor.
479
+ - Background `{colors.primary}`, white icon glyph, shape `{rounded.sm}`. Acts as a focal element between content bands, often near the centre of long pages.
480
+
481
+ **`badge-chip`** — the inline metadata pill used for category tags inside story cards.
482
+ - Background `{colors.canvas-soft}`, text `{colors.ink}`, label in `{typography.caption-strong}`, padding `{spacing.xs} {spacing.md}`, shape `{rounded.pill-md}` 32 px.
483
+
484
+ **`divider-on-dark`** — the 1 px hairline used between sections / columns on dark surfaces.
485
+ - 1 px solid `{colors.on-dark}` (often at 25 % opacity at the component level).
486
+
487
+ ### Examples (illustrative)
488
+
489
+ > 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.
490
+
491
+ **`ex-pricing-tier`** — Default Pricing tier card. Re-uses feature-card chrome with brand canvas-soft surface.
492
+ - Properties: `backgroundColor`, `textColor`, `borderColor`, `rounded`, `padding`
493
+
494
+ **`ex-pricing-tier-featured`** — Featured/highlighted tier — polarity-flipped surface (dark fill + light text in light mode, light fill + dark text in dark mode).
495
+ - Properties: `backgroundColor`, `textColor`, `rounded`, `padding`
496
+
497
+ **`ex-product-selector`** — What's Included summary card — re-purposed for SaaS / B2B verticals (NOT a literal product gallery).
498
+ - Properties: `backgroundColor`, `rounded`, `padding`
499
+
500
+ **`ex-cart-drawer`** — Subscription summary — re-purposed for SaaS / B2B (line items per add-on, not literal cart).
501
+ - Properties: `backgroundColor`, `rounded`, `padding`, `item-divider`
502
+
503
+ **`ex-app-shell-row`** — Sidebar nav row inside the App Shell example. Active state uses brand primary as the indicator.
504
+ - Properties: `backgroundColor`, `activeIndicator`, `rounded`, `padding`
505
+
506
+ **`ex-data-table-cell`** — Default data-table th + td chrome. Header uses mono-caps eyebrow typography; body uses body-sm.
507
+ - Properties: `headerBackground`, `headerTypography`, `bodyTypography`, `cellPadding`, `rowBorder`
508
+
509
+ **`ex-auth-form-card`** — Sign-in / sign-up card. Re-uses feature-card chrome with text-input primitives inside.
510
+ - Properties: `backgroundColor`, `rounded`, `padding`
511
+
512
+ **`ex-modal-card`** — Modal dialog surface — same chrome as feature-card with elevated shadow.
513
+ - Properties: `backgroundColor`, `rounded`, `padding`
514
+
515
+ **`ex-empty-state-card`** — Empty-state illustration frame.
516
+ - Properties: `backgroundColor`, `rounded`, `padding`, `captionTypography`
517
+
518
+ **`ex-toast`** — Toast notification surface — feature-card shape + medium shadow.
519
+ - Properties: `backgroundColor`, `rounded`, `padding`, `typography`
520
+
521
+
522
+ ## Do's and Don'ts
523
+
524
+ ### Do
525
+ - Reserve `{colors.primary}` Vodafone Red for primary CTAs and the `speechmark-logo-orb`. Every conversion target uses the red pill.
526
+ - Set hero headlines in `{typography.display-hero}` weight 800 UPPERCASE with tight `-1px` tracking. That stencil look IS the brand voice.
527
+ - Use `{rounded.pill-lg}` 60 px on every interactive pill. The brand never uses square corners on CTAs.
528
+ - Cycle page surfaces in `{colors.ink}` dark hero → `{colors.canvas}` light content → `{colors.ink}` footer. Surface contrast is the depth cue.
529
+ - Pair editorial portrait photography with the massive display headline overlay — that combination IS the brand's signature.
530
+ - Render the speechmark logo orb at consistent size relative to surrounding content — it's the brand's centre of gravity on every page.
531
+
532
+ ### Don't
533
+ - Don't introduce a second accent colour. The brand operates with red + ink + grayscale only.
534
+ - Don't render headlines in sentence case at hero scale. Hero display IS uppercase weight 800.
535
+ - Don't render the primary CTA as a square rectangle. The 60 px pill is non-negotiable.
536
+ - Don't drop a soft drop-shadow on cards. The brand relies on surface-colour contrast, not shadow.
537
+ - Don't substitute the speechmark logo orb with a wordmark or a different shape. The orb is the iconic mark.
538
+ - Don't pair the weight 800 display face with letter-spacing 0 at 144 px — the `-1px` tracking is part of the brand's calibration.
@@ -0,0 +1,5 @@
1
+ # Vodafone Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/vodafone/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.