@vodailoc/kilo-kit-mcp 1.1.0 → 1.2.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 (582) hide show
  1. package/.mcp/kilo-kit.codex-windows.toml +5 -0
  2. package/LICENSE +190 -190
  3. package/QUICKSTART.md +265 -255
  4. package/README.md +321 -267
  5. package/mcp/README.md +64 -12
  6. package/mcp/dist/formatters.js +142 -1
  7. package/mcp/dist/orchestration-audit.js +20 -0
  8. package/mcp/dist/orchestration-memory.js +258 -0
  9. package/mcp/dist/orchestration-types.js +1 -0
  10. package/mcp/dist/orchestrator.js +222 -0
  11. package/mcp/dist/question-templates.js +249 -0
  12. package/mcp/dist/route-analytics.js +149 -0
  13. package/mcp/dist/router.js +75 -82
  14. package/mcp/dist/routing-policy-data.js +241 -0
  15. package/mcp/dist/routing-policy.js +145 -0
  16. package/mcp/dist/server.js +93 -4
  17. package/mcp/dist/smoke-env.js +18 -0
  18. package/mcp/dist/smoke.js +68 -1
  19. package/mcp/package.json +1 -2
  20. package/package.json +3 -2
  21. package/skills/README.md +647 -647
  22. package/skills/SKILLS_INDEX.md +139 -139
  23. package/skills/ai-media/ai-multimodal/.env.example +97 -97
  24. package/skills/ai-media/ai-multimodal/SKILL.md +357 -357
  25. package/skills/ai-media/ai-multimodal/references/audio-processing.md +373 -373
  26. package/skills/ai-media/ai-multimodal/references/image-generation.md +558 -558
  27. package/skills/ai-media/ai-multimodal/references/video-analysis.md +502 -502
  28. package/skills/ai-media/ai-multimodal/references/vision-understanding.md +483 -483
  29. package/skills/ai-media/ai-multimodal/scripts/document_converter.py +395 -395
  30. package/skills/ai-media/ai-multimodal/scripts/gemini_batch_process.py +480 -480
  31. package/skills/ai-media/ai-multimodal/scripts/media_optimizer.py +506 -506
  32. package/skills/ai-media/ai-multimodal/scripts/requirements.txt +26 -26
  33. package/skills/ai-media/ai-multimodal/scripts/tests/requirements.txt +20 -20
  34. package/skills/ai-media/ai-multimodal/scripts/tests/test_document_converter.py +299 -299
  35. package/skills/ai-media/ai-multimodal/scripts/tests/test_gemini_batch_process.py +362 -362
  36. package/skills/ai-media/ai-multimodal/scripts/tests/test_media_optimizer.py +373 -373
  37. package/skills/ai-media/media-processing/SKILL.md +358 -358
  38. package/skills/ai-media/media-processing/references/ffmpeg-encoding.md +358 -358
  39. package/skills/ai-media/media-processing/references/ffmpeg-filters.md +503 -503
  40. package/skills/ai-media/media-processing/references/ffmpeg-streaming.md +403 -403
  41. package/skills/ai-media/media-processing/references/format-compatibility.md +375 -375
  42. package/skills/ai-media/media-processing/references/imagemagick-batch.md +612 -612
  43. package/skills/ai-media/media-processing/references/imagemagick-editing.md +623 -623
  44. package/skills/ai-media/media-processing/scripts/batch_resize.py +342 -342
  45. package/skills/ai-media/media-processing/scripts/media_convert.py +311 -311
  46. package/skills/ai-media/media-processing/scripts/requirements.txt +24 -24
  47. package/skills/ai-media/media-processing/scripts/tests/requirements.txt +2 -2
  48. package/skills/ai-media/media-processing/scripts/tests/test_batch_resize.py +372 -372
  49. package/skills/ai-media/media-processing/scripts/tests/test_media_convert.py +259 -259
  50. package/skills/ai-media/media-processing/scripts/tests/test_video_optimize.py +397 -397
  51. package/skills/ai-media/media-processing/scripts/video_optimize.py +414 -414
  52. package/skills/ai-media/screenshot/LICENSE.txt +201 -201
  53. package/skills/ai-media/screenshot/SKILL.md +267 -267
  54. package/skills/ai-media/screenshot/agents/openai.yaml +6 -6
  55. package/skills/ai-media/screenshot/assets/screenshot-small.svg +5 -5
  56. package/skills/ai-media/screenshot/scripts/ensure_macos_permissions.sh +54 -54
  57. package/skills/ai-media/screenshot/scripts/macos_display_info.swift +22 -22
  58. package/skills/ai-media/screenshot/scripts/macos_permissions.swift +40 -40
  59. package/skills/ai-media/screenshot/scripts/macos_window_info.swift +126 -126
  60. package/skills/ai-media/screenshot/scripts/take_screenshot.ps1 +163 -163
  61. package/skills/ai-media/screenshot/scripts/take_screenshot.py +585 -585
  62. package/skills/ai-media/sora/LICENSE.txt +201 -201
  63. package/skills/ai-media/sora/SKILL.md +153 -153
  64. package/skills/ai-media/sora/agents/openai.yaml +6 -6
  65. package/skills/ai-media/sora/assets/sora-small.svg +4 -4
  66. package/skills/ai-media/sora/references/cinematic-shots.md +53 -53
  67. package/skills/ai-media/sora/references/cli.md +248 -248
  68. package/skills/ai-media/sora/references/codex-network.md +28 -28
  69. package/skills/ai-media/sora/references/prompting.md +137 -137
  70. package/skills/ai-media/sora/references/sample-prompts.md +95 -95
  71. package/skills/ai-media/sora/references/social-ads.md +42 -42
  72. package/skills/ai-media/sora/references/troubleshooting.md +58 -58
  73. package/skills/ai-media/sora/references/video-api.md +45 -45
  74. package/skills/ai-media/sora/scripts/sora.py +970 -970
  75. package/skills/design/aesthetic/SKILL.md +121 -121
  76. package/skills/design/aesthetic/assets/design-guideline-template.md +163 -163
  77. package/skills/design/aesthetic/assets/design-story-template.md +135 -135
  78. package/skills/design/aesthetic/references/design-principles.md +62 -62
  79. package/skills/design/aesthetic/references/design-resources.md +75 -75
  80. package/skills/design/aesthetic/references/micro-interactions.md +53 -53
  81. package/skills/design/aesthetic/references/storytelling-design.md +50 -50
  82. package/skills/design/figma/LICENSE.txt +202 -202
  83. package/skills/design/figma/SKILL.md +42 -42
  84. package/skills/design/figma/agents/openai.yaml +14 -14
  85. package/skills/design/figma/assets/figma-small.svg +3 -3
  86. package/skills/design/figma/assets/icon.svg +28 -28
  87. package/skills/design/figma/references/figma-mcp-config.md +35 -35
  88. package/skills/design/figma/references/figma-tools-and-prompts.md +34 -34
  89. package/skills/design/figma-implement-design/LICENSE.txt +202 -202
  90. package/skills/design/figma-implement-design/SKILL.md +264 -264
  91. package/skills/design/figma-implement-design/agents/openai.yaml +14 -14
  92. package/skills/design/figma-implement-design/assets/figma-small.svg +3 -3
  93. package/skills/design/figma-implement-design/assets/icon.svg +28 -28
  94. package/skills/design/frontend-design/SKILL.md +41 -41
  95. package/skills/design/frontend-design/references/animejs.md +395 -395
  96. package/skills/design/ui-styling/LICENSE.txt +201 -201
  97. package/skills/design/ui-styling/SKILL.md +321 -321
  98. package/skills/design/ui-styling/canvas-fonts/ArsenalSC-OFL.txt +93 -93
  99. package/skills/design/ui-styling/canvas-fonts/BigShoulders-OFL.txt +93 -93
  100. package/skills/design/ui-styling/canvas-fonts/Boldonse-OFL.txt +93 -93
  101. package/skills/design/ui-styling/canvas-fonts/BricolageGrotesque-OFL.txt +93 -93
  102. package/skills/design/ui-styling/canvas-fonts/CrimsonPro-OFL.txt +93 -93
  103. package/skills/design/ui-styling/canvas-fonts/DMMono-OFL.txt +93 -93
  104. package/skills/design/ui-styling/canvas-fonts/EricaOne-OFL.txt +94 -94
  105. package/skills/design/ui-styling/canvas-fonts/GeistMono-OFL.txt +93 -93
  106. package/skills/design/ui-styling/canvas-fonts/Gloock-OFL.txt +93 -93
  107. package/skills/design/ui-styling/canvas-fonts/IBMPlexMono-OFL.txt +93 -93
  108. package/skills/design/ui-styling/canvas-fonts/InstrumentSans-OFL.txt +93 -93
  109. package/skills/design/ui-styling/canvas-fonts/Italiana-OFL.txt +93 -93
  110. package/skills/design/ui-styling/canvas-fonts/JetBrainsMono-OFL.txt +93 -93
  111. package/skills/design/ui-styling/canvas-fonts/Jura-OFL.txt +93 -93
  112. package/skills/design/ui-styling/canvas-fonts/LibreBaskerville-OFL.txt +93 -93
  113. package/skills/design/ui-styling/canvas-fonts/Lora-OFL.txt +93 -93
  114. package/skills/design/ui-styling/canvas-fonts/NationalPark-OFL.txt +93 -93
  115. package/skills/design/ui-styling/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -93
  116. package/skills/design/ui-styling/canvas-fonts/Outfit-OFL.txt +93 -93
  117. package/skills/design/ui-styling/canvas-fonts/PixelifySans-OFL.txt +93 -93
  118. package/skills/design/ui-styling/canvas-fonts/PoiretOne-OFL.txt +93 -93
  119. package/skills/design/ui-styling/canvas-fonts/RedHatMono-OFL.txt +93 -93
  120. package/skills/design/ui-styling/canvas-fonts/Silkscreen-OFL.txt +93 -93
  121. package/skills/design/ui-styling/canvas-fonts/SmoochSans-OFL.txt +93 -93
  122. package/skills/design/ui-styling/canvas-fonts/Tektur-OFL.txt +93 -93
  123. package/skills/design/ui-styling/canvas-fonts/WorkSans-OFL.txt +93 -93
  124. package/skills/design/ui-styling/canvas-fonts/YoungSerif-OFL.txt +93 -93
  125. package/skills/design/ui-styling/references/canvas-design-system.md +320 -320
  126. package/skills/design/ui-styling/references/shadcn-accessibility.md +471 -471
  127. package/skills/design/ui-styling/references/shadcn-components.md +424 -424
  128. package/skills/design/ui-styling/references/shadcn-theming.md +373 -373
  129. package/skills/design/ui-styling/references/tailwind-customization.md +483 -483
  130. package/skills/design/ui-styling/references/tailwind-responsive.md +382 -382
  131. package/skills/design/ui-styling/references/tailwind-utilities.md +455 -455
  132. package/skills/design/ui-styling/scripts/requirements.txt +17 -17
  133. package/skills/design/ui-styling/scripts/shadcn_add.py +292 -292
  134. package/skills/design/ui-styling/scripts/tailwind_config_gen.py +456 -456
  135. package/skills/design/ui-styling/scripts/tests/requirements.txt +3 -3
  136. package/skills/design/ui-styling/scripts/tests/test_shadcn_add.py +266 -266
  137. package/skills/design/ui-styling/scripts/tests/test_tailwind_config_gen.py +336 -336
  138. package/skills/engineering/aspnet-core/LICENSE.txt +201 -201
  139. package/skills/engineering/aspnet-core/SKILL.md +61 -61
  140. package/skills/engineering/aspnet-core/agents/openai.yaml +5 -5
  141. package/skills/engineering/aspnet-core/references/_sections.md +40 -40
  142. package/skills/engineering/aspnet-core/references/apis-minimal-and-controllers.md +81 -81
  143. package/skills/engineering/aspnet-core/references/data-state-and-services.md +69 -69
  144. package/skills/engineering/aspnet-core/references/program-and-pipeline.md +103 -103
  145. package/skills/engineering/aspnet-core/references/realtime-grpc-and-background-work.md +58 -58
  146. package/skills/engineering/aspnet-core/references/security-and-identity.md +75 -75
  147. package/skills/engineering/aspnet-core/references/source-map.md +43 -43
  148. package/skills/engineering/aspnet-core/references/stack-selection.md +63 -63
  149. package/skills/engineering/aspnet-core/references/testing-performance-and-operations.md +92 -92
  150. package/skills/engineering/aspnet-core/references/ui-blazor.md +53 -53
  151. package/skills/engineering/aspnet-core/references/ui-mvc.md +56 -56
  152. package/skills/engineering/aspnet-core/references/ui-razor-pages.md +55 -55
  153. package/skills/engineering/aspnet-core/references/versioning-and-upgrades.md +51 -51
  154. package/skills/engineering/backend-development/SKILL.md +95 -95
  155. package/skills/engineering/backend-development/references/backend-api-design.md +495 -495
  156. package/skills/engineering/backend-development/references/backend-architecture.md +454 -454
  157. package/skills/engineering/backend-development/references/backend-authentication.md +338 -338
  158. package/skills/engineering/backend-development/references/backend-code-quality.md +659 -659
  159. package/skills/engineering/backend-development/references/backend-debugging.md +904 -904
  160. package/skills/engineering/backend-development/references/backend-devops.md +494 -494
  161. package/skills/engineering/backend-development/references/backend-mindset.md +387 -387
  162. package/skills/engineering/backend-development/references/backend-performance.md +397 -397
  163. package/skills/engineering/backend-development/references/backend-security.md +290 -290
  164. package/skills/engineering/backend-development/references/backend-technologies.md +256 -256
  165. package/skills/engineering/backend-development/references/backend-testing.md +429 -429
  166. package/skills/engineering/better-auth/SKILL.md +204 -204
  167. package/skills/engineering/better-auth/references/advanced-features.md +553 -553
  168. package/skills/engineering/better-auth/references/database-integration.md +577 -577
  169. package/skills/engineering/better-auth/references/email-password-auth.md +416 -416
  170. package/skills/engineering/better-auth/references/oauth-providers.md +430 -430
  171. package/skills/engineering/better-auth/scripts/better_auth_init.py +521 -521
  172. package/skills/engineering/better-auth/scripts/requirements.txt +15 -15
  173. package/skills/engineering/better-auth/scripts/tests/test_better_auth_init.py +421 -421
  174. package/skills/engineering/code-review/SKILL.md +140 -140
  175. package/skills/engineering/code-review/references/code-review-reception.md +208 -208
  176. package/skills/engineering/code-review/references/requesting-code-review.md +104 -104
  177. package/skills/engineering/code-review/references/verification-before-completion.md +138 -138
  178. package/skills/engineering/context-engineering/SKILL.md +86 -86
  179. package/skills/engineering/context-engineering/references/context-compression.md +84 -84
  180. package/skills/engineering/context-engineering/references/context-degradation.md +93 -93
  181. package/skills/engineering/context-engineering/references/context-fundamentals.md +75 -75
  182. package/skills/engineering/context-engineering/references/context-optimization.md +82 -82
  183. package/skills/engineering/context-engineering/references/evaluation.md +89 -89
  184. package/skills/engineering/context-engineering/references/memory-systems.md +88 -88
  185. package/skills/engineering/context-engineering/references/multi-agent-patterns.md +90 -90
  186. package/skills/engineering/context-engineering/references/project-development.md +97 -97
  187. package/skills/engineering/context-engineering/references/tool-design.md +86 -86
  188. package/skills/engineering/context-engineering/scripts/compression_evaluator.py +329 -329
  189. package/skills/engineering/context-engineering/scripts/context_analyzer.py +294 -294
  190. package/skills/engineering/databases/SKILL.md +232 -232
  191. package/skills/engineering/databases/references/mongodb-aggregation.md +447 -447
  192. package/skills/engineering/databases/references/mongodb-atlas.md +465 -465
  193. package/skills/engineering/databases/references/mongodb-crud.md +408 -408
  194. package/skills/engineering/databases/references/mongodb-indexing.md +442 -442
  195. package/skills/engineering/databases/references/postgresql-administration.md +594 -594
  196. package/skills/engineering/databases/references/postgresql-performance.md +527 -527
  197. package/skills/engineering/databases/references/postgresql-psql-cli.md +467 -467
  198. package/skills/engineering/databases/references/postgresql-queries.md +475 -475
  199. package/skills/engineering/databases/scripts/db_backup.py +502 -502
  200. package/skills/engineering/databases/scripts/db_migrate.py +414 -414
  201. package/skills/engineering/databases/scripts/db_performance_check.py +444 -444
  202. package/skills/engineering/databases/scripts/requirements.txt +20 -20
  203. package/skills/engineering/databases/scripts/tests/requirements.txt +4 -4
  204. package/skills/engineering/databases/scripts/tests/test_db_backup.py +340 -340
  205. package/skills/engineering/databases/scripts/tests/test_db_migrate.py +277 -277
  206. package/skills/engineering/databases/scripts/tests/test_db_performance_check.py +370 -370
  207. package/skills/engineering/diagnose/SKILL.md +117 -117
  208. package/skills/engineering/diagnose/scripts/hitl-loop.template.sh +41 -41
  209. package/skills/engineering/docs-seeker/SKILL.md +207 -207
  210. package/skills/engineering/docs-seeker/WORKFLOWS.md +505 -505
  211. package/skills/engineering/docs-seeker/references/best-practices.md +632 -632
  212. package/skills/engineering/docs-seeker/references/documentation-sources.md +461 -461
  213. package/skills/engineering/docs-seeker/references/error-handling.md +621 -621
  214. package/skills/engineering/docs-seeker/references/limitations.md +821 -821
  215. package/skills/engineering/docs-seeker/references/performance.md +574 -574
  216. package/skills/engineering/docs-seeker/references/tool-selection.md +262 -262
  217. package/skills/engineering/frontend-development/SKILL.md +398 -398
  218. package/skills/engineering/frontend-development/resources/common-patterns.md +330 -330
  219. package/skills/engineering/frontend-development/resources/complete-examples.md +871 -871
  220. package/skills/engineering/frontend-development/resources/component-patterns.md +501 -501
  221. package/skills/engineering/frontend-development/resources/data-fetching.md +766 -766
  222. package/skills/engineering/frontend-development/resources/file-organization.md +501 -501
  223. package/skills/engineering/frontend-development/resources/loading-and-error-states.md +500 -500
  224. package/skills/engineering/frontend-development/resources/performance.md +405 -405
  225. package/skills/engineering/frontend-development/resources/routing-guide.md +363 -363
  226. package/skills/engineering/frontend-development/resources/styling-guide.md +427 -427
  227. package/skills/engineering/frontend-development/resources/typescript-standards.md +417 -417
  228. package/skills/engineering/improve-codebase-architecture/DEEPENING.md +37 -37
  229. package/skills/engineering/improve-codebase-architecture/INTERFACE-DESIGN.md +44 -44
  230. package/skills/engineering/improve-codebase-architecture/LANGUAGE.md +53 -53
  231. package/skills/engineering/improve-codebase-architecture/SKILL.md +71 -71
  232. package/skills/engineering/openai-docs/LICENSE.txt +201 -201
  233. package/skills/engineering/openai-docs/SKILL.md +69 -69
  234. package/skills/engineering/openai-docs/agents/openai.yaml +14 -14
  235. package/skills/engineering/openai-docs/assets/openai-small.svg +3 -3
  236. package/skills/engineering/openai-docs/references/gpt-5p4-prompting-guide.md +433 -433
  237. package/skills/engineering/openai-docs/references/latest-model.md +35 -35
  238. package/skills/engineering/openai-docs/references/upgrading-to-gpt-5p4.md +164 -164
  239. package/skills/engineering/playwright/LICENSE.txt +201 -201
  240. package/skills/engineering/playwright/NOTICE.txt +14 -14
  241. package/skills/engineering/playwright/SKILL.md +147 -147
  242. package/skills/engineering/playwright/agents/openai.yaml +6 -6
  243. package/skills/engineering/playwright/assets/playwright-small.svg +3 -3
  244. package/skills/engineering/playwright/references/cli.md +116 -116
  245. package/skills/engineering/playwright/references/workflows.md +95 -95
  246. package/skills/engineering/playwright/scripts/playwright_cli.sh +25 -25
  247. package/skills/engineering/playwright-interactive/LICENSE.txt +201 -201
  248. package/skills/engineering/playwright-interactive/NOTICE.txt +13 -13
  249. package/skills/engineering/playwright-interactive/SKILL.md +689 -689
  250. package/skills/engineering/playwright-interactive/agents/openai.yaml +6 -6
  251. package/skills/engineering/playwright-interactive/assets/playwright-small.svg +3 -3
  252. package/skills/engineering/render-deploy/LICENSE.txt +201 -201
  253. package/skills/engineering/render-deploy/SKILL.md +479 -479
  254. package/skills/engineering/render-deploy/agents/openai.yaml +14 -14
  255. package/skills/engineering/render-deploy/assets/docker.yaml +62 -62
  256. package/skills/engineering/render-deploy/assets/go-api.yaml +35 -35
  257. package/skills/engineering/render-deploy/assets/nextjs-postgres.yaml +35 -35
  258. package/skills/engineering/render-deploy/assets/node-express.yaml +25 -25
  259. package/skills/engineering/render-deploy/assets/python-django.yaml +89 -89
  260. package/skills/engineering/render-deploy/assets/render-small.svg +3 -3
  261. package/skills/engineering/render-deploy/assets/static-site.yaml +54 -54
  262. package/skills/engineering/render-deploy/references/blueprint-spec.md +718 -718
  263. package/skills/engineering/render-deploy/references/codebase-analysis.md +49 -49
  264. package/skills/engineering/render-deploy/references/configuration-guide.md +603 -603
  265. package/skills/engineering/render-deploy/references/deployment-details.md +224 -224
  266. package/skills/engineering/render-deploy/references/direct-creation.md +113 -113
  267. package/skills/engineering/render-deploy/references/error-patterns.md +13 -13
  268. package/skills/engineering/render-deploy/references/post-deploy-checks.md +36 -36
  269. package/skills/engineering/render-deploy/references/runtimes.md +473 -473
  270. package/skills/engineering/render-deploy/references/service-types.md +450 -450
  271. package/skills/engineering/render-deploy/references/troubleshooting-basics.md +36 -36
  272. package/skills/engineering/repomix/SKILL.md +215 -215
  273. package/skills/engineering/repomix/references/configuration.md +211 -211
  274. package/skills/engineering/repomix/references/usage-patterns.md +232 -232
  275. package/skills/engineering/repomix/scripts/README.md +179 -179
  276. package/skills/engineering/repomix/scripts/repomix_batch.py +455 -455
  277. package/skills/engineering/repomix/scripts/repos.example.json +15 -15
  278. package/skills/engineering/repomix/scripts/requirements.txt +15 -15
  279. package/skills/engineering/repomix/scripts/tests/test_repomix_batch.py +531 -531
  280. package/skills/engineering/setup-matt-pocock-skills/SKILL.md +121 -121
  281. package/skills/engineering/setup-matt-pocock-skills/domain.md +51 -51
  282. package/skills/engineering/setup-matt-pocock-skills/issue-tracker-github.md +22 -22
  283. package/skills/engineering/setup-matt-pocock-skills/issue-tracker-gitlab.md +23 -23
  284. package/skills/engineering/setup-matt-pocock-skills/issue-tracker-local.md +19 -19
  285. package/skills/engineering/setup-matt-pocock-skills/triage-labels.md +15 -15
  286. package/skills/engineering/shopify/README.md +66 -66
  287. package/skills/engineering/shopify/SKILL.md +319 -319
  288. package/skills/engineering/shopify/references/app-development.md +470 -470
  289. package/skills/engineering/shopify/references/extensions.md +493 -493
  290. package/skills/engineering/shopify/references/themes.md +498 -498
  291. package/skills/engineering/shopify/scripts/requirements.txt +19 -19
  292. package/skills/engineering/shopify/scripts/shopify_init.py +423 -423
  293. package/skills/engineering/shopify/scripts/tests/test_shopify_init.py +385 -385
  294. package/skills/engineering/tdd/SKILL.md +109 -109
  295. package/skills/engineering/tdd/deep-modules.md +33 -33
  296. package/skills/engineering/tdd/interface-design.md +31 -31
  297. package/skills/engineering/tdd/mocking.md +59 -59
  298. package/skills/engineering/tdd/refactoring.md +10 -10
  299. package/skills/engineering/tdd/tests.md +61 -61
  300. package/skills/engineering/to-issues/SKILL.md +81 -81
  301. package/skills/engineering/to-prd/SKILL.md +74 -74
  302. package/skills/engineering/triage/AGENT-BRIEF.md +168 -168
  303. package/skills/engineering/triage/OUT-OF-SCOPE.md +101 -101
  304. package/skills/engineering/triage/SKILL.md +103 -103
  305. package/skills/engineering/web-frameworks/SKILL.md +324 -324
  306. package/skills/engineering/web-frameworks/references/nextjs-app-router.md +465 -465
  307. package/skills/engineering/web-frameworks/references/nextjs-data-fetching.md +459 -459
  308. package/skills/engineering/web-frameworks/references/nextjs-optimization.md +511 -511
  309. package/skills/engineering/web-frameworks/references/nextjs-server-components.md +495 -495
  310. package/skills/engineering/web-frameworks/references/remix-icon-integration.md +603 -603
  311. package/skills/engineering/web-frameworks/references/turborepo-caching.md +551 -551
  312. package/skills/engineering/web-frameworks/references/turborepo-pipelines.md +517 -517
  313. package/skills/engineering/web-frameworks/references/turborepo-setup.md +542 -542
  314. package/skills/engineering/web-frameworks/scripts/nextjs_init.py +547 -547
  315. package/skills/engineering/web-frameworks/scripts/requirements.txt +16 -16
  316. package/skills/engineering/web-frameworks/scripts/tests/requirements.txt +3 -3
  317. package/skills/engineering/web-frameworks/scripts/tests/test_nextjs_init.py +319 -319
  318. package/skills/engineering/web-frameworks/scripts/tests/test_turborepo_migrate.py +374 -374
  319. package/skills/engineering/web-frameworks/scripts/turborepo_migrate.py +394 -394
  320. package/skills/engineering/write-a-skill/SKILL.md +117 -117
  321. package/skills/kilo-kit/SKILL.md +346 -346
  322. package/skills/kilo-kit/_template/SKILL.md +185 -185
  323. package/skills/kilo-kit/debugging/root-cause/SKILL.md +360 -360
  324. package/skills/kilo-kit/debugging/systematic/SKILL.md +339 -339
  325. package/skills/kilo-kit/debugging/verification/SKILL.md +424 -424
  326. package/skills/kilo-kit/development/backend/SKILL.md +540 -540
  327. package/skills/kilo-kit/development/security/SKILL.md +529 -529
  328. package/skills/kilo-kit/quality/code-review/SKILL.md +297 -297
  329. package/skills/kilo-kit/quality/testing/SKILL.md +540 -540
  330. package/skills/kilo-kit/references/output-formats.md +204 -204
  331. package/skills/kilo-kit/references/patterns.md +156 -156
  332. package/skills/kilo-kit/references/performance-benchmarks.md +90 -90
  333. package/skills/operations/chrome-devtools/SKILL.md +392 -392
  334. package/skills/operations/chrome-devtools/references/cdp-domains.md +694 -694
  335. package/skills/operations/chrome-devtools/references/performance-guide.md +940 -940
  336. package/skills/operations/chrome-devtools/references/puppeteer-reference.md +953 -953
  337. package/skills/operations/chrome-devtools/scripts/PERSISTENT-BROWSER.md +107 -107
  338. package/skills/operations/chrome-devtools/scripts/README.md +213 -213
  339. package/skills/operations/chrome-devtools/scripts/__tests__/selector.test.js +210 -210
  340. package/skills/operations/chrome-devtools/scripts/click.js +79 -79
  341. package/skills/operations/chrome-devtools/scripts/close-persistent.js +36 -36
  342. package/skills/operations/chrome-devtools/scripts/console.js +75 -75
  343. package/skills/operations/chrome-devtools/scripts/evaluate.js +49 -49
  344. package/skills/operations/chrome-devtools/scripts/fill.js +72 -72
  345. package/skills/operations/chrome-devtools/scripts/install-deps.sh +181 -181
  346. package/skills/operations/chrome-devtools/scripts/install.sh +83 -83
  347. package/skills/operations/chrome-devtools/scripts/launch-persistent.js +71 -71
  348. package/skills/operations/chrome-devtools/scripts/lib/browser.js +144 -144
  349. package/skills/operations/chrome-devtools/scripts/lib/selector.js +178 -178
  350. package/skills/operations/chrome-devtools/scripts/navigate.js +46 -46
  351. package/skills/operations/chrome-devtools/scripts/network.js +102 -102
  352. package/skills/operations/chrome-devtools/scripts/package-lock.json +1206 -1206
  353. package/skills/operations/chrome-devtools/scripts/package.json +15 -15
  354. package/skills/operations/chrome-devtools/scripts/performance.js +145 -145
  355. package/skills/operations/chrome-devtools/scripts/screenshot.js +180 -180
  356. package/skills/operations/chrome-devtools/scripts/snapshot.js +131 -131
  357. package/skills/operations/devops/.env.example +76 -76
  358. package/skills/operations/devops/SKILL.md +285 -285
  359. package/skills/operations/devops/references/browser-rendering.md +305 -305
  360. package/skills/operations/devops/references/cloudflare-d1-kv.md +123 -123
  361. package/skills/operations/devops/references/cloudflare-platform.md +271 -271
  362. package/skills/operations/devops/references/cloudflare-r2-storage.md +280 -280
  363. package/skills/operations/devops/references/cloudflare-workers-advanced.md +312 -312
  364. package/skills/operations/devops/references/cloudflare-workers-apis.md +309 -309
  365. package/skills/operations/devops/references/cloudflare-workers-basics.md +418 -418
  366. package/skills/operations/devops/references/docker-basics.md +297 -297
  367. package/skills/operations/devops/references/docker-compose.md +292 -292
  368. package/skills/operations/devops/references/gcloud-platform.md +297 -297
  369. package/skills/operations/devops/references/gcloud-services.md +304 -304
  370. package/skills/operations/devops/scripts/cloudflare_deploy.py +269 -269
  371. package/skills/operations/devops/scripts/docker_optimize.py +320 -320
  372. package/skills/operations/devops/scripts/requirements.txt +20 -20
  373. package/skills/operations/devops/scripts/tests/requirements.txt +3 -3
  374. package/skills/operations/devops/scripts/tests/test_cloudflare_deploy.py +285 -285
  375. package/skills/operations/devops/scripts/tests/test_docker_optimize.py +436 -436
  376. package/skills/operations/mcp-builder/LICENSE.txt +201 -201
  377. package/skills/operations/mcp-builder/SKILL.md +328 -328
  378. package/skills/operations/mcp-builder/reference/evaluation.md +601 -601
  379. package/skills/operations/mcp-builder/reference/mcp_best_practices.md +915 -915
  380. package/skills/operations/mcp-builder/reference/node_mcp_server.md +915 -915
  381. package/skills/operations/mcp-builder/reference/python_mcp_server.md +751 -751
  382. package/skills/operations/mcp-builder/scripts/connections.py +151 -151
  383. package/skills/operations/mcp-builder/scripts/evaluation.py +373 -373
  384. package/skills/operations/mcp-builder/scripts/example_evaluation.xml +22 -22
  385. package/skills/operations/mcp-builder/scripts/requirements.txt +2 -2
  386. package/skills/operations/mcp-management/README.md +219 -219
  387. package/skills/operations/mcp-management/SKILL.md +175 -175
  388. package/skills/operations/mcp-management/assets/tools.json +3043 -3043
  389. package/skills/operations/mcp-management/references/configuration.md +114 -114
  390. package/skills/operations/mcp-management/references/gemini-cli-integration.md +201 -201
  391. package/skills/operations/mcp-management/references/mcp-protocol.md +116 -116
  392. package/skills/operations/mcp-management/scripts/.env.example +10 -10
  393. package/skills/operations/mcp-management/scripts/cli.ts +155 -155
  394. package/skills/operations/mcp-management/scripts/dist/analyze-tools.js +70 -70
  395. package/skills/operations/mcp-management/scripts/dist/cli.js +131 -131
  396. package/skills/operations/mcp-management/scripts/dist/mcp-client.js +115 -115
  397. package/skills/operations/mcp-management/scripts/mcp-client.ts +163 -163
  398. package/skills/operations/mcp-management/scripts/package.json +18 -18
  399. package/skills/operations/mcp-management/scripts/tsconfig.json +15 -15
  400. package/skills/problem-solving/collision-zone-thinking/SKILL.md +62 -62
  401. package/skills/problem-solving/defense-in-depth/SKILL.md +130 -130
  402. package/skills/problem-solving/inversion-exercise/SKILL.md +58 -58
  403. package/skills/problem-solving/meta-pattern-recognition/SKILL.md +54 -54
  404. package/skills/problem-solving/root-cause-tracing/SKILL.md +177 -177
  405. package/skills/problem-solving/root-cause-tracing/find-polluter.sh +63 -63
  406. package/skills/problem-solving/scale-game/SKILL.md +63 -63
  407. package/skills/problem-solving/sequential-thinking/README.md +118 -118
  408. package/skills/problem-solving/sequential-thinking/SKILL.md +93 -93
  409. package/skills/problem-solving/sequential-thinking/references/advanced.md +122 -122
  410. package/skills/problem-solving/sequential-thinking/references/examples.md +274 -274
  411. package/skills/problem-solving/simplification-cascades/SKILL.md +76 -76
  412. package/skills/problem-solving/when-stuck/SKILL.md +88 -88
  413. package/skills/productivity/caveman/SKILL.md +49 -49
  414. package/skills/productivity/grill-me/SKILL.md +10 -10
  415. package/skills/productivity/grill-with-docs/ADR-FORMAT.md +47 -47
  416. package/skills/productivity/grill-with-docs/CONTEXT-FORMAT.md +77 -77
  417. package/skills/productivity/grill-with-docs/SKILL.md +88 -88
  418. package/skills/productivity/writing-skills/graphviz-conventions.dot +171 -171
  419. package/skills/productivity/zoom-out/SKILL.md +7 -7
  420. package/skills/writing-docs/doc/LICENSE.txt +201 -201
  421. package/skills/writing-docs/doc/SKILL.md +80 -80
  422. package/skills/writing-docs/doc/agents/openai.yaml +6 -6
  423. package/skills/writing-docs/doc/assets/doc-small.svg +3 -3
  424. package/skills/writing-docs/doc/scripts/render_docx.py +296 -296
  425. package/skills/writing-docs/docx/LICENSE.txt +30 -30
  426. package/skills/writing-docs/docx/SKILL.md +196 -196
  427. package/skills/writing-docs/docx/docx-js.md +349 -349
  428. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -1499
  429. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -146
  430. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -1085
  431. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -11
  432. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -3081
  433. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -23
  434. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -185
  435. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -287
  436. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -1676
  437. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -28
  438. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -144
  439. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -174
  440. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -25
  441. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -18
  442. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -59
  443. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -56
  444. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -195
  445. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -582
  446. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -25
  447. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -4439
  448. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -570
  449. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -509
  450. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -12
  451. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -108
  452. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -96
  453. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -3646
  454. package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -116
  455. package/skills/writing-docs/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -42
  456. package/skills/writing-docs/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -50
  457. package/skills/writing-docs/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -49
  458. package/skills/writing-docs/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -33
  459. package/skills/writing-docs/docx/ooxml/schemas/mce/mc.xsd +75 -75
  460. package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -560
  461. package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -67
  462. package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -14
  463. package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -20
  464. package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -13
  465. package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -4
  466. package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -8
  467. package/skills/writing-docs/docx/ooxml/scripts/pack.py +159 -159
  468. package/skills/writing-docs/docx/ooxml/scripts/unpack.py +29 -29
  469. package/skills/writing-docs/docx/ooxml/scripts/validate.py +69 -69
  470. package/skills/writing-docs/docx/ooxml/scripts/validation/__init__.py +15 -15
  471. package/skills/writing-docs/docx/ooxml/scripts/validation/base.py +951 -951
  472. package/skills/writing-docs/docx/ooxml/scripts/validation/docx.py +274 -274
  473. package/skills/writing-docs/docx/ooxml/scripts/validation/pptx.py +315 -315
  474. package/skills/writing-docs/docx/ooxml/scripts/validation/redlining.py +279 -279
  475. package/skills/writing-docs/docx/ooxml.md +609 -609
  476. package/skills/writing-docs/docx/scripts/__init__.py +1 -1
  477. package/skills/writing-docs/docx/scripts/document.py +1276 -1276
  478. package/skills/writing-docs/docx/scripts/templates/comments.xml +2 -2
  479. package/skills/writing-docs/docx/scripts/templates/commentsExtended.xml +2 -2
  480. package/skills/writing-docs/docx/scripts/templates/commentsExtensible.xml +2 -2
  481. package/skills/writing-docs/docx/scripts/templates/commentsIds.xml +2 -2
  482. package/skills/writing-docs/docx/scripts/templates/people.xml +2 -2
  483. package/skills/writing-docs/docx/scripts/utilities.py +374 -374
  484. package/skills/writing-docs/mermaidjs-v11/SKILL.md +115 -115
  485. package/skills/writing-docs/mermaidjs-v11/references/cli-usage.md +228 -228
  486. package/skills/writing-docs/mermaidjs-v11/references/configuration.md +232 -232
  487. package/skills/writing-docs/mermaidjs-v11/references/diagram-types.md +315 -315
  488. package/skills/writing-docs/mermaidjs-v11/references/examples.md +344 -344
  489. package/skills/writing-docs/mermaidjs-v11/references/integration.md +310 -310
  490. package/skills/writing-docs/pdf/LICENSE.txt +30 -30
  491. package/skills/writing-docs/pdf/SKILL.md +294 -294
  492. package/skills/writing-docs/pdf/forms.md +205 -205
  493. package/skills/writing-docs/pdf/reference.md +611 -611
  494. package/skills/writing-docs/pdf/scripts/check_bounding_boxes.py +70 -70
  495. package/skills/writing-docs/pdf/scripts/check_bounding_boxes_test.py +226 -226
  496. package/skills/writing-docs/pdf/scripts/check_fillable_fields.py +12 -12
  497. package/skills/writing-docs/pdf/scripts/convert_pdf_to_images.py +35 -35
  498. package/skills/writing-docs/pdf/scripts/create_validation_image.py +41 -41
  499. package/skills/writing-docs/pdf/scripts/extract_form_field_info.py +152 -152
  500. package/skills/writing-docs/pdf/scripts/fill_fillable_fields.py +114 -114
  501. package/skills/writing-docs/pdf/scripts/fill_pdf_form_with_annotations.py +107 -107
  502. package/skills/writing-docs/pptx/LICENSE.txt +30 -30
  503. package/skills/writing-docs/pptx/SKILL.md +483 -483
  504. package/skills/writing-docs/pptx/html2pptx.md +624 -624
  505. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -1499
  506. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -146
  507. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -1085
  508. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -11
  509. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -3081
  510. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -23
  511. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -185
  512. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -287
  513. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -1676
  514. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -28
  515. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -144
  516. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -174
  517. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -25
  518. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -18
  519. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -59
  520. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -56
  521. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -195
  522. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -582
  523. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -25
  524. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -4439
  525. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -570
  526. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -509
  527. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -12
  528. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -108
  529. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -96
  530. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -3646
  531. package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -116
  532. package/skills/writing-docs/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -42
  533. package/skills/writing-docs/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -50
  534. package/skills/writing-docs/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -49
  535. package/skills/writing-docs/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -33
  536. package/skills/writing-docs/pptx/ooxml/schemas/mce/mc.xsd +75 -75
  537. package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -560
  538. package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -67
  539. package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -14
  540. package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -20
  541. package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -13
  542. package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -4
  543. package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -8
  544. package/skills/writing-docs/pptx/ooxml/scripts/pack.py +159 -159
  545. package/skills/writing-docs/pptx/ooxml/scripts/unpack.py +29 -29
  546. package/skills/writing-docs/pptx/ooxml/scripts/validate.py +69 -69
  547. package/skills/writing-docs/pptx/ooxml/scripts/validation/__init__.py +15 -15
  548. package/skills/writing-docs/pptx/ooxml/scripts/validation/base.py +951 -951
  549. package/skills/writing-docs/pptx/ooxml/scripts/validation/docx.py +274 -274
  550. package/skills/writing-docs/pptx/ooxml/scripts/validation/pptx.py +315 -315
  551. package/skills/writing-docs/pptx/ooxml/scripts/validation/redlining.py +279 -279
  552. package/skills/writing-docs/pptx/ooxml.md +426 -426
  553. package/skills/writing-docs/pptx/scripts/html2pptx.js +978 -978
  554. package/skills/writing-docs/pptx/scripts/inventory.py +1020 -1020
  555. package/skills/writing-docs/pptx/scripts/rearrange.py +231 -231
  556. package/skills/writing-docs/pptx/scripts/replace.py +385 -385
  557. package/skills/writing-docs/pptx/scripts/thumbnail.py +450 -450
  558. package/skills/writing-docs/slides/LICENSE.txt +201 -201
  559. package/skills/writing-docs/slides/SKILL.md +71 -71
  560. package/skills/writing-docs/slides/agents/openai.yaml +6 -6
  561. package/skills/writing-docs/slides/assets/pptxgenjs_helpers/code.js +104 -104
  562. package/skills/writing-docs/slides/assets/pptxgenjs_helpers/image.js +333 -333
  563. package/skills/writing-docs/slides/assets/pptxgenjs_helpers/index.js +33 -33
  564. package/skills/writing-docs/slides/assets/pptxgenjs_helpers/latex.js +51 -51
  565. package/skills/writing-docs/slides/assets/pptxgenjs_helpers/layout.js +643 -643
  566. package/skills/writing-docs/slides/assets/pptxgenjs_helpers/layout_builders.js +358 -358
  567. package/skills/writing-docs/slides/assets/pptxgenjs_helpers/svg.js +36 -36
  568. package/skills/writing-docs/slides/assets/pptxgenjs_helpers/text.js +789 -789
  569. package/skills/writing-docs/slides/assets/pptxgenjs_helpers/util.js +24 -24
  570. package/skills/writing-docs/slides/assets/slides-small.svg +3 -3
  571. package/skills/writing-docs/slides/references/pptxgenjs-helpers.md +61 -61
  572. package/skills/writing-docs/slides/scripts/create_montage.py +300 -300
  573. package/skills/writing-docs/slides/scripts/detect_font.py +873 -873
  574. package/skills/writing-docs/slides/scripts/ensure_raster_image.py +202 -202
  575. package/skills/writing-docs/slides/scripts/render_slides.py +273 -273
  576. package/skills/writing-docs/slides/scripts/slides_test.py +201 -201
  577. package/skills/writing-docs/template-skill/SKILL.md +26 -26
  578. package/skills/writing-docs/xlsx/LICENSE.txt +30 -30
  579. package/skills/writing-docs/xlsx/SKILL.md +288 -288
  580. package/skills/writing-docs/xlsx/recalc.py +177 -177
  581. package/src/core/KILO_MASTER.md +448 -448
  582. package/src/tools/validate-skill.js +421 -421
@@ -1,471 +1,471 @@
1
- # shadcn/ui Accessibility Patterns
2
-
3
- ARIA patterns, keyboard navigation, screen reader support, and accessible component usage.
4
-
5
- ## Foundation: Radix UI Primitives
6
-
7
- shadcn/ui built on Radix UI primitives - unstyled, accessible components following WAI-ARIA design patterns.
8
-
9
- Benefits:
10
- - Keyboard navigation built-in
11
- - Screen reader announcements
12
- - Focus management
13
- - ARIA attributes automatically applied
14
- - Tested against accessibility standards
15
-
16
- ## Keyboard Navigation
17
-
18
- ### Focus Management
19
-
20
- **Focus visible states:**
21
- ```tsx
22
- <Button className="focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2">
23
- Accessible Button
24
- </Button>
25
- ```
26
-
27
- **Skip to content:**
28
- ```tsx
29
- <a href="#main-content" className="sr-only focus:not-sr-only focus:absolute focus:top-4 focus:left-4 focus:z-50 focus:px-4 focus:py-2">
30
- Skip to content
31
- </a>
32
-
33
- <main id="main-content">
34
- {/* Content */}
35
- </main>
36
- ```
37
-
38
- ### Dialog/Modal Navigation
39
-
40
- Dialogs trap focus automatically via Radix Dialog primitive:
41
-
42
- ```tsx
43
- import { Dialog, DialogContent, DialogTrigger } from "@/components/ui/dialog"
44
-
45
- <Dialog>
46
- <DialogTrigger>Open</DialogTrigger>
47
- <DialogContent>
48
- {/* Focus trapped here */}
49
- <input /> {/* Auto-focused */}
50
- <Button>Action</Button>
51
- {/* Esc to close, Tab to navigate */}
52
- </DialogContent>
53
- </Dialog>
54
- ```
55
-
56
- Features:
57
- - Focus trapped within dialog
58
- - Esc key closes
59
- - Tab cycles through focusable elements
60
- - Focus returns to trigger on close
61
-
62
- ### Dropdown/Menu Navigation
63
-
64
- ```tsx
65
- import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from "@/components/ui/dropdown-menu"
66
-
67
- <DropdownMenu>
68
- <DropdownMenuTrigger>Open</DropdownMenuTrigger>
69
- <DropdownMenuContent>
70
- <DropdownMenuItem>Profile</DropdownMenuItem>
71
- <DropdownMenuItem>Settings</DropdownMenuItem>
72
- <DropdownMenuItem>Logout</DropdownMenuItem>
73
- </DropdownMenuContent>
74
- </DropdownMenu>
75
- ```
76
-
77
- Keyboard shortcuts:
78
- - `Space/Enter`: Open menu
79
- - `Arrow Up/Down`: Navigate items
80
- - `Esc`: Close menu
81
- - `Tab`: Close and move focus
82
-
83
- ### Command Palette Navigation
84
-
85
- ```tsx
86
- import { Command } from "@/components/ui/command"
87
-
88
- <Command>
89
- <CommandInput placeholder="Search..." />
90
- <CommandList>
91
- <CommandGroup heading="Suggestions">
92
- <CommandItem>Calendar</CommandItem>
93
- <CommandItem>Search</CommandItem>
94
- </CommandGroup>
95
- </CommandList>
96
- </Command>
97
- ```
98
-
99
- Features:
100
- - Type to filter
101
- - Arrow keys to navigate
102
- - Enter to select
103
- - Esc to close
104
-
105
- ## Screen Reader Support
106
-
107
- ### Semantic HTML
108
-
109
- Use proper HTML elements:
110
-
111
- ```tsx
112
- // Good: Semantic HTML
113
- <button>Click me</button>
114
- <nav><a href="/">Home</a></nav>
115
-
116
- // Avoid: Div soup
117
- <div onClick={handler}>Click me</div>
118
- ```
119
-
120
- ### ARIA Labels
121
-
122
- **Label interactive elements:**
123
- ```tsx
124
- <Button aria-label="Close dialog">
125
- <X className="h-4 w-4" />
126
- </Button>
127
-
128
- <Input aria-label="Email address" type="email" />
129
- ```
130
-
131
- **Describe elements:**
132
- ```tsx
133
- <Button aria-describedby="delete-description">
134
- Delete Account
135
- </Button>
136
- <p id="delete-description" className="sr-only">
137
- This action permanently deletes your account and cannot be undone
138
- </p>
139
- ```
140
-
141
- ### Screen Reader Only Text
142
-
143
- Use `sr-only` class for screen reader only content:
144
-
145
- ```tsx
146
- <Button>
147
- <Trash className="h-4 w-4" />
148
- <span className="sr-only">Delete item</span>
149
- </Button>
150
-
151
- // CSS for sr-only
152
- .sr-only {
153
- position: absolute;
154
- width: 1px;
155
- height: 1px;
156
- padding: 0;
157
- margin: -1px;
158
- overflow: hidden;
159
- clip: rect(0, 0, 0, 0);
160
- white-space: nowrap;
161
- border-width: 0;
162
- }
163
- ```
164
-
165
- ### Live Regions
166
-
167
- Announce dynamic content:
168
-
169
- ```tsx
170
- <div aria-live="polite" aria-atomic="true">
171
- {message}
172
- </div>
173
-
174
- // For urgent updates
175
- <div aria-live="assertive">
176
- {error}
177
- </div>
178
- ```
179
-
180
- Toast component includes live region:
181
- ```tsx
182
- const { toast } = useToast()
183
-
184
- toast({
185
- title: "Success",
186
- description: "Profile updated"
187
- })
188
- // Announced to screen readers automatically
189
- ```
190
-
191
- ## Form Accessibility
192
-
193
- ### Labels and Descriptions
194
-
195
- **Always label inputs:**
196
- ```tsx
197
- import { Label } from "@/components/ui/label"
198
- import { Input } from "@/components/ui/input"
199
-
200
- <div>
201
- <Label htmlFor="email">Email</Label>
202
- <Input id="email" type="email" />
203
- </div>
204
- ```
205
-
206
- **Add descriptions:**
207
- ```tsx
208
- import { FormDescription, FormMessage } from "@/components/ui/form"
209
-
210
- <FormItem>
211
- <FormLabel>Username</FormLabel>
212
- <FormControl>
213
- <Input {...field} />
214
- </FormControl>
215
- <FormDescription>
216
- Your public display name
217
- </FormDescription>
218
- <FormMessage /> {/* Error messages */}
219
- </FormItem>
220
- ```
221
-
222
- ### Error Handling
223
-
224
- Announce errors to screen readers:
225
-
226
- ```tsx
227
- <FormField
228
- control={form.control}
229
- name="email"
230
- render={({ field, fieldState }) => (
231
- <FormItem>
232
- <FormLabel>Email</FormLabel>
233
- <FormControl>
234
- <Input
235
- {...field}
236
- aria-invalid={!!fieldState.error}
237
- aria-describedby={fieldState.error ? "email-error" : undefined}
238
- />
239
- </FormControl>
240
- <FormMessage id="email-error" />
241
- </FormItem>
242
- )}
243
- />
244
- ```
245
-
246
- ### Required Fields
247
-
248
- Indicate required fields:
249
-
250
- ```tsx
251
- <Label htmlFor="name">
252
- Name <span className="text-destructive">*</span>
253
- <span className="sr-only">(required)</span>
254
- </Label>
255
- <Input id="name" required />
256
- ```
257
-
258
- ### Fieldset and Legend
259
-
260
- Group related fields:
261
-
262
- ```tsx
263
- <fieldset>
264
- <legend className="text-lg font-semibold mb-4">
265
- Contact Information
266
- </legend>
267
- <div className="space-y-4">
268
- <FormField name="email" />
269
- <FormField name="phone" />
270
- </div>
271
- </fieldset>
272
- ```
273
-
274
- ## Component-Specific Patterns
275
-
276
- ### Accordion
277
-
278
- ```tsx
279
- import { Accordion } from "@/components/ui/accordion"
280
-
281
- <Accordion type="single" collapsible>
282
- <AccordionItem value="item-1">
283
- <AccordionTrigger>
284
- {/* Includes aria-expanded, aria-controls automatically */}
285
- Is it accessible?
286
- </AccordionTrigger>
287
- <AccordionContent>
288
- {/* Hidden when collapsed, announced when expanded */}
289
- Yes. Follows WAI-ARIA design pattern.
290
- </AccordionContent>
291
- </AccordionItem>
292
- </Accordion>
293
- ```
294
-
295
- ### Tabs
296
-
297
- ```tsx
298
- import { Tabs } from "@/components/ui/tabs"
299
-
300
- <Tabs defaultValue="account">
301
- <TabsList role="tablist">
302
- {/* Arrow keys navigate, Space/Enter activates */}
303
- <TabsTrigger value="account">Account</TabsTrigger>
304
- <TabsTrigger value="password">Password</TabsTrigger>
305
- </TabsList>
306
- <TabsContent value="account">
307
- {/* Hidden unless selected, aria-labelledby links to trigger */}
308
- Account content
309
- </TabsContent>
310
- </Tabs>
311
- ```
312
-
313
- ### Select
314
-
315
- ```tsx
316
- import { Select } from "@/components/ui/select"
317
-
318
- <Select>
319
- <SelectTrigger aria-label="Choose theme">
320
- <SelectValue placeholder="Theme" />
321
- </SelectTrigger>
322
- <SelectContent>
323
- {/* Keyboard navigable, announced to screen readers */}
324
- <SelectItem value="light">Light</SelectItem>
325
- <SelectItem value="dark">Dark</SelectItem>
326
- </SelectContent>
327
- </Select>
328
- ```
329
-
330
- ### Checkbox and Radio
331
-
332
- ```tsx
333
- import { Checkbox } from "@/components/ui/checkbox"
334
- import { Label } from "@/components/ui/label"
335
-
336
- <div className="flex items-center space-x-2">
337
- <Checkbox id="terms" aria-describedby="terms-description" />
338
- <Label htmlFor="terms">Accept terms</Label>
339
- </div>
340
- <p id="terms-description" className="text-sm text-muted-foreground">
341
- You agree to our Terms of Service and Privacy Policy
342
- </p>
343
- ```
344
-
345
- ### Alert
346
-
347
- ```tsx
348
- import { Alert } from "@/components/ui/alert"
349
-
350
- <Alert role="alert">
351
- {/* Announced immediately to screen readers */}
352
- <AlertTitle>Error</AlertTitle>
353
- <AlertDescription>
354
- Your session has expired
355
- </AlertDescription>
356
- </Alert>
357
- ```
358
-
359
- ## Color Contrast
360
-
361
- Ensure sufficient contrast between text and background.
362
-
363
- **WCAG Requirements:**
364
- - **AA**: 4.5:1 for normal text, 3:1 for large text
365
- - **AAA**: 7:1 for normal text, 4.5:1 for large text
366
-
367
- **Check defaults:**
368
- ```tsx
369
- // Good: High contrast
370
- <p className="text-gray-900 dark:text-gray-100">Text</p>
371
-
372
- // Avoid: Low contrast
373
- <p className="text-gray-400 dark:text-gray-600">Hard to read</p>
374
- ```
375
-
376
- **Muted text:**
377
- ```tsx
378
- // Use semantic muted foreground
379
- <p className="text-muted-foreground">
380
- Secondary text with accessible contrast
381
- </p>
382
- ```
383
-
384
- ## Focus Indicators
385
-
386
- Always provide visible focus indicators:
387
-
388
- **Default focus ring:**
389
- ```tsx
390
- <Button className="focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2">
391
- Button
392
- </Button>
393
- ```
394
-
395
- **Custom focus styles:**
396
- ```tsx
397
- <a href="#" className="focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary focus-visible:underline">
398
- Link
399
- </a>
400
- ```
401
-
402
- **Don't remove focus styles:**
403
- ```tsx
404
- // Avoid
405
- <button className="focus:outline-none">Bad</button>
406
-
407
- // Use focus-visible instead
408
- <button className="focus-visible:ring-2">Good</button>
409
- ```
410
-
411
- ## Motion and Animation
412
-
413
- Respect reduced motion preference:
414
-
415
- ```css
416
- @media (prefers-reduced-motion: reduce) {
417
- * {
418
- animation-duration: 0.01ms !important;
419
- animation-iteration-count: 1 !important;
420
- transition-duration: 0.01ms !important;
421
- }
422
- }
423
- ```
424
-
425
- In components:
426
- ```tsx
427
- <div className="transition-all motion-reduce:transition-none">
428
- Respects user preference
429
- </div>
430
- ```
431
-
432
- ## Testing Checklist
433
-
434
- - [ ] All interactive elements keyboard accessible
435
- - [ ] Focus indicators visible
436
- - [ ] Screen reader announces all content correctly
437
- - [ ] Form errors announced and associated
438
- - [ ] Color contrast meets WCAG AA
439
- - [ ] Semantic HTML used
440
- - [ ] ARIA labels provided for icon-only buttons
441
- - [ ] Modal/dialog focus trap works
442
- - [ ] Dropdown/select keyboard navigable
443
- - [ ] Live regions announce updates
444
- - [ ] Respects reduced motion preference
445
- - [ ] Works with browser zoom up to 200%
446
- - [ ] Tab order logical
447
- - [ ] Skip links provided for navigation
448
-
449
- ## Tools
450
-
451
- **Testing tools:**
452
- - Lighthouse accessibility audit
453
- - axe DevTools browser extension
454
- - NVDA/JAWS screen readers
455
- - Keyboard-only navigation testing
456
- - Color contrast checkers (Contrast Ratio, WebAIM)
457
-
458
- **Automated testing:**
459
- ```bash
460
- npm install -D @axe-core/react
461
- ```
462
-
463
- ```tsx
464
- import { useEffect } from 'react'
465
-
466
- if (process.env.NODE_ENV === 'development') {
467
- import('@axe-core/react').then((axe) => {
468
- axe.default(React, ReactDOM, 1000)
469
- })
470
- }
471
- ```
1
+ # shadcn/ui Accessibility Patterns
2
+
3
+ ARIA patterns, keyboard navigation, screen reader support, and accessible component usage.
4
+
5
+ ## Foundation: Radix UI Primitives
6
+
7
+ shadcn/ui built on Radix UI primitives - unstyled, accessible components following WAI-ARIA design patterns.
8
+
9
+ Benefits:
10
+ - Keyboard navigation built-in
11
+ - Screen reader announcements
12
+ - Focus management
13
+ - ARIA attributes automatically applied
14
+ - Tested against accessibility standards
15
+
16
+ ## Keyboard Navigation
17
+
18
+ ### Focus Management
19
+
20
+ **Focus visible states:**
21
+ ```tsx
22
+ <Button className="focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2">
23
+ Accessible Button
24
+ </Button>
25
+ ```
26
+
27
+ **Skip to content:**
28
+ ```tsx
29
+ <a href="#main-content" className="sr-only focus:not-sr-only focus:absolute focus:top-4 focus:left-4 focus:z-50 focus:px-4 focus:py-2">
30
+ Skip to content
31
+ </a>
32
+
33
+ <main id="main-content">
34
+ {/* Content */}
35
+ </main>
36
+ ```
37
+
38
+ ### Dialog/Modal Navigation
39
+
40
+ Dialogs trap focus automatically via Radix Dialog primitive:
41
+
42
+ ```tsx
43
+ import { Dialog, DialogContent, DialogTrigger } from "@/components/ui/dialog"
44
+
45
+ <Dialog>
46
+ <DialogTrigger>Open</DialogTrigger>
47
+ <DialogContent>
48
+ {/* Focus trapped here */}
49
+ <input /> {/* Auto-focused */}
50
+ <Button>Action</Button>
51
+ {/* Esc to close, Tab to navigate */}
52
+ </DialogContent>
53
+ </Dialog>
54
+ ```
55
+
56
+ Features:
57
+ - Focus trapped within dialog
58
+ - Esc key closes
59
+ - Tab cycles through focusable elements
60
+ - Focus returns to trigger on close
61
+
62
+ ### Dropdown/Menu Navigation
63
+
64
+ ```tsx
65
+ import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from "@/components/ui/dropdown-menu"
66
+
67
+ <DropdownMenu>
68
+ <DropdownMenuTrigger>Open</DropdownMenuTrigger>
69
+ <DropdownMenuContent>
70
+ <DropdownMenuItem>Profile</DropdownMenuItem>
71
+ <DropdownMenuItem>Settings</DropdownMenuItem>
72
+ <DropdownMenuItem>Logout</DropdownMenuItem>
73
+ </DropdownMenuContent>
74
+ </DropdownMenu>
75
+ ```
76
+
77
+ Keyboard shortcuts:
78
+ - `Space/Enter`: Open menu
79
+ - `Arrow Up/Down`: Navigate items
80
+ - `Esc`: Close menu
81
+ - `Tab`: Close and move focus
82
+
83
+ ### Command Palette Navigation
84
+
85
+ ```tsx
86
+ import { Command } from "@/components/ui/command"
87
+
88
+ <Command>
89
+ <CommandInput placeholder="Search..." />
90
+ <CommandList>
91
+ <CommandGroup heading="Suggestions">
92
+ <CommandItem>Calendar</CommandItem>
93
+ <CommandItem>Search</CommandItem>
94
+ </CommandGroup>
95
+ </CommandList>
96
+ </Command>
97
+ ```
98
+
99
+ Features:
100
+ - Type to filter
101
+ - Arrow keys to navigate
102
+ - Enter to select
103
+ - Esc to close
104
+
105
+ ## Screen Reader Support
106
+
107
+ ### Semantic HTML
108
+
109
+ Use proper HTML elements:
110
+
111
+ ```tsx
112
+ // Good: Semantic HTML
113
+ <button>Click me</button>
114
+ <nav><a href="/">Home</a></nav>
115
+
116
+ // Avoid: Div soup
117
+ <div onClick={handler}>Click me</div>
118
+ ```
119
+
120
+ ### ARIA Labels
121
+
122
+ **Label interactive elements:**
123
+ ```tsx
124
+ <Button aria-label="Close dialog">
125
+ <X className="h-4 w-4" />
126
+ </Button>
127
+
128
+ <Input aria-label="Email address" type="email" />
129
+ ```
130
+
131
+ **Describe elements:**
132
+ ```tsx
133
+ <Button aria-describedby="delete-description">
134
+ Delete Account
135
+ </Button>
136
+ <p id="delete-description" className="sr-only">
137
+ This action permanently deletes your account and cannot be undone
138
+ </p>
139
+ ```
140
+
141
+ ### Screen Reader Only Text
142
+
143
+ Use `sr-only` class for screen reader only content:
144
+
145
+ ```tsx
146
+ <Button>
147
+ <Trash className="h-4 w-4" />
148
+ <span className="sr-only">Delete item</span>
149
+ </Button>
150
+
151
+ // CSS for sr-only
152
+ .sr-only {
153
+ position: absolute;
154
+ width: 1px;
155
+ height: 1px;
156
+ padding: 0;
157
+ margin: -1px;
158
+ overflow: hidden;
159
+ clip: rect(0, 0, 0, 0);
160
+ white-space: nowrap;
161
+ border-width: 0;
162
+ }
163
+ ```
164
+
165
+ ### Live Regions
166
+
167
+ Announce dynamic content:
168
+
169
+ ```tsx
170
+ <div aria-live="polite" aria-atomic="true">
171
+ {message}
172
+ </div>
173
+
174
+ // For urgent updates
175
+ <div aria-live="assertive">
176
+ {error}
177
+ </div>
178
+ ```
179
+
180
+ Toast component includes live region:
181
+ ```tsx
182
+ const { toast } = useToast()
183
+
184
+ toast({
185
+ title: "Success",
186
+ description: "Profile updated"
187
+ })
188
+ // Announced to screen readers automatically
189
+ ```
190
+
191
+ ## Form Accessibility
192
+
193
+ ### Labels and Descriptions
194
+
195
+ **Always label inputs:**
196
+ ```tsx
197
+ import { Label } from "@/components/ui/label"
198
+ import { Input } from "@/components/ui/input"
199
+
200
+ <div>
201
+ <Label htmlFor="email">Email</Label>
202
+ <Input id="email" type="email" />
203
+ </div>
204
+ ```
205
+
206
+ **Add descriptions:**
207
+ ```tsx
208
+ import { FormDescription, FormMessage } from "@/components/ui/form"
209
+
210
+ <FormItem>
211
+ <FormLabel>Username</FormLabel>
212
+ <FormControl>
213
+ <Input {...field} />
214
+ </FormControl>
215
+ <FormDescription>
216
+ Your public display name
217
+ </FormDescription>
218
+ <FormMessage /> {/* Error messages */}
219
+ </FormItem>
220
+ ```
221
+
222
+ ### Error Handling
223
+
224
+ Announce errors to screen readers:
225
+
226
+ ```tsx
227
+ <FormField
228
+ control={form.control}
229
+ name="email"
230
+ render={({ field, fieldState }) => (
231
+ <FormItem>
232
+ <FormLabel>Email</FormLabel>
233
+ <FormControl>
234
+ <Input
235
+ {...field}
236
+ aria-invalid={!!fieldState.error}
237
+ aria-describedby={fieldState.error ? "email-error" : undefined}
238
+ />
239
+ </FormControl>
240
+ <FormMessage id="email-error" />
241
+ </FormItem>
242
+ )}
243
+ />
244
+ ```
245
+
246
+ ### Required Fields
247
+
248
+ Indicate required fields:
249
+
250
+ ```tsx
251
+ <Label htmlFor="name">
252
+ Name <span className="text-destructive">*</span>
253
+ <span className="sr-only">(required)</span>
254
+ </Label>
255
+ <Input id="name" required />
256
+ ```
257
+
258
+ ### Fieldset and Legend
259
+
260
+ Group related fields:
261
+
262
+ ```tsx
263
+ <fieldset>
264
+ <legend className="text-lg font-semibold mb-4">
265
+ Contact Information
266
+ </legend>
267
+ <div className="space-y-4">
268
+ <FormField name="email" />
269
+ <FormField name="phone" />
270
+ </div>
271
+ </fieldset>
272
+ ```
273
+
274
+ ## Component-Specific Patterns
275
+
276
+ ### Accordion
277
+
278
+ ```tsx
279
+ import { Accordion } from "@/components/ui/accordion"
280
+
281
+ <Accordion type="single" collapsible>
282
+ <AccordionItem value="item-1">
283
+ <AccordionTrigger>
284
+ {/* Includes aria-expanded, aria-controls automatically */}
285
+ Is it accessible?
286
+ </AccordionTrigger>
287
+ <AccordionContent>
288
+ {/* Hidden when collapsed, announced when expanded */}
289
+ Yes. Follows WAI-ARIA design pattern.
290
+ </AccordionContent>
291
+ </AccordionItem>
292
+ </Accordion>
293
+ ```
294
+
295
+ ### Tabs
296
+
297
+ ```tsx
298
+ import { Tabs } from "@/components/ui/tabs"
299
+
300
+ <Tabs defaultValue="account">
301
+ <TabsList role="tablist">
302
+ {/* Arrow keys navigate, Space/Enter activates */}
303
+ <TabsTrigger value="account">Account</TabsTrigger>
304
+ <TabsTrigger value="password">Password</TabsTrigger>
305
+ </TabsList>
306
+ <TabsContent value="account">
307
+ {/* Hidden unless selected, aria-labelledby links to trigger */}
308
+ Account content
309
+ </TabsContent>
310
+ </Tabs>
311
+ ```
312
+
313
+ ### Select
314
+
315
+ ```tsx
316
+ import { Select } from "@/components/ui/select"
317
+
318
+ <Select>
319
+ <SelectTrigger aria-label="Choose theme">
320
+ <SelectValue placeholder="Theme" />
321
+ </SelectTrigger>
322
+ <SelectContent>
323
+ {/* Keyboard navigable, announced to screen readers */}
324
+ <SelectItem value="light">Light</SelectItem>
325
+ <SelectItem value="dark">Dark</SelectItem>
326
+ </SelectContent>
327
+ </Select>
328
+ ```
329
+
330
+ ### Checkbox and Radio
331
+
332
+ ```tsx
333
+ import { Checkbox } from "@/components/ui/checkbox"
334
+ import { Label } from "@/components/ui/label"
335
+
336
+ <div className="flex items-center space-x-2">
337
+ <Checkbox id="terms" aria-describedby="terms-description" />
338
+ <Label htmlFor="terms">Accept terms</Label>
339
+ </div>
340
+ <p id="terms-description" className="text-sm text-muted-foreground">
341
+ You agree to our Terms of Service and Privacy Policy
342
+ </p>
343
+ ```
344
+
345
+ ### Alert
346
+
347
+ ```tsx
348
+ import { Alert } from "@/components/ui/alert"
349
+
350
+ <Alert role="alert">
351
+ {/* Announced immediately to screen readers */}
352
+ <AlertTitle>Error</AlertTitle>
353
+ <AlertDescription>
354
+ Your session has expired
355
+ </AlertDescription>
356
+ </Alert>
357
+ ```
358
+
359
+ ## Color Contrast
360
+
361
+ Ensure sufficient contrast between text and background.
362
+
363
+ **WCAG Requirements:**
364
+ - **AA**: 4.5:1 for normal text, 3:1 for large text
365
+ - **AAA**: 7:1 for normal text, 4.5:1 for large text
366
+
367
+ **Check defaults:**
368
+ ```tsx
369
+ // Good: High contrast
370
+ <p className="text-gray-900 dark:text-gray-100">Text</p>
371
+
372
+ // Avoid: Low contrast
373
+ <p className="text-gray-400 dark:text-gray-600">Hard to read</p>
374
+ ```
375
+
376
+ **Muted text:**
377
+ ```tsx
378
+ // Use semantic muted foreground
379
+ <p className="text-muted-foreground">
380
+ Secondary text with accessible contrast
381
+ </p>
382
+ ```
383
+
384
+ ## Focus Indicators
385
+
386
+ Always provide visible focus indicators:
387
+
388
+ **Default focus ring:**
389
+ ```tsx
390
+ <Button className="focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2">
391
+ Button
392
+ </Button>
393
+ ```
394
+
395
+ **Custom focus styles:**
396
+ ```tsx
397
+ <a href="#" className="focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary focus-visible:underline">
398
+ Link
399
+ </a>
400
+ ```
401
+
402
+ **Don't remove focus styles:**
403
+ ```tsx
404
+ // Avoid
405
+ <button className="focus:outline-none">Bad</button>
406
+
407
+ // Use focus-visible instead
408
+ <button className="focus-visible:ring-2">Good</button>
409
+ ```
410
+
411
+ ## Motion and Animation
412
+
413
+ Respect reduced motion preference:
414
+
415
+ ```css
416
+ @media (prefers-reduced-motion: reduce) {
417
+ * {
418
+ animation-duration: 0.01ms !important;
419
+ animation-iteration-count: 1 !important;
420
+ transition-duration: 0.01ms !important;
421
+ }
422
+ }
423
+ ```
424
+
425
+ In components:
426
+ ```tsx
427
+ <div className="transition-all motion-reduce:transition-none">
428
+ Respects user preference
429
+ </div>
430
+ ```
431
+
432
+ ## Testing Checklist
433
+
434
+ - [ ] All interactive elements keyboard accessible
435
+ - [ ] Focus indicators visible
436
+ - [ ] Screen reader announces all content correctly
437
+ - [ ] Form errors announced and associated
438
+ - [ ] Color contrast meets WCAG AA
439
+ - [ ] Semantic HTML used
440
+ - [ ] ARIA labels provided for icon-only buttons
441
+ - [ ] Modal/dialog focus trap works
442
+ - [ ] Dropdown/select keyboard navigable
443
+ - [ ] Live regions announce updates
444
+ - [ ] Respects reduced motion preference
445
+ - [ ] Works with browser zoom up to 200%
446
+ - [ ] Tab order logical
447
+ - [ ] Skip links provided for navigation
448
+
449
+ ## Tools
450
+
451
+ **Testing tools:**
452
+ - Lighthouse accessibility audit
453
+ - axe DevTools browser extension
454
+ - NVDA/JAWS screen readers
455
+ - Keyboard-only navigation testing
456
+ - Color contrast checkers (Contrast Ratio, WebAIM)
457
+
458
+ **Automated testing:**
459
+ ```bash
460
+ npm install -D @axe-core/react
461
+ ```
462
+
463
+ ```tsx
464
+ import { useEffect } from 'react'
465
+
466
+ if (process.env.NODE_ENV === 'development') {
467
+ import('@axe-core/react').then((axe) => {
468
+ axe.default(React, ReactDOM, 1000)
469
+ })
470
+ }
471
+ ```