claude-mpm 4.1.6__py3-none-any.whl → 4.24.0__py3-none-any.whl

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.

Potentially problematic release.


This version of claude-mpm might be problematic. Click here for more details.

Files changed (866) hide show
  1. claude_mpm/BUILD_NUMBER +1 -1
  2. claude_mpm/VERSION +1 -1
  3. claude_mpm/__init__.py +20 -5
  4. claude_mpm/agents/BASE_AGENT_TEMPLATE.md +118 -0
  5. claude_mpm/agents/BASE_DOCUMENTATION.md +53 -0
  6. claude_mpm/agents/BASE_ENGINEER.md +658 -0
  7. claude_mpm/agents/BASE_OPS.md +219 -0
  8. claude_mpm/agents/BASE_PM.md +431 -214
  9. claude_mpm/agents/BASE_PROMPT_ENGINEER.md +787 -0
  10. claude_mpm/agents/BASE_QA.md +167 -0
  11. claude_mpm/agents/BASE_RESEARCH.md +53 -0
  12. claude_mpm/agents/MEMORY.md +3 -0
  13. claude_mpm/agents/OUTPUT_STYLE.md +335 -0
  14. claude_mpm/agents/PM_INSTRUCTIONS.md +1159 -0
  15. claude_mpm/agents/WORKFLOW.md +355 -187
  16. claude_mpm/agents/agent_loader.py +40 -10
  17. claude_mpm/agents/agent_loader_integration.py +3 -2
  18. claude_mpm/agents/agents_metadata.py +57 -0
  19. claude_mpm/agents/async_agent_loader.py +3 -3
  20. claude_mpm/agents/base_agent_loader.py +11 -9
  21. claude_mpm/agents/frontmatter_validator.py +291 -251
  22. claude_mpm/agents/system_agent_config.py +3 -2
  23. claude_mpm/agents/templates/.claude-mpm/memories/README.md +17 -0
  24. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +3 -0
  25. claude_mpm/agents/templates/README.md +465 -0
  26. claude_mpm/agents/templates/agent-manager.json +267 -18
  27. claude_mpm/agents/templates/agentic-coder-optimizer.json +248 -0
  28. claude_mpm/agents/templates/api_qa.json +16 -4
  29. claude_mpm/agents/templates/circuit_breakers.md +638 -0
  30. claude_mpm/agents/templates/clerk-ops.json +235 -0
  31. claude_mpm/agents/templates/code_analyzer.json +25 -9
  32. claude_mpm/agents/templates/content-agent.json +358 -0
  33. claude_mpm/agents/templates/dart_engineer.json +307 -0
  34. claude_mpm/agents/templates/data_engineer.json +87 -14
  35. claude_mpm/agents/templates/documentation.json +76 -13
  36. claude_mpm/agents/templates/engineer.json +44 -10
  37. claude_mpm/agents/templates/gcp_ops_agent.json +253 -0
  38. claude_mpm/agents/templates/git_file_tracking.md +584 -0
  39. claude_mpm/agents/templates/golang_engineer.json +270 -0
  40. claude_mpm/agents/templates/imagemagick.json +5 -2
  41. claude_mpm/agents/templates/java_engineer.json +346 -0
  42. claude_mpm/agents/templates/javascript_engineer_agent.json +380 -0
  43. claude_mpm/agents/templates/local_ops_agent.json +1840 -0
  44. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +39 -0
  45. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +400 -0
  46. claude_mpm/agents/templates/memory_manager.json +6 -3
  47. claude_mpm/agents/templates/nextjs_engineer.json +285 -0
  48. claude_mpm/agents/templates/ops.json +27 -8
  49. claude_mpm/agents/templates/php-engineer.json +287 -0
  50. claude_mpm/agents/templates/pm_examples.md +474 -0
  51. claude_mpm/agents/templates/pm_red_flags.md +262 -0
  52. claude_mpm/agents/templates/product_owner.json +338 -0
  53. claude_mpm/agents/templates/project_organizer.json +19 -5
  54. claude_mpm/agents/templates/prompt-engineer.json +737 -0
  55. claude_mpm/agents/templates/python_engineer.json +387 -0
  56. claude_mpm/agents/templates/qa.json +26 -6
  57. claude_mpm/agents/templates/react_engineer.json +239 -0
  58. claude_mpm/agents/templates/refactoring_engineer.json +15 -5
  59. claude_mpm/agents/templates/research.json +47 -22
  60. claude_mpm/agents/templates/response_format.md +583 -0
  61. claude_mpm/agents/templates/ruby-engineer.json +280 -0
  62. claude_mpm/agents/templates/rust_engineer.json +275 -0
  63. claude_mpm/agents/templates/security.json +59 -10
  64. claude_mpm/agents/templates/svelte-engineer.json +225 -0
  65. claude_mpm/agents/templates/tauri_engineer.json +274 -0
  66. claude_mpm/agents/templates/ticketing.json +16 -7
  67. claude_mpm/agents/templates/typescript_engineer.json +285 -0
  68. claude_mpm/agents/templates/validation_templates.md +312 -0
  69. claude_mpm/agents/templates/vercel_ops_agent.json +164 -33
  70. claude_mpm/agents/templates/version_control.json +16 -4
  71. claude_mpm/agents/templates/web_qa.json +243 -21
  72. claude_mpm/agents/templates/web_ui.json +18 -5
  73. claude_mpm/cli/__init__.py +38 -363
  74. claude_mpm/cli/commands/__init__.py +8 -0
  75. claude_mpm/cli/commands/agent_manager.py +675 -20
  76. claude_mpm/cli/commands/agent_state_manager.py +186 -0
  77. claude_mpm/cli/commands/agents.py +722 -150
  78. claude_mpm/cli/commands/agents_detect.py +380 -0
  79. claude_mpm/cli/commands/agents_recommend.py +309 -0
  80. claude_mpm/cli/commands/aggregate.py +10 -6
  81. claude_mpm/cli/commands/analyze.py +553 -0
  82. claude_mpm/cli/commands/analyze_code.py +528 -0
  83. claude_mpm/cli/commands/auto_configure.py +570 -0
  84. claude_mpm/cli/commands/cleanup.py +12 -12
  85. claude_mpm/cli/commands/config.py +47 -13
  86. claude_mpm/cli/commands/configure.py +488 -884
  87. claude_mpm/cli/commands/configure_agent_display.py +261 -0
  88. claude_mpm/cli/commands/configure_behavior_manager.py +204 -0
  89. claude_mpm/cli/commands/configure_hook_manager.py +225 -0
  90. claude_mpm/cli/commands/configure_models.py +18 -0
  91. claude_mpm/cli/commands/configure_navigation.py +167 -0
  92. claude_mpm/cli/commands/configure_paths.py +104 -0
  93. claude_mpm/cli/commands/configure_persistence.py +254 -0
  94. claude_mpm/cli/commands/configure_startup_manager.py +646 -0
  95. claude_mpm/cli/commands/configure_template_editor.py +497 -0
  96. claude_mpm/cli/commands/configure_validators.py +73 -0
  97. claude_mpm/cli/commands/dashboard.py +286 -0
  98. claude_mpm/cli/commands/debug.py +1386 -0
  99. claude_mpm/cli/commands/doctor.py +43 -7
  100. claude_mpm/cli/commands/info.py +3 -4
  101. claude_mpm/cli/commands/local_deploy.py +537 -0
  102. claude_mpm/cli/commands/mcp.py +17 -10
  103. claude_mpm/cli/commands/mcp_command_router.py +11 -0
  104. claude_mpm/cli/commands/mcp_config.py +154 -0
  105. claude_mpm/cli/commands/mcp_external_commands.py +249 -0
  106. claude_mpm/cli/commands/mcp_install_commands.py +101 -32
  107. claude_mpm/cli/commands/mcp_pipx_config.py +2 -2
  108. claude_mpm/cli/commands/mcp_setup_external.py +868 -0
  109. claude_mpm/cli/commands/memory.py +55 -21
  110. claude_mpm/cli/commands/monitor.py +168 -617
  111. claude_mpm/cli/commands/mpm_init/__init__.py +73 -0
  112. claude_mpm/cli/commands/mpm_init/core.py +525 -0
  113. claude_mpm/cli/commands/mpm_init/display.py +341 -0
  114. claude_mpm/cli/commands/mpm_init/git_activity.py +427 -0
  115. claude_mpm/cli/commands/mpm_init/modes.py +397 -0
  116. claude_mpm/cli/commands/mpm_init/prompts.py +442 -0
  117. claude_mpm/cli/commands/mpm_init_cli.py +396 -0
  118. claude_mpm/cli/commands/mpm_init_handler.py +195 -0
  119. claude_mpm/cli/commands/run.py +169 -42
  120. claude_mpm/cli/commands/search.py +458 -0
  121. claude_mpm/cli/commands/skills.py +488 -0
  122. claude_mpm/cli/commands/uninstall.py +176 -0
  123. claude_mpm/cli/commands/upgrade.py +152 -0
  124. claude_mpm/cli/commands/verify.py +119 -0
  125. claude_mpm/cli/executor.py +204 -0
  126. claude_mpm/cli/helpers.py +105 -0
  127. claude_mpm/cli/interactive/__init__.py +21 -0
  128. claude_mpm/cli/interactive/agent_wizard.py +962 -0
  129. claude_mpm/cli/interactive/skills_wizard.py +491 -0
  130. claude_mpm/cli/parser.py +79 -2
  131. claude_mpm/cli/parsers/__init__.py +7 -1
  132. claude_mpm/cli/parsers/agent_manager_parser.py +161 -1
  133. claude_mpm/cli/parsers/agents_parser.py +116 -0
  134. claude_mpm/cli/parsers/analyze_code_parser.py +170 -0
  135. claude_mpm/cli/parsers/analyze_parser.py +135 -0
  136. claude_mpm/cli/parsers/auto_configure_parser.py +245 -0
  137. claude_mpm/cli/parsers/base_parser.py +187 -3
  138. claude_mpm/cli/parsers/configure_parser.py +34 -15
  139. claude_mpm/cli/parsers/dashboard_parser.py +113 -0
  140. claude_mpm/cli/parsers/debug_parser.py +319 -0
  141. claude_mpm/cli/parsers/local_deploy_parser.py +227 -0
  142. claude_mpm/cli/parsers/mcp_parser.py +15 -0
  143. claude_mpm/cli/parsers/monitor_parser.py +12 -2
  144. claude_mpm/cli/parsers/mpm_init_parser.py +311 -0
  145. claude_mpm/cli/parsers/run_parser.py +5 -0
  146. claude_mpm/cli/parsers/search_parser.py +245 -0
  147. claude_mpm/cli/parsers/skills_parser.py +137 -0
  148. claude_mpm/cli/shared/argument_patterns.py +20 -13
  149. claude_mpm/cli/shared/base_command.py +2 -2
  150. claude_mpm/cli/shared/output_formatters.py +28 -19
  151. claude_mpm/cli/startup.py +562 -0
  152. claude_mpm/cli/startup_logging.py +179 -13
  153. claude_mpm/cli/utils.py +53 -2
  154. claude_mpm/commands/__init__.py +14 -0
  155. claude_mpm/commands/mpm-agents-detect.md +168 -0
  156. claude_mpm/commands/mpm-agents-recommend.md +214 -0
  157. claude_mpm/commands/mpm-agents.md +122 -0
  158. claude_mpm/commands/mpm-auto-configure.md +269 -0
  159. claude_mpm/commands/mpm-config.md +141 -0
  160. claude_mpm/commands/mpm-doctor.md +24 -0
  161. claude_mpm/commands/mpm-help.md +290 -0
  162. claude_mpm/commands/mpm-init.md +521 -0
  163. claude_mpm/commands/mpm-monitor.md +409 -0
  164. claude_mpm/commands/mpm-organize.md +295 -0
  165. claude_mpm/commands/mpm-resume.md +372 -0
  166. claude_mpm/commands/mpm-status.md +75 -0
  167. claude_mpm/commands/mpm-tickets.md +151 -0
  168. claude_mpm/commands/mpm-version.md +113 -0
  169. claude_mpm/commands/mpm.md +21 -0
  170. claude_mpm/config/agent_config.py +4 -4
  171. claude_mpm/config/experimental_features.py +7 -7
  172. claude_mpm/config/model_config.py +428 -0
  173. claude_mpm/config/paths.py +3 -2
  174. claude_mpm/config/socketio_config.py +36 -7
  175. claude_mpm/constants.py +27 -1
  176. claude_mpm/core/__init__.py +53 -17
  177. claude_mpm/core/agent_name_normalizer.py +3 -2
  178. claude_mpm/core/agent_registry.py +2 -2
  179. claude_mpm/core/agent_session_manager.py +10 -10
  180. claude_mpm/core/api_validator.py +330 -0
  181. claude_mpm/core/base_service.py +33 -23
  182. claude_mpm/core/cache.py +9 -9
  183. claude_mpm/core/claude_runner.py +19 -8
  184. claude_mpm/core/config.py +103 -8
  185. claude_mpm/core/config_aliases.py +7 -6
  186. claude_mpm/core/constants.py +65 -0
  187. claude_mpm/core/container.py +11 -5
  188. claude_mpm/core/enums.py +452 -0
  189. claude_mpm/core/error_handler.py +623 -0
  190. claude_mpm/core/factories.py +1 -1
  191. claude_mpm/core/file_utils.py +764 -0
  192. claude_mpm/core/framework/__init__.py +38 -0
  193. claude_mpm/core/framework/formatters/__init__.py +11 -0
  194. claude_mpm/core/framework/formatters/capability_generator.py +367 -0
  195. claude_mpm/core/framework/formatters/content_formatter.py +288 -0
  196. claude_mpm/core/framework/formatters/context_generator.py +185 -0
  197. claude_mpm/core/framework/loaders/__init__.py +13 -0
  198. claude_mpm/core/framework/loaders/agent_loader.py +210 -0
  199. claude_mpm/core/framework/loaders/file_loader.py +223 -0
  200. claude_mpm/core/framework/loaders/instruction_loader.py +161 -0
  201. claude_mpm/core/framework/loaders/packaged_loader.py +232 -0
  202. claude_mpm/core/framework/processors/__init__.py +11 -0
  203. claude_mpm/core/framework/processors/memory_processor.py +230 -0
  204. claude_mpm/core/framework/processors/metadata_processor.py +146 -0
  205. claude_mpm/core/framework/processors/template_processor.py +244 -0
  206. claude_mpm/core/framework_loader.py +323 -1491
  207. claude_mpm/core/hook_manager.py +8 -6
  208. claude_mpm/core/injectable_service.py +11 -8
  209. claude_mpm/core/instruction_reinforcement_hook.py +267 -0
  210. claude_mpm/core/interactive_session.py +55 -8
  211. claude_mpm/core/interfaces.py +56 -1
  212. claude_mpm/core/lazy.py +3 -3
  213. claude_mpm/core/log_manager.py +100 -28
  214. claude_mpm/core/logger.py +19 -14
  215. claude_mpm/core/logging_config.py +6 -2
  216. claude_mpm/core/logging_utils.py +520 -0
  217. claude_mpm/core/oneshot_session.py +51 -7
  218. claude_mpm/core/optimized_agent_loader.py +9 -9
  219. claude_mpm/core/optimized_startup.py +1 -1
  220. claude_mpm/core/output_style_manager.py +12 -192
  221. claude_mpm/core/pm_hook_interceptor.py +118 -15
  222. claude_mpm/core/service_registry.py +7 -3
  223. claude_mpm/core/session_manager.py +14 -12
  224. claude_mpm/core/shared/config_loader.py +1 -1
  225. claude_mpm/core/socketio_pool.py +15 -15
  226. claude_mpm/core/tool_access_control.py +3 -2
  227. claude_mpm/core/types.py +4 -11
  228. claude_mpm/core/typing_utils.py +7 -6
  229. claude_mpm/core/unified_agent_registry.py +116 -12
  230. claude_mpm/core/unified_config.py +6 -6
  231. claude_mpm/core/unified_paths.py +23 -20
  232. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +1 -0
  233. claude_mpm/dashboard/__init__.py +12 -0
  234. claude_mpm/dashboard/analysis_runner.py +455 -0
  235. claude_mpm/dashboard/api/simple_directory.py +261 -0
  236. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +188 -0
  237. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +156 -0
  238. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +38 -0
  239. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +92 -0
  240. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +248 -0
  241. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +61 -0
  242. claude_mpm/dashboard/static/archive/test_activity_connection.html +179 -0
  243. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +68 -0
  244. claude_mpm/dashboard/static/archive/test_dashboard.html +409 -0
  245. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +519 -0
  246. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +181 -0
  247. claude_mpm/dashboard/static/archive/test_file_data.html +315 -0
  248. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +243 -0
  249. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +234 -0
  250. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +117 -0
  251. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +115 -0
  252. claude_mpm/dashboard/static/archive/test_file_viewer.html +224 -0
  253. claude_mpm/dashboard/static/archive/test_final_activity.html +220 -0
  254. claude_mpm/dashboard/static/archive/test_tab_fix.html +139 -0
  255. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +1 -0
  256. claude_mpm/dashboard/static/built/components/activity-tree.js +2 -0
  257. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +777 -0
  258. claude_mpm/dashboard/static/built/components/agent-inference.js +1 -1
  259. claude_mpm/dashboard/static/built/components/build-tracker.js +333 -0
  260. claude_mpm/dashboard/static/built/components/code-simple.js +857 -0
  261. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +353 -0
  262. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +235 -0
  263. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +409 -0
  264. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +435 -0
  265. claude_mpm/dashboard/static/built/components/code-tree.js +2 -0
  266. claude_mpm/dashboard/static/built/components/code-viewer.js +2 -0
  267. claude_mpm/dashboard/static/built/components/connection-debug.js +654 -0
  268. claude_mpm/dashboard/static/built/components/diff-viewer.js +891 -0
  269. claude_mpm/dashboard/static/built/components/event-processor.js +1 -1
  270. claude_mpm/dashboard/static/built/components/event-viewer.js +1 -1
  271. claude_mpm/dashboard/static/built/components/export-manager.js +1 -1
  272. claude_mpm/dashboard/static/built/components/file-change-tracker.js +443 -0
  273. claude_mpm/dashboard/static/built/components/file-change-viewer.js +690 -0
  274. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +1 -1
  275. claude_mpm/dashboard/static/built/components/file-viewer.js +2 -0
  276. claude_mpm/dashboard/static/built/components/module-viewer.js +1 -1
  277. claude_mpm/dashboard/static/built/components/nav-bar.js +145 -0
  278. claude_mpm/dashboard/static/built/components/page-structure.js +429 -0
  279. claude_mpm/dashboard/static/built/components/session-manager.js +1 -1
  280. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +2 -0
  281. claude_mpm/dashboard/static/built/components/working-directory.js +1 -1
  282. claude_mpm/dashboard/static/built/connection-manager.js +536 -0
  283. claude_mpm/dashboard/static/built/dashboard.js +1 -1
  284. claude_mpm/dashboard/static/built/extension-error-handler.js +164 -0
  285. claude_mpm/dashboard/static/built/react/events.js +30 -0
  286. claude_mpm/dashboard/static/built/shared/dom-helpers.js +396 -0
  287. claude_mpm/dashboard/static/built/shared/event-bus.js +330 -0
  288. claude_mpm/dashboard/static/built/shared/event-filter-service.js +540 -0
  289. claude_mpm/dashboard/static/built/shared/logger.js +385 -0
  290. claude_mpm/dashboard/static/built/shared/page-structure.js +249 -0
  291. claude_mpm/dashboard/static/built/shared/tooltip-service.js +253 -0
  292. claude_mpm/dashboard/static/built/socket-client.js +1 -1
  293. claude_mpm/dashboard/static/built/tab-isolation-fix.js +185 -0
  294. claude_mpm/dashboard/static/css/activity.css +1958 -0
  295. claude_mpm/dashboard/static/css/dashboard.css +1413 -72
  296. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +1 -0
  297. claude_mpm/dashboard/static/dist/components/activity-tree.js +2 -0
  298. claude_mpm/dashboard/static/dist/components/agent-inference.js +1 -1
  299. claude_mpm/dashboard/static/dist/components/code-tree.js +2 -0
  300. claude_mpm/dashboard/static/dist/components/code-viewer.js +2 -0
  301. claude_mpm/dashboard/static/dist/components/event-processor.js +1 -1
  302. claude_mpm/dashboard/static/dist/components/event-viewer.js +1 -1
  303. claude_mpm/dashboard/static/dist/components/export-manager.js +1 -1
  304. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +1 -1
  305. claude_mpm/dashboard/static/dist/components/file-viewer.js +2 -0
  306. claude_mpm/dashboard/static/dist/components/module-viewer.js +1 -1
  307. claude_mpm/dashboard/static/dist/components/session-manager.js +1 -1
  308. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +2 -0
  309. claude_mpm/dashboard/static/dist/components/working-directory.js +1 -1
  310. claude_mpm/dashboard/static/dist/dashboard.js +1 -1
  311. claude_mpm/dashboard/static/dist/react/events.js +30 -0
  312. claude_mpm/dashboard/static/dist/socket-client.js +1 -1
  313. claude_mpm/dashboard/static/events.html +607 -0
  314. claude_mpm/dashboard/static/index.html +635 -0
  315. claude_mpm/dashboard/static/js/components/activity-tree.js +1871 -0
  316. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +4 -1
  317. claude_mpm/dashboard/static/js/components/agent-inference.js +3 -0
  318. claude_mpm/dashboard/static/js/components/build-tracker.js +23 -13
  319. claude_mpm/dashboard/static/js/components/code-simple.js +857 -0
  320. claude_mpm/dashboard/static/js/components/diff-viewer.js +891 -0
  321. claude_mpm/dashboard/static/js/components/event-processor.js +3 -107
  322. claude_mpm/dashboard/static/js/components/event-viewer.js +98 -11
  323. claude_mpm/dashboard/static/js/components/export-manager.js +3 -0
  324. claude_mpm/dashboard/static/js/components/file-change-tracker.js +443 -0
  325. claude_mpm/dashboard/static/js/components/file-change-viewer.js +690 -0
  326. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +30 -10
  327. claude_mpm/dashboard/static/js/components/file-viewer.js +580 -0
  328. claude_mpm/dashboard/static/js/components/module-viewer.js +68 -205
  329. claude_mpm/dashboard/static/js/components/session-manager.js +46 -10
  330. claude_mpm/dashboard/static/js/components/socket-manager.js +16 -0
  331. claude_mpm/dashboard/static/js/components/ui-state-manager.js +359 -40
  332. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +1824 -0
  333. claude_mpm/dashboard/static/js/components/working-directory.js +61 -10
  334. claude_mpm/dashboard/static/js/connection-manager.js +1 -1
  335. claude_mpm/dashboard/static/js/dashboard.js +523 -622
  336. claude_mpm/dashboard/static/js/shared/dom-helpers.js +396 -0
  337. claude_mpm/dashboard/static/js/shared/event-bus.js +330 -0
  338. claude_mpm/dashboard/static/js/shared/logger.js +385 -0
  339. claude_mpm/dashboard/static/js/shared/tooltip-service.js +253 -0
  340. claude_mpm/dashboard/static/js/socket-client.js +549 -62
  341. claude_mpm/dashboard/static/js/stores/dashboard-store.js +562 -0
  342. claude_mpm/dashboard/static/js/tab-isolation-fix.js +185 -0
  343. claude_mpm/dashboard/static/legacy/activity.html +736 -0
  344. claude_mpm/dashboard/static/legacy/agents.html +786 -0
  345. claude_mpm/dashboard/static/legacy/files.html +747 -0
  346. claude_mpm/dashboard/static/legacy/tools.html +831 -0
  347. claude_mpm/dashboard/static/monitors.html +431 -0
  348. claude_mpm/dashboard/static/production/events.html +659 -0
  349. claude_mpm/dashboard/static/production/main.html +698 -0
  350. claude_mpm/dashboard/static/production/monitors.html +483 -0
  351. claude_mpm/dashboard/static/socket.io.min.js +7 -0
  352. claude_mpm/dashboard/static/socket.io.v4.8.1.backup.js +7 -0
  353. claude_mpm/dashboard/static/test-archive/dashboard.html +635 -0
  354. claude_mpm/dashboard/static/test-archive/debug-events.html +147 -0
  355. claude_mpm/dashboard/static/test-archive/test-navigation.html +256 -0
  356. claude_mpm/dashboard/static/test-archive/test-react-exports.html +180 -0
  357. claude_mpm/dashboard/static/test-archive/test_debug.html +25 -0
  358. claude_mpm/dashboard/templates/code_simple.html +153 -0
  359. claude_mpm/dashboard/templates/index.html +267 -9
  360. claude_mpm/experimental/__init__.py +10 -0
  361. claude_mpm/experimental/cli_enhancements.py +4 -2
  362. claude_mpm/generators/agent_profile_generator.py +5 -3
  363. claude_mpm/hooks/__init__.py +37 -1
  364. claude_mpm/hooks/base_hook.py +5 -4
  365. claude_mpm/hooks/claude_hooks/connection_pool.py +4 -4
  366. claude_mpm/hooks/claude_hooks/event_handlers.py +21 -18
  367. claude_mpm/hooks/claude_hooks/hook_handler.py +209 -25
  368. claude_mpm/hooks/claude_hooks/installer.py +783 -0
  369. claude_mpm/hooks/claude_hooks/memory_integration.py +3 -3
  370. claude_mpm/hooks/claude_hooks/response_tracking.py +57 -17
  371. claude_mpm/hooks/claude_hooks/services/connection_manager.py +64 -49
  372. claude_mpm/hooks/claude_hooks/services/connection_manager_http.py +140 -76
  373. claude_mpm/hooks/claude_hooks/services/state_manager.py +11 -9
  374. claude_mpm/hooks/claude_hooks/services/subagent_processor.py +3 -3
  375. claude_mpm/hooks/failure_learning/__init__.py +60 -0
  376. claude_mpm/hooks/failure_learning/failure_detection_hook.py +235 -0
  377. claude_mpm/hooks/failure_learning/fix_detection_hook.py +217 -0
  378. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +286 -0
  379. claude_mpm/hooks/instruction_reinforcement.py +301 -0
  380. claude_mpm/hooks/kuzu_enrichment_hook.py +263 -0
  381. claude_mpm/hooks/kuzu_memory_hook.py +386 -0
  382. claude_mpm/hooks/kuzu_response_hook.py +183 -0
  383. claude_mpm/hooks/memory_integration_hook.py +1 -1
  384. claude_mpm/hooks/session_resume_hook.py +121 -0
  385. claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
  386. claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
  387. claude_mpm/hooks/tool_call_interceptor.py +8 -5
  388. claude_mpm/hooks/validation_hooks.py +3 -3
  389. claude_mpm/init.py +23 -4
  390. claude_mpm/models/agent_session.py +8 -6
  391. claude_mpm/models/resume_log.py +340 -0
  392. claude_mpm/schemas/__init__.py +12 -0
  393. claude_mpm/scripts/claude-hook-handler.sh +187 -0
  394. claude_mpm/scripts/launch_monitor.py +85 -0
  395. claude_mpm/scripts/mcp_server.py +3 -5
  396. claude_mpm/scripts/mpm_doctor.py +3 -2
  397. claude_mpm/scripts/socketio_daemon.py +156 -396
  398. claude_mpm/services/__init__.py +144 -160
  399. claude_mpm/services/agents/__init__.py +18 -5
  400. claude_mpm/services/agents/agent_builder.py +13 -11
  401. claude_mpm/services/agents/auto_config_manager.py +796 -0
  402. claude_mpm/services/agents/deployment/agent_config_provider.py +127 -27
  403. claude_mpm/services/agents/deployment/agent_configuration_manager.py +1 -1
  404. claude_mpm/services/agents/deployment/agent_deployment.py +38 -15
  405. claude_mpm/services/agents/deployment/agent_discovery_service.py +125 -7
  406. claude_mpm/services/agents/deployment/agent_filesystem_manager.py +5 -5
  407. claude_mpm/services/agents/deployment/agent_format_converter.py +56 -12
  408. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +4 -2
  409. claude_mpm/services/agents/deployment/agent_operation_service.py +2 -2
  410. claude_mpm/services/agents/deployment/agent_record_service.py +5 -6
  411. claude_mpm/services/agents/deployment/agent_state_service.py +2 -2
  412. claude_mpm/services/agents/deployment/agent_template_builder.py +722 -37
  413. claude_mpm/services/agents/deployment/agent_validator.py +31 -7
  414. claude_mpm/services/agents/deployment/agent_version_manager.py +9 -1
  415. claude_mpm/services/agents/deployment/agent_versioning.py +1 -1
  416. claude_mpm/services/agents/deployment/async_agent_deployment.py +1 -1
  417. claude_mpm/services/agents/deployment/deployment_config_loader.py +131 -7
  418. claude_mpm/services/agents/deployment/deployment_type_detector.py +10 -14
  419. claude_mpm/services/agents/deployment/deployment_wrapper.py +58 -0
  420. claude_mpm/services/agents/deployment/interface_adapter.py +3 -2
  421. claude_mpm/services/agents/deployment/local_template_deployment.py +360 -0
  422. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +134 -38
  423. claude_mpm/services/agents/deployment/pipeline/steps/agent_processing_step.py +8 -7
  424. claude_mpm/services/agents/deployment/pipeline/steps/base_step.py +7 -16
  425. claude_mpm/services/agents/deployment/pipeline/steps/configuration_step.py +4 -3
  426. claude_mpm/services/agents/deployment/pipeline/steps/target_directory_step.py +7 -5
  427. claude_mpm/services/agents/deployment/pipeline/steps/validation_step.py +6 -5
  428. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +9 -6
  429. claude_mpm/services/agents/deployment/system_instructions_deployer.py +9 -6
  430. claude_mpm/services/agents/deployment/validation/__init__.py +3 -1
  431. claude_mpm/services/agents/deployment/validation/template_validator.py +64 -44
  432. claude_mpm/services/agents/deployment/validation/validation_result.py +1 -9
  433. claude_mpm/services/agents/loading/agent_profile_loader.py +10 -9
  434. claude_mpm/services/agents/loading/base_agent_manager.py +16 -6
  435. claude_mpm/services/agents/loading/framework_agent_loader.py +2 -2
  436. claude_mpm/services/agents/local_template_manager.py +744 -0
  437. claude_mpm/services/agents/management/agent_capabilities_generator.py +3 -2
  438. claude_mpm/services/agents/management/agent_management_service.py +5 -5
  439. claude_mpm/services/agents/memory/agent_memory_manager.py +32 -29
  440. claude_mpm/services/agents/memory/content_manager.py +17 -9
  441. claude_mpm/services/agents/memory/memory_categorization_service.py +4 -2
  442. claude_mpm/services/agents/memory/memory_file_service.py +32 -6
  443. claude_mpm/services/agents/memory/memory_format_service.py +7 -7
  444. claude_mpm/services/agents/memory/memory_limits_service.py +4 -2
  445. claude_mpm/services/agents/memory/template_generator.py +3 -3
  446. claude_mpm/services/agents/observers.py +547 -0
  447. claude_mpm/services/agents/recommender.py +615 -0
  448. claude_mpm/services/agents/registry/deployed_agent_discovery.py +3 -3
  449. claude_mpm/services/agents/registry/modification_tracker.py +30 -19
  450. claude_mpm/services/async_session_logger.py +141 -98
  451. claude_mpm/services/claude_session_logger.py +82 -74
  452. claude_mpm/services/cli/agent_cleanup_service.py +6 -5
  453. claude_mpm/services/cli/agent_dependency_service.py +1 -1
  454. claude_mpm/services/cli/agent_listing_service.py +5 -5
  455. claude_mpm/services/cli/agent_validation_service.py +6 -5
  456. claude_mpm/services/cli/memory_crud_service.py +12 -7
  457. claude_mpm/services/cli/memory_output_formatter.py +2 -2
  458. claude_mpm/services/cli/resume_service.py +617 -0
  459. claude_mpm/services/cli/session_manager.py +104 -13
  460. claude_mpm/services/cli/session_pause_manager.py +504 -0
  461. claude_mpm/services/cli/session_resume_helper.py +372 -0
  462. claude_mpm/services/cli/startup_checker.py +13 -21
  463. claude_mpm/services/cli/unified_dashboard_manager.py +439 -0
  464. claude_mpm/services/command_deployment_service.py +17 -9
  465. claude_mpm/services/command_handler_service.py +11 -5
  466. claude_mpm/services/core/__init__.py +33 -1
  467. claude_mpm/services/core/base.py +26 -11
  468. claude_mpm/services/core/cache_manager.py +1 -3
  469. claude_mpm/services/core/interfaces/__init__.py +90 -3
  470. claude_mpm/services/core/interfaces/agent.py +184 -0
  471. claude_mpm/services/core/interfaces/health.py +172 -0
  472. claude_mpm/services/core/interfaces/model.py +281 -0
  473. claude_mpm/services/core/interfaces/process.py +372 -0
  474. claude_mpm/services/core/interfaces/project.py +121 -0
  475. claude_mpm/services/core/interfaces/restart.py +307 -0
  476. claude_mpm/services/core/interfaces/stability.py +260 -0
  477. claude_mpm/services/core/interfaces.py +56 -1
  478. claude_mpm/services/core/memory_manager.py +92 -47
  479. claude_mpm/services/core/models/__init__.py +79 -0
  480. claude_mpm/services/core/models/agent_config.py +384 -0
  481. claude_mpm/services/core/models/health.py +162 -0
  482. claude_mpm/services/core/models/process.py +239 -0
  483. claude_mpm/services/core/models/restart.py +302 -0
  484. claude_mpm/services/core/models/stability.py +264 -0
  485. claude_mpm/services/core/models/toolchain.py +306 -0
  486. claude_mpm/services/core/path_resolver.py +37 -18
  487. claude_mpm/services/core/service_container.py +2 -2
  488. claude_mpm/services/diagnostics/__init__.py +2 -2
  489. claude_mpm/services/diagnostics/checks/__init__.py +4 -2
  490. claude_mpm/services/diagnostics/checks/agent_check.py +30 -32
  491. claude_mpm/services/diagnostics/checks/claude_code_check.py +270 -0
  492. claude_mpm/services/diagnostics/checks/common_issues_check.py +28 -27
  493. claude_mpm/services/diagnostics/checks/configuration_check.py +26 -25
  494. claude_mpm/services/diagnostics/checks/filesystem_check.py +18 -17
  495. claude_mpm/services/diagnostics/checks/installation_check.py +165 -60
  496. claude_mpm/services/diagnostics/checks/instructions_check.py +22 -24
  497. claude_mpm/services/diagnostics/checks/mcp_check.py +57 -43
  498. claude_mpm/services/diagnostics/checks/mcp_services_check.py +1066 -0
  499. claude_mpm/services/diagnostics/checks/monitor_check.py +24 -23
  500. claude_mpm/services/diagnostics/checks/startup_log_check.py +14 -11
  501. claude_mpm/services/diagnostics/diagnostic_runner.py +22 -13
  502. claude_mpm/services/diagnostics/doctor_reporter.py +275 -47
  503. claude_mpm/services/diagnostics/models.py +37 -21
  504. claude_mpm/services/event_aggregator.py +5 -3
  505. claude_mpm/services/event_bus/direct_relay.py +152 -13
  506. claude_mpm/services/event_bus/event_bus.py +51 -9
  507. claude_mpm/services/event_bus/relay.py +33 -14
  508. claude_mpm/services/events/consumers/dead_letter.py +7 -5
  509. claude_mpm/services/events/core.py +5 -6
  510. claude_mpm/services/events/producers/hook.py +6 -6
  511. claude_mpm/services/events/producers/system.py +8 -8
  512. claude_mpm/services/exceptions.py +5 -5
  513. claude_mpm/services/framework_claude_md_generator/__init__.py +1 -1
  514. claude_mpm/services/framework_claude_md_generator/content_assembler.py +5 -5
  515. claude_mpm/services/framework_claude_md_generator/content_validator.py +2 -2
  516. claude_mpm/services/framework_claude_md_generator/deployment_manager.py +3 -3
  517. claude_mpm/services/framework_claude_md_generator/section_generators/__init__.py +2 -2
  518. claude_mpm/services/framework_claude_md_generator/version_manager.py +1 -1
  519. claude_mpm/services/hook_installer_service.py +506 -0
  520. claude_mpm/services/hook_service.py +5 -6
  521. claude_mpm/services/infrastructure/context_preservation.py +13 -11
  522. claude_mpm/services/infrastructure/daemon_manager.py +9 -9
  523. claude_mpm/services/infrastructure/logging.py +2 -2
  524. claude_mpm/services/infrastructure/monitoring/__init__.py +12 -12
  525. claude_mpm/services/infrastructure/monitoring/aggregator.py +12 -12
  526. claude_mpm/services/infrastructure/monitoring/base.py +5 -13
  527. claude_mpm/services/infrastructure/monitoring/network.py +7 -6
  528. claude_mpm/services/infrastructure/monitoring/process.py +13 -12
  529. claude_mpm/services/infrastructure/monitoring/resources.py +8 -7
  530. claude_mpm/services/infrastructure/monitoring/service.py +16 -15
  531. claude_mpm/services/infrastructure/monitoring.py +12 -12
  532. claude_mpm/services/infrastructure/resume_log_generator.py +439 -0
  533. claude_mpm/services/local_ops/__init__.py +165 -0
  534. claude_mpm/services/local_ops/crash_detector.py +257 -0
  535. claude_mpm/services/local_ops/health_checks/__init__.py +28 -0
  536. claude_mpm/services/local_ops/health_checks/http_check.py +224 -0
  537. claude_mpm/services/local_ops/health_checks/process_check.py +236 -0
  538. claude_mpm/services/local_ops/health_checks/resource_check.py +255 -0
  539. claude_mpm/services/local_ops/health_manager.py +430 -0
  540. claude_mpm/services/local_ops/log_monitor.py +396 -0
  541. claude_mpm/services/local_ops/memory_leak_detector.py +294 -0
  542. claude_mpm/services/local_ops/process_manager.py +595 -0
  543. claude_mpm/services/local_ops/resource_monitor.py +331 -0
  544. claude_mpm/services/local_ops/restart_manager.py +401 -0
  545. claude_mpm/services/local_ops/restart_policy.py +387 -0
  546. claude_mpm/services/local_ops/state_manager.py +372 -0
  547. claude_mpm/services/local_ops/unified_manager.py +600 -0
  548. claude_mpm/services/mcp_config_manager.py +1612 -0
  549. claude_mpm/services/mcp_gateway/__init__.py +97 -93
  550. claude_mpm/services/mcp_gateway/auto_configure.py +43 -38
  551. claude_mpm/services/mcp_gateway/config/config_loader.py +3 -3
  552. claude_mpm/services/mcp_gateway/config/configuration.py +23 -4
  553. claude_mpm/services/mcp_gateway/core/__init__.py +1 -2
  554. claude_mpm/services/mcp_gateway/core/base.py +20 -33
  555. claude_mpm/services/mcp_gateway/core/process_pool.py +585 -31
  556. claude_mpm/services/mcp_gateway/core/singleton_manager.py +2 -2
  557. claude_mpm/services/mcp_gateway/core/startup_verification.py +3 -3
  558. claude_mpm/services/mcp_gateway/main.py +90 -15
  559. claude_mpm/services/mcp_gateway/registry/service_registry.py +4 -2
  560. claude_mpm/services/mcp_gateway/registry/tool_registry.py +12 -9
  561. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +4 -4
  562. claude_mpm/services/mcp_gateway/server/stdio_server.py +9 -15
  563. claude_mpm/services/mcp_gateway/tools/__init__.py +14 -2
  564. claude_mpm/services/mcp_gateway/tools/base_adapter.py +15 -15
  565. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +10 -9
  566. claude_mpm/services/mcp_gateway/tools/external_mcp_services.py +654 -0
  567. claude_mpm/services/mcp_gateway/tools/health_check_tool.py +36 -34
  568. claude_mpm/services/mcp_gateway/tools/hello_world.py +8 -8
  569. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +551 -0
  570. claude_mpm/services/mcp_gateway/utils/__init__.py +14 -0
  571. claude_mpm/services/mcp_gateway/utils/package_version_checker.py +160 -0
  572. claude_mpm/services/mcp_gateway/utils/update_preferences.py +170 -0
  573. claude_mpm/services/mcp_service_verifier.py +729 -0
  574. claude_mpm/services/memory/builder.py +9 -8
  575. claude_mpm/services/memory/cache/shared_prompt_cache.py +2 -1
  576. claude_mpm/services/memory/cache/simple_cache.py +2 -2
  577. claude_mpm/services/memory/failure_tracker.py +578 -0
  578. claude_mpm/services/memory/indexed_memory.py +8 -8
  579. claude_mpm/services/memory/optimizer.py +8 -9
  580. claude_mpm/services/memory/router.py +3 -3
  581. claude_mpm/services/memory_hook_service.py +165 -4
  582. claude_mpm/services/model/__init__.py +147 -0
  583. claude_mpm/services/model/base_provider.py +365 -0
  584. claude_mpm/services/model/claude_provider.py +412 -0
  585. claude_mpm/services/model/model_router.py +453 -0
  586. claude_mpm/services/model/ollama_provider.py +415 -0
  587. claude_mpm/services/monitor/__init__.py +20 -0
  588. claude_mpm/services/monitor/daemon.py +671 -0
  589. claude_mpm/services/monitor/daemon_manager.py +963 -0
  590. claude_mpm/services/monitor/event_emitter.py +350 -0
  591. claude_mpm/services/monitor/handlers/__init__.py +21 -0
  592. claude_mpm/services/monitor/handlers/code_analysis.py +332 -0
  593. claude_mpm/services/monitor/handlers/dashboard.py +299 -0
  594. claude_mpm/services/monitor/handlers/file.py +264 -0
  595. claude_mpm/services/monitor/handlers/hooks.py +512 -0
  596. claude_mpm/services/monitor/management/__init__.py +18 -0
  597. claude_mpm/services/monitor/management/health.py +124 -0
  598. claude_mpm/services/monitor/management/lifecycle.py +724 -0
  599. claude_mpm/services/monitor/server.py +817 -0
  600. claude_mpm/services/monitor_build_service.py +2 -2
  601. claude_mpm/services/native_agent_converter.py +356 -0
  602. claude_mpm/services/orphan_detection.py +786 -0
  603. claude_mpm/services/port_manager.py +2 -2
  604. claude_mpm/services/project/__init__.py +23 -0
  605. claude_mpm/services/project/analyzer.py +3 -3
  606. claude_mpm/services/project/architecture_analyzer.py +6 -6
  607. claude_mpm/services/project/archive_manager.py +1045 -0
  608. claude_mpm/services/project/dependency_analyzer.py +8 -8
  609. claude_mpm/services/project/detection_strategies.py +719 -0
  610. claude_mpm/services/project/documentation_manager.py +553 -0
  611. claude_mpm/services/project/enhanced_analyzer.py +572 -0
  612. claude_mpm/services/project/language_analyzer.py +3 -3
  613. claude_mpm/services/project/metrics_collector.py +7 -10
  614. claude_mpm/services/project/project_organizer.py +1005 -0
  615. claude_mpm/services/project/registry.py +13 -7
  616. claude_mpm/services/project/toolchain_analyzer.py +581 -0
  617. claude_mpm/services/project_port_allocator.py +596 -0
  618. claude_mpm/services/response_tracker.py +21 -10
  619. claude_mpm/services/runner_configuration_service.py +1 -0
  620. claude_mpm/services/self_upgrade_service.py +500 -0
  621. claude_mpm/services/session_management_service.py +7 -5
  622. claude_mpm/services/session_manager.py +380 -0
  623. claude_mpm/services/shared/__init__.py +2 -1
  624. claude_mpm/services/shared/async_service_base.py +16 -27
  625. claude_mpm/services/shared/config_service_base.py +17 -14
  626. claude_mpm/services/shared/lifecycle_service_base.py +1 -14
  627. claude_mpm/services/shared/service_factory.py +8 -5
  628. claude_mpm/services/socketio/client_proxy.py +60 -5
  629. claude_mpm/services/socketio/dashboard_server.py +361 -0
  630. claude_mpm/services/socketio/event_normalizer.py +74 -6
  631. claude_mpm/services/socketio/handlers/__init__.py +5 -0
  632. claude_mpm/services/socketio/handlers/base.py +2 -2
  633. claude_mpm/services/socketio/handlers/code_analysis.py +682 -0
  634. claude_mpm/services/socketio/handlers/connection.py +21 -40
  635. claude_mpm/services/socketio/handlers/connection_handler.py +16 -28
  636. claude_mpm/services/socketio/handlers/file.py +46 -10
  637. claude_mpm/services/socketio/handlers/git.py +8 -8
  638. claude_mpm/services/socketio/handlers/hook.py +29 -17
  639. claude_mpm/services/socketio/handlers/registry.py +4 -0
  640. claude_mpm/services/socketio/monitor_client.py +364 -0
  641. claude_mpm/services/socketio/server/broadcaster.py +9 -7
  642. claude_mpm/services/socketio/server/connection_manager.py +131 -68
  643. claude_mpm/services/socketio/server/core.py +275 -22
  644. claude_mpm/services/socketio/server/eventbus_integration.py +20 -14
  645. claude_mpm/services/socketio/server/main.py +99 -29
  646. claude_mpm/services/socketio_client_manager.py +4 -4
  647. claude_mpm/services/subprocess_launcher_service.py +19 -15
  648. claude_mpm/services/system_instructions_service.py +2 -2
  649. claude_mpm/services/ticket_services/formatter_service.py +1 -1
  650. claude_mpm/services/ticket_services/validation_service.py +5 -5
  651. claude_mpm/services/unified/__init__.py +65 -0
  652. claude_mpm/services/unified/analyzer_strategies/__init__.py +44 -0
  653. claude_mpm/services/unified/analyzer_strategies/code_analyzer.py +518 -0
  654. claude_mpm/services/unified/analyzer_strategies/dependency_analyzer.py +680 -0
  655. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +903 -0
  656. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +746 -0
  657. claude_mpm/services/unified/analyzer_strategies/structure_analyzer.py +733 -0
  658. claude_mpm/services/unified/config_strategies/__init__.py +175 -0
  659. claude_mpm/services/unified/config_strategies/config_schema.py +731 -0
  660. claude_mpm/services/unified/config_strategies/context_strategy.py +747 -0
  661. claude_mpm/services/unified/config_strategies/error_handling_strategy.py +1005 -0
  662. claude_mpm/services/unified/config_strategies/file_loader_strategy.py +881 -0
  663. claude_mpm/services/unified/config_strategies/unified_config_service.py +823 -0
  664. claude_mpm/services/unified/config_strategies/validation_strategy.py +1148 -0
  665. claude_mpm/services/unified/deployment_strategies/__init__.py +97 -0
  666. claude_mpm/services/unified/deployment_strategies/base.py +553 -0
  667. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +573 -0
  668. claude_mpm/services/unified/deployment_strategies/local.py +607 -0
  669. claude_mpm/services/unified/deployment_strategies/utils.py +667 -0
  670. claude_mpm/services/unified/deployment_strategies/vercel.py +475 -0
  671. claude_mpm/services/unified/interfaces.py +475 -0
  672. claude_mpm/services/unified/migration.py +509 -0
  673. claude_mpm/services/unified/strategies.py +534 -0
  674. claude_mpm/services/unified/unified_analyzer.py +542 -0
  675. claude_mpm/services/unified/unified_config.py +691 -0
  676. claude_mpm/services/unified/unified_deployment.py +470 -0
  677. claude_mpm/services/utility_service.py +6 -3
  678. claude_mpm/services/version_control/branch_strategy.py +2 -2
  679. claude_mpm/services/version_control/conflict_resolution.py +8 -4
  680. claude_mpm/services/version_control/git_operations.py +26 -24
  681. claude_mpm/services/version_control/semantic_versioning.py +14 -14
  682. claude_mpm/services/version_control/version_parser.py +14 -11
  683. claude_mpm/services/version_service.py +104 -1
  684. claude_mpm/services/visualization/__init__.py +19 -0
  685. claude_mpm/services/visualization/mermaid_generator.py +938 -0
  686. claude_mpm/skills/__init__.py +42 -0
  687. claude_mpm/skills/agent_skills_injector.py +324 -0
  688. claude_mpm/skills/bundled/LICENSE_ATTRIBUTIONS.md +79 -0
  689. claude_mpm/skills/bundled/__init__.py +6 -0
  690. claude_mpm/skills/bundled/api-documentation.md +393 -0
  691. claude_mpm/skills/bundled/async-testing.md +571 -0
  692. claude_mpm/skills/bundled/code-review.md +143 -0
  693. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +79 -0
  694. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +178 -0
  695. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
  696. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
  697. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
  698. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
  699. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +112 -0
  700. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +146 -0
  701. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
  702. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +81 -0
  703. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
  704. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
  705. claude_mpm/skills/bundled/database-migration.md +199 -0
  706. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +152 -0
  707. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
  708. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
  709. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
  710. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
  711. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +119 -0
  712. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +148 -0
  713. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +483 -0
  714. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +452 -0
  715. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +449 -0
  716. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +411 -0
  717. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +14 -0
  718. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +58 -0
  719. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +68 -0
  720. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +69 -0
  721. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +131 -0
  722. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +325 -0
  723. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
  724. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
  725. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +499 -0
  726. claude_mpm/skills/bundled/docker-containerization.md +194 -0
  727. claude_mpm/skills/bundled/express-local-dev.md +1429 -0
  728. claude_mpm/skills/bundled/fastapi-local-dev.md +1199 -0
  729. claude_mpm/skills/bundled/git-workflow.md +414 -0
  730. claude_mpm/skills/bundled/imagemagick.md +204 -0
  731. claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
  732. claude_mpm/skills/bundled/json-data-handling.md +223 -0
  733. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +86 -0
  734. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +43 -0
  735. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +47 -0
  736. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +65 -0
  737. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +30 -0
  738. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +16 -0
  739. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +160 -0
  740. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
  741. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +602 -0
  742. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +915 -0
  743. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +916 -0
  744. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +752 -0
  745. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
  746. claude_mpm/skills/bundled/main/mcp-builder/scripts/connections.py +157 -0
  747. claude_mpm/skills/bundled/main/mcp-builder/scripts/evaluation.py +425 -0
  748. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +189 -0
  749. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
  750. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
  751. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
  752. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
  753. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
  754. claude_mpm/skills/bundled/main/skill-creator/scripts/init_skill.py +303 -0
  755. claude_mpm/skills/bundled/main/skill-creator/scripts/package_skill.py +113 -0
  756. claude_mpm/skills/bundled/main/skill-creator/scripts/quick_validate.py +72 -0
  757. claude_mpm/skills/bundled/nextjs-local-dev.md +807 -0
  758. claude_mpm/skills/bundled/pdf.md +141 -0
  759. claude_mpm/skills/bundled/performance-profiling.md +573 -0
  760. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
  761. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
  762. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
  763. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
  764. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
  765. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
  766. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
  767. claude_mpm/skills/bundled/refactoring-patterns.md +180 -0
  768. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
  769. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
  770. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
  771. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
  772. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
  773. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
  774. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
  775. claude_mpm/skills/bundled/security-scanning.md +327 -0
  776. claude_mpm/skills/bundled/systematic-debugging.md +473 -0
  777. claude_mpm/skills/bundled/test-driven-development.md +378 -0
  778. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +119 -0
  779. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
  780. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +145 -0
  781. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +543 -0
  782. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +741 -0
  783. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +470 -0
  784. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +458 -0
  785. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +639 -0
  786. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +140 -0
  787. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
  788. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
  789. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
  790. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
  791. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +184 -0
  792. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
  793. claude_mpm/skills/bundled/testing/webapp-testing/examples/console_logging.py +35 -0
  794. claude_mpm/skills/bundled/testing/webapp-testing/examples/element_discovery.py +44 -0
  795. claude_mpm/skills/bundled/testing/webapp-testing/examples/static_html_automation.py +34 -0
  796. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
  797. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
  798. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +129 -0
  799. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
  800. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
  801. claude_mpm/skills/bundled/vite-local-dev.md +1061 -0
  802. claude_mpm/skills/bundled/web-performance-optimization.md +2305 -0
  803. claude_mpm/skills/bundled/xlsx.md +157 -0
  804. claude_mpm/skills/registry.py +286 -0
  805. claude_mpm/skills/skill_manager.py +310 -0
  806. claude_mpm/skills/skills_registry.py +348 -0
  807. claude_mpm/skills/skills_service.py +739 -0
  808. claude_mpm/storage/state_storage.py +31 -31
  809. claude_mpm/tools/__init__.py +10 -0
  810. claude_mpm/tools/__main__.py +208 -0
  811. claude_mpm/tools/code_tree_analyzer/__init__.py +45 -0
  812. claude_mpm/tools/code_tree_analyzer/analysis.py +299 -0
  813. claude_mpm/tools/code_tree_analyzer/cache.py +131 -0
  814. claude_mpm/tools/code_tree_analyzer/core.py +380 -0
  815. claude_mpm/tools/code_tree_analyzer/discovery.py +403 -0
  816. claude_mpm/tools/code_tree_analyzer/events.py +168 -0
  817. claude_mpm/tools/code_tree_analyzer/gitignore.py +308 -0
  818. claude_mpm/tools/code_tree_analyzer/models.py +39 -0
  819. claude_mpm/tools/code_tree_analyzer/multilang_analyzer.py +224 -0
  820. claude_mpm/tools/code_tree_analyzer/python_analyzer.py +284 -0
  821. claude_mpm/tools/code_tree_builder.py +631 -0
  822. claude_mpm/tools/code_tree_events.py +420 -0
  823. claude_mpm/tools/socketio_debug.py +671 -0
  824. claude_mpm/utils/agent_dependency_loader.py +108 -27
  825. claude_mpm/utils/common.py +544 -0
  826. claude_mpm/utils/config_manager.py +12 -6
  827. claude_mpm/utils/database_connector.py +298 -0
  828. claude_mpm/utils/dependency_cache.py +2 -2
  829. claude_mpm/utils/dependency_strategies.py +15 -10
  830. claude_mpm/utils/display_helper.py +260 -0
  831. claude_mpm/utils/environment_context.py +4 -3
  832. claude_mpm/utils/error_handler.py +5 -3
  833. claude_mpm/utils/file_utils.py +13 -14
  834. claude_mpm/utils/git_analyzer.py +407 -0
  835. claude_mpm/utils/log_cleanup.py +627 -0
  836. claude_mpm/utils/path_operations.py +7 -4
  837. claude_mpm/utils/robust_installer.py +133 -24
  838. claude_mpm/utils/session_logging.py +2 -2
  839. claude_mpm/utils/subprocess_utils.py +9 -8
  840. claude_mpm/validation/agent_validator.py +6 -6
  841. claude_mpm/validation/frontmatter_validator.py +6 -6
  842. claude_mpm-4.24.0.dist-info/METADATA +675 -0
  843. claude_mpm-4.24.0.dist-info/RECORD +1018 -0
  844. {claude_mpm-4.1.6.dist-info → claude_mpm-4.24.0.dist-info}/entry_points.txt +1 -0
  845. claude_mpm/agents/INSTRUCTIONS.md +0 -237
  846. claude_mpm/agents/schema/agent_schema.json +0 -314
  847. claude_mpm/agents/templates/agent-manager.md +0 -304
  848. claude_mpm/cli/commands/configure_tui.py +0 -1921
  849. claude_mpm/cli/commands/socketio_monitor.py +0 -233
  850. claude_mpm/hooks/claude_hooks/hook_handler_eventbus.py +0 -425
  851. claude_mpm/hooks/claude_hooks/hook_handler_original.py +0 -1040
  852. claude_mpm/hooks/claude_hooks/hook_handler_refactored.py +0 -347
  853. claude_mpm/scripts/socketio_daemon_hardened.py +0 -937
  854. claude_mpm/scripts/socketio_server_manager.py +0 -349
  855. claude_mpm/services/agents/deployment/agent_lifecycle_manager_refactored.py +0 -575
  856. claude_mpm/services/cli/dashboard_launcher.py +0 -424
  857. claude_mpm/services/cli/socketio_manager.py +0 -498
  858. claude_mpm/services/diagnostics/checks/claude_desktop_check.py +0 -286
  859. claude_mpm/services/mcp_gateway/tools/ticket_tools.py +0 -645
  860. claude_mpm/services/mcp_gateway/tools/unified_ticket_tool.py +0 -602
  861. claude_mpm/services/project/analyzer_refactored.py +0 -450
  862. claude_mpm-4.1.6.dist-info/METADATA +0 -325
  863. claude_mpm-4.1.6.dist-info/RECORD +0 -550
  864. {claude_mpm-4.1.6.dist-info → claude_mpm-4.24.0.dist-info}/WHEEL +0 -0
  865. {claude_mpm-4.1.6.dist-info → claude_mpm-4.24.0.dist-info}/licenses/LICENSE +0 -0
  866. {claude_mpm-4.1.6.dist-info → claude_mpm-4.24.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,1958 @@
1
+ /* Activity Tab Styles for Linear Tree View */
2
+
3
+ /* Container and Layout */
4
+ .activity-container {
5
+ padding: 20px;
6
+ height: calc(100vh - 280px);
7
+ display: flex;
8
+ flex-direction: column;
9
+ }
10
+
11
+ .activity-header {
12
+ display: flex;
13
+ justify-content: space-between;
14
+ align-items: center;
15
+ padding: 15px;
16
+ background: white;
17
+ border-radius: 8px;
18
+ margin-bottom: 15px;
19
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
20
+ }
21
+
22
+ .activity-controls {
23
+ display: flex;
24
+ gap: 10px;
25
+ align-items: center;
26
+ }
27
+
28
+ .activity-controls .btn-sm {
29
+ padding: 6px 12px;
30
+ font-size: 12px;
31
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
32
+ color: white;
33
+ border: none;
34
+ border-radius: 4px;
35
+ cursor: pointer;
36
+ transition: all 0.3s;
37
+ }
38
+
39
+ .activity-controls .btn-sm:hover {
40
+ transform: translateY(-1px);
41
+ box-shadow: 0 4px 8px rgba(102, 126, 234, 0.4);
42
+ }
43
+
44
+ .activity-controls select {
45
+ padding: 6px 10px;
46
+ border: 1px solid #e2e8f0;
47
+ border-radius: 4px;
48
+ font-size: 12px;
49
+ background: white;
50
+ }
51
+
52
+ .activity-controls input {
53
+ padding: 6px 12px;
54
+ border: 1px solid #e2e8f0;
55
+ border-radius: 4px;
56
+ font-size: 12px;
57
+ width: 200px;
58
+ }
59
+
60
+ .activity-stats {
61
+ display: flex;
62
+ gap: 20px;
63
+ }
64
+
65
+ .stat-item {
66
+ display: flex;
67
+ align-items: center;
68
+ gap: 5px;
69
+ }
70
+
71
+ .stat-label {
72
+ font-size: 12px;
73
+ color: #718096;
74
+ font-weight: 600;
75
+ }
76
+
77
+ .stat-value {
78
+ font-size: 14px;
79
+ font-weight: bold;
80
+ color: #2d3748;
81
+ }
82
+
83
+ /* Tree Container */
84
+ .activity-tree-container {
85
+ flex: 1;
86
+ background: white;
87
+ border-radius: 8px;
88
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
89
+ position: relative;
90
+ overflow-y: auto;
91
+ overflow-x: hidden;
92
+ min-height: 400px;
93
+ max-height: calc(100vh - 320px);
94
+ padding: 0;
95
+ scroll-behavior: smooth;
96
+ }
97
+
98
+ /* SVG Tree Styles */
99
+ #activity-tree-svg {
100
+ font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', monospace;
101
+ width: 100%;
102
+ height: 100%;
103
+ min-height: 400px;
104
+ }
105
+
106
+ /* D3 Tree Group */
107
+ .tree-group {
108
+ cursor: move; /* Cursor for pan */
109
+ }
110
+
111
+ /* D3 Node Styles */
112
+ .node {
113
+ cursor: pointer;
114
+ transition: all 0.3s ease;
115
+ }
116
+
117
+ .node.selected .node-circle {
118
+ stroke: #4299e1 !important;
119
+ stroke-width: 3px !important;
120
+ filter: drop-shadow(0 0 6px rgba(66, 153, 225, 0.6));
121
+ }
122
+
123
+ .node-circle {
124
+ transition: all 0.3s ease;
125
+ }
126
+
127
+ .node:hover .node-circle {
128
+ stroke-width: 3px;
129
+ filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.3));
130
+ }
131
+
132
+ .node-icon {
133
+ font-size: 12px;
134
+ pointer-events: none;
135
+ font-weight: bold;
136
+ }
137
+
138
+ .node-label {
139
+ font-size: 14px;
140
+ font-weight: 500;
141
+ fill: #2d3748;
142
+ transition: all 0.3s ease;
143
+ }
144
+
145
+ .node:hover .node-label {
146
+ fill: #4299e1;
147
+ }
148
+
149
+ /* Node Type Colors */
150
+ .node-project .node-circle {
151
+ fill: #4299e1;
152
+ stroke: #2c5282;
153
+ }
154
+
155
+ .node-session .node-circle {
156
+ fill: #38a169;
157
+ stroke: #276749;
158
+ }
159
+
160
+ .node-todo .node-circle {
161
+ fill: #ed8936;
162
+ stroke: #c05621;
163
+ }
164
+
165
+ .node-agent .node-circle {
166
+ fill: #9f7aea;
167
+ stroke: #6b46c1;
168
+ }
169
+
170
+ .node-tool .node-circle {
171
+ fill: #e53e3e;
172
+ stroke: #c53030;
173
+ }
174
+
175
+ /* Status Badges */
176
+ .status-badge {
177
+ transition: all 0.3s ease;
178
+ }
179
+
180
+ .status-text {
181
+ font-size: 10px;
182
+ font-weight: 600;
183
+ text-transform: uppercase;
184
+ letter-spacing: 0.5px;
185
+ pointer-events: none;
186
+ }
187
+
188
+ /* Links */
189
+ .link {
190
+ transition: all 0.3s ease;
191
+ }
192
+
193
+ .node:hover .link {
194
+ stroke: #4299e1;
195
+ stroke-width: 3px;
196
+ }
197
+
198
+ /* D3 Tooltip */
199
+ .d3-tooltip {
200
+ font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
201
+ line-height: 1.4;
202
+ max-width: 250px;
203
+ word-wrap: break-word;
204
+ }
205
+
206
+ /* Legacy Tree Styles - Keep for fallback */
207
+ .linear-tree {
208
+ font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', monospace;
209
+ line-height: 1.6;
210
+ padding: 15px;
211
+ min-height: 100%;
212
+ }
213
+
214
+ /* Tree Node Base Styles */
215
+ .tree-node {
216
+ margin: 2px 0;
217
+ border-radius: 4px;
218
+ transition: background-color 0.2s ease;
219
+ }
220
+
221
+ .tree-node:hover {
222
+ background-color: #f7fafc;
223
+ }
224
+
225
+ .tree-node-content {
226
+ display: flex;
227
+ align-items: center;
228
+ padding: 6px 8px;
229
+ gap: 8px;
230
+ cursor: pointer;
231
+ border-radius: 4px;
232
+ transition: all 0.2s ease;
233
+ }
234
+
235
+ .tree-node-content:hover {
236
+ background-color: #edf2f7;
237
+ }
238
+
239
+ /* Tree Indentation */
240
+ .tree-node[data-level="1"] {
241
+ margin-left: 20px;
242
+ }
243
+
244
+ .tree-node[data-level="2"] {
245
+ margin-left: 40px;
246
+ }
247
+
248
+ .tree-node[data-level="3"] {
249
+ margin-left: 60px;
250
+ }
251
+
252
+ .tree-node[data-level="4"] {
253
+ margin-left: 80px;
254
+ }
255
+
256
+ /* Tree Icons */
257
+ .tree-icon {
258
+ font-size: 16px;
259
+ width: 20px;
260
+ text-align: center;
261
+ flex-shrink: 0;
262
+ }
263
+
264
+ .tree-status-icon {
265
+ font-size: 14px;
266
+ width: 18px;
267
+ text-align: center;
268
+ flex-shrink: 0;
269
+ margin-left: 2px;
270
+ }
271
+
272
+ .tree-expand-icon {
273
+ font-size: 12px;
274
+ width: 16px;
275
+ text-align: center;
276
+ flex-shrink: 0;
277
+ cursor: pointer;
278
+ color: #718096;
279
+ transition: transform 0.2s ease;
280
+ }
281
+
282
+ .tree-expand-icon:hover {
283
+ color: #4a5568;
284
+ transform: scale(1.2);
285
+ }
286
+
287
+ /* Tree Labels and Text */
288
+ .tree-label {
289
+ flex-grow: 1;
290
+ font-size: 14px;
291
+ color: #2d3748;
292
+ font-weight: 500;
293
+ }
294
+
295
+ .tree-label.clickable {
296
+ cursor: pointer;
297
+ transition: all 0.2s ease;
298
+ border-radius: 3px;
299
+ padding: 2px 4px;
300
+ }
301
+
302
+ .tree-label.clickable:hover {
303
+ background-color: #e2e8f0;
304
+ color: #2c5282;
305
+ }
306
+
307
+ .tree-meta {
308
+ font-size: 12px;
309
+ color: #718096;
310
+ font-style: italic;
311
+ margin-left: auto;
312
+ }
313
+
314
+ .tree-params {
315
+ font-size: 11px;
316
+ color: #4a5568;
317
+ background: #edf2f7;
318
+ padding: 2px 6px;
319
+ border-radius: 3px;
320
+ max-width: 200px;
321
+ overflow: hidden;
322
+ text-overflow: ellipsis;
323
+ white-space: nowrap;
324
+ }
325
+
326
+ .tree-status {
327
+ font-size: 11px;
328
+ padding: 2px 6px;
329
+ border-radius: 12px;
330
+ font-weight: 600;
331
+ text-transform: uppercase;
332
+ letter-spacing: 0.5px;
333
+ margin-left: 8px;
334
+ }
335
+
336
+ /* Tree Children */
337
+ .tree-children {
338
+ margin-left: 0;
339
+ border-left: 1px solid #e2e8f0;
340
+ margin-left: 20px;
341
+ padding-left: 0;
342
+ }
343
+
344
+ /* Node Type Styles */
345
+
346
+ /* Project Root */
347
+ .tree-node.project-root {
348
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
349
+ color: white;
350
+ margin-bottom: 10px;
351
+ border-radius: 6px;
352
+ }
353
+
354
+ .tree-node.project-root .tree-node-content {
355
+ padding: 10px 12px;
356
+ }
357
+
358
+ .tree-node.project-root .tree-label {
359
+ color: white;
360
+ font-weight: 600;
361
+ font-size: 16px;
362
+ }
363
+
364
+ .tree-node.project-root .tree-meta {
365
+ color: rgba(255, 255, 255, 0.8);
366
+ }
367
+
368
+ /* Session Nodes */
369
+ .tree-node.session {
370
+ background: #f8f9fa;
371
+ border: 1px solid #e9ecef;
372
+ margin-bottom: 8px;
373
+ border-radius: 6px;
374
+ }
375
+
376
+ .tree-node.session .tree-node-content {
377
+ padding: 8px 12px;
378
+ font-weight: 600;
379
+ }
380
+
381
+ .tree-node.session .tree-icon {
382
+ font-size: 18px;
383
+ }
384
+
385
+ .tree-node.session .tree-label {
386
+ font-size: 15px;
387
+ color: #495057;
388
+ }
389
+
390
+ /* Todo Nodes */
391
+ .tree-node.todo {
392
+ border-left: 3px solid #cbd5e0;
393
+ margin: 4px 0;
394
+ }
395
+
396
+ .tree-node.todo.status-pending {
397
+ border-left-color: #cbd5e0;
398
+ background: #f8f9fa;
399
+ }
400
+
401
+ .tree-node.todo.status-in_progress {
402
+ border-left-color: #3182ce;
403
+ background: #ebf8ff;
404
+ }
405
+
406
+ .tree-node.todo.status-completed {
407
+ border-left-color: #38a169;
408
+ background: #f0fff4;
409
+ }
410
+
411
+ /* Agent Nodes */
412
+ .tree-node.agent {
413
+ background: #fef5e7;
414
+ border-left: 2px solid #ed8936;
415
+ margin: 2px 0;
416
+ cursor: pointer;
417
+ transition: all 0.2s ease;
418
+ }
419
+
420
+ .tree-node.agent:hover {
421
+ background: #fed7aa;
422
+ transform: translateX(2px);
423
+ box-shadow: 0 2px 4px rgba(237, 137, 54, 0.2);
424
+ }
425
+
426
+ .tree-node.agent.selected {
427
+ background: #fed7aa;
428
+ border-left-color: #c05621;
429
+ border-left-width: 4px;
430
+ box-shadow: 0 4px 8px rgba(192, 86, 33, 0.3);
431
+ }
432
+
433
+ .tree-node.agent.status-active {
434
+ background: #fef5e7;
435
+ border-left-color: #ed8936;
436
+ }
437
+
438
+ .tree-node.agent.status-completed {
439
+ background: #f0fff4;
440
+ border-left-color: #38a169;
441
+ }
442
+
443
+ /* Tool Nodes - Maximum Specificity to Override Any Conflicting Styles */
444
+ body .activity-tree-container .linear-tree .tree-node.tool,
445
+ .tree-node.tool {
446
+ background: #faf5ff !important;
447
+ border-left: 2px solid #9f7aea !important;
448
+ margin: 1px 0 !important;
449
+ cursor: pointer !important;
450
+ transition: all 0.2s ease !important;
451
+ }
452
+
453
+ body .activity-tree-container .linear-tree .tree-node.tool:hover,
454
+ .tree-node.tool:hover {
455
+ background: #f3e8ff !important;
456
+ transform: translateX(2px) !important;
457
+ box-shadow: 0 2px 4px rgba(159, 122, 234, 0.2) !important;
458
+ }
459
+
460
+ body .activity-tree-container .linear-tree .tree-node.tool.selected,
461
+ .tree-node.tool.selected {
462
+ background: #e9d8fd !important;
463
+ border-left-color: #7c3aed !important;
464
+ border-left-width: 4px !important;
465
+ box-shadow: 0 4px 8px rgba(124, 58, 237, 0.3) !important;
466
+ }
467
+
468
+ /* Tool Status Styles - Maximum Specificity to Override Any Other Rules */
469
+ body .activity-tree-container .linear-tree .tree-node.tool.status-pending,
470
+ .tree-node.tool.status-pending {
471
+ background: #faf5ff !important;
472
+ border-left-color: #9f7aea !important;
473
+ border-left-width: 2px !important;
474
+ }
475
+
476
+ body .activity-tree-container .linear-tree .tree-node.tool.status-in_progress,
477
+ .tree-node.tool.status-in_progress {
478
+ background: #e6fffa !important;
479
+ border-left-color: #38b2ac !important;
480
+ border-left-width: 3px !important;
481
+ animation: pulse-tool 2s infinite;
482
+ }
483
+
484
+ body .activity-tree-container .linear-tree .tree-node.tool.status-completed,
485
+ .tree-node.tool.status-completed {
486
+ background: #f0fff4 !important;
487
+ border-left-color: #38a169 !important;
488
+ border-left-width: 2px !important;
489
+ }
490
+
491
+ body .activity-tree-container .linear-tree .tree-node.tool.status-failed,
492
+ .tree-node.tool.status-failed {
493
+ background: #fed7d7 !important;
494
+ border-left-color: #e53e3e !important;
495
+ border-left-width: 2px !important;
496
+ }
497
+
498
+ /* Tool Status Icons */
499
+ .tree-node.tool .tree-status-icon {
500
+ color: #718096;
501
+ }
502
+
503
+ .tree-node.tool.status-in_progress .tree-status-icon {
504
+ color: #38b2ac;
505
+ animation: spin 2s linear infinite;
506
+ }
507
+
508
+ .tree-node.tool.status-completed .tree-status-icon {
509
+ color: #38a169;
510
+ }
511
+
512
+ .tree-node.tool.status-failed .tree-status-icon {
513
+ color: #e53e3e;
514
+ }
515
+
516
+ /* Spinning animation for in-progress tools */
517
+ @keyframes spin {
518
+ 0% { transform: rotate(0deg); }
519
+ 100% { transform: rotate(360deg); }
520
+ }
521
+
522
+ /* Pulse animation for in-progress tools */
523
+ @keyframes pulse-tool {
524
+ 0% {
525
+ background: #e6fffa !important;
526
+ }
527
+ 50% {
528
+ background: #b2f5ea !important;
529
+ }
530
+ 100% {
531
+ background: #e6fffa !important;
532
+ }
533
+ }
534
+
535
+ /* Privileged Tool (TodoWrite) - High Specificity */
536
+ body .activity-tree-container .linear-tree .tree-node.tool.privileged-tool,
537
+ .tree-node.tool.privileged-tool {
538
+ background: #fff8e1 !important;
539
+ border-left: 3px solid #ff9800 !important;
540
+ border-radius: 6px !important;
541
+ margin: 4px 0 !important;
542
+ }
543
+
544
+ body .activity-tree-container .linear-tree .tree-node.tool.privileged-tool .tree-label,
545
+ .tree-node.tool.privileged-tool .tree-label {
546
+ font-weight: 600 !important;
547
+ color: #e65100 !important;
548
+ }
549
+
550
+ body .activity-tree-container .linear-tree .tree-node.tool.privileged-tool .tree-params,
551
+ .tree-node.tool.privileged-tool .tree-params {
552
+ background: #ffe0b2 !important;
553
+ color: #e65100 !important;
554
+ font-weight: 500 !important;
555
+ }
556
+
557
+ /* Catch-all rule to prevent any other styles from overriding tool styling */
558
+ .tree-node.tool:not(.privileged-tool) {
559
+ background: #faf5ff !important;
560
+ border-left: 2px solid #9f7aea !important;
561
+ }
562
+
563
+ .tree-node.tool:not(.privileged-tool).status-pending {
564
+ background: #faf5ff !important;
565
+ border-left-color: #9f7aea !important;
566
+ }
567
+
568
+ .tree-node.tool:not(.privileged-tool).status-in_progress {
569
+ background: #e6fffa !important;
570
+ border-left-color: #38b2ac !important;
571
+ border-left-width: 3px !important;
572
+ animation: pulse-tool 2s infinite;
573
+ }
574
+
575
+ .tree-node.tool:not(.privileged-tool).status-completed {
576
+ background: #f0fff4 !important;
577
+ border-left-color: #38a169 !important;
578
+ }
579
+
580
+ .tree-node.tool:not(.privileged-tool).status-failed {
581
+ background: #fed7d7 !important;
582
+ border-left-color: #e53e3e !important;
583
+ }
584
+
585
+ /* Todo Items within TodoWrite tool */
586
+ .tree-node.todo-item {
587
+ background: #f8f9fa;
588
+ border-left: 2px solid #cbd5e0;
589
+ margin: 1px 0;
590
+ border-radius: 3px;
591
+ }
592
+
593
+ .tree-node.todo-item.status-pending {
594
+ border-left-color: #cbd5e0;
595
+ background: #f8f9fa;
596
+ }
597
+
598
+ .tree-node.todo-item.status-in_progress {
599
+ border-left-color: #3182ce;
600
+ background: #ebf8ff;
601
+ animation: pulse-todo 2s infinite;
602
+ }
603
+
604
+ .tree-node.todo-item.status-completed {
605
+ border-left-color: #38a169;
606
+ background: #f0fff4;
607
+ }
608
+
609
+ @keyframes pulse-todo {
610
+ 0% {
611
+ background: #ebf8ff;
612
+ }
613
+ 50% {
614
+ background: #bee3f8;
615
+ }
616
+ 100% {
617
+ background: #ebf8ff;
618
+ }
619
+ }
620
+
621
+ /* Status Badges */
622
+ .tree-status.status-pending {
623
+ background: #e2e8f0;
624
+ color: #4a5568;
625
+ }
626
+
627
+ .tree-status.status-in_progress {
628
+ background: #bee3f8;
629
+ color: #2c5282;
630
+ animation: pulse-status 2s infinite;
631
+ }
632
+
633
+ .tree-status.status-active {
634
+ background: #fbb6ce;
635
+ color: #97266d;
636
+ animation: pulse-status 2s infinite;
637
+ }
638
+
639
+ .tree-status.status-completed {
640
+ background: #c6f6d5;
641
+ color: #276749;
642
+ }
643
+
644
+ .tree-status.status-failed {
645
+ background: #fed7d7;
646
+ color: #c53030;
647
+ }
648
+
649
+ /* Status Animation */
650
+ @keyframes pulse-status {
651
+ 0% {
652
+ opacity: 1;
653
+ }
654
+ 50% {
655
+ opacity: 0.7;
656
+ }
657
+ 100% {
658
+ opacity: 1;
659
+ }
660
+ }
661
+
662
+ /* Pinned TODOs Styles */
663
+ .tree-node.pinned-todos {
664
+ background: linear-gradient(135deg, #fff8dc 0%, #f0e68c 100%) !important;
665
+ border-left: 4px solid #daa520 !important;
666
+ border-radius: 6px !important;
667
+ margin: 4px 0 !important;
668
+ font-weight: 600 !important;
669
+ }
670
+
671
+ .tree-node.pinned-todos:hover {
672
+ background: linear-gradient(135deg, #f0e68c 0%, #daa520 100%) !important;
673
+ box-shadow: 0 4px 8px rgba(218, 165, 32, 0.3) !important;
674
+ }
675
+
676
+ .tree-node.pinned-todos .tree-label {
677
+ color: #b8860b !important;
678
+ font-weight: bold !important;
679
+ }
680
+
681
+ .tree-node.pinned-todos .tree-icon {
682
+ color: #daa520 !important;
683
+ font-size: 18px !important;
684
+ }
685
+
686
+ .tree-node.pinned-todos .tree-params {
687
+ background: #f5deb3 !important;
688
+ color: #8b4513 !important;
689
+ font-weight: 600 !important;
690
+ border: 1px solid #daa520 !important;
691
+ }
692
+
693
+ .tree-node.pinned-todos .tree-status {
694
+ background: #daa520 !important;
695
+ color: white !important;
696
+ font-weight: bold !important;
697
+ text-transform: uppercase !important;
698
+ }
699
+
700
+ /* Tree Legend */
701
+ .tree-legend {
702
+ position: absolute;
703
+ top: 15px;
704
+ right: 15px;
705
+ background: rgba(255, 255, 255, 0.95);
706
+ border: 1px solid #e2e8f0;
707
+ border-radius: 6px;
708
+ padding: 10px;
709
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
710
+ }
711
+
712
+ .legend-item {
713
+ display: flex;
714
+ align-items: center;
715
+ gap: 8px;
716
+ margin-bottom: 5px;
717
+ font-size: 12px;
718
+ color: #4a5568;
719
+ }
720
+
721
+ .legend-item:last-child {
722
+ margin-bottom: 0;
723
+ }
724
+
725
+ .legend-icon {
726
+ width: 14px;
727
+ height: 14px;
728
+ display: inline-block;
729
+ text-align: center;
730
+ }
731
+
732
+ .legend-icon.pm {
733
+ color: #4A90E2;
734
+ }
735
+
736
+ .legend-icon.todowrite {
737
+ color: #9B59B6;
738
+ }
739
+
740
+ .legend-icon.agent {
741
+ color: #27AE60;
742
+ }
743
+
744
+ .legend-icon.tool {
745
+ color: #E67E22;
746
+ }
747
+
748
+ .legend-icon.file {
749
+ color: #95A5A6;
750
+ }
751
+
752
+ /* Search Highlighting - Specific to activity tree only */
753
+ .activity-tree-container .tree-node.search-match:not(.tool) {
754
+ background: #fff3cd !important;
755
+ border-left-color: #ffc107 !important;
756
+ }
757
+
758
+ .activity-tree-container .tree-node.search-match:not(.tool) .tree-label {
759
+ background: #ffecb5;
760
+ padding: 2px 4px;
761
+ border-radius: 3px;
762
+ }
763
+
764
+ /* Empty State */
765
+ .linear-tree:empty::after {
766
+ content: "No activity data available. Start using the PM to see the activity tree.";
767
+ display: block;
768
+ text-align: center;
769
+ color: #718096;
770
+ font-style: italic;
771
+ padding: 40px 20px;
772
+ }
773
+
774
+ /* Scrollbar Styles */
775
+ .activity-tree-container::-webkit-scrollbar {
776
+ width: 8px;
777
+ }
778
+
779
+ .activity-tree-container::-webkit-scrollbar-track {
780
+ background: #f1f1f1;
781
+ border-radius: 4px;
782
+ }
783
+
784
+ .activity-tree-container::-webkit-scrollbar-thumb {
785
+ background: #c1c1c1;
786
+ border-radius: 4px;
787
+ }
788
+
789
+ .activity-tree-container::-webkit-scrollbar-thumb:hover {
790
+ background: #a8a8a8;
791
+ }
792
+
793
+ /* User instruction styles */
794
+ .tree-node.user-instruction {
795
+ background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
796
+ border-left: 4px solid #2196f3;
797
+ cursor: pointer;
798
+ transition: all 0.2s ease;
799
+ }
800
+
801
+ .tree-node.user-instruction.selected {
802
+ background: linear-gradient(135deg, #bbdefb 0%, #90caf9 100%);
803
+ border-left-color: #1976d2;
804
+ box-shadow: 0 4px 8px rgba(25, 118, 210, 0.3);
805
+ }
806
+
807
+ .tree-node.user-instruction:hover {
808
+ background: linear-gradient(135deg, #bbdefb 0%, #90caf9 100%);
809
+ box-shadow: 0 4px 8px rgba(33, 150, 243, 0.2);
810
+ }
811
+
812
+ .tree-node.user-instruction .tree-label {
813
+ font-style: italic;
814
+ color: #1976d2;
815
+ }
816
+
817
+ /* TODO checklist styles */
818
+ .tree-node.todo-checklist {
819
+ background: linear-gradient(135deg, #f3e5f5 0%, #e1bee7 100%);
820
+ border-left: 4px solid #9c27b0;
821
+ font-weight: 600;
822
+ }
823
+
824
+ .tree-node.todo-checklist:hover {
825
+ background: linear-gradient(135deg, #e1bee7 0%, #ce93d8 100%);
826
+ box-shadow: 0 4px 8px rgba(156, 39, 176, 0.2);
827
+ }
828
+
829
+ .tree-node.todo-checklist .tree-label {
830
+ color: #7b1fa2;
831
+ font-weight: bold;
832
+ }
833
+
834
+ /* Enhanced TODO item styles */
835
+ .tree-node.todo-item {
836
+ margin: 2px 0;
837
+ border-radius: 4px;
838
+ transition: all 0.2s ease;
839
+ }
840
+
841
+ .tree-node.todo-item.status-pending {
842
+ background: linear-gradient(135deg, #f7fafc 0%, #e2e8f0 20%);
843
+ border-left: 3px solid #a0aec0;
844
+ }
845
+
846
+ .tree-node.todo-item.status-in_progress {
847
+ background: linear-gradient(135deg, #e8f5e8 0%, #a5d6a7 20%);
848
+ border-left: 3px solid #4caf50;
849
+ animation: pulse 2s infinite;
850
+ }
851
+
852
+ .tree-node.todo-item.status-completed {
853
+ background: linear-gradient(135deg, #e8f5e8 0%, #c8e6c9 20%);
854
+ border-left: 3px solid #2e7d32;
855
+ opacity: 0.8;
856
+ }
857
+
858
+ .tree-node.todo-item.status-completed .tree-label {
859
+ text-decoration: line-through;
860
+ color: #666;
861
+ }
862
+
863
+ /* Instruction and todo item detail styles */
864
+ .instruction-details,
865
+ .generic-details,
866
+ .tool-details,
867
+ .agent-details {
868
+ font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', monospace;
869
+ font-size: 12px;
870
+ }
871
+
872
+ .detail-row {
873
+ display: flex;
874
+ margin-bottom: 12px;
875
+ padding: 8px 0;
876
+ border-bottom: 1px solid #f0f0f0;
877
+ align-items: flex-start;
878
+ }
879
+
880
+ .detail-label {
881
+ font-weight: bold;
882
+ color: #4a5568;
883
+ width: 120px;
884
+ flex-shrink: 0;
885
+ line-height: 1.4;
886
+ }
887
+
888
+ .detail-value {
889
+ color: #2d3748;
890
+ word-break: break-word;
891
+ flex: 1;
892
+ line-height: 1.4;
893
+ }
894
+
895
+ .detail-section {
896
+ margin-top: 20px;
897
+ padding-top: 16px;
898
+ border-top: 2px solid #e2e8f0;
899
+ }
900
+
901
+ .detail-section-title {
902
+ font-weight: bold;
903
+ color: #2d3748;
904
+ margin-bottom: 12px;
905
+ display: block;
906
+ font-size: 14px;
907
+ }
908
+
909
+ .params-list {
910
+ background: #f7fafc;
911
+ border-radius: 6px;
912
+ padding: 12px;
913
+ border: 1px solid #e2e8f0;
914
+ }
915
+
916
+ .param-item {
917
+ margin-bottom: 16px;
918
+ padding-bottom: 12px;
919
+ border-bottom: 1px solid #e2e8f0;
920
+ }
921
+
922
+ .param-item:last-child {
923
+ margin-bottom: 0;
924
+ padding-bottom: 0;
925
+ border-bottom: none;
926
+ }
927
+
928
+ .param-key {
929
+ font-weight: bold;
930
+ color: #553c9a;
931
+ margin-bottom: 4px;
932
+ display: block;
933
+ font-size: 12px;
934
+ }
935
+
936
+ .param-value {
937
+ color: #2d3748;
938
+ }
939
+
940
+ .param-text-short {
941
+ background: #ffffff;
942
+ padding: 4px 8px;
943
+ border-radius: 3px;
944
+ border: 1px solid #cbd5e0;
945
+ display: inline-block;
946
+ font-family: inherit;
947
+ }
948
+
949
+ .param-text,
950
+ .param-text-long {
951
+ background: #ffffff;
952
+ border: 1px solid #cbd5e0;
953
+ border-radius: 4px;
954
+ padding: 8px;
955
+ margin: 4px 0;
956
+ white-space: pre-wrap;
957
+ word-wrap: break-word;
958
+ font-size: 11px;
959
+ line-height: 1.4;
960
+ max-height: 200px;
961
+ overflow-y: auto;
962
+ }
963
+
964
+ .param-json {
965
+ background: #f8f9fa;
966
+ border: 1px solid #d6d8db;
967
+ border-radius: 4px;
968
+ padding: 8px;
969
+ margin: 4px 0;
970
+ white-space: pre;
971
+ font-size: 11px;
972
+ line-height: 1.3;
973
+ max-height: 300px;
974
+ overflow: auto;
975
+ color: #24292e;
976
+ }
977
+
978
+ .param-primitive {
979
+ background: #edf2f7;
980
+ padding: 2px 6px;
981
+ border-radius: 3px;
982
+ font-weight: 500;
983
+ color: #2d3748;
984
+ }
985
+
986
+ .param-error {
987
+ background: #fed7d7;
988
+ padding: 4px 8px;
989
+ border-radius: 3px;
990
+ color: #c53030;
991
+ font-style: italic;
992
+ }
993
+
994
+ .status-badge {
995
+ display: inline-block;
996
+ padding: 3px 8px;
997
+ border-radius: 12px;
998
+ font-size: 11px;
999
+ font-weight: 600;
1000
+ text-transform: capitalize;
1001
+ letter-spacing: 0.5px;
1002
+ }
1003
+
1004
+ .status-badge.status-pending {
1005
+ background: #e2e8f0;
1006
+ color: #4a5568;
1007
+ }
1008
+
1009
+ .status-badge.status-in_progress {
1010
+ background: #bee3f8;
1011
+ color: #2c5282;
1012
+ }
1013
+
1014
+ .status-badge.status-completed {
1015
+ background: #c6f6d5;
1016
+ color: #276749;
1017
+ }
1018
+
1019
+ .status-badge.status-failed {
1020
+ background: #fed7d7;
1021
+ color: #c53030;
1022
+ }
1023
+
1024
+ .status-badge.status-active {
1025
+ background: #fbb6ce;
1026
+ color: #97266d;
1027
+ }
1028
+
1029
+ .tool-result {
1030
+ background: #f8f9fa;
1031
+ border: 1px solid #d6d8db;
1032
+ border-radius: 4px;
1033
+ padding: 12px;
1034
+ margin: 8px 0;
1035
+ white-space: pre-wrap;
1036
+ font-size: 11px;
1037
+ line-height: 1.4;
1038
+ max-height: 400px;
1039
+ overflow: auto;
1040
+ color: #24292e;
1041
+ }
1042
+
1043
+ /* Pulse animation for in-progress items */
1044
+ @keyframes pulse {
1045
+ 0% {
1046
+ box-shadow: 0 0 0 0 rgba(76, 175, 80, 0.4);
1047
+ }
1048
+ 70% {
1049
+ box-shadow: 0 0 0 4px rgba(76, 175, 80, 0);
1050
+ }
1051
+ 100% {
1052
+ box-shadow: 0 0 0 0 rgba(76, 175, 80, 0);
1053
+ }
1054
+ }
1055
+
1056
+ /* Responsive adjustments */
1057
+ @media (max-width: 1024px) {
1058
+ .activity-header {
1059
+ flex-direction: column;
1060
+ gap: 15px;
1061
+ }
1062
+
1063
+ .activity-controls {
1064
+ width: 100%;
1065
+ flex-wrap: wrap;
1066
+ justify-content: center;
1067
+ }
1068
+
1069
+ .tree-legend {
1070
+ position: static;
1071
+ margin-top: 15px;
1072
+ max-width: 300px;
1073
+ }
1074
+
1075
+ .tree-params {
1076
+ max-width: 150px;
1077
+ }
1078
+
1079
+ .activity-controls input {
1080
+ width: 150px;
1081
+ }
1082
+ }
1083
+
1084
+ @media (max-width: 768px) {
1085
+ .activity-container {
1086
+ padding: 10px;
1087
+ }
1088
+
1089
+ .activity-tree-container {
1090
+ padding: 0;
1091
+ }
1092
+
1093
+ .linear-tree {
1094
+ padding: 10px;
1095
+ }
1096
+
1097
+ .tree-node[data-level="1"] {
1098
+ margin-left: 15px;
1099
+ }
1100
+
1101
+ .tree-node[data-level="2"] {
1102
+ margin-left: 30px;
1103
+ }
1104
+
1105
+ .tree-node[data-level="3"] {
1106
+ margin-left: 45px;
1107
+ }
1108
+
1109
+ .tree-node[data-level="4"] {
1110
+ margin-left: 60px;
1111
+ }
1112
+
1113
+ .tree-params {
1114
+ max-width: 100px;
1115
+ }
1116
+
1117
+ .stat-item {
1118
+ flex-direction: column;
1119
+ gap: 2px;
1120
+ text-align: center;
1121
+ }
1122
+ }
1123
+
1124
+ /* Dark mode support */
1125
+ @media (prefers-color-scheme: dark) {
1126
+ .activity-tree-container {
1127
+ background: #1a202c;
1128
+ color: #e2e8f0;
1129
+ }
1130
+
1131
+ /* D3 Dark Mode Styles */
1132
+ #activity-tree-svg {
1133
+ background: #1a202c;
1134
+ }
1135
+
1136
+ .node-label {
1137
+ fill: #e2e8f0;
1138
+ }
1139
+
1140
+ .node:hover .node-label {
1141
+ fill: #63b3ed;
1142
+ }
1143
+
1144
+ .link {
1145
+ stroke: #4a5568;
1146
+ }
1147
+
1148
+ .node:hover .link {
1149
+ stroke: #63b3ed;
1150
+ }
1151
+
1152
+ .d3-tooltip {
1153
+ background: rgba(45, 55, 72, 0.95) !important;
1154
+ color: #e2e8f0 !important;
1155
+ border: 1px solid #4a5568;
1156
+ }
1157
+
1158
+ .activity-header {
1159
+ background: #2d3748;
1160
+ }
1161
+
1162
+ .activity-controls select,
1163
+ .activity-controls input {
1164
+ background: #2d3748;
1165
+ color: #e2e8f0;
1166
+ border-color: #4a5568;
1167
+ }
1168
+
1169
+ .stat-label {
1170
+ color: #a0aec0;
1171
+ }
1172
+
1173
+ .stat-value {
1174
+ color: #e2e8f0;
1175
+ }
1176
+
1177
+ .tree-legend {
1178
+ background: rgba(45, 55, 72, 0.95);
1179
+ border-color: #4a5568;
1180
+ }
1181
+
1182
+ .legend-item {
1183
+ color: #e2e8f0;
1184
+ }
1185
+
1186
+ .tree-node:hover {
1187
+ background-color: #2d3748;
1188
+ }
1189
+
1190
+ .tree-node-content:hover {
1191
+ background-color: #4a5568;
1192
+ }
1193
+
1194
+ .tree-label {
1195
+ color: #e2e8f0;
1196
+ }
1197
+
1198
+ .tree-meta {
1199
+ color: #a0aec0;
1200
+ }
1201
+
1202
+ .tree-node.project-root {
1203
+ background: linear-gradient(135deg, #4299e1 0%, #553c9a 100%);
1204
+ }
1205
+
1206
+ .tree-node.session {
1207
+ background: #2d3748;
1208
+ border-color: #4a5568;
1209
+ }
1210
+
1211
+ .tree-node.session .tree-label {
1212
+ color: #e2e8f0;
1213
+ }
1214
+
1215
+ .tree-children {
1216
+ border-left-color: #4a5568;
1217
+ }
1218
+
1219
+ .tree-label.clickable:hover {
1220
+ background-color: rgba(74, 85, 104, 0.5);
1221
+ color: #e2e8f0;
1222
+ }
1223
+
1224
+ .module-item-details {
1225
+ color: #e2e8f0;
1226
+ }
1227
+
1228
+ .module-item-header {
1229
+ border-bottom-color: #4a5568;
1230
+ }
1231
+
1232
+ .module-item-header h6 {
1233
+ color: #e2e8f0;
1234
+ }
1235
+
1236
+ .detail-label {
1237
+ color: #a0aec0;
1238
+ }
1239
+
1240
+ .detail-value {
1241
+ color: #e2e8f0;
1242
+ }
1243
+
1244
+ .detail-section {
1245
+ border-top-color: #4a5568;
1246
+ }
1247
+
1248
+ .detail-section-title {
1249
+ color: #a0aec0;
1250
+ }
1251
+
1252
+ .tools-list, .params-list {
1253
+ background: #2d3748;
1254
+ border-color: #4a5568;
1255
+ }
1256
+
1257
+ .tool-summary {
1258
+ background: #4a5568;
1259
+ border-color: #718096;
1260
+ color: #e2e8f0;
1261
+ }
1262
+
1263
+ .tool-params-expanded {
1264
+ background: #2d3748;
1265
+ border-color: #4a5568;
1266
+ color: #e2e8f0;
1267
+ }
1268
+
1269
+ .param-line .param-key,
1270
+ .param-key {
1271
+ color: #9f7aea;
1272
+ }
1273
+
1274
+ .param-line .param-value,
1275
+ .param-value {
1276
+ color: #e2e8f0;
1277
+ }
1278
+
1279
+ .param-item {
1280
+ border-bottom-color: #4a5568;
1281
+ }
1282
+
1283
+ .param-text-short {
1284
+ background: #2d3748;
1285
+ border-color: #4a5568;
1286
+ color: #e2e8f0;
1287
+ }
1288
+
1289
+ .param-text,
1290
+ .param-text-long {
1291
+ background: #2d3748;
1292
+ border-color: #4a5568;
1293
+ color: #e2e8f0;
1294
+ }
1295
+
1296
+ .param-json {
1297
+ background: #1a202c;
1298
+ border-color: #4a5568;
1299
+ color: #e2e8f0;
1300
+ }
1301
+
1302
+ .param-primitive {
1303
+ background: #4a5568;
1304
+ color: #e2e8f0;
1305
+ }
1306
+
1307
+ .param-error {
1308
+ background: #742a2a;
1309
+ color: #feb2b2;
1310
+ }
1311
+
1312
+ .tool-result {
1313
+ background: #1a202c;
1314
+ border-color: #4a5568;
1315
+ color: #e2e8f0;
1316
+ }
1317
+ }
1318
+
1319
+ /* Enhanced TodoWrite Display Styles */
1320
+
1321
+ /* Todo Summary Items */
1322
+ .todo-summary {
1323
+ display: flex;
1324
+ gap: 15px;
1325
+ margin: 15px 0;
1326
+ flex-wrap: wrap;
1327
+ }
1328
+
1329
+ .summary-item {
1330
+ display: flex;
1331
+ align-items: center;
1332
+ gap: 8px;
1333
+ padding: 8px 12px;
1334
+ background: #f8fafc;
1335
+ border-radius: 6px;
1336
+ border-left: 3px solid #e2e8f0;
1337
+ min-width: 120px;
1338
+ flex: 1;
1339
+ }
1340
+
1341
+ .summary-item.completed {
1342
+ background: #f0fff4;
1343
+ border-left-color: #38a169;
1344
+ }
1345
+
1346
+ .summary-item.in_progress {
1347
+ background: #e6fffa;
1348
+ border-left-color: #38b2ac;
1349
+ }
1350
+
1351
+ .summary-item.pending {
1352
+ background: #f7fafc;
1353
+ border-left-color: #a0aec0;
1354
+ }
1355
+
1356
+ .summary-icon {
1357
+ font-size: 16px;
1358
+ flex-shrink: 0;
1359
+ }
1360
+
1361
+ .summary-count {
1362
+ font-size: 18px;
1363
+ font-weight: bold;
1364
+ color: #2d3748;
1365
+ flex-shrink: 0;
1366
+ }
1367
+
1368
+ .summary-label {
1369
+ font-size: 12px;
1370
+ color: #718096;
1371
+ font-weight: 500;
1372
+ text-transform: uppercase;
1373
+ letter-spacing: 0.5px;
1374
+ }
1375
+
1376
+ /* Todo Checklist Items */
1377
+ .todo-checklist {
1378
+ background: #f8fafc;
1379
+ border-radius: 6px;
1380
+ border: 1px solid #e2e8f0;
1381
+ padding: 8px;
1382
+ }
1383
+
1384
+ .todo-checklist-item {
1385
+ display: flex;
1386
+ align-items: flex-start;
1387
+ gap: 12px;
1388
+ padding: 8px;
1389
+ margin: 4px 0;
1390
+ border-radius: 4px;
1391
+ transition: background 0.2s ease;
1392
+ border-left: 3px solid transparent;
1393
+ }
1394
+
1395
+ .todo-checklist-item:hover {
1396
+ background: #edf2f7;
1397
+ }
1398
+
1399
+ .todo-checklist-item.completed {
1400
+ background: #f0fff4;
1401
+ border-left-color: #38a169;
1402
+ }
1403
+
1404
+ .todo-checklist-item.in_progress {
1405
+ background: #e6fffa;
1406
+ border-left-color: #38b2ac;
1407
+ animation: pulse-todo 2s infinite;
1408
+ }
1409
+
1410
+ .todo-checklist-item.pending {
1411
+ background: #f7fafc;
1412
+ border-left-color: #cbd5e0;
1413
+ }
1414
+
1415
+ .todo-checkbox {
1416
+ flex-shrink: 0;
1417
+ width: 24px;
1418
+ height: 24px;
1419
+ display: flex;
1420
+ align-items: center;
1421
+ justify-content: center;
1422
+ border-radius: 4px;
1423
+ background: white;
1424
+ border: 2px solid #e2e8f0;
1425
+ margin-top: 2px;
1426
+ }
1427
+
1428
+ .checkbox-icon {
1429
+ font-size: 14px;
1430
+ font-weight: bold;
1431
+ }
1432
+
1433
+ .checkbox-icon.status-completed {
1434
+ color: #38a169;
1435
+ }
1436
+
1437
+ .checkbox-icon.status-in_progress {
1438
+ color: #38b2ac;
1439
+ }
1440
+
1441
+ .checkbox-icon.status-pending {
1442
+ color: #a0aec0;
1443
+ }
1444
+
1445
+ .todo-text {
1446
+ flex: 1;
1447
+ min-width: 0;
1448
+ }
1449
+
1450
+ .todo-content {
1451
+ display: block;
1452
+ font-size: 14px;
1453
+ color: #2d3748;
1454
+ line-height: 1.4;
1455
+ margin-bottom: 4px;
1456
+ word-wrap: break-word;
1457
+ }
1458
+
1459
+ .todo-checklist-item.completed .todo-content {
1460
+ text-decoration: line-through;
1461
+ color: #718096;
1462
+ }
1463
+
1464
+ .todo-status-badge {
1465
+ display: inline-block;
1466
+ padding: 2px 6px;
1467
+ font-size: 10px;
1468
+ font-weight: 600;
1469
+ text-transform: uppercase;
1470
+ letter-spacing: 0.5px;
1471
+ border-radius: 10px;
1472
+ margin-top: 2px;
1473
+ }
1474
+
1475
+ .todo-status-badge.status-completed {
1476
+ background: #c6f6d5;
1477
+ color: #276749;
1478
+ }
1479
+
1480
+ .todo-status-badge.status-in_progress {
1481
+ background: #b2f5ea;
1482
+ color: #285e61;
1483
+ }
1484
+
1485
+ .todo-status-badge.status-pending {
1486
+ background: #e2e8f0;
1487
+ color: #4a5568;
1488
+ }
1489
+
1490
+ /* No todos message */
1491
+ .no-todos {
1492
+ text-align: center;
1493
+ color: #718096;
1494
+ font-style: italic;
1495
+ padding: 20px;
1496
+ background: #f7fafc;
1497
+ border-radius: 6px;
1498
+ border: 1px dashed #cbd5e0;
1499
+ }
1500
+
1501
+ /* Animation for in-progress items */
1502
+ @keyframes pulse-todo {
1503
+ 0% {
1504
+ background: #e6fffa;
1505
+ }
1506
+ 50% {
1507
+ background: #b2f5ea;
1508
+ }
1509
+ 100% {
1510
+ background: #e6fffa;
1511
+ }
1512
+ }
1513
+
1514
+ /* Unified viewer status and headers */
1515
+ .unified-viewer-header {
1516
+ display: flex;
1517
+ justify-content: space-between;
1518
+ align-items: center;
1519
+ padding: 12px 16px;
1520
+ background: #f8fafc;
1521
+ border-bottom: 1px solid #e2e8f0;
1522
+ border-radius: 6px 6px 0 0;
1523
+ }
1524
+
1525
+ .unified-viewer-header h6 {
1526
+ margin: 0;
1527
+ font-size: 16px;
1528
+ font-weight: 600;
1529
+ color: #2d3748;
1530
+ }
1531
+
1532
+ .unified-viewer-status {
1533
+ font-size: 12px;
1534
+ font-weight: 600;
1535
+ padding: 4px 8px;
1536
+ border-radius: 12px;
1537
+ text-transform: uppercase;
1538
+ letter-spacing: 0.5px;
1539
+ }
1540
+
1541
+ .unified-viewer-content {
1542
+ padding: 16px;
1543
+ }
1544
+
1545
+ /* Responsive adjustments for TodoWrite display */
1546
+ @media (max-width: 768px) {
1547
+ .todo-summary {
1548
+ flex-direction: column;
1549
+ gap: 8px;
1550
+ }
1551
+
1552
+ .summary-item {
1553
+ min-width: auto;
1554
+ }
1555
+
1556
+ .todo-checklist-item {
1557
+ padding: 6px;
1558
+ }
1559
+
1560
+ .todo-checkbox {
1561
+ width: 20px;
1562
+ height: 20px;
1563
+ }
1564
+
1565
+ .checkbox-icon {
1566
+ font-size: 12px;
1567
+ }
1568
+ }
1569
+
1570
+ /* Print Styles */
1571
+ @media print {
1572
+ .activity-header {
1573
+ display: none;
1574
+ }
1575
+
1576
+ .tree-legend {
1577
+ position: static;
1578
+ margin-bottom: 20px;
1579
+ }
1580
+
1581
+ .activity-tree-container {
1582
+ box-shadow: none;
1583
+ border: 1px solid #000;
1584
+ }
1585
+
1586
+ .tree-node {
1587
+ break-inside: avoid;
1588
+ }
1589
+
1590
+ .tree-status {
1591
+ border: 1px solid #000;
1592
+ background: transparent !important;
1593
+ color: #000 !important;
1594
+ }
1595
+ }
1596
+
1597
+ /* Focus and Accessibility */
1598
+ .tree-node-content:focus {
1599
+ outline: 2px solid #4299e1;
1600
+ outline-offset: 2px;
1601
+ }
1602
+
1603
+ .tree-expand-icon:focus {
1604
+ outline: 2px solid #4299e1;
1605
+ outline-offset: 2px;
1606
+ }
1607
+
1608
+ /* Active/current item highlighting */
1609
+ .tree-node.current-active {
1610
+ background: linear-gradient(90deg, rgba(245, 158, 11, 0.1) 0%, transparent 100%);
1611
+ border-left: 3px solid #f59e0b;
1612
+ animation: pulse-active 2s ease-in-out infinite;
1613
+ }
1614
+
1615
+ .tree-node.has-active .tree-node-content {
1616
+ font-weight: 600;
1617
+ }
1618
+
1619
+ .tree-node.todowrite.has-active .tree-icon {
1620
+ animation: rotate-icon 3s linear infinite;
1621
+ }
1622
+
1623
+ @keyframes pulse-active {
1624
+ 0%, 100% {
1625
+ background: linear-gradient(90deg, rgba(245, 158, 11, 0.1) 0%, transparent 100%);
1626
+ }
1627
+ 50% {
1628
+ background: linear-gradient(90deg, rgba(245, 158, 11, 0.2) 0%, transparent 100%);
1629
+ }
1630
+ }
1631
+
1632
+ @keyframes rotate-icon {
1633
+ from {
1634
+ transform: rotate(0deg);
1635
+ }
1636
+ to {
1637
+ transform: rotate(360deg);
1638
+ }
1639
+ }
1640
+
1641
+ /* Collapsed state indicators */
1642
+ .tree-node.agent:not(.expanded) .tree-label {
1643
+ font-style: italic;
1644
+ color: #4b5563;
1645
+ }
1646
+
1647
+ .tree-node.agent .tree-label .current-status {
1648
+ color: #f59e0b;
1649
+ font-weight: 600;
1650
+ margin-left: 10px;
1651
+ }
1652
+
1653
+ /* TodoWrite specific styles */
1654
+ .tree-node.todowrite {
1655
+ background: rgba(99, 102, 241, 0.05);
1656
+ border-radius: 4px;
1657
+ margin: 2px 0;
1658
+ }
1659
+
1660
+ .tree-node.todowrite .tree-node-content {
1661
+ padding: 4px 8px;
1662
+ }
1663
+
1664
+ /* Multiple call/update indicators */
1665
+ .tree-node .tree-label .call-count,
1666
+ .tree-node .tree-label .update-count {
1667
+ color: #6366f1;
1668
+ font-weight: 600;
1669
+ font-size: 0.85em;
1670
+ opacity: 0.8;
1671
+ }
1672
+
1673
+ .tree-node.tool .tree-label {
1674
+ position: relative;
1675
+ }
1676
+
1677
+ .tree-node.tool .call-indicator {
1678
+ display: inline-block;
1679
+ background: #f59e0b;
1680
+ color: white;
1681
+ border-radius: 10px;
1682
+ padding: 0 6px;
1683
+ font-size: 0.75em;
1684
+ margin-left: 5px;
1685
+ font-weight: 600;
1686
+ }
1687
+
1688
+ /* ==================== IMPROVED DATA VIEWER STYLES ==================== */
1689
+
1690
+ /* Primary data section for important information */
1691
+ .primary-data {
1692
+ padding: 10px 0;
1693
+ border-bottom: 1px solid #e5e7eb;
1694
+ margin-bottom: 15px;
1695
+ }
1696
+
1697
+ .primary-data .detail-row.highlight {
1698
+ background: rgba(59, 130, 246, 0.05);
1699
+ padding: 8px 12px;
1700
+ border-radius: 6px;
1701
+ margin: 5px 0;
1702
+ font-weight: 500;
1703
+ }
1704
+
1705
+ .primary-data .code {
1706
+ font-family: 'Monaco', 'Courier New', monospace;
1707
+ background: #1e293b;
1708
+ color: #94a3b8;
1709
+ padding: 2px 6px;
1710
+ border-radius: 3px;
1711
+ }
1712
+
1713
+ /* TodoWrite specific styles */
1714
+ .todo-status-bar {
1715
+ display: flex;
1716
+ gap: 20px;
1717
+ padding: 12px;
1718
+ background: linear-gradient(90deg, #f8fafc 0%, #f1f5f9 100%);
1719
+ border-radius: 8px;
1720
+ margin-bottom: 15px;
1721
+ }
1722
+
1723
+ .todo-status-bar .status-item {
1724
+ display: flex;
1725
+ align-items: center;
1726
+ gap: 6px;
1727
+ }
1728
+
1729
+ .todo-status-bar .status-icon {
1730
+ font-size: 1.2em;
1731
+ }
1732
+
1733
+ .todo-status-bar .status-count {
1734
+ font-size: 1.4em;
1735
+ font-weight: 700;
1736
+ color: #1e293b;
1737
+ }
1738
+
1739
+ .todo-status-bar .status-label {
1740
+ color: #64748b;
1741
+ font-size: 0.9em;
1742
+ }
1743
+
1744
+ /* Horizontal status line for TodoWrite */
1745
+ .todo-status-line {
1746
+ display: flex;
1747
+ gap: 20px;
1748
+ padding: 8px 12px;
1749
+ background: #f8fafc;
1750
+ border-radius: 6px;
1751
+ margin-bottom: 12px;
1752
+ font-size: 0.95em;
1753
+ border: 1px solid #e2e8f0;
1754
+ }
1755
+
1756
+ .todo-status-line .status-inline {
1757
+ display: inline-flex;
1758
+ align-items: center;
1759
+ gap: 4px;
1760
+ font-weight: 500;
1761
+ color: #475569;
1762
+ }
1763
+
1764
+ /* Todo list primary display */
1765
+ .todo-list-primary {
1766
+ padding: 10px 0;
1767
+ }
1768
+
1769
+ .todo-item {
1770
+ display: flex;
1771
+ align-items: center;
1772
+ gap: 10px;
1773
+ padding: 10px 12px;
1774
+ margin: 5px 0;
1775
+ background: white;
1776
+ border: 1px solid #e5e7eb;
1777
+ border-radius: 6px;
1778
+ transition: all 0.2s ease;
1779
+ }
1780
+
1781
+ .todo-item:hover {
1782
+ border-color: #cbd5e1;
1783
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
1784
+ }
1785
+
1786
+ .todo-item.completed {
1787
+ opacity: 0.7;
1788
+ background: #f8fafc;
1789
+ }
1790
+
1791
+ .todo-item.completed .todo-text {
1792
+ text-decoration: line-through;
1793
+ color: #94a3b8;
1794
+ }
1795
+
1796
+ .todo-item.in_progress {
1797
+ background: linear-gradient(90deg, rgba(251, 146, 60, 0.1) 0%, white 100%);
1798
+ border-color: #fb923c;
1799
+ }
1800
+
1801
+ .todo-item .todo-icon {
1802
+ font-size: 1.2em;
1803
+ flex-shrink: 0;
1804
+ }
1805
+
1806
+ .todo-item .todo-text {
1807
+ flex-grow: 1;
1808
+ font-size: 0.95em;
1809
+ color: #334155;
1810
+ }
1811
+
1812
+ .todo-item .todo-badge.active {
1813
+ background: #fb923c;
1814
+ color: white;
1815
+ padding: 2px 8px;
1816
+ border-radius: 12px;
1817
+ font-size: 0.75em;
1818
+ font-weight: 600;
1819
+ text-transform: uppercase;
1820
+ animation: pulse 2s ease-in-out infinite;
1821
+ }
1822
+
1823
+ /* Tool display improvements */
1824
+ .tool-chip {
1825
+ display: inline-flex;
1826
+ align-items: center;
1827
+ gap: 6px;
1828
+ padding: 4px 10px;
1829
+ background: #f1f5f9;
1830
+ border: 1px solid #e2e8f0;
1831
+ border-radius: 15px;
1832
+ font-size: 0.9em;
1833
+ margin: 2px;
1834
+ }
1835
+
1836
+ .tool-chip.active {
1837
+ background: linear-gradient(90deg, #fef3c7 0%, #fed7aa 100%);
1838
+ border-color: #fb923c;
1839
+ font-weight: 500;
1840
+ }
1841
+
1842
+ .tools-grid {
1843
+ display: flex;
1844
+ flex-wrap: wrap;
1845
+ gap: 5px;
1846
+ margin-top: 8px;
1847
+ }
1848
+
1849
+ .active-tools-section {
1850
+ margin: 10px 0;
1851
+ padding: 10px;
1852
+ background: rgba(251, 146, 60, 0.05);
1853
+ border-radius: 6px;
1854
+ }
1855
+
1856
+ .active-tools-section .section-label {
1857
+ font-weight: 600;
1858
+ color: #ea580c;
1859
+ display: block;
1860
+ margin-bottom: 8px;
1861
+ }
1862
+
1863
+ /* Instruction display */
1864
+ .instruction-content {
1865
+ background: #f8fafc;
1866
+ padding: 15px;
1867
+ border-radius: 8px;
1868
+ border-left: 4px solid #3b82f6;
1869
+ font-size: 0.95em;
1870
+ line-height: 1.6;
1871
+ color: #1e293b;
1872
+ margin-bottom: 10px;
1873
+ }
1874
+
1875
+ .instruction-meta {
1876
+ display: flex;
1877
+ gap: 15px;
1878
+ padding: 8px 0;
1879
+ color: #64748b;
1880
+ font-size: 0.85em;
1881
+ }
1882
+
1883
+ .instruction-meta .meta-item {
1884
+ display: flex;
1885
+ align-items: center;
1886
+ gap: 5px;
1887
+ }
1888
+
1889
+ /* Collapsible JSON viewer */
1890
+ .collapsible-json-section {
1891
+ margin-top: 15px;
1892
+ border-top: 1px solid #e5e7eb;
1893
+ padding-top: 10px;
1894
+ }
1895
+
1896
+ .collapsible-json-toggle {
1897
+ background: #f8fafc;
1898
+ border: 1px solid #e2e8f0;
1899
+ padding: 6px 12px;
1900
+ border-radius: 6px;
1901
+ cursor: pointer;
1902
+ font-size: 0.9em;
1903
+ color: #475569;
1904
+ transition: all 0.2s ease;
1905
+ width: auto;
1906
+ display: inline-block;
1907
+ }
1908
+
1909
+ .collapsible-json-toggle:hover {
1910
+ background: #f1f5f9;
1911
+ border-color: #cbd5e1;
1912
+ }
1913
+
1914
+ .collapsible-json-toggle.expanded {
1915
+ background: #e0e7ff;
1916
+ border-color: #818cf8;
1917
+ color: #4338ca;
1918
+ }
1919
+
1920
+ .collapsible-json-content {
1921
+ margin-top: 10px;
1922
+ max-height: 400px;
1923
+ overflow-y: auto;
1924
+ }
1925
+
1926
+ .json-viewer {
1927
+ background: #1e293b;
1928
+ color: #94a3b8;
1929
+ padding: 12px;
1930
+ border-radius: 6px;
1931
+ font-family: 'Monaco', 'Courier New', monospace;
1932
+ font-size: 0.85em;
1933
+ line-height: 1.4;
1934
+ overflow-x: auto;
1935
+ }
1936
+
1937
+ /* Code snippets in viewers */
1938
+ .code-snippet {
1939
+ background: #1e293b;
1940
+ color: #94a3b8;
1941
+ padding: 8px 12px;
1942
+ border-radius: 4px;
1943
+ font-family: 'Monaco', 'Courier New', monospace;
1944
+ font-size: 0.9em;
1945
+ margin: 5px 0;
1946
+ overflow-x: auto;
1947
+ max-width: 100%;
1948
+ }
1949
+
1950
+ /* Animation for active items */
1951
+ @keyframes pulse {
1952
+ 0%, 100% {
1953
+ opacity: 1;
1954
+ }
1955
+ 50% {
1956
+ opacity: 0.7;
1957
+ }
1958
+ }