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.
- package/LICENSE +21 -0
- package/README.md +40 -0
- package/bin/relay.js +362 -0
- package/design-md/airbnb/DESIGN.md +545 -0
- package/design-md/airbnb/README.md +5 -0
- package/design-md/airtable/DESIGN.md +554 -0
- package/design-md/airtable/README.md +5 -0
- package/design-md/apple/DESIGN.md +562 -0
- package/design-md/apple/README.md +5 -0
- package/design-md/binance/DESIGN.md +634 -0
- package/design-md/binance/README.md +5 -0
- package/design-md/bmw/DESIGN.md +544 -0
- package/design-md/bmw/README.md +5 -0
- package/design-md/bmw-m/DESIGN.md +503 -0
- package/design-md/bmw-m/README.md +5 -0
- package/design-md/bugatti/DESIGN.md +454 -0
- package/design-md/bugatti/README.md +5 -0
- package/design-md/cal/DESIGN.md +542 -0
- package/design-md/cal/README.md +5 -0
- package/design-md/claude/DESIGN.md +589 -0
- package/design-md/claude/README.md +5 -0
- package/design-md/clay/DESIGN.md +541 -0
- package/design-md/clay/README.md +5 -0
- package/design-md/clickhouse/DESIGN.md +544 -0
- package/design-md/clickhouse/README.md +5 -0
- package/design-md/cohere/DESIGN.md +451 -0
- package/design-md/cohere/README.md +5 -0
- package/design-md/coinbase/DESIGN.md +570 -0
- package/design-md/coinbase/README.md +5 -0
- package/design-md/composio/DESIGN.md +506 -0
- package/design-md/composio/README.md +5 -0
- package/design-md/cursor/DESIGN.md +537 -0
- package/design-md/cursor/README.md +5 -0
- package/design-md/elevenlabs/DESIGN.md +504 -0
- package/design-md/elevenlabs/README.md +5 -0
- package/design-md/expo/DESIGN.md +526 -0
- package/design-md/expo/README.md +5 -0
- package/design-md/ferrari/DESIGN.md +531 -0
- package/design-md/ferrari/README.md +5 -0
- package/design-md/figma/DESIGN.md +578 -0
- package/design-md/figma/README.md +5 -0
- package/design-md/framer/DESIGN.md +544 -0
- package/design-md/framer/README.md +5 -0
- package/design-md/hashicorp/DESIGN.md +575 -0
- package/design-md/hashicorp/README.md +5 -0
- package/design-md/ibm/DESIGN.md +550 -0
- package/design-md/ibm/README.md +5 -0
- package/design-md/intercom/DESIGN.md +546 -0
- package/design-md/intercom/README.md +5 -0
- package/design-md/kraken/DESIGN.md +125 -0
- package/design-md/kraken/README.md +5 -0
- package/design-md/lamborghini/DESIGN.md +288 -0
- package/design-md/lamborghini/README.md +5 -0
- package/design-md/linear.app/DESIGN.md +548 -0
- package/design-md/linear.app/README.md +5 -0
- package/design-md/lovable/DESIGN.md +298 -0
- package/design-md/lovable/README.md +5 -0
- package/design-md/mastercard/DESIGN.md +365 -0
- package/design-md/mastercard/README.md +5 -0
- package/design-md/meta/DESIGN.md +683 -0
- package/design-md/meta/README.md +5 -0
- package/design-md/minimax/DESIGN.md +746 -0
- package/design-md/minimax/README.md +5 -0
- package/design-md/mintlify/DESIGN.md +852 -0
- package/design-md/mintlify/README.md +5 -0
- package/design-md/miro/DESIGN.md +825 -0
- package/design-md/miro/README.md +5 -0
- package/design-md/mistral.ai/DESIGN.md +773 -0
- package/design-md/mistral.ai/README.md +5 -0
- package/design-md/mongodb/DESIGN.md +767 -0
- package/design-md/mongodb/README.md +5 -0
- package/design-md/nike/DESIGN.md +575 -0
- package/design-md/nike/README.md +5 -0
- package/design-md/notion/DESIGN.md +821 -0
- package/design-md/notion/README.md +5 -0
- package/design-md/nvidia/DESIGN.md +640 -0
- package/design-md/nvidia/README.md +5 -0
- package/design-md/ollama/DESIGN.md +539 -0
- package/design-md/ollama/README.md +5 -0
- package/design-md/opencode.ai/DESIGN.md +521 -0
- package/design-md/opencode.ai/README.md +5 -0
- package/design-md/pinterest/DESIGN.md +597 -0
- package/design-md/pinterest/README.md +5 -0
- package/design-md/playstation/DESIGN.md +661 -0
- package/design-md/playstation/README.md +5 -0
- package/design-md/posthog/DESIGN.md +690 -0
- package/design-md/posthog/README.md +5 -0
- package/design-md/raycast/DESIGN.md +669 -0
- package/design-md/raycast/README.md +5 -0
- package/design-md/renault/DESIGN.md +589 -0
- package/design-md/renault/README.md +5 -0
- package/design-md/replicate/DESIGN.md +616 -0
- package/design-md/replicate/README.md +5 -0
- package/design-md/resend/DESIGN.md +585 -0
- package/design-md/resend/README.md +5 -0
- package/design-md/revolut/DESIGN.md +636 -0
- package/design-md/revolut/README.md +5 -0
- package/design-md/runwayml/DESIGN.md +244 -0
- package/design-md/runwayml/README.md +5 -0
- package/design-md/sanity/DESIGN.md +357 -0
- package/design-md/sanity/README.md +5 -0
- package/design-md/sentry/DESIGN.md +551 -0
- package/design-md/sentry/README.md +5 -0
- package/design-md/shopify/DESIGN.md +516 -0
- package/design-md/shopify/README.md +5 -0
- package/design-md/slack/DESIGN.md +482 -0
- package/design-md/spacex/DESIGN.md +363 -0
- package/design-md/spacex/README.md +5 -0
- package/design-md/spotify/DESIGN.md +246 -0
- package/design-md/spotify/README.md +5 -0
- package/design-md/starbucks/DESIGN.md +580 -0
- package/design-md/starbucks/README.md +5 -0
- package/design-md/stripe/DESIGN.md +487 -0
- package/design-md/stripe/README.md +5 -0
- package/design-md/supabase/DESIGN.md +462 -0
- package/design-md/supabase/README.md +5 -0
- package/design-md/superhuman/DESIGN.md +448 -0
- package/design-md/superhuman/README.md +5 -0
- package/design-md/tesla/DESIGN.md +286 -0
- package/design-md/tesla/README.md +5 -0
- package/design-md/theverge/DESIGN.md +339 -0
- package/design-md/theverge/README.md +5 -0
- package/design-md/together.ai/DESIGN.md +633 -0
- package/design-md/together.ai/README.md +5 -0
- package/design-md/uber/DESIGN.md +636 -0
- package/design-md/uber/README.md +5 -0
- package/design-md/vercel/DESIGN.md +736 -0
- package/design-md/vercel/README.md +5 -0
- package/design-md/vodafone/DESIGN.md +538 -0
- package/design-md/vodafone/README.md +5 -0
- package/design-md/voltagent/DESIGN.md +521 -0
- package/design-md/voltagent/README.md +5 -0
- package/design-md/warp/DESIGN.md +526 -0
- package/design-md/warp/README.md +5 -0
- package/design-md/webflow/DESIGN.md +588 -0
- package/design-md/webflow/README.md +5 -0
- package/design-md/wired/DESIGN.md +497 -0
- package/design-md/wired/README.md +5 -0
- package/design-md/wise/DESIGN.md +544 -0
- package/design-md/wise/README.md +5 -0
- package/design-md/x.ai/DESIGN.md +465 -0
- package/design-md/x.ai/README.md +5 -0
- package/design-md/zapier/DESIGN.md +537 -0
- package/design-md/zapier/README.md +5 -0
- 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.
|