rivet-design 0.9.2 → 0.9.3

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 (137) hide show
  1. package/dist/mcp/agent-variants/SessionStore.d.ts +63 -2
  2. package/dist/mcp/agent-variants/SessionStore.d.ts.map +1 -1
  3. package/dist/mcp/agent-variants/SessionStore.js +331 -71
  4. package/dist/mcp/agent-variants/SessionStore.js.map +1 -1
  5. package/dist/mcp/agent-variants/WorktreeOrchestrator.d.ts +197 -8
  6. package/dist/mcp/agent-variants/WorktreeOrchestrator.d.ts.map +1 -1
  7. package/dist/mcp/agent-variants/WorktreeOrchestrator.js +805 -46
  8. package/dist/mcp/agent-variants/WorktreeOrchestrator.js.map +1 -1
  9. package/dist/mcp/agent-variants/contracts.d.ts +1101 -9
  10. package/dist/mcp/agent-variants/contracts.d.ts.map +1 -1
  11. package/dist/mcp/agent-variants/contracts.js +131 -5
  12. package/dist/mcp/agent-variants/contracts.js.map +1 -1
  13. package/dist/mcp/agent-variants/createZeroToOneTool.d.ts +205 -0
  14. package/dist/mcp/agent-variants/createZeroToOneTool.d.ts.map +1 -0
  15. package/dist/mcp/agent-variants/createZeroToOneTool.js +295 -0
  16. package/dist/mcp/agent-variants/createZeroToOneTool.js.map +1 -0
  17. package/dist/mcp/agent-variants/designContextStore.d.ts +160 -0
  18. package/dist/mcp/agent-variants/designContextStore.d.ts.map +1 -0
  19. package/dist/mcp/agent-variants/designContextStore.js +295 -0
  20. package/dist/mcp/agent-variants/designContextStore.js.map +1 -0
  21. package/dist/mcp/agent-variants/elementRefToTarget.d.ts +21 -0
  22. package/dist/mcp/agent-variants/elementRefToTarget.d.ts.map +1 -0
  23. package/dist/mcp/agent-variants/elementRefToTarget.js +47 -0
  24. package/dist/mcp/agent-variants/elementRefToTarget.js.map +1 -0
  25. package/dist/mcp/agent-variants/errors.d.ts +1 -1
  26. package/dist/mcp/agent-variants/errors.d.ts.map +1 -1
  27. package/dist/mcp/agent-variants/errors.js +6 -0
  28. package/dist/mcp/agent-variants/errors.js.map +1 -1
  29. package/dist/mcp/agent-variants/index.d.ts +4 -1
  30. package/dist/mcp/agent-variants/index.d.ts.map +1 -1
  31. package/dist/mcp/agent-variants/index.js +7 -1
  32. package/dist/mcp/agent-variants/index.js.map +1 -1
  33. package/dist/mcp/agent-variants/inspirationDesignContext.d.ts +430 -0
  34. package/dist/mcp/agent-variants/inspirationDesignContext.d.ts.map +1 -0
  35. package/dist/mcp/agent-variants/inspirationDesignContext.js +2379 -0
  36. package/dist/mcp/agent-variants/inspirationDesignContext.js.map +1 -0
  37. package/dist/mcp/agent-variants/pendingChangesAdapter.d.ts.map +1 -1
  38. package/dist/mcp/agent-variants/pendingChangesAdapter.js +10 -7
  39. package/dist/mcp/agent-variants/pendingChangesAdapter.js.map +1 -1
  40. package/dist/mcp/agent-variants/sourceContext.d.ts +7 -0
  41. package/dist/mcp/agent-variants/sourceContext.d.ts.map +1 -0
  42. package/dist/mcp/agent-variants/sourceContext.js +158 -0
  43. package/dist/mcp/agent-variants/sourceContext.js.map +1 -0
  44. package/dist/mcp/agent-variants/tools.d.ts +14 -0
  45. package/dist/mcp/agent-variants/tools.d.ts.map +1 -1
  46. package/dist/mcp/agent-variants/tools.js +330 -15
  47. package/dist/mcp/agent-variants/tools.js.map +1 -1
  48. package/dist/mcp/changeBatchClassification.d.ts +30 -0
  49. package/dist/mcp/changeBatchClassification.d.ts.map +1 -0
  50. package/dist/mcp/changeBatchClassification.js +65 -0
  51. package/dist/mcp/changeBatchClassification.js.map +1 -0
  52. package/dist/mcp/server.d.ts.map +1 -1
  53. package/dist/mcp/server.js +237 -39
  54. package/dist/mcp/server.js.map +1 -1
  55. package/dist/proxy-middleware/proxy-config.d.ts.map +1 -1
  56. package/dist/proxy-middleware/proxy-config.js +1 -15
  57. package/dist/proxy-middleware/proxy-config.js.map +1 -1
  58. package/dist/routes/agentVariants.d.ts +3 -1
  59. package/dist/routes/agentVariants.d.ts.map +1 -1
  60. package/dist/routes/agentVariants.js +131 -13
  61. package/dist/routes/agentVariants.js.map +1 -1
  62. package/dist/routes/mcp.d.ts +7 -1
  63. package/dist/routes/mcp.d.ts.map +1 -1
  64. package/dist/routes/mcp.js +139 -16
  65. package/dist/routes/mcp.js.map +1 -1
  66. package/dist/server.d.ts.map +1 -1
  67. package/dist/server.js +2 -2
  68. package/dist/server.js.map +1 -1
  69. package/dist/services/SessionBridgeService.d.ts +22 -0
  70. package/dist/services/SessionBridgeService.d.ts.map +1 -1
  71. package/dist/services/SessionBridgeService.js +61 -0
  72. package/dist/services/SessionBridgeService.js.map +1 -1
  73. package/dist/services/TelemetryService.d.ts +121 -0
  74. package/dist/services/TelemetryService.d.ts.map +1 -1
  75. package/dist/services/TelemetryService.js +155 -0
  76. package/dist/services/TelemetryService.js.map +1 -1
  77. package/dist/services/WorktreeManager.d.ts +57 -5
  78. package/dist/services/WorktreeManager.d.ts.map +1 -1
  79. package/dist/services/WorktreeManager.js +205 -13
  80. package/dist/services/WorktreeManager.js.map +1 -1
  81. package/dist/services/templates/designCatalog.d.ts +27 -0
  82. package/dist/services/templates/designCatalog.d.ts.map +1 -0
  83. package/dist/services/templates/designCatalog.js +141 -0
  84. package/dist/services/templates/designCatalog.js.map +1 -0
  85. package/dist/services/templates/designmd/airbnb.md +545 -0
  86. package/dist/services/templates/designmd/airtable.md +554 -0
  87. package/dist/services/templates/designmd/apple.md +562 -0
  88. package/dist/services/templates/designmd/binance.md +634 -0
  89. package/dist/services/templates/designmd/bmw-m.md +503 -0
  90. package/dist/services/templates/designmd/bmw.md +544 -0
  91. package/dist/services/templates/designmd/bugatti.md +454 -0
  92. package/dist/services/templates/designmd/cal.md +542 -0
  93. package/dist/services/templates/designmd/claude.md +589 -0
  94. package/dist/services/templates/designmd/clay.md +541 -0
  95. package/dist/services/templates/designmd/cohere.md +451 -0
  96. package/dist/services/templates/designmd/cursor.md +537 -0
  97. package/dist/services/templates/designmd/expo.md +526 -0
  98. package/dist/services/templates/designmd/figma.md +578 -0
  99. package/dist/services/templates/designmd/framer.md +544 -0
  100. package/dist/services/templates/designmd/hp.md +670 -0
  101. package/dist/services/templates/designmd/linear.app.md +548 -0
  102. package/dist/services/templates/designmd/mintlify.md +852 -0
  103. package/dist/services/templates/designmd/miro.md +825 -0
  104. package/dist/services/templates/designmd/notion.md +821 -0
  105. package/dist/services/templates/designmd/raycast.md +669 -0
  106. package/dist/services/templates/designmd/resend.md +585 -0
  107. package/dist/services/templates/designmd/sentry.md +262 -0
  108. package/dist/services/templates/designmd/shopify.md +350 -0
  109. package/dist/services/templates/designmd/spotify.md +246 -0
  110. package/dist/services/templates/designmd/stripe.md +322 -0
  111. package/dist/services/templates/designmd/supabase.md +255 -0
  112. package/dist/services/templates/designmd/superhuman.md +252 -0
  113. package/dist/services/templates/designmd/uber.md +295 -0
  114. package/dist/services/templates/designmd/vercel.md +310 -0
  115. package/dist/services/templates/viteReactTs.d.ts +42 -0
  116. package/dist/services/templates/viteReactTs.d.ts.map +1 -0
  117. package/dist/services/templates/viteReactTs.js +267 -0
  118. package/dist/services/templates/viteReactTs.js.map +1 -0
  119. package/dist/types/change-request-types.d.ts +15 -3
  120. package/dist/types/change-request-types.d.ts.map +1 -1
  121. package/dist/utils/skills/claude-skill.d.ts +2 -2
  122. package/dist/utils/skills/claude-skill.d.ts.map +1 -1
  123. package/dist/utils/skills/claude-skill.js +19 -98
  124. package/dist/utils/skills/claude-skill.js.map +1 -1
  125. package/dist/utils/skills/cursor-rules.d.ts +2 -2
  126. package/dist/utils/skills/cursor-rules.d.ts.map +1 -1
  127. package/dist/utils/skills/cursor-rules.js +15 -80
  128. package/dist/utils/skills/cursor-rules.js.map +1 -1
  129. package/dist/utils/skills/shared-variants-protocol.d.ts +23 -0
  130. package/dist/utils/skills/shared-variants-protocol.d.ts.map +1 -0
  131. package/dist/utils/skills/shared-variants-protocol.js +131 -0
  132. package/dist/utils/skills/shared-variants-protocol.js.map +1 -0
  133. package/package.json +4 -3
  134. package/src/ui/dist/assets/main-C9jfEp80.css +1 -0
  135. package/src/ui/dist/assets/{main-AsPCtLsx.js → main-DejhsBWR.js} +93 -93
  136. package/src/ui/dist/index.html +2 -2
  137. package/src/ui/dist/assets/main-BzmseUDd.css +0 -1
@@ -0,0 +1,670 @@
1
+ ---
2
+ version: alpha
3
+ name: HP Inspired
4
+ description: An inspired interpretation of HP's design language — a white-paper enterprise-consumer system anchored by HP Electric Blue (`#024ad8`) as the lone signal CTA, near-black ink (`#1a1a1a`) for headlines, geometric Forma-DJR sans throughout, and angular blue-chevron decorations that nod to the HP wordmark's slashes. Cards round at 8–16px, photos sit in soft 16px frames, and dark navy slabs anchor the customer-story and "how can we help" closing bands.
5
+
6
+ colors:
7
+ primary: "#024ad8"
8
+ primary-bright: "#296ef9"
9
+ primary-deep: "#0e3191"
10
+ primary-soft: "#c9e0fc"
11
+ on-primary: "#ffffff"
12
+ ink: "#1a1a1a"
13
+ ink-deep: "#000000"
14
+ ink-soft: "#292929"
15
+ on-ink: "#ffffff"
16
+ canvas: "#ffffff"
17
+ paper: "#ffffff"
18
+ cloud: "#f7f7f7"
19
+ fog: "#e8e8e8"
20
+ steel: "#c2c2c2"
21
+ graphite: "#636363"
22
+ charcoal: "#3d3d3d"
23
+ hairline: "#e8e8e8"
24
+ hairline-strong: "#c2c2c2"
25
+ link: "#024ad8"
26
+ link-pressed: "#0e3191"
27
+ bloom-coral: "#ff5050"
28
+ bloom-rose: "#f9d4d2"
29
+ bloom-deep: "#b3262b"
30
+ bloom-wine: "#5a1313"
31
+ storm-mist: "#8ebdce"
32
+ storm-sea: "#7fadbe"
33
+ storm-deep: "#356373"
34
+ error: "#b3262b"
35
+
36
+ typography:
37
+ display-xxl:
38
+ fontFamily: Forma DJR Micro
39
+ fontSize: 72px
40
+ fontWeight: 500
41
+ lineHeight: 1.0
42
+ letterSpacing: 0
43
+ display-xl:
44
+ fontFamily: Forma DJR Micro
45
+ fontSize: 56px
46
+ fontWeight: 500
47
+ lineHeight: 1.0
48
+ letterSpacing: 0
49
+ display-lg:
50
+ fontFamily: Forma DJR Micro
51
+ fontSize: 44px
52
+ fontWeight: 500
53
+ lineHeight: 1.0
54
+ letterSpacing: 0
55
+ display-md:
56
+ fontFamily: Forma DJR Micro
57
+ fontSize: 32px
58
+ fontWeight: 500
59
+ lineHeight: 1.0
60
+ letterSpacing: 0
61
+ display-sm:
62
+ fontFamily: Forma DJR Micro
63
+ fontSize: 24px
64
+ fontWeight: 500
65
+ lineHeight: 1.17
66
+ letterSpacing: 0
67
+ display-xs:
68
+ fontFamily: Forma DJR Micro
69
+ fontSize: 20px
70
+ fontWeight: 500
71
+ lineHeight: 1.0
72
+ letterSpacing: 0
73
+ body-lg:
74
+ fontFamily: Forma DJR Micro
75
+ fontSize: 18px
76
+ fontWeight: 400
77
+ lineHeight: 1.33
78
+ letterSpacing: 0
79
+ body-md:
80
+ fontFamily: Forma DJR Micro
81
+ fontSize: 16px
82
+ fontWeight: 400
83
+ lineHeight: 1.38
84
+ letterSpacing: 0
85
+ body-emphasis:
86
+ fontFamily: Forma DJR Micro
87
+ fontSize: 16px
88
+ fontWeight: 500
89
+ lineHeight: 1.38
90
+ letterSpacing: 0
91
+ caption-md:
92
+ fontFamily: Forma DJR Micro
93
+ fontSize: 14px
94
+ fontWeight: 400
95
+ lineHeight: 1.5
96
+ letterSpacing: 0
97
+ caption-sm:
98
+ fontFamily: Forma DJR Micro
99
+ fontSize: 12px
100
+ fontWeight: 400
101
+ lineHeight: 1.33
102
+ letterSpacing: 0
103
+ caption-bold:
104
+ fontFamily: Forma DJR Micro
105
+ fontSize: 14px
106
+ fontWeight: 700
107
+ lineHeight: 1.3
108
+ letterSpacing: 0
109
+ link-md:
110
+ fontFamily: Forma DJR Micro
111
+ fontSize: 16px
112
+ fontWeight: 500
113
+ lineHeight: 1.38
114
+ letterSpacing: 0
115
+ button-md:
116
+ fontFamily: Forma DJR Micro
117
+ fontSize: 14px
118
+ fontWeight: 600
119
+ lineHeight: 1.4
120
+ letterSpacing: 0.7px
121
+ textTransform: uppercase
122
+ button-sm:
123
+ fontFamily: Forma DJR Micro
124
+ fontSize: 12.6px
125
+ fontWeight: 700
126
+ lineHeight: 1.0
127
+ letterSpacing: 0.126px
128
+ price-md:
129
+ fontFamily: Forma DJR Micro
130
+ fontSize: 24px
131
+ fontWeight: 500
132
+ lineHeight: 1.17
133
+ letterSpacing: 0
134
+
135
+ rounded:
136
+ none: 0px
137
+ xs: 2px
138
+ sm: 3px
139
+ md: 4px
140
+ lg: 8px
141
+ xl: 16px
142
+ pill: 9999px
143
+ full: 9999px
144
+
145
+ spacing:
146
+ xxs: 4px
147
+ xs: 8px
148
+ sm: 12px
149
+ md: 16px
150
+ lg: 20px
151
+ xl: 24px
152
+ xxl: 32px
153
+ section: 80px
154
+
155
+ components:
156
+ button-primary:
157
+ backgroundColor: "{colors.primary}"
158
+ textColor: "{colors.on-primary}"
159
+ typography: "{typography.button-md}"
160
+ rounded: "{rounded.md}"
161
+ padding: 12px 24px
162
+ height: 44px
163
+ button-primary-pressed:
164
+ backgroundColor: "{colors.primary-deep}"
165
+ textColor: "{colors.on-primary}"
166
+ button-primary-disabled:
167
+ backgroundColor: "{colors.steel}"
168
+ textColor: "{colors.on-primary}"
169
+ button-ink:
170
+ backgroundColor: "{colors.ink}"
171
+ textColor: "{colors.on-primary}"
172
+ typography: "{typography.button-md}"
173
+ rounded: "{rounded.md}"
174
+ padding: 12px 24px
175
+ height: 44px
176
+ button-outline:
177
+ backgroundColor: "{colors.canvas}"
178
+ textColor: "{colors.primary}"
179
+ typography: "{typography.button-md}"
180
+ rounded: "{rounded.md}"
181
+ padding: 12px 24px
182
+ height: 44px
183
+ button-outline-ink:
184
+ backgroundColor: "{colors.canvas}"
185
+ textColor: "{colors.ink}"
186
+ typography: "{typography.button-md}"
187
+ rounded: "{rounded.md}"
188
+ padding: 12px 24px
189
+ height: 44px
190
+ button-text-link:
191
+ backgroundColor: "{colors.canvas}"
192
+ textColor: "{colors.primary}"
193
+ typography: "{typography.link-md}"
194
+ padding: 4px 0
195
+ badge-pill-ink:
196
+ backgroundColor: "{colors.ink}"
197
+ textColor: "{colors.on-primary}"
198
+ typography: "{typography.body-md}"
199
+ rounded: "{rounded.lg}"
200
+ padding: 6px 12px
201
+ badge-pill-outline:
202
+ backgroundColor: "{colors.canvas}"
203
+ textColor: "{colors.ink}"
204
+ typography: "{typography.body-md}"
205
+ rounded: "{rounded.lg}"
206
+ padding: 6px 12px
207
+ badge-sale-coral:
208
+ backgroundColor: "{colors.bloom-coral}"
209
+ textColor: "{colors.on-primary}"
210
+ typography: "{typography.caption-bold}"
211
+ rounded: "{rounded.sm}"
212
+ padding: 4px 8px
213
+ text-input:
214
+ backgroundColor: "{colors.canvas}"
215
+ textColor: "{colors.ink}"
216
+ typography: "{typography.body-md}"
217
+ rounded: "{rounded.md}"
218
+ padding: 12px 16px
219
+ height: 44px
220
+ text-input-focused:
221
+ backgroundColor: "{colors.canvas}"
222
+ textColor: "{colors.ink}"
223
+ text-input-search:
224
+ backgroundColor: "{colors.canvas}"
225
+ textColor: "{colors.ink}"
226
+ typography: "{typography.body-md}"
227
+ rounded: "{rounded.md}"
228
+ padding: 12px 16px
229
+ height: 40px
230
+ card-product:
231
+ backgroundColor: "{colors.canvas}"
232
+ textColor: "{colors.ink}"
233
+ rounded: "{rounded.xl}"
234
+ padding: 24px
235
+ card-product-feature:
236
+ backgroundColor: "{colors.cloud}"
237
+ textColor: "{colors.ink}"
238
+ rounded: "{rounded.xl}"
239
+ padding: 32px
240
+ card-pricing-tier:
241
+ backgroundColor: "{colors.canvas}"
242
+ textColor: "{colors.ink}"
243
+ rounded: "{rounded.xl}"
244
+ padding: 24px
245
+ card-pricing-tier-featured:
246
+ backgroundColor: "{colors.canvas}"
247
+ textColor: "{colors.ink}"
248
+ rounded: "{rounded.xl}"
249
+ padding: 24px
250
+ card-customer-story:
251
+ backgroundColor: "{colors.canvas}"
252
+ textColor: "{colors.ink}"
253
+ rounded: "{rounded.xl}"
254
+ padding: 16px
255
+ card-article-tile:
256
+ backgroundColor: "{colors.canvas}"
257
+ textColor: "{colors.ink}"
258
+ rounded: "{rounded.xl}"
259
+ padding: 16px
260
+ card-category-icon:
261
+ backgroundColor: "{colors.canvas}"
262
+ textColor: "{colors.ink}"
263
+ typography: "{typography.body-emphasis}"
264
+ rounded: "{rounded.lg}"
265
+ padding: 16px
266
+ promo-strip-dark:
267
+ backgroundColor: "{colors.ink}"
268
+ textColor: "{colors.on-primary}"
269
+ typography: "{typography.body-md}"
270
+ rounded: "{rounded.xl}"
271
+ padding: 48px
272
+ hero-promo-card:
273
+ backgroundColor: "{colors.canvas}"
274
+ textColor: "{colors.ink}"
275
+ rounded: "{rounded.xl}"
276
+ padding: 32px
277
+ utility-strip:
278
+ backgroundColor: "{colors.ink}"
279
+ textColor: "{colors.on-primary}"
280
+ typography: "{typography.caption-md}"
281
+ height: 36px
282
+ padding: 0 24px
283
+ nav-bar-top:
284
+ backgroundColor: "{colors.canvas}"
285
+ textColor: "{colors.ink}"
286
+ typography: "{typography.body-md}"
287
+ height: 64px
288
+ padding: 0 32px
289
+ nav-link:
290
+ backgroundColor: "{colors.canvas}"
291
+ textColor: "{colors.ink}"
292
+ typography: "{typography.body-md}"
293
+ padding: 8px 16px
294
+ category-tab:
295
+ backgroundColor: "{colors.canvas}"
296
+ textColor: "{colors.ink}"
297
+ typography: "{typography.body-emphasis}"
298
+ rounded: "{rounded.pill}"
299
+ padding: 8px 20px
300
+ category-tab-active:
301
+ backgroundColor: "{colors.ink}"
302
+ textColor: "{colors.on-primary}"
303
+ rounded: "{rounded.pill}"
304
+ faq-row:
305
+ backgroundColor: "{colors.canvas}"
306
+ textColor: "{colors.ink}"
307
+ typography: "{typography.body-emphasis}"
308
+ rounded: "{rounded.lg}"
309
+ padding: 20px 24px
310
+ chevron-decoration:
311
+ backgroundColor: "{colors.primary}"
312
+ textColor: "{colors.on-primary}"
313
+ rounded: "{rounded.none}"
314
+ help-band-dark:
315
+ backgroundColor: "{colors.ink}"
316
+ textColor: "{colors.on-primary}"
317
+ typography: "{typography.body-md}"
318
+ padding: 64px 32px
319
+ footer-dark:
320
+ backgroundColor: "{colors.ink}"
321
+ textColor: "{colors.on-primary}"
322
+ typography: "{typography.body-md}"
323
+ padding: 64px 32px
324
+ ---
325
+
326
+ ## Overview
327
+
328
+ HP reads like a long-running consumer-electronics catalog crossed with an enterprise-software product page. The whole system sits on **pure white** (`{colors.canvas}` — `#ffffff`) with thin gray panels (`{colors.cloud}` / `{colors.fog}`) for alternating section bands. There is one chromatic action color — **HP Electric Blue** (`{colors.primary}` — `#024ad8`) — and one ink color (`{colors.ink}` — `#1a1a1a`); together they do ninety percent of the work. Type is a single family across every surface: **Forma DJR Micro**, HP's bespoke geometric grotesque, set at weight 500 for headlines and 400 for body — clean, neutral, slightly mechanical.
329
+
330
+ The signature gesture is **angular blue chevrons** — sharp 0-radius slashes derived from the HP wordmark's pair of parallel slashes — that anchor the homepage hero, the laptop-page hero, and the printer pricing page. They appear on the left and right edges of the primary banner card, layered behind product photography. Outside those decorative slashes, every other surface is rectilinear with **soft 8–16px corners** on cards and a 4px corner on buttons.
331
+
332
+ The system breaks into three voice modes: a **white commercial body** for product browsing (cards, category icons, pricing tiers); a **dark navy slab** (`{colors.ink}` near-black) for testimonial bands, the closing "How can we help?" footer-prelude, and the page footer; and a **light fog band** (`{colors.cloud}` / `{colors.fog}`) for utility sections like comparison strips and FAQ accordions. The blue accent appears only on filled CTAs, link text, the chevron decorations, and the active price-stamp on a featured tier — never as a section background.
333
+
334
+ **Key Characteristics:**
335
+ - Pure white canvas (`{colors.canvas}`) with deep ink (`{colors.ink}`) running every body surface; light fog bands (`{colors.cloud}`, `{colors.fog}`) alternate for section rhythm
336
+ - HP Electric Blue (`{colors.primary}`) is the lone CTA fill and link color; it appears at most twice per viewport
337
+ - Bespoke Forma DJR Micro across every surface — display, body, button, caption — at weights 400 / 500 / 600 / 700
338
+ - Cards round at `{rounded.xl}` (16px) for product/pricing tiles; buttons sit at `{rounded.md}` (4px) with capitalize labels
339
+ - Geometric blue chevrons (`{colors.primary}` rectangles cut at 45°) frame hero photography and reinforce the wordmark
340
+ - Dark-navy slabs (`{colors.ink}`) close every page rhythm — testimonial bands, "how can we help?" prelude, and the footer
341
+ - Section rhythm: utility-strip → top nav → white body → cloud-band → ink slab → cloud-band → ink footer
342
+
343
+ ## Colors
344
+
345
+ > **No Interaction sub-section.** Hover colors are silently filtered. Allowed sub-sections: Brand & Accent, Surface, Text, Semantic.
346
+
347
+ ### Brand & Accent
348
+ - **HP Electric Blue** (`{colors.primary}` — `#024ad8`): the system's lone signal — primary CTA fill, link color, chevron-decoration fill, active sub-nav indicator. Reserved.
349
+ - **Bright Blue** (`{colors.primary-bright}` — `#296ef9`): a slightly lighter variant used inside dark slabs (testimonial-card buttons, dark-band CTA links) where the deeper blue would muddy.
350
+ - **Deep Navy** (`{colors.primary-deep}` — `#0e3191`): pressed state for the primary CTA and the visited-link color.
351
+ - **Soft Blue** (`{colors.primary-soft}` — `#c9e0fc`): pale-blue surface used inside customer-story cards and selection chips.
352
+
353
+ ### Surface
354
+ - **Canvas** (`{colors.canvas}` — `#ffffff`): the universal page background. White, full opacity.
355
+ - **Paper** (`{colors.paper}` — `#ffffff`): card surfaces — same white as canvas, with hairline borders or shadows providing the lift.
356
+ - **Cloud** (`{colors.cloud}` — `#f7f7f7`): the lightest gray section band, used for alternating-row backgrounds and product-feature card groups.
357
+ - **Fog** (`{colors.fog}` — `#e8e8e8`): a slightly darker gray surface band, used for FAQ outer panels and the "Trending laptops" header strip.
358
+ - **Steel** (`{colors.steel}` — `#c2c2c2`): hairline border used on outlined elements with stronger emphasis (focus states, active filter).
359
+ - **Bloom Coral / Bloom Rose** (`{colors.bloom-coral}` / `{colors.bloom-rose}` — `#ff5050`, `#f9d4d2`): the "Get 25% off" sale-tag chip + soft pink lifestyle accent on the sale hero.
360
+ - **Storm Mist / Sea / Deep** (`{colors.storm-mist}`, `{colors.storm-sea}`, `{colors.storm-deep}` — `#8ebdce`, `#7fadbe`, `#356373`): the teal-storm tones reserved for the printer-plan illustration backdrop and supporting infographic accents.
361
+
362
+ ### Text
363
+ - **Ink** (`{colors.ink}` — `#1a1a1a`): the universal text color on white surfaces — headlines, body, button labels, navigation.
364
+ - **Ink Deep** (`{colors.ink-deep}` — `#000000`): pure black used for the wordmark and 1px hairline strokes around badge outlines.
365
+ - **Ink Soft** (`{colors.ink-soft}` — `#292929`): an alternate near-black used inside dark-navy slabs as a subtle textural shift.
366
+ - **On Ink** (`{colors.on-ink}` — `#ffffff`): pure white used for headline and body text on every dark-navy slab.
367
+ - **Charcoal** (`{colors.charcoal}` — `#3d3d3d`): muted body color on white surfaces — secondary descriptions, fine-print disclaimers.
368
+ - **Graphite** (`{colors.graphite}` — `#636363`): smaller-print color, used for legal lines and timestamp metadata.
369
+
370
+ ### Semantic
371
+ - **Bloom Deep** (`{colors.bloom-deep}` — `#b3262b`) + **Bloom Wine** (`{colors.bloom-wine}` — `#5a1313`): error and discount-emphasis colors. The deep brick reads as "sale" or "destructive" depending on placement.
372
+ - **Storm Deep** (`{colors.storm-deep}` — `#356373`): used as a neutral status accent (e.g., printer-plan tier "Versatile" tier color).
373
+
374
+ ## Typography
375
+
376
+ ### Font Family
377
+
378
+ The voice is **single-family**: Forma DJR Micro (HP's bespoke geometric grotesque, fallback Arial) across every surface — display, body, button, caption. Forma DJR Micro is a wide, slightly rounded grotesque designed at small optical sizes to stay legible at UI-chrome scale. HP runs it at weight 400 for body, 500 for display headlines, 600/700 for emphasis and button labels.
379
+
380
+ The 16/14/12-px caption tier carries the catalog metadata — model numbers, spec rows, fine print — at weight 400 with a 1.4–1.5 line-height. Button labels lift to weight 600/700 with positive 0.5–1.1px letter-spacing and uppercase transform — the only place the system tracks letters.
381
+
382
+ ### Hierarchy
383
+
384
+ | Token | Size | Weight | Line Height | Letter Spacing | Use |
385
+ |---|---|---|---|---|---|
386
+ | `{typography.display-xxl}` | 72px | 500 | 1.0 | 0 | Hero headline (homepage, laptop hub) |
387
+ | `{typography.display-xl}` | 56px | 500 | 1.0 | 0 | Section headlines on landing pages |
388
+ | `{typography.display-lg}` | 44px | 500 | 1.0 | 0 | Sub-section headlines on shop pages |
389
+ | `{typography.display-md}` | 32px | 500 | 1.0 | 0 | Promo strip headlines, FAQ section headers |
390
+ | `{typography.display-sm}` | 24px | 500 | 1.17 | 0 | Card titles, pricing-tier names |
391
+ | `{typography.display-xs}` | 20px | 500 | 1.0 | 0 | Inline list headers, accordion labels |
392
+ | `{typography.body-lg}` | 18px | 400 | 1.33 | 0 | Lead paragraphs |
393
+ | `{typography.body-md}` | 16px | 400 | 1.38 | 0 | Default body |
394
+ | `{typography.body-emphasis}` | 16px | 500 | 1.38 | 0 | Bolded run-in copy |
395
+ | `{typography.caption-md}` | 14px | 400 | 1.5 | 0 | Specs, metadata, captions |
396
+ | `{typography.caption-bold}` | 14px | 700 | 1.3 | 0 | Sale tags, in-card highlights |
397
+ | `{typography.caption-sm}` | 12px | 400 | 1.33 | 0 | Footnotes, legal lines |
398
+ | `{typography.link-md}` | 16px | 500 | 1.38 | 0 | Inline link emphasis |
399
+ | `{typography.button-md}` | 14px | 600 | 1.4 | 0.7px | Primary/secondary button labels (uppercase) |
400
+ | `{typography.button-sm}` | 12.6px | 700 | 1.0 | 0.126px | Compact button labels in tight cells |
401
+ | `{typography.price-md}` | 24px | 500 | 1.17 | 0 | Tier and product price stamps |
402
+
403
+ ### Principles
404
+
405
+ The typographic decision worth flagging: HP runs **weight 500 for every display size**, including the largest 72px hero headline. Most editorial systems jump to 600/700 at hero scale; HP doesn't. The result feels open and approachable rather than commanding — appropriate for a brand that sells across consumer, SMB, and enterprise audiences in the same catalog.
406
+
407
+ Forma DJR Micro's rounded-grotesque shapes do most of the warmth. There's no italic in the system except inside legal disclaimers; emphasis is carried by weight (500 → body-emphasis, 700 → caption-bold) instead.
408
+
409
+ ### Note on Font Substitutes
410
+
411
+ Forma DJR Micro is proprietary (Commercial Type / Mark Caneso). Closest open-source substitutes:
412
+ - **Inter** at weights 400 / 500 / 600 / 700 — slightly narrower than Forma DJR Micro; bump font-size by ~3% to compensate
413
+ - **Manrope** at weights 400 / 500 / 600 / 700 — closer in proportion, gentler curves; use directly with no metric adjustment
414
+ - **Roboto** at weights 400 / 500 / 700 — flatter character; use as last-resort fallback
415
+
416
+ When swapping, set body line-height to 1.4 and display line-height to 1.0 explicitly — the Forma DJR Micro line-height numbers are tight, and most substitutes default looser.
417
+
418
+ ## Layout
419
+
420
+ ### Spacing System
421
+
422
+ - **Base unit**: 8px. Smaller half-step at 4px. The scale is gentle — most card padding lands at 16px or 24px; section gap at 80px.
423
+ - **Tokens (front matter)**: `{spacing.xxs}` 4px · `{spacing.xs}` 8px · `{spacing.sm}` 12px · `{spacing.md}` 16px · `{spacing.lg}` 20px · `{spacing.xl}` 24px · `{spacing.xxl}` 32px · `{spacing.section}` 80px
424
+ - **Section padding**: `{spacing.section}` (80px) vertical between major bands on desktop; collapses to ~48px on mobile.
425
+ - **Card internal padding**: `{spacing.xl}` (24px) for product cards; `{spacing.xxl}` (32px) for promo strips and feature cards; `{spacing.md}` (16px) for compact article tiles.
426
+ - **Gutter**: `{spacing.xl}` (24px) between grid columns at desktop; `{spacing.md}` (16px) on tablet/mobile.
427
+
428
+ The 80px section gap is the universal rhythm constant — it appears between every major homepage band, between the hero and the comparison table on the printer-plan page, and between feature rows on the laptop-shop page.
429
+
430
+ ### Grid & Container
431
+
432
+ - **Desktop max-width**: 1366px content container with full-bleed-on-canvas section backgrounds.
433
+ - **Hero**: a single full-width photo card (homepage and laptop-hub hero) with the headline overlay positioned upper-left or upper-right.
434
+ - **Product family grid**: 4 columns at >1200px, 3 at 1024–1199px, 2 at 768–1023px, 1 below 768px.
435
+ - **Pricing tiers**: 4 columns at >1024px, 2x2 grid at 768–1023px, single-column accordion below 768px.
436
+ - **Footer**: 5-column link grid at >1024px, collapsing to 2-column then accordion on mobile.
437
+
438
+ ### Whitespace Philosophy
439
+
440
+ Whitespace is **commercial-clean** — generous around hero photography, tight around catalog spec rows. Product cards leave breathing room above and below the photo (≥32px) so the laptop or printer reads as a hero shot rather than a thumbnail. The fine-print disclaimer regions (legal, footnote rows) tighten line-height to 1.3 and shrink type to 11–12px so the bulk of fine print stays compact.
441
+
442
+ ## Elevation & Depth
443
+
444
+ | Level | Treatment | Use |
445
+ |---|---|---|
446
+ | 0 — Flat | No border, no shadow. | Section bands (white, cloud, fog), full-bleed photo heroes |
447
+ | 1 — Hairline | 1px solid `{colors.hairline}` (`#e8e8e8`) border, no shadow. | Outlined buttons, comparison-table cells, FAQ accordion outers |
448
+ | 2 — Soft Lift | `0 2px 8px rgba(26, 26, 26, 0.08)`. | Product cards, pricing-tier columns, customer-story tiles |
449
+ | 3 — Floating Modal | `0 8px 24px rgba(26, 26, 26, 0.12)`. | Add-to-cart drawer, mobile-nav sheet, image zoom modal |
450
+
451
+ The system is mostly flat — depth is communicated by **color contrast** (cloud-band vs. white card on the same band) rather than shadow elevation. The Soft Lift level is the workhorse for the catalog — every product tile and pricing column gets it; nothing else does. Modal-floating is rare and reserved for transient overlays.
452
+
453
+ ### Decorative Depth
454
+
455
+ The system's most distinctive depth gesture is the **HP blue chevron pair** — two angular `{colors.primary}` slashes (no radius, no shadow) that sit on the left and right of the homepage hero card and the laptop-shop hero. They're not decorative noise; they're a literal echo of the HP wordmark's two parallel slashes, scaled up to architectural size. Treat them as a brand artifact, not a generic geometric flourish.
456
+
457
+ Photography on the homepage and laptop-shop pages frames product imagery inside `{rounded.xl}` (16px) containers with a soft 1px hairline. Lifestyle photography (testimonials, "How HP works for X") sits full-bleed inside dark-navy slabs without rounding.
458
+
459
+ ## Shapes
460
+
461
+ ### Border Radius Scale
462
+
463
+ | Token | Value | Use |
464
+ |---|---|---|
465
+ | `{rounded.none}` | 0px | Hero chevron decorations, full-bleed photo heroes, marquee strips |
466
+ | `{rounded.xs}` | 2px | Secondary chip backgrounds, sale-tag pills |
467
+ | `{rounded.sm}` | 3px | Default secondary CTA radius (small touch zones) |
468
+ | `{rounded.md}` | 4px | Primary buttons, secondary buttons, text inputs |
469
+ | `{rounded.lg}` | 8px | Badge pills, category-icon cards, FAQ row containers |
470
+ | `{rounded.xl}` | 16px | Product cards, pricing tiers, customer-story tiles, photo frames |
471
+ | `{rounded.pill}` | 9999px | Category sub-nav tabs, search-pill input, filter chips |
472
+
473
+ The system maintains a clear two-tier philosophy: **buttons stay sharp** (4px, almost rectilinear) while **cards and photo frames stay soft** (16px). This split is the visual signature — sharp interactive elements against softer container surfaces.
474
+
475
+ ### Photography Geometry
476
+
477
+ Hero photography sits in `{rounded.xl}` (16px) frames with no border. Product family thumbnails inside the laptop-grid are 1:1 (square) on a `{colors.canvas}` background, padded so the laptop is shown at ~70% of the frame. Customer-story photography uses 16:9 inside the same `{rounded.xl}` frame. There are no full-bleed circular avatars; testimonial avatars are 4px-rounded squares.
478
+
479
+ ## Components
480
+
481
+ > **No hover states documented.** Every component spec below documents only Default and Active/Pressed states. Variants live as separate front-matter entries.
482
+
483
+ ### Buttons
484
+
485
+ **`button-primary`** — the lone HP Electric Blue CTA
486
+ - Background `{colors.primary}`, text `{colors.on-primary}`, type `{typography.button-md}` (uppercase, 0.7px tracking), padding `{spacing.sm} {spacing.xl}` (12 × 24), height 44px, rounded `{rounded.md}`
487
+ - Pressed state `button-primary-pressed` — background `{colors.primary-deep}`, same text
488
+ - Disabled state `button-primary-disabled` — background `{colors.steel}`, white text
489
+ - Used for: "Buy now", "Shop now", "Get a printer", primary form submit
490
+
491
+ **`button-ink`** — black filled CTA
492
+ - Background `{colors.ink}`, text `{colors.on-primary}`, padding `{spacing.sm} {spacing.xl}`, height 44px, rounded `{rounded.md}`, type `{typography.button-md}`
493
+ - Used for: "Buy now" on dark photo overlays, secondary primary actions where the blue would clash with imagery
494
+
495
+ **`button-outline`** — blue-text outlined CTA
496
+ - Background `{colors.canvas}`, text `{colors.primary}`, 1px `{colors.primary}` border, padding `{spacing.sm} {spacing.xl}`, height 44px, rounded `{rounded.md}`
497
+ - Used for: "Compare", "Customize", "Learn more" — secondary actions on white surfaces
498
+
499
+ **`button-outline-ink`** — black-text outlined CTA
500
+ - Background `{colors.canvas}`, text `{colors.ink}`, 1px `{colors.ink}` border, padding `{spacing.sm} {spacing.xl}`, height 44px, rounded `{rounded.md}`
501
+ - Used for: "View" buttons inside product family card grids — neutral against the blue primary
502
+
503
+ **`button-text-link`** — inline blue link with underline
504
+ - Background `{colors.canvas}`, text `{colors.primary}`, type `{typography.link-md}`, padding `{spacing.xxs} 0`
505
+ - Used for: "See details", "Read more" inside cards and disclaimer rows
506
+
507
+ ### Cards & Containers
508
+
509
+ **`card-product`** — the workhorse product tile
510
+ - Background `{colors.canvas}`, rounded `{rounded.xl}` (16px), padding `{spacing.xl}` (24px), Soft Lift shadow
511
+ - Layout: hero photo (1:1 ratio) on top, title in `{typography.display-xs}`, spec rows in `{typography.caption-md}`, price in `{typography.price-md}`, CTA pinned to bottom
512
+ - Used for: laptop catalog cards, desktop catalog cards
513
+
514
+ **`card-product-feature`** — full-row feature card with photo + copy
515
+ - Background `{colors.cloud}`, rounded `{rounded.xl}`, padding `{spacing.xxl}` (32px)
516
+ - Layout: photo on the left (50% width), copy on the right with section eyebrow + title + body + CTA pair
517
+ - Used for: "Trending laptops" feature rows, "Shop these must haves"
518
+
519
+ **`card-pricing-tier`** + **`card-pricing-tier-featured`**
520
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.xl}`, Soft Lift shadow
521
+ - Tier name in `{typography.display-sm}`, monthly price in `{typography.display-md}` with `{typography.caption-md}` cadence, page count caption, full feature list, primary CTA
522
+ - Featured tier carries `{colors.primary}` text accent on the price-stamp + a `{colors.primary}` thin top border instead of a colored card background — never inverted to dark
523
+
524
+ **`card-customer-story`** — the three-up testimonial tile
525
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.md}` (16px), Soft Lift shadow
526
+ - 16:9 photo at top in `{rounded.xl}` frame, quote excerpt in `{typography.body-md}`, attribution row at the bottom
527
+ - Used in the "See what our customers say" homepage section
528
+
529
+ **`card-article-tile`** — the four-up "Latest from HP" tile
530
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.md}`, Soft Lift shadow
531
+ - 16:9 thumbnail at top, date eyebrow in `{typography.caption-sm}`, title in `{typography.body-emphasis}`, "Read more" link
532
+
533
+ **`card-category-icon`** — the small icon-and-label card in the homepage "Our Products" row
534
+ - Background `{colors.canvas}`, rounded `{rounded.lg}` (8px), padding `{spacing.md}`
535
+ - 48px icon at top, label in `{typography.body-emphasis}` below
536
+ - Used for: Laptops, Desktops, Printers, Computer Tools, Accessories, Enterprise Solutions
537
+
538
+ **`hero-promo-card`** — the homepage hero card with chevron decorations
539
+ - Background `{colors.canvas}`, rounded `{rounded.xl}`, padding `{spacing.xxl}` (32px)
540
+ - Photography occupies left half; copy block (eyebrow + headline + price stamp + CTA pair) occupies right half
541
+ - Flanked by `chevron-decoration` blue slashes outside the card's bounding box on left and right edges
542
+
543
+ **`promo-strip-dark`** — the inline dark navy promo block
544
+ - Background `{colors.ink}`, text `{colors.on-ink}`, rounded `{rounded.xl}`, padding `{spacing.xxl} 48px`
545
+ - Used for: "When did work start getting in the way of work?" mid-page promo, the SMB testimonial slab
546
+
547
+ ### Inputs & Forms
548
+
549
+ **`text-input`** + **`text-input-focused`**
550
+ - Background `{colors.canvas}`, text `{colors.ink}`, rounded `{rounded.md}`, padding `{spacing.sm} {spacing.md}`, height 44px
551
+ - 1px `{colors.steel}` border in default; gains 1px `{colors.ink}` border on focus (no halo)
552
+
553
+ **`text-input-search`** — pill search in the top nav
554
+ - Background `{colors.canvas}`, rounded `{rounded.md}`, padding `{spacing.sm} {spacing.md}`, height 40px, 1px `{colors.steel}` border, magnifying-glass icon at right
555
+
556
+ **`badge-pill-ink`** — filled tag pill
557
+ - Background `{colors.ink}`, text `{colors.on-primary}`, rounded `{rounded.lg}`, padding 6px 12px, type `{typography.body-md}`
558
+ - Used inline next to product titles to mark "New" or featured indicators
559
+
560
+ **`badge-pill-outline`** — outlined tag pill
561
+ - Background `{colors.canvas}`, text `{colors.ink}`, 1px `{colors.ink}` border, rounded `{rounded.lg}`, padding 6px 12px
562
+
563
+ **`badge-sale-coral`** — the sale price-stamp
564
+ - Background `{colors.bloom-coral}`, text `{colors.on-primary}`, rounded `{rounded.sm}`, padding `{spacing.xxs} {spacing.xs}`, type `{typography.caption-bold}`
565
+ - Used for: "Save $200", "25% off" overlay tags on hero promo cards
566
+
567
+ ### Navigation
568
+
569
+ **`utility-strip`** — the top-of-page utility bar
570
+ - Background `{colors.ink}`, text `{colors.on-primary}`, height 36px, padding 0 {spacing.xl}, type `{typography.caption-md}`
571
+ - Holds: country/locale picker, "For Business / For Home" toggle, "Sign in" link, cart link
572
+
573
+ **`nav-bar-top`** — desktop top nav (sits below utility strip)
574
+ - Background `{colors.canvas}`, height 64px, padding 0 32px
575
+ - Layout: HP wordmark logo flush left → middle category list (Laptops / Desktops / Printers / Accessories / Solutions / Support) → right slot with Search field, Sign-in link, Cart icon
576
+ - 1px `{colors.hairline}` bottom border separates nav from page
577
+
578
+ **`nav-link`**
579
+ - Background `{colors.canvas}`, text `{colors.ink}`, type `{typography.body-md}`, padding `{spacing.xs} {spacing.md}`
580
+ - Active page draws a 2px `{colors.primary}` underline below the text baseline
581
+
582
+ **Top Nav (Mobile)**
583
+ - Same height, hamburger icon replaces the middle category list, Search and Cart stay visible
584
+ - Drawer expands as a full-canvas sheet with `{typography.body-lg}` link list and a sticky Sign-in CTA at bottom
585
+
586
+ **`category-tab`** + **`category-tab-active`** — the pill sub-nav
587
+ - Default: background `{colors.canvas}`, text `{colors.ink}`, type `{typography.body-emphasis}`, rounded `{rounded.pill}`, padding `{spacing.xs} {spacing.lg}`
588
+ - Active: background `{colors.ink}`, text `{colors.on-primary}`, same rounding
589
+ - Used on the laptop-shop page for "All / Trending / On Sale" filtering, and on the homepage "How can we help?" closing band
590
+
591
+ ### Signature Components
592
+
593
+ **`chevron-decoration`** — the geometric blue slash motif
594
+ - Background `{colors.primary}`, rounded `{rounded.none}`, no shadow
595
+ - Renders as a sharp parallelogram cut at ~60° angle, sized to the height of the hero card it flanks
596
+ - Reserved for hero bands and full-page banners — never decorative noise inside cards
597
+
598
+ **`faq-row`** — the accordion row on the printer-plan FAQ
599
+ - Background `{colors.canvas}`, rounded `{rounded.lg}`, padding `{spacing.lg} {spacing.xl}`, type `{typography.body-emphasis}`
600
+ - 1px `{colors.hairline}` divider between rows; chevron-down icon on the right collapsed, chevron-up when expanded
601
+ - Body answer renders inside the same row container in `{typography.body-md}` after expansion
602
+
603
+ **`help-band-dark`** — the closing "How can we help?" prelude band
604
+ - Background `{colors.ink}`, text `{colors.on-primary}`, padding 64px {spacing.xl}
605
+ - Layout: large lifestyle photograph as the band background (low-opacity) with chip-style category tabs centered: Browse Topics / Live Chat / Contact / Diagnose / Order Status
606
+
607
+ **`footer-dark`**
608
+ - Background `{colors.ink}`, text `{colors.on-primary}`, type `{typography.body-md}`, padding 64px {spacing.xl}
609
+ - 5-column link grid (Company / Shop / Support / Resources / Connect) with `{typography.body-emphasis}` headers and `{typography.caption-md}` link rows
610
+ - Bottom strip carries social icons, language picker, and legal lines in `{typography.caption-sm}` muted to `{colors.steel}`
611
+
612
+ ## Do's and Don'ts
613
+
614
+ ### Do
615
+ - Reserve `{colors.primary}` for the primary CTA, link color, and `chevron-decoration` motif — at most twice per viewport
616
+ - Set every headline in Forma DJR Micro at weight 500 with line-height 1.0 — resist the urge to bump weight at hero scale
617
+ - Use `{rounded.xl}` (16px) for cards and photo frames; `{rounded.md}` (4px) for buttons and inputs — keep the two-tier split sharp
618
+ - Pair white `{colors.canvas}` body bands with `{colors.cloud}` (`#f7f7f7`) alternating bands; let the gray do the breathing
619
+ - Close every page rhythm with a dark-navy `{colors.ink}` slab — the "How can we help?" prelude + footer
620
+ - Set button labels in uppercase with `{typography.button-md}` (0.7px tracking) — the only place the system tracks letters
621
+ - Use Soft Lift shadow exclusively for product cards and pricing tiers — leave section bands flat
622
+ - Frame product photography inside `{rounded.xl}` containers; never use full-bleed circular masks
623
+
624
+ ### Don't
625
+ - Don't introduce secondary saturated colors outside `{colors.primary}` family + the `bloom-coral` sale-tag and `storm` printer-plan accents
626
+ - Don't apply heavy material shadows — depth is via color contrast (cloud vs. white) and Soft Lift only
627
+ - Don't round buttons above `{rounded.md}` (4px); a soft 8px+ button reads as a different brand
628
+ - Don't run Forma DJR Micro below 12px — small caption at 11px is the floor
629
+ - Don't use the chevron decoration as inline noise; it is a hero-only architectural element tied to the wordmark
630
+ - Don't drop ink text opacity to create hierarchy — switch surface or shift to `{colors.charcoal}` / `{colors.graphite}` instead
631
+ - Don't replace the HP wordmark with a generic sans lockup; the wordmark is a custom mark with its own ratio
632
+
633
+ ## Responsive Behavior
634
+
635
+ ### Breakpoints
636
+
637
+ | Name | Width | Key Changes |
638
+ |---|---|---|
639
+ | Mobile | < 480px | Single-column stack; hamburger nav; section padding drops to ~48px; hero serif scales to ~36px |
640
+ | Mobile-Large | 480–767px | Same column count; hero scales to ~44px; pricing tiers stack vertically |
641
+ | Tablet | 768–1023px | 2-column product grid; pricing 2x2; nav still full text labels |
642
+ | Desktop | 1024–1279px | 3-column product grid; 4-column pricing; full nav |
643
+ | Desktop-Large | ≥ 1280px | 4-column product grid; 1366px content max-width with full-bleed bands |
644
+
645
+ ### Touch Targets
646
+
647
+ Every interactive element clears 44×44px on mobile. `button-primary` at 44px height + 24px horizontal padding meets WCAG-AAA touch target. `category-tab` at 8px 20px padding bumps to 12px 24px on touch screens. Nav-link tap areas extend invisibly beyond the text run to the full 44px row height. Sticky cart/sign-in icons in the top nav use 44×44 invisible hit boxes around their visible 24×24 glyph.
648
+
649
+ ### Collapsing Strategy
650
+
651
+ - **Utility strip**: stays visible on every breakpoint; dropdowns collapse into a single "Account" icon below 768px
652
+ - **Top nav**: middle category list collapses into a hamburger drawer below 1024px; the right-side Search + Sign-in + Cart stay visible
653
+ - **Hero**: stays single-column at every breakpoint; chevron decorations shrink to ~60% size on tablet and disappear entirely on mobile
654
+ - **Product family grid**: 4 → 3 → 2 → 1 column as breakpoints shrink; cards keep `{rounded.xl}` corners at every size
655
+ - **Pricing comparison table**: 4-column grid on desktop collapses to 2x2 on tablet, then stacks into individual accordion-style cards on mobile
656
+ - **Footer**: 5-column link grid → 2-column tablet → single-column accordion on mobile; HP wordmark stays flush left
657
+
658
+ ### Image Behavior
659
+
660
+ Hero photography uses `{rounded.xl}` containers at every breakpoint. The chevron decorations vanish on mobile; the underlying photo card centers in the viewport. Lifestyle photography in the testimonial and "how-can-we-help" bands maintains 16:9 ratio with horizontal cropping rather than letterboxing on mobile. There are no art-direction crop swaps between desktop and mobile — the same image is used at every size.
661
+
662
+ ## Iteration Guide
663
+
664
+ 1. Focus on ONE component at a time; resist refactoring an entire section in one pass
665
+ 2. Reference component names and tokens directly (`{colors.primary}`, `{typography.display-xxl}`, `{rounded.xl}`, `card-product`) — do not paraphrase to hex/px in prose
666
+ 3. Run `npx @google/design.md lint DESIGN.md` after edits — `broken-ref`, `contrast-ratio`, and `orphaned-tokens` warnings flag issues automatically
667
+ 4. Add new variants as separate component entries (`-pressed`, `-disabled`, `-focused`); never bury state inside prose
668
+ 5. Default body to `{typography.body-md}`; reach for `{typography.body-emphasis}` for run-in bolds; keep display sizes for true heading roles
669
+ 6. Keep `{colors.primary}` scarce — at most two flame elements per viewport (one CTA + one chevron decoration). Three flame items in one viewport is over-saturation
670
+ 7. When introducing a new section band, choose from `{colors.canvas}` / `{colors.cloud}` / `{colors.fog}` / `{colors.ink}` — six pre-defined surface modes is the entire surface vocabulary