codymaster 7.0.2 → 7.0.3

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 (341) hide show
  1. package/CHANGELOG.md +64 -0
  2. package/README.md +38 -1
  3. package/dist/agent/codex.js +73 -21
  4. package/dist/agent-dispatch.js +63 -48
  5. package/dist/cli/commands/brain.js +18 -0
  6. package/dist/cli/commands/design-studio.js +1 -1
  7. package/dist/cm-suggest.js +3 -3
  8. package/dist/dashboard-project-summary.js +9 -0
  9. package/dist/dashboard.js +11 -5
  10. package/dist/execution-analyzer.js +9 -1
  11. package/dist/judge.js +16 -15
  12. package/dist/mcp-context-server.js +45 -23
  13. package/dist/mcp-skills-tools.js +2 -2
  14. package/dist/skill-chain.js +26 -3
  15. package/dist/skill-token-report.js +105 -0
  16. package/dist/sprint-pipeline.js +3 -3
  17. package/dist/ui/onboarding.js +3 -4
  18. package/dist/utils/design-taste.js +1 -1
  19. package/dist/utils/output-compress.js +8 -0
  20. package/package.json +2 -1
  21. package/public/dashboard/app.js +40 -13
  22. package/public/dashboard/index.html +190 -5
  23. package/public/dashboard/style.css +1 -1
  24. package/scripts/build-skills.mjs +36 -2
  25. package/scripts/mcp-bridge.js +41 -24
  26. package/scripts/pack-plugin.mjs +206 -0
  27. package/skills/cm-ads-tracker/SKILL.md +401 -0
  28. package/skills/cm-ads-tracker/evals/evals.json +55 -0
  29. package/skills/cm-ads-tracker/references/gtm-architecture.md +321 -0
  30. package/skills/cm-ads-tracker/references/industry-events.md +294 -0
  31. package/skills/cm-ads-tracker/references/platforms-api.md +238 -0
  32. package/skills/cm-ads-tracker/templates/capi-payload.md +79 -0
  33. package/skills/cm-ads-tracker/templates/datalayer-push.js +104 -0
  34. package/skills/cm-ads-tracker/templates/gtm-variables.js +56 -0
  35. package/skills/cm-auto-publisher/SKILL.md +81 -0
  36. package/skills/cm-booking-calendar/SKILL.md +521 -0
  37. package/skills/cm-booking-calendar/references/industry-patterns.md +527 -0
  38. package/skills/cm-booking-calendar/templates/booking-form.css +626 -0
  39. package/skills/cm-booking-calendar/templates/booking-form.html +477 -0
  40. package/skills/cm-booking-calendar/templates/calendar-engine.js +419 -0
  41. package/skills/cm-booking-calendar/templates/calendar-export.js +395 -0
  42. package/skills/cm-booking-calendar/templates/reminder-config.js +629 -0
  43. package/skills/cm-brainstorm-idea/SKILL.md +5 -5
  44. package/skills/cm-code-review/SKILL.md +2 -2
  45. package/skills/cm-codeintell/SKILL.md +47 -580
  46. package/skills/cm-codeintell/references/integration-workflows.md +23 -0
  47. package/skills/cm-codeintell/references/layer-0-skeleton.md +54 -0
  48. package/skills/cm-codeintell/references/layer-1-codegraph.md +58 -0
  49. package/skills/cm-codeintell/references/layer-2-architecture.md +31 -0
  50. package/skills/cm-codeintell/references/layer-3-context-builder.md +32 -0
  51. package/skills/cm-content-factory/.content-factory-state.json +132 -0
  52. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +1 -0
  53. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +1 -0
  54. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  55. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  56. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  57. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  58. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  59. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  60. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  61. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  62. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  63. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  64. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  65. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  66. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  67. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  68. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  69. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  70. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  71. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  72. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  73. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  74. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  75. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  76. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  77. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  78. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  79. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  80. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  81. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  82. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  83. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  84. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  85. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  86. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  87. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  88. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  89. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  90. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  91. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  92. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  93. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  94. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  95. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  96. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  97. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +5 -0
  98. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  99. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  100. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  101. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  102. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  103. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  104. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  105. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  106. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  107. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  108. package/skills/cm-content-factory/.git 2/refs/heads/main +1 -0
  109. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +1 -0
  110. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +76 -0
  111. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +1 -0
  112. package/skills/cm-content-factory/AGENTS.md +61 -0
  113. package/skills/cm-content-factory/CLAUDE.md +63 -0
  114. package/skills/cm-content-factory/CURSOR.md +43 -0
  115. package/skills/cm-content-factory/Content Factory.zip +0 -0
  116. package/skills/cm-content-factory/SKILL.md +416 -0
  117. package/skills/cm-content-factory/cf +313 -0
  118. package/skills/cm-content-factory/config.schema.json +397 -0
  119. package/skills/cm-content-factory/dashboard/app.js +556 -0
  120. package/skills/cm-content-factory/dashboard/index.html +397 -0
  121. package/skills/cm-content-factory/dashboard/style.css +1211 -0
  122. package/skills/cm-content-factory/examples/01-real-estate.config.json +146 -0
  123. package/skills/cm-content-factory/examples/02-personal-finance.config.json +146 -0
  124. package/skills/cm-content-factory/examples/03-health-wellness.config.json +147 -0
  125. package/skills/cm-content-factory/examples/04-saas-software.config.json +147 -0
  126. package/skills/cm-content-factory/examples/05-legal-services.config.json +147 -0
  127. package/skills/cm-content-factory/examples/06-insurance.config.json +146 -0
  128. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +146 -0
  129. package/skills/cm-content-factory/examples/08-online-education.config.json +147 -0
  130. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +147 -0
  131. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +147 -0
  132. package/skills/cm-content-factory/examples/11-home-services.config.json +146 -0
  133. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +147 -0
  134. package/skills/cm-content-factory/examples/13-pet-care.config.json +147 -0
  135. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +147 -0
  136. package/skills/cm-content-factory/examples/15-ai-automation.config.json +147 -0
  137. package/skills/cm-content-factory/examples/16-wedding-events.config.json +147 -0
  138. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +148 -0
  139. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +147 -0
  140. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +148 -0
  141. package/skills/cm-content-factory/examples/20-solar-energy.config.json +147 -0
  142. package/skills/cm-content-factory/examples/fitness-blog.config.json +116 -0
  143. package/skills/cm-content-factory/examples/tech-blog.config.json +107 -0
  144. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +72 -0
  145. package/skills/cm-content-factory/extensions/hooks.py +126 -0
  146. package/skills/cm-content-factory/extensions/openclaw_adapter.py +132 -0
  147. package/skills/cm-content-factory/landing/docs/content/changelog.md +36 -0
  148. package/skills/cm-content-factory/landing/docs/content/deployment.md +46 -0
  149. package/skills/cm-content-factory/landing/docs/content/execution-flow.md +67 -0
  150. package/skills/cm-content-factory/landing/docs/content/openspace.md +27 -0
  151. package/skills/cm-content-factory/landing/docs/content/openviking.md +33 -0
  152. package/skills/cm-content-factory/landing/docs/content/use-cases.md +26 -0
  153. package/skills/cm-content-factory/landing/docs/content/v5-intro.md +28 -0
  154. package/skills/cm-content-factory/landing/docs/index.html +240 -0
  155. package/skills/cm-content-factory/landing/index.html +680 -0
  156. package/skills/cm-content-factory/landing/script.js +143 -0
  157. package/skills/cm-content-factory/landing/style.css +1216 -0
  158. package/skills/cm-content-factory/landing/translations.js +508 -0
  159. package/skills/cm-content-factory/logs/events.jsonl +11 -0
  160. package/skills/cm-content-factory/profiles/_template.profile.json +231 -0
  161. package/skills/cm-content-factory/profiles/finance.profile.json +278 -0
  162. package/skills/cm-content-factory/profiles/legal.profile.json +263 -0
  163. package/skills/cm-content-factory/profiles/medical-research.profile.json +321 -0
  164. package/skills/cm-content-factory/profiles/technology.profile.json +275 -0
  165. package/skills/cm-content-factory/scripts/agent_dispatcher.py +266 -0
  166. package/skills/cm-content-factory/scripts/audit.py +106 -0
  167. package/skills/cm-content-factory/scripts/dashboard_server.py +225 -0
  168. package/skills/cm-content-factory/scripts/deploy.py +146 -0
  169. package/skills/cm-content-factory/scripts/extract.py +132 -0
  170. package/skills/cm-content-factory/scripts/landing_generator.py +459 -0
  171. package/skills/cm-content-factory/scripts/memory.py +521 -0
  172. package/skills/cm-content-factory/scripts/monetize.py +239 -0
  173. package/skills/cm-content-factory/scripts/pipeline.py +357 -0
  174. package/skills/cm-content-factory/scripts/plan.py +163 -0
  175. package/skills/cm-content-factory/scripts/publish.py +145 -0
  176. package/skills/cm-content-factory/scripts/research.py +337 -0
  177. package/skills/cm-content-factory/scripts/scaffold.py +464 -0
  178. package/skills/cm-content-factory/scripts/scoreboard.py +336 -0
  179. package/skills/cm-content-factory/scripts/seo.py +90 -0
  180. package/skills/cm-content-factory/scripts/state_manager.py +320 -0
  181. package/skills/cm-content-factory/scripts/token_manager.py +268 -0
  182. package/skills/cm-content-factory/scripts/validate.py +221 -0
  183. package/skills/cm-content-factory/scripts/wizard.py +329 -0
  184. package/skills/cm-content-factory/scripts/write.py +93 -0
  185. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  186. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +90 -0
  187. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +54 -0
  188. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +38 -0
  189. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +65 -0
  190. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +48 -0
  191. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +39 -0
  192. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +42 -0
  193. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +51 -0
  194. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +52 -0
  195. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +86 -0
  196. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +80 -0
  197. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +58 -0
  198. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +102 -0
  199. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +45 -0
  200. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +29 -0
  201. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +55 -0
  202. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +29 -0
  203. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +41 -0
  204. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +40 -0
  205. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +56 -0
  206. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +46 -0
  207. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +45 -0
  208. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +45 -0
  209. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +108 -0
  210. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +22 -0
  211. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +52 -0
  212. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +58 -0
  213. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +92 -0
  214. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +575 -0
  215. package/skills/cm-content-factory/tests/conftest.py +66 -0
  216. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +125 -0
  217. package/skills/cm-content-factory/tests/test_memory.py +128 -0
  218. package/skills/cm-content-factory/tests/test_pipeline.py +107 -0
  219. package/skills/cm-content-factory/tests/test_research.py +56 -0
  220. package/skills/cm-content-factory/tests/test_state_manager.py +131 -0
  221. package/skills/cm-content-factory/tests/test_token_manager.py +110 -0
  222. package/skills/cm-content-factory/tests/test_wizard.py +121 -0
  223. package/skills/cm-continuity/SKILL.md +49 -480
  224. package/skills/cm-continuity/references/cm-uri-scheme.md +23 -0
  225. package/skills/cm-continuity/references/continuity-template.md +48 -0
  226. package/skills/cm-continuity/references/mcp-context-server.md +27 -0
  227. package/skills/cm-continuity/references/memory-architecture.md +26 -0
  228. package/skills/cm-continuity/references/memory-audit.md +18 -0
  229. package/skills/cm-continuity/references/session-protocol.md +31 -0
  230. package/skills/cm-continuity/references/storage-formats.md +20 -0
  231. package/skills/cm-cro-methodology/SKILL.md +290 -0
  232. package/skills/cm-cro-methodology/references/COPYWRITING.md +178 -0
  233. package/skills/cm-cro-methodology/references/OBJECTIONS.md +135 -0
  234. package/skills/cm-cro-methodology/references/PERSUASION.md +158 -0
  235. package/skills/cm-cro-methodology/references/RESEARCH.md +220 -0
  236. package/skills/cm-cro-methodology/references/funnel-analysis.md +365 -0
  237. package/skills/cm-cro-methodology/references/testing-methodology.md +330 -0
  238. package/skills/cm-design-system/SKILL.md +5 -6
  239. package/skills/cm-execution/SKILL.md +61 -379
  240. package/skills/cm-execution/references/mode-a-batch.md +28 -0
  241. package/skills/cm-execution/references/mode-b-subagent.md +46 -0
  242. package/skills/cm-execution/references/mode-c-parallel.md +39 -0
  243. package/skills/cm-execution/references/mode-d-rarv.md +62 -0
  244. package/skills/cm-execution/references/mode-e-triz-parallel.md +53 -0
  245. package/skills/cm-execution/references/mode-f-party.md +61 -0
  246. package/skills/cm-execution/references/persona-dispatch.md +22 -0
  247. package/skills/cm-execution/references/security-rules.md +47 -0
  248. package/skills/cm-google-form/SKILL.md +266 -0
  249. package/skills/cm-google-form/templates/apps-script.js +55 -0
  250. package/skills/cm-google-form/templates/form-markup.html +110 -0
  251. package/skills/cm-google-form/templates/form-submit.js +201 -0
  252. package/skills/cm-google-form/templates/toast.css +152 -0
  253. package/skills/cm-growth-hacking/SKILL.md +282 -0
  254. package/skills/cm-growth-hacking/bottom-sheet-engine.md +261 -0
  255. package/skills/cm-growth-hacking/calendar-integration.md +264 -0
  256. package/skills/cm-growth-hacking/references/engagement-patterns.md +346 -0
  257. package/skills/cm-growth-hacking/templates/bottom-sheet.css +528 -0
  258. package/skills/cm-growth-hacking/templates/bottom-sheet.js +269 -0
  259. package/skills/cm-growth-hacking/templates/calendar-cta.js +213 -0
  260. package/skills/cm-growth-hacking/templates/tracking-events.js +211 -0
  261. package/skills/cm-growth-hacking/templates/trigger-manager.js +254 -0
  262. package/skills/cm-growth-hacking/tracking-events.md +246 -0
  263. package/skills/cm-growth-hacking/trigger-system.md +342 -0
  264. package/skills/cm-how-it-work/SKILL.md +8 -9
  265. package/skills/cm-identity-guard/SKILL.md +4 -4
  266. package/skills/cm-jtbd/SKILL.md +98 -0
  267. package/skills/cm-notebooklm/SKILL.md +156 -0
  268. package/skills/cm-notebooklm/references/command_reference.md +94 -0
  269. package/skills/cm-notebooklm/references/workflows.md +60 -0
  270. package/skills/cm-notebooklm/resources/knowledge_sources.md +106 -0
  271. package/skills/cm-notebooklm/scripts/brain-sync.sh +453 -0
  272. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +101 -0
  273. package/skills/cm-planning/SKILL.md +3 -3
  274. package/skills/cm-project-bootstrap/SKILL.md +2 -2
  275. package/skills/cm-quality-gate/SKILL.md +1 -1
  276. package/skills/cm-readit/SKILL.md +289 -0
  277. package/skills/cm-readit/audio-player.md +206 -0
  278. package/skills/cm-readit/examples/blog-reader.js +352 -0
  279. package/skills/cm-readit/examples/voice-cro.js +390 -0
  280. package/skills/cm-readit/tts-engine.md +262 -0
  281. package/skills/cm-readit/ui-patterns.md +362 -0
  282. package/skills/cm-readit/voice-cro.md +223 -0
  283. package/skills/cm-safe-deploy/SKILL.md +80 -510
  284. package/skills/cm-safe-deploy/references/gate-0-5-security-scan.md +31 -0
  285. package/skills/cm-safe-deploy/references/gate-0-secret-hygiene.md +68 -0
  286. package/skills/cm-safe-deploy/references/gate-1-syntax.md +23 -0
  287. package/skills/cm-safe-deploy/references/gate-2-test-suite.md +28 -0
  288. package/skills/cm-safe-deploy/references/gate-3-i18n.md +19 -0
  289. package/skills/cm-safe-deploy/references/gate-4-5-build-dist.md +16 -0
  290. package/skills/cm-safe-deploy/references/gate-6-deploy-smoke.md +18 -0
  291. package/skills/cm-safe-deploy/references/rollback.md +17 -0
  292. package/skills/cm-safe-deploy/references/setup-new-project.md +20 -0
  293. package/skills/cm-skill-index/SKILL.md +15 -15
  294. package/skills/cm-start/SKILL.md +1 -1
  295. package/skills/cm-tdd/SKILL.md +51 -356
  296. package/skills/cm-tdd/references/bugfix-example.md +15 -0
  297. package/skills/cm-tdd/references/rationalizations.md +20 -0
  298. package/skills/cm-tdd/references/red-green-refactor.md +33 -0
  299. package/skills/cm-tdd/references/stuck-debugging.md +18 -0
  300. package/skills/cm-tdd/references/test-quality.md +19 -0
  301. package/skills/cm-ux-master/SKILL.md +368 -115
  302. package/skills/profiles/core.txt +1 -4
  303. package/skills/profiles/design.txt +1 -2
  304. package/skills/profiles/full.txt +10 -16
  305. package/skills/profiles/growth.txt +9 -9
  306. package/skills/profiles/top35.json +13 -13
  307. package/skills/cm-conductor-worktrees/SKILL.archive.md +0 -28
  308. package/skills/cm-conductor-worktrees/SKILL.md +0 -26
  309. package/skills/cm-dashboard/SKILL.archive.md +0 -15
  310. package/skills/cm-dashboard/SKILL.md +0 -26
  311. package/skills/cm-dashboard/ui/app.js +0 -1278
  312. package/skills/cm-dashboard/ui/index.html +0 -206
  313. package/skills/cm-dashboard/ui/style.css +0 -440
  314. package/skills/cm-design-studio/SKILL.archive.md +0 -34
  315. package/skills/cm-design-studio/SKILL.md +0 -26
  316. package/skills/cm-engineering-meta/SKILL.archive.md +0 -73
  317. package/skills/cm-engineering-meta/SKILL.md +0 -26
  318. package/skills/cm-git-worktrees/SKILL.archive.md +0 -157
  319. package/skills/cm-git-worktrees/SKILL.md +0 -26
  320. package/skills/cm-post-deploy-canary/SKILL.archive.md +0 -22
  321. package/skills/cm-post-deploy-canary/SKILL.md +0 -26
  322. package/skills/cm-qa-visual-cli/SKILL.archive.md +0 -22
  323. package/skills/cm-qa-visual-cli/SKILL.md +0 -26
  324. package/skills/cm-second-opinion-cli/SKILL.archive.md +0 -23
  325. package/skills/cm-second-opinion-cli/SKILL.md +0 -26
  326. package/skills/cm-secret-shield/SKILL.archive.md +0 -580
  327. package/skills/cm-secret-shield/SKILL.md +0 -26
  328. package/skills/cm-security-gate/SKILL.archive.md +0 -239
  329. package/skills/cm-security-gate/SKILL.md +0 -26
  330. package/skills/cm-skill-health/SKILL.archive.md +0 -83
  331. package/skills/cm-skill-health/SKILL.md +0 -26
  332. package/skills/cm-skill-mastery/SKILL.archive.md +0 -156
  333. package/skills/cm-skill-mastery/SKILL.md +0 -26
  334. package/skills/cm-skill-search/SKILL.archive.md +0 -49
  335. package/skills/cm-skill-search/SKILL.md +0 -26
  336. package/skills/cm-skill-share/SKILL.archive.md +0 -58
  337. package/skills/cm-skill-share/SKILL.md +0 -26
  338. package/skills/cm-test-gate/SKILL.archive.md +0 -245
  339. package/skills/cm-test-gate/SKILL.md +0 -26
  340. package/skills/cm-ui-preview/SKILL.archive.md +0 -153
  341. package/skills/cm-ui-preview/SKILL.md +0 -26
@@ -0,0 +1,1211 @@
1
+ /* Content Factory Dashboard — UX Master Compliant Theme */
2
+ /* Mobile-first · Fitts's Law · Hick's Law · Miller's Law · Doherty Threshold */
3
+
4
+ :root {
5
+ /* Base Colors */
6
+ --bg-primary: #0a0e17;
7
+ --bg-secondary: #111827;
8
+ --bg-card: #1a2332;
9
+ --bg-hover: #243046;
10
+ --bg-input: #0f1724;
11
+
12
+ /* Text */
13
+ --text-primary: #e2e8f0;
14
+ --text-secondary: #94a3b8;
15
+ --text-muted: #64748b;
16
+
17
+ /* Accent Colors */
18
+ --accent-cyan: #06b6d4;
19
+ --accent-green: #10b981;
20
+ --accent-amber: #f59e0b;
21
+ --accent-red: #ef4444;
22
+ --accent-purple: #8b5cf6;
23
+ --accent-blue: #3b82f6;
24
+
25
+ /* Status */
26
+ --status-running: #06b6d4;
27
+ --status-done: #10b981;
28
+ --status-failed: #ef4444;
29
+ --status-pending: #475569;
30
+ --status-warning: #f59e0b;
31
+
32
+ /* Borders */
33
+ --border-color: #1e293b;
34
+ --border-accent: #334155;
35
+
36
+ /* Shadows */
37
+ --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3);
38
+ --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
39
+ --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5);
40
+ --shadow-glow-cyan: 0 0 20px rgba(6, 182, 212, 0.15);
41
+ --shadow-glow-green: 0 0 20px rgba(16, 185, 129, 0.15);
42
+
43
+ /* Typography */
44
+ --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
45
+ --font-mono: 'JetBrains Mono', 'Fira Code', monospace;
46
+
47
+ /* Spacing */
48
+ --radius-sm: 6px;
49
+ --radius-md: 10px;
50
+ --radius-lg: 14px;
51
+
52
+ /* Transitions */
53
+ --transition-fast: 150ms ease;
54
+ --transition-normal: 250ms ease;
55
+ }
56
+
57
+ *,
58
+ *::before,
59
+ *::after {
60
+ box-sizing: border-box;
61
+ margin: 0;
62
+ padding: 0;
63
+ }
64
+
65
+ html {
66
+ font-size: 14px;
67
+ -webkit-font-smoothing: antialiased;
68
+ -moz-osx-font-smoothing: grayscale;
69
+ }
70
+
71
+ body {
72
+ font-family: var(--font-sans);
73
+ background: var(--bg-primary);
74
+ color: var(--text-primary);
75
+ line-height: 1.6;
76
+ min-height: 100vh;
77
+ min-height: 100dvh;
78
+ overscroll-behavior: none;
79
+ }
80
+
81
+ /* ─── Header ─── */
82
+ .header {
83
+ display: flex;
84
+ align-items: center;
85
+ justify-content: space-between;
86
+ padding: 0.5rem 1rem;
87
+ background: var(--bg-secondary);
88
+ border-bottom: 1px solid var(--border-color);
89
+ position: sticky;
90
+ top: 0;
91
+ z-index: 100;
92
+ backdrop-filter: blur(12px);
93
+ min-height: 48px;
94
+ }
95
+
96
+ .header-left {
97
+ display: flex;
98
+ align-items: center;
99
+ gap: 0.5rem;
100
+ min-width: 0;
101
+ }
102
+
103
+ .logo {
104
+ display: flex;
105
+ align-items: center;
106
+ gap: 0.5rem;
107
+ font-weight: 700;
108
+ font-size: 1rem;
109
+ color: var(--accent-cyan);
110
+ white-space: nowrap;
111
+ }
112
+
113
+ .logo svg {
114
+ opacity: 0.9;
115
+ flex-shrink: 0;
116
+ }
117
+
118
+ .version-badge {
119
+ font-size: 0.65rem;
120
+ font-weight: 600;
121
+ padding: 2px 6px;
122
+ border-radius: 999px;
123
+ background: rgba(6, 182, 212, 0.12);
124
+ color: var(--accent-cyan);
125
+ border: 1px solid rgba(6, 182, 212, 0.2);
126
+ flex-shrink: 0;
127
+ }
128
+
129
+ .header-right {
130
+ display: flex;
131
+ align-items: center;
132
+ gap: 0.75rem;
133
+ }
134
+
135
+ .connection-status {
136
+ display: flex;
137
+ align-items: center;
138
+ gap: 6px;
139
+ font-size: 0.75rem;
140
+ color: var(--text-secondary);
141
+ }
142
+
143
+ .status-dot {
144
+ width: 8px;
145
+ height: 8px;
146
+ border-radius: 50%;
147
+ background: var(--status-pending);
148
+ transition: background var(--transition-normal);
149
+ flex-shrink: 0;
150
+ }
151
+
152
+ .connection-status.connected .status-dot {
153
+ background: var(--status-done);
154
+ box-shadow: 0 0 8px rgba(16, 185, 129, 0.5);
155
+ animation: pulse-dot 2s ease infinite;
156
+ }
157
+
158
+ .connection-status.disconnected .status-dot {
159
+ background: var(--status-failed);
160
+ }
161
+
162
+ @keyframes pulse-dot {
163
+
164
+ 0%,
165
+ 100% {
166
+ opacity: 1;
167
+ }
168
+
169
+ 50% {
170
+ opacity: 0.5;
171
+ }
172
+ }
173
+
174
+ .header-time {
175
+ font-family: var(--font-mono);
176
+ font-size: 0.75rem;
177
+ color: var(--text-muted);
178
+ display: none;
179
+ }
180
+
181
+ /* UX: Fitts's Law — Icon buttons min 44×44 touch target */
182
+ .icon-btn {
183
+ display: inline-flex;
184
+ align-items: center;
185
+ justify-content: center;
186
+ min-width: 44px;
187
+ min-height: 44px;
188
+ border: none;
189
+ background: transparent;
190
+ color: var(--text-secondary);
191
+ border-radius: var(--radius-sm);
192
+ cursor: pointer;
193
+ transition: color var(--transition-fast), background var(--transition-fast);
194
+ -webkit-tap-highlight-color: transparent;
195
+ }
196
+
197
+ .icon-btn:hover {
198
+ color: var(--text-primary);
199
+ background: var(--bg-hover);
200
+ }
201
+
202
+ .icon-btn:focus-visible {
203
+ outline: 2px solid var(--accent-cyan);
204
+ outline-offset: 2px;
205
+ }
206
+
207
+ /* ─── Main ─── */
208
+ .main {
209
+ max-width: 1200px;
210
+ margin: 0 auto;
211
+ padding: 0.75rem;
212
+ display: flex;
213
+ flex-direction: column;
214
+ gap: 0.75rem;
215
+ }
216
+
217
+ /* ─── Status Bar ─── */
218
+ /* UX: Miller's Law — 2×2 grid on mobile (chunk of 4) */
219
+ .status-bar {
220
+ display: grid;
221
+ grid-template-columns: 1fr 1fr;
222
+ gap: 0.5rem;
223
+ }
224
+
225
+ .status-card {
226
+ display: flex;
227
+ align-items: center;
228
+ gap: 0.75rem;
229
+ padding: 0.75rem;
230
+ background: var(--bg-card);
231
+ border-radius: var(--radius-md);
232
+ border: 1px solid var(--border-color);
233
+ transition: border-color var(--transition-normal), box-shadow var(--transition-normal);
234
+ }
235
+
236
+ .status-card:hover {
237
+ border-color: var(--border-accent);
238
+ box-shadow: var(--shadow-sm);
239
+ }
240
+
241
+ .status-icon-wrap {
242
+ display: flex;
243
+ align-items: center;
244
+ justify-content: center;
245
+ width: 36px;
246
+ height: 36px;
247
+ border-radius: var(--radius-sm);
248
+ background: rgba(6, 182, 212, 0.08);
249
+ color: var(--accent-cyan);
250
+ flex-shrink: 0;
251
+ }
252
+
253
+ .status-info {
254
+ display: flex;
255
+ flex-direction: column;
256
+ min-width: 0;
257
+ }
258
+
259
+ .status-label {
260
+ font-size: 0.65rem;
261
+ text-transform: uppercase;
262
+ letter-spacing: 0.05em;
263
+ color: var(--text-muted);
264
+ font-weight: 500;
265
+ }
266
+
267
+ .status-value {
268
+ font-size: 1rem;
269
+ font-weight: 700;
270
+ color: var(--text-primary);
271
+ white-space: nowrap;
272
+ overflow: hidden;
273
+ text-overflow: ellipsis;
274
+ }
275
+
276
+ /* ─── Cards ─── */
277
+ .card {
278
+ background: var(--bg-card);
279
+ border-radius: var(--radius-lg);
280
+ border: 1px solid var(--border-color);
281
+ padding: 1rem;
282
+ }
283
+
284
+ .card-header {
285
+ display: flex;
286
+ align-items: center;
287
+ justify-content: space-between;
288
+ margin-bottom: 0.75rem;
289
+ gap: 0.5rem;
290
+ flex-wrap: wrap;
291
+ }
292
+
293
+ .card-title {
294
+ font-size: 0.9rem;
295
+ font-weight: 600;
296
+ color: var(--text-primary);
297
+ }
298
+
299
+ /* ─── Pipeline Progress ─── */
300
+ .pipeline-section {
301
+ padding: 1rem;
302
+ }
303
+
304
+ .pipeline-scroll-wrap {
305
+ overflow-x: auto;
306
+ -webkit-overflow-scrolling: touch;
307
+ scroll-snap-type: x mandatory;
308
+ margin: 0 -1rem;
309
+ padding: 0.75rem 1rem 0.25rem;
310
+ scrollbar-width: none;
311
+ }
312
+
313
+ .pipeline-scroll-wrap::-webkit-scrollbar {
314
+ display: none;
315
+ }
316
+
317
+ .pipeline-track {
318
+ display: flex;
319
+ align-items: flex-start;
320
+ justify-content: space-between;
321
+ gap: 0;
322
+ min-width: 520px;
323
+ }
324
+
325
+ .phase-node {
326
+ display: flex;
327
+ flex-direction: column;
328
+ align-items: center;
329
+ gap: 0.4rem;
330
+ flex: 0 0 auto;
331
+ width: 72px;
332
+ position: relative;
333
+ scroll-snap-align: center;
334
+ }
335
+
336
+ .phase-circle {
337
+ width: 40px;
338
+ height: 40px;
339
+ border-radius: 50%;
340
+ display: flex;
341
+ align-items: center;
342
+ justify-content: center;
343
+ background: var(--bg-input);
344
+ border: 2px solid var(--status-pending);
345
+ color: var(--text-muted);
346
+ transition: all var(--transition-normal);
347
+ cursor: default;
348
+ }
349
+
350
+ .phase-node[data-status="running"] .phase-circle {
351
+ border-color: var(--status-running);
352
+ color: var(--status-running);
353
+ box-shadow: var(--shadow-glow-cyan);
354
+ animation: pulse-ring 2s ease infinite;
355
+ }
356
+
357
+ .phase-node[data-status="done"] .phase-circle {
358
+ border-color: var(--status-done);
359
+ color: var(--status-done);
360
+ background: rgba(16, 185, 129, 0.1);
361
+ }
362
+
363
+ .phase-node[data-status="failed"] .phase-circle {
364
+ border-color: var(--status-failed);
365
+ color: var(--status-failed);
366
+ background: rgba(239, 68, 68, 0.1);
367
+ }
368
+
369
+ @keyframes pulse-ring {
370
+
371
+ 0%,
372
+ 100% {
373
+ box-shadow: var(--shadow-glow-cyan);
374
+ }
375
+
376
+ 50% {
377
+ box-shadow: 0 0 30px rgba(6, 182, 212, 0.3);
378
+ }
379
+ }
380
+
381
+ .phase-label {
382
+ font-size: 0.7rem;
383
+ font-weight: 500;
384
+ color: var(--text-muted);
385
+ text-align: center;
386
+ }
387
+
388
+ .phase-node[data-status="running"] .phase-label {
389
+ color: var(--status-running);
390
+ }
391
+
392
+ .phase-node[data-status="done"] .phase-label {
393
+ color: var(--status-done);
394
+ }
395
+
396
+ .phase-node[data-status="failed"] .phase-label {
397
+ color: var(--status-failed);
398
+ }
399
+
400
+ .phase-progress {
401
+ width: 100%;
402
+ height: 3px;
403
+ border-radius: 2px;
404
+ background: var(--bg-input);
405
+ overflow: hidden;
406
+ }
407
+
408
+ .phase-progress-fill {
409
+ height: 100%;
410
+ border-radius: 2px;
411
+ background: var(--accent-cyan);
412
+ transition: width 0.5s ease;
413
+ }
414
+
415
+ .phase-node[data-status="done"] .phase-progress-fill {
416
+ background: var(--status-done);
417
+ }
418
+
419
+ .phase-node[data-status="failed"] .phase-progress-fill {
420
+ background: var(--status-failed);
421
+ }
422
+
423
+ .phase-connector {
424
+ flex: 1;
425
+ height: 2px;
426
+ background: var(--border-color);
427
+ margin-top: 20px;
428
+ min-width: 12px;
429
+ }
430
+
431
+ /* ─── Grid ─── */
432
+ .grid-2col {
433
+ display: grid;
434
+ grid-template-columns: 1fr;
435
+ gap: 0.75rem;
436
+ }
437
+
438
+ /* ─── Task List ─── */
439
+ .task-list {
440
+ max-height: 320px;
441
+ overflow-y: auto;
442
+ display: flex;
443
+ flex-direction: column;
444
+ gap: 0.35rem;
445
+ }
446
+
447
+ .task-list::-webkit-scrollbar {
448
+ width: 4px;
449
+ }
450
+
451
+ .task-list::-webkit-scrollbar-track {
452
+ background: transparent;
453
+ }
454
+
455
+ .task-list::-webkit-scrollbar-thumb {
456
+ background: var(--border-accent);
457
+ border-radius: 2px;
458
+ }
459
+
460
+ .task-item {
461
+ display: flex;
462
+ align-items: center;
463
+ gap: 0.6rem;
464
+ padding: 0.5rem 0.6rem;
465
+ border-radius: var(--radius-sm);
466
+ background: var(--bg-input);
467
+ border: 1px solid transparent;
468
+ transition: all var(--transition-fast);
469
+ /* UX: Fitts's Law — min touch target */
470
+ min-height: 44px;
471
+ }
472
+
473
+ .task-item:hover {
474
+ border-color: var(--border-accent);
475
+ }
476
+
477
+ .task-status-dot {
478
+ width: 8px;
479
+ height: 8px;
480
+ border-radius: 50%;
481
+ flex-shrink: 0;
482
+ }
483
+
484
+ .task-status-dot.running {
485
+ background: var(--status-running);
486
+ animation: pulse-dot 1.5s ease infinite;
487
+ }
488
+
489
+ .task-status-dot.queued {
490
+ background: var(--status-pending);
491
+ }
492
+
493
+ .task-status-dot.done {
494
+ background: var(--status-done);
495
+ }
496
+
497
+ .task-status-dot.failed {
498
+ background: var(--status-failed);
499
+ }
500
+
501
+ .task-id {
502
+ font-family: var(--font-mono);
503
+ font-size: 0.75rem;
504
+ color: var(--text-secondary);
505
+ flex: 1;
506
+ overflow: hidden;
507
+ text-overflow: ellipsis;
508
+ white-space: nowrap;
509
+ }
510
+
511
+ .task-time {
512
+ font-family: var(--font-mono);
513
+ font-size: 0.65rem;
514
+ color: var(--text-muted);
515
+ flex-shrink: 0;
516
+ }
517
+
518
+ /* ─── Token Stats ─── */
519
+ .token-stats {
520
+ display: flex;
521
+ flex-direction: column;
522
+ gap: 0.6rem;
523
+ }
524
+
525
+ .token-row {
526
+ display: flex;
527
+ justify-content: space-between;
528
+ align-items: center;
529
+ }
530
+
531
+ .token-label {
532
+ font-size: 0.8rem;
533
+ color: var(--text-secondary);
534
+ }
535
+
536
+ .token-value {
537
+ font-family: var(--font-mono);
538
+ font-size: 0.9rem;
539
+ font-weight: 600;
540
+ }
541
+
542
+ .token-value.accent {
543
+ color: var(--accent-cyan);
544
+ }
545
+
546
+ .budget-bar {
547
+ margin-top: 0.5rem;
548
+ padding-top: 0.6rem;
549
+ border-top: 1px solid var(--border-color);
550
+ }
551
+
552
+ .budget-header {
553
+ display: flex;
554
+ justify-content: space-between;
555
+ font-size: 0.72rem;
556
+ color: var(--text-muted);
557
+ margin-bottom: 0.4rem;
558
+ }
559
+
560
+ .budget-track {
561
+ height: 6px;
562
+ border-radius: 3px;
563
+ background: var(--bg-input);
564
+ overflow: hidden;
565
+ }
566
+
567
+ .budget-fill {
568
+ height: 100%;
569
+ border-radius: 3px;
570
+ background: linear-gradient(90deg, var(--accent-green), var(--accent-cyan));
571
+ transition: width 0.5s ease;
572
+ }
573
+
574
+ .budget-fill.warning {
575
+ background: linear-gradient(90deg, var(--accent-amber), var(--accent-red));
576
+ }
577
+
578
+ .provider-list {
579
+ margin-top: 0.75rem;
580
+ display: flex;
581
+ flex-direction: column;
582
+ gap: 0.35rem;
583
+ }
584
+
585
+ .provider-item {
586
+ display: flex;
587
+ align-items: center;
588
+ justify-content: space-between;
589
+ padding: 0.5rem 0.6rem;
590
+ border-radius: var(--radius-sm);
591
+ background: var(--bg-input);
592
+ font-size: 0.75rem;
593
+ min-height: 40px;
594
+ }
595
+
596
+ .provider-name {
597
+ font-weight: 600;
598
+ color: var(--text-primary);
599
+ }
600
+
601
+ .provider-stats {
602
+ font-family: var(--font-mono);
603
+ color: var(--text-muted);
604
+ font-size: 0.7rem;
605
+ }
606
+
607
+ /* ─── Log Viewer (Collapsible) ─── */
608
+ .log-section {
609
+ /* Reset details/summary default styles */
610
+ }
611
+
612
+ .log-summary {
613
+ cursor: pointer;
614
+ list-style: none;
615
+ user-select: none;
616
+ -webkit-tap-highlight-color: transparent;
617
+ min-height: 44px;
618
+ margin-bottom: 0;
619
+ }
620
+
621
+ .log-summary::-webkit-details-marker {
622
+ display: none;
623
+ }
624
+
625
+ .log-summary::marker {
626
+ display: none;
627
+ content: '';
628
+ }
629
+
630
+ .log-header-right {
631
+ display: flex;
632
+ align-items: center;
633
+ gap: 0.5rem;
634
+ }
635
+
636
+ .log-badge {
637
+ display: inline-flex;
638
+ align-items: center;
639
+ justify-content: center;
640
+ min-width: 20px;
641
+ height: 20px;
642
+ padding: 0 6px;
643
+ border-radius: 999px;
644
+ background: var(--accent-cyan);
645
+ color: var(--bg-primary);
646
+ font-size: 0.65rem;
647
+ font-weight: 700;
648
+ }
649
+
650
+ .chevron-icon {
651
+ transition: transform var(--transition-normal);
652
+ color: var(--text-muted);
653
+ flex-shrink: 0;
654
+ }
655
+
656
+ .log-section[open] .chevron-icon {
657
+ transform: rotate(180deg);
658
+ }
659
+
660
+ .log-section[open] .log-summary {
661
+ margin-bottom: 0.75rem;
662
+ }
663
+
664
+ .log-viewer {
665
+ max-height: 260px;
666
+ overflow-y: auto;
667
+ font-family: var(--font-mono);
668
+ font-size: 0.72rem;
669
+ line-height: 1.7;
670
+ background: var(--bg-input);
671
+ border-radius: var(--radius-sm);
672
+ padding: 0.6rem;
673
+ }
674
+
675
+ .log-viewer::-webkit-scrollbar {
676
+ width: 4px;
677
+ }
678
+
679
+ .log-viewer::-webkit-scrollbar-track {
680
+ background: transparent;
681
+ }
682
+
683
+ .log-viewer::-webkit-scrollbar-thumb {
684
+ background: var(--border-accent);
685
+ border-radius: 2px;
686
+ }
687
+
688
+ .log-entry {
689
+ display: flex;
690
+ gap: 0.4rem;
691
+ padding: 2px 0;
692
+ }
693
+
694
+ .log-time {
695
+ color: var(--text-muted);
696
+ white-space: nowrap;
697
+ }
698
+
699
+ .log-level {
700
+ font-weight: 600;
701
+ width: 36px;
702
+ flex-shrink: 0;
703
+ text-align: center;
704
+ }
705
+
706
+ .log-level.info {
707
+ color: var(--accent-cyan);
708
+ }
709
+
710
+ .log-level.warn {
711
+ color: var(--accent-amber);
712
+ }
713
+
714
+ .log-level.error {
715
+ color: var(--accent-red);
716
+ }
717
+
718
+ .log-msg {
719
+ color: var(--text-secondary);
720
+ word-break: break-word;
721
+ }
722
+
723
+ /* ─── Filters ─── */
724
+ .task-filters,
725
+ .log-filters {
726
+ display: flex;
727
+ gap: 4px;
728
+ flex-wrap: wrap;
729
+ }
730
+
731
+ /* UX: Fitts's Law — min 44px touch target for filter buttons */
732
+ .filter-btn {
733
+ font-family: var(--font-sans);
734
+ font-size: 0.7rem;
735
+ font-weight: 500;
736
+ padding: 6px 12px;
737
+ border: 1px solid var(--border-color);
738
+ border-radius: 999px;
739
+ background: transparent;
740
+ color: var(--text-muted);
741
+ cursor: pointer;
742
+ transition: all var(--transition-fast);
743
+ min-height: 32px;
744
+ -webkit-tap-highlight-color: transparent;
745
+ }
746
+
747
+ .filter-btn:hover {
748
+ border-color: var(--border-accent);
749
+ color: var(--text-secondary);
750
+ }
751
+
752
+ .filter-btn:focus-visible {
753
+ outline: 2px solid var(--accent-cyan);
754
+ outline-offset: 2px;
755
+ }
756
+
757
+ .filter-btn.active {
758
+ background: rgba(6, 182, 212, 0.12);
759
+ border-color: rgba(6, 182, 212, 0.3);
760
+ color: var(--accent-cyan);
761
+ }
762
+
763
+ /* ─── Error Section — Actionable ─── */
764
+ .error-title {
765
+ display: flex;
766
+ align-items: center;
767
+ gap: 0.5rem;
768
+ color: var(--accent-red);
769
+ }
770
+
771
+ .error-list {
772
+ display: flex;
773
+ flex-direction: column;
774
+ gap: 0.5rem;
775
+ }
776
+
777
+ .error-item {
778
+ display: flex;
779
+ flex-direction: column;
780
+ gap: 0.5rem;
781
+ padding: 0.75rem;
782
+ border-radius: var(--radius-md);
783
+ background: rgba(239, 68, 68, 0.06);
784
+ border: 1px solid rgba(239, 68, 68, 0.15);
785
+ }
786
+
787
+ .error-top {
788
+ display: flex;
789
+ align-items: flex-start;
790
+ gap: 0.6rem;
791
+ }
792
+
793
+ .error-icon {
794
+ color: var(--accent-red);
795
+ flex-shrink: 0;
796
+ margin-top: 1px;
797
+ }
798
+
799
+ .error-content {
800
+ flex: 1;
801
+ min-width: 0;
802
+ }
803
+
804
+ .error-source {
805
+ font-size: 0.7rem;
806
+ font-weight: 600;
807
+ color: var(--accent-red);
808
+ text-transform: uppercase;
809
+ letter-spacing: 0.03em;
810
+ }
811
+
812
+ .error-message {
813
+ font-size: 0.8rem;
814
+ color: var(--text-secondary);
815
+ margin-top: 2px;
816
+ word-break: break-word;
817
+ }
818
+
819
+ .error-time {
820
+ font-family: var(--font-mono);
821
+ font-size: 0.65rem;
822
+ color: var(--text-muted);
823
+ flex-shrink: 0;
824
+ white-space: nowrap;
825
+ }
826
+
827
+ /* UX: Poka-Yoke — Actionable error buttons */
828
+ .error-actions {
829
+ display: flex;
830
+ gap: 0.4rem;
831
+ flex-wrap: wrap;
832
+ padding-left: 1.75rem;
833
+ }
834
+
835
+ .error-action-btn {
836
+ font-family: var(--font-sans);
837
+ font-size: 0.7rem;
838
+ font-weight: 500;
839
+ padding: 4px 12px;
840
+ border-radius: 999px;
841
+ cursor: pointer;
842
+ transition: all var(--transition-fast);
843
+ min-height: 32px;
844
+ display: inline-flex;
845
+ align-items: center;
846
+ gap: 4px;
847
+ -webkit-tap-highlight-color: transparent;
848
+ }
849
+
850
+ .error-action-btn.primary {
851
+ background: rgba(6, 182, 212, 0.12);
852
+ border: 1px solid rgba(6, 182, 212, 0.3);
853
+ color: var(--accent-cyan);
854
+ }
855
+
856
+ .error-action-btn.primary:hover {
857
+ background: rgba(6, 182, 212, 0.2);
858
+ border-color: var(--accent-cyan);
859
+ }
860
+
861
+ .error-action-btn.secondary {
862
+ background: transparent;
863
+ border: 1px solid var(--border-accent);
864
+ color: var(--text-secondary);
865
+ }
866
+
867
+ .error-action-btn.secondary:hover {
868
+ border-color: var(--text-muted);
869
+ color: var(--text-primary);
870
+ }
871
+
872
+ .error-action-btn:focus-visible {
873
+ outline: 2px solid var(--accent-cyan);
874
+ outline-offset: 2px;
875
+ }
876
+
877
+ /* ─── Settings Dialog ─── */
878
+ /* UX: Fitts's Law — Bottom-sheet on mobile (thumb zone) */
879
+ .settings-dialog {
880
+ position: fixed;
881
+ border: none;
882
+ background: var(--bg-card);
883
+ color: var(--text-primary);
884
+ border-radius: var(--radius-lg) var(--radius-lg) 0 0;
885
+ padding: 0;
886
+ width: 100%;
887
+ max-width: 100%;
888
+ max-height: 85dvh;
889
+ bottom: 0;
890
+ left: 0;
891
+ right: 0;
892
+ margin: 0;
893
+ overflow-y: auto;
894
+ box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.6);
895
+ animation: slide-up var(--transition-normal) ease;
896
+ }
897
+
898
+ .settings-dialog::backdrop {
899
+ background: rgba(0, 0, 0, 0.6);
900
+ backdrop-filter: blur(4px);
901
+ }
902
+
903
+ @keyframes slide-up {
904
+ from {
905
+ transform: translateY(100%);
906
+ }
907
+
908
+ to {
909
+ transform: translateY(0);
910
+ }
911
+ }
912
+
913
+ .dialog-header {
914
+ display: flex;
915
+ align-items: center;
916
+ justify-content: space-between;
917
+ padding: 1rem 1.25rem;
918
+ border-bottom: 1px solid var(--border-color);
919
+ position: sticky;
920
+ top: 0;
921
+ background: var(--bg-card);
922
+ z-index: 1;
923
+ }
924
+
925
+ .dialog-title {
926
+ font-size: 1rem;
927
+ font-weight: 700;
928
+ }
929
+
930
+ .dialog-close {
931
+ color: var(--text-muted);
932
+ }
933
+
934
+ .dialog-body {
935
+ padding: 1.25rem;
936
+ display: flex;
937
+ flex-direction: column;
938
+ gap: 1.25rem;
939
+ }
940
+
941
+ .settings-group {
942
+ display: flex;
943
+ flex-direction: column;
944
+ gap: 0.4rem;
945
+ }
946
+
947
+ .settings-label {
948
+ display: flex;
949
+ align-items: center;
950
+ gap: 0.5rem;
951
+ font-size: 0.78rem;
952
+ font-weight: 500;
953
+ color: var(--text-secondary);
954
+ }
955
+
956
+ .settings-label svg {
957
+ color: var(--accent-cyan);
958
+ flex-shrink: 0;
959
+ }
960
+
961
+ .settings-select,
962
+ .settings-input {
963
+ font-family: var(--font-sans);
964
+ font-size: 0.85rem;
965
+ padding: 0.6rem 0.75rem;
966
+ background: var(--bg-input);
967
+ border: 1px solid var(--border-color);
968
+ border-radius: var(--radius-sm);
969
+ color: var(--text-primary);
970
+ min-height: 44px;
971
+ transition: border-color var(--transition-fast);
972
+ width: 100%;
973
+ }
974
+
975
+ .settings-select:focus,
976
+ .settings-input:focus {
977
+ outline: none;
978
+ border-color: var(--accent-cyan);
979
+ box-shadow: 0 0 0 2px rgba(6, 182, 212, 0.15);
980
+ }
981
+
982
+ .settings-select option {
983
+ background: var(--bg-card);
984
+ color: var(--text-primary);
985
+ }
986
+
987
+ .settings-input-group {
988
+ display: flex;
989
+ gap: 0;
990
+ align-items: stretch;
991
+ }
992
+
993
+ .settings-input-group .settings-input {
994
+ border-radius: var(--radius-sm) 0 0 var(--radius-sm);
995
+ border-right: none;
996
+ }
997
+
998
+ .settings-input-group .icon-btn {
999
+ border: 1px solid var(--border-color);
1000
+ border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
1001
+ background: var(--bg-input);
1002
+ min-width: 44px;
1003
+ }
1004
+
1005
+ .dialog-footer {
1006
+ display: flex;
1007
+ gap: 0.5rem;
1008
+ padding: 1rem 1.25rem;
1009
+ border-top: 1px solid var(--border-color);
1010
+ position: sticky;
1011
+ bottom: 0;
1012
+ background: var(--bg-card);
1013
+ }
1014
+
1015
+ /* Buttons */
1016
+ .btn {
1017
+ font-family: var(--font-sans);
1018
+ font-size: 0.85rem;
1019
+ font-weight: 600;
1020
+ padding: 0.6rem 1.25rem;
1021
+ border-radius: var(--radius-sm);
1022
+ cursor: pointer;
1023
+ transition: all var(--transition-fast);
1024
+ min-height: 44px;
1025
+ border: none;
1026
+ flex: 1;
1027
+ -webkit-tap-highlight-color: transparent;
1028
+ }
1029
+
1030
+ .btn:focus-visible {
1031
+ outline: 2px solid var(--accent-cyan);
1032
+ outline-offset: 2px;
1033
+ }
1034
+
1035
+ .btn-primary {
1036
+ background: var(--accent-cyan);
1037
+ color: var(--bg-primary);
1038
+ }
1039
+
1040
+ .btn-primary:hover {
1041
+ background: #08c4e0;
1042
+ }
1043
+
1044
+ .btn-secondary {
1045
+ background: transparent;
1046
+ border: 1px solid var(--border-accent);
1047
+ color: var(--text-secondary);
1048
+ }
1049
+
1050
+ .btn-secondary:hover {
1051
+ border-color: var(--text-muted);
1052
+ color: var(--text-primary);
1053
+ }
1054
+
1055
+ /* ─── Empty State ─── */
1056
+ .empty-state {
1057
+ display: flex;
1058
+ flex-direction: column;
1059
+ align-items: center;
1060
+ justify-content: center;
1061
+ padding: 1.5rem;
1062
+ color: var(--text-muted);
1063
+ text-align: center;
1064
+ gap: 0.5rem;
1065
+ }
1066
+
1067
+ .empty-state p {
1068
+ font-size: 0.8rem;
1069
+ }
1070
+
1071
+ /* ─── Footer ─── */
1072
+ .footer {
1073
+ display: flex;
1074
+ justify-content: space-between;
1075
+ align-items: center;
1076
+ padding: 0.6rem 1rem;
1077
+ font-size: 0.7rem;
1078
+ color: var(--text-muted);
1079
+ border-top: 1px solid var(--border-color);
1080
+ margin-top: 0.5rem;
1081
+ }
1082
+
1083
+ /* ─── Skeleton Loader ─── */
1084
+ /* UX: Doherty Threshold — Perceived performance */
1085
+ .skeleton {
1086
+ background: linear-gradient(90deg, var(--bg-input) 25%, var(--bg-hover) 50%, var(--bg-input) 75%);
1087
+ background-size: 200% 100%;
1088
+ animation: shimmer 1.5s ease-in-out infinite;
1089
+ border-radius: var(--radius-sm);
1090
+ }
1091
+
1092
+ @keyframes shimmer {
1093
+ 0% {
1094
+ background-position: 200% 0;
1095
+ }
1096
+
1097
+ 100% {
1098
+ background-position: -200% 0;
1099
+ }
1100
+ }
1101
+
1102
+ /* ─── Responsive: Tablet (≥640px) ─── */
1103
+ @media (min-width: 640px) {
1104
+ .header-time {
1105
+ display: block;
1106
+ }
1107
+
1108
+ .main {
1109
+ padding: 1rem;
1110
+ gap: 1rem;
1111
+ }
1112
+
1113
+ .status-bar {
1114
+ grid-template-columns: repeat(4, 1fr);
1115
+ gap: 0.75rem;
1116
+ }
1117
+
1118
+ .status-card {
1119
+ padding: 1rem;
1120
+ }
1121
+
1122
+ .grid-2col {
1123
+ grid-template-columns: 1fr 1fr;
1124
+ }
1125
+
1126
+ .filter-btn {
1127
+ min-height: 28px;
1128
+ padding: 4px 10px;
1129
+ }
1130
+
1131
+ .log-viewer {
1132
+ max-height: 300px;
1133
+ }
1134
+ }
1135
+
1136
+ /* ─── Responsive: Desktop (≥1024px) ─── */
1137
+ @media (min-width: 1024px) {
1138
+ .header {
1139
+ padding: 0.75rem 1.5rem;
1140
+ }
1141
+
1142
+ .main {
1143
+ padding: 1.25rem;
1144
+ gap: 1.25rem;
1145
+ }
1146
+
1147
+ .status-card {
1148
+ padding: 1rem 1.25rem;
1149
+ }
1150
+
1151
+ .status-icon-wrap {
1152
+ width: 40px;
1153
+ height: 40px;
1154
+ }
1155
+
1156
+ .status-value {
1157
+ font-size: 1.15rem;
1158
+ }
1159
+
1160
+ .pipeline-track {
1161
+ min-width: auto;
1162
+ }
1163
+
1164
+ .phase-node {
1165
+ width: 80px;
1166
+ }
1167
+
1168
+ .phase-circle {
1169
+ width: 44px;
1170
+ height: 44px;
1171
+ }
1172
+
1173
+ /* Desktop: Settings dialog as centered modal */
1174
+ .settings-dialog {
1175
+ position: fixed;
1176
+ top: 50%;
1177
+ left: 50%;
1178
+ bottom: auto;
1179
+ right: auto;
1180
+ transform: translate(-50%, -50%);
1181
+ border-radius: var(--radius-lg);
1182
+ max-width: 480px;
1183
+ max-height: 80vh;
1184
+ animation: fade-scale-in var(--transition-normal) ease;
1185
+ }
1186
+
1187
+ @keyframes fade-scale-in {
1188
+ from {
1189
+ opacity: 0;
1190
+ transform: translate(-50%, -50%) scale(0.95);
1191
+ }
1192
+
1193
+ to {
1194
+ opacity: 1;
1195
+ transform: translate(-50%, -50%) scale(1);
1196
+ }
1197
+ }
1198
+ }
1199
+
1200
+ /* ─── Reduced Motion ─── */
1201
+ /* UX: A11y — Respect prefers-reduced-motion */
1202
+ @media (prefers-reduced-motion: reduce) {
1203
+
1204
+ *,
1205
+ *::before,
1206
+ *::after {
1207
+ animation-duration: 0.01ms !important;
1208
+ animation-iteration-count: 1 !important;
1209
+ transition-duration: 0.01ms !important;
1210
+ }
1211
+ }