@invisibleloop/pulse 0.1.21

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 (344) hide show
  1. package/.claude/commands/build-page.md +59 -0
  2. package/.claude/commands/new-doc-page.md +45 -0
  3. package/.claude/commands/verify.md +52 -0
  4. package/.claude/pulse-checklist.md +111 -0
  5. package/.claude/settings.local.json +102 -0
  6. package/.github/workflows/ci.yml +22 -0
  7. package/.github/workflows/publish.yml +41 -0
  8. package/.pulse/load-reports/home/1773432711417.json +22 -0
  9. package/CLAUDE.md +383 -0
  10. package/README.md +95 -0
  11. package/docs/.claude/pulse-checklist.md +111 -0
  12. package/docs/public/.pulse-ui-version +1 -0
  13. package/docs/public/dist/accessibility.boot-5DVTARJU.js +115 -0
  14. package/docs/public/dist/actions.boot-P66HKQEM.js +164 -0
  15. package/docs/public/dist/auth.boot-IMAJAUPH.js +140 -0
  16. package/docs/public/dist/caching.boot-DVR6KDE7.js +53 -0
  17. package/docs/public/dist/components--accordion.boot-3HVKMNWC.js +11 -0
  18. package/docs/public/dist/components--alert.boot-GCEXOZAC.js +6 -0
  19. package/docs/public/dist/components--app-badge.boot-DVT3GCHJ.js +6 -0
  20. package/docs/public/dist/components--avatar.boot-PSW24EVA.js +5 -0
  21. package/docs/public/dist/components--badge.boot-TYDY2RMK.js +7 -0
  22. package/docs/public/dist/components--banner.boot-EI5PZSZK.js +7 -0
  23. package/docs/public/dist/components--breadcrumbs.boot-SMA2E2GO.js +34 -0
  24. package/docs/public/dist/components--button.boot-J54BQM2E.js +23 -0
  25. package/docs/public/dist/components--card.boot-PZGNDIB6.js +138 -0
  26. package/docs/public/dist/components--carousel.boot-TP6LPFZZ.js +12 -0
  27. package/docs/public/dist/components--charts.boot-2EOYQWKL.js +108 -0
  28. package/docs/public/dist/components--checkbox.boot-DS5BSL6T.js +54 -0
  29. package/docs/public/dist/components--cluster.boot-HHVIBBJG.js +9 -0
  30. package/docs/public/dist/components--code-window.boot-2GR2DV33.js +20 -0
  31. package/docs/public/dist/components--container.boot-7LOOGK2K.js +5 -0
  32. package/docs/public/dist/components--cta.boot-FSNZ5YRT.js +11 -0
  33. package/docs/public/dist/components--divider.boot-3NI2C3QG.js +6 -0
  34. package/docs/public/dist/components--empty.boot-YX2UR3PV.js +7 -0
  35. package/docs/public/dist/components--feature.boot-MUD7NSUO.js +13 -0
  36. package/docs/public/dist/components--fieldset.boot-J7BYHMKF.js +19 -0
  37. package/docs/public/dist/components--fileupload.boot-NIKVTTPD.js +52 -0
  38. package/docs/public/dist/components--footer.boot-EYUK5FRG.js +14 -0
  39. package/docs/public/dist/components--grid.boot-URDQVDDR.js +59 -0
  40. package/docs/public/dist/components--heading.boot-BPQKU43E.js +44 -0
  41. package/docs/public/dist/components--hero.boot-4RAPRGAB.js +17 -0
  42. package/docs/public/dist/components--icons.boot-ZITNU5JP.js +68 -0
  43. package/docs/public/dist/components--image.boot-XEEGHQZF.js +19 -0
  44. package/docs/public/dist/components--input.boot-SGASZG5K.js +7 -0
  45. package/docs/public/dist/components--list.boot-W3XC5MHD.js +55 -0
  46. package/docs/public/dist/components--media.boot-5VFIETZO.js +13 -0
  47. package/docs/public/dist/components--modal.boot-RZUYXBN2.js +47 -0
  48. package/docs/public/dist/components--nav.boot-ODBOHU7O.js +33 -0
  49. package/docs/public/dist/components--pricing.boot-4AQ4ZVBY.js +21 -0
  50. package/docs/public/dist/components--progress.boot-GHAGYZOK.js +30 -0
  51. package/docs/public/dist/components--prose.boot-QANJL6JI.js +67 -0
  52. package/docs/public/dist/components--pullquote.boot-Q2WMNAZU.js +22 -0
  53. package/docs/public/dist/components--radio.boot-TJRDQ2OL.js +75 -0
  54. package/docs/public/dist/components--rating.boot-QBAN6DEL.js +38 -0
  55. package/docs/public/dist/components--search.boot-PXH5O5AG.js +17 -0
  56. package/docs/public/dist/components--section.boot-AQGIYHWW.js +12 -0
  57. package/docs/public/dist/components--segmented.boot-BEVTKEJO.js +33 -0
  58. package/docs/public/dist/components--select.boot-47X5RHOC.js +10 -0
  59. package/docs/public/dist/components--slider.boot-PSRRX7XL.js +47 -0
  60. package/docs/public/dist/components--spinner.boot-MZ5MO2OH.js +22 -0
  61. package/docs/public/dist/components--stack.boot-DI4NJXBF.js +9 -0
  62. package/docs/public/dist/components--stat.boot-QMFUWBQT.js +9 -0
  63. package/docs/public/dist/components--stepper.boot-34PP2NEV.js +22 -0
  64. package/docs/public/dist/components--table.boot-FCQGSFIQ.js +11 -0
  65. package/docs/public/dist/components--testimonial.boot-DWQPDKYG.js +11 -0
  66. package/docs/public/dist/components--textarea.boot-QVXLBOJ5.js +4 -0
  67. package/docs/public/dist/components--timeline.boot-26LN52P2.js +95 -0
  68. package/docs/public/dist/components--toggle.boot-IQQEI76S.js +29 -0
  69. package/docs/public/dist/components--tooltip.boot-LGHCO6NN.js +9 -0
  70. package/docs/public/dist/components.boot-SE6PQ4P7.js +103 -0
  71. package/docs/public/dist/config.boot-DTRRWUE6.js +126 -0
  72. package/docs/public/dist/constraints.boot-DUHDZBMC.js +71 -0
  73. package/docs/public/dist/deploy.boot-SLAD3NI2.js +163 -0
  74. package/docs/public/dist/docs-8e3d4b5c.css +1 -0
  75. package/docs/public/dist/extending.boot-UA3CN243.js +159 -0
  76. package/docs/public/dist/faq.boot-6EQAWLQR.js +43 -0
  77. package/docs/public/dist/getting-started.boot-TDKIFL5U.js +86 -0
  78. package/docs/public/dist/guard.boot-AUHAWTG4.js +80 -0
  79. package/docs/public/dist/home.boot-BVQXRH32.js +383 -0
  80. package/docs/public/dist/how-it-works.boot-LTWAKWKW.js +104 -0
  81. package/docs/public/dist/hydration.boot-JRM6IPJL.js +78 -0
  82. package/docs/public/dist/images.boot-M6ZVKTZS.js +80 -0
  83. package/docs/public/dist/manifest.json +94 -0
  84. package/docs/public/dist/meta.boot-7NXGPHR4.js +79 -0
  85. package/docs/public/dist/mutations.boot-F6F43UDX.js +79 -0
  86. package/docs/public/dist/navigation.boot-AOXWS3ZF.js +57 -0
  87. package/docs/public/dist/performance.boot-C3UPCOBK.js +98 -0
  88. package/docs/public/dist/persist.boot-WT32PQOQ.js +61 -0
  89. package/docs/public/dist/project-structure.boot-FB3LRVJ4.js +63 -0
  90. package/docs/public/dist/prompt-examples.boot-YKR4VDK4.js +31 -0
  91. package/docs/public/dist/pulse-ui-81a85c03.css +1 -0
  92. package/docs/public/dist/raw-responses.boot-M4KA5YXL.js +104 -0
  93. package/docs/public/dist/routing.boot-FNX5FDGH.js +70 -0
  94. package/docs/public/dist/runtime-B73WLANC.js +1 -0
  95. package/docs/public/dist/runtime-KO4BHUQ3.js +49 -0
  96. package/docs/public/dist/runtime-L2HNXIHW.js +59 -0
  97. package/docs/public/dist/runtime-QFURDKA2.js +5 -0
  98. package/docs/public/dist/runtime-UVPXO4IR.js +375 -0
  99. package/docs/public/dist/runtime-VMJA3Z4N.js +10 -0
  100. package/docs/public/dist/runtime-ZJ4FXT5O.js +11 -0
  101. package/docs/public/dist/server-api.boot-K7X3LCFB.js +219 -0
  102. package/docs/public/dist/server-data.boot-Y7HQYC4R.js +157 -0
  103. package/docs/public/dist/slash-commands.boot-V2UV7OW2.js +26 -0
  104. package/docs/public/dist/spec.boot-2WU7ZHCV.js +159 -0
  105. package/docs/public/dist/state.boot-B24GUE3R.js +73 -0
  106. package/docs/public/dist/store.boot-TLIB4XHH.js +150 -0
  107. package/docs/public/dist/streaming.boot-W2DZSMW4.js +80 -0
  108. package/docs/public/dist/stripe.boot-QN3C2GEL.js +164 -0
  109. package/docs/public/dist/supabase.boot-BG4XXLZE.js +303 -0
  110. package/docs/public/dist/testing.boot-6U4WKMTE.js +130 -0
  111. package/docs/public/dist/validation.boot-PQHYGW5B.js +100 -0
  112. package/docs/public/docs.css +2020 -0
  113. package/docs/public/menu.js +83 -0
  114. package/docs/public/pulse-ui.css +2739 -0
  115. package/docs/public/pulse-ui.js +236 -0
  116. package/docs/server.js +192 -0
  117. package/docs/src/lib/component-page.js +47 -0
  118. package/docs/src/lib/highlight.js +255 -0
  119. package/docs/src/lib/layout.js +131 -0
  120. package/docs/src/lib/metrics-store.js +6 -0
  121. package/docs/src/lib/nav.js +159 -0
  122. package/docs/src/lib/stats.js +81 -0
  123. package/docs/src/pages/accessibility.js +157 -0
  124. package/docs/src/pages/actions.js +191 -0
  125. package/docs/src/pages/auth.js +177 -0
  126. package/docs/src/pages/caching.js +95 -0
  127. package/docs/src/pages/components/accordion.js +48 -0
  128. package/docs/src/pages/components/alert.js +35 -0
  129. package/docs/src/pages/components/app-badge.js +41 -0
  130. package/docs/src/pages/components/avatar.js +35 -0
  131. package/docs/src/pages/components/badge.js +36 -0
  132. package/docs/src/pages/components/banner.js +45 -0
  133. package/docs/src/pages/components/breadcrumbs.js +94 -0
  134. package/docs/src/pages/components/button.js +84 -0
  135. package/docs/src/pages/components/card.js +225 -0
  136. package/docs/src/pages/components/carousel.js +72 -0
  137. package/docs/src/pages/components/charts.js +278 -0
  138. package/docs/src/pages/components/checkbox.js +129 -0
  139. package/docs/src/pages/components/cluster.js +47 -0
  140. package/docs/src/pages/components/code-window.js +57 -0
  141. package/docs/src/pages/components/container.js +40 -0
  142. package/docs/src/pages/components/cta.js +53 -0
  143. package/docs/src/pages/components/divider.js +37 -0
  144. package/docs/src/pages/components/empty.js +36 -0
  145. package/docs/src/pages/components/feature.js +60 -0
  146. package/docs/src/pages/components/fieldset.js +65 -0
  147. package/docs/src/pages/components/fileupload.js +127 -0
  148. package/docs/src/pages/components/footer.js +58 -0
  149. package/docs/src/pages/components/grid.js +165 -0
  150. package/docs/src/pages/components/heading.js +107 -0
  151. package/docs/src/pages/components/hero.js +65 -0
  152. package/docs/src/pages/components/icons.js +285 -0
  153. package/docs/src/pages/components/image.js +71 -0
  154. package/docs/src/pages/components/input.js +51 -0
  155. package/docs/src/pages/components/list.js +112 -0
  156. package/docs/src/pages/components/media.js +51 -0
  157. package/docs/src/pages/components/modal.js +111 -0
  158. package/docs/src/pages/components/nav.js +86 -0
  159. package/docs/src/pages/components/pricing.js +68 -0
  160. package/docs/src/pages/components/progress.js +102 -0
  161. package/docs/src/pages/components/prose.js +111 -0
  162. package/docs/src/pages/components/pullquote.js +71 -0
  163. package/docs/src/pages/components/radio.js +194 -0
  164. package/docs/src/pages/components/rating.js +106 -0
  165. package/docs/src/pages/components/search.js +61 -0
  166. package/docs/src/pages/components/section.js +59 -0
  167. package/docs/src/pages/components/segmented.js +121 -0
  168. package/docs/src/pages/components/select.js +45 -0
  169. package/docs/src/pages/components/slider.js +114 -0
  170. package/docs/src/pages/components/spinner.js +73 -0
  171. package/docs/src/pages/components/stack.js +48 -0
  172. package/docs/src/pages/components/stat.js +55 -0
  173. package/docs/src/pages/components/stepper.js +66 -0
  174. package/docs/src/pages/components/table.js +45 -0
  175. package/docs/src/pages/components/testimonial.js +49 -0
  176. package/docs/src/pages/components/textarea.js +31 -0
  177. package/docs/src/pages/components/timeline.js +227 -0
  178. package/docs/src/pages/components/toggle.js +84 -0
  179. package/docs/src/pages/components/tooltip.js +48 -0
  180. package/docs/src/pages/components.js +204 -0
  181. package/docs/src/pages/config.js +193 -0
  182. package/docs/src/pages/constraints.js +99 -0
  183. package/docs/src/pages/deploy.js +233 -0
  184. package/docs/src/pages/extending.js +198 -0
  185. package/docs/src/pages/faq.js +96 -0
  186. package/docs/src/pages/getting-started.js +106 -0
  187. package/docs/src/pages/guard.js +121 -0
  188. package/docs/src/pages/home.js +401 -0
  189. package/docs/src/pages/how-it-works.js +183 -0
  190. package/docs/src/pages/hydration.js +98 -0
  191. package/docs/src/pages/images.js +121 -0
  192. package/docs/src/pages/meta.js +120 -0
  193. package/docs/src/pages/mutations.js +106 -0
  194. package/docs/src/pages/navigation.js +85 -0
  195. package/docs/src/pages/performance.js +157 -0
  196. package/docs/src/pages/persist.js +88 -0
  197. package/docs/src/pages/project-structure.js +90 -0
  198. package/docs/src/pages/prompt-examples.js +186 -0
  199. package/docs/src/pages/raw-responses.js +124 -0
  200. package/docs/src/pages/routing.js +99 -0
  201. package/docs/src/pages/server-api.js +281 -0
  202. package/docs/src/pages/server-data.js +185 -0
  203. package/docs/src/pages/slash-commands.js +55 -0
  204. package/docs/src/pages/spec.js +207 -0
  205. package/docs/src/pages/state.js +101 -0
  206. package/docs/src/pages/store.js +181 -0
  207. package/docs/src/pages/streaming.js +108 -0
  208. package/docs/src/pages/stripe.js +193 -0
  209. package/docs/src/pages/supabase.js +323 -0
  210. package/docs/src/pages/testing.js +198 -0
  211. package/docs/src/pages/validation.js +138 -0
  212. package/examples/contact.js +166 -0
  213. package/examples/counter.js +94 -0
  214. package/examples/dev.server.js +91 -0
  215. package/examples/examples.test.js +394 -0
  216. package/examples/pricing.js +244 -0
  217. package/examples/products.js +191 -0
  218. package/examples/quiz.js +208 -0
  219. package/examples/shared.js +78 -0
  220. package/examples/todos.js +162 -0
  221. package/package.json +75 -0
  222. package/public/.pulse-ui-version +1 -0
  223. package/public/chippy-bird.css +246 -0
  224. package/public/examples/contact.css +119 -0
  225. package/public/examples/counter.css +79 -0
  226. package/public/examples/pricing.css +132 -0
  227. package/public/examples/products.css +100 -0
  228. package/public/examples/quiz.css +200 -0
  229. package/public/examples/todos.css +137 -0
  230. package/public/favicon.ico +0 -0
  231. package/public/log-dashboard.css +383 -0
  232. package/public/pulse-ui.css +2740 -0
  233. package/public/pulse-ui.js +236 -0
  234. package/public/pulse.css +149 -0
  235. package/scripts/build.js +411 -0
  236. package/src/agent/checklist.md +111 -0
  237. package/src/agent/coverage-check.js +66 -0
  238. package/src/agent/guide-components.md +274 -0
  239. package/src/agent/guide-examples.md +54 -0
  240. package/src/agent/guide-routing.md +36 -0
  241. package/src/agent/guide-server.md +258 -0
  242. package/src/agent/guide-spec.md +103 -0
  243. package/src/agent/guide-styles.md +191 -0
  244. package/src/agent/guide.md +979 -0
  245. package/src/agent/identity.md +106 -0
  246. package/src/agent/workflow.md +108 -0
  247. package/src/cli/cli.test.js +82 -0
  248. package/src/cli/dev.js +195 -0
  249. package/src/cli/discover.js +113 -0
  250. package/src/cli/index.js +361 -0
  251. package/src/cli/load-report.js +91 -0
  252. package/src/cli/load-runner.js +121 -0
  253. package/src/cli/report-server.js +723 -0
  254. package/src/cli/report.js +116 -0
  255. package/src/cli/scaffold.archive.js +1371 -0
  256. package/src/cli/scaffold.js +349 -0
  257. package/src/cli/start.js +74 -0
  258. package/src/html.js +19 -0
  259. package/src/mcp/server.js +884 -0
  260. package/src/mcp/validate-worker.js +110 -0
  261. package/src/runtime/image.js +74 -0
  262. package/src/runtime/image.test.js +111 -0
  263. package/src/runtime/index.js +621 -0
  264. package/src/runtime/navigate.js +146 -0
  265. package/src/runtime/runtime.test.js +773 -0
  266. package/src/runtime/ssr.js +464 -0
  267. package/src/runtime/ssr.test.js +421 -0
  268. package/src/runtime/store.js +92 -0
  269. package/src/runtime/toast.js +163 -0
  270. package/src/server/index.js +1386 -0
  271. package/src/server/server.test.js +1248 -0
  272. package/src/spec/schema.js +428 -0
  273. package/src/spec/schema.test.js +291 -0
  274. package/src/store/index.js +102 -0
  275. package/src/store/store.test.js +210 -0
  276. package/src/testing/html.js +283 -0
  277. package/src/testing/index.js +249 -0
  278. package/src/testing/testing.test.js +450 -0
  279. package/src/ui/accordion.js +28 -0
  280. package/src/ui/alert.js +43 -0
  281. package/src/ui/app-badge.js +48 -0
  282. package/src/ui/avatar.js +47 -0
  283. package/src/ui/badge.js +24 -0
  284. package/src/ui/banner.js +26 -0
  285. package/src/ui/breadcrumbs.js +38 -0
  286. package/src/ui/button.js +66 -0
  287. package/src/ui/card.js +34 -0
  288. package/src/ui/carousel.js +59 -0
  289. package/src/ui/charts.js +321 -0
  290. package/src/ui/checkbox.js +65 -0
  291. package/src/ui/cluster.js +44 -0
  292. package/src/ui/code-window.js +39 -0
  293. package/src/ui/container.js +24 -0
  294. package/src/ui/cta.js +37 -0
  295. package/src/ui/divider.js +29 -0
  296. package/src/ui/empty.js +33 -0
  297. package/src/ui/feature.js +33 -0
  298. package/src/ui/fieldset.js +37 -0
  299. package/src/ui/fileupload.js +89 -0
  300. package/src/ui/footer.js +38 -0
  301. package/src/ui/grid.js +36 -0
  302. package/src/ui/heading.js +45 -0
  303. package/src/ui/hero.js +37 -0
  304. package/src/ui/icons.js +161 -0
  305. package/src/ui/index.js +89 -0
  306. package/src/ui/input.js +74 -0
  307. package/src/ui/list.js +36 -0
  308. package/src/ui/media.js +44 -0
  309. package/src/ui/modal.js +80 -0
  310. package/src/ui/nav.js +61 -0
  311. package/src/ui/pricing.js +56 -0
  312. package/src/ui/progress.js +62 -0
  313. package/src/ui/prose.js +29 -0
  314. package/src/ui/pullquote.js +34 -0
  315. package/src/ui/radio.js +102 -0
  316. package/src/ui/rating.js +93 -0
  317. package/src/ui/search.js +77 -0
  318. package/src/ui/section.js +69 -0
  319. package/src/ui/segmented.js +50 -0
  320. package/src/ui/select.js +77 -0
  321. package/src/ui/slider.js +84 -0
  322. package/src/ui/spinner.js +34 -0
  323. package/src/ui/stack.js +36 -0
  324. package/src/ui/stat.js +52 -0
  325. package/src/ui/stepper.js +46 -0
  326. package/src/ui/switch.js +57 -0
  327. package/src/ui/table.js +45 -0
  328. package/src/ui/testimonial.js +48 -0
  329. package/src/ui/textarea.js +72 -0
  330. package/src/ui/timeline.js +72 -0
  331. package/src/ui/tooltip.js +28 -0
  332. package/src/ui/ui.test.js +1241 -0
  333. package/src/ui/uiimage.js +65 -0
  334. package/tsconfig.json +13 -0
  335. package/types/html.d.ts +17 -0
  336. package/types/image.d.ts +70 -0
  337. package/types/index.d.ts +7 -0
  338. package/types/navigate.d.ts +38 -0
  339. package/types/runtime.d.ts +63 -0
  340. package/types/schema.d.ts +243 -0
  341. package/types/server.d.ts +145 -0
  342. package/types/ssr.d.ts +110 -0
  343. package/types/testing.d.ts +154 -0
  344. package/types/ui.d.ts +704 -0
@@ -0,0 +1,79 @@
1
+ /* ─── Counter example ────────────────────────────────────────────────────── */
2
+
3
+ *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
4
+
5
+ body {
6
+ font-family: var(--ui-font, system-ui, sans-serif);
7
+ background: var(--ui-bg);
8
+ color: var(--ui-text);
9
+ min-height: 100dvh;
10
+ }
11
+
12
+ .cnt-root { display: flex; flex-direction: column; min-height: 100dvh; }
13
+
14
+ .cnt-main {
15
+ flex: 1;
16
+ display: flex;
17
+ align-items: center;
18
+ justify-content: center;
19
+ padding: 3rem 1.5rem;
20
+ }
21
+
22
+ .cnt-eyebrow {
23
+ font-size: .75rem;
24
+ text-transform: uppercase;
25
+ letter-spacing: .08em;
26
+ color: var(--ui-muted);
27
+ }
28
+
29
+ /* Counter display — no component equivalent for this scale */
30
+ .cnt-display {
31
+ display: flex;
32
+ align-items: baseline;
33
+ gap: .5rem;
34
+ }
35
+
36
+ .cnt-value {
37
+ font-size: 5rem;
38
+ font-weight: 800;
39
+ line-height: 1;
40
+ color: var(--ui-accent);
41
+ font-variant-numeric: tabular-nums;
42
+ min-width: 3ch;
43
+ text-align: center;
44
+ }
45
+
46
+ .cnt-of-max {
47
+ font-size: 1.5rem;
48
+ color: var(--ui-muted);
49
+ }
50
+
51
+ /* Progress track — server serves old markup until restart */
52
+ .cnt-track {
53
+ width: 100%;
54
+ height: 6px;
55
+ background: var(--ui-border);
56
+ border-radius: 3px;
57
+ overflow: hidden;
58
+ }
59
+
60
+ .cnt-track-fill {
61
+ height: 100%;
62
+ background: var(--ui-accent);
63
+ border-radius: 3px;
64
+ transition: width .2s ease;
65
+ }
66
+
67
+ .cnt-step-label {
68
+ font-size: .8rem;
69
+ color: var(--ui-muted);
70
+ text-transform: uppercase;
71
+ letter-spacing: .06em;
72
+ }
73
+
74
+ .cnt-hint {
75
+ font-size: .8rem;
76
+ color: var(--ui-muted);
77
+ text-align: center;
78
+ max-width: 32ch;
79
+ }
@@ -0,0 +1,132 @@
1
+ /* ─── Pricing example ────────────────────────────────────────────────────── */
2
+
3
+ body {
4
+ font-family: var(--ui-font, system-ui, sans-serif);
5
+ min-height: 100dvh;
6
+ }
7
+
8
+ /* Logo */
9
+ .pr-logo {
10
+ font-weight: 800;
11
+ font-size: 1.1rem;
12
+ letter-spacing: -.01em;
13
+ }
14
+
15
+ /* Hero */
16
+ .pr-eyebrow {
17
+ font-size: .75rem;
18
+ text-transform: uppercase;
19
+ letter-spacing: .1em;
20
+ color: var(--ui-accent);
21
+ font-weight: 600;
22
+ }
23
+
24
+ /* Fluid type for hero title — kept custom since heading() uses fixed sizes */
25
+ .pr-hero-title {
26
+ font-size: clamp(2rem, 5vw, 3rem);
27
+ font-weight: 800;
28
+ text-align: center;
29
+ line-height: 1.1;
30
+ }
31
+
32
+ .pr-hero-sub {
33
+ color: var(--ui-muted);
34
+ text-align: center;
35
+ max-width: 44ch;
36
+ line-height: 1.6;
37
+ }
38
+
39
+ /* Billing toggle */
40
+ .pr-toggle {
41
+ display: flex;
42
+ gap: .25rem;
43
+ background: var(--ui-surface-2);
44
+ border: 1px solid var(--ui-border);
45
+ border-radius: 10px;
46
+ padding: .25rem;
47
+ align-items: center;
48
+ }
49
+
50
+ .pr-save-label {
51
+ font-size: .7rem;
52
+ font-weight: 700;
53
+ padding: .15rem .45rem;
54
+ border-radius: 99px;
55
+ border: 1px solid currentColor;
56
+ color: var(--ui-text);
57
+ }
58
+
59
+ .pr-annual-note {
60
+ font-size: .8rem;
61
+ color: var(--ui-muted);
62
+ text-align: center;
63
+ }
64
+
65
+ /* Plans */
66
+ .pr-plans {
67
+ display: grid;
68
+ grid-template-columns: repeat(3, minmax(0, 1fr));
69
+ gap: 1.25rem;
70
+ width: 100%;
71
+ align-items: start;
72
+ }
73
+
74
+ @media (max-width: 760px) {
75
+ .pr-plans { grid-template-columns: 1fr; max-width: 400px; }
76
+ }
77
+
78
+ /* Feature table */
79
+ .pr-feature-table {
80
+ width: 100%;
81
+ display: flex;
82
+ flex-direction: column;
83
+ border: 1px solid var(--ui-border);
84
+ border-radius: 12px;
85
+ overflow: hidden;
86
+ }
87
+
88
+ .pr-feature-header,
89
+ .pr-feature-row {
90
+ display: grid;
91
+ grid-template-columns: 2fr 1fr 1fr 1fr;
92
+ gap: 1rem;
93
+ padding: .75rem 1.25rem;
94
+ align-items: center;
95
+ }
96
+
97
+ .pr-feature-header {
98
+ background: var(--ui-surface-2);
99
+ font-size: .8rem;
100
+ font-weight: 600;
101
+ text-transform: uppercase;
102
+ letter-spacing: .06em;
103
+ color: var(--ui-muted);
104
+ border-bottom: 1px solid var(--ui-border);
105
+ }
106
+
107
+ .pr-feature-header span:not(:first-child),
108
+ .pr-feature-row span:not(:first-child) {
109
+ text-align: center;
110
+ }
111
+
112
+ .pr-feature-row {
113
+ font-size: .9rem;
114
+ border-bottom: 1px solid var(--ui-border);
115
+ }
116
+
117
+ .pr-feature-row:last-child { border-bottom: none; }
118
+ .pr-feature-row:nth-child(odd) { background: color-mix(in srgb, var(--ui-surface-2) 50%, transparent); }
119
+
120
+ .pr-feature-name { color: var(--ui-text); }
121
+
122
+ .pr-feature-val { color: var(--ui-muted); font-size: .875rem; }
123
+
124
+ .pr-feature-val--yes {
125
+ color: #10b981;
126
+ font-weight: 700;
127
+ font-size: 1rem;
128
+ }
129
+
130
+ .pr-feature-val--no {
131
+ color: var(--ui-border);
132
+ }
@@ -0,0 +1,100 @@
1
+ /* ─── Products example ───────────────────────────────────────────────────── */
2
+
3
+ *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
4
+
5
+ body {
6
+ font-family: var(--ui-font, system-ui, sans-serif);
7
+ background: var(--ui-bg);
8
+ color: var(--ui-text);
9
+ min-height: 100dvh;
10
+ }
11
+
12
+ .pd-root { display: flex; flex-direction: column; min-height: 100dvh; }
13
+
14
+ /* Logo */
15
+ .pd-logo-text { font-weight: 700; }
16
+
17
+ /* Main */
18
+ .pd-main {
19
+ flex: 1;
20
+ max-width: 1200px;
21
+ width: 100%;
22
+ margin: 0 auto;
23
+ padding: 2rem 1.5rem;
24
+ }
25
+
26
+ /* Page header */
27
+ .pd-page-header {
28
+ display: flex;
29
+ align-items: center;
30
+ justify-content: space-between;
31
+ flex-wrap: wrap;
32
+ gap: 1rem;
33
+ margin-bottom: 1.75rem;
34
+ }
35
+
36
+ .pd-subtitle { font-size: .875rem; color: var(--ui-muted); margin-top: .25rem; }
37
+
38
+ /* Sort uses ui-field/ui-select components */
39
+ .pd-sort-wrap { display: flex; align-items: flex-end; gap: .625rem; }
40
+
41
+ /* Layout: sidebar + content */
42
+ .pd-sidebar {
43
+ display: flex;
44
+ flex-direction: row;
45
+ flex-wrap: wrap;
46
+ gap: 1.5rem;
47
+ margin-bottom: 1.5rem;
48
+ padding-bottom: 1.5rem;
49
+ border-bottom: 1px solid var(--ui-border);
50
+ }
51
+
52
+ /* Search — uses ui-search component */
53
+ .ui-search { flex: 1; min-width: 200px; }
54
+
55
+ /* Categories */
56
+ .pd-category-wrap { display: flex; flex-direction: column; gap: .375rem; }
57
+ .pd-sidebar-label { font-size: .8rem; color: var(--ui-muted); text-transform: uppercase; letter-spacing: .05em; }
58
+
59
+ .pd-categories {
60
+ list-style: none;
61
+ display: flex;
62
+ flex-wrap: wrap;
63
+ gap: .375rem;
64
+ }
65
+
66
+ .pd-cat-pill { border-radius: 999px !important; }
67
+
68
+ /* Image inside card — card overflow:hidden clips top corners; remove image radius so bottom is square */
69
+ .ui-card .ui-image-crop { border-radius: 0; }
70
+
71
+ /* Grid */
72
+ .pd-grid {
73
+ list-style: none;
74
+ display: grid;
75
+ grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
76
+ gap: 1.25rem;
77
+ }
78
+
79
+ .pd-product-body { display: flex; flex-direction: column; gap: .5rem; padding: .875rem; }
80
+
81
+ .pd-product-meta { display: flex; gap: .375rem; flex-wrap: wrap; }
82
+
83
+ .pd-product-stats { display: flex; align-items: center; gap: .375rem; }
84
+
85
+ .pd-rating {
86
+ font-size: .8rem;
87
+ color: #b45309;
88
+ font-weight: 600;
89
+ }
90
+
91
+ .pd-reviews {
92
+ font-size: .775rem;
93
+ color: var(--ui-muted);
94
+ }
95
+
96
+ .pd-price {
97
+ font-size: 1.1rem;
98
+ font-weight: 700;
99
+ color: var(--ui-accent);
100
+ }
@@ -0,0 +1,200 @@
1
+ /* ─── Quiz example ───────────────────────────────────────────────────────── */
2
+
3
+ *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
4
+
5
+ body {
6
+ font-family: var(--ui-font, system-ui, sans-serif);
7
+ background: var(--ui-bg);
8
+ color: var(--ui-text);
9
+ min-height: 100dvh;
10
+ }
11
+
12
+ .qz-root { display: flex; flex-direction: column; min-height: 100dvh; }
13
+
14
+ /* Main */
15
+ .qz-main {
16
+ flex: 1;
17
+ display: flex;
18
+ align-items: flex-start;
19
+ justify-content: center;
20
+ padding: 3rem 1rem;
21
+ }
22
+
23
+ .qz-card {
24
+ width: 100%;
25
+ max-width: 580px;
26
+ background: var(--ui-surface);
27
+ border: 1px solid var(--ui-border);
28
+ border-radius: 16px;
29
+ padding: 2.5rem;
30
+ display: flex;
31
+ flex-direction: column;
32
+ align-items: center;
33
+ gap: 1.75rem;
34
+ }
35
+
36
+ /* Intro */
37
+ .qz-intro-icon { font-size: 3.5rem; }
38
+
39
+ /* Used for results phase heading (wraps badge HTML — cannot use heading component) */
40
+ .qz-title {
41
+ font-size: 1.75rem;
42
+ font-weight: 800;
43
+ text-align: center;
44
+ }
45
+
46
+ .qz-subtitle {
47
+ font-size: .875rem;
48
+ color: var(--ui-muted);
49
+ text-align: center;
50
+ }
51
+
52
+ .qz-intro-desc {
53
+ color: var(--ui-muted);
54
+ text-align: center;
55
+ line-height: 1.6;
56
+ max-width: 36ch;
57
+ }
58
+
59
+ /* Progress */
60
+ .qz-progress-row {
61
+ width: 100%;
62
+ display: flex;
63
+ align-items: center;
64
+ justify-content: space-between;
65
+ font-size: .85rem;
66
+ color: var(--ui-muted);
67
+ }
68
+
69
+ /* Question */
70
+ .qz-question {
71
+ font-size: 1.25rem;
72
+ font-weight: 600;
73
+ text-align: center;
74
+ line-height: 1.45;
75
+ width: 100%;
76
+ }
77
+
78
+ /* Options */
79
+ .qz-options {
80
+ list-style: none;
81
+ width: 100%;
82
+ display: flex;
83
+ flex-direction: column;
84
+ gap: .625rem;
85
+ }
86
+
87
+ .qz-option {
88
+ width: 100%;
89
+ display: flex;
90
+ align-items: center;
91
+ gap: 1rem;
92
+ padding: .875rem 1.25rem;
93
+ border: 1px solid var(--ui-border);
94
+ border-radius: 10px;
95
+ background: var(--ui-bg);
96
+ color: var(--ui-text);
97
+ font-size: .95rem;
98
+ cursor: pointer;
99
+ text-align: left;
100
+ transition: all .15s;
101
+ }
102
+
103
+ .qz-option:hover {
104
+ border-color: var(--ui-accent);
105
+ background: color-mix(in srgb, var(--ui-accent) 8%, transparent);
106
+ }
107
+
108
+ .qz-option:focus-visible {
109
+ outline: 2px solid var(--ui-accent);
110
+ outline-offset: 2px;
111
+ }
112
+
113
+ .qz-option-letter {
114
+ flex-shrink: 0;
115
+ width: 1.75rem;
116
+ height: 1.75rem;
117
+ border-radius: 50%;
118
+ background: var(--ui-border);
119
+ color: var(--ui-muted);
120
+ font-size: .8rem;
121
+ font-weight: 700;
122
+ display: flex;
123
+ align-items: center;
124
+ justify-content: center;
125
+ transition: all .15s;
126
+ }
127
+
128
+ .qz-option:hover .qz-option-letter {
129
+ background: var(--ui-accent);
130
+ color: #fff;
131
+ }
132
+
133
+ .qz-option-text { flex: 1; }
134
+
135
+ /* Results */
136
+ .qz-score-wrap { display: flex; justify-content: center; }
137
+
138
+ .qz-score-ring {
139
+ width: 6rem;
140
+ height: 6rem;
141
+ border-radius: 50%;
142
+ border: 4px solid var(--ui-accent);
143
+ display: flex;
144
+ flex-direction: column;
145
+ align-items: center;
146
+ justify-content: center;
147
+ gap: .1rem;
148
+ }
149
+
150
+ .qz-score-num {
151
+ font-size: 2rem;
152
+ font-weight: 800;
153
+ color: var(--ui-accent);
154
+ line-height: 1;
155
+ }
156
+
157
+ .qz-score-denom {
158
+ font-size: .7rem;
159
+ color: var(--ui-muted);
160
+ }
161
+
162
+ .qz-results {
163
+ list-style: none;
164
+ width: 100%;
165
+ display: flex;
166
+ flex-direction: column;
167
+ gap: .5rem;
168
+ }
169
+
170
+ .qz-result-row {
171
+ display: flex;
172
+ align-items: flex-start;
173
+ gap: .875rem;
174
+ padding: .875rem;
175
+ border-radius: 8px;
176
+ background: var(--ui-bg);
177
+ border: 1px solid var(--ui-border);
178
+ }
179
+
180
+ .qz-result-row--correct { border-left: 3px solid #10b981; }
181
+ .qz-result-row--wrong { border-left: 3px solid #ef4444; }
182
+
183
+ .qz-result-icon {
184
+ flex-shrink: 0;
185
+ margin-top: .1rem;
186
+ }
187
+
188
+ .qz-result-row--correct .qz-result-icon { color: #10b981; }
189
+ .qz-result-row--wrong .qz-result-icon { color: #ef4444; }
190
+
191
+ .qz-result-q {
192
+ font-size: .9rem;
193
+ line-height: 1.4;
194
+ }
195
+
196
+ .qz-result-answer {
197
+ font-size: .8rem;
198
+ color: #10b981;
199
+ margin-top: .25rem;
200
+ }
@@ -0,0 +1,137 @@
1
+ /* ─── Todos example ──────────────────────────────────────────────────────── */
2
+
3
+ *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
4
+
5
+ body {
6
+ font-family: var(--ui-font, system-ui, sans-serif);
7
+ background: var(--ui-bg);
8
+ color: var(--ui-text);
9
+ min-height: 100dvh;
10
+ }
11
+
12
+ .td-root { display: flex; flex-direction: column; min-height: 100dvh; }
13
+
14
+ /* Main */
15
+ .td-main {
16
+ flex: 1;
17
+ display: flex;
18
+ justify-content: center;
19
+ padding: 2.5rem 1rem;
20
+ }
21
+
22
+ .td-panel {
23
+ width: 100%;
24
+ max-width: 520px;
25
+ display: flex;
26
+ flex-direction: column;
27
+ gap: 1.25rem;
28
+ }
29
+
30
+ .td-panel-header {
31
+ display: flex;
32
+ align-items: center;
33
+ justify-content: space-between;
34
+ flex-wrap: wrap;
35
+ gap: .5rem;
36
+ }
37
+
38
+ .td-counts { display: flex; gap: .375rem; }
39
+
40
+ /* Form */
41
+ .td-form { display: flex; flex-direction: column; gap: .5rem; }
42
+
43
+ .td-form-row { display: flex; align-items: flex-end; gap: .5rem; }
44
+
45
+ /* Override the ui-field wrapper inside the form row so it grows to fill space */
46
+ .td-text-field { flex: 1; margin: 0; }
47
+
48
+ .td-limit-msg {
49
+ font-size: .8rem;
50
+ color: var(--ui-warning, #f59e0b);
51
+ }
52
+
53
+ /* Toolbar */
54
+ .td-toolbar {
55
+ display: flex;
56
+ align-items: center;
57
+ justify-content: space-between;
58
+ flex-wrap: wrap;
59
+ gap: .5rem;
60
+ }
61
+
62
+ .td-filters { display: flex; gap: .25rem; }
63
+
64
+ /* List */
65
+ .td-list { list-style: none; }
66
+
67
+ .td-item {
68
+ display: flex;
69
+ align-items: center;
70
+ gap: .75rem;
71
+ padding: .875rem 1rem;
72
+ border-bottom: 1px solid var(--ui-border);
73
+ transition: background .1s;
74
+ }
75
+
76
+ .td-item:last-child { border-bottom: none; }
77
+ .td-item:hover { background: color-mix(in srgb, var(--ui-accent) 4%, transparent); }
78
+
79
+ .td-item--done .td-text {
80
+ text-decoration: line-through;
81
+ color: var(--ui-muted);
82
+ }
83
+
84
+ /* Custom checkbox */
85
+ .td-check-label {
86
+ display: flex;
87
+ align-items: center;
88
+ gap: .625rem;
89
+ flex: 1;
90
+ cursor: pointer;
91
+ }
92
+
93
+ .td-checkbox { position: absolute; opacity: 0; width: 0; height: 0; }
94
+
95
+ .td-check-mark {
96
+ flex-shrink: 0;
97
+ width: 1.125rem;
98
+ height: 1.125rem;
99
+ border: 2px solid var(--ui-border);
100
+ border-radius: 4px;
101
+ display: flex;
102
+ align-items: center;
103
+ justify-content: center;
104
+ transition: all .15s;
105
+ }
106
+
107
+ .td-checkbox:checked + .td-check-mark {
108
+ background: var(--ui-accent);
109
+ border-color: var(--ui-accent);
110
+ }
111
+
112
+ .td-checkbox:checked + .td-check-mark::after {
113
+ content: '';
114
+ width: 5px;
115
+ height: 9px;
116
+ border: 2px solid #fff;
117
+ border-top: none;
118
+ border-left: none;
119
+ transform: rotate(45deg) translate(-1px, -1px);
120
+ display: block;
121
+ }
122
+
123
+ .td-checkbox:focus-visible + .td-check-mark {
124
+ outline: 2px solid var(--ui-accent);
125
+ outline-offset: 2px;
126
+ }
127
+
128
+ .td-text {
129
+ font-size: .95rem;
130
+ line-height: 1.4;
131
+ word-break: break-word;
132
+ }
133
+
134
+ /* Remove button — hidden until hover/focus */
135
+ .td-remove-btn { opacity: 0; transition: opacity .15s; }
136
+ .td-item:hover .td-remove-btn,
137
+ .td-remove-btn:focus-visible { opacity: 1; }
Binary file