sdd-es 2.0.0 → 2.5.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 (95) hide show
  1. package/.claude/settings.json +21 -45
  2. package/LICENSE +21 -0
  3. package/README.md +51 -21
  4. package/agents/architecture-designer.md +174 -0
  5. package/agents/arquitecto.md +16 -1
  6. package/agents/asesor-datos.md +15 -1
  7. package/agents/critico.md +37 -1
  8. package/agents/desarrollador-backend.md +3 -1
  9. package/agents/desarrollador-frontend.md +3 -1
  10. package/agents/disenador-api.md +13 -1
  11. package/agents/documentador.md +3 -1
  12. package/agents/investigador.md +3 -1
  13. package/agents/operaciones.md +3 -1
  14. package/agents/product-designer.md +232 -0
  15. package/agents/revisor.md +25 -1
  16. package/agents/seguridad.md +5 -1
  17. package/agents/tester.md +3 -1
  18. package/claude-hooks/agent-memory.js +154 -0
  19. package/cli/index.js +1 -2
  20. package/commands/sdd.analizar.md +23 -2
  21. package/commands/sdd.compliance.md +516 -0
  22. package/commands/sdd.configurar.md +33 -0
  23. package/commands/sdd.constitucion.md +198 -23
  24. package/commands/sdd.construir.md +210 -0
  25. package/commands/sdd.dise/303/261ar.md +188 -0
  26. package/commands/sdd.estado.md +68 -1
  27. package/commands/sdd.exportar.md +344 -0
  28. package/commands/sdd.implementar.md +203 -23
  29. package/commands/sdd.interpretar.md +239 -0
  30. package/commands/sdd.md +70 -1
  31. package/commands/sdd.optimizar.md +164 -0
  32. package/commands/sdd.planificar.md +64 -0
  33. package/commands/sdd.verificar.md +10 -0
  34. package/craft/accessibility-baseline.md +216 -0
  35. package/craft/anti-ai-slop.md +158 -0
  36. package/craft/color.md +160 -0
  37. package/craft/typography.md +121 -0
  38. package/design-systems/bold-brutalist/DESIGN.md +239 -0
  39. package/design-systems/editorial-minimal/DESIGN.md +205 -0
  40. package/design-systems/neutral-modern/DESIGN.md +227 -0
  41. package/design-systems/vibrant-consumer/DESIGN.md +257 -0
  42. package/design-systems/warm-editorial/DESIGN.md +221 -0
  43. package/docs/AGENTES.md +4 -1
  44. package/docs/FABRICA.md +164 -115
  45. package/docs/MEMORIA-Y-OBSERVABILIDAD.md +237 -0
  46. package/docs/MODELOS.md +3 -0
  47. package/docs/QUE-PASA-SI-FALLA.md +404 -0
  48. package/docs/SEGURIDAD-PARA-NOTECNICOS.md +280 -0
  49. package/package.json +5 -3
  50. package/skills/cache-audit/SKILL.md +163 -0
  51. package/skills/critica-diseno/SKILL.md +193 -0
  52. package/skills/descubrir-idea/SKILL.md +133 -0
  53. package/skills/effort-router/SKILL.md +128 -0
  54. package/skills/elegir-direccion/SKILL.md +184 -0
  55. package/skills/github-connect/IMPLEMENTATION-CHECKLIST.md +297 -0
  56. package/skills/github-connect/INDEX.md +223 -0
  57. package/skills/github-connect/INTEGRATION.md +361 -0
  58. package/skills/github-connect/QUICK-START.md +168 -0
  59. package/skills/github-connect/README.md +414 -0
  60. package/skills/github-connect/RESUMEN_IMPLEMENTACION.txt +374 -0
  61. package/skills/github-connect/SKILL.md +343 -0
  62. package/skills/github-connect/STRUCTURE.txt +252 -0
  63. package/skills/github-connect/example-config.yaml +41 -0
  64. package/skills/github-connect/github-connect.sh +419 -0
  65. package/skills/interpretar-idea/SKILL.md +254 -0
  66. package/skills/memory-compactor/SKILL.md +114 -0
  67. package/skills/modo-guiado/SKILL.md +12 -2
  68. package/skills/observabilidad-consumo/SKILL.md +164 -0
  69. package/skills/token-budget/SKILL.md +154 -0
  70. package/skills/vercel-deploy/00-START-HERE.txt +364 -0
  71. package/skills/vercel-deploy/CHECKLIST.md +205 -0
  72. package/skills/vercel-deploy/EXEC-SUMMARY.txt +322 -0
  73. package/skills/vercel-deploy/FLOW.txt +334 -0
  74. package/skills/vercel-deploy/INDEX.md +276 -0
  75. package/skills/vercel-deploy/INTEGRATION.md +328 -0
  76. package/skills/vercel-deploy/MANIFEST.md +310 -0
  77. package/skills/vercel-deploy/README.md +65 -0
  78. package/skills/vercel-deploy/SKILL.md +356 -0
  79. package/skills/vercel-deploy/deploy.sh +298 -0
  80. package/skills/vercel-deploy/estado.json.example +205 -0
  81. package/skills/vercel-deploy/skill.yaml +323 -0
  82. package/skills/vercel-deploy/vercel-deploy.sh +216 -0
  83. package/skills/wireframe-mvp/SKILL.md +157 -0
  84. package/.claude-plugin/marketplace.json +0 -31
  85. package/.claude-plugin/plugin.json +0 -97
  86. package/docs/EJEMPLO-PRACTICA.md +0 -383
  87. package/docs/EJEMPLOS.md +0 -212
  88. /package/skills/{compresion-tokens.md → compresion-tokens/SKILL.md} +0 -0
  89. /package/skills/{constitucion-constraint.md → constitucion-constraint/SKILL.md} +0 -0
  90. /package/skills/{deteccion-stack.md → deteccion-stack/SKILL.md} +0 -0
  91. /package/skills/{enrutador-agentes.md → enrutador-agentes/SKILL.md} +0 -0
  92. /package/skills/{gestion-estado.md → gestion-estado/SKILL.md} +0 -0
  93. /package/skills/{indexador.md → indexador/SKILL.md} +0 -0
  94. /package/skills/{validacion-spec.md → validacion-spec/SKILL.md} +0 -0
  95. /package/skills/{verificador-implementacion.md → verificador-implementacion/SKILL.md} +0 -0
@@ -0,0 +1,516 @@
1
+ # /sdd.compliance — Reporte de Cumplimiento Regulatorio
2
+
3
+ ## Descripción
4
+
5
+ Genera un reporte en tiempo real que diagnostica el estado de compliance del proyecto contra regulaciones internacionales (GDPR, SOC2, ISO 27001, HIPAA). Identifica gaps, asigna un nivel de riesgo y recomienda acciones concretas.
6
+
7
+ ---
8
+
9
+ ## Uso
10
+
11
+ ```bash
12
+ /sdd.compliance
13
+ ```
14
+
15
+ Sin opciones: genera reporte completo (todas las regulaciones activas).
16
+
17
+ ### Opciones
18
+
19
+ ```bash
20
+ /sdd.compliance --framework=gdpr # Solo GDPR
21
+ /sdd.compliance --framework=soc2 # Solo SOC2
22
+ /sdd.compliance --framework=iso27001 # Solo ISO 27001
23
+ /sdd.compliance --framework=hipaa # Solo HIPAA
24
+ /sdd.compliance --output=json # Salida en JSON (para CI/CD)
25
+ /sdd.compliance --strict # Reporta warnings como errores
26
+ ```
27
+
28
+ ---
29
+
30
+ ## PASO 1: Detectar Configuración Actual
31
+
32
+ El comando comienza leyendo la configuración de tu proyecto:
33
+
34
+ ### Busca en `sdd.config.yaml`:
35
+
36
+ ```yaml
37
+ preset: enterprise # ← lean / startup / enterprise
38
+ compliance:
39
+ enabled: true # ← ¿Está habilitado compliance?
40
+ frameworks:
41
+ - gdpr
42
+ - soc2
43
+ - iso27001
44
+ security:
45
+ agente_seguridad: true # ← ¿Está activo agente de seguridad?
46
+ deteccion_pii: true # ← ¿Detecta datos personales?
47
+ encryption: aes-256 # ← Algoritmo configurado
48
+ autenticacion: oauth2 # ← Método de autenticación
49
+ ```
50
+
51
+ **Salida**:
52
+ ```
53
+ ✅ Configuración detectada:
54
+ Preset: enterprise
55
+ Frameworks activos: GDPR, SOC2, ISO 27001
56
+ Agente de seguridad: ACTIVADO
57
+ ```
58
+
59
+ ### Lee la Constitución de seguridad
60
+
61
+ El comando analiza qué restricciones están configuradas en el proyecto:
62
+
63
+ ```
64
+ ✅ Constitución de seguridad:
65
+ - Encriptación AES-256 de datos en reposo
66
+ - OAuth2 para autenticación
67
+ - Logging obligatorio de cambios sensibles
68
+ - Detección de PII automatizada
69
+ ```
70
+
71
+ ### Verifica Agentes activos
72
+
73
+ ```
74
+ ✅ Agentes especializados:
75
+ ✓ security_agent (detecta vulnerabilidades)
76
+ ✓ auditor_agent (genera logs)
77
+ ✓ documentador_agent (escribe especificaciones)
78
+ ```
79
+
80
+ ---
81
+
82
+ ## PASO 2: Generar Reporte de Compliance
83
+
84
+ El comando evalúa cada regulación activa contra el estado actual del proyecto.
85
+
86
+ ### Formato: Tabla de Cumplimiento
87
+
88
+ ```
89
+ ┌─────────────────────────────────────────────────────────────────┐
90
+ │ REGULACIÓN: GDPR (EU - Protección de Datos) │
91
+ ├────────────────────┬────────┬──────────┬──────────┬─────────────┤
92
+ │ Requerimiento │ Estado │ Evidencia│ Riesgo │ Acción │
93
+ ├────────────────────┼────────┼──────────┼──────────┼─────────────┤
94
+ │ 1. Especificación │ ✅ │ spec.md │ BAJO │ OK │
95
+ │ clara de datos │ │ 2.5 KB │ │ │
96
+ │ personales │ │ │ │ │
97
+ ├────────────────────┼────────┼──────────┼──────────┼─────────────┤
98
+ │ 2. Protección de │ ✅ │ Agente │ BAJO │ OK │
99
+ │ PII │ │ detecta │ │ │
100
+ │ │ │ en-code │ │ │
101
+ ├────────────────────┼────────┼──────────┼──────────┼─────────────┤
102
+ │ 3. Auditoría de │ ✅ │ .sdd/ │ BAJO │ OK │
103
+ │ acceso │ │ cambios/ │ │ │
104
+ │ │ │ 45 items │ │ │
105
+ ├────────────────────┼────────┼──────────┼──────────┼─────────────┤
106
+ │ 4. Encriptación │ ⚠️ │ En │ MEDIO │ Ejecutar │
107
+ │ de datos en │ │ tránsito │ │ /sdd.spec │
108
+ │ tránsito │ │ OK, en │ │ y mencionar │
109
+ │ │ │ reposo? │ │'data at rest│
110
+ ├────────────────────┼────────┼──────────┼──────────┼─────────────┤
111
+ │ 5. Data │ ⚠️ │ Política │ MEDIO │ Agregar │
112
+ │ Retention │ │ no │ │ a spec │
113
+ │ Policy │ │ definida │ │ "Datos se │
114
+ │ │ │ │ │ retienen N │
115
+ │ │ │ │ │ días" │
116
+ └────────────────────┴────────┴──────────┴──────────┴─────────────┘
117
+ ```
118
+
119
+ ### Leyenda de Estados
120
+
121
+ | Estado | Significado | Acción |
122
+ |--------|-------------|--------|
123
+ | ✅ | Cumplimiento verificado | Ninguna — mantén el control |
124
+ | ⚠️ | Cumplimiento parcial / Gap menor | Ejecución de comando recomendado |
125
+ | ❌ | No cumple — riesgo alto | Detener cambios, ejecutar acción inmediatamente |
126
+
127
+ ### Leyenda de Riesgo
128
+
129
+ | Riesgo | Impacto | Urgencia |
130
+ |--------|---------|----------|
131
+ | **BAJO** | No hay exposición inmediata | Resolver en próximo sprint |
132
+ | **MEDIO** | Exposición si auditan ahora | Resolver esta semana |
133
+ | **ALTO** | Violación clara de regulación | Resolver hoy |
134
+
135
+ ---
136
+
137
+ ## PASO 3: Gaps Identificados y Acciones
138
+
139
+ Para cada gap, el comando te da:
140
+
141
+ 1. **Descripción clara** del problema
142
+ 2. **Comando específico** a ejecutar
143
+ 3. **Tiempo estimado** para resolverlo
144
+
145
+ ### Ejemplo 1: GDPR — Falta definir data retention policy
146
+
147
+ ```
148
+ Gap GDPR-002: Data Retention Policy no documentada
149
+
150
+ Estado: ⚠️ Riesgo MEDIO
151
+ Regulación: GDPR Art. 5 (Principios) - Los datos debe retenerse solo
152
+ mientras sea necesario
153
+
154
+ Problema: Tu especificación menciona que almacenas emails de usuarios
155
+ pero no dice por cuánto tiempo.
156
+
157
+ Acción:
158
+ 1. Ejecuta: /sdd.especificar
159
+ 2. Selecciona: "Actualizar especificación existente"
160
+ 3. Agrega: "Los datos de usuario se retienen 12 meses tras
161
+ inactividad, luego se eliminan automáticamente"
162
+ 4. El agente de seguridad validará la política
163
+
164
+ Tiempo estimado: 5 minutos
165
+ ```
166
+
167
+ ### Ejemplo 2: SOC2 — Logging incompleto
168
+
169
+ ```
170
+ Gap SOC2-CC6.2: Audit logging insuficiente
171
+
172
+ Estado: ⚠️ Riesgo ALTO
173
+ Regulación: SOC2 Trust Service Criteria CC6.2 - Se deben registrar
174
+ cambios con quién, qué, cuándo, dónde
175
+
176
+ Problema: Tu proyecto logguea cambios de código pero no cambios de
177
+ permisos ni acceso a bases de datos sensibles.
178
+
179
+ Acción:
180
+ 1. Ejecuta: /sdd.especificar cambios-de-permisos
181
+ 2. Declara qué permisos son "sensibles" (admin, finance, etc)
182
+ 3. El agente de auditoría agregará logging automático
183
+ 4. Verifica: /sdd.compliance --framework=soc2
184
+
185
+ Tiempo estimado: 15 minutos
186
+ ```
187
+
188
+ ### Ejemplo 3: ISO 27001 — Control de acceso débil
189
+
190
+ ```
191
+ Gap ISO27001-A.12.1.1: Acceso sin restricción por rol
192
+
193
+ Estado: ❌ Riesgo ALTO
194
+ Regulación: ISO 27001 A.12.1.1 - Debe haber segregación de duties
195
+
196
+ Problema: Tu config permite que un usuario apruebe y ejecute su propio
197
+ cambio. ISO 27001 requiere "least privilege" — nadie puede
198
+ autorizar y ejecutar.
199
+
200
+ Acción:
201
+ 1. Edita: sdd.config.yaml
202
+ 2. Agraga en [security]:
203
+ segregation_of_duties: true
204
+ reviewer_must_differ_from_author: true
205
+ 3. Ejecuta: /sdd.implementar
206
+ 4. Verifica: /sdd.compliance --framework=iso27001
207
+
208
+ Tiempo estimado: 20 minutos
209
+ ```
210
+
211
+ ### Ejemplo 4: HIPAA — MFA no obligatorio
212
+
213
+ ```
214
+ Gap HIPAA-A.9.4.3: Autenticación multi-factor no obligatoria
215
+
216
+ Estado: ❌ Riesgo CRÍTICO
217
+ Regulación: HIPAA Security Rule - Acceso a PHI (Protected Health Info)
218
+ requiere MFA obligatorio
219
+
220
+ Problema: Tu config tiene autenticación OAuth2 pero MFA es opcional.
221
+ Para HIPAA, debe ser obligatorio.
222
+
223
+ Acción:
224
+ 1. Edita: sdd.config.yaml
225
+ 2. Cambia:
226
+ autenticacion: oauth2
227
+ mfa: optional
228
+ ↓↓↓
229
+ autenticacion: oauth2
230
+ mfa: required
231
+ 3. Ejecuta: /sdd.implementar
232
+ 4. Verifica: /sdd.compliance --framework=hipaa --strict
233
+
234
+ Tiempo estimado: 25 minutos
235
+ ```
236
+
237
+ ---
238
+
239
+ ## PASO 4: Recomendación Final
240
+
241
+ Al terminar, el comando te da una recomendación estratégica:
242
+
243
+ ### Escenario A: Preset enterprise, sin gaps
244
+
245
+ ```
246
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
247
+
248
+ ✅ CUMPLIMIENTO CERTIFICADO
249
+
250
+ Preset: enterprise
251
+ Frameworks: GDPR ✓, SOC2 ✓, ISO 27001 ✓, HIPAA ✓
252
+ Agentes: security ✓, auditor ✓, documentador ✓
253
+ Gaps: 0
254
+
255
+ Tu proyecto está ready para auditoría. Recomendación:
256
+
257
+ 1. Ejecuta /sdd.implementar antes de cada release para verificar
258
+ que los cambios mantienen compliance
259
+ 2. Revisa /sdd.compliance mensualmente para detectar nuevos gaps
260
+ 3. Si hay cambio de regulación (ej: expande a mercado EU), ejecuta
261
+ /sdd.compliance --framework=gdpr
262
+
263
+ Next: Integra en CI/CD
264
+
265
+ gh secret set SDD_COMPLIANCE_STRICT=true
266
+ # En tu workflow:
267
+ /sdd.compliance --output=json --strict > compliance.json
268
+ # Bloquea el merge si compliance falla
269
+
270
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
271
+ ```
272
+
273
+ ### Escenario B: Preset startup, algunos gaps
274
+
275
+ ```
276
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
277
+
278
+ ⚠️ CUMPLIMIENTO PARCIAL
279
+
280
+ Preset: startup
281
+ Frameworks: GDPR ⚠️ (2 gaps), SOC2 ❌ (4 gaps)
282
+ Gaps: 6 total
283
+ Riesgo: MEDIO-ALTO
284
+
285
+ Tu proyecto puede lanzarse, pero si auditan hoy, encontrarán issues.
286
+
287
+ Recomendación:
288
+
289
+ Opción 1 (RÁPIDO - para MVP):
290
+ - Resuelve los gaps ALTO (3 de 6)
291
+ - Tiempo: 1-2 horas
292
+ - Resultado: Reduce riesgo a MEDIO
293
+
294
+ Opción 2 (COMPLETO - antes de escalar):
295
+ - Cambia preset: startup → enterprise en sdd.config.yaml
296
+ - Ejecuta: /sdd.compliance
297
+ - Resuelve todos los gaps
298
+ - Tiempo: 4-6 horas
299
+ - Resultado: Listo para auditoría
300
+
301
+ Te recomiendo Opción 2 si:
302
+ - Ya tienes datos de usuarios (no importa volumen)
303
+ - Planeas levantar inversión
304
+ - El cliente es empresa grande (fintech, healthcare)
305
+
306
+ Primeros pasos:
307
+ sdd.config.yaml → cambiar preset a enterprise
308
+ /sdd.compliance → ver gaps priorizados
309
+ /sdd.implementar → ejecutar agente de seguridad
310
+
311
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
312
+ ```
313
+
314
+ ### Escenario C: Preset lean, sin compliance
315
+
316
+ ```
317
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
318
+
319
+ ❌ COMPLIANCE NO CONFIGURADO
320
+
321
+ Preset: lean
322
+ Frameworks: ninguno habilitado
323
+ Agentes: ninguno activo
324
+ Gaps: N/A (compliance deshabilitado)
325
+
326
+ Tu proyecto no tiene compliance integrado. Esto es OK si:
327
+ - Es solo para interno / demo
328
+ - No toca datos de usuarios
329
+ - No busca inversión ni clientes empresariales
330
+
331
+ Si en el futuro necesitas compliance, cambia a:
332
+
333
+ sdd.config.yaml:
334
+ preset: enterprise
335
+ compliance:
336
+ enabled: true
337
+
338
+ Luego ejecuta:
339
+ /sdd.compliance
340
+
341
+ El agente te guiará automáticamente.
342
+
343
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
344
+ ```
345
+
346
+ ---
347
+
348
+ ## Integración en CI/CD
349
+
350
+ Para bloquear merges que violen compliance:
351
+
352
+ ### GitHub Actions
353
+
354
+ ```yaml
355
+ name: Compliance Check
356
+ on: [pull_request]
357
+
358
+ jobs:
359
+ compliance:
360
+ runs-on: ubuntu-latest
361
+ steps:
362
+ - uses: actions/checkout@v3
363
+ - name: Run compliance check
364
+ run: /sdd.compliance --output=json --strict > compliance.json
365
+ - name: Block if compliance fails
366
+ run: |
367
+ if grep -q '"status": "fail"' compliance.json; then
368
+ echo "❌ Compliance check failed"
369
+ cat compliance.json
370
+ exit 1
371
+ fi
372
+ - name: Upload compliance report
373
+ uses: actions/upload-artifact@v3
374
+ with:
375
+ name: compliance-report
376
+ path: compliance.json
377
+ ```
378
+
379
+ ### GitLab CI
380
+
381
+ ```yaml
382
+ compliance_check:
383
+ stage: test
384
+ script:
385
+ - /sdd.compliance --output=json --strict > compliance.json
386
+ - |
387
+ if grep -q '"status": "fail"' compliance.json; then
388
+ echo "❌ Compliance check failed"
389
+ cat compliance.json
390
+ exit 1
391
+ fi
392
+ artifacts:
393
+ paths:
394
+ - compliance.json
395
+ ```
396
+
397
+ ---
398
+
399
+ ## Ejemplos de salida real
400
+
401
+ ### Output por terminal (legible)
402
+
403
+ ```bash
404
+ $ /sdd.compliance --framework=gdpr
405
+
406
+ ┌─ GDPR: Protección de Datos (EU) ────────────────────────────────┐
407
+ │ │
408
+ │ ✅ CUMPLIMIENTO: 4/5 requisitos │
409
+ │ │
410
+ │ ✅ Especificación clara │
411
+ │ Encontrado: .sdd/especificaciones/datos-personales.md │
412
+ │ │
413
+ │ ✅ Protección de PII │
414
+ │ Agente de seguridad detecta datos personales en código │
415
+ │ │
416
+ │ ✅ Auditoría de acceso │
417
+ │ Historial: .sdd/cambios/ (48 entradas) │
418
+ │ │
419
+ │ ⚠️ Data retention policy │
420
+ │ NO ENCONTRADO. Acción: /sdd.especificar │
421
+ │ │
422
+ │ ⚠️ Encryption en reposo │
423
+ │ En tránsito: ✓ (TLS 1.3) │
424
+ │ En reposo: ? (revisar config de BD) │
425
+ │ Acción: sdd.config.yaml → [storage] encryption: aes-256 │
426
+ │ │
427
+ └───────────────────────────────────────────────────────────────────┘
428
+
429
+ RESUMEN:
430
+ Gaps: 2 (ambos resolvibles en <30 min)
431
+ Riesgo: MEDIO
432
+ Recomendación: Ejecuta las 2 acciones y listo
433
+ ```
434
+
435
+ ### Output JSON (para máquinas)
436
+
437
+ ```json
438
+ {
439
+ "timestamp": "2026-06-13T14:23:45Z",
440
+ "preset": "enterprise",
441
+ "compliance_enabled": true,
442
+ "frameworks": [
443
+ {
444
+ "name": "gdpr",
445
+ "status": "partial",
446
+ "score": 80,
447
+ "requirements": [
448
+ {
449
+ "id": "GDPR-001",
450
+ "name": "Especificación clara",
451
+ "status": "pass",
452
+ "evidence": "spec.md 2.5 KB"
453
+ },
454
+ {
455
+ "id": "GDPR-004",
456
+ "name": "Data retention policy",
457
+ "status": "fail",
458
+ "evidence": null,
459
+ "action": "/sdd.especificar",
460
+ "severity": "medium"
461
+ }
462
+ ]
463
+ }
464
+ ],
465
+ "total_gaps": 3,
466
+ "total_severity": "medium",
467
+ "next_action": "Execute: /sdd.especificar"
468
+ }
469
+ ```
470
+
471
+ ---
472
+
473
+ ## Troubleshooting
474
+
475
+ ### "Error: sdd.config.yaml not found"
476
+
477
+ ```bash
478
+ # Verifica que estés en la raíz del proyecto
479
+ ls sdd.config.yaml
480
+
481
+ # Si no existe, inicializa SDD-ES
482
+ /sdd.init --preset=enterprise
483
+ ```
484
+
485
+ ### "Error: .sdd/ directory is empty"
486
+
487
+ ```bash
488
+ # El directorio .sdd/ debe existir con artefactos
489
+ # Genera al menos una especificación
490
+ /sdd.especificar "Sistema procesa datos de usuarios"
491
+
492
+ # Luego intenta de nuevo
493
+ /sdd.compliance
494
+ ```
495
+
496
+ ### "Gap reportado es falso positivo"
497
+
498
+ ```bash
499
+ # Abre docs/COMPLIANCE.md para entender qué busca el agente
500
+ # Ajusta tu especificación o sdd.config.yaml según corresponda
501
+ # Si aún así es falso, reporta:
502
+ /sdd.issue "compliance-gap-false-positive"
503
+ ```
504
+
505
+ ---
506
+
507
+ ## Resumen rápido
508
+
509
+ | Comando | Para qué | Frecuencia |
510
+ |---------|----------|-----------|
511
+ | `/sdd.compliance` | Diagnóstico completo | Semanal o antes de release |
512
+ | `/sdd.compliance --framework=gdpr` | Solo GDPR | Cuando manejes datos EU |
513
+ | `/sdd.compliance --output=json --strict` | CI/CD integration | En cada PR |
514
+ | `/sdd.compliance --framework=hipaa` | Solo HIPAA | Si es healthcare |
515
+
516
+ **Prioridad**: Resuelve gaps ALTO primero, luego MEDIO, BAJO al final.
@@ -179,6 +179,39 @@ CAMBIOS:
179
179
  Los cambios se aplican a la próxima ejecución de comandos SDD.
180
180
  ```
181
181
 
182
+ ## Modo: Control de esfuerzo (effort level)
183
+
184
+ Claude Code tiene un nivel de esfuerzo **global** que controla cuánto razonamiento aplica el modelo. No es un campo de agente — es una configuración de la sesión.
185
+
186
+ **Cómo cambiarlo:**
187
+
188
+ ```bash
189
+ # En la sesión activa de Claude Code — escribe directamente:
190
+ /effort low # rápido, respuestas cortas
191
+ /effort medium # balanceado (default)
192
+ /effort high # más razonamiento
193
+ /effort xhigh # máximo — equivale a "ultracode"
194
+
195
+ # O desde el terminal antes de abrir Claude Code:
196
+ CLAUDE_CODE_EFFORT_LEVEL=xhigh claude
197
+ ```
198
+
199
+ **Recomendación SDD-ES por fase:**
200
+
201
+ | Fase | Effort recomendado | Razón |
202
+ |------|--------------------|-------|
203
+ | `/sdd.descubrir`, `/sdd.especificar` | `medium` | Exploración inicial |
204
+ | `/sdd.planificar`, `/sdd.analizar` | `high` | Decisiones con impacto |
205
+ | `/sdd.implementar` (agentes OPUS) | `xhigh` | Arquitectura, seguridad, BD |
206
+ | `/sdd.implementar` (agentes SONNET) | `medium` | Implementación estándar |
207
+ | `/sdd.qa`, `/sdd.verificar` | `high` | Revisión crítica |
208
+ | `/sdd.documentar`, investigación | `low` | Tareas de baja complejidad |
209
+
210
+ Cuando el usuario escribe `/sdd.configurar effort:X`:
211
+ - Muestra el nivel actual y el recomendado para la fase activa
212
+ - Indica cómo aplicarlo (`/effort X` en Claude Code o la variable de entorno)
213
+ - NO modifica ningún archivo de agente — el effort es siempre global de sesión
214
+
182
215
  ## Modo asistente: Recomendar configuración
183
216
 
184
217
  Si el usuario escribe `/sdd.configurar recomendar`: