howone 0.1.20 → 0.1.23

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 (298) hide show
  1. package/package.json +1 -1
  2. package/templates/nextjs/lib/sdk.ts +3 -0
  3. package/templates/vite/.howone/skills/hallmark/LICENSE +21 -0
  4. package/templates/vite/.howone/skills/hallmark/README.md +147 -0
  5. package/templates/vite/.howone/skills/hallmark/ROADMAP.md +201 -0
  6. package/templates/vite/.howone/skills/hallmark/SKILL.md +551 -0
  7. package/templates/vite/.howone/skills/hallmark/docs/recipes.md +186 -0
  8. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-anya.jpg +0 -0
  9. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-bananastudio.jpg +0 -0
  10. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-hyperlane.jpg +0 -0
  11. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-najm.jpg +0 -0
  12. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-slow-pour.jpg +0 -0
  13. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-soroe.jpg +0 -0
  14. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-tally.jpg +0 -0
  15. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-wayfare.jpg +0 -0
  16. package/templates/vite/.howone/skills/hallmark/docs/study-examples.md +176 -0
  17. package/templates/vite/.howone/skills/hallmark/docs/talk-slides.md +364 -0
  18. package/templates/vite/.howone/skills/hallmark/package.json +36 -0
  19. package/templates/vite/.howone/skills/hallmark/references/anti-patterns.md +412 -0
  20. package/templates/vite/.howone/skills/hallmark/references/assets.md +399 -0
  21. package/templates/vite/.howone/skills/hallmark/references/color.md +95 -0
  22. package/templates/vite/.howone/skills/hallmark/references/component-cookbook.md +256 -0
  23. package/templates/vite/.howone/skills/hallmark/references/components/c1-outlined-chip.md +12 -0
  24. package/templates/vite/.howone/skills/hallmark/references/components/c2-inline-form-as-cta.md +16 -0
  25. package/templates/vite/.howone/skills/hallmark/references/components/c3-typographic-link.md +8 -0
  26. package/templates/vite/.howone/skills/hallmark/references/components/c4-sticky-bottom-bar.md +16 -0
  27. package/templates/vite/.howone/skills/hallmark/references/components/f1-bento-grid.md +20 -0
  28. package/templates/vite/.howone/skills/hallmark/references/components/f2-sticky-scroll-stack.md +20 -0
  29. package/templates/vite/.howone/skills/hallmark/references/components/f3-tabular-spec-sheet.md +11 -0
  30. package/templates/vite/.howone/skills/hallmark/references/components/f4-step-sequence.md +11 -0
  31. package/templates/vite/.howone/skills/hallmark/references/components/f5-annotated-screenshot.md +11 -0
  32. package/templates/vite/.howone/skills/hallmark/references/components/f6-product-card-grid.md +41 -0
  33. package/templates/vite/.howone/skills/hallmark/references/components/ft1-mast-headed.md +13 -0
  34. package/templates/vite/.howone/skills/hallmark/references/components/ft2-inline-rule-single-line.md +10 -0
  35. package/templates/vite/.howone/skills/hallmark/references/components/ft3-index-style-category-list.md +12 -0
  36. package/templates/vite/.howone/skills/hallmark/references/components/ft4-dense-typographic.md +10 -0
  37. package/templates/vite/.howone/skills/hallmark/references/components/ft5-statement.md +21 -0
  38. package/templates/vite/.howone/skills/hallmark/references/components/ft6-letter-close.md +19 -0
  39. package/templates/vite/.howone/skills/hallmark/references/components/ft7-newsletter-first.md +27 -0
  40. package/templates/vite/.howone/skills/hallmark/references/components/ft8-marquee-scroll.md +25 -0
  41. package/templates/vite/.howone/skills/hallmark/references/components/h1-marquee.md +15 -0
  42. package/templates/vite/.howone/skills/hallmark/references/components/h2-split-diptych.md +15 -0
  43. package/templates/vite/.howone/skills/hallmark/references/components/h3-quote-led.md +11 -0
  44. package/templates/vite/.howone/skills/hallmark/references/components/h4-stat-led.md +14 -0
  45. package/templates/vite/.howone/skills/hallmark/references/components/h5-letter-hero.md +11 -0
  46. package/templates/vite/.howone/skills/hallmark/references/components/h6-photographic-fold.md +16 -0
  47. package/templates/vite/.howone/skills/hallmark/references/components/h7-demo-video-clipped-by-viewport-edge.md +27 -0
  48. package/templates/vite/.howone/skills/hallmark/references/components/h8-mockup-split-browser-framed.md +23 -0
  49. package/templates/vite/.howone/skills/hallmark/references/components/h9-custom-illustration-centerpiece.md +27 -0
  50. package/templates/vite/.howone/skills/hallmark/references/components/n1-wordmark-2-links.md +12 -0
  51. package/templates/vite/.howone/skills/hallmark/references/components/n10-floating-on-scroll-morph.md +19 -0
  52. package/templates/vite/.howone/skills/hallmark/references/components/n2-floating-chip.md +14 -0
  53. package/templates/vite/.howone/skills/hallmark/references/components/n3-side-rail.md +14 -0
  54. package/templates/vite/.howone/skills/hallmark/references/components/n4-hidden-behind-k.md +9 -0
  55. package/templates/vite/.howone/skills/hallmark/references/components/n5-floating-pill.md +28 -0
  56. package/templates/vite/.howone/skills/hallmark/references/components/n6-newspaper-masthead.md +24 -0
  57. package/templates/vite/.howone/skills/hallmark/references/components/n7-brutal-slab.md +22 -0
  58. package/templates/vite/.howone/skills/hallmark/references/components/n8-terminal-command.md +21 -0
  59. package/templates/vite/.howone/skills/hallmark/references/components/n9-edge-aligned-minimal.md +17 -0
  60. package/templates/vite/.howone/skills/hallmark/references/components/s1-left-margin-numbered.md +15 -0
  61. package/templates/vite/.howone/skills/hallmark/references/components/s2-hanging.md +13 -0
  62. package/templates/vite/.howone/skills/hallmark/references/components/s3-sticky-pinned.md +19 -0
  63. package/templates/vite/.howone/skills/hallmark/references/components/s4-inline-no-break.md +11 -0
  64. package/templates/vite/.howone/skills/hallmark/references/components/s5-bottom-anchored.md +13 -0
  65. package/templates/vite/.howone/skills/hallmark/references/components/t1-pull-quote-with-marginalia.md +12 -0
  66. package/templates/vite/.howone/skills/hallmark/references/components/t2-logo-wall-hairline.md +19 -0
  67. package/templates/vite/.howone/skills/hallmark/references/components/t3-single-huge-quote.md +11 -0
  68. package/templates/vite/.howone/skills/hallmark/references/components/t4-numbered-stat-strip.md +14 -0
  69. package/templates/vite/.howone/skills/hallmark/references/contract.md +24 -0
  70. package/templates/vite/.howone/skills/hallmark/references/copy.md +182 -0
  71. package/templates/vite/.howone/skills/hallmark/references/custom-craft.md +626 -0
  72. package/templates/vite/.howone/skills/hallmark/references/custom-theme.md +329 -0
  73. package/templates/vite/.howone/skills/hallmark/references/design-md.md +116 -0
  74. package/templates/vite/.howone/skills/hallmark/references/export-formats.md +328 -0
  75. package/templates/vite/.howone/skills/hallmark/references/floating-nav.md +89 -0
  76. package/templates/vite/.howone/skills/hallmark/references/genres/atmospheric.md +65 -0
  77. package/templates/vite/.howone/skills/hallmark/references/genres/editorial.md +70 -0
  78. package/templates/vite/.howone/skills/hallmark/references/genres/modern-minimal.md +67 -0
  79. package/templates/vite/.howone/skills/hallmark/references/genres/playful.md +65 -0
  80. package/templates/vite/.howone/skills/hallmark/references/hero-enrichment.md +474 -0
  81. package/templates/vite/.howone/skills/hallmark/references/imagery-kit.md +170 -0
  82. package/templates/vite/.howone/skills/hallmark/references/interaction-and-states.md +207 -0
  83. package/templates/vite/.howone/skills/hallmark/references/layout-and-space.md +111 -0
  84. package/templates/vite/.howone/skills/hallmark/references/macrostructures/01-bento-grid.md +35 -0
  85. package/templates/vite/.howone/skills/hallmark/references/macrostructures/02-long-document.md +34 -0
  86. package/templates/vite/.howone/skills/hallmark/references/macrostructures/03-marquee-hero.md +31 -0
  87. package/templates/vite/.howone/skills/hallmark/references/macrostructures/04-stat-led.md +32 -0
  88. package/templates/vite/.howone/skills/hallmark/references/macrostructures/05-workbench.md +32 -0
  89. package/templates/vite/.howone/skills/hallmark/references/macrostructures/06-conversational-faq.md +33 -0
  90. package/templates/vite/.howone/skills/hallmark/references/macrostructures/07-manifesto.md +32 -0
  91. package/templates/vite/.howone/skills/hallmark/references/macrostructures/08-photographic.md +34 -0
  92. package/templates/vite/.howone/skills/hallmark/references/macrostructures/09-quote-led.md +32 -0
  93. package/templates/vite/.howone/skills/hallmark/references/macrostructures/10-specimen.md +32 -0
  94. package/templates/vite/.howone/skills/hallmark/references/macrostructures/11-catalogue.md +23 -0
  95. package/templates/vite/.howone/skills/hallmark/references/macrostructures/12-letter.md +23 -0
  96. package/templates/vite/.howone/skills/hallmark/references/macrostructures/13-index-first.md +23 -0
  97. package/templates/vite/.howone/skills/hallmark/references/macrostructures/14-narrative-workflow.md +23 -0
  98. package/templates/vite/.howone/skills/hallmark/references/macrostructures/15-split-studio.md +23 -0
  99. package/templates/vite/.howone/skills/hallmark/references/macrostructures/16-feature-stack.md +23 -0
  100. package/templates/vite/.howone/skills/hallmark/references/macrostructures/17-type-specimen.md +23 -0
  101. package/templates/vite/.howone/skills/hallmark/references/macrostructures/18-portfolio-grid.md +23 -0
  102. package/templates/vite/.howone/skills/hallmark/references/macrostructures/19-map-diagram.md +23 -0
  103. package/templates/vite/.howone/skills/hallmark/references/macrostructures/20-ecosystem-index.md +23 -0
  104. package/templates/vite/.howone/skills/hallmark/references/macrostructures/21-component-playground.md +23 -0
  105. package/templates/vite/.howone/skills/hallmark/references/macrostructures.md +89 -0
  106. package/templates/vite/.howone/skills/hallmark/references/microinteractions.md +260 -0
  107. package/templates/vite/.howone/skills/hallmark/references/motion.md +109 -0
  108. package/templates/vite/.howone/skills/hallmark/references/preview-examples.md +49 -0
  109. package/templates/vite/.howone/skills/hallmark/references/responsive.md +138 -0
  110. package/templates/vite/.howone/skills/hallmark/references/slop-test.md +205 -0
  111. package/templates/vite/.howone/skills/hallmark/references/structure.md +164 -0
  112. package/templates/vite/.howone/skills/hallmark/references/study.md +486 -0
  113. package/templates/vite/.howone/skills/hallmark/references/typography.md +243 -0
  114. package/templates/vite/.howone/skills/hallmark/references/verbs/audit.md +25 -0
  115. package/templates/vite/.howone/skills/hallmark/references/verbs/redesign.md +269 -0
  116. package/templates/vite/.howone/skills/hallmark/site/OG-hallmark.png +0 -0
  117. package/templates/vite/.howone/skills/hallmark/site/_tests/01-tide-podcast/brief.md +71 -0
  118. package/templates/vite/.howone/skills/hallmark/site/_tests/01-tide-podcast/index.html +64 -0
  119. package/templates/vite/.howone/skills/hallmark/site/_tests/01-tide-podcast/style.css +240 -0
  120. package/templates/vite/.howone/skills/hallmark/site/_tests/02-streampipe-cli/brief.md +65 -0
  121. package/templates/vite/.howone/skills/hallmark/site/_tests/02-streampipe-cli/index.html +105 -0
  122. package/templates/vite/.howone/skills/hallmark/site/_tests/02-streampipe-cli/style.css +250 -0
  123. package/templates/vite/.howone/skills/hallmark/site/_tests/03-maple-bakery/brief.md +64 -0
  124. package/templates/vite/.howone/skills/hallmark/site/_tests/03-maple-bakery/index.html +131 -0
  125. package/templates/vite/.howone/skills/hallmark/site/_tests/03-maple-bakery/style.css +240 -0
  126. package/templates/vite/.howone/skills/hallmark/site/_tests/04-meridian-manifesto/brief.md +67 -0
  127. package/templates/vite/.howone/skills/hallmark/site/_tests/04-meridian-manifesto/index.html +86 -0
  128. package/templates/vite/.howone/skills/hallmark/site/_tests/04-meridian-manifesto/style.css +262 -0
  129. package/templates/vite/.howone/skills/hallmark/site/_tests/05-tracejam-saas/brief.md +63 -0
  130. package/templates/vite/.howone/skills/hallmark/site/_tests/05-tracejam-saas/index.html +167 -0
  131. package/templates/vite/.howone/skills/hallmark/site/_tests/05-tracejam-saas/style.css +457 -0
  132. package/templates/vite/.howone/skills/hallmark/site/_tests/06-anya-portfolio/brief.md +65 -0
  133. package/templates/vite/.howone/skills/hallmark/site/_tests/06-anya-portfolio/index.html +159 -0
  134. package/templates/vite/.howone/skills/hallmark/site/_tests/06-anya-portfolio/style.css +288 -0
  135. package/templates/vite/.howone/skills/hallmark/site/_tests/07-foundry-compliance/brief.md +64 -0
  136. package/templates/vite/.howone/skills/hallmark/site/_tests/07-foundry-compliance/index.html +146 -0
  137. package/templates/vite/.howone/skills/hallmark/site/_tests/07-foundry-compliance/style.css +484 -0
  138. package/templates/vite/.howone/skills/hallmark/site/_tests/08-cohort-courses/brief.md +64 -0
  139. package/templates/vite/.howone/skills/hallmark/site/_tests/08-cohort-courses/index.html +116 -0
  140. package/templates/vite/.howone/skills/hallmark/site/_tests/08-cohort-courses/style.css +354 -0
  141. package/templates/vite/.howone/skills/hallmark/site/_tests/09-slow-pour/index.html +638 -0
  142. package/templates/vite/.howone/skills/hallmark/site/_tests/10-owl-hours/index.html +515 -0
  143. package/templates/vite/.howone/skills/hallmark/site/_tests/11-soroe-ceramics/index.html +515 -0
  144. package/templates/vite/.howone/skills/hallmark/site/_tests/12-loafer/index.html +608 -0
  145. package/templates/vite/.howone/skills/hallmark/site/_tests/13-alma/index.html +587 -0
  146. package/templates/vite/.howone/skills/hallmark/site/_tests/README.md +157 -0
  147. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/BananaStudio-loop.mp4 +0 -0
  148. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/BananaStudio-still.jpg +0 -0
  149. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Hyperlane-example.mp4 +0 -0
  150. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Hyperlane-still.jpg +0 -0
  151. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Najm-loop.mp4 +0 -0
  152. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Najm-still.jpg +0 -0
  153. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Podcast-loop.mp4 +0 -0
  154. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/SaaS-loop.mp4 +0 -0
  155. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/SaaS-still.jpg +0 -0
  156. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Soroe-loop.mp4 +0 -0
  157. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Soroe-still.jpg +0 -0
  158. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/after-quiet-hour.png +0 -0
  159. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/anya-loop.mp4 +0 -0
  160. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/anya-still.jpg +0 -0
  161. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/audit-example.png +0 -0
  162. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/before-quiet-hour.png +0 -0
  163. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/example-redesign-uractivation.png +0 -0
  164. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/slow-pour-loop.mp4 +0 -0
  165. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/slow-pour-still.jpg +0 -0
  166. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/study-example.png +0 -0
  167. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/uractivation-after-loop.mp4 +0 -0
  168. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/wayfare-loop.mp4 +0 -0
  169. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/wayfare-still.jpg +0 -0
  170. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/01-coffeebox/index.html +77 -0
  171. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/01-coffeebox/style.css +238 -0
  172. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/02-loop/index.html +110 -0
  173. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/02-loop/style.css +326 -0
  174. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/03-mossroot/index.html +134 -0
  175. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/03-mossroot/style.css +262 -0
  176. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/README.md +30 -0
  177. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/README.md +17 -0
  178. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/audit/audit-report.md +56 -0
  179. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/audit/input.html +160 -0
  180. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/audit/notes.md +29 -0
  181. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/redesign/input.html +63 -0
  182. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/redesign/notes.md +72 -0
  183. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/redesign/output.html +374 -0
  184. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/diagnosis.md +52 -0
  185. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/input-description.md +29 -0
  186. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/notes.md +61 -0
  187. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/output.css +193 -0
  188. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/output.html +66 -0
  189. package/templates/vite/.howone/skills/hallmark/site/css/base.css +194 -0
  190. package/templates/vite/.howone/skills/hallmark/site/css/components.css +4886 -0
  191. package/templates/vite/.howone/skills/hallmark/site/css/sections.css +2072 -0
  192. package/templates/vite/.howone/skills/hallmark/site/css/tokens.css +1129 -0
  193. package/templates/vite/.howone/skills/hallmark/site/examples/bananastudio/index.html +475 -0
  194. package/templates/vite/.howone/skills/hallmark/site/examples/bananastudio/styles.css +1584 -0
  195. package/templates/vite/.howone/skills/hallmark/site/examples/bananastudio/tokens.css +96 -0
  196. package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/index.html +344 -0
  197. package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/script.js +103 -0
  198. package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/styles.css +1103 -0
  199. package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/tokens.css +83 -0
  200. package/templates/vite/.howone/skills/hallmark/site/examples/najm/index.html +368 -0
  201. package/templates/vite/.howone/skills/hallmark/site/examples/najm/script.js +133 -0
  202. package/templates/vite/.howone/skills/hallmark/site/examples/najm/styles.css +1062 -0
  203. package/templates/vite/.howone/skills/hallmark/site/examples/najm/tokens.css +97 -0
  204. package/templates/vite/.howone/skills/hallmark/site/examples/tally/app.js +84 -0
  205. package/templates/vite/.howone/skills/hallmark/site/examples/tally/index.html +446 -0
  206. package/templates/vite/.howone/skills/hallmark/site/examples/tally/styles.css +1087 -0
  207. package/templates/vite/.howone/skills/hallmark/site/examples/tally/tokens.css +101 -0
  208. package/templates/vite/.howone/skills/hallmark/site/examples/wayfare/index.html +359 -0
  209. package/templates/vite/.howone/skills/hallmark/site/examples/wayfare/style.css +1168 -0
  210. package/templates/vite/.howone/skills/hallmark/site/examples/wayfare/tokens.css +81 -0
  211. package/templates/vite/.howone/skills/hallmark/site/favicon-dark.svg +5 -0
  212. package/templates/vite/.howone/skills/hallmark/site/favicon-light.svg +5 -0
  213. package/templates/vite/.howone/skills/hallmark/site/index.html +1043 -0
  214. package/templates/vite/.howone/skills/hallmark/site/js/main.js +1175 -0
  215. package/templates/vite/.howone/skills/hallmark/vercel.json +6 -0
  216. package/templates/vite/.howone/skills/howone-sdk/01-architect/01-app-generation.md +126 -0
  217. package/templates/vite/.howone/skills/howone-sdk/{references/08-manifest-codegen.md → 01-architect/02-manifest-codegen.md} +31 -19
  218. package/templates/vite/.howone/skills/howone-sdk/02-database/01-schema-design.md +147 -0
  219. package/templates/vite/.howone/skills/howone-sdk/02-database/02-schema-operations.md +96 -0
  220. package/templates/vite/.howone/skills/howone-sdk/02-database/03-data-access-patterns.md +172 -0
  221. package/templates/vite/.howone/skills/howone-sdk/{references → 03-sdk}/01-client-setup.md +3 -3
  222. package/templates/vite/.howone/skills/howone-sdk/{references/04-auth.md → 03-sdk/03-auth.md} +120 -3
  223. package/templates/vite/.howone/skills/howone-sdk/{references/06-react-integration.md → 03-sdk/04-react-integration.md} +2 -4
  224. package/templates/vite/.howone/skills/howone-sdk/{references/03-ai-actions.md → 03-sdk/07-ai-action-calls.md} +31 -34
  225. package/templates/vite/.howone/skills/howone-sdk/04-ai/.gitkeep +1 -0
  226. package/templates/vite/.howone/skills/howone-sdk/04-ai/01-ai-capability-architecture.md +142 -0
  227. package/templates/vite/.howone/skills/howone-sdk/04-ai/02-workflow-contract-rules.md +169 -0
  228. package/templates/vite/.howone/skills/howone-sdk/04-ai/03-ai-sdk-handoff.md +80 -0
  229. package/templates/vite/.howone/skills/howone-sdk/SKILL.md +118 -93
  230. package/templates/vite/.howone/skills/howone-sdk/agents/openai.yaml +3 -3
  231. package/templates/vite/.howone/skills/impeccable/SKILL.md +168 -0
  232. package/templates/vite/.howone/skills/impeccable/agents/impeccable-asset-producer.md +101 -0
  233. package/templates/vite/.howone/skills/impeccable/reference/adapt.md +190 -0
  234. package/templates/vite/.howone/skills/impeccable/reference/animate.md +175 -0
  235. package/templates/vite/.howone/skills/impeccable/reference/audit.md +133 -0
  236. package/templates/vite/.howone/skills/impeccable/reference/bolder.md +113 -0
  237. package/templates/vite/.howone/skills/impeccable/reference/brand.md +118 -0
  238. package/templates/vite/.howone/skills/impeccable/reference/clarify.md +174 -0
  239. package/templates/vite/.howone/skills/impeccable/reference/codex.md +105 -0
  240. package/templates/vite/.howone/skills/impeccable/reference/cognitive-load.md +106 -0
  241. package/templates/vite/.howone/skills/impeccable/reference/color-and-contrast.md +105 -0
  242. package/templates/vite/.howone/skills/impeccable/reference/colorize.md +154 -0
  243. package/templates/vite/.howone/skills/impeccable/reference/craft.md +123 -0
  244. package/templates/vite/.howone/skills/impeccable/reference/critique.md +273 -0
  245. package/templates/vite/.howone/skills/impeccable/reference/delight.md +302 -0
  246. package/templates/vite/.howone/skills/impeccable/reference/distill.md +111 -0
  247. package/templates/vite/.howone/skills/impeccable/reference/document.md +427 -0
  248. package/templates/vite/.howone/skills/impeccable/reference/extract.md +69 -0
  249. package/templates/vite/.howone/skills/impeccable/reference/harden.md +347 -0
  250. package/templates/vite/.howone/skills/impeccable/reference/heuristics-scoring.md +234 -0
  251. package/templates/vite/.howone/skills/impeccable/reference/interaction-design.md +195 -0
  252. package/templates/vite/.howone/skills/impeccable/reference/layout.md +141 -0
  253. package/templates/vite/.howone/skills/impeccable/reference/live.md +622 -0
  254. package/templates/vite/.howone/skills/impeccable/reference/motion-design.md +109 -0
  255. package/templates/vite/.howone/skills/impeccable/reference/onboard.md +234 -0
  256. package/templates/vite/.howone/skills/impeccable/reference/optimize.md +258 -0
  257. package/templates/vite/.howone/skills/impeccable/reference/overdrive.md +130 -0
  258. package/templates/vite/.howone/skills/impeccable/reference/personas.md +179 -0
  259. package/templates/vite/.howone/skills/impeccable/reference/polish.md +242 -0
  260. package/templates/vite/.howone/skills/impeccable/reference/product.md +62 -0
  261. package/templates/vite/.howone/skills/impeccable/reference/quieter.md +99 -0
  262. package/templates/vite/.howone/skills/impeccable/reference/responsive-design.md +114 -0
  263. package/templates/vite/.howone/skills/impeccable/reference/shape.md +165 -0
  264. package/templates/vite/.howone/skills/impeccable/reference/spatial-design.md +100 -0
  265. package/templates/vite/.howone/skills/impeccable/reference/teach.md +156 -0
  266. package/templates/vite/.howone/skills/impeccable/reference/typeset.md +124 -0
  267. package/templates/vite/.howone/skills/impeccable/reference/typography.md +159 -0
  268. package/templates/vite/.howone/skills/impeccable/reference/ux-writing.md +107 -0
  269. package/templates/vite/.howone/skills/impeccable/scripts/cleanup-deprecated.mjs +284 -0
  270. package/templates/vite/.howone/skills/impeccable/scripts/command-metadata.json +94 -0
  271. package/templates/vite/.howone/skills/impeccable/scripts/critique-storage.mjs +242 -0
  272. package/templates/vite/.howone/skills/impeccable/scripts/design-parser.mjs +820 -0
  273. package/templates/vite/.howone/skills/impeccable/scripts/detect-csp.mjs +198 -0
  274. package/templates/vite/.howone/skills/impeccable/scripts/detect.mjs +21 -0
  275. package/templates/vite/.howone/skills/impeccable/scripts/impeccable-paths.mjs +110 -0
  276. package/templates/vite/.howone/skills/impeccable/scripts/is-generated.mjs +69 -0
  277. package/templates/vite/.howone/skills/impeccable/scripts/live-accept.mjs +595 -0
  278. package/templates/vite/.howone/skills/impeccable/scripts/live-browser-session.js +123 -0
  279. package/templates/vite/.howone/skills/impeccable/scripts/live-browser.js +4860 -0
  280. package/templates/vite/.howone/skills/impeccable/scripts/live-complete.mjs +75 -0
  281. package/templates/vite/.howone/skills/impeccable/scripts/live-completion.mjs +18 -0
  282. package/templates/vite/.howone/skills/impeccable/scripts/live-inject.mjs +446 -0
  283. package/templates/vite/.howone/skills/impeccable/scripts/live-poll.mjs +200 -0
  284. package/templates/vite/.howone/skills/impeccable/scripts/live-resume.mjs +48 -0
  285. package/templates/vite/.howone/skills/impeccable/scripts/live-server.mjs +838 -0
  286. package/templates/vite/.howone/skills/impeccable/scripts/live-session-store.mjs +254 -0
  287. package/templates/vite/.howone/skills/impeccable/scripts/live-status.mjs +47 -0
  288. package/templates/vite/.howone/skills/impeccable/scripts/live-wrap.mjs +632 -0
  289. package/templates/vite/.howone/skills/impeccable/scripts/live.mjs +247 -0
  290. package/templates/vite/.howone/skills/impeccable/scripts/load-context.mjs +141 -0
  291. package/templates/vite/.howone/skills/impeccable/scripts/modern-screenshot.umd.js +14 -0
  292. package/templates/vite/.howone/skills/impeccable/scripts/pin.mjs +214 -0
  293. package/templates/vite/AGENTS.md +2 -12
  294. package/templates/vite/package.json +1 -1
  295. package/templates/vite/src/lib/sdk.ts +3 -0
  296. /package/templates/vite/.howone/skills/howone-sdk/{references → 03-sdk}/02-entity-operations.md +0 -0
  297. /package/templates/vite/.howone/skills/howone-sdk/{references → 03-sdk}/05-file-upload.md +0 -0
  298. /package/templates/vite/.howone/skills/howone-sdk/{references/07-raw-http.md → 03-sdk/06-raw-http.md} +0 -0
@@ -0,0 +1,1043 @@
1
+ <!doctype html>
2
+ <html lang="en" data-theme="specimen">
3
+
4
+ <head>
5
+ <meta charset="utf-8" />
6
+ <meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover" />
7
+ <meta name="color-scheme" content="light" />
8
+ <title>Hallmark — A design skill that refuses to look AI-generated</title>
9
+ <meta name="description"
10
+ content="Hallmark is a design skill for AI coding assistants. It encodes the anti-AI-slop consensus — typography, colour, layout, motion, interaction — into one holistic ruleset. Powered by Together AI." />
11
+
12
+ <meta property="og:title" content="Hallmark — A design skill that refuses to look AI-generated" />
13
+ <meta property="og:description"
14
+ content="A design skill for AI coding assistants. Encodes the anti-slop consensus into one ruleset. Powered by Together AI." />
15
+ <meta property="og:type" content="website" />
16
+ <meta property="og:url" content="https://www.usehallmark.com/" />
17
+ <meta property="og:site_name" content="Hallmark" />
18
+ <meta property="og:image" content="https://www.usehallmark.com/OG-hallmark.png" />
19
+ <meta property="og:image:secure_url" content="https://www.usehallmark.com/OG-hallmark.png" />
20
+ <meta property="og:image:type" content="image/png" />
21
+ <meta property="og:image:width" content="4800" />
22
+ <meta property="og:image:height" content="2520" />
23
+ <meta property="og:image:alt" content="Hallmark — A design skill that refuses to look AI-generated" />
24
+ <meta name="twitter:card" content="summary_large_image" />
25
+ <meta name="twitter:title" content="Hallmark — A design skill that refuses to look AI-generated" />
26
+ <meta name="twitter:description"
27
+ content="A design skill for AI coding assistants. Encodes the anti-slop consensus into one ruleset. Powered by Together AI." />
28
+ <meta name="twitter:image" content="https://www.usehallmark.com/OG-hallmark.png" />
29
+ <meta name="twitter:image:alt" content="Hallmark — A design skill that refuses to look AI-generated" />
30
+
31
+ <link rel="icon" type="image/svg+xml" href="favicon-light.svg" media="(prefers-color-scheme: light)" />
32
+ <link rel="icon" type="image/svg+xml" href="favicon-dark.svg" media="(prefers-color-scheme: dark)" />
33
+ <link rel="icon" type="image/svg+xml" href="favicon-light.svg" />
34
+
35
+ <!-- Entrance gate. Hides body until web fonts resolve so the page doesn't
36
+ flash system fonts then snap to the real faces. Fires once on first
37
+ load only — the matching script in the pre-paint block at the bottom
38
+ of <head> sets data-fonts-ready on <html> when document.fonts.ready
39
+ resolves (or after a 1200 ms safety timeout). Theme switches modify
40
+ [data-theme], not [data-fonts-ready], so the fade never re-runs. -->
41
+ <style>
42
+ html:not([data-fonts-ready]) body { opacity: 0; }
43
+ body {
44
+ opacity: 1;
45
+ transition: opacity 280ms cubic-bezier(0.22, 1, 0.36, 1);
46
+ }
47
+ @media (prefers-reduced-motion: reduce) {
48
+ html:not([data-fonts-ready]) body { opacity: 1; }
49
+ body { transition: none; }
50
+ }
51
+ </style>
52
+
53
+ <!-- Google Fonts — Anton, Albert Sans, Fraunces, Geist, Geist Mono, Hanken Grotesk, Inter, Inter Tight, Newsreader, Playfair Display, Public Sans. -->
54
+ <link rel="preconnect" href="https://fonts.googleapis.com" />
55
+ <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin />
56
+ <link rel="stylesheet"
57
+ href="https://fonts.googleapis.com/css2?family=Albert+Sans:wght@400;500;600;700;800&family=Anton&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,900;1,9..144,400;1,9..144,500&family=Geist:wght@400;500;600;700&family=Geist+Mono:wght@400;500&family=Hanken+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=Inter+Tight:ital,wght@0,500;0,600;0,700;0,800;1,500;1,600;1,700&family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;1,6..72,400;1,6..72,500&family=Playfair+Display:ital,wght@1,400;1,500;1,600&family=Public+Sans:wght@400;500;600;700&display=swap" />
58
+
59
+ <link rel="stylesheet" href="css/tokens.css" />
60
+ <link rel="stylesheet" href="css/base.css" />
61
+ <link rel="stylesheet" href="css/components.css" />
62
+ <link rel="stylesheet" href="css/sections.css" />
63
+
64
+ <script>
65
+ // Load theme before paint to avoid flash. Order: ?theme= → localStorage → default.
66
+ try {
67
+ const url = new URL(window.location.href);
68
+ const q = url.searchParams.get("theme");
69
+ const t = q || localStorage.getItem("hallmark-theme");
70
+ if (t) document.documentElement.dataset.theme = t;
71
+ } catch (e) { }
72
+
73
+ // Mark fonts-ready when document.fonts resolves; safety timeout at 1200 ms.
74
+ // Pairs with the entrance-fade <style> above. Fires once on first load —
75
+ // theme switches don't reset the attribute, so the fade never re-runs.
76
+ (function () {
77
+ var html = document.documentElement;
78
+ var fired = false;
79
+ function ready() {
80
+ if (fired) return;
81
+ fired = true;
82
+ html.setAttribute("data-fonts-ready", "");
83
+ }
84
+ if (document.fonts && document.fonts.ready && typeof document.fonts.ready.then === "function") {
85
+ document.fonts.ready.then(ready);
86
+ } else {
87
+ ready();
88
+ }
89
+ setTimeout(ready, 1200);
90
+ })();
91
+ </script>
92
+
93
+ <!-- Privacy-friendly analytics by Plausible -->
94
+ <script async src="https://plausible.io/js/pa-C-D0j4RyxujH0xB9vHv0a.js"></script>
95
+ <script>
96
+ window.plausible=window.plausible||function(){(plausible.q=plausible.q||[]).push(arguments)},plausible.init=plausible.init||function(i){plausible.o=i||{}};
97
+ plausible.init()
98
+ </script>
99
+ </head>
100
+
101
+ <body>
102
+
103
+ <!-- BANNER — sticky top, thin, holds the theme picker -->
104
+ <header class="banner" role="banner">
105
+ <a class="banner__mark" href="#top" aria-label="Hallmark — top of page">
106
+ <span class="brand-mark" aria-hidden="true"><span class="brand-mark__slash">/</span><span class="brand-mark__name">hallmark</span></span>
107
+ <span class="banner__ver tnum">v1.0</span>
108
+ </a>
109
+
110
+ <a class="banner__install" href="#install" aria-label="Jump to install section">Install</a>
111
+
112
+ <a class="banner__star" href="https://github.com/nutlope/hallmark" target="_blank" rel="noopener"
113
+ aria-label="Star Hallmark on GitHub">
114
+ <svg class="banner__star-icon" viewBox="0 0 16 16" width="11" height="11" aria-hidden="true">
115
+ <path fill="currentColor"
116
+ d="M8 0.5l2.36 4.78 5.27.77-3.81 3.72.9 5.24L8 12.55 3.28 15.01l.9-5.24L.37 6.05l5.27-.77L8 .5z" />
117
+ </svg>
118
+ <span class="banner__star-count tnum" data-star-count>0</span>
119
+ </a>
120
+
121
+ <span class="banner__spacer" aria-hidden="true"></span>
122
+
123
+ <div class="banner__theme-wrap" data-theme-wrap>
124
+ <button class="banner__theme-indicator" type="button" aria-haspopup="listbox" aria-expanded="false"
125
+ aria-controls="theme-dropdown" data-theme-trigger>
126
+ <span class="banner__ordinal tnum" data-theme-ordinal>01 / 23</span>
127
+ <span class="banner__indicator-sep" aria-hidden="true">—</span>
128
+ <span class="banner__theme" data-theme-current>Specimen</span>
129
+ <svg class="banner__caret" viewBox="0 0 12 12" width="10" height="10" aria-hidden="true">
130
+ <path d="M2 4l4 4 4-4" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"
131
+ stroke-linejoin="round" />
132
+ </svg>
133
+ </button>
134
+
135
+ <div class="theme-dropdown" id="theme-dropdown" role="listbox" aria-label="Theme picker" hidden>
136
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="specimen" aria-label="01 — Specimen"
137
+ style="--dot: oklch(96% 0.018 80); --dot-edge: oklch(70% 0.04 75);"><span
138
+ class="theme-dropdown__num">01</span></button>
139
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="midnight" aria-label="02 — Midnight"
140
+ style="--dot: oklch(15% 0.022 250); --dot-edge: oklch(72% 0.16 220);"><span
141
+ class="theme-dropdown__num">02</span></button>
142
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="brutal" aria-label="03 — Brutal"
143
+ style="--dot: oklch(98% 0.001 0); --dot-edge: oklch(60% 0.21 27);"><span
144
+ class="theme-dropdown__num">03</span></button>
145
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="garden" aria-label="04 — Garden"
146
+ style="--dot: oklch(95% 0.030 130); --dot-edge: oklch(54% 0.16 14);"><span
147
+ class="theme-dropdown__num">04</span></button>
148
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="atelier" aria-label="05 — Atelier"
149
+ style="--dot: oklch(94% 0.005 60); --dot-edge: oklch(45% 0.13 60);"><span
150
+ class="theme-dropdown__num">05</span></button>
151
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="newsprint" aria-label="06 — Newsprint"
152
+ style="--dot: oklch(92% 0.045 50); --dot-edge: oklch(32% 0.10 28);"><span
153
+ class="theme-dropdown__num">06</span></button>
154
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="terminal" aria-label="07 — Terminal"
155
+ style="--dot: oklch(11% 0.018 145); --dot-edge: oklch(78% 0.19 138);"><span
156
+ class="theme-dropdown__num">07</span></button>
157
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="manifesto" aria-label="08 — Manifesto"
158
+ style="--dot: oklch(10% 0.005 60); --dot-edge: oklch(60% 0.22 27);"><span
159
+ class="theme-dropdown__num">08</span></button>
160
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="salon" aria-label="09 — Salon"
161
+ style="--dot: oklch(94% 0.030 65); --dot-edge: oklch(40% 0.085 50);"><span
162
+ class="theme-dropdown__num">09</span></button>
163
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="linen" aria-label="10 — Linen"
164
+ style="--dot: oklch(89% 0.022 95); --dot-edge: oklch(46% 0.06 95);"><span
165
+ class="theme-dropdown__num">10</span></button>
166
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="almanac" aria-label="11 — Almanac"
167
+ style="--dot: oklch(94% 0.008 245); --dot-edge: oklch(38% 0.135 250);"><span
168
+ class="theme-dropdown__num">11</span></button>
169
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="sport" aria-label="12 — Sport"
170
+ style="--dot: oklch(98% 0.003 250); --dot-edge: oklch(58% 0.190 35);"><span
171
+ class="theme-dropdown__num">12</span></button>
172
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="studio" aria-label="13 — Studio"
173
+ style="--dot: oklch(96.5% 0.014 95); --dot-edge: oklch(46% 0.140 145);"><span
174
+ class="theme-dropdown__num">13</span></button>
175
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="riso" aria-label="14 — Riso"
176
+ style="--dot: oklch(91% 0.034 30); --dot-edge: oklch(58% 0.170 220);"><span
177
+ class="theme-dropdown__num">14</span></button>
178
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="quiet" aria-label="15 — Quiet"
179
+ style="--dot: oklch(100% 0 0); --dot-edge: oklch(15% 0 0);"><span
180
+ class="theme-dropdown__num">15</span></button>
181
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="bloom" aria-label="16 — Bloom"
182
+ style="--dot: oklch(96% 0.018 35); --dot-edge: oklch(64% 0.180 18);"><span
183
+ class="theme-dropdown__num">16</span></button>
184
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="coral" aria-label="17 — Coral"
185
+ style="--dot: oklch(96.5% 0.005 50); --dot-edge: oklch(64% 0.165 28);"><span
186
+ class="theme-dropdown__num">17</span></button>
187
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="violet" aria-label="18 — Violet"
188
+ style="--dot: oklch(99% 0.003 280); --dot-edge: oklch(58% 0.16 285);"><span
189
+ class="theme-dropdown__num">18</span></button>
190
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="aurora" aria-label="19 — Aurora"
191
+ style="--dot: oklch(11% 0.025 200); --dot-edge: oklch(72% 0.170 200);"><span
192
+ class="theme-dropdown__num">19</span></button>
193
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="halo" aria-label="20 — Halo"
194
+ style="--dot: oklch(13% 0.005 60); --dot-edge: oklch(74% 0.16 70);"><span
195
+ class="theme-dropdown__num">20</span></button>
196
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="plume" aria-label="21 — Plume"
197
+ style="--dot: oklch(96% 0.020 70); --dot-edge: oklch(68% 0.130 18);"><span
198
+ class="theme-dropdown__num">21</span></button>
199
+ <button class="theme-dropdown__dot" type="button" data-theme-btn="editorial" aria-label="22 — Editorial"
200
+ style="--dot: oklch(94% 0.020 75); --dot-edge: oklch(60% 0.160 35);"><span
201
+ class="theme-dropdown__num">22</span></button>
202
+ </div>
203
+ </div>
204
+
205
+ <button class="banner__shuffle" type="button" aria-label="Random theme · T cycles · R randomises"
206
+ title="Click → random · T cycles · R randomises">
207
+ <svg viewBox="0 0 24 24" width="14" height="14" fill="none" stroke="currentColor" stroke-width="2"
208
+ stroke-linecap="round" stroke-linejoin="round" aria-hidden="true">
209
+ <path d="M16 3h5v5" />
210
+ <path d="M4 20 21 3" />
211
+ <path d="M21 16v5h-5" />
212
+ <path d="m15 15 6 6" />
213
+ <path d="M4 4l5 5" />
214
+ </svg>
215
+ <span class="banner__shuffle-key">T</span>
216
+ </button>
217
+
218
+ <aside class="t-tooltip" data-t-tooltip hidden role="status" aria-live="polite">
219
+ <span class="t-tooltip__arrow" aria-hidden="true"></span>
220
+ <span class="t-tooltip__body">
221
+ Press <kbd>T</kbd> to see this page in <strong>22 shapes</strong>.
222
+ </span>
223
+ </aside>
224
+ </header>
225
+
226
+ <main class="page">
227
+
228
+ <!-- 01 · HERO SLOT — archetype swaps per theme -->
229
+ <section class="slot slot--hero reveal" data-slot="hero" id="top" style="--i:0" aria-label="Opening"></section>
230
+
231
+ <!-- 02 · EXAMPLES — full-bleed rail, the centerpiece -->
232
+ <section class="section section--bleed reveal" style="--i:1" id="examples" aria-labelledby="s2">
233
+ <header class="section__head">
234
+ <p class="section-label">
235
+ <span class="num">02</span><span class="divider">⁄</span><span>Examples</span>
236
+ </p>
237
+ <h2 class="section__title" id="s2">
238
+ Worked examples.
239
+ </h2>
240
+ </header>
241
+
242
+ <p class="examples__intro">One-shotted. No shared theme. No shared layout.</p>
243
+
244
+ <div class="examples-rail" role="list" aria-label="Example landing pages">
245
+
246
+ <a class="ex-card" role="listitem" href="examples/tally/" target="_blank" rel="noopener" aria-label="Open the Tally example — SaaS product page, modern-minimal — in a new tab">
247
+ <div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
248
+ <video data-hover-play src="_tests/_thumbs/SaaS-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
249
+ </div>
250
+ <p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a SaaS product page, modern-minimal</p>
251
+ </a>
252
+
253
+ <a class="ex-card" role="listitem" href="examples/wayfare/" target="_blank" rel="noopener" aria-label="Open the Wayfare example — travel booking site, atmospheric — in a new tab">
254
+ <div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
255
+ <video data-hover-play src="_tests/_thumbs/wayfare-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
256
+ </div>
257
+ <p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a travel booking site, atmospheric</p>
258
+ </a>
259
+
260
+ <a class="ex-card" role="listitem" href="_tests/09-slow-pour/" target="_blank" rel="noopener" aria-label="Open the Slow Pour example — small-batch coffee subscription — in a new tab">
261
+ <div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
262
+ <video data-hover-play src="_tests/_thumbs/slow-pour-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
263
+ </div>
264
+ <p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a small-batch coffee subscription page</p>
265
+ </a>
266
+
267
+ <a class="ex-card" role="listitem" href="examples/bananastudio/" target="_blank" rel="noopener" aria-label="Open the BananaStudio example — creative studio with playful motion — in a new tab">
268
+ <div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
269
+ <video data-hover-play src="_tests/_thumbs/BananaStudio-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
270
+ </div>
271
+ <p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a creative studio with playful motion</p>
272
+ </a>
273
+
274
+ <a class="ex-card" role="listitem" href="_tests/06-anya-portfolio/" target="_blank" rel="noopener" aria-label="Open the Anya Reis example — software architect personal site — in a new tab">
275
+ <div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
276
+ <video data-hover-play src="_tests/_thumbs/anya-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
277
+ </div>
278
+ <p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a software architect personal site</p>
279
+ </a>
280
+
281
+ <a class="ex-card" role="listitem" href="examples/najm/" target="_blank" rel="noopener" aria-label="Open the NAJM example — Moroccan fashion brand landing page — in a new tab">
282
+ <div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
283
+ <video data-hover-play src="_tests/_thumbs/Najm-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
284
+ </div>
285
+ <p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a Moroccan fashion brand landing page</p>
286
+ </a>
287
+
288
+ <a class="ex-card" role="listitem" href="_tests/11-soroe-ceramics/" target="_blank" rel="noopener" aria-label="Open the Soroe example — small ceramics studio site — in a new tab">
289
+ <div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
290
+ <video data-hover-play src="_tests/_thumbs/Soroe-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1804" height="1080"></video>
291
+ </div>
292
+ <p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a small ceramics studio site</p>
293
+ </a>
294
+
295
+ <a class="ex-card" role="listitem" href="examples/hyperlane/" target="_blank" rel="noopener" aria-label="Open the Hyperlane example — developer infrastructure landing page — in a new tab">
296
+ <div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
297
+ <video data-hover-play src="_tests/_thumbs/Hyperlane-example.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
298
+ </div>
299
+ <p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a developer infrastructure landing page</p>
300
+ </a>
301
+
302
+ </div>
303
+
304
+ </section>
305
+
306
+ <!-- 03 · SKILLS — five things Hallmark does, one ruleset underneath -->
307
+ <section class="section reveal" style="--i:2" id="skills" aria-labelledby="s-skills">
308
+ <header class="section__head">
309
+ <p class="section-label">
310
+ <span class="num">03</span><span class="divider">⁄</span><span>Skills</span>
311
+ </p>
312
+ <h2 class="section__title" id="s-skills">
313
+ What it does.
314
+ </h2>
315
+ </header>
316
+
317
+ <p class="skills__intro">
318
+ Hallmark has one default behaviour and three explicit verbs. Each reads a different input and returns a
319
+ different shape — same opinions, different jobs.
320
+ </p>
321
+
322
+ <ol class="skills-list">
323
+
324
+ <!-- Row I — Build (default) -->
325
+ <li class="skill-row" data-verb="build">
326
+ <header class="skill-row__head">
327
+ <div class="skill-row__head-body">
328
+ <h3 class="skill-row__title">Build <span class="skill-row__title-meta">(default)</span></h3>
329
+ <p class="skill-row__lede">Ask for a page. Get a page that doesn't look generated. Hallmark picks a
330
+ macrostructure first, then dresses it — and refuses to repeat the same shape twice.</p>
331
+ </div>
332
+ </header>
333
+
334
+ <div class="skill-row__body">
335
+ <figure class="skill-row__demo skill-row__demo--build">
336
+ <span class="brief-pill" aria-label="Example brief">"Build me a landing page for an indie podcast
337
+ platform."</span>
338
+ <span class="brief-arrow" aria-hidden="true">↓</span>
339
+ <span class="fig-corners brief-output">
340
+ <span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
341
+ <video class="brief-output__media" src="_tests/_thumbs/Podcast-loop.mp4" autoplay loop muted playsinline
342
+ preload="metadata" width="1600" height="1022"
343
+ aria-label="Podcast platform — a Hallmark output looping through its scroll"></video>
344
+ </span>
345
+ </figure>
346
+
347
+ <ol class="skill-row__list">
348
+ <li class="dna__row"><span class="dna__k">Invocation</span><span class="dna__v">(default) — just
349
+ ask</span></li>
350
+ <li class="dna__row"><span class="dna__k">Reads</span><span class="dna__v">your brief, project tokens,
351
+ framework</span></li>
352
+ <li class="dna__row"><span class="dna__k">Picks</span><span class="dna__v">macrostructure → theme →
353
+ enrichment</span></li>
354
+ <li class="dna__row"><span class="dna__k">Returns</span><span class="dna__v">a working page, stamped,
355
+ slop-tested</span></li>
356
+ <li class="dna__row"><span class="dna__k">Refuses</span><span class="dna__v">repeating the last 3
357
+ macrostructures</span></li>
358
+ </ol>
359
+ </div>
360
+ </li>
361
+
362
+ <!-- Row II — Study (preserves the existing DNA cards as THE demo) -->
363
+ <li class="skill-row" data-verb="study">
364
+ <header class="skill-row__head">
365
+ <div class="skill-row__head-body">
366
+ <h3 class="skill-row__title">Study</h3>
367
+ <p class="skill-row__lede">Paste a design you admire — a screenshot <em>or</em> a URL. Hallmark reads its
368
+ structure, not its pixels, and returns a DNA card you can build against. Or say <code>lock the
369
+ DNA</code> to write a portable <code>design.md</code> you can hand to another AI tool. Never copies
370
+ pixels. Tighter refusal layer for the portable spec than for the diagnosis.</p>
371
+ </div>
372
+ </header>
373
+
374
+ <div class="skill-row__body">
375
+ <figure class="skill-row__demo skill-row__demo--build">
376
+ <span class="brief-pill" aria-label="Example brief">/hallmark study together.ai &nbsp;·&nbsp; or paste a screenshot</span>
377
+ <span class="brief-arrow" aria-hidden="true">↓</span>
378
+ <span class="fig-corners brief-output">
379
+ <span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
380
+ <img src="_tests/_thumbs/study-example.png"
381
+ alt="A scheduling-tool landing page — used as a study reference for Hallmark's DNA extractor"
382
+ loading="lazy" decoding="async" width="1680" height="1050" />
383
+ </span>
384
+ </figure>
385
+
386
+ <ol class="skill-row__list">
387
+ <li class="dna__row"><span class="dna__k">Invocation</span><span
388
+ class="dna__v"><code>hallmark study &lt;screenshot &#124; URL&gt;</code></span></li>
389
+ <li class="dna__row"><span class="dna__k">Macrostructure</span><span class="dna__v">Split Hero</span></li>
390
+ <li class="dna__row"><span class="dna__k">Hero archetype</span><span class="dna__v">H7 Clipped · copy-left
391
+ + product-mock right</span></li>
392
+ <li class="dna__row"><span class="dna__k">Display role</span><span class="dna__v">heavy geometric
393
+ sans</span></li>
394
+ <li class="dna__row"><span class="dna__k">Body role</span><span class="dna__v">same family · regular
395
+ weight</span></li>
396
+ <li class="dna__row"><span class="dna__k">Label role</span><span class="dna__v">grotesque · sentence
397
+ case</span></li>
398
+ <li class="dna__row"><span class="dna__k">Paper band</span><span class="dna__v">light · pure white</span>
399
+ </li>
400
+ <li class="dna__row"><span class="dna__k">Accent hue</span><span class="dna__v">cool blue + magenta ·
401
+ organic gradient</span></li>
402
+ <li class="dna__row"><span class="dna__k">Rhythm</span><span class="dna__v">left-copy · right product card
403
+ · overlapping watercolor blobs</span></li>
404
+ <li class="dna__row"><span class="dna__k">Refuses</span><span class="dna__v">to ID fonts · to copy
405
+ pixels</span></li>
406
+ </ol>
407
+ </div>
408
+ </li>
409
+
410
+ <!-- Row III — Audit -->
411
+ <li class="skill-row" data-verb="audit">
412
+ <header class="skill-row__head">
413
+ <div class="skill-row__head-body">
414
+ <h3 class="skill-row__title">Audit</h3>
415
+ <p class="skill-row__lede">Point Hallmark at a page. Get a ranked punch list of what's wrong — scored
416
+ against the anti-pattern catalogue. <strong>No edits.</strong> Just the diagnosis.</p>
417
+ </div>
418
+ </header>
419
+
420
+ <div class="skill-row__body">
421
+ <figure class="skill-row__demo skill-row__demo--audit" aria-label="A Hallmark output for reference">
422
+ <span class="fig-corners brief-output">
423
+ <span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
424
+ <img src="_tests/_thumbs/audit-example.png"
425
+ alt="A Hallmark output — editorial display, real proof, hand-built illustration"
426
+ loading="lazy" decoding="async" width="1024" height="640" />
427
+ </span>
428
+ </figure>
429
+
430
+ <ol class="audit-check">
431
+ <li class="audit-check__row">
432
+ <span class="audit-check__cross" aria-hidden="true">✗</span>
433
+ <span class="audit-check__problem">Purple-to-pink gradient hero</span>
434
+ <span class="audit-check__arrow" aria-hidden="true">→</span>
435
+ <span class="audit-check__fix">Solid surface, single accent</span>
436
+ </li>
437
+ <li class="audit-check__row">
438
+ <span class="audit-check__cross" aria-hidden="true">✗</span>
439
+ <span class="audit-check__problem">Inter as display + body</span>
440
+ <span class="audit-check__arrow" aria-hidden="true">→</span>
441
+ <span class="audit-check__fix">Pair distinctive display + body</span>
442
+ </li>
443
+ <li class="audit-check__row">
444
+ <span class="audit-check__cross" aria-hidden="true">✗</span>
445
+ <span class="audit-check__problem">Centered everything</span>
446
+ <span class="audit-check__arrow" aria-hidden="true">→</span>
447
+ <span class="audit-check__fix">Bias the layout, break symmetry</span>
448
+ </li>
449
+ <li class="audit-check__row">
450
+ <span class="audit-check__cross" aria-hidden="true">✗</span>
451
+ <span class="audit-check__problem">Sparkle ✨ emoji as badge</span>
452
+ <span class="audit-check__arrow" aria-hidden="true">→</span>
453
+ <span class="audit-check__fix">Pick an icon library, or drop it</span>
454
+ </li>
455
+ <li class="audit-check__row">
456
+ <span class="audit-check__cross" aria-hidden="true">✗</span>
457
+ <span class="audit-check__problem">Gradient pill CTA</span>
458
+ <span class="audit-check__arrow" aria-hidden="true">→</span>
459
+ <span class="audit-check__fix">Solid fill or outline, single hue</span>
460
+ </li>
461
+ </ol>
462
+ </div>
463
+ </li>
464
+
465
+ <!-- Row IV — Redesign -->
466
+ <li class="skill-row" data-verb="redesign">
467
+ <header class="skill-row__head">
468
+ <div class="skill-row__head-body">
469
+ <h3 class="skill-row__title">Redesign</h3>
470
+ <p class="skill-row__lede">Same content. Same brand. Different bones. Hallmark throws out the structural
471
+ fingerprint and rebuilds with a deliberately different one — new section rhythm, new heading placement,
472
+ new component voice.</p>
473
+ </div>
474
+ </header>
475
+
476
+ <div class="skill-row__body skill-row__body--full">
477
+ <figure class="skill-row__demo skill-row__demo--diptych">
478
+ <figure class="diptych__half" data-state="before">
479
+ <span class="fig-corners">
480
+ <span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
481
+ <img src="_tests/_thumbs/example-redesign-uractivation.png"
482
+ alt="The original page — generic SaaS chrome before the redesign" loading="lazy" decoding="async"
483
+ width="1784" height="1080" />
484
+ </span>
485
+ <figcaption class="diptych__cap">Before</figcaption>
486
+ </figure>
487
+ <figure class="diptych__half" data-state="after">
488
+ <span class="fig-corners">
489
+ <span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
490
+ <video src="_tests/_thumbs/uractivation-after-loop.mp4" autoplay loop muted
491
+ playsinline preload="metadata" width="1784" height="1080"
492
+ aria-label="Same content, redesigned by Hallmark — different macrostructure, different fingerprint"></video>
493
+ </span>
494
+ <figcaption class="diptych__cap">After Hallmark redesign</figcaption>
495
+ </figure>
496
+ </figure>
497
+ </div>
498
+ </li>
499
+
500
+ </ol>
501
+
502
+ </section>
503
+
504
+ <!-- INTERLUDE — full-bleed typographic moment between III and IV.
505
+ Mid-scroll punctuation: a single declarative phrase set in
506
+ the active theme's display face, on a contrasting paper band.
507
+ Reprise of the marketing pitch in oversized type. -->
508
+ <aside class="interlude reveal" style="--i:3" aria-hidden="true">
509
+ <p class="interlude__phrase"><em>The page</em> is the demo.</p>
510
+ </aside>
511
+
512
+ <!-- 04 · ANTI-PATTERNS — Slop, by name. Five named AI-UI tells, each
513
+ with the Hallmark fix beside it. Replaces the original Without/
514
+ With section (preserved as a <template> below). -->
515
+ <section class="section reveal" style="--i:3" id="anti-patterns" aria-labelledby="s-anti">
516
+ <header class="section__head">
517
+ <p class="section-label">
518
+ <span class="num">04</span><span class="divider">⁄</span><span>Anti-patterns</span>
519
+ </p>
520
+ <h2 class="section__title" id="s-anti">
521
+ Slop, by name.
522
+ </h2>
523
+ </header>
524
+
525
+ <p class="anti__intro">
526
+ Five tells the LLM reaches for by default. The Hallmark fix beside each. <code>hallmark audit</code> flags every
527
+ one of these on existing code.
528
+ </p>
529
+
530
+ <ol class="anti-list">
531
+
532
+ <li class="anti-row">
533
+ <p class="anti-row__num tnum">01</p>
534
+ <div class="anti-row__slop">
535
+ <h3 class="anti-row__name">The purple-gradient hero.</h3>
536
+ <p class="anti-row__desc">A hero with a background gradient from purple to blue or purple to pink, white
537
+ centred text. The single most-recognised AI aesthetic.</p>
538
+ </div>
539
+ <div class="anti-row__fix">
540
+ <p class="anti-row__fix-label">Hallmark</p>
541
+ <p class="anti-row__fix-body">Pick a single anchor hue. One accent. No gradient backgrounds on heroes. If
542
+ you want warmth, tint the neutrals.</p>
543
+ </div>
544
+ </li>
545
+
546
+ <li class="anti-row">
547
+ <p class="anti-row__num tnum">02</p>
548
+ <div class="anti-row__slop">
549
+ <h3 class="anti-row__name">Inter as display.</h3>
550
+ <p class="anti-row__desc">Inter (or Roboto, or Open Sans) used as both display and body, no pairing face. A
551
+ one-font page is a template page.</p>
552
+ </div>
553
+ <div class="anti-row__fix">
554
+ <p class="anti-row__fix-label">Hallmark</p>
555
+ <p class="anti-row__fix-body">Pair a distinctive display face with a refined body. Two faces minimum, never
556
+ the same family doing both jobs.</p>
557
+ </div>
558
+ </li>
559
+
560
+ <li class="anti-row">
561
+ <p class="anti-row__num tnum">03</p>
562
+ <div class="anti-row__slop">
563
+ <h3 class="anti-row__name">Centred everything.</h3>
564
+ <p class="anti-row__desc">Headline centred, body centred, button centred, section after section of centred
565
+ columns. Symmetry as default.</p>
566
+ </div>
567
+ <div class="anti-row__fix">
568
+ <p class="anti-row__fix-label">Hallmark</p>
569
+ <p class="anti-row__fix-body">Bias the layout. Wide left margin, narrow right — or the reverse. Breaking
570
+ symmetry once is enough to register intent.</p>
571
+ </div>
572
+ </li>
573
+
574
+ <li class="anti-row">
575
+ <p class="anti-row__num tnum">04</p>
576
+ <div class="anti-row__slop">
577
+ <h3 class="anti-row__name">The icon-tile feature card.</h3>
578
+ <p class="anti-row__desc">Rounded rectangle, icon in a coloured square top-left, two-line heading,
579
+ three-line copy, optional "Learn more →". The universal template.</p>
580
+ </div>
581
+ <div class="anti-row__fix">
582
+ <p class="anti-row__fix-label">Hallmark</p>
583
+ <p class="anti-row__fix-body">If you need feature cards, let them be asymmetric — vary sizes, vary
584
+ alignments, pull the icon inline. Or drop the icon and lead with type.</p>
585
+ </div>
586
+ </li>
587
+
588
+ <li class="anti-row">
589
+ <p class="anti-row__num tnum">05</p>
590
+ <div class="anti-row__slop">
591
+ <h3 class="anti-row__name">The AI nav.</h3>
592
+ <p class="anti-row__desc">Wordmark hard-left, four inline links centred, CTA button hard-right, sticky on
593
+ scroll, hairline border-bottom. The shape every LLM ships.</p>
594
+ </div>
595
+ <div class="anti-row__fix">
596
+ <p class="anti-row__fix-label">Hallmark</p>
597
+ <p class="anti-row__fix-body">Pick a nav archetype that matches the page's genre — newspaper masthead,
598
+ terminal command bar, edge-aligned minimal. The nav should tell you what kind of site you're on.</p>
599
+ </div>
600
+ </li>
601
+
602
+ </ol>
603
+
604
+ </section>
605
+
606
+
607
+ <!-- 05 · FOUNDATIONS — eight compact cards in a 4×2 grid. Each
608
+ card holds a hand-drawn SVG icon, one-word title, and a single
609
+ line of description. Replaces the radio-tab Foundations panel
610
+ (preserved in <template id="section-05-archive-foundations-tabs">
611
+ below). -->
612
+ <section class="section reveal" style="--i:4" id="foundations" aria-labelledby="s5-foundations">
613
+ <header class="section__head">
614
+ <p class="section-label">
615
+ <span class="num">05</span><span class="divider">⁄</span><span>Foundations</span>
616
+ </p>
617
+ <h2 class="section__title" id="s5-foundations">
618
+ Foundations.
619
+ </h2>
620
+ </header>
621
+
622
+ <p class="found__intro">Eight rules that hold across every theme. None of them are settings.</p>
623
+
624
+ <ul class="found-cards" role="list">
625
+
626
+ <li class="found-card">
627
+ <span class="found-card__icon" aria-hidden="true">
628
+ <svg viewBox="0 0 48 48" fill="none" stroke-linecap="round" stroke-linejoin="round">
629
+ <text x="3" y="36" font-family="'Fraunces', 'Tiempos', serif" font-style="italic" font-size="34"
630
+ font-weight="500" fill="currentColor">A</text>
631
+ <text x="22" y="42" font-family="'Geist', 'Inter', sans-serif" font-size="22" font-weight="600"
632
+ fill="currentColor">a</text>
633
+ </svg>
634
+ </span>
635
+ <h3 class="found-card__name">Type</h3>
636
+ <p class="found-card__body">Pair a display face with a body face. Never one font doing both jobs.</p>
637
+ </li>
638
+
639
+ <li class="found-card">
640
+ <span class="found-card__icon" aria-hidden="true">
641
+ <svg viewBox="0 0 48 48" fill="currentColor">
642
+ <circle cx="9" cy="24" r="4.5" />
643
+ <circle cx="20" cy="24" r="4.5" opacity="0.7" />
644
+ <circle cx="31" cy="24" r="4.5" opacity="0.4" />
645
+ <circle cx="42" cy="24" r="4.5" fill="none" stroke="currentColor" stroke-width="1.5" />
646
+ </svg>
647
+ </span>
648
+ <h3 class="found-card__name">Colour</h3>
649
+ <p class="found-card__body">OKLCH palettes. One anchor hue. The accent stays under five percent.</p>
650
+ </li>
651
+
652
+ <li class="found-card">
653
+ <span class="found-card__icon" aria-hidden="true">
654
+ <svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round">
655
+ <line x1="4" y1="26" x2="44" y2="26" />
656
+ <line x1="8" y1="22" x2="8" y2="30" />
657
+ <line x1="16" y1="24" x2="16" y2="28" />
658
+ <line x1="24" y1="18" x2="24" y2="32" />
659
+ <line x1="32" y1="24" x2="32" y2="28" />
660
+ <line x1="40" y1="22" x2="40" y2="30" />
661
+ </svg>
662
+ </span>
663
+ <h3 class="found-card__name">Space</h3>
664
+ <p class="found-card__body">A named scale. Multiples of four. No arbitrary 17-pixel paddings.</p>
665
+ </li>
666
+
667
+ <li class="found-card">
668
+ <span class="found-card__icon" aria-hidden="true">
669
+ <svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"
670
+ stroke-linejoin="round">
671
+ <path d="M 6 32 Q 18 32 24 24 T 40 14" />
672
+ <path d="M 34 14 L 40 14 L 40 20" />
673
+ </svg>
674
+ </span>
675
+ <h3 class="found-card__name">Motion</h3>
676
+ <p class="found-card__body">Exponential ease-out. Reduced-motion alternative for every animation.</p>
677
+ </li>
678
+
679
+ <li class="found-card">
680
+ <span class="found-card__icon" aria-hidden="true">
681
+ <svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="2.4" stroke-linecap="round">
682
+ <path d="M 11 16 Q 7 19 7 24 Q 7 28 11 28" />
683
+ <path d="M 17 16 Q 13 19 13 24 Q 13 28 17 28" />
684
+ <path d="M 31 16 Q 27 19 27 24 Q 27 28 31 28" />
685
+ <path d="M 37 16 Q 33 19 33 24 Q 33 28 37 28" />
686
+ </svg>
687
+ </span>
688
+ <h3 class="found-card__name">Voice</h3>
689
+ <p class="found-card__body">Distinct register per theme. Never the SaaS-default neutral middle.</p>
690
+ </li>
691
+
692
+ <li class="found-card">
693
+ <span class="found-card__icon" aria-hidden="true">
694
+ <svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="1.5">
695
+ <rect x="6" y="12" width="14" height="26" />
696
+ <rect x="22" y="18" width="20" height="20" />
697
+ </svg>
698
+ </span>
699
+ <h3 class="found-card__name">Layout</h3>
700
+ <p class="found-card__body">Bias the page. Asymmetric is intentional. Centred everything is a tell.</p>
701
+ </li>
702
+
703
+ <li class="found-card">
704
+ <span class="found-card__icon" aria-hidden="true">
705
+ <svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-linecap="round">
706
+ <line x1="6" y1="14" x2="42" y2="14" stroke-width="3.5" />
707
+ <line x1="6" y1="25" x2="32" y2="25" stroke-width="2" />
708
+ <line x1="6" y1="36" x2="22" y2="36" stroke-width="1.2" />
709
+ </svg>
710
+ </span>
711
+ <h3 class="found-card__name">Hierarchy</h3>
712
+ <p class="found-card__body">Display, body, label. A weight ladder you can read in two seconds.</p>
713
+ </li>
714
+
715
+ <li class="found-card">
716
+ <span class="found-card__icon" aria-hidden="true">
717
+ <svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="1.5">
718
+ <rect x="6" y="6" width="36" height="36" />
719
+ <circle cx="24" cy="24" r="3" fill="currentColor" />
720
+ </svg>
721
+ </span>
722
+ <h3 class="found-card__name">Restraint</h3>
723
+ <p class="found-card__body">Better nothing than bad something. The strongest fail-state is silence.</p>
724
+ </li>
725
+
726
+ </ul>
727
+
728
+ </section>
729
+
730
+ <!-- DEPRECATED: original Section 05 (Foundations radio tabs) — replaced
731
+ by the 8-card grid above. Wrapped in <template> so the markup stays
732
+ in this file but doesn't render. To revert: change the opening
733
+ <template> to <section class="section reveal" style="--i:4"
734
+ aria-labelledby="s5-foundations"> and the closing </template> to
735
+ </section>, then remove the new 8-card section above. -->
736
+
737
+ <!-- 06 · WITH / WITHOUT HALLMARK — same prompt, two different outputs.
738
+ The "without" was generated by Sonnet 4.6 alone; the "with" by
739
+ Sonnet 4.6 with Hallmark loaded. Both are real outputs of the
740
+ same brief. -->
741
+ <section class="section reveal" style="--i:5" id="before-after" aria-labelledby="s-ba">
742
+ <header class="section__head">
743
+ <p class="section-label">
744
+ <span class="num">06</span><span class="divider">⁄</span><span>With / Without</span>
745
+ </p>
746
+ <h2 class="section__title" id="s-ba">
747
+ Same prompt. Two different outputs.
748
+ </h2>
749
+ </header>
750
+
751
+ <p class="ba__prompt" aria-label="The shared prompt"><span class="ba__prompt-mark">$</span> /hallmark build a landing page for a dev event launch.</p>
752
+
753
+ <div class="ba">
754
+ <figure class="ba__panel ba__panel--before">
755
+ <p class="ba__panel-label"><span class="ba__panel-tag">Sonnet 4.6, no Hallmark</span></p>
756
+ <span class="fig-corners ba__frame">
757
+ <span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
758
+ <img src="_tests/_thumbs/before-quiet-hour.png" alt="Generic AI-default landing page — purple-pink gradient hero, generic 'Discover natural wines' headline, ★★★★★ trust strip, 3-column feature cards" loading="lazy" decoding="async" width="1440" height="900" />
759
+ </span>
760
+ <figcaption class="ba__panel-cap">Default reach for the gradient. Generic stat strip, made-up Trustpilot rating, "10× faster" feature card.</figcaption>
761
+ </figure>
762
+
763
+ <figure class="ba__panel ba__panel--after">
764
+ <p class="ba__panel-label"><span class="ba__panel-tag ba__panel-tag--accent">Sonnet 4.6 + Hallmark</span></p>
765
+ <span class="fig-corners ba__frame">
766
+ <span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
767
+ <img src="_tests/_thumbs/after-quiet-hour.png" alt="A Hallmark output — editorial Lisbon dispatch, italic Fraunces display, real bottle plate with grape + region + tasting notes, no fabricated proof" loading="lazy" decoding="async" width="1440" height="900" />
768
+ </span>
769
+ <figcaption class="ba__panel-cap">Marquee Hero · Atelier · italic Fraunces. Real bottle, real grape, real region. No fabricated stats.</figcaption>
770
+ </figure>
771
+ </div>
772
+ </section>
773
+
774
+ <!-- 07 · INSTALL — one command, every harness -->
775
+ <section class="section reveal" style="--i:6" id="install" aria-labelledby="s6">
776
+ <header class="section__head">
777
+ <p class="section-label">
778
+ <span class="num">07</span><span class="divider">⁄</span><span>Install</span>
779
+ </p>
780
+ <h2 class="section__title" id="s6">
781
+ Install.
782
+ </h2>
783
+ </header>
784
+
785
+ <div class="install-pane">
786
+
787
+ <div class="install-pane__row install-pane__row--cmd">
788
+ <p class="install-pane__label"><span class="install-pane__step">I</span> Run</p>
789
+ <div class="install-pane__cmd" data-copy-source>
790
+ <span class="install-pane__prompt" aria-hidden="true">$</span>
791
+ <span class="install-pane__cmd-text" data-copy-text>npx skills add nutlope/hallmark</span>
792
+ <button class="install-pane__copy" type="button" data-copy-btn aria-label="Copy install command">
793
+ <span class="install-pane__copy-default">Copy</span>
794
+ <span class="install-pane__copy-done">Copied</span>
795
+ </button>
796
+ </div>
797
+ </div>
798
+
799
+ <div class="install-pane__row">
800
+ <p class="install-pane__label"><span class="install-pane__step">II</span> In</p>
801
+ <ul class="install-pane__harnesses">
802
+ <li class="harness"> <span class="harness__name">Claude Code</span>
803
+ <code class="harness__path">~/.claude/skills/hallmark/</code>
804
+ <span class="harness__status harness__status--ok">auto-detected</span>
805
+ </li>
806
+ <li class="harness"> <span class="harness__name">Cursor</span>
807
+ <code class="harness__path">.cursor/rules/hallmark.mdc</code>
808
+ <span class="harness__status harness__status--ok">auto-detected</span>
809
+ </li>
810
+ <li class="harness"> <span class="harness__name">Codex</span>
811
+ <code class="harness__path">~/.codex/skills/hallmark/</code>
812
+ <span class="harness__status harness__status--ok">auto-detected</span>
813
+ </li>
814
+ </ul>
815
+ </div>
816
+
817
+ <div class="install-pane__row">
818
+ <p class="install-pane__label"><span class="install-pane__step">III</span> Then</p>
819
+ <p class="install-pane__next">Ask your agent for a UI. <code>hallmark</code> attaches itself.</p>
820
+ </div>
821
+
822
+ </div>
823
+ </section>
824
+ <!-- FOOTER SLOT — archetype swaps per theme -->
825
+ <footer class="slot slot--foot reveal" data-slot="footer" style="--i:6" role="contentinfo" aria-label="Colophon">
826
+ </footer>
827
+
828
+ </main>
829
+
830
+ <!-- ─── Easter egg ─── revealed when the user spams T —— -->
831
+ <aside class="easter" data-easter-egg hidden role="dialog" aria-modal="true" aria-label="A note from Hallmark">
832
+ <div class="easter__panel">
833
+ <ol class="easter__lines" aria-live="polite">
834
+ <li class="easter__line easter__line--cmd"><span class="easter__prompt">$</span> hallmark.observe()</li>
835
+ <li class="easter__line easter__line--punchline" data-easter-punchline>
836
+ <span class="easter__arrow">&gt;</span> <span data-easter-line>theme connoisseur.</span><span
837
+ class="easter__cursor" aria-hidden="true"></span>
838
+ </li>
839
+ </ol>
840
+ <p class="easter__hint">
841
+ <span>back in a moment</span>
842
+ </p>
843
+ </div>
844
+ </aside>
845
+
846
+ <!-- ─────────── HERO ARCHETYPES ─────────── -->
847
+
848
+ <template id="hero-marquee">
849
+ <div class="hero hero--marquee">
850
+ <div class="hero__main">
851
+ <p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
852
+ <h1 class="hero__display" data-text="{{title}}">{{title}}</h1>
853
+ <p class="hero__lede">{{lede}}</p>
854
+ <div class="hero__cta">
855
+ <p class="label">{{ctaLabel}}</p>
856
+ <pre class="code"
857
+ data-copy-source><span class="prompt">$</span><span data-copy-text>npx skills add nutlope/hallmark</span><button class="code__copy" type="button" data-copy-btn aria-label="Copy install command"><span class="code__copy-default">Copy</span><span class="code__copy-done">Copied</span></button></pre>
858
+ </div>
859
+ </div>
860
+ <aside class="hero__moment" aria-hidden="true"></aside>
861
+ </div>
862
+ </template>
863
+
864
+ <template id="hero-split">
865
+ <div class="hero hero--split">
866
+ <div class="hero__col">
867
+ <p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
868
+ <h1 class="hero__display">{{title}}</h1>
869
+ <p class="hero__lede">{{lede}}</p>
870
+ </div>
871
+ <aside class="hero__proof">
872
+ <p class="label">{{proofLabel}}</p>
873
+ <p class="hero__proof-line">{{proofA}}</p>
874
+ <p class="hero__proof-line">{{proofB}}</p>
875
+ <p class="hero__proof-line">{{proofC}}</p>
876
+ <a href="#install" class="link">{{cta}} &rarr;</a>
877
+ </aside>
878
+ </div>
879
+ </template>
880
+
881
+ <template id="hero-stat-led">
882
+ <div class="hero hero--stat">
883
+ <div class="hero__main">
884
+ <p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
885
+ <span class="hero__stat tabular-nums">{{stat}}</span>
886
+ <p class="hero__qualifier">{{qualifier}}</p>
887
+ <p class="hero__lede">{{lede}}</p>
888
+ <a href="#install" class="link hero__link">{{cta}} &rarr;</a>
889
+ </div>
890
+ <aside class="hero__moment" aria-hidden="true"></aside>
891
+ </div>
892
+ </template>
893
+
894
+ <template id="hero-quote-led">
895
+ <div class="hero hero--quote">
896
+ <div class="hero__main">
897
+ <p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
898
+ <blockquote class="hero__quote">
899
+ <p>&ldquo;{{quote}}&rdquo;</p>
900
+ <footer class="hero__attrib">— {{attrib}}</footer>
901
+ </blockquote>
902
+ <p class="hero__lede">{{lede}}</p>
903
+ <a href="#install" class="link hero__link">{{cta}} &rarr;</a>
904
+ </div>
905
+ <aside class="hero__moment" aria-hidden="true"></aside>
906
+ </div>
907
+ </template>
908
+
909
+ <template id="hero-letter">
910
+ <div class="hero hero--letter">
911
+ <div class="hero__main">
912
+ <p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
913
+ <p class="hero__salutation">{{salutation}}</p>
914
+ <p class="hero__letter-body">{{letterBody}}</p>
915
+ <p class="hero__signoff">{{signoff}}<br><span class="hero__sign">— Hallmark</span></p>
916
+ </div>
917
+ <aside class="hero__moment" aria-hidden="true"></aside>
918
+ </div>
919
+ </template>
920
+
921
+
922
+
923
+
924
+ <!-- H9 — Bloom. Two-column hero with a layered watercolor + brushstroke
925
+ composition on the right: soft transparent SVG wash + oversized
926
+ italic wordmark + small geometric accents. Painterly, no chrome. -->
927
+ <template id="hero-bloom">
928
+ <div class="hero hero--bloom">
929
+ <div class="hero__copy">
930
+ <p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
931
+ <h1 class="hero__display hero__display--small">{{title}}</h1>
932
+ <p class="hero__lede">{{lede}}</p>
933
+ <div class="hero__cta">
934
+ <pre class="code"
935
+ data-copy-source><span class="prompt">$</span><span data-copy-text>npx skills add nutlope/hallmark</span><button class="code__copy" type="button" data-copy-btn aria-label="Copy install command"><span class="code__copy-default">Copy</span><span class="code__copy-done">Copied</span></button></pre>
936
+ </div>
937
+ </div>
938
+ <figure class="hero__bloom-stage" aria-hidden="true">
939
+ <svg class="hero__bloom-wash" viewBox="0 0 400 500" preserveAspectRatio="xMidYMid meet">
940
+ <defs>
941
+ <radialGradient id="bloomGrad" cx="0.42" cy="0.36" r="0.72">
942
+ <stop offset="0%" stop-color="currentColor" stop-opacity="0.85" />
943
+ <stop offset="55%" stop-color="currentColor" stop-opacity="0.45" />
944
+ <stop offset="100%" stop-color="currentColor" stop-opacity="0" />
945
+ </radialGradient>
946
+ </defs>
947
+ <path
948
+ d="M 80 60 Q 60 140 90 220 Q 50 280 80 360 Q 110 410 200 420 Q 320 440 340 360 Q 380 280 340 220 Q 380 130 320 80 Q 240 30 180 60 Q 130 30 80 60 Z"
949
+ fill="url(#bloomGrad)" />
950
+ </svg>
951
+ <span class="hero__bloom-glyph"><em>Hallmark.</em></span>
952
+ <span class="hero__bloom-dot" aria-hidden="true"></span>
953
+ <span class="hero__bloom-line" aria-hidden="true"></span>
954
+ <span class="hero__bloom-circle" aria-hidden="true"></span>
955
+ </figure>
956
+ </div>
957
+ </template>
958
+
959
+ <!-- H10 — Orbit. Two-column hero with concentric rings + a glowing
960
+ center dot. Slow rotation gives the page life without noise.
961
+ Reserved for atmospheric warm-glow themes (Halo). -->
962
+ <template id="hero-orbit">
963
+ <div class="hero hero--orbit">
964
+ <div class="hero__copy">
965
+ <p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
966
+ <h1 class="hero__display hero__display--small">{{title}}</h1>
967
+ <p class="hero__lede">{{lede}}</p>
968
+ <div class="hero__cta">
969
+ <pre class="code"
970
+ data-copy-source><span class="prompt">$</span><span data-copy-text>npx skills add nutlope/hallmark</span><button class="code__copy" type="button" data-copy-btn aria-label="Copy install command"><span class="code__copy-default">Copy</span><span class="code__copy-done">Copied</span></button></pre>
971
+ </div>
972
+ </div>
973
+ <figure class="hero__orbit-stage" aria-hidden="true">
974
+ <div class="hero__orbit-rings">
975
+ <svg viewBox="0 0 400 400" preserveAspectRatio="xMidYMid meet">
976
+ <g fill="none" stroke="currentColor" stroke-linecap="round">
977
+ <circle cx="200" cy="200" r="190" stroke-width="0.6" opacity="0.35" />
978
+ <circle cx="200" cy="200" r="155" stroke-width="0.8" opacity="0.5" />
979
+ <circle cx="200" cy="200" r="118" stroke-width="1" opacity="0.7" />
980
+ <circle cx="200" cy="200" r="82" stroke-width="1.4" opacity="0.85" />
981
+ <circle cx="200" cy="200" r="48" stroke-width="1.8" opacity="1" />
982
+ <line x1="200" y1="10" x2="200" y2="22" stroke-width="1.2" stroke="var(--color-accent)" />
983
+ </g>
984
+ </svg>
985
+ </div>
986
+ <span class="hero__orbit-dot pulse" aria-hidden="true"></span>
987
+ <div class="hero__orbit-rule"></div>
988
+ <p class="hero__orbit-spec">{{captionA}} · {{captionB}}</p>
989
+ </figure>
990
+ </div>
991
+ </template>
992
+
993
+ <!-- ─────────── FOOTER ARCHETYPES ─────────── -->
994
+
995
+ <!-- The COLOPHON — a single editorial footer for every theme. The
996
+ publisher's signature page traditionally doesn't change across
997
+ volumes; the structural variety lives in the body, not here.
998
+ Per-theme typography still re-renders this block. -->
999
+ <template id="footer-colophon">
1000
+ <div class="foot foot--colophon">
1001
+
1002
+ <div class="foot__masthead">
1003
+ <span class="foot__wordmark" aria-label="Hallmark"><span class="brand-mark brand-mark--lg" aria-hidden="true"><span class="brand-mark__slash">/</span><span class="brand-mark__name">hallmark</span></span></span>
1004
+ <span class="foot__version tnum">v1.0 · MMXXVI</span>
1005
+ </div>
1006
+
1007
+ <div class="foot__grid">
1008
+ <section class="foot__block">
1009
+ <p class="foot__label">Currently in</p>
1010
+ <p class="foot__value"><strong data-theme-current-foot>Specimen</strong></p>
1011
+ <p class="foot__hint">Press <kbd class="kbd">T</kbd> to cycle · <kbd class="kbd">R</kbd> to randomise.</p>
1012
+ </section>
1013
+
1014
+ <section class="foot__block">
1015
+ <p class="foot__label">In the catalog</p>
1016
+ <ul class="foot__stats">
1017
+ <li><span class="foot__stat-num tnum">22</span><span class="foot__stat-key">themes</span></li>
1018
+ <li><span class="foot__stat-num tnum">21</span><span class="foot__stat-key">macrostructures</span></li>
1019
+ <li><span class="foot__stat-num tnum">65</span><span class="foot__stat-key">slop-test gates</span></li>
1020
+ </ul>
1021
+ </section>
1022
+
1023
+ <section class="foot__block">
1024
+ <p class="foot__label">Read or take a copy</p>
1025
+ <ul class="foot__nav">
1026
+ <li><a class="link" href="https://github.com/nutlope/hallmark">Source on GitHub &rarr;</a></li>
1027
+ <li><a class="link" href="#install">Install command</a></li>
1028
+ <li><a class="link" href="#top">Back to top</a></li>
1029
+ </ul>
1030
+ </section>
1031
+ </div>
1032
+
1033
+ <p class="foot__base">
1034
+ Made by <a class="foot__powered-mark" href="https://www.together.ai" target="_blank" rel="noopener">Together&nbsp;AI</a>. MIT licensed.
1035
+ </p>
1036
+
1037
+ </div>
1038
+ </template>
1039
+
1040
+ <script type="module" src="js/main.js"></script>
1041
+ </body>
1042
+
1043
+ </html>