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,825 @@
1
+ ---
2
+ version: alpha
3
+ name: Miro
4
+ description: Miro presents itself as the AI-powered visual workspace through a confident, almost playful brand voice — anchored by its signature canary yellow ({colors.brand-yellow}) wordmark over white canvas, broken open by colorful pastel feature tints (rose, teal, coral, orange, mint) that echo the actual sticky-note color palette used on the live whiteboard. Black-pill primary buttons dominate marketing, real Miro-board mockups serve as feature illustrations, and a 4-tier pricing grid leads into a dense comparison table. Roobert PRO carries display headlines; the system supports homepage, pricing, AI Workflows product page, agile vertical, and customer stories surfaces.
5
+
6
+ colors:
7
+ primary: "#1c1c1e"
8
+ on-primary: "#ffffff"
9
+ brand-yellow: "#ffd02f"
10
+ brand-yellow-deep: "#fcb900"
11
+ yellow-light: "#fff4c4"
12
+ yellow-dark: "#746019"
13
+ brand-blue: "#4262ff"
14
+ blue-450: "#5b76fe"
15
+ blue-pressed: "#2a41b6"
16
+ brand-coral: "#ff9999"
17
+ coral-light: "#ffc6c6"
18
+ coral-dark: "#600000"
19
+ brand-rose: "#ffd8f4"
20
+ rose-light: "#fde0f0"
21
+ brand-pink: "#fde0f0"
22
+ brand-teal: "#0fbcb0"
23
+ teal-light: "#c3faf5"
24
+ moss-dark: "#187574"
25
+ brand-orange-light: "#ffe6cd"
26
+ brand-red: "#fbd4d4"
27
+ brand-red-dark: "#e3c5c5"
28
+ success-accent: "#00b473"
29
+ canvas: "#ffffff"
30
+ surface: "#f7f8fa"
31
+ surface-soft: "#fafbfc"
32
+ surface-yellow: "#fff8e0"
33
+ surface-pricing-featured: "#f5f3ff"
34
+ hairline: "#e0e2e8"
35
+ hairline-soft: "#eef0f3"
36
+ hairline-strong: "#c7cad5"
37
+ ink-deep: "#050038"
38
+ ink: "#1c1c1e"
39
+ charcoal: "#2c2c34"
40
+ slate: "#555a6a"
41
+ steel: "#6b6f7e"
42
+ stone: "#8e91a0"
43
+ muted: "#a5a8b5"
44
+ on-dark: "#ffffff"
45
+ on-dark-muted: "#a5a8b5"
46
+ footer-bg: "#1c1c1e"
47
+
48
+ typography:
49
+ hero-display:
50
+ fontFamily: Roobert PRO
51
+ fontSize: 80px
52
+ fontWeight: 500
53
+ lineHeight: 1.05
54
+ letterSpacing: -2px
55
+ display-lg:
56
+ fontFamily: Roobert PRO
57
+ fontSize: 60px
58
+ fontWeight: 500
59
+ lineHeight: 1.10
60
+ letterSpacing: -1.5px
61
+ heading-1:
62
+ fontFamily: Roobert PRO
63
+ fontSize: 48px
64
+ fontWeight: 500
65
+ lineHeight: 1.15
66
+ letterSpacing: -1px
67
+ heading-2:
68
+ fontFamily: Roobert PRO
69
+ fontSize: 36px
70
+ fontWeight: 500
71
+ lineHeight: 1.20
72
+ letterSpacing: -0.5px
73
+ heading-3:
74
+ fontFamily: Roobert PRO
75
+ fontSize: 28px
76
+ fontWeight: 500
77
+ lineHeight: 1.25
78
+ heading-4:
79
+ fontFamily: Roobert PRO
80
+ fontSize: 22px
81
+ fontWeight: 500
82
+ lineHeight: 1.30
83
+ heading-5:
84
+ fontFamily: Roobert PRO
85
+ fontSize: 18px
86
+ fontWeight: 500
87
+ lineHeight: 1.40
88
+ subtitle:
89
+ fontFamily: Roobert PRO
90
+ fontSize: 18px
91
+ fontWeight: 400
92
+ lineHeight: 1.50
93
+ body-md:
94
+ fontFamily: Roobert PRO
95
+ fontSize: 16px
96
+ fontWeight: 400
97
+ lineHeight: 1.50
98
+ body-md-medium:
99
+ fontFamily: Roobert PRO
100
+ fontSize: 16px
101
+ fontWeight: 500
102
+ lineHeight: 1.50
103
+ body-sm:
104
+ fontFamily: Roobert PRO
105
+ fontSize: 14px
106
+ fontWeight: 400
107
+ lineHeight: 1.50
108
+ body-sm-medium:
109
+ fontFamily: Roobert PRO
110
+ fontSize: 14px
111
+ fontWeight: 500
112
+ lineHeight: 1.50
113
+ caption:
114
+ fontFamily: Roobert PRO
115
+ fontSize: 13px
116
+ fontWeight: 400
117
+ lineHeight: 1.40
118
+ caption-bold:
119
+ fontFamily: Roobert PRO
120
+ fontSize: 13px
121
+ fontWeight: 600
122
+ lineHeight: 1.40
123
+ micro:
124
+ fontFamily: Roobert PRO
125
+ fontSize: 12px
126
+ fontWeight: 500
127
+ lineHeight: 1.40
128
+ micro-uppercase:
129
+ fontFamily: Roobert PRO
130
+ fontSize: 11px
131
+ fontWeight: 600
132
+ lineHeight: 1.40
133
+ letterSpacing: 0.5px
134
+ button-md:
135
+ fontFamily: Roobert PRO
136
+ fontSize: 14px
137
+ fontWeight: 500
138
+ lineHeight: 1.30
139
+ stat-display:
140
+ fontFamily: Roobert PRO
141
+ fontSize: 64px
142
+ fontWeight: 500
143
+ lineHeight: 1.10
144
+ letterSpacing: -1.5px
145
+
146
+ rounded:
147
+ xs: 4px
148
+ sm: 6px
149
+ md: 8px
150
+ lg: 12px
151
+ xl: 16px
152
+ xxl: 20px
153
+ xxxl: 28px
154
+ feature: 32px
155
+ full: 9999px
156
+
157
+ spacing:
158
+ xxs: 4px
159
+ xs: 8px
160
+ sm: 12px
161
+ md: 16px
162
+ lg: 20px
163
+ xl: 24px
164
+ xxl: 32px
165
+ xxxl: 40px
166
+ section-sm: 48px
167
+ section: 64px
168
+ section-lg: 96px
169
+ hero: 120px
170
+
171
+ components:
172
+ button-primary:
173
+ backgroundColor: "{colors.primary}"
174
+ textColor: "{colors.on-primary}"
175
+ typography: "{typography.button-md}"
176
+ rounded: "{rounded.full}"
177
+ padding: "12px 24px"
178
+ button-primary-pressed:
179
+ backgroundColor: "{colors.charcoal}"
180
+ textColor: "{colors.on-primary}"
181
+ button-primary-disabled:
182
+ backgroundColor: "{colors.hairline}"
183
+ textColor: "{colors.muted}"
184
+ button-yellow:
185
+ backgroundColor: "{colors.brand-yellow}"
186
+ textColor: "{colors.primary}"
187
+ typography: "{typography.button-md}"
188
+ rounded: "{rounded.full}"
189
+ padding: "12px 24px"
190
+ button-blue:
191
+ backgroundColor: "{colors.brand-blue}"
192
+ textColor: "{colors.on-primary}"
193
+ typography: "{typography.button-md}"
194
+ rounded: "{rounded.full}"
195
+ padding: "12px 24px"
196
+ button-secondary:
197
+ backgroundColor: "transparent"
198
+ textColor: "{colors.ink}"
199
+ typography: "{typography.button-md}"
200
+ rounded: "{rounded.full}"
201
+ padding: "12px 24px"
202
+ border: "1px solid {colors.hairline-strong}"
203
+ button-on-dark:
204
+ backgroundColor: "{colors.on-dark}"
205
+ textColor: "{colors.primary}"
206
+ typography: "{typography.button-md}"
207
+ rounded: "{rounded.full}"
208
+ padding: "12px 24px"
209
+ button-ghost:
210
+ backgroundColor: "transparent"
211
+ textColor: "{colors.ink}"
212
+ typography: "{typography.button-md}"
213
+ rounded: "{rounded.md}"
214
+ padding: "8px 12px"
215
+ button-link:
216
+ backgroundColor: "transparent"
217
+ textColor: "{colors.brand-blue}"
218
+ typography: "{typography.body-sm-medium}"
219
+ padding: "0"
220
+ button-icon-circular:
221
+ backgroundColor: "{colors.canvas}"
222
+ textColor: "{colors.ink}"
223
+ rounded: "{rounded.full}"
224
+ size: 36px
225
+ border: "1px solid {colors.hairline}"
226
+ card-base:
227
+ backgroundColor: "{colors.canvas}"
228
+ rounded: "{rounded.xl}"
229
+ padding: "{spacing.xl}"
230
+ border: "1px solid {colors.hairline-soft}"
231
+ card-feature:
232
+ backgroundColor: "{colors.canvas}"
233
+ rounded: "{rounded.xxxl}"
234
+ padding: "{spacing.xxl}"
235
+ border: "1px solid {colors.hairline-soft}"
236
+ card-feature-yellow:
237
+ backgroundColor: "{colors.brand-yellow}"
238
+ textColor: "{colors.primary}"
239
+ rounded: "{rounded.xxxl}"
240
+ padding: "{spacing.xxl}"
241
+ card-feature-coral:
242
+ backgroundColor: "{colors.coral-light}"
243
+ textColor: "{colors.primary}"
244
+ rounded: "{rounded.xxxl}"
245
+ padding: "{spacing.xxl}"
246
+ card-feature-teal:
247
+ backgroundColor: "{colors.teal-light}"
248
+ textColor: "{colors.primary}"
249
+ rounded: "{rounded.xxxl}"
250
+ padding: "{spacing.xxl}"
251
+ card-feature-rose:
252
+ backgroundColor: "{colors.rose-light}"
253
+ textColor: "{colors.primary}"
254
+ rounded: "{rounded.xxxl}"
255
+ padding: "{spacing.xxl}"
256
+ card-customer-story:
257
+ backgroundColor: "{colors.canvas}"
258
+ rounded: "{rounded.xxxl}"
259
+ padding: "0"
260
+ border: "1px solid {colors.hairline-soft}"
261
+ card-stat:
262
+ backgroundColor: "transparent"
263
+ textColor: "{colors.ink}"
264
+ typography: "{typography.stat-display}"
265
+ padding: "{spacing.lg}"
266
+ pricing-card:
267
+ backgroundColor: "{colors.canvas}"
268
+ rounded: "{rounded.xl}"
269
+ padding: "{spacing.xxl}"
270
+ border: "1px solid {colors.hairline}"
271
+ pricing-card-featured:
272
+ backgroundColor: "{colors.surface-pricing-featured}"
273
+ rounded: "{rounded.xl}"
274
+ padding: "{spacing.xxl}"
275
+ border: "2px solid {colors.brand-blue}"
276
+ pricing-card-enterprise:
277
+ backgroundColor: "{colors.primary}"
278
+ textColor: "{colors.on-primary}"
279
+ rounded: "{rounded.xl}"
280
+ padding: "{spacing.xxl}"
281
+ text-input:
282
+ backgroundColor: "{colors.canvas}"
283
+ textColor: "{colors.ink}"
284
+ typography: "{typography.body-md}"
285
+ rounded: "{rounded.md}"
286
+ padding: "{spacing.sm} {spacing.md}"
287
+ border: "1px solid {colors.hairline-strong}"
288
+ height: 44px
289
+ text-input-focused:
290
+ backgroundColor: "{colors.canvas}"
291
+ textColor: "{colors.ink}"
292
+ border: "2px solid {colors.brand-blue}"
293
+ search-pill:
294
+ backgroundColor: "{colors.surface}"
295
+ textColor: "{colors.steel}"
296
+ typography: "{typography.body-sm}"
297
+ rounded: "{rounded.md}"
298
+ padding: "{spacing.xs} {spacing.md}"
299
+ height: 40px
300
+ border: "1px solid {colors.hairline}"
301
+ filter-dropdown:
302
+ backgroundColor: "{colors.canvas}"
303
+ textColor: "{colors.ink}"
304
+ typography: "{typography.body-sm-medium}"
305
+ rounded: "{rounded.full}"
306
+ padding: "{spacing.xs} {spacing.md}"
307
+ border: "1px solid {colors.hairline-strong}"
308
+ pill-tab:
309
+ backgroundColor: "{colors.canvas}"
310
+ textColor: "{colors.steel}"
311
+ typography: "{typography.body-sm-medium}"
312
+ rounded: "{rounded.full}"
313
+ padding: "{spacing.xs} {spacing.md}"
314
+ border: "1px solid {colors.hairline}"
315
+ pill-tab-active:
316
+ backgroundColor: "{colors.primary}"
317
+ textColor: "{colors.on-primary}"
318
+ rounded: "{rounded.full}"
319
+ border: "1px solid {colors.primary}"
320
+ toggle-monthly-yearly:
321
+ backgroundColor: "{colors.surface}"
322
+ textColor: "{colors.ink}"
323
+ rounded: "{rounded.full}"
324
+ padding: "4px"
325
+ badge-promo:
326
+ backgroundColor: "{colors.brand-yellow}"
327
+ textColor: "{colors.primary}"
328
+ typography: "{typography.caption-bold}"
329
+ rounded: "{rounded.full}"
330
+ padding: "4px 10px"
331
+ badge-tag-yellow:
332
+ backgroundColor: "{colors.surface-yellow}"
333
+ textColor: "{colors.yellow-dark}"
334
+ typography: "{typography.caption-bold}"
335
+ rounded: "{rounded.full}"
336
+ padding: "4px 10px"
337
+ badge-tag-purple:
338
+ backgroundColor: "{colors.surface-pricing-featured}"
339
+ textColor: "{colors.brand-blue}"
340
+ typography: "{typography.caption-bold}"
341
+ rounded: "{rounded.full}"
342
+ padding: "4px 10px"
343
+ badge-tag-coral:
344
+ backgroundColor: "{colors.coral-light}"
345
+ textColor: "{colors.coral-dark}"
346
+ typography: "{typography.caption-bold}"
347
+ rounded: "{rounded.full}"
348
+ padding: "4px 10px"
349
+ badge-success:
350
+ backgroundColor: "{colors.success-accent}"
351
+ textColor: "{colors.on-primary}"
352
+ typography: "{typography.caption-bold}"
353
+ rounded: "{rounded.full}"
354
+ padding: "4px 10px"
355
+ badge-discount:
356
+ backgroundColor: "{colors.brand-yellow}"
357
+ textColor: "{colors.primary}"
358
+ typography: "{typography.caption-bold}"
359
+ rounded: "{rounded.sm}"
360
+ padding: "2px 6px"
361
+ promo-banner:
362
+ backgroundColor: "{colors.primary}"
363
+ textColor: "{colors.on-primary}"
364
+ typography: "{typography.body-sm-medium}"
365
+ padding: "{spacing.sm} {spacing.md}"
366
+ comparison-table:
367
+ backgroundColor: "{colors.canvas}"
368
+ textColor: "{colors.ink}"
369
+ typography: "{typography.body-sm}"
370
+ rounded: "{rounded.md}"
371
+ border: "1px solid {colors.hairline}"
372
+ comparison-row:
373
+ backgroundColor: "{colors.canvas}"
374
+ textColor: "{colors.ink}"
375
+ padding: "{spacing.md} {spacing.lg}"
376
+ border: "0 0 1px {colors.hairline-soft} solid"
377
+ template-card:
378
+ backgroundColor: "{colors.canvas}"
379
+ rounded: "{rounded.xl}"
380
+ padding: "{spacing.md}"
381
+ border: "1px solid {colors.hairline}"
382
+ whiteboard-mockup:
383
+ backgroundColor: "{colors.canvas}"
384
+ rounded: "{rounded.xl}"
385
+ padding: "0"
386
+ border: "1px solid {colors.hairline-soft}"
387
+ shadow: "rgba(5, 0, 56, 0.08) 0px 12px 32px -4px"
388
+ faq-accordion-item:
389
+ backgroundColor: "{colors.canvas}"
390
+ rounded: "{rounded.md}"
391
+ padding: "{spacing.xl}"
392
+ border: "0 0 1px {colors.hairline} solid"
393
+ logo-wall-item:
394
+ backgroundColor: "transparent"
395
+ textColor: "{colors.steel}"
396
+ typography: "{typography.body-md-medium}"
397
+ padding: "{spacing.lg}"
398
+ hero-band-marketing:
399
+ backgroundColor: "{colors.canvas}"
400
+ textColor: "{colors.ink}"
401
+ typography: "{typography.hero-display}"
402
+ rounded: "0"
403
+ padding: "{spacing.hero}"
404
+ cta-banner-dark:
405
+ backgroundColor: "{colors.primary}"
406
+ textColor: "{colors.on-primary}"
407
+ rounded: "{rounded.feature}"
408
+ padding: "{spacing.section}"
409
+ industry-tile:
410
+ backgroundColor: "{colors.canvas}"
411
+ rounded: "{rounded.xl}"
412
+ padding: "{spacing.xl}"
413
+ border: "1px solid {colors.hairline-soft}"
414
+ capterra-badge:
415
+ backgroundColor: "{colors.canvas}"
416
+ textColor: "{colors.ink}"
417
+ typography: "{typography.caption}"
418
+ rounded: "{rounded.md}"
419
+ padding: "{spacing.sm} {spacing.md}"
420
+ border: "1px solid {colors.hairline}"
421
+ footer-region:
422
+ backgroundColor: "{colors.footer-bg}"
423
+ textColor: "{colors.on-dark}"
424
+ typography: "{typography.body-sm}"
425
+ padding: "{spacing.section} {spacing.xxl}"
426
+ footer-link:
427
+ backgroundColor: "transparent"
428
+ textColor: "{colors.on-dark-muted}"
429
+ typography: "{typography.body-sm}"
430
+ padding: "{spacing.xxs} 0"
431
+ app-store-badge:
432
+ backgroundColor: "{colors.canvas}"
433
+ textColor: "{colors.primary}"
434
+ typography: "{typography.caption-bold}"
435
+ rounded: "{rounded.md}"
436
+ padding: "{spacing.sm} {spacing.md}"
437
+ ---
438
+
439
+ ## Overview
440
+
441
+ Miro positions itself as the AI-powered visual workspace through a confident, slightly playful brand voice. The homepage opens with a stark white canvas anchored by a small canary-yellow Miro wordmark in the top-left, a black-pill primary CTA "Get started free" and a secondary "Book a demo" outline pill — then dramatic real-Miro-board mockup imagery (sticky notes, kanban, mind maps) carries the visual weight. Across deeper surfaces, the system breaks open: pastel feature cards (rose, teal, coral, yellow) echo the actual sticky-note color palette of the live whiteboard product, and customer story cards reuse those tints to differentiate brand vignettes.
442
+
443
+ Roobert PRO — Miro's custom display face — anchors every typographic surface, from the 80px hero display down to 11px micro labels. The face's slightly rounded, geometric character pairs naturally with the playful product photography and the friendly product positioning. Black-pill primary buttons (`{rounded.full}`) dominate marketing CTAs; the brand color, signature canary yellow ({colors.brand-yellow}), is reserved for the wordmark, top promo banners, and "yellow tag" feature pills — never as a primary CTA. The 4-tier pricing comparison (Free / Starter / Business / Enterprise) leads into the densest surface in the system: a feature comparison table that runs ~80 rows deep across multiple section dividers.
444
+
445
+ **Key Characteristics:**
446
+ - Stark white canvas + Miro wordmark in canary yellow ({colors.brand-yellow}) as the recognizable opening signature
447
+ - Black-pill primary CTAs ({colors.primary} + `{rounded.full}`) as the dominant interactive element
448
+ - Pastel feature cards (yellow, rose, coral, teal, mint) that echo the actual sticky-note palette
449
+ - Roobert PRO across every UI surface; geometric, slightly rounded character
450
+ - Real Miro-board mockup imagery used as feature illustrations
451
+ - 4-tier pricing card grid + dense feature comparison table
452
+ - Massive dark footer ({colors.footer-bg}) with multi-column links + app-store badges
453
+
454
+ ## Colors
455
+
456
+ > Source pages: miro.com/ (homepage), /pricing/ (4-tier comparison), /products/ai-workflows/ (AI product), /agile/ (vertical landing), /customers/ (story directory). Token coverage was identical across all five pages.
457
+
458
+ ### Brand & Accent
459
+ - **Miro Yellow** ({colors.brand-yellow}): The brand's recognizable canary yellow — wordmark color, top promo banner, "yellow tag" pills
460
+ - **Yellow Deep** ({colors.brand-yellow-deep}): Darker variant for hover states and emphasis
461
+ - **Yellow Light** ({colors.yellow-light}): Pale yellow background tint for tag chips
462
+ - **Yellow Dark** ({colors.yellow-dark}): Yellow-tag text color (dark olive) for chip foreground
463
+ - **Brand Blue** ({colors.brand-blue}): Action blue for inline links and featured-pricing-tier border
464
+ - **Blue Pressed** ({colors.blue-pressed}): Pressed-state blue
465
+ - **Brand Coral** ({colors.brand-coral}): Coral accent for warm callouts
466
+ - **Coral Light** ({colors.coral-light}): Pale coral for feature card backgrounds
467
+ - **Coral Dark** ({colors.coral-dark}): Coral-tag text color (deep wine)
468
+ - **Brand Rose** ({colors.brand-rose}): Soft rose-pink for feature card variants
469
+ - **Brand Teal** ({colors.brand-teal}): Brand teal
470
+ - **Teal Light** ({colors.teal-light}): Pale teal for feature card backgrounds
471
+ - **Moss Dark** ({colors.moss-dark}): Deep teal-green text color
472
+ - **Brand Pink** ({colors.brand-pink}): Pale pink for soft callouts
473
+ - **Brand Orange Light** ({colors.brand-orange-light}): Soft orange for feature card backgrounds
474
+
475
+ ### Surface
476
+ - **Canvas White** ({colors.canvas}): Page background and primary card surface
477
+ - **Surface** ({colors.surface}): Subtle section backgrounds, search-pill rest
478
+ - **Surface Soft** ({colors.surface-soft}): Quieter section divisions
479
+ - **Surface Yellow** ({colors.surface-yellow}): Pale yellow-tinted surface for tag chip
480
+ - **Surface Pricing Featured** ({colors.surface-pricing-featured}): Pale lavender for featured pricing tier
481
+ - **Hairline** ({colors.hairline}): 1px borders and primary dividers
482
+ - **Hairline Soft** ({colors.hairline-soft}): Quieter table-row dividers
483
+ - **Hairline Strong** ({colors.hairline-strong}): Stronger 1px border for inputs
484
+
485
+ ### Text
486
+ - **Ink Deep** ({colors.ink-deep}): Headlines on lighter feature cards
487
+ - **Ink** ({colors.ink}): Primary headlines and body text
488
+ - **Charcoal** ({colors.charcoal}): Body emphasis text
489
+ - **Slate** ({colors.slate}): Secondary text, metadata
490
+ - **Steel** ({colors.steel}): Tertiary text, footer links
491
+ - **Stone** ({colors.stone}): Captions, muted labels
492
+ - **Muted** ({colors.muted}): Disabled labels, input placeholders
493
+ - **On Dark** ({colors.on-dark}): White text on dark surfaces
494
+ - **On Dark Muted** ({colors.on-dark-muted}): Reduced-opacity white on dark
495
+
496
+ ### Semantic
497
+ - **Success Accent** ({colors.success-accent}): Confirmation/success indicator green
498
+ - **Brand Red** ({colors.brand-red}): Soft red for error backgrounds
499
+ - **Brand Red Dark** ({colors.brand-red-dark}): Stronger red for error borders
500
+
501
+ ## Typography
502
+
503
+ ### Font Family
504
+ **Roobert PRO** (primary): Miro's custom geometric sans-serif typeface. Used across every UI surface from oversized 80px hero displays to 11px micro labels. The face has a slightly rounded, friendly character that matches the brand's playful product positioning. Fallbacks: Noto Sans, -apple-system, BlinkMacSystemFont, sans-serif.
505
+
506
+ ### Hierarchy
507
+
508
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
509
+ |---|---|---|---|---|---|
510
+ | `{typography.hero-display}` | 80px | 500 | 1.05 | -2px | Marketing hero ("See how teams get great done with Miro") |
511
+ | `{typography.display-lg}` | 60px | 500 | 1.10 | -1.5px | Major section openers |
512
+ | `{typography.heading-1}` | 48px | 500 | 1.15 | -1px | Page-level headlines |
513
+ | `{typography.heading-2}` | 36px | 500 | 1.20 | -0.5px | Subsection headlines |
514
+ | `{typography.heading-3}` | 28px | 500 | 1.25 | 0 | Card titles |
515
+ | `{typography.heading-4}` | 22px | 500 | 1.30 | 0 | Feature tile titles |
516
+ | `{typography.heading-5}` | 18px | 500 | 1.40 | 0 | FAQ questions, smaller cards |
517
+ | `{typography.subtitle}` | 18px | 400 | 1.50 | 0 | Hero subtitle |
518
+ | `{typography.body-md}` | 16px | 400 | 1.50 | 0 | Primary body text |
519
+ | `{typography.body-md-medium}` | 16px | 500 | 1.50 | 0 | Logo wall labels |
520
+ | `{typography.body-sm}` | 14px | 400 | 1.50 | 0 | Secondary body, table cells |
521
+ | `{typography.body-sm-medium}` | 14px | 500 | 1.50 | 0 | Filter dropdowns, button labels |
522
+ | `{typography.caption}` | 13px | 400 | 1.40 | 0 | Helper text |
523
+ | `{typography.caption-bold}` | 13px | 600 | 1.40 | 0 | Badge labels, tag chips |
524
+ | `{typography.micro}` | 12px | 500 | 1.40 | 0 | Footer microcopy |
525
+ | `{typography.micro-uppercase}` | 11px | 600 | 1.40 | 0.5px | Section dividers in tables |
526
+ | `{typography.button-md}` | 14px | 500 | 1.30 | 0 | Pill button labels |
527
+ | `{typography.stat-display}` | 64px | 500 | 1.10 | -1.5px | "100M+ users" stat callouts |
528
+
529
+ ### Principles
530
+ - **Tight hero leading** (1.05) creates magazine-grade display headlines on the 80px hero
531
+ - **Negative letter-spacing progression** — display sizes use -2px to -1.5px; smaller headings relax to 0
532
+ - **Stat-display token** (64px / 500) for marketing stat callouts
533
+ - **Single weight scale** — 400 (body), 500 (medium emphasis + headings), 600 (badges and uppercase). Roobert PRO does not use 700 in this system.
534
+
535
+ ## Layout
536
+
537
+ ### Spacing System
538
+ - **Base unit**: 4px (8px primary increment)
539
+ - **Tokens**: `{spacing.xxs}` (4px) · `{spacing.xs}` (8px) · `{spacing.sm}` (12px) · `{spacing.md}` (16px) · `{spacing.lg}` (20px) · `{spacing.xl}` (24px) · `{spacing.xxl}` (32px) · `{spacing.xxxl}` (40px) · `{spacing.section-sm}` (48px) · `{spacing.section}` (64px) · `{spacing.section-lg}` (96px) · `{spacing.hero}` (120px)
540
+ - **Section rhythm**: Marketing pages use `{spacing.section-lg}` (96px); pricing comparison tightens to `{spacing.section}` (64px); customer story stack uses `{spacing.xxl}` (32px)
541
+ - **Card internal padding**: `{spacing.xl}` (24px) for compact cards; `{spacing.xxl}` (32px) for feature panels
542
+
543
+ ### Grid & Container
544
+ - Marketing pages use 1280px max-width with 32px gutters
545
+ - Pricing page renders 4-tier card row at desktop (Free / Starter / Business / Enterprise)
546
+ - Customer stories page uses 2-column grid with filter dropdowns
547
+ - AI Workflows page uses 2-column hero, then 3-up feature grid
548
+
549
+ ### Whitespace Philosophy
550
+ Marketing surfaces give content generous breathing room — `{spacing.hero}` (120px) hero padding gives the small wordmark room to breathe. Pricing surfaces tighten dramatically.
551
+
552
+ ## Elevation & Depth
553
+
554
+ The system runs predominantly flat with strategic depth on hero mockups.
555
+
556
+ | Level | Treatment | Use |
557
+ |---|---|---|
558
+ | 0 (flat) | No shadow; `{colors.hairline-soft}` border | Default cards, table rows, form inputs |
559
+ | 1 (subtle) | `rgba(5, 0, 56, 0.04) 0px 1px 2px 0px` | Subtle hover-elevated tiles |
560
+ | 2 (card) | `rgba(5, 0, 56, 0.06) 0px 4px 12px 0px` | Standard feature cards |
561
+ | 3 (mockup) | `rgba(5, 0, 56, 0.08) 0px 12px 32px -4px` | Hero whiteboard mockup framing |
562
+ | 4 (modal) | `rgba(5, 0, 56, 0.12) 0px 16px 48px -8px` | Modals, dropdowns |
563
+
564
+ ### Decorative Depth
565
+ - The atmospheric depth on Miro's hero comes from the live-product-board mockup illustrations — sticky notes layered at z-offsets, color-block tints behind whiteboard frames
566
+ - Pastel feature cards carry their own visual weight via saturated background color
567
+ - Customer-story cards layer dark photographic content with overlay scrims
568
+
569
+ ## Shapes
570
+
571
+ ### Border Radius Scale
572
+
573
+ | Token | Value | Use |
574
+ |---|---|---|
575
+ | `{rounded.xs}` | 4px | Small chips, micro-controls |
576
+ | `{rounded.sm}` | 6px | Discount badges |
577
+ | `{rounded.md}` | 8px | Inputs, search-pill |
578
+ | `{rounded.lg}` | 12px | Standard cards, table containers |
579
+ | `{rounded.xl}` | 16px | Pricing cards, feature panels |
580
+ | `{rounded.xxl}` | 20px | Larger feature cards |
581
+ | `{rounded.xxxl}` | 28px | Pastel feature cards (yellow, rose, coral, teal) |
582
+ | `{rounded.feature}` | 32px | Hero CTA banner cards |
583
+ | `{rounded.full}` | 9999px | All buttons, pill tabs, badges |
584
+
585
+ ### Photography Geometry
586
+ - Real Miro board mockups render with `{rounded.xl}` (16px) corners and a subtle drop shadow
587
+ - Customer story cards use `{rounded.xxxl}` (28px) corners with full-bleed photography
588
+ - Template card thumbnails use `{rounded.xl}` (16px) with photographic content
589
+ - Customer logos wall presents wordmarks inline at consistent 100px height
590
+
591
+ ## Components
592
+
593
+ > Per the no-hover policy, hover states are NOT documented. Default and pressed/active states only.
594
+
595
+ ### Buttons
596
+
597
+ **`button-primary`** — Black pill primary CTA, the dominant action ("Get started free").
598
+ - Background `{colors.primary}`, text `{colors.on-primary}`, typography `{typography.button-md}`, padding `12px 24px`, rounded `{rounded.full}`.
599
+ - Pressed state `button-primary-pressed` lifts to `{colors.charcoal}`.
600
+ - Disabled state `button-primary-disabled` uses `{colors.hairline}` background and `{colors.muted}` text.
601
+
602
+ **`button-yellow`** — Brand-yellow pill for moments of brand emphasis.
603
+ - Background `{colors.brand-yellow}`, text `{colors.primary}`, typography `{typography.button-md}`, padding `12px 24px`, rounded `{rounded.full}`.
604
+
605
+ **`button-blue`** — Brand-blue pill for inline action callouts.
606
+ - Background `{colors.brand-blue}`, text `{colors.on-primary}`, typography `{typography.button-md}`, padding `12px 24px`, rounded `{rounded.full}`.
607
+
608
+ **`button-secondary`** — Outlined pill for secondary actions ("Book a demo").
609
+ - Background transparent, text `{colors.ink}`, border `1px solid {colors.hairline-strong}`, typography `{typography.button-md}`, padding `12px 24px`, rounded `{rounded.full}`.
610
+
611
+ **`button-on-dark`** — White pill for dark CTA banners.
612
+ - Background `{colors.on-dark}`, text `{colors.primary}`, typography `{typography.button-md}`, padding `12px 24px`, rounded `{rounded.full}`.
613
+
614
+ **`button-ghost`** — Quieter rectangular ghost button.
615
+ - Background transparent, text `{colors.ink}`, typography `{typography.button-md}`, padding `8px 12px`, rounded `{rounded.md}`.
616
+
617
+ **`button-link`** — Inline text link.
618
+ - Background transparent, text `{colors.brand-blue}`, typography `{typography.body-sm-medium}`, padding `0`.
619
+
620
+ **`button-icon-circular`** — 36×36px circular utility button.
621
+ - Background `{colors.canvas}`, text `{colors.ink}`, border `1px solid {colors.hairline}`, rounded `{rounded.full}`.
622
+
623
+ ### Cards & Containers
624
+
625
+ **`card-base`** — Standard content card.
626
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.xl}`, border `1px solid {colors.hairline-soft}`.
627
+
628
+ **`card-feature`** — White feature card with larger 28px corners.
629
+ - Background `{colors.canvas}`, rounded `{rounded.xxxl}`, padding `{spacing.xxl}`, border `1px solid {colors.hairline-soft}`.
630
+
631
+ **`card-feature-yellow`** — Pastel-yellow feature card.
632
+ - Background `{colors.brand-yellow}`, text `{colors.primary}`, rounded `{rounded.xxxl}`, padding `{spacing.xxl}`.
633
+
634
+ **`card-feature-coral`** — Pastel-coral feature card variant.
635
+ - Background `{colors.coral-light}`, text `{colors.primary}`, rounded `{rounded.xxxl}`, padding `{spacing.xxl}`.
636
+
637
+ **`card-feature-teal`** — Pastel-teal feature card variant.
638
+ - Background `{colors.teal-light}`, text `{colors.primary}`, rounded `{rounded.xxxl}`, padding `{spacing.xxl}`.
639
+
640
+ **`card-feature-rose`** — Pastel-rose feature card variant.
641
+ - Background `{colors.rose-light}`, text `{colors.primary}`, rounded `{rounded.xxxl}`, padding `{spacing.xxl}`.
642
+
643
+ **`card-customer-story`** — Customer story card.
644
+ - Background `{colors.canvas}`, rounded `{rounded.xxxl}`, padding `0` (image fills the card), border `1px solid {colors.hairline-soft}`.
645
+
646
+ **`card-stat`** — Stat-row cell for "100M+ users".
647
+ - Background transparent, text `{colors.ink}`, typography `{typography.stat-display}`, padding `{spacing.lg}`.
648
+
649
+ **`pricing-card`** — Standard pricing tier card.
650
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.xxl}`, border `1px solid {colors.hairline}`.
651
+
652
+ **`pricing-card-featured`** — Featured pricing tier (Business — lavender background + blue border).
653
+ - Background `{colors.surface-pricing-featured}`, rounded `{rounded.xl}`, padding `{spacing.xxl}`, border `2px solid {colors.brand-blue}`.
654
+
655
+ **`pricing-card-enterprise`** — Dark-canvas enterprise tier card.
656
+ - Background `{colors.primary}`, text `{colors.on-primary}`, rounded `{rounded.xl}`, padding `{spacing.xxl}`.
657
+
658
+ ### Inputs & Forms
659
+
660
+ **`text-input`** — Standard text field.
661
+ - Background `{colors.canvas}`, text `{colors.ink}`, border `1px solid {colors.hairline-strong}`, rounded `{rounded.md}`, padding `{spacing.sm} {spacing.md}`, height 44px.
662
+
663
+ **`text-input-focused`** — Activated state.
664
+ - Border switches to `2px solid {colors.brand-blue}`.
665
+
666
+ **`search-pill`** — Search bar.
667
+ - Background `{colors.surface}`, text `{colors.steel}`, typography `{typography.body-sm}`, rounded `{rounded.md}`, height 40px, border `1px solid {colors.hairline}`.
668
+
669
+ **`filter-dropdown`** — Pill-shaped filter dropdown ("Company use" / "Industry" / "Use case").
670
+ - Background `{colors.canvas}`, text `{colors.ink}`, typography `{typography.body-sm-medium}`, rounded `{rounded.full}`, padding `{spacing.xs} {spacing.md}`, border `1px solid {colors.hairline-strong}`.
671
+
672
+ ### Tabs
673
+
674
+ **`pill-tab`** + **`pill-tab-active`** — Pill-style tab nav.
675
+ - Inactive: background `{colors.canvas}`, text `{colors.steel}`, border `1px solid {colors.hairline}`, padding `{spacing.xs} {spacing.md}`, rounded `{rounded.full}`.
676
+ - Active: background `{colors.primary}`, text `{colors.on-primary}`.
677
+
678
+ **`toggle-monthly-yearly`** — Two-state pill toggle (Monthly / Annual on pricing).
679
+ - Background `{colors.surface}`, rounded `{rounded.full}`, padding `4px`.
680
+
681
+ ### Badges & Status
682
+
683
+ **`badge-promo`** — Yellow promo banner badge.
684
+ - Background `{colors.brand-yellow}`, text `{colors.primary}`, typography `{typography.caption-bold}`, rounded `{rounded.full}`, padding `4px 10px`.
685
+
686
+ **`badge-tag-yellow`** — Soft-yellow feature tag chip ("Yellow" tag on AI Workflows page).
687
+ - Background `{colors.surface-yellow}`, text `{colors.yellow-dark}`, typography `{typography.caption-bold}`, rounded `{rounded.full}`, padding `4px 10px`.
688
+
689
+ **`badge-tag-purple`** — Lavender feature tag chip ("AI agent" tag).
690
+ - Background `{colors.surface-pricing-featured}`, text `{colors.brand-blue}`, typography `{typography.caption-bold}`, rounded `{rounded.full}`, padding `4px 10px`.
691
+
692
+ **`badge-tag-coral`** — Coral feature tag chip variant.
693
+ - Background `{colors.coral-light}`, text `{colors.coral-dark}`, typography `{typography.caption-bold}`, rounded `{rounded.full}`, padding `4px 10px`.
694
+
695
+ **`badge-success`** — Green success indicator.
696
+ - Background `{colors.success-accent}`, text `{colors.on-primary}`, typography `{typography.caption-bold}`, rounded `{rounded.full}`, padding `4px 10px`.
697
+
698
+ **`badge-discount`** — Yellow rectangular discount pill ("Save 15%").
699
+ - Background `{colors.brand-yellow}`, text `{colors.primary}`, typography `{typography.caption-bold}`, rounded `{rounded.sm}`, padding `2px 6px`.
700
+
701
+ **`promo-banner`** — Sticky black promo strip ABOVE the top nav.
702
+ - Background `{colors.primary}`, text `{colors.on-primary}`, typography `{typography.body-sm-medium}`, padding `{spacing.sm} {spacing.md}`. Carries inline yellow "GET YOUR SPOT" pill.
703
+
704
+ ### Tables
705
+
706
+ **`comparison-table`** — Pricing feature comparison table.
707
+ - Background `{colors.canvas}`, text `{colors.ink}`, typography `{typography.body-sm}`, rounded `{rounded.md}`, border `1px solid {colors.hairline}`.
708
+
709
+ **`comparison-row`** — Individual feature row.
710
+ - Background `{colors.canvas}`, text `{colors.ink}`, padding `{spacing.md} {spacing.lg}`, bottom border `1px solid {colors.hairline-soft}`.
711
+
712
+ ### Documentation Components
713
+
714
+ **`whiteboard-mockup`** — Real Miro-board UI rendered as feature illustration.
715
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, border `1px solid {colors.hairline-soft}`, shadow `rgba(5, 0, 56, 0.08) 0px 12px 32px -4px`.
716
+
717
+ **`template-card`** — Template thumbnail card.
718
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.md}`, border `1px solid {colors.hairline}`.
719
+
720
+ **`industry-tile`** — Industry-vertical tile.
721
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.xl}`, border `1px solid {colors.hairline-soft}`.
722
+
723
+ **`faq-accordion-item`** — FAQ panel item.
724
+ - Background `{colors.canvas}`, rounded `{rounded.md}`, padding `{spacing.xl}`, bottom border `1px solid {colors.hairline}`.
725
+
726
+ **`logo-wall-item`** — Customer logo wordmark cell.
727
+ - Background transparent, text `{colors.steel}`, typography `{typography.body-md-medium}`, padding `{spacing.lg}`.
728
+
729
+ **`capterra-badge`** — Review/rating badge in the footer.
730
+ - Background `{colors.canvas}`, text `{colors.ink}`, typography `{typography.caption}`, rounded `{rounded.md}`, padding `{spacing.sm} {spacing.md}`, border `1px solid {colors.hairline}`.
731
+
732
+ **`app-store-badge`** — App store / Google Play download pill.
733
+ - Background `{colors.canvas}`, text `{colors.primary}`, typography `{typography.caption-bold}`, rounded `{rounded.md}`, padding `{spacing.sm} {spacing.md}`.
734
+
735
+ ### Navigation
736
+
737
+ **Top Navigation (Marketing)** — Sticky white bar with yellow Miro wordmark + horizontal links + right-side CTAs.
738
+ - Background `{colors.canvas}`, height ~64px.
739
+ - Left: Yellow square Miro wordmark + horizontal link list (Product, Solutions, Resources).
740
+ - Right: "Login / Pricing / Contact sales" links + black-pill "Get started free".
741
+
742
+ ### Signature Components
743
+
744
+ **`hero-band-marketing`** — Marketing hero band.
745
+ - Background `{colors.canvas}`, padding `{spacing.hero}`.
746
+ - Layout: centered headline in `{typography.hero-display}`, centered subtitle, centered button row, then whiteboard mockup illustration below.
747
+
748
+ **`cta-banner-dark`** — Dark CTA banner at the bottom of feature pages.
749
+ - Background `{colors.primary}`, text `{colors.on-primary}`, rounded `{rounded.feature}`, padding `{spacing.section}`. Centered headline + subtitle + `button-on-dark` "Get started free".
750
+
751
+ **`footer-region`** — Massive multi-column dark footer.
752
+ - Background `{colors.footer-bg}`, padding `{spacing.section} {spacing.xxl}`.
753
+ - 6-column link grid (Product / Solutions / Tools / Resources / Company / Plans & Pricing).
754
+ - Section headings in `{typography.body-md-medium}` `{colors.on-dark}`.
755
+
756
+ **`footer-link`** — Individual link in the footer.
757
+ - Background transparent, text `{colors.on-dark-muted}`, typography `{typography.body-sm}`, padding `{spacing.xxs} 0`.
758
+
759
+ ## Do's and Don'ts
760
+
761
+ ### Do
762
+ - Reserve `{colors.brand-yellow}` for the wordmark, top promo banner, and "yellow tag" chips
763
+ - Use `{colors.primary}` (black) as the dominant CTA on all surfaces
764
+ - Pair pastel feature cards (yellow, rose, coral, teal) with white feature cards in the same viewport
765
+ - Apply `{rounded.full}` to every button, every pill tab, every status badge
766
+ - Apply `{rounded.xxxl}` (28px) to pastel feature cards
767
+ - Use real Miro-board mockups as feature illustrations
768
+ - Maintain Roobert PRO across every UI surface
769
+
770
+ ### Don't
771
+ - Don't use `{colors.brand-yellow}` on standard CTAs or large background surfaces
772
+ - Don't introduce additional accent colors beyond yellow + brand pastels
773
+ - Don't soften corners on buttons; the pill is a brand signature
774
+ - Don't reduce hero leading below 1.05
775
+ - Don't apply heavy shadows on flat documentation cards; reserve elevation for whiteboard mockups
776
+ - Don't use stock photography — show the live product board UI
777
+
778
+ ## Responsive Behavior
779
+
780
+ ### Breakpoints
781
+ | Name | Width | Key Changes |
782
+ |---|---|---|
783
+ | Mobile (small) | < 480px | Single column. Hero scales to 36px. Pill nav collapses to hamburger. Pricing tiers stack 1-up. |
784
+ | Mobile (large) | 480 – 767px | Feature tiles 2-up. Hero scales to 48px. |
785
+ | Tablet | 768 – 1023px | 2-column feature grids. Pill-tab nav returns. |
786
+ | Desktop | 1024 – 1279px | 4-tier pricing card row. Customer story grid 2-up. Hero at 64px. |
787
+ | Wide Desktop | ≥ 1280px | Full hero presentation, 80px hero display. |
788
+
789
+ ### Touch Targets
790
+ - Pill buttons render at 40–44px effective height — at WCAG AAA floor
791
+ - Circular icon buttons: 36×36px desktop → 44×44px mobile
792
+ - Form inputs render at 44px height
793
+ - Filter dropdowns render at ~36px tall — bumps to 44px on mobile
794
+
795
+ ### Collapsing Strategy
796
+ - **Promo banner** stays full-width; truncates at < 480px
797
+ - **Top nav** below 1024px collapses to hamburger
798
+ - **Hero band**: 2-column hero collapses to stacked at < 1024px
799
+ - **Pricing comparison**: 4-column tiers → 2-column tablet → 1-column mobile; comparison table becomes horizontal-scroll
800
+ - **Customer story grid**: 2-up → 1-up at < 768px
801
+ - **Hero typography**: 80px → 60px tablet → 48px mobile-large → 36px mobile-small
802
+ - **Footer**: 6-column desktop → 3-column tablet → 2-column mobile → accordion at small mobile
803
+
804
+ ### Image Behavior
805
+ - Whiteboard mockups maintain aspect ratio; lazy-loaded below the fold
806
+ - Customer story photography uses 16:9 ratio with full-bleed scaling
807
+ - Logo wall presents wordmarks at consistent 100px height
808
+
809
+ ## Iteration Guide
810
+
811
+ 1. Focus on ONE component at a time
812
+ 2. Reference component names and tokens directly
813
+ 3. Run `npx @google/design.md lint DESIGN.md` after edits
814
+ 4. Add new variants as separate `components:` entries
815
+ 5. Default to `{typography.body-md}` for body and `{typography.subtitle}` for emphasis
816
+ 6. Keep `{colors.brand-yellow}` confined to wordmark, promo banner, and yellow-tag chips
817
+ 7. Pill-shaped buttons (`{rounded.full}`) always
818
+ 8. When showing the product, use a real Miro-board mockup with sticky-note color tints
819
+
820
+ ## Known Gaps
821
+
822
+ - Specific dark-mode token values not surfaced
823
+ - Animation/transition timings not extracted; recommend 150–200ms ease
824
+ - Form validation success state not explicitly captured beyond defaults
825
+ - Sticky note color tints inside the actual whiteboard product are richer than what marketing surfaces capture