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,1087 @@
1
+ @import url("./tokens.css");
2
+
3
+ * { box-sizing: border-box; }
4
+ html, body { margin: 0; padding: 0; }
5
+
6
+ html {
7
+ font-family: var(--font-body);
8
+ color: var(--color-ink-0);
9
+ background: var(--color-paper-0);
10
+ -webkit-font-smoothing: antialiased;
11
+ text-rendering: optimizeLegibility;
12
+ }
13
+
14
+ body {
15
+ font-size: var(--text-base);
16
+ line-height: 1.55;
17
+ background:
18
+ radial-gradient(1200px 600px at 12% -10%, color-mix(in oklch, var(--color-accent-tint) 70%, transparent), transparent 60%),
19
+ radial-gradient(900px 500px at 88% 8%, color-mix(in oklch, var(--color-companion) 35%, transparent), transparent 55%),
20
+ var(--color-paper-0);
21
+ background-attachment: fixed;
22
+ }
23
+
24
+ ::selection { background: var(--color-accent); color: var(--color-paper-0); }
25
+
26
+ a { color: inherit; text-decoration: none; }
27
+
28
+ button, input, select { font: inherit; color: inherit; }
29
+
30
+ :focus-visible {
31
+ outline: 2px solid var(--color-focus);
32
+ outline-offset: 3px;
33
+ border-radius: var(--radius-sm);
34
+ }
35
+
36
+ /* ───────── shared layout ───────── */
37
+ .container {
38
+ width: 100%;
39
+ max-width: 1240px;
40
+ margin: 0 auto;
41
+ padding-inline: var(--space-xl);
42
+ }
43
+
44
+ .eyebrow {
45
+ font-family: var(--font-mono);
46
+ font-size: var(--text-xs);
47
+ letter-spacing: 0.08em;
48
+ text-transform: uppercase;
49
+ color: var(--color-ink-2);
50
+ display: inline-flex;
51
+ align-items: center;
52
+ gap: var(--space-xs);
53
+ }
54
+
55
+ .italic-accent {
56
+ font-family: var(--font-italic);
57
+ font-style: italic;
58
+ font-weight: 400;
59
+ letter-spacing: -0.01em;
60
+ }
61
+
62
+ /* ───────── nav · N5 Floating pill ───────── */
63
+ .nav {
64
+ position: fixed;
65
+ top: 18px;
66
+ left: 50%;
67
+ transform: translateX(-50%);
68
+ z-index: 50;
69
+ display: flex;
70
+ align-items: center;
71
+ gap: var(--space-md);
72
+ padding: 6px 8px 6px 18px;
73
+ background: color-mix(in oklch, var(--color-paper-0) 78%, transparent);
74
+ -webkit-backdrop-filter: blur(20px);
75
+ backdrop-filter: blur(20px);
76
+ border: var(--rule-soft);
77
+ border-radius: var(--radius-pill);
78
+ box-shadow: 0 1px 0 rgba(255, 255, 255, 0.6) inset, 0 8px 30px -12px rgba(20, 30, 80, 0.18);
79
+ font-size: var(--text-sm);
80
+ }
81
+
82
+ .nav__brand {
83
+ font-weight: 600;
84
+ letter-spacing: -0.01em;
85
+ display: flex;
86
+ align-items: center;
87
+ gap: 8px;
88
+ margin-right: var(--space-xs);
89
+ }
90
+
91
+ .nav__brand svg { display: block; }
92
+
93
+ .nav__links {
94
+ display: flex;
95
+ gap: 4px;
96
+ }
97
+
98
+ .nav__link {
99
+ padding: 8px 14px;
100
+ border-radius: var(--radius-pill);
101
+ color: var(--color-ink-1);
102
+ transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
103
+ }
104
+
105
+ .nav__link:hover { background: var(--color-paper-2); color: var(--color-ink-0); }
106
+ .nav__link.is-hover { background: var(--color-paper-2); color: var(--color-ink-0); }
107
+
108
+ .nav__cta {
109
+ padding: 8px 14px;
110
+ border-radius: var(--radius-pill);
111
+ background: var(--color-ink-0);
112
+ color: var(--color-paper-0);
113
+ font-weight: 500;
114
+ border: 1px solid var(--color-ink-0);
115
+ cursor: pointer;
116
+ transition: transform var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
117
+ }
118
+
119
+ .nav__cta:hover { background: var(--color-accent); border-color: var(--color-accent); transform: translateY(-1px); }
120
+ .nav__cta:active { transform: translateY(0); }
121
+
122
+ @media (max-width: 760px) {
123
+ .nav__links { display: none; }
124
+ .nav { padding: 6px 8px 6px 14px; }
125
+ }
126
+
127
+ /* ───────── hero · Marquee Hero ───────── */
128
+ .hero {
129
+ padding-top: 140px;
130
+ padding-bottom: var(--space-3xl);
131
+ position: relative;
132
+ overflow: clip;
133
+ }
134
+
135
+ .hero::before {
136
+ content: "";
137
+ position: absolute;
138
+ inset: 0;
139
+ background-image:
140
+ linear-gradient(to right, color-mix(in oklch, var(--color-ink-0) 6%, transparent) 1px, transparent 1px),
141
+ linear-gradient(to bottom, color-mix(in oklch, var(--color-ink-0) 6%, transparent) 1px, transparent 1px);
142
+ background-size: 64px 64px;
143
+ mask-image: radial-gradient(ellipse 80% 60% at 50% 35%, black 30%, transparent 70%);
144
+ -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 35%, black 30%, transparent 70%);
145
+ pointer-events: none;
146
+ }
147
+
148
+ .hero__live {
149
+ display: inline-flex;
150
+ align-items: center;
151
+ gap: 10px;
152
+ padding: 6px 14px 6px 12px;
153
+ border: var(--rule-soft);
154
+ background: var(--color-paper-0);
155
+ border-radius: var(--radius-pill);
156
+ font-family: var(--font-mono);
157
+ font-size: var(--text-xs);
158
+ color: var(--color-ink-1);
159
+ }
160
+
161
+ .hero__live .dot {
162
+ width: 8px;
163
+ height: 8px;
164
+ border-radius: 999px;
165
+ background: var(--color-success);
166
+ box-shadow: 0 0 0 0 color-mix(in oklch, var(--color-success) 60%, transparent);
167
+ animation: pulse 1800ms var(--ease-in-out) infinite;
168
+ }
169
+
170
+ @keyframes pulse {
171
+ 0% { box-shadow: 0 0 0 0 color-mix(in oklch, var(--color-success) 60%, transparent); }
172
+ 70% { box-shadow: 0 0 0 10px color-mix(in oklch, var(--color-success) 0%, transparent); }
173
+ 100% { box-shadow: 0 0 0 0 color-mix(in oklch, var(--color-success) 0%, transparent); }
174
+ }
175
+
176
+ .hero__layout {
177
+ display: grid;
178
+ grid-template-columns: minmax(0, 1.45fr) minmax(0, 1fr);
179
+ gap: var(--space-3xl);
180
+ align-items: center;
181
+ margin-top: var(--space-xl);
182
+ }
183
+
184
+ @media (max-width: 980px) {
185
+ .hero__layout { grid-template-columns: 1fr; gap: var(--space-2xl); }
186
+ }
187
+
188
+ .hero__h1 {
189
+ font-family: var(--font-display);
190
+ font-weight: 600;
191
+ font-size: var(--text-5xl);
192
+ line-height: 0.96;
193
+ letter-spacing: -0.03em;
194
+ margin: 0.4em 0 0.2em;
195
+ max-width: 13ch;
196
+ }
197
+
198
+ .hero__h1 .italic-accent {
199
+ color: var(--color-accent);
200
+ font-weight: 400;
201
+ }
202
+
203
+ .hero__sub {
204
+ font-size: var(--text-md);
205
+ color: var(--color-ink-1);
206
+ max-width: 46ch;
207
+ margin: 0 0 var(--space-xl);
208
+ line-height: 1.5;
209
+ }
210
+
211
+ .hero__ctas {
212
+ display: flex;
213
+ gap: var(--space-sm);
214
+ align-items: center;
215
+ flex-wrap: wrap;
216
+ }
217
+
218
+ .btn {
219
+ display: inline-flex;
220
+ align-items: center;
221
+ gap: 8px;
222
+ padding: 14px 22px;
223
+ border-radius: var(--radius-pill);
224
+ font-weight: 500;
225
+ font-size: var(--text-base);
226
+ border: 1px solid transparent;
227
+ cursor: pointer;
228
+ transition: transform var(--dur-fast) var(--ease-out),
229
+ background var(--dur-fast) var(--ease-out),
230
+ border-color var(--dur-fast) var(--ease-out),
231
+ box-shadow var(--dur-fast) var(--ease-out);
232
+ position: relative;
233
+ isolation: isolate;
234
+ }
235
+
236
+ .btn--primary {
237
+ background: var(--color-ink-0);
238
+ color: var(--color-paper-0);
239
+ border-color: var(--color-ink-0);
240
+ box-shadow: 0 1px 0 rgba(255, 255, 255, 0.16) inset, 0 8px 24px -10px rgba(0, 10, 60, 0.4);
241
+ }
242
+
243
+ .btn--primary:hover { background: var(--color-accent); border-color: var(--color-accent); transform: translateY(-1px); }
244
+ .btn--primary:active { transform: translateY(0); }
245
+
246
+ .btn--ghost {
247
+ background: transparent;
248
+ color: var(--color-ink-0);
249
+ border-color: color-mix(in oklch, var(--color-ink-0) 16%, transparent);
250
+ }
251
+
252
+ .btn--ghost:hover { background: var(--color-paper-2); border-color: color-mix(in oklch, var(--color-ink-0) 22%, transparent); }
253
+
254
+ .btn[disabled] { opacity: 0.5; cursor: not-allowed; transform: none; }
255
+
256
+ .hero__fineprint {
257
+ margin-top: var(--space-md);
258
+ font-family: var(--font-mono);
259
+ font-size: var(--text-xs);
260
+ color: var(--color-ink-2);
261
+ display: flex;
262
+ gap: var(--space-md);
263
+ flex-wrap: wrap;
264
+ }
265
+
266
+ .hero__fineprint span::before { content: "·"; margin-right: var(--space-md); color: var(--color-ink-3); }
267
+ .hero__fineprint span:first-child::before { content: ""; margin: 0; }
268
+
269
+ /* live invoice card · Tier-A pure-CSS art */
270
+ .invoice {
271
+ background: var(--color-paper-0);
272
+ border: var(--rule-soft);
273
+ border-radius: var(--radius-lg);
274
+ padding: var(--space-lg);
275
+ box-shadow:
276
+ 0 1px 0 rgba(255, 255, 255, 0.7) inset,
277
+ 0 24px 60px -28px rgba(20, 30, 80, 0.25),
278
+ 0 4px 12px -4px rgba(20, 30, 80, 0.08);
279
+ font-family: var(--font-mono);
280
+ font-size: var(--text-sm);
281
+ position: relative;
282
+ transform: rotate(0.5deg);
283
+ max-width: 420px;
284
+ margin-left: auto;
285
+ }
286
+
287
+ .invoice::before {
288
+ content: "";
289
+ position: absolute;
290
+ inset: -8px;
291
+ border: 1px dashed color-mix(in oklch, var(--color-ink-0) 8%, transparent);
292
+ border-radius: calc(var(--radius-lg) + 8px);
293
+ pointer-events: none;
294
+ }
295
+
296
+ .invoice__head {
297
+ display: flex;
298
+ justify-content: space-between;
299
+ align-items: center;
300
+ padding-bottom: var(--space-sm);
301
+ border-bottom: var(--rule-hair);
302
+ }
303
+
304
+ .invoice__title { font-weight: 600; color: var(--color-ink-0); }
305
+
306
+ .invoice__tag {
307
+ font-size: 10px;
308
+ letter-spacing: 0.1em;
309
+ text-transform: uppercase;
310
+ color: var(--color-success);
311
+ background: color-mix(in oklch, var(--color-success) 18%, transparent);
312
+ padding: 3px 8px;
313
+ border-radius: var(--radius-pill);
314
+ }
315
+
316
+ .invoice__rows {
317
+ display: flex;
318
+ flex-direction: column;
319
+ gap: 8px;
320
+ padding: var(--space-sm) 0;
321
+ }
322
+
323
+ .invoice__row {
324
+ display: flex;
325
+ justify-content: space-between;
326
+ font-size: var(--text-xs);
327
+ color: var(--color-ink-1);
328
+ }
329
+
330
+ .invoice__row strong { color: var(--color-ink-0); font-weight: 500; }
331
+
332
+ .invoice__total {
333
+ display: flex;
334
+ justify-content: space-between;
335
+ align-items: baseline;
336
+ padding-top: var(--space-sm);
337
+ border-top: var(--rule-hair);
338
+ font-size: var(--text-sm);
339
+ }
340
+
341
+ .invoice__total .num {
342
+ font-family: var(--font-display);
343
+ font-size: var(--text-xl);
344
+ font-weight: 600;
345
+ color: var(--color-ink-0);
346
+ letter-spacing: -0.01em;
347
+ }
348
+
349
+ .invoice__bar {
350
+ height: 6px;
351
+ background: var(--color-paper-3);
352
+ border-radius: var(--radius-pill);
353
+ margin-top: var(--space-md);
354
+ overflow: hidden;
355
+ }
356
+
357
+ .invoice__bar > i {
358
+ display: block;
359
+ height: 100%;
360
+ width: 64%;
361
+ background: linear-gradient(90deg, var(--color-accent), var(--color-companion));
362
+ border-radius: inherit;
363
+ transition: width var(--dur-slow) var(--ease-out);
364
+ }
365
+
366
+ /* hero marquee strip */
367
+ .hero__marquee {
368
+ margin-top: var(--space-3xl);
369
+ border-top: var(--rule-hair);
370
+ border-bottom: var(--rule-hair);
371
+ padding: var(--space-md) 0;
372
+ overflow: hidden;
373
+ position: relative;
374
+ -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
375
+ mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
376
+ }
377
+
378
+ .hero__marquee__track {
379
+ display: flex;
380
+ gap: var(--space-3xl);
381
+ animation: marquee 38s linear infinite;
382
+ width: max-content;
383
+ font-family: var(--font-mono);
384
+ font-size: var(--text-sm);
385
+ color: var(--color-ink-2);
386
+ text-transform: uppercase;
387
+ letter-spacing: 0.18em;
388
+ }
389
+
390
+ .hero__marquee__track span { display: inline-flex; align-items: center; gap: var(--space-md); }
391
+ .hero__marquee__track span::after { content: "✦"; color: var(--color-accent); }
392
+
393
+ @keyframes marquee {
394
+ to { transform: translateX(-50%); }
395
+ }
396
+
397
+ @media (prefers-reduced-motion: reduce) {
398
+ .hero__marquee__track { animation: none; }
399
+ }
400
+
401
+ /* ───────── logos strip ───────── */
402
+ .logos {
403
+ padding: var(--space-2xl) 0;
404
+ }
405
+
406
+ .logos__label {
407
+ text-align: center;
408
+ font-family: var(--font-mono);
409
+ font-size: var(--text-xs);
410
+ text-transform: uppercase;
411
+ letter-spacing: 0.16em;
412
+ color: var(--color-ink-2);
413
+ margin-bottom: var(--space-lg);
414
+ }
415
+
416
+ .logos__row {
417
+ display: grid;
418
+ grid-template-columns: repeat(6, 1fr);
419
+ gap: var(--space-xl);
420
+ align-items: center;
421
+ opacity: 0.62;
422
+ }
423
+
424
+ .logos__row > div {
425
+ font-family: var(--font-display);
426
+ font-weight: 600;
427
+ font-size: var(--text-md);
428
+ letter-spacing: -0.02em;
429
+ text-align: center;
430
+ color: var(--color-ink-1);
431
+ }
432
+
433
+ .logos__row .l-1 { font-family: var(--font-italic); font-style: italic; font-weight: 400; }
434
+ .logos__row .l-2 { font-family: var(--font-mono); font-weight: 500; text-transform: lowercase; letter-spacing: -0.02em; }
435
+ .logos__row .l-3 { font-weight: 700; letter-spacing: -0.05em; }
436
+ .logos__row .l-4 { font-weight: 300; letter-spacing: 0.3em; text-transform: uppercase; font-size: var(--text-sm); }
437
+ .logos__row .l-5 { font-weight: 800; }
438
+ .logos__row .l-6 { font-weight: 500; font-style: italic; }
439
+
440
+ @media (max-width: 760px) {
441
+ .logos__row { grid-template-columns: repeat(3, 1fr); row-gap: var(--space-lg); }
442
+ }
443
+
444
+ /* ───────── workbench / live demo ───────── */
445
+ .workbench {
446
+ padding: var(--space-4xl) 0 var(--space-3xl);
447
+ }
448
+
449
+ .section-head {
450
+ display: grid;
451
+ grid-template-columns: 1fr 1fr;
452
+ gap: var(--space-2xl);
453
+ align-items: end;
454
+ margin-bottom: var(--space-2xl);
455
+ }
456
+
457
+ @media (max-width: 760px) {
458
+ .section-head { grid-template-columns: 1fr; gap: var(--space-md); }
459
+ }
460
+
461
+ .section-head__title {
462
+ font-family: var(--font-display);
463
+ font-size: var(--text-3xl);
464
+ font-weight: 600;
465
+ letter-spacing: -0.025em;
466
+ line-height: 1.05;
467
+ margin: var(--space-sm) 0 0;
468
+ }
469
+
470
+ .section-head__title em { font-family: var(--font-italic); font-weight: 400; color: var(--color-accent); font-style: italic; }
471
+
472
+ .section-head__desc {
473
+ font-size: var(--text-md);
474
+ color: var(--color-ink-1);
475
+ max-width: 50ch;
476
+ }
477
+
478
+ .bench {
479
+ display: grid;
480
+ grid-template-columns: 280px 1fr;
481
+ background: var(--color-paper-0);
482
+ border: var(--rule-soft);
483
+ border-radius: var(--radius-xl);
484
+ overflow: hidden;
485
+ box-shadow: 0 30px 80px -40px rgba(20, 30, 80, 0.2);
486
+ }
487
+
488
+ @media (max-width: 880px) {
489
+ .bench { grid-template-columns: 1fr; }
490
+ }
491
+
492
+ .bench__rail {
493
+ padding: var(--space-lg);
494
+ border-right: var(--rule-hair);
495
+ background: var(--color-paper-1);
496
+ }
497
+
498
+ @media (max-width: 880px) {
499
+ .bench__rail { border-right: 0; border-bottom: var(--rule-hair); }
500
+ }
501
+
502
+ .bench__brand {
503
+ display: flex;
504
+ align-items: center;
505
+ gap: 10px;
506
+ font-weight: 600;
507
+ margin-bottom: var(--space-lg);
508
+ }
509
+
510
+ .bench__nav { display: flex; flex-direction: column; gap: 2px; font-size: var(--text-sm); }
511
+
512
+ .bench__navitem {
513
+ padding: 8px 12px;
514
+ border-radius: var(--radius-md);
515
+ color: var(--color-ink-1);
516
+ display: flex;
517
+ align-items: center;
518
+ gap: 10px;
519
+ cursor: pointer;
520
+ transition: background var(--dur-fast) var(--ease-out);
521
+ }
522
+
523
+ .bench__navitem:hover { background: var(--color-paper-2); }
524
+ .bench__navitem[aria-current="page"] { background: var(--color-paper-2); color: var(--color-ink-0); font-weight: 500; }
525
+
526
+ .bench__navitem .glyph { width: 14px; height: 14px; flex: none; opacity: 0.8; }
527
+
528
+ .bench__main { padding: var(--space-lg); display: flex; flex-direction: column; gap: var(--space-lg); }
529
+
530
+ .bench__statrow { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-md); }
531
+
532
+ @media (max-width: 580px) { .bench__statrow { grid-template-columns: 1fr; } }
533
+
534
+ .bench__stat {
535
+ background: var(--color-paper-1);
536
+ padding: var(--space-md);
537
+ border-radius: var(--radius-md);
538
+ border: var(--rule-hair);
539
+ }
540
+
541
+ .bench__stat .label {
542
+ font-family: var(--font-mono);
543
+ font-size: 10px;
544
+ letter-spacing: 0.12em;
545
+ text-transform: uppercase;
546
+ color: var(--color-ink-2);
547
+ }
548
+
549
+ .bench__stat .value {
550
+ font-family: var(--font-display);
551
+ font-size: var(--text-xl);
552
+ font-weight: 600;
553
+ letter-spacing: -0.02em;
554
+ margin-top: 4px;
555
+ display: flex;
556
+ align-items: baseline;
557
+ gap: 6px;
558
+ }
559
+
560
+ .bench__stat .delta {
561
+ font-family: var(--font-mono);
562
+ font-size: var(--text-xs);
563
+ color: var(--color-success);
564
+ background: color-mix(in oklch, var(--color-success) 14%, transparent);
565
+ padding: 2px 6px;
566
+ border-radius: var(--radius-pill);
567
+ }
568
+
569
+ .bench__chart {
570
+ background: var(--color-paper-1);
571
+ border-radius: var(--radius-md);
572
+ border: var(--rule-hair);
573
+ padding: var(--space-lg);
574
+ position: relative;
575
+ min-height: 240px;
576
+ }
577
+
578
+ .bench__chart h4 {
579
+ margin: 0 0 var(--space-sm);
580
+ font-size: var(--text-sm);
581
+ font-weight: 500;
582
+ color: var(--color-ink-1);
583
+ display: flex;
584
+ justify-content: space-between;
585
+ }
586
+
587
+ .bench__chart h4 .live {
588
+ font-family: var(--font-mono);
589
+ font-size: var(--text-xs);
590
+ color: var(--color-success);
591
+ display: inline-flex;
592
+ align-items: center;
593
+ gap: 6px;
594
+ }
595
+
596
+ .bench__chart h4 .live::before {
597
+ content: "";
598
+ width: 6px;
599
+ height: 6px;
600
+ border-radius: 999px;
601
+ background: var(--color-success);
602
+ }
603
+
604
+ .bench__chart svg { width: 100%; height: auto; display: block; }
605
+
606
+ .bench__chart .grid line { stroke: color-mix(in oklch, var(--color-ink-0) 6%, transparent); stroke-width: 1; }
607
+ .bench__chart .area { fill: url(#area-grad); }
608
+ .bench__chart .line { fill: none; stroke: var(--color-accent); stroke-width: 2.4; stroke-linejoin: round; stroke-linecap: round; }
609
+ .bench__chart .dot {
610
+ fill: var(--color-paper-0);
611
+ stroke: var(--color-accent);
612
+ stroke-width: 2;
613
+ filter: drop-shadow(0 4px 10px rgba(60, 30, 220, 0.25));
614
+ }
615
+
616
+ /* ───────── stats triplet ───────── */
617
+ .stats {
618
+ padding: var(--space-3xl) 0;
619
+ }
620
+
621
+ .stats__grid {
622
+ display: grid;
623
+ grid-template-columns: repeat(3, 1fr);
624
+ gap: var(--space-md);
625
+ margin-top: var(--space-xl);
626
+ }
627
+
628
+ @media (max-width: 760px) { .stats__grid { grid-template-columns: 1fr; } }
629
+
630
+ .stats__card {
631
+ padding: var(--space-2xl) var(--space-xl);
632
+ background: var(--color-paper-0);
633
+ border: var(--rule-soft);
634
+ border-radius: var(--radius-lg);
635
+ position: relative;
636
+ overflow: hidden;
637
+ }
638
+
639
+ .stats__card:nth-child(1) { background: linear-gradient(160deg, var(--color-accent-tint), var(--color-paper-0) 60%); }
640
+ .stats__card:nth-child(2) { background: linear-gradient(160deg, color-mix(in oklch, var(--color-companion) 35%, var(--color-paper-0)), var(--color-paper-0) 60%); }
641
+ .stats__card:nth-child(3) { background: linear-gradient(160deg, color-mix(in oklch, var(--color-warning) 25%, var(--color-paper-0)), var(--color-paper-0) 60%); }
642
+
643
+ .stats__num {
644
+ font-family: var(--font-display);
645
+ font-size: clamp(2.8rem, 6vw, 4.5rem);
646
+ font-weight: 600;
647
+ letter-spacing: -0.04em;
648
+ line-height: 1;
649
+ display: inline-flex;
650
+ align-items: baseline;
651
+ }
652
+
653
+ .stats__num small {
654
+ font-size: 0.5em;
655
+ font-weight: 500;
656
+ color: var(--color-ink-1);
657
+ margin-left: 4px;
658
+ }
659
+
660
+ .stats__label {
661
+ font-family: var(--font-mono);
662
+ text-transform: uppercase;
663
+ letter-spacing: 0.12em;
664
+ font-size: var(--text-xs);
665
+ color: var(--color-ink-1);
666
+ margin-top: var(--space-md);
667
+ }
668
+
669
+ .stats__note {
670
+ margin-top: var(--space-sm);
671
+ font-size: var(--text-sm);
672
+ color: var(--color-ink-1);
673
+ max-width: 28ch;
674
+ }
675
+
676
+ /* ───────── three feature cards ───────── */
677
+ .features {
678
+ padding: var(--space-4xl) 0 var(--space-3xl);
679
+ }
680
+
681
+ .features__grid {
682
+ display: grid;
683
+ grid-template-columns: repeat(3, 1fr);
684
+ gap: var(--space-md);
685
+ margin-top: var(--space-xl);
686
+ }
687
+
688
+ @media (max-width: 880px) { .features__grid { grid-template-columns: 1fr; } }
689
+
690
+ .feature {
691
+ background: var(--color-paper-0);
692
+ border: var(--rule-soft);
693
+ border-radius: var(--radius-lg);
694
+ padding: var(--space-xl);
695
+ display: flex;
696
+ flex-direction: column;
697
+ gap: var(--space-md);
698
+ transition: transform var(--dur-mid) var(--ease-out), box-shadow var(--dur-mid) var(--ease-out);
699
+ transform-style: preserve-3d;
700
+ will-change: transform;
701
+ }
702
+
703
+ .feature:hover {
704
+ box-shadow: 0 20px 60px -30px rgba(40, 30, 120, 0.28);
705
+ }
706
+
707
+ .feature__art {
708
+ height: 180px;
709
+ border-radius: var(--radius-md);
710
+ background: var(--color-paper-1);
711
+ border: var(--rule-hair);
712
+ position: relative;
713
+ overflow: hidden;
714
+ }
715
+
716
+ /* Feature 1 — meter / counter */
717
+ .art-meter { background: linear-gradient(180deg, var(--color-paper-0), var(--color-paper-1)); }
718
+ .art-meter::before {
719
+ content: "";
720
+ position: absolute;
721
+ inset: 22px;
722
+ border: var(--rule-soft);
723
+ border-radius: var(--radius-md);
724
+ background:
725
+ repeating-linear-gradient(90deg, transparent 0 22px, color-mix(in oklch, var(--color-ink-0) 6%, transparent) 22px 23px);
726
+ }
727
+ .art-meter::after {
728
+ content: "1,247 / sec";
729
+ position: absolute;
730
+ left: 50%;
731
+ top: 50%;
732
+ transform: translate(-50%, -50%);
733
+ font-family: var(--font-mono);
734
+ font-size: var(--text-md);
735
+ font-weight: 600;
736
+ letter-spacing: -0.02em;
737
+ color: var(--color-accent);
738
+ background: var(--color-paper-0);
739
+ padding: 6px 12px;
740
+ border-radius: var(--radius-pill);
741
+ border: var(--rule-soft);
742
+ }
743
+
744
+ /* Feature 2 — pricing tiers visualisation */
745
+ .art-tiers { padding: 22px; display: flex; align-items: end; gap: 10px; height: 180px; }
746
+ .art-tiers > i {
747
+ flex: 1;
748
+ background: linear-gradient(180deg, var(--color-companion), color-mix(in oklch, var(--color-companion) 50%, var(--color-paper-1)));
749
+ border-radius: var(--radius-sm);
750
+ border: var(--rule-hair);
751
+ }
752
+ .art-tiers > i:nth-child(1) { height: 35%; }
753
+ .art-tiers > i:nth-child(2) { height: 50%; }
754
+ .art-tiers > i:nth-child(3) { height: 70%; background: linear-gradient(180deg, var(--color-accent), var(--color-accent-soft)); }
755
+ .art-tiers > i:nth-child(4) { height: 90%; }
756
+ .art-tiers > i:nth-child(5) { height: 60%; }
757
+
758
+ /* Feature 3 — invoice stack */
759
+ .art-invoice {
760
+ padding: 22px;
761
+ }
762
+ .art-invoice .sheet {
763
+ position: absolute;
764
+ width: 70%;
765
+ height: 60%;
766
+ background: var(--color-paper-0);
767
+ border: var(--rule-soft);
768
+ border-radius: var(--radius-md);
769
+ padding: 14px;
770
+ font-family: var(--font-mono);
771
+ font-size: 10px;
772
+ color: var(--color-ink-2);
773
+ box-shadow: 0 6px 16px -8px rgba(20, 30, 80, 0.2);
774
+ }
775
+ .art-invoice .sheet:nth-child(1) { top: 20%; left: 14%; transform: rotate(-4deg); z-index: 1; }
776
+ .art-invoice .sheet:nth-child(2) { top: 16%; left: 22%; transform: rotate(2deg); z-index: 2; }
777
+ .art-invoice .sheet:nth-child(3) { top: 12%; left: 30%; transform: rotate(-1deg); z-index: 3; background: var(--color-accent-tint); }
778
+ .art-invoice .sheet b { display: block; color: var(--color-ink-0); font-size: 12px; margin-bottom: 6px; font-family: var(--font-display); font-weight: 600; }
779
+ .art-invoice .sheet em { font-style: normal; color: var(--color-accent); font-weight: 600; font-size: 14px; }
780
+
781
+ .feature__title {
782
+ font-family: var(--font-display);
783
+ font-size: var(--text-lg);
784
+ font-weight: 600;
785
+ letter-spacing: -0.02em;
786
+ margin: 0;
787
+ }
788
+
789
+ .feature__desc {
790
+ font-size: var(--text-sm);
791
+ color: var(--color-ink-1);
792
+ margin: 0;
793
+ line-height: 1.55;
794
+ }
795
+
796
+ .feature__link {
797
+ margin-top: auto;
798
+ font-family: var(--font-mono);
799
+ font-size: var(--text-xs);
800
+ text-transform: uppercase;
801
+ letter-spacing: 0.12em;
802
+ color: var(--color-accent);
803
+ display: inline-flex;
804
+ align-items: center;
805
+ gap: 6px;
806
+ }
807
+
808
+ .feature__link::after {
809
+ content: "→";
810
+ transition: transform var(--dur-fast) var(--ease-out);
811
+ }
812
+
813
+ .feature:hover .feature__link::after { transform: translateX(3px); }
814
+
815
+ /* ───────── pricing ───────── */
816
+ .pricing {
817
+ padding: var(--space-4xl) 0 var(--space-3xl);
818
+ }
819
+
820
+ .pricing__head { text-align: center; margin-bottom: var(--space-xl); }
821
+
822
+ .pricing__toggle {
823
+ margin: var(--space-md) auto 0;
824
+ display: inline-flex;
825
+ padding: 4px;
826
+ background: var(--color-paper-2);
827
+ border: var(--rule-soft);
828
+ border-radius: var(--radius-pill);
829
+ }
830
+
831
+ .pricing__toggle button {
832
+ border: 0;
833
+ background: transparent;
834
+ padding: 8px 16px;
835
+ border-radius: var(--radius-pill);
836
+ font-size: var(--text-sm);
837
+ cursor: pointer;
838
+ color: var(--color-ink-1);
839
+ transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
840
+ }
841
+
842
+ .pricing__toggle button[aria-pressed="true"] { background: var(--color-paper-0); color: var(--color-ink-0); font-weight: 500; box-shadow: 0 2px 6px -2px rgba(20, 30, 80, 0.14); }
843
+
844
+ .pricing__toggle .save {
845
+ font-family: var(--font-mono);
846
+ font-size: 10px;
847
+ text-transform: uppercase;
848
+ letter-spacing: 0.1em;
849
+ color: var(--color-success);
850
+ margin-left: 6px;
851
+ }
852
+
853
+ .pricing__grid {
854
+ display: grid;
855
+ grid-template-columns: repeat(3, 1fr);
856
+ gap: var(--space-md);
857
+ margin-top: var(--space-xl);
858
+ }
859
+
860
+ @media (max-width: 980px) { .pricing__grid { grid-template-columns: 1fr; } }
861
+
862
+ .tier {
863
+ background: var(--color-paper-0);
864
+ border: var(--rule-soft);
865
+ border-radius: var(--radius-lg);
866
+ padding: var(--space-xl);
867
+ display: flex;
868
+ flex-direction: column;
869
+ gap: var(--space-md);
870
+ position: relative;
871
+ }
872
+
873
+ .tier--featured {
874
+ background: var(--color-ink-0);
875
+ color: var(--color-paper-0);
876
+ border-color: var(--color-ink-0);
877
+ transform: scale(1.02);
878
+ box-shadow: 0 24px 60px -30px rgba(0, 0, 60, 0.5);
879
+ }
880
+
881
+ .tier--featured .tier__price { color: var(--color-paper-0); }
882
+ .tier--featured .tier__features li { color: color-mix(in oklch, var(--color-paper-0) 75%, transparent); }
883
+ .tier--featured .tier__features li::before { color: var(--color-companion); }
884
+ .tier--featured .btn--primary { background: var(--color-companion); color: var(--color-ink-0); border-color: var(--color-companion); }
885
+ .tier--featured .btn--primary:hover { background: var(--color-paper-0); border-color: var(--color-paper-0); }
886
+
887
+ .tier__badge {
888
+ position: absolute;
889
+ top: -12px;
890
+ left: var(--space-xl);
891
+ font-family: var(--font-mono);
892
+ font-size: 10px;
893
+ letter-spacing: 0.12em;
894
+ text-transform: uppercase;
895
+ background: var(--color-companion);
896
+ color: var(--color-ink-0);
897
+ padding: 4px 10px;
898
+ border-radius: var(--radius-pill);
899
+ }
900
+
901
+ .tier__name {
902
+ font-family: var(--font-mono);
903
+ font-size: var(--text-xs);
904
+ text-transform: uppercase;
905
+ letter-spacing: 0.12em;
906
+ }
907
+
908
+ .tier__price {
909
+ font-family: var(--font-display);
910
+ font-size: var(--text-3xl);
911
+ font-weight: 600;
912
+ letter-spacing: -0.03em;
913
+ display: flex;
914
+ align-items: baseline;
915
+ gap: 4px;
916
+ }
917
+
918
+ .tier__price small {
919
+ font-size: 0.4em;
920
+ font-weight: 400;
921
+ color: var(--color-ink-2);
922
+ }
923
+
924
+ .tier--featured .tier__price small { color: color-mix(in oklch, var(--color-paper-0) 70%, transparent); }
925
+
926
+ .tier__desc { font-size: var(--text-sm); color: var(--color-ink-1); margin-top: -4px; }
927
+ .tier--featured .tier__desc { color: color-mix(in oklch, var(--color-paper-0) 75%, transparent); }
928
+
929
+ .tier__features { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; font-size: var(--text-sm); }
930
+
931
+ .tier__features li { padding-left: 22px; position: relative; color: var(--color-ink-1); }
932
+ .tier__features li::before {
933
+ content: "✓";
934
+ position: absolute;
935
+ left: 0;
936
+ top: 0;
937
+ color: var(--color-accent);
938
+ font-weight: 700;
939
+ }
940
+
941
+ /* ───────── testimonial ───────── */
942
+ .testimonial { padding: var(--space-3xl) 0; }
943
+
944
+ .testimonial__quote {
945
+ font-family: var(--font-italic);
946
+ font-style: italic;
947
+ font-weight: 400;
948
+ font-size: clamp(1.6rem, 3.4vw, 2.6rem);
949
+ line-height: 1.25;
950
+ letter-spacing: -0.015em;
951
+ max-width: 22ch;
952
+ margin: 0 auto;
953
+ text-align: center;
954
+ }
955
+
956
+ .testimonial__quote::before { content: "\201C"; color: var(--color-accent); margin-right: 4px; }
957
+ .testimonial__quote::after { content: "\201D"; color: var(--color-accent); }
958
+
959
+ .testimonial__byline {
960
+ margin-top: var(--space-xl);
961
+ display: flex;
962
+ flex-direction: column;
963
+ align-items: center;
964
+ gap: 2px;
965
+ font-size: var(--text-sm);
966
+ color: var(--color-ink-1);
967
+ }
968
+
969
+ .testimonial__byline strong { color: var(--color-ink-0); font-weight: 500; }
970
+ .testimonial__byline span { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-ink-2); text-transform: uppercase; letter-spacing: 0.1em; }
971
+
972
+ /* ───────── CTA ───────── */
973
+ .cta {
974
+ padding: var(--space-3xl) 0 var(--space-4xl);
975
+ }
976
+
977
+ .cta__panel {
978
+ position: relative;
979
+ background: var(--color-ink-0);
980
+ color: var(--color-paper-0);
981
+ border-radius: var(--radius-xl);
982
+ padding: var(--space-4xl) var(--space-2xl);
983
+ text-align: center;
984
+ overflow: hidden;
985
+ isolation: isolate;
986
+ }
987
+
988
+ .cta__panel::before {
989
+ content: "";
990
+ position: absolute;
991
+ inset: 0;
992
+ background:
993
+ radial-gradient(600px 200px at 20% 110%, color-mix(in oklch, var(--color-accent) 60%, transparent), transparent 70%),
994
+ radial-gradient(500px 220px at 90% -10%, color-mix(in oklch, var(--color-companion) 50%, transparent), transparent 70%);
995
+ z-index: -1;
996
+ }
997
+
998
+ .cta__panel::after {
999
+ content: "";
1000
+ position: absolute;
1001
+ inset: 0;
1002
+ background-image:
1003
+ linear-gradient(to right, rgba(255, 255, 255, 0.05) 1px, transparent 1px),
1004
+ linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
1005
+ background-size: 48px 48px;
1006
+ z-index: -1;
1007
+ }
1008
+
1009
+ .cta__title {
1010
+ font-family: var(--font-display);
1011
+ font-size: clamp(2.4rem, 6vw, 5rem);
1012
+ font-weight: 600;
1013
+ letter-spacing: -0.035em;
1014
+ line-height: 1;
1015
+ margin: 0 0 var(--space-md);
1016
+ max-width: 16ch;
1017
+ margin-inline: auto;
1018
+ }
1019
+
1020
+ .cta__title em { font-family: var(--font-italic); font-weight: 400; font-style: italic; color: var(--color-companion); }
1021
+
1022
+ .cta__sub {
1023
+ color: color-mix(in oklch, var(--color-paper-0) 75%, transparent);
1024
+ max-width: 50ch;
1025
+ margin: 0 auto var(--space-xl);
1026
+ font-size: var(--text-md);
1027
+ }
1028
+
1029
+ .cta__panel .btn--primary { background: var(--color-paper-0); color: var(--color-ink-0); border-color: var(--color-paper-0); }
1030
+ .cta__panel .btn--primary:hover { background: var(--color-companion); border-color: var(--color-companion); }
1031
+ .cta__panel .btn--ghost { color: var(--color-paper-0); border-color: rgba(255, 255, 255, 0.18); }
1032
+ .cta__panel .btn--ghost:hover { background: rgba(255, 255, 255, 0.1); border-color: rgba(255, 255, 255, 0.3); }
1033
+
1034
+ /* ───────── footer · Ft5 Statement ───────── */
1035
+ .footer { padding: var(--space-3xl) 0 var(--space-2xl); border-top: var(--rule-hair); }
1036
+
1037
+ .footer__statement {
1038
+ font-family: var(--font-display);
1039
+ font-size: clamp(1.8rem, 4.5vw, 3.2rem);
1040
+ font-weight: 600;
1041
+ letter-spacing: -0.03em;
1042
+ line-height: 1.05;
1043
+ max-width: 22ch;
1044
+ margin: 0 0 var(--space-2xl);
1045
+ }
1046
+
1047
+ .footer__statement em { font-family: var(--font-italic); font-weight: 400; font-style: italic; color: var(--color-accent); }
1048
+
1049
+ .footer__row {
1050
+ display: grid;
1051
+ grid-template-columns: 1.2fr 1fr 1fr 1fr;
1052
+ gap: var(--space-xl);
1053
+ border-top: var(--rule-hair);
1054
+ padding-top: var(--space-xl);
1055
+ }
1056
+
1057
+ @media (max-width: 760px) { .footer__row { grid-template-columns: 1fr 1fr; } }
1058
+
1059
+ .footer__col h5 {
1060
+ font-family: var(--font-mono);
1061
+ font-size: var(--text-xs);
1062
+ font-weight: 500;
1063
+ text-transform: uppercase;
1064
+ letter-spacing: 0.12em;
1065
+ color: var(--color-ink-2);
1066
+ margin: 0 0 var(--space-sm);
1067
+ }
1068
+
1069
+ .footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: var(--text-sm); }
1070
+ .footer__col a { color: var(--color-ink-1); transition: color var(--dur-fast) var(--ease-out); }
1071
+ .footer__col a:hover { color: var(--color-ink-0); }
1072
+
1073
+ .footer__legal {
1074
+ margin-top: var(--space-2xl);
1075
+ display: flex;
1076
+ justify-content: space-between;
1077
+ align-items: center;
1078
+ font-family: var(--font-mono);
1079
+ font-size: var(--text-xs);
1080
+ color: var(--color-ink-2);
1081
+ border-top: var(--rule-hair);
1082
+ padding-top: var(--space-md);
1083
+ }
1084
+
1085
+ .footer__legal .wordmark { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: var(--text-base); color: var(--color-ink-0); }
1086
+
1087
+ @media (max-width: 760px) { .footer__legal { flex-direction: column; gap: var(--space-sm); align-items: flex-start; } }