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,531 @@
1
+ ---
2
+ version: alpha
3
+ name: Ferrari
4
+ description: A luxury-automotive brand whose marketing surfaces read as cinematic editorial. The base canvas is **near-black** (`#181818`) holding pure white display type; white-canvas bands appear only inside specific editorial contexts (preowned listings, pricing tables). The single brand voltage is **Rosso Corsa** (`#da291c`) — the iconic Ferrari racing red — used scarcely on primary CTAs, the Cavallino mark, and Formula 1 race-position highlights. Type runs **FerrariSans** at modest weights (display 500, body 400) — never bombastic. Spacing follows an explicit 8px token ladder (`xxxs` 4px through `super` 128px); generous editorial pacing throughout. The brand's strongest visual signature is the **full-bleed cinematic hero photograph** that fills the viewport top with car photography, model details, or trackside livery — followed by a tighter editorial body layout below.
5
+
6
+ colors:
7
+ primary: "#da291c"
8
+ primary-active: "#b01e0a"
9
+ primary-hover: "#9d2211"
10
+ ink: "#ffffff"
11
+ body: "#969696"
12
+ body-strong: "#ffffff"
13
+ body-on-light: "#181818"
14
+ muted: "#666666"
15
+ muted-soft: "#8f8f8f"
16
+ hairline: "#303030"
17
+ hairline-on-light: "#d2d2d2"
18
+ hairline-soft: "#ebebeb"
19
+ canvas: "#181818"
20
+ canvas-elevated: "#303030"
21
+ canvas-light: "#ffffff"
22
+ surface-card: "#303030"
23
+ surface-soft-light: "#f7f7f7"
24
+ surface-strong-light: "#ebebeb"
25
+ on-primary: "#ffffff"
26
+ on-dark: "#ffffff"
27
+ on-light: "#181818"
28
+ accent-yellow-hypersail: "#fff200"
29
+ accent-yellow: "#f6e500"
30
+ semantic-info: "#4c98b9"
31
+ semantic-success: "#03904a"
32
+ semantic-warning: "#f13a2c"
33
+
34
+ typography:
35
+ display-mega:
36
+ fontFamily: "'FerrariSans', -apple-system, system-ui, sans-serif"
37
+ fontSize: 80px
38
+ fontWeight: 500
39
+ lineHeight: 1.05
40
+ letterSpacing: -1.6px
41
+ display-xl:
42
+ fontFamily: "'FerrariSans', sans-serif"
43
+ fontSize: 56px
44
+ fontWeight: 500
45
+ lineHeight: 1.1
46
+ letterSpacing: -1.12px
47
+ display-lg:
48
+ fontFamily: "'FerrariSans', sans-serif"
49
+ fontSize: 36px
50
+ fontWeight: 500
51
+ lineHeight: 1.2
52
+ letterSpacing: -0.36px
53
+ display-md:
54
+ fontFamily: "'FerrariSans', sans-serif"
55
+ fontSize: 26px
56
+ fontWeight: 500
57
+ lineHeight: 1.5
58
+ letterSpacing: 0.195px
59
+ title-md:
60
+ fontFamily: "'FerrariSans', sans-serif"
61
+ fontSize: 18px
62
+ fontWeight: 700
63
+ lineHeight: 1.2
64
+ letterSpacing: 0
65
+ title-sm:
66
+ fontFamily: "'FerrariSans', sans-serif"
67
+ fontSize: 16px
68
+ fontWeight: 500
69
+ lineHeight: 1.4
70
+ letterSpacing: 0.08px
71
+ body-md:
72
+ fontFamily: "'FerrariSans', sans-serif"
73
+ fontSize: 14px
74
+ fontWeight: 400
75
+ lineHeight: 1.5
76
+ letterSpacing: 0
77
+ body-sm:
78
+ fontFamily: "'FerrariSans', sans-serif"
79
+ fontSize: 13px
80
+ fontWeight: 400
81
+ lineHeight: 1.5
82
+ letterSpacing: 0
83
+ caption:
84
+ fontFamily: "'FerrariSans', sans-serif"
85
+ fontSize: 12px
86
+ fontWeight: 400
87
+ lineHeight: 1.4
88
+ letterSpacing: 0
89
+ caption-uppercase:
90
+ fontFamily: "'FerrariSans', sans-serif"
91
+ fontSize: 11px
92
+ fontWeight: 600
93
+ lineHeight: 1.4
94
+ letterSpacing: 1.1px
95
+ textTransform: uppercase
96
+ button:
97
+ fontFamily: "'FerrariSans', sans-serif"
98
+ fontSize: 14px
99
+ fontWeight: 700
100
+ lineHeight: 1.0
101
+ letterSpacing: 1.4px
102
+ textTransform: uppercase
103
+ nav-link:
104
+ fontFamily: "'FerrariSans', sans-serif"
105
+ fontSize: 13px
106
+ fontWeight: 600
107
+ lineHeight: 1.4
108
+ letterSpacing: 0.65px
109
+ textTransform: uppercase
110
+ number-display:
111
+ fontFamily: "'FerrariSans', sans-serif"
112
+ fontSize: 80px
113
+ fontWeight: 700
114
+ lineHeight: 1.0
115
+ letterSpacing: -1.6px
116
+
117
+ rounded:
118
+ none: 0px
119
+ xs: 2px
120
+ sm: 4px
121
+ md: 6px
122
+ lg: 8px
123
+ xl: 12px
124
+ full: 9999px
125
+
126
+ spacing:
127
+ xxxs: 4px
128
+ xxs: 8px
129
+ xs: 16px
130
+ sm: 24px
131
+ md: 32px
132
+ lg: 48px
133
+ xl: 64px
134
+ xxl: 96px
135
+ super: 128px
136
+
137
+ components:
138
+ top-nav-on-dark:
139
+ backgroundColor: "{colors.canvas}"
140
+ textColor: "{colors.ink}"
141
+ typography: "{typography.nav-link}"
142
+ height: 64px
143
+ top-nav-on-light:
144
+ backgroundColor: "{colors.canvas-light}"
145
+ textColor: "{colors.body-on-light}"
146
+ typography: "{typography.nav-link}"
147
+ height: 64px
148
+ button-primary:
149
+ backgroundColor: "{colors.primary}"
150
+ textColor: "{colors.on-primary}"
151
+ typography: "{typography.button}"
152
+ rounded: "{rounded.none}"
153
+ padding: 14px 32px
154
+ height: 48px
155
+ button-primary-active:
156
+ backgroundColor: "{colors.primary-active}"
157
+ textColor: "{colors.on-primary}"
158
+ rounded: "{rounded.none}"
159
+ button-outline-on-dark:
160
+ backgroundColor: transparent
161
+ textColor: "{colors.ink}"
162
+ typography: "{typography.button}"
163
+ rounded: "{rounded.none}"
164
+ padding: 13px 31px
165
+ height: 48px
166
+ button-outline-on-light:
167
+ backgroundColor: transparent
168
+ textColor: "{colors.body-on-light}"
169
+ typography: "{typography.button}"
170
+ rounded: "{rounded.none}"
171
+ padding: 13px 31px
172
+ height: 48px
173
+ button-tertiary-text:
174
+ backgroundColor: transparent
175
+ textColor: "{colors.ink}"
176
+ typography: "{typography.button}"
177
+ hero-band-cinema:
178
+ backgroundColor: "{colors.canvas}"
179
+ textColor: "{colors.ink}"
180
+ typography: "{typography.display-mega}"
181
+ padding: 0
182
+ hero-band-light:
183
+ backgroundColor: "{colors.canvas-light}"
184
+ textColor: "{colors.body-on-light}"
185
+ typography: "{typography.display-xl}"
186
+ padding: 96px
187
+ feature-card-photo:
188
+ backgroundColor: "{colors.canvas}"
189
+ textColor: "{colors.ink}"
190
+ typography: "{typography.title-md}"
191
+ rounded: "{rounded.none}"
192
+ padding: 0
193
+ feature-card-light:
194
+ backgroundColor: "{colors.canvas-light}"
195
+ textColor: "{colors.body-on-light}"
196
+ typography: "{typography.title-md}"
197
+ rounded: "{rounded.none}"
198
+ padding: 32px
199
+ livery-band:
200
+ backgroundColor: "{colors.primary}"
201
+ textColor: "{colors.ink}"
202
+ typography: "{typography.display-lg}"
203
+ padding: 96px
204
+ preowned-listing-card:
205
+ backgroundColor: "{colors.canvas-light}"
206
+ textColor: "{colors.body-on-light}"
207
+ typography: "{typography.body-md}"
208
+ rounded: "{rounded.none}"
209
+ padding: 24px
210
+ spec-cell:
211
+ backgroundColor: transparent
212
+ textColor: "{colors.ink}"
213
+ typography: "{typography.number-display}"
214
+ padding: 24px 0
215
+ race-position-cell:
216
+ backgroundColor: transparent
217
+ textColor: "{colors.primary}"
218
+ typography: "{typography.number-display}"
219
+ race-calendar-row:
220
+ backgroundColor: transparent
221
+ textColor: "{colors.ink}"
222
+ typography: "{typography.body-md}"
223
+ padding: 16px 0
224
+ driver-card:
225
+ backgroundColor: "{colors.canvas-elevated}"
226
+ textColor: "{colors.ink}"
227
+ typography: "{typography.title-md}"
228
+ rounded: "{rounded.none}"
229
+ padding: 24px
230
+ text-input-on-dark:
231
+ backgroundColor: "{colors.canvas}"
232
+ textColor: "{colors.ink}"
233
+ typography: "{typography.body-md}"
234
+ rounded: "{rounded.sm}"
235
+ padding: 14px 16px
236
+ height: 48px
237
+ text-input-on-light:
238
+ backgroundColor: "{colors.canvas-light}"
239
+ textColor: "{colors.body-on-light}"
240
+ typography: "{typography.body-md}"
241
+ rounded: "{rounded.sm}"
242
+ padding: 14px 16px
243
+ height: 48px
244
+ badge-pill:
245
+ backgroundColor: "{colors.canvas-elevated}"
246
+ textColor: "{colors.ink}"
247
+ typography: "{typography.caption-uppercase}"
248
+ rounded: "{rounded.full}"
249
+ padding: 4px 12px
250
+ cta-band-dark:
251
+ backgroundColor: "{colors.canvas}"
252
+ textColor: "{colors.ink}"
253
+ typography: "{typography.display-lg}"
254
+ padding: 96px
255
+ newsletter-input-band:
256
+ backgroundColor: "{colors.canvas-elevated}"
257
+ textColor: "{colors.ink}"
258
+ typography: "{typography.body-md}"
259
+ rounded: "{rounded.sm}"
260
+ padding: 32px
261
+ footer-dark:
262
+ backgroundColor: "{colors.canvas}"
263
+ textColor: "{colors.body}"
264
+ typography: "{typography.body-sm}"
265
+ padding: 64px 48px
266
+ footer-link:
267
+ backgroundColor: transparent
268
+ textColor: "{colors.body}"
269
+ typography: "{typography.body-sm}"
270
+ ---
271
+
272
+ ## Overview
273
+
274
+ Ferrari's marketing site reads as cinematic editorial — closer to a luxury-magazine spread than a typical car-OEM site. The base canvas is **near-black** (`{colors.canvas}` — #181818) holding pure white display type; white-canvas bands appear only inside specific editorial contexts (preowned listings, pricing tables, dealer surfaces). The single brand voltage is **Rosso Corsa** (`{colors.primary}` — #da291c), the iconic Ferrari racing red, used scarcely on primary CTAs, the Cavallino mark, and Formula 1 race-position highlights.
275
+
276
+ Type runs **FerrariSans** as the single sans family at modest weights — display 500, body 400. CTA labels render in uppercase with generous tracking (1.1-1.4px). The brand never uses bold display copy.
277
+
278
+ The brand's strongest visual signature is the **full-bleed cinematic hero photograph** — top-of-page imagery shows car photography, model details, or trackside livery without any chrome competing with it. Headlines float over the bottom of the photo or sit in a tight band beneath. Spacing follows the explicit 8px token ladder: `xxxs` 4 / `xxs` 8 / `xs` 16 / `sm` 24 / `md` 32 / `lg` 48 / `xl` 64 / `xxl` 96 / `super` 128.
279
+
280
+ **Key Characteristics:**
281
+ - Single accent: `{colors.primary}` (Rosso Corsa #da291c) for primary CTAs, the Cavallino, F1 race-position highlights. Used scarcely.
282
+ - Near-black canvas (#181818) — never pure black. White-canvas bands only inside editorial contexts.
283
+ - Single sans family: FerrariSans across every text role.
284
+ - Display weight stays at 500 — never bold.
285
+ - CTA labels render uppercase with 1.4px tracking.
286
+ - Sharp `{rounded.none}` (0px) corners on every CTA, card, and band — luxury-automotive precision.
287
+ - Full-bleed cinematic hero photography is the page chrome.
288
+ - Explicit 8px spacing token ladder with named scale (xxxs through super).
289
+ - Hairlines + photographic depth — no drop shadow tiers.
290
+
291
+ ## Colors
292
+
293
+ ### Brand & Accent
294
+ - **Rosso Corsa** (`{colors.primary}` — #da291c): The iconic Ferrari racing red. Primary CTA fill, Cavallino mark, F1 driver-position highlights. Used scarcely.
295
+ - **Rosso Corsa Active** (`{colors.primary-active}` — #b01e0a): Press state.
296
+ - **Rosso Corsa Hover-darker** (`{colors.primary-hover}` — #9d2211): Documented for completeness; per the no-hover policy this is not used in preview HTML.
297
+ - **Hypersail Yellow** (`{colors.accent-yellow-hypersail}` — #fff200) + **Yellow** (`{colors.accent-yellow}` — #f6e500): Sub-brand accents reserved for the Hypersail sailing program and the global focus-ring color. Not part of the main automotive palette.
298
+
299
+ ### Surface
300
+ - **Canvas** (`{colors.canvas}` — #181818): Near-black page floor — never pure black, slight warmth.
301
+ - **Canvas Elevated** (`{colors.canvas-elevated}` — #303030): Cards and panels on dark canvas.
302
+ - **Canvas Light** (`{colors.canvas-light}` — #ffffff): White editorial bands (preowned listings, pricing).
303
+ - **Surface Card** (`{colors.surface-card}` — #303030): Same as canvas-elevated — driver cards, livery photo plates.
304
+ - **Surface Soft Light** (`{colors.surface-soft-light}` — #f7f7f7): Light editorial alternating band.
305
+ - **Surface Strong Light** (`{colors.surface-strong-light}` — #ebebeb): Light-canvas dividers, badges.
306
+
307
+ ### Hairlines
308
+ - **Hairline** (`{colors.hairline}` — #303030): 1px divider on dark — same hex as `{colors.canvas-elevated}`.
309
+ - **Hairline On Light** (`{colors.hairline-on-light}` — #d2d2d2): 1px divider on light bands.
310
+ - **Hairline Soft** (`{colors.hairline-soft}` — #ebebeb): Lighter divider.
311
+
312
+ ### Text
313
+ - **Ink** (`{colors.ink}` — #ffffff): Display, body emphasis on dark.
314
+ - **Body** (`{colors.body}` — #969696): Default running-text on dark.
315
+ - **Body Strong** (`{colors.body-strong}` — #ffffff): Same as ink.
316
+ - **Body On Light** (`{colors.body-on-light}` — #181818): Default text on light bands.
317
+ - **Muted** (`{colors.muted}` — #666666): Sub-titles, captions on dark.
318
+ - **Muted Soft** (`{colors.muted-soft}` — #8f8f8f): Disabled link text.
319
+ - **On Primary** (`{colors.on-primary}` — #ffffff): White text on Rosso Corsa.
320
+
321
+ ### Semantic
322
+ - **Info** (`{colors.semantic-info}` — #4c98b9): Info badges, callout backgrounds.
323
+ - **Success** (`{colors.semantic-success}` — #03904a): Confirmation.
324
+ - **Warning** (`{colors.semantic-warning}` — #f13a2c): Validation warnings.
325
+
326
+ ## Typography
327
+
328
+ ### Font Family
329
+ **FerrariSans** is the licensed single sans family across every text role. Fallback: `-apple-system, system-ui, sans-serif`. No display/body family split.
330
+
331
+ ### Hierarchy
332
+
333
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
334
+ |---|---|---|---|---|---|
335
+ | `{typography.display-mega}` | 80px | 500 | 1.05 | -1.6px | Homepage hero h1 |
336
+ | `{typography.display-xl}` | 56px | 500 | 1.1 | -1.12px | Subsidiary heroes |
337
+ | `{typography.display-lg}` | 36px | 500 | 1.2 | -0.36px | Section heads, livery band |
338
+ | `{typography.display-md}` | 26px | 500 | 1.5 | 0.195px | Sub-section heads |
339
+ | `{typography.title-md}` | 18px | 700 | 1.2 | 0 | Component titles |
340
+ | `{typography.title-sm}` | 16px | 500 | 1.4 | 0.08px | List labels |
341
+ | `{typography.body-md}` | 14px | 400 | 1.5 | 0 | Default body |
342
+ | `{typography.body-sm}` | 13px | 400 | 1.5 | 0 | Footer body |
343
+ | `{typography.caption}` | 12px | 400 | 1.4 | 0 | Photo captions |
344
+ | `{typography.caption-uppercase}` | 11px | 600 | 1.4 | 1.1px | Section labels, badges |
345
+ | `{typography.button}` | 14px | 700 | 1.0 | 1.4px (uppercase) | CTA pill labels |
346
+ | `{typography.nav-link}` | 13px | 600 | 1.4 | 0.65px (uppercase) | Top-nav menu items |
347
+ | `{typography.number-display}` | 80px | 700 | 1.0 | -1.6px | Race position highlights, spec values |
348
+
349
+ ### Principles
350
+ - **Display weight stays at 500.** Editorial confidence, not bombastic. The cinematic photography is doing the visual heavy-lifting — type doesn't need to compete.
351
+ - **CTA labels are uppercase with 1.4px tracking.** Luxury-precision feel.
352
+ - **Nav labels are uppercase with 0.65px tracking.** Consistent with CTA voice.
353
+ - **Negative letter-spacing on display only.** -0.36px to -1.6px on display sizes; body stays at 0.
354
+
355
+ ### Note on Font Substitutes
356
+ FerrariSans is licensed. Open-source substitute: **Inter** at weight 500 with letter-spacing -1%, or **Söhne** for closer humanist proportions.
357
+
358
+ ## Layout
359
+
360
+ ### Spacing System
361
+ - **Base unit:** 4px.
362
+ - **Tokens:** `{spacing.xxxs}` 4px · `{spacing.xxs}` 8px · `{spacing.xs}` 16px · `{spacing.sm}` 24px · `{spacing.md}` 32px · `{spacing.lg}` 48px · `{spacing.xl}` 64px · `{spacing.xxl}` 96px · `{spacing.super}` 128px.
363
+ - **Section padding:** `{spacing.xxl}` (96px) for major bands; `{spacing.super}` (128px) reserved for hero band depth.
364
+
365
+ ### Grid & Container
366
+ - Max content width: ~1280px on editorial bands. Hero photography goes full-bleed.
367
+ - Editorial body: 12-column grid.
368
+ - Feature card grids: 2-up at desktop for hero splits, 3-up for benefit grids, 4-up for preowned listing tiles.
369
+ - Footer: 5-column at desktop.
370
+
371
+ ### Whitespace Philosophy
372
+ Generous editorial pacing. Cinematic hero photography occupies generous viewport real-estate; body sections sit in tighter editorial layouts beneath. The canvas-light editorial bands (preowned, pricing) carry tighter density than the dark cinema bands.
373
+
374
+ ## Elevation & Depth
375
+
376
+ The system uses **photographic depth + brightness-step** elevation. No drop shadows except a single soft-small `{shadow.small}` documented in extracted tokens.
377
+
378
+ | Level | Treatment | Use |
379
+ |---|---|---|
380
+ | Flat (canvas) | `{colors.canvas}` (#181818) | Body bands, footer |
381
+ | Card | `{colors.canvas-elevated}` (#303030) | Driver cards, livery plates |
382
+ | Light band | `{colors.canvas-light}` (#ffffff) | Preowned listings, pricing |
383
+ | Hairline border | 1px `{colors.hairline}` or `{colors.hairline-on-light}` | Card outlines, dividers |
384
+ | Soft drop | `0 4px 8px rgba(0,0,0,0.1)` | Hovered cards (single shadow tier) |
385
+ | Photographic | Full-bleed cinema imagery | Hero band, livery photographs |
386
+
387
+ ### Decorative Depth
388
+ - **Full-bleed cinema photography** is the brand's primary depth treatment.
389
+ - **Brand red gradient** (`linear-gradient(180deg, #a00c01, #da291c 64%)`): The Rosso Corsa gradient used inside accent bands and CTA hover states.
390
+ - **Dark grey gradient** (`linear-gradient(180deg, #3c3c3c, #030303 64%)`): Atmospheric darken used at section transitions.
391
+
392
+ ## Shapes
393
+
394
+ ### Border Radius Scale
395
+
396
+ | Token | Value | Use |
397
+ |---|---|---|
398
+ | `{rounded.none}` | 0px | Every CTA, card, band — dominant radius |
399
+ | `{rounded.xs}` | 2px | Tight badges (rare) |
400
+ | `{rounded.sm}` | 4px | Form inputs |
401
+ | `{rounded.md}` | 6px | Compact cards (rare) |
402
+ | `{rounded.lg}` | 8px | Mobile-only collapse cards |
403
+ | `{rounded.xl}` | 12px | Modal/dialog corners (rare) |
404
+ | `{rounded.full}` | 9999px | Avatar plates, badge pills |
405
+
406
+ The radius vocabulary is **sharp by default**. Sharp 0px corners are the brand button shape — never rounded pills. Pill geometry is reserved for badge labels only.
407
+
408
+ ## Components
409
+
410
+ ### Top Navigation
411
+
412
+ **`top-nav-on-dark`** — Default top nav on dark hero pages. Background `{colors.canvas}`, text `{colors.ink}`, height 64px. Layout: Cavallino mark left, primary horizontal menu (Models / F1 / Lifestyle / Owners / Preowned), language picker + utilities right. Menu items render uppercase with 0.65px tracking.
413
+
414
+ **`top-nav-on-light`** — White-canvas variant for editorial light bands.
415
+
416
+ ### Buttons
417
+
418
+ **`button-primary`** — The signature Rosso Corsa CTA. Background `{colors.primary}`, text `{colors.on-primary}`, type `{typography.button}` (14px / 700 / 1.4px tracking, uppercase), padding 14px × 32px, height 48px, **rounded `{rounded.none}` (0px — sharp corners)**.
419
+
420
+ **`button-primary-active`** — Press state. Background `{colors.primary-active}`.
421
+
422
+ **`button-outline-on-dark`** — Transparent with 1px white border. Background transparent, text `{colors.ink}`, 1px white border, same sharp 0px corners.
423
+
424
+ **`button-outline-on-light`** — Transparent with 1px ink border on light bands.
425
+
426
+ **`button-tertiary-text`** — Inline text link, uppercase tracking.
427
+
428
+ ### Hero Bands
429
+
430
+ **`hero-band-cinema`** — Full-bleed cinematic photograph. Background `{colors.canvas}` underneath, but the photo fills the viewport. Display headline floats over the bottom of the photo or sits in a tight band beneath, in `{typography.display-mega}` (80px / 500 / -1.6px). One primary CTA + one outline CTA. Zero padding — the photo fills edge-to-edge.
431
+
432
+ **`hero-band-light`** — White-canvas variant for editorial bands. Background `{colors.canvas-light}`, text `{colors.body-on-light}`, padding 96px.
433
+
434
+ ### Cards
435
+
436
+ **`feature-card-photo`** — Image-first card. Background `{colors.canvas}`, text `{colors.ink}`, rounded `{rounded.none}`. Image fills the top edge-to-edge; title + body sit beneath in tight typography.
437
+
438
+ **`feature-card-light`** — White-canvas variant. Background `{colors.canvas-light}`, text `{colors.body-on-light}`, rounded `{rounded.none}`, padding 32px.
439
+
440
+ **`driver-card`** — F1 driver portrait card. Background `{colors.canvas-elevated}`, text `{colors.ink}`, rounded `{rounded.none}`, padding 24px. Layout: driver portrait + name + race number + team badge.
441
+
442
+ ### Editorial Surfaces
443
+
444
+ **`livery-band`** — A full-width Rosso Corsa accent band. Background `{colors.primary}`, text `{colors.ink}`, type `{typography.display-lg}`, 96px padding. Used as a standout livery callout between dark editorial bands.
445
+
446
+ **`preowned-listing-card`** — Used in the preowned Ferrari listing grid. Background `{colors.canvas-light}`, text `{colors.body-on-light}`, rounded `{rounded.none}`, padding 24px. Layout: car photo top + model name + year/mileage + price.
447
+
448
+ ### Spec & Race Surfaces
449
+
450
+ **`spec-cell`** — Technical spec callout. Transparent background, value in `{typography.number-display}` (80px / 700 / -1.6px white), label below in `{typography.caption-uppercase}`.
451
+
452
+ **`race-position-cell`** — F1 driver finishing position. Same number-display geometry but text in `{colors.primary}` Rosso Corsa for the brand's racing identity.
453
+
454
+ **`race-calendar-row`** — Hairline-divided row in the F1 race calendar. Layout: date column left, race name + circuit middle, results column right.
455
+
456
+ ### Forms & Tags
457
+
458
+ **`text-input-on-dark`** — Background `{colors.canvas}`, text `{colors.ink}`, rounded `{rounded.sm}` (4px), padding 14px × 16px, height 48px, 1px `{colors.hairline}` border.
459
+
460
+ **`text-input-on-light`** — White-canvas variant.
461
+
462
+ **`badge-pill`** — Small uppercase pill. Background `{colors.canvas-elevated}`, text `{colors.ink}`, type `{typography.caption-uppercase}` (11px / 600 / 1.1px tracking, uppercase), rounded `{rounded.full}` (9999px), padding 4px × 12px. The only place pill geometry is used.
463
+
464
+ ### Newsletter / CTA / Footer
465
+
466
+ **`newsletter-input-band`** — Newsletter signup band. Background `{colors.canvas-elevated}`, padding 32px, rounded `{rounded.sm}`. Holds an inline email input + primary CTA.
467
+
468
+ **`cta-band-dark`** — Pre-footer band. Background `{colors.canvas}`, centered display headline in `{typography.display-lg}`, single Rosso Corsa CTA. 96px padding.
469
+
470
+ **`footer-dark`** — Closing dark footer. Background `{colors.canvas}`, text `{colors.body}`. 5-column link list. 64×48px padding.
471
+
472
+ **`footer-link`** — Background transparent, text `{colors.body}`, type `{typography.body-sm}`.
473
+
474
+ ## Do's and Don'ts
475
+
476
+ ### Do
477
+ - Reserve `{colors.primary}` (Rosso Corsa) for primary CTAs, the Cavallino mark, and F1 race-position highlights.
478
+ - Set every CTA at `{rounded.none}` (0px sharp corners) — the brand's signature precision.
479
+ - Render CTA labels in uppercase with 1.4px tracking via `{typography.button}`.
480
+ - Pair every hero with a full-bleed cinematic photograph — the photograph IS the depth.
481
+ - Use the explicit 8px spacing ladder (`xxxs` through `super`) rather than ad-hoc px values.
482
+ - Keep display weight at 500 — never bold.
483
+
484
+ ### Don't
485
+ - Don't introduce a saturated brand color other than Rosso Corsa.
486
+ - Don't use rounded or pill CTAs — sharp 0px corners are the brand button.
487
+ - Don't bold display copy. The cinematic photography does the visual heavy-lifting.
488
+ - Don't use Hypersail yellow outside the Hypersail sailing program context.
489
+ - Don't use pure black canvas. The brand canvas is `{colors.canvas}` (#181818) — slightly warm.
490
+ - Don't add drop shadow tiers. Photography + brightness-step elevation carry the depth.
491
+ - 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, not on injected modals.
492
+
493
+ ## Responsive Behavior
494
+
495
+ ### Breakpoints
496
+
497
+ | Name | Width | Key Changes |
498
+ |---|---|---|
499
+ | Mobile | < 640px | Hero photograph crops vertically; hero h1 80→32px; feature card grid 1-up; nav hamburger; preowned listing 1-up. |
500
+ | Tablet | 640–1024px | Hero h1 56px; feature card grid 2-up; preowned listing 2-up. |
501
+ | Desktop | 1024–1280px | Full hero h1 80px; feature card grid 3-up; preowned listing 4-up. |
502
+ | Wide | > 1280px | Editorial body content caps at 1280px; hero photography continues full-bleed. |
503
+
504
+ ### Touch Targets
505
+ - Primary CTA at 48px height — at WCAG AAA (44 × 44).
506
+ - Nav items render uppercase with 0.65px tracking, padded for an effective 48px tap area.
507
+
508
+ ### Collapsing Strategy
509
+ - Top nav switches to hamburger below 768px.
510
+ - Hero photograph reframes per breakpoint via art direction — desktop carries wide cinematic; mobile crops tighter or shifts to vertical.
511
+ - Feature card grid: 4-up → 3-up → 2-up → 1-up.
512
+ - F1 driver cards: 2-up at desktop, 1-up at mobile.
513
+
514
+ ## Iteration Guide
515
+
516
+ 1. Focus on a single component at a time.
517
+ 2. CTAs default to `{rounded.none}` (0px sharp). Cards use `{rounded.none}` too. Pill is reserved for badges.
518
+ 3. Variants live as separate entries inside `components:`.
519
+ 4. Use `{token.refs}` everywhere — never inline hex.
520
+ 5. Hover state never documented.
521
+ 6. FerrariSans 500 for display, 400/700 for body. Uppercase + tracking on CTAs and nav.
522
+ 7. Rosso Corsa stays scarce — primary CTAs, Cavallino, race-position highlights only.
523
+ 8. Use the explicit 8px named spacing ladder.
524
+
525
+ ## Known Gaps
526
+
527
+ - FerrariSans is a licensed typeface; Inter at weight 500 is the documented substitute.
528
+ - Animation timings (hero parallax, livery band entrance, race position counter) out of scope.
529
+ - In-product surfaces (preowned configurator, F1 telemetry overlays) only partially captured via marketing surfaces.
530
+ - Form validation states beyond focus not visible on captured surfaces.
531
+ - Hypersail yellow tokens are extracted but only appear in the Hypersail sailing program context — documented as scoped accents.
@@ -0,0 +1,5 @@
1
+ # Ferrari Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/ferrari/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.