ai-control-center 1.15.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (154) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +584 -0
  3. package/bin/aicc.js +772 -0
  4. package/lib/actions/approve.js +71 -0
  5. package/lib/actions/assign-project.js +132 -0
  6. package/lib/actions/browser-test.js +64 -0
  7. package/lib/actions/cleanup.js +174 -0
  8. package/lib/actions/debug.js +298 -0
  9. package/lib/actions/deploy.js +1229 -0
  10. package/lib/actions/fix-bug.js +134 -0
  11. package/lib/actions/new-feature.js +255 -0
  12. package/lib/actions/reject.js +307 -0
  13. package/lib/actions/review.js +706 -0
  14. package/lib/actions/status.js +47 -0
  15. package/lib/agents/browser-qa-agent.js +611 -0
  16. package/lib/agents/payment-agent.js +116 -0
  17. package/lib/agents/suggestion-agent.js +88 -0
  18. package/lib/cli.js +303 -0
  19. package/lib/config.js +243 -0
  20. package/lib/hub/hub-server.js +440 -0
  21. package/lib/hub/project-poller.js +75 -0
  22. package/lib/hub/skill-registry.js +89 -0
  23. package/lib/hub/state-aggregator.js +204 -0
  24. package/lib/index.js +471 -0
  25. package/lib/init/doctor.js +523 -0
  26. package/lib/init/presets.js +222 -0
  27. package/lib/init/skill-fetcher.js +77 -0
  28. package/lib/init/wizard.js +973 -0
  29. package/lib/integrations/codex-runner.js +128 -0
  30. package/lib/integrations/github-actions.js +248 -0
  31. package/lib/integrations/github-reporter.js +229 -0
  32. package/lib/integrations/screenshot-store.js +102 -0
  33. package/lib/openclaw/bridge.js +650 -0
  34. package/lib/openclaw/generate-skill.js +235 -0
  35. package/lib/openclaw/openclaw.json +64 -0
  36. package/lib/orchestrator/autonomous-loop.js +429 -0
  37. package/lib/orchestrator/thread-triggers.js +63 -0
  38. package/lib/roleplay/agent-messenger.js +75 -0
  39. package/lib/roleplay/discussion-threads.js +303 -0
  40. package/lib/roleplay/health-monitor.js +121 -0
  41. package/lib/roleplay/pm-agent.js +513 -0
  42. package/lib/roleplay/roleplay-config.js +25 -0
  43. package/lib/roleplay/room.js +164 -0
  44. package/lib/shared/action-runner.js +2330 -0
  45. package/lib/shared/event-bus.js +185 -0
  46. package/lib/slack/bot.js +378 -0
  47. package/lib/telegram/bot.js +416 -0
  48. package/lib/telegram/commands.js +1267 -0
  49. package/lib/telegram/keyboards.js +113 -0
  50. package/lib/telegram/notifications.js +247 -0
  51. package/lib/twitch/bot.js +354 -0
  52. package/lib/twitch/commands.js +302 -0
  53. package/lib/twitch/notifications.js +63 -0
  54. package/lib/utils/achievements.js +191 -0
  55. package/lib/utils/activity-log.js +182 -0
  56. package/lib/utils/agent-leaderboard.js +119 -0
  57. package/lib/utils/audit-logger.js +232 -0
  58. package/lib/utils/codebase-context.js +288 -0
  59. package/lib/utils/codebase-indexer.js +381 -0
  60. package/lib/utils/config-schema.js +230 -0
  61. package/lib/utils/context-compressor.js +172 -0
  62. package/lib/utils/correlation.js +63 -0
  63. package/lib/utils/cost-tracker.js +423 -0
  64. package/lib/utils/cron-scheduler.js +53 -0
  65. package/lib/utils/db-adapter.js +293 -0
  66. package/lib/utils/display.js +272 -0
  67. package/lib/utils/errors.js +116 -0
  68. package/lib/utils/format.js +134 -0
  69. package/lib/utils/intent-engine.js +464 -0
  70. package/lib/utils/mcp-client.js +238 -0
  71. package/lib/utils/model-ab-test.js +164 -0
  72. package/lib/utils/notify.js +122 -0
  73. package/lib/utils/persona-loader.js +80 -0
  74. package/lib/utils/pipeline-lock.js +73 -0
  75. package/lib/utils/pipeline.js +214 -0
  76. package/lib/utils/plugin-runner.js +234 -0
  77. package/lib/utils/rate-limiter.js +84 -0
  78. package/lib/utils/rbac.js +74 -0
  79. package/lib/utils/runner.js +1809 -0
  80. package/lib/utils/security.js +191 -0
  81. package/lib/utils/self-healer.js +144 -0
  82. package/lib/utils/skill-loader.js +255 -0
  83. package/lib/utils/spinner.js +132 -0
  84. package/lib/utils/stage-queue.js +50 -0
  85. package/lib/utils/state-machine.js +89 -0
  86. package/lib/utils/status-bar.js +327 -0
  87. package/lib/utils/token-estimator.js +101 -0
  88. package/lib/utils/ux-analyzer.js +101 -0
  89. package/lib/utils/webhook-emitter.js +83 -0
  90. package/lib/web/public/css/styles.css +417 -0
  91. package/lib/web/public/dark-mode.js +44 -0
  92. package/lib/web/public/hub/kanban.html +206 -0
  93. package/lib/web/public/index.html +45 -0
  94. package/lib/web/public/js/app.js +71 -0
  95. package/lib/web/public/js/ask.js +110 -0
  96. package/lib/web/public/js/dashboard.js +165 -0
  97. package/lib/web/public/js/deploy.js +72 -0
  98. package/lib/web/public/js/feature.js +79 -0
  99. package/lib/web/public/js/health.js +65 -0
  100. package/lib/web/public/js/logs.js +93 -0
  101. package/lib/web/public/js/review.js +123 -0
  102. package/lib/web/public/js/ws-client.js +82 -0
  103. package/lib/web/public/office/css/office.css +678 -0
  104. package/lib/web/public/office/index.html +148 -0
  105. package/lib/web/public/office/js/achievements-ui.js +117 -0
  106. package/lib/web/public/office/js/character.js +1056 -0
  107. package/lib/web/public/office/js/chat-bubbles.js +177 -0
  108. package/lib/web/public/office/js/cost-overlay.js +123 -0
  109. package/lib/web/public/office/js/day-night.js +68 -0
  110. package/lib/web/public/office/js/effects.js +632 -0
  111. package/lib/web/public/office/js/engine.js +146 -0
  112. package/lib/web/public/office/js/feature-ticket.js +216 -0
  113. package/lib/web/public/office/js/hub-client.js +60 -0
  114. package/lib/web/public/office/js/main.js +1757 -0
  115. package/lib/web/public/office/js/office-layout.js +1524 -0
  116. package/lib/web/public/office/js/pathfinding.js +144 -0
  117. package/lib/web/public/office/js/pixel-sprites.js +1454 -0
  118. package/lib/web/public/office/js/progress-bars.js +117 -0
  119. package/lib/web/public/office/js/replay.js +191 -0
  120. package/lib/web/public/office/js/sound-effects.js +91 -0
  121. package/lib/web/public/office/js/sprite-renderer.js +211 -0
  122. package/lib/web/public/office/js/stamina-system.js +89 -0
  123. package/lib/web/public/office/js/ui.js +107 -0
  124. package/lib/web/public/onboarding/index.html +243 -0
  125. package/lib/web/public/timeline/index.html +195 -0
  126. package/lib/web/routes/api.js +499 -0
  127. package/lib/web/routes/logs.js +20 -0
  128. package/lib/web/routes/metrics.js +99 -0
  129. package/lib/web/server.js +183 -0
  130. package/lib/web/ws/handler.js +65 -0
  131. package/package.json +67 -0
  132. package/templates/agent-architect.md +69 -0
  133. package/templates/agent-gemini-pm.md +49 -0
  134. package/templates/agent-gemini-reviewer.md +52 -0
  135. package/templates/copilot-instructions.md +36 -0
  136. package/templates/pipelines/mobile.json +27 -0
  137. package/templates/pipelines/nodejs-api.json +27 -0
  138. package/templates/pipelines/python.json +27 -0
  139. package/templates/pipelines/react.json +27 -0
  140. package/templates/pipelines/salesforce.json +27 -0
  141. package/templates/role-gemini.md +97 -0
  142. package/templates/skill-architect.md +114 -0
  143. package/templates/skill-browser-qa.md +50 -0
  144. package/templates/skill-bug-from-qa.md +58 -0
  145. package/templates/skill-chatbot.md +93 -0
  146. package/templates/skill-implement.md +78 -0
  147. package/templates/skill-openclaw.md +174 -0
  148. package/templates/skill-payment.md +110 -0
  149. package/templates/skill-pm-spec.md +77 -0
  150. package/templates/skill-requirement-capture.md +97 -0
  151. package/templates/skill-review.md +108 -0
  152. package/templates/skill-reviewer-qa.md +44 -0
  153. package/templates/skill-suggestion.md +45 -0
  154. package/templates/skill-template.md +142 -0
@@ -0,0 +1,678 @@
1
+ /* ── AI Office Visualizer — Retro RPG Pixel Art Theme ────────────────────── */
2
+
3
+ @import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap');
4
+
5
+ * { margin: 0; padding: 0; box-sizing: border-box; }
6
+
7
+ :root {
8
+ --bg: #0a0a1a;
9
+ --bg2: #12122a;
10
+ --bg3: #1a1a3a;
11
+ --text: #e0e0e0;
12
+ --text-dim: #8888aa;
13
+ --text-bright: #ffffff;
14
+ --accent: #40d8c0;
15
+ --accent2: #ff6080;
16
+ --accent3: #f8d030;
17
+ --panel: #181838;
18
+ --panel-border: #3a3a6a;
19
+ --border: #2a2a5a;
20
+ --rpg-gold: #e8c020;
21
+ --rpg-blue: #4080d0;
22
+ --rpg-red: #d04040;
23
+ --rpg-green: #40b060;
24
+ --font-pixel: 'Press Start 2P', monospace;
25
+ --font-ui: 'SF Mono', 'Cascadia Code', 'Consolas', monospace;
26
+ }
27
+
28
+ body {
29
+ font-family: var(--font-ui);
30
+ background: var(--bg);
31
+ color: var(--text);
32
+ height: 100vh;
33
+ overflow: hidden;
34
+ }
35
+
36
+ #app {
37
+ display: flex;
38
+ flex-direction: column;
39
+ height: 100vh;
40
+ }
41
+
42
+ /* ── Top Bar (RPG-styled) ────────────────────────────────────────────────── */
43
+
44
+ #topbar {
45
+ display: flex;
46
+ justify-content: space-between;
47
+ align-items: center;
48
+ padding: 8px 16px;
49
+ background: var(--bg2);
50
+ border-bottom: 3px solid var(--panel-border);
51
+ z-index: 10;
52
+ /* RPG border effect */
53
+ box-shadow:
54
+ inset 0 -1px 0 #4a4a8a,
55
+ 0 2px 8px rgba(0,0,0,0.5);
56
+ }
57
+
58
+ .topbar-left {
59
+ display: flex;
60
+ align-items: center;
61
+ gap: 12px;
62
+ }
63
+
64
+ .topbar-left .logo {
65
+ font-size: 20px;
66
+ filter: drop-shadow(0 0 4px rgba(64, 216, 192, 0.5));
67
+ }
68
+
69
+ .topbar-left h1 {
70
+ font-family: var(--font-pixel);
71
+ font-size: 10px;
72
+ font-weight: 400;
73
+ letter-spacing: 1px;
74
+ color: var(--accent);
75
+ text-shadow: 0 0 8px rgba(64, 216, 192, 0.3);
76
+ }
77
+
78
+ .topbar-right {
79
+ display: flex;
80
+ align-items: center;
81
+ gap: 14px;
82
+ font-size: 11px;
83
+ color: var(--text-dim);
84
+ font-family: var(--font-pixel);
85
+ }
86
+
87
+ .status-dot {
88
+ width: 8px;
89
+ height: 8px;
90
+ display: inline-block;
91
+ /* Pixel style - square instead of circle */
92
+ border-radius: 0;
93
+ image-rendering: pixelated;
94
+ }
95
+
96
+ .status-dot.online {
97
+ background: var(--rpg-green);
98
+ box-shadow: 0 0 6px var(--rpg-green), 0 0 12px rgba(64, 176, 96, 0.3);
99
+ animation: pulse-green 2s infinite;
100
+ }
101
+
102
+ .status-dot.offline {
103
+ background: var(--rpg-red);
104
+ box-shadow: 0 0 6px var(--rpg-red);
105
+ }
106
+
107
+ @keyframes pulse-green {
108
+ 0%, 100% { opacity: 1; }
109
+ 50% { opacity: 0.6; }
110
+ }
111
+
112
+ /* ── RPG Buttons ─────────────────────────────────────────────────────────── */
113
+
114
+ .btn {
115
+ padding: 6px 14px;
116
+ border: 2px solid var(--panel-border);
117
+ background: var(--panel);
118
+ color: var(--text);
119
+ cursor: pointer;
120
+ font-family: var(--font-pixel);
121
+ font-size: 8px;
122
+ letter-spacing: 0.5px;
123
+ /* RPG box style */
124
+ box-shadow:
125
+ inset 1px 1px 0 #4a4a8a,
126
+ inset -1px -1px 0 #0a0a1a,
127
+ 2px 2px 0 #000;
128
+ transition: all 0.1s;
129
+ image-rendering: pixelated;
130
+ }
131
+
132
+ .btn:hover {
133
+ background: var(--bg3);
134
+ transform: translate(1px, 1px);
135
+ box-shadow:
136
+ inset 1px 1px 0 #4a4a8a,
137
+ inset -1px -1px 0 #0a0a1a,
138
+ 1px 1px 0 #000;
139
+ }
140
+
141
+ .btn:active {
142
+ transform: translate(2px, 2px);
143
+ box-shadow: inset 1px 1px 0 #0a0a1a;
144
+ }
145
+
146
+ .btn-primary {
147
+ background: #1a3a5a;
148
+ border-color: var(--accent);
149
+ color: var(--accent);
150
+ box-shadow:
151
+ inset 1px 1px 0 #4ac0b0,
152
+ inset -1px -1px 0 #0a2a3a,
153
+ 2px 2px 0 #000;
154
+ }
155
+
156
+ .btn-primary:hover {
157
+ background: #1a4a6a;
158
+ color: var(--text-bright);
159
+ }
160
+
161
+ .btn-sm { padding: 4px 10px; font-size: 7px; }
162
+
163
+ /* RPG action button colors */
164
+ .btn-report-bug {
165
+ border-color: var(--rpg-red);
166
+ color: var(--rpg-red);
167
+ }
168
+
169
+ .btn-new-feature {
170
+ border-color: var(--rpg-green);
171
+ color: var(--rpg-green);
172
+ }
173
+
174
+ .btn-check-status {
175
+ border-color: var(--rpg-blue);
176
+ color: var(--rpg-blue);
177
+ }
178
+
179
+ /* ── Canvas Container ────────────────────────────────────────────────────── */
180
+
181
+ #canvas-container {
182
+ flex: 1;
183
+ position: relative;
184
+ overflow: hidden;
185
+ background: #08081a;
186
+ /* Scanline effect */
187
+ background-image: repeating-linear-gradient(
188
+ 0deg,
189
+ transparent,
190
+ transparent 2px,
191
+ rgba(0, 0, 0, 0.03) 2px,
192
+ rgba(0, 0, 0, 0.03) 4px
193
+ );
194
+ }
195
+
196
+ #office-canvas {
197
+ display: block;
198
+ width: 100%;
199
+ height: 100%;
200
+ image-rendering: pixelated;
201
+ image-rendering: crisp-edges;
202
+ cursor: crosshair;
203
+ }
204
+
205
+ /* ── Character Popup (RPG Dialog Box) ────────────────────────────────────── */
206
+
207
+ .popup {
208
+ position: absolute;
209
+ background: var(--panel);
210
+ min-width: 260px;
211
+ z-index: 20;
212
+ font-size: 11px;
213
+ image-rendering: pixelated;
214
+ /* RPG dialog box border */
215
+ border: 3px solid var(--panel-border);
216
+ box-shadow:
217
+ inset 2px 2px 0 #3a3a7a,
218
+ inset -2px -2px 0 #0a0a1a,
219
+ 4px 4px 0 rgba(0,0,0,0.5);
220
+ /* Pixel corners */
221
+ border-radius: 0;
222
+ }
223
+
224
+ .popup.hidden { display: none; }
225
+
226
+ .popup-header {
227
+ display: flex;
228
+ align-items: center;
229
+ gap: 8px;
230
+ padding: 10px 12px 8px;
231
+ border-bottom: 2px solid var(--border);
232
+ font-family: var(--font-pixel);
233
+ font-size: 8px;
234
+ color: var(--accent3);
235
+ }
236
+
237
+ .popup-close {
238
+ margin-left: auto;
239
+ background: none;
240
+ border: none;
241
+ color: var(--text-dim);
242
+ cursor: pointer;
243
+ font-family: var(--font-pixel);
244
+ font-size: 8px;
245
+ padding: 2px 6px;
246
+ }
247
+
248
+ .popup-close:hover { color: var(--accent2); }
249
+
250
+ .popup-body {
251
+ padding: 8px 12px;
252
+ }
253
+
254
+ .popup-row {
255
+ display: flex;
256
+ gap: 8px;
257
+ margin-bottom: 4px;
258
+ font-family: var(--font-pixel);
259
+ font-size: 7px;
260
+ line-height: 1.8;
261
+ }
262
+
263
+ .popup-row .label {
264
+ color: var(--text-dim);
265
+ min-width: 55px;
266
+ }
267
+
268
+ .popup-row .value {
269
+ color: var(--text-bright);
270
+ }
271
+
272
+ /* Features / package info panel */
273
+ .fp-row {
274
+ display: flex;
275
+ gap: 6px;
276
+ margin-bottom: 3px;
277
+ font-family: var(--font-pixel);
278
+ font-size: 7px;
279
+ line-height: 1.8;
280
+ flex-wrap: wrap;
281
+ }
282
+
283
+ .fp-row .label {
284
+ color: var(--text-dim);
285
+ min-width: 60px;
286
+ }
287
+
288
+ .fp-current {
289
+ background: rgba(64, 180, 90, 0.12);
290
+ border-left: 2px solid #40b45a;
291
+ padding-left: 4px;
292
+ margin-bottom: 6px;
293
+ }
294
+
295
+ .popup-actions {
296
+ display: flex;
297
+ gap: 6px;
298
+ padding: 8px 12px 10px;
299
+ border-top: 2px solid var(--border);
300
+ }
301
+
302
+ /* PM interaction menu */
303
+ .pm-menu {
304
+ display: flex;
305
+ flex-direction: column;
306
+ gap: 4px;
307
+ padding: 8px 12px 10px;
308
+ border-top: 2px solid var(--border);
309
+ }
310
+
311
+ .pm-menu-item {
312
+ display: flex;
313
+ align-items: center;
314
+ gap: 8px;
315
+ padding: 6px 10px;
316
+ background: var(--bg2);
317
+ border: 2px solid var(--border);
318
+ color: var(--text);
319
+ cursor: pointer;
320
+ font-family: var(--font-pixel);
321
+ font-size: 7px;
322
+ transition: all 0.1s;
323
+ }
324
+
325
+ .pm-menu-item:hover {
326
+ background: var(--bg3);
327
+ border-color: var(--accent);
328
+ color: var(--accent);
329
+ }
330
+
331
+ .pm-menu-item .arrow {
332
+ margin-left: auto;
333
+ color: var(--text-dim);
334
+ }
335
+
336
+ /* ── Submit Modal (RPG Menu) ─────────────────────────────────────────────── */
337
+
338
+ .modal {
339
+ position: fixed;
340
+ top: 0; left: 0; right: 0; bottom: 0;
341
+ background: rgba(0,0,0,0.7);
342
+ display: flex;
343
+ justify-content: center;
344
+ align-items: center;
345
+ z-index: 100;
346
+ }
347
+
348
+ .modal.hidden { display: none; }
349
+
350
+ .modal-content {
351
+ background: var(--panel);
352
+ width: 420px;
353
+ max-width: 90vw;
354
+ /* RPG dialog box */
355
+ border: 3px solid var(--panel-border);
356
+ border-radius: 0;
357
+ box-shadow:
358
+ inset 2px 2px 0 #3a3a7a,
359
+ inset -2px -2px 0 #0a0a1a,
360
+ 6px 6px 0 rgba(0,0,0,0.6);
361
+ }
362
+
363
+ .modal-header {
364
+ display: flex;
365
+ justify-content: space-between;
366
+ align-items: center;
367
+ padding: 14px 18px 10px;
368
+ border-bottom: 2px solid var(--border);
369
+ }
370
+
371
+ .modal-header h2 {
372
+ font-family: var(--font-pixel);
373
+ font-size: 9px;
374
+ font-weight: 400;
375
+ color: var(--accent3);
376
+ }
377
+
378
+ .modal-body {
379
+ padding: 14px 18px;
380
+ display: flex;
381
+ flex-direction: column;
382
+ gap: 14px;
383
+ }
384
+
385
+ .modal-body label {
386
+ display: flex;
387
+ flex-direction: column;
388
+ gap: 6px;
389
+ font-family: var(--font-pixel);
390
+ font-size: 7px;
391
+ color: var(--text-dim);
392
+ }
393
+
394
+ .modal-body select,
395
+ .modal-body textarea {
396
+ padding: 8px 10px;
397
+ background: var(--bg);
398
+ border: 2px solid var(--border);
399
+ border-radius: 0;
400
+ color: var(--text);
401
+ font-family: var(--font-ui);
402
+ font-size: 12px;
403
+ resize: vertical;
404
+ image-rendering: pixelated;
405
+ }
406
+
407
+ .modal-body select:focus,
408
+ .modal-body textarea:focus {
409
+ outline: none;
410
+ border-color: var(--accent);
411
+ box-shadow: 0 0 8px rgba(64, 216, 192, 0.2);
412
+ }
413
+
414
+ .modal-footer {
415
+ padding: 10px 18px 14px;
416
+ display: flex;
417
+ justify-content: flex-end;
418
+ }
419
+
420
+ /* ── Activity Feed (RPG Log) ─────────────────────────────────────────────── */
421
+
422
+ #activity-feed {
423
+ height: 130px;
424
+ background: var(--bg2);
425
+ border-top: 3px solid var(--panel-border);
426
+ overflow: hidden;
427
+ box-shadow: inset 0 2px 8px rgba(0,0,0,0.3);
428
+ }
429
+
430
+ .feed-header {
431
+ padding: 6px 16px;
432
+ font-family: var(--font-pixel);
433
+ font-size: 7px;
434
+ color: var(--accent3);
435
+ border-bottom: 2px solid var(--border);
436
+ letter-spacing: 1px;
437
+ }
438
+
439
+ #feed-entries {
440
+ padding: 4px 16px;
441
+ font-size: 11px;
442
+ font-family: var(--font-ui);
443
+ overflow-y: auto;
444
+ height: calc(100% - 28px);
445
+ }
446
+
447
+ /* Custom scrollbar */
448
+ #feed-entries::-webkit-scrollbar {
449
+ width: 6px;
450
+ }
451
+
452
+ #feed-entries::-webkit-scrollbar-track {
453
+ background: var(--bg);
454
+ }
455
+
456
+ #feed-entries::-webkit-scrollbar-thumb {
457
+ background: var(--border);
458
+ }
459
+
460
+ .feed-entry {
461
+ padding: 2px 0;
462
+ color: var(--text-dim);
463
+ white-space: nowrap;
464
+ overflow: hidden;
465
+ text-overflow: ellipsis;
466
+ font-size: 11px;
467
+ }
468
+
469
+ .feed-entry .time { color: #6a6a8a; }
470
+ .feed-entry .project { color: var(--accent); font-weight: 600; }
471
+ .feed-entry .msg { color: var(--text); }
472
+
473
+ /* ── Animations ──────────────────────────────────────────────────────────── */
474
+
475
+ @keyframes rpg-appear {
476
+ 0% { transform: scale(0.8); opacity: 0; }
477
+ 50% { transform: scale(1.02); }
478
+ 100% { transform: scale(1); opacity: 1; }
479
+ }
480
+
481
+ .popup:not(.hidden),
482
+ .modal:not(.hidden) .modal-content {
483
+ animation: rpg-appear 0.15s ease-out;
484
+ }
485
+
486
+ /* Blinking cursor for text inputs */
487
+ .modal-body textarea::placeholder {
488
+ color: var(--text-dim);
489
+ font-style: italic;
490
+ }
491
+
492
+ /* ── Pipeline action buttons ─────────────────────────────────────────────── */
493
+
494
+ #popup-pipeline-menu {
495
+ flex-direction: column;
496
+ gap: 4px;
497
+ padding: 6px 12px 10px;
498
+ }
499
+
500
+ .pipeline-label {
501
+ font-family: var(--font-pixel);
502
+ font-size: 7px;
503
+ color: var(--accent2);
504
+ margin-bottom: 2px;
505
+ }
506
+
507
+ .pipeline-btns {
508
+ display: flex;
509
+ flex-wrap: wrap;
510
+ gap: 4px;
511
+ }
512
+
513
+ .btn-action {
514
+ font-size: 7px !important;
515
+ padding: 3px 7px !important;
516
+ flex: 0 0 auto;
517
+ transition: all 0.15s;
518
+ }
519
+
520
+ .btn-action:hover {
521
+ background: var(--accent);
522
+ color: var(--bg);
523
+ border-color: var(--accent);
524
+ }
525
+
526
+ .btn-action.btn-dim { opacity: 0.5; }
527
+ .btn-action.btn-dim:hover { opacity: 1; }
528
+ .btn-action.btn-danger { background: #8b2020; border-color: #c04040; color: #ffcccc; }
529
+ .btn-action.btn-danger:hover { background: #a03030; border-color: #e05050; }
530
+
531
+ .btn-action.pipeline-hidden { display: none; }
532
+
533
+ /* ── Command Bar (Slash Commands) ────────────────────────────────────────── */
534
+
535
+ .command-bar {
536
+ position: fixed;
537
+ bottom: 140px;
538
+ left: 50%;
539
+ transform: translateX(-50%);
540
+ width: 420px;
541
+ max-width: 90vw;
542
+ z-index: 200;
543
+ animation: rpg-appear 0.12s ease-out;
544
+ }
545
+
546
+ .command-bar input {
547
+ width: 100%;
548
+ padding: 10px 14px;
549
+ background: var(--panel);
550
+ border: 3px solid var(--accent);
551
+ border-radius: 0;
552
+ color: var(--text-bright);
553
+ font-family: var(--font-pixel);
554
+ font-size: 9px;
555
+ letter-spacing: 0.5px;
556
+ image-rendering: pixelated;
557
+ box-shadow:
558
+ inset 2px 2px 0 #3a3a7a,
559
+ inset -2px -2px 0 #0a0a1a,
560
+ 0 0 16px rgba(64, 216, 192, 0.25),
561
+ 4px 4px 0 rgba(0,0,0,0.5);
562
+ }
563
+
564
+ .command-bar input:focus {
565
+ outline: none;
566
+ border-color: var(--accent);
567
+ box-shadow:
568
+ inset 2px 2px 0 #3a3a7a,
569
+ inset -2px -2px 0 #0a0a1a,
570
+ 0 0 20px rgba(64, 216, 192, 0.35),
571
+ 4px 4px 0 rgba(0,0,0,0.5);
572
+ }
573
+
574
+ .command-bar input::placeholder {
575
+ color: var(--text-dim);
576
+ font-family: var(--font-pixel);
577
+ font-size: 8px;
578
+ }
579
+
580
+ .command-dropdown {
581
+ display: none;
582
+ position: absolute;
583
+ bottom: 100%;
584
+ left: 0;
585
+ right: 0;
586
+ margin-bottom: 4px;
587
+ background: var(--panel);
588
+ border: 3px solid var(--panel-border);
589
+ border-radius: 0;
590
+ max-height: 300px;
591
+ overflow-y: auto;
592
+ box-shadow:
593
+ inset 2px 2px 0 #3a3a7a,
594
+ inset -2px -2px 0 #0a0a1a,
595
+ 4px 4px 0 rgba(0,0,0,0.5);
596
+ }
597
+
598
+ .command-dropdown.visible {
599
+ display: block;
600
+ animation: rpg-appear 0.1s ease-out;
601
+ }
602
+
603
+ .command-dropdown-item {
604
+ display: flex;
605
+ align-items: center;
606
+ gap: 10px;
607
+ padding: 8px 12px;
608
+ cursor: pointer;
609
+ border-bottom: 1px solid var(--border);
610
+ transition: all 0.08s;
611
+ }
612
+
613
+ .command-dropdown-item:last-child {
614
+ border-bottom: none;
615
+ }
616
+
617
+ .command-dropdown-item:hover,
618
+ .command-dropdown-item.active {
619
+ background: var(--bg3);
620
+ border-left: 3px solid var(--accent);
621
+ padding-left: 9px;
622
+ }
623
+
624
+ .command-dropdown-item .cmd-icon {
625
+ font-size: 14px;
626
+ width: 22px;
627
+ text-align: center;
628
+ flex-shrink: 0;
629
+ }
630
+
631
+ .command-dropdown-item .cmd-info {
632
+ display: flex;
633
+ flex-direction: column;
634
+ gap: 2px;
635
+ min-width: 0;
636
+ }
637
+
638
+ .command-dropdown-item .cmd-name {
639
+ font-family: var(--font-pixel);
640
+ font-size: 8px;
641
+ color: var(--accent);
642
+ }
643
+
644
+ .command-dropdown-item .cmd-desc {
645
+ font-family: var(--font-ui);
646
+ font-size: 10px;
647
+ color: var(--text-dim);
648
+ white-space: nowrap;
649
+ overflow: hidden;
650
+ text-overflow: ellipsis;
651
+ }
652
+
653
+ .command-dropdown-hint {
654
+ padding: 6px 12px;
655
+ font-family: var(--font-pixel);
656
+ font-size: 7px;
657
+ color: var(--text-dim);
658
+ border-top: 1px solid var(--border);
659
+ text-align: center;
660
+ letter-spacing: 0.5px;
661
+ }
662
+
663
+ /* Scrollbar for command dropdown */
664
+ .command-dropdown::-webkit-scrollbar { width: 6px; }
665
+ .command-dropdown::-webkit-scrollbar-track { background: var(--bg); }
666
+ .command-dropdown::-webkit-scrollbar-thumb { background: var(--border); }
667
+
668
+ /* ── Responsive ──────────────────────────────────────────────────────────── */
669
+
670
+ @media (max-width: 768px) {
671
+ .topbar-left h1 { font-size: 8px; }
672
+ .topbar-right { gap: 8px; }
673
+ .topbar-right span:not(.status-dot) { display: none; }
674
+ .popup { min-width: 200px; }
675
+ .modal-content { width: 95vw; }
676
+ #activity-feed { height: 80px; }
677
+ .command-bar { width: 95vw; bottom: 90px; }
678
+ }