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,526 @@
1
+ ---
2
+ version: alpha
3
+ name: Expo
4
+ description: A React Native developer-platform whose marketing site reads like a quietly-confident infrastructure brand. The base canvas is pure white with a soft sky-blue gradient atmospheric wash behind the hero; near-black ink (`#171717`) carries body and display alike. The single brand voltage is **pure black** (`#000000`) for primary CTAs — minimal and editorial-feeling, paired with a small blue text-link accent (`#0d74ce`) reserved for inline body links. Type pairs Inter at modest weights (display 600, body 400) with JetBrains Mono on every code surface. The brand's strongest visual signature is the **device-mockup hero** — a centered MacBook + iPhone composite showing real Expo dev surfaces — over the gradient sky wash.
5
+
6
+ colors:
7
+ primary: "#000000"
8
+ primary-active: "#1a1a1a"
9
+ text-link: "#0d74ce"
10
+ text-link-secondary: "#476cff"
11
+ ink: "#171717"
12
+ body: "#60646c"
13
+ body-strong: "#171717"
14
+ muted: "#999999"
15
+ muted-soft: "#cccccc"
16
+ hairline: "#f0f0f3"
17
+ hairline-soft: "#f5f5f7"
18
+ hairline-strong: "#dcdee0"
19
+ canvas: "#ffffff"
20
+ canvas-soft: "#fafafa"
21
+ surface-card: "#ffffff"
22
+ surface-strong: "#f0f0f3"
23
+ surface-dark: "#171717"
24
+ surface-dark-elevated: "#1a1a1a"
25
+ on-primary: "#ffffff"
26
+ on-dark: "#ffffff"
27
+ on-dark-soft: "#b0b4ba"
28
+ gradient-sky-light: "#cfe7ff"
29
+ gradient-sky-mid: "#a8c8e8"
30
+ accent-warning: "#ab6400"
31
+ accent-preview: "#8145b5"
32
+ accent-link-bright: "#47c2ff"
33
+ semantic-error: "#eb8e90"
34
+ semantic-success: "#16a34a"
35
+
36
+ typography:
37
+ display-mega:
38
+ fontFamily: "'Inter', -apple-system, system-ui, sans-serif"
39
+ fontSize: 64px
40
+ fontWeight: 600
41
+ lineHeight: 1.05
42
+ letterSpacing: -1.92px
43
+ display-xl:
44
+ fontFamily: "'Inter', sans-serif"
45
+ fontSize: 48px
46
+ fontWeight: 600
47
+ lineHeight: 1.1
48
+ letterSpacing: -1.44px
49
+ display-lg:
50
+ fontFamily: "'Inter', sans-serif"
51
+ fontSize: 36px
52
+ fontWeight: 600
53
+ lineHeight: 1.15
54
+ letterSpacing: -1.08px
55
+ display-md:
56
+ fontFamily: "'Inter', sans-serif"
57
+ fontSize: 28px
58
+ fontWeight: 600
59
+ lineHeight: 1.2
60
+ letterSpacing: -0.84px
61
+ display-sm:
62
+ fontFamily: "'Inter', sans-serif"
63
+ fontSize: 22px
64
+ fontWeight: 600
65
+ lineHeight: 1.25
66
+ letterSpacing: -0.5px
67
+ title-md:
68
+ fontFamily: "'Inter', sans-serif"
69
+ fontSize: 18px
70
+ fontWeight: 600
71
+ lineHeight: 1.4
72
+ letterSpacing: 0
73
+ title-sm:
74
+ fontFamily: "'Inter', sans-serif"
75
+ fontSize: 16px
76
+ fontWeight: 600
77
+ lineHeight: 1.4
78
+ letterSpacing: 0
79
+ body-md:
80
+ fontFamily: "'Inter', sans-serif"
81
+ fontSize: 16px
82
+ fontWeight: 400
83
+ lineHeight: 1.5
84
+ letterSpacing: 0
85
+ body-sm:
86
+ fontFamily: "'Inter', sans-serif"
87
+ fontSize: 14px
88
+ fontWeight: 400
89
+ lineHeight: 1.5
90
+ letterSpacing: 0
91
+ caption:
92
+ fontFamily: "'Inter', sans-serif"
93
+ fontSize: 13px
94
+ fontWeight: 400
95
+ lineHeight: 1.4
96
+ letterSpacing: 0
97
+ caption-uppercase:
98
+ fontFamily: "'Inter', sans-serif"
99
+ fontSize: 11px
100
+ fontWeight: 600
101
+ lineHeight: 1.4
102
+ letterSpacing: 0.88px
103
+ textTransform: uppercase
104
+ code:
105
+ fontFamily: "'JetBrains Mono', 'Fira Code', monospace"
106
+ fontSize: 13px
107
+ fontWeight: 400
108
+ lineHeight: 1.5
109
+ letterSpacing: 0
110
+ button:
111
+ fontFamily: "'Inter', sans-serif"
112
+ fontSize: 14px
113
+ fontWeight: 500
114
+ lineHeight: 1.0
115
+ letterSpacing: 0
116
+ nav-link:
117
+ fontFamily: "'Inter', sans-serif"
118
+ fontSize: 14px
119
+ fontWeight: 500
120
+ lineHeight: 1.4
121
+ letterSpacing: 0
122
+
123
+ rounded:
124
+ none: 0px
125
+ xs: 4px
126
+ sm: 6px
127
+ md: 8px
128
+ lg: 12px
129
+ xl: 16px
130
+ xxl: 24px
131
+ pill: 9999px
132
+ full: 9999px
133
+
134
+ spacing:
135
+ xxs: 4px
136
+ xs: 8px
137
+ sm: 12px
138
+ base: 16px
139
+ md: 20px
140
+ lg: 24px
141
+ xl: 32px
142
+ xxl: 48px
143
+ section: 96px
144
+
145
+ components:
146
+ top-nav:
147
+ backgroundColor: "{colors.canvas}"
148
+ textColor: "{colors.ink}"
149
+ typography: "{typography.nav-link}"
150
+ height: 64px
151
+ button-primary:
152
+ backgroundColor: "{colors.primary}"
153
+ textColor: "{colors.on-primary}"
154
+ typography: "{typography.button}"
155
+ rounded: "{rounded.md}"
156
+ padding: 10px 18px
157
+ height: 40px
158
+ button-primary-active:
159
+ backgroundColor: "{colors.primary-active}"
160
+ textColor: "{colors.on-primary}"
161
+ rounded: "{rounded.md}"
162
+ button-secondary:
163
+ backgroundColor: "{colors.surface-card}"
164
+ textColor: "{colors.ink}"
165
+ typography: "{typography.button}"
166
+ rounded: "{rounded.md}"
167
+ padding: 9px 17px
168
+ height: 40px
169
+ button-tertiary-text:
170
+ backgroundColor: transparent
171
+ textColor: "{colors.text-link}"
172
+ typography: "{typography.button}"
173
+ hero-band:
174
+ backgroundColor: "{colors.canvas}"
175
+ textColor: "{colors.ink}"
176
+ typography: "{typography.display-mega}"
177
+ padding: 96px
178
+ device-mockup-card:
179
+ backgroundColor: "{colors.surface-card}"
180
+ textColor: "{colors.ink}"
181
+ rounded: "{rounded.xl}"
182
+ padding: 0
183
+ feature-card:
184
+ backgroundColor: "{colors.surface-card}"
185
+ textColor: "{colors.ink}"
186
+ typography: "{typography.title-md}"
187
+ rounded: "{rounded.lg}"
188
+ padding: 24px
189
+ feature-card-dark:
190
+ backgroundColor: "{colors.surface-dark}"
191
+ textColor: "{colors.on-dark}"
192
+ typography: "{typography.title-md}"
193
+ rounded: "{rounded.lg}"
194
+ padding: 24px
195
+ workflow-step-card:
196
+ backgroundColor: "{colors.surface-card}"
197
+ textColor: "{colors.body}"
198
+ typography: "{typography.body-md}"
199
+ rounded: "{rounded.lg}"
200
+ padding: 20px
201
+ workflow-step-icon:
202
+ backgroundColor: "{colors.surface-strong}"
203
+ rounded: "{rounded.md}"
204
+ size: 32px
205
+ code-block:
206
+ backgroundColor: "{colors.surface-dark}"
207
+ textColor: "{colors.on-dark}"
208
+ typography: "{typography.code}"
209
+ rounded: "{rounded.lg}"
210
+ padding: 20px
211
+ ide-mockup-card:
212
+ backgroundColor: "{colors.surface-dark}"
213
+ textColor: "{colors.on-dark}"
214
+ rounded: "{rounded.lg}"
215
+ padding: 0
216
+ pricing-tier-card:
217
+ backgroundColor: "{colors.surface-card}"
218
+ textColor: "{colors.ink}"
219
+ typography: "{typography.body-md}"
220
+ rounded: "{rounded.lg}"
221
+ padding: 32px
222
+ pricing-tier-featured:
223
+ backgroundColor: "{colors.surface-dark}"
224
+ textColor: "{colors.on-dark}"
225
+ typography: "{typography.body-md}"
226
+ rounded: "{rounded.lg}"
227
+ padding: 32px
228
+ text-input:
229
+ backgroundColor: "{colors.surface-card}"
230
+ textColor: "{colors.ink}"
231
+ typography: "{typography.body-md}"
232
+ rounded: "{rounded.md}"
233
+ padding: 12px 16px
234
+ height: 44px
235
+ badge-pill:
236
+ backgroundColor: "{colors.surface-strong}"
237
+ textColor: "{colors.ink}"
238
+ typography: "{typography.caption-uppercase}"
239
+ rounded: "{rounded.pill}"
240
+ padding: 4px 10px
241
+ ecosystem-tile:
242
+ backgroundColor: "{colors.surface-card}"
243
+ rounded: "{rounded.md}"
244
+ size: 64px
245
+ cta-band:
246
+ backgroundColor: "{colors.canvas}"
247
+ textColor: "{colors.ink}"
248
+ typography: "{typography.display-lg}"
249
+ padding: 96px
250
+ testimonial-card:
251
+ backgroundColor: "{colors.surface-card}"
252
+ textColor: "{colors.body}"
253
+ typography: "{typography.body-md}"
254
+ rounded: "{rounded.lg}"
255
+ padding: 24px
256
+ footer-light:
257
+ backgroundColor: "{colors.canvas}"
258
+ textColor: "{colors.body}"
259
+ typography: "{typography.body-sm}"
260
+ padding: 64px 48px
261
+ footer-link:
262
+ backgroundColor: transparent
263
+ textColor: "{colors.body}"
264
+ typography: "{typography.body-sm}"
265
+ ---
266
+
267
+ ## Overview
268
+
269
+ Expo's marketing site reads like a quietly-confident React-Native developer platform. The base canvas is **pure white** (`{colors.canvas}` — #ffffff) with a soft **sky-blue gradient atmospheric wash** behind the hero band. Near-black ink `{colors.ink}` (#171717) carries body and display alike. The single brand voltage is **pure black** (`{colors.primary}` — #000000) for primary CTAs — minimal and editorial-feeling. A small blue text-link accent (`{colors.text-link}` — #0d74ce) is reserved for inline body links, never as a CTA.
270
+
271
+ Type runs **Inter** as the single sans family at modest weights (display 600, body 400). JetBrains Mono carries every code surface. No custom typeface — the brand trusts Inter's editorial neutrality.
272
+
273
+ The brand's strongest visual signature is the **device-mockup hero** — a centered MacBook + iPhone composite showing real Expo dev surfaces (Expo Studio, EAS Build dashboard, the Expo Go simulator) — over a sky-blue gradient atmospheric wash. The composite is the page's chrome instead of an illustration.
274
+
275
+ **Key Characteristics:**
276
+ - Pure white canvas with sky-blue gradient atmospheric backdrop in hero only.
277
+ - Single primary CTA: pure black pill at `{rounded.md}` (8px) — compact developer-tool dialect.
278
+ - Text-link blue (`{colors.text-link}`) for inline links only — never on a CTA.
279
+ - Inter as the single sans family — no custom display typeface.
280
+ - JetBrains Mono on every code surface.
281
+ - Device-mockup hero with real Expo product surfaces is the brand chrome.
282
+ - Hairline + soft drop depth; no atmospheric brand decoration outside the hero.
283
+ - 96px section rhythm.
284
+
285
+ ## Colors
286
+
287
+ ### Brand & Accent
288
+ - **Black** (`{colors.primary}` — #000000): Primary CTA fill. Used scarcely.
289
+ - **Black Active** (`{colors.primary-active}` — #1a1a1a): Press state.
290
+ - **Text Link Blue** (`{colors.text-link}` — #0d74ce): Inline body links inside long-form copy. Scoped narrowly — never on CTAs.
291
+ - **Legal Link Blue** (`{colors.text-link-secondary}` — #476cff): Inline links inside legal copy footer.
292
+ - **Bright Cyan** (`{colors.accent-link-bright}` — #47c2ff): Used very sparingly inside docs widget links.
293
+
294
+ ### Surface
295
+ - **Canvas** (`{colors.canvas}` — #ffffff): Pure white page floor.
296
+ - **Canvas Soft** (`{colors.canvas-soft}` — #fafafa): Subtle alternating band.
297
+ - **Surface Card** (`{colors.surface-card}` — #ffffff): Pure white card.
298
+ - **Surface Strong** (`{colors.surface-strong}` — #f0f0f3): Badges, ecosystem tiles, secondary buttons.
299
+ - **Surface Dark** (`{colors.surface-dark}` — #171717): Dark feature cards, code blocks, IDE mockups, featured pricing.
300
+ - **Surface Dark Elevated** (`{colors.surface-dark-elevated}` — #1a1a1a): One step lighter inside dark cards.
301
+
302
+ ### Atmospheric Backdrop
303
+ - **Sky Light** (`{colors.gradient-sky-light}` — #cfe7ff) + **Sky Mid** (`{colors.gradient-sky-mid}` — #a8c8e8): The soft sky-blue gradient wash behind the homepage hero only. Not a brand action color.
304
+
305
+ ### Hairlines
306
+ - **Hairline** (`{colors.hairline}` — #f0f0f3): Default 1px divider.
307
+ - **Hairline Soft** (`{colors.hairline-soft}` — #f5f5f7): Lighter divider.
308
+ - **Hairline Strong** (`{colors.hairline-strong}` — #dcdee0): Stronger panel outline.
309
+
310
+ ### Text
311
+ - **Ink** (`{colors.ink}` — #171717): Display, body emphasis.
312
+ - **Body** (`{colors.body}` — #60646c): Default running-text — slightly cool gray.
313
+ - **Body Strong** (`{colors.body-strong}` — #171717): Same as ink.
314
+ - **Muted** (`{colors.muted}` — #999999): Sub-titles.
315
+ - **Muted Soft** (`{colors.muted-soft}` — #cccccc): Disabled text.
316
+ - **On Primary** (`{colors.on-primary}` — #ffffff): White text on black CTA.
317
+ - **On Dark** (`{colors.on-dark}` — #ffffff): White text on dark cards.
318
+ - **On Dark Soft** (`{colors.on-dark-soft}` — #b0b4ba): Muted off-white on dark.
319
+
320
+ ### Semantic
321
+ - **Warning** (`{colors.accent-warning}` — #ab6400): Warning text inside docs callouts.
322
+ - **Preview** (`{colors.accent-preview}` — #8145b5): "Preview" tag color.
323
+ - **Success** (`{colors.semantic-success}` — #16a34a): Confirmation.
324
+ - **Error** (`{colors.semantic-error}` — #eb8e90): Validation errors.
325
+
326
+ ## Typography
327
+
328
+ ### Font Family
329
+ **Inter** is the single sans family across every text role. **JetBrains Mono** carries every code surface. Fallback: `-apple-system, system-ui, sans-serif`.
330
+
331
+ ### Hierarchy
332
+
333
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
334
+ |---|---|---|---|---|---|
335
+ | `{typography.display-mega}` | 64px | 600 | 1.05 | -1.92px | Homepage hero h1 |
336
+ | `{typography.display-xl}` | 48px | 600 | 1.1 | -1.44px | Subsidiary heroes |
337
+ | `{typography.display-lg}` | 36px | 600 | 1.15 | -1.08px | Section heads |
338
+ | `{typography.display-md}` | 28px | 600 | 1.2 | -0.84px | Sub-section heads |
339
+ | `{typography.display-sm}` | 22px | 600 | 1.25 | -0.5px | Card group titles |
340
+ | `{typography.title-md}` | 18px | 600 | 1.4 | 0 | Component titles |
341
+ | `{typography.title-sm}` | 16px | 600 | 1.4 | 0 | List labels |
342
+ | `{typography.body-md}` | 16px | 400 | 1.5 | 0 | Default body |
343
+ | `{typography.body-sm}` | 14px | 400 | 1.5 | 0 | Footer body |
344
+ | `{typography.caption}` | 13px | 400 | 1.4 | 0 | Photo captions |
345
+ | `{typography.caption-uppercase}` | 11px | 600 | 1.4 | 0.88px | Section labels, badges |
346
+ | `{typography.code}` | 13px | 400 | 1.5 | 0 | Code blocks — JetBrains Mono |
347
+ | `{typography.button}` | 14px | 500 | 1.0 | 0 | CTA labels |
348
+ | `{typography.nav-link}` | 14px | 500 | 1.4 | 0 | Top-nav menu |
349
+
350
+ ### Principles
351
+ - **Display weight stays at 600** — confident but not bombastic. Inter at 600 reads cleaner than 700.
352
+ - **Negative letter-spacing on display** — -0.5px to -1.92px tracking.
353
+ - **JetBrains Mono on every code surface.**
354
+
355
+ ### Note on Font Substitutes
356
+ Inter and JetBrains Mono are both freely available — the system uses them directly.
357
+
358
+ ## Layout
359
+
360
+ ### Spacing System
361
+ - **Base unit:** 4px.
362
+ - **Tokens:** `{spacing.xxs}` 4px · `{spacing.xs}` 8px · `{spacing.sm}` 12px · `{spacing.base}` 16px · `{spacing.md}` 20px · `{spacing.lg}` 24px · `{spacing.xl}` 32px · `{spacing.xxl}` 48px · `{spacing.section}` 96px.
363
+ - **Section padding:** 96px.
364
+
365
+ ### Grid & Container
366
+ - Max content width: ~1200px.
367
+ - Editorial body: 12-column grid.
368
+ - Feature card grids: 2-up at desktop for hero splits, 3-up for benefit grids.
369
+ - Ecosystem tile grid: 8-up at desktop.
370
+ - Footer: 5-column at desktop.
371
+
372
+ ### Whitespace Philosophy
373
+ Generous editorial pacing. The white canvas does not compete with the hero's gradient sky wash; cards inside dense workflow sections sit close (16-24px gap).
374
+
375
+ ## Elevation & Depth
376
+
377
+ | Level | Treatment | Use |
378
+ |---|---|---|
379
+ | Flat (canvas) | `{colors.canvas}` (#ffffff) | Body bands, footer |
380
+ | Card | `{colors.surface-card}` (#ffffff) | Content cards |
381
+ | Hairline border | 1px `{colors.hairline}` | Card outlines |
382
+ | Soft drop | `0 4px 12px rgba(0, 0, 0, 0.04)` | Hovered cards (single shadow tier) |
383
+ | Atmospheric gradient | Sky-blue radial wash | Hero backdrop only |
384
+ | Dark inversion | `{colors.surface-dark}` (#171717) | Dark feature cards, code blocks, featured pricing |
385
+
386
+ ### Decorative Depth
387
+ - **Sky-blue gradient backdrop** in the hero only — atmospheric depth without claiming to be a brand color.
388
+ - **Device mockup composite** as page chrome — MacBook + iPhone showing real Expo dev surfaces.
389
+
390
+ ## Shapes
391
+
392
+ ### Border Radius Scale
393
+
394
+ | Token | Value | Use |
395
+ |---|---|---|
396
+ | `{rounded.none}` | 0px | Reserved |
397
+ | `{rounded.xs}` | 4px | Inline tags |
398
+ | `{rounded.sm}` | 6px | Compact rows |
399
+ | `{rounded.md}` | 8px | CTA buttons, form inputs, ecosystem tiles |
400
+ | `{rounded.lg}` | 12px | Feature cards, code blocks, pricing tiers |
401
+ | `{rounded.xl}` | 16px | Device mockup cards |
402
+ | `{rounded.xxl}` | 24px | Larger atmospheric cards (rare) |
403
+ | `{rounded.pill}` | 9999px | Badges only |
404
+ | `{rounded.full}` | 9999px | Avatar plates (rare) |
405
+
406
+ Compact developer-ergonomic radii — 8px CTAs, 12px cards. Pill geometry is reserved for badges, never CTAs.
407
+
408
+ ## Components
409
+
410
+ ### Top Navigation
411
+
412
+ **`top-nav`** — Background `{colors.canvas}`, text `{colors.ink}`, height 64px. Layout: Expo wordmark left, primary horizontal menu (Tools / Workflows / EAS / Pricing / Docs / Showcase), Sign In + Get started CTA right.
413
+
414
+ ### Buttons
415
+
416
+ **`button-primary`** — Pure black pill. Background `{colors.primary}`, text `{colors.on-primary}`, type `{typography.button}` (14px / 500), padding 10px × 18px, height 40px, rounded `{rounded.md}` (8px).
417
+
418
+ **`button-primary-active`** — Press state. Background `{colors.primary-active}`.
419
+
420
+ **`button-secondary`** — White card with 1px hairline-strong border. Background `{colors.surface-card}`, text `{colors.ink}`, 1px `{colors.hairline-strong}` border.
421
+
422
+ **`button-tertiary-text`** — Inline blue text link. Background transparent, text `{colors.text-link}`.
423
+
424
+ ### Hero & Device Mockup
425
+
426
+ **`hero-band`** — Background `{colors.canvas}` with a soft sky-blue gradient wash behind the centered headline. Display headline in `{typography.display-mega}` (64px / 600 / -1.92px), subhead in `{typography.body-md}`, single primary CTA, then below — the device mockup composite.
427
+
428
+ **`device-mockup-card`** — A layered MacBook + iPhone composite showing real Expo dev surfaces. Background `{colors.surface-card}`, rounded `{rounded.xl}`. The MacBook holds the EAS dashboard or Expo Studio screenshot; the iPhone overlay shows the running app in Expo Go. This is the page chrome.
429
+
430
+ ### Cards
431
+
432
+ **`feature-card`** — Background `{colors.surface-card}`, text `{colors.ink}`, type `{typography.title-md}`, rounded `{rounded.lg}`, padding 24px, 1px `{colors.hairline-strong}` border.
433
+
434
+ **`feature-card-dark`** — Dark variant. Background `{colors.surface-dark}`, text `{colors.on-dark}`. Same shape, dark inversion.
435
+
436
+ **`workflow-step-card`** — Step in the "Get your app on every device" workflow row. Background `{colors.surface-card}`, text `{colors.body}`, rounded `{rounded.lg}`, padding 20px. Layout: 32px square `{component.workflow-step-icon}` + step number + label + body.
437
+
438
+ **`workflow-step-icon`** — Square plate. Background `{colors.surface-strong}`, rounded `{rounded.md}`, 32px size.
439
+
440
+ **`testimonial-card`** — Quote card. Background `{colors.surface-card}`, text `{colors.body}`, rounded `{rounded.lg}`, padding 24px.
441
+
442
+ ### Code & IDE
443
+
444
+ **`code-block`** — Inline code block. Background `{colors.surface-dark}`, text `{colors.on-dark}` in `{typography.code}` (JetBrains Mono 13px), rounded `{rounded.lg}`, padding 20px. White text on dark.
445
+
446
+ **`ide-mockup-card`** — Stylized IDE mockup. Background `{colors.surface-dark}`, rounded `{rounded.lg}`. Multi-pane editor + terminal preview.
447
+
448
+ ### Pricing
449
+
450
+ **`pricing-tier-card`** — Standard pricing tier. Background `{colors.surface-card}`, rounded `{rounded.lg}`, padding 32px, 1px `{colors.hairline-strong}` border.
451
+
452
+ **`pricing-tier-featured`** — Featured tier. Background `{colors.surface-dark}`, text `{colors.on-dark}`. Same shape, dark inversion.
453
+
454
+ ### Ecosystem
455
+
456
+ **`ecosystem-tile`** — Square logo plate for ecosystem partner logos (TypeScript, React, Sentry, etc.). Background `{colors.surface-card}`, rounded `{rounded.md}`, 64px size, 1px `{colors.hairline}` border.
457
+
458
+ ### Forms & Tags
459
+
460
+ **`text-input`** — Background `{colors.surface-card}`, text `{colors.ink}`, rounded `{rounded.md}` (8px), padding 12px × 16px, height 44px, 1px `{colors.hairline-strong}` border. Focus thickens border to 2px ink.
461
+
462
+ **`badge-pill`** — Small uppercase pill. Background `{colors.surface-strong}`, text `{colors.ink}`, type `{typography.caption-uppercase}`, rounded `{rounded.pill}`, padding 4px × 10px.
463
+
464
+ ### CTA / Footer
465
+
466
+ **`cta-band`** — Pre-footer band. Background `{colors.canvas}`, centered display headline in `{typography.display-lg}`, single black pill CTA. 96px padding.
467
+
468
+ **`footer-light`** — Closing white footer. Background `{colors.canvas}`, text `{colors.body}`. 5-column link list. 64×48px padding.
469
+
470
+ **`footer-link`** — Background transparent, text `{colors.body}`, type `{typography.body-sm}`.
471
+
472
+ ## Do's and Don'ts
473
+
474
+ ### Do
475
+ - Reserve `{colors.primary}` (black) for primary CTAs.
476
+ - Use `{colors.text-link}` (blue) for inline body links only — never on CTAs or buttons.
477
+ - Set every CTA at `{rounded.md}` (8px) — developer dialect.
478
+ - Use Inter at weight 600 for display, 400 for body.
479
+ - Render every code surface in JetBrains Mono.
480
+ - Pair the hero with the device-mockup composite — it's the page chrome.
481
+
482
+ ### Don't
483
+ - Don't introduce a saturated brand action color. Black is the only CTA fill.
484
+ - Don't use blue (`{colors.text-link}`) on a CTA. Inline links only.
485
+ - Don't drop display below weight 600 or above 700.
486
+ - Don't use full pills on CTAs — pills are for badges only.
487
+ - Don't replicate the sky-blue gradient backdrop outside the hero.
488
+ - Don't extract a CTA color from a third-party widget (cookie consent, OneTrust). The brand's CTA is what appears on actual page CTAs.
489
+
490
+ ## Responsive Behavior
491
+
492
+ ### Breakpoints
493
+
494
+ | Name | Width | Key Changes |
495
+ |---|---|---|
496
+ | Mobile | < 640px | Hero h1 64→32px; device mockup → single iPhone screen; feature grid 1-up; nav hamburger. |
497
+ | Tablet | 640–1024px | Hero h1 48px; device mockup compresses; feature grid 2-up. |
498
+ | Desktop | 1024–1280px | Full hero h1 64px; full MacBook + iPhone composite; feature grid 3-up. |
499
+ | Wide | > 1280px | Content caps at 1200px. |
500
+
501
+ ### Touch Targets
502
+ - Primary CTA at 40px height — at WCAG AA, padded for AAA.
503
+ - Search input 44px — at AAA.
504
+
505
+ ### Collapsing Strategy
506
+ - Top nav switches to hamburger below 768px.
507
+ - Device mockup MacBook + iPhone collapses to a single iPhone preview on mobile.
508
+ - Feature grid: 3-up → 2-up → 1-up.
509
+ - Ecosystem tile grid: 8-up → 4-up → 3-up → 2-up.
510
+
511
+ ## Iteration Guide
512
+
513
+ 1. Focus on a single component at a time.
514
+ 2. CTAs default to `{rounded.md}` (8px). Cards use `{rounded.lg}` (12px).
515
+ 3. Variants live as separate entries.
516
+ 4. Use `{token.refs}` everywhere — never inline hex.
517
+ 5. Hover state never documented.
518
+ 6. Inter 600 for display, Inter 400 for body. JetBrains Mono on code.
519
+ 7. Black stays the only CTA color; text-link blue stays inline-only.
520
+
521
+ ## Known Gaps
522
+
523
+ - Inter and JetBrains Mono are freely available — no licensing concerns.
524
+ - Animation timings (device mockup parallax, hero entrance) out of scope.
525
+ - In-app surfaces (EAS dashboard interactive, Expo Go simulator) only partially captured via marketing mockups.
526
+ - Form validation states beyond focus not visible on captured surfaces.
@@ -0,0 +1,5 @@
1
+ # Expo Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/expo/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.