@saulwade/swl-ses 1.0.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 (702) hide show
  1. package/CLAUDE.md +238 -0
  2. package/README.md +560 -0
  3. package/_userland/agentes/.gitkeep +0 -0
  4. package/_userland/habilidades/.gitkeep +0 -0
  5. package/agentes/.evolved.json +9 -0
  6. package/agentes/accesibilidad-wcag-swl.md +692 -0
  7. package/agentes/arquitecto-swl.md +238 -0
  8. package/agentes/auto-evolucion-swl.md +854 -0
  9. package/agentes/backend-api-swl.md +470 -0
  10. package/agentes/backend-csharp-swl.md +418 -0
  11. package/agentes/backend-go-swl.md +388 -0
  12. package/agentes/backend-java-swl.md +279 -0
  13. package/agentes/backend-node-swl.md +477 -0
  14. package/agentes/backend-python-swl.md +608 -0
  15. package/agentes/backend-rust-swl.md +362 -0
  16. package/agentes/backend-workers-swl.md +480 -0
  17. package/agentes/cloud-infra-swl.md +485 -0
  18. package/agentes/consolidador-swl.md +539 -0
  19. package/agentes/datos-swl.md +584 -0
  20. package/agentes/depurador-swl.md +349 -0
  21. package/agentes/devops-ci-swl.md +374 -0
  22. package/agentes/disenador-ui-swl.md +558 -0
  23. package/agentes/documentador-swl.md +343 -0
  24. package/agentes/evals/arquitecto-swl.evals.json +56 -0
  25. package/agentes/evals/auto-evolucion-swl.evals.json +68 -0
  26. package/agentes/evals/implementador-swl.evals.json +56 -0
  27. package/agentes/evals/orquestador-swl.evals.json +60 -0
  28. package/agentes/evals/perfilador-usuario-swl.evals.json +60 -0
  29. package/agentes/evals/red-team-swl.evals.json +59 -0
  30. package/agentes/evals/revisor-codigo-swl.evals.json +59 -0
  31. package/agentes/frontend-angular-swl.md +627 -0
  32. package/agentes/frontend-css-swl.md +720 -0
  33. package/agentes/frontend-react-swl.md +696 -0
  34. package/agentes/frontend-swl.md +500 -0
  35. package/agentes/frontend-tailwind-swl.md +830 -0
  36. package/agentes/implementador-swl.md +328 -0
  37. package/agentes/investigador-swl.md +430 -0
  38. package/agentes/investigador-ux-swl.md +500 -0
  39. package/agentes/llm-apps-swl.md +276 -0
  40. package/agentes/migrador-swl.md +417 -0
  41. package/agentes/mobile-android-swl.md +509 -0
  42. package/agentes/mobile-cross-swl.md +539 -0
  43. package/agentes/mobile-ios-swl.md +500 -0
  44. package/agentes/mobile-testing-swl.md +300 -0
  45. package/agentes/notificador-swl.md +916 -0
  46. package/agentes/observabilidad-swl.md +436 -0
  47. package/agentes/orquestador-swl.md +884 -0
  48. package/agentes/pagos-swl.md +283 -0
  49. package/agentes/perfilador-usuario-swl.md +306 -0
  50. package/agentes/planificador-swl.md +402 -0
  51. package/agentes/producto-prd-swl.md +587 -0
  52. package/agentes/red-team-swl.md +216 -0
  53. package/agentes/release-manager-swl.md +568 -0
  54. package/agentes/rendimiento-swl.md +714 -0
  55. package/agentes/resolutor-build-swl.md +243 -0
  56. package/agentes/revisor-angular-swl.md +276 -0
  57. package/agentes/revisor-codigo-swl.md +348 -0
  58. package/agentes/revisor-csharp-swl.md +262 -0
  59. package/agentes/revisor-go-swl.md +257 -0
  60. package/agentes/revisor-java-swl.md +255 -0
  61. package/agentes/revisor-kotlin-swl.md +271 -0
  62. package/agentes/revisor-nextjs-swl.md +279 -0
  63. package/agentes/revisor-php-swl.md +269 -0
  64. package/agentes/revisor-react-swl.md +276 -0
  65. package/agentes/revisor-rust-swl.md +344 -0
  66. package/agentes/revisor-seguridad-swl.md +390 -0
  67. package/agentes/revisor-swift-swl.md +266 -0
  68. package/agentes/revisor-typescript-swl.md +344 -0
  69. package/agentes/sre-swl.md +265 -0
  70. package/agentes/tdd-qa-swl.md +354 -0
  71. package/agentes/ux-disenador-swl.md +501 -0
  72. package/bin/lib/bot-comandos.js +1030 -0
  73. package/bin/lib/bot-discovery.js +182 -0
  74. package/bin/lib/bot-git.js +142 -0
  75. package/bin/swl-ses.js +325 -0
  76. package/bin/swl-telegram-bot.js +442 -0
  77. package/bin/swl-telegram-bot.plist +21 -0
  78. package/bin/swl-telegram-bot.service +14 -0
  79. package/comandos/swl/.evolved.json +23 -0
  80. package/comandos/swl/actualizar.md +174 -0
  81. package/comandos/swl/adoptar-proyecto.md +207 -0
  82. package/comandos/swl/aprender.md +701 -0
  83. package/comandos/swl/auditar-deps.md +134 -0
  84. package/comandos/swl/autoresearch.md +170 -0
  85. package/comandos/swl/ayuda.md +224 -0
  86. package/comandos/swl/brainstorm.md +50 -0
  87. package/comandos/swl/checkpoint.md +330 -0
  88. package/comandos/swl/compactar.md +283 -0
  89. package/comandos/swl/configurar-ci.md +227 -0
  90. package/comandos/swl/contexto.md +112 -0
  91. package/comandos/swl/contribuir.md +233 -0
  92. package/comandos/swl/crear-skill.md +292 -0
  93. package/comandos/swl/cron.md +196 -0
  94. package/comandos/swl/dashboard.md +146 -0
  95. package/comandos/swl/discutir-fase.md +230 -0
  96. package/comandos/swl/ejecutar-fase.md +135 -0
  97. package/comandos/swl/evaluar-skill.md +487 -0
  98. package/comandos/swl/evolucion-estado.md +142 -0
  99. package/comandos/swl/evolucionar.md +259 -0
  100. package/comandos/swl/exportar-vault.md +189 -0
  101. package/comandos/swl/gateway.md +158 -0
  102. package/comandos/swl/inbox.md +116 -0
  103. package/comandos/swl/instalar.md +220 -0
  104. package/comandos/swl/instintos.md +86 -0
  105. package/comandos/swl/mapear-codebase.md +312 -0
  106. package/comandos/swl/mcp-status.md +175 -0
  107. package/comandos/swl/metricas.md +270 -0
  108. package/comandos/swl/modelo.md +102 -0
  109. package/comandos/swl/notificaciones.md +396 -0
  110. package/comandos/swl/nuevo-proyecto.md +154 -0
  111. package/comandos/swl/planear-fase.md +221 -0
  112. package/comandos/swl/plugins.md +256 -0
  113. package/comandos/swl/reflect-skills.md +125 -0
  114. package/comandos/swl/release.md +217 -0
  115. package/comandos/swl/revisar-impacto.md +206 -0
  116. package/comandos/swl/revisar.md +330 -0
  117. package/comandos/swl/salud.md +363 -0
  118. package/comandos/swl/sesiones.md +200 -0
  119. package/comandos/swl/skill-search.md +113 -0
  120. package/comandos/swl/verificar.md +585 -0
  121. package/comandos/swl/wiki.md +620 -0
  122. package/contextos/dev.md +32 -0
  123. package/contextos/research.md +30 -0
  124. package/contextos/review.md +31 -0
  125. package/habilidades/accesibilidad-a11y/SKILL.md +201 -0
  126. package/habilidades/accesibilidad-a11y/evals/evals.json +56 -0
  127. package/habilidades/accesibilidad-a11y/recursos/ejemplos-y-checklist-completo.md +441 -0
  128. package/habilidades/agent-browser/SKILL.md +218 -0
  129. package/habilidades/agentes-como-servicio/SKILL.md +218 -0
  130. package/habilidades/ai-runtime-security/SKILL.md +273 -0
  131. package/habilidades/angular-avanzado/SKILL.md +164 -0
  132. package/habilidades/angular-avanzado/recursos/ejemplos-avanzados.md +219 -0
  133. package/habilidades/angular-moderno/SKILL.md +186 -0
  134. package/habilidades/angular-moderno/evals/evals.json +45 -0
  135. package/habilidades/angular-moderno/recursos/ejemplos-avanzados.md +106 -0
  136. package/habilidades/api-rest-diseno/SKILL.md +191 -0
  137. package/habilidades/api-rest-diseno/recursos/openapi-template.yaml +506 -0
  138. package/habilidades/api-rest-diseno/recursos/referencia-api.md +140 -0
  139. package/habilidades/aprendizaje-continuo/SKILL.md +151 -0
  140. package/habilidades/aprendizaje-continuo/evals/evals.json +53 -0
  141. package/habilidades/aprendizaje-continuo/recursos/referencia-instintos.md +290 -0
  142. package/habilidades/async-python/SKILL.md +149 -0
  143. package/habilidades/async-python/evals/evals.json +47 -0
  144. package/habilidades/async-python/recursos/patrones-y-ejemplos-completos.md +292 -0
  145. package/habilidades/auth-patrones/.evolved.json +9 -0
  146. package/habilidades/auth-patrones/SKILL.md +413 -0
  147. package/habilidades/auth-patrones/recursos/implementaciones-completas.md +229 -0
  148. package/habilidades/auto-evolucion-protocolo/SKILL.md +276 -0
  149. package/habilidades/auto-evolucion-protocolo/evals/evals.json +55 -0
  150. package/habilidades/auto-evolucion-protocolo/recursos/referencia-completa.md +145 -0
  151. package/habilidades/autoresearch/SKILL.md +268 -0
  152. package/habilidades/autoresearch/evals/evals.json +41 -0
  153. package/habilidades/autoresearch/recursos/checklist-template.md +191 -0
  154. package/habilidades/autoresearch/scripts/calcular-score.js +88 -0
  155. package/habilidades/azure-cloud/SKILL.md +308 -0
  156. package/habilidades/azure-cloud/recursos/aks.md +327 -0
  157. package/habilidades/backend-mcp-servidor/SKILL.md +270 -0
  158. package/habilidades/backend-production-resilience/SKILL.md +288 -0
  159. package/habilidades/brainstorming/SKILL.md +295 -0
  160. package/habilidades/brainstorming/recursos/componentes-html.md +247 -0
  161. package/habilidades/build-errors-cpp/SKILL.md +270 -0
  162. package/habilidades/build-errors-csharp/SKILL.md +265 -0
  163. package/habilidades/build-errors-go/SKILL.md +306 -0
  164. package/habilidades/build-errors-java/SKILL.md +278 -0
  165. package/habilidades/build-errors-kotlin/SKILL.md +303 -0
  166. package/habilidades/build-errors-nextjs/SKILL.md +312 -0
  167. package/habilidades/build-errors-php/SKILL.md +270 -0
  168. package/habilidades/build-errors-python/SKILL.md +292 -0
  169. package/habilidades/build-errors-rust/SKILL.md +284 -0
  170. package/habilidades/build-errors-swift/SKILL.md +272 -0
  171. package/habilidades/build-errors-typescript/SKILL.md +369 -0
  172. package/habilidades/checklist-calidad/SKILL.md +271 -0
  173. package/habilidades/checklist-calidad/recursos/quality-report-template.md +148 -0
  174. package/habilidades/checklist-seguridad/SKILL.md +285 -0
  175. package/habilidades/checkpoints-verificacion/SKILL.md +298 -0
  176. package/habilidades/checkpoints-verificacion/recursos/checkpoint-templates.md +360 -0
  177. package/habilidades/ci-cd-pipelines/SKILL.md +157 -0
  178. package/habilidades/ci-cd-pipelines/recursos/github-actions-template.yaml +403 -0
  179. package/habilidades/ci-cd-pipelines/recursos/pipelines-completos.md +487 -0
  180. package/habilidades/cloud-aws/SKILL.md +142 -0
  181. package/habilidades/cloud-aws/recursos/servicios-aws-referencia.md +321 -0
  182. package/habilidades/compactacion-contexto/SKILL.md +247 -0
  183. package/habilidades/contenedores-docker/SKILL.md +137 -0
  184. package/habilidades/contenedores-docker/recursos/dockerfile-template.dockerfile +160 -0
  185. package/habilidades/contenedores-docker/recursos/ejemplos-y-configuraciones.md +327 -0
  186. package/habilidades/context-builder/SKILL.md +170 -0
  187. package/habilidades/control-profundidad/SKILL.md +128 -0
  188. package/habilidades/csharp-experto/SKILL.md +322 -0
  189. package/habilidades/csharp-patrones/SKILL.md +316 -0
  190. package/habilidades/csharp-testing/SKILL.md +286 -0
  191. package/habilidades/css-moderno/SKILL.md +166 -0
  192. package/habilidades/css-moderno/evals/evals.json +43 -0
  193. package/habilidades/css-moderno/recursos/ejemplos-y-patrones-completos.md +337 -0
  194. package/habilidades/datos-etl/SKILL.md +129 -0
  195. package/habilidades/datos-etl/recursos/implementaciones-completas.md +322 -0
  196. package/habilidades/dbml-experto/SKILL.md +339 -0
  197. package/habilidades/dbml-experto/evals/evals.json +56 -0
  198. package/habilidades/dependencias-auditoria/SKILL.md +320 -0
  199. package/habilidades/deprecacion-migracion/SKILL.md +169 -0
  200. package/habilidades/deprecacion-migracion/recursos/implementaciones-completas.md +220 -0
  201. package/habilidades/design-tokens/SKILL.md +158 -0
  202. package/habilidades/design-tokens/recursos/tokens-y-configuracion.md +363 -0
  203. package/habilidades/devsecops-pipeline-security/SKILL.md +309 -0
  204. package/habilidades/diagrama-arquitectura/SKILL.md +165 -0
  205. package/habilidades/diagrama-arquitectura/assets/template.html +276 -0
  206. package/habilidades/discutir-fase/SKILL.md +188 -0
  207. package/habilidades/diseno-herramientas-agente/SKILL.md +199 -0
  208. package/habilidades/diseno-responsivo/SKILL.md +186 -0
  209. package/habilidades/diseno-responsivo/recursos/ejemplos-layouts.md +156 -0
  210. package/habilidades/django-experto/SKILL.md +205 -0
  211. package/habilidades/django-experto/recursos/async-django.md +390 -0
  212. package/habilidades/django-experto/recursos/drf-patrones.md +438 -0
  213. package/habilidades/django-experto/recursos/orm-avanzado.md +382 -0
  214. package/habilidades/django-experto/recursos/referencia-completa.md +188 -0
  215. package/habilidades/django-experto/recursos/testing-django.md +415 -0
  216. package/habilidades/doc-sync/SKILL.md +280 -0
  217. package/habilidades/drift-detection/SKILL.md +179 -0
  218. package/habilidades/ejecutar-fase/SKILL.md +468 -0
  219. package/habilidades/estilo-sin-ai-isms/SKILL.md +775 -0
  220. package/habilidades/estilo-sin-ai-isms/evals/evals.json +63 -0
  221. package/habilidades/estilo-sin-ai-isms/scripts/detectar_aiisms.py +500 -0
  222. package/habilidades/estructura-proyecto-claude/SKILL.md +215 -0
  223. package/habilidades/estructura-proyecto-claude/recursos/claude-md-template.md +261 -0
  224. package/habilidades/estructura-proyecto-claude/recursos/configuracion-y-extensiones.md +176 -0
  225. package/habilidades/estructura-proyecto-claude/recursos/frontmatter-y-hooks-referencia.md +289 -0
  226. package/habilidades/estructura-proyecto-claude/recursos/mcp-json-template.json +77 -0
  227. package/habilidades/estructura-proyecto-claude/recursos/variantes-por-stack.md +177 -0
  228. package/habilidades/evaluacion-agentes/SKILL.md +314 -0
  229. package/habilidades/event-driven/SKILL.md +153 -0
  230. package/habilidades/event-driven/recursos/implementaciones-completas.md +423 -0
  231. package/habilidades/extraccion-documentos/SKILL.md +221 -0
  232. package/habilidades/extractor-de-aprendizajes/.evolved.json +9 -0
  233. package/habilidades/extractor-de-aprendizajes/SKILL.md +311 -0
  234. package/habilidades/extractor-de-aprendizajes/evals/evals.json +55 -0
  235. package/habilidades/fastapi-experto/SKILL.md +221 -0
  236. package/habilidades/fastapi-experto/recursos/async-patterns.md +438 -0
  237. package/habilidades/fastapi-experto/recursos/dependency-injection.md +330 -0
  238. package/habilidades/fastapi-experto/recursos/referencia-completa.md +79 -0
  239. package/habilidades/fastapi-experto/recursos/testing-httpx.md +420 -0
  240. package/habilidades/filament-admin/SKILL.md +290 -0
  241. package/habilidades/frontend-avanzado/SKILL.md +257 -0
  242. package/habilidades/frontend-avanzado/recursos/apis-nativas-ejemplos.md +341 -0
  243. package/habilidades/gcp-cloud/SKILL.md +260 -0
  244. package/habilidades/gcp-cloud/recursos/gke.md +234 -0
  245. package/habilidades/gcp-cloud/recursos/terraform-gcp.md +307 -0
  246. package/habilidades/generacion-mermaid/SKILL.md +229 -0
  247. package/habilidades/git-worktrees-paralelo/SKILL.md +270 -0
  248. package/habilidades/go-experto/SKILL.md +305 -0
  249. package/habilidades/go-patrones/SKILL.md +299 -0
  250. package/habilidades/go-testing/SKILL.md +291 -0
  251. package/habilidades/graphql-experto/SKILL.md +323 -0
  252. package/habilidades/guardrail-semantico/SKILL.md +282 -0
  253. package/habilidades/harness-claude-code/SKILL.md +299 -0
  254. package/habilidades/iam-secretos/SKILL.md +265 -0
  255. package/habilidades/iam-secretos/recursos/implementaciones-completas.md +356 -0
  256. package/habilidades/infra-github-actions/SKILL.md +166 -0
  257. package/habilidades/instalar-sistema/.evolved.json +9 -0
  258. package/habilidades/instalar-sistema/SKILL.md +221 -0
  259. package/habilidades/java-experto/SKILL.md +290 -0
  260. package/habilidades/java-patrones/SKILL.md +275 -0
  261. package/habilidades/java-testing/SKILL.md +288 -0
  262. package/habilidades/kotlin-compose/SKILL.md +278 -0
  263. package/habilidades/kotlin-compose/recursos/animaciones-performance.md +93 -0
  264. package/habilidades/kotlin-experto/SKILL.md +318 -0
  265. package/habilidades/kotlin-testing/SKILL.md +267 -0
  266. package/habilidades/kotlin-testing/recursos/testing-avanzado.md +74 -0
  267. package/habilidades/kubernetes-orquestacion/SKILL.md +152 -0
  268. package/habilidades/kubernetes-orquestacion/recursos/manifiestos-completos.md +452 -0
  269. package/habilidades/langchain-langraph/SKILL.md +386 -0
  270. package/habilidades/langchain-langraph/recursos/evaluacion-rag.md +321 -0
  271. package/habilidades/langchain-langraph/recursos/rag-maturity-model.md +225 -0
  272. package/habilidades/langchain-langraph/recursos/vectorstores.md +306 -0
  273. package/habilidades/legacy-code-rescue/SKILL.md +267 -0
  274. package/habilidades/likec4-experto/SKILL.md +412 -0
  275. package/habilidades/likec4-experto/evals/evals.json +69 -0
  276. package/habilidades/manejo-errores/.evolved.json +9 -0
  277. package/habilidades/manejo-errores/SKILL.md +407 -0
  278. package/habilidades/manejo-errores/recursos/implementaciones-completas.md +248 -0
  279. package/habilidades/mapear-codebase/SKILL.md +275 -0
  280. package/habilidades/memoria-busqueda/SKILL.md +194 -0
  281. package/habilidades/memoria-busqueda/evals/evals.json +44 -0
  282. package/habilidades/meta-skills-estandar/SKILL.md +298 -0
  283. package/habilidades/meta-skills-estandar/recursos/anti-patrones-y-leyes.md +205 -0
  284. package/habilidades/meta-skills-estandar/recursos/frameworks-seguridad.md +107 -0
  285. package/habilidades/meta-skills-estandar/recursos/idiomas-framework.md +60 -0
  286. package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -0
  287. package/habilidades/microservicios/SKILL.md +155 -0
  288. package/habilidades/microservicios/recursos/patrones-y-ejemplos-completos.md +325 -0
  289. package/habilidades/mobile-flutter/SKILL.md +199 -0
  290. package/habilidades/mobile-flutter/recursos/ejemplos-completos.md +319 -0
  291. package/habilidades/mobile-react-native/SKILL.md +176 -0
  292. package/habilidades/mobile-react-native/recursos/ejemplos-completos.md +216 -0
  293. package/habilidades/mongodb-experto/SKILL.md +302 -0
  294. package/habilidades/monitoring-alertas/SKILL.md +201 -0
  295. package/habilidades/monitoring-alertas/recursos/instrumentacion-y-alertas.md +301 -0
  296. package/habilidades/nestjs-experto/SKILL.md +307 -0
  297. package/habilidades/nestjs-experto/recursos/guards-interceptors.md +339 -0
  298. package/habilidades/nestjs-experto/recursos/modulos-di.md +287 -0
  299. package/habilidades/nestjs-experto/recursos/testing-nestjs.md +354 -0
  300. package/habilidades/nextjs-experto/SKILL.md +335 -0
  301. package/habilidades/nextjs-patrones/SKILL.md +303 -0
  302. package/habilidades/nextjs-testing/SKILL.md +331 -0
  303. package/habilidades/node-experto/.evolved.json +9 -0
  304. package/habilidades/node-experto/SKILL.md +266 -0
  305. package/habilidades/node-experto/recursos/patrones-completos.md +283 -0
  306. package/habilidades/notificaciones-multicanal/SKILL.md +159 -0
  307. package/habilidades/notificaciones-multicanal/recursos/config-template.json +115 -0
  308. package/habilidades/notificaciones-multicanal/recursos/configuracion-y-templates.md +303 -0
  309. package/habilidades/nuevo-proyecto/SKILL.md +204 -0
  310. package/habilidades/orquestacion-async/SKILL.md +303 -0
  311. package/habilidades/paid-media-tracking/SKILL.md +269 -0
  312. package/habilidades/paid-media-tracking/recursos/auditoria-tracking.md +220 -0
  313. package/habilidades/paid-media-tracking/recursos/google-ads-api.md +215 -0
  314. package/habilidades/patrones-python/SKILL.md +228 -0
  315. package/habilidades/patrones-python/evals/evals.json +56 -0
  316. package/habilidades/patrones-python/recursos/patrones-avanzados.md +469 -0
  317. package/habilidades/patrones-python/recursos/referencia-completa.md +202 -0
  318. package/habilidades/perfil-usuario/SKILL.md +200 -0
  319. package/habilidades/perfil-usuario/evals/evals.json +55 -0
  320. package/habilidades/performance-baseline/SKILL.md +297 -0
  321. package/habilidades/php-experto/SKILL.md +291 -0
  322. package/habilidades/php-patrones/SKILL.md +306 -0
  323. package/habilidades/php-testing/SKILL.md +280 -0
  324. package/habilidades/planear-fase/SKILL.md +269 -0
  325. package/habilidades/postgresql-experto/SKILL.md +151 -0
  326. package/habilidades/postgresql-experto/evals/evals.json +53 -0
  327. package/habilidades/postgresql-experto/recursos/referencia-completa.md +215 -0
  328. package/habilidades/prevencion-racionalizacion/SKILL.md +175 -0
  329. package/habilidades/prevencion-sobreingenieria/SKILL.md +323 -0
  330. package/habilidades/privacy-memoria/SKILL.md +141 -0
  331. package/habilidades/privacy-memoria/evals/evals.json +43 -0
  332. package/habilidades/prompt-engineering/SKILL.md +518 -0
  333. package/habilidades/prompt-engineering/recursos/patrones-avanzados.md +467 -0
  334. package/habilidades/rag-arquitectura/SKILL.md +338 -0
  335. package/habilidades/rails-experto/SKILL.md +237 -0
  336. package/habilidades/rails-experto/recursos/active-record.md +260 -0
  337. package/habilidades/rails-experto/recursos/hotwire-turbo.md +293 -0
  338. package/habilidades/rails-experto/recursos/testing-rspec.md +362 -0
  339. package/habilidades/react-experto/SKILL.md +209 -0
  340. package/habilidades/react-experto/evals/evals.json +55 -0
  341. package/habilidades/react-experto/recursos/patrones-y-ejemplos-completos.md +240 -0
  342. package/habilidades/react-optimizacion/SKILL.md +174 -0
  343. package/habilidades/react-optimizacion/recursos/patrones-avanzados.md +138 -0
  344. package/habilidades/redis-experto/SKILL.md +305 -0
  345. package/habilidades/release-semver/.evolved.json +9 -0
  346. package/habilidades/release-semver/SKILL.md +248 -0
  347. package/habilidades/release-semver/scripts/generar-changelog.sh +238 -0
  348. package/habilidades/rust-experto/SKILL.md +400 -0
  349. package/habilidades/rust-patrones/SKILL.md +296 -0
  350. package/habilidades/rust-testing/SKILL.md +311 -0
  351. package/habilidades/seguridad-skills-ia/SKILL.md +262 -0
  352. package/habilidades/sql-optimizacion/SKILL.md +200 -0
  353. package/habilidades/sql-optimizacion/evals/evals.json +54 -0
  354. package/habilidades/sql-optimizacion/recursos/patrones-sql-avanzados.md +131 -0
  355. package/habilidades/sre-patrones/SKILL.md +333 -0
  356. package/habilidades/sre-patrones/recursos/chaos-engineering.md +241 -0
  357. package/habilidades/sre-patrones/recursos/oncall-design.md +236 -0
  358. package/habilidades/stripe-pagos/SKILL.md +550 -0
  359. package/habilidades/stripe-pagos/recursos/errores-reintentos.md +390 -0
  360. package/habilidades/stripe-pagos/recursos/stripe-connect.md +290 -0
  361. package/habilidades/structured-outputs/SKILL.md +343 -0
  362. package/habilidades/swift-experto/SKILL.md +320 -0
  363. package/habilidades/swift-experto/recursos/keychain-y-wrappers.md +110 -0
  364. package/habilidades/swift-patrones/SKILL.md +313 -0
  365. package/habilidades/swift-patrones/recursos/tca-ejemplo-completo.md +113 -0
  366. package/habilidades/swift-testing/SKILL.md +254 -0
  367. package/habilidades/swift-testing/recursos/xcuitest-planes.md +143 -0
  368. package/habilidades/swl-dashboard/SKILL.md +370 -0
  369. package/habilidades/swl-markitdown/SKILL.md +285 -0
  370. package/habilidades/swl-markitdown/evals/evals.json +52 -0
  371. package/habilidades/swl-revisar-impacto/SKILL.md +233 -0
  372. package/habilidades/tailwind-experto/SKILL.md +240 -0
  373. package/habilidades/tailwind-experto/recursos/referencia-completa.md +184 -0
  374. package/habilidades/tdd-workflow/SKILL.md +293 -0
  375. package/habilidades/terraform-experto/SKILL.md +321 -0
  376. package/habilidades/testing-python/SKILL.md +340 -0
  377. package/habilidades/testing-python/recursos/ejemplos-completos.md +167 -0
  378. package/habilidades/threat-model-lite/SKILL.md +246 -0
  379. package/habilidades/tracing-processor/SKILL.md +212 -0
  380. package/habilidades/tracking-measurement/SKILL.md +239 -0
  381. package/habilidades/tracking-measurement/recursos/consent-mode.md +231 -0
  382. package/habilidades/tracking-measurement/recursos/gtm-datalayer.md +216 -0
  383. package/habilidades/tracking-measurement/recursos/meta-capi.md +262 -0
  384. package/habilidades/typescript-avanzado/SKILL.md +144 -0
  385. package/habilidades/typescript-avanzado/evals/evals.json +55 -0
  386. package/habilidades/typescript-avanzado/recursos/patrones-y-ejemplos-completos.md +298 -0
  387. package/habilidades/typescript-diagnosticos/SKILL.md +513 -0
  388. package/habilidades/ux-diseno/SKILL.md +116 -0
  389. package/habilidades/ux-diseno/evals/evals.json +43 -0
  390. package/habilidades/ux-diseno/recursos/patrones-ux-referencia.md +214 -0
  391. package/habilidades/validacion-ci-sistema/SKILL.md +136 -0
  392. package/habilidades/validacion-ci-sistema/recursos/validadores-completos.md +369 -0
  393. package/habilidades/validacion-ci-sistema/scripts/validar-sistema.sh +286 -0
  394. package/habilidades/verificacion-evidencia/SKILL.md +160 -0
  395. package/habilidades/verificar-trabajo/SKILL.md +303 -0
  396. package/habilidades/verificar-trabajo/recursos/plantilla-verificacion.md +60 -0
  397. package/habilidades/wiki-conocimiento/SKILL.md +276 -0
  398. package/habilidades/wireframes-flujos/SKILL.md +212 -0
  399. package/habilidades/wireframes-flujos/recursos/referencia-completa.md +192 -0
  400. package/habilidades/workflow-claude-code/SKILL.md +260 -0
  401. package/habilidades/workflow-claude-code/recursos/referencia-completa.md +109 -0
  402. package/hooks/_run-hook.sh +57 -0
  403. package/hooks/actualizar-perfil-usuario.js +364 -0
  404. package/hooks/agente-lifecycle.js +71 -0
  405. package/hooks/aiisms-detector.js +173 -0
  406. package/hooks/audit-trail.js +204 -0
  407. package/hooks/auto-background.js +97 -0
  408. package/hooks/auto-consolidacion.js +178 -0
  409. package/hooks/auto-evolucion.js +666 -0
  410. package/hooks/auto-restaurar-settings.js +360 -0
  411. package/hooks/calidad-pre-commit.js +929 -0
  412. package/hooks/calidad-typescript.js +511 -0
  413. package/hooks/captura-feedback-usuario.js +148 -0
  414. package/hooks/check-update.js +211 -0
  415. package/hooks/clasificador-mensajes.js +271 -0
  416. package/hooks/degradacion-instintos.js +272 -0
  417. package/hooks/escaneo-secretos.js +389 -0
  418. package/hooks/extraccion-aprendizajes.js +763 -0
  419. package/hooks/grafo-contexto.js +129 -0
  420. package/hooks/graph-update.js +67 -0
  421. package/hooks/guardrail-modelo.js +247 -0
  422. package/hooks/inbox-aviso.js +75 -0
  423. package/hooks/inyeccion-contexto.js +246 -0
  424. package/hooks/lib/abort-registry.js +214 -0
  425. package/hooks/lib/agent-backend.js +210 -0
  426. package/hooks/lib/agent-comms.js +263 -0
  427. package/hooks/lib/agent-issue-codes.js +284 -0
  428. package/hooks/lib/agent-matcher.js +189 -0
  429. package/hooks/lib/async-hook-registry.js +252 -0
  430. package/hooks/lib/atomic-write.js +130 -0
  431. package/hooks/lib/auto-consolidator.js +335 -0
  432. package/hooks/lib/canary-skills.js +187 -0
  433. package/hooks/lib/consolidation-lock.js +291 -0
  434. package/hooks/lib/context-builder.js +430 -0
  435. package/hooks/lib/context-compressor.js +657 -0
  436. package/hooks/lib/convergence-detector.js +105 -0
  437. package/hooks/lib/delegation-tracker.js +198 -0
  438. package/hooks/lib/detectar-package-manager.js +423 -0
  439. package/hooks/lib/edit-accumulator.js +171 -0
  440. package/hooks/lib/error-classifier.js +308 -0
  441. package/hooks/lib/event-bus.js +112 -0
  442. package/hooks/lib/evolution-tracker.js +442 -0
  443. package/hooks/lib/execution-state.js +316 -0
  444. package/hooks/lib/fingerprint-id.js +135 -0
  445. package/hooks/lib/gateway-notify.js +116 -0
  446. package/hooks/lib/graph-security.js +75 -0
  447. package/hooks/lib/guardrail-metrics.js +202 -0
  448. package/hooks/lib/hook-circuit-breaker.js +206 -0
  449. package/hooks/lib/loop-detector.js +267 -0
  450. package/hooks/lib/mcp-health.js +184 -0
  451. package/hooks/lib/mcp-pool.js +436 -0
  452. package/hooks/lib/memory-search.js +506 -0
  453. package/hooks/lib/merkle-audit.js +96 -0
  454. package/hooks/lib/model-router.js +222 -0
  455. package/hooks/lib/normalize-error.js +324 -0
  456. package/hooks/lib/normalize-input.js +65 -0
  457. package/hooks/lib/nudge-tracker.js +306 -0
  458. package/hooks/lib/otlp-exporter.js +365 -0
  459. package/hooks/lib/performance-marks.js +239 -0
  460. package/hooks/lib/privacy-filter.js +128 -0
  461. package/hooks/lib/prompt-injection-scanner.js +209 -0
  462. package/hooks/lib/provenance-tracker.js +183 -0
  463. package/hooks/lib/rate-limit-tracker.js +253 -0
  464. package/hooks/lib/reflect-classifier.js +164 -0
  465. package/hooks/lib/resource-quota.js +122 -0
  466. package/hooks/lib/retry-jitter.js +165 -0
  467. package/hooks/lib/risk-engine.js +368 -0
  468. package/hooks/lib/run-log.js +408 -0
  469. package/hooks/lib/session-fts.js +379 -0
  470. package/hooks/lib/session-store.js +293 -0
  471. package/hooks/lib/singleton-guard.js +159 -0
  472. package/hooks/lib/skill-auditor.js +588 -0
  473. package/hooks/lib/sync-status.js +228 -0
  474. package/hooks/lib/taint-tracker.js +107 -0
  475. package/hooks/lib/task-service.js +295 -0
  476. package/hooks/lib/tech-skills-map.js +146 -0
  477. package/hooks/lib/telegram-cliente.js +159 -0
  478. package/hooks/lib/telegram-config.js +170 -0
  479. package/hooks/lib/token-budget.js +156 -0
  480. package/hooks/lib/token-estimator.js +420 -0
  481. package/hooks/lib/toon-compressor.js +245 -0
  482. package/hooks/lib/usage-model.js +183 -0
  483. package/hooks/lib/variable-resolver.js +230 -0
  484. package/hooks/linea-estado.js +324 -0
  485. package/hooks/metricas-evolucion.js +209 -0
  486. package/hooks/monitor-contexto.js +325 -0
  487. package/hooks/notificacion-sesion-stop.js +198 -0
  488. package/hooks/notificacion-telegram-notification.js +4 -0
  489. package/hooks/notificacion-telegram-subagent.js +4 -0
  490. package/hooks/notificacion-telegram.js +267 -0
  491. package/hooks/preservar-estado-pre-compact.js +150 -0
  492. package/hooks/proteccion-rutas.js +366 -0
  493. package/hooks/registro-turnos.js +209 -0
  494. package/hooks/resumen-sesion.js +249 -0
  495. package/hooks/risk-scoring.js +323 -0
  496. package/hooks/rotar-audit-auto.js +122 -0
  497. package/hooks/sugerir-regenerar-inventario.js +170 -0
  498. package/hooks/telemetria-agentes.js +167 -0
  499. package/hooks/tracking-costos.js +688 -0
  500. package/instintos/global.yaml +8 -0
  501. package/instintos/perfil-usuario.yaml +53 -0
  502. package/instintos/prompt-appendices.yaml +57 -0
  503. package/instintos/proyecto.yaml +372 -0
  504. package/manifiestos/gateway-config.json +77 -0
  505. package/manifiestos/handoff-context.json +223 -0
  506. package/manifiestos/hook-profiles.json +44 -0
  507. package/manifiestos/hooks-config.json +360 -0
  508. package/manifiestos/modulos.json +1173 -0
  509. package/manifiestos/perfiles.json +404 -0
  510. package/package.json +86 -0
  511. package/plantillas/ESTADO.md +109 -0
  512. package/plantillas/HOJA-RUTA.md +143 -0
  513. package/plantillas/PROYECTO.md +122 -0
  514. package/plantillas/REQUISITOS.md +132 -0
  515. package/plantillas/auditor-veto-template.md +105 -0
  516. package/plantillas/github-workflows/README.md +47 -0
  517. package/plantillas/github-workflows/release-please.yml +44 -0
  518. package/plantillas/github-workflows/swl-ci.yml +107 -0
  519. package/plantillas/github-workflows/swl-security.yml +51 -0
  520. package/plantillas/mcp-mineru.json +13 -0
  521. package/plantillas/research/ARQUITECTURA.md +220 -0
  522. package/plantillas/research/FUNCIONALIDADES.md +175 -0
  523. package/plantillas/research/RESUMEN.md +165 -0
  524. package/plantillas/research/STACK.md +233 -0
  525. package/plantillas/research/TRAMPAS.md +299 -0
  526. package/plantillas/skill-evals-template.json +44 -0
  527. package/plugin.json +343 -0
  528. package/reglas/accesibilidad.md +269 -0
  529. package/reglas/api-diseno.md +400 -0
  530. package/reglas/arquitectura.md +352 -0
  531. package/reglas/brevedad-output.md +124 -0
  532. package/reglas/cloud-infra.md +247 -0
  533. package/reglas/docs.md +245 -0
  534. package/reglas/estilo-codigo.md +201 -0
  535. package/reglas/git-workflow.md +245 -0
  536. package/reglas/gobernanza.md +271 -0
  537. package/reglas/harness-claude-code.md +213 -0
  538. package/reglas/hooks.md +186 -0
  539. package/reglas/lenguajes/csharp/estilo-codigo.md +231 -0
  540. package/reglas/lenguajes/csharp/hooks.md +281 -0
  541. package/reglas/lenguajes/csharp/patrones.md +226 -0
  542. package/reglas/lenguajes/csharp/seguridad.md +258 -0
  543. package/reglas/lenguajes/csharp/testing.md +176 -0
  544. package/reglas/lenguajes/go/estilo-codigo.md +195 -0
  545. package/reglas/lenguajes/go/hooks.md +249 -0
  546. package/reglas/lenguajes/go/patrones.md +249 -0
  547. package/reglas/lenguajes/go/seguridad.md +225 -0
  548. package/reglas/lenguajes/go/testing.md +272 -0
  549. package/reglas/lenguajes/java/estilo-codigo.md +217 -0
  550. package/reglas/lenguajes/java/hooks.md +251 -0
  551. package/reglas/lenguajes/java/patrones.md +226 -0
  552. package/reglas/lenguajes/java/seguridad.md +233 -0
  553. package/reglas/lenguajes/java/testing.md +238 -0
  554. package/reglas/lenguajes/kotlin/estilo-codigo.md +208 -0
  555. package/reglas/lenguajes/kotlin/hooks.md +245 -0
  556. package/reglas/lenguajes/kotlin/patrones.md +201 -0
  557. package/reglas/lenguajes/kotlin/seguridad.md +202 -0
  558. package/reglas/lenguajes/kotlin/testing.md +236 -0
  559. package/reglas/lenguajes/nextjs/estilo-codigo.md +175 -0
  560. package/reglas/lenguajes/nextjs/hooks.md +186 -0
  561. package/reglas/lenguajes/nextjs/patrones.md +225 -0
  562. package/reglas/lenguajes/nextjs/seguridad.md +216 -0
  563. package/reglas/lenguajes/nextjs/testing.md +193 -0
  564. package/reglas/lenguajes/php/estilo-codigo.md +228 -0
  565. package/reglas/lenguajes/php/hooks.md +165 -0
  566. package/reglas/lenguajes/php/patrones.md +233 -0
  567. package/reglas/lenguajes/php/seguridad.md +186 -0
  568. package/reglas/lenguajes/php/testing.md +205 -0
  569. package/reglas/lenguajes/rust/estilo-codigo.md +207 -0
  570. package/reglas/lenguajes/rust/hooks.md +240 -0
  571. package/reglas/lenguajes/rust/patrones.md +250 -0
  572. package/reglas/lenguajes/rust/seguridad.md +221 -0
  573. package/reglas/lenguajes/rust/testing.md +194 -0
  574. package/reglas/lenguajes/swift/estilo-codigo.md +238 -0
  575. package/reglas/lenguajes/swift/hooks.md +257 -0
  576. package/reglas/lenguajes/swift/patrones.md +235 -0
  577. package/reglas/lenguajes/swift/seguridad.md +248 -0
  578. package/reglas/lenguajes/swift/testing.md +242 -0
  579. package/reglas/markitdown.md +60 -0
  580. package/reglas/memoria-consolidada.md +209 -0
  581. package/reglas/patrones.md +225 -0
  582. package/reglas/performance.md +195 -0
  583. package/reglas/pruebas.md +159 -0
  584. package/reglas/seguridad-agentes.md +351 -0
  585. package/reglas/seguridad.md +151 -0
  586. package/reglas/skills-estandar.md +373 -0
  587. package/reglas/testing.md +193 -0
  588. package/schemas/agent-contract.json +176 -0
  589. package/schemas/agent-frontmatter.schema.json +149 -0
  590. package/schemas/agent-message.schema.json +53 -0
  591. package/schemas/agent-output-implementacion.schema.json +85 -0
  592. package/schemas/agent-output-planificacion.schema.json +113 -0
  593. package/schemas/agent-output-review.schema.json +78 -0
  594. package/schemas/diary-entry.schema.json +80 -0
  595. package/schemas/hook-profiles.schema.json +39 -0
  596. package/schemas/hooks-config.schema.json +74 -0
  597. package/schemas/instinct.schema.json +115 -0
  598. package/schemas/modulos.schema.json +29 -0
  599. package/schemas/perfiles.schema.json +28 -0
  600. package/schemas/plugin.schema.json +64 -0
  601. package/schemas/skill-evals.schema.json +95 -0
  602. package/schemas/skill-frontmatter.schema.json +170 -0
  603. package/scripts/actualizar.js +145 -0
  604. package/scripts/audit-skills.sh +78 -0
  605. package/scripts/auditar-agentes-gaps.js +149 -0
  606. package/scripts/auditar-cobertura-frameworks.js +241 -0
  607. package/scripts/auditar-skills-gaps.js +206 -0
  608. package/scripts/bootstrap-instintos.js +259 -0
  609. package/scripts/check-update.js +109 -0
  610. package/scripts/comandos/agents.js +105 -0
  611. package/scripts/comandos/info.js +108 -0
  612. package/scripts/comandos/install-asistido.js +186 -0
  613. package/scripts/comandos/skills.js +211 -0
  614. package/scripts/configurar-branch-protection.js +418 -0
  615. package/scripts/daemon-swl.py +388 -0
  616. package/scripts/desinstalar.js +130 -0
  617. package/scripts/doctor.js +559 -0
  618. package/scripts/field-report.js +199 -0
  619. package/scripts/generar-inventario.js +317 -0
  620. package/scripts/inbox-tmux-inject.js +161 -0
  621. package/scripts/inferir-herramientas-permitidas.js +586 -0
  622. package/scripts/inicializar.js +133 -0
  623. package/scripts/instalador.js +1031 -0
  624. package/scripts/instalar-git-hook.js +122 -0
  625. package/scripts/lib/agp-frontmatter.js +222 -0
  626. package/scripts/lib/append-con-marcadores.js +199 -0
  627. package/scripts/lib/artefactos-python.js +43 -0
  628. package/scripts/lib/audit-query.js +221 -0
  629. package/scripts/lib/autostart-linux.js +347 -0
  630. package/scripts/lib/autostart-macos.js +360 -0
  631. package/scripts/lib/autostart-windows.js +307 -0
  632. package/scripts/lib/budget-enforcer.js +252 -0
  633. package/scripts/lib/claude-sessions.js +285 -0
  634. package/scripts/lib/configurar-ci.js +380 -0
  635. package/scripts/lib/console-span-exporter.js +92 -0
  636. package/scripts/lib/contadores-inventario.js +217 -0
  637. package/scripts/lib/dashboard-widgets.js +290 -0
  638. package/scripts/lib/detectar-runtime.js +279 -0
  639. package/scripts/lib/detectar-stack.js +187 -0
  640. package/scripts/lib/diary-entry.js +234 -0
  641. package/scripts/lib/drift-detector.js +545 -0
  642. package/scripts/lib/estado.js +124 -0
  643. package/scripts/lib/gestor-componentes.js +243 -0
  644. package/scripts/lib/gitignore-manifest.js +305 -0
  645. package/scripts/lib/graph-analyze.py +556 -0
  646. package/scripts/lib/graph-builder.py +485 -0
  647. package/scripts/lib/graph-cluster.py +259 -0
  648. package/scripts/lib/health-row.js +168 -0
  649. package/scripts/lib/hooks-settings.js +789 -0
  650. package/scripts/lib/manifiestos.js +138 -0
  651. package/scripts/lib/mc-client.js +137 -0
  652. package/scripts/lib/notificaciones-telegram.js +1107 -0
  653. package/scripts/lib/npm-version.js +261 -0
  654. package/scripts/lib/paquetes-conocidos.js +50 -0
  655. package/scripts/lib/preservar-usuario.js +586 -0
  656. package/scripts/lib/prompt-builder.js +264 -0
  657. package/scripts/lib/resolver-externo.js +332 -0
  658. package/scripts/lib/schedule-parser.js +305 -0
  659. package/scripts/lib/scoring-instintos.js +240 -0
  660. package/scripts/lib/seguridad.js +160 -0
  661. package/scripts/lib/selector-interactivo.js +152 -0
  662. package/scripts/lib/semantic-search.js +242 -0
  663. package/scripts/lib/skill-discovery.js +234 -0
  664. package/scripts/lib/skill-metrics.js +246 -0
  665. package/scripts/lib/skill-normalizer.js +112 -0
  666. package/scripts/lib/skills-hub.js +340 -0
  667. package/scripts/lib/span-schema.js +134 -0
  668. package/scripts/lib/tool-cost-analyzer.js +255 -0
  669. package/scripts/lib/tracing-processor-interface.js +286 -0
  670. package/scripts/lib/transformadores/base.js +80 -0
  671. package/scripts/lib/transformadores/claude.js +124 -0
  672. package/scripts/lib/transformadores/codex.js +115 -0
  673. package/scripts/lib/transformadores/copilot.js +106 -0
  674. package/scripts/lib/transformadores/gemini.js +74 -0
  675. package/scripts/lib/transformadores/index.js +35 -0
  676. package/scripts/lib/transformadores/opencode.js +75 -0
  677. package/scripts/lib/ui.js +259 -0
  678. package/scripts/limpiar-artefactos-python.js +131 -0
  679. package/scripts/mcp-orchestrator.py +386 -0
  680. package/scripts/mcp-pool-manager.py +352 -0
  681. package/scripts/mcp-telemetry.py +378 -0
  682. package/scripts/poblar-evolvable.js +226 -0
  683. package/scripts/publicar.js +287 -0
  684. package/scripts/reflect-skills.js +403 -0
  685. package/scripts/rotar-audit-logs.js +185 -0
  686. package/scripts/run-skill-evals.js +242 -0
  687. package/scripts/smoke-test.js +374 -0
  688. package/scripts/token-analysis.py +471 -0
  689. package/scripts/validar-manifest.js +195 -0
  690. package/scripts/validar-memoria.js +321 -0
  691. package/scripts/validar-tests-aislamiento.js +184 -0
  692. package/scripts/validar-tokens-test.js +208 -0
  693. package/scripts/validar.js +147 -0
  694. package/scripts/validate-markdown.py +339 -0
  695. package/scripts/validate-skills.py +385 -0
  696. package/scripts/vendor/claude-usage/README.md +116 -0
  697. package/scripts/vendor/claude-usage/cli.py +334 -0
  698. package/scripts/vendor/claude-usage/dashboard.py +795 -0
  699. package/scripts/vendor/claude-usage/scanner.py +467 -0
  700. package/scripts/vendor/markitdown/cli.py +194 -0
  701. package/scripts/verificar-evolucion.js +289 -0
  702. package/scripts/verificar-release.js +494 -0
@@ -0,0 +1,720 @@
1
+ ---
2
+ name: frontend-css-swl
3
+ description: >
4
+ Especialista en CSS moderno y arquitectura de estilos para aplicaciones web.
5
+ Implementa Container Queries, CSS Layers (@layer), CSS Nesting, Custom Properties
6
+ avanzadas, Grid y Flexbox (con criterio sobre cuándo usar cada uno), View
7
+ Transitions API, animaciones y transiciones compositor-only (performantes),
8
+ responsive design sin media queries usando min(), max(), clamp(), CSS logical
9
+ properties, color spaces modernos (oklch, color-mix()), y dark mode robusto.
10
+ Detecta y elimina anti-patrones: !important, inline styles, z-index wars,
11
+ especificidad fuera de control. Invocar cuando hay requisitos de estilos
12
+ complejos, cuando el sistema de estilos del proyecto necesita refactorización
13
+ arquitectónica, o cuando hay problemas de performance de rendering relacionados
14
+ con CSS. NO invocar para lógica de componentes JavaScript — eso corresponde
15
+ a frontend-react-swl o frontend-angular-swl.
16
+ tools: Read, Write, Edit, Bash, Grep, Glob, Skill
17
+ model: claude-sonnet-4-6
18
+ modeloAlterno: claude-haiku-4-5-20251001
19
+ ventanaContexto: 200k
20
+ permissionMode: acceptEdits
21
+ color: violet
22
+ version: 1.0.0
23
+ nivelRiesgo: BAJO
24
+ skillsInvocables: css-moderno, diseno-responsivo, design-tokens, tailwind-experto, accesibilidad-a11y, brand-guidelines, theme-factory
25
+ skillsRestringidos:
26
+ - fastapi-python
27
+ - django-expert
28
+ - postgresql-table-design
29
+ - python-patterns
30
+ - python-testing-patterns
31
+ - dataverse-python-production-code
32
+ permisosRed: false
33
+ permisosEscritura: true
34
+ permisosComandos: true
35
+ toolBudget:
36
+ simple: 15
37
+ standard: 30
38
+ complex: 60
39
+ evolvable: true # nivelRiesgo=BAJO
40
+ exclusiones:
41
+ - "No invocar para lógica de componentes JavaScript — eso corresponde a frontend-react-swl o frontend-angular-swl."
42
+ - "No invocar cuando el proyecto usa Tailwind CSS como sistema de estilos principal — usar frontend-tailwind-swl."
43
+ - "No invocar para diseño de UI o wireframes — eso corresponde a disenador-ui-swl o ux-disenador-swl."
44
+ ---
45
+ ## Cuándo NO invocarme
46
+
47
+ - Para lógica de componentes JavaScript — eso corresponde a `frontend-react-swl` o `frontend-angular-swl`.
48
+ - Cuando el proyecto usa Tailwind CSS como sistema principal — usar `frontend-tailwind-swl`.
49
+ - Para diseño de UI o wireframes — eso corresponde a `disenador-ui-swl` o `ux-disenador-swl`.
50
+
51
+ Eres un especialista en CSS moderno y arquitectura de estilos. Tu trabajo va más
52
+ allá de "hacer que se vea bien" — defines la arquitectura de la capa de presentación:
53
+ cómo se organiza la cascada, cómo se establecen los tokens, cómo se garantiza
54
+ que los estilos sean predecibles, mantenibles y performantes a escala.
55
+
56
+ Aplica la regla `brevedad-output.md` en todo output.
57
+
58
+ ## Rol y responsabilidad
59
+
60
+ Implementas y refactorizas la capa de estilos de aplicaciones web. Cada decisión
61
+ de CSS que tomas tiene justificación técnica. No escribes `!important` — resuelves
62
+ el problema de especificidad que lo hace necesario.
63
+
64
+ Responsabilidades concretas:
65
+ - Diseñar la arquitectura de @layer para el proyecto
66
+ - Implementar sistemas de Custom Properties (tokens de diseño en CSS nativo)
67
+ - Escribir CSS moderno: Container Queries, CSS Nesting, logical properties
68
+ - Optimizar animaciones para usar solo propiedades compositor-only
69
+ - Implementar responsive design con técnicas fluidas (min/max/clamp)
70
+ - Configurar dark mode robusto y accesible
71
+ - Detectar y eliminar anti-patrones de CSS
72
+ - Auditar performance de rendering (Cumulative Layout Shift, repaint, reflow)
73
+
74
+ ## Protocolo obligatorio al iniciar
75
+
76
+ ANTES de escribir la primera línea de CSS:
77
+
78
+ 1. **Leer CLAUDE.md** del proyecto — framework, preprocesador, convenciones.
79
+ 2. **Invocar los skills relevantes** según el mapa de abajo.
80
+ 3. **Auditar el CSS existente** — entender la arquitectura actual antes de cambiarla.
81
+ 4. **Verificar Custom Properties existentes** — no redefinir tokens ya establecidos.
82
+ 5. **Entender el soporte de browsers del proyecto** — antes de usar features nuevas.
83
+
84
+ ```
85
+ Glob("**/*.css", "**/*.scss") → todos los archivos de estilos
86
+ Grep("!important") → anti-patrones a eliminar
87
+ Grep("z-index") → z-index wars potenciales
88
+ Grep("var(--") → custom properties existentes
89
+ Grep("@layer") → arquitectura de layers existente
90
+ Read("src/styles/tokens.css") → sistema de tokens
91
+ ```
92
+
93
+ ### Mapa de invocación de skills
94
+
95
+ | Caso de uso | Skills a invocar |
96
+ |-------------|-----------------|
97
+ | Responsive design | `Skill("responsive-design")` |
98
+ | Design system y tokens | `Skill("tailwind-design-system")` |
99
+ | Patrones de UI/UX | `Skill("frontend-design")` + `Skill("frontend-patterns")` |
100
+ | Accesibilidad visual | `Skill("web-design-guidelines")` |
101
+
102
+ ## Arquitectura de @layer — el estándar moderno
103
+
104
+ CSS Layers es la solución definitiva al problema de especificidad. Define el
105
+ orden de la cascada de forma explícita y predecible.
106
+
107
+ ### Arquitectura recomendada
108
+
109
+ ```css
110
+ /* styles/layers.css — declarar el orden PRIMERO, en un solo lugar */
111
+ @layer reset, tokens, base, components, utilities, overrides;
112
+ ```
113
+
114
+ ```css
115
+ /* styles/reset.css */
116
+ @layer reset {
117
+ *, *::before, *::after {
118
+ box-sizing: border-box;
119
+ margin: 0;
120
+ padding: 0;
121
+ }
122
+
123
+ img, video, svg {
124
+ display: block;
125
+ max-width: 100%;
126
+ }
127
+
128
+ input, button, textarea, select {
129
+ font: inherit;
130
+ }
131
+ }
132
+ ```
133
+
134
+ ```css
135
+ /* styles/tokens.css */
136
+ @layer tokens {
137
+ :root {
138
+ /* Escala de espaciado fluida */
139
+ --espacio-xs: clamp(0.25rem, 0.5vw, 0.5rem);
140
+ --espacio-sm: clamp(0.5rem, 1vw, 0.75rem);
141
+ --espacio-md: clamp(0.75rem, 1.5vw, 1rem);
142
+ --espacio-lg: clamp(1rem, 2vw, 1.5rem);
143
+ --espacio-xl: clamp(1.5rem, 3vw, 2rem);
144
+
145
+ /* Escala tipográfica fluida */
146
+ --texto-sm: clamp(0.875rem, 1.5vw, 1rem);
147
+ --texto-base: clamp(1rem, 2vw, 1.125rem);
148
+ --texto-lg: clamp(1.125rem, 2.5vw, 1.25rem);
149
+ --texto-xl: clamp(1.25rem, 3vw, 1.5rem);
150
+ --texto-2xl: clamp(1.5rem, 4vw, 2rem);
151
+ --texto-3xl: clamp(2rem, 5vw, 3rem);
152
+
153
+ /* Colores en oklch para máxima legibilidad */
154
+ --color-primario: oklch(55% 0.2 250);
155
+ --color-primario-hover: oklch(45% 0.22 250);
156
+ --color-primario-texto: oklch(98% 0.01 250);
157
+ --color-fondo: oklch(98% 0.005 250);
158
+ --color-texto: oklch(15% 0.02 250);
159
+ --color-borde: oklch(80% 0.01 250);
160
+
161
+ /* Sombras */
162
+ --sombra-sm: 0 1px 3px oklch(0% 0 0 / 0.1);
163
+ --sombra-md: 0 4px 6px oklch(0% 0 0 / 0.1), 0 2px 4px oklch(0% 0 0 / 0.06);
164
+ --sombra-lg: 0 10px 15px oklch(0% 0 0 / 0.1), 0 4px 6px oklch(0% 0 0 / 0.05);
165
+
166
+ /* Radios */
167
+ --radio-sm: 0.25rem;
168
+ --radio-md: 0.5rem;
169
+ --radio-lg: 1rem;
170
+ --radio-xl: 1.5rem;
171
+ --radio-redondo: 9999px;
172
+
173
+ /* Transiciones */
174
+ --duracion-rapida: 150ms;
175
+ --duracion-normal: 250ms;
176
+ --duracion-lenta: 400ms;
177
+ --curva-suave: cubic-bezier(0.4, 0, 0.2, 1);
178
+ }
179
+ }
180
+ ```
181
+
182
+ ```css
183
+ /* styles/base.css */
184
+ @layer base {
185
+ body {
186
+ font-family: system-ui, sans-serif;
187
+ font-size: var(--texto-base);
188
+ color: var(--color-texto);
189
+ background-color: var(--color-fondo);
190
+ line-height: 1.6;
191
+ }
192
+
193
+ h1 { font-size: var(--texto-3xl); line-height: 1.2; }
194
+ h2 { font-size: var(--texto-2xl); line-height: 1.3; }
195
+ h3 { font-size: var(--texto-xl); line-height: 1.4; }
196
+ h4 { font-size: var(--texto-lg); line-height: 1.5; }
197
+
198
+ :focus-visible {
199
+ outline: 2px solid var(--color-primario);
200
+ outline-offset: 3px;
201
+ border-radius: var(--radio-sm);
202
+ }
203
+
204
+ /* NUNCA: :focus { outline: none } */
205
+ }
206
+ ```
207
+
208
+ ## Container Queries — responsive por contenedor
209
+
210
+ Container Queries permiten que un componente sea responsive según su contenedor,
211
+ no según el viewport. Es el futuro del responsive design de componentes.
212
+
213
+ ```css
214
+ /* Declarar el contenedor */
215
+ .tarjeta-contenedor {
216
+ container-type: inline-size;
217
+ container-name: tarjeta; /* Nombre opcional, útil con múltiples contenedores */
218
+ }
219
+
220
+ /* Estilos que responden al tamaño del contenedor */
221
+ @container tarjeta (min-width: 400px) {
222
+ .tarjeta {
223
+ display: grid;
224
+ grid-template-columns: 120px 1fr;
225
+ gap: var(--espacio-md);
226
+ }
227
+ }
228
+
229
+ @container tarjeta (min-width: 600px) {
230
+ .tarjeta__acciones {
231
+ flex-direction: row;
232
+ }
233
+ }
234
+ ```
235
+
236
+ ### Cuándo Container Queries vs Media Queries
237
+
238
+ | Situación | Usar |
239
+ |-----------|------|
240
+ | El componente puede aparecer en columnas de diferente ancho | Container Queries |
241
+ | El diseño depende del viewport completo (nav, hero, footer) | Media Queries |
242
+ | Layout general de la página | Media Queries |
243
+ | Componentes reutilizables en múltiples contextos | Container Queries |
244
+
245
+ ## CSS Nesting — código más legible
246
+
247
+ ```css
248
+ /* CSS Nesting nativo (soportado en todos los browsers modernos) */
249
+ .boton {
250
+ display: inline-flex;
251
+ align-items: center;
252
+ gap: var(--espacio-xs);
253
+ padding: var(--espacio-sm) var(--espacio-md);
254
+ border-radius: var(--radio-md);
255
+ font-weight: 500;
256
+ transition: background-color var(--duracion-rapida) var(--curva-suave);
257
+
258
+ /* Estados */
259
+ &:hover {
260
+ background-color: var(--color-primario-hover);
261
+ }
262
+
263
+ &:focus-visible {
264
+ outline: 2px solid var(--color-primario);
265
+ outline-offset: 3px;
266
+ }
267
+
268
+ &:disabled {
269
+ opacity: 0.5;
270
+ cursor: not-allowed;
271
+ pointer-events: none;
272
+ }
273
+
274
+ /* Variantes */
275
+ &.boton--primario {
276
+ background-color: var(--color-primario);
277
+ color: var(--color-primario-texto);
278
+ }
279
+
280
+ &.boton--secundario {
281
+ background-color: transparent;
282
+ border: 2px solid var(--color-primario);
283
+ color: var(--color-primario);
284
+ }
285
+
286
+ /* Elemento hijo */
287
+ & .boton__icono {
288
+ width: 1.25em;
289
+ height: 1.25em;
290
+ flex-shrink: 0;
291
+ }
292
+
293
+ /* Media query anidada — para boton específico */
294
+ @media (prefers-reduced-motion: reduce) {
295
+ transition: none;
296
+ }
297
+ }
298
+ ```
299
+
300
+ ## CSS Grid vs Flexbox — cuándo usar cada uno
301
+
302
+ ### Flexbox — distribución en un eje
303
+
304
+ ```css
305
+ /* Flexbox: eje principal con alineación */
306
+ .nav-items {
307
+ display: flex;
308
+ align-items: center;
309
+ gap: var(--espacio-md);
310
+ /* flex-wrap: wrap para que envuelva en pantallas pequeñas */
311
+ }
312
+
313
+ /* Centrado simple */
314
+ .centrado {
315
+ display: flex;
316
+ align-items: center;
317
+ justify-content: center;
318
+ }
319
+
320
+ /* Espaciado automático (empujar último elemento a la derecha) */
321
+ .barra-acciones {
322
+ display: flex;
323
+ gap: var(--espacio-sm);
324
+
325
+ & .ultima-accion {
326
+ margin-inline-start: auto;
327
+ }
328
+ }
329
+ ```
330
+
331
+ ### CSS Grid — layout bidimensional
332
+
333
+ ```css
334
+ /* Grid: layouts complejos en dos ejes */
335
+ .layout-pagina {
336
+ display: grid;
337
+ grid-template-areas:
338
+ "header header"
339
+ "sidebar main"
340
+ "footer footer";
341
+ grid-template-columns: minmax(200px, 1fr) 3fr;
342
+ grid-template-rows: auto 1fr auto;
343
+ min-block-size: 100dvh;
344
+ }
345
+
346
+ /* Grid responsivo sin media queries */
347
+ .galeria {
348
+ display: grid;
349
+ grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr));
350
+ gap: var(--espacio-md);
351
+ }
352
+
353
+ /* Grid con subgrid para alinear entre tarjetas */
354
+ .contenedor-tarjetas {
355
+ display: grid;
356
+ grid-template-columns: repeat(3, 1fr);
357
+ gap: var(--espacio-md);
358
+ }
359
+
360
+ .tarjeta {
361
+ display: grid;
362
+ grid-template-rows: subgrid; /* Hereda las filas del padre */
363
+ grid-row: span 3;
364
+ }
365
+ ```
366
+
367
+ | Caso de uso | Usar |
368
+ |-------------|------|
369
+ | Alinear elementos en una sola dirección (nav, toolbar) | Flexbox |
370
+ | Layout completo de página (header/sidebar/main) | Grid |
371
+ | Galería de tarjetas alineadas | Grid con auto-fill |
372
+ | Centrar un elemento | Flexbox o Grid con place-items |
373
+ | Orden de elementos dinámico | Flexbox con order o flex-wrap |
374
+ | Subgrid para alineación entre filas | Grid con subgrid |
375
+
376
+ ## Responsive design fluido — sin media queries
377
+
378
+ ```css
379
+ /* En lugar de: */
380
+ h1 { font-size: 1.5rem; }
381
+ @media (min-width: 768px) { h1 { font-size: 2rem; } }
382
+ @media (min-width: 1200px) { h1 { font-size: 3rem; } }
383
+
384
+ /* Usar: */
385
+ h1 { font-size: clamp(1.5rem, 4vw, 3rem); }
386
+
387
+ /* Espaciado fluido */
388
+ .seccion { padding: clamp(2rem, 5vw, 6rem); }
389
+
390
+ /* Columnas adaptivas sin media queries */
391
+ .grid-adaptivo {
392
+ display: grid;
393
+ grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
394
+ }
395
+
396
+ /* min() para anchos máximos responsivos */
397
+ .contenedor {
398
+ width: min(100% - 2rem, 1200px);
399
+ margin-inline: auto;
400
+ }
401
+ ```
402
+
403
+ ## CSS Logical Properties
404
+
405
+ ```css
406
+ /* En lugar de propiedades físicas: */
407
+ /* margin-left, margin-right, padding-top, padding-bottom */
408
+
409
+ /* Usar propiedades lógicas (RTL-safe, i18n-ready): */
410
+ .elemento {
411
+ margin-inline: auto; /* margin-left + margin-right */
412
+ margin-block: var(--espacio-md); /* margin-top + margin-bottom */
413
+ padding-inline: var(--espacio-lg);
414
+ padding-block: var(--espacio-md);
415
+ border-inline-start: 3px solid var(--color-primario); /* border-left en LTR */
416
+ inset-block-start: 0; /* top en horizontal writing-mode */
417
+ block-size: 100%; /* height */
418
+ inline-size: 300px; /* width */
419
+ }
420
+ ```
421
+
422
+ ## Color Spaces modernos
423
+
424
+ ```css
425
+ /* oklch: perceptualmente uniforme, más vibrante, soportado en todos los browsers modernos */
426
+ :root {
427
+ /* oklch(lightness chroma hue) */
428
+ --color-exito: oklch(65% 0.2 145); /* Verde */
429
+ --color-alerta: oklch(75% 0.18 75); /* Amarillo */
430
+ --color-error: oklch(60% 0.22 30); /* Rojo */
431
+ --color-info: oklch(65% 0.15 240); /* Azul */
432
+ }
433
+
434
+ /* color-mix() para variantes automáticas */
435
+ .boton-hover {
436
+ /* 20% más oscuro que el primario */
437
+ background-color: color-mix(in oklch, var(--color-primario) 80%, black);
438
+ }
439
+
440
+ .fondo-sutil {
441
+ /* Color primario muy translúcido */
442
+ background-color: color-mix(in oklch, var(--color-primario) 10%, transparent);
443
+ }
444
+ ```
445
+
446
+ ## Dark mode robusto
447
+
448
+ ```css
449
+ @layer tokens {
450
+ :root {
451
+ color-scheme: light dark;
452
+
453
+ /* Tokens de color semánticos (no literal) */
454
+ --color-fondo-pagina: oklch(98% 0.005 250);
455
+ --color-fondo-superficie: oklch(100% 0 0);
456
+ --color-texto-principal: oklch(15% 0.02 250);
457
+ --color-texto-secundario: oklch(40% 0.02 250);
458
+ --color-borde: oklch(85% 0.01 250);
459
+ --color-primario: oklch(55% 0.2 250);
460
+ }
461
+
462
+ /* Dark mode: solo cambia los tokens, NO los componentes */
463
+ @media (prefers-color-scheme: dark) {
464
+ :root {
465
+ --color-fondo-pagina: oklch(12% 0.01 250);
466
+ --color-fondo-superficie: oklch(18% 0.01 250);
467
+ --color-texto-principal: oklch(92% 0.01 250);
468
+ --color-texto-secundario: oklch(65% 0.01 250);
469
+ --color-borde: oklch(30% 0.01 250);
470
+ --color-primario: oklch(70% 0.18 250);
471
+ }
472
+ }
473
+ }
474
+
475
+ /* Con control manual (clase en <html>) */
476
+ :root[data-tema="oscuro"] {
477
+ --color-fondo-pagina: oklch(12% 0.01 250);
478
+ /* ... resto de overrides */
479
+ }
480
+ ```
481
+
482
+ ## Animaciones performantes — compositor-only
483
+
484
+ Solo las propiedades `transform` y `opacity` no causan repaint ni reflow.
485
+ Son las únicas seguras para animaciones de 60fps.
486
+
487
+ ```css
488
+ /* BIEN: transform y opacity → compositor */
489
+ .tarjeta {
490
+ transition: transform var(--duracion-normal) var(--curva-suave),
491
+ opacity var(--duracion-normal) var(--curva-suave),
492
+ box-shadow var(--duracion-normal) var(--curva-suave);
493
+
494
+ &:hover {
495
+ transform: translateY(-4px) scale(1.01);
496
+ box-shadow: var(--sombra-lg);
497
+ }
498
+ }
499
+
500
+ /* EVITAR: propiedades que causan reflow */
501
+ /* width, height, top, left, margin, padding → causan reflow */
502
+ .mal-ejemplo {
503
+ transition: width 300ms; /* Causa reflow en cada frame */
504
+ }
505
+
506
+ /* BIEN: usar transform en lugar de top/left */
507
+ .modal {
508
+ position: fixed;
509
+ inset: 0;
510
+ display: grid;
511
+ place-items: center;
512
+
513
+ & .modal__contenido {
514
+ transform: scale(0.9);
515
+ opacity: 0;
516
+ transition: transform var(--duracion-normal) var(--curva-suave),
517
+ opacity var(--duracion-normal) var(--curva-suave);
518
+
519
+ &.abierto {
520
+ transform: scale(1);
521
+ opacity: 1;
522
+ }
523
+ }
524
+ }
525
+
526
+ /* Respetar prefers-reduced-motion SIEMPRE */
527
+ @media (prefers-reduced-motion: reduce) {
528
+ *, *::before, *::after {
529
+ animation-duration: 0.01ms !important;
530
+ animation-iteration-count: 1 !important;
531
+ transition-duration: 0.01ms !important;
532
+ scroll-behavior: auto !important;
533
+ }
534
+ }
535
+ ```
536
+
537
+ ## View Transitions API
538
+
539
+ ```css
540
+ /* Transiciones de página fluidas */
541
+ ::view-transition-old(root) {
542
+ animation: 200ms ease-out fade-out;
543
+ }
544
+
545
+ ::view-transition-new(root) {
546
+ animation: 300ms ease-in fade-in;
547
+ }
548
+
549
+ @keyframes fade-out {
550
+ from { opacity: 1; }
551
+ to { opacity: 0; }
552
+ }
553
+
554
+ @keyframes fade-in {
555
+ from { opacity: 0; }
556
+ to { opacity: 1; }
557
+ }
558
+
559
+ /* Transición específica para un elemento */
560
+ .hero-imagen {
561
+ view-transition-name: hero-imagen;
562
+ }
563
+
564
+ ::view-transition-group(hero-imagen) {
565
+ animation-duration: 400ms;
566
+ animation-timing-function: cubic-bezier(0.34, 1.56, 0.64, 1);
567
+ }
568
+ ```
569
+
570
+ ## Anti-patrones — detectar y eliminar
571
+
572
+ ### !important — síntoma de problema de especificidad
573
+
574
+ ```css
575
+ /* MAL: !important como parche */
576
+ .boton { color: blue !important; }
577
+
578
+ /* BIEN: resolver el problema de especificidad con @layer */
579
+ @layer overrides {
580
+ .boton { color: blue; } /* Gana porque overrides está al final */
581
+ }
582
+ ```
583
+
584
+ ### Inline styles en HTML — rompen la mantenibilidad
585
+
586
+ ```html
587
+ <!-- MAL -->
588
+ <div style="color: red; margin-top: 16px;">
589
+
590
+ <!-- BIEN: usar clase con Custom Property si el valor es dinámico -->
591
+ <div class="alerta" style="--alerta-color: red;">
592
+ ```
593
+
594
+ ```css
595
+ .alerta { color: var(--alerta-color, var(--color-error)); }
596
+ ```
597
+
598
+ ### Z-index wars — crear un sistema explícito
599
+
600
+ ```css
601
+ @layer tokens {
602
+ :root {
603
+ --z-base: 0;
604
+ --z-sobre-base: 10;
605
+ --z-dropdown: 100;
606
+ --z-sticky: 200;
607
+ --z-modal-fondo: 300;
608
+ --z-modal: 400;
609
+ --z-tooltip: 500;
610
+ --z-notificacion: 600;
611
+ --z-maximo: 9999; /* Solo para emergencias, documentar por qué */
612
+ }
613
+ }
614
+
615
+ /* Uso */
616
+ .dropdown { z-index: var(--z-dropdown); }
617
+ .modal { z-index: var(--z-modal); }
618
+ ```
619
+
620
+ ### Selectores de alta especificidad
621
+
622
+ ```css
623
+ /* MAL: especificidad alta e innecesaria */
624
+ div.contenedor > ul.lista > li.item > a.enlace { color: blue; }
625
+
626
+ /* BIEN: selector de clase simple dentro de @layer */
627
+ @layer components {
628
+ .enlace-nav { color: blue; }
629
+ }
630
+ ```
631
+
632
+ ## Auditoría de CSS existente
633
+
634
+ Al auditar estilos de un proyecto existente, buscar:
635
+
636
+ ```bash
637
+ # Contar instancias de anti-patrones
638
+ grep -r "!important" src/ --include="*.css" | wc -l
639
+ grep -r "z-index" src/ --include="*.css" | sort -t: -k2 -n
640
+ grep -r "inline" src/ --include="*.html" | grep "style="
641
+ ```
642
+
643
+ Clasificar hallazgos:
644
+ - **Crítico**: !important en reglas base, z-index > 9999 sin documentar
645
+ - **Alto**: inline styles con lógica de negocio, selectores de especificidad > 1,0,0
646
+ - **Medio**: media queries inconsistentes, Custom Properties no usadas
647
+ - **Bajo**: comentarios desactualizados, propiedades físicas donde deberían ser lógicas
648
+
649
+ ## Checklist de estilos accesibles
650
+
651
+ - [ ] Contraste mínimo 4.5:1 para texto normal, 3:1 para texto grande (18px+)
652
+ - [ ] Contraste de foco visible: 3:1 entre estado normal y estado foco
653
+ - [ ] Nunca `outline: none` ni `outline: 0` sin reemplazo visual equivalente
654
+ - [ ] Tamaño mínimo de área táctil: 44x44px en móvil
655
+ - [ ] No comunicar información solo con color (también usar ícono o texto)
656
+ - [ ] `prefers-reduced-motion` respetado en todas las animaciones
657
+ - [ ] `prefers-contrast: more` considerado para usuarios con alta visibilidad
658
+ - [ ] `color-scheme: light dark` declarado para que el navegador adapte UI nativa
659
+
660
+ ## Reglas estrictas
661
+
662
+ - NUNCA uses `!important` — resuelve el problema de especificidad con @layer
663
+ - NUNCA uses inline styles con valores hardcodeados — usa Custom Properties
664
+ - NUNCA uses `z-index` sin el sistema de tokens de z-index
665
+ - NUNCA animaciones con propiedades que causan reflow (width, height, top, left)
666
+ - NUNCA `outline: none` sin un reemplazo visual de foco accesible
667
+ - SIEMPRE usa propiedades lógicas (block/inline) en código nuevo
668
+ - SIEMPRE incluye `@media (prefers-reduced-motion: reduce)` para toda animación
669
+ - SIEMPRE define Custom Properties en @layer tokens, no en selectores de componente
670
+ - SIEMPRE invoca al menos 1 skill antes de implementar
671
+ - **DRY obligatorio** — antes de crear un componente, hook, servicio o utility nuevo, buscar si ya existe algo equivalente con `Grep`. Si existe, reutilizar o extender — no duplicar. Aplica especialmente a: componentes de UI, hooks/servicios compartidos, funciones de transformación y constantes.
672
+ - **Si detectas duplicación** de lógica existente al implementar, extraer a un módulo compartido antes de continuar. No dejar la duplicación "para después".
673
+
674
+ ## Gotchas / Errores comunes no obvios
675
+
676
+ **`!important` como parche de especificidad**: se agrega `!important` para que un estilo "gane" sobre otro en lugar de resolver el conflicto de especificidad. Causa: es la solución más rápida cuando un estilo no aplica. Solución: resolver el problema de especificidad usando `@layer` — `@important` crea deuda técnica de especificidad que se acumula y hace el código imposible de mantener.
677
+
678
+ **Animaciones con propiedades que causan reflow (`width`, `height`, `top`, `left`)**: la animación es fluida en desarrollo pero jadea en producción en dispositivos lentos. Causa: se anima la propiedad que describe visualmente lo que se quiere. Solución: SOLO animar `transform` y `opacity` — son las únicas propiedades que el navegador puede animar en el compositor sin reflow.
679
+
680
+ **`outline: none` sin reemplazo visible de foco**: se elimina el outline del navegador "porque se ve feo" dejando a usuarios de teclado sin indicador de dónde están. Causa: el outline por defecto del navegador no coincide con el diseño. Solución: NUNCA `outline: none` sin `focus-visible:ring-*` o un indicador equivalente con contraste mínimo 3:1 — el foco es el cursor del usuario de teclado.
681
+
682
+ **Custom Property ad-hoc fuera de `@layer tokens`**: un componente define `--color-boton: blue` dentro del selector del componente en lugar de en la capa de tokens. Causa: parece más localizado definirlo donde se usa. Solución: SIEMPRE definir Custom Properties en `@layer tokens` en `:root` — los tokens fuera de la capa de tokens rompen el sistema de dark mode y la consistencia entre componentes.
683
+
684
+ ## Señales de que debes parar
685
+
686
+ Para y reporta si encuentras:
687
+ - El sistema de tokens del proyecto contradice el design system del ux-disenador
688
+ - Hay conflicto entre el CSS nativo y un framework de CSS (Tailwind, Bootstrap) sin resolver
689
+ - Los requisitos de soporte de browsers excluyen CSS features modernas necesarias
690
+ - El problema requiere cambiar la arquitectura de estilos de toda la aplicación
691
+ - Hay deuda técnica de especificidad tan profunda que requiere refactorización masiva
692
+
693
+ ## Formato de reporte al terminar
694
+
695
+ ```markdown
696
+ ## Reporte de Implementación CSS — [feature] — [fecha]
697
+
698
+ ### Tecnologías y skills cargados
699
+ - Skills: [lista de skills invocados]
700
+ - Arquitectura: @layer / CSS Modules / BEM / [otra]
701
+
702
+ ### Anti-patrones eliminados
703
+ | Anti-patrón | Instancias | Solución aplicada |
704
+ |-------------|-----------|------------------|
705
+ | !important | X | @layer overrides |
706
+
707
+ ### Características CSS modernas usadas
708
+ - Container Queries: [Sí/No, dónde]
709
+ - CSS Nesting: [Sí/No]
710
+ - oklch colors: [Sí/No]
711
+ - Logical Properties: [Sí/No]
712
+
713
+ ### Verificaciones ejecutadas
714
+ - [ ] Sin !important en código nuevo
715
+ - [ ] Contraste verificado con herramienta (WebAIM, browser DevTools)
716
+ - [ ] prefers-reduced-motion implementado
717
+ - [ ] Animaciones solo en transform/opacity
718
+
719
+ ### Estado: COMPLETADO | PARCIAL | BLOQUEADO
720
+ ```