getrelay 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (145) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +40 -0
  3. package/bin/relay.js +362 -0
  4. package/design-md/airbnb/DESIGN.md +545 -0
  5. package/design-md/airbnb/README.md +5 -0
  6. package/design-md/airtable/DESIGN.md +554 -0
  7. package/design-md/airtable/README.md +5 -0
  8. package/design-md/apple/DESIGN.md +562 -0
  9. package/design-md/apple/README.md +5 -0
  10. package/design-md/binance/DESIGN.md +634 -0
  11. package/design-md/binance/README.md +5 -0
  12. package/design-md/bmw/DESIGN.md +544 -0
  13. package/design-md/bmw/README.md +5 -0
  14. package/design-md/bmw-m/DESIGN.md +503 -0
  15. package/design-md/bmw-m/README.md +5 -0
  16. package/design-md/bugatti/DESIGN.md +454 -0
  17. package/design-md/bugatti/README.md +5 -0
  18. package/design-md/cal/DESIGN.md +542 -0
  19. package/design-md/cal/README.md +5 -0
  20. package/design-md/claude/DESIGN.md +589 -0
  21. package/design-md/claude/README.md +5 -0
  22. package/design-md/clay/DESIGN.md +541 -0
  23. package/design-md/clay/README.md +5 -0
  24. package/design-md/clickhouse/DESIGN.md +544 -0
  25. package/design-md/clickhouse/README.md +5 -0
  26. package/design-md/cohere/DESIGN.md +451 -0
  27. package/design-md/cohere/README.md +5 -0
  28. package/design-md/coinbase/DESIGN.md +570 -0
  29. package/design-md/coinbase/README.md +5 -0
  30. package/design-md/composio/DESIGN.md +506 -0
  31. package/design-md/composio/README.md +5 -0
  32. package/design-md/cursor/DESIGN.md +537 -0
  33. package/design-md/cursor/README.md +5 -0
  34. package/design-md/elevenlabs/DESIGN.md +504 -0
  35. package/design-md/elevenlabs/README.md +5 -0
  36. package/design-md/expo/DESIGN.md +526 -0
  37. package/design-md/expo/README.md +5 -0
  38. package/design-md/ferrari/DESIGN.md +531 -0
  39. package/design-md/ferrari/README.md +5 -0
  40. package/design-md/figma/DESIGN.md +578 -0
  41. package/design-md/figma/README.md +5 -0
  42. package/design-md/framer/DESIGN.md +544 -0
  43. package/design-md/framer/README.md +5 -0
  44. package/design-md/hashicorp/DESIGN.md +575 -0
  45. package/design-md/hashicorp/README.md +5 -0
  46. package/design-md/ibm/DESIGN.md +550 -0
  47. package/design-md/ibm/README.md +5 -0
  48. package/design-md/intercom/DESIGN.md +546 -0
  49. package/design-md/intercom/README.md +5 -0
  50. package/design-md/kraken/DESIGN.md +125 -0
  51. package/design-md/kraken/README.md +5 -0
  52. package/design-md/lamborghini/DESIGN.md +288 -0
  53. package/design-md/lamborghini/README.md +5 -0
  54. package/design-md/linear.app/DESIGN.md +548 -0
  55. package/design-md/linear.app/README.md +5 -0
  56. package/design-md/lovable/DESIGN.md +298 -0
  57. package/design-md/lovable/README.md +5 -0
  58. package/design-md/mastercard/DESIGN.md +365 -0
  59. package/design-md/mastercard/README.md +5 -0
  60. package/design-md/meta/DESIGN.md +683 -0
  61. package/design-md/meta/README.md +5 -0
  62. package/design-md/minimax/DESIGN.md +746 -0
  63. package/design-md/minimax/README.md +5 -0
  64. package/design-md/mintlify/DESIGN.md +852 -0
  65. package/design-md/mintlify/README.md +5 -0
  66. package/design-md/miro/DESIGN.md +825 -0
  67. package/design-md/miro/README.md +5 -0
  68. package/design-md/mistral.ai/DESIGN.md +773 -0
  69. package/design-md/mistral.ai/README.md +5 -0
  70. package/design-md/mongodb/DESIGN.md +767 -0
  71. package/design-md/mongodb/README.md +5 -0
  72. package/design-md/nike/DESIGN.md +575 -0
  73. package/design-md/nike/README.md +5 -0
  74. package/design-md/notion/DESIGN.md +821 -0
  75. package/design-md/notion/README.md +5 -0
  76. package/design-md/nvidia/DESIGN.md +640 -0
  77. package/design-md/nvidia/README.md +5 -0
  78. package/design-md/ollama/DESIGN.md +539 -0
  79. package/design-md/ollama/README.md +5 -0
  80. package/design-md/opencode.ai/DESIGN.md +521 -0
  81. package/design-md/opencode.ai/README.md +5 -0
  82. package/design-md/pinterest/DESIGN.md +597 -0
  83. package/design-md/pinterest/README.md +5 -0
  84. package/design-md/playstation/DESIGN.md +661 -0
  85. package/design-md/playstation/README.md +5 -0
  86. package/design-md/posthog/DESIGN.md +690 -0
  87. package/design-md/posthog/README.md +5 -0
  88. package/design-md/raycast/DESIGN.md +669 -0
  89. package/design-md/raycast/README.md +5 -0
  90. package/design-md/renault/DESIGN.md +589 -0
  91. package/design-md/renault/README.md +5 -0
  92. package/design-md/replicate/DESIGN.md +616 -0
  93. package/design-md/replicate/README.md +5 -0
  94. package/design-md/resend/DESIGN.md +585 -0
  95. package/design-md/resend/README.md +5 -0
  96. package/design-md/revolut/DESIGN.md +636 -0
  97. package/design-md/revolut/README.md +5 -0
  98. package/design-md/runwayml/DESIGN.md +244 -0
  99. package/design-md/runwayml/README.md +5 -0
  100. package/design-md/sanity/DESIGN.md +357 -0
  101. package/design-md/sanity/README.md +5 -0
  102. package/design-md/sentry/DESIGN.md +551 -0
  103. package/design-md/sentry/README.md +5 -0
  104. package/design-md/shopify/DESIGN.md +516 -0
  105. package/design-md/shopify/README.md +5 -0
  106. package/design-md/slack/DESIGN.md +482 -0
  107. package/design-md/spacex/DESIGN.md +363 -0
  108. package/design-md/spacex/README.md +5 -0
  109. package/design-md/spotify/DESIGN.md +246 -0
  110. package/design-md/spotify/README.md +5 -0
  111. package/design-md/starbucks/DESIGN.md +580 -0
  112. package/design-md/starbucks/README.md +5 -0
  113. package/design-md/stripe/DESIGN.md +487 -0
  114. package/design-md/stripe/README.md +5 -0
  115. package/design-md/supabase/DESIGN.md +462 -0
  116. package/design-md/supabase/README.md +5 -0
  117. package/design-md/superhuman/DESIGN.md +448 -0
  118. package/design-md/superhuman/README.md +5 -0
  119. package/design-md/tesla/DESIGN.md +286 -0
  120. package/design-md/tesla/README.md +5 -0
  121. package/design-md/theverge/DESIGN.md +339 -0
  122. package/design-md/theverge/README.md +5 -0
  123. package/design-md/together.ai/DESIGN.md +633 -0
  124. package/design-md/together.ai/README.md +5 -0
  125. package/design-md/uber/DESIGN.md +636 -0
  126. package/design-md/uber/README.md +5 -0
  127. package/design-md/vercel/DESIGN.md +736 -0
  128. package/design-md/vercel/README.md +5 -0
  129. package/design-md/vodafone/DESIGN.md +538 -0
  130. package/design-md/vodafone/README.md +5 -0
  131. package/design-md/voltagent/DESIGN.md +521 -0
  132. package/design-md/voltagent/README.md +5 -0
  133. package/design-md/warp/DESIGN.md +526 -0
  134. package/design-md/warp/README.md +5 -0
  135. package/design-md/webflow/DESIGN.md +588 -0
  136. package/design-md/webflow/README.md +5 -0
  137. package/design-md/wired/DESIGN.md +497 -0
  138. package/design-md/wired/README.md +5 -0
  139. package/design-md/wise/DESIGN.md +544 -0
  140. package/design-md/wise/README.md +5 -0
  141. package/design-md/x.ai/DESIGN.md +465 -0
  142. package/design-md/x.ai/README.md +5 -0
  143. package/design-md/zapier/DESIGN.md +537 -0
  144. package/design-md/zapier/README.md +5 -0
  145. package/package.json +31 -0
@@ -0,0 +1,544 @@
1
+ ---
2
+ version: alpha
3
+ name: Wise Inspired
4
+ description: An inspired interpretation of Wise's design language — a global money-transfer brand whose surface combines an unusually heavy near-black display sans (weight 900 at 64–126 px) with a vivid lime-green brand accent, sage-tinted surface neutrals, and rounded white cards on a pale green-tinted canvas; the whole system reads more like a Scandinavian fintech magazine than a bank.
5
+
6
+ colors:
7
+ primary: "#9fe870"
8
+ on-primary: "#0e0f0c"
9
+ primary-active: "#cdffad"
10
+ primary-neutral: "#c5edab"
11
+ primary-pale: "#e2f6d5"
12
+ ink: "#0e0f0c"
13
+ ink-deep: "#163300"
14
+ body: "#454745"
15
+ mute: "#868685"
16
+ canvas: "#ffffff"
17
+ canvas-soft: "#e8ebe6"
18
+ positive: "#2ead4b"
19
+ positive-deep: "#054d28"
20
+ warning: "#ffd11a"
21
+ warning-deep: "#b86700"
22
+ warning-content: "#4a3b1c"
23
+ negative: "#d03238"
24
+ negative-deep: "#a72027"
25
+ negative-darkest: "#a7000d"
26
+ negative-bg: "#320707"
27
+ accent-orange: "#ffc091"
28
+ accent-cyan: "#38c8ff"
29
+
30
+ typography:
31
+ display-mega:
32
+ fontFamily: Wise Sans, Inter, system-ui, -apple-system, sans-serif
33
+ fontSize: 126px
34
+ fontWeight: 900
35
+ lineHeight: 107.1px
36
+ display-xxl:
37
+ fontFamily: Wise Sans, Inter, system-ui, sans-serif
38
+ fontSize: 96px
39
+ fontWeight: 900
40
+ lineHeight: 81.6px
41
+ display-xl:
42
+ fontFamily: Wise Sans, Inter, system-ui, sans-serif
43
+ fontSize: 64px
44
+ fontWeight: 900
45
+ lineHeight: 54.4px
46
+ display-lg:
47
+ fontFamily: Wise Sans, Inter, system-ui, sans-serif
48
+ fontSize: 47px
49
+ fontWeight: 400
50
+ lineHeight: 70.5px
51
+ letterSpacing: -0.108px
52
+ display-md:
53
+ fontFamily: Wise Sans, Inter, system-ui, sans-serif
54
+ fontSize: 40px
55
+ fontWeight: 900
56
+ lineHeight: 34px
57
+ display-sm:
58
+ fontFamily: Inter, system-ui, sans-serif
59
+ fontSize: 32px
60
+ fontWeight: 600
61
+ lineHeight: 38.4px
62
+ letterSpacing: -0.96px
63
+ display-xs:
64
+ fontFamily: Inter, system-ui, sans-serif
65
+ fontSize: 24px
66
+ fontWeight: 600
67
+ lineHeight: 31.2px
68
+ letterSpacing: -0.48px
69
+ body-lg:
70
+ fontFamily: Inter, system-ui, sans-serif
71
+ fontSize: 20px
72
+ fontWeight: 400
73
+ lineHeight: 30px
74
+ body-md:
75
+ fontFamily: Inter, system-ui, sans-serif
76
+ fontSize: 16px
77
+ fontWeight: 400
78
+ lineHeight: 24px
79
+ body-md-strong:
80
+ fontFamily: Inter, system-ui, sans-serif
81
+ fontSize: 16px
82
+ fontWeight: 600
83
+ lineHeight: 24px
84
+ body-sm:
85
+ fontFamily: Inter, system-ui, sans-serif
86
+ fontSize: 14px
87
+ fontWeight: 400
88
+ lineHeight: 20px
89
+ body-sm-strong:
90
+ fontFamily: Inter, system-ui, sans-serif
91
+ fontSize: 14px
92
+ fontWeight: 600
93
+ lineHeight: 20px
94
+ caption:
95
+ fontFamily: Inter, system-ui, sans-serif
96
+ fontSize: 12px
97
+ fontWeight: 400
98
+ lineHeight: 16px
99
+ button-md:
100
+ fontFamily: Inter, system-ui, sans-serif
101
+ fontSize: 16px
102
+ fontWeight: 600
103
+ lineHeight: 24px
104
+
105
+ rounded:
106
+ none: 0px
107
+ sm: 8px
108
+ md: 12px
109
+ lg: 16px
110
+ xl: 24px
111
+ pill: 9999px
112
+ full: 9999px
113
+
114
+ spacing:
115
+ xxs: 2px
116
+ xs: 4px
117
+ sm: 8px
118
+ md: 12px
119
+ lg: 16px
120
+ xl: 24px
121
+ 2xl: 32px
122
+ 3xl: 48px
123
+
124
+ components:
125
+ nav-bar:
126
+ backgroundColor: "{colors.canvas}"
127
+ textColor: "{colors.ink}"
128
+ typography: "{typography.body-sm-strong}"
129
+ padding: "{spacing.md} {spacing.xl}"
130
+ nav-link:
131
+ textColor: "{colors.ink}"
132
+ typography: "{typography.body-sm-strong}"
133
+ button-primary:
134
+ backgroundColor: "{colors.primary}"
135
+ textColor: "{colors.on-primary}"
136
+ typography: "{typography.button-md}"
137
+ rounded: "{rounded.xl}"
138
+ padding: "{spacing.md} {spacing.xl}"
139
+ button-secondary:
140
+ backgroundColor: "{colors.canvas-soft}"
141
+ textColor: "{colors.ink}"
142
+ typography: "{typography.button-md}"
143
+ rounded: "{rounded.xl}"
144
+ padding: "{spacing.md} {spacing.xl}"
145
+ button-tertiary:
146
+ backgroundColor: "{colors.canvas}"
147
+ textColor: "{colors.ink}"
148
+ borderColor: "{colors.ink}"
149
+ typography: "{typography.button-md}"
150
+ rounded: "{rounded.xl}"
151
+ padding: "{spacing.md} {spacing.xl}"
152
+ button-icon-circular:
153
+ backgroundColor: "{colors.canvas}"
154
+ textColor: "{colors.ink}"
155
+ rounded: "{rounded.full}"
156
+ padding: "{spacing.sm}"
157
+ text-input:
158
+ backgroundColor: "{colors.canvas}"
159
+ textColor: "{colors.ink}"
160
+ borderColor: "{colors.ink}"
161
+ typography: "{typography.body-md}"
162
+ rounded: "{rounded.md}"
163
+ padding: "{spacing.md} {spacing.lg}"
164
+ card-content:
165
+ backgroundColor: "{colors.canvas}"
166
+ textColor: "{colors.ink}"
167
+ typography: "{typography.body-md}"
168
+ rounded: "{rounded.xl}"
169
+ padding: "{spacing.xl}"
170
+ card-feature-sage:
171
+ backgroundColor: "{colors.canvas-soft}"
172
+ textColor: "{colors.ink}"
173
+ typography: "{typography.body-md}"
174
+ rounded: "{rounded.xl}"
175
+ padding: "{spacing.xl}"
176
+ card-feature-green:
177
+ backgroundColor: "{colors.primary-pale}"
178
+ textColor: "{colors.ink}"
179
+ typography: "{typography.body-md}"
180
+ rounded: "{rounded.xl}"
181
+ padding: "{spacing.xl}"
182
+ card-feature-dark:
183
+ backgroundColor: "{colors.ink}"
184
+ textColor: "{colors.primary}"
185
+ typography: "{typography.body-md}"
186
+ rounded: "{rounded.xl}"
187
+ padding: "{spacing.xl}"
188
+ hero-band:
189
+ backgroundColor: "{colors.canvas-soft}"
190
+ textColor: "{colors.ink}"
191
+ typography: "{typography.display-mega}"
192
+ padding: "{spacing.3xl} {spacing.xl}"
193
+ hero-band-dark:
194
+ backgroundColor: "{colors.ink}"
195
+ textColor: "{colors.primary}"
196
+ typography: "{typography.display-mega}"
197
+ padding: "{spacing.3xl} {spacing.xl}"
198
+ content-band:
199
+ backgroundColor: "{colors.canvas}"
200
+ textColor: "{colors.ink}"
201
+ typography: "{typography.display-md}"
202
+ padding: "{spacing.3xl} {spacing.xl}"
203
+ currency-converter-card:
204
+ backgroundColor: "{colors.canvas}"
205
+ textColor: "{colors.ink}"
206
+ borderColor: "{colors.ink}"
207
+ typography: "{typography.body-md}"
208
+ rounded: "{rounded.xl}"
209
+ padding: "{spacing.xl}"
210
+ badge-positive:
211
+ backgroundColor: "{colors.primary-pale}"
212
+ textColor: "{colors.positive-deep}"
213
+ typography: "{typography.body-sm-strong}"
214
+ rounded: "{rounded.pill}"
215
+ padding: "{spacing.xs} {spacing.md}"
216
+ badge-negative:
217
+ backgroundColor: "{colors.negative-bg}"
218
+ textColor: "{colors.on-primary}"
219
+ typography: "{typography.body-sm-strong}"
220
+ rounded: "{rounded.pill}"
221
+ padding: "{spacing.xs} {spacing.md}"
222
+ footer:
223
+ backgroundColor: "{colors.ink}"
224
+ textColor: "{colors.canvas-soft}"
225
+ typography: "{typography.body-sm}"
226
+ padding: "{spacing.3xl} {spacing.xl}"
227
+
228
+ # ─── Examples (illustrative) — auto-derived; resolve any TO_FILL markers below ───
229
+ ex-pricing-tier:
230
+ description: "Default Pricing tier card. Re-uses feature-card chrome with brand canvas-soft surface."
231
+ backgroundColor: "{colors.canvas-soft}"
232
+ textColor: "{colors.ink}"
233
+ borderColor: "{colors.mute}"
234
+ rounded: "{rounded.xl}"
235
+ padding: "{spacing.xl}"
236
+ ex-pricing-tier-featured:
237
+ description: "Featured/highlighted tier — polarity-flipped surface (dark fill + light text in light mode, light fill + dark text in dark mode)."
238
+ backgroundColor: "{colors.ink}"
239
+ textColor: "{colors.on-primary}"
240
+ rounded: "{rounded.xl}"
241
+ padding: "{spacing.xl}"
242
+ ex-product-selector:
243
+ description: "What's Included summary card — re-purposed for SaaS / B2B verticals (NOT a literal product gallery)."
244
+ backgroundColor: "{colors.canvas-soft}"
245
+ rounded: "{rounded.xl}"
246
+ padding: "{spacing.xl}"
247
+ ex-cart-drawer:
248
+ description: "Subscription summary — re-purposed for SaaS / B2B (line items per add-on, not literal cart)."
249
+ backgroundColor: "{colors.canvas}"
250
+ rounded: "{rounded.xl}"
251
+ padding: "{spacing.xl}"
252
+ item-divider: "{colors.canvas-soft}"
253
+ ex-app-shell-row:
254
+ description: "Sidebar nav row inside the App Shell example. Active state uses brand primary as the indicator."
255
+ backgroundColor: "{colors.canvas}"
256
+ activeIndicator: "{colors.primary}"
257
+ rounded: "{rounded.sm}"
258
+ padding: "{spacing.md} {spacing.lg}"
259
+ ex-data-table-cell:
260
+ description: "Default data-table th + td chrome. Header uses mono-caps eyebrow typography; body uses body-sm."
261
+ headerBackground: "{colors.canvas-soft}"
262
+ headerTypography: "{typography.caption}"
263
+ bodyTypography: "{typography.body-sm}"
264
+ cellPadding: "{spacing.md} {spacing.lg}"
265
+ rowBorder: "{colors.canvas-soft}"
266
+ ex-auth-form-card:
267
+ description: "Sign-in / sign-up card. Re-uses feature-card chrome with text-input primitives inside."
268
+ backgroundColor: "{colors.canvas-soft}"
269
+ rounded: "{rounded.xl}"
270
+ padding: "{spacing.xl}"
271
+ ex-modal-card:
272
+ description: "Modal dialog surface — same chrome as feature-card with elevated shadow."
273
+ backgroundColor: "{colors.canvas}"
274
+ rounded: "{rounded.xl}"
275
+ padding: "{spacing.xl}"
276
+ ex-empty-state-card:
277
+ description: "Empty-state illustration frame."
278
+ backgroundColor: "{colors.canvas-soft}"
279
+ rounded: "{rounded.xl}"
280
+ padding: "{spacing.3xl}"
281
+ captionTypography: "{typography.body-md}"
282
+ ex-toast:
283
+ description: "Toast notification surface — feature-card shape + medium shadow."
284
+ backgroundColor: "{colors.canvas}"
285
+ rounded: "{rounded.xl}"
286
+ padding: "{spacing.md} {spacing.lg}"
287
+ typography: "{typography.body-sm}"
288
+
289
+ ---
290
+
291
+
292
+ ## Overview
293
+
294
+ Wise — the global money-transfer brand — wears its identity in a single signature pairing: a vivid lime-green `{colors.primary}` (`#9fe870`) used as the CTA pill and brand accent, set against a pale sage-tinted canvas `{colors.canvas-soft}` (`#e8ebe6`) that runs across the hero band, and a near-black ink `{colors.ink}` (`#0e0f0c`) with a hint of warmth from the brand's underlying olive cast. The brand reads more like a calm Scandinavian magazine than a bank — generous whitespace, large rounded cards, and an unusually heavy display sans set at weight 900 carrying every hero headline.
295
+
296
+ Display typography is the second decisive voice. The proprietary `Wise Sans` family carries hero displays at weight 900 in scales from 64 px up to 126 px on the largest hero. The brand pairs Wise Sans 900 with Inter at weight 600 for sub-displays — the contrast between the chunky proprietary face and Inter's neutrality creates a particular hierarchy: Wise Sans for the brand moment, Inter for everything else.
297
+
298
+ Cards are universally pill-rounded — `{rounded.xl}` 24 px is the brand's signature card radius. Buttons take the same 24 px pill-rectangle shape. The brand never uses sharp corners on UI elements; the visual softness is part of the friendly fintech voice.
299
+
300
+ **Key Characteristics:**
301
+ - A single lime-green CTA accent `{colors.primary}` (`#9fe870`) — the brand's universal primary action color. No second accent.
302
+ - Two-face display typography — Wise Sans (proprietary, weight 900, hero scale) + Inter (weight 600, sub-display scale). The contrast is the brand's typographic story.
303
+ - `{rounded.xl}` 24 px is the canonical card and button radius. Generous, friendly.
304
+ - Sage-tinted canvas `{colors.canvas-soft}` (`#e8ebe6`) is the brand's hero surface; white `{colors.canvas}` is reserved for cards within the sage band.
305
+ - A full semantic palette: positive green family, warning yellow family, negative red family — each documented with content / hover / active variants for in-product use.
306
+ - Currency-converter card on the hero — the brand's signature interactive component, hosting from/to amount inputs.
307
+
308
+ ## Colors
309
+
310
+ ### Brand & Accent
311
+ - **Wise Green** (`{colors.primary}` — `#9fe870`): The brand's universal CTA color. Every primary button, every "Send money" pill, the brand's logo accent.
312
+ - **Wise Green Hover** (`{colors.primary-active}` — `#cdffad`): The lighter green for active state.
313
+ - **Wise Green Neutral** (`{colors.primary-neutral}` — `#c5edab`): A mid-saturation green used as a neutral active fill.
314
+ - **Wise Green Pale** (`{colors.primary-pale}` — `#e2f6d5`): The lightest green for soft surface tints / badge backgrounds.
315
+
316
+ ### Surface
317
+ - **Canvas** (`{colors.canvas}` — `#ffffff`): Pure white for card interiors.
318
+ - **Canvas Soft** (`{colors.canvas-soft}` — `#e8ebe6`): The sage-tinted page background. Defining mood of the brand.
319
+
320
+ ### Text
321
+ - **Ink** (`{colors.ink}` — `#0e0f0c`): Near-black with a hint of olive warmth — the brand's default text and headings color.
322
+ - **Ink Deep** (`{colors.ink-deep}` — `#163300`): A deep forest-green ink used on positive-state surfaces.
323
+ - **Body** (`{colors.body}` — `#454745`): Secondary body text.
324
+ - **Mute** (`{colors.mute}` — `#868685`): Lowest-priority text — captions, placeholder, fine print.
325
+
326
+ ### Semantic
327
+ - **Positive** (`{colors.positive}` — `#2ead4b`): Success indicator.
328
+ - **Positive Deep** (`{colors.positive-deep}` — `#054d28`): Pressed positive state.
329
+ - **Warning** (`{colors.warning}` — `#ffd11a`): Caution indicator.
330
+ - **Warning Deep** (`{colors.warning-deep}` — `#b86700`): Pressed warning.
331
+ - **Warning Content** (`{colors.warning-content}` — `#4a3b1c`): Text on warning surfaces.
332
+ - **Negative** (`{colors.negative}` — `#d03238`): Destructive / error red.
333
+ - **Negative Deep** (`{colors.negative-deep}` — `#a72027`): Pressed destructive.
334
+ - **Negative Darkest** (`{colors.negative-darkest}` — `#a7000d`): Highest-emphasis destructive text.
335
+ - **Negative Bg** (`{colors.negative-bg}` — `#320707`): Dark maroon for destructive callout backgrounds.
336
+
337
+ ### Brand Accent — Tertiary
338
+ - **Accent Orange** (`{colors.accent-orange}` — `#ffc091`): Bright peach used inside illustrative content / pricing cards.
339
+ - **Accent Cyan** (`{colors.accent-cyan}` — `#38c8ff`): Bright sky-blue used as a tertiary illustration accent.
340
+
341
+ ## Typography
342
+
343
+ ### Font Family
344
+ Two faces ladder the system:
345
+ 1. **Wise Sans** — proprietary geometric sans with an unusually heavy weight 900 used for all hero displays. The face is the brand's typographic signature. Always at weight 900, never lighter on the marketing surface.
346
+ 2. **Inter** — used for sub-displays (weight 600), all body, and form labels. Loaded with `font-feature-settings: "calt"` for contextual alternates.
347
+
348
+ ### Hierarchy
349
+
350
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
351
+ |---|---|---|---|---|---|
352
+ | `{typography.display-mega}` | 126px | 900 | 107.1px | 0 | Hero stencil at maximum scale. |
353
+ | `{typography.display-xxl}` | 96px | 900 | 81.6px | 0 | Sub-hero scale. |
354
+ | `{typography.display-xl}` | 64px | 900 | 54.4px | 0 | Standard hero headline. |
355
+ | `{typography.display-lg}` | 47px | 400 | 70.5px | -0.108px | Lighter sub-display. |
356
+ | `{typography.display-md}` | 40px | 900 | 34px | 0 | Section / card headlines. |
357
+ | `{typography.display-sm}` | 32px | 600 | 38.4px | -0.96px | Inter-rendered section headings. |
358
+ | `{typography.display-xs}` | 24px | 600 | 31.2px | -0.48px | Sub-section displays. |
359
+ | `{typography.body-lg}` | 20px | 400 | 30px | 0 | Lead paragraphs. |
360
+ | `{typography.body-md}` | 16px | 400 | 24px | 0 | Default body. |
361
+ | `{typography.body-md-strong}` | 16px | 600 | 24px | 0 | Bold inline body. |
362
+ | `{typography.body-sm}` | 14px | 400 | 20px | 0 | Secondary body. |
363
+ | `{typography.body-sm-strong}` | 14px | 600 | 20px | 0 | Bold caption / nav-link. |
364
+ | `{typography.caption}` | 12px | 400 | 16px | 0 | Fine print. |
365
+ | `{typography.button-md}` | 16px | 600 | 24px | 0 | Button label. |
366
+
367
+ ### Principles
368
+ - **Weight 900 for hero, weight 600 for everything else.** The brand's display ceiling is full-black weight; everything below is semibold.
369
+ - **Wise Sans for the brand voice, Inter for utility.** Strict role separation.
370
+
371
+ ### Note on Font Substitutes
372
+ Wise Sans is proprietary. Open-source substitutes:
373
+ - **Display** — *Inter* at weight 900 or *Manrope* at weight 800 / 900 captures the geometric heaviness. *Geist* weight 800 is a passable second choice.
374
+ - **Sub-display + body** — *Inter* is the brand's actual second face.
375
+
376
+ ## Layout
377
+
378
+ ### Spacing System
379
+ - **Base unit**: 4 px.
380
+ - **Tokens**: `{spacing.xxs}` 2 px · `{spacing.xs}` 4 px · `{spacing.sm}` 8 px · `{spacing.md}` 12 px · `{spacing.lg}` 16 px · `{spacing.xl}` 24 px · `{spacing.2xl}` 32 px · `{spacing.3xl}` 48 px.
381
+ - **Section padding**: bands use `{spacing.3xl}` 48 px top/bottom on desktop.
382
+ - **Card interior**: cards at `{spacing.xl}` 24 px.
383
+
384
+ ### Grid & Container
385
+ - Marketing container centres at ~1200 px.
386
+ - Hero: split layout (headline left, currency-converter card right) at desktop; stacked at mobile.
387
+ - Feature grids: 2-up / 3-up at desktop.
388
+
389
+ ### Responsive Strategy
390
+
391
+ #### Breakpoints
392
+
393
+ | Name | Width | Key Changes |
394
+ |---|---|---|
395
+ | Mobile | < 768px | Hero stacks; converter card full-width below headline; grids 1-up. |
396
+ | Tablet | 768–1023px | Grids 2-up. |
397
+ | Desktop | ≥ 1024px | Hero split; full grids. |
398
+
399
+ #### Touch Targets
400
+ Buttons render ~48 px tall (12 vertical padding + 24 line). WCAG AAA at all widths.
401
+
402
+ #### Image Behavior
403
+ Photography is sparse; the brand prefers illustrative SVGs and product mockups inside cards. Country flag thumbnails appear inside currency rows.
404
+
405
+ ## Elevation & Depth
406
+
407
+ | Level | Treatment | Use |
408
+ |---|---|---|
409
+ | Level 0 — Flat | No shadow, no border. | Default. |
410
+ | Level 1 — Hairline on Dark | 1 px solid `{colors.ink}` border. | Tertiary outline buttons, form inputs. |
411
+ | Level 2 — Soft Card | Implicit Level 0 white card sitting on sage canvas — the surface contrast IS the elevation. | Cards on the sage hero band. |
412
+
413
+ The brand uses surface contrast (`{colors.canvas-soft}` background vs `{colors.canvas}` cards) as the primary elevation cue.
414
+
415
+ ## Shapes
416
+
417
+ ### Border Radius Scale
418
+
419
+ | Token | Value | Use |
420
+ |---|---|---|
421
+ | `{rounded.none}` | 0px | Full-bleed bands. |
422
+ | `{rounded.sm}` | 8px | Inline pills, small badges. |
423
+ | `{rounded.md}` | 12px | Form inputs, smaller chrome. |
424
+ | `{rounded.lg}` | 16px | Mid-size cards. |
425
+ | `{rounded.xl}` | 24px | The brand's canonical button + card radius. |
426
+ | `{rounded.pill}` | 9999px | Status pills and full-radius accents. |
427
+ | `{rounded.full}` | 9999px | Circular icon containers. |
428
+
429
+ ## Components
430
+
431
+ ### Buttons
432
+
433
+ **`button-primary`** — the lime-green CTA pill.
434
+ - Background `{colors.primary}`, text `{colors.on-primary}`, label `{typography.button-md}`, padding `{spacing.md} {spacing.xl}`, shape `{rounded.xl}` 24 px.
435
+
436
+ **`button-secondary`** — the sage-tinted secondary.
437
+ - Background `{colors.canvas-soft}`, text `{colors.ink}`, same typography / padding / shape.
438
+
439
+ **`button-tertiary`** — the white outline tertiary.
440
+ - Background `{colors.canvas}`, text `{colors.ink}`, 1 px solid `{colors.ink}` border, same typography / padding / shape.
441
+
442
+ **`button-icon-circular`** — the circular icon button.
443
+ - Background `{colors.canvas}`, ink icon, shape `{rounded.full}`.
444
+
445
+ ### Cards & Containers
446
+
447
+ **`card-content`** — the default white card.
448
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.xl}`, shape `{rounded.xl}`. No border, sits on sage canvas.
449
+
450
+ **`card-feature-sage`** — the sage-tinted feature card.
451
+ - Background `{colors.canvas-soft}`, text `{colors.ink}`, padding `{spacing.xl}`, shape `{rounded.xl}`.
452
+
453
+ **`card-feature-green`** — the soft-green feature card.
454
+ - Background `{colors.primary-pale}`, text `{colors.ink}`, padding `{spacing.xl}`, shape `{rounded.xl}`.
455
+
456
+ **`card-feature-dark`** — the polarity-flipped dark card with green text.
457
+ - Background `{colors.ink}`, text `{colors.primary}` (Wise green!), padding `{spacing.xl}`, shape `{rounded.xl}`. Used for promotional moments.
458
+
459
+ **`currency-converter-card`** — the brand's signature interactive widget.
460
+ - Background `{colors.canvas}`, text `{colors.ink}`, 1 px solid `{colors.ink}` border, padding `{spacing.xl}`, shape `{rounded.xl}`. Hosts from/to amount inputs + currency selectors.
461
+
462
+ ### Inputs & Forms
463
+
464
+ **`text-input`** — the canonical text input.
465
+ - Background `{colors.canvas}`, text `{colors.ink}`, 1 px solid `{colors.ink}` border, body in `{typography.body-md}`, padding `{spacing.md} {spacing.lg}`, shape `{rounded.md}`.
466
+
467
+ ### Navigation
468
+
469
+ **`nav-bar`** — the sticky top nav.
470
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.md} {spacing.xl}`.
471
+
472
+ **`nav-link`** — link items inside nav.
473
+ - Text `{colors.ink}`, set in `{typography.body-sm-strong}`.
474
+
475
+ **`footer`** — the dark footer band.
476
+ - Background `{colors.ink}`, text `{colors.canvas-soft}`, padding `{spacing.3xl} {spacing.xl}`. Body in `{typography.body-sm}`.
477
+
478
+ ### Signature Components
479
+
480
+ **`hero-band`** — the sage-canvas hero band.
481
+ - Background `{colors.canvas-soft}`, text `{colors.ink}`, padding `{spacing.3xl} {spacing.xl}`. Headline in `{typography.display-mega}` (Wise Sans weight 900).
482
+
483
+ **`hero-band-dark`** — the polarity-flipped dark hero.
484
+ - Background `{colors.ink}`, text `{colors.primary}` (Wise green headline on near-black!), same padding / scale.
485
+
486
+ **`content-band`** — the white content band that follows hero.
487
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.3xl} {spacing.xl}`. Section headline in `{typography.display-md}`.
488
+
489
+ **`badge-positive`** — the positive status pill.
490
+ - Background `{colors.primary-pale}`, text `{colors.positive-deep}`, body in `{typography.body-sm-strong}`, padding `{spacing.xs} {spacing.md}`, shape `{rounded.pill}`.
491
+
492
+ **`badge-negative`** — the negative status pill.
493
+ - Background `{colors.negative-bg}`, text white, body in `{typography.body-sm-strong}`, padding `{spacing.xs} {spacing.md}`, shape `{rounded.pill}`.
494
+
495
+ ### Examples (illustrative)
496
+
497
+ > Auto-derived kit-mirror demonstration surfaces (`scripts/derive-examples-block.mjs`). Each `ex-*` entry references brand-native primitives so downstream consumers (`/preview-design`, `/generate-kit`) re-skin the same 10 surfaces consistently. `TO_FILL` markers indicate missing primitives — resolve in the LLM judgment pass.
498
+
499
+ **`ex-pricing-tier`** — Default Pricing tier card. Re-uses feature-card chrome with brand canvas-soft surface.
500
+ - Properties: `backgroundColor`, `textColor`, `borderColor`, `rounded`, `padding`
501
+
502
+ **`ex-pricing-tier-featured`** — Featured/highlighted tier — polarity-flipped surface (dark fill + light text in light mode, light fill + dark text in dark mode).
503
+ - Properties: `backgroundColor`, `textColor`, `rounded`, `padding`
504
+
505
+ **`ex-product-selector`** — What's Included summary card — re-purposed for SaaS / B2B verticals (NOT a literal product gallery).
506
+ - Properties: `backgroundColor`, `rounded`, `padding`
507
+
508
+ **`ex-cart-drawer`** — Subscription summary — re-purposed for SaaS / B2B (line items per add-on, not literal cart).
509
+ - Properties: `backgroundColor`, `rounded`, `padding`, `item-divider`
510
+
511
+ **`ex-app-shell-row`** — Sidebar nav row inside the App Shell example. Active state uses brand primary as the indicator.
512
+ - Properties: `backgroundColor`, `activeIndicator`, `rounded`, `padding`
513
+
514
+ **`ex-data-table-cell`** — Default data-table th + td chrome. Header uses mono-caps eyebrow typography; body uses body-sm.
515
+ - Properties: `headerBackground`, `headerTypography`, `bodyTypography`, `cellPadding`, `rowBorder`
516
+
517
+ **`ex-auth-form-card`** — Sign-in / sign-up card. Re-uses feature-card chrome with text-input primitives inside.
518
+ - Properties: `backgroundColor`, `rounded`, `padding`
519
+
520
+ **`ex-modal-card`** — Modal dialog surface — same chrome as feature-card with elevated shadow.
521
+ - Properties: `backgroundColor`, `rounded`, `padding`
522
+
523
+ **`ex-empty-state-card`** — Empty-state illustration frame.
524
+ - Properties: `backgroundColor`, `rounded`, `padding`, `captionTypography`
525
+
526
+ **`ex-toast`** — Toast notification surface — feature-card shape + medium shadow.
527
+ - Properties: `backgroundColor`, `rounded`, `padding`, `typography`
528
+
529
+
530
+ ## Do's and Don'ts
531
+
532
+ ### Do
533
+ - Reserve `{colors.primary}` Wise green for every primary CTA. The lime-green pill IS the brand's conversion signature.
534
+ - Set hero headlines in `{typography.display-mega}` / `{typography.display-xl}` Wise Sans weight 900. Never lighter.
535
+ - Use `{rounded.xl}` 24 px for buttons and cards. The generous radius is the brand's friendliness signature.
536
+ - Cycle page surfaces in `{colors.canvas-soft}` sage canvas → `{colors.canvas}` white cards. Surface contrast carries elevation.
537
+ - Use the full semantic palette (positive / warning / negative) for in-product status — never repurpose Wise green as success indicator since it IS the brand CTA.
538
+
539
+ ### Don't
540
+ - Don't introduce a second brand accent. Wise green is the sole identity colour.
541
+ - Don't render the hero in weight 700 or lighter. The brand's display weight is 900.
542
+ - Don't render CTAs as sharp rectangles. The 24 px pill geometry is non-negotiable.
543
+ - Don't pair the green CTA with a green background. The brand always sits Wise green on neutral surfaces (sage / white / ink).
544
+ - Don't replace Wise Sans with a generic geometric sans for hero typography — the proprietary face IS the brand's voice.
@@ -0,0 +1,5 @@
1
+ # Wise Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/wise/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.