bmad-plus 0.7.5 → 0.9.0

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 (281) hide show
  1. package/CHANGELOG.md +479 -425
  2. package/LICENSE +21 -21
  3. package/README.md +557 -447
  4. package/osint-agent-package/README.md +88 -88
  5. package/osint-agent-package/SETUP_KEYS.md +108 -108
  6. package/osint-agent-package/agents/osint-investigator.md +80 -80
  7. package/osint-agent-package/install.ps1 +87 -87
  8. package/osint-agent-package/install.sh +76 -76
  9. package/osint-agent-package/skills/bmad-osint-investigate/SKILL.md +147 -147
  10. package/osint-agent-package/skills/bmad-osint-investigate/osint/SKILL.md +452 -452
  11. package/osint-agent-package/skills/bmad-osint-investigate/osint/assets/dossier-template.md +116 -116
  12. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/content-extraction.md +100 -100
  13. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/enrichment-databases-fr.md +148 -148
  14. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/platforms.md +130 -130
  15. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/psychoprofile.md +69 -69
  16. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/tools.md +281 -281
  17. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/_http.py +101 -101
  18. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/apify.py +266 -260
  19. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/brightdata.py +101 -101
  20. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/diagnose.py +141 -141
  21. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/exa.py +79 -79
  22. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/jina.py +71 -71
  23. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/mcp-client.py +136 -136
  24. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/parallel.py +85 -85
  25. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/perplexity.py +102 -102
  26. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/tavily.py +72 -72
  27. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/volley.py +208 -208
  28. package/osint-agent-package/skills/bmad-osint-investigator/SKILL.md +15 -15
  29. package/package.json +62 -57
  30. package/readme-international/README.de.md +584 -426
  31. package/readme-international/README.es.md +601 -518
  32. package/readme-international/README.fr.md +599 -516
  33. package/src/bmad-plus/agents/agent-architect-dev/SKILL.md +96 -96
  34. package/src/bmad-plus/agents/agent-architect-dev/bmad-skill-manifest.yaml +13 -13
  35. package/src/bmad-plus/agents/agent-maker/SKILL.md +201 -201
  36. package/src/bmad-plus/agents/agent-maker/bmad-skill-manifest.yaml +13 -13
  37. package/src/bmad-plus/agents/agent-orchestrator/SKILL.md +137 -137
  38. package/src/bmad-plus/agents/agent-orchestrator/bmad-skill-manifest.yaml +13 -13
  39. package/src/bmad-plus/agents/agent-quality/SKILL.md +83 -83
  40. package/src/bmad-plus/agents/agent-quality/bmad-skill-manifest.yaml +13 -13
  41. package/src/bmad-plus/agents/agent-shadow/SKILL.md +71 -71
  42. package/src/bmad-plus/agents/agent-shadow/bmad-skill-manifest.yaml +13 -13
  43. package/src/bmad-plus/agents/agent-strategist/SKILL.md +80 -80
  44. package/src/bmad-plus/agents/agent-strategist/bmad-skill-manifest.yaml +13 -13
  45. package/src/bmad-plus/data/role-triggers.yaml +209 -209
  46. package/src/bmad-plus/module-help.csv +10 -10
  47. package/src/bmad-plus/module.yaml +283 -280
  48. package/src/bmad-plus/{agents → packs}/pack-animated/animated-website-agent.md +325 -325
  49. package/src/bmad-plus/{agents → packs}/pack-animated/templates/animated-website-workflow.md +55 -55
  50. package/src/bmad-plus/{agents → packs}/pack-backup/backup-agent.md +71 -71
  51. package/src/bmad-plus/{agents → packs}/pack-backup/templates/backup-workflow.md +51 -51
  52. package/src/bmad-plus/packs/pack-dev-studio/README.md +162 -162
  53. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/analyst-agent.md +73 -73
  54. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/document-project.md +61 -61
  55. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/domain-research.md +95 -95
  56. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/market-research.md +95 -95
  57. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/prfaq.md +134 -134
  58. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/product-brief.md +80 -80
  59. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/tech-writer-agent.md +73 -73
  60. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/technical-research.md +95 -95
  61. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/architect-agent.md +73 -73
  62. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/create-architecture.md +73 -73
  63. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/create-epics-stories.md +92 -92
  64. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/generate-project-context.md +80 -80
  65. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/implementation-readiness.md +90 -90
  66. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-01-init.md +153 -153
  67. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-01b-continue.md +173 -173
  68. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-02-context.md +224 -224
  69. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-03-starter.md +329 -329
  70. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-04-decisions.md +318 -318
  71. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-05-patterns.md +359 -359
  72. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-06-structure.md +379 -379
  73. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-07-validation.md +361 -361
  74. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-08-complete.md +81 -81
  75. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/checkpoint-preview.md +67 -67
  76. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-01-gather-context.md +85 -85
  77. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-02-review.md +35 -35
  78. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-03-triage.md +49 -49
  79. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-04-present.md +131 -131
  80. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review.md +89 -89
  81. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/correct-course.md +300 -300
  82. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/create-story.md +428 -428
  83. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-agent.md +73 -73
  84. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-story-checklist.md +80 -80
  85. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-story.md +484 -484
  86. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/investigate.md +193 -193
  87. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/qa-e2e-tests.md +175 -175
  88. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/quick-dev.md +110 -110
  89. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/retrospective.md +1511 -1511
  90. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/sprint-planning.md +298 -298
  91. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/sprint-status.md +296 -296
  92. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/create-prd.md +29 -29
  93. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/create-ux-design.md +74 -74
  94. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/edit-prd.md +29 -29
  95. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/pm-agent.md +73 -73
  96. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/prd.md +89 -89
  97. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/ux-designer-agent.md +73 -73
  98. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/validate-prd.md +29 -29
  99. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/advanced-elicitation.md +141 -141
  100. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/adversarial-review.md +37 -37
  101. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/bmad-help.md +75 -75
  102. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/brainstorming.md +6 -6
  103. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/customize.md +110 -110
  104. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/distillator.md +176 -176
  105. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/edge-case-hunter.md +67 -67
  106. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/editorial-review-prose.md +86 -86
  107. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/editorial-review-structure.md +179 -179
  108. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/index-docs.md +66 -66
  109. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/party-mode.md +127 -127
  110. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/shard-doc.md +105 -105
  111. package/src/bmad-plus/packs/pack-dev-studio/dev-studio-orchestrator.md +120 -120
  112. package/src/bmad-plus/packs/pack-dev-studio/shared/architecture-decision-template.md +12 -12
  113. package/src/bmad-plus/packs/pack-dev-studio/shared/bwml-spec.md +328 -328
  114. package/src/bmad-plus/packs/pack-dev-studio/shared/module-help.csv +32 -32
  115. package/src/bmad-plus/packs/pack-dev-studio/upstream-sync.yaml +81 -81
  116. package/src/bmad-plus/packs/pack-memory/README.md +106 -106
  117. package/src/bmad-plus/packs/pack-memory/memory-orchestrator.md +79 -79
  118. package/src/bmad-plus/packs/pack-memory/shared/karpathy-guardrails.md +86 -86
  119. package/src/bmad-plus/packs/pack-memory/shared/memory-protocol.md +143 -143
  120. package/src/bmad-plus/packs/pack-memory/templates/context.md +39 -39
  121. package/src/bmad-plus/packs/pack-memory/templates/decisions.md +25 -25
  122. package/src/bmad-plus/packs/pack-memory/templates/identity.yaml +39 -39
  123. package/src/bmad-plus/packs/pack-memory/templates/lessons.md +31 -31
  124. package/src/bmad-plus/packs/pack-memory/templates/patterns.md +24 -24
  125. package/src/bmad-plus/packs/pack-memory/templates/session-handoff.md +25 -25
  126. package/src/bmad-plus/packs/pack-memory/zecher-agent.md +157 -157
  127. package/src/bmad-plus/{agents → packs}/pack-seo/SKILL.md +171 -171
  128. package/src/bmad-plus/packs/pack-seo/bmad-skill-manifest.yaml +13 -0
  129. package/src/bmad-plus/{agents → packs}/pack-seo/checklist.md +140 -140
  130. package/src/bmad-plus/{agents → packs}/pack-seo/pagespeed-playbook.md +320 -320
  131. package/src/bmad-plus/{agents → packs}/pack-seo/ref/audit-schema.json +187 -187
  132. package/src/bmad-plus/{agents → packs}/pack-seo/ref/cwv-thresholds.md +87 -87
  133. package/src/bmad-plus/{agents → packs}/pack-seo/ref/eeat-criteria.md +123 -123
  134. package/src/bmad-plus/{agents → packs}/pack-seo/ref/geo-signals.md +167 -167
  135. package/src/bmad-plus/{agents → packs}/pack-seo/ref/hreflang-rules.md +153 -153
  136. package/src/bmad-plus/{agents → packs}/pack-seo/ref/quality-gates.md +133 -133
  137. package/src/bmad-plus/{agents → packs}/pack-seo/ref/schema-catalog.md +91 -91
  138. package/src/bmad-plus/{agents → packs}/pack-seo/ref/schema-templates.json +356 -356
  139. package/src/bmad-plus/{agents → packs}/pack-seo/seo-chief.md +294 -294
  140. package/src/bmad-plus/{agents → packs}/pack-seo/seo-judge.md +241 -241
  141. package/src/bmad-plus/{agents → packs}/pack-seo/seo-scout.md +171 -171
  142. package/src/bmad-plus/{agents → packs}/pack-seo/templates/seo-audit-workflow.md +241 -241
  143. package/src/bmad-plus/packs/pack-shield/README.md +110 -110
  144. package/src/bmad-plus/packs/pack-shield/SKILL.md +82 -0
  145. package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/csrd-agent.md +262 -262
  146. package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/section508-agent.md +179 -179
  147. package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/wcag-agent.md +201 -201
  148. package/src/bmad-plus/packs/pack-shield/categories/ai-governance/eu-ai-act-agent.md +97 -97
  149. package/src/bmad-plus/packs/pack-shield/categories/ai-governance/iso42001-agent.md +251 -251
  150. package/src/bmad-plus/packs/pack-shield/categories/ai-governance/nist-ai-rmf-agent.md +133 -133
  151. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/cis-controls-agent.md +221 -221
  152. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/ism-agent.md +150 -150
  153. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/iso27001-agent.md +167 -167
  154. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nis2-agent.md +83 -83
  155. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-800-53-agent.md +250 -250
  156. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-csf-agent.md +218 -218
  157. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/ccpa-agent.md +94 -94
  158. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/dpdpa-agent.md +136 -136
  159. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/gdpr-agent.md +296 -296
  160. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/iso27701-agent.md +134 -134
  161. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/lgpd-agent.md +129 -129
  162. package/src/bmad-plus/packs/pack-shield/categories/defense-export/cmmc-agent.md +127 -127
  163. package/src/bmad-plus/packs/pack-shield/categories/defense-export/ear-agent.md +272 -272
  164. package/src/bmad-plus/packs/pack-shield/categories/defense-export/itar-agent.md +202 -202
  165. package/src/bmad-plus/packs/pack-shield/categories/defense-export/tsa-agent.md +367 -367
  166. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/dora-agent.md +510 -510
  167. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/fedramp-agent.md +247 -247
  168. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/hipaa-agent.md +173 -173
  169. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/pci-dss-agent.md +239 -239
  170. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/soc2-agent.md +266 -266
  171. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/swift-csp-agent.md +164 -164
  172. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-classifier.md +131 -131
  173. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-fria.md +155 -155
  174. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-incidents.md +187 -187
  175. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-roles.md +113 -113
  176. package/src/bmad-plus/packs/pack-shield/categories/workflows/breach-sentinel.md +197 -197
  177. package/src/bmad-plus/packs/pack-shield/categories/workflows/cookie-policy-gen.md +180 -180
  178. package/src/bmad-plus/packs/pack-shield/categories/workflows/dpia-sentinel.md +235 -235
  179. package/src/bmad-plus/packs/pack-shield/categories/workflows/legitimate-interest.md +159 -159
  180. package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-advisor.md +133 -133
  181. package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-notice-gen.md +160 -160
  182. package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-policy-gen.md +135 -135
  183. package/src/bmad-plus/packs/pack-shield/references/ccpa/ccpa-gdpr-comparison.md +117 -117
  184. package/src/bmad-plus/packs/pack-shield/references/ccpa/consumer-rights-workflows.md +177 -177
  185. package/src/bmad-plus/packs/pack-shield/references/cis-controls/framework-mappings.md +162 -162
  186. package/src/bmad-plus/packs/pack-shield/references/cis-controls/implementation-guidance.md +235 -235
  187. package/src/bmad-plus/packs/pack-shield/references/cis-controls/safeguards-detail.md +252 -252
  188. package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-assessment.md +170 -170
  189. package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-levels.md +113 -113
  190. package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-practices.md +211 -211
  191. package/src/bmad-plus/packs/pack-shield/references/csrd/compliance-program.md +281 -281
  192. package/src/bmad-plus/packs/pack-shield/references/csrd/double-materiality.md +253 -253
  193. package/src/bmad-plus/packs/pack-shield/references/csrd/esrs-standards.md +401 -401
  194. package/src/bmad-plus/packs/pack-shield/references/dora/article-reference.md +441 -441
  195. package/src/bmad-plus/packs/pack-shield/references/dora/incident-classification.md +297 -297
  196. package/src/bmad-plus/packs/pack-shield/references/dora/rts-its-guide.md +306 -306
  197. package/src/bmad-plus/packs/pack-shield/references/dora/third-party-risk.md +349 -349
  198. package/src/bmad-plus/packs/pack-shield/references/dpdpa/gdpr-comparison.md +173 -173
  199. package/src/bmad-plus/packs/pack-shield/references/dpdpa/rights-and-obligations.md +426 -426
  200. package/src/bmad-plus/packs/pack-shield/references/dpdpa/rules-2025.md +599 -599
  201. package/src/bmad-plus/packs/pack-shield/references/dpdpa/sections-reference.md +319 -319
  202. package/src/bmad-plus/packs/pack-shield/references/ear/ccl-eccn-guide.md +250 -250
  203. package/src/bmad-plus/packs/pack-shield/references/ear/compliance-program.md +280 -280
  204. package/src/bmad-plus/packs/pack-shield/references/ear/license-exceptions.md +207 -207
  205. package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/gpai-governance.md +267 -267
  206. package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/obligations-high-risk.md +287 -287
  207. package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/risk-classification.md +182 -182
  208. package/src/bmad-plus/packs/pack-shield/references/fedramp/appendices-guide.md +209 -209
  209. package/src/bmad-plus/packs/pack-shield/references/fedramp/control-families.md +281 -281
  210. package/src/bmad-plus/packs/pack-shield/references/fedramp/poam-guide.md +93 -93
  211. package/src/bmad-plus/packs/pack-shield/references/fedramp/readiness-checklist.md +134 -134
  212. package/src/bmad-plus/packs/pack-shield/references/fedramp/sap-sar-guide.md +86 -86
  213. package/src/bmad-plus/packs/pack-shield/references/fedramp/ssp-guide.md +129 -129
  214. package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/documents.md +192 -192
  215. package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/dpa-template.md +121 -121
  216. package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/privacy-notice.md +87 -87
  217. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/breach-notification.md +293 -293
  218. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/privacy-rule.md +276 -276
  219. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/security-rule.md +299 -299
  220. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/templates.md +568 -568
  221. package/src/bmad-plus/packs/pack-shield/references/ism/control-applicability.md +181 -181
  222. package/src/bmad-plus/packs/pack-shield/references/ism/guidelines-overview.md +183 -183
  223. package/src/bmad-plus/packs/pack-shield/references/iso27001/annex-a-2013.md +203 -203
  224. package/src/bmad-plus/packs/pack-shield/references/iso27001/annex-a-2022.md +132 -132
  225. package/src/bmad-plus/packs/pack-shield/references/iso27001/control-mapping.md +153 -153
  226. package/src/bmad-plus/packs/pack-shield/references/iso27701/annex-a-controls.md +195 -195
  227. package/src/bmad-plus/packs/pack-shield/references/iso27701/regulatory-mapping.md +229 -229
  228. package/src/bmad-plus/packs/pack-shield/references/iso27701/transition-guide.md +219 -219
  229. package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-ai-risk-assessment.md +258 -258
  230. package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-clauses-requirements.md +279 -279
  231. package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-controls-annex-a.md +155 -155
  232. package/src/bmad-plus/packs/pack-shield/references/itar/compliance-program.md +174 -174
  233. package/src/bmad-plus/packs/pack-shield/references/itar/licensing-guide.md +146 -146
  234. package/src/bmad-plus/packs/pack-shield/references/itar/usml-categories.md +93 -93
  235. package/src/bmad-plus/packs/pack-shield/references/lgpd/anpd-enforcement.md +147 -147
  236. package/src/bmad-plus/packs/pack-shield/references/lgpd/compliance-program.md +272 -272
  237. package/src/bmad-plus/packs/pack-shield/references/lgpd/lgpd-articles.md +271 -271
  238. package/src/bmad-plus/packs/pack-shield/references/nis2/article-21-measures.md +153 -153
  239. package/src/bmad-plus/packs/pack-shield/references/nis2/iso27001-nis2-mapping.md +68 -68
  240. package/src/bmad-plus/packs/pack-shield/references/nist-800-53/assessment-rmf.md +349 -349
  241. package/src/bmad-plus/packs/pack-shield/references/nist-800-53/baselines-tailoring.md +277 -277
  242. package/src/bmad-plus/packs/pack-shield/references/nist-800-53/control-families.md +450 -450
  243. package/src/bmad-plus/packs/pack-shield/references/nist-ai-rmf/rmf-core.md +361 -361
  244. package/src/bmad-plus/packs/pack-shield/references/nist-ai-rmf/rmf-profiles.md +192 -192
  245. package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-10-to-20-mapping.md +143 -143
  246. package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-20-functions-categories.md +278 -278
  247. package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-implementation-tiers.md +135 -135
  248. package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-requirements.md +366 -366
  249. package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-saq-guide.md +217 -217
  250. package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-v4-changes.md +190 -190
  251. package/src/bmad-plus/packs/pack-shield/references/section-508/wcag-mapping.md +160 -160
  252. package/src/bmad-plus/packs/pack-shield/references/soc2/controls.md +241 -241
  253. package/src/bmad-plus/packs/pack-shield/references/soc2/evidence.md +236 -236
  254. package/src/bmad-plus/packs/pack-shield/references/soc2/policies.md +254 -254
  255. package/src/bmad-plus/packs/pack-shield/references/soc2/vendor.md +276 -276
  256. package/src/bmad-plus/packs/pack-shield/references/swift-csp/swift-assessment.md +202 -202
  257. package/src/bmad-plus/packs/pack-shield/references/swift-csp/swift-controls.md +545 -545
  258. package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-crmp-requirements.md +359 -359
  259. package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-directives-overview.md +187 -187
  260. package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-incident-reporting.md +187 -187
  261. package/src/bmad-plus/packs/pack-shield/references/wcag/criteria-detail.md +510 -510
  262. package/src/bmad-plus/packs/pack-shield/shared/audit-report-template.md +103 -103
  263. package/src/bmad-plus/packs/pack-shield/shared/cross-framework-mapper.md +103 -103
  264. package/src/bmad-plus/packs/pack-shield/shared/gap-analysis-template.md +83 -83
  265. package/src/bmad-plus/packs/pack-shield/shield-orchestrator.md +229 -229
  266. package/src/bmad-plus/packs/pack-shield/upstream-sync.yaml +68 -68
  267. package/src/bmad-plus/skills/bmad-plus-autopilot/SKILL.md +99 -99
  268. package/src/bmad-plus/skills/bmad-plus-parallel/SKILL.md +93 -93
  269. package/src/bmad-plus/skills/bmad-plus-sync/SKILL.md +69 -69
  270. package/tools/bmad-plus-npx.js +3 -5
  271. package/tools/cli/commands/autoconfig.js +508 -489
  272. package/tools/cli/commands/doctor.js +219 -222
  273. package/tools/cli/commands/install.js +548 -739
  274. package/tools/cli/commands/memory.js +194 -194
  275. package/tools/cli/commands/scan.js +362 -350
  276. package/tools/cli/commands/uninstall.js +96 -96
  277. package/tools/cli/commands/update.js +116 -174
  278. package/tools/cli/i18n.js +845 -763
  279. package/tools/cli/lib/memory-init.js +114 -0
  280. package/tools/cli/lib/pack-copy.js +84 -0
  281. package/tools/cli/lib/packs.js +114 -0
@@ -1,325 +1,325 @@
1
- # Agent: Animated Website Creator
2
-
3
- ## Persona
4
- Tu es un expert en création de sites web animés de luxe. Tu convertis des vidéos MP4 en expériences web interactives avec animation au scroll, style pages produit Apple. Tu maîtrises FFmpeg, les animations CSS/JS, le canvas HTML5, et le design cinématique haut de gamme.
5
-
6
- ## Activation
7
- Déclenché par les requêtes contenant : "animated website", "scroll animation", "video to website", "Apple-style page", "scroll-driven site", "frame animation", "convert video to website", "luxury website from video", "site animé", "animation scroll".
8
-
9
- ## Pré-requis
10
- - FFmpeg + FFprobe installés
11
- - Python 3
12
- - Fichier vidéo MP4 source
13
-
14
- ---
15
-
16
- ## Processus Complet
17
-
18
- ### Étape 1 — Analyser la vidéo
19
-
20
- ```bash
21
- ffprobe -v quiet -print_format json -show_format -show_streams "/path/to/video.mp4"
22
- ```
23
-
24
- Présenter au client :
25
- ```
26
- VIDEO ANALYSIS:
27
- Duration: 12.4s
28
- Resolution: 3840x2160
29
- Frame Rate: 30fps
30
- Total Frames: 372
31
- Codec: H.264
32
- ```
33
-
34
- Recommander le nombre de frames :
35
-
36
- | Durée vidéo | Frames recommandées | Scroll Height |
37
- |------------|-------------------|---------------|
38
- | 0-5s | 60-90 | 400vh |
39
- | 5-15s | 100-150 | 650vh |
40
- | 15-30s | 150-200 | 800vh |
41
- | 30s+ | Cap à 200 | 900vh |
42
-
43
- **Confirmer avec l'utilisateur avant extraction.**
44
-
45
- ### Étape 2 — Extraire et optimiser les frames
46
-
47
- Utiliser le script `extract_frames.py` :
48
-
49
- **Windows :**
50
- ```powershell
51
- python scripts/extract_frames.py --input "C:/path/to/video.mp4" --output "output/frames" --frames 120 --quality 80
52
- ```
53
-
54
- **Mac/Linux :**
55
- ```bash
56
- python3 scripts/extract_frames.py --input "/path/to/video.mp4" --output "output/frames" --frames 120 --quality 80
57
- ```
58
-
59
- Le script produit :
60
- - `frames/desktop/` — WebP 1920x1080
61
- - `frames/mobile/` — WebP 960x540
62
- - `frames/manifest.json` — métadonnées
63
-
64
- **Budget payload :** Desktop < 10MB, Mobile < 5MB.
65
-
66
- ### Étape 3 — Contenu des 6 sections
67
-
68
- Préparer le contenu pour les 6 overlay sections :
69
-
70
- 1. **Hero** — Nom du produit/marque, tagline, stats clés (glass stat bar)
71
- 2. **Vision** — Citation inspirante, guillemet décoratif, attribution
72
- 3. **Details** — Caractéristiques techniques, liste avec icônes
73
- 4. **Grid** — 4-6 features en grille glass morphism
74
- 5. **Context** — Contexte, localisation, informations secondaires
75
- 6. **CTA** — Call to action, boutons, contact
76
-
77
- ### Étape 4 — Construire le site
78
-
79
- Générer un fichier HTML unique avec tout le design system intégré.
80
-
81
- ### Étape 5 — Servir et prévisualiser
82
-
83
- ```bash
84
- python3 -m http.server 8080
85
- ```
86
-
87
- ---
88
-
89
- ## Design System
90
-
91
- ### Palette de couleurs
92
-
93
- ```css
94
- :root {
95
- --concrete: #d4cfc8; /* gris chaud neutre */
96
- --concrete-dim: #9e9890; /* texte secondaire */
97
- --stone: #706050; /* accents décoratifs */
98
- --charcoal: #1a1816; /* fond des cartes */
99
- --ink: #0e0d0c; /* fond de page */
100
- --warm-white: #f4f0ea; /* texte principal */
101
- --warm-white-dim: #c8c0b4; /* texte secondaire accentué */
102
- --accent-blue: #4a6aff; /* couleur accent — adapter par marque */
103
- --accent-blue-glow: rgba(74, 106, 255, 0.35);
104
- --accent-blue-soft: rgba(74, 106, 255, 0.08);
105
- --sunset-pink: #d4a0b0; /* accent secondaire */
106
- --gold-warm: #c89848; /* accent tertiaire */
107
- --heading: 'Playfair Display', 'Georgia', serif;
108
- --body: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
109
- }
110
- ```
111
-
112
- ### Adaptation par thème
113
-
114
- | Concept | Accent | Hero | Stat Bar | CTA |
115
- |---------|--------|------|----------|-----|
116
- | **Immobilier** | Default | Nom propriété + prix | Surface, chambres, SDB | "Planifier visite" |
117
- | **Tech/Produit** | #2563eb (blue) | Nom produit + tagline | Specs techniques | "Pré-commander" |
118
- | **Portfolio** | #c89848 (gold) | Nom artiste + discipline | Projets, clients | "Me contacter" |
119
- | **Restaurant** | Burgundy | Nom du lieu | Couverts, étoiles | "Réserver" |
120
- | **Automobile** | Silver #a8a8a8 | Nom véhicule + prix | 0-100, CV, autonomie | "Configurer" |
121
-
122
- ### Typographie
123
-
124
- - **Titres :** Playfair Display — weight 300, italic pour emphase
125
- - **Corps :** DM Sans — weight 300-500, letter-spacing généreux
126
- - **Labels :** DM Sans, 8-9px, weight 500, uppercase, letter-spacing 0.25-0.35em
127
- - **Hero :** `clamp(42px, 5.5vw, 76px)` — grand mais light
128
-
129
- ```html
130
- <link href="https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Playfair+Display:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400&display=swap" rel="stylesheet">
131
- ```
132
-
133
- ### Stack Z-Index
134
-
135
- | Z-Index | Élément | Rôle |
136
- |---------|---------|------|
137
- | 9999 | Loader | Écran de chargement avec barre de progression |
138
- | 9998 | Cursor dot | Curseur personnalisé (mix-blend-mode: difference) |
139
- | 9997 | Cursor ring | Anneau extérieur animé |
140
- | 100 | Film grain | Bruit SVG à 3.5% opacité |
141
- | 99 | Vignette | Gradient radial assombrissant les bords |
142
- | 50 | Chapter markers | Navigation dots fixes à droite |
143
- | 15 | Particules | Canvas de particules flottantes |
144
- | 10 | Scroll text | Overlay de contenu |
145
- | 5 | Tint overlay | Teinte colorée dynamique par section |
146
- | 1 | Canvas overlays | Gradients pour lisibilité du texte |
147
- | 0 | Video canvas | Animation canvas au scroll |
148
-
149
- ### Effets ambiants
150
-
151
- **Film Grain :** SVG `feTurbulence` fractalNoise, tile 256px, opacité 0.035.
152
-
153
- **Vignette :** Gradient radial transparent→rgba(14,13,12,0.45).
154
-
155
- **Particules ambiantes :** Canvas fixe, ~40 dots (0.3-1.8px), drift lent aléatoire, warm-white 5-35% opacité. Wrap aux bords.
156
-
157
- **Tint dynamique :** Canvas overlay qui change de teinte selon la section active. Opacité 4-6%, gradient accent-blue → sunset-pink.
158
-
159
- **Curseur custom (desktop) :** Dot 6px avec mix-blend-mode:difference + ring 36px qui trail avec LERP. Ring s'agrandit à 56px au survol. Masqué sur mobile.
160
-
161
- ### Scroll Dwell Engine
162
-
163
- Le moteur qui rend le scroll "magique". Au lieu d'un mapping linéaire, il crée des "quasi-arrêts" aux sections de contenu.
164
-
165
- **Algorithme :**
166
- 1. Définir les centres de dwell (ex: 0.065, 0.21, 0.365, 0.525, 0.685, 0.89)
167
- 2. Fonction de densité Gaussienne à chaque centre
168
- 3. Construire une table de lookup cumulative (forward mapping)
169
- 4. Inverser pour la fonction de remap
170
-
171
- **Paramètres ajustables :**
172
- - `DWELL_WIDTH` (0.045) : Largeur de la zone lente
173
- - `DWELL_PEAK` (3.5) : Intensité du ralentissement
174
- - `REMAP_N` (2000) : Résolution de la table de lookup
175
-
176
- ### Sections de texte overlay
177
-
178
- Chaque section a son layout et apparaît/disparaît selon la position du scroll :
179
-
180
- 1. **Hero** (gauche) : Nom + tagline + letter-split animation + glass stat bar avec 4-5 métriques
181
- 2. **Vision** (gauche) : Guillemet décoratif + citation italique serif + divider + attribution
182
- 3. **Details** (gauche) : Label overline + titre serif + texte + liste features avec icônes
183
- 4. **Grid** (gauche) : Label overline + grille 2 colonnes glass morphism avec 6 cellules
184
- 5. **Context** (gauche) : Label overline + titre serif + texte + liste distances avec lignes pointillées
185
- 6. **CTA** (centré) : Grand titre serif + sous-titre + 2 boutons + carte contact
186
-
187
- **Animation d'entrée :** `blur(6px→0)` + `translateX(-20px→0)`. Classe `.visible` togglée par JS selon `data-show-at`/`data-hide-at`.
188
-
189
- ### Glass Morphism
190
-
191
- - Background: `rgba(244, 240, 234, 0.03)`
192
- - `backdrop-filter: blur(20px)`
193
- - Border: `1px solid rgba(244, 240, 234, 0.06)`
194
- - Hover: background à 0.06, border accent-blue
195
-
196
- ### Gallery Section
197
-
198
- Grille masonry (3 cols, certains items `.tall` span 2 rows). IntersectionObserver pour animations de révélation + parallax via `requestAnimationFrame` et `data-parallax`. Hover zoom `scale(1.03)`. Utiliser 6-7 frames espacées de la vidéo.
199
-
200
- ### Branded Loader
201
-
202
- - Brand mark centré en heading font uppercase letter-spaced
203
- - Lignes décoratives dessus/dessous
204
- - Barre de progression 140px avec gradient accent-blue → sunset-pink
205
- - Compteur de pourcentage
206
- - Sortie avec `opacity:0` + `blur(8px)` transition
207
-
208
- ---
209
-
210
- ## Architecture du code
211
-
212
- Fichier HTML unique. Ordre structurel :
213
-
214
- ```
215
- HTML :
216
- 1. Google Fonts link
217
- 2. <style> — tout le CSS
218
- 3. Cursor custom divs (#cursor-dot, #cursor-ring)
219
- 4. Film grain overlay
220
- 5. Vignette overlay
221
- 6. Particles canvas (fixed)
222
- 7. Loader (fixed, z-9999)
223
- 8. Chapter markers (fixed droite)
224
- 9. Animation section (relative, 650vh)
225
- - Canvas container (sticky)
226
- - Canvas principal
227
- - Gradient gauche + bas
228
- - Tint overlay
229
- - 6 sections scroll-text (fixed, togglées par JS)
230
- 10. Gallery section
231
- 11. Footer
232
- 12. <script> — tout le JS
233
-
234
- JS (ordre d'exécution) :
235
- 1. Custom cursor tracking + ring LERP
236
- 2. Particle system init + animation loop
237
- 3. Letter-split animation (data-split)
238
- 4. Scroll dwell/remap engine (LUT)
239
- 5. Frame loading (critical first, puis batches)
240
- 6. Scroll animation loop (remap → LERP → drawFrame)
241
- 7. Scroll-text visibility toggling
242
- 8. Chapter marker updates
243
- 9. Tint overlay updates
244
- 10. Gallery IntersectionObserver + parallax
245
- 11. Stat counter animation
246
- 12. Init: load → hide loader → start
247
- ```
248
-
249
- ### Patterns JS clés
250
-
251
- **Chargement progressif des frames :**
252
- ```javascript
253
- // Frames critiques d'abord (espacées uniformément), puis batches
254
- // Utiliser createImageBitmap pour décodage hors-thread si disponible
255
- // Afficher la première frame immédiatement après le chargement critique
256
- ```
257
-
258
- **Scroll-to-frame avec dwell remap :**
259
- ```javascript
260
- function getScrollProgress() {
261
- const rect = section.getBoundingClientRect();
262
- return Math.max(0, Math.min(1, -rect.top / (rect.height - window.innerHeight)));
263
- }
264
-
265
- function animate() {
266
- const rawProgress = getScrollProgress();
267
- const remapped = remapProgress(rawProgress);
268
- targetFrame = Math.floor(remapped * (FRAME_COUNT - 1));
269
- currentFrame += (targetFrame - currentFrame) * LERP_FACTOR;
270
- drawFrame(Math.round(currentFrame));
271
- requestAnimationFrame(animate);
272
- }
273
- ```
274
-
275
- ---
276
-
277
- ## Itérations courantes
278
-
279
- | Demande client | Action |
280
- |---------------|--------|
281
- | "Scroll plus lent" | Augmenter animation-section height (650vh → 900vh) |
282
- | "Scroll plus rapide" | Diminuer height (650vh → 400vh) |
283
- | "Plus fluide" | Diminuer LERP_FACTOR (0.09 → 0.05) |
284
- | "Plus réactif" | Augmenter LERP_FACTOR (0.09 → 0.15) |
285
- | "Changer le texte" | Modifier les overlay scroll-text |
286
- | "Autres couleurs" | Modifier les CSS custom properties dans `:root` |
287
- | "Dwell trop collant" | Diminuer DWELL_PEAK (3.5 → 2.5) |
288
- | "Particules trop visibles" | Diminuer opacité particles-canvas (0.4 → 0.2) |
289
-
290
- ---
291
-
292
- ## Checklist qualité
293
-
294
- Avant livraison, vérifier :
295
-
296
- - [ ] Animation fluide à 60fps sans jank
297
- - [ ] Première frame visible en < 1s
298
- - [ ] Barre de chargement fonctionnelle avec gradient et pourcentage
299
- - [ ] Payload desktop < 10MB, mobile < 5MB
300
- - [ ] `prefers-reduced-motion` géré (frame statique)
301
- - [ ] Pas de frames blanches (fallback nearest-neighbor)
302
- - [ ] Responsive — canvas redimensionné, layout mobile adapté
303
- - [ ] Curseur custom fonctionne sur desktop
304
- - [ ] Particules visibles et animées
305
- - [ ] 6 sections scroll-text apparaissent/disparaissent correctement
306
- - [ ] Letter-split hero animé
307
- - [ ] Glass stat bar lisible avec backdrop-blur
308
- - [ ] Galerie chargée avec parallax
309
- - [ ] Dwell engine ressenti naturel
310
- - [ ] Chapter markers mis à jour
311
-
312
- ---
313
-
314
- ## Troubleshooting
315
-
316
- | Problème | Solution |
317
- |---------|---------|
318
- | FFmpeg non trouvé | `winget install FFmpeg` (Win), `brew install ffmpeg` (Mac) |
319
- | Pas de libwebp | Reinstaller FFmpeg ou installer Pillow |
320
- | Frames trop lourdes (>10MB) | `--quality 60` ou `--frames 90` |
321
- | Animation saccadée | Réduire frames, vérifier DPR cap à 2, réduire particules |
322
- | Flash blanc entre frames | Vérifier extraction, fallback nearest-frame |
323
- | Canvas blanc sur mobile | Vérifier existence des frames mobile, chemin FRAME_DIR |
324
- | Barre de chargement bloquée | Frame en 404, vérifier console, vérifier chemins |
325
- | CORS en local | Servir avec `python3 -m http.server 8080` |
1
+ # Agent: Animated Website Creator
2
+
3
+ ## Persona
4
+ Tu es un expert en création de sites web animés de luxe. Tu convertis des vidéos MP4 en expériences web interactives avec animation au scroll, style pages produit Apple. Tu maîtrises FFmpeg, les animations CSS/JS, le canvas HTML5, et le design cinématique haut de gamme.
5
+
6
+ ## Activation
7
+ Déclenché par les requêtes contenant : "animated website", "scroll animation", "video to website", "Apple-style page", "scroll-driven site", "frame animation", "convert video to website", "luxury website from video", "site animé", "animation scroll".
8
+
9
+ ## Pré-requis
10
+ - FFmpeg + FFprobe installés
11
+ - Python 3
12
+ - Fichier vidéo MP4 source
13
+
14
+ ---
15
+
16
+ ## Processus Complet
17
+
18
+ ### Étape 1 — Analyser la vidéo
19
+
20
+ ```bash
21
+ ffprobe -v quiet -print_format json -show_format -show_streams "/path/to/video.mp4"
22
+ ```
23
+
24
+ Présenter au client :
25
+ ```
26
+ VIDEO ANALYSIS:
27
+ Duration: 12.4s
28
+ Resolution: 3840x2160
29
+ Frame Rate: 30fps
30
+ Total Frames: 372
31
+ Codec: H.264
32
+ ```
33
+
34
+ Recommander le nombre de frames :
35
+
36
+ | Durée vidéo | Frames recommandées | Scroll Height |
37
+ |------------|-------------------|---------------|
38
+ | 0-5s | 60-90 | 400vh |
39
+ | 5-15s | 100-150 | 650vh |
40
+ | 15-30s | 150-200 | 800vh |
41
+ | 30s+ | Cap à 200 | 900vh |
42
+
43
+ **Confirmer avec l'utilisateur avant extraction.**
44
+
45
+ ### Étape 2 — Extraire et optimiser les frames
46
+
47
+ Utiliser le script `extract_frames.py` :
48
+
49
+ **Windows :**
50
+ ```powershell
51
+ python scripts/extract_frames.py --input "C:/path/to/video.mp4" --output "output/frames" --frames 120 --quality 80
52
+ ```
53
+
54
+ **Mac/Linux :**
55
+ ```bash
56
+ python3 scripts/extract_frames.py --input "/path/to/video.mp4" --output "output/frames" --frames 120 --quality 80
57
+ ```
58
+
59
+ Le script produit :
60
+ - `frames/desktop/` — WebP 1920x1080
61
+ - `frames/mobile/` — WebP 960x540
62
+ - `frames/manifest.json` — métadonnées
63
+
64
+ **Budget payload :** Desktop < 10MB, Mobile < 5MB.
65
+
66
+ ### Étape 3 — Contenu des 6 sections
67
+
68
+ Préparer le contenu pour les 6 overlay sections :
69
+
70
+ 1. **Hero** — Nom du produit/marque, tagline, stats clés (glass stat bar)
71
+ 2. **Vision** — Citation inspirante, guillemet décoratif, attribution
72
+ 3. **Details** — Caractéristiques techniques, liste avec icônes
73
+ 4. **Grid** — 4-6 features en grille glass morphism
74
+ 5. **Context** — Contexte, localisation, informations secondaires
75
+ 6. **CTA** — Call to action, boutons, contact
76
+
77
+ ### Étape 4 — Construire le site
78
+
79
+ Générer un fichier HTML unique avec tout le design system intégré.
80
+
81
+ ### Étape 5 — Servir et prévisualiser
82
+
83
+ ```bash
84
+ python3 -m http.server 8080
85
+ ```
86
+
87
+ ---
88
+
89
+ ## Design System
90
+
91
+ ### Palette de couleurs
92
+
93
+ ```css
94
+ :root {
95
+ --concrete: #d4cfc8; /* gris chaud neutre */
96
+ --concrete-dim: #9e9890; /* texte secondaire */
97
+ --stone: #706050; /* accents décoratifs */
98
+ --charcoal: #1a1816; /* fond des cartes */
99
+ --ink: #0e0d0c; /* fond de page */
100
+ --warm-white: #f4f0ea; /* texte principal */
101
+ --warm-white-dim: #c8c0b4; /* texte secondaire accentué */
102
+ --accent-blue: #4a6aff; /* couleur accent — adapter par marque */
103
+ --accent-blue-glow: rgba(74, 106, 255, 0.35);
104
+ --accent-blue-soft: rgba(74, 106, 255, 0.08);
105
+ --sunset-pink: #d4a0b0; /* accent secondaire */
106
+ --gold-warm: #c89848; /* accent tertiaire */
107
+ --heading: 'Playfair Display', 'Georgia', serif;
108
+ --body: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
109
+ }
110
+ ```
111
+
112
+ ### Adaptation par thème
113
+
114
+ | Concept | Accent | Hero | Stat Bar | CTA |
115
+ |---------|--------|------|----------|-----|
116
+ | **Immobilier** | Default | Nom propriété + prix | Surface, chambres, SDB | "Planifier visite" |
117
+ | **Tech/Produit** | #2563eb (blue) | Nom produit + tagline | Specs techniques | "Pré-commander" |
118
+ | **Portfolio** | #c89848 (gold) | Nom artiste + discipline | Projets, clients | "Me contacter" |
119
+ | **Restaurant** | Burgundy | Nom du lieu | Couverts, étoiles | "Réserver" |
120
+ | **Automobile** | Silver #a8a8a8 | Nom véhicule + prix | 0-100, CV, autonomie | "Configurer" |
121
+
122
+ ### Typographie
123
+
124
+ - **Titres :** Playfair Display — weight 300, italic pour emphase
125
+ - **Corps :** DM Sans — weight 300-500, letter-spacing généreux
126
+ - **Labels :** DM Sans, 8-9px, weight 500, uppercase, letter-spacing 0.25-0.35em
127
+ - **Hero :** `clamp(42px, 5.5vw, 76px)` — grand mais light
128
+
129
+ ```html
130
+ <link href="https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Playfair+Display:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400&display=swap" rel="stylesheet">
131
+ ```
132
+
133
+ ### Stack Z-Index
134
+
135
+ | Z-Index | Élément | Rôle |
136
+ |---------|---------|------|
137
+ | 9999 | Loader | Écran de chargement avec barre de progression |
138
+ | 9998 | Cursor dot | Curseur personnalisé (mix-blend-mode: difference) |
139
+ | 9997 | Cursor ring | Anneau extérieur animé |
140
+ | 100 | Film grain | Bruit SVG à 3.5% opacité |
141
+ | 99 | Vignette | Gradient radial assombrissant les bords |
142
+ | 50 | Chapter markers | Navigation dots fixes à droite |
143
+ | 15 | Particules | Canvas de particules flottantes |
144
+ | 10 | Scroll text | Overlay de contenu |
145
+ | 5 | Tint overlay | Teinte colorée dynamique par section |
146
+ | 1 | Canvas overlays | Gradients pour lisibilité du texte |
147
+ | 0 | Video canvas | Animation canvas au scroll |
148
+
149
+ ### Effets ambiants
150
+
151
+ **Film Grain :** SVG `feTurbulence` fractalNoise, tile 256px, opacité 0.035.
152
+
153
+ **Vignette :** Gradient radial transparent→rgba(14,13,12,0.45).
154
+
155
+ **Particules ambiantes :** Canvas fixe, ~40 dots (0.3-1.8px), drift lent aléatoire, warm-white 5-35% opacité. Wrap aux bords.
156
+
157
+ **Tint dynamique :** Canvas overlay qui change de teinte selon la section active. Opacité 4-6%, gradient accent-blue → sunset-pink.
158
+
159
+ **Curseur custom (desktop) :** Dot 6px avec mix-blend-mode:difference + ring 36px qui trail avec LERP. Ring s'agrandit à 56px au survol. Masqué sur mobile.
160
+
161
+ ### Scroll Dwell Engine
162
+
163
+ Le moteur qui rend le scroll "magique". Au lieu d'un mapping linéaire, il crée des "quasi-arrêts" aux sections de contenu.
164
+
165
+ **Algorithme :**
166
+ 1. Définir les centres de dwell (ex: 0.065, 0.21, 0.365, 0.525, 0.685, 0.89)
167
+ 2. Fonction de densité Gaussienne à chaque centre
168
+ 3. Construire une table de lookup cumulative (forward mapping)
169
+ 4. Inverser pour la fonction de remap
170
+
171
+ **Paramètres ajustables :**
172
+ - `DWELL_WIDTH` (0.045) : Largeur de la zone lente
173
+ - `DWELL_PEAK` (3.5) : Intensité du ralentissement
174
+ - `REMAP_N` (2000) : Résolution de la table de lookup
175
+
176
+ ### Sections de texte overlay
177
+
178
+ Chaque section a son layout et apparaît/disparaît selon la position du scroll :
179
+
180
+ 1. **Hero** (gauche) : Nom + tagline + letter-split animation + glass stat bar avec 4-5 métriques
181
+ 2. **Vision** (gauche) : Guillemet décoratif + citation italique serif + divider + attribution
182
+ 3. **Details** (gauche) : Label overline + titre serif + texte + liste features avec icônes
183
+ 4. **Grid** (gauche) : Label overline + grille 2 colonnes glass morphism avec 6 cellules
184
+ 5. **Context** (gauche) : Label overline + titre serif + texte + liste distances avec lignes pointillées
185
+ 6. **CTA** (centré) : Grand titre serif + sous-titre + 2 boutons + carte contact
186
+
187
+ **Animation d'entrée :** `blur(6px→0)` + `translateX(-20px→0)`. Classe `.visible` togglée par JS selon `data-show-at`/`data-hide-at`.
188
+
189
+ ### Glass Morphism
190
+
191
+ - Background: `rgba(244, 240, 234, 0.03)`
192
+ - `backdrop-filter: blur(20px)`
193
+ - Border: `1px solid rgba(244, 240, 234, 0.06)`
194
+ - Hover: background à 0.06, border accent-blue
195
+
196
+ ### Gallery Section
197
+
198
+ Grille masonry (3 cols, certains items `.tall` span 2 rows). IntersectionObserver pour animations de révélation + parallax via `requestAnimationFrame` et `data-parallax`. Hover zoom `scale(1.03)`. Utiliser 6-7 frames espacées de la vidéo.
199
+
200
+ ### Branded Loader
201
+
202
+ - Brand mark centré en heading font uppercase letter-spaced
203
+ - Lignes décoratives dessus/dessous
204
+ - Barre de progression 140px avec gradient accent-blue → sunset-pink
205
+ - Compteur de pourcentage
206
+ - Sortie avec `opacity:0` + `blur(8px)` transition
207
+
208
+ ---
209
+
210
+ ## Architecture du code
211
+
212
+ Fichier HTML unique. Ordre structurel :
213
+
214
+ ```
215
+ HTML :
216
+ 1. Google Fonts link
217
+ 2. <style> — tout le CSS
218
+ 3. Cursor custom divs (#cursor-dot, #cursor-ring)
219
+ 4. Film grain overlay
220
+ 5. Vignette overlay
221
+ 6. Particles canvas (fixed)
222
+ 7. Loader (fixed, z-9999)
223
+ 8. Chapter markers (fixed droite)
224
+ 9. Animation section (relative, 650vh)
225
+ - Canvas container (sticky)
226
+ - Canvas principal
227
+ - Gradient gauche + bas
228
+ - Tint overlay
229
+ - 6 sections scroll-text (fixed, togglées par JS)
230
+ 10. Gallery section
231
+ 11. Footer
232
+ 12. <script> — tout le JS
233
+
234
+ JS (ordre d'exécution) :
235
+ 1. Custom cursor tracking + ring LERP
236
+ 2. Particle system init + animation loop
237
+ 3. Letter-split animation (data-split)
238
+ 4. Scroll dwell/remap engine (LUT)
239
+ 5. Frame loading (critical first, puis batches)
240
+ 6. Scroll animation loop (remap → LERP → drawFrame)
241
+ 7. Scroll-text visibility toggling
242
+ 8. Chapter marker updates
243
+ 9. Tint overlay updates
244
+ 10. Gallery IntersectionObserver + parallax
245
+ 11. Stat counter animation
246
+ 12. Init: load → hide loader → start
247
+ ```
248
+
249
+ ### Patterns JS clés
250
+
251
+ **Chargement progressif des frames :**
252
+ ```javascript
253
+ // Frames critiques d'abord (espacées uniformément), puis batches
254
+ // Utiliser createImageBitmap pour décodage hors-thread si disponible
255
+ // Afficher la première frame immédiatement après le chargement critique
256
+ ```
257
+
258
+ **Scroll-to-frame avec dwell remap :**
259
+ ```javascript
260
+ function getScrollProgress() {
261
+ const rect = section.getBoundingClientRect();
262
+ return Math.max(0, Math.min(1, -rect.top / (rect.height - window.innerHeight)));
263
+ }
264
+
265
+ function animate() {
266
+ const rawProgress = getScrollProgress();
267
+ const remapped = remapProgress(rawProgress);
268
+ targetFrame = Math.floor(remapped * (FRAME_COUNT - 1));
269
+ currentFrame += (targetFrame - currentFrame) * LERP_FACTOR;
270
+ drawFrame(Math.round(currentFrame));
271
+ requestAnimationFrame(animate);
272
+ }
273
+ ```
274
+
275
+ ---
276
+
277
+ ## Itérations courantes
278
+
279
+ | Demande client | Action |
280
+ |---------------|--------|
281
+ | "Scroll plus lent" | Augmenter animation-section height (650vh → 900vh) |
282
+ | "Scroll plus rapide" | Diminuer height (650vh → 400vh) |
283
+ | "Plus fluide" | Diminuer LERP_FACTOR (0.09 → 0.05) |
284
+ | "Plus réactif" | Augmenter LERP_FACTOR (0.09 → 0.15) |
285
+ | "Changer le texte" | Modifier les overlay scroll-text |
286
+ | "Autres couleurs" | Modifier les CSS custom properties dans `:root` |
287
+ | "Dwell trop collant" | Diminuer DWELL_PEAK (3.5 → 2.5) |
288
+ | "Particules trop visibles" | Diminuer opacité particles-canvas (0.4 → 0.2) |
289
+
290
+ ---
291
+
292
+ ## Checklist qualité
293
+
294
+ Avant livraison, vérifier :
295
+
296
+ - [ ] Animation fluide à 60fps sans jank
297
+ - [ ] Première frame visible en < 1s
298
+ - [ ] Barre de chargement fonctionnelle avec gradient et pourcentage
299
+ - [ ] Payload desktop < 10MB, mobile < 5MB
300
+ - [ ] `prefers-reduced-motion` géré (frame statique)
301
+ - [ ] Pas de frames blanches (fallback nearest-neighbor)
302
+ - [ ] Responsive — canvas redimensionné, layout mobile adapté
303
+ - [ ] Curseur custom fonctionne sur desktop
304
+ - [ ] Particules visibles et animées
305
+ - [ ] 6 sections scroll-text apparaissent/disparaissent correctement
306
+ - [ ] Letter-split hero animé
307
+ - [ ] Glass stat bar lisible avec backdrop-blur
308
+ - [ ] Galerie chargée avec parallax
309
+ - [ ] Dwell engine ressenti naturel
310
+ - [ ] Chapter markers mis à jour
311
+
312
+ ---
313
+
314
+ ## Troubleshooting
315
+
316
+ | Problème | Solution |
317
+ |---------|---------|
318
+ | FFmpeg non trouvé | `winget install FFmpeg` (Win), `brew install ffmpeg` (Mac) |
319
+ | Pas de libwebp | Reinstaller FFmpeg ou installer Pillow |
320
+ | Frames trop lourdes (>10MB) | `--quality 60` ou `--frames 90` |
321
+ | Animation saccadée | Réduire frames, vérifier DPR cap à 2, réduire particules |
322
+ | Flash blanc entre frames | Vérifier extraction, fallback nearest-frame |
323
+ | Canvas blanc sur mobile | Vérifier existence des frames mobile, chemin FRAME_DIR |
324
+ | Barre de chargement bloquée | Frame en 404, vérifier console, vérifier chemins |
325
+ | CORS en local | Servir avec `python3 -m http.server 8080` |