@hienlh/ppm 0.9.80 → 0.9.81

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 (1651) hide show
  1. package/.opencode/.ckignore +27 -0
  2. package/.opencode/.env.example +98 -0
  3. package/.opencode/agents/analytics-analyst.md +168 -0
  4. package/.opencode/agents/attraction-specialist.md +152 -0
  5. package/.opencode/agents/brainstormer.md +114 -0
  6. package/.opencode/agents/campaign-debugger.md +149 -0
  7. package/.opencode/agents/campaign-manager.md +185 -0
  8. package/.opencode/agents/code-reviewer.md +163 -0
  9. package/.opencode/agents/code-simplifier.md +59 -0
  10. package/.opencode/agents/community-manager.md +181 -0
  11. package/.opencode/agents/content-creator.md +166 -0
  12. package/.opencode/agents/content-reviewer.md +170 -0
  13. package/.opencode/agents/continuity-specialist.md +149 -0
  14. package/.opencode/agents/copywriter.md +118 -0
  15. package/.opencode/agents/database-admin.md +98 -0
  16. package/.opencode/agents/debugger.md +143 -0
  17. package/.opencode/agents/docs-manager.md +127 -0
  18. package/.opencode/agents/email-wizard.md +166 -0
  19. package/.opencode/agents/fullstack-developer.md +101 -0
  20. package/.opencode/agents/funnel-architect.md +176 -0
  21. package/.opencode/agents/git-manager.md +399 -0
  22. package/.opencode/agents/journal-writer.md +119 -0
  23. package/.opencode/agents/lead-qualifier.md +146 -0
  24. package/.opencode/agents/mcp-manager.md +99 -0
  25. package/.opencode/agents/planner.md +114 -0
  26. package/.opencode/agents/project-manager.md +130 -0
  27. package/.opencode/agents/researcher.md +44 -0
  28. package/.opencode/agents/sale-enabler.md +161 -0
  29. package/.opencode/agents/scout-external.md +146 -0
  30. package/.opencode/agents/scout.md +112 -0
  31. package/.opencode/agents/seo-specialist.md +185 -0
  32. package/.opencode/agents/social-media-manager.md +163 -0
  33. package/.opencode/agents/tester.md +111 -0
  34. package/.opencode/agents/ui-ux-designer.md +241 -0
  35. package/.opencode/agents/upsell-maximizer.md +147 -0
  36. package/.opencode/commands/ckm-analyze-report.md +66 -0
  37. package/.opencode/commands/ckm-analyze.md +63 -0
  38. package/.opencode/commands/ckm-ask.md +55 -0
  39. package/.opencode/commands/ckm-brand-update.md +122 -0
  40. package/.opencode/commands/ckm-campaign-analyze.md +54 -0
  41. package/.opencode/commands/ckm-campaign-create.md +215 -0
  42. package/.opencode/commands/ckm-campaign-email.md +63 -0
  43. package/.opencode/commands/ckm-campaign-status.md +38 -0
  44. package/.opencode/commands/ckm-campaign.md +64 -0
  45. package/.opencode/commands/ckm-competitor.md +69 -0
  46. package/.opencode/commands/ckm-dashboard-check.md +97 -0
  47. package/.opencode/commands/ckm-dashboard.md +90 -0
  48. package/.opencode/commands/ckm-docs-init.md +27 -0
  49. package/.opencode/commands/ckm-docs-llms.md +12 -0
  50. package/.opencode/commands/ckm-docs-summarize.md +22 -0
  51. package/.opencode/commands/ckm-docs-update.md +36 -0
  52. package/.opencode/commands/ckm-email-flow.md +169 -0
  53. package/.opencode/commands/ckm-email-sequence.md +170 -0
  54. package/.opencode/commands/ckm-email.md +64 -0
  55. package/.opencode/commands/ckm-funnel.md +77 -0
  56. package/.opencode/commands/ckm-hub.md +50 -0
  57. package/.opencode/commands/ckm-init.md +214 -0
  58. package/.opencode/commands/ckm-journal.md +18 -0
  59. package/.opencode/commands/ckm-kanban.md +65 -0
  60. package/.opencode/commands/ckm-persona.md +61 -0
  61. package/.opencode/commands/ckm-plan-archive.md +56 -0
  62. package/.opencode/commands/ckm-plan-ci.md +32 -0
  63. package/.opencode/commands/ckm-plan-cro.md +68 -0
  64. package/.opencode/commands/ckm-plan-fast.md +65 -0
  65. package/.opencode/commands/ckm-plan-hard.md +91 -0
  66. package/.opencode/commands/ckm-plan-parallel.md +128 -0
  67. package/.opencode/commands/ckm-plan-two.md +44 -0
  68. package/.opencode/commands/ckm-plan-validate.md +116 -0
  69. package/.opencode/commands/ckm-plan.md +29 -0
  70. package/.opencode/commands/ckm-play-create.md +15 -0
  71. package/.opencode/commands/ckm-play-goals.md +15 -0
  72. package/.opencode/commands/ckm-play-next.md +15 -0
  73. package/.opencode/commands/ckm-play-status.md +15 -0
  74. package/.opencode/commands/ckm-play.md +27 -0
  75. package/.opencode/commands/ckm-preview.md +83 -0
  76. package/.opencode/commands/ckm-seo-audit.md +125 -0
  77. package/.opencode/commands/ckm-seo-keywords.md +135 -0
  78. package/.opencode/commands/ckm-seo-pseo.md +66 -0
  79. package/.opencode/commands/ckm-seo.md +67 -0
  80. package/.opencode/commands/ckm-skill-add.md +41 -0
  81. package/.opencode/commands/ckm-skill-create.md +34 -0
  82. package/.opencode/commands/ckm-skill-fix-logs.md +28 -0
  83. package/.opencode/commands/ckm-skill-optimize-auto.md +30 -0
  84. package/.opencode/commands/ckm-skill-optimize.md +39 -0
  85. package/.opencode/commands/ckm-skill-plan.md +50 -0
  86. package/.opencode/commands/ckm-skill-update.md +35 -0
  87. package/.opencode/commands/ckm-slides-create.md +8 -0
  88. package/.opencode/commands/ckm-social-schedule.md +54 -0
  89. package/.opencode/commands/ckm-social.md +69 -0
  90. package/.opencode/commands/ckm-storage-list.md +90 -0
  91. package/.opencode/commands/ckm-storage-sync.md +92 -0
  92. package/.opencode/commands/ckm-storage-upload.md +80 -0
  93. package/.opencode/commands/ckm-storage-url.md +66 -0
  94. package/.opencode/commands/ckm-test-ui.md +91 -0
  95. package/.opencode/commands/ckm-test-workflow.md +106 -0
  96. package/.opencode/commands/ckm-use-mcp.md +34 -0
  97. package/.opencode/commands/ckm-video-create.md +326 -0
  98. package/.opencode/commands/ckm-video-script-create.md +395 -0
  99. package/.opencode/commands/ckm-video-storyboard-create.md +214 -0
  100. package/.opencode/commands/ckm-watzup.md +9 -0
  101. package/.opencode/commands/ckm-worktree.md +125 -0
  102. package/.opencode/commands/ckm-write-audit.md +97 -0
  103. package/.opencode/commands/ckm-write-blog-youtube.md +158 -0
  104. package/.opencode/commands/ckm-write-blog.md +85 -0
  105. package/.opencode/commands/ckm-write-cro.md +42 -0
  106. package/.opencode/commands/ckm-write-enhance.md +13 -0
  107. package/.opencode/commands/ckm-write-fast.md +12 -0
  108. package/.opencode/commands/ckm-write-formula.md +116 -0
  109. package/.opencode/commands/ckm-write-good.md +16 -0
  110. package/.opencode/commands/ckm-write-publish.md +74 -0
  111. package/.opencode/commands/ckm-youtube-blog.md +136 -0
  112. package/.opencode/commands/ckm-youtube-infographic.md +156 -0
  113. package/.opencode/commands/ckm-youtube-social.md +169 -0
  114. package/.opencode/package.json +8 -0
  115. package/.opencode/plugin/context-injector.ts +84 -0
  116. package/.opencode/plugin/lib/ck-config-utils.cjs +816 -0
  117. package/.opencode/plugin/lib/colors.cjs +95 -0
  118. package/.opencode/plugin/lib/context-builder.cjs +600 -0
  119. package/.opencode/plugin/lib/privacy-checker.cjs +297 -0
  120. package/.opencode/plugin/lib/project-detector.cjs +430 -0
  121. package/.opencode/plugin/lib/scout-checker.cjs +172 -0
  122. package/.opencode/plugin/privacy-block.ts +32 -0
  123. package/.opencode/plugin/scout-block/broad-pattern-detector.cjs +266 -0
  124. package/.opencode/plugin/scout-block/error-formatter.cjs +156 -0
  125. package/.opencode/plugin/scout-block/path-extractor.cjs +238 -0
  126. package/.opencode/plugin/scout-block/pattern-matcher.cjs +184 -0
  127. package/.opencode/plugin/scout-block/vendor/ignore.cjs +627 -0
  128. package/.opencode/plugin/scout-block.ts +40 -0
  129. package/.opencode/scripts/README.md +153 -0
  130. package/.opencode/scripts/ck-help.py +1164 -0
  131. package/.opencode/scripts/commands_data.yaml +363 -0
  132. package/.opencode/scripts/fix-shebang-permissions.sh +50 -0
  133. package/.opencode/scripts/requirements.txt +1 -0
  134. package/.opencode/scripts/resolve_env.py +329 -0
  135. package/.opencode/scripts/scan_commands.py +98 -0
  136. package/.opencode/scripts/scan_skills.py +186 -0
  137. package/.opencode/scripts/set-active-plan.cjs +50 -0
  138. package/.opencode/scripts/skills_data.yaml +370 -0
  139. package/.opencode/scripts/test-ck-help.py +218 -0
  140. package/.opencode/scripts/validate-docs.cjs +342 -0
  141. package/.opencode/scripts/win_compat.py +57 -0
  142. package/.opencode/scripts/worktree.cjs +822 -0
  143. package/.opencode/scripts/worktree.test.cjs +759 -0
  144. package/.opencode/skills/ab-test-setup/SKILL.md +512 -0
  145. package/.opencode/skills/ads-management/SKILL.md +134 -0
  146. package/.opencode/skills/ads-management/references/ad-copy-templates.md +82 -0
  147. package/.opencode/skills/ads-management/references/audience-targeting.md +97 -0
  148. package/.opencode/skills/ads-management/references/campaign-setup-and-bidding.md +88 -0
  149. package/.opencode/skills/ads-management/references/competitor-analysis-and-tools.md +67 -0
  150. package/.opencode/skills/ads-management/references/creative-asset-generation.md +110 -0
  151. package/.opencode/skills/ads-management/references/measurement-and-attribution.md +63 -0
  152. package/.opencode/skills/ads-management/references/optimization-playbook.md +83 -0
  153. package/.opencode/skills/ads-management/references/platform-specs.md +64 -0
  154. package/.opencode/skills/ads-management/scripts/.env.example +13 -0
  155. package/.opencode/skills/ads-management/scripts/google-ads-manager.py +294 -0
  156. package/.opencode/skills/ads-management/scripts/meta-ads-manager.py +360 -0
  157. package/.opencode/skills/affiliate-marketing/SKILL.md +96 -0
  158. package/.opencode/skills/affiliate-marketing/references/case-studies.md +66 -0
  159. package/.opencode/skills/affiliate-marketing/references/compliance-legal.md +78 -0
  160. package/.opencode/skills/affiliate-marketing/references/fraud-prevention.md +81 -0
  161. package/.opencode/skills/affiliate-marketing/references/kol-koc-partnerships.md +86 -0
  162. package/.opencode/skills/affiliate-marketing/references/outreach-templates.md +72 -0
  163. package/.opencode/skills/affiliate-marketing/references/platform-selection.md +82 -0
  164. package/.opencode/skills/affiliate-marketing/references/program-structure.md +74 -0
  165. package/.opencode/skills/agent-browser/SKILL.md +297 -0
  166. package/.opencode/skills/agent-browser/references/.gitkeep +0 -0
  167. package/.opencode/skills/agent-browser/references/agent-browser-vs-chrome-devtools.md +112 -0
  168. package/.opencode/skills/agent-browser/references/browserbase-cloud-setup.md +161 -0
  169. package/.opencode/skills/ai-artist/SKILL.md +122 -0
  170. package/.opencode/skills/ai-artist/data/awesome-prompts.csv +3592 -0
  171. package/.opencode/skills/ai-artist/data/domains.csv +16 -0
  172. package/.opencode/skills/ai-artist/data/image-styles.csv +21 -0
  173. package/.opencode/skills/ai-artist/data/lighting.csv +19 -0
  174. package/.opencode/skills/ai-artist/data/llm-patterns.csv +17 -0
  175. package/.opencode/skills/ai-artist/data/nano-banana-templates.csv +17 -0
  176. package/.opencode/skills/ai-artist/data/platforms.csv +11 -0
  177. package/.opencode/skills/ai-artist/data/quality-modifiers.csv +26 -0
  178. package/.opencode/skills/ai-artist/data/styles.csv +26 -0
  179. package/.opencode/skills/ai-artist/data/subjects.csv +17 -0
  180. package/.opencode/skills/ai-artist/data/techniques.csv +19 -0
  181. package/.opencode/skills/ai-artist/data/use-cases.csv +16 -0
  182. package/.opencode/skills/ai-artist/references/advanced-techniques.md +184 -0
  183. package/.opencode/skills/ai-artist/references/awesome-nano-banana-pro-prompts.md +8575 -0
  184. package/.opencode/skills/ai-artist/references/character-consistency.md +160 -0
  185. package/.opencode/skills/ai-artist/references/domain-code.md +66 -0
  186. package/.opencode/skills/ai-artist/references/domain-data.md +72 -0
  187. package/.opencode/skills/ai-artist/references/domain-marketing.md +66 -0
  188. package/.opencode/skills/ai-artist/references/domain-patterns.md +33 -0
  189. package/.opencode/skills/ai-artist/references/domain-writing.md +68 -0
  190. package/.opencode/skills/ai-artist/references/image-generation-workflow.md +124 -0
  191. package/.opencode/skills/ai-artist/references/image-prompting.md +141 -0
  192. package/.opencode/skills/ai-artist/references/llm-prompting.md +165 -0
  193. package/.opencode/skills/ai-artist/references/nano-banana-pro-examples.md +132 -0
  194. package/.opencode/skills/ai-artist/references/nano-banana.md +59 -0
  195. package/.opencode/skills/ai-artist/references/reasoning-techniques.md +201 -0
  196. package/.opencode/skills/ai-artist/references/validation-workflow.md +117 -0
  197. package/.opencode/skills/ai-artist/scripts/core.py +201 -0
  198. package/.opencode/skills/ai-artist/scripts/extract_prompts.py +102 -0
  199. package/.opencode/skills/ai-artist/scripts/generate.py +371 -0
  200. package/.opencode/skills/ai-artist/scripts/prompt_builder.py +234 -0
  201. package/.opencode/skills/ai-artist/scripts/search.py +111 -0
  202. package/.opencode/skills/ai-multimodal/.env.example +230 -0
  203. package/.opencode/skills/ai-multimodal/SKILL.md +108 -0
  204. package/.opencode/skills/ai-multimodal/assets/demo-minimax/minimax-music-midnight-glow.mp3 +0 -0
  205. package/.opencode/skills/ai-multimodal/assets/demo-minimax/minimax-speech-demo.mp3 +0 -0
  206. package/.opencode/skills/ai-multimodal/assets/demo-minimax/minimax-speech-vietnamese.mp3 +0 -0
  207. package/.opencode/skills/ai-multimodal/assets/demo-minimax/minimax-video-kitsune.mp4 +0 -0
  208. package/.opencode/skills/ai-multimodal/references/audio-processing.md +387 -0
  209. package/.opencode/skills/ai-multimodal/references/image-generation.md +1002 -0
  210. package/.opencode/skills/ai-multimodal/references/minimax-generation.md +141 -0
  211. package/.opencode/skills/ai-multimodal/references/music-generation.md +311 -0
  212. package/.opencode/skills/ai-multimodal/references/video-analysis.md +515 -0
  213. package/.opencode/skills/ai-multimodal/references/video-generation.md +457 -0
  214. package/.opencode/skills/ai-multimodal/references/vision-understanding.md +492 -0
  215. package/.opencode/skills/ai-multimodal/scripts/.coverage +0 -0
  216. package/.opencode/skills/ai-multimodal/scripts/check_setup.py +316 -0
  217. package/.opencode/skills/ai-multimodal/scripts/document_converter.py +395 -0
  218. package/.opencode/skills/ai-multimodal/scripts/gemini_batch_process.py +1187 -0
  219. package/.opencode/skills/ai-multimodal/scripts/media_optimizer.py +506 -0
  220. package/.opencode/skills/ai-multimodal/scripts/minimax_api_client.py +189 -0
  221. package/.opencode/skills/ai-multimodal/scripts/minimax_cli.py +178 -0
  222. package/.opencode/skills/ai-multimodal/scripts/minimax_generate.py +278 -0
  223. package/.opencode/skills/ai-multimodal/scripts/requirements.txt +26 -0
  224. package/.opencode/skills/analytics/SKILL.md +132 -0
  225. package/.opencode/skills/analytics/package.json +19 -0
  226. package/.opencode/skills/analytics/references/analysis-workflows.md +104 -0
  227. package/.opencode/skills/analytics/references/attribution-models.md +75 -0
  228. package/.opencode/skills/analytics/references/ga-admin-api.md +219 -0
  229. package/.opencode/skills/analytics/references/ga-data-api.md +344 -0
  230. package/.opencode/skills/analytics/references/marketing-kpis.md +63 -0
  231. package/.opencode/skills/analytics/references/report-templates.md +411 -0
  232. package/.opencode/skills/analytics/scripts/ga-auth-setup.cjs +283 -0
  233. package/.opencode/skills/analytics/scripts/ga-config-loader.cjs +320 -0
  234. package/.opencode/skills/analytics/scripts/ga-list-accounts.cjs +277 -0
  235. package/.opencode/skills/analytics/scripts/ga-run-report.cjs +334 -0
  236. package/.opencode/skills/analyze/SKILL.md +80 -0
  237. package/.opencode/skills/analyze/references/report.md +62 -0
  238. package/.opencode/skills/ask/SKILL.md +60 -0
  239. package/.opencode/skills/assets-organizing/SKILL.md +164 -0
  240. package/.opencode/skills/assets-organizing/references/asset-types.md +1478 -0
  241. package/.opencode/skills/assets-organizing/references/directory-structure.md +178 -0
  242. package/.opencode/skills/assets-organizing/references/naming-conventions.md +85 -0
  243. package/.opencode/skills/backend-development/SKILL.md +98 -0
  244. package/.opencode/skills/backend-development/references/backend-api-design.md +495 -0
  245. package/.opencode/skills/backend-development/references/backend-architecture.md +454 -0
  246. package/.opencode/skills/backend-development/references/backend-authentication.md +338 -0
  247. package/.opencode/skills/backend-development/references/backend-code-quality.md +659 -0
  248. package/.opencode/skills/backend-development/references/backend-debugging.md +904 -0
  249. package/.opencode/skills/backend-development/references/backend-devops.md +494 -0
  250. package/.opencode/skills/backend-development/references/backend-mindset.md +387 -0
  251. package/.opencode/skills/backend-development/references/backend-performance.md +397 -0
  252. package/.opencode/skills/backend-development/references/backend-security.md +290 -0
  253. package/.opencode/skills/backend-development/references/backend-technologies.md +256 -0
  254. package/.opencode/skills/backend-development/references/backend-testing.md +429 -0
  255. package/.opencode/skills/banner-design/SKILL.md +192 -0
  256. package/.opencode/skills/banner-design/references/banner-sizes-and-styles.md +118 -0
  257. package/.opencode/skills/better-auth/SKILL.md +207 -0
  258. package/.opencode/skills/better-auth/references/advanced-features.md +553 -0
  259. package/.opencode/skills/better-auth/references/database-integration.md +577 -0
  260. package/.opencode/skills/better-auth/references/email-password-auth.md +416 -0
  261. package/.opencode/skills/better-auth/references/oauth-providers.md +430 -0
  262. package/.opencode/skills/better-auth/scripts/.coverage +0 -0
  263. package/.opencode/skills/better-auth/scripts/better_auth_init.py +521 -0
  264. package/.opencode/skills/better-auth/scripts/requirements.txt +15 -0
  265. package/.opencode/skills/bootstrap/SKILL.md +105 -0
  266. package/.opencode/skills/bootstrap/references/shared-phases.md +59 -0
  267. package/.opencode/skills/bootstrap/references/workflow-auto.md +52 -0
  268. package/.opencode/skills/bootstrap/references/workflow-fast.md +50 -0
  269. package/.opencode/skills/bootstrap/references/workflow-full.md +60 -0
  270. package/.opencode/skills/bootstrap/references/workflow-parallel.md +59 -0
  271. package/.opencode/skills/brainstorm/SKILL.md +79 -0
  272. package/.opencode/skills/brand/SKILL.md +97 -0
  273. package/.opencode/skills/brand/references/approval-checklist.md +169 -0
  274. package/.opencode/skills/brand/references/asset-organization.md +157 -0
  275. package/.opencode/skills/brand/references/brand-guideline-template.md +140 -0
  276. package/.opencode/skills/brand/references/color-palette-management.md +186 -0
  277. package/.opencode/skills/brand/references/consistency-checklist.md +94 -0
  278. package/.opencode/skills/brand/references/logo-usage-rules.md +185 -0
  279. package/.opencode/skills/brand/references/messaging-framework.md +85 -0
  280. package/.opencode/skills/brand/references/typography-specifications.md +214 -0
  281. package/.opencode/skills/brand/references/update.md +118 -0
  282. package/.opencode/skills/brand/references/visual-identity.md +96 -0
  283. package/.opencode/skills/brand/references/voice-framework.md +88 -0
  284. package/.opencode/skills/brand/scripts/extract-colors.cjs +341 -0
  285. package/.opencode/skills/brand/scripts/inject-brand-context.cjs +349 -0
  286. package/.opencode/skills/brand/scripts/sync-brand-to-tokens.cjs +266 -0
  287. package/.opencode/skills/brand/scripts/validate-asset.cjs +387 -0
  288. package/.opencode/skills/brand/templates/brand-guidelines-starter.md +275 -0
  289. package/.opencode/skills/campaign/SKILL.md +73 -0
  290. package/.opencode/skills/campaign/references/analyze.md +50 -0
  291. package/.opencode/skills/campaign/references/budget-allocation.md +85 -0
  292. package/.opencode/skills/campaign/references/campaign-brief.md +79 -0
  293. package/.opencode/skills/campaign/references/create.md +211 -0
  294. package/.opencode/skills/campaign/references/email.md +59 -0
  295. package/.opencode/skills/campaign/references/launch-checklist.md +70 -0
  296. package/.opencode/skills/campaign/references/optimization-framework.md +103 -0
  297. package/.opencode/skills/campaign/references/status.md +34 -0
  298. package/.opencode/skills/chrome-devtools/SKILL.md +475 -0
  299. package/.opencode/skills/chrome-devtools/references/cdp-domains.md +694 -0
  300. package/.opencode/skills/chrome-devtools/references/performance-guide.md +940 -0
  301. package/.opencode/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
  302. package/.opencode/skills/chrome-devtools/scripts/README.md +272 -0
  303. package/.opencode/skills/chrome-devtools/scripts/__tests__/error-handling.test.js +102 -0
  304. package/.opencode/skills/chrome-devtools/scripts/__tests__/selector.test.js +210 -0
  305. package/.opencode/skills/chrome-devtools/scripts/aria-snapshot.js +362 -0
  306. package/.opencode/skills/chrome-devtools/scripts/click.js +83 -0
  307. package/.opencode/skills/chrome-devtools/scripts/connect-chrome.js +146 -0
  308. package/.opencode/skills/chrome-devtools/scripts/console.js +79 -0
  309. package/.opencode/skills/chrome-devtools/scripts/evaluate.js +53 -0
  310. package/.opencode/skills/chrome-devtools/scripts/fill.js +76 -0
  311. package/.opencode/skills/chrome-devtools/scripts/import-cookies.js +205 -0
  312. package/.opencode/skills/chrome-devtools/scripts/inject-auth.js +229 -0
  313. package/.opencode/skills/chrome-devtools/scripts/install-deps.sh +181 -0
  314. package/.opencode/skills/chrome-devtools/scripts/install.sh +83 -0
  315. package/.opencode/skills/chrome-devtools/scripts/lib/browser.js +318 -0
  316. package/.opencode/skills/chrome-devtools/scripts/lib/selector.js +178 -0
  317. package/.opencode/skills/chrome-devtools/scripts/navigate.js +54 -0
  318. package/.opencode/skills/chrome-devtools/scripts/network.js +106 -0
  319. package/.opencode/skills/chrome-devtools/scripts/package.json +16 -0
  320. package/.opencode/skills/chrome-devtools/scripts/performance.js +149 -0
  321. package/.opencode/skills/chrome-devtools/scripts/screenshot.js +198 -0
  322. package/.opencode/skills/chrome-devtools/scripts/select-ref.js +131 -0
  323. package/.opencode/skills/chrome-devtools/scripts/snapshot.js +135 -0
  324. package/.opencode/skills/chrome-devtools/scripts/ws-debug.js +44 -0
  325. package/.opencode/skills/chrome-devtools/scripts/ws-full-debug.js +107 -0
  326. package/.opencode/skills/cip-design/.env.example +6 -0
  327. package/.opencode/skills/cip-design/SKILL.md +161 -0
  328. package/.opencode/skills/cip-design/data/deliverables.csv +51 -0
  329. package/.opencode/skills/cip-design/data/industries.csv +21 -0
  330. package/.opencode/skills/cip-design/data/mockup-contexts.csv +21 -0
  331. package/.opencode/skills/cip-design/data/styles.csv +21 -0
  332. package/.opencode/skills/cip-design/references/deliverable-guide.md +95 -0
  333. package/.opencode/skills/cip-design/references/prompt-engineering.md +84 -0
  334. package/.opencode/skills/cip-design/references/style-guide.md +68 -0
  335. package/.opencode/skills/cip-design/scripts/core.py +215 -0
  336. package/.opencode/skills/cip-design/scripts/generate.py +488 -0
  337. package/.opencode/skills/cip-design/scripts/render-html.py +424 -0
  338. package/.opencode/skills/cip-design/scripts/search.py +127 -0
  339. package/.opencode/skills/ck-autoresearch/SKILL.md +153 -0
  340. package/.opencode/skills/ck-autoresearch/references/autonomous-loop-protocol.md +193 -0
  341. package/.opencode/skills/ck-autoresearch/references/git-memory-pattern.md +109 -0
  342. package/.opencode/skills/ck-autoresearch/references/guard-and-noise.md +140 -0
  343. package/.opencode/skills/ck-autoresearch/references/metric-library.md +200 -0
  344. package/.opencode/skills/ck-autoresearch/references/results-logging.md +74 -0
  345. package/.opencode/skills/ck-debug/SKILL.md +123 -0
  346. package/.opencode/skills/ck-debug/references/defense-in-depth.md +124 -0
  347. package/.opencode/skills/ck-debug/references/frontend-verification.md +103 -0
  348. package/.opencode/skills/ck-debug/references/investigation-methodology.md +101 -0
  349. package/.opencode/skills/ck-debug/references/log-and-ci-analysis.md +97 -0
  350. package/.opencode/skills/ck-debug/references/performance-diagnostics.md +113 -0
  351. package/.opencode/skills/ck-debug/references/reporting-standards.md +122 -0
  352. package/.opencode/skills/ck-debug/references/root-cause-tracing.md +122 -0
  353. package/.opencode/skills/ck-debug/references/systematic-debugging.md +102 -0
  354. package/.opencode/skills/ck-debug/references/task-management-debugging.md +155 -0
  355. package/.opencode/skills/ck-debug/references/verification.md +123 -0
  356. package/.opencode/skills/ck-debug/scripts/find-polluter.sh +63 -0
  357. package/.opencode/skills/ck-debug/scripts/find-polluter.test.md +102 -0
  358. package/.opencode/skills/ck-loop/SKILL.md +149 -0
  359. package/.opencode/skills/ck-loop/references/autonomous-loop-protocol.md +193 -0
  360. package/.opencode/skills/ck-loop/references/git-memory-pattern.md +109 -0
  361. package/.opencode/skills/ck-loop/references/guard-and-noise.md +140 -0
  362. package/.opencode/skills/ck-loop/references/metric-library.md +200 -0
  363. package/.opencode/skills/ck-loop/references/results-logging.md +74 -0
  364. package/.opencode/skills/ck-plan/SKILL.md +198 -0
  365. package/.opencode/skills/ck-plan/references/archive-workflow.md +53 -0
  366. package/.opencode/skills/ck-plan/references/codebase-understanding.md +62 -0
  367. package/.opencode/skills/ck-plan/references/output-standards.md +145 -0
  368. package/.opencode/skills/ck-plan/references/plan-organization.md +183 -0
  369. package/.opencode/skills/ck-plan/references/red-team-personas.md +69 -0
  370. package/.opencode/skills/ck-plan/references/red-team-workflow.md +77 -0
  371. package/.opencode/skills/ck-plan/references/research-phase.md +49 -0
  372. package/.opencode/skills/ck-plan/references/scope-challenge.md +90 -0
  373. package/.opencode/skills/ck-plan/references/solution-design.md +63 -0
  374. package/.opencode/skills/ck-plan/references/task-management.md +134 -0
  375. package/.opencode/skills/ck-plan/references/validate-question-framework.md +80 -0
  376. package/.opencode/skills/ck-plan/references/validate-workflow.md +65 -0
  377. package/.opencode/skills/ck-plan/references/workflow-modes.md +155 -0
  378. package/.opencode/skills/ck-predict/SKILL.md +119 -0
  379. package/.opencode/skills/ck-scenario/SKILL.md +113 -0
  380. package/.opencode/skills/ck-security/SKILL.md +144 -0
  381. package/.opencode/skills/ck-security/references/stride-owasp-checklist.md +128 -0
  382. package/.opencode/skills/ckm-storage/SKILL.md +23 -0
  383. package/.opencode/skills/ckm-storage/references/list.md +87 -0
  384. package/.opencode/skills/ckm-storage/references/sync.md +89 -0
  385. package/.opencode/skills/ckm-storage/references/upload.md +77 -0
  386. package/.opencode/skills/ckm-storage/references/url.md +63 -0
  387. package/.opencode/skills/claude-code/SKILL.md +64 -0
  388. package/.opencode/skills/claude-code/references/advanced-features.md +399 -0
  389. package/.opencode/skills/claude-code/references/agent-skills.md +399 -0
  390. package/.opencode/skills/claude-code/references/api-reference.md +498 -0
  391. package/.opencode/skills/claude-code/references/best-practices.md +447 -0
  392. package/.opencode/skills/claude-code/references/cicd-integration.md +428 -0
  393. package/.opencode/skills/claude-code/references/common-workflows.md +119 -0
  394. package/.opencode/skills/claude-code/references/configuration.md +480 -0
  395. package/.opencode/skills/claude-code/references/enterprise-features.md +472 -0
  396. package/.opencode/skills/claude-code/references/getting-started.md +252 -0
  397. package/.opencode/skills/claude-code/references/hooks-and-plugins.md +444 -0
  398. package/.opencode/skills/claude-code/references/hooks-comprehensive.md +622 -0
  399. package/.opencode/skills/claude-code/references/ide-integration.md +316 -0
  400. package/.opencode/skills/claude-code/references/mcp-integration.md +386 -0
  401. package/.opencode/skills/claude-code/references/slash-commands.md +489 -0
  402. package/.opencode/skills/claude-code/references/troubleshooting.md +456 -0
  403. package/.opencode/skills/code-review/SKILL.md +147 -0
  404. package/.opencode/skills/code-review/references/adversarial-review.md +223 -0
  405. package/.opencode/skills/code-review/references/checklist-workflow.md +100 -0
  406. package/.opencode/skills/code-review/references/checklists/api.md +52 -0
  407. package/.opencode/skills/code-review/references/checklists/base.md +100 -0
  408. package/.opencode/skills/code-review/references/checklists/web-app.md +54 -0
  409. package/.opencode/skills/code-review/references/code-review-reception.md +209 -0
  410. package/.opencode/skills/code-review/references/codebase-scan-workflow.md +30 -0
  411. package/.opencode/skills/code-review/references/edge-case-scouting.md +119 -0
  412. package/.opencode/skills/code-review/references/input-mode-resolution.md +135 -0
  413. package/.opencode/skills/code-review/references/parallel-review-workflow.md +76 -0
  414. package/.opencode/skills/code-review/references/requesting-code-review.md +105 -0
  415. package/.opencode/skills/code-review/references/spec-compliance-review.md +43 -0
  416. package/.opencode/skills/code-review/references/task-management-reviews.md +155 -0
  417. package/.opencode/skills/code-review/references/verification-before-completion.md +139 -0
  418. package/.opencode/skills/coding-level/SKILL.md +59 -0
  419. package/.opencode/skills/competitor/SKILL.md +95 -0
  420. package/.opencode/skills/competitor/references/alternatives.md +245 -0
  421. package/.opencode/skills/content-hub/SKILL.md +83 -0
  422. package/.opencode/skills/content-hub/assets/hub.css +693 -0
  423. package/.opencode/skills/content-hub/assets/hub.js +514 -0
  424. package/.opencode/skills/content-hub/assets/template.html +185 -0
  425. package/.opencode/skills/content-hub/scripts/lib/ai-bridge.cjs +165 -0
  426. package/.opencode/skills/content-hub/scripts/lib/brand-context.cjs +118 -0
  427. package/.opencode/skills/content-hub/scripts/lib/port-finder.cjs +43 -0
  428. package/.opencode/skills/content-hub/scripts/lib/process-mgr.cjs +102 -0
  429. package/.opencode/skills/content-hub/scripts/lib/router.cjs +276 -0
  430. package/.opencode/skills/content-hub/scripts/lib/scanner.cjs +278 -0
  431. package/.opencode/skills/content-hub/scripts/server.cjs +140 -0
  432. package/.opencode/skills/content-hub/scripts/start-all.sh +58 -0
  433. package/.opencode/skills/content-marketing/SKILL.md +87 -0
  434. package/.opencode/skills/content-marketing/references/blog-post-templates.md +108 -0
  435. package/.opencode/skills/content-marketing/references/content-audit-checklist.md +76 -0
  436. package/.opencode/skills/content-marketing/references/content-strategy-framework.md +72 -0
  437. package/.opencode/skills/content-marketing/references/editorial-calendar-template.md +59 -0
  438. package/.opencode/skills/context-engineering/SKILL.md +110 -0
  439. package/.opencode/skills/context-engineering/references/context-compression.md +84 -0
  440. package/.opencode/skills/context-engineering/references/context-degradation.md +93 -0
  441. package/.opencode/skills/context-engineering/references/context-fundamentals.md +75 -0
  442. package/.opencode/skills/context-engineering/references/context-optimization.md +82 -0
  443. package/.opencode/skills/context-engineering/references/evaluation.md +89 -0
  444. package/.opencode/skills/context-engineering/references/memory-systems.md +88 -0
  445. package/.opencode/skills/context-engineering/references/multi-agent-patterns.md +90 -0
  446. package/.opencode/skills/context-engineering/references/project-development.md +97 -0
  447. package/.opencode/skills/context-engineering/references/runtime-awareness.md +202 -0
  448. package/.opencode/skills/context-engineering/references/tool-design.md +86 -0
  449. package/.opencode/skills/context-engineering/scripts/compression_evaluator.py +349 -0
  450. package/.opencode/skills/context-engineering/scripts/context_analyzer.py +317 -0
  451. package/.opencode/skills/cook/README.md +86 -0
  452. package/.opencode/skills/cook/SKILL.md +115 -0
  453. package/.opencode/skills/cook/references/intent-detection.md +101 -0
  454. package/.opencode/skills/cook/references/review-cycle.md +75 -0
  455. package/.opencode/skills/cook/references/subagent-patterns.md +75 -0
  456. package/.opencode/skills/cook/references/workflow-steps.md +166 -0
  457. package/.opencode/skills/copywriting/SKILL.md +88 -0
  458. package/.opencode/skills/copywriting/references/copy-formulas.md +150 -0
  459. package/.opencode/skills/copywriting/references/cta-patterns.md +168 -0
  460. package/.opencode/skills/copywriting/references/email-copy.md +193 -0
  461. package/.opencode/skills/copywriting/references/headline-templates.md +140 -0
  462. package/.opencode/skills/copywriting/references/landing-page-copy.md +175 -0
  463. package/.opencode/skills/copywriting/references/power-words.md +189 -0
  464. package/.opencode/skills/copywriting/references/social-media-copy.md +222 -0
  465. package/.opencode/skills/copywriting/references/workflow-cro.md +83 -0
  466. package/.opencode/skills/copywriting/references/workflow-enhance.md +32 -0
  467. package/.opencode/skills/copywriting/references/workflow-fast.md +29 -0
  468. package/.opencode/skills/copywriting/references/workflow-good.md +39 -0
  469. package/.opencode/skills/copywriting/references/writing-styles.md +247 -0
  470. package/.opencode/skills/copywriting/scripts/extract-writing-styles.py +308 -0
  471. package/.opencode/skills/copywriting/templates/copy-brief.md +49 -0
  472. package/.opencode/skills/creativity/SKILL.md +189 -0
  473. package/.opencode/skills/creativity/data/creative-reasoning.csv +31 -0
  474. package/.opencode/skills/creativity/data/music.csv +18 -0
  475. package/.opencode/skills/creativity/data/platforms.csv +19 -0
  476. package/.opencode/skills/creativity/data/styles.csv +56 -0
  477. package/.opencode/skills/creativity/data/voiceover.csv +13 -0
  478. package/.opencode/skills/creativity/references/audio-music.md +74 -0
  479. package/.opencode/skills/creativity/references/color-psychology.md +68 -0
  480. package/.opencode/skills/creativity/references/creative-styles-part1.md +31 -0
  481. package/.opencode/skills/creativity/references/creative-styles-part2.md +36 -0
  482. package/.opencode/skills/creativity/references/visual-trends.md +84 -0
  483. package/.opencode/skills/creativity/references/voiceover-styles.md +107 -0
  484. package/.opencode/skills/creativity/scripts/core.py +179 -0
  485. package/.opencode/skills/creativity/scripts/creative_brief.py +470 -0
  486. package/.opencode/skills/creativity/scripts/search.py +62 -0
  487. package/.opencode/skills/dashboard/SKILL.md +108 -0
  488. package/.opencode/skills/dashboard/references/check.md +93 -0
  489. package/.opencode/skills/databases/SKILL.md +236 -0
  490. package/.opencode/skills/databases/analytics.md +198 -0
  491. package/.opencode/skills/databases/db-design.md +188 -0
  492. package/.opencode/skills/databases/incremental-etl.md +213 -0
  493. package/.opencode/skills/databases/references/mongodb-aggregation.md +447 -0
  494. package/.opencode/skills/databases/references/mongodb-atlas.md +465 -0
  495. package/.opencode/skills/databases/references/mongodb-crud.md +408 -0
  496. package/.opencode/skills/databases/references/mongodb-indexing.md +442 -0
  497. package/.opencode/skills/databases/references/postgresql-administration.md +594 -0
  498. package/.opencode/skills/databases/references/postgresql-performance.md +527 -0
  499. package/.opencode/skills/databases/references/postgresql-psql-cli.md +467 -0
  500. package/.opencode/skills/databases/references/postgresql-queries.md +475 -0
  501. package/.opencode/skills/databases/scripts/.coverage +0 -0
  502. package/.opencode/skills/databases/scripts/db_backup.py +502 -0
  503. package/.opencode/skills/databases/scripts/db_migrate.py +425 -0
  504. package/.opencode/skills/databases/scripts/db_performance_check.py +456 -0
  505. package/.opencode/skills/databases/scripts/requirements.txt +20 -0
  506. package/.opencode/skills/databases/stacks/bigquery.md +231 -0
  507. package/.opencode/skills/databases/stacks/d1_cloudflare.md +137 -0
  508. package/.opencode/skills/databases/stacks/mysql.md +216 -0
  509. package/.opencode/skills/databases/stacks/postgres.md +235 -0
  510. package/.opencode/skills/databases/stacks/sqlite.md +244 -0
  511. package/.opencode/skills/databases/transactional.md +176 -0
  512. package/.opencode/skills/debugging/SKILL.md +87 -0
  513. package/.opencode/skills/debugging/references/defense-in-depth.md +124 -0
  514. package/.opencode/skills/debugging/references/root-cause-tracing.md +122 -0
  515. package/.opencode/skills/debugging/references/systematic-debugging.md +102 -0
  516. package/.opencode/skills/debugging/references/verification.md +123 -0
  517. package/.opencode/skills/debugging/scripts/find-polluter.sh +63 -0
  518. package/.opencode/skills/debugging/scripts/find-polluter.test.md +102 -0
  519. package/.opencode/skills/deploy/SKILL.md +157 -0
  520. package/.opencode/skills/deploy/references/platform-config-templates.md +35 -0
  521. package/.opencode/skills/deploy/references/platforms/aws.md +58 -0
  522. package/.opencode/skills/deploy/references/platforms/cloudflare.md +41 -0
  523. package/.opencode/skills/deploy/references/platforms/coolify.md +32 -0
  524. package/.opencode/skills/deploy/references/platforms/digitalocean.md +45 -0
  525. package/.opencode/skills/deploy/references/platforms/dokploy.md +29 -0
  526. package/.opencode/skills/deploy/references/platforms/flyio.md +54 -0
  527. package/.opencode/skills/deploy/references/platforms/gcp.md +45 -0
  528. package/.opencode/skills/deploy/references/platforms/github-pages.md +56 -0
  529. package/.opencode/skills/deploy/references/platforms/heroku.md +31 -0
  530. package/.opencode/skills/deploy/references/platforms/netlify.md +39 -0
  531. package/.opencode/skills/deploy/references/platforms/railway.md +38 -0
  532. package/.opencode/skills/deploy/references/platforms/render.md +39 -0
  533. package/.opencode/skills/deploy/references/platforms/tose.md +35 -0
  534. package/.opencode/skills/deploy/references/platforms/vercel.md +37 -0
  535. package/.opencode/skills/deploy/references/platforms/vultr.md +27 -0
  536. package/.opencode/skills/design/SKILL.md +302 -0
  537. package/.opencode/skills/design/data/cip/deliverables.csv +51 -0
  538. package/.opencode/skills/design/data/cip/industries.csv +21 -0
  539. package/.opencode/skills/design/data/cip/mockup-contexts.csv +21 -0
  540. package/.opencode/skills/design/data/cip/styles.csv +21 -0
  541. package/.opencode/skills/design/data/icon/styles.csv +16 -0
  542. package/.opencode/skills/design/data/logo/colors.csv +56 -0
  543. package/.opencode/skills/design/data/logo/industries.csv +56 -0
  544. package/.opencode/skills/design/data/logo/styles.csv +56 -0
  545. package/.opencode/skills/design/references/banner-sizes-and-styles.md +118 -0
  546. package/.opencode/skills/design/references/cip-deliverable-guide.md +95 -0
  547. package/.opencode/skills/design/references/cip-design.md +121 -0
  548. package/.opencode/skills/design/references/cip-prompt-engineering.md +84 -0
  549. package/.opencode/skills/design/references/cip-style-guide.md +68 -0
  550. package/.opencode/skills/design/references/design-routing.md +207 -0
  551. package/.opencode/skills/design/references/icon-design.md +122 -0
  552. package/.opencode/skills/design/references/logo-color-psychology.md +101 -0
  553. package/.opencode/skills/design/references/logo-design.md +92 -0
  554. package/.opencode/skills/design/references/logo-prompt-engineering.md +158 -0
  555. package/.opencode/skills/design/references/logo-style-guide.md +109 -0
  556. package/.opencode/skills/design/references/slides-copywriting-formulas.md +84 -0
  557. package/.opencode/skills/design/references/slides-create.md +4 -0
  558. package/.opencode/skills/design/references/slides-html-template.md +295 -0
  559. package/.opencode/skills/design/references/slides-layout-patterns.md +137 -0
  560. package/.opencode/skills/design/references/slides-strategies.md +94 -0
  561. package/.opencode/skills/design/references/slides.md +42 -0
  562. package/.opencode/skills/design/references/social-photos-design.md +329 -0
  563. package/.opencode/skills/design/scripts/cip/core.py +215 -0
  564. package/.opencode/skills/design/scripts/cip/generate.py +488 -0
  565. package/.opencode/skills/design/scripts/cip/render-html.py +424 -0
  566. package/.opencode/skills/design/scripts/cip/search.py +127 -0
  567. package/.opencode/skills/design/scripts/icon/generate.py +487 -0
  568. package/.opencode/skills/design/scripts/logo/core.py +175 -0
  569. package/.opencode/skills/design/scripts/logo/generate.py +363 -0
  570. package/.opencode/skills/design/scripts/logo/search.py +114 -0
  571. package/.opencode/skills/design-system/SKILL.md +244 -0
  572. package/.opencode/skills/design-system/data/slide-backgrounds.csv +11 -0
  573. package/.opencode/skills/design-system/data/slide-charts.csv +26 -0
  574. package/.opencode/skills/design-system/data/slide-color-logic.csv +14 -0
  575. package/.opencode/skills/design-system/data/slide-copy.csv +26 -0
  576. package/.opencode/skills/design-system/data/slide-layout-logic.csv +16 -0
  577. package/.opencode/skills/design-system/data/slide-layouts.csv +26 -0
  578. package/.opencode/skills/design-system/data/slide-strategies.csv +16 -0
  579. package/.opencode/skills/design-system/data/slide-typography.csv +15 -0
  580. package/.opencode/skills/design-system/references/component-specs.md +236 -0
  581. package/.opencode/skills/design-system/references/component-tokens.md +214 -0
  582. package/.opencode/skills/design-system/references/primitive-tokens.md +203 -0
  583. package/.opencode/skills/design-system/references/semantic-tokens.md +215 -0
  584. package/.opencode/skills/design-system/references/states-and-variants.md +241 -0
  585. package/.opencode/skills/design-system/references/tailwind-integration.md +251 -0
  586. package/.opencode/skills/design-system/references/token-architecture.md +224 -0
  587. package/.opencode/skills/design-system/scripts/embed-tokens.cjs +99 -0
  588. package/.opencode/skills/design-system/scripts/fetch-background.py +317 -0
  589. package/.opencode/skills/design-system/scripts/generate-slide.py +753 -0
  590. package/.opencode/skills/design-system/scripts/generate-tokens.cjs +205 -0
  591. package/.opencode/skills/design-system/scripts/html-token-validator.py +327 -0
  592. package/.opencode/skills/design-system/scripts/search-slides.py +218 -0
  593. package/.opencode/skills/design-system/scripts/slide-token-validator.py +35 -0
  594. package/.opencode/skills/design-system/scripts/slide_search_core.py +453 -0
  595. package/.opencode/skills/design-system/scripts/validate-tokens.cjs +251 -0
  596. package/.opencode/skills/design-system/templates/design-tokens-starter.json +143 -0
  597. package/.opencode/skills/devops/.env.example +76 -0
  598. package/.opencode/skills/devops/SKILL.md +288 -0
  599. package/.opencode/skills/devops/references/browser-rendering.md +305 -0
  600. package/.opencode/skills/devops/references/cloudflare-d1-kv.md +123 -0
  601. package/.opencode/skills/devops/references/cloudflare-platform.md +271 -0
  602. package/.opencode/skills/devops/references/cloudflare-r2-storage.md +280 -0
  603. package/.opencode/skills/devops/references/cloudflare-workers-advanced.md +312 -0
  604. package/.opencode/skills/devops/references/cloudflare-workers-apis.md +309 -0
  605. package/.opencode/skills/devops/references/cloudflare-workers-basics.md +418 -0
  606. package/.opencode/skills/devops/references/docker-basics.md +297 -0
  607. package/.opencode/skills/devops/references/docker-compose.md +292 -0
  608. package/.opencode/skills/devops/references/gcloud-platform.md +297 -0
  609. package/.opencode/skills/devops/references/gcloud-services.md +304 -0
  610. package/.opencode/skills/devops/references/kubernetes-basics.md +99 -0
  611. package/.opencode/skills/devops/references/kubernetes-helm-advanced.md +75 -0
  612. package/.opencode/skills/devops/references/kubernetes-helm.md +81 -0
  613. package/.opencode/skills/devops/references/kubernetes-kubectl.md +74 -0
  614. package/.opencode/skills/devops/references/kubernetes-security-advanced.md +98 -0
  615. package/.opencode/skills/devops/references/kubernetes-security.md +95 -0
  616. package/.opencode/skills/devops/references/kubernetes-troubleshooting-advanced.md +74 -0
  617. package/.opencode/skills/devops/references/kubernetes-troubleshooting.md +49 -0
  618. package/.opencode/skills/devops/references/kubernetes-workflows-advanced.md +75 -0
  619. package/.opencode/skills/devops/references/kubernetes-workflows.md +78 -0
  620. package/.opencode/skills/devops/scripts/cloudflare_deploy.py +269 -0
  621. package/.opencode/skills/devops/scripts/docker_optimize.py +331 -0
  622. package/.opencode/skills/devops/scripts/requirements.txt +20 -0
  623. package/.opencode/skills/docs/SKILL.md +23 -0
  624. package/.opencode/skills/docs/references/init-workflow.md +32 -0
  625. package/.opencode/skills/docs/references/init.md +23 -0
  626. package/.opencode/skills/docs/references/llms.md +8 -0
  627. package/.opencode/skills/docs/references/summarize-workflow.md +18 -0
  628. package/.opencode/skills/docs/references/summarize.md +18 -0
  629. package/.opencode/skills/docs/references/update-workflow.md +59 -0
  630. package/.opencode/skills/docs/references/update.md +32 -0
  631. package/.opencode/skills/docs-seeker/.env.example +15 -0
  632. package/.opencode/skills/docs-seeker/SKILL.md +100 -0
  633. package/.opencode/skills/docs-seeker/package.json +25 -0
  634. package/.opencode/skills/docs-seeker/references/advanced.md +79 -0
  635. package/.opencode/skills/docs-seeker/references/context7-patterns.md +68 -0
  636. package/.opencode/skills/docs-seeker/references/errors.md +68 -0
  637. package/.opencode/skills/docs-seeker/scripts/analyze-llms-txt.js +211 -0
  638. package/.opencode/skills/docs-seeker/scripts/detect-topic.js +172 -0
  639. package/.opencode/skills/docs-seeker/scripts/fetch-docs.js +213 -0
  640. package/.opencode/skills/docs-seeker/scripts/utils/env-loader.js +94 -0
  641. package/.opencode/skills/docs-seeker/workflows/library-search.md +87 -0
  642. package/.opencode/skills/docs-seeker/workflows/repo-analysis.md +91 -0
  643. package/.opencode/skills/docs-seeker/workflows/topic-search.md +77 -0
  644. package/.opencode/skills/elevenlabs/.env.example +3 -0
  645. package/.opencode/skills/elevenlabs/README.md +57 -0
  646. package/.opencode/skills/elevenlabs/SKILL.md +97 -0
  647. package/.opencode/skills/elevenlabs/references/available-models.md +720 -0
  648. package/.opencode/skills/elevenlabs/references/conversational-ai-agents-guide.md +168 -0
  649. package/.opencode/skills/elevenlabs/references/sound-effects-and-music-generation-guide.md +131 -0
  650. package/.opencode/skills/elevenlabs/references/text-to-speech-guide.md +132 -0
  651. package/.opencode/skills/elevenlabs/references/voice-cloning-guide.md +94 -0
  652. package/.opencode/skills/elevenlabs/references/voice-design-prompting-guide.md +96 -0
  653. package/.opencode/skills/elevenlabs/requirements.txt +1 -0
  654. package/.opencode/skills/elevenlabs/scripts/elevenlabs-sound-effects-generator.py +108 -0
  655. package/.opencode/skills/elevenlabs/scripts/elevenlabs-text-to-speech-generator.py +184 -0
  656. package/.opencode/skills/elevenlabs/scripts/elevenlabs-voice-cloner.py +127 -0
  657. package/.opencode/skills/elevenlabs/scripts/elevenlabs-voice-manager.py +194 -0
  658. package/.opencode/skills/email/SKILL.md +56 -0
  659. package/.opencode/skills/email/references/automation-flows.md +429 -0
  660. package/.opencode/skills/email/references/deliverability-checklist.md +73 -0
  661. package/.opencode/skills/email/references/email-templates.md +127 -0
  662. package/.opencode/skills/email/references/flow.md +165 -0
  663. package/.opencode/skills/email/references/sequence.md +166 -0
  664. package/.opencode/skills/email/references/subject-line-formulas.md +67 -0
  665. package/.opencode/skills/find-skills/SKILL.md +137 -0
  666. package/.opencode/skills/fix/SKILL.md +75 -0
  667. package/.opencode/skills/fix/references/complexity-assessment.md +61 -0
  668. package/.opencode/skills/fix/references/diagnosis-protocol.md +133 -0
  669. package/.opencode/skills/fix/references/mode-selection.md +46 -0
  670. package/.opencode/skills/fix/references/parallel-exploration.md +77 -0
  671. package/.opencode/skills/fix/references/prevention-gate.md +87 -0
  672. package/.opencode/skills/fix/references/review-cycle.md +77 -0
  673. package/.opencode/skills/fix/references/skill-activation-matrix.md +65 -0
  674. package/.opencode/skills/fix/references/task-orchestration.md +110 -0
  675. package/.opencode/skills/fix/references/workflow-ci.md +28 -0
  676. package/.opencode/skills/fix/references/workflow-deep.md +91 -0
  677. package/.opencode/skills/fix/references/workflow-logs.md +36 -0
  678. package/.opencode/skills/fix/references/workflow-quick.md +59 -0
  679. package/.opencode/skills/fix/references/workflow-standard.md +86 -0
  680. package/.opencode/skills/fix/references/workflow-test.md +36 -0
  681. package/.opencode/skills/fix/references/workflow-types.md +33 -0
  682. package/.opencode/skills/fix/references/workflow-ui.md +37 -0
  683. package/.opencode/skills/form-cro/SKILL.md +429 -0
  684. package/.opencode/skills/free-tool-strategy/SKILL.md +580 -0
  685. package/.opencode/skills/frontend-design/SKILL.md +81 -0
  686. package/.opencode/skills/frontend-design/references/ai-multimodal-overview.md +165 -0
  687. package/.opencode/skills/frontend-design/references/analysis-best-practices.md +80 -0
  688. package/.opencode/skills/frontend-design/references/analysis-prompts.md +141 -0
  689. package/.opencode/skills/frontend-design/references/analysis-techniques.md +118 -0
  690. package/.opencode/skills/frontend-design/references/animejs.md +396 -0
  691. package/.opencode/skills/frontend-design/references/anti-slop-rules.md +103 -0
  692. package/.opencode/skills/frontend-design/references/asset-generation.md +337 -0
  693. package/.opencode/skills/frontend-design/references/bento-motion-engine.md +142 -0
  694. package/.opencode/skills/frontend-design/references/design-extraction-overview.md +71 -0
  695. package/.opencode/skills/frontend-design/references/extraction-best-practices.md +141 -0
  696. package/.opencode/skills/frontend-design/references/extraction-output-templates.md +162 -0
  697. package/.opencode/skills/frontend-design/references/extraction-prompts.md +127 -0
  698. package/.opencode/skills/frontend-design/references/magicui-components.md +129 -0
  699. package/.opencode/skills/frontend-design/references/performance-guardrails.md +169 -0
  700. package/.opencode/skills/frontend-design/references/premium-design-patterns.md +93 -0
  701. package/.opencode/skills/frontend-design/references/redesign-audit-checklist.md +114 -0
  702. package/.opencode/skills/frontend-design/references/technical-accessibility.md +119 -0
  703. package/.opencode/skills/frontend-design/references/technical-best-practices.md +97 -0
  704. package/.opencode/skills/frontend-design/references/technical-optimization.md +44 -0
  705. package/.opencode/skills/frontend-design/references/technical-overview.md +90 -0
  706. package/.opencode/skills/frontend-design/references/technical-workflows.md +150 -0
  707. package/.opencode/skills/frontend-design/references/visual-analysis-overview.md +95 -0
  708. package/.opencode/skills/frontend-design/references/workflow-3d.md +102 -0
  709. package/.opencode/skills/frontend-design/references/workflow-describe.md +87 -0
  710. package/.opencode/skills/frontend-design/references/workflow-immersive.md +87 -0
  711. package/.opencode/skills/frontend-design/references/workflow-quick.md +57 -0
  712. package/.opencode/skills/frontend-design/references/workflow-screenshot.md +63 -0
  713. package/.opencode/skills/frontend-design/references/workflow-video.md +74 -0
  714. package/.opencode/skills/frontend-development/SKILL.md +403 -0
  715. package/.opencode/skills/frontend-development/resources/common-patterns.md +331 -0
  716. package/.opencode/skills/frontend-development/resources/complete-examples.md +872 -0
  717. package/.opencode/skills/frontend-development/resources/component-patterns.md +502 -0
  718. package/.opencode/skills/frontend-development/resources/data-fetching.md +767 -0
  719. package/.opencode/skills/frontend-development/resources/file-organization.md +502 -0
  720. package/.opencode/skills/frontend-development/resources/loading-and-error-states.md +501 -0
  721. package/.opencode/skills/frontend-development/resources/performance.md +406 -0
  722. package/.opencode/skills/frontend-development/resources/routing-guide.md +364 -0
  723. package/.opencode/skills/frontend-development/resources/styling-guide.md +428 -0
  724. package/.opencode/skills/frontend-development/resources/typescript-standards.md +418 -0
  725. package/.opencode/skills/funnel/SKILL.md +82 -0
  726. package/.opencode/skills/gamification-marketing/SKILL.md +95 -0
  727. package/.opencode/skills/gamification-marketing/references/analytics-events.md +84 -0
  728. package/.opencode/skills/gamification-marketing/references/campaign-templates.md +80 -0
  729. package/.opencode/skills/gamification-marketing/references/case-studies.md +60 -0
  730. package/.opencode/skills/gamification-marketing/references/challenge-configs.md +86 -0
  731. package/.opencode/skills/gamification-marketing/references/database-schema.md +98 -0
  732. package/.opencode/skills/gamification-marketing/references/implementation-guide.md +57 -0
  733. package/.opencode/skills/gamification-marketing/references/kpi-tracking.md +53 -0
  734. package/.opencode/skills/gamification-marketing/references/mechanics-selection.md +81 -0
  735. package/.opencode/skills/gamification-marketing/references/psychology-frameworks.md +96 -0
  736. package/.opencode/skills/git/SKILL.md +101 -0
  737. package/.opencode/skills/git/references/branch-management.md +88 -0
  738. package/.opencode/skills/git/references/commit-standards.md +45 -0
  739. package/.opencode/skills/git/references/gh-cli-guide.md +109 -0
  740. package/.opencode/skills/git/references/safety-protocols.md +69 -0
  741. package/.opencode/skills/git/references/workflow-commit.md +56 -0
  742. package/.opencode/skills/git/references/workflow-merge.md +48 -0
  743. package/.opencode/skills/git/references/workflow-pr.md +58 -0
  744. package/.opencode/skills/git/references/workflow-push.md +52 -0
  745. package/.opencode/skills/gkg/SKILL.md +94 -0
  746. package/.opencode/skills/gkg/references/cli-commands.md +106 -0
  747. package/.opencode/skills/gkg/references/http-api.md +102 -0
  748. package/.opencode/skills/gkg/references/language-support.md +57 -0
  749. package/.opencode/skills/gkg/references/mcp-tools.md +99 -0
  750. package/.opencode/skills/google-adk-python/SKILL.md +246 -0
  751. package/.opencode/skills/google-adk-python/references/agent-types-and-architecture.md +128 -0
  752. package/.opencode/skills/google-adk-python/references/callbacks-plugins-observability.md +117 -0
  753. package/.opencode/skills/google-adk-python/references/deployment-cloud-run-vertex-gke.md +138 -0
  754. package/.opencode/skills/google-adk-python/references/evaluation-testing-cli.md +112 -0
  755. package/.opencode/skills/google-adk-python/references/multi-agent-and-a2a-protocol.md +145 -0
  756. package/.opencode/skills/google-adk-python/references/sessions-state-memory-artifacts.md +131 -0
  757. package/.opencode/skills/google-adk-python/references/tools-and-mcp-integration.md +146 -0
  758. package/.opencode/skills/hub/SKILL.md +55 -0
  759. package/.opencode/skills/init/SKILL.md +219 -0
  760. package/.opencode/skills/journal/SKILL.md +22 -0
  761. package/.opencode/skills/kanban/SKILL.md +69 -0
  762. package/.opencode/skills/kit-builder/SKILL.md +85 -0
  763. package/.opencode/skills/kit-builder/references/agent-guide.md +79 -0
  764. package/.opencode/skills/kit-builder/references/best-practices.md +117 -0
  765. package/.opencode/skills/kit-builder/references/command-guide.md +91 -0
  766. package/.opencode/skills/kit-builder/references/marketing-checklist.md +121 -0
  767. package/.opencode/skills/kit-builder/references/skill-guide.md +74 -0
  768. package/.opencode/skills/kit-builder/references/workflow-guide.md +113 -0
  769. package/.opencode/skills/kit-builder/scripts/init_component.py +260 -0
  770. package/.opencode/skills/kit-builder/templates/agent-template.md +48 -0
  771. package/.opencode/skills/kit-builder/templates/command-template.md +37 -0
  772. package/.opencode/skills/kit-builder/templates/skill-template.md +53 -0
  773. package/.opencode/skills/kit-builder/templates/workflow-template.md +80 -0
  774. package/.opencode/skills/launch-strategy/SKILL.md +348 -0
  775. package/.opencode/skills/llms/SKILL.md +120 -0
  776. package/.opencode/skills/llms/references/llms-txt-specification.md +87 -0
  777. package/.opencode/skills/llms/scripts/generate-llms-txt.py +350 -0
  778. package/.opencode/skills/logo-design/SKILL.md +156 -0
  779. package/.opencode/skills/logo-design/data/colors.csv +56 -0
  780. package/.opencode/skills/logo-design/data/industries.csv +56 -0
  781. package/.opencode/skills/logo-design/data/styles.csv +56 -0
  782. package/.opencode/skills/logo-design/references/color-psychology.md +101 -0
  783. package/.opencode/skills/logo-design/references/prompt-engineering.md +158 -0
  784. package/.opencode/skills/logo-design/references/style-guide.md +109 -0
  785. package/.opencode/skills/logo-design/scripts/core.py +175 -0
  786. package/.opencode/skills/logo-design/scripts/generate.py +363 -0
  787. package/.opencode/skills/logo-design/scripts/search.py +114 -0
  788. package/.opencode/skills/markdown-novel-viewer/SKILL.md +285 -0
  789. package/.opencode/skills/markdown-novel-viewer/assets/directory-browser.css +215 -0
  790. package/.opencode/skills/markdown-novel-viewer/assets/novel-theme.css +872 -0
  791. package/.opencode/skills/markdown-novel-viewer/assets/reader.js +357 -0
  792. package/.opencode/skills/markdown-novel-viewer/assets/styles/novel-theme-base.css +54 -0
  793. package/.opencode/skills/markdown-novel-viewer/assets/styles/novel-theme-components.css +188 -0
  794. package/.opencode/skills/markdown-novel-viewer/assets/styles/novel-theme-content.css +178 -0
  795. package/.opencode/skills/markdown-novel-viewer/assets/styles/novel-theme-header.css +217 -0
  796. package/.opencode/skills/markdown-novel-viewer/assets/styles/novel-theme-mermaid.css +153 -0
  797. package/.opencode/skills/markdown-novel-viewer/assets/styles/novel-theme-overlays.css +202 -0
  798. package/.opencode/skills/markdown-novel-viewer/assets/styles/novel-theme-responsive.css +285 -0
  799. package/.opencode/skills/markdown-novel-viewer/assets/styles/novel-theme-sidebar.css +358 -0
  800. package/.opencode/skills/markdown-novel-viewer/assets/styles/novel-theme-variables.css +56 -0
  801. package/.opencode/skills/markdown-novel-viewer/assets/template.html +85 -0
  802. package/.opencode/skills/markdown-novel-viewer/bun.lock +38 -0
  803. package/.opencode/skills/markdown-novel-viewer/package.json +15 -0
  804. package/.opencode/skills/markdown-novel-viewer/scripts/lib/http-server.cjs +434 -0
  805. package/.opencode/skills/markdown-novel-viewer/scripts/lib/markdown-renderer.cjs +335 -0
  806. package/.opencode/skills/markdown-novel-viewer/scripts/lib/plan-navigator.cjs +509 -0
  807. package/.opencode/skills/markdown-novel-viewer/scripts/lib/port-finder.cjs +48 -0
  808. package/.opencode/skills/markdown-novel-viewer/scripts/lib/process-mgr.cjs +150 -0
  809. package/.opencode/skills/markdown-novel-viewer/scripts/server.cjs +411 -0
  810. package/.opencode/skills/marketing-dashboard/.env.example +15 -0
  811. package/.opencode/skills/marketing-dashboard/README.md +363 -0
  812. package/.opencode/skills/marketing-dashboard/SKILL.md +84 -0
  813. package/.opencode/skills/marketing-dashboard/app/.env.example +2 -0
  814. package/.opencode/skills/marketing-dashboard/app/README.md +5 -0
  815. package/.opencode/skills/marketing-dashboard/app/index.html +13 -0
  816. package/.opencode/skills/marketing-dashboard/app/package.json +31 -0
  817. package/.opencode/skills/marketing-dashboard/app/postcss.config.js +5 -0
  818. package/.opencode/skills/marketing-dashboard/app/public/vite.svg +1 -0
  819. package/.opencode/skills/marketing-dashboard/app/src/App.vue +9 -0
  820. package/.opencode/skills/marketing-dashboard/app/src/assets/vue.svg +1 -0
  821. package/.opencode/skills/marketing-dashboard/app/src/components/assets/AssetCard.vue +338 -0
  822. package/.opencode/skills/marketing-dashboard/app/src/components/assets/AssetGrid.vue +673 -0
  823. package/.opencode/skills/marketing-dashboard/app/src/components/assets/AssetPreview.vue +530 -0
  824. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/CodePreview.vue +402 -0
  825. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/ImagePreview.vue +282 -0
  826. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/InfographicPreview.vue +167 -0
  827. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/JsonVisualizer.vue +548 -0
  828. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/MarkdownPreview.vue +774 -0
  829. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/SlidePreview.vue +341 -0
  830. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/SocialPostPreview.vue +505 -0
  831. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/StoryboardPreview.vue +311 -0
  832. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/TranscriptPreview.vue +350 -0
  833. package/.opencode/skills/marketing-dashboard/app/src/components/assets/previews/VideoPreview.vue +351 -0
  834. package/.opencode/skills/marketing-dashboard/app/src/components/brand/ColorPalette.vue +131 -0
  835. package/.opencode/skills/marketing-dashboard/app/src/components/brand/ComponentShowcase.vue +188 -0
  836. package/.opencode/skills/marketing-dashboard/app/src/components/brand/LogoGallery.vue +167 -0
  837. package/.opencode/skills/marketing-dashboard/app/src/components/brand/SpacingScale.vue +33 -0
  838. package/.opencode/skills/marketing-dashboard/app/src/components/brand/TypographyPreview.vue +97 -0
  839. package/.opencode/skills/marketing-dashboard/app/src/components/brand/VoiceSummary.vue +92 -0
  840. package/.opencode/skills/marketing-dashboard/app/src/components/common/LoadingSpinner.vue +75 -0
  841. package/.opencode/skills/marketing-dashboard/app/src/components/common/Modal.vue +60 -0
  842. package/.opencode/skills/marketing-dashboard/app/src/components/common/Toast.vue +119 -0
  843. package/.opencode/skills/marketing-dashboard/app/src/components/layout/AppHeader.vue +17 -0
  844. package/.opencode/skills/marketing-dashboard/app/src/components/layout/AppLayout.vue +16 -0
  845. package/.opencode/skills/marketing-dashboard/app/src/components/layout/AppSidebar.vue +103 -0
  846. package/.opencode/skills/marketing-dashboard/app/src/config.js +1 -0
  847. package/.opencode/skills/marketing-dashboard/app/src/main.js +12 -0
  848. package/.opencode/skills/marketing-dashboard/app/src/router/index.js +33 -0
  849. package/.opencode/skills/marketing-dashboard/app/src/stores/assets.js +108 -0
  850. package/.opencode/skills/marketing-dashboard/app/src/stores/brand.js +94 -0
  851. package/.opencode/skills/marketing-dashboard/app/src/style.css +72 -0
  852. package/.opencode/skills/marketing-dashboard/app/src/views/AssetsView.vue +109 -0
  853. package/.opencode/skills/marketing-dashboard/app/src/views/BrandView.vue +82 -0
  854. package/.opencode/skills/marketing-dashboard/app/src/views/SettingsView.vue +108 -0
  855. package/.opencode/skills/marketing-dashboard/app/tailwind.config.js +34 -0
  856. package/.opencode/skills/marketing-dashboard/app/vite.config.js +19 -0
  857. package/.opencode/skills/marketing-dashboard/build.sh +43 -0
  858. package/.opencode/skills/marketing-dashboard/server/.env.example +2 -0
  859. package/.opencode/skills/marketing-dashboard/server/__tests__/ai.test.js +456 -0
  860. package/.opencode/skills/marketing-dashboard/server/__tests__/assets.test.js +286 -0
  861. package/.opencode/skills/marketing-dashboard/server/__tests__/brand-security.test.js +183 -0
  862. package/.opencode/skills/marketing-dashboard/server/__tests__/security-file-serving.test.js +159 -0
  863. package/.opencode/skills/marketing-dashboard/server/__tests__/test-db.js +31 -0
  864. package/.opencode/skills/marketing-dashboard/server/coverage_output.txt +7 -0
  865. package/.opencode/skills/marketing-dashboard/server/db/database.js +61 -0
  866. package/.opencode/skills/marketing-dashboard/server/db/schema.sql +26 -0
  867. package/.opencode/skills/marketing-dashboard/server/index.js +105 -0
  868. package/.opencode/skills/marketing-dashboard/server/lib/ai-bridge.cjs +201 -0
  869. package/.opencode/skills/marketing-dashboard/server/lib/brand-context.cjs +118 -0
  870. package/.opencode/skills/marketing-dashboard/server/lib/scanner.cjs +440 -0
  871. package/.opencode/skills/marketing-dashboard/server/middleware/auth.js +48 -0
  872. package/.opencode/skills/marketing-dashboard/server/package.json +31 -0
  873. package/.opencode/skills/marketing-dashboard/server/routes/assets.js +269 -0
  874. package/.opencode/skills/marketing-dashboard/server/routes/brand.js +143 -0
  875. package/.opencode/skills/marketing-dashboard/server/vitest.config.js +23 -0
  876. package/.opencode/skills/marketing-dashboard/start-production.sh +55 -0
  877. package/.opencode/skills/marketing-dashboard/start.sh +63 -0
  878. package/.opencode/skills/marketing-dashboard/stop.sh +54 -0
  879. package/.opencode/skills/marketing-dashboard/temp/enhance/enhance-1766508537903.md +7 -0
  880. package/.opencode/skills/marketing-ideas/SKILL.md +569 -0
  881. package/.opencode/skills/marketing-planning/SKILL.md +122 -0
  882. package/.opencode/skills/marketing-planning/references/brand-context.md +54 -0
  883. package/.opencode/skills/marketing-planning/references/output-standards.md +117 -0
  884. package/.opencode/skills/marketing-planning/references/plan-organization.md +109 -0
  885. package/.opencode/skills/marketing-planning/references/research-phase.md +39 -0
  886. package/.opencode/skills/marketing-planning/references/strategy-design.md +61 -0
  887. package/.opencode/skills/marketing-psychology/SKILL.md +455 -0
  888. package/.opencode/skills/marketing-research/SKILL.md +172 -0
  889. package/.opencode/skills/mcp-builder/LICENSE.txt +202 -0
  890. package/.opencode/skills/mcp-builder/SKILL.md +332 -0
  891. package/.opencode/skills/mcp-builder/reference/evaluation.md +602 -0
  892. package/.opencode/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
  893. package/.opencode/skills/mcp-builder/reference/node_mcp_server.md +916 -0
  894. package/.opencode/skills/mcp-builder/reference/python_mcp_server.md +752 -0
  895. package/.opencode/skills/mcp-builder/scripts/connections.py +151 -0
  896. package/.opencode/skills/mcp-builder/scripts/evaluation.py +373 -0
  897. package/.opencode/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  898. package/.opencode/skills/mcp-builder/scripts/requirements.txt +2 -0
  899. package/.opencode/skills/mcp-management/README.md +219 -0
  900. package/.opencode/skills/mcp-management/SKILL.md +213 -0
  901. package/.opencode/skills/mcp-management/assets/tools.json +3146 -0
  902. package/.opencode/skills/mcp-management/references/configuration.md +114 -0
  903. package/.opencode/skills/mcp-management/references/gemini-cli-integration.md +215 -0
  904. package/.opencode/skills/mcp-management/references/mcp-protocol.md +116 -0
  905. package/.opencode/skills/mcp-management/scripts/.env.example +10 -0
  906. package/.opencode/skills/mcp-management/scripts/cli.ts +195 -0
  907. package/.opencode/skills/mcp-management/scripts/dist/analyze-tools.js +70 -0
  908. package/.opencode/skills/mcp-management/scripts/dist/cli.js +160 -0
  909. package/.opencode/skills/mcp-management/scripts/dist/mcp-client.js +183 -0
  910. package/.opencode/skills/mcp-management/scripts/mcp-client.ts +230 -0
  911. package/.opencode/skills/mcp-management/scripts/package.json +20 -0
  912. package/.opencode/skills/mcp-management/scripts/tsconfig.json +15 -0
  913. package/.opencode/skills/media-processing/SKILL.md +95 -0
  914. package/.opencode/skills/media-processing/references/common-workflows.md +132 -0
  915. package/.opencode/skills/media-processing/references/ffmpeg-encoding.md +358 -0
  916. package/.opencode/skills/media-processing/references/ffmpeg-filters.md +503 -0
  917. package/.opencode/skills/media-processing/references/ffmpeg-streaming.md +403 -0
  918. package/.opencode/skills/media-processing/references/format-compatibility.md +375 -0
  919. package/.opencode/skills/media-processing/references/imagemagick-batch.md +612 -0
  920. package/.opencode/skills/media-processing/references/imagemagick-editing.md +623 -0
  921. package/.opencode/skills/media-processing/references/rmbg-background-removal.md +66 -0
  922. package/.opencode/skills/media-processing/references/troubleshooting.md +109 -0
  923. package/.opencode/skills/media-processing/scripts/README.md +111 -0
  924. package/.opencode/skills/media-processing/scripts/batch-remove-background.sh +124 -0
  925. package/.opencode/skills/media-processing/scripts/batch_resize.py +342 -0
  926. package/.opencode/skills/media-processing/scripts/media_convert.py +311 -0
  927. package/.opencode/skills/media-processing/scripts/remove-background.sh +96 -0
  928. package/.opencode/skills/media-processing/scripts/remove-bg-node.js +158 -0
  929. package/.opencode/skills/media-processing/scripts/requirements.txt +24 -0
  930. package/.opencode/skills/media-processing/scripts/video_optimize.py +414 -0
  931. package/.opencode/skills/mermaidjs-v11/SKILL.md +119 -0
  932. package/.opencode/skills/mermaidjs-v11/references/cli-usage.md +228 -0
  933. package/.opencode/skills/mermaidjs-v11/references/configuration.md +232 -0
  934. package/.opencode/skills/mermaidjs-v11/references/diagram-types.md +315 -0
  935. package/.opencode/skills/mermaidjs-v11/references/examples.md +344 -0
  936. package/.opencode/skills/mermaidjs-v11/references/integration.md +310 -0
  937. package/.opencode/skills/mintlify/SKILL.md +123 -0
  938. package/.opencode/skills/mintlify/references/ai-features-and-integrations-reference.md +756 -0
  939. package/.opencode/skills/mintlify/references/api-documentation-components-reference.md +873 -0
  940. package/.opencode/skills/mintlify/references/deployment-and-continuous-integration-reference.md +674 -0
  941. package/.opencode/skills/mintlify/references/docs-json-configuration-reference.md +724 -0
  942. package/.opencode/skills/mintlify/references/mdx-components-reference.md +551 -0
  943. package/.opencode/skills/mintlify/references/navigation-structure-and-organization-reference.md +775 -0
  944. package/.opencode/skills/mobile-development/SKILL.md +215 -0
  945. package/.opencode/skills/mobile-development/references/mobile-android.md +604 -0
  946. package/.opencode/skills/mobile-development/references/mobile-best-practices.md +545 -0
  947. package/.opencode/skills/mobile-development/references/mobile-debugging.md +1089 -0
  948. package/.opencode/skills/mobile-development/references/mobile-frameworks.md +465 -0
  949. package/.opencode/skills/mobile-development/references/mobile-ios.md +496 -0
  950. package/.opencode/skills/mobile-development/references/mobile-mindset.md +544 -0
  951. package/.opencode/skills/onboarding-cro/SKILL.md +437 -0
  952. package/.opencode/skills/paid-ads/SKILL.md +555 -0
  953. package/.opencode/skills/payment-integration/README.md +217 -0
  954. package/.opencode/skills/payment-integration/SKILL.md +156 -0
  955. package/.opencode/skills/payment-integration/references/creem/api.md +139 -0
  956. package/.opencode/skills/payment-integration/references/creem/checkouts.md +99 -0
  957. package/.opencode/skills/payment-integration/references/creem/licensing.md +136 -0
  958. package/.opencode/skills/payment-integration/references/creem/overview.md +65 -0
  959. package/.opencode/skills/payment-integration/references/creem/sdk.md +161 -0
  960. package/.opencode/skills/payment-integration/references/creem/subscriptions.md +129 -0
  961. package/.opencode/skills/payment-integration/references/creem/webhooks.md +120 -0
  962. package/.opencode/skills/payment-integration/references/implementation-workflows.md +43 -0
  963. package/.opencode/skills/payment-integration/references/multi-provider-order-management-patterns.md +821 -0
  964. package/.opencode/skills/payment-integration/references/paddle/api.md +116 -0
  965. package/.opencode/skills/payment-integration/references/paddle/best-practices.md +130 -0
  966. package/.opencode/skills/payment-integration/references/paddle/overview.md +57 -0
  967. package/.opencode/skills/payment-integration/references/paddle/paddle-js.md +106 -0
  968. package/.opencode/skills/payment-integration/references/paddle/sdk.md +131 -0
  969. package/.opencode/skills/payment-integration/references/paddle/subscriptions.md +118 -0
  970. package/.opencode/skills/payment-integration/references/paddle/webhooks.md +112 -0
  971. package/.opencode/skills/payment-integration/references/polar/benefits.md +396 -0
  972. package/.opencode/skills/payment-integration/references/polar/best-practices.md +902 -0
  973. package/.opencode/skills/payment-integration/references/polar/checkouts.md +266 -0
  974. package/.opencode/skills/payment-integration/references/polar/overview.md +184 -0
  975. package/.opencode/skills/payment-integration/references/polar/products.md +244 -0
  976. package/.opencode/skills/payment-integration/references/polar/sdk.md +436 -0
  977. package/.opencode/skills/payment-integration/references/polar/subscriptions.md +340 -0
  978. package/.opencode/skills/payment-integration/references/polar/webhooks.md +405 -0
  979. package/.opencode/skills/payment-integration/references/sepay/api.md +140 -0
  980. package/.opencode/skills/payment-integration/references/sepay/best-practices.md +939 -0
  981. package/.opencode/skills/payment-integration/references/sepay/overview.md +138 -0
  982. package/.opencode/skills/payment-integration/references/sepay/qr-codes.md +228 -0
  983. package/.opencode/skills/payment-integration/references/sepay/sdk.md +213 -0
  984. package/.opencode/skills/payment-integration/references/sepay/webhooks.md +208 -0
  985. package/.opencode/skills/payment-integration/references/stripe/stripe-best-practices.md +32 -0
  986. package/.opencode/skills/payment-integration/references/stripe/stripe-cli.md +148 -0
  987. package/.opencode/skills/payment-integration/references/stripe/stripe-js.md +116 -0
  988. package/.opencode/skills/payment-integration/references/stripe/stripe-sdks.md +84 -0
  989. package/.opencode/skills/payment-integration/references/stripe/stripe-upgrade.md +175 -0
  990. package/.opencode/skills/payment-integration/scripts/.env.example +20 -0
  991. package/.opencode/skills/payment-integration/scripts/checkout-helper.js +244 -0
  992. package/.opencode/skills/payment-integration/scripts/package.json +17 -0
  993. package/.opencode/skills/payment-integration/scripts/polar-webhook-verify.js +202 -0
  994. package/.opencode/skills/payment-integration/scripts/sepay-webhook-verify.js +193 -0
  995. package/.opencode/skills/payment-integration/scripts/test-scripts.js +237 -0
  996. package/.opencode/skills/persona/SKILL.md +66 -0
  997. package/.opencode/skills/plan/SKILL.md +53 -0
  998. package/.opencode/skills/plan/references/archive.md +52 -0
  999. package/.opencode/skills/plan/references/ci.md +28 -0
  1000. package/.opencode/skills/plan/references/cro.md +64 -0
  1001. package/.opencode/skills/plan/references/fast.md +61 -0
  1002. package/.opencode/skills/plan/references/hard.md +87 -0
  1003. package/.opencode/skills/plan/references/parallel.md +124 -0
  1004. package/.opencode/skills/plan/references/two.md +40 -0
  1005. package/.opencode/skills/plan/references/validate.md +112 -0
  1006. package/.opencode/skills/plans-kanban/SKILL.md +170 -0
  1007. package/.opencode/skills/plans-kanban/assets/dashboard-template.html +119 -0
  1008. package/.opencode/skills/plans-kanban/assets/dashboard.css +1594 -0
  1009. package/.opencode/skills/plans-kanban/assets/dashboard.js +596 -0
  1010. package/.opencode/skills/plans-kanban/package.json +13 -0
  1011. package/.opencode/skills/plans-kanban/scripts/lib/dashboard-renderer.cjs +884 -0
  1012. package/.opencode/skills/plans-kanban/scripts/lib/http-server.cjs +310 -0
  1013. package/.opencode/skills/plans-kanban/scripts/lib/plan-metadata-extractor.cjs +489 -0
  1014. package/.opencode/skills/plans-kanban/scripts/lib/plan-parser.cjs +175 -0
  1015. package/.opencode/skills/plans-kanban/scripts/lib/plan-scanner.cjs +272 -0
  1016. package/.opencode/skills/plans-kanban/scripts/lib/port-finder.cjs +48 -0
  1017. package/.opencode/skills/plans-kanban/scripts/lib/process-mgr.cjs +126 -0
  1018. package/.opencode/skills/plans-kanban/scripts/server.cjs +253 -0
  1019. package/.opencode/skills/play/SKILL.md +111 -0
  1020. package/.opencode/skills/play/references/blocked.md +55 -0
  1021. package/.opencode/skills/play/references/create.md +48 -0
  1022. package/.opencode/skills/play/references/gate.md +38 -0
  1023. package/.opencode/skills/play/references/goals.md +53 -0
  1024. package/.opencode/skills/play/references/learn.md +48 -0
  1025. package/.opencode/skills/play/references/list.md +34 -0
  1026. package/.opencode/skills/play/references/next.md +51 -0
  1027. package/.opencode/skills/play/references/reset.md +34 -0
  1028. package/.opencode/skills/play/references/status.md +56 -0
  1029. package/.opencode/skills/play/references/templates.md +38 -0
  1030. package/.opencode/skills/play/scripts/goals.cjs +229 -0
  1031. package/.opencode/skills/play/scripts/graph.cjs +331 -0
  1032. package/.opencode/skills/play/scripts/manifest.cjs +474 -0
  1033. package/.opencode/skills/play/scripts/metrics-bridge.cjs +355 -0
  1034. package/.opencode/skills/play/scripts/metrics-email.cjs +182 -0
  1035. package/.opencode/skills/play/scripts/metrics-social.cjs +151 -0
  1036. package/.opencode/skills/play/scripts/smart-suggest.cjs +292 -0
  1037. package/.opencode/skills/play/scripts/template-loader.cjs +359 -0
  1038. package/.opencode/skills/play/templates/_schema.json +150 -0
  1039. package/.opencode/skills/play/templates/campaign-sprint.json +195 -0
  1040. package/.opencode/skills/play/templates/content-engine.json +348 -0
  1041. package/.opencode/skills/play/templates/product-hunt-launch.json +210 -0
  1042. package/.opencode/skills/play/templates/saas-launch.json +224 -0
  1043. package/.opencode/skills/preview/SKILL.md +87 -0
  1044. package/.opencode/skills/preview/references/generation-modes.md +192 -0
  1045. package/.opencode/skills/preview/references/html-css-patterns.md +1717 -0
  1046. package/.opencode/skills/preview/references/html-design-guidelines.md +393 -0
  1047. package/.opencode/skills/preview/references/html-libraries.md +592 -0
  1048. package/.opencode/skills/preview/references/html-responsive-nav.md +212 -0
  1049. package/.opencode/skills/preview/references/html-slide-patterns.md +1401 -0
  1050. package/.opencode/skills/preview/references/view-mode.md +42 -0
  1051. package/.opencode/skills/preview/templates/architecture.html +650 -0
  1052. package/.opencode/skills/preview/templates/data-table.html +590 -0
  1053. package/.opencode/skills/preview/templates/mermaid-flowchart.html +768 -0
  1054. package/.opencode/skills/preview/templates/slide-deck.html +968 -0
  1055. package/.opencode/skills/pricing-strategy/SKILL.md +714 -0
  1056. package/.opencode/skills/problem-solving/SKILL.md +99 -0
  1057. package/.opencode/skills/problem-solving/references/attribution.md +69 -0
  1058. package/.opencode/skills/problem-solving/references/collision-zone-thinking.md +79 -0
  1059. package/.opencode/skills/problem-solving/references/inversion-exercise.md +91 -0
  1060. package/.opencode/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
  1061. package/.opencode/skills/problem-solving/references/scale-game.md +95 -0
  1062. package/.opencode/skills/problem-solving/references/simplification-cascades.md +80 -0
  1063. package/.opencode/skills/problem-solving/references/when-stuck.md +72 -0
  1064. package/.opencode/skills/project-management/SKILL.md +136 -0
  1065. package/.opencode/skills/project-management/references/documentation-triggers.md +60 -0
  1066. package/.opencode/skills/project-management/references/hydration-workflow.md +89 -0
  1067. package/.opencode/skills/project-management/references/progress-tracking.md +120 -0
  1068. package/.opencode/skills/project-management/references/reporting-patterns.md +94 -0
  1069. package/.opencode/skills/project-management/references/task-operations.md +87 -0
  1070. package/.opencode/skills/project-organization/SKILL.md +228 -0
  1071. package/.opencode/skills/project-organization/references/directory-patterns.md +176 -0
  1072. package/.opencode/skills/project-organization/references/markdown-body-templates.md +311 -0
  1073. package/.opencode/skills/project-organization/references/naming-conventions.md +140 -0
  1074. package/.opencode/skills/react-best-practices/AGENTS.md +2249 -0
  1075. package/.opencode/skills/react-best-practices/README.md +123 -0
  1076. package/.opencode/skills/react-best-practices/SKILL.md +125 -0
  1077. package/.opencode/skills/react-best-practices/metadata.json +15 -0
  1078. package/.opencode/skills/react-best-practices/rules/_sections.md +46 -0
  1079. package/.opencode/skills/react-best-practices/rules/_template.md +28 -0
  1080. package/.opencode/skills/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  1081. package/.opencode/skills/react-best-practices/rules/advanced-use-latest.md +49 -0
  1082. package/.opencode/skills/react-best-practices/rules/async-api-routes.md +38 -0
  1083. package/.opencode/skills/react-best-practices/rules/async-defer-await.md +80 -0
  1084. package/.opencode/skills/react-best-practices/rules/async-dependencies.md +36 -0
  1085. package/.opencode/skills/react-best-practices/rules/async-parallel.md +28 -0
  1086. package/.opencode/skills/react-best-practices/rules/async-suspense-boundaries.md +99 -0
  1087. package/.opencode/skills/react-best-practices/rules/bundle-barrel-imports.md +59 -0
  1088. package/.opencode/skills/react-best-practices/rules/bundle-conditional.md +31 -0
  1089. package/.opencode/skills/react-best-practices/rules/bundle-defer-third-party.md +49 -0
  1090. package/.opencode/skills/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  1091. package/.opencode/skills/react-best-practices/rules/bundle-preload.md +50 -0
  1092. package/.opencode/skills/react-best-practices/rules/client-event-listeners.md +74 -0
  1093. package/.opencode/skills/react-best-practices/rules/client-swr-dedup.md +56 -0
  1094. package/.opencode/skills/react-best-practices/rules/js-batch-dom-css.md +82 -0
  1095. package/.opencode/skills/react-best-practices/rules/js-cache-function-results.md +80 -0
  1096. package/.opencode/skills/react-best-practices/rules/js-cache-property-access.md +28 -0
  1097. package/.opencode/skills/react-best-practices/rules/js-cache-storage.md +70 -0
  1098. package/.opencode/skills/react-best-practices/rules/js-combine-iterations.md +32 -0
  1099. package/.opencode/skills/react-best-practices/rules/js-early-exit.md +50 -0
  1100. package/.opencode/skills/react-best-practices/rules/js-hoist-regexp.md +45 -0
  1101. package/.opencode/skills/react-best-practices/rules/js-index-maps.md +37 -0
  1102. package/.opencode/skills/react-best-practices/rules/js-length-check-first.md +49 -0
  1103. package/.opencode/skills/react-best-practices/rules/js-min-max-loop.md +82 -0
  1104. package/.opencode/skills/react-best-practices/rules/js-set-map-lookups.md +24 -0
  1105. package/.opencode/skills/react-best-practices/rules/js-tosorted-immutable.md +57 -0
  1106. package/.opencode/skills/react-best-practices/rules/rendering-activity.md +26 -0
  1107. package/.opencode/skills/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  1108. package/.opencode/skills/react-best-practices/rules/rendering-conditional-render.md +40 -0
  1109. package/.opencode/skills/react-best-practices/rules/rendering-content-visibility.md +38 -0
  1110. package/.opencode/skills/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  1111. package/.opencode/skills/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  1112. package/.opencode/skills/react-best-practices/rules/rendering-svg-precision.md +28 -0
  1113. package/.opencode/skills/react-best-practices/rules/rerender-defer-reads.md +39 -0
  1114. package/.opencode/skills/react-best-practices/rules/rerender-dependencies.md +45 -0
  1115. package/.opencode/skills/react-best-practices/rules/rerender-derived-state.md +29 -0
  1116. package/.opencode/skills/react-best-practices/rules/rerender-functional-setstate.md +74 -0
  1117. package/.opencode/skills/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  1118. package/.opencode/skills/react-best-practices/rules/rerender-memo.md +44 -0
  1119. package/.opencode/skills/react-best-practices/rules/rerender-transitions.md +40 -0
  1120. package/.opencode/skills/react-best-practices/rules/server-after-nonblocking.md +73 -0
  1121. package/.opencode/skills/react-best-practices/rules/server-cache-lru.md +41 -0
  1122. package/.opencode/skills/react-best-practices/rules/server-cache-react.md +26 -0
  1123. package/.opencode/skills/react-best-practices/rules/server-parallel-fetching.md +79 -0
  1124. package/.opencode/skills/react-best-practices/rules/server-serialization.md +38 -0
  1125. package/.opencode/skills/referral-program-building/SKILL.md +81 -0
  1126. package/.opencode/skills/referral-program-building/references/email-templates.md +75 -0
  1127. package/.opencode/skills/referral-program-building/references/fraud-prevention.md +95 -0
  1128. package/.opencode/skills/referral-program-building/references/metrics-tracking.md +64 -0
  1129. package/.opencode/skills/referral-program-building/references/platform-selection.md +80 -0
  1130. package/.opencode/skills/referral-program-building/references/reward-structures.md +82 -0
  1131. package/.opencode/skills/referral-program-building/references/technical-implementation.md +98 -0
  1132. package/.opencode/skills/remotion/SKILL.md +45 -0
  1133. package/.opencode/skills/remotion/rules/3d.md +86 -0
  1134. package/.opencode/skills/remotion/rules/animations.md +29 -0
  1135. package/.opencode/skills/remotion/rules/assets/charts-bar-chart.tsx +173 -0
  1136. package/.opencode/skills/remotion/rules/assets/text-animations-typewriter.tsx +100 -0
  1137. package/.opencode/skills/remotion/rules/assets/text-animations-word-highlight.tsx +108 -0
  1138. package/.opencode/skills/remotion/rules/assets.md +78 -0
  1139. package/.opencode/skills/remotion/rules/audio.md +172 -0
  1140. package/.opencode/skills/remotion/rules/calculate-metadata.md +104 -0
  1141. package/.opencode/skills/remotion/rules/can-decode.md +75 -0
  1142. package/.opencode/skills/remotion/rules/charts.md +58 -0
  1143. package/.opencode/skills/remotion/rules/compositions.md +146 -0
  1144. package/.opencode/skills/remotion/rules/display-captions.md +126 -0
  1145. package/.opencode/skills/remotion/rules/extract-frames.md +229 -0
  1146. package/.opencode/skills/remotion/rules/fonts.md +152 -0
  1147. package/.opencode/skills/remotion/rules/get-audio-duration.md +58 -0
  1148. package/.opencode/skills/remotion/rules/get-video-dimensions.md +68 -0
  1149. package/.opencode/skills/remotion/rules/get-video-duration.md +58 -0
  1150. package/.opencode/skills/remotion/rules/gifs.md +138 -0
  1151. package/.opencode/skills/remotion/rules/images.md +130 -0
  1152. package/.opencode/skills/remotion/rules/import-srt-captions.md +67 -0
  1153. package/.opencode/skills/remotion/rules/lottie.md +68 -0
  1154. package/.opencode/skills/remotion/rules/measuring-dom-nodes.md +35 -0
  1155. package/.opencode/skills/remotion/rules/measuring-text.md +143 -0
  1156. package/.opencode/skills/remotion/rules/sequencing.md +106 -0
  1157. package/.opencode/skills/remotion/rules/tailwind.md +11 -0
  1158. package/.opencode/skills/remotion/rules/text-animations.md +20 -0
  1159. package/.opencode/skills/remotion/rules/timing.md +179 -0
  1160. package/.opencode/skills/remotion/rules/transcribe-captions.md +19 -0
  1161. package/.opencode/skills/remotion/rules/transitions.md +122 -0
  1162. package/.opencode/skills/remotion/rules/trimming.md +53 -0
  1163. package/.opencode/skills/remotion/rules/videos.md +171 -0
  1164. package/.opencode/skills/repomix/SKILL.md +251 -0
  1165. package/.opencode/skills/repomix/references/configuration.md +211 -0
  1166. package/.opencode/skills/repomix/references/usage-patterns.md +232 -0
  1167. package/.opencode/skills/repomix/scripts/.coverage +0 -0
  1168. package/.opencode/skills/repomix/scripts/README.md +179 -0
  1169. package/.opencode/skills/repomix/scripts/repomix_batch.py +455 -0
  1170. package/.opencode/skills/repomix/scripts/repos.example.json +15 -0
  1171. package/.opencode/skills/repomix/scripts/requirements.txt +15 -0
  1172. package/.opencode/skills/research/SKILL.md +176 -0
  1173. package/.opencode/skills/retro/SKILL.md +138 -0
  1174. package/.opencode/skills/retro/references/metrics-guide.md +133 -0
  1175. package/.opencode/skills/retro/references/report-template.md +110 -0
  1176. package/.opencode/skills/scout/SKILL.md +82 -0
  1177. package/.opencode/skills/scout/references/external-scouting.md +140 -0
  1178. package/.opencode/skills/scout/references/internal-scouting.md +119 -0
  1179. package/.opencode/skills/scout/references/task-management-scouting.md +125 -0
  1180. package/.opencode/skills/security-scan/SKILL.md +141 -0
  1181. package/.opencode/skills/security-scan/references/secret-patterns.md +77 -0
  1182. package/.opencode/skills/security-scan/references/vulnerability-patterns.md +105 -0
  1183. package/.opencode/skills/seo/SKILL.md +95 -0
  1184. package/.opencode/skills/seo/references/audit.md +121 -0
  1185. package/.opencode/skills/seo/references/backlink-analysis-framework.md +192 -0
  1186. package/.opencode/skills/seo/references/browser-seo-audit-workflow.md +180 -0
  1187. package/.opencode/skills/seo/references/canonical-url-strategy.md +286 -0
  1188. package/.opencode/skills/seo/references/content-gap-analysis-framework.md +255 -0
  1189. package/.opencode/skills/seo/references/core-web-vitals-remediation.md +279 -0
  1190. package/.opencode/skills/seo/references/directory-submission-list.md +280 -0
  1191. package/.opencode/skills/seo/references/google-search-console-api-guide.md +745 -0
  1192. package/.opencode/skills/seo/references/internal-linking-automation.md +685 -0
  1193. package/.opencode/skills/seo/references/keyword-clustering-methodology.md +175 -0
  1194. package/.opencode/skills/seo/references/keyword-research-workflow.md +63 -0
  1195. package/.opencode/skills/seo/references/keywords.md +131 -0
  1196. package/.opencode/skills/seo/references/link-building-campaign-framework.md +246 -0
  1197. package/.opencode/skills/seo/references/meta-tag-templates.md +229 -0
  1198. package/.opencode/skills/seo/references/mobile-seo-checklist.md +557 -0
  1199. package/.opencode/skills/seo/references/on-page-seo-checklist-2025.md +328 -0
  1200. package/.opencode/skills/seo/references/outreach-email-templates.md +335 -0
  1201. package/.opencode/skills/seo/references/pseo-best-practices.md +366 -0
  1202. package/.opencode/skills/seo/references/pseo-scale-architecture.md +801 -0
  1203. package/.opencode/skills/seo/references/pseo-template-syntax.md +329 -0
  1204. package/.opencode/skills/seo/references/pseo-templates.md +85 -0
  1205. package/.opencode/skills/seo/references/pseo-url-structure-guide.md +562 -0
  1206. package/.opencode/skills/seo/references/pseo.md +62 -0
  1207. package/.opencode/skills/seo/references/readability-scoring-guide.md +304 -0
  1208. package/.opencode/skills/seo/references/reviewweb-api.md +69 -0
  1209. package/.opencode/skills/seo/references/reviewweb-content-api.md +89 -0
  1210. package/.opencode/skills/seo/references/robots-txt-best-practices-2025.md +479 -0
  1211. package/.opencode/skills/seo/references/schema-generation.md +102 -0
  1212. package/.opencode/skills/seo/references/schema-templates/article-schema.json +25 -0
  1213. package/.opencode/skills/seo/references/schema-templates/faq-schema.json +47 -0
  1214. package/.opencode/skills/seo/references/schema-templates/howto-schema.json +66 -0
  1215. package/.opencode/skills/seo/references/schema-templates/localbusiness-schema.json +64 -0
  1216. package/.opencode/skills/seo/references/schema-templates/organization-schema.json +49 -0
  1217. package/.opencode/skills/seo/references/schema-templates/product-schema.json +49 -0
  1218. package/.opencode/skills/seo/references/search-console-query-patterns.md +606 -0
  1219. package/.opencode/skills/seo/references/semantic-seo-framework.md +480 -0
  1220. package/.opencode/skills/seo/references/seo-audit-workflow.md +90 -0
  1221. package/.opencode/skills/seo/references/sitemap-best-practices.md +391 -0
  1222. package/.opencode/skills/seo/references/technical-seo-checklist.md +74 -0
  1223. package/.opencode/skills/seo/scripts/analyze-keywords.cjs +575 -0
  1224. package/.opencode/skills/seo/scripts/audit-core-web-vitals.cjs +496 -0
  1225. package/.opencode/skills/seo/scripts/env-loader.cjs +213 -0
  1226. package/.opencode/skills/seo/scripts/env-loader.test.cjs +231 -0
  1227. package/.opencode/skills/seo/scripts/generate-schema.cjs +119 -0
  1228. package/.opencode/skills/seo/scripts/generate-sitemap.cjs +66 -0
  1229. package/.opencode/skills/seo/scripts/gsc-auth.cjs +352 -0
  1230. package/.opencode/skills/seo/scripts/gsc-config-loader.cjs +238 -0
  1231. package/.opencode/skills/seo/scripts/gsc-query.cjs +499 -0
  1232. package/.opencode/skills/seo/scripts/pseo-generator.cjs +464 -0
  1233. package/.opencode/skills/seo/scripts/validate-schema.cjs +421 -0
  1234. package/.opencode/skills/sequential-thinking/.env.example +8 -0
  1235. package/.opencode/skills/sequential-thinking/README.md +183 -0
  1236. package/.opencode/skills/sequential-thinking/SKILL.md +97 -0
  1237. package/.opencode/skills/sequential-thinking/package.json +31 -0
  1238. package/.opencode/skills/sequential-thinking/references/advanced-strategies.md +79 -0
  1239. package/.opencode/skills/sequential-thinking/references/advanced-techniques.md +76 -0
  1240. package/.opencode/skills/sequential-thinking/references/core-patterns.md +95 -0
  1241. package/.opencode/skills/sequential-thinking/references/examples-api.md +88 -0
  1242. package/.opencode/skills/sequential-thinking/references/examples-architecture.md +94 -0
  1243. package/.opencode/skills/sequential-thinking/references/examples-debug.md +90 -0
  1244. package/.opencode/skills/sequential-thinking/scripts/format-thought.js +159 -0
  1245. package/.opencode/skills/sequential-thinking/scripts/process-thought.js +236 -0
  1246. package/.opencode/skills/shader/SKILL.md +115 -0
  1247. package/.opencode/skills/shader/references/glsl-cellular-voronoi-worley-noise-patterns.md +142 -0
  1248. package/.opencode/skills/shader/references/glsl-colors-rgb-hsb-gradients-mixing-color-spaces.md +143 -0
  1249. package/.opencode/skills/shader/references/glsl-fbm-fractional-brownian-motion-turbulence-octaves.md +146 -0
  1250. package/.opencode/skills/shader/references/glsl-fundamentals-data-types-vectors-precision-coordinates.md +104 -0
  1251. package/.opencode/skills/shader/references/glsl-noise-random-perlin-simplex-cellular-voronoi.md +115 -0
  1252. package/.opencode/skills/shader/references/glsl-pattern-symmetry-truchet-domain-warping.md +134 -0
  1253. package/.opencode/skills/shader/references/glsl-patterns-tiling-fract-matrices-transformations.md +133 -0
  1254. package/.opencode/skills/shader/references/glsl-procedural-textures-clouds-marble-wood-terrain.md +144 -0
  1255. package/.opencode/skills/shader/references/glsl-shader-builtin-functions-complete-api-reference.md +112 -0
  1256. package/.opencode/skills/shader/references/glsl-shapes-polygon-star-polar-sdf-combinations.md +124 -0
  1257. package/.opencode/skills/shader/references/glsl-shapes-sdf-circles-rectangles-polar-distance-fields.md +106 -0
  1258. package/.opencode/skills/shader/references/glsl-shaping-functions-step-smoothstep-curves-interpolation.md +141 -0
  1259. package/.opencode/skills/ship/SKILL.md +119 -0
  1260. package/.opencode/skills/ship/references/auto-detect.md +103 -0
  1261. package/.opencode/skills/ship/references/pr-template.md +90 -0
  1262. package/.opencode/skills/ship/references/ship-workflow.md +241 -0
  1263. package/.opencode/skills/shopify/README.md +66 -0
  1264. package/.opencode/skills/shopify/SKILL.md +323 -0
  1265. package/.opencode/skills/shopify/references/app-development.md +470 -0
  1266. package/.opencode/skills/shopify/references/extensions.md +493 -0
  1267. package/.opencode/skills/shopify/references/themes.md +498 -0
  1268. package/.opencode/skills/shopify/scripts/.coverage +0 -0
  1269. package/.opencode/skills/shopify/scripts/requirements.txt +19 -0
  1270. package/.opencode/skills/shopify/scripts/shopify_init.py +423 -0
  1271. package/.opencode/skills/skill-creator/LICENSE.txt +202 -0
  1272. package/.opencode/skills/skill-creator/SKILL.md +121 -0
  1273. package/.opencode/skills/skill-creator/agents/analyzer.md +274 -0
  1274. package/.opencode/skills/skill-creator/agents/comparator.md +202 -0
  1275. package/.opencode/skills/skill-creator/agents/grader.md +223 -0
  1276. package/.opencode/skills/skill-creator/assets/eval_review.html +146 -0
  1277. package/.opencode/skills/skill-creator/eval-viewer/generate_review.py +471 -0
  1278. package/.opencode/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  1279. package/.opencode/skills/skill-creator/references/benchmark-optimization-guide.md +86 -0
  1280. package/.opencode/skills/skill-creator/references/distribution-guide.md +79 -0
  1281. package/.opencode/skills/skill-creator/references/eval-infrastructure-guide.md +129 -0
  1282. package/.opencode/skills/skill-creator/references/eval-schemas.md +121 -0
  1283. package/.opencode/skills/skill-creator/references/mcp-skills-integration.md +71 -0
  1284. package/.opencode/skills/skill-creator/references/metadata-quality-criteria.md +76 -0
  1285. package/.opencode/skills/skill-creator/references/plugin-marketplace-hosting.md +104 -0
  1286. package/.opencode/skills/skill-creator/references/plugin-marketplace-overview.md +89 -0
  1287. package/.opencode/skills/skill-creator/references/plugin-marketplace-schema.md +93 -0
  1288. package/.opencode/skills/skill-creator/references/plugin-marketplace-sources.md +103 -0
  1289. package/.opencode/skills/skill-creator/references/plugin-marketplace-troubleshooting.md +76 -0
  1290. package/.opencode/skills/skill-creator/references/script-quality-criteria.md +106 -0
  1291. package/.opencode/skills/skill-creator/references/skill-anatomy-and-requirements.md +76 -0
  1292. package/.opencode/skills/skill-creator/references/skill-creation-workflow.md +95 -0
  1293. package/.opencode/skills/skill-creator/references/skill-design-patterns.md +75 -0
  1294. package/.opencode/skills/skill-creator/references/skillmark-benchmark-criteria.md +102 -0
  1295. package/.opencode/skills/skill-creator/references/structure-organization-criteria.md +114 -0
  1296. package/.opencode/skills/skill-creator/references/testing-and-iteration.md +78 -0
  1297. package/.opencode/skills/skill-creator/references/token-efficiency-criteria.md +74 -0
  1298. package/.opencode/skills/skill-creator/references/troubleshooting-guide.md +80 -0
  1299. package/.opencode/skills/skill-creator/references/validation-checklist.md +83 -0
  1300. package/.opencode/skills/skill-creator/references/writing-effective-instructions.md +88 -0
  1301. package/.opencode/skills/skill-creator/references/yaml-frontmatter-reference.md +91 -0
  1302. package/.opencode/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
  1303. package/.opencode/skills/skill-creator/scripts/debug.zip +0 -0
  1304. package/.opencode/skills/skill-creator/scripts/encoding_utils.py +36 -0
  1305. package/.opencode/skills/skill-creator/scripts/generate_report.py +326 -0
  1306. package/.opencode/skills/skill-creator/scripts/improve_description.py +248 -0
  1307. package/.opencode/skills/skill-creator/scripts/init_skill.py +308 -0
  1308. package/.opencode/skills/skill-creator/scripts/package_skill.py +115 -0
  1309. package/.opencode/skills/skill-creator/scripts/quick_validate.py +69 -0
  1310. package/.opencode/skills/skill-creator/scripts/run_eval.py +310 -0
  1311. package/.opencode/skills/skill-creator/scripts/run_loop.py +332 -0
  1312. package/.opencode/skills/skill-creator/scripts/utils.py +47 -0
  1313. package/.opencode/skills/slides/SKILL.md +42 -0
  1314. package/.opencode/skills/slides/references/copywriting-formulas.md +84 -0
  1315. package/.opencode/skills/slides/references/create.md +4 -0
  1316. package/.opencode/skills/slides/references/html-template.md +295 -0
  1317. package/.opencode/skills/slides/references/layout-patterns.md +137 -0
  1318. package/.opencode/skills/slides/references/slide-strategies.md +94 -0
  1319. package/.opencode/skills/social/SKILL.md +75 -0
  1320. package/.opencode/skills/social/references/engagement-templates.md +58 -0
  1321. package/.opencode/skills/social/references/facebook-workflow.md +175 -0
  1322. package/.opencode/skills/social/references/hook-writing.md +190 -0
  1323. package/.opencode/skills/social/references/linkedin-workflow.md +162 -0
  1324. package/.opencode/skills/social/references/platform-specs.md +58 -0
  1325. package/.opencode/skills/social/references/posting-best-practices.md +61 -0
  1326. package/.opencode/skills/social/references/rate-limits-errors.md +191 -0
  1327. package/.opencode/skills/social/references/schedule.md +50 -0
  1328. package/.opencode/skills/social/references/thread-templates.md +72 -0
  1329. package/.opencode/skills/social/references/threads-workflow.md +198 -0
  1330. package/.opencode/skills/social/references/tiktok-workflow.md +194 -0
  1331. package/.opencode/skills/social/references/unified-api-services.md +153 -0
  1332. package/.opencode/skills/social/references/x-twitter-workflow.md +111 -0
  1333. package/.opencode/skills/social/references/youtube-workflow.md +179 -0
  1334. package/.opencode/skills/social/scripts/schedule-post.js +222 -0
  1335. package/.opencode/skills/social/scripts/validate-post-content.js +195 -0
  1336. package/.opencode/skills/stitch/SKILL.md +171 -0
  1337. package/.opencode/skills/stitch/data/mcp-config-snippet.json +11 -0
  1338. package/.opencode/skills/stitch/references/design-to-code-pipeline.md +128 -0
  1339. package/.opencode/skills/stitch/references/quota-management.md +64 -0
  1340. package/.opencode/skills/stitch/references/stitch-mcp-setup.md +95 -0
  1341. package/.opencode/skills/stitch/references/stitch-sdk-api.md +136 -0
  1342. package/.opencode/skills/stitch/scripts/package.json +17 -0
  1343. package/.opencode/skills/stitch/scripts/stitch-export.ts +173 -0
  1344. package/.opencode/skills/stitch/scripts/stitch-generate.ts +182 -0
  1345. package/.opencode/skills/stitch/scripts/stitch-quota.ts +123 -0
  1346. package/.opencode/skills/storage/SKILL.md +93 -0
  1347. package/.opencode/skills/storage/scripts/s3-client.cjs +357 -0
  1348. package/.opencode/skills/tanstack/SKILL.md +144 -0
  1349. package/.opencode/skills/tanstack/references/tanstack-ai.md +97 -0
  1350. package/.opencode/skills/tanstack/references/tanstack-form.md +125 -0
  1351. package/.opencode/skills/tanstack/references/tanstack-start.md +100 -0
  1352. package/.opencode/skills/team/SKILL.md +361 -0
  1353. package/.opencode/skills/team/references/agent-teams-controls-and-modes.md +129 -0
  1354. package/.opencode/skills/team/references/agent-teams-examples-and-best-practices.md +220 -0
  1355. package/.opencode/skills/team/references/agent-teams-official-docs.md +221 -0
  1356. package/.opencode/skills/template-skill/SKILL.md +9 -0
  1357. package/.opencode/skills/test/SKILL.md +40 -0
  1358. package/.opencode/skills/test/references/report-format.md +58 -0
  1359. package/.opencode/skills/test/references/test-execution-workflow.md +103 -0
  1360. package/.opencode/skills/test/references/ui-testing-workflow.md +65 -0
  1361. package/.opencode/skills/test/references/ui.md +87 -0
  1362. package/.opencode/skills/test/references/workflow.md +102 -0
  1363. package/.opencode/skills/test/scripts/scan-components.py +281 -0
  1364. package/.opencode/skills/threejs/SKILL.md +144 -0
  1365. package/.opencode/skills/threejs/data/api-reference.csv +61 -0
  1366. package/.opencode/skills/threejs/data/categories.csv +14 -0
  1367. package/.opencode/skills/threejs/data/examples-all.csv +557 -0
  1368. package/.opencode/skills/threejs/data/use-cases.csv +21 -0
  1369. package/.opencode/skills/threejs/references/00-fundamentals.md +487 -0
  1370. package/.opencode/skills/threejs/references/01-getting-started.md +177 -0
  1371. package/.opencode/skills/threejs/references/02-loaders.md +169 -0
  1372. package/.opencode/skills/threejs/references/03-textures.md +170 -0
  1373. package/.opencode/skills/threejs/references/04-cameras.md +195 -0
  1374. package/.opencode/skills/threejs/references/05-lights.md +183 -0
  1375. package/.opencode/skills/threejs/references/06-animations.md +214 -0
  1376. package/.opencode/skills/threejs/references/07-math.md +260 -0
  1377. package/.opencode/skills/threejs/references/08-interaction.md +267 -0
  1378. package/.opencode/skills/threejs/references/09-postprocessing.md +240 -0
  1379. package/.opencode/skills/threejs/references/10-controls.md +259 -0
  1380. package/.opencode/skills/threejs/references/11-materials-advanced.md +270 -0
  1381. package/.opencode/skills/threejs/references/11-materials.md +519 -0
  1382. package/.opencode/skills/threejs/references/12-performance.md +269 -0
  1383. package/.opencode/skills/threejs/references/13-node-materials.md +298 -0
  1384. package/.opencode/skills/threejs/references/14-physics-vr.md +304 -0
  1385. package/.opencode/skills/threejs/references/15-specialized-loaders.md +333 -0
  1386. package/.opencode/skills/threejs/references/16-webgpu.md +302 -0
  1387. package/.opencode/skills/threejs/references/17-shader.md +641 -0
  1388. package/.opencode/skills/threejs/references/18-geometry.md +547 -0
  1389. package/.opencode/skills/threejs/scripts/core.py +236 -0
  1390. package/.opencode/skills/threejs/scripts/extract_examples.py +688 -0
  1391. package/.opencode/skills/threejs/scripts/generate_csv_from_json.py +135 -0
  1392. package/.opencode/skills/threejs/scripts/search.py +77 -0
  1393. package/.opencode/skills/ui-styling/LICENSE.txt +202 -0
  1394. package/.opencode/skills/ui-styling/SKILL.md +324 -0
  1395. package/.opencode/skills/ui-styling/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  1396. package/.opencode/skills/ui-styling/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  1397. package/.opencode/skills/ui-styling/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  1398. package/.opencode/skills/ui-styling/canvas-fonts/BigShoulders-OFL.txt +93 -0
  1399. package/.opencode/skills/ui-styling/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  1400. package/.opencode/skills/ui-styling/canvas-fonts/Boldonse-OFL.txt +93 -0
  1401. package/.opencode/skills/ui-styling/canvas-fonts/Boldonse-Regular.ttf +0 -0
  1402. package/.opencode/skills/ui-styling/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  1403. package/.opencode/skills/ui-styling/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  1404. package/.opencode/skills/ui-styling/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  1405. package/.opencode/skills/ui-styling/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  1406. package/.opencode/skills/ui-styling/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  1407. package/.opencode/skills/ui-styling/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  1408. package/.opencode/skills/ui-styling/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  1409. package/.opencode/skills/ui-styling/canvas-fonts/DMMono-OFL.txt +93 -0
  1410. package/.opencode/skills/ui-styling/canvas-fonts/DMMono-Regular.ttf +0 -0
  1411. package/.opencode/skills/ui-styling/canvas-fonts/EricaOne-OFL.txt +94 -0
  1412. package/.opencode/skills/ui-styling/canvas-fonts/EricaOne-Regular.ttf +0 -0
  1413. package/.opencode/skills/ui-styling/canvas-fonts/GeistMono-Bold.ttf +0 -0
  1414. package/.opencode/skills/ui-styling/canvas-fonts/GeistMono-OFL.txt +93 -0
  1415. package/.opencode/skills/ui-styling/canvas-fonts/GeistMono-Regular.ttf +0 -0
  1416. package/.opencode/skills/ui-styling/canvas-fonts/Gloock-OFL.txt +93 -0
  1417. package/.opencode/skills/ui-styling/canvas-fonts/Gloock-Regular.ttf +0 -0
  1418. package/.opencode/skills/ui-styling/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  1419. package/.opencode/skills/ui-styling/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  1420. package/.opencode/skills/ui-styling/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  1421. package/.opencode/skills/ui-styling/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  1422. package/.opencode/skills/ui-styling/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  1423. package/.opencode/skills/ui-styling/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  1424. package/.opencode/skills/ui-styling/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  1425. package/.opencode/skills/ui-styling/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  1426. package/.opencode/skills/ui-styling/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  1427. package/.opencode/skills/ui-styling/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  1428. package/.opencode/skills/ui-styling/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  1429. package/.opencode/skills/ui-styling/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  1430. package/.opencode/skills/ui-styling/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  1431. package/.opencode/skills/ui-styling/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  1432. package/.opencode/skills/ui-styling/canvas-fonts/Italiana-OFL.txt +93 -0
  1433. package/.opencode/skills/ui-styling/canvas-fonts/Italiana-Regular.ttf +0 -0
  1434. package/.opencode/skills/ui-styling/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  1435. package/.opencode/skills/ui-styling/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  1436. package/.opencode/skills/ui-styling/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  1437. package/.opencode/skills/ui-styling/canvas-fonts/Jura-Light.ttf +0 -0
  1438. package/.opencode/skills/ui-styling/canvas-fonts/Jura-Medium.ttf +0 -0
  1439. package/.opencode/skills/ui-styling/canvas-fonts/Jura-OFL.txt +93 -0
  1440. package/.opencode/skills/ui-styling/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  1441. package/.opencode/skills/ui-styling/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  1442. package/.opencode/skills/ui-styling/canvas-fonts/Lora-Bold.ttf +0 -0
  1443. package/.opencode/skills/ui-styling/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  1444. package/.opencode/skills/ui-styling/canvas-fonts/Lora-Italic.ttf +0 -0
  1445. package/.opencode/skills/ui-styling/canvas-fonts/Lora-OFL.txt +93 -0
  1446. package/.opencode/skills/ui-styling/canvas-fonts/Lora-Regular.ttf +0 -0
  1447. package/.opencode/skills/ui-styling/canvas-fonts/NationalPark-Bold.ttf +0 -0
  1448. package/.opencode/skills/ui-styling/canvas-fonts/NationalPark-OFL.txt +93 -0
  1449. package/.opencode/skills/ui-styling/canvas-fonts/NationalPark-Regular.ttf +0 -0
  1450. package/.opencode/skills/ui-styling/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  1451. package/.opencode/skills/ui-styling/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  1452. package/.opencode/skills/ui-styling/canvas-fonts/Outfit-Bold.ttf +0 -0
  1453. package/.opencode/skills/ui-styling/canvas-fonts/Outfit-OFL.txt +93 -0
  1454. package/.opencode/skills/ui-styling/canvas-fonts/Outfit-Regular.ttf +0 -0
  1455. package/.opencode/skills/ui-styling/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  1456. package/.opencode/skills/ui-styling/canvas-fonts/PixelifySans-OFL.txt +93 -0
  1457. package/.opencode/skills/ui-styling/canvas-fonts/PoiretOne-OFL.txt +93 -0
  1458. package/.opencode/skills/ui-styling/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  1459. package/.opencode/skills/ui-styling/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  1460. package/.opencode/skills/ui-styling/canvas-fonts/RedHatMono-OFL.txt +93 -0
  1461. package/.opencode/skills/ui-styling/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  1462. package/.opencode/skills/ui-styling/canvas-fonts/Silkscreen-OFL.txt +93 -0
  1463. package/.opencode/skills/ui-styling/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  1464. package/.opencode/skills/ui-styling/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  1465. package/.opencode/skills/ui-styling/canvas-fonts/SmoochSans-OFL.txt +93 -0
  1466. package/.opencode/skills/ui-styling/canvas-fonts/Tektur-Medium.ttf +0 -0
  1467. package/.opencode/skills/ui-styling/canvas-fonts/Tektur-OFL.txt +93 -0
  1468. package/.opencode/skills/ui-styling/canvas-fonts/Tektur-Regular.ttf +0 -0
  1469. package/.opencode/skills/ui-styling/canvas-fonts/WorkSans-Bold.ttf +0 -0
  1470. package/.opencode/skills/ui-styling/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  1471. package/.opencode/skills/ui-styling/canvas-fonts/WorkSans-Italic.ttf +0 -0
  1472. package/.opencode/skills/ui-styling/canvas-fonts/WorkSans-OFL.txt +93 -0
  1473. package/.opencode/skills/ui-styling/canvas-fonts/WorkSans-Regular.ttf +0 -0
  1474. package/.opencode/skills/ui-styling/canvas-fonts/YoungSerif-OFL.txt +93 -0
  1475. package/.opencode/skills/ui-styling/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  1476. package/.opencode/skills/ui-styling/references/canvas-design-system.md +320 -0
  1477. package/.opencode/skills/ui-styling/references/shadcn-accessibility.md +471 -0
  1478. package/.opencode/skills/ui-styling/references/shadcn-components.md +424 -0
  1479. package/.opencode/skills/ui-styling/references/shadcn-theming.md +373 -0
  1480. package/.opencode/skills/ui-styling/references/tailwind-customization.md +483 -0
  1481. package/.opencode/skills/ui-styling/references/tailwind-responsive.md +382 -0
  1482. package/.opencode/skills/ui-styling/references/tailwind-utilities.md +455 -0
  1483. package/.opencode/skills/ui-styling/scripts/.coverage +0 -0
  1484. package/.opencode/skills/ui-styling/scripts/requirements.txt +17 -0
  1485. package/.opencode/skills/ui-styling/scripts/shadcn_add.py +292 -0
  1486. package/.opencode/skills/ui-styling/scripts/tailwind_config_gen.py +456 -0
  1487. package/.opencode/skills/ui-ux-pro-max/SKILL.md +662 -0
  1488. package/.opencode/skills/ui-ux-pro-max/data/_sync_all.py +414 -0
  1489. package/.opencode/skills/ui-ux-pro-max/data/app-interface.csv +31 -0
  1490. package/.opencode/skills/ui-ux-pro-max/data/charts.csv +26 -0
  1491. package/.opencode/skills/ui-ux-pro-max/data/colors.csv +162 -0
  1492. package/.opencode/skills/ui-ux-pro-max/data/design.csv +1776 -0
  1493. package/.opencode/skills/ui-ux-pro-max/data/draft.csv +1779 -0
  1494. package/.opencode/skills/ui-ux-pro-max/data/google-fonts.csv +1924 -0
  1495. package/.opencode/skills/ui-ux-pro-max/data/icons.csv +106 -0
  1496. package/.opencode/skills/ui-ux-pro-max/data/landing.csv +35 -0
  1497. package/.opencode/skills/ui-ux-pro-max/data/products.csv +162 -0
  1498. package/.opencode/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
  1499. package/.opencode/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  1500. package/.opencode/skills/ui-ux-pro-max/data/styles.csv +85 -0
  1501. package/.opencode/skills/ui-ux-pro-max/data/typography.csv +74 -0
  1502. package/.opencode/skills/ui-ux-pro-max/data/ui-reasoning.csv +162 -0
  1503. package/.opencode/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  1504. package/.opencode/skills/ui-ux-pro-max/scripts/core.py +247 -0
  1505. package/.opencode/skills/ui-ux-pro-max/scripts/design_system.py +1067 -0
  1506. package/.opencode/skills/ui-ux-pro-max/scripts/search.py +114 -0
  1507. package/.opencode/skills/use-mcp/SKILL.md +39 -0
  1508. package/.opencode/skills/video/SKILL.md +72 -0
  1509. package/.opencode/skills/video/references/audio-directive-guide.md +274 -0
  1510. package/.opencode/skills/video/references/create.md +322 -0
  1511. package/.opencode/skills/video/references/production-workflow.md +135 -0
  1512. package/.opencode/skills/video/references/quality-review-workflow.md +566 -0
  1513. package/.opencode/skills/video/references/script-create.md +391 -0
  1514. package/.opencode/skills/video/references/script-templates.md +107 -0
  1515. package/.opencode/skills/video/references/storyboard-create.md +210 -0
  1516. package/.opencode/skills/video/references/storyboard-format.md +255 -0
  1517. package/.opencode/skills/video/references/thumbnail-design-guide.md +367 -0
  1518. package/.opencode/skills/video/references/veo-prompt-guide.md +360 -0
  1519. package/.opencode/skills/video/references/video-art-directions.md +64 -0
  1520. package/.opencode/skills/video/references/video-optimization.md +95 -0
  1521. package/.opencode/skills/video/references/video-seo-optimization.md +399 -0
  1522. package/.opencode/skills/video/references/video-types-specs.md +66 -0
  1523. package/.opencode/skills/video/scripts/analyze-video.cjs +321 -0
  1524. package/.opencode/skills/video/scripts/create-storyboard.cjs +476 -0
  1525. package/.opencode/skills/video/scripts/extract-captions.cjs +355 -0
  1526. package/.opencode/skills/video/scripts/generate-video.cjs +331 -0
  1527. package/.opencode/skills/video/scripts/optimize-for-platform.cjs +428 -0
  1528. package/.opencode/skills/video/templates/explainer.json +73 -0
  1529. package/.opencode/skills/video/templates/product-demo.json +69 -0
  1530. package/.opencode/skills/video/templates/short-form.json +111 -0
  1531. package/.opencode/skills/video/templates/testimonial.json +73 -0
  1532. package/.opencode/skills/watzup/SKILL.md +13 -0
  1533. package/.opencode/skills/web-design-guidelines/SKILL.md +39 -0
  1534. package/.opencode/skills/web-frameworks/SKILL.md +327 -0
  1535. package/.opencode/skills/web-frameworks/references/nextjs-app-router.md +465 -0
  1536. package/.opencode/skills/web-frameworks/references/nextjs-data-fetching.md +459 -0
  1537. package/.opencode/skills/web-frameworks/references/nextjs-optimization.md +511 -0
  1538. package/.opencode/skills/web-frameworks/references/nextjs-server-components.md +495 -0
  1539. package/.opencode/skills/web-frameworks/references/remix-icon-integration.md +603 -0
  1540. package/.opencode/skills/web-frameworks/references/turborepo-caching.md +551 -0
  1541. package/.opencode/skills/web-frameworks/references/turborepo-pipelines.md +517 -0
  1542. package/.opencode/skills/web-frameworks/references/turborepo-setup.md +542 -0
  1543. package/.opencode/skills/web-frameworks/scripts/.coverage +0 -0
  1544. package/.opencode/skills/web-frameworks/scripts/__init__.py +0 -0
  1545. package/.opencode/skills/web-frameworks/scripts/nextjs_init.py +547 -0
  1546. package/.opencode/skills/web-frameworks/scripts/requirements.txt +16 -0
  1547. package/.opencode/skills/web-frameworks/scripts/turborepo_migrate.py +394 -0
  1548. package/.opencode/skills/web-testing/SKILL.md +99 -0
  1549. package/.opencode/skills/web-testing/references/accessibility-testing.md +84 -0
  1550. package/.opencode/skills/web-testing/references/api-testing.md +78 -0
  1551. package/.opencode/skills/web-testing/references/ci-cd-testing-workflows.md +121 -0
  1552. package/.opencode/skills/web-testing/references/component-testing.md +94 -0
  1553. package/.opencode/skills/web-testing/references/contract-testing.md +146 -0
  1554. package/.opencode/skills/web-testing/references/cross-browser-checklist.md +72 -0
  1555. package/.opencode/skills/web-testing/references/database-testing.md +139 -0
  1556. package/.opencode/skills/web-testing/references/e2e-testing-playwright.md +119 -0
  1557. package/.opencode/skills/web-testing/references/functional-testing-checklist.md +88 -0
  1558. package/.opencode/skills/web-testing/references/interactive-testing-patterns.md +89 -0
  1559. package/.opencode/skills/web-testing/references/load-testing-k6.md +93 -0
  1560. package/.opencode/skills/web-testing/references/mobile-gesture-testing.md +85 -0
  1561. package/.opencode/skills/web-testing/references/performance-core-web-vitals.md +124 -0
  1562. package/.opencode/skills/web-testing/references/playwright-component-testing.md +115 -0
  1563. package/.opencode/skills/web-testing/references/pre-release-checklist.md +75 -0
  1564. package/.opencode/skills/web-testing/references/security-checklists.md +81 -0
  1565. package/.opencode/skills/web-testing/references/security-testing-overview.md +92 -0
  1566. package/.opencode/skills/web-testing/references/shadow-dom-testing.md +70 -0
  1567. package/.opencode/skills/web-testing/references/test-data-management.md +131 -0
  1568. package/.opencode/skills/web-testing/references/test-flakiness-mitigation.md +86 -0
  1569. package/.opencode/skills/web-testing/references/testing-pyramid-strategy.md +76 -0
  1570. package/.opencode/skills/web-testing/references/unit-integration-testing.md +138 -0
  1571. package/.opencode/skills/web-testing/references/visual-regression.md +92 -0
  1572. package/.opencode/skills/web-testing/references/vulnerability-payloads.md +93 -0
  1573. package/.opencode/skills/web-testing/scripts/analyze-test-results.js +280 -0
  1574. package/.opencode/skills/web-testing/scripts/init-playwright.js +233 -0
  1575. package/.opencode/skills/worktree/SKILL.md +130 -0
  1576. package/.opencode/skills/worktree/scripts/worktree.cjs +979 -0
  1577. package/.opencode/skills/worktree/scripts/worktree.test.cjs +857 -0
  1578. package/.opencode/skills/write/SKILL.md +28 -0
  1579. package/.opencode/skills/write/references/audit.md +93 -0
  1580. package/.opencode/skills/write/references/blog-youtube.md +164 -0
  1581. package/.opencode/skills/write/references/blog.md +95 -0
  1582. package/.opencode/skills/write/references/cro.md +38 -0
  1583. package/.opencode/skills/write/references/enhance.md +9 -0
  1584. package/.opencode/skills/write/references/fast.md +8 -0
  1585. package/.opencode/skills/write/references/formula.md +112 -0
  1586. package/.opencode/skills/write/references/good.md +29 -0
  1587. package/.opencode/skills/write/references/publish.md +70 -0
  1588. package/.opencode/skills/youtube/SKILL.md +50 -0
  1589. package/.opencode/skills/youtube/references/api-content.md +96 -0
  1590. package/.opencode/skills/youtube/references/api-media.md +66 -0
  1591. package/.opencode/skills/youtube/references/blog.md +132 -0
  1592. package/.opencode/skills/youtube/references/infographic.md +152 -0
  1593. package/.opencode/skills/youtube/references/social.md +165 -0
  1594. package/.opencode/skills/youtube/scripts/test_vidcap.py +172 -0
  1595. package/.opencode/skills/youtube/scripts/vidcap.py +302 -0
  1596. package/.opencode/skills/youtube-thumbnail-design/SKILL.md +186 -0
  1597. package/.opencode/skills/youtube-thumbnail-design/data/niches.csv +13 -0
  1598. package/.opencode/skills/youtube-thumbnail-design/data/styles.csv +18 -0
  1599. package/.opencode/skills/youtube-thumbnail-design/references/thumbnail-styles.md +170 -0
  1600. package/.opencode/skills/youtube-thumbnail-design/scripts/core.py +150 -0
  1601. package/.opencode/skills/youtube-thumbnail-design/scripts/generate.py +441 -0
  1602. package/.opencode/skills/youtube-thumbnail-design/scripts/search.py +115 -0
  1603. package/.opencode/workflows/analytics-workflow.md +264 -0
  1604. package/.opencode/workflows/campaign-workflow.md +228 -0
  1605. package/.opencode/workflows/content-workflow.md +275 -0
  1606. package/.opencode/workflows/development-rules.md +42 -0
  1607. package/.opencode/workflows/documentation-management.md +121 -0
  1608. package/.opencode/workflows/marketing-workflow.md +198 -0
  1609. package/.opencode/workflows/orchestration-protocol.md +16 -0
  1610. package/.opencode/workflows/primary-workflow.md +45 -0
  1611. package/.opencode/workflows/sales-workflow.md +193 -0
  1612. package/.opencode/workflows/seo-workflow.md +248 -0
  1613. package/.repomixignore +22 -0
  1614. package/AGENTS.md +62 -0
  1615. package/CHANGELOG.md +12 -0
  1616. package/dist/web/assets/chat-tab-B3ut-s33.js +10 -0
  1617. package/dist/web/assets/{code-editor-BFe-hnpF.js → code-editor-CKhVVTIi.js} +1 -1
  1618. package/dist/web/assets/{database-viewer-BeY2V5QI.js → database-viewer-VT17cuX4.js} +1 -1
  1619. package/dist/web/assets/{diff-viewer-D6xzs8PP.js → diff-viewer-D6gXDpSU.js} +1 -1
  1620. package/dist/web/assets/{extension-webview-Cd1XYFXO.js → extension-webview-CAQUbBuw.js} +1 -1
  1621. package/dist/web/assets/{git-graph-D2XXpiMQ.js → git-graph-CdRJbH07.js} +1 -1
  1622. package/dist/web/assets/{index-D6_wwsL_.js → index-BFXOaZuI.js} +9 -9
  1623. package/dist/web/assets/{index-BtwsLrdT.css → index-Dxq-L2b4.css} +1 -1
  1624. package/dist/web/assets/keybindings-store-A-4OusX7.js +1 -0
  1625. package/dist/web/assets/{markdown-renderer-xYMhd9cE.js → markdown-renderer-Br_NykOI.js} +2 -2
  1626. package/dist/web/assets/{port-forwarding-tab-B5rj_I66.js → port-forwarding-tab-1vSZG1Ga.js} +1 -1
  1627. package/dist/web/assets/{postgres-viewer-DnlqzOnm.js → postgres-viewer-Bn8hKEnP.js} +1 -1
  1628. package/dist/web/assets/{settings-tab-CNZpuPD3.js → settings-tab-CpG9UbHr.js} +1 -1
  1629. package/dist/web/assets/{sql-query-editor-Df2kzbPj.js → sql-query-editor-yvUfZVDr.js} +1 -1
  1630. package/dist/web/assets/{sqlite-viewer-Cj1G70z4.js → sqlite-viewer-BSFIa0hd.js} +1 -1
  1631. package/dist/web/assets/{terminal-tab-Dv9A7Xe2.js → terminal-tab-CbIBTfPE.js} +1 -1
  1632. package/dist/web/assets/{use-monaco-theme-CPfIEo8t.js → use-monaco-theme-x9tJcwlL.js} +1 -1
  1633. package/dist/web/index.html +2 -2
  1634. package/dist/web/sw.js +1 -1
  1635. package/package.json +1 -1
  1636. package/release-manifest.json +15784 -0
  1637. package/src/providers/claude-agent-sdk.ts +10 -10
  1638. package/src/server/ws/chat.ts +15 -0
  1639. package/src/services/cloud-ws.service.ts +4 -1
  1640. package/src/services/tunnel.service.ts +19 -1
  1641. package/src/web/components/chat/chat-history-bar.tsx +2 -15
  1642. package/src/web/components/chat/chat-tab.tsx +1 -1
  1643. package/src/web/components/chat/message-list.tsx +17 -3
  1644. package/src/web/components/layout/mobile-nav.tsx +47 -21
  1645. package/src/web/components/layout/panel-layout.tsx +11 -0
  1646. package/src/web/components/shared/markdown-renderer.tsx +3 -2
  1647. package/src/web/hooks/use-chat.ts +30 -0
  1648. package/src/web/stores/panel-store.ts +25 -1
  1649. package/src/web/styles/globals.css +14 -0
  1650. package/dist/web/assets/chat-tab-CmSLt4tg.js +0 -10
  1651. package/dist/web/assets/keybindings-store-C8ryKudw.js +0 -1
@@ -0,0 +1,1717 @@
1
+ # CSS Patterns for HTML Diagrams
2
+
3
+ Reusable patterns for layout, connectors, theming, and visual effects in self-contained HTML diagrams.
4
+
5
+ ## Theme Setup
6
+
7
+ Always define both light and dark palettes via custom properties. Start with whichever fits the chosen aesthetic, ensure both work.
8
+
9
+ **Palette cohesion rule:** Background, text, and accent colors must belong to the same color family. A warm palette (terracotta, cream, sage) should have warm grays for text-dim and warm-tinted borders — never mix warm accents with cool GitHub-gray backgrounds. Each page should feel like one intentional color story, not a generic template with an accent color dropped on top.
10
+
11
+ **Semantic color richness:** Define 5-6 semantic colors per palette, not just 3 node colors. Richer palettes give the page visual variety without clashing. Include status colors (--green, --red/danger, --amber) and secondary accents (--sage, --teal, --plum) so different sections can have distinct character while staying harmonious.
12
+
13
+ Light is the default. Dark activates via OS preference (`@media`) OR manual toggle (`[data-theme="dark"]`). The `[data-theme]` selector has higher specificity, so a manual toggle always wins.
14
+
15
+ ```css
16
+ /* ── Light (default) ── */
17
+ :root {
18
+ --font-body: 'IBM Plex Sans', system-ui, sans-serif;
19
+ --font-mono: 'IBM Plex Mono', 'SF Mono', Consolas, monospace;
20
+
21
+ --bg: #faf7f5;
22
+ --surface: #ffffff;
23
+ --surface2: #f5f0ec;
24
+ --surface-elevated: #fff9f5;
25
+ --border: rgba(0, 0, 0, 0.07);
26
+ --border-bright: rgba(0, 0, 0, 0.14);
27
+ --text: #292017;
28
+ --text-dim: #8a7e72;
29
+ --text-bright: #1a1510;
30
+ --accent: #c2410c;
31
+ --accent-dim: rgba(194, 65, 12, 0.07);
32
+
33
+ --node-a: #c2410c;
34
+ --node-a-dim: rgba(194, 65, 12, 0.07);
35
+ --node-b: #4d7c0f;
36
+ --node-b-dim: rgba(77, 124, 15, 0.07);
37
+ --node-c: #0f766e;
38
+ --node-c-dim: rgba(15, 118, 110, 0.07);
39
+
40
+ --green: #4d7c0f;
41
+ --green-dim: rgba(77, 124, 15, 0.07);
42
+ --red: #b91c1c;
43
+ --red-dim: rgba(185, 28, 28, 0.07);
44
+ --amber: #b45309;
45
+ --amber-dim: rgba(180, 83, 9, 0.07);
46
+ --sage: #65a30d;
47
+ --sage-dim: rgba(101, 163, 13, 0.07);
48
+ --teal: #0f766e;
49
+ --teal-dim: rgba(15, 118, 110, 0.07);
50
+ --plum: #9f1239;
51
+ --plum-dim: rgba(159, 18, 57, 0.07);
52
+ }
53
+
54
+ /* ── Dark (OS preference fallback) ── */
55
+ @media (prefers-color-scheme: dark) {
56
+ :root:not([data-theme="light"]) {
57
+ --bg: #1a1412;
58
+ --surface: #231d1a;
59
+ --surface2: #2e2622;
60
+ --surface-elevated: #352d28;
61
+ --border: rgba(255, 255, 255, 0.06);
62
+ --border-bright: rgba(255, 255, 255, 0.12);
63
+ --text: #ede5dd;
64
+ --text-dim: #a69889;
65
+ --text-bright: #faf5f0;
66
+ --accent: #fb923c;
67
+ --accent-dim: rgba(251, 146, 60, 0.12);
68
+
69
+ --node-a: #fb923c;
70
+ --node-a-dim: rgba(251, 146, 60, 0.12);
71
+ --node-b: #a3e635;
72
+ --node-b-dim: rgba(163, 230, 53, 0.1);
73
+ --node-c: #5eead4;
74
+ --node-c-dim: rgba(94, 234, 212, 0.1);
75
+
76
+ --green: #a3e635;
77
+ --green-dim: rgba(163, 230, 53, 0.1);
78
+ --red: #fca5a5;
79
+ --red-dim: rgba(252, 165, 165, 0.1);
80
+ --amber: #fbbf24;
81
+ --amber-dim: rgba(251, 191, 36, 0.1);
82
+ --sage: #bef264;
83
+ --sage-dim: rgba(190, 242, 100, 0.1);
84
+ --teal: #5eead4;
85
+ --teal-dim: rgba(94, 234, 212, 0.1);
86
+ --plum: #fda4af;
87
+ --plum-dim: rgba(253, 164, 175, 0.1);
88
+ }
89
+ }
90
+
91
+ /* ── Dark (manual toggle override) ── */
92
+ [data-theme="dark"] {
93
+ --bg: #1a1412;
94
+ --surface: #231d1a;
95
+ --surface2: #2e2622;
96
+ --surface-elevated: #352d28;
97
+ --border: rgba(255, 255, 255, 0.06);
98
+ --border-bright: rgba(255, 255, 255, 0.12);
99
+ --text: #ede5dd;
100
+ --text-dim: #a69889;
101
+ --text-bright: #faf5f0;
102
+ --accent: #fb923c;
103
+ --accent-dim: rgba(251, 146, 60, 0.12);
104
+
105
+ --node-a: #fb923c;
106
+ --node-a-dim: rgba(251, 146, 60, 0.12);
107
+ --node-b: #a3e635;
108
+ --node-b-dim: rgba(163, 230, 53, 0.1);
109
+ --node-c: #5eead4;
110
+ --node-c-dim: rgba(94, 234, 212, 0.1);
111
+
112
+ --green: #a3e635;
113
+ --green-dim: rgba(163, 230, 53, 0.1);
114
+ --red: #fca5a5;
115
+ --red-dim: rgba(252, 165, 165, 0.1);
116
+ --amber: #fbbf24;
117
+ --amber-dim: rgba(251, 191, 36, 0.1);
118
+ --sage: #bef264;
119
+ --sage-dim: rgba(190, 242, 100, 0.1);
120
+ --teal: #5eead4;
121
+ --teal-dim: rgba(94, 234, 212, 0.1);
122
+ --plum: #fda4af;
123
+ --plum-dim: rgba(253, 164, 175, 0.1);
124
+ }
125
+ ```
126
+
127
+ **How it works:** `:root` = light default. `@media (prefers-color-scheme: dark)` with `:root:not([data-theme="light"])` respects OS preference unless user explicitly chose light. `[data-theme="dark"]` forces dark regardless of OS. No JS needed for the CSS — toggle button JS just sets the attribute.
128
+
129
+ **Choosing a different palette:** The above is the warm default. For other aesthetics, pick a preset from `html-design-guidelines.md` and extend it with the same semantic color structure (--green, --red, --amber, --sage, --teal, --plum). Every preset in that file defines the core variables; add the semantic layer on top to maintain richness. When using a different preset, replicate the three-tier pattern above (`:root` light, `@media` dark with `:not([data-theme="light"])`, `[data-theme="dark"]` override).
130
+
131
+ ## Theme Toggle Button (MANDATORY)
132
+
133
+ **MUST include a theme toggle button in EVERY generated HTML page. This is non-negotiable — pages without the toggle are considered incomplete.** Place it fixed in the top-right corner.
134
+
135
+ ### CSS
136
+
137
+ ```css
138
+ .theme-toggle {
139
+ position: fixed;
140
+ top: 16px;
141
+ right: 16px;
142
+ z-index: 300;
143
+ width: 36px;
144
+ height: 36px;
145
+ border-radius: 8px;
146
+ border: 1px solid var(--border);
147
+ background: var(--surface);
148
+ color: var(--text-dim);
149
+ cursor: pointer;
150
+ display: flex;
151
+ align-items: center;
152
+ justify-content: center;
153
+ font-size: 16px;
154
+ transition: background 0.15s, color 0.15s;
155
+ box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
156
+ }
157
+ .theme-toggle:hover {
158
+ background: var(--surface2);
159
+ color: var(--text);
160
+ }
161
+ ```
162
+
163
+ ### HTML + JS
164
+
165
+ Place the button as the first child of `<body>`. The script detects OS preference on load and persists manual choice in `localStorage`.
166
+
167
+ ```html
168
+ <button class="theme-toggle" id="themeToggle" title="Toggle theme" aria-label="Toggle light/dark theme"></button>
169
+
170
+ <script>
171
+ (function() {
172
+ var toggle = document.getElementById('themeToggle');
173
+ var saved = localStorage.getItem('theme');
174
+ var initial = saved || (matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light');
175
+ if (saved) document.documentElement.setAttribute('data-theme', initial);
176
+ toggle.textContent = initial === 'dark' ? '\u2600' : '\u263E';
177
+ toggle.addEventListener('click', function() {
178
+ var current = document.documentElement.getAttribute('data-theme')
179
+ || (matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light');
180
+ var next = current === 'light' ? 'dark' : 'light';
181
+ document.documentElement.setAttribute('data-theme', next);
182
+ localStorage.setItem('theme', next);
183
+ toggle.textContent = next === 'dark' ? '\u2600' : '\u263E';
184
+ });
185
+ })();
186
+ </script>
187
+ ```
188
+
189
+ **Symbols:** `\u2600` = sun (shown in dark mode — click to go light), `\u263E` = moon (shown in light mode — click to go dark). No emoji — these are Unicode dingbats that render consistently across platforms.
190
+
191
+ ## Typography Floor
192
+
193
+ Minimum readable font sizes for generated HTML pages. Smaller sizes strain readability, especially on high-DPI screens.
194
+
195
+ | Element | Minimum | Recommended |
196
+ |---------|---------|-------------|
197
+ | Body / card content | 15px | 15–16px |
198
+ | Code blocks | 14px | 14px |
199
+ | Table cells | 14px | 14–15px |
200
+ | Table headers (mono uppercase) | 12px | 12px |
201
+ | List items | 14px | 15px |
202
+ | Section labels (mono uppercase) | 11px | 12px |
203
+ | Card labels (mono uppercase) | 11px | 11px |
204
+ | Status badges (mono) | 12px | 12px |
205
+ | TOC links | 11px | 12px |
206
+ | Callout body | 15px | 16px |
207
+
208
+ Monospace uppercase labels are allowed at 11px because letter-spacing and uppercase improve legibility at small sizes. Body text and content must stay at 14px+.
209
+
210
+ ## Background Atmosphere
211
+
212
+ Flat backgrounds feel dead. Use subtle gradients or patterns.
213
+
214
+ ```css
215
+ /* Radial glow behind focal area */
216
+ body {
217
+ background: var(--bg);
218
+ background-image: radial-gradient(ellipse at 50% 0%, var(--accent-dim) 0%, transparent 60%);
219
+ }
220
+
221
+ /* Faint dot grid */
222
+ body {
223
+ background-color: var(--bg);
224
+ background-image: radial-gradient(circle, var(--border) 1px, transparent 1px);
225
+ background-size: 24px 24px;
226
+ }
227
+
228
+ /* Diagonal subtle lines */
229
+ body {
230
+ background-color: var(--bg);
231
+ background-image: repeating-linear-gradient(
232
+ -45deg, transparent, transparent 40px,
233
+ var(--border) 40px, var(--border) 41px
234
+ );
235
+ }
236
+
237
+ /* Gradient mesh (pick 2-3 positioned radials) */
238
+ body {
239
+ background: var(--bg);
240
+ background-image:
241
+ radial-gradient(at 20% 20%, var(--node-a-dim) 0%, transparent 50%),
242
+ radial-gradient(at 80% 60%, var(--node-b-dim) 0%, transparent 50%);
243
+ }
244
+ ```
245
+
246
+ ## Link Styling
247
+
248
+ **Never rely on browser default link colors.** The default blue (`#0000EE`) has poor contrast on dark backgrounds. Style links with `color: var(--accent)` and keep underlines for discoverability. On dark backgrounds, use bright accents from the palette (`--node-a`, `--teal`, `--sage`). On light backgrounds, use deeper tones (`--accent`, `--node-b`, `--node-c`). Always use palette variables — never hardcode hex values for links.
249
+
250
+ ## Section / Card Components
251
+
252
+ The fundamental building block. A colored card representing a system component, pipeline step, or data entity.
253
+
254
+ **IMPORTANT: Never use `.node` as a CSS class name.** Mermaid.js internally uses `.node` on its SVG `<g>` elements with `transform: translate(x, y)` for positioning. Any page-level `.node` styles (hover transforms, box-shadows, transitions) will leak into Mermaid diagrams and break their layout. Use `.ve-card` instead (namespaced to avoid collisions with CSS frameworks like Bootstrap/Tailwind that also use `.card`).
255
+
256
+ ```css
257
+ .ve-card {
258
+ background: var(--surface);
259
+ border: 1px solid var(--border);
260
+ border-radius: 10px;
261
+ padding: 16px 20px;
262
+ position: relative;
263
+ }
264
+
265
+ /* Colored accent border (left or top) */
266
+ .ve-card--accent-a {
267
+ border-left: 3px solid var(--node-a);
268
+ }
269
+
270
+ /* --- Depth tiers: vary card depth to signal importance --- */
271
+
272
+ /* Elevated: KPIs, key sections, anything that should pop */
273
+ .ve-card--elevated {
274
+ background: var(--surface-elevated);
275
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
276
+ }
277
+
278
+ /* Recessed: code blocks, secondary content, detail panels */
279
+ .ve-card--recessed {
280
+ background: color-mix(in srgb, var(--bg) 70%, var(--surface) 30%);
281
+ box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.06);
282
+ border-color: var(--border);
283
+ }
284
+
285
+ /* Hero: executive summaries, focal elements — demands attention */
286
+ .ve-card--hero {
287
+ background: color-mix(in srgb, var(--surface) 92%, var(--accent) 8%);
288
+ box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.04);
289
+ border-color: color-mix(in srgb, var(--border) 50%, var(--accent) 50%);
290
+ }
291
+
292
+ /* Glass: special-occasion overlay effect (use sparingly) */
293
+ .ve-card--glass {
294
+ background: color-mix(in srgb, var(--surface) 60%, transparent 40%);
295
+ backdrop-filter: blur(12px);
296
+ -webkit-backdrop-filter: blur(12px);
297
+ border-color: rgba(255, 255, 255, 0.1);
298
+ }
299
+
300
+ /* Section label (monospace, uppercase) */
301
+ .ve-card__label {
302
+ font-family: var(--font-mono);
303
+ font-size: 11px;
304
+ font-weight: 600;
305
+ text-transform: uppercase;
306
+ letter-spacing: 1.5px;
307
+ color: var(--node-a);
308
+ margin-bottom: 10px;
309
+ display: flex;
310
+ align-items: center;
311
+ gap: 8px;
312
+ }
313
+
314
+ /* Colored dot indicator */
315
+ .ve-card__label::before {
316
+ content: '';
317
+ width: 8px;
318
+ height: 8px;
319
+ border-radius: 50%;
320
+ background: currentColor;
321
+ }
322
+ ```
323
+
324
+ ## Code Blocks
325
+
326
+ Code blocks need explicit whitespace preservation and a max-height constraint. Without these, code runs together and long files overwhelm the page.
327
+
328
+ ### Basic Pattern
329
+
330
+ ```css
331
+ .code-block {
332
+ font-family: var(--font-mono);
333
+ font-size: 14px;
334
+ line-height: 1.5;
335
+ background: var(--surface);
336
+ border: 1px solid var(--border);
337
+ border-radius: 8px;
338
+ padding: 16px;
339
+ overflow-x: auto;
340
+ /* CRITICAL: preserve line breaks and indentation */
341
+ white-space: pre-wrap;
342
+ word-break: break-word;
343
+ }
344
+
345
+ /* Constrain height for long code */
346
+ .code-block--scroll {
347
+ max-height: 400px;
348
+ overflow-y: auto;
349
+ }
350
+ ```
351
+
352
+ ```html
353
+ <pre class="code-block code-block--scroll"><code>// Your code here
354
+ function example() {
355
+ return true;
356
+ }</code></pre>
357
+ ```
358
+
359
+ ### With File Header
360
+
361
+ ```css
362
+ .code-file {
363
+ border: 1px solid var(--border);
364
+ border-radius: 8px;
365
+ overflow: hidden;
366
+ }
367
+
368
+ .code-file__header {
369
+ display: flex;
370
+ align-items: center;
371
+ gap: 8px;
372
+ padding: 10px 16px;
373
+ background: var(--surface);
374
+ border-bottom: 1px solid var(--border);
375
+ font-family: var(--font-mono);
376
+ font-size: 12px;
377
+ color: var(--text-dim);
378
+ }
379
+
380
+ .code-file__body {
381
+ font-family: var(--font-mono);
382
+ font-size: 14px;
383
+ line-height: 1.5;
384
+ padding: 16px;
385
+ background: var(--surface-elevated);
386
+ white-space: pre-wrap;
387
+ word-break: break-word;
388
+ max-height: 500px;
389
+ overflow: auto;
390
+ }
391
+ ```
392
+
393
+ ```html
394
+ <div class="code-file">
395
+ <div class="code-file__header">
396
+ <span>src/extension.ts</span>
397
+ </div>
398
+ <pre class="code-file__body"><code>export function activate() {
399
+ // ...
400
+ }</code></pre>
401
+ </div>
402
+ ```
403
+
404
+ ### Implementation Plans: Don't Dump Full Files
405
+
406
+ For implementation plans and architecture docs, **don't display entire source files inline**. Instead:
407
+
408
+ 1. **Show structure, not code:**
409
+ ```html
410
+ <div class="file-structure">
411
+ <div class="file-structure__path">src/extension.ts</div>
412
+ <ul class="file-structure__outline">
413
+ <li><code>activate()</code> — Entry point</li>
414
+ <li><code>clearState()</code> — Reset extension state</li>
415
+ </ul>
416
+ </div>
417
+ ```
418
+
419
+ 2. **Use collapsible sections for full code:**
420
+ ```html
421
+ <details class="collapsible">
422
+ <summary>Full implementation (87 lines)</summary>
423
+ <pre class="code-file__body"><code>...</code></pre>
424
+ </details>
425
+ ```
426
+
427
+ 3. **Show key snippets only** — the 5-10 lines illustrating core logic.
428
+
429
+ **Anti-patterns:**
430
+ - Displaying full source files inline (100+ lines overwhelming the page)
431
+ - Code blocks without `white-space: pre-wrap` (code runs together)
432
+ - No height constraint on long code (page becomes endless scroll)
433
+
434
+ ## Directory Tree
435
+
436
+ For file structures, use `<pre>` with monospace + `white-space: pre`. Tree connectors (`├──`, `└──`, `│`) only work when vertically aligned.
437
+
438
+ ```css
439
+ .dir-tree {
440
+ font-family: var(--font-mono);
441
+ font-size: 13px;
442
+ line-height: 1.7;
443
+ background: var(--surface);
444
+ border: 1px solid var(--border);
445
+ border-radius: 8px;
446
+ padding: 16px 20px;
447
+ overflow-x: auto;
448
+ white-space: pre;
449
+ }
450
+
451
+ .dir-tree .ann { color: var(--text-dim); font-size: 11px; font-style: italic; }
452
+ .dir-tree .hl { color: var(--accent); font-weight: 600; }
453
+ ```
454
+
455
+ ```html
456
+ <pre class="dir-tree">my-project/
457
+ ├── src/
458
+ │ ├── <span class="hl">index.ts</span> <span class="ann">— entry point</span>
459
+ │ └── utils/
460
+ └── README.md</pre>
461
+ ```
462
+
463
+ **Never** render tree connectors inside wrapping text, flex children, or grid items — vertical pipes lose alignment and the hierarchy becomes unreadable.
464
+
465
+ ## Overflow Protection
466
+
467
+ Grid and flex children default to `min-width: auto`, which prevents them from shrinking below their content width.
468
+
469
+ ### Global rules
470
+
471
+ ```css
472
+ /* Every grid/flex child must be able to shrink */
473
+ .grid > *, .flex > *,
474
+ [style*="display: grid"] > *,
475
+ [style*="display: flex"] > * {
476
+ min-width: 0;
477
+ }
478
+
479
+ /* Long text wraps instead of overflowing */
480
+ body {
481
+ overflow-wrap: break-word;
482
+ }
483
+ ```
484
+
485
+ ### Side-by-side comparison panels
486
+
487
+ ```css
488
+ .comparison {
489
+ display: grid;
490
+ grid-template-columns: 1fr 1fr;
491
+ gap: 16px;
492
+ }
493
+
494
+ .comparison > * {
495
+ min-width: 0;
496
+ overflow-wrap: break-word;
497
+ }
498
+
499
+ @media (max-width: 768px) {
500
+ .comparison { grid-template-columns: 1fr; }
501
+ }
502
+ ```
503
+
504
+ ### Never use `display: flex` on `<li>` for marker characters
505
+
506
+ Using `display: flex` on a list item creates an anonymous flex item for the remaining text. That anonymous item gets `min-width: auto` and you **cannot** set `min-width: 0` on anonymous boxes. Lines with many inline `<code>` badges will overflow with no CSS fix possible.
507
+
508
+ Use absolute positioning for markers instead:
509
+
510
+ ```css
511
+ /* WRONG — causes overflow with inline code badges */
512
+ li {
513
+ display: flex;
514
+ align-items: baseline;
515
+ gap: 6px;
516
+ }
517
+ li::before {
518
+ content: '›';
519
+ flex-shrink: 0;
520
+ }
521
+
522
+ /* RIGHT — text wraps normally */
523
+ li {
524
+ padding-left: 14px;
525
+ position: relative;
526
+ }
527
+ li::before {
528
+ content: '›';
529
+ position: absolute;
530
+ left: 0;
531
+ }
532
+ ```
533
+
534
+ ### List markers overlapping container borders
535
+
536
+ ```css
537
+ /* RIGHT — use inside positioning or adequate padding */
538
+ .card ol, .card ul {
539
+ list-style-position: inside;
540
+ }
541
+
542
+ /* OR — adequate padding for outside markers */
543
+ .card ol, .card ul {
544
+ padding-left: 2em;
545
+ }
546
+
547
+ /* OR — custom markers with absolute positioning */
548
+ .card ol {
549
+ list-style: none;
550
+ padding-left: 0;
551
+ counter-reset: item;
552
+ }
553
+ .card ol li {
554
+ counter-increment: item;
555
+ padding-left: 2em;
556
+ position: relative;
557
+ }
558
+ .card ol li::before {
559
+ content: counter(item) ".";
560
+ position: absolute;
561
+ left: 0;
562
+ color: var(--accent);
563
+ font-weight: 600;
564
+ }
565
+ ```
566
+
567
+ **Rule of thumb:** Any `<ol>` or `<ul>` inside a bordered container needs either `list-style-position: inside` or `padding-left: 2em` minimum.
568
+
569
+ ## Mermaid Containers
570
+
571
+ Mermaid diagrams have two common layout issues: they render too small to read, and they left-align leaving awkward dead space.
572
+
573
+ ### Centering (Required)
574
+
575
+ ```css
576
+ /* WRONG — diagram hugs left edge */
577
+ .mermaid-container {
578
+ padding: 24px;
579
+ border: 1px solid var(--border);
580
+ }
581
+
582
+ /* RIGHT — diagram centers in container */
583
+ .mermaid-wrap {
584
+ display: flex;
585
+ justify-content: center;
586
+ align-items: flex-start;
587
+ padding: 24px;
588
+ border: 1px solid var(--border);
589
+ }
590
+ ```
591
+
592
+ ### Scaling Small Diagrams
593
+
594
+ **1. Increase fontSize in themeVariables** (most effective):
595
+ ```javascript
596
+ mermaid.initialize({
597
+ theme: 'base',
598
+ themeVariables: {
599
+ fontSize: '18px', // default 16px, bump to 18-20px for complex diagrams
600
+ }
601
+ });
602
+ ```
603
+
604
+ **2. CSS zoom** for diagrams that still render too small:
605
+ ```css
606
+ .mermaid-wrap--scaled .mermaid {
607
+ zoom: 1.3;
608
+ }
609
+ ```
610
+
611
+ **3. Constrain container width** so the diagram doesn't float in dead space:
612
+ ```css
613
+ .mermaid-wrap--constrained {
614
+ max-width: 800px;
615
+ margin: 0 auto;
616
+ }
617
+ ```
618
+
619
+ **Rule of thumb:** If the diagram has 10+ nodes or text is smaller than 12px rendered, increase fontSize to 18-20px or apply CSS zoom.
620
+
621
+ ### Zoom Controls — Full Pattern
622
+
623
+ Add zoom controls to every `.mermaid-wrap` container.
624
+
625
+ ```css
626
+ .mermaid-wrap {
627
+ position: relative;
628
+ background: var(--surface);
629
+ border: 1px solid var(--border);
630
+ border-radius: 12px;
631
+ padding: 32px 24px;
632
+ overflow: auto;
633
+ /* CRITICAL: center the diagram */
634
+ display: flex;
635
+ justify-content: center;
636
+ align-items: center;
637
+ /* Prevent vertical flowcharts from compressing */
638
+ min-height: 400px;
639
+ }
640
+
641
+ .mermaid-wrap--compact { min-height: 200px; }
642
+ .mermaid-wrap--tall { min-height: 600px; }
643
+
644
+ .zoom-controls {
645
+ position: absolute;
646
+ top: 8px;
647
+ right: 8px;
648
+ display: flex;
649
+ gap: 2px;
650
+ z-index: 10;
651
+ background: var(--surface);
652
+ border: 1px solid var(--border);
653
+ border-radius: 6px;
654
+ padding: 2px;
655
+ }
656
+
657
+ .zoom-controls button {
658
+ width: 28px;
659
+ height: 28px;
660
+ border: none;
661
+ background: transparent;
662
+ color: var(--text-dim);
663
+ font-family: var(--font-mono);
664
+ font-size: 14px;
665
+ cursor: pointer;
666
+ border-radius: 4px;
667
+ display: flex;
668
+ align-items: center;
669
+ justify-content: center;
670
+ transition: background 0.15s ease, color 0.15s ease;
671
+ }
672
+
673
+ .zoom-controls button:hover {
674
+ background: var(--border);
675
+ color: var(--text);
676
+ }
677
+
678
+ .mermaid-wrap { cursor: grab; }
679
+ .mermaid-wrap.is-panning { cursor: grabbing; user-select: none; }
680
+
681
+ /* Multi-diagram structure */
682
+ .diagram-shell {
683
+ position: relative;
684
+ }
685
+
686
+ .diagram-shell__hint {
687
+ font-family: var(--font-mono);
688
+ font-size: 11px;
689
+ color: var(--text-dim);
690
+ margin-bottom: 8px;
691
+ opacity: 0.7;
692
+ }
693
+
694
+ .mermaid-viewport {
695
+ position: relative;
696
+ overflow: hidden;
697
+ width: 100%;
698
+ height: 100%;
699
+ min-height: 300px;
700
+ }
701
+
702
+ .mermaid-canvas {
703
+ position: absolute;
704
+ top: 0;
705
+ left: 0;
706
+ }
707
+
708
+ .zoom-label {
709
+ font-family: var(--font-mono);
710
+ font-size: 10px;
711
+ color: var(--text-dim);
712
+ padding: 0 6px;
713
+ white-space: nowrap;
714
+ }
715
+ ```
716
+
717
+ **How the zoom/pan engine works:** The SVG is rendered into `.mermaid-canvas` which is absolutely positioned inside `.mermaid-viewport`. Zooming sets the SVG's `width` and `height` styles directly. Panning applies `transform: translate()` to the canvas. The viewport has `overflow: hidden` to clip panned content.
718
+
719
+ ### HTML Structure
720
+
721
+ ```html
722
+ <section class="diagram-shell">
723
+ <p class="diagram-shell__hint">
724
+ Ctrl/Cmd + wheel to zoom. Scroll to pan. Drag to pan when zoomed. Double-click to fit.
725
+ </p>
726
+ <div class="mermaid-wrap">
727
+ <div class="zoom-controls">
728
+ <button type="button" data-action="zoom-in" title="Zoom in">+</button>
729
+ <button type="button" data-action="zoom-out" title="Zoom out">&minus;</button>
730
+ <button type="button" data-action="zoom-fit" title="Smart fit">&#8634;</button>
731
+ <button type="button" data-action="zoom-one" title="1:1 zoom">1:1</button>
732
+ <button type="button" data-action="zoom-expand" title="Open full size">&#x26F6;</button>
733
+ <span class="zoom-label">Loading...</span>
734
+ </div>
735
+ <div class="mermaid-viewport">
736
+ <div class="mermaid mermaid-canvas"></div>
737
+ </div>
738
+ </div>
739
+ <script type="text/plain" class="diagram-source">
740
+ graph TD
741
+ A --> B
742
+ </script>
743
+ </section>
744
+ ```
745
+
746
+ Use one `.diagram-shell` per diagram. The source Mermaid text lives in `<script type="text/plain" class="diagram-source">`, so multiple diagrams can coexist without ID collisions.
747
+
748
+ ### JavaScript (Closure-Based)
749
+
750
+ ```javascript
751
+ const config = { /* fitPadding, zoom bounds, readabilityFloor */ };
752
+ const clamp = (n, lo, hi) => Math.max(lo, Math.min(hi, n));
753
+ let activeDrag = null;
754
+
755
+ addEventListener('mousemove', (e) => activeDrag?.onMove(e));
756
+ addEventListener('mouseup', () => { activeDrag?.onEnd(); activeDrag = null; });
757
+
758
+ function initDiagram(shell) {
759
+ const wrap = shell.querySelector('.mermaid-wrap');
760
+ const viewport = shell.querySelector('.mermaid-viewport');
761
+ const canvas = shell.querySelector('.mermaid-canvas');
762
+ const source = shell.querySelector('.diagram-source');
763
+ const label = shell.querySelector('.zoom-label');
764
+
765
+ if (!wrap || !viewport || !canvas || !source || !label) {
766
+ console.error('initDiagram: missing required elements in', shell);
767
+ return;
768
+ }
769
+
770
+ // Per-diagram state in closure
771
+ let zoom = 1;
772
+ let panX = 0;
773
+ let panY = 0;
774
+
775
+ async function render() {
776
+ try {
777
+ const code = source.textContent.trim();
778
+ if (!code) { label.textContent = 'Error: Empty source'; return; }
779
+ const id = 'diagram-' + Date.now() + '-' + Math.random().toString(36).slice(2, 8);
780
+ const { svg } = await mermaid.render(id, code);
781
+ canvas.innerHTML = svg;
782
+ // wire controls, fit, zoom/pan/touch handlers scoped to this shell
783
+ } catch (err) {
784
+ console.error('Mermaid render failed:', err);
785
+ label.textContent = 'Error: ' + (err.message || 'Render failed');
786
+ }
787
+ }
788
+
789
+ render();
790
+ }
791
+
792
+ document.querySelectorAll('.diagram-shell').forEach(initDiagram);
793
+ ```
794
+
795
+ This pattern removes all hardcoded IDs and supports unlimited diagrams per page. For the full implementation (smart fit, pinch zoom, shared drag state), use the full template from the skill's `templates/` directory.
796
+
797
+ **⚠️ Never use bare `<pre class="mermaid">`.** It renders but has no zoom/pan controls — diagrams become tiny and unusable. Always use the full `diagram-shell` pattern above.
798
+
799
+ ## Grid Layouts
800
+
801
+ ### Architecture Diagram (2-column with sidebar)
802
+ ```css
803
+ .arch-grid {
804
+ display: grid;
805
+ grid-template-columns: 260px 1fr;
806
+ grid-template-rows: auto;
807
+ gap: 20px;
808
+ max-width: 1100px;
809
+ margin: 0 auto;
810
+ }
811
+
812
+ .arch-grid__sidebar { grid-column: 1; }
813
+ .arch-grid__main { grid-column: 2; }
814
+ .arch-grid__full { grid-column: 1 / -1; }
815
+ ```
816
+
817
+ ### Pipeline (horizontal steps)
818
+ ```css
819
+ .pipeline {
820
+ display: flex;
821
+ align-items: stretch;
822
+ gap: 0;
823
+ overflow-x: auto;
824
+ padding-bottom: 8px;
825
+ }
826
+
827
+ .pipeline__step {
828
+ min-width: 130px;
829
+ flex-shrink: 0;
830
+ }
831
+
832
+ .pipeline__arrow {
833
+ display: flex;
834
+ align-items: center;
835
+ padding: 0 4px;
836
+ color: var(--border-bright);
837
+ font-size: 18px;
838
+ flex-shrink: 0;
839
+ }
840
+
841
+ /* Parallel branch within a pipeline */
842
+ .pipeline__parallel {
843
+ display: flex;
844
+ flex-direction: column;
845
+ gap: 6px;
846
+ }
847
+ ```
848
+
849
+ ### Card Grid (dashboard / metrics)
850
+ ```css
851
+ .card-grid {
852
+ display: grid;
853
+ grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
854
+ gap: 16px;
855
+ }
856
+ ```
857
+
858
+ ### Data Tables
859
+
860
+ Use real `<table>` elements for tabular data. Wrap in a scrollable container for wide tables.
861
+
862
+ ```css
863
+ /* Scrollable wrapper for wide tables */
864
+ .table-wrap {
865
+ background: var(--surface);
866
+ border: 1px solid var(--border);
867
+ border-radius: 12px;
868
+ overflow: hidden;
869
+ }
870
+
871
+ .table-scroll {
872
+ overflow-x: auto;
873
+ -webkit-overflow-scrolling: touch;
874
+ }
875
+
876
+ /* Base table */
877
+ .data-table {
878
+ width: 100%;
879
+ border-collapse: collapse;
880
+ font-size: 14px;
881
+ line-height: 1.5;
882
+ }
883
+
884
+ /* Header */
885
+ .data-table thead {
886
+ position: sticky;
887
+ top: 0;
888
+ z-index: 2;
889
+ }
890
+
891
+ .data-table th {
892
+ background: var(--surface-elevated, var(--surface));
893
+ font-family: var(--font-mono);
894
+ font-size: 12px;
895
+ font-weight: 600;
896
+ text-transform: uppercase;
897
+ letter-spacing: 1px;
898
+ color: var(--text-dim);
899
+ text-align: left;
900
+ padding: 12px 16px;
901
+ border-bottom: 2px solid var(--border-bright);
902
+ white-space: nowrap;
903
+ }
904
+
905
+ /* Cells */
906
+ .data-table td {
907
+ padding: 12px 16px;
908
+ border-bottom: 1px solid var(--border);
909
+ vertical-align: top;
910
+ color: var(--text);
911
+ }
912
+
913
+ /* Let text-heavy columns wrap naturally */
914
+ .data-table .wide {
915
+ min-width: 200px;
916
+ max-width: 500px;
917
+ }
918
+
919
+ /* Right-align numeric columns */
920
+ .data-table td.num,
921
+ .data-table th.num {
922
+ text-align: right;
923
+ font-variant-numeric: tabular-nums;
924
+ font-family: var(--font-mono);
925
+ }
926
+
927
+ /* Alternating rows */
928
+ .data-table tbody tr:nth-child(even) {
929
+ background: var(--accent-dim);
930
+ }
931
+
932
+ /* Row hover */
933
+ .data-table tbody tr {
934
+ transition: background 0.15s ease;
935
+ }
936
+
937
+ .data-table tbody tr:hover {
938
+ background: var(--border);
939
+ }
940
+
941
+ /* Last row: no bottom border */
942
+ .data-table tbody tr:last-child td {
943
+ border-bottom: none;
944
+ }
945
+
946
+ /* Code inside cells */
947
+ .data-table code {
948
+ font-family: var(--font-mono);
949
+ font-size: 11px;
950
+ background: var(--accent-dim);
951
+ color: var(--accent);
952
+ padding: 1px 5px;
953
+ border-radius: 3px;
954
+ }
955
+
956
+ /* Secondary detail text */
957
+ .data-table small {
958
+ display: block;
959
+ color: var(--text-dim);
960
+ font-size: 11px;
961
+ margin-top: 2px;
962
+ }
963
+ ```
964
+
965
+ #### Status Indicators
966
+
967
+ Styled spans for match/gap/warning states. Never use emoji.
968
+
969
+ ```css
970
+ .status {
971
+ display: inline-flex;
972
+ align-items: center;
973
+ gap: 6px;
974
+ font-family: var(--font-mono);
975
+ font-size: 12px;
976
+ font-weight: 500;
977
+ padding: 3px 10px;
978
+ border-radius: 6px;
979
+ white-space: nowrap;
980
+ }
981
+
982
+ .status--match {
983
+ background: var(--green-dim, rgba(5, 150, 105, 0.1));
984
+ color: var(--green, #059669);
985
+ }
986
+
987
+ .status--gap {
988
+ background: var(--red-dim, rgba(239, 68, 68, 0.1));
989
+ color: var(--red, #ef4444);
990
+ }
991
+
992
+ .status--warn {
993
+ background: var(--orange-dim, rgba(217, 119, 6, 0.1));
994
+ color: var(--orange, #d97706);
995
+ }
996
+
997
+ .status--info {
998
+ background: var(--accent-dim);
999
+ color: var(--accent);
1000
+ }
1001
+
1002
+ /* Dot variant (compact, no text) */
1003
+ .status-dot {
1004
+ width: 8px;
1005
+ height: 8px;
1006
+ border-radius: 50%;
1007
+ display: inline-block;
1008
+ }
1009
+
1010
+ .status-dot--match { background: var(--green, #059669); }
1011
+ .status-dot--gap { background: var(--red, #ef4444); }
1012
+ .status-dot--warn { background: var(--orange, #d97706); }
1013
+ ```
1014
+
1015
+ Usage in table cells:
1016
+ ```html
1017
+ <td><span class="status status--match">Match</span></td>
1018
+ <td><span class="status status--gap">Gap</span></td>
1019
+ <td><span class="status status--warn">Partial</span></td>
1020
+ ```
1021
+
1022
+ #### Table Summary Row
1023
+
1024
+ ```css
1025
+ .data-table tfoot td {
1026
+ background: var(--surface-elevated, var(--surface));
1027
+ font-weight: 600;
1028
+ font-size: 12px;
1029
+ border-top: 2px solid var(--border-bright);
1030
+ border-bottom: none;
1031
+ padding: 12px 16px;
1032
+ }
1033
+ ```
1034
+
1035
+ #### Sticky First Column (for very wide tables)
1036
+
1037
+ ```css
1038
+ .data-table th:first-child,
1039
+ .data-table td:first-child {
1040
+ position: sticky;
1041
+ left: 0;
1042
+ z-index: 1;
1043
+ background: var(--surface);
1044
+ }
1045
+
1046
+ .data-table tbody tr:nth-child(even) td:first-child {
1047
+ background: color-mix(in srgb, var(--surface) 95%, var(--accent) 5%);
1048
+ }
1049
+ ```
1050
+
1051
+ ## Connectors
1052
+
1053
+ ### CSS Arrow (vertical, between stacked sections)
1054
+ ```css
1055
+ .flow-arrow {
1056
+ display: flex;
1057
+ justify-content: center;
1058
+ align-items: center;
1059
+ gap: 8px;
1060
+ color: var(--text-dim);
1061
+ font-family: var(--font-mono);
1062
+ font-size: 12px;
1063
+ padding: 6px 0;
1064
+ }
1065
+
1066
+ .flow-arrow svg {
1067
+ width: 20px;
1068
+ height: 20px;
1069
+ fill: none;
1070
+ stroke: var(--border-bright);
1071
+ stroke-width: 2;
1072
+ stroke-linecap: round;
1073
+ stroke-linejoin: round;
1074
+ }
1075
+ ```
1076
+
1077
+ Down arrow SVG (reuse inline):
1078
+ ```html
1079
+ <svg viewBox="0 0 20 20"><path d="M10 4 L10 16 M6 12 L10 16 L14 12"/></svg>
1080
+ ```
1081
+
1082
+ ### CSS Arrow (horizontal, between inline steps)
1083
+ ```css
1084
+ .h-arrow::after {
1085
+ content: '→';
1086
+ color: var(--border-bright);
1087
+ font-size: 18px;
1088
+ padding: 0 4px;
1089
+ }
1090
+ ```
1091
+
1092
+ ### SVG Curved Connector (between arbitrary nodes)
1093
+ ```html
1094
+ <svg class="connectors" style="position:absolute;inset:0;width:100%;height:100%;pointer-events:none;">
1095
+ <path d="M 150,100 C 150,200 350,100 350,200" fill="none" stroke="var(--accent)" stroke-width="1.5" stroke-dasharray="4 3"/>
1096
+ <!-- Arrowhead -->
1097
+ <polygon points="348,195 352,205 356,195" fill="var(--accent)"/>
1098
+ </svg>
1099
+ ```
1100
+
1101
+ Position the parent container as `position: relative` to scope the SVG overlay.
1102
+
1103
+ ## Animations
1104
+
1105
+ ### Staggered Fade-In on Load
1106
+
1107
+ Define the keyframe once, then stagger via a `--i` CSS variable set per element.
1108
+
1109
+ ```css
1110
+ @keyframes fadeUp {
1111
+ from { opacity: 0; transform: translateY(12px); }
1112
+ to { opacity: 1; transform: translateY(0); }
1113
+ }
1114
+
1115
+ .ve-card {
1116
+ animation: fadeUp 0.4s ease-out both;
1117
+ animation-delay: calc(var(--i, 0) * 0.05s);
1118
+ }
1119
+ ```
1120
+
1121
+ Set `--i` per element to control stagger order:
1122
+ ```html
1123
+ <div class="ve-card" style="--i: 0">First</div>
1124
+ <div class="ve-card" style="--i: 1">Second</div>
1125
+ <div class="ve-card" style="--i: 2">Third</div>
1126
+ ```
1127
+
1128
+ ### Hover Lift
1129
+ ```css
1130
+ .ve-card {
1131
+ transition: transform 0.2s ease, box-shadow 0.2s ease;
1132
+ }
1133
+
1134
+ .ve-card:hover {
1135
+ transform: translateY(-2px);
1136
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
1137
+ }
1138
+ ```
1139
+
1140
+ ### Scale-Fade (for KPI cards, badges)
1141
+
1142
+ ```css
1143
+ @keyframes fadeScale {
1144
+ from { opacity: 0; transform: scale(0.92); }
1145
+ to { opacity: 1; transform: scale(1); }
1146
+ }
1147
+
1148
+ .kpi-card {
1149
+ animation: fadeScale 0.35s ease-out both;
1150
+ animation-delay: calc(var(--i, 0) * 0.06s);
1151
+ }
1152
+ ```
1153
+
1154
+ ### SVG Draw-In (for connectors, path elements)
1155
+
1156
+ ```css
1157
+ @keyframes drawIn {
1158
+ from { stroke-dashoffset: var(--path-length); }
1159
+ to { stroke-dashoffset: 0; }
1160
+ }
1161
+
1162
+ /* Set --path-length to the path's getTotalLength() value */
1163
+ .connector path {
1164
+ stroke-dasharray: var(--path-length);
1165
+ animation: drawIn 0.8s ease-in-out both;
1166
+ animation-delay: calc(var(--i, 0) * 0.1s);
1167
+ }
1168
+ ```
1169
+
1170
+ ### CSS Counter (hero numbers without JS)
1171
+
1172
+ Uses `@property` to animate a custom property as an integer. Falls back to showing the final value in browsers without `@property` support.
1173
+
1174
+ ```css
1175
+ @property --count {
1176
+ syntax: '<integer>';
1177
+ initial-value: 0;
1178
+ inherits: false;
1179
+ }
1180
+
1181
+ @keyframes countUp {
1182
+ to { --count: var(--target); }
1183
+ }
1184
+
1185
+ .kpi-card__value--animated {
1186
+ --target: 247;
1187
+ counter-reset: val var(--count);
1188
+ animation: countUp 1.2s ease-out forwards;
1189
+ }
1190
+
1191
+ .kpi-card__value--animated::after {
1192
+ content: counter(val);
1193
+ }
1194
+ ```
1195
+
1196
+ ### Choreography
1197
+
1198
+ Mix animation types by element role:
1199
+ - **Cards**: `fadeUp` — default entrance, reliable and subtle
1200
+ - **KPI / badges**: `fadeScale` — scale draws the eye to important numbers
1201
+ - **SVG connectors**: `drawIn` — reveals flow direction, pairs with card stagger
1202
+ - **Hero numbers**: `countUp` — counting motion signals "this number matters"
1203
+ - **Stagger timing**: `calc(var(--i) * 0.06s)` with lower `--i` on important elements (appear first)
1204
+
1205
+ ### Respect Reduced Motion
1206
+ ```css
1207
+ @media (prefers-reduced-motion: reduce) {
1208
+ *, *::before, *::after {
1209
+ animation-duration: 0.01ms !important;
1210
+ animation-iteration-count: 1 !important;
1211
+ transition-duration: 0.01ms !important;
1212
+ }
1213
+ }
1214
+ ```
1215
+
1216
+ ## Sparklines and Simple Charts (Pure SVG)
1217
+
1218
+ ```html
1219
+ <!-- Sparkline -->
1220
+ <svg viewBox="0 0 100 30" style="width:100px;height:30px;">
1221
+ <polyline points="0,25 15,20 30,22 45,10 60,15 75,5 90,12 100,8"
1222
+ fill="none" stroke="var(--accent)" stroke-width="1.5" stroke-linecap="round"/>
1223
+ </svg>
1224
+
1225
+ <!-- Progress bar -->
1226
+ <div style="height:6px;background:var(--border);border-radius:3px;overflow:hidden;">
1227
+ <div style="height:100%;width:72%;background:var(--accent);border-radius:3px;"></div>
1228
+ </div>
1229
+ ```
1230
+
1231
+ ## Responsive Breakpoint
1232
+
1233
+ Include a single breakpoint for narrow viewports:
1234
+
1235
+ ```css
1236
+ @media (max-width: 768px) {
1237
+ .arch-grid { grid-template-columns: 1fr; }
1238
+ .pipeline { flex-wrap: wrap; gap: 8px; }
1239
+ .pipeline__arrow { display: none; }
1240
+ body { padding: 16px; }
1241
+ }
1242
+ ```
1243
+
1244
+ ## Badges and Tags
1245
+
1246
+ ```css
1247
+ .tag {
1248
+ font-family: var(--font-mono);
1249
+ font-size: 10px;
1250
+ font-weight: 500;
1251
+ padding: 2px 7px;
1252
+ border-radius: 4px;
1253
+ background: var(--node-a-dim);
1254
+ color: var(--node-a);
1255
+ }
1256
+ ```
1257
+
1258
+ ## Lists Inside Nodes
1259
+
1260
+ ```css
1261
+ .node-list {
1262
+ list-style: none;
1263
+ padding: 0;
1264
+ margin: 0;
1265
+ font-size: 14px;
1266
+ line-height: 1.8;
1267
+ }
1268
+
1269
+ .node-list li {
1270
+ padding-left: 14px;
1271
+ position: relative;
1272
+ }
1273
+
1274
+ .node-list li::before {
1275
+ content: '›';
1276
+ color: var(--text-dim);
1277
+ font-weight: 600;
1278
+ position: absolute;
1279
+ left: 0;
1280
+ }
1281
+
1282
+ .node-list code {
1283
+ font-family: var(--font-mono);
1284
+ font-size: 11px;
1285
+ background: var(--accent-dim);
1286
+ color: var(--accent);
1287
+ padding: 1px 5px;
1288
+ border-radius: 3px;
1289
+ }
1290
+ ```
1291
+
1292
+ ## KPI / Metric Cards
1293
+
1294
+ ```css
1295
+ .kpi-row {
1296
+ display: grid;
1297
+ grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
1298
+ gap: 16px;
1299
+ }
1300
+
1301
+ .kpi-card {
1302
+ background: var(--surface-elevated);
1303
+ border: 1px solid var(--border);
1304
+ border-radius: 10px;
1305
+ padding: 20px;
1306
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
1307
+ }
1308
+
1309
+ .kpi-card__value {
1310
+ font-size: 36px;
1311
+ font-weight: 700;
1312
+ letter-spacing: -1px;
1313
+ line-height: 1.1;
1314
+ font-variant-numeric: tabular-nums;
1315
+ }
1316
+
1317
+ .kpi-card__label {
1318
+ font-family: var(--font-mono);
1319
+ font-size: 10px;
1320
+ font-weight: 600;
1321
+ text-transform: uppercase;
1322
+ letter-spacing: 1.5px;
1323
+ color: var(--text-dim);
1324
+ margin-top: 6px;
1325
+ }
1326
+
1327
+ .kpi-card__trend {
1328
+ font-family: var(--font-mono);
1329
+ font-size: 12px;
1330
+ margin-top: 4px;
1331
+ }
1332
+
1333
+ .kpi-card__trend--up { color: var(--node-b, #059669); }
1334
+ .kpi-card__trend--down { color: var(--red, #ef4444); }
1335
+ ```
1336
+
1337
+ ```html
1338
+ <div class="kpi-row">
1339
+ <div class="kpi-card">
1340
+ <div class="kpi-card__value">247</div>
1341
+ <div class="kpi-card__label">Lines Added</div>
1342
+ <div class="kpi-card__trend kpi-card__trend--up">+34%</div>
1343
+ </div>
1344
+ </div>
1345
+ ```
1346
+
1347
+ ## Before / After Panels
1348
+
1349
+ ```css
1350
+ .diff-panels {
1351
+ display: grid;
1352
+ grid-template-columns: 1fr 1fr;
1353
+ gap: 0;
1354
+ border: 1px solid var(--border);
1355
+ border-radius: 10px;
1356
+ overflow: hidden;
1357
+ }
1358
+
1359
+ .diff-panels > * { min-width: 0; overflow-wrap: break-word; }
1360
+
1361
+ .diff-panel__header {
1362
+ font-family: var(--font-mono);
1363
+ font-size: 11px;
1364
+ font-weight: 600;
1365
+ text-transform: uppercase;
1366
+ letter-spacing: 1px;
1367
+ padding: 10px 16px;
1368
+ }
1369
+
1370
+ .diff-panel__header--before {
1371
+ background: var(--red-dim, rgba(239, 68, 68, 0.08));
1372
+ color: var(--red, #ef4444);
1373
+ border-bottom: 2px solid var(--red, #ef4444);
1374
+ }
1375
+
1376
+ .diff-panel__header--after {
1377
+ background: var(--green-dim, rgba(5, 150, 105, 0.08));
1378
+ color: var(--green, #059669);
1379
+ border-bottom: 2px solid var(--green, #059669);
1380
+ }
1381
+
1382
+ .diff-panel__body {
1383
+ padding: 16px;
1384
+ background: var(--surface);
1385
+ font-size: 15px;
1386
+ line-height: 1.6;
1387
+ }
1388
+
1389
+ .diff-changed {
1390
+ background: var(--accent-dim);
1391
+ border-radius: 3px;
1392
+ padding: 0 3px;
1393
+ }
1394
+
1395
+ @media (max-width: 768px) {
1396
+ .diff-panels { grid-template-columns: 1fr; }
1397
+ }
1398
+ ```
1399
+
1400
+ ## Collapsible Sections
1401
+
1402
+ Native `<details>/<summary>` with styled disclosure. Zero JS, accessible. For lower-priority content: file maps, decision logs, reference sections.
1403
+
1404
+ ```css
1405
+ details.collapsible {
1406
+ border: 1px solid var(--border);
1407
+ border-radius: 10px;
1408
+ overflow: hidden;
1409
+ }
1410
+
1411
+ details.collapsible summary {
1412
+ padding: 14px 20px;
1413
+ background: var(--surface);
1414
+ font-family: var(--font-mono);
1415
+ font-size: 12px;
1416
+ font-weight: 600;
1417
+ cursor: pointer;
1418
+ list-style: none;
1419
+ display: flex;
1420
+ align-items: center;
1421
+ gap: 8px;
1422
+ color: var(--text);
1423
+ transition: background 0.15s ease;
1424
+ }
1425
+
1426
+ details.collapsible summary:hover {
1427
+ background: var(--surface-elevated, var(--surface));
1428
+ }
1429
+
1430
+ details.collapsible summary::-webkit-details-marker { display: none; }
1431
+
1432
+ /* Chevron indicator */
1433
+ details.collapsible summary::before {
1434
+ content: '▸';
1435
+ font-size: 11px;
1436
+ color: var(--text-dim);
1437
+ transition: transform 0.15s ease;
1438
+ }
1439
+
1440
+ details.collapsible[open] summary::before {
1441
+ transform: rotate(90deg);
1442
+ }
1443
+
1444
+ details.collapsible .collapsible__body {
1445
+ padding: 16px 20px;
1446
+ border-top: 1px solid var(--border);
1447
+ font-size: 15px;
1448
+ line-height: 1.6;
1449
+ }
1450
+ ```
1451
+
1452
+ ```html
1453
+ <details class="collapsible">
1454
+ <summary>File Map (14 files changed)</summary>
1455
+ <div class="collapsible__body">
1456
+ <!-- content here -->
1457
+ </div>
1458
+ </details>
1459
+ ```
1460
+
1461
+ ## Prose Page Elements
1462
+
1463
+ Patterns for documentation, articles, blog posts, and reading-first content. Optimize for sustained reading, not scanning.
1464
+
1465
+ ### Body Text Settings
1466
+
1467
+ ```css
1468
+ .prose {
1469
+ font-size: clamp(17px, 1.1vw + 14px, 19px);
1470
+ line-height: 1.7;
1471
+ max-width: 65ch;
1472
+ text-wrap: pretty;
1473
+ }
1474
+
1475
+ .prose p {
1476
+ margin-bottom: 1.5em;
1477
+ }
1478
+
1479
+ .prose--narrow {
1480
+ max-width: 60ch;
1481
+ line-height: 1.8;
1482
+ }
1483
+
1484
+ .prose--wide {
1485
+ max-width: 75ch;
1486
+ line-height: 1.6;
1487
+ }
1488
+ ```
1489
+
1490
+ ### Lead Paragraph
1491
+
1492
+ ```css
1493
+ .lead {
1494
+ font-size: 20px;
1495
+ line-height: 1.6;
1496
+ color: var(--text-bright);
1497
+ margin-bottom: 32px;
1498
+ }
1499
+
1500
+ .lead--dropcap::first-letter {
1501
+ float: left;
1502
+ font-family: var(--font-display);
1503
+ font-size: 64px;
1504
+ font-weight: 600;
1505
+ line-height: 0.85;
1506
+ padding-right: 12px;
1507
+ padding-top: 6px;
1508
+ color: var(--accent);
1509
+ }
1510
+ ```
1511
+
1512
+ ### Pull Quotes
1513
+
1514
+ ```css
1515
+ /* Border left — most versatile */
1516
+ .pullquote {
1517
+ margin: 48px 0;
1518
+ padding-left: 24px;
1519
+ border-left: 3px solid var(--accent);
1520
+ }
1521
+ .pullquote p {
1522
+ font-size: 22px;
1523
+ font-style: italic;
1524
+ line-height: 1.4;
1525
+ color: var(--text-bright);
1526
+ margin: 0;
1527
+ }
1528
+
1529
+ /* Centered with quotation mark */
1530
+ .pullquote--centered {
1531
+ margin: 56px 0;
1532
+ padding: 32px 40px;
1533
+ border-top: 1px solid var(--border);
1534
+ border-bottom: 1px solid var(--border);
1535
+ text-align: center;
1536
+ position: relative;
1537
+ }
1538
+ .pullquote--centered::before {
1539
+ content: '"';
1540
+ position: absolute;
1541
+ top: -12px;
1542
+ left: 50%;
1543
+ transform: translateX(-50%);
1544
+ background: var(--bg);
1545
+ padding: 0 16px;
1546
+ font-size: 48px;
1547
+ color: var(--accent);
1548
+ line-height: 1;
1549
+ }
1550
+ ```
1551
+
1552
+ ### Callout Boxes
1553
+
1554
+ ```css
1555
+ .callout {
1556
+ padding: 16px 20px;
1557
+ border-radius: 8px;
1558
+ border-left: 4px solid var(--callout-border);
1559
+ background: var(--callout-bg);
1560
+ margin: 24px 0;
1561
+ }
1562
+
1563
+ .callout--info {
1564
+ --callout-border: var(--accent);
1565
+ --callout-bg: color-mix(in srgb, var(--accent) 10%, transparent);
1566
+ }
1567
+
1568
+ .callout--warning {
1569
+ --callout-border: var(--amber);
1570
+ --callout-bg: color-mix(in srgb, var(--amber) 10%, transparent);
1571
+ }
1572
+
1573
+ .callout--success {
1574
+ --callout-border: var(--green);
1575
+ --callout-bg: color-mix(in srgb, var(--green) 10%, transparent);
1576
+ }
1577
+
1578
+ .callout__title {
1579
+ font-weight: 600;
1580
+ margin-bottom: 8px;
1581
+ color: var(--callout-border);
1582
+ }
1583
+
1584
+ /* Lists inside callouts need padding fix */
1585
+ .callout ul, .callout ol {
1586
+ padding-left: 1.5em;
1587
+ margin: 8px 0 0 0;
1588
+ }
1589
+ ```
1590
+
1591
+ ### Theme Toggle
1592
+
1593
+ ```css
1594
+ :root, [data-theme="light"] {
1595
+ --bg: #fafaf9;
1596
+ --surface: #ffffff;
1597
+ --text: #1c1917;
1598
+ --text-dim: #78716c;
1599
+ --border: #e7e5e4;
1600
+ --accent: #0d9488;
1601
+ }
1602
+
1603
+ [data-theme="dark"] {
1604
+ --bg: #0c0a09;
1605
+ --surface: #1c1917;
1606
+ --text: #fafaf9;
1607
+ --text-dim: #a8a29e;
1608
+ --border: #292524;
1609
+ --accent: #14b8a6;
1610
+ }
1611
+ ```
1612
+
1613
+ ```javascript
1614
+ // Random initial theme
1615
+ const themes = ['light', 'dark'];
1616
+ document.documentElement.setAttribute('data-theme', themes[Math.floor(Math.random() * 2)]);
1617
+
1618
+ // Toggle
1619
+ function toggleTheme() {
1620
+ const current = document.documentElement.getAttribute('data-theme');
1621
+ document.documentElement.setAttribute('data-theme', current === 'light' ? 'dark' : 'light');
1622
+ }
1623
+ ```
1624
+
1625
+ ### Prose Anti-Patterns
1626
+
1627
+ Avoid in reading-first content:
1628
+ - Body text smaller than 16px
1629
+ - Line-height below 1.5
1630
+ - Measure wider than 75ch
1631
+ - Pull quotes every other paragraph
1632
+ - Busy background patterns behind text
1633
+
1634
+ ## Generated Images
1635
+
1636
+ For AI-generated illustrations embedded as base64 data URIs. Use `/ck:ai-multimodal` skill for image generation if available.
1637
+
1638
+ ### Hero Banner
1639
+
1640
+ ```css
1641
+ .hero-img-wrap {
1642
+ position: relative;
1643
+ border-radius: 12px;
1644
+ overflow: hidden;
1645
+ margin-bottom: 24px;
1646
+ }
1647
+
1648
+ .hero-img-wrap img {
1649
+ width: 100%;
1650
+ height: 240px;
1651
+ object-fit: cover;
1652
+ display: block;
1653
+ }
1654
+
1655
+ /* Gradient fade into page background */
1656
+ .hero-img-wrap::after {
1657
+ content: '';
1658
+ position: absolute;
1659
+ bottom: 0;
1660
+ left: 0;
1661
+ right: 0;
1662
+ height: 50%;
1663
+ background: linear-gradient(to top, var(--bg), transparent);
1664
+ pointer-events: none;
1665
+ }
1666
+ ```
1667
+
1668
+ ```html
1669
+ <div class="hero-img-wrap">
1670
+ <img src="data:image/png;base64,..." alt="Descriptive alt text">
1671
+ </div>
1672
+ ```
1673
+
1674
+ ### Inline Illustration
1675
+
1676
+ ```css
1677
+ .illus {
1678
+ text-align: center;
1679
+ margin: 24px 0;
1680
+ }
1681
+
1682
+ .illus img {
1683
+ max-width: 480px;
1684
+ width: 100%;
1685
+ border-radius: 10px;
1686
+ border: 1px solid var(--border);
1687
+ box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
1688
+ }
1689
+
1690
+ .illus figcaption {
1691
+ font-family: var(--font-mono);
1692
+ font-size: 11px;
1693
+ color: var(--text-dim);
1694
+ margin-top: 8px;
1695
+ }
1696
+ ```
1697
+
1698
+ ### Side Accent
1699
+
1700
+ ```css
1701
+ .accent-img {
1702
+ float: right;
1703
+ max-width: 200px;
1704
+ margin: 0 0 16px 24px;
1705
+ border-radius: 10px;
1706
+ border: 1px solid var(--border);
1707
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
1708
+ }
1709
+
1710
+ @media (max-width: 768px) {
1711
+ .accent-img {
1712
+ float: none;
1713
+ max-width: 100%;
1714
+ margin: 0 0 16px 0;
1715
+ }
1716
+ }
1717
+ ```