@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,2020 @@
1
+ /* Pulse Documentation — Design System */
2
+
3
+ *,
4
+ *::before,
5
+ *::after {
6
+ box-sizing: border-box;
7
+ margin: 0;
8
+ padding: 0;
9
+ }
10
+
11
+ /* ─── Tokens ───────────────────────────────────────────────────────────────── */
12
+ :root {
13
+ --bg: #0d0d10;
14
+ --surface: #111116;
15
+ --surface-2: #18181f;
16
+ --border: #38383f;
17
+ --border-subtle: #1a1a20;
18
+ --text: #e2e2ea;
19
+ --muted: #9090a0;
20
+ --muted-2: #7e7e92;
21
+ --accent: #c9b800;
22
+ --accent-text: #0a0a0a;
23
+ --accent-hover: #e0ce00;
24
+ --accent-dim: rgba(201, 184, 0, 0.12);
25
+ --green: #3dd68c;
26
+ --red: #ff6b6b;
27
+
28
+ /* Syntax tokens */
29
+ --tok-kw: #c792ea;
30
+ --tok-str: #c3e88d;
31
+ --tok-cmt: #7a8a9a;
32
+ --tok-num: #f78c6c;
33
+ --tok-fn: #82aaff;
34
+ --tok-prop: #ffcb6b;
35
+ --tok-op: #89ddff;
36
+ --tok-punct: #7e8899;
37
+
38
+ /* Layout */
39
+ --sidebar-w: 260px;
40
+ --header-h: 52px;
41
+ --content-w: 740px;
42
+
43
+ /* Type */
44
+ --font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
45
+ --mono:
46
+ "Fira Code", "Cascadia Code", "JetBrains Mono", "Menlo", "Monaco", monospace;
47
+ --radius: 8px;
48
+ }
49
+
50
+ /* ─── Base ──────────────────────────────────────────────────────────────────── */
51
+ html {
52
+ font-size: 16px;
53
+ }
54
+
55
+ body {
56
+ font-family: var(--font);
57
+ background: var(--bg);
58
+ color: var(--text);
59
+ line-height: 1.6;
60
+ min-height: 100vh;
61
+ -webkit-font-smoothing: antialiased;
62
+ }
63
+
64
+ a {
65
+ color: var(--accent);
66
+ text-decoration: none;
67
+ }
68
+ a:hover {
69
+ color: var(--accent-hover);
70
+ }
71
+
72
+ /* ─── Home page ─────────────────────────────────────────────────────────────── */
73
+ /*
74
+ * Yellow/black theme — token overrides scoped to .home so docs pages
75
+ * keep the dark theme. All .home children inherit these values.
76
+ */
77
+ .home {
78
+ min-height: 100vh;
79
+ background: #f0e642;
80
+ /* Subtle dark dot grid over yellow sections */
81
+ background-image: radial-gradient(
82
+ circle,
83
+ rgba(0, 0, 0, 0.12) 1px,
84
+ transparent 1px
85
+ );
86
+ background-size: 22px 22px;
87
+ color: #0a0a0a;
88
+
89
+ --accent: #0a0a0a;
90
+ --accent-hover: #2a2a2a;
91
+ --accent-dim: rgba(0, 0, 0, 0.07);
92
+ --text: #0a0a0a;
93
+ --muted: #52524a;
94
+ --muted-2: #888880;
95
+ --surface: #ffffff;
96
+ --surface-2: #f0ede0;
97
+ --border: #c8c4aa;
98
+ --border-subtle: rgba(0, 0, 0, 0.1);
99
+ --green: #1a7a4a;
100
+ --red: #c0392b;
101
+ }
102
+
103
+ .home-nav {
104
+ display: flex;
105
+ align-items: center;
106
+ justify-content: space-between;
107
+ padding: 1.25rem 2rem;
108
+ border-bottom: none;
109
+ position: sticky;
110
+ top: 0;
111
+ background: #0a0a0a;
112
+ backdrop-filter: none;
113
+ z-index: 10;
114
+ /* Yellow bolt + white text inside the black nav */
115
+ --accent: #f0e642;
116
+ --text: #ffffff;
117
+ }
118
+
119
+ .home-nav-logo {
120
+ display: flex;
121
+ align-items: center;
122
+ gap: 0.5rem;
123
+ color: var(--text);
124
+ font-weight: 700;
125
+ font-size: 1.1rem;
126
+ text-decoration: none;
127
+ }
128
+
129
+ .home-nav-links {
130
+ display: flex;
131
+ align-items: center;
132
+ gap: 1.5rem;
133
+ }
134
+
135
+ .home-nav-links a {
136
+ color: rgba(255, 255, 255, 0.85);
137
+ font-size: 0.9rem;
138
+ transition: color 0.15s;
139
+ }
140
+ .home-nav-links a:hover {
141
+ color: #ffffff;
142
+ }
143
+
144
+ .home-nav-links .btn-primary {
145
+ background: #f0e642;
146
+ color: #0a0a0a;
147
+ font-weight: 600;
148
+ padding: 0.4rem 1rem;
149
+ border-radius: 6px;
150
+ font-size: 0.875rem;
151
+ }
152
+ .home-nav-links .btn-primary:hover {
153
+ background: #f7f040;
154
+ color: #0a0a0a;
155
+ }
156
+
157
+ /* Hero — sits on the yellow .home background */
158
+ .hero {
159
+ max-width: 860px;
160
+ margin: 0 auto;
161
+ padding: 5rem 2rem;
162
+ text-align: center;
163
+ background: none;
164
+ }
165
+
166
+ .hero-icon {
167
+ margin-bottom: 1.25rem;
168
+ }
169
+
170
+ .hero-badge {
171
+ display: inline-flex;
172
+ align-items: center;
173
+ gap: 0.4rem;
174
+ font-size: 0.78rem;
175
+ font-weight: 600;
176
+ color: #0a0a0a;
177
+ background: rgba(0, 0, 0, 0.08);
178
+ border: 1px solid rgba(0, 0, 0, 0.18);
179
+ border-radius: 100px;
180
+ padding: 0.3rem 0.85rem;
181
+ margin-bottom: 2rem;
182
+ letter-spacing: 0.06em;
183
+ text-transform: uppercase;
184
+ }
185
+
186
+ .hero h1 {
187
+ font-size: clamp(2.5rem, 6vw, 4.5rem);
188
+ font-weight: 800;
189
+ line-height: 1.1;
190
+ letter-spacing: -0.03em;
191
+ text-wrap: balance;
192
+ margin-bottom: 1.5rem;
193
+ color: #0a0a0a;
194
+ background: none;
195
+ -webkit-background-clip: unset;
196
+ -webkit-text-fill-color: #0a0a0a;
197
+ background-clip: unset;
198
+ }
199
+
200
+ .hero-subtitle {
201
+ font-size: 1.1rem;
202
+ color: var(--muted);
203
+ max-width: 580px;
204
+ margin: 0 auto 2.5rem;
205
+ line-height: 1.65;
206
+ }
207
+
208
+ .hero-ctas {
209
+ display: flex;
210
+ gap: 1rem;
211
+ justify-content: center;
212
+ flex-wrap: wrap;
213
+ }
214
+
215
+ /* Default: hero area (yellow bg) — black button with yellow text */
216
+ .btn-primary {
217
+ display: inline-flex;
218
+ align-items: center;
219
+ padding: 0.7rem 1.5rem;
220
+ border-radius: var(--radius);
221
+ font-size: 0.95rem;
222
+ font-weight: 600;
223
+ background: #0a0a0a;
224
+ color: #f0e642;
225
+ text-decoration: none;
226
+ border: 2px solid #0a0a0a;
227
+ transition:
228
+ background 0.15s,
229
+ color 0.15s,
230
+ transform 0.15s;
231
+ }
232
+ .btn-primary:hover {
233
+ background: #f0e642;
234
+ color: #0a0a0a;
235
+ border-color: #0a0a0a;
236
+ transform: translateY(-1px);
237
+ }
238
+
239
+ .btn-secondary {
240
+ display: inline-flex;
241
+ align-items: center;
242
+ padding: 0.7rem 1.5rem;
243
+ border-radius: var(--radius);
244
+ font-size: 0.95rem;
245
+ font-weight: 600;
246
+ background: transparent;
247
+ color: #0a0a0a;
248
+ border: 1px solid rgba(0, 0, 0, 0.25);
249
+ text-decoration: none;
250
+ transition:
251
+ background 0.15s,
252
+ border-color 0.15s;
253
+ }
254
+ .btn-secondary:hover {
255
+ background: rgba(0, 0, 0, 0.06);
256
+ border-color: #0a0a0a;
257
+ color: #0a0a0a;
258
+ }
259
+
260
+ /* CTA section (black bg) — flip to yellow button with black text */
261
+ .home-cta .btn-primary {
262
+ background: #f0e642;
263
+ color: #0a0a0a;
264
+ border-color: #f0e642;
265
+ }
266
+ .home-cta .btn-primary:hover {
267
+ background: #0a0a0a;
268
+ color: #f0e642;
269
+ border-color: #f0e642;
270
+ transform: translateY(-1px);
271
+ }
272
+ .home-cta .btn-secondary {
273
+ background: transparent;
274
+ border-color: rgba(255, 255, 255, 0.25);
275
+ color: rgba(255, 255, 255, 0.75);
276
+ }
277
+ .home-cta .btn-secondary:hover {
278
+ background: rgba(255, 255, 255, 0.08);
279
+ border-color: rgba(255, 255, 255, 0.5);
280
+ color: #ffffff;
281
+ }
282
+
283
+ .hero-sub {
284
+ font-size: 1.2rem;
285
+ color: var(--muted);
286
+ max-width: 560px;
287
+ margin: 0 auto 2.5rem;
288
+ line-height: 1.65;
289
+ }
290
+
291
+ .hero-actions {
292
+ display: flex;
293
+ gap: 1rem;
294
+ justify-content: center;
295
+ flex-wrap: wrap;
296
+ }
297
+
298
+ .btn {
299
+ display: inline-flex;
300
+ align-items: center;
301
+ gap: 0.5rem;
302
+ padding: 0.65rem 1.4rem;
303
+ border-radius: var(--radius);
304
+ font-size: 0.95rem;
305
+ font-weight: 600;
306
+ cursor: pointer;
307
+ border: none;
308
+ transition: all 0.15s;
309
+ text-decoration: none;
310
+ }
311
+
312
+ .btn-accent {
313
+ background: var(--accent);
314
+ color: #0d0d10;
315
+ }
316
+ .btn-accent:hover {
317
+ background: var(--accent-hover);
318
+ color: #0d0d10;
319
+ transform: translateY(-1px);
320
+ }
321
+
322
+ .btn-outline {
323
+ background: transparent;
324
+ color: var(--text);
325
+ border: 1px solid var(--border);
326
+ }
327
+ .btn-outline:hover {
328
+ background: var(--surface-2);
329
+ border-color: var(--muted-2);
330
+ color: var(--text);
331
+ transform: translateY(-1px);
332
+ }
333
+
334
+ /* Stats */
335
+ .hero-stats {
336
+ display: flex;
337
+ justify-content: center;
338
+ gap: 2.5rem;
339
+ margin-top: 4rem;
340
+ flex-wrap: wrap;
341
+ }
342
+
343
+ .stat {
344
+ text-align: center;
345
+ }
346
+
347
+ .stat-value {
348
+ font-size: 2rem;
349
+ font-weight: 800;
350
+ color: var(--accent);
351
+ letter-spacing: -0.03em;
352
+ line-height: 1;
353
+ }
354
+
355
+ .stat-label {
356
+ font-size: 0.78rem;
357
+ color: var(--muted);
358
+ text-transform: uppercase;
359
+ letter-spacing: 0.06em;
360
+ margin-top: 0.35rem;
361
+ }
362
+
363
+ /* Feature grid */
364
+ .features {
365
+ max-width: 1000px;
366
+ margin: 0 auto;
367
+ padding: 4rem 2rem;
368
+ }
369
+
370
+ .features-grid {
371
+ display: grid;
372
+ grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
373
+ gap: 1px;
374
+ background: var(--border);
375
+ border: 1px solid var(--border);
376
+ border-radius: var(--radius);
377
+ overflow: hidden;
378
+ margin-top: 3rem;
379
+ }
380
+
381
+ .feature-card {
382
+ background: var(--surface);
383
+ padding: 1.75rem;
384
+ transition: background 0.15s;
385
+ }
386
+ .feature-card:hover {
387
+ background: var(--surface-2);
388
+ }
389
+
390
+ .feature-icon {
391
+ font-size: 1.5rem;
392
+ margin-bottom: 0.75rem;
393
+ line-height: 1;
394
+ }
395
+
396
+ .feature-title {
397
+ font-size: 0.95rem;
398
+ font-weight: 700;
399
+ color: var(--text);
400
+ margin-bottom: 0.4rem;
401
+ }
402
+
403
+ .feature-desc {
404
+ font-size: 0.85rem;
405
+ color: var(--muted);
406
+ line-height: 1.55;
407
+ }
408
+
409
+ /* Home code example */
410
+ .home-example {
411
+ max-width: 860px;
412
+ margin: 0 auto;
413
+ padding: 0 2rem 6rem;
414
+ }
415
+
416
+ .home-example h2 {
417
+ font-size: 1.6rem;
418
+ font-weight: 700;
419
+ text-align: center;
420
+ margin-bottom: 0.75rem;
421
+ letter-spacing: -0.02em;
422
+ }
423
+
424
+ .home-example-sub {
425
+ text-align: center;
426
+ color: var(--muted);
427
+ font-size: 0.95rem;
428
+ margin-bottom: 2.5rem;
429
+ }
430
+
431
+ /* Home code section — dark panel against yellow */
432
+ .home-code {
433
+ background: #111114;
434
+ padding: 5rem 2rem 6rem;
435
+ }
436
+
437
+ .home-code-inner {
438
+ max-width: 1000px;
439
+ margin: 0 auto;
440
+ }
441
+
442
+ .home-code-header {
443
+ text-align: center;
444
+ margin-bottom: 2.5rem;
445
+ }
446
+
447
+ .home-code-header h2 {
448
+ font-size: clamp(1.6rem, 3vw, 2.2rem);
449
+ font-weight: 700;
450
+ letter-spacing: -0.02em;
451
+ color: #ffffff;
452
+ margin-bottom: 0.6rem;
453
+ }
454
+
455
+ .home-code-header p {
456
+ color: rgba(255, 255, 255, 0.5);
457
+ font-size: 1.1rem;
458
+ max-width: 560px;
459
+ margin: 0 auto;
460
+ line-height: 1.65;
461
+ }
462
+
463
+
464
+ /* ─── FAQ page ───────────────────────────────────────────────────────────────── */
465
+ .faq-item {
466
+ padding: 2rem 0;
467
+ border-bottom: 1px solid var(--border-subtle);
468
+ }
469
+ .faq-item:last-child {
470
+ border-bottom: none;
471
+ }
472
+
473
+ .faq-q {
474
+ font-size: 1.1rem;
475
+ font-weight: 600;
476
+ color: var(--text);
477
+ margin-bottom: 0.875rem;
478
+ letter-spacing: -0.01em;
479
+ line-height: 1.4;
480
+ }
481
+
482
+ .faq-a p {
483
+ font-size: 0.925rem;
484
+ color: var(--muted);
485
+ line-height: 1.75;
486
+ max-width: 68ch;
487
+ margin-bottom: 0.75rem;
488
+ }
489
+ .faq-a p:last-child {
490
+ margin-bottom: 0;
491
+ }
492
+ .faq-a .code-block {
493
+ margin: 0.75rem 0;
494
+ }
495
+
496
+ /* ─── Home footer — black band ───────────────────────────────────────────────── */
497
+ .home-footer {
498
+ border-top: 1px solid rgba(255, 255, 255, 0.08);
499
+ text-align: center;
500
+ padding: 2rem;
501
+ background: #0a0a0a;
502
+ color: rgba(255, 255, 255, 0.6);
503
+ font-size: 0.82rem;
504
+ }
505
+ .home-footer a {
506
+ color: rgba(255, 255, 255, 0.75);
507
+ }
508
+ .home-footer a:hover {
509
+ color: #f0e642;
510
+ }
511
+
512
+ /* Section headers */
513
+ .section-label {
514
+ font-size: 1rem;
515
+ font-weight: 700;
516
+ text-transform: uppercase;
517
+ letter-spacing: 0.1em;
518
+ color: #0a0a0a;
519
+ text-align: center;
520
+ margin-bottom: 1rem;
521
+ opacity: 0.5;
522
+ }
523
+
524
+ /* ─── Stats bar — black band ─────────────────────────────────────────────────── */
525
+ .home-stats {
526
+ display: flex;
527
+ align-items: center;
528
+ justify-content: center;
529
+ gap: 0;
530
+ padding: 2.5rem 2rem;
531
+ border-top: none;
532
+ border-bottom: 1px solid rgba(255, 255, 255, 0.08);
533
+ background: #0a0a0a;
534
+ flex-wrap: wrap;
535
+ }
536
+
537
+ .home-stat {
538
+ display: flex;
539
+ flex-direction: column;
540
+ align-items: center;
541
+ gap: 0.35rem;
542
+ padding: 0.75rem 3rem;
543
+ }
544
+
545
+ .home-stat-value {
546
+ font-size: 2rem;
547
+ font-weight: 700;
548
+ color: #f0e642;
549
+ letter-spacing: -0.02em;
550
+ line-height: 1;
551
+ }
552
+
553
+ .home-stat-label {
554
+ font-size: 1.1rem;
555
+ color: rgba(255, 255, 255, 0.7);
556
+ text-align: center;
557
+ }
558
+
559
+ .home-stat-divider {
560
+ width: 1px;
561
+ height: 2.5rem;
562
+ background: #f0e642;
563
+ flex-shrink: 0;
564
+ }
565
+
566
+ /* ─── How it works — black band ─────────────────────────────────────────────── */
567
+ .how {
568
+ background: #0a0a0a;
569
+ background-image: radial-gradient(
570
+ circle,
571
+ rgba(255, 255, 255, 0.08) 1px,
572
+ transparent 1px
573
+ );
574
+ background-size: 22px 22px;
575
+ padding: 5rem 2rem;
576
+ margin: 0;
577
+ max-width: none;
578
+ --accent: #f0e642;
579
+ --text: #ffffff;
580
+ --muted: 47473e;
581
+ --border: rgba(255, 255, 255, 0.12);
582
+ }
583
+
584
+ .how-inner {
585
+ max-width: 960px;
586
+ margin: 0 auto;
587
+ text-align: center;
588
+ }
589
+
590
+ .how .section-label {
591
+ color: #f0e642;
592
+ opacity: 1;
593
+ }
594
+
595
+ .how-steps {
596
+ display: flex;
597
+ align-items: flex-start;
598
+ justify-content: center;
599
+ gap: 0;
600
+ margin-top: 3rem;
601
+ }
602
+
603
+ .how-step {
604
+ flex: 1;
605
+ max-width: 260px;
606
+ display: flex;
607
+ flex-direction: column;
608
+ align-items: center;
609
+ gap: 0.75rem;
610
+ padding: 0 1rem;
611
+ }
612
+
613
+ .how-step-num {
614
+ width: 2.5rem;
615
+ height: 2.5rem;
616
+ border-radius: 50%;
617
+ background: #f0e642;
618
+ border: 1px solid #f0e642;
619
+ display: flex;
620
+ align-items: center;
621
+ justify-content: center;
622
+ font-size: 0.9rem;
623
+ font-weight: 700;
624
+ color: #0a0a0a;
625
+ flex-shrink: 0;
626
+ }
627
+
628
+ .how-step h3 {
629
+ font-size: 1.1rem;
630
+ font-weight: 600;
631
+ color: var(--text);
632
+ }
633
+
634
+ .how-step p {
635
+ font-size: 1.1rem;
636
+ color: rgba(255, 255, 255, 0.5);
637
+ line-height: 1.6;
638
+ }
639
+
640
+ .how-connector {
641
+ width: 3rem;
642
+ height: 1px;
643
+ background: #f0e642;
644
+ margin-top: 1.25rem;
645
+ flex-shrink: 0;
646
+ }
647
+
648
+ /* ─── AI-first section ───────────────────────────────────────────────────────── */
649
+ .ai-first {
650
+ padding: 5rem 2rem;
651
+ max-width: 900px;
652
+ margin: 0 auto;
653
+ }
654
+
655
+ .ai-first-title {
656
+ font-size: clamp(1.6rem, 4vw, 2.2rem);
657
+ font-weight: 700;
658
+ letter-spacing: -0.02em;
659
+ margin: 0.75rem 0 1.25rem;
660
+ }
661
+
662
+ .ai-first-lead {
663
+ color: var(--muted);
664
+ font-size: 1.1rem;
665
+ line-height: 1.75;
666
+ max-width: 72ch;
667
+ margin-bottom: 3rem;
668
+ }
669
+
670
+ .ai-cols {
671
+ display: grid;
672
+ grid-template-columns: 1fr 1fr;
673
+ gap: 1.5rem;
674
+ }
675
+
676
+ @media (max-width: 640px) {
677
+ .ai-cols {
678
+ grid-template-columns: 1fr;
679
+ }
680
+ .ai-col--pulse {
681
+ order: -1;
682
+ }
683
+ }
684
+
685
+ .ai-col {
686
+ padding: 1.75rem;
687
+ border-radius: 10px;
688
+ border: 1px solid var(--border);
689
+ background: var(--surface);
690
+ }
691
+
692
+ .ai-col--pulse {
693
+ border-color: #0a0a0a;
694
+ background: #0a0a0a;
695
+ }
696
+
697
+ .ai-col-title {
698
+ font-size: 0.8rem;
699
+ font-weight: 600;
700
+ letter-spacing: 0.07em;
701
+ text-transform: uppercase;
702
+ margin-bottom: 1.25rem;
703
+ }
704
+
705
+ .ai-col-title--bad {
706
+ color: #5f5f5a;
707
+ }
708
+ .ai-col-title--good {
709
+ color: #f0e642;
710
+ }
711
+
712
+ .ai-col-list {
713
+ list-style: none;
714
+ display: flex;
715
+ flex-direction: column;
716
+ gap: 0.9rem;
717
+ }
718
+
719
+ .ai-col-list li {
720
+ font-size: 1.1rem;
721
+ color: var(--muted);
722
+ line-height: 1.6;
723
+ padding-left: 1.1rem;
724
+ position: relative;
725
+ }
726
+
727
+ .ai-col-list li::before {
728
+ content: "–";
729
+ position: absolute;
730
+ left: 0;
731
+ color: var(--muted-2);
732
+ }
733
+
734
+ .ai-col--pulse .ai-col-list li {
735
+ color: rgba(255, 255, 255, 0.75);
736
+ }
737
+ .ai-col--pulse .ai-col-list li::before {
738
+ content: "✓";
739
+ color: #f0e642;
740
+ }
741
+
742
+ /* ─── Versus section — black panel ──────────────────────────────────────────── */
743
+ .versus {
744
+ padding: 5rem 2rem;
745
+ background: #0a0a0a;
746
+ border-top: none;
747
+ border-bottom: none;
748
+ text-align: center;
749
+ --accent: #f0e642;
750
+ }
751
+
752
+ .versus-title {
753
+ font-size: 1.75rem;
754
+ font-weight: 700;
755
+ margin-bottom: 0.75rem;
756
+ color: #ffffff;
757
+ }
758
+
759
+ .versus-sub {
760
+ color: rgba(255, 255, 255, 0.5);
761
+ max-width: 560px;
762
+ margin: 0 auto 2.5rem;
763
+ font-size: 1.1rem;
764
+ line-height: 1.7;
765
+ }
766
+
767
+ .versus .section-label {
768
+ color: #f0e642;
769
+ opacity: 1;
770
+ }
771
+
772
+ /* Sticky first column — add .table-sticky-col to any table wrapper. */
773
+ .table-sticky-col {
774
+ overflow-x: auto;
775
+ }
776
+ .table-sticky-col table th:first-child,
777
+ .table-sticky-col table td:first-child {
778
+ position: sticky;
779
+ left: 0;
780
+ z-index: 1;
781
+ border-right: 1px solid rgba(255, 255, 255, 0.15);
782
+ }
783
+
784
+ .versus-table-wrap {
785
+ overflow-x: auto;
786
+ max-width: 900px;
787
+ margin: 0 auto;
788
+ }
789
+
790
+ .versus-table {
791
+ width: 100%;
792
+ min-width: 640px;
793
+ border-collapse: collapse;
794
+ font-size: 1rem;
795
+ text-align: left;
796
+ }
797
+
798
+ .versus-table thead {
799
+ background: rgba(255, 255, 255, 0.06);
800
+ }
801
+
802
+ .versus-table thead th {
803
+ padding: 0.75rem 1rem;
804
+ color: rgba(255, 255, 255, 0.45);
805
+ font-size: 0.78rem;
806
+ font-weight: 600;
807
+ text-transform: uppercase;
808
+ letter-spacing: 0.07em;
809
+ border-bottom: 1px solid rgba(255, 255, 255, 0.1);
810
+ }
811
+
812
+ .versus-table thead th:first-child {
813
+ width: 22%;
814
+ background: #111314; /* solid equivalent of rgba(255,255,255,0.06) on #0a0a0a */
815
+ }
816
+
817
+ .versus-table th[scope="row"] {
818
+ background: #0a0a0a; /* solid — prevents scroll bleed-through */
819
+ }
820
+
821
+ .versus-table tbody tr:nth-child(odd) th[scope="row"] {
822
+ background: #111214; /* match the odd-row tint */
823
+ }
824
+
825
+ .versus-table tbody tr:nth-child(odd) {
826
+ background: rgba(255, 255, 255, 0.04);
827
+ }
828
+
829
+ .versus-table tr:hover td {
830
+ background: rgba(255, 255, 255, 0.08);
831
+ }
832
+
833
+ .versus-table td {
834
+ padding: 0.85rem 1rem;
835
+ border-bottom: 1px solid rgba(255, 255, 255, 0.06);
836
+ color: rgba(255, 255, 255, 0.45);
837
+ vertical-align: top;
838
+ line-height: 1.5;
839
+ }
840
+
841
+ .versus-table th[scope="row"] {
842
+ padding: 0.85rem 1rem;
843
+ border-bottom: 1px solid rgba(255, 255, 255, 0.06);
844
+ color: rgba(255, 255, 255, 0.75);
845
+ font-weight: 500;
846
+ font-size: 0.87rem;
847
+ text-align: left;
848
+ }
849
+
850
+ .versus-table .v-yes {
851
+ color: #f0e642;
852
+ }
853
+ .versus-table .v-partial {
854
+ color: rgba(255, 255, 255, 0.6);
855
+ }
856
+ .versus-table .v-no {
857
+ color: rgba(255, 255, 255, 0.6);
858
+ }
859
+
860
+ /* ─── USP blocks ─────────────────────────────────────────────────────────────── */
861
+ .usp-blocks {
862
+ padding: 4rem 2rem;
863
+ max-width: 1000px;
864
+ margin: 0 auto;
865
+ display: flex;
866
+ flex-direction: column;
867
+ gap: 0;
868
+ }
869
+
870
+ .usp-block {
871
+ display: grid;
872
+ grid-template-columns: 280px 1fr;
873
+ gap: 3rem;
874
+ padding: 3.5rem 0;
875
+ border-bottom: 1px solid var(--border-subtle);
876
+ align-items: start;
877
+ }
878
+
879
+ .usp-block:last-child {
880
+ border-bottom: none;
881
+ }
882
+
883
+ .usp-block-alt {
884
+ direction: rtl;
885
+ }
886
+ .usp-block-alt > * {
887
+ direction: ltr;
888
+ }
889
+
890
+ .usp-block-aside {
891
+ display: flex;
892
+ flex-direction: column;
893
+ gap: 0.75rem;
894
+ }
895
+
896
+ .usp-icon {
897
+ width: 3rem;
898
+ height: 3rem;
899
+ background: #0a0a0a;
900
+ border: none;
901
+ border-radius: var(--radius);
902
+ display: flex;
903
+ align-items: center;
904
+ justify-content: center;
905
+ margin-bottom: 0.25rem;
906
+ /* Yellow icon inside the black box */
907
+ --accent: #f0e642;
908
+ }
909
+
910
+ .usp-block-aside h2 {
911
+ font-size: 1.2rem;
912
+ font-weight: 700;
913
+ }
914
+
915
+ .usp-block-aside p {
916
+ font-size: 1.1rem;
917
+ color: var(--muted);
918
+ line-height: 1.7;
919
+ }
920
+
921
+ .usp-points {
922
+ list-style: none;
923
+ display: flex;
924
+ flex-direction: column;
925
+ gap: 1.25rem;
926
+ padding-top: 0.25rem;
927
+ }
928
+
929
+ .usp-points li {
930
+ padding-left: 1.25rem;
931
+ border-left: 2px solid #0a0a0a;
932
+ font-size: 1.1rem;
933
+ color: var(--muted);
934
+ line-height: 1.7;
935
+ }
936
+
937
+ .usp-points li strong {
938
+ display: block;
939
+ color: var(--text);
940
+ font-weight: 600;
941
+ margin-bottom: 0.15rem;
942
+ }
943
+
944
+ /* ─── Metrics report ─────────────────────────────────────────────────────────── */
945
+ .metrics-report {
946
+ padding: 5rem 2rem;
947
+ border-top: 1px solid var(--border-subtle);
948
+ max-width: 1100px;
949
+ margin: 0 auto;
950
+ }
951
+
952
+ .metrics-header {
953
+ text-align: center;
954
+ margin-bottom: 3rem;
955
+ }
956
+
957
+ .metrics-title {
958
+ font-size: clamp(1.6rem, 3.5vw, 2.2rem);
959
+ font-weight: 700;
960
+ letter-spacing: -0.02em;
961
+ margin-bottom: 0.6rem;
962
+ }
963
+
964
+ .metrics-generated {
965
+ font-size: 0.8rem;
966
+ color: var(--muted);
967
+ letter-spacing: 0.01em;
968
+ }
969
+
970
+ .metrics-groups {
971
+ display: grid;
972
+ grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
973
+ gap: 1rem;
974
+ }
975
+
976
+ .metrics-group {
977
+ background: var(--surface);
978
+ border: 1px solid var(--border-subtle);
979
+ border-radius: var(--radius);
980
+ padding: 1.25rem 1.5rem 1.5rem;
981
+ }
982
+
983
+ .metrics-group-label {
984
+ font-size: 0.7rem;
985
+ font-weight: 600;
986
+ letter-spacing: 0.1em;
987
+ text-transform: uppercase;
988
+ color: var(--muted);
989
+ margin-bottom: 1rem;
990
+ padding-bottom: 0.6rem;
991
+ border-bottom: 1px solid var(--border-subtle);
992
+ }
993
+
994
+ .metrics-items {
995
+ display: flex;
996
+ flex-direction: column;
997
+ gap: 1rem;
998
+ }
999
+
1000
+ .metric-item {
1001
+ display: flex;
1002
+ flex-direction: column;
1003
+ gap: 0.15rem;
1004
+ }
1005
+
1006
+ .metric-val {
1007
+ font-size: 1.5rem;
1008
+ font-weight: 700;
1009
+ letter-spacing: -0.02em;
1010
+ color: var(--text);
1011
+ line-height: 1;
1012
+ }
1013
+
1014
+ .metric-val--green {
1015
+ color: var(--green);
1016
+ }
1017
+ .metric-val--accent {
1018
+ color: var(--accent);
1019
+ }
1020
+
1021
+ .metric-label {
1022
+ font-size: 0.78rem;
1023
+ color: var(--muted);
1024
+ line-height: 1.3;
1025
+ }
1026
+
1027
+ /* ─── CTA section — black band ───────────────────────────────────────────────── */
1028
+ .home-cta {
1029
+ text-align: center;
1030
+ padding: 5rem 2rem;
1031
+ background: #0a0a0a;
1032
+ background-image: radial-gradient(
1033
+ circle,
1034
+ rgba(255, 255, 255, 0.07) 1px,
1035
+ transparent 1px
1036
+ );
1037
+ background-size: 22px 22px;
1038
+ border-top: none;
1039
+ }
1040
+
1041
+ .home-cta h2 {
1042
+ font-size: 2rem;
1043
+ font-weight: 700;
1044
+ margin-bottom: 0.75rem;
1045
+ color: #ffffff;
1046
+ }
1047
+
1048
+ .home-cta p {
1049
+ color: rgba(255, 255, 255, 0.5);
1050
+ margin-bottom: 2rem;
1051
+ font-size: 1.1rem;
1052
+ }
1053
+
1054
+ .home-cta-checks {
1055
+ list-style: none;
1056
+ display: flex;
1057
+ flex-wrap: wrap;
1058
+ justify-content: center;
1059
+ gap: 0.6rem 1.5rem;
1060
+ margin-bottom: 2rem;
1061
+ }
1062
+
1063
+ .home-cta-checks li {
1064
+ font-size: 1.1rem;
1065
+ color: rgba(255, 255, 255, 0.8);
1066
+ display: flex;
1067
+ align-items: center;
1068
+ gap: 0.4rem;
1069
+ }
1070
+
1071
+ .home-cta-checks li::before {
1072
+ content: "✓";
1073
+ color: #f0e642;
1074
+ font-weight: 700;
1075
+ font-size: 1rem;
1076
+ }
1077
+
1078
+ .home-cta-actions {
1079
+ display: flex;
1080
+ gap: 1rem;
1081
+ justify-content: center;
1082
+ flex-wrap: wrap;
1083
+ }
1084
+
1085
+ /* ─── Sidebar overlay (mobile) ───────────────────────────────────────────────── */
1086
+ .sidebar-overlay {
1087
+ display: none;
1088
+ position: fixed;
1089
+ inset: 0;
1090
+ background: rgba(0, 0, 0, 0.55);
1091
+ z-index: 99;
1092
+ opacity: 0;
1093
+ transition: opacity 0.25s ease;
1094
+ }
1095
+
1096
+ @media (max-width: 768px) {
1097
+ .sidebar-overlay {
1098
+ display: block;
1099
+ pointer-events: none;
1100
+ }
1101
+ .sidebar-overlay.visible {
1102
+ opacity: 1;
1103
+ pointer-events: auto;
1104
+ }
1105
+ }
1106
+
1107
+ /* ─── Component demo blocks ──────────────────────────────────────────────────── */
1108
+ .component-demo {
1109
+ border: 1px solid var(--border);
1110
+ border-radius: var(--radius);
1111
+ margin: 1.5rem 0;
1112
+ }
1113
+
1114
+ .demo-preview {
1115
+ padding: 3.5rem 1.5rem 1.5rem;
1116
+ background: #0d0d10;
1117
+ border-radius: var(--radius) var(--radius) 0 0;
1118
+ display: flex;
1119
+ flex-direction: column;
1120
+ gap: 0.75rem;
1121
+ position: relative;
1122
+ }
1123
+
1124
+ .demo-preview-inner {
1125
+ display: flex;
1126
+ flex-wrap: wrap;
1127
+ gap: 0.75rem;
1128
+ align-items: flex-start;
1129
+ min-width: 0;
1130
+ width: 100%;
1131
+ }
1132
+
1133
+ .demo-preview--col .demo-preview-inner {
1134
+ flex-direction: column;
1135
+ align-items: stretch;
1136
+ }
1137
+
1138
+ .demo-preview--scroll .demo-preview-inner {
1139
+ flex-wrap: nowrap;
1140
+ overflow-x: auto;
1141
+ }
1142
+
1143
+ .demo-preview--dark {
1144
+ background: var(--bg);
1145
+ }
1146
+ .demo-preview--light {
1147
+ background: #f0f0f8;
1148
+ }
1149
+
1150
+ /* Force a child nav into mobile layout regardless of viewport width */
1151
+ .demo-mobile-nav .ui-nav-links {
1152
+ display: none;
1153
+ }
1154
+ .demo-mobile-nav .ui-nav-burger {
1155
+ display: flex;
1156
+ }
1157
+
1158
+ /* Phone frame — wraps a nav demo in a minimal phone outline */
1159
+ .demo-phone {
1160
+ width: 320px;
1161
+ border-radius: 32px;
1162
+ overflow: hidden;
1163
+ background: var(--bg, #0d0d10);
1164
+ box-shadow:
1165
+ 0 0 0 7px var(--surface-2, #18181f),
1166
+ 0 0 0 8px var(--border, #222228),
1167
+ 0 24px 48px rgba(0, 0, 0, 0.5);
1168
+ }
1169
+ .demo-phone-statusbar {
1170
+ height: 28px;
1171
+ background: var(--bg, #0d0d10);
1172
+ display: flex;
1173
+ align-items: center;
1174
+ justify-content: center;
1175
+ }
1176
+ .demo-phone-pill {
1177
+ width: 64px;
1178
+ height: 10px;
1179
+ background: var(--surface-2, #18181f);
1180
+ border-radius: 99px;
1181
+ }
1182
+ .demo-phone-content {
1183
+ min-height: 160px;
1184
+ display: flex;
1185
+ align-items: center;
1186
+ justify-content: center;
1187
+ padding: 1.5rem;
1188
+ }
1189
+ .demo-phone-content p {
1190
+ margin: 0;
1191
+ color: var(--muted, #6b6b80);
1192
+ font-size: 0.8rem;
1193
+ text-align: center;
1194
+ }
1195
+ .demo-preview.is-light {
1196
+ background: #f0f0f8;
1197
+ }
1198
+
1199
+ /* Theme toggle button */
1200
+ .demo-theme-toggle {
1201
+ position: absolute;
1202
+ top: 0.6rem;
1203
+ right: 0.6rem;
1204
+ display: flex;
1205
+ align-items: center;
1206
+ justify-content: center;
1207
+ width: 28px;
1208
+ height: 28px;
1209
+ border: 1px solid rgba(255, 255, 255, 0.15);
1210
+ border-radius: 6px;
1211
+ background: rgba(255, 255, 255, 0.07);
1212
+ color: rgba(255, 255, 255, 0.5);
1213
+ cursor: pointer;
1214
+ transition:
1215
+ background 0.15s,
1216
+ color 0.15s;
1217
+ z-index: 1;
1218
+ }
1219
+ .demo-theme-toggle:hover {
1220
+ background: rgba(255, 255, 255, 0.15);
1221
+ color: rgba(255, 255, 255, 0.9);
1222
+ }
1223
+ .demo-preview.is-light .demo-theme-toggle {
1224
+ border-color: rgba(0, 0, 0, 0.15);
1225
+ background: rgba(0, 0, 0, 0.05);
1226
+ color: rgba(0, 0, 0, 0.4);
1227
+ }
1228
+ .demo-preview.is-light .demo-theme-toggle:hover {
1229
+ background: rgba(0, 0, 0, 0.1);
1230
+ color: rgba(0, 0, 0, 0.8);
1231
+ }
1232
+
1233
+ /* Show/hide sun vs moon icon */
1234
+ .demo-theme-toggle__light {
1235
+ display: none;
1236
+ }
1237
+ .demo-preview.is-light .demo-theme-toggle__dark {
1238
+ display: none;
1239
+ }
1240
+ .demo-preview.is-light .demo-theme-toggle__light {
1241
+ display: block;
1242
+ }
1243
+
1244
+ .demo-code pre.code-block {
1245
+ margin: 0;
1246
+ border-radius: 0;
1247
+ border: none;
1248
+ border-top: 1px solid var(--border);
1249
+ }
1250
+
1251
+ .demo-code .code-filename {
1252
+ border-radius: 0;
1253
+ border: none;
1254
+ border-top: 1px solid var(--border);
1255
+ }
1256
+
1257
+ /* ─── Prompt examples page ───────────────────────────────────────────────────── */
1258
+ .prompt-group {
1259
+ margin-bottom: 3rem;
1260
+ }
1261
+
1262
+ .prompt-group-title {
1263
+ font-size: 0.78rem;
1264
+ font-weight: 600;
1265
+ text-transform: uppercase;
1266
+ letter-spacing: 0.1em;
1267
+ color: var(--muted);
1268
+ margin-bottom: 1rem;
1269
+ padding-bottom: 0.5rem;
1270
+ border-bottom: 1px solid var(--border-subtle);
1271
+ }
1272
+
1273
+ .prompt-grid {
1274
+ display: flex;
1275
+ flex-direction: column;
1276
+ gap: 0.75rem;
1277
+ }
1278
+
1279
+ .prompt-card {
1280
+ background: var(--surface);
1281
+ border: 1px solid var(--border);
1282
+ border-radius: var(--radius);
1283
+ padding: 1.25rem 1.5rem;
1284
+ }
1285
+
1286
+ .prompt-tag {
1287
+ font-size: 0.72rem;
1288
+ font-weight: 700;
1289
+ text-transform: uppercase;
1290
+ letter-spacing: 0.08em;
1291
+ color: var(--accent);
1292
+ margin-bottom: 0.65rem;
1293
+ }
1294
+
1295
+ .prompt-text {
1296
+ font-size: 0.93rem;
1297
+ color: var(--text);
1298
+ line-height: 1.65;
1299
+ border-left: 3px solid var(--accent);
1300
+ padding-left: 1rem;
1301
+ margin: 0 0 0.85rem;
1302
+ font-style: italic;
1303
+ }
1304
+
1305
+ .prompt-produces {
1306
+ font-size: 0.82rem;
1307
+ color: var(--muted);
1308
+ line-height: 1.6;
1309
+ }
1310
+
1311
+ .prompt-produces code {
1312
+ font-family: var(--mono);
1313
+ font-size: 0.8rem;
1314
+ background: var(--surface-2);
1315
+ border: 1px solid var(--border);
1316
+ border-radius: 3px;
1317
+ padding: 0.1em 0.35em;
1318
+ color: var(--tok-str);
1319
+ font-style: normal;
1320
+ }
1321
+
1322
+ /* ─── Docs layout ────────────────────────────────────────────────────────────── */
1323
+ .docs-layout {
1324
+ display: flex;
1325
+ min-height: 100vh;
1326
+ }
1327
+
1328
+ /* Sidebar */
1329
+ .docs-sidebar {
1330
+ position: fixed;
1331
+ top: 0;
1332
+ left: 0;
1333
+ width: var(--sidebar-w);
1334
+ height: 100vh;
1335
+ overflow-y: auto;
1336
+ background: var(--surface);
1337
+ border-right: 1px solid var(--border);
1338
+ display: flex;
1339
+ flex-direction: column;
1340
+ z-index: 100;
1341
+ scrollbar-width: thin;
1342
+ scrollbar-color: var(--border) transparent;
1343
+ }
1344
+
1345
+ .docs-sidebar::-webkit-scrollbar {
1346
+ width: 4px;
1347
+ }
1348
+ .docs-sidebar::-webkit-scrollbar-track {
1349
+ background: transparent;
1350
+ }
1351
+ .docs-sidebar::-webkit-scrollbar-thumb {
1352
+ background: var(--border);
1353
+ border-radius: 2px;
1354
+ }
1355
+
1356
+ .sidebar-logo {
1357
+ display: flex;
1358
+ align-items: center;
1359
+ justify-content: space-between;
1360
+ padding: 1.25rem 1.25rem 1rem;
1361
+ border-bottom: 1px solid var(--border);
1362
+ flex-shrink: 0;
1363
+ }
1364
+
1365
+ .logo-link {
1366
+ display: flex;
1367
+ align-items: center;
1368
+ gap: 0.5rem;
1369
+ color: var(--text);
1370
+ font-weight: 700;
1371
+ font-size: 1rem;
1372
+ text-decoration: none;
1373
+ }
1374
+ .logo-link:hover {
1375
+ color: var(--accent);
1376
+ }
1377
+
1378
+ .logo-name {
1379
+ color: var(--text);
1380
+ }
1381
+
1382
+ .version-badge {
1383
+ font-size: 0.7rem;
1384
+ font-weight: 600;
1385
+ color: var(--accent);
1386
+ background: var(--accent-dim);
1387
+ border: 1px solid rgba(155, 141, 255, 0.2);
1388
+ border-radius: 4px;
1389
+ padding: 0.15rem 0.45rem;
1390
+ font-family: var(--mono);
1391
+ }
1392
+
1393
+ .sidebar-nav {
1394
+ padding: 0.75rem 0 2rem;
1395
+ flex: 1;
1396
+ }
1397
+
1398
+ .nav-section {
1399
+ padding: 0.5rem 0;
1400
+ }
1401
+
1402
+ .nav-section + .nav-section {
1403
+ border-top: 1px solid var(--border-subtle);
1404
+ margin-top: 0.25rem;
1405
+ padding-top: 0.75rem;
1406
+ }
1407
+
1408
+ .nav-section-title {
1409
+ font-size: 0.68rem;
1410
+ font-weight: 700;
1411
+ text-transform: uppercase;
1412
+ letter-spacing: 0.1em;
1413
+ color: var(--muted-2);
1414
+ padding: 0.25rem 1.25rem 0.5rem;
1415
+ }
1416
+
1417
+ .nav-link {
1418
+ display: block;
1419
+ padding: 0.35rem 1.25rem;
1420
+ font-size: 0.875rem;
1421
+ color: var(--muted);
1422
+ border-radius: 0;
1423
+ transition:
1424
+ color 0.1s,
1425
+ background 0.1s;
1426
+ position: relative;
1427
+ border-left: 2px solid transparent;
1428
+ }
1429
+
1430
+ .nav-link:hover {
1431
+ color: var(--text);
1432
+ background: var(--surface-2);
1433
+ }
1434
+
1435
+ .nav-link.active {
1436
+ color: var(--accent);
1437
+ border-left-color: var(--accent);
1438
+ background: var(--accent-dim);
1439
+ }
1440
+
1441
+ /* Main content area */
1442
+ .docs-main {
1443
+ margin-left: var(--sidebar-w);
1444
+ flex: 1;
1445
+ min-width: 0;
1446
+ display: flex;
1447
+ flex-direction: column;
1448
+ }
1449
+
1450
+ .docs-header {
1451
+ height: var(--header-h);
1452
+ border-bottom: 1px solid var(--border-subtle);
1453
+ display: flex;
1454
+ align-items: center;
1455
+ justify-content: space-between;
1456
+ padding: 0 2rem;
1457
+ position: sticky;
1458
+ top: 0;
1459
+ background: rgba(13, 13, 16, 0.9);
1460
+ backdrop-filter: blur(8px);
1461
+ z-index: 10;
1462
+ }
1463
+
1464
+ .mobile-menu-btn {
1465
+ display: none;
1466
+ background: none;
1467
+ border: none;
1468
+ color: var(--muted);
1469
+ cursor: pointer;
1470
+ padding: 0.25rem;
1471
+ }
1472
+ .mobile-menu-btn:hover {
1473
+ color: var(--text);
1474
+ }
1475
+
1476
+ .header-logo-mobile {
1477
+ display: none;
1478
+ color: var(--text);
1479
+ }
1480
+
1481
+ .header-github {
1482
+ display: flex;
1483
+ align-items: center;
1484
+ gap: 0.4rem;
1485
+ font-size: 0.82rem;
1486
+ color: var(--muted);
1487
+ transition: color 0.1s;
1488
+ margin-left: auto;
1489
+ }
1490
+ .header-github:hover {
1491
+ color: var(--text);
1492
+ }
1493
+
1494
+ .docs-content {
1495
+ flex: 1;
1496
+ padding: 3rem 3.5rem 5rem;
1497
+ max-width: calc(var(--content-w) + 7rem);
1498
+ }
1499
+
1500
+ /* ─── Doc Typography ─────────────────────────────────────────────────────────── */
1501
+ .doc-h1 {
1502
+ font-size: 2.25rem;
1503
+ font-weight: 800;
1504
+ letter-spacing: -0.03em;
1505
+ line-height: 1.15;
1506
+ margin-bottom: 1rem;
1507
+ color: var(--text);
1508
+ }
1509
+
1510
+ .doc-lead {
1511
+ font-size: 1.1rem;
1512
+ color: var(--muted);
1513
+ line-height: 1.65;
1514
+ max-width: 600px;
1515
+ margin-bottom: 2.5rem;
1516
+ }
1517
+
1518
+ .doc-h2 {
1519
+ font-size: 1.35rem;
1520
+ font-weight: 700;
1521
+ letter-spacing: -0.02em;
1522
+ margin: 2.5rem 0 0.75rem;
1523
+ color: var(--text);
1524
+ padding-top: 1rem;
1525
+ border-top: 1px solid var(--border-subtle);
1526
+ }
1527
+
1528
+ .doc-h2:first-of-type {
1529
+ border-top: none;
1530
+ margin-top: 0;
1531
+ }
1532
+
1533
+ .doc-h3 {
1534
+ font-size: 1.05rem;
1535
+ font-weight: 600;
1536
+ margin: 1.75rem 0 0.6rem;
1537
+ color: var(--text);
1538
+ }
1539
+
1540
+ .definition-list {
1541
+ display: flex;
1542
+ flex-direction: column;
1543
+ gap: 0.75rem;
1544
+ margin: 1rem 0;
1545
+ }
1546
+
1547
+ .definition-list dt {
1548
+ margin: 0;
1549
+ font-weight: 600;
1550
+ }
1551
+
1552
+ .definition-list dd {
1553
+ margin: 0.2rem 0 0 0;
1554
+ color: var(--muted);
1555
+ font-size: 0.9rem;
1556
+ line-height: 1.55;
1557
+ padding-bottom: 0.75rem;
1558
+ border-bottom: 1px solid var(--border-subtle);
1559
+ }
1560
+
1561
+ .definition-list dd:last-of-type {
1562
+ border-bottom: none;
1563
+ padding-bottom: 0;
1564
+ }
1565
+
1566
+ .docs-content p:not([class*="ui-"]) {
1567
+ margin-bottom: 0.9rem;
1568
+ line-height: 1.7;
1569
+ color: var(--text);
1570
+ }
1571
+
1572
+ .docs-content p + p {
1573
+ margin-top: -0.1rem;
1574
+ }
1575
+
1576
+ .docs-content ul:not([class*="ui-"]),
1577
+ .docs-content ol {
1578
+ padding-left: 1.5rem;
1579
+ margin-bottom: 1rem;
1580
+ }
1581
+
1582
+ .docs-content li:not([class*="ui-"]) {
1583
+ margin-bottom: 0.35rem;
1584
+ line-height: 1.65;
1585
+ color: var(--text);
1586
+ }
1587
+
1588
+ .docs-content strong:not([class*="ui-"]) {
1589
+ font-weight: 600;
1590
+ color: #fff;
1591
+ }
1592
+
1593
+ .docs-content
1594
+ a:not(.ui-btn):not(.ui-nav-link):not(.ui-nav-logo):not(.ui-app-badge) {
1595
+ color: var(--accent);
1596
+ text-decoration: underline;
1597
+ text-underline-offset: 2px;
1598
+ }
1599
+ .docs-content
1600
+ a:not(.ui-btn):not(.ui-nav-link):not(.ui-nav-logo):not(.ui-app-badge):hover {
1601
+ color: var(--accent-hover);
1602
+ }
1603
+
1604
+ /* Light-mode demo preview: ensure prose rules don't override component text colors */
1605
+ .docs-content .ui-theme-light p,
1606
+ .docs-content .ui-theme-light li,
1607
+ .docs-content .ui-theme-light strong {
1608
+ color: var(--ui-text);
1609
+ }
1610
+
1611
+ .docs-content code:not(pre code) {
1612
+ font-family: var(--mono);
1613
+ font-size: 0.82em;
1614
+ background: var(--surface-2);
1615
+ border: 1px solid var(--border);
1616
+ border-radius: 4px;
1617
+ padding: 0.1em 0.35em;
1618
+ color: var(--accent-hover);
1619
+ }
1620
+
1621
+ .heading-anchor {
1622
+ color: inherit;
1623
+ text-decoration: none;
1624
+ }
1625
+ .heading-anchor:hover {
1626
+ color: var(--accent);
1627
+ }
1628
+
1629
+ /* ─── Code Blocks ────────────────────────────────────────────────────────────── */
1630
+ .code-filename {
1631
+ background: var(--surface-2);
1632
+ border: 1px solid var(--border);
1633
+ border-bottom: none;
1634
+ border-radius: var(--radius) var(--radius) 0 0;
1635
+ padding: 0.4rem 1rem;
1636
+ font-family: var(--mono);
1637
+ font-size: 0.75rem;
1638
+ color: var(--muted);
1639
+ }
1640
+
1641
+ .code-filename + .code-block {
1642
+ border-radius: 0 0 var(--radius) var(--radius);
1643
+ margin-top: 0;
1644
+ }
1645
+
1646
+ .code-block {
1647
+ background: var(--surface);
1648
+ border: 1px solid var(--border);
1649
+ border-radius: var(--radius);
1650
+ padding: 1.25rem 1.5rem;
1651
+ overflow-x: auto;
1652
+ font-family: var(--mono);
1653
+ font-size: 0.9rem;
1654
+ line-height: 1.75;
1655
+ margin: 1.25rem 0;
1656
+ tab-size: 2;
1657
+ white-space: pre;
1658
+ scrollbar-width: thin;
1659
+ scrollbar-color: var(--border) transparent;
1660
+ }
1661
+
1662
+ .code-block::-webkit-scrollbar {
1663
+ height: 4px;
1664
+ }
1665
+ .code-block::-webkit-scrollbar-track {
1666
+ background: transparent;
1667
+ }
1668
+ .code-block::-webkit-scrollbar-thumb {
1669
+ background: var(--border);
1670
+ border-radius: 2px;
1671
+ }
1672
+
1673
+ /* Token colours */
1674
+ .tok-kw {
1675
+ color: var(--tok-kw);
1676
+ }
1677
+ .tok-str {
1678
+ color: var(--tok-str);
1679
+ }
1680
+ .tok-cmt {
1681
+ color: var(--tok-cmt);
1682
+ font-style: italic;
1683
+ }
1684
+ .tok-num {
1685
+ color: var(--tok-num);
1686
+ }
1687
+ .tok-fn {
1688
+ color: var(--tok-fn);
1689
+ }
1690
+ .tok-prop {
1691
+ color: var(--tok-prop);
1692
+ }
1693
+ .tok-op {
1694
+ color: var(--tok-op);
1695
+ }
1696
+ .tok-punct {
1697
+ color: var(--tok-punct);
1698
+ }
1699
+
1700
+ /* ─── Tables ─────────────────────────────────────────────────────────────────── */
1701
+ .table-wrap {
1702
+ overflow-x: auto;
1703
+ margin: 1.25rem 0;
1704
+ border: 1px solid var(--border);
1705
+ border-radius: var(--radius);
1706
+ }
1707
+
1708
+ table {
1709
+ width: 100%;
1710
+ border-collapse: collapse;
1711
+ font-size: 0.875rem;
1712
+ }
1713
+
1714
+ thead {
1715
+ background: var(--surface-2);
1716
+ }
1717
+
1718
+ th {
1719
+ font-weight: 600;
1720
+ font-size: 0.78rem;
1721
+ text-transform: uppercase;
1722
+ letter-spacing: 0.06em;
1723
+ color: var(--muted);
1724
+ padding: 0.65rem 1rem;
1725
+ text-align: left;
1726
+ border-bottom: 1px solid var(--border);
1727
+ }
1728
+
1729
+ td {
1730
+ padding: 0.65rem 1rem;
1731
+ border-bottom: 1px solid var(--border-subtle);
1732
+ vertical-align: top;
1733
+ line-height: 1.5;
1734
+ }
1735
+
1736
+ tr:last-child td {
1737
+ border-bottom: none;
1738
+ }
1739
+ tr:hover td {
1740
+ background: var(--surface-2);
1741
+ }
1742
+
1743
+ /* ─── Callouts ───────────────────────────────────────────────────────────────── */
1744
+ .callout {
1745
+ display: flex;
1746
+ gap: 0.75rem;
1747
+ padding: 1rem 1.25rem;
1748
+ border-radius: var(--radius);
1749
+ margin: 1.25rem 0;
1750
+ border-left: 3px solid;
1751
+ font-size: 0.9rem;
1752
+ line-height: 1.6;
1753
+ }
1754
+
1755
+ .callout-note {
1756
+ background: rgba(130, 170, 255, 0.07);
1757
+ border-color: rgba(130, 170, 255, 0.5);
1758
+ }
1759
+ .callout-warning {
1760
+ background: rgba(255, 107, 107, 0.07);
1761
+ border-color: rgba(255, 107, 107, 0.5);
1762
+ }
1763
+ .callout-tip {
1764
+ background: rgba(61, 214, 140, 0.07);
1765
+ border-color: rgba(61, 214, 140, 0.5);
1766
+ }
1767
+
1768
+ .callout-note .callout-icon {
1769
+ color: #82aaff;
1770
+ }
1771
+ .callout-warning .callout-icon {
1772
+ color: var(--red);
1773
+ }
1774
+ .callout-tip .callout-icon {
1775
+ color: var(--green);
1776
+ }
1777
+
1778
+ .callout-icon {
1779
+ font-size: 1rem;
1780
+ flex-shrink: 0;
1781
+ margin-top: 0.1rem;
1782
+ }
1783
+
1784
+ .callout-body p:last-child {
1785
+ margin-bottom: 0;
1786
+ }
1787
+
1788
+ /* ─── Prev / Next ────────────────────────────────────────────────────────────── */
1789
+ .doc-prev-next {
1790
+ margin-top: 4rem;
1791
+ padding-top: 2rem;
1792
+ border-top: 1px solid var(--border);
1793
+ }
1794
+
1795
+ .prev-next-grid {
1796
+ display: grid;
1797
+ grid-template-columns: 1fr 1fr;
1798
+ gap: 1rem;
1799
+ }
1800
+
1801
+ .prev-next-link {
1802
+ display: flex;
1803
+ flex-direction: column;
1804
+ gap: 0.2rem;
1805
+ padding: 1rem 1.25rem;
1806
+ border: 1px solid var(--border);
1807
+ border-radius: var(--radius);
1808
+ color: inherit;
1809
+ text-decoration: none;
1810
+ transition:
1811
+ border-color 0.15s,
1812
+ background 0.15s;
1813
+ }
1814
+
1815
+ .prev-next-link:hover {
1816
+ border-color: var(--accent);
1817
+ background: var(--accent-dim);
1818
+ color: inherit;
1819
+ }
1820
+
1821
+ .next-link {
1822
+ text-align: right;
1823
+ }
1824
+
1825
+ .prev-next-label {
1826
+ font-size: 0.75rem;
1827
+ color: var(--muted);
1828
+ text-transform: uppercase;
1829
+ letter-spacing: 0.06em;
1830
+ }
1831
+
1832
+ .prev-next-title {
1833
+ font-size: 0.95rem;
1834
+ font-weight: 600;
1835
+ color: var(--accent);
1836
+ }
1837
+
1838
+ /* ─── Inline helpers ─────────────────────────────────────────────────────────── */
1839
+ .tag {
1840
+ display: inline-block;
1841
+ font-size: 0.7rem;
1842
+ font-weight: 700;
1843
+ text-transform: uppercase;
1844
+ letter-spacing: 0.06em;
1845
+ padding: 0.1rem 0.45rem;
1846
+ border-radius: 4px;
1847
+ font-family: var(--mono);
1848
+ vertical-align: middle;
1849
+ margin-left: 0.25rem;
1850
+ }
1851
+
1852
+ .tag-required {
1853
+ background: rgba(255, 107, 107, 0.15);
1854
+ color: #ff8080;
1855
+ }
1856
+ .tag-optional {
1857
+ background: var(--surface-2);
1858
+ color: var(--muted);
1859
+ }
1860
+
1861
+ hr.doc-hr {
1862
+ border: none;
1863
+ border-top: 1px solid var(--border);
1864
+ margin: 2.5rem 0;
1865
+ }
1866
+
1867
+ /* ─── Mobile ─────────────────────────────────────────────────────────────────── */
1868
+ @media (max-width: 768px) {
1869
+ .docs-sidebar {
1870
+ transform: translateX(-100%);
1871
+ transition: transform 0.25s ease;
1872
+ }
1873
+
1874
+ .docs-sidebar.open {
1875
+ transform: translateX(0);
1876
+ box-shadow: 4px 0 24px rgba(0, 0, 0, 0.4);
1877
+ }
1878
+
1879
+ .docs-main {
1880
+ margin-left: 0;
1881
+ }
1882
+
1883
+ .mobile-menu-btn,
1884
+ .header-logo-mobile {
1885
+ display: flex;
1886
+ }
1887
+
1888
+ .docs-content {
1889
+ padding: 2rem 1.25rem 4rem;
1890
+ }
1891
+
1892
+ .doc-h1 {
1893
+ font-size: 1.75rem;
1894
+ }
1895
+
1896
+ .prev-next-grid {
1897
+ grid-template-columns: 1fr;
1898
+ }
1899
+
1900
+ .hero {
1901
+ padding: 4rem 1.25rem 3rem;
1902
+ }
1903
+
1904
+ .hero-stats {
1905
+ gap: 1.5rem;
1906
+ }
1907
+
1908
+ .home-example {
1909
+ padding: 0 1.25rem 4rem;
1910
+ }
1911
+
1912
+ .features {
1913
+ padding: 3rem 1.25rem;
1914
+ }
1915
+
1916
+ .home-nav {
1917
+ padding: 1rem 1.25rem;
1918
+ }
1919
+
1920
+ .home-nav-links {
1921
+ gap: 1rem;
1922
+ }
1923
+
1924
+ .home-stats {
1925
+ padding: 2rem 1rem;
1926
+ gap: 0;
1927
+ }
1928
+ .home-stat {
1929
+ padding: 0.75rem 1.5rem;
1930
+ }
1931
+ .home-stat-value {
1932
+ font-size: 1.5rem;
1933
+ }
1934
+ .home-stat-divider {
1935
+ display: none;
1936
+ }
1937
+
1938
+ .how {
1939
+ padding: 3.5rem 1.25rem;
1940
+ }
1941
+ .how-steps {
1942
+ flex-direction: column;
1943
+ align-items: center;
1944
+ gap: 1.5rem;
1945
+ }
1946
+ .how-connector {
1947
+ width: 1px;
1948
+ height: 2rem;
1949
+ }
1950
+ .how-step {
1951
+ max-width: 100%;
1952
+ }
1953
+
1954
+ .versus {
1955
+ padding: 3.5rem 1.25rem;
1956
+ }
1957
+ .versus-title {
1958
+ font-size: 1.4rem;
1959
+ }
1960
+
1961
+ .usp-blocks {
1962
+ padding: 2.5rem 1.25rem;
1963
+ }
1964
+ .usp-block {
1965
+ grid-template-columns: 1fr;
1966
+ gap: 1.5rem;
1967
+ }
1968
+ .usp-block-alt {
1969
+ direction: ltr;
1970
+ }
1971
+
1972
+ .home-cta {
1973
+ padding: 3.5rem 1.25rem;
1974
+ }
1975
+ .home-cta h2 {
1976
+ font-size: 1.5rem;
1977
+ }
1978
+ }
1979
+
1980
+ /* ─── Icon grid ─────────────────────────────────────────────────────────────── */
1981
+ .icon-grid {
1982
+ display: grid;
1983
+ grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
1984
+ gap: 0.5rem;
1985
+ margin-bottom: 1rem;
1986
+ }
1987
+
1988
+ .icon-grid-item {
1989
+ display: flex;
1990
+ flex-direction: column;
1991
+ align-items: center;
1992
+ gap: 0.5rem;
1993
+ padding: 1rem 0.5rem;
1994
+ border: 1px solid var(--border-subtle);
1995
+ border-radius: 8px;
1996
+ background: var(--surface);
1997
+ cursor: default;
1998
+ transition:
1999
+ border-color 0.15s,
2000
+ background 0.15s;
2001
+ }
2002
+
2003
+ .icon-grid-item:hover {
2004
+ border-color: var(--border);
2005
+ background: var(--surface-2);
2006
+ }
2007
+
2008
+ .icon-grid-preview {
2009
+ color: var(--text);
2010
+ line-height: 1;
2011
+ }
2012
+
2013
+ .icon-grid-name {
2014
+ font-family: var(--mono, monospace);
2015
+ font-size: 0.6rem;
2016
+ color: var(--muted);
2017
+ text-align: center;
2018
+ word-break: break-all;
2019
+ line-height: 1.4;
2020
+ }