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,544 @@
1
+ ---
2
+ version: alpha
3
+ name: BMW
4
+ description: BMW's corporate site — distinct from BMW M's motorsport-bombastic variant, this is a measured and settled corporate-automotive interface. On a light (cream-tinted white) canvas, BMW corporate blue (#1c69d4) carries every primary CTA; dark navy hero bands frame model photography. BMW Type Next Latin sets the entire hierarchy on two weights — heavy 700 display and Light 300 body. Configuration and reservation flows ride a card-based 4-up grid, where each card holds a model render, a name, and a "Learn More" link.
5
+
6
+ colors:
7
+ primary: "#1c69d4"
8
+ primary-active: "#0653b6"
9
+ primary-disabled: "#d6d6d6"
10
+ ink: "#262626"
11
+ body: "#3c3c3c"
12
+ body-strong: "#1a1a1a"
13
+ muted: "#6b6b6b"
14
+ muted-soft: "#9a9a9a"
15
+ hairline: "#e6e6e6"
16
+ hairline-strong: "#cccccc"
17
+ canvas: "#ffffff"
18
+ surface-soft: "#f7f7f7"
19
+ surface-card: "#fafafa"
20
+ surface-strong: "#ebebeb"
21
+ surface-dark: "#1a2129"
22
+ surface-dark-elevated: "#262e38"
23
+ on-primary: "#ffffff"
24
+ on-dark: "#ffffff"
25
+ on-dark-soft: "#bbbbbb"
26
+ m-blue-light: "#0066b1"
27
+ m-blue-dark: "#1c69d4"
28
+ m-red: "#e22718"
29
+ success: "#22c55e"
30
+ warning: "#f59e0b"
31
+ error: "#dc2626"
32
+
33
+ typography:
34
+ display-xl:
35
+ fontFamily: "'BMW Type Next Latin', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif"
36
+ fontSize: 64px
37
+ fontWeight: 700
38
+ lineHeight: 1.05
39
+ letterSpacing: 0
40
+ display-lg:
41
+ fontFamily: "'BMW Type Next Latin', sans-serif"
42
+ fontSize: 48px
43
+ fontWeight: 700
44
+ lineHeight: 1.1
45
+ letterSpacing: 0
46
+ display-md:
47
+ fontFamily: "'BMW Type Next Latin', sans-serif"
48
+ fontSize: 32px
49
+ fontWeight: 700
50
+ lineHeight: 1.15
51
+ letterSpacing: 0
52
+ display-sm:
53
+ fontFamily: "'BMW Type Next Latin', sans-serif"
54
+ fontSize: 24px
55
+ fontWeight: 700
56
+ lineHeight: 1.25
57
+ letterSpacing: 0
58
+ title-lg:
59
+ fontFamily: "'BMW Type Next Latin', sans-serif"
60
+ fontSize: 20px
61
+ fontWeight: 700
62
+ lineHeight: 1.3
63
+ letterSpacing: 0
64
+ title-md:
65
+ fontFamily: "'BMW Type Next Latin', sans-serif"
66
+ fontSize: 18px
67
+ fontWeight: 700
68
+ lineHeight: 1.4
69
+ letterSpacing: 0
70
+ title-sm:
71
+ fontFamily: "'BMW Type Next Latin', sans-serif"
72
+ fontSize: 16px
73
+ fontWeight: 700
74
+ lineHeight: 1.4
75
+ letterSpacing: 0
76
+ body-md:
77
+ fontFamily: "'BMW Type Next Latin', sans-serif"
78
+ fontSize: 16px
79
+ fontWeight: 300
80
+ lineHeight: 1.55
81
+ letterSpacing: 0
82
+ body-sm:
83
+ fontFamily: "'BMW Type Next Latin', sans-serif"
84
+ fontSize: 14px
85
+ fontWeight: 300
86
+ lineHeight: 1.55
87
+ letterSpacing: 0
88
+ caption:
89
+ fontFamily: "'BMW Type Next Latin', sans-serif"
90
+ fontSize: 12px
91
+ fontWeight: 400
92
+ lineHeight: 1.4
93
+ letterSpacing: 0.5px
94
+ label-uppercase:
95
+ fontFamily: "'BMW Type Next Latin', sans-serif"
96
+ fontSize: 13px
97
+ fontWeight: 700
98
+ lineHeight: 1.3
99
+ letterSpacing: 1.5px
100
+ textTransform: uppercase
101
+ button:
102
+ fontFamily: "'BMW Type Next Latin', sans-serif"
103
+ fontSize: 14px
104
+ fontWeight: 700
105
+ lineHeight: 1.0
106
+ letterSpacing: 0.5px
107
+ nav-link:
108
+ fontFamily: "'BMW Type Next Latin', sans-serif"
109
+ fontSize: 14px
110
+ fontWeight: 400
111
+ lineHeight: 1.4
112
+ letterSpacing: 0.3px
113
+
114
+ rounded:
115
+ none: 0px
116
+ xs: 2px
117
+ sm: 4px
118
+ md: 8px
119
+ lg: 12px
120
+ pill: 9999px
121
+ full: 9999px
122
+
123
+ spacing:
124
+ xxs: 4px
125
+ xs: 8px
126
+ sm: 12px
127
+ md: 16px
128
+ lg: 24px
129
+ xl: 32px
130
+ xxl: 48px
131
+ section: 80px
132
+
133
+ components:
134
+ top-nav:
135
+ backgroundColor: "{colors.canvas}"
136
+ textColor: "{colors.ink}"
137
+ typography: "{typography.nav-link}"
138
+ height: 64px
139
+ button-primary:
140
+ backgroundColor: "{colors.primary}"
141
+ textColor: "{colors.on-primary}"
142
+ typography: "{typography.button}"
143
+ rounded: "{rounded.none}"
144
+ padding: 14px 32px
145
+ height: 48px
146
+ button-primary-active:
147
+ backgroundColor: "{colors.primary-active}"
148
+ textColor: "{colors.on-primary}"
149
+ rounded: "{rounded.none}"
150
+ button-primary-disabled:
151
+ backgroundColor: "{colors.primary-disabled}"
152
+ textColor: "{colors.muted}"
153
+ rounded: "{rounded.none}"
154
+ button-secondary:
155
+ backgroundColor: "{colors.canvas}"
156
+ textColor: "{colors.ink}"
157
+ typography: "{typography.button}"
158
+ rounded: "{rounded.none}"
159
+ padding: 13px 31px
160
+ height: 48px
161
+ button-secondary-on-dark:
162
+ backgroundColor: transparent
163
+ textColor: "{colors.on-dark}"
164
+ typography: "{typography.button}"
165
+ rounded: "{rounded.none}"
166
+ padding: 13px 31px
167
+ button-text-link:
168
+ backgroundColor: transparent
169
+ textColor: "{colors.ink}"
170
+ typography: "{typography.label-uppercase}"
171
+ text-link:
172
+ backgroundColor: transparent
173
+ textColor: "{colors.ink}"
174
+ typography: "{typography.body-md}"
175
+ hero-band-dark:
176
+ backgroundColor: "{colors.surface-dark}"
177
+ textColor: "{colors.on-dark}"
178
+ typography: "{typography.display-xl}"
179
+ padding: 80px
180
+ hero-photo-band:
181
+ backgroundColor: "{colors.canvas}"
182
+ textColor: "{colors.ink}"
183
+ typography: "{typography.display-lg}"
184
+ padding: 80px
185
+ model-card:
186
+ backgroundColor: "{colors.canvas}"
187
+ textColor: "{colors.ink}"
188
+ typography: "{typography.title-md}"
189
+ rounded: "{rounded.none}"
190
+ padding: 24px
191
+ model-card-photo:
192
+ backgroundColor: "{colors.surface-card}"
193
+ rounded: "{rounded.none}"
194
+ feature-photo-card:
195
+ backgroundColor: "{colors.canvas}"
196
+ textColor: "{colors.ink}"
197
+ typography: "{typography.title-md}"
198
+ rounded: "{rounded.none}"
199
+ padding: 24px
200
+ spec-cell:
201
+ backgroundColor: transparent
202
+ textColor: "{colors.ink}"
203
+ typography: "{typography.display-sm}"
204
+ rounded: "{rounded.none}"
205
+ padding: 24px
206
+ inventory-card:
207
+ backgroundColor: "{colors.canvas}"
208
+ textColor: "{colors.ink}"
209
+ typography: "{typography.title-sm}"
210
+ rounded: "{rounded.none}"
211
+ padding: 16px
212
+ filter-chip:
213
+ backgroundColor: "{colors.canvas}"
214
+ textColor: "{colors.ink}"
215
+ typography: "{typography.caption}"
216
+ rounded: "{rounded.none}"
217
+ padding: 8px 14px
218
+ filter-chip-active:
219
+ backgroundColor: "{colors.ink}"
220
+ textColor: "{colors.on-dark}"
221
+ rounded: "{rounded.none}"
222
+ configurator-option-tile:
223
+ backgroundColor: "{colors.canvas}"
224
+ textColor: "{colors.ink}"
225
+ typography: "{typography.body-md}"
226
+ rounded: "{rounded.none}"
227
+ padding: 16px 24px
228
+ configurator-option-tile-selected:
229
+ backgroundColor: "{colors.canvas}"
230
+ textColor: "{colors.ink}"
231
+ rounded: "{rounded.none}"
232
+ padding: 15px 23px
233
+ text-input:
234
+ backgroundColor: "{colors.canvas}"
235
+ textColor: "{colors.ink}"
236
+ typography: "{typography.body-md}"
237
+ rounded: "{rounded.none}"
238
+ padding: 14px 16px
239
+ height: 48px
240
+ cookie-consent-card:
241
+ backgroundColor: "{colors.canvas}"
242
+ textColor: "{colors.body}"
243
+ typography: "{typography.body-sm}"
244
+ rounded: "{rounded.none}"
245
+ padding: 24px
246
+ category-tab:
247
+ backgroundColor: transparent
248
+ textColor: "{colors.muted}"
249
+ typography: "{typography.label-uppercase}"
250
+ rounded: "{rounded.none}"
251
+ category-tab-active:
252
+ backgroundColor: transparent
253
+ textColor: "{colors.ink}"
254
+ typography: "{typography.label-uppercase}"
255
+ rounded: "{rounded.none}"
256
+ m-stripe-divider:
257
+ backgroundColor: transparent
258
+ rounded: "{rounded.none}"
259
+ cta-band-photo:
260
+ backgroundColor: "{colors.surface-dark}"
261
+ textColor: "{colors.on-dark}"
262
+ typography: "{typography.display-md}"
263
+ padding: 80px
264
+ footer:
265
+ backgroundColor: "{colors.surface-soft}"
266
+ textColor: "{colors.body}"
267
+ typography: "{typography.body-sm}"
268
+ padding: 64px
269
+ ---
270
+
271
+ ## Overview
272
+
273
+ BMW's corporate site carries a far more **measured, corporate-automotive** interface than its motorsport-bombastic cousin BMW M. The atmosphere is light: `{colors.canvas}` (#ffffff) is the base surface, `{colors.surface-card}` (#fafafa) carries the soft-grey card plates, and dark navy `{colors.surface-dark}` (#1a2129) appears only inside hero bands — one per page, framing the lead model render.
274
+
275
+ Type runs BMW's licensed **BMW Type Next Latin** at two weights: heavy 700 (display + button + nav) and Light 300 (body + secondary copy). That contrast — heavy display next to thin paragraph — is the editorial signature, channeling the brand's "European-engineered" voice. Weight 500 is deliberately absent; weight 400 only appears on caption and nav-link in neutral utility contexts.
276
+
277
+ The brand action color, **BMW corporate blue** (`{colors.primary}` — #1c69d4), works alone across every primary CTA — buttons are **rectangular, 0px corner**, with white type. The site rotates a blue-button + dark-navy-hero combination across page rhythm. The M tricolor stripe (`{colors.m-blue-light}` → `{colors.m-blue-dark}` → `{colors.m-red}`) only appears in motorsport contexts and as M-model badges/dividers — never in the corporate site's main language.
278
+
279
+ The configuration and reservation flows add a dealer-side inventory UI on top of the same system — filter chips, model cards, price tables — but typography and color stay identical; only density goes up.
280
+
281
+ **Key Characteristics:**
282
+ - Light `{colors.canvas}` is the base surface; dark navy `{colors.surface-dark}` appears only inside hero bands — page rhythm relies on contrast.
283
+ - BMW corporate blue (`{colors.primary}` — #1c69d4) acts as the single primary action color.
284
+ - BMW Type Next Latin: weight 700 display against weight 300 body is the signature.
285
+ - Buttons are **rectangular, 0px radius** — corporate dialect, distinct from M's sportier radii.
286
+ - Model cards run as 4-up or 5-up grids with no hairline border or only minimal border — just white plate + photo + title.
287
+ - Photography (model renders) sits in environment, no shadow — depth comes entirely from color-block contrast.
288
+ - M tricolor stripe appears only in M-model contexts — not part of the corporate language.
289
+ - Section rhythm holds at `{spacing.section}` (80px) for every major band.
290
+
291
+ ## Colors
292
+
293
+ ### Brand & Accent
294
+ - **BMW Blue (Primary)** (`{colors.primary}` — #1c69d4): The single brand action color. All primary CTAs, "Learn More" link prefixes (blue text), nav-link active state. Press shifts to `{colors.primary-active}` (#0653b6).
295
+ - **M Blue Light** (`{colors.m-blue-light}` — #0066b1) + **M Blue Dark** (`{colors.m-blue-dark}` — #1c69d4) + **M Red** (`{colors.m-red}` — #e22718): The M tricolor stripe — appears on the corporate site only on M-model pages and the "M" badge. Never as CTA colors.
296
+
297
+ ### Surface
298
+ - **Canvas** (`{colors.canvas}` — #ffffff): The default page surface.
299
+ - **Surface Soft** (`{colors.surface-soft}` — #f7f7f7): Soft grey for the footer and sub-navigation bands.
300
+ - **Surface Card** (`{colors.surface-card}` — #fafafa): The light plate behind a model card's photo block.
301
+ - **Surface Strong** (`{colors.surface-strong}` — #ebebeb): A slightly heavier grey used as a section divider.
302
+ - **Surface Dark** (`{colors.surface-dark}` — #1a2129): Dark navy for hero bands and large dark CTAs. Not pure black — carries a warm undertone.
303
+ - **Surface Dark Elevated** (`{colors.surface-dark-elevated}` — #262e38): One step lighter, used for nested cards on top of the dark hero.
304
+
305
+ ### Hairlines
306
+ - **Hairline** (`{colors.hairline}` — #e6e6e6): The 1px divider — input outline, configurator card outline, table separator.
307
+ - **Hairline Strong** (`{colors.hairline-strong}` — #cccccc): A more visible 1px outline — disabled secondary buttons, emphasized table border.
308
+
309
+ ### Text
310
+ - **Ink** (`{colors.ink}` — #262626): All display and primary text. Not pure black — soft against photography.
311
+ - **Body** (`{colors.body}` — #3c3c3c): Default running text.
312
+ - **Body Strong** (`{colors.body-strong}` — #1a1a1a): Emphasized paragraphs and lead text.
313
+ - **Muted** (`{colors.muted}` — #6b6b6b): Footer links, breadcrumbs, captions.
314
+ - **Muted Soft** (`{colors.muted-soft}` — #9a9a9a): Disabled text, fine-print legal.
315
+ - **On Primary** (`{colors.on-primary}` — #ffffff): White text on a blue button.
316
+ - **On Dark** (`{colors.on-dark}` — #ffffff): White text on a dark hero band.
317
+ - **On Dark Soft** (`{colors.on-dark-soft}` — #bbbbbb): A slightly muted white for secondary text on dark bands.
318
+
319
+ ### Semantic
320
+ - **Success** (`{colors.success}` — #22c55e): Confirmation messages and "available" indicators.
321
+ - **Warning** (`{colors.warning}` — #f59e0b): Warning callouts.
322
+ - **Error** (`{colors.error}` — #dc2626): Validation errors.
323
+
324
+ ## Typography
325
+
326
+ ### Font Family
327
+ The system runs **BMW Type Next Latin** in two cuts: regular (display + UI labels) and **BMW Type Next Latin Light** (body + secondary copy). Fallback stack: `system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif`.
328
+
329
+ The display/body split is functional:
330
+ - BMW Type Next Latin (700) → display headlines, button labels, nav links
331
+ - BMW Type Next Latin Light (300) → paragraphs, descriptive copy
332
+ - BMW Type Next Latin (400) → caption, neutral nav-link contexts
333
+
334
+ This three-way split mirrors BMW M's — corporate and the M sub-brand share the same typographic DNA; only the weight/size ratios differ.
335
+
336
+ ### Hierarchy
337
+
338
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
339
+ |---|---|---|---|---|---|
340
+ | `{typography.display-xl}` | 64px | 700 | 1.05 | 0 | Hero h1 ("iX3", model name) |
341
+ | `{typography.display-lg}` | 48px | 700 | 1.1 | 0 | Section heads |
342
+ | `{typography.display-md}` | 32px | 700 | 1.15 | 0 | Sub-section heads |
343
+ | `{typography.display-sm}` | 24px | 700 | 1.25 | 0 | CTA-band headlines |
344
+ | `{typography.title-lg}` | 20px | 700 | 1.3 | 0 | Card group titles |
345
+ | `{typography.title-md}` | 18px | 700 | 1.4 | 0 | Model card title, intro paragraphs |
346
+ | `{typography.title-sm}` | 16px | 700 | 1.4 | 0 | Inventory card title, list label |
347
+ | `{typography.body-md}` | 16px | 300 (Light) | 1.55 | 0 | Default body — BMW Type Next Latin Light |
348
+ | `{typography.body-sm}` | 14px | 300 (Light) | 1.55 | 0 | Footer body, fine-print |
349
+ | `{typography.caption}` | 12px | 400 | 1.4 | 0.5px | Photo captions, meta |
350
+ | `{typography.label-uppercase}` | 13px | 700 | 1.3 | 1.5px | "LEARN MORE" inline links, category tabs |
351
+ | `{typography.button}` | 14px | 700 | 1.0 | 0.5px | Standard CTA button label |
352
+ | `{typography.nav-link}` | 14px | 400 | 1.4 | 0.3px | Top-nav menu items |
353
+
354
+ ### Principles
355
+ - The **700/300 contrast** is the editorial signature. Weight 500 is absent from the system.
356
+ - **No negative letter-spacing** — BMW Type Next Latin works on a wide body, so tracking stays at default. Apple/Cal.com-style tightening reads off-brand here.
357
+ - **UPPERCASE inline links** — "LEARN MORE"-style CTAs run uppercase with 1.5px tracking. The "machined precision" voice.
358
+ - **Weight 400 lives in a narrow lane** — only caption and nav-link, both neutral utility roles.
359
+
360
+ ### Note on Font Substitutes
361
+ BMW Type Next Latin is a licensed BMW typeface. Open-source alternatives:
362
+ - **Inter** (variable) — close match at weight 700/300. Leave letter-spacing at 0.0em.
363
+ - **Saira Condensed** — for a slightly more compressed BMW Type feel.
364
+
365
+ ## Layout
366
+
367
+ ### Spacing System
368
+ - **Base unit:** 8px.
369
+ - **Tokens:** `{spacing.xxs}` 4px · `{spacing.xs}` 8px · `{spacing.sm}` 12px · `{spacing.md}` 16px · `{spacing.lg}` 24px · `{spacing.xl}` 32px · `{spacing.xxl}` 48px · `{spacing.section}` 80px.
370
+ - **Section padding:** `{spacing.section}` (80px) for every major editorial band.
371
+ - **Card internal padding:** `{spacing.lg}` (24px) for model and feature cards.
372
+
373
+ ### Grid & Container
374
+ - **Max content width:** ~1440px center-aligned.
375
+ - **Editorial body:** A single 12-column grid.
376
+ - **Model card grids:** 4-up or 5-up at desktop, 2-up at tablet, 1-up on mobile.
377
+ - **Configurator inventory grids:** 3-up filter row + 4-up vehicle cards, dense layout.
378
+
379
+ ### Whitespace Philosophy
380
+ BMW's whitespace strategy is tighter than BMW M's motorsport-aerated grenadier — the corporate side is more utility-driven. Section rhythm is 80px (not M's 96px). Card padding is 24px (not M's 32px). The page is denser, more dealership-functional.
381
+
382
+ ## Elevation & Depth
383
+
384
+ | Level | Treatment | Use |
385
+ |---|---|---|
386
+ | Flat | No shadow, no border | Body, top nav, footer, hero bands |
387
+ | Soft hairline | 1px `{colors.hairline}` border | Configurator option tile, table divider |
388
+ | Card surface | `{colors.surface-card}` background — no shadow | Model card photo plate |
389
+ | Photographic | Edge-to-edge photography | Hero band, model renders |
390
+
391
+ The system never uses a drop shadow. Depth comes entirely from (a) color-block contrast (light canvas vs dark hero) and (b) photographic subject + lighting.
392
+
393
+ ### Decorative Depth
394
+ - **`m-stripe-divider`** — a 4px-tall horizontal tricolor stripe (`{colors.m-blue-light}` → `{colors.m-blue-dark}` → `{colors.m-red}`). Only in M-model contexts, motorsport badges, or as an M-related section divider. Not part of the main corporate flow.
395
+ - **Photographic depth** — full-bleed vehicle photography (lighting + subject) does the work chrome would otherwise do.
396
+
397
+ ## Shapes
398
+
399
+ ### Border Radius Scale
400
+
401
+ | Token | Value | Use |
402
+ |---|---|---|
403
+ | `{rounded.none}` | 0px | Every button, card, input, configurator chip — the dominant radius |
404
+ | `{rounded.xs}` | 2px | Very small badges, very rare |
405
+ | `{rounded.sm}` | 4px | Small inline button (rare) |
406
+ | `{rounded.md}` | 8px | Mobile-only collapse cards (rare) |
407
+ | `{rounded.lg}` | 12px | Very rare — modal/dialog corners |
408
+ | `{rounded.pill}` | 9999px | Filter chips in some contexts (rare) |
409
+ | `{rounded.full}` | 9999px / 50% | Avatar, circular icon button |
410
+
411
+ The radius hierarchy is binary: **rectangular for everything, circular only for icon buttons.** A clear departure from the soft-cornered SaaS dialect of Apple or Cal.com — closer to BMW corporate-automotive's "engineered precision" voice.
412
+
413
+ ### Photography Geometry
414
+ - Hero photography is full-bleed at 16:9 or 21:9 cinematic ratio.
415
+ - Model card photos sit at 16:10, edge-to-edge with `{rounded.none}` corners.
416
+ - Configurator vehicle renders sit on a white studio background, full silhouette visible.
417
+
418
+ ## Components
419
+
420
+ ### Top Navigation
421
+
422
+ **`top-nav`** — A white sticky nav bar pinned to the top of the page. 64px tall, `{colors.canvas}` background. Left: BMW circular badge logo; center: primary horizontal menu (Models, Next Generation, Pre-Owned, Dealers, Test Drive); right: cart icon, language picker, profile. Menu items render in `{typography.nav-link}` (14px / 400 / 0.3px tracking).
423
+
424
+ ### Buttons
425
+
426
+ **`button-primary`** — The signature primary CTA. Background `{colors.primary}` (BMW Blue #1c69d4), text `{colors.on-primary}`, type `{typography.button}` (BMW Type Next Latin 14px / 700 / 0.5px tracking), padding 14px × 32px, height 48px, rounded `{rounded.none}` (0px — rectangular). Press state: `button-primary-active` shifts to `{colors.primary-active}`.
427
+
428
+ **`button-secondary`** — A white button with a hairline outline. Background `{colors.canvas}`, text `{colors.ink}`, 1px `{colors.hairline-strong}` border, same padding + height + radius.
429
+
430
+ **`button-secondary-on-dark`** — Used over a dark hero band. Background transparent, text `{colors.on-dark}`, 1px `{colors.on-dark}` border, same rectangular shape.
431
+
432
+ **`button-text-link`** — An inline UPPERCASE letter-spaced link. No background, text `{colors.ink}`, type `{typography.label-uppercase}` (13px / 700 / 1.5px tracking). Reads as "LEARN MORE", terminated by a `›` chevron.
433
+
434
+ **`text-link`** — An inline link inside body copy. `{colors.ink}` text, no underline by default; underlines per context.
435
+
436
+ ### Cards & Containers
437
+
438
+ **`hero-band-dark`** — Full-width dark navy hero. Background `{colors.surface-dark}`, text `{colors.on-dark}`, vertical padding `{spacing.section}` (80px). Centered: model name in `{typography.display-xl}` (64px / 700) + sub-headline + vehicle render (right-aligned or below). A single `{component.button-primary}` (blue) or `{component.button-secondary-on-dark}`.
439
+
440
+ **`hero-photo-band`** — A light-canvas model showcase band. Background `{colors.canvas}`, text `{colors.ink}`. The vehicle render takes the wide area; right or below, a headline + two link CTAs + sub-tagline.
441
+
442
+ **`model-card`** — Used in 4-up or 5-up model card grids on the homepage ("BMW iX3", "BMW iX", "BMW 5 Series"). Background `{colors.canvas}`, rounded `{rounded.none}`, padding `{spacing.lg}` (24px). Contents: model render at the top (`{component.model-card-photo}` on `{colors.surface-card}`), model name in `{typography.title-md}` (18px / 700) below, a one-line tagline in `{typography.body-sm}` (14px / 300), and a `{component.button-text-link}` ("LEARN MORE ›").
443
+
444
+ **`model-card-photo`** — The card's photo plate. Background `{colors.surface-card}` (#fafafa — soft grey), rounded `{rounded.none}`, vehicle render in full silhouette. Zero padding — the photo runs edge-to-edge.
445
+
446
+ **`feature-photo-card`** — A feature/lifestyle card. Background `{colors.canvas}`, padding `{spacing.lg}`. 16:9 photo at the top, `{typography.title-md}` headline + body excerpt below.
447
+
448
+ **`spec-cell`** — A technical spec cell (model detail page). Transparent background, separated by hairline dividers. Value on top (`{typography.display-sm}` 24px / 700), label below (`{typography.label-uppercase}`).
449
+
450
+ ### Inventory & Configurator
451
+
452
+ **`inventory-card`** — One card per vehicle on the dealer inventory page. Background `{colors.canvas}`, padding `{spacing.md}` (16px), rounded `{rounded.none}`. Vehicle photo on top, model + variant name + price + "View" link below.
453
+
454
+ **`filter-chip`** + **`filter-chip-active`** — Inventory filter chips (model, year, price range). Inactive: background `{colors.canvas}`, 1px `{colors.hairline-strong}` border, text `{colors.ink}`, type `{typography.caption}`. Active: background `{colors.ink}`, text `{colors.on-dark}`. Padding 8px × 14px, radius `{rounded.none}`.
455
+
456
+ **`configurator-option-tile`** + **`configurator-option-tile-selected`** — Configurator selection cell (color, wheels, upholstery). Inactive: background `{colors.canvas}`, 1px hairline. Selected: 2px `{colors.primary}` border. Padding 16px × 24px, radius `{rounded.none}`.
457
+
458
+ ### Inputs & Forms
459
+
460
+ **`text-input`** — Standard text input. Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.body-md}`, rounded `{rounded.none}` (0px), padding 14px × 16px, height 48px, 1px hairline border. On focus, the border thickens to ink.
461
+
462
+ **`cookie-consent-card`** — Cookie banner. Background `{colors.canvas}`, 1px hairline, padding `{spacing.lg}` (24px), `{typography.body-sm}` (14px / 300 — Light even in legal copy).
463
+
464
+ ### Tabs / Tags
465
+
466
+ **`category-tab`** + **`category-tab-active`** — Category sub-nav. Inactive: transparent + `{colors.muted}` UPPERCASE label. Active: transparent + `{colors.ink}` UPPERCASE label + 2px ink underline. 12px vertical padding, no horizontal radius.
467
+
468
+ ### Brand Signature
469
+
470
+ **`m-stripe-divider`** — A 4px-tall horizontal tricolor stripe (`{colors.m-blue-light}` → `{colors.m-blue-dark}` → `{colors.m-red}`). Only in M-model contexts, motorsport badges, or as an M-related section divider. Absent from the corporate main flow; on M-model detail pages and the M Performance badge it plays an inline divider role.
471
+
472
+ ### CTA / Footer
473
+
474
+ **`cta-band-photo`** — A pre-footer "Discover the New iX3"-style band. Background `{colors.surface-dark}` with a full-bleed vehicle photo. Centered headline in `{typography.display-md}` (32px / 700) + a single `{component.button-secondary-on-dark}`. 80px padding.
475
+
476
+ **`footer`** — The closing soft-grey footer. Background `{colors.surface-soft}` (#f7f7f7 — not pure white — soft grey), text `{colors.body}`. A 4-column link list: Models / Services / Dealers / About. Vertical padding 64px. Below, a copyright line in `{typography.body-sm}` with `{colors.muted}`.
477
+
478
+ ## Do's and Don'ts
479
+
480
+ ### Do
481
+ - Sit every page on `{colors.canvas}` (pure white); reserve `{colors.surface-dark}` for hero bands only.
482
+ - Pair primary CTAs with `{colors.primary}` (BMW Blue) + `{colors.on-primary}` white text + `{rounded.none}` 0px corners — the corporate signature.
483
+ - Set display headlines in BMW Type Next Latin 700 and body in Light 300. The contrast is non-negotiable.
484
+ - Use UPPERCASE letter-spaced links like "LEARN MORE" as inline CTAs.
485
+ - Place the model card photo on `{colors.surface-card}` with the title beneath — the standard BMW corporate pattern.
486
+ - Hold section rhythm at `{spacing.section}` (80px) — tighter than BMW M's 96px.
487
+ - Reserve the M tricolor stripe for M-model contexts and motorsport dividers.
488
+
489
+ ### Don't
490
+ - Don't add a brand color other than blue — BMW Blue is the only primary action color.
491
+ - Don't use pill or rounded buttons — `{rounded.none}` (0px) rectangular IS the brand button.
492
+ - Don't drop display weight to 500 — the system uses 700 / 400 / 300; 500 is absent.
493
+ - Don't bold body type — Light 300 is the BMW corporate editorial voice.
494
+ - Don't add drop shadows to cards — depth comes from photo + color-block contrast.
495
+ - Don't repeat the same surface mode across two consecutive bands — light → dark hero → light → light feature → dark CTA → light footer rotation is required.
496
+ - Don't use the M tricolor stripe as a CTA fill — divider/accent role only.
497
+ - Don't mix languages in a single page — UI language must stay consistent.
498
+
499
+ ## Responsive Behavior
500
+
501
+ ### Breakpoints
502
+
503
+ | Name | Width | Key Changes |
504
+ |---|---|---|
505
+ | Mobile | < 768px | Hamburger nav; hero h1 64→40px; model card grid 1-up; configurator filter chips 2-up; footer 4 col → 1 col |
506
+ | Tablet | 768–1024px | Top nav narrows, secondary menu hides under "More"; model card 2-up; inventory 2-up |
507
+ | Desktop | 1024–1440px | Full top-nav; 4-up or 5-up model card grid; inventory 3-up; full configurator UI |
508
+ | Wide | > 1440px | Same as desktop, content fixed at 1440px; gutters absorb the rest |
509
+
510
+ ### Touch Targets
511
+ - `{component.button-primary}` minimum 48 × 48px — above WCAG AAA (44 × 44).
512
+ - `{component.text-input}` height 48px.
513
+ - Category tabs run with 12px vertical padding, giving an effective tap area > 44px.
514
+
515
+ ### Collapsing Strategy
516
+ - The top nav collapses to a hamburger below 768px; the menu opens as a full-screen sheet.
517
+ - The hero band's internal layout drops to a single column.
518
+ - Model card grid 4-up/5-up → 2-up → 1-up.
519
+ - The configurator filter chip row scrolls horizontally on mobile.
520
+ - The M tricolor stripe stays at 4px height across every breakpoint.
521
+
522
+ ### Image Behavior
523
+ - Model renders scale at every breakpoint while preserving native aspect ratios.
524
+ - Hero photography may shift to a more vertical crop on mobile (art direction).
525
+ - Inventory vehicle photos may move from 16:9 to 4:3 on mobile.
526
+
527
+ ## Iteration Guide
528
+
529
+ 1. Focus on a single component. Reference its YAML key directly (`{component.model-card}`, `{component.button-primary}`).
530
+ 2. New components default to `{rounded.none}` (0px). Use `{rounded.full}` only for circular icon buttons.
531
+ 3. Variants (`-active`, `-disabled`, `-selected`) live as separate entries inside the `components:` block.
532
+ 4. `{token.refs}` everywhere — never inline hex.
533
+ 5. Hover state is never documented. Only Default and Active/Pressed states.
534
+ 6. Display headlines stay BMW Type Next Latin 700; body stays Light 300; the trio is fixed.
535
+ 7. Keep UI strings in a single language — match the locale of the page.
536
+
537
+ ## Known Gaps
538
+
539
+ - BMW Type Next Latin is licensed to BMW and not published as a public web font; Inter at weights 700/300 is documented as the substitute.
540
+ - Animation and transition timings (configurator color swap, model card hover-reveal) are out of scope here.
541
+ - Form validation states beyond `{component.text-input}` focus were not extracted — error/success states would need a dedicated form page.
542
+ - The dealer inventory sub-domain shares typography and color with the main corporate site; only UI density rises (filters, tables, prices).
543
+ - A cookie consent overlay can occlude part of the hero — the lead hero band content may not be fully captured.
544
+ - The M tricolor stripe appears infrequently on this corporate site; full motorsport context lives on the BMW M site.
@@ -0,0 +1,5 @@
1
+ # Bmw Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/bmw/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.