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
+ # Raycast Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/raycast/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.
@@ -0,0 +1,589 @@
1
+ ---
2
+ version: alpha
3
+ name: Renault
4
+ description: |
5
+ Renault's web presence pairs the freshly-modernised Renault diamond
6
+ (the 2021 flat-line rhombus mark) with a stark black-and-white canvas, a
7
+ signature Sunlight Yellow accent, and the proprietary NouvelR display
8
+ typeface. The system reads as confident, photography-first automotive — large
9
+ hero cars on neutral or atmospheric backdrops, square-edged or barely-rounded
10
+ containers, and a small disciplined palette where every coloured element is
11
+ intentional. Tile grids, full-bleed banners, and a recurring "configurator"
12
+ surface (white card, yellow accent dots, neutral product chrome) carry the
13
+ mass-market dealership tone without crossing into luxury.
14
+
15
+ colors:
16
+ primary: "#ffed00"
17
+ primary-deep: "#e6d200"
18
+ on-primary: "#000000"
19
+ ink: "#000000"
20
+ body: "#222222"
21
+ charcoal: "#333333"
22
+ mute: "#666666"
23
+ ash: "#8a8a8a"
24
+ stone: "#c4c4c4"
25
+ on-dark: "#ffffff"
26
+ on-dark-mute: "rgba(255,255,255,0.72)"
27
+ canvas: "#ffffff"
28
+ surface-soft: "#f7f7f7"
29
+ surface-card: "#ffffff"
30
+ surface-dark: "#000000"
31
+ surface-deep: "#111111"
32
+ hairline: "#f2f2f2"
33
+ hairline-strong: "#000000"
34
+ divider-dark: "rgba(255,255,255,0.16)"
35
+ badge-new: "#ffed00"
36
+ link: "#0000ee"
37
+ error: "#be6464"
38
+ warning: "#f0ad4e"
39
+ success: "#8dc572"
40
+ info: "#337ab7"
41
+
42
+ typography:
43
+ display-xl:
44
+ fontFamily: NouvelR
45
+ fontSize: 56px
46
+ fontWeight: 700
47
+ lineHeight: 0.95
48
+ letterSpacing: 0
49
+ display-lg:
50
+ fontFamily: NouvelR
51
+ fontSize: 40px
52
+ fontWeight: 700
53
+ lineHeight: 0.95
54
+ letterSpacing: 0
55
+ display-md:
56
+ fontFamily: NouvelR
57
+ fontSize: 32px
58
+ fontWeight: 700
59
+ lineHeight: 0.95
60
+ letterSpacing: 0
61
+ heading-lg:
62
+ fontFamily: NouvelR
63
+ fontSize: 24px
64
+ fontWeight: 700
65
+ lineHeight: 0.95
66
+ letterSpacing: 0
67
+ heading-md:
68
+ fontFamily: NouvelR
69
+ fontSize: 20px
70
+ fontWeight: 700
71
+ lineHeight: 0.95
72
+ letterSpacing: 0
73
+ heading-sm:
74
+ fontFamily: NouvelR
75
+ fontSize: 18px
76
+ fontWeight: 700
77
+ lineHeight: 1.0
78
+ letterSpacing: 0
79
+ subtitle:
80
+ fontFamily: NouvelR
81
+ fontSize: 19.2px
82
+ fontWeight: 600
83
+ lineHeight: 1.3
84
+ letterSpacing: 0
85
+ body-lg:
86
+ fontFamily: NouvelR
87
+ fontSize: 18px
88
+ fontWeight: 400
89
+ lineHeight: 1.5
90
+ letterSpacing: 0
91
+ body-md:
92
+ fontFamily: NouvelR
93
+ fontSize: 16px
94
+ fontWeight: 400
95
+ lineHeight: 1.4
96
+ letterSpacing: 0
97
+ body-sm:
98
+ fontFamily: NouvelR
99
+ fontSize: 14px
100
+ fontWeight: 400
101
+ lineHeight: 1.57
102
+ letterSpacing: 0
103
+ button-lg:
104
+ fontFamily: NouvelR
105
+ fontSize: 16px
106
+ fontWeight: 700
107
+ lineHeight: 1.0
108
+ letterSpacing: 0
109
+ button-md:
110
+ fontFamily: NouvelR
111
+ fontSize: 14.4px
112
+ fontWeight: 700
113
+ lineHeight: 1.0
114
+ letterSpacing: 0.144px
115
+ button-sm:
116
+ fontFamily: NouvelR
117
+ fontSize: 13px
118
+ fontWeight: 600
119
+ lineHeight: 1.2
120
+ letterSpacing: 0.13px
121
+ caption:
122
+ fontFamily: NouvelR
123
+ fontSize: 12px
124
+ fontWeight: 400
125
+ lineHeight: 1.4
126
+ letterSpacing: 0
127
+ overline:
128
+ fontFamily: NouvelR
129
+ fontSize: 10px
130
+ fontWeight: 700
131
+ lineHeight: 1.45
132
+ letterSpacing: 0
133
+
134
+ rounded:
135
+ none: 0px
136
+ xs: 2px
137
+ sm: 3px
138
+ md: 4px
139
+ pill: 46px
140
+ full: 9999px
141
+
142
+ spacing:
143
+ xxs: 4px
144
+ xs: 8px
145
+ sm: 12px
146
+ md: 16px
147
+ lg: 20px
148
+ xl: 24px
149
+ xxl: 32px
150
+ xxxl: 40px
151
+ section: 80px
152
+
153
+ components:
154
+ button-primary:
155
+ backgroundColor: "{colors.primary}"
156
+ textColor: "{colors.on-primary}"
157
+ typography: "{typography.button-md}"
158
+ rounded: "{rounded.xs}"
159
+ padding: 14px 24px
160
+ height: 48px
161
+ button-primary-pressed:
162
+ backgroundColor: "{colors.primary-deep}"
163
+ textColor: "{colors.on-primary}"
164
+ typography: "{typography.button-md}"
165
+ rounded: "{rounded.xs}"
166
+ button-secondary-dark:
167
+ backgroundColor: "{colors.surface-dark}"
168
+ textColor: "{colors.on-dark}"
169
+ typography: "{typography.button-md}"
170
+ rounded: "{rounded.xs}"
171
+ padding: 14px 24px
172
+ button-outline-dark:
173
+ backgroundColor: "{colors.canvas}"
174
+ textColor: "{colors.ink}"
175
+ typography: "{typography.button-md}"
176
+ rounded: "{rounded.xs}"
177
+ padding: 13px 23px
178
+ button-outline-light:
179
+ backgroundColor: "{colors.surface-dark}"
180
+ textColor: "{colors.on-dark}"
181
+ typography: "{typography.button-md}"
182
+ rounded: "{rounded.xs}"
183
+ padding: 13px 23px
184
+ button-pill:
185
+ backgroundColor: "{colors.canvas}"
186
+ textColor: "{colors.ink}"
187
+ typography: "{typography.button-sm}"
188
+ rounded: "{rounded.pill}"
189
+ padding: 8px 16px
190
+ height: 36px
191
+ button-icon-square:
192
+ backgroundColor: "{colors.canvas}"
193
+ textColor: "{colors.ink}"
194
+ rounded: "{rounded.xs}"
195
+ size: 40px
196
+ text-input:
197
+ backgroundColor: "{colors.canvas}"
198
+ textColor: "{colors.ink}"
199
+ typography: "{typography.body-md}"
200
+ rounded: "{rounded.none}"
201
+ padding: 12px 16px
202
+ height: 48px
203
+ hero-banner:
204
+ backgroundColor: "{colors.surface-dark}"
205
+ textColor: "{colors.on-dark}"
206
+ rounded: "{rounded.none}"
207
+ padding: 0
208
+ promo-tile-light:
209
+ backgroundColor: "{colors.canvas}"
210
+ textColor: "{colors.ink}"
211
+ typography: "{typography.heading-lg}"
212
+ rounded: "{rounded.none}"
213
+ padding: 32px
214
+ promo-tile-dark:
215
+ backgroundColor: "{colors.surface-dark}"
216
+ textColor: "{colors.on-dark}"
217
+ typography: "{typography.heading-lg}"
218
+ rounded: "{rounded.none}"
219
+ padding: 32px
220
+ promo-tile-yellow:
221
+ backgroundColor: "{colors.primary}"
222
+ textColor: "{colors.on-primary}"
223
+ typography: "{typography.heading-lg}"
224
+ rounded: "{rounded.none}"
225
+ padding: 32px
226
+ vehicle-card:
227
+ backgroundColor: "{colors.canvas}"
228
+ textColor: "{colors.ink}"
229
+ rounded: "{rounded.none}"
230
+ padding: 0
231
+ configurator-row:
232
+ backgroundColor: "{colors.canvas}"
233
+ textColor: "{colors.ink}"
234
+ typography: "{typography.body-md}"
235
+ rounded: "{rounded.none}"
236
+ padding: 24px 0
237
+ configurator-swatch:
238
+ backgroundColor: "{colors.surface-soft}"
239
+ rounded: "{rounded.full}"
240
+ size: 56px
241
+ badge-new:
242
+ backgroundColor: "{colors.badge-new}"
243
+ textColor: "{colors.on-primary}"
244
+ typography: "{typography.button-md}"
245
+ rounded: "{rounded.full}"
246
+ padding: 6px 14px
247
+ nav-bar:
248
+ backgroundColor: "{colors.canvas}"
249
+ textColor: "{colors.ink}"
250
+ typography: "{typography.button-md}"
251
+ rounded: "{rounded.none}"
252
+ height: 60px
253
+ sub-nav-pill:
254
+ backgroundColor: "{colors.canvas}"
255
+ textColor: "{colors.ink}"
256
+ typography: "{typography.button-sm}"
257
+ rounded: "{rounded.pill}"
258
+ padding: 8px 16px
259
+ footer:
260
+ backgroundColor: "{colors.surface-dark}"
261
+ textColor: "{colors.on-dark}"
262
+ typography: "{typography.body-sm}"
263
+ rounded: "{rounded.none}"
264
+ padding: 64px 24px
265
+ ---
266
+
267
+ ## Overview
268
+
269
+ Renault's Turkish marketing surfaces are unapologetically high-contrast: a
270
+ white canvas for browsing, a black canvas for product storytelling, and a
271
+ single Sunlight Yellow accent (`{colors.primary}` — `#ffed00`) reserved for
272
+ the most consequential actions. The brand's modernised flat diamond logo sets
273
+ the tone — geometric, confident, slightly industrial — and the system follows
274
+ suit. Square corners dominate, hairline borders are rare, and elevation is
275
+ expressed through colour blocking rather than shadow.
276
+
277
+ The typography is monolithic. Every text on the site is set in **NouvelR**,
278
+ Renault's bespoke display family, with a strong preference for weight 700 at
279
+ display sizes (with a tight `lineHeight: 0.95`) and weight 400 for body. There
280
+ is no secondary serif, no decorative italic, no script — the discipline is
281
+ the signature.
282
+
283
+ Page rhythm cycles between three surface modes: a **white catalogue mode** for
284
+ listings and configurators (`{colors.canvas}` with hairline-thin
285
+ `{colors.hairline}` dividers), a **black storytelling mode** for hero
286
+ sections, lifestyle imagery, and the lower half of campaign pages, and brief
287
+ **yellow accent moments** (`{colors.primary}` tiles, "NEW" badges, R5-coded
288
+ yellow paint shots) that punctuate the otherwise neutral palette.
289
+
290
+ **Key Characteristics:**
291
+ - Two-tone canvas system — `{colors.canvas}` (white) for browsing, `{colors.surface-dark}` (black) for storytelling — switched in full-bleed bands rather than subtle gradations.
292
+ - A single brand accent — `{colors.primary}` Sunlight Yellow — used scarcely on primary CTAs, "NEW" badges, R5 hero photography, and configurator dot indicators.
293
+ - **NouvelR everywhere**, with `{typography.display-xl}` headlines at 56px / weight 700 / `lineHeight: 0.95` so condensed multi-line headlines stack cleanly.
294
+ - Square geometry: `{rounded.xs}` (2px) on buttons, `{rounded.none}` on tiles and product cards, `{rounded.pill}` reserved exclusively for sub-nav chips and decorative badges.
295
+ - Photography-first product tiles — vehicle photos full-bleed inside otherwise neutral cards, with copy stacked beneath rather than overlaid.
296
+ - Page-level rhythm cycles white → black → yellow accent → black, with the wordmark and footer always closing on `{colors.surface-dark}`.
297
+
298
+ ## Colors
299
+
300
+ ### Brand & Accent
301
+ - **Sunlight Yellow** (`{colors.primary}` — `#ffed00`): the brand accent. Reserved for primary CTAs, "NEW" / "yeni" badges, configurator dot indicators, and full-bleed promotional tiles. Never decorative.
302
+ - **Sunlight Yellow Pressed** (`{colors.primary-deep}` — `#e6d200`): the active/pressed state of `{colors.primary}` buttons and tiles.
303
+ - **On-Primary** (`{colors.on-primary}` — `#000000`): label colour on top of `{colors.primary}` surfaces. Yellow always pairs with black text — never white.
304
+
305
+ ### Surface
306
+ - **Canvas** (`{colors.canvas}` — `#ffffff`): the default page background and card surface.
307
+ - **Surface Soft** (`{colors.surface-soft}` — `#f7f7f7`): subtle elevation step for grouped configurator rows and inactive form fields.
308
+ - **Surface Dark** (`{colors.surface-dark}` — `#000000`): the alternate canvas, used for hero bands, footer, and full-bleed storytelling sections.
309
+ - **Surface Deep** (`{colors.surface-deep}` — `#111111`): a one-step-up elevation inside `{colors.surface-dark}` regions for inset cards and form panels.
310
+ - **Hairline** (`{colors.hairline}` — `#f2f2f2`): the soft 1px divider between rows on white surfaces.
311
+ - **Hairline Strong** (`{colors.hairline-strong}` — `#000000`): full-strength dividers on white, plus all card / button outlines.
312
+ - **Divider Dark** (`{colors.divider-dark}` — `rgba(255,255,255,0.16)`): the corresponding low-contrast divider used inside `{colors.surface-dark}` regions.
313
+
314
+ ### Text
315
+ - **Ink** (`{colors.ink}` — `#000000`): primary text colour on white surfaces. The same value also drives logos, icons, and outline borders — black is structural, not decorative.
316
+ - **Body** (`{colors.body}` — `#222222`): secondary body text where pure black would feel too heavy in long paragraphs.
317
+ - **Charcoal** (`{colors.charcoal}` — `#333333`): captions, metadata, and small labels.
318
+ - **Mute** (`{colors.mute}` — `#666666`): supporting text and inactive nav labels.
319
+ - **Ash** (`{colors.ash}` — `#8a8a8a`): placeholder text, disabled labels.
320
+ - **Stone** (`{colors.stone}` — `#c4c4c4`): disabled-state foreground.
321
+ - **On-Dark** (`{colors.on-dark}` — `#ffffff`): primary text on `{colors.surface-dark}` surfaces.
322
+ - **On-Dark Mute** (`{colors.on-dark-mute}` — `rgba(255,255,255,0.72)`): secondary text in dark regions; preserves the brand's high-contrast feel without resorting to mid-grey.
323
+
324
+ ### Semantic
325
+ - **Error** (`{colors.error}` — `#be6464`): muted desaturated red used for inline form errors. Notably warmer than typical pure-red error states.
326
+ - **Warning** (`{colors.warning}` — `#f0ad4e`): amber alert.
327
+ - **Success** (`{colors.success}` — `#8dc572`): muted green confirmation.
328
+ - **Info** (`{colors.info}` — `#337ab7`): a desaturated mid-blue used in informational chips.
329
+ - **Link** (`{colors.link}` — `#0000ee`): the unstyled-anchor default kept for fallback inline text links — production links inherit `{colors.ink}` and rely on underline/weight rather than colour.
330
+
331
+ ## Typography
332
+
333
+ ### Font Family
334
+
335
+ The entire system is set in **NouvelR**, Renault's proprietary display
336
+ family, used across navigation, headlines, body, captions, and button
337
+ labels. The family carries a slightly geometric, semi-condensed personality
338
+ with tall x-heights and squared apexes that pair naturally with the diamond
339
+ logomark.
340
+
341
+ When NouvelR cannot be licensed, suitable open-source substitutes include
342
+ **Inter Tight**, **Manrope**, or **HK Grotesk Semi Condensed** — all share
343
+ the geometric-with-warmth feel and adapt cleanly to weights 400 / 600 / 700.
344
+ Tighten `lineHeight` on display sizes to ~0.95 to match the original; do not
345
+ relax it.
346
+
347
+ ### Hierarchy
348
+
349
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
350
+ |---|---|---|---|---|---|
351
+ | `{typography.display-xl}` | 56px | 700 | 0.95 | 0 | Hero headlines, campaign titles ("E-TECH ELEKTRİKLİ", "REVOLUTION"). |
352
+ | `{typography.display-lg}` | 40px | 700 | 0.95 | 0 | Secondary section titles. |
353
+ | `{typography.display-md}` | 32px | 700 | 0.95 | 0 | Page-level H1 on sub-pages and configurator panels. |
354
+ | `{typography.heading-lg}` | 24px | 700 | 0.95 | 0 | Section headers, card titles. |
355
+ | `{typography.heading-md}` | 20px | 700 | 0.95 | 0 | Sub-section headers, prominent labels. |
356
+ | `{typography.heading-sm}` | 18px | 700 | 1.0 | 0 | Tile titles, list group headers. |
357
+ | `{typography.subtitle}` | 19.2px | 600 | 1.3 | 0 | Lead paragraphs, hero subtitles. |
358
+ | `{typography.body-lg}` | 18px | 400 | 1.5 | 0 | Long-form body. |
359
+ | `{typography.body-md}` | 16px | 400 | 1.4 | 0 | Default body and form fields. |
360
+ | `{typography.body-sm}` | 14px | 400 | 1.57 | 0 | Captions, metadata. |
361
+ | `{typography.button-lg}` | 16px | 700 | 1.0 | 0 | Large CTAs in hero bands. |
362
+ | `{typography.button-md}` | 14.4px | 700 | 1.0 | 0.144px | Default button label across the system. |
363
+ | `{typography.button-sm}` | 13px | 600 | 1.2 | 0.13px | Sub-nav pills, small in-card actions. |
364
+ | `{typography.caption}` | 12px | 400 | 1.4 | 0 | Footer disclosure, regulatory text. |
365
+ | `{typography.overline}` | 10px | 700 | 1.45 | 0 | Short uppercase labels above titles. |
366
+
367
+ ### Principles
368
+ - Display sizes always weight 700, always at `lineHeight: 0.95`. The tightness is what makes the brand feel confident rather than corporate.
369
+ - Body copy stays at weight 400 — never 500. The contrast between body and display is part of the system.
370
+ - Button labels carry a tiny positive letter-spacing (`0.144px` on `{typography.button-md}`) — almost imperceptible, but it adds the small bit of mechanical precision the brand wants on CTAs.
371
+ - No italics, no script, no decorative ligatures.
372
+
373
+ ### Note on Font Substitutes
374
+
375
+ NouvelR is licensed; substitutes (Inter Tight / Manrope / HK Grotesk Semi
376
+ Condensed) preserve the geometric character but typically render with
377
+ slightly looser line heights at display sizes — clamp display
378
+ `lineHeight` to 0.95 explicitly to match the source.
379
+
380
+ ## Layout
381
+
382
+ ### Spacing System
383
+ - **Base unit**: 4px, with the working scale built on multiples of 4 and 8.
384
+ - **Tokens**: `{spacing.xxs}` 4px · `{spacing.xs}` 8px · `{spacing.sm}` 12px · `{spacing.md}` 16px · `{spacing.lg}` 20px · `{spacing.xl}` 24px · `{spacing.xxl}` 32px · `{spacing.xxxl}` 40px · `{spacing.section}` 80px.
385
+ - Section padding (full-bleed band → next band): `{spacing.section}` (80px) on desktop, collapsing to `{spacing.xxxl}` (40px) on mobile.
386
+ - Promo-tile internal padding: `{spacing.xxl}` (32px) all sides on desktop.
387
+ - Configurator row vertical padding: `{spacing.xl}` (24px) top/bottom with hairline divider between rows.
388
+
389
+ ### Grid & Container
390
+ - **Max content width** ≈ 1440px. Beyond that, content remains centred and the dark/light bands extend full-bleed.
391
+ - **Promo grid** on the homepage: a 2-column tile grid on desktop, dropping to 1-up on mobile. Each tile is square-cornered (`{rounded.none}`) with the photography or solid colour as the background.
392
+ - **Vehicle range grids**: 3 to 4 cars per row at desktop, collapsing 2-up at tablet and 1-up at small mobile.
393
+ - **Configurator** uses a fixed left visualisation pane (~60% width) with a right-hand scrolling option list (~40% width) on desktop.
394
+
395
+ ### Whitespace Philosophy
396
+ - Whitespace is structural, not decorative. Sections are separated by colour-blocking (white → black) rather than soft padding ramps.
397
+ - Inside cards and configurator rows, padding is generous but never airy — the brand is mass-market, so density is acceptable.
398
+ - Hairline `{colors.hairline}` dividers on white surfaces create the sense of catalogue precision; on dark surfaces, `{colors.divider-dark}` carries the same role.
399
+
400
+ ## Elevation & Depth
401
+
402
+ | Level | Treatment | Use |
403
+ |---|---|---|
404
+ | 0 — flat | No shadow, no border | Default page surface, full-bleed bands. |
405
+ | 1 — outline | 1px solid `{colors.hairline-strong}` or `{colors.hairline}` | Promo tiles on light, vehicle cards, configurator panels. |
406
+ | 2 — colour-blocked elevation | Surface colour shift (e.g. `{colors.canvas}` card sitting inside a `{colors.surface-soft}` band) | Configurator detail cards, related-content rows. |
407
+ | 3 — dark inversion | Card swaps to `{colors.surface-dark}` against a `{colors.canvas}` band | "Ticari araç" hero promo tiles, lifestyle storytelling cards. |
408
+
409
+ Drop shadows are extracted from the system but rarely visible on the marketing
410
+ surfaces. When they appear, they are very subtle (~10% opacity, 2–4px blur)
411
+ and used on floating elements like the configurator's sticky summary bar.
412
+
413
+ ### Decorative Depth
414
+ - The R5 hero band uses an atmospheric mesh-gradient backdrop — purple-to-pink-to-yellow glow behind the car silhouette — that acts as the only true atmospheric depth in the system. Everywhere else, depth is structural (colour-blocking + outlines), not atmospheric.
415
+ - E-TECH electric powertrain pages use a luminous magenta-to-violet gradient behind cutaway diagrams, reserved for the electric sub-brand.
416
+
417
+ ## Shapes
418
+
419
+ ### Border Radius Scale
420
+
421
+ | Token | Value | Use |
422
+ |---|---|---|
423
+ | `{rounded.none}` | 0px | Tiles, vehicle cards, dividers, banner bands, full-bleed images. |
424
+ | `{rounded.xs}` | 2px | Default buttons (primary yellow, secondary black, outline). |
425
+ | `{rounded.sm}` | 3px | Tab panels, small chips. |
426
+ | `{rounded.md}` | 4px | Form labels, inline tags. |
427
+ | `{rounded.pill}` | 46px | Sub-nav pills, "yeni" / "NEW" badges, decorative carousel chips. |
428
+ | `{rounded.full}` | 9999px | Configurator colour swatches, avatar dots. |
429
+
430
+ ### Photography Geometry
431
+ - Vehicle photography is **always square-cornered** (`{rounded.none}`). No rounded vehicle hero shots, no soft-edged car cards.
432
+ - Aspect ratios cluster around **16:9** (hero bands), **1:1** (square promo tiles), and **4:3** (vehicle range cards). Lifestyle imagery sometimes runs **2:1 wide** for full-bleed bands.
433
+ - Avatars and small profile cues — when present — use `{rounded.full}` circles to contrast with the otherwise square geometry.
434
+
435
+ ## Components
436
+
437
+ ### Buttons
438
+
439
+ **`button-primary`** — yellow CTA
440
+ - Background `{colors.primary}`, label `{colors.on-primary}`, type `{typography.button-md}`, padding `14px 24px`, `rounded: {rounded.xs}`.
441
+ - The single most important action on a page (e.g. "Hemen randevu al", "Hesapla", "Konfigüratörü başlat").
442
+ - Pressed state lives in `button-primary-pressed` (background `{colors.primary-deep}`).
443
+
444
+ **`button-secondary-dark`** — solid black CTA
445
+ - Background `{colors.surface-dark}`, label `{colors.on-dark}`, type `{typography.button-md}`, `rounded: {rounded.xs}`.
446
+ - Equal-weight secondary action paired with `{component.button-primary}`, or the primary action when used on a yellow tile background.
447
+
448
+ **`button-outline-dark`** — outlined CTA on light
449
+ - Background `{colors.canvas}`, label `{colors.ink}`, 1px solid `{colors.hairline-strong}`, type `{typography.button-md}`, `rounded: {rounded.xs}`.
450
+ - Tertiary action; appears alongside primary/secondary for "Detayları gör", "Modeller", etc.
451
+
452
+ **`button-outline-light`** — outlined CTA on dark
453
+ - Background `{colors.surface-dark}`, label `{colors.on-dark}`, 1px solid `{colors.on-dark}`, type `{typography.button-md}`, `rounded: {rounded.xs}`.
454
+ - The dark-canvas counterpart to `{component.button-outline-dark}`.
455
+
456
+ **`button-pill`** — sub-nav chip
457
+ - Background `{colors.canvas}`, label `{colors.ink}`, 1px solid `{colors.hairline-strong}`, type `{typography.button-sm}`, `rounded: {rounded.pill}`, height 36px.
458
+ - The only place the system uses a pill — for top-level filter chips ("Servis & randevu", "Sahiplik dönemi geçişi", "Kampanyalar") and configurator tab switches.
459
+
460
+ **`button-icon-square`** — small icon button
461
+ - Background `{colors.canvas}`, 1px solid `{colors.hairline-strong}`, `rounded: {rounded.xs}`, 40×40px square.
462
+ - Carousel arrows, share, language switcher.
463
+
464
+ ### Cards & Containers
465
+
466
+ **`promo-tile-light`** — white promo tile
467
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.heading-lg}`, padding `{spacing.xxl}`, `rounded: {rounded.none}`.
468
+ - Used in the homepage 2-up grid for "Hybrid araç modelleri", "binek araç satış kampanyaları" tiles.
469
+
470
+ **`promo-tile-dark`** — black promo tile
471
+ - Background `{colors.surface-dark}`, text `{colors.on-dark}`, type `{typography.heading-lg}`, padding `{spacing.xxl}`, `rounded: {rounded.none}`.
472
+ - Lifestyle / commercial-vehicle storytelling tiles ("ticari araç satış kampanyaları").
473
+
474
+ **`promo-tile-yellow`** — accent promo tile
475
+ - Background `{colors.primary}`, text `{colors.on-primary}`, type `{typography.heading-lg}`, padding `{spacing.xxl}`, `rounded: {rounded.none}`.
476
+ - The single "PARLAK SARI" / "Sunlight Yellow" attention tile that anchors a campaign band. Reserved — usually one per page maximum.
477
+
478
+ **`vehicle-card`** — car listing card
479
+ - Background `{colors.canvas}`, full-bleed product photography on top, text below, `rounded: {rounded.none}`, no outer border.
480
+ - Includes vehicle name (`{typography.heading-md}`), variant subtitle (`{typography.body-sm}`), and a single trailing arrow icon.
481
+
482
+ **`hero-banner`** — full-bleed hero
483
+ - Background `{colors.surface-dark}` with full-bleed photo or atmospheric gradient, content stacked left, type `{typography.display-xl}` for the title.
484
+ - "SCENIC E-TECH ELEKTRİKLİ" hero on the homepage.
485
+
486
+ ### Inputs & Forms
487
+
488
+ **`text-input`** — default input
489
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.body-md}`, 1px bottom border `{colors.hairline-strong}`, `rounded: {rounded.none}`, padding `{spacing.sm} {spacing.md}`, height 48px.
490
+ - Inputs intentionally minimal — borderless on top and sides, single hairline at the bottom — keeping the catalogue feel.
491
+
492
+ ### Configurator
493
+
494
+ **`configurator-row`** — option list row
495
+ - Background `{colors.canvas}`, separator hairline `{colors.hairline}` between rows, padding `{spacing.xl}` top/bottom, type `{typography.body-md}`.
496
+ - Right-side scrolling list on the configurator: "kasa tipi", "motor seçimi", "versiyon seçimi", "renk seçenekleri", etc.
497
+
498
+ **`configurator-swatch`** — circular colour pick
499
+ - Background `{colors.surface-soft}` (or the actual car colour), `rounded: {rounded.full}`, 56×56px.
500
+ - Used for paint colour selection. Active state adds a 1px solid `{colors.hairline-strong}` ring.
501
+
502
+ ### Navigation
503
+
504
+ **`nav-bar`** — top nav (desktop)
505
+ - Background `{colors.canvas}`, type `{typography.button-md}`, height 60px, hairline `{colors.hairline}` bottom border.
506
+ - Left: diamond logomark. Centre: top-level nav ("Modeller", "Hizmetler", "Renault Yaşamı", "MyRenault"). Right: language switcher + login icon.
507
+
508
+ **`nav-bar`** (mobile)
509
+ - Same height 60px, collapses centre nav into a hamburger icon. Logo stays left, login stays right.
510
+
511
+ **`sub-nav-pill`** — pill-style sub-nav
512
+ - Pill chips set in a horizontal scroll bar between hero and content body (e.g. "Servis & randevu", "Sahiplik dönemi geçişi", "Kampanyalar"), `{component.button-pill}` styling.
513
+
514
+ ### Signature Components
515
+
516
+ **`badge-new`** — "yeni" badge
517
+ - Background `{colors.primary}`, label `{colors.on-primary}`, type `{typography.button-md}`, `rounded: {rounded.full}`, padding `6px 14px`.
518
+ - Anchored on the bottom-left of new vehicle cards.
519
+
520
+ **`footer`** — global footer
521
+ - Background `{colors.surface-dark}`, text `{colors.on-dark}`, type `{typography.body-sm}`, padding `64px 24px`.
522
+ - Three-column legal/quick-links/locale grid above a single-line copyright row separated by `{colors.divider-dark}`.
523
+
524
+ ## Do's and Don'ts
525
+
526
+ ### Do
527
+ - Reserve `{colors.primary}` exclusively for primary CTAs, "yeni"/"NEW" badges, and at most one accent promo tile per band — `{component.promo-tile-yellow}` is intentionally rare.
528
+ - Pair `{colors.primary}` only with `{colors.on-primary}` text. Yellow + white is forbidden.
529
+ - Set everything in **NouvelR** — no secondary serif, no script, no decorative italic.
530
+ - Hold display headlines at `{typography.display-xl}` weight 700 with `lineHeight: 0.95` so they stack tightly on multi-line wraps.
531
+ - Use `{rounded.xs}` (2px) on every standard button — the near-flat corner is part of the brand.
532
+ - Switch full bands between `{colors.canvas}` and `{colors.surface-dark}` for storytelling rhythm. Avoid mid-greys as section backgrounds.
533
+ - Show vehicle photography full-bleed inside `{component.vehicle-card}` with copy stacked beneath, never overlaid.
534
+ - Use `{component.sub-nav-pill}` (`{rounded.pill}`) only for sub-nav and small filter rows — never for primary CTAs.
535
+
536
+ ### Don't
537
+ - Don't introduce a secondary accent colour. Yellow is the only brand accent; semantic colours (`{colors.error}`, `{colors.success}`, `{colors.warning}`) are functional, not decorative.
538
+ - Don't round vehicle cards or promo tiles. Square-cornered photography is core to the brand expression.
539
+ - Don't soften body weights to 500 or 600 — the system relies on the 400 / 700 contrast.
540
+ - Don't apply `{colors.primary}` to body text or large surfaces beyond the single accent tile per band.
541
+ - Don't add atmospheric gradient washes outside the dedicated R5 / E-TECH hero contexts.
542
+ - Don't pair light grey text on white. Body text steps through `{colors.body}`, `{colors.charcoal}`, `{colors.mute}` — `{colors.ash}` and `{colors.stone}` are reserved for placeholders and disabled states.
543
+ - Don't add drop shadows to vehicle cards or promo tiles — the system is shadow-free at the catalogue level.
544
+
545
+ ## Responsive Behavior
546
+
547
+ ### Breakpoints
548
+
549
+ | Name | Width | Key Changes |
550
+ |---|---|---|
551
+ | Desktop XL | ≥ 1440px | Full max-width container, 3–4 column vehicle grid, 2-up promo tile grid. |
552
+ | Desktop | 1280–1439px | Same layout, container shrinks to viewport with `{spacing.xl}` side padding. |
553
+ | Tablet Large | 1024–1279px | Vehicle grid drops to 3-up, configurator left/right panes resize to 55/45. |
554
+ | Tablet | 768–1023px | Promo tile grid collapses to 2-up, sub-nav pills become horizontal scroll. |
555
+ | Mobile Large | 426–767px | Vehicle grid 2-up, configurator switches to stacked panes (visualisation on top, options below), nav collapses to hamburger. |
556
+ | Mobile | ≤ 425px | All grids 1-up, hero `{typography.display-xl}` clamps to ~40px, section padding `{spacing.section}` collapses to `{spacing.xxxl}`. |
557
+
558
+ ### Touch Targets
559
+ - All buttons ship at minimum 44×44px on mobile; default `{component.button-primary}` is 48px tall, comfortably exceeding WCAG AAA.
560
+ - `{component.sub-nav-pill}` (36px) is bumped to 40px tall on mobile via increased vertical padding.
561
+ - `{component.button-icon-square}` (40px) sits at the WCAG AA minimum and remains tappable, but should grow to 44px when used as a primary navigation control.
562
+
563
+ ### Collapsing Strategy
564
+ - Top-level nav collapses to hamburger at < 1024px; the logo and login icon stay anchored.
565
+ - 2-up promo grid collapses to 1-up at < 768px; tile padding shrinks from `{spacing.xxl}` to `{spacing.lg}`.
566
+ - Configurator switches from side-by-side to stacked at < 1024px, with the visualisation pinned to the top of the viewport on scroll.
567
+ - Display headlines clamp: `{typography.display-xl}` 56px → 40px → 32px across the breakpoint ladder.
568
+ - Sub-nav pills convert from a wrap row to a horizontal scroll-rail at < 768px.
569
+
570
+ ### Image Behavior
571
+ - Vehicle photography is served at 1.5× and 2× DPR; below 768px, the system swaps to a portrait-oriented composition where art direction allows.
572
+ - Hero atmospheric gradients (R5, E-TECH) load lazily after primary content; they are not blocking.
573
+ - Lifestyle / commercial photography in `{component.promo-tile-dark}` keeps the same 16:9 framing across breakpoints, cropping inward rather than letterboxing.
574
+
575
+ ## Iteration Guide
576
+
577
+ 1. Focus on ONE component at a time. Most components share `{rounded.xs}`, `{colors.canvas}` / `{colors.surface-dark}`, and NouvelR — only the role-specific tokens (`{colors.primary}`, `{component.promo-tile-yellow}`) shift between variants.
578
+ 2. Reference component names and tokens directly (`{colors.primary}`, `{component.button-primary-pressed}`, `{rounded.pill}`) — do not paraphrase.
579
+ 3. Run `npx @google/design.md lint DESIGN.md` after edits; the orphaned-tokens warning will catch unused entries before they ship.
580
+ 4. Add new variants as separate entries (`-pressed`, `-disabled`, `-outline`) — do not bury them in prose.
581
+ 5. Default body type to `{typography.body-md}`; reach for `{typography.subtitle}` only on hero subtitles and lead paragraphs.
582
+ 6. Keep `{colors.primary}` scarce — if more than one yellow element appears per viewport, ask whether one of them should drop to `{colors.surface-dark}` or `{colors.canvas}` instead.
583
+
584
+ ## Known Gaps
585
+
586
+ - Active/pressed visual states are not consistently observable in static surfaces; `button-primary-pressed` documents the extracted darkened-yellow value, but no other component has a pressed variant promoted to the YAML.
587
+ - Drop-shadow values exist in the extracted tokens but are rarely surfaced visually; only the configurator's sticky summary bar uses them on the captured pages.
588
+ - The MyRenault application surfaces (logged-in product) are out of scope for this extraction — only the public marketing canvas is documented.
589
+ - Form-field focus styling is not extracted; the system likely relies on a thicker bottom border at `{colors.ink}`, but this is not visually confirmed on the captured pages.
@@ -0,0 +1,5 @@
1
+ # Renault Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/renault/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.