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,487 @@
1
+ ---
2
+ version: alpha
3
+ name: Stripi Inspired
4
+ description: An inspired interpretation of Stripi's design language — a financial-infrastructure brand built on a deep navy ink, an electric indigo primary, and a recurring atmospheric gradient mesh that occupies the upper third of nearly every marketing page. The system pairs the proprietary Sohne family at thin (300) weights with negative letter-spacing for editorial-density display headlines, and uses tabular-figure body type where money and numerics matter. Buttons are tight-radius pills, cards live on near-white surfaces, and the dashboard track flips polarity to a familiar dark-app shell.
5
+
6
+ colors:
7
+ primary: "#533afd"
8
+ primary-deep: "#4434d4"
9
+ primary-press: "#2e2b8c"
10
+ primary-soft: "#665efd"
11
+ primary-bg-subdued-hover: "#b9b9f9"
12
+ brand-dark-900: "#1c1e54"
13
+ ink: "#0d253d"
14
+ ink-secondary: "#273951"
15
+ ink-mute: "#64748d"
16
+ ink-mute-2: "#61718a"
17
+ on-primary: "#ffffff"
18
+ canvas: "#ffffff"
19
+ canvas-soft: "#f6f9fc"
20
+ canvas-cream: "#f5e9d4"
21
+ hairline: "#e3e8ee"
22
+ hairline-input: "#a8c3de"
23
+ ruby: "#ea2261"
24
+ magenta: "#f96bee"
25
+ lemon: "#9b6829"
26
+ shadow-blue: "#003770"
27
+
28
+ typography:
29
+ display-xxl:
30
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
31
+ fontSize: 56px
32
+ fontWeight: 300
33
+ lineHeight: 1.03
34
+ letterSpacing: -1.4px
35
+ fontFeature: ss01
36
+ display-xl:
37
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
38
+ fontSize: 48px
39
+ fontWeight: 300
40
+ lineHeight: 1.15
41
+ letterSpacing: -0.96px
42
+ fontFeature: ss01
43
+ display-lg:
44
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
45
+ fontSize: 32px
46
+ fontWeight: 300
47
+ lineHeight: 1.1
48
+ letterSpacing: -0.64px
49
+ fontFeature: ss01
50
+ display-md:
51
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
52
+ fontSize: 26px
53
+ fontWeight: 300
54
+ lineHeight: 1.12
55
+ letterSpacing: -0.26px
56
+ fontFeature: ss01
57
+ heading-lg:
58
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
59
+ fontSize: 22px
60
+ fontWeight: 300
61
+ lineHeight: 1.1
62
+ letterSpacing: -0.22px
63
+ fontFeature: ss01
64
+ heading-md:
65
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
66
+ fontSize: 20px
67
+ fontWeight: 300
68
+ lineHeight: 1.4
69
+ letterSpacing: -0.2px
70
+ fontFeature: ss01
71
+ heading-sm:
72
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
73
+ fontSize: 18px
74
+ fontWeight: 300
75
+ lineHeight: 1.4
76
+ letterSpacing: 0
77
+ fontFeature: ss01
78
+ body-lg:
79
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
80
+ fontSize: 16px
81
+ fontWeight: 300
82
+ lineHeight: 1.4
83
+ letterSpacing: 0
84
+ fontFeature: ss01
85
+ body-md:
86
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
87
+ fontSize: 15px
88
+ fontWeight: 300
89
+ lineHeight: 1.4
90
+ letterSpacing: 0
91
+ fontFeature: ss01
92
+ body-tabular:
93
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
94
+ fontSize: 14px
95
+ fontWeight: 300
96
+ lineHeight: 1.4
97
+ letterSpacing: -0.42px
98
+ fontFeature: tnum
99
+ button-md:
100
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
101
+ fontSize: 16px
102
+ fontWeight: 400
103
+ lineHeight: 1.0
104
+ letterSpacing: 0
105
+ fontFeature: ss01
106
+ button-sm:
107
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
108
+ fontSize: 14px
109
+ fontWeight: 400
110
+ lineHeight: 1.0
111
+ letterSpacing: 0
112
+ fontFeature: ss01
113
+ caption:
114
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
115
+ fontSize: 13px
116
+ fontWeight: 400
117
+ lineHeight: 1.4
118
+ letterSpacing: -0.39px
119
+ fontFeature: tnum
120
+ micro:
121
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
122
+ fontSize: 11px
123
+ fontWeight: 300
124
+ lineHeight: 1.4
125
+ letterSpacing: 0
126
+ fontFeature: ss01
127
+ micro-cap:
128
+ fontFamily: "sohne-var, 'SF Pro Display', system-ui, -apple-system, sans-serif"
129
+ fontSize: 10px
130
+ fontWeight: 400
131
+ lineHeight: 1.15
132
+ letterSpacing: 0.1px
133
+ fontFeature: ss01
134
+
135
+ rounded:
136
+ xs: 4px
137
+ sm: 6px
138
+ md: 8px
139
+ lg: 12px
140
+ xl: 16px
141
+ pill: 9999px
142
+
143
+ spacing:
144
+ xxs: 2px
145
+ xs: 4px
146
+ sm: 8px
147
+ md: 12px
148
+ lg: 16px
149
+ xl: 24px
150
+ xxl: 32px
151
+ huge: 64px
152
+
153
+ components:
154
+ button-primary-pill:
155
+ backgroundColor: "{colors.primary}"
156
+ textColor: "{colors.on-primary}"
157
+ typography: "{typography.button-md}"
158
+ rounded: "{rounded.pill}"
159
+ padding: 8px 16px
160
+ button-primary-pill-pressed:
161
+ backgroundColor: "{colors.primary-press}"
162
+ textColor: "{colors.on-primary}"
163
+ typography: "{typography.button-md}"
164
+ rounded: "{rounded.pill}"
165
+ padding: 8px 16px
166
+ button-secondary:
167
+ backgroundColor: "{colors.canvas}"
168
+ textColor: "{colors.primary}"
169
+ typography: "{typography.button-md}"
170
+ rounded: "{rounded.pill}"
171
+ padding: 8px 16px
172
+ button-on-dark:
173
+ backgroundColor: "{colors.brand-dark-900}"
174
+ textColor: "{colors.on-primary}"
175
+ typography: "{typography.button-md}"
176
+ rounded: "{rounded.pill}"
177
+ padding: 8px 16px
178
+ text-input:
179
+ backgroundColor: "{colors.canvas}"
180
+ textColor: "{colors.ink}"
181
+ typography: "{typography.body-md}"
182
+ rounded: "{rounded.sm}"
183
+ padding: 8px 12px
184
+ text-input-focused:
185
+ backgroundColor: "{colors.canvas}"
186
+ textColor: "{colors.ink}"
187
+ typography: "{typography.body-md}"
188
+ rounded: "{rounded.sm}"
189
+ padding: 8px 12px
190
+ card-feature-light:
191
+ backgroundColor: "{colors.canvas}"
192
+ textColor: "{colors.ink}"
193
+ typography: "{typography.body-md}"
194
+ rounded: "{rounded.lg}"
195
+ padding: 32px
196
+ card-pricing:
197
+ backgroundColor: "{colors.canvas}"
198
+ textColor: "{colors.ink}"
199
+ typography: "{typography.body-md}"
200
+ rounded: "{rounded.lg}"
201
+ padding: 32px
202
+ card-pricing-featured:
203
+ backgroundColor: "{colors.brand-dark-900}"
204
+ textColor: "{colors.on-primary}"
205
+ typography: "{typography.body-md}"
206
+ rounded: "{rounded.lg}"
207
+ padding: 32px
208
+ card-cream-band:
209
+ backgroundColor: "{colors.canvas-cream}"
210
+ textColor: "{colors.ink}"
211
+ typography: "{typography.body-md}"
212
+ rounded: "{rounded.lg}"
213
+ padding: 32px
214
+ card-dashboard-mockup:
215
+ backgroundColor: "{colors.canvas}"
216
+ textColor: "{colors.ink}"
217
+ typography: "{typography.body-tabular}"
218
+ rounded: "{rounded.lg}"
219
+ padding: 24px
220
+ pill-tag-soft:
221
+ backgroundColor: "{colors.primary-bg-subdued-hover}"
222
+ textColor: "{colors.primary-deep}"
223
+ typography: "{typography.micro-cap}"
224
+ rounded: "{rounded.pill}"
225
+ padding: 4px 8px
226
+ nav-bar-on-mesh:
227
+ backgroundColor: "{colors.canvas}"
228
+ textColor: "{colors.ink}"
229
+ typography: "{typography.body-md}"
230
+ rounded: "{rounded.xs}"
231
+ padding: 16px 24px
232
+ link-on-light:
233
+ backgroundColor: "{colors.canvas}"
234
+ textColor: "{colors.primary}"
235
+ typography: "{typography.body-md}"
236
+ rounded: "{rounded.xs}"
237
+ padding: 0px
238
+ footer-light:
239
+ backgroundColor: "{colors.canvas}"
240
+ textColor: "{colors.ink-mute}"
241
+ typography: "{typography.caption}"
242
+ rounded: "{rounded.xs}"
243
+ padding: 64px 24px
244
+ ---
245
+
246
+ ## Overview
247
+
248
+ Stripi's design language opens with the gradient mesh. A wide horizontal band of pastel cream, sherbet orange, lavender, electric indigo, and ruby pink occupies the upper third of nearly every marketing page — the brand's instantly-recognizable atmospheric backdrop. Type and product UI mockups float above it on `{colors.canvas}` (white), with the gradient acting as both decoration and visual anchor. The lower portion of the page returns to white, with feature explanations on `{colors.canvas-soft}` (a barely-tinted cool off-white) and dashboard product mockups composited as faux IDE/console panels in deep navy.
249
+
250
+ The color system has two primary roles. **Indigo** (`{colors.primary}` — `#533afd`) is the brand's signature CTA color, used sparingly: one filled pill per band. **Deep navy** (`{colors.ink}` — `#0d253d`) is the universal body text color and the fill of dashboard mockups, the featured pricing tier, and the dark-app surfaces on the dashboard track. Ruby (`{colors.ruby}`) and magenta (`{colors.magenta}`) appear inside the gradient mesh and as accent dots in product UI mockups; they are not used as button colors.
251
+
252
+ Typography is built around **Sohne** at weight 300 with negative letter-spacing — the brand's editorial-density display signature. Display sizes (32–56px) use -1.4px to -0.64px tracking; body sizes use 0; tabular caption sizes (where money and numerics matter) use the OpenType `tnum` feature plus a tightening -0.36 to -0.42px tracking. The `ss01` stylistic set is enabled across all roles.
253
+
254
+ **Key Characteristics:**
255
+ - Gradient-mesh backdrop on every marketing hero — cream/orange/lavender/indigo/ruby horizontally washed across the upper third of the page.
256
+ - Single-indigo CTA hierarchy: filled `{colors.primary}` pill is the only filled button on marketing surfaces.
257
+ - Sohne thin (weight 300) display tier with negative tracking from -1.4px to -0.2px depending on size.
258
+ - Tabular-figure body type (`tnum`) for any cell containing money or numerics — the brand's quiet financial-data signal.
259
+ - Dark-app dashboard track: deep navy product UI mockups sit composited above the white canvas, frequently with rendered code or dashboard tables inside.
260
+ - Pill-shaped buttons (`{rounded.pill}` 9999px) with tight `8px 16px` padding — short, decisive, transactional.
261
+ - Cream-band feature cards (`{colors.canvas-cream}`) introduce a warm interlude between blue/white sections without breaking the brand's chromatic logic.
262
+
263
+ ## Colors
264
+
265
+ > **Source pages:** home (`/`), `/payments`, `/pricing`, `dashboard.stripe.com/register/payments`.
266
+
267
+ ### Brand & Accent
268
+ - **Indigo** (`{colors.primary}` — `#533afd`): The brand's signature CTA color. Filled-pill button, link emphasis, gradient anchor.
269
+ - **Indigo Deep** (`{colors.primary-deep}` — `#4434d4`): A deeper indigo used in gradient mid-stops and as the press-state warmer alternative.
270
+ - **Indigo Press** (`{colors.primary-press}` — `#2e2b8c`): Pressed-state lift of the primary.
271
+ - **Indigo Soft** (`{colors.primary-soft}` — `#665efd`): A lighter indigo used in product-UI accents and chart highlights.
272
+ - **Indigo Subdued** (`{colors.primary-bg-subdued-hover}` — `#b9b9f9`): Pale indigo fill used as soft tag background.
273
+ - **Brand Dark 900** (`{colors.brand-dark-900}` — `#1c1e54`): The deep navy used on the featured pricing tier and dashboard chrome.
274
+ - **Ruby** (`{colors.ruby}` — `#ea2261`): Gradient accent and chart highlight; never a button.
275
+ - **Magenta** (`{colors.magenta}` — `#f96bee`): Brighter pink stop in gradient meshes.
276
+ - **Lemon** (`{colors.lemon}` — `#9b6829`): Warm sherbet stop in gradient backdrops.
277
+
278
+ ### Surface
279
+ - **Canvas** (`{colors.canvas}` — `#ffffff`): Default page background.
280
+ - **Canvas Soft** (`{colors.canvas-soft}` — `#f6f9fc`): Cool-tinted off-white used on feature bands beneath the gradient hero.
281
+ - **Canvas Cream** (`{colors.canvas-cream}` — `#f5e9d4`): Warm cream used as a feature-band fill — the brand's chromatic interlude.
282
+ - **Hairline** (`{colors.hairline}` — `#e3e8ee`): 1px borders on cards and tables.
283
+ - **Hairline Input** (`{colors.hairline-input}` — `#a8c3de`): Slightly cooler hairline used on form inputs.
284
+
285
+ ### Text
286
+ - **Ink** (`{colors.ink}` — `#0d253d`): Default body text color across the brand. Deep navy, never pure black.
287
+ - **Ink Secondary** (`{colors.ink-secondary}` — `#273951`): Secondary text on white.
288
+ - **Ink Mute** (`{colors.ink-mute}` — `#64748d`): Helper text, captions, table labels.
289
+ - **Ink Mute 2** (`{colors.ink-mute-2}` — `#61718a`): Near-equivalent to ink-mute used in nav.
290
+ - **On Primary** (`{colors.on-primary}` — `#ffffff`): Text on indigo / dark-navy surfaces.
291
+
292
+ ### Semantic
293
+ The brand does not use a separate semantic color palette in the marketing system — error / success states live in dashboard-product UI specifically.
294
+
295
+ ## Typography
296
+
297
+ ### Font Family
298
+
299
+ The display and UI tier is **Sohne** (proprietary, licensed from Klim Type Foundry) at weights 300 (thin) and 400 (regular). The variable font (`sohne-var`) is loaded with `font-feature-settings: "ss01"` enabled globally — the stylistic set substitutes a single-story `a` and other character variants that are part of the brand's typographic signature.
300
+
301
+ When Sohne is unavailable, fall back to **SF Pro Display** at thin weights, then system-ui. For maximum brand fidelity, **Inter** (open-source) at weight 300 with `font-feature-settings: "ss01"` and `letter-spacing: -1.4px` on display sizes approximates the rhythm closely.
302
+
303
+ ### Hierarchy
304
+
305
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
306
+ |---|---|---|---|---|---|
307
+ | `{typography.display-xxl}` | 56px | 300 | 1.03 | -1.4px | Hero headline |
308
+ | `{typography.display-xl}` | 48px | 300 | 1.15 | -0.96px | Section opener |
309
+ | `{typography.display-lg}` | 32px | 300 | 1.1 | -0.64px | Card title / sub-section |
310
+ | `{typography.display-md}` | 26px | 300 | 1.12 | -0.26px | Compact card title |
311
+ | `{typography.heading-lg}` | 22px | 300 | 1.1 | -0.22px | Pricing tier name |
312
+ | `{typography.heading-md}` | 20px | 300 | 1.4 | -0.2px | Section sub-heading |
313
+ | `{typography.heading-sm}` | 18px | 300 | 1.4 | 0 | Mini-section label |
314
+ | `{typography.body-lg}` | 16px | 300 | 1.4 | 0 | Marketing body lead |
315
+ | `{typography.body-md}` | 15px | 300 | 1.4 | 0 | Default UI body |
316
+ | `{typography.body-tabular}` | 14px | 300 | 1.4 | -0.42px | Money / numeric tables (uses `tnum`) |
317
+ | `{typography.button-md}` | 16px | 400 | 1.0 | 0 | Pill button label |
318
+ | `{typography.button-sm}` | 14px | 400 | 1.0 | 0 | Compact pill label |
319
+ | `{typography.caption}` | 13px | 400 | 1.4 | -0.39px | Helper, table labels |
320
+ | `{typography.micro}` | 11px | 300 | 1.4 | 0 | Fine print |
321
+ | `{typography.micro-cap}` | 10px | 400 | 1.15 | 0.1px | All-caps eyebrow |
322
+
323
+ ### Principles
324
+ - **Thin weight is the brand.** Display tiers always render at weight 300. Bumping to 400+ removes the brand's editorial air.
325
+ - **Negative tracking on display.** -1.4px at 56px, scaling proportionally down to -0.2px at 20px. The negative tracking is the brand's typographic signature.
326
+ - **Tabular figures for money.** Any cell rendering currency, transaction amounts, or numeric counts uses `font-feature-settings: "tnum"` plus a tightening tracking. The brand quietly signals its financial DNA through this micro-detail.
327
+ - **`ss01` globally.** Apply `font-feature-settings: "ss01"` to the body element so the stylistic-set substitution is on for every text role.
328
+
329
+ ### Note on Font Substitutes
330
+ Sohne is proprietary. Use **Inter** (open-source via Google Fonts) at weight 300 with `letter-spacing: -1.4px` and `font-feature-settings: "ss01"` for display tiers — Inter is the closest open-source analogue. For body sizes, Inter at 300 weight with `font-feature-settings: "tnum"` (where applicable) is the canonical substitute. Avoid Helvetica or system-ui defaults — they're heavier than the brand needs.
331
+
332
+ ## Layout
333
+
334
+ ### Spacing System
335
+ - **Base unit**: 8px (with 2 / 4 / 12 sub-tokens for fine work).
336
+ - **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.
337
+ - **Section padding**: 64–96px on marketing surfaces; 32–48px on dashboard / product surfaces.
338
+ - **Card internal padding**: 32px on feature cards; 24px on dashboard mockups.
339
+
340
+ ### Grid & Container
341
+ - Marketing pages center in a ~1200px container with the gradient mesh extending edge-to-edge above.
342
+ - Pricing collapses 4-up → 2-up → 1-up at 1024 / 768 breakpoints.
343
+ - Dashboard product mockups use their own internal grids (12-col tables, 3-col card grids) rendered as static composites.
344
+
345
+ ### Whitespace Philosophy
346
+ The gradient mesh occupies the upper third of the page; the white canvas below is generously padded. Section gaps tend toward 96px, with content tightening to 32px on dashboard / pricing pages where users compare and act.
347
+
348
+ ## Elevation & Depth
349
+
350
+ | Level | Treatment | Use |
351
+ |---|---|---|
352
+ | 0 | Flat | Default surface |
353
+ | 1 | `box-shadow: rgba(0,55,112,0.08) 0 1px 3px` | Card lift on white |
354
+ | 2 | `box-shadow: rgba(0,55,112,0.08) 0 8px 24px, rgba(0,55,112,0.04) 0 2px 6px` | Floating panels, dashboard mockup chrome |
355
+ | 3 | Gradient mesh backdrop | The brand's primary depth medium — atmospheric color rather than literal shadow |
356
+
357
+ ### Decorative Depth
358
+ The gradient mesh IS the depth system. Implemented as a layered SVG or large background image rather than CSS gradients (the actual mesh has organic blob shapes that aren't CSS-renderable). The mesh provides the brand's signature lift; literal shadows are reserved for product-UI mockups and stay subtle.
359
+
360
+ ## Shapes
361
+
362
+ ### Border Radius Scale
363
+
364
+ | Token | Value | Use |
365
+ |---|---|---|
366
+ | `{rounded.xs}` | 4px | Hairline tags, table chrome |
367
+ | `{rounded.sm}` | 6px | Form inputs |
368
+ | `{rounded.md}` | 8px | Compact cards, alerts |
369
+ | `{rounded.lg}` | 12px | Pricing cards, feature cards |
370
+ | `{rounded.xl}` | 16px | Dashboard product mockup chrome |
371
+ | `{rounded.pill}` | 9999px | All buttons, tag pills |
372
+
373
+ ### Photography Geometry
374
+ The brand uses **product UI mockups** more than photography. Dashboard composites render as faux IDE/terminal/dashboard chrome inside `{rounded.lg}` 12px containers with a subtle `box-shadow`. Real photography appears in customer logo strips and the rare case-study card; treated as inset 4:3 with no shadow.
375
+
376
+ ## Components
377
+
378
+ ### Buttons
379
+
380
+ **`button-primary-pill`** — the dominant CTA system-wide.
381
+ - Background `{colors.primary}`, text `{colors.on-primary}`, type `{typography.button-md}`, padding `{spacing.sm} {spacing.lg}` (8px 16px), rounded `{rounded.pill}` 9999px.
382
+ - Pressed state `button-primary-pill-pressed` shifts background to `{colors.primary-press}`.
383
+
384
+ **`button-secondary`** — outline-style alternative.
385
+ - Background `{colors.canvas}`, text `{colors.primary}`, 1px solid `{colors.primary}` border, same pill geometry.
386
+
387
+ **`button-on-dark`** — used on dashboard / dark surfaces.
388
+ - Background `{colors.brand-dark-900}`, text `{colors.on-primary}`, same pill geometry.
389
+
390
+ ### Cards & Containers
391
+
392
+ **`card-feature-light`** — feature explanation card on white.
393
+ - Background `{colors.canvas}`, padding `{spacing.xxl}`, rounded `{rounded.lg}` 12px, 1px `{colors.hairline}` border, optional Level 1 shadow.
394
+
395
+ **`card-pricing`** — standard pricing tier.
396
+ - Background `{colors.canvas}`, padding `{spacing.xxl}`, rounded `{rounded.lg}`, 1px `{colors.hairline}` border. Title `{typography.heading-lg}`, price `{typography.display-md}`, body `{typography.body-md}`, CTA pinned bottom as `button-primary-pill`.
397
+
398
+ **`card-pricing-featured`** — the inverted dark featured tier.
399
+ - Background `{colors.brand-dark-900}`, text `{colors.on-primary}`, otherwise identical structure to `card-pricing`. The deep-navy fill is the brand's distinctive featured-tier choice.
400
+
401
+ **`card-cream-band`** — warm interlude card.
402
+ - Background `{colors.canvas-cream}`, text `{colors.ink}`, padding `{spacing.xxl}`, rounded `{rounded.lg}`. Used to break up the indigo / white rhythm with warmth.
403
+
404
+ **`card-dashboard-mockup`** — composited dashboard / product UI screenshot.
405
+ - Background `{colors.canvas}`, type `{typography.body-tabular}` (with `tnum`), padding `{spacing.xl}` 24px, rounded `{rounded.lg}` 12px, Level 2 shadow. Often contains nested mini-mockups: code preview + dashboard table + chart card.
406
+
407
+ ### Inputs & Forms
408
+
409
+ **`text-input`** — standard form field.
410
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.body-md}`, padding `{spacing.sm} {spacing.md}` (8px 12px), rounded `{rounded.sm}` 6px, 1px `{colors.hairline-input}` border.
411
+ - Focus state `text-input-focused`: border swaps to `{colors.primary}`.
412
+
413
+ ### Navigation
414
+
415
+ **`nav-bar-on-mesh`** — top nav floating over the gradient hero.
416
+ - Background `{colors.canvas}` (or transparent depending on scroll), text `{colors.ink}`, padding `{spacing.lg} {spacing.xl}`. Logo wordmark on the left, primary nav center, sign-in + filled `button-primary-pill` on the right.
417
+
418
+ ### Pills, Tags, and Chips
419
+
420
+ **`pill-tag-soft`** — subdued indigo tag.
421
+ - Background `{colors.primary-bg-subdued-hover}`, text `{colors.primary-deep}`, type `{typography.micro-cap}`, padding `4px 8px`, rounded `{rounded.pill}`.
422
+
423
+ ### Signature Components
424
+
425
+ **Gradient Mesh Backdrop** — pastel cream → sherbet orange → lavender → indigo → ruby pink stops blurred horizontally across the upper third of the page. Implemented as SVG or a large background image — not a flat CSS gradient (the real mesh has organic blob shapes).
426
+
427
+ **Composited Dashboard Mockup** — multi-layer faux-product-UI compositions: an IDE panel on the left, a dashboard table center, a chart card on the right, all rendered at small scale inside `{rounded.lg}` containers with subtle Level 2 shadows. The composite is the brand's most-photographed feature.
428
+
429
+ **Tabular-Figure Money Type** — every number rendering money, count, or transaction value uses `font-feature-settings: "tnum"`. The brand's quiet signal that it's a financial-infrastructure platform.
430
+
431
+ **`link-on-light`** — inline links on light surfaces.
432
+ - Text `{colors.primary}` rendered in `{typography.body-md}`, no underline by default.
433
+
434
+ **`footer-light`** — site-wide footer.
435
+ - Background `{colors.canvas}`, text `{colors.ink-mute}`, type `{typography.caption}`, padding `{spacing.huge} {spacing.xl}` (64px 24px). Holds 4–6 columns of link groups, social icons, and a small legal row.
436
+
437
+ ## Do's and Don'ts
438
+
439
+ ### Do
440
+ - Reserve `{colors.primary}` for filled CTAs and inline link emphasis — it should appear sparingly, one filled button per band.
441
+ - Apply the gradient mesh to every marketing hero; bare-canvas heroes feel off-brand.
442
+ - Render display tiers at weight 300 with negative letter-spacing — the thin tracking is the typographic signature.
443
+ - Use `font-feature-settings: "tnum"` on every money / numeric cell.
444
+ - Apply `font-feature-settings: "ss01"` globally on the body element.
445
+ - Pair every feature explanation with a composited product UI mockup; the brand's argument is "look at the actual product."
446
+
447
+ ### Don't
448
+ - Don't bump display weight above 300 — at 400 the brand's editorial air collapses.
449
+ - Don't add new accent colors outside the documented gradient stops (cream / orange / lavender / indigo / ruby / magenta).
450
+ - Don't use the indigo `{colors.primary}` as a body-text color — it's a CTA and link color, not a type color at body size.
451
+ - Don't shrink button padding below `8px 16px` — the tight pill is part of the brand's transactional feel.
452
+ - Don't render money cells without `tnum` — it breaks the quiet financial-data signature.
453
+ - Don't replace the pill shape with rounded-rectangles for buttons.
454
+
455
+ ## Responsive Behavior
456
+
457
+ ### Breakpoints
458
+
459
+ | Name | Width | Key Changes |
460
+ |---|---|---|
461
+ | Wide | ≥ 1440px | Full gradient mesh edge-to-edge; dashboard composite at full scale |
462
+ | Desktop | 1024–1440px | Default content max-width; pricing 4-up |
463
+ | Tablet | 768–1023px | Pricing 2-up; dashboard composite simplifies to 2 panels |
464
+ | Mobile | < 768px | Pricing 1-up; hamburger nav; display drops 56 → 36px |
465
+
466
+ ### Touch Targets
467
+ - Pill buttons hit ≥ 40×40px on mobile via padding scaling. On smaller screens, buttons size up to 44×44px to maintain WCAG AAA.
468
+ - Form fields stay at 40px minimum height.
469
+
470
+ ### Collapsing Strategy
471
+ - Display tiers stair-step 56 → 48 → 32 → 26 → 22px through the breakpoints.
472
+ - Gradient mesh re-tiles on mobile to preserve the wash without disappearing.
473
+ - Dashboard composites simplify to single-panel mockups on mobile; the multi-layer composition only renders at desktop+.
474
+ - Pricing tiers stair-step 4-up → 2-up → 1-up.
475
+
476
+ ### Image Behavior
477
+ Product UI composites use `srcset` with art-direction crops at major breakpoints. Mobile crops focus on the most actionable inner panel; desktop crops show the full multi-layer composition.
478
+
479
+ ## Iteration Guide
480
+
481
+ 1. Focus on ONE component at a time.
482
+ 2. Reference component names and tokens directly (`{colors.primary}`, `{button-primary-pill}-pressed`, `{rounded.pill}`).
483
+ 3. Run `npx @google/design.md lint DESIGN.md` after edits.
484
+ 4. Add new variants as separate entries.
485
+ 5. Default body to `{typography.body-md}` (15px); use `{typography.body-tabular}` for any money / numeric cell.
486
+ 6. Apply `ss01` globally on the body; apply `tnum` per-element on numeric content.
487
+ 7. The gradient mesh is non-negotiable on marketing heroes — bare-canvas heroes break the brand.
@@ -0,0 +1,5 @@
1
+ # Stripe Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/stripe/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.