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,516 @@
1
+ ---
2
+ version: alpha
3
+ name: Shopifi Inspired
4
+ description: An inspired interpretation of Shopifi's design language — a cinematic commerce platform that runs two parallel design tracks. The marketing-hero and product-narrative pages live on near-black canvases with full-bleed photography of merchants, giant Neue Haas Grotesk display type at thin weights, and a single black-pill CTA stroked in white. The transactional pages (pricing, signup, dashboards) flip to a cream-mint canvas with pastel aloe and pistachio greens, the same pill button vocabulary, and Inter for UI body. The two tracks share typographic DNA but diverge sharply in canvas polarity — and that choice is the brand.
5
+
6
+ colors:
7
+ primary: "#000000"
8
+ ink: "#000000"
9
+ on-primary: "#ffffff"
10
+ on-dark: "#ffffff"
11
+ canvas-night: "#000000"
12
+ canvas-night-elevated: "#0a0a0a"
13
+ canvas-light: "#ffffff"
14
+ canvas-cream: "#fbfbf5"
15
+ surface-elevated-dark: "#1e2c31"
16
+ shade-30: "#d4d4d8"
17
+ shade-40: "#a1a1aa"
18
+ shade-50: "#71717a"
19
+ shade-60: "#52525b"
20
+ shade-70: "#3f3f46"
21
+ hairline-light: "#e4e4e7"
22
+ hairline-dark: "#1e2c31"
23
+ aloe-10: "#c1fbd4"
24
+ pistachio-10: "#d4f9e0"
25
+ link-cool-1: "#9dabad"
26
+ link-cool-2: "#9797a2"
27
+ link-cool-3: "#bdbdca"
28
+ link-mint: "#99b3ad"
29
+
30
+ typography:
31
+ display-xxl:
32
+ fontFamily: "NeueHaasGrotesk Display, Helvetica, Arial, sans-serif"
33
+ fontSize: 96px
34
+ fontWeight: 330
35
+ lineHeight: 1.0
36
+ letterSpacing: 2.4px
37
+ fontFeature: ss03
38
+ display-xl:
39
+ fontFamily: "NeueHaasGrotesk Display, Helvetica, Arial, sans-serif"
40
+ fontSize: 70px
41
+ fontWeight: 330
42
+ lineHeight: 1.0
43
+ letterSpacing: 0
44
+ fontFeature: ss03
45
+ display-lg:
46
+ fontFamily: "NeueHaasGrotesk Display, Helvetica, Arial, sans-serif"
47
+ fontSize: 55px
48
+ fontWeight: 330
49
+ lineHeight: 1.16
50
+ letterSpacing: 0
51
+ fontFeature: ss03
52
+ display-md:
53
+ fontFamily: "NeueHaasGrotesk Display, Helvetica, Arial, sans-serif"
54
+ fontSize: 48px
55
+ fontWeight: 330
56
+ lineHeight: 1.14
57
+ letterSpacing: 0
58
+ fontFeature: ss03
59
+ heading-xl:
60
+ fontFamily: "NeueHaasGrotesk Display, Helvetica, Arial, sans-serif"
61
+ fontSize: 28px
62
+ fontWeight: 500
63
+ lineHeight: 1.28
64
+ letterSpacing: 0.42px
65
+ fontFeature: ss03
66
+ heading-lg:
67
+ fontFamily: "NeueHaasGrotesk Display, Helvetica, Arial, sans-serif"
68
+ fontSize: 24px
69
+ fontWeight: 400
70
+ lineHeight: 1.14
71
+ letterSpacing: 0.36px
72
+ fontFeature: ss03
73
+ heading-md:
74
+ fontFamily: "NeueHaasGrotesk Display, Helvetica, Arial, sans-serif"
75
+ fontSize: 20px
76
+ fontWeight: 500
77
+ lineHeight: 1.4
78
+ letterSpacing: 0.3px
79
+ fontFeature: ss03
80
+ heading-sm:
81
+ fontFamily: "NeueHaasGrotesk Display, Helvetica, Arial, sans-serif"
82
+ fontSize: 18px
83
+ fontWeight: 500
84
+ lineHeight: 1.25
85
+ letterSpacing: 0.72px
86
+ fontFeature: ss03
87
+ body-lg:
88
+ fontFamily: "Inter Variable, Inter, Helvetica, Arial, sans-serif"
89
+ fontSize: 18px
90
+ fontWeight: 550
91
+ lineHeight: 1.56
92
+ letterSpacing: 0
93
+ fontFeature: ss03
94
+ body-md:
95
+ fontFamily: "Inter Variable, Inter, Helvetica, Arial, sans-serif"
96
+ fontSize: 16px
97
+ fontWeight: 420
98
+ lineHeight: 1.5
99
+ letterSpacing: 0
100
+ fontFeature: ss03
101
+ body-strong:
102
+ fontFamily: "Inter Variable, Inter, Helvetica, Arial, sans-serif"
103
+ fontSize: 16px
104
+ fontWeight: 550
105
+ lineHeight: 1.5
106
+ letterSpacing: 0
107
+ fontFeature: ss03
108
+ caption:
109
+ fontFamily: "Inter Variable, Inter, Helvetica, Arial, sans-serif"
110
+ fontSize: 14px
111
+ fontWeight: 500
112
+ lineHeight: 1.49
113
+ letterSpacing: 0.28px
114
+ fontFeature: ss03
115
+ micro:
116
+ fontFamily: "Inter Variable, Inter, Helvetica, Arial, sans-serif"
117
+ fontSize: 13px
118
+ fontWeight: 500
119
+ lineHeight: 1.5
120
+ letterSpacing: -0.13px
121
+ fontFeature: ss03
122
+ eyebrow-cap:
123
+ fontFamily: "Inter Variable, Inter, Helvetica, Arial, sans-serif"
124
+ fontSize: 12px
125
+ fontWeight: 400
126
+ lineHeight: 1.2
127
+ letterSpacing: 0.72px
128
+ fontFeature: ss03
129
+ code:
130
+ fontFamily: "ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace"
131
+ fontSize: 16px
132
+ fontWeight: 400
133
+ lineHeight: 1.5
134
+ letterSpacing: 0
135
+ fontFeature: ss03
136
+
137
+ rounded:
138
+ xs: 4px
139
+ sm: 5px
140
+ md: 8px
141
+ lg: 12px
142
+ xl: 20px
143
+ pill: 9999px
144
+
145
+ spacing:
146
+ xxs: 2px
147
+ xs: 4px
148
+ sm: 8px
149
+ md: 12px
150
+ lg: 16px
151
+ xl: 24px
152
+ xxl: 32px
153
+ huge: 64px
154
+
155
+ components:
156
+ button-primary-pill:
157
+ backgroundColor: "{colors.primary}"
158
+ textColor: "{colors.on-primary}"
159
+ typography: "{typography.body-md}"
160
+ rounded: "{rounded.pill}"
161
+ padding: 12px 24px
162
+ button-primary-pill-pressed:
163
+ backgroundColor: "{colors.shade-70}"
164
+ textColor: "{colors.on-primary}"
165
+ typography: "{typography.body-md}"
166
+ rounded: "{rounded.pill}"
167
+ padding: 12px 24px
168
+ button-outline-on-dark:
169
+ backgroundColor: "{colors.canvas-night}"
170
+ textColor: "{colors.on-primary}"
171
+ typography: "{typography.body-md}"
172
+ rounded: "{rounded.pill}"
173
+ padding: 12px 26px
174
+ button-outline-on-light:
175
+ backgroundColor: "{colors.canvas-light}"
176
+ textColor: "{colors.ink}"
177
+ typography: "{typography.body-md}"
178
+ rounded: "{rounded.pill}"
179
+ padding: 12px 24px
180
+ button-aloe-pill:
181
+ backgroundColor: "{colors.aloe-10}"
182
+ textColor: "{colors.ink}"
183
+ typography: "{typography.body-md}"
184
+ rounded: "{rounded.pill}"
185
+ padding: 12px 24px
186
+ text-input:
187
+ backgroundColor: "{colors.canvas-light}"
188
+ textColor: "{colors.ink}"
189
+ typography: "{typography.body-md}"
190
+ rounded: "{rounded.md}"
191
+ padding: 10px 12px
192
+ card-pricing:
193
+ backgroundColor: "{colors.canvas-light}"
194
+ textColor: "{colors.ink}"
195
+ typography: "{typography.body-md}"
196
+ rounded: "{rounded.lg}"
197
+ padding: 32px
198
+ card-pricing-featured:
199
+ backgroundColor: "{colors.aloe-10}"
200
+ textColor: "{colors.ink}"
201
+ typography: "{typography.body-md}"
202
+ rounded: "{rounded.lg}"
203
+ padding: 32px
204
+ card-feature-cinematic:
205
+ backgroundColor: "{colors.canvas-night-elevated}"
206
+ textColor: "{colors.on-primary}"
207
+ typography: "{typography.body-lg}"
208
+ rounded: "{rounded.lg}"
209
+ padding: 32px
210
+ card-pistachio-band:
211
+ backgroundColor: "{colors.pistachio-10}"
212
+ textColor: "{colors.ink}"
213
+ typography: "{typography.body-md}"
214
+ rounded: "{rounded.lg}"
215
+ padding: 32px
216
+ card-photo-frame:
217
+ backgroundColor: "{colors.canvas-night}"
218
+ textColor: "{colors.on-primary}"
219
+ typography: "{typography.body-md}"
220
+ rounded: "{rounded.xl}"
221
+ padding: 0px
222
+ pill-tag-mint:
223
+ backgroundColor: "{colors.aloe-10}"
224
+ textColor: "{colors.ink}"
225
+ typography: "{typography.eyebrow-cap}"
226
+ rounded: "{rounded.pill}"
227
+ padding: 4px 12px
228
+ pill-tag-shade:
229
+ backgroundColor: "{colors.shade-30}"
230
+ textColor: "{colors.ink}"
231
+ typography: "{typography.eyebrow-cap}"
232
+ rounded: "{rounded.pill}"
233
+ padding: 4px 12px
234
+ nav-bar-light:
235
+ backgroundColor: "{colors.canvas-light}"
236
+ textColor: "{colors.ink}"
237
+ typography: "{typography.body-md}"
238
+ rounded: "{rounded.xs}"
239
+ padding: 16px 24px
240
+ nav-bar-dark:
241
+ backgroundColor: "{colors.canvas-night}"
242
+ textColor: "{colors.on-primary}"
243
+ typography: "{typography.body-md}"
244
+ rounded: "{rounded.xs}"
245
+ padding: 16px 24px
246
+ link-on-dark:
247
+ backgroundColor: "{colors.canvas-night}"
248
+ textColor: "{colors.on-primary}"
249
+ typography: "{typography.body-md}"
250
+ rounded: "{rounded.xs}"
251
+ padding: 0px
252
+ footer-dark:
253
+ backgroundColor: "{colors.canvas-night}"
254
+ textColor: "{colors.on-primary}"
255
+ typography: "{typography.caption}"
256
+ rounded: "{rounded.xs}"
257
+ padding: 64px 24px
258
+ footer-light:
259
+ backgroundColor: "{colors.canvas-light}"
260
+ textColor: "{colors.ink}"
261
+ typography: "{typography.caption}"
262
+ rounded: "{rounded.xs}"
263
+ padding: 64px 24px
264
+ ---
265
+
266
+ ## Overview
267
+
268
+ Shopifi runs two parallel design tracks that share typographic DNA and a single button vocabulary, but diverge in canvas polarity. The marketing track lives on `{colors.canvas-night}` (`#000000`) — full-bleed cinematic photography of merchants, giant `{typography.display-xxl}` headlines in Neue Haas Grotesk Display set at weight 330 (a thin, almost editorial cut), and a single CTA: a white-stroked black pill with the form `button-outline-on-dark`. The pages read like the spread of a high-end print magazine: lots of black, lots of negative space, photography that doesn't compete with text, and one and only one action per band.
269
+
270
+ The transactional track flips to `{colors.canvas-light}` and `{colors.canvas-cream}` (an off-white that's barely warmer than pure white). Pricing tiers, comparison tables, and signup flows sit on this lighter canvas, with the same pill button system but in inverse polarity (a solid black pill with white text, or a `{colors.aloe-10}` mint pill for the featured / "Start free trial" tier). The accents — `{colors.aloe-10}` mint and `{colors.pistachio-10}` pistachio — show up only on the light track, never on the cinematic dark hero pages.
271
+
272
+ Typography is split across three families. **Neue Haas Grotesk Display** at thin weights (330–500) handles every display, headline, and editorial moment — the brand's identity is that thin display cut. **Inter Variable** at 420–550 weights handles every UI body, button label, caption, and form field — utility text that doesn't fight the display. **ui-monospace** appears only in code blocks and rare technical eyebrows. Across all three families, the OpenType `ss03` stylistic set is enabled — it's the brand's character-level signature, applied universally.
273
+
274
+ **Key Characteristics:**
275
+ - Two-canvas system: `{colors.canvas-night}` for cinematic marketing, `{colors.canvas-light}` / `{colors.canvas-cream}` for transactional surfaces — never blended.
276
+ - Pill-shape (`{rounded.pill}`) is the only button shape across both tracks; rounded rectangles do not exist for buttons.
277
+ - Thin-weight (330) display typography is the signature; `{typography.display-xxl}` at 96px / weight 330 is the brand's loudest visual.
278
+ - Aloe and pistachio greens (`{colors.aloe-10}`, `{colors.pistachio-10}`) are reserved for the light track — they signal commerce, growth, transactional success.
279
+ - Photography is full-bleed, edge-to-edge, never inset in cards on the cinematic track; merchants and storefront imagery do the heavy visual lifting that gradients and illustrations would do elsewhere.
280
+ - The OpenType `ss03` stylistic set is enabled across every text role — a character-level unifier that tracks across both tracks.
281
+ - Tight letter-spacing on display sizes (2.4px positive tracking on 96px display) gives the thin weight extra optical air.
282
+
283
+ ## Colors
284
+
285
+ > **Source pages:** home (`/`), `/start`, `/website/builder`, `/pricing`.
286
+
287
+ ### Brand & Accent
288
+ - **Aloe** (`{colors.aloe-10}` — `#c1fbd4`): The featured-tier and "growth" accent. Used as a pill button background on light surfaces and as a feature-card fill in the pricing comparison band.
289
+ - **Pistachio** (`{colors.pistachio-10}` — `#d4f9e0`): Softer than aloe; used as a wide section band fill on the light track to signal a different category of feature without leaving the green family.
290
+ - **Cool Link Tones** (`{colors.link-cool-1}` `#9dabad`, `{colors.link-cool-2}` `#9797a2`, `{colors.link-cool-3}` `#bdbdca`, `{colors.link-mint}` `#99b3ad`): Muted footer / tertiary link colors used on dark surfaces to create a quiet hierarchy below the primary white type.
291
+
292
+ ### Surface
293
+ - **Canvas Night** (`{colors.canvas-night}` — `#000000`): Pure black hero, cinematic feature pages, footer.
294
+ - **Canvas Night Elevated** (`{colors.canvas-night-elevated}` — `#0a0a0a`): Cards on cinematic surfaces, video frames.
295
+ - **Surface Elevated Dark** (`{colors.surface-elevated-dark}` — `#1e2c31`): Dark teal-shifted surface used on a small subset of dark cards to introduce subtle depth without breaking the black.
296
+ - **Canvas Light** (`{colors.canvas-light}` — `#ffffff`): Pricing, signup, comparison tables.
297
+ - **Canvas Cream** (`{colors.canvas-cream}` — `#fbfbf5`): Slightly warm off-white used on the pricing-page background canvas — invisibly different from `#ffffff` but adds editorial warmth.
298
+ - **Hairline Light** (`{colors.hairline-light}` — `#e4e4e7`): 1px borders on light cards, table dividers.
299
+ - **Hairline Dark** (`{colors.hairline-dark}` — `#1e2c31`): 1px borders on the rare dark cards that have visible chrome.
300
+
301
+ ### Shade Ladder
302
+ - **Shade-30** (`{colors.shade-30}` — `#d4d4d8`): Tag / chip background on light, footer hairline on dark.
303
+ - **Shade-40** (`{colors.shade-40}` — `#a1a1aa`): Tertiary text on light, secondary text on dark.
304
+ - **Shade-50** (`{colors.shade-50}` — `#71717a`): Secondary text on light.
305
+ - **Shade-60** (`{colors.shade-60}` — `#52525b`): Tertiary text on light, deep on dark.
306
+ - **Shade-70** (`{colors.shade-70}` — `#3f3f46`): Pressed-state of the primary pill button; deep dark surface accent.
307
+
308
+ ### Text
309
+ - **Ink** (`{colors.ink}` — `#000000`): All text on light canvas.
310
+ - **On Primary** (`{colors.on-primary}` — `#ffffff`): All text on dark canvas + filled-pill labels.
311
+
312
+ ## Typography
313
+
314
+ ### Font Family
315
+
316
+ The display tier is **Neue Haas Grotesk Display** at thin weights (330–500). When unavailable, fall back to **Helvetica** at light weight, then Arial. The thin-weight cut is the brand — no substitution should default to weight 400+.
317
+
318
+ The UI tier is **Inter Variable** at 420–550 — a variable font with sub-weight precision that lets the system span body (420), strong (550), and caption (500) without jumping to heavier tiers. Inter is open-source via Google Fonts.
319
+
320
+ The code tier is **ui-monospace**, the system mono — preferred over a webfont mono to avoid unnecessary downloads.
321
+
322
+ The OpenType `ss03` stylistic set is enabled across every role. It alters specific glyph forms (lowercase `a`, `g`, single-story numerals) for a slightly more geometric character. Apply via `font-feature-settings: "ss03"` on the body element or root.
323
+
324
+ ### Hierarchy
325
+
326
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
327
+ |---|---|---|---|---|---|
328
+ | `{typography.display-xxl}` | 96px | 330 | 1.0 | 2.4px | Cinematic hero headline |
329
+ | `{typography.display-xl}` | 70px | 330 | 1.0 | 0 | Section opener on cinematic pages |
330
+ | `{typography.display-lg}` | 55px | 330 | 1.16 | 0 | Pricing-page page title |
331
+ | `{typography.display-md}` | 48px | 330 | 1.14 | 0 | Sub-section headline on light track |
332
+ | `{typography.heading-xl}` | 28px | 500 | 1.28 | 0.42px | Card title / pricing tier name |
333
+ | `{typography.heading-lg}` | 24px | 400 | 1.14 | 0.36px | Compact card title |
334
+ | `{typography.heading-md}` | 20px | 500 | 1.4 | 0.3px | Section sub-heading |
335
+ | `{typography.heading-sm}` | 18px | 500 | 1.25 | 0.72px | Eyebrow / mini-section label |
336
+ | `{typography.body-lg}` | 18px | 550 | 1.56 | 0 | Marketing body lead, large body |
337
+ | `{typography.body-md}` | 16px | 420 | 1.5 | 0 | Default UI body, pill-button labels |
338
+ | `{typography.body-strong}` | 16px | 550 | 1.5 | 0 | Emphasized body run |
339
+ | `{typography.caption}` | 14px | 500 | 1.49 | 0.28px | Helper copy, footnotes |
340
+ | `{typography.micro}` | 13px | 500 | 1.5 | -0.13px | Pricing fine print |
341
+ | `{typography.eyebrow-cap}` | 12px | 400 | 1.2 | 0.72px | All-caps eyebrow above large headlines |
342
+ | `{typography.code}` | 16px | 400 | 1.5 | 0 | Code blocks |
343
+
344
+ ### Principles
345
+ - **Display thinness is the brand.** Always render display sizes at weight 330 — never 400+. The thinness is a deliberate editorial choice that makes the giant size feel quiet.
346
+ - **Display in NHGD, body in Inter.** Don't push body roles up to NHGD; don't push display roles down to Inter.
347
+ - **Tracking lifts on display.** The 96px hero gets +2.4px positive tracking — the thin glyphs need air. At 70px and below, tracking returns to 0.
348
+
349
+ ### Note on Font Substitutes
350
+ Open substitutes for Neue Haas Grotesk Display: **Helvetica Now Display** (proprietary) or **Inter Display** at light weights (open-source) are the closest matches. Avoid Helvetica Neue at default weight — it's too heavy for the brand's thin tier. **Inter Variable** is open-source via Google Fonts and is the canonical body face — no substitute needed.
351
+
352
+ ## Layout
353
+
354
+ ### Spacing System
355
+ - **Base unit**: 8px (with denser sub-units 1, 2, 3, 4 for fine work).
356
+ - **Tokens**: `{spacing.xxs}` 2px · `{spacing.xs}` 4px · `{spacing.sm}` 8px · `{spacing.md}` 12px · `{spacing.lg}` 16px · `{spacing.xl}` 24px · `{spacing.xxl}` 32px · `{spacing.huge}` 64px.
357
+ - **Section padding**: `{spacing.huge}` 64–128px on cinematic marketing pages (extreme negative space is the point); collapses to ~48px on transactional pages where density takes priority.
358
+ - **Card internal padding**: `{spacing.xxl}` 32px on pricing cards; `{spacing.xl}` 24px on compact tag rows.
359
+
360
+ ### Grid & Container
361
+ - Cinematic hero pages use a wide max-width container (~1440–1600px) with edge-bleeding photography that escapes the container.
362
+ - Pricing collapses through 4-up → 2-up → 1-up tiers based on viewport.
363
+ - Body content centers in a ~720–840px reading column on long-form pages.
364
+
365
+ ### Whitespace Philosophy
366
+ The cinematic track treats whitespace as the brand's most valuable asset — sections often have 128–192px of vertical air between content blocks, with photography filling the rest. The transactional track tightens to ~48–64px between bands because users are scanning, comparing, and acting. The contrast between the two whitespace philosophies is part of the brand voice.
367
+
368
+ ## Elevation & Depth
369
+
370
+ | Level | Treatment | Use |
371
+ |---|---|---|
372
+ | 0 | Flat, no shadow | Default surface |
373
+ | 1 | `0 1px 2px rgba(255,255,255,0.05), inset 0 1px 0 rgba(255,255,255,0.04)` | Subtle inset highlight on dark cards (a top-edge sheen) |
374
+ | 2 | `0 0 0 1px rgba(255,255,255,0.08), 0 1px 3px rgba(0,0,0,0.3), 0 5px 10px rgba(0,0,0,0.2)` | Dark elevated cards with hairline + drop shadow stack |
375
+ | 3 | `0 8px 8px rgba(0,0,0,0.1), 0 4px 4px rgba(0,0,0,0.1), 0 2px 2px rgba(0,0,0,0.1), 0 0 0 1px rgba(0,0,0,0.1)` | Stacked-shadow card on light surfaces; layered tiny shadows produce a soft halo |
376
+ | 4 | `0 25px 50px -12px rgba(0,0,0,0.25)` | Modal / floating panel on light |
377
+
378
+ ### Decorative Depth
379
+ On the cinematic track, depth comes from photography — full-bleed merchant imagery layered behind cards, with subtle inset top-edge highlights creating the illusion of light hitting a glass surface. On the light track, the layered tiny-shadow stack (Level 3) produces a soft, paper-like halo around pricing cards — depth without harshness.
380
+
381
+ ## Shapes
382
+
383
+ ### Border Radius Scale
384
+
385
+ | Token | Value | Use |
386
+ |---|---|---|
387
+ | `{rounded.xs}` | 4px | Inputs, hairline tags |
388
+ | `{rounded.sm}` | 5px | Image containers (small) |
389
+ | `{rounded.md}` | 8px | Form inputs, video frames, smaller cards |
390
+ | `{rounded.lg}` | 12px | Pricing cards, feature cards |
391
+ | `{rounded.xl}` | 20px (top-only on some asymmetric cards) | Hero photo frames, cinematic card chrome |
392
+ | `{rounded.pill}` | 9999px | All buttons, pill tags, mint chips |
393
+
394
+ ### Photography Geometry
395
+ Photography is full-bleed with no border. On cinematic pages it escapes the container entirely; on transactional pages it sits inside `{rounded.lg}` containers with no shadow. Avatar treatments in customer-logo strips are simple greyscale wordmarks at uniform height (~24–32px), aligned in a single horizontal strip.
396
+
397
+ ## Components
398
+
399
+ ### Buttons
400
+
401
+ **`button-primary-pill`** — the dominant CTA across the system.
402
+ - Background `{colors.primary}` (black), text `{colors.on-primary}`, type `{typography.body-md}`, padding `{spacing.md} {spacing.xl}` (12px 24px), rounded `{rounded.pill}` 9999px.
403
+ - Pressed state `button-primary-pill-pressed`: background lifts to `{colors.shade-70}`.
404
+
405
+ **`button-outline-on-dark`** — the cinematic hero CTA.
406
+ - Background `{colors.canvas-night}` (transparent on the canvas), 2px solid `{colors.on-primary}` border, text `{colors.on-primary}`, same pill geometry.
407
+
408
+ **`button-outline-on-light`** — the light-track equivalent.
409
+ - Background `{colors.canvas-light}`, 1px solid `{colors.ink}` border, text `{colors.ink}`, same pill geometry.
410
+
411
+ **`button-aloe-pill`** — the featured CTA on pricing pages.
412
+ - Background `{colors.aloe-10}`, text `{colors.ink}`, same pill geometry. Used for the "Start free trial" tier.
413
+
414
+ ### Cards & Containers
415
+
416
+ **`card-pricing`** — the standard tier card on the pricing page.
417
+ - Background `{colors.canvas-light}`, padding `{spacing.xxl}`, rounded `{rounded.lg}` 12px, 1px `{colors.hairline-light}` border. Title in `{typography.heading-xl}`, price in `{typography.display-md}`, body in `{typography.body-md}`, CTA pinned to the bottom as `button-primary-pill`.
418
+
419
+ **`card-pricing-featured`** — the highlighted pricing tier.
420
+ - Background `{colors.aloe-10}`, otherwise identical to `card-pricing`. The mint fill (rather than a brand-color border) is the brand's distinctive featured-tier choice.
421
+
422
+ **`card-feature-cinematic`** — feature card on the cinematic track.
423
+ - Background `{colors.canvas-night-elevated}`, text `{colors.on-primary}`, rounded `{rounded.lg}`, often with a top-edge inset highlight (Level 1 elevation). Holds full-bleed photography or a single large statement.
424
+
425
+ **`card-pistachio-band`** — wide horizontal band card used to highlight a category of features on the light track.
426
+ - Background `{colors.pistachio-10}`, text `{colors.ink}`, rounded `{rounded.lg}` 12px, padding `{spacing.xxl}`.
427
+
428
+ **`card-photo-frame`** — full-bleed photography container on cinematic pages.
429
+ - Background `{colors.canvas-night}`, padding 0, rounded `{rounded.xl}` 20px (often top-only). The photo IS the content; no inner padding, no overlay text inside the card.
430
+
431
+ ### Inputs & Forms
432
+
433
+ **`text-input`** — standard text input on light surfaces.
434
+ - Background `{colors.canvas-light}`, text `{colors.ink}`, type `{typography.body-md}`, padding `{spacing.sm}+ {spacing.md}` (10px 12px), rounded `{rounded.md}` 8px, 1px `{colors.hairline-light}` border.
435
+
436
+ ### Navigation
437
+
438
+ **`nav-bar-light`** — top nav on light pages.
439
+ - Background `{colors.canvas-light}`, text `{colors.ink}`, padding `{spacing.lg} {spacing.xl}`. Logo wordmark on the left, nav items center, two pill buttons on the right (`button-outline-on-light` for "Log in", `button-primary-pill` for "Start free trial").
440
+
441
+ **`nav-bar-dark`** — top nav on cinematic pages.
442
+ - Background `{colors.canvas-night}`, text `{colors.on-primary}`, otherwise identical structure. Two pill buttons on the right (`button-outline-on-dark` for both, with the rightmost subtly more prominent via type weight).
443
+
444
+ ### Pills, Tags, and Chips
445
+
446
+ **`pill-tag-mint`** — small tag on light surfaces, signaling a feature category.
447
+ - Background `{colors.aloe-10}`, text `{colors.ink}`, type `{typography.eyebrow-cap}`, padding `{spacing.xs} {spacing.md}`, rounded `{rounded.pill}`.
448
+
449
+ **`pill-tag-shade`** — neutral tag on light surfaces.
450
+ - Background `{colors.shade-30}`, text `{colors.ink}`, otherwise same shape as `pill-tag-mint`.
451
+
452
+ ### Signature Components
453
+
454
+ **Cinematic Photography Layer** — full-bleed merchant photos on the hero. No overlay scrim, no text-on-image; instead, the type sits in clean negative space above or below the photo. The brand treats photography as an editorial spread, not as decoration.
455
+
456
+ **Stacked Tiny Shadows (Level 3 Elevation)** — pricing cards on the light track use 4 stacked tiny drop shadows (each 1–8px Y offset, 10% black) to produce a soft, layered paper halo. This is the brand's distinctive depth on light.
457
+
458
+ **`link-on-dark`** — inline link on cinematic pages.
459
+ - Color `{colors.on-primary}`, no underline by default (links rely on context); for tertiary footer links, color shifts to one of the cool muted tones (`{colors.link-cool-1}` etc.) with a persistent underline.
460
+
461
+ **`footer-dark`** — full-page-width footer on the cinematic track.
462
+ - Background `{colors.canvas-night}`, text `{colors.on-primary}`, type `{typography.caption}`, padding `{spacing.huge} {spacing.xl}`. Contains 4–5 columns of muted-tone link groups, social icons, and a small legal row.
463
+
464
+ **`footer-light`** — equivalent on the transactional track.
465
+ - Background `{colors.canvas-light}`, text `{colors.ink}`, otherwise same structure.
466
+
467
+ ## Do's and Don'ts
468
+
469
+ ### Do
470
+ - Reserve `{colors.aloe-10}` and `{colors.pistachio-10}` for the light track only — they don't appear on cinematic black pages.
471
+ - Always use `{rounded.pill}` for buttons; never `{rounded.md}` or `{rounded.lg}`.
472
+ - Render display tiers at weight 330; bumping to 400 or 500 breaks the brand's thin-display signature.
473
+ - Use full-bleed photography on cinematic pages — let it escape the container.
474
+ - Apply `font-feature-settings: "ss03"` globally; the stylistic set is the brand's typographic signature.
475
+ - Pair black canvas with white type and white-stroked outline pills; pair light canvas with black type and filled-black pills.
476
+
477
+ ### Don't
478
+ - Don't introduce a third canvas color — stick to black or light/cream. Greys, beiges, and blues are not in the system.
479
+ - Don't add drop shadows on cinematic dark cards beyond the subtle inset top-highlight; the cinematic track wants flat blackness.
480
+ - Don't shrink display tiers below `{typography.display-md}` (48px) on hero surfaces; below that they read as section heads, not display.
481
+ - Don't put aloe / pistachio greens behind type — they're surface fills, not text colors.
482
+ - Don't replace the pill shape with a rounded-rectangle button anywhere.
483
+
484
+ ## Responsive Behavior
485
+
486
+ ### Breakpoints
487
+
488
+ | Name | Width | Key Changes |
489
+ |---|---|---|
490
+ | Wide | ≥ 1440px | Full cinematic hero with edge-bleeding photography; pricing 4-up |
491
+ | Desktop | 1024–1440px | Default content max-width; pricing 4-up tightens |
492
+ | Tablet | 768–1023px | Pricing 2-up; cinematic hero photography crops |
493
+ | Mobile | < 768px | Pricing 1-up; hamburger nav; display-xxl drops to ~56–64px |
494
+
495
+ ### Touch Targets
496
+ - Pill buttons hit ≥ 44×44px on mobile via 12px vertical padding × 16px line-height. WCAG AAA compliant.
497
+ - Form fields stay at the 44px minimum height across all breakpoints.
498
+
499
+ ### Collapsing Strategy
500
+ - Display sizes scale down through the breakpoint stair: 96 → 70 → 55 → 48 → 36px on mobile.
501
+ - Cinematic photography crops aggressively at smaller widths, prioritizing focal subject over edge-bleed.
502
+ - Pricing tiers stair-step 4-up → 2-up → 1-up; the featured aloe tier stays visually distinguished at every step.
503
+ - Top nav collapses to hamburger below 768px; menu inherits canvas polarity.
504
+
505
+ ### Image Behavior
506
+ Photography uses responsive `srcset` with art-direction crops at major breakpoints. Mobile crops favor close subjects; wide crops favor environmental / storefront context.
507
+
508
+ ## Iteration Guide
509
+
510
+ 1. Focus on ONE component at a time.
511
+ 2. Reference component names and tokens directly (`{colors.aloe-10}`, `{button-primary-pill}-pressed`, `{rounded.pill}`).
512
+ 3. Run `npx @google/design.md lint DESIGN.md` after edits.
513
+ 4. Add new variants as separate entries.
514
+ 5. Default body to `{typography.body-md}`; reserve `{typography.body-lg}` for marketing leads.
515
+ 6. Keep the two canvas tracks separated — when designing a new page, choose cinematic OR transactional, not both.
516
+ 7. The pill shape is non-negotiable; new button variants vary in fill / border / canvas, never in shape.
@@ -0,0 +1,5 @@
1
+ # Shopify Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/shopify/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.