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,683 @@
1
+ ---
2
+ version: alpha
3
+ name: Meta
4
+ description: Meta's design system spans hardware commerce (Quest VR, Ray-Ban Meta AI glasses) and brand surfaces with a confident product-merchandising voice. The system pairs a stark white canvas with full-bleed photographic product cards, a confident Optimistic VF wordmark/headline face, dual-CTA hero patterns (black primary + outlined secondary), and a saturated cobalt blue (#0064E0) for in-product purchase actions. Pill-shaped 100px-radius buttons, generous 24-32px card rounding, and tight three-tier text hierarchy carry across homepage, product detail (PDP), buy-now configurator, and accessory subpages.
5
+
6
+ colors:
7
+ primary: "#0064e0"
8
+ primary-deep: "#0457cb"
9
+ primary-soft: "#0091ff"
10
+ on-primary: "#ffffff"
11
+ ink-button: "#000000"
12
+ on-ink-button: "#ffffff"
13
+ fb-blue: "#1876f2"
14
+ meta-link: "#385898"
15
+ oculus-purple: "#a121ce"
16
+ success: "#31a24c"
17
+ success-bg: "#24e400"
18
+ attention: "#f2a918"
19
+ warning: "#f7b928"
20
+ warning-bg: "#ffe200"
21
+ critical: "#e41e3f"
22
+ critical-strong: "#f0284a"
23
+ canvas: "#ffffff"
24
+ surface-soft: "#f1f4f7"
25
+ ink-deep: "#0a1317"
26
+ ink: "#1c1e21"
27
+ charcoal: "#444950"
28
+ slate: "#4b4c4f"
29
+ steel: "#5d6c7b"
30
+ stone: "#8595a4"
31
+ hairline: "#ced0d4"
32
+ hairline-soft: "#dee3e9"
33
+ disabled-text: "#bcc0c4"
34
+
35
+ typography:
36
+ hero-display:
37
+ fontFamily: Optimistic VF
38
+ fontSize: 64px
39
+ fontWeight: 500
40
+ lineHeight: 1.16
41
+ fontFeature: "ss01, ss02"
42
+ display-lg:
43
+ fontFamily: Optimistic VF
44
+ fontSize: 48px
45
+ fontWeight: 500
46
+ lineHeight: 1.17
47
+ fontFeature: "ss01, ss02"
48
+ heading-lg:
49
+ fontFamily: Optimistic VF
50
+ fontSize: 36px
51
+ fontWeight: 500
52
+ lineHeight: 1.28
53
+ fontFeature: "ss01, ss02"
54
+ heading-md:
55
+ fontFamily: Optimistic VF
56
+ fontSize: 28px
57
+ fontWeight: 300
58
+ lineHeight: 1.21
59
+ fontFeature: "ss01, ss02"
60
+ heading-sm:
61
+ fontFamily: Optimistic VF
62
+ fontSize: 24px
63
+ fontWeight: 500
64
+ lineHeight: 1.25
65
+ fontFeature: "ss01, ss02"
66
+ subtitle-lg:
67
+ fontFamily: Optimistic VF
68
+ fontSize: 18px
69
+ fontWeight: 700
70
+ lineHeight: 1.44
71
+ subtitle-md:
72
+ fontFamily: Optimistic VF
73
+ fontSize: 18px
74
+ fontWeight: 400
75
+ lineHeight: 1.44
76
+ body-md-bold:
77
+ fontFamily: Optimistic VF
78
+ fontSize: 16px
79
+ fontWeight: 700
80
+ lineHeight: 1.50
81
+ letterSpacing: -0.16px
82
+ body-md:
83
+ fontFamily: Optimistic VF
84
+ fontSize: 16px
85
+ fontWeight: 400
86
+ lineHeight: 1.50
87
+ letterSpacing: -0.16px
88
+ body-sm-bold:
89
+ fontFamily: Optimistic VF
90
+ fontSize: 14px
91
+ fontWeight: 700
92
+ lineHeight: 1.43
93
+ letterSpacing: -0.14px
94
+ body-sm:
95
+ fontFamily: Optimistic VF
96
+ fontSize: 14px
97
+ fontWeight: 400
98
+ lineHeight: 1.43
99
+ letterSpacing: -0.14px
100
+ caption-bold:
101
+ fontFamily: Optimistic VF
102
+ fontSize: 12px
103
+ fontWeight: 700
104
+ lineHeight: 1.33
105
+ caption:
106
+ fontFamily: Optimistic VF
107
+ fontSize: 12px
108
+ fontWeight: 400
109
+ lineHeight: 1.33
110
+ button-md:
111
+ fontFamily: Optimistic VF
112
+ fontSize: 14px
113
+ fontWeight: 700
114
+ lineHeight: 1.43
115
+ letterSpacing: -0.14px
116
+ link-md:
117
+ fontFamily: Optimistic VF
118
+ fontSize: 16px
119
+ fontWeight: 700
120
+ lineHeight: 1.50
121
+ letterSpacing: -0.16px
122
+
123
+ rounded:
124
+ xs: 2px
125
+ sm: 4px
126
+ md: 6px
127
+ lg: 8px
128
+ xl: 16px
129
+ xxl: 24px
130
+ xxxl: 32px
131
+ feature: 40px
132
+ full: 100px
133
+ circle: 9999px
134
+
135
+ spacing:
136
+ xxs: 4px
137
+ xs: 8px
138
+ sm: 10px
139
+ md: 12px
140
+ base: 16px
141
+ lg: 20px
142
+ xl: 24px
143
+ xxl: 32px
144
+ xxxl: 40px
145
+ section-sm: 48px
146
+ section: 64px
147
+ section-lg: 80px
148
+ hero: 120px
149
+
150
+ components:
151
+ button-primary:
152
+ backgroundColor: "{colors.ink-button}"
153
+ textColor: "{colors.on-ink-button}"
154
+ typography: "{typography.button-md}"
155
+ rounded: "{rounded.full}"
156
+ padding: "14px 30px"
157
+ button-primary-pressed:
158
+ backgroundColor: "{colors.charcoal}"
159
+ textColor: "{colors.on-ink-button}"
160
+ button-primary-disabled:
161
+ backgroundColor: "{colors.disabled-text}"
162
+ textColor: "{colors.canvas}"
163
+ button-buy-cta:
164
+ backgroundColor: "{colors.primary}"
165
+ textColor: "{colors.on-primary}"
166
+ typography: "{typography.button-md}"
167
+ rounded: "{rounded.full}"
168
+ padding: "14px 30px"
169
+ button-buy-cta-pressed:
170
+ backgroundColor: "{colors.primary-deep}"
171
+ textColor: "{colors.on-primary}"
172
+ button-secondary:
173
+ backgroundColor: "transparent"
174
+ textColor: "{colors.ink-deep}"
175
+ typography: "{typography.button-md}"
176
+ rounded: "{rounded.full}"
177
+ padding: "12px 28px"
178
+ border: "2px solid {colors.ink-deep}"
179
+ button-ghost:
180
+ backgroundColor: "transparent"
181
+ textColor: "{colors.ink-deep}"
182
+ typography: "{typography.button-md}"
183
+ rounded: "{rounded.full}"
184
+ padding: "10px 22px"
185
+ border: "2px solid rgba(10, 19, 23, 0.12)"
186
+ button-pill-tab:
187
+ backgroundColor: "{colors.canvas}"
188
+ textColor: "{colors.ink}"
189
+ typography: "{typography.body-sm-bold}"
190
+ rounded: "{rounded.full}"
191
+ padding: "8px 16px"
192
+ border: "1px solid {colors.hairline}"
193
+ button-pill-tab-active:
194
+ backgroundColor: "{colors.ink-deep}"
195
+ textColor: "{colors.canvas}"
196
+ button-icon-circular:
197
+ backgroundColor: "{colors.canvas}"
198
+ textColor: "{colors.ink}"
199
+ rounded: "{rounded.circle}"
200
+ size: 40px
201
+ card-product-feature:
202
+ backgroundColor: "{colors.canvas}"
203
+ rounded: "{rounded.xxxl}"
204
+ padding: "{spacing.xxl}"
205
+ border: "1px solid {colors.hairline-soft}"
206
+ card-feature-photo:
207
+ backgroundColor: "{colors.canvas}"
208
+ rounded: "{rounded.xxxl}"
209
+ padding: "0"
210
+ border: "none"
211
+ card-promo-strip:
212
+ backgroundColor: "{colors.ink-deep}"
213
+ textColor: "{colors.canvas}"
214
+ rounded: "{rounded.xxxl}"
215
+ padding: "{spacing.section}"
216
+ card-icon-feature:
217
+ backgroundColor: "{colors.canvas}"
218
+ rounded: "{rounded.xl}"
219
+ padding: "{spacing.xl}"
220
+ card-checkout-summary:
221
+ backgroundColor: "{colors.canvas}"
222
+ rounded: "{rounded.xl}"
223
+ padding: "{spacing.xl}"
224
+ border: "1px solid {colors.hairline-soft}"
225
+ shadow: "rgba(20, 22, 26, 0.3) 0px 1px 4px 0px"
226
+ product-thumbnail:
227
+ backgroundColor: "{colors.surface-soft}"
228
+ rounded: "{rounded.xl}"
229
+ padding: "{spacing.base}"
230
+ aspect-ratio: "1 / 1"
231
+ text-input:
232
+ backgroundColor: "{colors.canvas}"
233
+ textColor: "{colors.ink}"
234
+ typography: "{typography.body-md}"
235
+ rounded: "{rounded.lg}"
236
+ padding: "{spacing.md}"
237
+ border: "1px solid {colors.hairline}"
238
+ height: 44px
239
+ text-input-focused:
240
+ backgroundColor: "{colors.canvas}"
241
+ textColor: "{colors.ink}"
242
+ border: "2px solid {colors.fb-blue}"
243
+ text-input-error:
244
+ backgroundColor: "{colors.canvas}"
245
+ textColor: "{colors.ink}"
246
+ border: "1px solid {colors.critical-strong}"
247
+ search-pill:
248
+ backgroundColor: "{colors.surface-soft}"
249
+ textColor: "{colors.steel}"
250
+ typography: "{typography.body-sm}"
251
+ rounded: "{rounded.full}"
252
+ padding: "{spacing.md} {spacing.lg}"
253
+ height: 40px
254
+ radio-option:
255
+ backgroundColor: "{colors.canvas}"
256
+ rounded: "{rounded.lg}"
257
+ padding: "{spacing.lg}"
258
+ border: "1px solid rgba(10, 19, 23, 0.12)"
259
+ radio-option-selected:
260
+ backgroundColor: "{colors.canvas}"
261
+ rounded: "{rounded.lg}"
262
+ border: "2px solid #0143b5"
263
+ color-swatch-circle:
264
+ rounded: "{rounded.circle}"
265
+ size: 32px
266
+ border: "2px solid {colors.canvas}"
267
+ badge-promo-yellow:
268
+ backgroundColor: "{colors.warning}"
269
+ textColor: "{colors.ink-deep}"
270
+ typography: "{typography.caption-bold}"
271
+ rounded: "{rounded.full}"
272
+ padding: "4px 10px"
273
+ badge-attention:
274
+ backgroundColor: "{colors.attention}"
275
+ textColor: "{colors.canvas}"
276
+ typography: "{typography.caption-bold}"
277
+ rounded: "{rounded.full}"
278
+ padding: "4px 10px"
279
+ badge-success:
280
+ backgroundColor: "{colors.success}"
281
+ textColor: "{colors.canvas}"
282
+ typography: "{typography.caption-bold}"
283
+ rounded: "{rounded.full}"
284
+ padding: "4px 10px"
285
+ badge-critical:
286
+ backgroundColor: "{colors.critical}"
287
+ textColor: "{colors.canvas}"
288
+ typography: "{typography.caption-bold}"
289
+ rounded: "{rounded.full}"
290
+ padding: "4px 10px"
291
+ promo-banner:
292
+ backgroundColor: "{colors.ink-deep}"
293
+ textColor: "{colors.canvas}"
294
+ typography: "{typography.body-sm-bold}"
295
+ padding: "{spacing.md} {spacing.xl}"
296
+ faq-accordion-item:
297
+ backgroundColor: "{colors.canvas}"
298
+ rounded: "{rounded.xl}"
299
+ padding: "{spacing.xl}"
300
+ border: "1px solid {colors.hairline-soft}"
301
+ why-buy-tile:
302
+ backgroundColor: "{colors.canvas}"
303
+ rounded: "{rounded.xl}"
304
+ padding: "{spacing.xxl} {spacing.xl}"
305
+ border: "1px solid {colors.hairline-soft}"
306
+ warranty-card:
307
+ backgroundColor: "{colors.surface-soft}"
308
+ rounded: "{rounded.xxl}"
309
+ padding: "{spacing.xxl}"
310
+ footer-region:
311
+ backgroundColor: "{colors.canvas}"
312
+ textColor: "{colors.steel}"
313
+ typography: "{typography.body-sm}"
314
+ padding: "{spacing.section} {spacing.xxl}"
315
+ border: "1px solid {colors.hairline-soft}"
316
+ hero-band-marketing:
317
+ backgroundColor: "{colors.canvas}"
318
+ textColor: "{colors.canvas}"
319
+ typography: "{typography.hero-display}"
320
+ rounded: "{rounded.xxxl}"
321
+ padding: "{spacing.section-lg}"
322
+ product-gallery-pdp:
323
+ backgroundColor: "{colors.canvas}"
324
+ rounded: "{rounded.xxxl}"
325
+ padding: "{spacing.base}"
326
+ color-sku-picker-row:
327
+ backgroundColor: "{colors.surface-soft}"
328
+ rounded: "{rounded.lg}"
329
+ padding: "{spacing.base}"
330
+ feature-icon-row:
331
+ backgroundColor: "{colors.canvas}"
332
+ rounded: "{rounded.xl}"
333
+ padding: "{spacing.xl}"
334
+ border: "1px solid {colors.hairline-soft}"
335
+ tech-specs-table:
336
+ backgroundColor: "{colors.canvas}"
337
+ textColor: "{colors.ink}"
338
+ typography: "{typography.body-sm}"
339
+ rounded: "{rounded.lg}"
340
+ padding: "{spacing.lg}"
341
+ border: "1px solid {colors.hairline-soft}"
342
+ testimonial-customer-card:
343
+ backgroundColor: "{colors.canvas}"
344
+ textColor: "{colors.ink}"
345
+ typography: "{typography.body-md}"
346
+ rounded: "{rounded.xl}"
347
+ padding: "{spacing.xxl}"
348
+ border: "1px solid {colors.hairline-soft}"
349
+ ---
350
+
351
+ ## Overview
352
+
353
+ Meta's commerce surfaces (homepage, Quest configurator, Ray-Ban product detail, prescription page) read as a confident hardware merchandiser. The brand voice is photography-first: large, full-bleed product imagery dominates above-the-fold real estate, with white space and tight typographic hierarchy carrying the rest. The system has a recognizable dual-CTA pattern — a black pill-shaped primary on marketing surfaces shifting to a saturated cobalt blue ({colors.primary}) inside the buy-now flows, paired with an outlined ghost button for secondary navigation.
354
+
355
+ Optimistic VF — Meta's variable display face — anchors the entire system, ranging from a 64px hero display down to a 12px caption. The face's `ss01` and `ss02` stylistic sets are switched on across every heading role, contributing to the brand's slightly humanist, friendly geometric character. Below 768px the system collapses cleanly: hero stacks, pill nav becomes a hamburger, three-up feature grids flatten to a single column, and product configurators drop their right-rail summary into a sticky bottom bar.
356
+
357
+ **Key Characteristics:**
358
+ - Stark white canvas ({colors.canvas}) carrying full-bleed product photography with `{rounded.xxxl}` (32px) corner softening on showcase tiles
359
+ - Two-tier primary button system: marketing CTAs use {colors.ink-button} pills; commerce CTAs use {colors.primary} cobalt pills inside buy-now panels
360
+ - Optimistic VF as the universal display + body face with consistent `ss01, ss02` OpenType features
361
+ - Pill-shaped buttons ({rounded.full}) and `{rounded.xxxl}`/`{rounded.feature}` cards as the dominant geometric signature
362
+ - Saturated promotional banners (yellow {colors.warning}, dark {colors.ink-deep}) used sparingly above the nav for time-bound offers
363
+ - Photographic feature cards with no card chrome (no border, no shadow) — the product imagery IS the surface treatment
364
+
365
+ ## Colors
366
+
367
+ > Source pages: meta.com/ (homepage), /ai-glasses/ray-ban-meta-skyler-gen-2/ (PDP), /quest/quest-3s/buy-now/ (configurator), /ai-glasses/prescription/ (lens upsell). Token coverage was identical across all four pages — the design system is genuinely unified.
368
+
369
+ ### Brand & Accent
370
+ - **Cobalt Primary** ({colors.primary}): The buy-now CTA color. Used on every "Add to cart", "Configure", "Pre-order" button inside the commerce flow and the right-rail purchase panel.
371
+ - **Deep Cobalt** ({colors.primary-deep}): Pressed-state and dark-surface variant of the cobalt primary; also the active link color.
372
+ - **Soft Cobalt** ({colors.primary-soft}): Translucent background tint for informational callouts (`{colors.primary-soft}` at 15% alpha).
373
+ - **Facebook Blue** ({colors.fb-blue}): Selected radio/checkbox state and inline form-control activation color.
374
+ - **Meta Link Blue** ({colors.meta-link}): Reserved for legacy navigation and footer link affordances.
375
+ - **Oculus Purple** ({colors.oculus-purple}): VR product accent — used inside Quest-branded surfaces for category emphasis.
376
+
377
+ ### Surface
378
+ - **Canvas White** ({colors.canvas}): Page background and primary card surface.
379
+ - **Soft Cloud** ({colors.surface-soft}): Subtle product-thumbnail and warranty-card background; also the search-pill rest state.
380
+ - **Hairline Gray** ({colors.hairline}): 1px input border and form-control divider.
381
+ - **Hairline Soft** ({colors.hairline-soft}): Quieter divider used on cards, footer separators, and section breaks.
382
+
383
+ ### Text
384
+ - **Deep Ink** ({colors.ink-deep}): Primary headline and body text on light surfaces.
385
+ - **Ink** ({colors.ink}): Standard body and secondary headline text.
386
+ - **Charcoal** ({colors.charcoal}): Tertiary body text and form-button labels.
387
+ - **Slate** ({colors.slate}): Section-header copy and supporting microcopy.
388
+ - **Steel** ({colors.steel}): Quieter caption text and footer link hierarchy.
389
+ - **Stone** ({colors.stone}): Disabled or de-emphasized labels.
390
+
391
+ ### Semantic
392
+ - **Success** ({colors.success}): "In stock", "Free returns" affirmations.
393
+ - **Attention** ({colors.attention}): Mid-priority alerts and timed callouts.
394
+ - **Warning** ({colors.warning}): Promotional banners ("Get 25% off…") and limited-time tags.
395
+ - **Critical** ({colors.critical}): Validation errors, destructive feedback.
396
+ - **Critical Strong** ({colors.critical-strong}): Form-input error border and inline error labels.
397
+
398
+ ## Typography
399
+
400
+ ### Font Family
401
+ **Optimistic VF** is Meta's proprietary variable display face. Fallbacks: Montserrat, Helvetica, Arial, Noto Sans. The variable axes carry from 300 (light heading-md, used for editorial intro headlines like "Look forward") through 500 (display, hero, heading-sm) up to 700 (subtitle, body emphasis, button labels). Stylistic sets `ss01` and `ss02` are switched on across every heading role — they soften the geometry and give the type a slightly humanist breathing.
402
+
403
+ A secondary Helvetica fallback chain is used for technical microcopy (12px) inside spec sheets and footer fine print.
404
+
405
+ ### Hierarchy
406
+
407
+ | Token | Size | Weight | Line Height | Letter Spacing | OpenType | Use |
408
+ |---|---|---|---|---|---|---|
409
+ | `{typography.hero-display}` | 64px | 500 | 1.16 | 0 | ss01, ss02 | Homepage hero ("Get 25% off…", category opener) |
410
+ | `{typography.display-lg}` | 48px | 500 | 1.17 | 0 | ss01, ss02 | Section-opener display ("Made for prescriptions. Built for comfort.") |
411
+ | `{typography.heading-lg}` | 36px | 500 | 1.28 | 0 | ss01, ss02 | Subsection headlines ("Why buy from Meta", "Tech specs") |
412
+ | `{typography.heading-md}` | 28px | 300 | 1.21 | 0 | ss01, ss02 | Editorial subheads in lighter weight ("Look forward", "Built for prescriptions") |
413
+ | `{typography.heading-sm}` | 24px | 500 | 1.25 | 0 | ss01, ss02 | Card titles, feature-tile headers |
414
+ | `{typography.subtitle-lg}` | 18px | 700 | 1.44 | 0 | — | Bold callouts, FAQ question titles |
415
+ | `{typography.subtitle-md}` | 18px | 400 | 1.44 | 0 | — | Body lead and longer-line subtitles |
416
+ | `{typography.body-md}` | 16px | 400 | 1.50 | -0.16px | — | Primary body text |
417
+ | `{typography.body-md-bold}` | 16px | 700 | 1.50 | -0.16px | — | Body emphasis and link-md |
418
+ | `{typography.body-sm}` | 14px | 400 | 1.43 | -0.14px | — | Secondary body, helper text |
419
+ | `{typography.body-sm-bold}` | 14px | 700 | 1.43 | -0.14px | — | Pill tab labels, footer headings |
420
+ | `{typography.caption-bold}` | 12px | 700 | 1.33 | 0 | — | Badge labels, timestamps |
421
+ | `{typography.caption}` | 12px | 400 | 1.33 | 0 | — | Footer fine print, legal microcopy |
422
+ | `{typography.button-md}` | 14px | 700 | 1.43 | -0.14px | — | Pill button labels |
423
+ | `{typography.link-md}` | 16px | 700 | 1.50 | -0.16px | — | Inline navigation links |
424
+
425
+ ### Principles
426
+ - Negative letter-spacing on body roles (`-0.14px` to `-0.16px`) tightens the type fractionally — Optimistic VF was designed for this snug-but-not-condensed setting.
427
+ - Editorial subheads use the 300 weight to introduce visual rest between the 500-weight display headlines and the 400-weight body, creating a three-tier visual rhythm.
428
+ - All headings carry `ss01, ss02` stylistic sets together — the design treats them as a paired alternates package, never one without the other.
429
+ - Buttons, pill tabs, and footer headings share `{typography.body-sm-bold}` (14px / 700 / -0.14px), creating a tight visual relationship between interactive elements.
430
+
431
+ ## Layout
432
+
433
+ ### Spacing System
434
+ - **Base unit**: 4px increment with 8px as the dominant primary step.
435
+ - **Tokens**: `{spacing.xxs}` (4px) · `{spacing.xs}` (8px) · `{spacing.sm}` (10px) · `{spacing.md}` (12px) · `{spacing.base}` (16px) · `{spacing.lg}` (20px) · `{spacing.xl}` (24px) · `{spacing.xxl}` (32px) · `{spacing.xxxl}` (40px) · `{spacing.section-sm}` (48px) · `{spacing.section}` (64px) · `{spacing.section-lg}` (80px) · `{spacing.hero}` (120px).
436
+ - **Section rhythm**: Marketing sections separate at `{spacing.section-lg}` (80px); product detail sections compress to `{spacing.section}` (64px); FAQ stacks tighten further to `{spacing.xxl}` (32px).
437
+ - **Card internal padding**: Standard `{spacing.xxl}` (32px); icon-feature tiles compress to `{spacing.xl}` (24px); promo-strip cards expand to `{spacing.section}` (64px) for hero presence.
438
+
439
+ ### Grid & Container
440
+ - Marketing page max-width sits around 1280px with 32–48px gutters.
441
+ - The PDP layout uses a 2-column split: hero gallery (~58% width) + sticky purchase rail (~42%, with `max-width: 380px` on the rail).
442
+ - Three-up feature grids ("Why buy from Meta") use a 24px column gap; six-up product thumbnail rows (color/SKU pickers) use a 12px gap.
443
+
444
+ ### Whitespace Philosophy
445
+ Whitespace is product-photography-first. Hero sections give product imagery 50–70% of the viewport height; copy is given oxygen to breathe in `{spacing.xxl}` to `{spacing.xxxl}` blocks above and below. Inside the configurator, whitespace tightens — the buy-now panel is information-dense, with `{spacing.base}` to `{spacing.lg}` rhythm between option groups.
446
+
447
+ ## Elevation & Depth
448
+
449
+ The system runs predominantly flat. Elevation is reserved for two interaction layers:
450
+
451
+ | Level | Treatment | Use |
452
+ |---|---|---|
453
+ | 0 (flat) | No shadow; `{rounded.xxxl}` rounding + `{colors.hairline-soft}` border | Default product cards, why-buy tiles |
454
+ | 1 (subtle) | `rgba(0, 0, 0, 0.2) 1px 1px 0px 0px` | Pill-tab activation indicator |
455
+ | 2 (sticky panel) | `rgba(20, 22, 26, 0.3) 0px 1px 4px 0px` | PDP right-rail purchase summary, sticky mobile checkout bar |
456
+
457
+ ### Decorative Depth
458
+ - Photography-as-depth: full-bleed product imagery on `{rounded.xxxl}` cards creates atmospheric layering without shadows.
459
+ - Translucent overlays (`rgba(255, 255, 255, 0.1)` to `rgba(10, 19, 23, 0.12)`) cover dark hero photography to lift legibility of overlaid text.
460
+ - Decorative pastel tints inside accessory cards — soft pink, ice-blue, mint — appear briefly behind product cutouts but are NOT formalized as system tokens (treated as photographic content).
461
+
462
+ ## Shapes
463
+
464
+ ### Border Radius Scale
465
+
466
+ | Token | Value | Use |
467
+ |---|---|---|
468
+ | `{rounded.xs}` | 2px | Inline checkbox marks, fine UI corners |
469
+ | `{rounded.sm}` | 4px | Tags, micro-controls |
470
+ | `{rounded.md}` | 6px | Square thumbnail rounding |
471
+ | `{rounded.lg}` | 8px | Form inputs, radio-option containers |
472
+ | `{rounded.xl}` | 16px | Standard feature cards, FAQ accordion items |
473
+ | `{rounded.xxl}` | 24px | Warranty / accessory tiles, ghost-style action cards |
474
+ | `{rounded.xxxl}` | 32px | Photographic feature cards, big promo strips |
475
+ | `{rounded.feature}` | 40px | Accessory hero panels, "Built for prescriptions" cards |
476
+ | `{rounded.full}` | 100px | Pill buttons, tab chips, badges |
477
+ | `{rounded.circle}` | 50% | Color swatches, circular icon buttons |
478
+
479
+ ### Photography Geometry
480
+ - Product hero photography sits in `{rounded.xxxl}` (32px) frames more often than rectangles.
481
+ - Color/material swatches are perfect circles (`{rounded.circle}`, 32px diameter, 2px white border ring when selected).
482
+ - Square product thumbnails (`aspect-ratio: 1/1`) use `{rounded.xl}` rounding.
483
+ - Six-up "color & SKU" picker rows use 1:1 aspect tiles with `{rounded.lg}` (8px) corners — tighter than the hero photography frames to differentiate selection-grid context from showcase context.
484
+
485
+ ## Components
486
+
487
+ > Per the no-hover policy, hover states are NOT documented for any component below. Default and pressed/active states only.
488
+
489
+ ### Buttons
490
+
491
+ **`button-primary`** — Black pill primary CTA for marketing surfaces ("Shop", "Pre-order").
492
+ - Background `{colors.ink-button}`, text `{colors.on-ink-button}`, typography `{typography.button-md}`, padding `14px 30px`, rounded `{rounded.full}`.
493
+ - Pressed state `button-primary-pressed` flips background to `{colors.charcoal}`.
494
+ - Disabled state `button-primary-disabled` uses `{colors.disabled-text}` background.
495
+
496
+ **`button-buy-cta`** — Cobalt pill primary CTA for commerce flows ("Add to cart", "Configure", "Continue").
497
+ - Background `{colors.primary}`, text `{colors.on-primary}`, typography `{typography.button-md}`, padding `14px 30px`, rounded `{rounded.full}`.
498
+ - Pressed state `button-buy-cta-pressed` deepens background to `{colors.primary-deep}`.
499
+ - This variant ONLY appears inside the buy-now configurator and PDP purchase rail. Marketing surfaces use `button-primary` instead.
500
+
501
+ **`button-secondary`** — Outlined ghost CTA, often paired with primary in dual-CTA hero patterns.
502
+ - Background transparent, text `{colors.ink-deep}`, border `2px solid {colors.ink-deep}`, typography `{typography.button-md}`, padding `12px 28px`, rounded `{rounded.full}`.
503
+
504
+ **`button-ghost`** — Quieter outlined variant used for tertiary CTAs.
505
+ - Background transparent, text `{colors.ink-deep}`, border `2px solid rgba(10, 19, 23, 0.12)`, typography `{typography.button-md}`, padding `10px 22px`, rounded `{rounded.full}`.
506
+
507
+ **`button-pill-tab`** + **`button-pill-tab-active`** — Top-of-page category navigation pills ("Glasses / Quest / Apps").
508
+ - Inactive: background `{colors.canvas}`, text `{colors.ink}`, border `1px solid {colors.hairline}`, padding `8px 16px`, rounded `{rounded.full}`.
509
+ - Active: background `{colors.ink-deep}`, text `{colors.canvas}`. No border in active state — the dark fill replaces it.
510
+
511
+ **`button-icon-circular`** — 40×40px circular utility buttons (carousel arrows, share, favorite).
512
+ - Background `{colors.canvas}`, icon color `{colors.ink}`, rounded `{rounded.circle}`.
513
+
514
+ ### Cards & Containers
515
+
516
+ **`card-product-feature`** — White feature card with product photography and copy (homepage "Designed for sport", "Advanced. Inside and out.").
517
+ - Background `{colors.canvas}`, rounded `{rounded.xxxl}`, padding `{spacing.xxl}`, border `1px solid {colors.hairline-soft}`.
518
+
519
+ **`card-feature-photo`** — Edge-to-edge photographic showcase tile with NO chrome (homepage "Built for prescriptions" full-bleed glasses card).
520
+ - Background `{colors.canvas}` (visible only at the corners), rounded `{rounded.xxxl}`, no padding, no border. The image fills the card; copy is overlaid bottom-left in white.
521
+
522
+ **`card-promo-strip`** — Dark full-width promo card with embedded copy + CTAs (homepage "Meta Quest brings the magic of virtual reality" wide strip).
523
+ - Background `{colors.ink-deep}`, text `{colors.canvas}`, rounded `{rounded.xxxl}`, padding `{spacing.section}`.
524
+
525
+ **`card-icon-feature`** — Three-up feature tile with line icon, headline, and short copy ("Free 2-day delivery", "Free 30-day returns", "Worry-free warranty", "Buy now, pay later").
526
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.xl}`, border `1px solid {colors.hairline-soft}`.
527
+
528
+ **`card-checkout-summary`** — PDP right-rail sticky summary with title, price, color picker, "Add to cart" button.
529
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.xl}`, border `1px solid {colors.hairline-soft}`, shadow `rgba(20, 22, 26, 0.3) 0px 1px 4px 0px`.
530
+
531
+ **`product-thumbnail`** — Square product image cell used in color/SKU pickers and "People also bought" rows.
532
+ - Background `{colors.surface-soft}`, rounded `{rounded.xl}`, padding `{spacing.base}`, aspect-ratio `1 / 1`.
533
+
534
+ **`warranty-card`** — Promo callout for warranty + finance offers ("1y Warranty", "Meta Horizon+").
535
+ - Background `{colors.surface-soft}`, rounded `{rounded.xxl}`, padding `{spacing.xxl}`. Uses pastel-tinted variants for additional perks.
536
+
537
+ **`why-buy-tile`** — 4-up reassurance tile row in the lower marketing zone.
538
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.xxl} {spacing.xl}`, border `1px solid {colors.hairline-soft}`. Heading in `{typography.subtitle-lg}`, body in `{typography.body-sm}`.
539
+
540
+ ### Inputs & Forms
541
+
542
+ **`text-input`** — Standard form field (footer email subscribe, support form).
543
+ - Background `{colors.canvas}`, text `{colors.ink}`, border `1px solid {colors.hairline}`, rounded `{rounded.lg}`, padding `{spacing.md}`, height 44px.
544
+
545
+ **`text-input-focused`** — Activated state.
546
+ - Border switches to `2px solid {colors.fb-blue}`.
547
+
548
+ **`text-input-error`** — Validation error state.
549
+ - Border switches to `1px solid {colors.critical-strong}`; error label below in `{colors.critical-strong}` `{typography.body-sm}`.
550
+
551
+ **`search-pill`** — Top-nav search field.
552
+ - Background `{colors.surface-soft}`, text `{colors.steel}`, typography `{typography.body-sm}`, rounded `{rounded.full}`, height 40px.
553
+
554
+ **`radio-option`** + **`radio-option-selected`** — Configurator option cards (storage, color variant, shipping option).
555
+ - Inactive: background `{colors.canvas}`, rounded `{rounded.lg}`, padding `{spacing.lg}`, border `1px solid rgba(10, 19, 23, 0.12)`.
556
+ - Selected: border switches to `2px solid #0143b5` (deep cobalt) — the cobalt theme persists into form-control selection signaling.
557
+
558
+ **`color-swatch-circle`** — Round color/material picker (Ray-Ban frame finishes, glass colors).
559
+ - 32px diameter, `{rounded.circle}`, `2px solid {colors.canvas}` ring on selection over the swatch's own fill color.
560
+
561
+ ### Badges & Status
562
+
563
+ **`badge-promo-yellow`** — Limited-time offer chip ("Limited time", "Sale").
564
+ - Background `{colors.warning}`, text `{colors.ink-deep}`, typography `{typography.caption-bold}`, rounded `{rounded.full}`, padding `4px 10px`.
565
+
566
+ **`badge-attention`** — Mid-priority status indicator ("Almost gone", "Selling fast").
567
+ - Background `{colors.attention}`, text `{colors.canvas}`, typography `{typography.caption-bold}`, rounded `{rounded.full}`, padding `4px 10px`.
568
+
569
+ **`badge-success`** — Affirmative status ("In stock", "Verified", "Free shipping").
570
+ - Background `{colors.success}`, text `{colors.canvas}`, typography `{typography.caption-bold}`, rounded `{rounded.full}`, padding `4px 10px`.
571
+
572
+ **`badge-critical`** — Urgent/destructive label ("Out of stock", "Discontinued", error chips).
573
+ - Background `{colors.critical}`, text `{colors.canvas}`, typography `{typography.caption-bold}`, rounded `{rounded.full}`, padding `4px 10px`.
574
+
575
+ **`promo-banner`** — Sticky full-width promotional strip ABOVE the top nav ("Get 25% off the #1 selling AI glasses").
576
+ - Background `{colors.ink-deep}` (or `{colors.warning}` for yellow promo variants), text `{colors.canvas}` (or `{colors.ink-deep}` on yellow), typography `{typography.body-sm-bold}`, padding `{spacing.md} {spacing.xl}`. Carries one-line offer copy plus an inline CTA link.
577
+
578
+ ### Navigation
579
+
580
+ **Top Navigation (Desktop)** — Sticky white bar with category pill tabs, search, account, cart.
581
+ - Background `{colors.canvas}`, height ~64px with bottom `1px solid {colors.hairline-soft}`.
582
+ - Left: Meta wordmark logo (61×14px). Center: pill-tab category nav. Right: search-pill + circular icon buttons (account, cart).
583
+
584
+ **Top Navigation (Mobile)** — Compressed to logo + hamburger + cart icon. Pill-tab nav slides into a full-screen drawer below 768px.
585
+
586
+ **Promo Banner** — Full-width strip ABOVE the nav for time-bound offers.
587
+ - Background `{colors.ink-deep}` or `{colors.warning}` (yellow), text `{colors.canvas}` or `{colors.ink-deep}`, typography `{typography.body-sm-bold}`, padding `{spacing.md} {spacing.xl}`. Carries one-line offer copy + inline link.
588
+
589
+ **Breadcrumb (PDP)** — Inline path above the product hero ("Glasses › Ray-Ban Meta › Skyler (Gen 2)").
590
+ - Typography `{typography.body-sm}`, separator dot in `{colors.stone}`, active leaf in `{colors.ink}`, parent links in `{colors.steel}`.
591
+
592
+ ### Signature Components
593
+
594
+ **`hero-band-marketing`** — Full-bleed photographic hero with overlaid copy + dual-CTA pair.
595
+ - Edge-to-edge product photography on a dark or photographic background. Overlay copy in `{typography.hero-display}` white. Below the title: 1-line subtitle in `{typography.subtitle-md}` then `button-primary` + `button-secondary` pair.
596
+
597
+ **`product-gallery-pdp`** — Product detail page main hero: 4-up vertical thumbnail strip on the left, large product image center, sticky purchase rail right.
598
+ - Thumbnails: 80×80px, `{rounded.lg}`, `{colors.surface-soft}` background, 1px `{colors.hairline-soft}` border (active border switches to `{colors.ink-deep}`).
599
+ - Main image area: ~720×720px on desktop, `{rounded.xxxl}` rounding, photographic surface.
600
+ - Sticky rail uses `card-checkout-summary`.
601
+
602
+ **`color-sku-picker-row`** — Six-up grid of square product variants with name + price below each.
603
+ - Tile background `{colors.surface-soft}`, rounded `{rounded.lg}`, image padded `{spacing.base}`. Active tile border switches to `2px solid {colors.ink-deep}`. Below the tile: variant name in `{typography.body-sm-bold}` and price in `{typography.body-sm}`.
604
+
605
+ **`feature-icon-row`** — Four reassurance benefits ("Free 2-day delivery", "Free 30-day returns", "Worry-free warranty", "Buy now, pay later").
606
+ - 4-column grid, each cell uses `card-icon-feature` chrome with a 32px line icon at top, headline `{typography.subtitle-lg}`, body `{typography.body-sm}`.
607
+
608
+ **`faq-accordion`** — Vertical stack of expandable Q&A items.
609
+ - Each item uses `faq-accordion-item` chrome. Question in `{typography.subtitle-lg}` left, chevron icon (`{colors.steel}`, 20px) right. Expanded answer drops in `{typography.body-md}` text below with `{spacing.base}` top padding.
610
+
611
+ **`tech-specs-table`** — Two-column key/value table for product specifications.
612
+ - Row layout: spec label (`{typography.body-sm-bold}` `{colors.ink}`) left, spec value (`{typography.body-sm}` `{colors.charcoal}`) right. Row separator `1px solid {colors.hairline-soft}`. Section headers in `{typography.heading-sm}` above each spec group.
613
+
614
+ **`testimonial-customer-card`** — Small editorial card with author + quote + photo.
615
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.xxl}`, border `1px solid {colors.hairline-soft}`. Avatar circle 40px, byline in `{typography.body-sm-bold}`, quote in `{typography.body-md}`.
616
+
617
+ **`footer-region`** — Dense multi-column site footer.
618
+ - Background `{colors.canvas}`, top border `1px solid {colors.hairline-soft}`, padding `{spacing.section} {spacing.xxl}`. Six column groups with section headings in `{typography.body-sm-bold}` `{colors.ink}` and link lists in `{typography.body-sm}` `{colors.steel}`. Bottom row contains language picker, region selector, legal links in `{typography.caption}` `{colors.stone}`.
619
+
620
+ ## Do's and Don'ts
621
+
622
+ ### Do
623
+ - Reserve `{colors.primary}` (cobalt) for buy-now CTAs only — its visual weight is meaningful precisely because it doesn't appear on marketing pages.
624
+ - Use `{colors.ink-button}` (black) for marketing-surface primary CTAs. Pair with `{colors.button-secondary}` ghost outline for the secondary action.
625
+ - Apply `{rounded.full}` to every button, every category pill, every badge, every chip — buttons are NEVER squared in Meta's system.
626
+ - Apply `{rounded.xxxl}` to photographic product cards and `{rounded.xl}` to icon-feature tiles to maintain the visible card-hierarchy contrast.
627
+ - Switch on `ss01, ss02` together for any Optimistic VF heading. Never one stylistic set without the other.
628
+ - Use the 300-weight `{typography.heading-md}` for editorial subheads — it creates the brand's signature visual rhythm against the 500-weight displays.
629
+
630
+ ### Don't
631
+ - Don't use `{colors.primary}` (cobalt) for marketing-surface primary buttons — it conflicts with Meta's brand-history positioning of black-CTA-on-white-canvas marketing.
632
+ - Don't introduce additional accent colors beyond cobalt + Oculus purple. The hardware brand is deliberately monochromatic outside its product photography.
633
+ - Don't soften the corners of pill buttons below `{rounded.full}`. The pill is a brand signature.
634
+ - Don't run feature cards without rounding — `{rounded.xxxl}` is the minimum for any photographic surface.
635
+ - Don't reduce `{typography.body-md}` line-height below 1.50 — the negative letter-spacing already tightens the metric and any further compression breaks legibility.
636
+ - Don't apply heavy shadows to marketing cards. Elevation is a commerce-flow signal, not a marketing flourish.
637
+
638
+ ## Responsive Behavior
639
+
640
+ ### Breakpoints
641
+ | Name | Width | Key Changes |
642
+ |---|---|---|
643
+ | Mobile (small) | < 480px | Single column. Hero text drops to `{typography.display-lg}` or smaller. Pill tabs collapse into hamburger drawer. PDP gallery stacks above purchase rail; rail becomes sticky bottom bar. |
644
+ | Mobile (large) | 480 – 767px | Same as small but feature tiles render two-up. |
645
+ | Tablet | 768 – 1023px | Two-column feature grids. Pill-tab nav returns. PDP gallery + purchase rail render side-by-side at compressed proportions (~60/40). |
646
+ | Desktop | 1024 – 1359px | Full three- and four-up feature grids; full pill-tab category nav; PDP at standard 58/42 split. |
647
+ | Wide Desktop | ≥ 1360px | Same as desktop with wider hero gutters and larger product photography. |
648
+
649
+ ### Touch Targets
650
+ - Pill buttons render at 40–44px effective height (with the 14px button text + `14px 30px` padding). Above the WCAG AAA 44px floor.
651
+ - Circular icon buttons are 40×40px — at the AA floor; bumps to 44×44px on mobile via override.
652
+ - Color swatch circles are 32×32px. To hit AAA, the swatch carries a 12px clear hit zone around it (effective hit target ~56px).
653
+ - Form inputs render at 44px height to align with primary button height.
654
+
655
+ ### Collapsing Strategy
656
+ - **Promo banner** stays full-width on all breakpoints; truncates with ellipsis on small mobile, retains the inline link affordance.
657
+ - **Pill-tab nav** below 768px collapses into a hamburger drawer; the active tab is rendered as a label inside the closed nav.
658
+ - **PDP layout**: gallery stacks above the purchase summary at < 1024px; the summary becomes a sticky bottom bar with price + "Add to cart" button at < 768px. The full summary remains scrollable above the sticky bar.
659
+ - **Feature grids** (3-up, 4-up) collapse to 2-up at 768–1023px and 1-up at < 768px. Card padding compresses from `{spacing.xxl}` to `{spacing.xl}` at the 1-up breakpoint.
660
+ - **Hero typography**: `{typography.hero-display}` (64px) drops to `{typography.heading-lg}` (36px) at < 768px and `{typography.heading-sm}` (24px) at < 480px.
661
+ - **Footer**: 6-column desktop layout reflows to 2-column at tablet and accordion-collapsed groups at mobile.
662
+
663
+ ### Image Behavior
664
+ - Product photography uses 1:1 (thumbnails, color pickers), 4:3 (PDP gallery), and 16:9 (homepage promo strips) ratios.
665
+ - Hero photography is full-bleed with `{rounded.xxxl}` corners; lazy-loaded below the fold.
666
+ - Product variant images preserve their `{rounded.lg}` thumbnails across all breakpoints — they never go full-width on mobile.
667
+
668
+ ## Iteration Guide
669
+
670
+ 1. Focus on ONE component at a time. The system has high internal consistency — small precision wins compound.
671
+ 2. Reference component names and tokens directly (`{colors.primary}`, `{component-name}-pressed`, `{rounded.full}`) — do not paraphrase.
672
+ 3. Run `npx @google/design.md lint DESIGN.md` after edits to catch broken refs, contrast issues, orphaned tokens.
673
+ 4. Add new variants as separate `components:` entries (`-pressed`, `-disabled`, `-focused`) — do not bury them inside prose.
674
+ 5. Default to `{typography.body-md}` for body and `{typography.subtitle-lg}` for emphasis. Headlines step down through `hero-display → display-lg → heading-lg → heading-md → heading-sm`.
675
+ 6. Keep `{colors.primary}` (cobalt) scarce. If it appears outside the buy-now flow on a viewport, ask whether the surface really needs to look like a checkout panel.
676
+ 7. Pill-shaped buttons (`{rounded.full}`) always; squared buttons signal "third-party widget" in this design language and should be filtered out of any work surface.
677
+
678
+ ## Known Gaps
679
+
680
+ - Selected/checked states for non-button form controls (toggle, multi-select) were not visible on the captured surfaces — implement following the cobalt-on-white pattern from `radio-option-selected`.
681
+ - Animation/transition timings are not extracted; recommend 150–250ms ease-out for primary surface transitions and 300ms ease-in-out for accordion expand/collapse.
682
+ - Specific dark-mode token values for canvas, surface, ink, and hairline are not defined; the brand has not surfaced a published dark-mode token set on these commerce pages.
683
+ - Pastel decorative tints inside accessory cards (soft pink, ice blue, mint) appear visually but are not formalized — treat them as photographic content, not as system colors.