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,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.
|