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,578 @@
1
+ ---
2
+ version: alpha
3
+ name: Figma
4
+ description: "A confident black-and-white editorial frame interrupted by oversized, hand-cut pastel color blocks. The marketing canvas is rigorously monochrome — figmaSans variable type, pure white surfaces, pure black ink, pill-shaped CTAs — while each story section drops the page into a saturated lime, lavender, cream, mint, or pink panel that reads like a sticky note placed on a clean desk. The result is a design system that feels both technical and joyful — a tool for serious work, made by people who like color."
5
+
6
+ colors:
7
+ primary: "#000000"
8
+ on-primary: "#ffffff"
9
+ ink: "#000000"
10
+ canvas: "#ffffff"
11
+ inverse-canvas: "#000000"
12
+ inverse-ink: "#ffffff"
13
+ on-inverse-soft: "#ffffff"
14
+ hairline: "#e6e6e6"
15
+ hairline-soft: "#f1f1f1"
16
+ surface-soft: "#f7f7f5"
17
+ block-lime: "#dceeb1"
18
+ block-lilac: "#c5b0f4"
19
+ block-cream: "#f4ecd6"
20
+ block-pink: "#efd4d4"
21
+ block-mint: "#c8e6cd"
22
+ block-coral: "#f3c9b6"
23
+ block-navy: "#1f1d3d"
24
+ accent-magenta: "#ff3d8b"
25
+ semantic-success: "#1ea64a"
26
+ overlay-scrim: "#000000"
27
+
28
+ typography:
29
+ display-xl:
30
+ fontFamily: figmaSans
31
+ fontSize: 86px
32
+ fontWeight: 340
33
+ lineHeight: 1.00
34
+ letterSpacing: -1.72px
35
+ fontFeature: kern
36
+ display-lg:
37
+ fontFamily: figmaSans
38
+ fontSize: 64px
39
+ fontWeight: 340
40
+ lineHeight: 1.10
41
+ letterSpacing: -0.96px
42
+ fontFeature: kern
43
+ headline:
44
+ fontFamily: figmaSans
45
+ fontSize: 26px
46
+ fontWeight: 540
47
+ lineHeight: 1.35
48
+ letterSpacing: -0.26px
49
+ fontFeature: kern
50
+ subhead:
51
+ fontFamily: figmaSans
52
+ fontSize: 26px
53
+ fontWeight: 340
54
+ lineHeight: 1.35
55
+ letterSpacing: -0.26px
56
+ fontFeature: kern
57
+ card-title:
58
+ fontFamily: figmaSans
59
+ fontSize: 24px
60
+ fontWeight: 700
61
+ lineHeight: 1.45
62
+ letterSpacing: 0
63
+ fontFeature: kern
64
+ body-lg:
65
+ fontFamily: figmaSans
66
+ fontSize: 20px
67
+ fontWeight: 330
68
+ lineHeight: 1.40
69
+ letterSpacing: -0.14px
70
+ fontFeature: kern
71
+ body:
72
+ fontFamily: figmaSans
73
+ fontSize: 18px
74
+ fontWeight: 320
75
+ lineHeight: 1.45
76
+ letterSpacing: -0.26px
77
+ fontFeature: kern
78
+ body-sm:
79
+ fontFamily: figmaSans
80
+ fontSize: 16px
81
+ fontWeight: 330
82
+ lineHeight: 1.45
83
+ letterSpacing: -0.14px
84
+ fontFeature: kern
85
+ link:
86
+ fontFamily: figmaSans
87
+ fontSize: 20px
88
+ fontWeight: 480
89
+ lineHeight: 1.40
90
+ letterSpacing: -0.10px
91
+ fontFeature: kern
92
+ button:
93
+ fontFamily: figmaSans
94
+ fontSize: 20px
95
+ fontWeight: 480
96
+ lineHeight: 1.40
97
+ letterSpacing: -0.10px
98
+ fontFeature: kern
99
+ eyebrow:
100
+ fontFamily: figmaMono
101
+ fontSize: 18px
102
+ fontWeight: 400
103
+ lineHeight: 1.30
104
+ letterSpacing: 0.54px
105
+ fontFeature: kern
106
+ caption:
107
+ fontFamily: figmaMono
108
+ fontSize: 12px
109
+ fontWeight: 400
110
+ lineHeight: 1.00
111
+ letterSpacing: 0.60px
112
+ fontFeature: kern
113
+
114
+ rounded:
115
+ xs: 2px
116
+ sm: 6px
117
+ md: 8px
118
+ lg: 24px
119
+ xl: 32px
120
+ pill: 50px
121
+ full: 9999px
122
+
123
+ spacing:
124
+ hair: 1px
125
+ xxs: 4px
126
+ xs: 8px
127
+ sm: 12px
128
+ md: 16px
129
+ lg: 24px
130
+ xl: 32px
131
+ xxl: 48px
132
+ section: 96px
133
+
134
+ components:
135
+ button-primary:
136
+ backgroundColor: "{colors.primary}"
137
+ textColor: "{colors.on-primary}"
138
+ typography: "{typography.button}"
139
+ rounded: "{rounded.pill}"
140
+ padding: 10px 20px
141
+ button-primary-pressed:
142
+ backgroundColor: "{colors.primary}"
143
+ textColor: "{colors.on-primary}"
144
+ typography: "{typography.button}"
145
+ rounded: "{rounded.pill}"
146
+ button-secondary:
147
+ backgroundColor: "{colors.canvas}"
148
+ textColor: "{colors.ink}"
149
+ typography: "{typography.button}"
150
+ rounded: "{rounded.pill}"
151
+ padding: 8px 18px 10px
152
+ button-tertiary-text:
153
+ backgroundColor: "{colors.canvas}"
154
+ textColor: "{colors.ink}"
155
+ typography: "{typography.link}"
156
+ rounded: "{rounded.full}"
157
+ padding: 8px 12px
158
+ button-icon-circular:
159
+ backgroundColor: "{colors.surface-soft}"
160
+ textColor: "{colors.ink}"
161
+ typography: "{typography.button}"
162
+ rounded: "{rounded.full}"
163
+ size: 40px
164
+ button-icon-circular-inverse:
165
+ backgroundColor: "{colors.on-inverse-soft}"
166
+ textColor: "{colors.inverse-ink}"
167
+ typography: "{typography.button}"
168
+ rounded: "{rounded.full}"
169
+ size: 40px
170
+ button-magenta-promo:
171
+ backgroundColor: "{colors.accent-magenta}"
172
+ textColor: "{colors.on-primary}"
173
+ typography: "{typography.button}"
174
+ rounded: "{rounded.pill}"
175
+ padding: 10px 18px
176
+ pricing-tab-default:
177
+ backgroundColor: "{colors.canvas}"
178
+ textColor: "{colors.ink}"
179
+ typography: "{typography.button}"
180
+ rounded: "{rounded.pill}"
181
+ padding: 8px 18px
182
+ pricing-tab-selected:
183
+ backgroundColor: "{colors.primary}"
184
+ textColor: "{colors.on-primary}"
185
+ typography: "{typography.button}"
186
+ rounded: "{rounded.pill}"
187
+ padding: 8px 18px
188
+ text-input:
189
+ backgroundColor: "{colors.canvas}"
190
+ textColor: "{colors.ink}"
191
+ typography: "{typography.body}"
192
+ rounded: "{rounded.md}"
193
+ padding: 12px 14px
194
+ text-input-focused:
195
+ backgroundColor: "{colors.canvas}"
196
+ textColor: "{colors.ink}"
197
+ typography: "{typography.body}"
198
+ rounded: "{rounded.md}"
199
+ padding: 12px 14px
200
+ pricing-card:
201
+ backgroundColor: "{colors.canvas}"
202
+ textColor: "{colors.ink}"
203
+ typography: "{typography.body}"
204
+ rounded: "{rounded.lg}"
205
+ padding: 24px
206
+ pricing-card-feature-row:
207
+ backgroundColor: "{colors.canvas}"
208
+ textColor: "{colors.ink}"
209
+ typography: "{typography.body-sm}"
210
+ rounded: "{rounded.xs}"
211
+ color-block-section:
212
+ backgroundColor: "{colors.block-lime}"
213
+ textColor: "{colors.ink}"
214
+ typography: "{typography.subhead}"
215
+ rounded: "{rounded.lg}"
216
+ padding: 48px
217
+ color-block-section-lilac:
218
+ backgroundColor: "{colors.block-lilac}"
219
+ textColor: "{colors.ink}"
220
+ typography: "{typography.subhead}"
221
+ rounded: "{rounded.lg}"
222
+ padding: 48px
223
+ color-block-section-navy:
224
+ backgroundColor: "{colors.block-navy}"
225
+ textColor: "{colors.inverse-ink}"
226
+ typography: "{typography.subhead}"
227
+ rounded: "{rounded.lg}"
228
+ padding: 48px
229
+ promo-banner-lilac:
230
+ backgroundColor: "{colors.block-lilac}"
231
+ textColor: "{colors.ink}"
232
+ typography: "{typography.body-sm}"
233
+ rounded: "{rounded.md}"
234
+ padding: 16px 24px
235
+ template-card:
236
+ backgroundColor: "{colors.surface-soft}"
237
+ textColor: "{colors.ink}"
238
+ typography: "{typography.body-sm}"
239
+ rounded: "{rounded.md}"
240
+ padding: 16px
241
+ feature-illustration-tile:
242
+ backgroundColor: "{colors.surface-soft}"
243
+ textColor: "{colors.ink}"
244
+ typography: "{typography.eyebrow}"
245
+ rounded: "{rounded.md}"
246
+ padding: 24px
247
+ top-nav:
248
+ backgroundColor: "{colors.canvas}"
249
+ textColor: "{colors.ink}"
250
+ typography: "{typography.body-sm}"
251
+ rounded: "{rounded.xs}"
252
+ height: 56px
253
+ marquee-strip:
254
+ backgroundColor: "{colors.inverse-canvas}"
255
+ textColor: "{colors.inverse-ink}"
256
+ typography: "{typography.body-sm}"
257
+ rounded: "{rounded.xs}"
258
+ height: 36px
259
+ comparison-checkmark:
260
+ backgroundColor: "{colors.canvas}"
261
+ textColor: "{colors.semantic-success}"
262
+ typography: "{typography.body-sm}"
263
+ rounded: "{rounded.full}"
264
+ size: 16px
265
+ footer:
266
+ backgroundColor: "{colors.canvas}"
267
+ textColor: "{colors.ink}"
268
+ typography: "{typography.caption}"
269
+ rounded: "{rounded.xs}"
270
+ padding: 64px 32px
271
+ ---
272
+
273
+ ## Overview
274
+
275
+ Figma's marketing canvas is, at the system level, an editor-clean black-and-white frame. The chrome — top nav, body type, footer, primary CTA — is monochrome. Headlines are oversized `{typography.display-xl}` set in `figmaSans` with aggressive negative tracking, body copy hovers around weight 320–340 of the same variable family, and small mono `{typography.eyebrow}` and `{typography.caption}` labels (figmaMono, all-caps, positive tracking) act as section markers. Every CTA is a pill — `{rounded.pill}` — and the primary action across the entire site is the same black `{components.button-primary}` paired with the same white `{components.button-secondary}`.
276
+
277
+ What makes the design unique is what happens **between** those monochrome bookends: the page repeatedly drops into oversized pastel **color-block sections** — lime, lavender, cream, mint, pink, coral, and a deep navy — that span the full content width with `{rounded.lg}` corners and `{spacing.xxl}` interior padding. These blocks are where the storytelling lives. They aren't accents tucked into a card; they take over a whole viewport's worth of vertical space, like a designer arranging giant sticky notes on a clean wall. FigJam is the most pastel-saturated, the home page rotates through the full set, and the pricing page ends with a lime FAQ panel — same vocabulary, different rhythm per route.
278
+
279
+ This is a system built on contrast: the monochrome chrome makes the color blocks feel intentional rather than decorative, and the color blocks make the monochrome chrome feel like editorial paper rather than enterprise SaaS. Density is generous, line-heights are tight on display sizes, and the interface never reaches for shadows or gradients to do the work that color blocks and confident typography already do.
280
+
281
+ **Key Characteristics:**
282
+ - Monochrome system core: `{colors.primary}` (black) and `{colors.canvas}` (white) carry every CTA, every body line, every footer link.
283
+ - Oversized pastel **color-block sections** (`{colors.block-lime}`, `{colors.block-lilac}`, `{colors.block-cream}`, `{colors.block-mint}`, `{colors.block-pink}`, `{colors.block-coral}`, `{colors.block-navy}`) define the narrative rhythm of every long-form page.
284
+ - Pill is the only button shape — `{rounded.pill}` for text CTAs, `{rounded.full}` for icon buttons. No square buttons anywhere.
285
+ - `figmaSans` variable typeface used at unusually fine weight increments (320, 330, 340, 450, 480, 540) — the type system reads as a single voice that flexes rather than a multi-weight family.
286
+ - Tight negative letter-spacing on display sizes (-1.72px at 86px, -0.96px at 64px) creates a confident editorial cadence.
287
+ - `figmaMono` reserved for category labels, eyebrows, and captions — always uppercase, positive tracking — to flag taxonomy without competing with display type.
288
+ - Color-block page rhythm (home): white hero → marquee strip → white feature → lime systems block → navy ship-products block → coral developer block → white template grid → white footer.
289
+
290
+ ## Colors
291
+
292
+ > Source pages: figma.com (home), /design/, /figjam/brainstorming-tool/, /pricing/, /contact/.
293
+
294
+ ### Brand & Accent
295
+ - **Black** ({colors.primary}): The system primary. Every primary CTA, every headline, every body line, the marquee strip, the inverse canvas of dark sections.
296
+ - **White** ({colors.on-primary}): Inverse text on black surfaces; also the canvas color used as the foreground of secondary pill buttons (`{components.button-secondary}`).
297
+ - **Magenta Promo** ({colors.accent-magenta}): A single saturated CTA pink reserved for promotional inline buttons — appears, for example, on the lilac "Save your spot" Release Notes banner. Use scarcely; it is not a section color.
298
+
299
+ ### Surface
300
+ - **Canvas** ({colors.canvas}): Default page background and the body of every white card.
301
+ - **Inverse Canvas** ({colors.inverse-canvas}): Footer, marquee strip, and a subset of "ship products"-style story sections.
302
+ - **Surface Soft** ({colors.surface-soft}): Off-white tile background used for icon buttons, template cards, and feature illustration tiles when they sit on the white canvas.
303
+ - **Hairline** ({colors.hairline}): 1px borders on form inputs, pricing cards, and table dividers.
304
+ - **Hairline Soft** ({colors.hairline-soft}): Even subtler dividers — comparison-table row separators and footer column rules.
305
+ - **Block Lime** ({colors.block-lime}): The signature **systems / FAQ / contact-form** color block. Recurs across home, pricing, contact.
306
+ - **Block Lilac** ({colors.block-lilac}): Hero block on `/design/`; also the inline Release Notes promo banner.
307
+ - **Block Cream** ({colors.block-cream}): Soft warm background — FigJam hero strip, template-grid section.
308
+ - **Block Mint** ({colors.block-mint}): FigJam pastel section.
309
+ - **Block Pink** ({colors.block-pink}): FigJam pastel section.
310
+ - **Block Coral** ({colors.block-coral}): "Ship products" coral story block on home.
311
+ - **Block Navy** ({colors.block-navy}): Deep indigo story block — only place dark surfaces appear above the footer.
312
+
313
+ ### Text
314
+ - **Ink** ({colors.ink}): All headline, body, and caption type on light surfaces. There is no softer mid-gray text role on marketing — body copy is always black at weight 320–340, and weight (not opacity) carries the hierarchy.
315
+ - **Inverse Ink** ({colors.inverse-ink}): Type on inverse-canvas surfaces (footer, marquee strip, navy color block).
316
+ - **On-Inverse Soft** ({colors.on-inverse-soft}): White used at ~16% opacity for circular icon-button surfaces against dark sections (token captures the base color; the translucency is applied at render time).
317
+
318
+ ### Semantic
319
+ - **Success Green** ({colors.semantic-success}): Comparison-table checkmarks on pricing. Used as a glyph fill, not a surface.
320
+ - **Overlay Scrim** ({colors.overlay-scrim}): Black used at ~60% opacity behind modal / video-overlay surfaces (token captures the base; opacity applied at render time).
321
+
322
+ ## Typography
323
+
324
+ ### Font Family
325
+
326
+ - **figmaSans** — Figma's proprietary variable typeface; fallback stack `figmaSans Fallback, SF Pro Display, system-ui, helvetica`. Variable weight axis is exercised at unusually fine increments (320, 330, 340, 450, 480, 540, 700) — the design system reads as a single voice modulating rather than a stepped weight family.
327
+ - **figmaMono** — Proprietary monospace; fallback `figmaMono Fallback, SF Mono, menlo`. Used exclusively for eyebrow labels and captions, always uppercase with positive letter-spacing.
328
+
329
+ OpenType `kern` is enabled across every role.
330
+
331
+ ### Hierarchy
332
+
333
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
334
+ |---|---|---|---|---|---|
335
+ | `{typography.display-xl}` | 86px | 340 | 1.00 | -1.72px | Hero headlines (home, FigJam) |
336
+ | `{typography.display-lg}` | 64px | 340 | 1.10 | -0.96px | Section opener headlines |
337
+ | `{typography.headline}` | 26px | 540 | 1.35 | -0.26px | Story-block titles inside color blocks |
338
+ | `{typography.subhead}` | 26px | 340 | 1.35 | -0.26px | Long-form intro paragraphs that sit at near-headline scale |
339
+ | `{typography.card-title}` | 24px | 700 | 1.45 | 0 | Pricing-tier titles, feature card titles |
340
+ | `{typography.body-lg}` | 20px | 330 | 1.40 | -0.14px | Lead body copy on hero, contact form labels |
341
+ | `{typography.body}` | 18px | 320 | 1.45 | -0.26px | Default body |
342
+ | `{typography.body-sm}` | 16px | 330 | 1.45 | -0.14px | Card body, footer link list |
343
+ | `{typography.link}` | 20px | 480 | 1.40 | -0.10px | Inline link emphasis |
344
+ | `{typography.button}` | 20px | 480 | 1.40 | -0.10px | All pill buttons, primary and secondary |
345
+ | `{typography.eyebrow}` | 18px | 400 | 1.30 | 0.54px | figmaMono uppercase section eyebrows |
346
+ | `{typography.caption}` | 12px | 400 | 1.00 | 0.60px | figmaMono uppercase captions, footer column heads |
347
+
348
+ ### Principles
349
+
350
+ - **Weight, not size, carries hierarchy on body copy.** A 20px paragraph at weight 330 sits next to a 20px link at weight 480 — the eye reads emphasis without scale change.
351
+ - **Negative letter-spacing scales with size.** Display-xl pulls -1.72px; subhead pulls only -0.26px. Body copy stays near-zero. The result is editorial-feeling display type without sacrificing readability at body size.
352
+ - **Mono is taxonomy, not body.** figmaMono is reserved for eyebrows and captions — never used to set a paragraph.
353
+ - **Tight line-heights on display, generous on body.** Display sizes run 1.00–1.10; body runs 1.40–1.45. The contrast reinforces that headlines are graphics and body copy is for reading.
354
+
355
+ ### Note on Font Substitutes
356
+
357
+ If implementing without access to figmaSans / figmaMono, suitable open-source substitutes are **Inter** (or **Geist**) for the sans, and **JetBrains Mono** (or **Geist Mono**) for the mono. Inter at variable weights closely matches the fine-grained weight axis figmaSans uses; expect to manually adjust line-heights down by ~0.02 to compensate for Inter's slightly taller x-height.
358
+
359
+ ## Layout
360
+
361
+ ### Spacing System
362
+
363
+ - **Base unit**: 8px.
364
+ - **Tokens (front matter)**: `{spacing.hair}` 1px · `{spacing.xxs}` 4px · `{spacing.xs}` 8px · `{spacing.sm}` 12px · `{spacing.md}` 16px · `{spacing.lg}` 24px · `{spacing.xl}` 32px · `{spacing.xxl}` 48px · `{spacing.section}` 96px.
365
+ - Section interior padding: `{spacing.xxl}` (48px) on color-block sections.
366
+ - Card interior padding: `{spacing.lg}` (24px) on pricing cards and template tiles.
367
+ - Form input padding: `{spacing.sm}` 12px vertical · 14px horizontal.
368
+ - Button padding: `{spacing.xs}` 8px vertical · `{spacing.lg}` 24px horizontal for pill buttons (the asymmetric `8px 18px 10px` extracted on `button-secondary` nudges the type optically inside the pill).
369
+ - Universal rhythm constant: `{spacing.section}` (96px) — the vertical gap between major content sections holds across home, pricing, and FigJam pages.
370
+
371
+ ### Grid & Container
372
+
373
+ - Max content width sits around 1280px (one of the explicit breakpoints), with side gutters that scale from `{spacing.xxl}` on desktop down to `{spacing.lg}` on mobile.
374
+ - Three- and four-column grids on the desktop pricing comparison and FigJam template galleries.
375
+ - Color-block sections break the column grid — they span content width with full bleed inside the rounded `{rounded.lg}` corners, then place a single editorial column of headline + body inside.
376
+
377
+ ### Whitespace Philosophy
378
+
379
+ White space is used to make the color blocks feel deliberate. Between every colored panel and the next, the page returns to white canvas with `{spacing.section}` of breathing room. Inside a color block, the type itself is given generous side margins (often more than 1/4 of the block's width on each side) so the panel reads as a poster, not a wall of copy.
380
+
381
+ ## Elevation & Depth
382
+
383
+ | Level | Treatment | Use |
384
+ |---|---|---|
385
+ | 0 (flat) | No shadow, no border | Default for color-block sections, inverse-canvas footer, hero |
386
+ | 1 (hairline) | 1px `{colors.hairline}` border on `{colors.canvas}` | Pricing cards, form inputs, comparison table cells |
387
+ | 2 (soft elevation) | Subtle drop shadow approx 0 4px 16px rgba(0,0,0,0.06) | Floating template tiles, dropdown menus |
388
+ | 3 (modal) | Stronger shadow + `{colors.overlay-scrim}` behind | Video / image lightbox overlays |
389
+
390
+ Figma's marketing system is shadow-light by design — the color blocks substitute for traditional elevation. Where most SaaS sites use a shadowed white card to draw attention, Figma uses a saturated background panel. This makes the rare actual shadow (e.g., a floating template card hovering over a cream section) feel like an exception worth noticing.
391
+
392
+ ### Decorative Depth
393
+
394
+ - **Color-block sections** are the primary depth device. The change from white canvas to lime / lavender / cream is the section break.
395
+ - **Sticky-note style component thumbnails** in FigJam — slightly off-axis pastel rectangles arranged like notes on a board — read as collage, not card-stack.
396
+ - **Embedded product UI mocks** (Figma Design panels, FigJam canvas snippets) appear as flat compositions on color blocks; their internal shadows are subtle and stay within the mock.
397
+
398
+ ## Shapes
399
+
400
+ ### Border Radius Scale
401
+
402
+ | Token | Value | Use |
403
+ |---|---|---|
404
+ | `{rounded.xs}` | 2px | Anchor / link decoration corners |
405
+ | `{rounded.sm}` | 6px | Small chips, sub-nav tabs |
406
+ | `{rounded.md}` | 8px | Form inputs, list items, image frames |
407
+ | `{rounded.lg}` | 24px | Pricing cards, color-block sections, large image containers |
408
+ | `{rounded.xl}` | 32px | Hero feature panels, oversized callouts |
409
+ | `{rounded.pill}` | 50px | All text CTAs (primary, secondary, tab toggles) |
410
+ | `{rounded.full}` | 9999px | Circular icon buttons, comparison-table checkmark glyphs |
411
+
412
+ ### Photography & Illustration Geometry
413
+
414
+ - Image frames use `{rounded.md}` (8px) — generous enough to feel friendly, conservative enough to read as editorial.
415
+ - Template thumbnails on the home grid sit in `{rounded.md}` tiles with `{spacing.md}` interior padding around the embedded preview.
416
+ - FigJam pastel sticky-note component thumbnails preserve a small `{rounded.sm}` corner that mimics actual sticky paper.
417
+ - No avatar circles appear in marketing surfaces — Figma's marketing avoids personification.
418
+
419
+ ## Components
420
+
421
+ ### Buttons
422
+
423
+ **`button-primary`** — The black "Get started for free" pill that appears in the top nav, every hero, and every closing CTA.
424
+ - Background `{colors.primary}`, text `{colors.on-primary}`, type `{typography.button}`, padding 10px 20px, rounded `{rounded.pill}`.
425
+ - Pressed state lives in `button-primary-pressed` (same surface; the live site relies on micro-scale rather than a darkened fill).
426
+
427
+ **`button-secondary`** — White pill with black text. Used for tertiary navigation actions ("Contact sales") and as the visual counterpart to the primary pill.
428
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.button}`, padding 8px 18px 10px (asymmetric vertical to optically center the type), rounded `{rounded.pill}`. No border.
429
+
430
+ **`button-tertiary-text`** — Plain text link styled as a button hit target inside top nav and footer.
431
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.link}`, rounded `{rounded.full}` (hit target only), padding `{spacing.xs}` `{spacing.sm}`.
432
+
433
+ **`button-icon-circular`** — 40px circular icon button used for carousel controls, social links, and inline actions on light surfaces.
434
+ - Background `{colors.surface-soft}`, text `{colors.ink}`, rounded `{rounded.full}`, size 40px.
435
+
436
+ **`button-icon-circular-inverse`** — Same shape, used on inverse-canvas / dark color blocks.
437
+ - Background `{colors.on-inverse-soft}` (translucent white), text `{colors.inverse-ink}`, rounded `{rounded.full}`, size 40px.
438
+
439
+ **`button-magenta-promo`** — Saturated pink pill used only inside promotional surfaces such as the lilac "Save your spot" Release Notes banner. Reserved for moments where Figma's product team wants the CTA to pop against an already-colored panel.
440
+ - Background `{colors.accent-magenta}`, text `{colors.on-primary}`, type `{typography.button}`, rounded `{rounded.pill}`, padding 10px 18px.
441
+
442
+ ### Pricing Tabs
443
+
444
+ **`pricing-tab-default`** + **`pricing-tab-selected`** — The pill-toggle that switches between Starter / Professional / Organization / Enterprise on `/pricing/`.
445
+ - Default: `{colors.canvas}` background, `{colors.ink}` text, rounded `{rounded.pill}`.
446
+ - Selected: `{colors.primary}` background, `{colors.on-primary}` text — exactly the same surface as `button-primary`, which makes the selected tab feel like an active CTA, not a passive state.
447
+
448
+ ### Inputs & Forms
449
+
450
+ **`text-input`** + **`text-input-focused`** — Form fields on `/contact/` and pricing seat-count steppers.
451
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.body}`, rounded `{rounded.md}`, padding 12px 14px.
452
+ - Focused state retains the same surface — focus is communicated via ring, not via fill change.
453
+
454
+ ### Cards & Containers
455
+
456
+ **`pricing-card`** — Each tier on `/pricing/`.
457
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.body}`, rounded `{rounded.lg}`, padding `{spacing.lg}`. Stroked with `{colors.hairline}` rather than shadowed.
458
+
459
+ **`pricing-card-feature-row`** — Single row inside the comparison table.
460
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.body-sm}`. Row separator is `{colors.hairline-soft}`.
461
+
462
+ **`template-card`** — Thumbnail tile in the home "Explore what people are making" grid and the FigJam template gallery.
463
+ - Background `{colors.surface-soft}`, text `{colors.ink}`, type `{typography.body-sm}`, rounded `{rounded.md}`, padding `{spacing.md}`.
464
+
465
+ **`feature-illustration-tile`** — Larger composition tile that holds a product UI mock or pastel illustration.
466
+ - Background `{colors.surface-soft}`, text `{colors.ink}`, type `{typography.eyebrow}`, rounded `{rounded.md}`, padding `{spacing.lg}`.
467
+
468
+ ### Color-Block Sections (signature)
469
+
470
+ The defining surface of Figma's marketing. Each is a full-content-width panel with `{rounded.lg}` corners and `{spacing.xxl}` interior padding. Variants:
471
+
472
+ **`color-block-section`** — lime ground for "systems" stories (home), pricing FAQ, and the contact form.
473
+ - Background `{colors.block-lime}`, text `{colors.ink}`, type `{typography.subhead}`, rounded `{rounded.lg}`, padding `{spacing.xxl}`.
474
+
475
+ **`color-block-section-lilac`** — lavender ground for `/design/` hero and FigJam highlight sections.
476
+ - Background `{colors.block-lilac}`, otherwise identical structure.
477
+
478
+ **`color-block-section-navy`** — deep indigo ground for the home "Ship products" story block. The only inverse color-block surface above the footer.
479
+ - Background `{colors.block-navy}`, text `{colors.inverse-ink}`, otherwise identical structure.
480
+
481
+ (Cream, mint, pink, and coral block variants follow the same shape with their respective `{colors.block-*}` surface.)
482
+
483
+ ### Promo Banner
484
+
485
+ **`promo-banner-lilac`** — The Release Notes / "Save your spot" inline banner that floats above the contact form.
486
+ - Background `{colors.block-lilac}`, text `{colors.ink}`, type `{typography.body-sm}`, rounded `{rounded.md}`, padding `{spacing.md}` `{spacing.lg}`. Carries a `button-magenta-promo` on the right edge.
487
+
488
+ ### Navigation
489
+
490
+ **`top-nav`** — Sticky white bar with logo, primary nav links, sign-in link, and the right-anchored `button-secondary` ("Contact sales") + `button-primary` ("Get started for free") pair.
491
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.body-sm}`, height 56px.
492
+ - Mobile: collapses primary links into a hamburger that opens a full-canvas overlay; the two pill CTAs remain visible on the bar.
493
+
494
+ **`marquee-strip`** — Thin black ribbon directly under the nav that scrolls through customer logos in white.
495
+ - Background `{colors.inverse-canvas}`, text `{colors.inverse-ink}`, type `{typography.body-sm}`, height 36px.
496
+
497
+ ### Comparison Glyphs
498
+
499
+ **`comparison-checkmark`** — Green check used in the pricing comparison matrix.
500
+ - Background `{colors.canvas}`, glyph color `{colors.semantic-success}`, rounded `{rounded.full}`, size 16px.
501
+
502
+ ### Footer
503
+
504
+ **`footer`** — Dense link grid on white canvas with the wordmark "Figma" set in display weight at the top-left.
505
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.caption}` for column headings and small links, padding `{spacing.section}` top/bottom · `{spacing.xl}` sides.
506
+
507
+ ## Do's and Don'ts
508
+
509
+ ### Do
510
+
511
+ - Reserve `{colors.primary}` for genuine primary CTAs and selected states (e.g., `pricing-tab-selected`). Don't use it as a decorative accent.
512
+ - When introducing a story section, choose **one** color block from the `{colors.block-*}` family and let it span full content width with `{rounded.lg}` corners and `{spacing.xxl}` interior padding.
513
+ - Keep type in `figmaSans` at variable weights — pick from 320, 330, 340, 480, 540, 700 to express hierarchy. Avoid intermediate weights outside this set.
514
+ - Use `figmaMono` only for eyebrows and captions, always uppercase, with the documented positive letter-spacing.
515
+ - Compose every CTA as a pill (`{rounded.pill}`) and every icon button as a circle (`{rounded.full}`).
516
+ - Allow the page to **return to white canvas** between every two color blocks so each block reads as deliberate.
517
+ - Pair `button-primary` and `button-secondary` whenever a section needs both a primary action and a sales / secondary action — the black-and-white pair is the brand signature.
518
+
519
+ ### Don't
520
+
521
+ - Don't introduce mid-gray text. Body hierarchy comes from `figmaSans` weight, not from opacity.
522
+ - Don't add drop shadows to color-block sections — the color is the depth device.
523
+ - Don't introduce new accent colors outside the documented `{colors.block-*}` palette and `{colors.accent-magenta}`. Adding, e.g., a saturated brand orange would break the system.
524
+ - Don't combine more than one color block visible inside a single viewport — Figma's pacing always lets the white canvas separate them.
525
+ - Don't square off CTAs. Square buttons read as a different brand.
526
+ - Don't put `figmaMono` in body copy — it's a taxonomy tool, not a reading typeface.
527
+ - Don't replace the `pricing-tab-selected` black fill with a colored tab; the brand pattern is "selected = primary surface".
528
+
529
+ ## Responsive Behavior
530
+
531
+ ### Breakpoints
532
+
533
+ | Name | Width | Key Changes |
534
+ |---|---|---|
535
+ | 4k | 1920px | Max content width holds at 1280px; gutters expand |
536
+ | Desktop-XL | 1440px | Default desktop layout |
537
+ | Desktop | 1400px | Comparison table column widths normalize |
538
+ | Desktop-S | 1280px | Pricing 4-up tier grid maintained |
539
+ | Tablet | 960px | Pricing collapses 4-up → 2-up; nav becomes hamburger |
540
+ | Mobile-L | 768px | Color-block sections become full-bleed (no rounded corners on edges) |
541
+ | Mobile | 560px | Display-xl reduces from 86px to ~48px; pill CTAs go full-width |
542
+ | Mobile-XS | 559px | Two-column footer collapses to single column |
543
+
544
+ ### Touch Targets
545
+
546
+ - Pill buttons (`button-primary`, `button-secondary`) maintain a minimum 44px tap height across all viewports — achieved by combining `{typography.button}` 20px line-height with the documented vertical padding.
547
+ - Circular icon buttons (`button-icon-circular`) are 40px on desktop and grow to 44px on touch viewports.
548
+ - Form input minimum tap target on `/contact/` is 48px high.
549
+
550
+ ### Collapsing Strategy
551
+
552
+ - **Nav**: desktop horizontal nav with two right-anchored pills collapses to a hamburger overlay below 960px. The two pills (`Contact sales`, `Get started for free`) stay visible on the bar above 560px and stack in the overlay below.
553
+ - **Pricing tier grid**: 4-up → 2-up at 960px → 1-up below 768px. The pill toggle stays horizontal and scrolls horizontally if needed below 560px.
554
+ - **Color-block sections**: above 768px the section keeps `{spacing.xxl}` of canvas around it so the rounded corners read; below 768px the corners are removed and the block bleeds to viewport edge for a poster effect.
555
+ - **Comparison table**: below 960px the matrix collapses into per-tier accordions to avoid horizontal scroll.
556
+
557
+ ### Image Behavior
558
+
559
+ - Product UI mocks inside color blocks scale proportionally and never crop. Below 768px they shrink rather than reflow.
560
+ - Template thumbnails in the home grid use lazy loading and animate in on scroll.
561
+ - Sticky-note style FigJam thumbnails maintain their slight off-axis rotation across breakpoints — the rotation is a brand signal, not a desktop-only flourish.
562
+
563
+ ## Iteration Guide
564
+
565
+ 1. Focus on ONE component at a time and reference it by its `components:` token name (e.g., `{components.button-primary}`, `{components.color-block-section}`).
566
+ 2. When introducing a new section, decide **first** which `{colors.block-*}` token it sits on; the surface choice is the most consequential decision.
567
+ 3. Default body type to `{typography.body}`; reach for `{typography.subhead}` or `{typography.headline}` only inside a color block.
568
+ 4. Run `npx @google/design.md lint DESIGN.md` after edits — `broken-ref`, `contrast-ratio`, and `orphaned-tokens` warnings flag issues automatically.
569
+ 5. Add new variants as separate component entries (`-pressed`, `-selected`) — do not bury them in prose.
570
+ 6. Keep `{colors.primary}` scarce. If two `button-primary` instances appear in the same viewport, the section is doing too much — neutralize one to `button-secondary`.
571
+ 7. Treat `{colors.accent-magenta}` as a single-shot color: one promo CTA per page, never two.
572
+
573
+ ## Known Gaps
574
+
575
+ - The exact pastel hex values of `{colors.block-*}` are derived from screenshot pixels; the production source likely uses named tokens that aren't exposed via CSS variables. Treat the documented hex values as faithful approximations rather than exact brand specs.
576
+ - Dark mode is not documented because the marketing site does not ship a dark theme — the closest analog is the navy color-block (`color-block-section-navy`) and the inverse-canvas footer.
577
+ - Form-field error and validation styling is not visible on `/contact/` because no error states render in the static screenshot. Inputs have hairline borders and rounded `{rounded.md}` corners; error treatment is not documented.
578
+ - The animated marquee-strip and color-block reveal animations are not documented (per the no-interaction policy).
@@ -0,0 +1,5 @@
1
+ # Figma Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/figma/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.