tryassay 0.21.2 → 0.22.1

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 (132) hide show
  1. package/demo/.claude/.truth_last_prompt +1 -0
  2. package/demo/.claude/truth_status +1 -0
  3. package/demo/css/style.css +840 -0
  4. package/demo/index.html +78 -0
  5. package/demo/js/chat.js +535 -0
  6. package/demo/js/code-panel.js +206 -0
  7. package/demo/js/preview.js +456 -0
  8. package/demo/js/sse-client.js +600 -0
  9. package/demo/js/state.js +172 -0
  10. package/demo/js/timeline.js +80 -0
  11. package/dist/api/server.d.ts +3 -0
  12. package/dist/api/server.js +127 -20
  13. package/dist/api/server.js.map +1 -1
  14. package/dist/cli.js +11 -0
  15. package/dist/cli.js.map +1 -1
  16. package/dist/commands/assess.d.ts +2 -0
  17. package/dist/commands/assess.js +132 -164
  18. package/dist/commands/assess.js.map +1 -1
  19. package/dist/commands/demo.d.ts +5 -0
  20. package/dist/commands/demo.js +357 -0
  21. package/dist/commands/demo.js.map +1 -0
  22. package/dist/lib/__tests__/arithmetic-quick-test.d.ts +6 -0
  23. package/dist/lib/__tests__/arithmetic-quick-test.js +197 -0
  24. package/dist/lib/__tests__/arithmetic-quick-test.js.map +1 -0
  25. package/dist/lib/__tests__/arithmetic-real-llm-test.d.ts +13 -0
  26. package/dist/lib/__tests__/arithmetic-real-llm-test.js +284 -0
  27. package/dist/lib/__tests__/arithmetic-real-llm-test.js.map +1 -0
  28. package/dist/lib/__tests__/arithmetic-value-demo.d.ts +10 -0
  29. package/dist/lib/__tests__/arithmetic-value-demo.js +193 -0
  30. package/dist/lib/__tests__/arithmetic-value-demo.js.map +1 -0
  31. package/dist/lib/__tests__/flow-to-claims.test.d.ts +1 -0
  32. package/dist/lib/__tests__/flow-to-claims.test.js +91 -0
  33. package/dist/lib/__tests__/flow-to-claims.test.js.map +1 -0
  34. package/dist/lib/__tests__/formal-verifier-api-misuse.test.d.ts +9 -0
  35. package/dist/lib/__tests__/formal-verifier-api-misuse.test.js +391 -0
  36. package/dist/lib/__tests__/formal-verifier-api-misuse.test.js.map +1 -0
  37. package/dist/lib/__tests__/formal-verifier-arithmetic.test.d.ts +7 -0
  38. package/dist/lib/__tests__/formal-verifier-arithmetic.test.js +318 -0
  39. package/dist/lib/__tests__/formal-verifier-arithmetic.test.js.map +1 -0
  40. package/dist/lib/__tests__/intent-extractor.test.d.ts +1 -0
  41. package/dist/lib/__tests__/intent-extractor.test.js +97 -0
  42. package/dist/lib/__tests__/intent-extractor.test.js.map +1 -0
  43. package/dist/lib/__tests__/intent-reviewer.test.d.ts +1 -0
  44. package/dist/lib/__tests__/intent-reviewer.test.js +55 -0
  45. package/dist/lib/__tests__/intent-reviewer.test.js.map +1 -0
  46. package/dist/lib/__tests__/mr-gsm8k-benchmark.d.ts +11 -0
  47. package/dist/lib/__tests__/mr-gsm8k-benchmark.js +224 -0
  48. package/dist/lib/__tests__/mr-gsm8k-benchmark.js.map +1 -0
  49. package/dist/lib/anthropic.js +25 -33
  50. package/dist/lib/anthropic.js.map +1 -1
  51. package/dist/lib/assessment-reporter.js +9 -13
  52. package/dist/lib/assessment-reporter.js.map +1 -1
  53. package/dist/lib/claim-extractor.js +10 -19
  54. package/dist/lib/claim-extractor.js.map +1 -1
  55. package/dist/lib/code-verifier.js +16 -36
  56. package/dist/lib/code-verifier.js.map +1 -1
  57. package/dist/lib/constraint-engine.js +10 -19
  58. package/dist/lib/constraint-engine.js.map +1 -1
  59. package/dist/lib/formal-verifier.d.ts +1 -1
  60. package/dist/lib/formal-verifier.js +454 -0
  61. package/dist/lib/formal-verifier.js.map +1 -1
  62. package/dist/lib/guided-generator.js +19 -37
  63. package/dist/lib/guided-generator.js.map +1 -1
  64. package/dist/lib/intent-extractor.d.ts +47 -0
  65. package/dist/lib/intent-extractor.js +427 -0
  66. package/dist/lib/intent-extractor.js.map +1 -0
  67. package/dist/lib/intent-reviewer.d.ts +14 -0
  68. package/dist/lib/intent-reviewer.js +148 -0
  69. package/dist/lib/intent-reviewer.js.map +1 -0
  70. package/dist/lib/intent-types.d.ts +89 -0
  71. package/dist/lib/intent-types.js +5 -0
  72. package/dist/lib/intent-types.js.map +1 -0
  73. package/dist/lib/inventory-extractor.js +9 -22
  74. package/dist/lib/inventory-extractor.js.map +1 -1
  75. package/dist/lib/llm-provider.d.ts +23 -0
  76. package/dist/lib/llm-provider.js +130 -0
  77. package/dist/lib/llm-provider.js.map +1 -0
  78. package/dist/lib/remediator.js +20 -28
  79. package/dist/lib/remediator.js.map +1 -1
  80. package/dist/lib/requirements-generator.js +14 -19
  81. package/dist/lib/requirements-generator.js.map +1 -1
  82. package/dist/lib/spec-synthesizer.js +10 -19
  83. package/dist/lib/spec-synthesizer.js.map +1 -1
  84. package/dist/runtime/agents/planner-agent.d.ts +5 -2
  85. package/dist/runtime/agents/planner-agent.js +232 -1
  86. package/dist/runtime/agents/planner-agent.js.map +1 -1
  87. package/dist/runtime/app-create-orchestrator.d.ts +9 -1
  88. package/dist/runtime/app-create-orchestrator.js +265 -87
  89. package/dist/runtime/app-create-orchestrator.js.map +1 -1
  90. package/dist/runtime/check-catalog.js +5 -3
  91. package/dist/runtime/check-catalog.js.map +1 -1
  92. package/dist/runtime/check-definitions.d.ts +10 -0
  93. package/dist/runtime/check-definitions.js +52 -2
  94. package/dist/runtime/check-definitions.js.map +1 -1
  95. package/dist/runtime/composition-verifier.js +8 -12
  96. package/dist/runtime/composition-verifier.js.map +1 -1
  97. package/dist/runtime/gap-detector.js +8 -10
  98. package/dist/runtime/gap-detector.js.map +1 -1
  99. package/dist/runtime/input-validator.d.ts +7 -0
  100. package/dist/runtime/input-validator.js +162 -0
  101. package/dist/runtime/input-validator.js.map +1 -0
  102. package/dist/runtime/model-router.d.ts +10 -0
  103. package/dist/runtime/model-router.js +42 -0
  104. package/dist/runtime/model-router.js.map +1 -0
  105. package/dist/runtime/pattern-extractor.js +8 -10
  106. package/dist/runtime/pattern-extractor.js.map +1 -1
  107. package/dist/runtime/planner.js +11 -16
  108. package/dist/runtime/planner.js.map +1 -1
  109. package/dist/runtime/prompt-guard.d.ts +2 -0
  110. package/dist/runtime/prompt-guard.js +180 -0
  111. package/dist/runtime/prompt-guard.js.map +1 -0
  112. package/dist/runtime/prompt-safety-analyzer.js +8 -13
  113. package/dist/runtime/prompt-safety-analyzer.js.map +1 -1
  114. package/dist/runtime/reasoner.js +19 -33
  115. package/dist/runtime/reasoner.js.map +1 -1
  116. package/dist/runtime/rule-meta-verifier.js +9 -11
  117. package/dist/runtime/rule-meta-verifier.js.map +1 -1
  118. package/dist/runtime/safe-executor.d.ts +23 -0
  119. package/dist/runtime/safe-executor.js +151 -0
  120. package/dist/runtime/safe-executor.js.map +1 -0
  121. package/dist/runtime/specialized-agent.js +10 -14
  122. package/dist/runtime/specialized-agent.js.map +1 -1
  123. package/dist/runtime/strategy-library.js +8 -10
  124. package/dist/runtime/strategy-library.js.map +1 -1
  125. package/dist/runtime/supabase-experience-store.js.map +1 -1
  126. package/dist/runtime/supabase-provisioner.d.ts +35 -0
  127. package/dist/runtime/supabase-provisioner.js +192 -0
  128. package/dist/runtime/supabase-provisioner.js.map +1 -0
  129. package/dist/runtime/types.d.ts +116 -0
  130. package/dist/sdk/forward-verify.js +16 -33
  131. package/dist/sdk/forward-verify.js.map +1 -1
  132. package/package.json +2 -1
@@ -0,0 +1,840 @@
1
+ /* style.css — Split-screen layout: chat left, preview right */
2
+
3
+ @import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&family=Inter:wght@300;400;500;600;700&display=swap');
4
+
5
+ * {
6
+ margin: 0;
7
+ padding: 0;
8
+ box-sizing: border-box;
9
+ }
10
+
11
+ :root {
12
+ --bg: #0a0a0a;
13
+ --bg-panel: rgba(15, 15, 25, 0.85);
14
+ --bg-glass: rgba(20, 20, 40, 0.6);
15
+ --border: rgba(255, 255, 255, 0.06);
16
+ --border-glow: rgba(255, 255, 255, 0.12);
17
+ --text: #e0e0e0;
18
+ --text-dim: #6b7280;
19
+ --text-bright: #ffffff;
20
+ --accent-blue: #1e3a5f;
21
+ --accent-cyan: #06b6d4;
22
+ --accent-amber: #f59e0b;
23
+ --accent-green: #22c55e;
24
+ --accent-red: #ef4444;
25
+ --accent-white: #ffffff;
26
+ --font-mono: 'JetBrains Mono', monospace;
27
+ --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
28
+ }
29
+
30
+ html, body {
31
+ width: 100%;
32
+ height: 100%;
33
+ overflow: hidden;
34
+ background: var(--bg);
35
+ color: var(--text);
36
+ font-family: var(--font-sans);
37
+ }
38
+
39
+ /* === Layout Grid === */
40
+ #app {
41
+ display: grid;
42
+ grid-template-columns: 40% 60%;
43
+ grid-template-rows: 48px 1fr 36px;
44
+ width: 100%;
45
+ height: 100%;
46
+ }
47
+
48
+ /* === Header === */
49
+ #header {
50
+ grid-column: 1 / -1;
51
+ display: flex;
52
+ align-items: center;
53
+ justify-content: space-between;
54
+ padding: 0 20px;
55
+ background: var(--bg-panel);
56
+ border-bottom: 1px solid var(--border);
57
+ z-index: 10;
58
+ }
59
+
60
+ #header-left {
61
+ display: flex;
62
+ align-items: center;
63
+ gap: 12px;
64
+ }
65
+
66
+ .header-title {
67
+ font-family: var(--font-mono);
68
+ font-size: 16px;
69
+ font-weight: 700;
70
+ color: var(--accent-cyan);
71
+ letter-spacing: 1px;
72
+ }
73
+
74
+ #header-right {
75
+ display: flex;
76
+ align-items: center;
77
+ gap: 16px;
78
+ }
79
+
80
+ #file-badge {
81
+ font-family: var(--font-mono);
82
+ font-size: 12px;
83
+ color: var(--text-dim);
84
+ background: rgba(6, 182, 212, 0.1);
85
+ padding: 4px 10px;
86
+ border-radius: 6px;
87
+ border: 1px solid rgba(6, 182, 212, 0.15);
88
+ transition: opacity 0.3s;
89
+ }
90
+
91
+ #file-badge.hidden {
92
+ opacity: 0;
93
+ pointer-events: none;
94
+ }
95
+
96
+ #file-badge span:last-child {
97
+ color: var(--accent-cyan);
98
+ font-weight: 600;
99
+ }
100
+
101
+ .global-clock {
102
+ display: flex;
103
+ align-items: center;
104
+ gap: 4px;
105
+ transition: opacity 0.4s ease;
106
+ }
107
+
108
+ .global-clock.hidden {
109
+ opacity: 0;
110
+ pointer-events: none;
111
+ }
112
+
113
+ .global-clock .clock-value {
114
+ font-family: var(--font-mono);
115
+ font-size: 16px;
116
+ font-weight: 700;
117
+ color: var(--accent-cyan);
118
+ letter-spacing: 1px;
119
+ }
120
+
121
+ /* === Chat Panel (Left 40%) === */
122
+ #chat-panel {
123
+ grid-column: 1;
124
+ grid-row: 2;
125
+ display: flex;
126
+ flex-direction: column;
127
+ background: var(--bg-panel);
128
+ border-right: 1px solid var(--border);
129
+ overflow: hidden;
130
+ }
131
+
132
+ /* Chat messages area */
133
+ #chat-messages {
134
+ flex: 1;
135
+ overflow-y: auto;
136
+ padding: 16px;
137
+ display: flex;
138
+ flex-direction: column;
139
+ gap: 12px;
140
+ }
141
+
142
+ /* Chat input area (shown during conversation) */
143
+ #chat-input-area {
144
+ display: flex;
145
+ gap: 8px;
146
+ padding: 12px 16px;
147
+ border-top: 1px solid var(--border);
148
+ background: rgba(5, 5, 10, 0.8);
149
+ flex-shrink: 0;
150
+ }
151
+
152
+ #chat-input-area.hidden {
153
+ display: none;
154
+ }
155
+
156
+ #chat-input-area input {
157
+ flex: 1;
158
+ background: rgba(20, 20, 30, 0.8);
159
+ border: 1px solid rgba(100, 200, 255, 0.2);
160
+ border-radius: 8px;
161
+ padding: 10px 14px;
162
+ color: rgba(200, 220, 255, 0.9);
163
+ font-size: 14px;
164
+ outline: none;
165
+ }
166
+
167
+ #chat-input-area input:focus {
168
+ border-color: rgba(100, 200, 255, 0.4);
169
+ }
170
+
171
+ #chat-input-area button {
172
+ background: rgba(100, 200, 255, 0.15);
173
+ border: 1px solid rgba(100, 200, 255, 0.3);
174
+ border-radius: 8px;
175
+ padding: 10px 18px;
176
+ color: rgba(100, 200, 255, 0.9);
177
+ cursor: pointer;
178
+ font-size: 14px;
179
+ transition: all 0.2s;
180
+ }
181
+
182
+ #chat-input-area button:hover {
183
+ background: rgba(100, 200, 255, 0.25);
184
+ }
185
+
186
+ /* Attach button */
187
+ #attach-btn {
188
+ background: none;
189
+ border: 1px solid rgba(100, 200, 255, 0.2);
190
+ border-radius: 8px;
191
+ padding: 8px 10px;
192
+ color: rgba(100, 200, 255, 0.7);
193
+ cursor: pointer;
194
+ font-size: 16px;
195
+ line-height: 1;
196
+ transition: all 0.2s;
197
+ flex-shrink: 0;
198
+ }
199
+
200
+ #attach-btn:hover {
201
+ background: rgba(100, 200, 255, 0.1);
202
+ border-color: rgba(100, 200, 255, 0.4);
203
+ color: rgba(100, 200, 255, 0.9);
204
+ }
205
+
206
+ /* Attachment preview */
207
+ #attachment-preview {
208
+ display: flex;
209
+ gap: 6px;
210
+ padding: 6px 16px;
211
+ flex-wrap: wrap;
212
+ border-top: 1px solid var(--border);
213
+ background: rgba(5, 5, 10, 0.6);
214
+ flex-shrink: 0;
215
+ }
216
+
217
+ #attachment-preview.hidden {
218
+ display: none;
219
+ }
220
+
221
+ .attachment-chip {
222
+ display: inline-flex;
223
+ align-items: center;
224
+ gap: 6px;
225
+ padding: 4px 10px;
226
+ background: rgba(100, 200, 255, 0.1);
227
+ border: 1px solid rgba(100, 200, 255, 0.2);
228
+ border-radius: 6px;
229
+ font-family: var(--font-mono);
230
+ font-size: 12px;
231
+ color: rgba(200, 220, 255, 0.8);
232
+ }
233
+
234
+ .attachment-chip-remove {
235
+ background: none;
236
+ border: none;
237
+ color: rgba(200, 220, 255, 0.5);
238
+ cursor: pointer;
239
+ font-size: 14px;
240
+ padding: 0 2px;
241
+ line-height: 1;
242
+ }
243
+
244
+ .attachment-chip-remove:hover {
245
+ color: var(--accent-red);
246
+ }
247
+
248
+ /* Chat messages */
249
+ .chat-msg {
250
+ max-width: 90%;
251
+ animation: chatFadeIn 0.3s ease;
252
+ }
253
+
254
+ .chat-msg-architect {
255
+ align-self: flex-start;
256
+ }
257
+
258
+ .chat-msg-user {
259
+ align-self: flex-end;
260
+ }
261
+
262
+ .chat-msg-text {
263
+ padding: 10px 14px;
264
+ border-radius: 12px;
265
+ font-size: 14px;
266
+ line-height: 1.5;
267
+ }
268
+
269
+ .chat-msg-architect .chat-msg-text {
270
+ background: rgba(100, 200, 255, 0.1);
271
+ color: rgba(200, 220, 255, 0.9);
272
+ border-bottom-left-radius: 4px;
273
+ }
274
+
275
+ .chat-msg-user .chat-msg-text {
276
+ background: rgba(100, 200, 255, 0.2);
277
+ color: rgba(220, 240, 255, 0.95);
278
+ border-bottom-right-radius: 4px;
279
+ }
280
+
281
+ @keyframes chatFadeIn {
282
+ from { opacity: 0; transform: translateY(8px); }
283
+ to { opacity: 1; transform: translateY(0); }
284
+ }
285
+
286
+ /* Chat cards (inline decision cards) */
287
+ .chat-cards {
288
+ margin-top: 8px;
289
+ display: flex;
290
+ flex-direction: column;
291
+ gap: 8px;
292
+ }
293
+
294
+ .chat-card {
295
+ background: rgba(20, 20, 35, 0.8);
296
+ border: 1px solid rgba(100, 200, 255, 0.15);
297
+ border-radius: 10px;
298
+ padding: 12px;
299
+ }
300
+
301
+ .chat-card-header {
302
+ font-size: 12px;
303
+ text-transform: uppercase;
304
+ letter-spacing: 0.05em;
305
+ color: rgba(100, 200, 255, 0.6);
306
+ margin-bottom: 4px;
307
+ }
308
+
309
+ .chat-card-question {
310
+ font-size: 13px;
311
+ color: rgba(200, 220, 255, 0.8);
312
+ margin-bottom: 8px;
313
+ }
314
+
315
+ .chat-card-options {
316
+ display: flex;
317
+ flex-direction: column;
318
+ gap: 4px;
319
+ }
320
+
321
+ .chat-card-option {
322
+ padding: 8px 12px;
323
+ border: 1px solid rgba(100, 200, 255, 0.1);
324
+ border-radius: 6px;
325
+ cursor: pointer;
326
+ transition: all 0.2s;
327
+ }
328
+
329
+ .chat-card-option:hover {
330
+ background: rgba(100, 200, 255, 0.08);
331
+ border-color: rgba(100, 200, 255, 0.25);
332
+ }
333
+
334
+ .chat-card-option.selected {
335
+ background: rgba(100, 200, 255, 0.15);
336
+ border-color: rgba(100, 200, 255, 0.4);
337
+ }
338
+
339
+ .chat-card-option-label {
340
+ font-size: 13px;
341
+ color: rgba(200, 220, 255, 0.9);
342
+ font-weight: 500;
343
+ }
344
+
345
+ .chat-card-option-desc {
346
+ font-size: 11px;
347
+ color: rgba(200, 220, 255, 0.5);
348
+ margin-top: 2px;
349
+ }
350
+
351
+ /* Ready state */
352
+ .chat-ready-summary {
353
+ margin-top: 8px;
354
+ padding: 8px 12px;
355
+ background: rgba(80, 200, 120, 0.1);
356
+ border: 1px solid rgba(80, 200, 120, 0.2);
357
+ border-radius: 8px;
358
+ font-size: 13px;
359
+ color: rgba(80, 200, 120, 0.9);
360
+ }
361
+
362
+ .chat-build-btn {
363
+ margin-top: 10px;
364
+ width: 100%;
365
+ padding: 12px;
366
+ background: rgba(80, 200, 120, 0.2);
367
+ border: 1px solid rgba(80, 200, 120, 0.4);
368
+ border-radius: 8px;
369
+ color: rgba(80, 200, 120, 0.95);
370
+ font-size: 15px;
371
+ font-weight: 600;
372
+ cursor: pointer;
373
+ transition: all 0.2s;
374
+ }
375
+
376
+ .chat-build-btn:hover {
377
+ background: rgba(80, 200, 120, 0.3);
378
+ }
379
+
380
+ /* === Preview Panel (Right 60%) === */
381
+ #preview-panel {
382
+ grid-column: 2;
383
+ grid-row: 2;
384
+ position: relative;
385
+ background: #111;
386
+ overflow: hidden;
387
+ }
388
+
389
+ #preview-iframe {
390
+ width: 100%;
391
+ height: 100%;
392
+ border: none;
393
+ background: #000;
394
+ }
395
+
396
+ /* Preview overlay — shown over iframe during non-building states */
397
+ #preview-overlay {
398
+ position: absolute;
399
+ top: 0;
400
+ left: 0;
401
+ width: 100%;
402
+ height: 100%;
403
+ display: flex;
404
+ flex-direction: column;
405
+ align-items: center;
406
+ justify-content: center;
407
+ background: rgba(10, 10, 15, 0.95);
408
+ z-index: 5;
409
+ transition: opacity 0.5s ease;
410
+ }
411
+
412
+ /* Hide overlay when building or done — let iframe show through */
413
+ #preview-panel.live #preview-overlay {
414
+ opacity: 0;
415
+ pointer-events: none;
416
+ }
417
+
418
+ #preview-status {
419
+ font-family: var(--font-mono);
420
+ font-size: 14px;
421
+ color: var(--text-dim);
422
+ text-align: center;
423
+ max-width: 300px;
424
+ line-height: 1.6;
425
+ }
426
+
427
+ /* State-specific status styling */
428
+ #preview-status[data-state="cold"] {
429
+ color: var(--text-dim);
430
+ }
431
+
432
+ #preview-status[data-state="cold"]::before {
433
+ content: '';
434
+ display: block;
435
+ width: 24px;
436
+ height: 24px;
437
+ margin: 0 auto 12px;
438
+ border: 2px solid var(--text-dim);
439
+ border-top-color: var(--accent-cyan);
440
+ border-radius: 50%;
441
+ animation: spin 1s linear infinite;
442
+ }
443
+
444
+ #preview-status[data-state="warm"] {
445
+ color: var(--accent-cyan);
446
+ }
447
+
448
+ #preview-status[data-state="building"] {
449
+ color: var(--accent-amber);
450
+ }
451
+
452
+ #preview-status[data-state="verifying"] {
453
+ color: var(--accent-cyan);
454
+ }
455
+
456
+ #preview-status[data-state="done"] {
457
+ color: var(--accent-green);
458
+ }
459
+
460
+ @keyframes spin {
461
+ to { transform: rotate(360deg); }
462
+ }
463
+
464
+ /* Download button (shown in DONE state) */
465
+ .preview-download-btn {
466
+ position: absolute;
467
+ bottom: 16px;
468
+ right: 16px;
469
+ background: rgba(34, 197, 94, 0.2);
470
+ border: 1px solid rgba(34, 197, 94, 0.4);
471
+ border-radius: 8px;
472
+ padding: 10px 20px;
473
+ color: var(--accent-green);
474
+ font-family: var(--font-sans);
475
+ font-size: 13px;
476
+ font-weight: 600;
477
+ cursor: pointer;
478
+ z-index: 10;
479
+ transition: all 0.2s;
480
+ }
481
+
482
+ .preview-download-btn:hover {
483
+ background: rgba(34, 197, 94, 0.3);
484
+ }
485
+
486
+ /* === Status Bar (Bottom) === */
487
+ #status-bar {
488
+ grid-column: 1 / -1;
489
+ grid-row: 3;
490
+ display: flex;
491
+ align-items: center;
492
+ gap: 24px;
493
+ padding: 0 20px;
494
+ background: rgba(10, 10, 15, 0.95);
495
+ border-top: 1px solid var(--border);
496
+ font-family: var(--font-mono);
497
+ font-size: 12px;
498
+ color: var(--text-dim);
499
+ }
500
+
501
+ #status-bar span {
502
+ white-space: nowrap;
503
+ }
504
+
505
+ #status-phase {
506
+ color: var(--accent-cyan);
507
+ }
508
+
509
+ /* === Activity Feed (build progress in chat panel) === */
510
+ .activity-separator {
511
+ display: flex;
512
+ align-items: center;
513
+ gap: 8px;
514
+ margin: 12px 0 8px;
515
+ font-family: var(--font-mono);
516
+ font-size: 11px;
517
+ color: var(--text-dim);
518
+ text-transform: uppercase;
519
+ letter-spacing: 0.05em;
520
+ }
521
+
522
+ .activity-separator::before,
523
+ .activity-separator::after {
524
+ content: '';
525
+ flex: 1;
526
+ height: 1px;
527
+ background: var(--border);
528
+ }
529
+
530
+ .activity-item {
531
+ display: flex;
532
+ align-items: baseline;
533
+ gap: 8px;
534
+ padding: 3px 8px;
535
+ font-family: var(--font-mono);
536
+ font-size: 12px;
537
+ line-height: 1.6;
538
+ color: var(--text-dim);
539
+ animation: activityFadeIn 0.2s ease;
540
+ }
541
+
542
+ @keyframes activityFadeIn {
543
+ from { opacity: 0; transform: translateX(-4px); }
544
+ to { opacity: 1; transform: translateX(0); }
545
+ }
546
+
547
+ .activity-icon {
548
+ flex-shrink: 0;
549
+ width: 14px;
550
+ text-align: center;
551
+ }
552
+
553
+ .activity-text {
554
+ word-break: break-all;
555
+ }
556
+
557
+ /* Activity item types */
558
+ .activity-phase {
559
+ color: var(--accent-cyan);
560
+ }
561
+
562
+ .activity-file {
563
+ color: var(--accent-green);
564
+ }
565
+
566
+ .activity-file .activity-icon {
567
+ color: #4ade80;
568
+ }
569
+
570
+ .activity-success {
571
+ color: var(--accent-green);
572
+ }
573
+
574
+ .activity-warn {
575
+ color: var(--accent-amber);
576
+ }
577
+
578
+ .activity-error {
579
+ color: var(--accent-red);
580
+ }
581
+
582
+ /* === Completion Overlay === */
583
+ #completion-overlay {
584
+ position: fixed;
585
+ top: 0;
586
+ left: 0;
587
+ width: 100%;
588
+ height: 100%;
589
+ display: flex;
590
+ align-items: center;
591
+ justify-content: center;
592
+ z-index: 100;
593
+ pointer-events: none;
594
+ opacity: 0;
595
+ transition: opacity 0.5s ease;
596
+ background: rgba(0, 0, 0, 0.7);
597
+ }
598
+
599
+ #completion-overlay.visible {
600
+ opacity: 1;
601
+ pointer-events: auto;
602
+ }
603
+
604
+ .completion-card {
605
+ position: relative;
606
+ background: rgba(10, 10, 30, 0.98);
607
+ border: 1px solid rgba(34, 197, 94, 0.3);
608
+ border-radius: 16px;
609
+ padding: 32px 40px;
610
+ max-width: 460px;
611
+ width: 90%;
612
+ text-align: center;
613
+ backdrop-filter: blur(20px);
614
+ box-shadow: 0 0 60px rgba(34, 197, 94, 0.1);
615
+ }
616
+
617
+ .completion-close-btn {
618
+ position: absolute;
619
+ top: 12px;
620
+ right: 16px;
621
+ background: none;
622
+ border: none;
623
+ color: var(--text-dim);
624
+ font-size: 24px;
625
+ cursor: pointer;
626
+ padding: 4px 8px;
627
+ line-height: 1;
628
+ border-radius: 4px;
629
+ transition: color 0.2s, background 0.2s;
630
+ }
631
+
632
+ .completion-close-btn:hover {
633
+ color: var(--text-bright);
634
+ background: rgba(255, 255, 255, 0.1);
635
+ }
636
+
637
+ .completion-icon {
638
+ font-size: 48px;
639
+ margin-bottom: 12px;
640
+ }
641
+
642
+ .completion-icon.success { color: var(--accent-green); }
643
+ .completion-icon.partial { color: var(--accent-amber); }
644
+
645
+ .completion-header {
646
+ font-size: 20px;
647
+ font-weight: 600;
648
+ color: var(--text-bright);
649
+ margin-bottom: 8px;
650
+ }
651
+
652
+ .completion-app-name {
653
+ font-size: 14px;
654
+ color: var(--text-dim);
655
+ margin-bottom: 16px;
656
+ }
657
+
658
+ .completion-metrics {
659
+ display: flex;
660
+ justify-content: center;
661
+ flex-wrap: wrap;
662
+ gap: 12px;
663
+ margin-bottom: 24px;
664
+ font-family: var(--font-mono);
665
+ font-size: 12px;
666
+ color: var(--accent-cyan);
667
+ }
668
+
669
+ .completion-actions {
670
+ display: flex;
671
+ gap: 12px;
672
+ justify-content: center;
673
+ margin-bottom: 8px;
674
+ }
675
+
676
+ .completion-action-btn {
677
+ display: flex;
678
+ align-items: center;
679
+ gap: 6px;
680
+ padding: 10px 20px;
681
+ border-radius: 8px;
682
+ font-family: var(--font-sans);
683
+ font-weight: 600;
684
+ font-size: 13px;
685
+ cursor: pointer;
686
+ transition: transform 0.15s, opacity 0.2s;
687
+ border: none;
688
+ }
689
+
690
+ .completion-action-btn:hover {
691
+ transform: scale(1.03);
692
+ }
693
+
694
+ .completion-action-btn:disabled {
695
+ opacity: 0.4;
696
+ cursor: not-allowed;
697
+ transform: none;
698
+ }
699
+
700
+ .completion-action-icon {
701
+ font-size: 16px;
702
+ }
703
+
704
+ .completion-download-btn {
705
+ background: linear-gradient(135deg, var(--accent-green), #16a34a);
706
+ color: #000;
707
+ }
708
+
709
+ .completion-github-btn {
710
+ background: rgba(255, 255, 255, 0.1);
711
+ color: var(--text-bright);
712
+ border: 1px solid rgba(255, 255, 255, 0.2);
713
+ }
714
+
715
+ .completion-github-btn:hover {
716
+ background: rgba(255, 255, 255, 0.15);
717
+ }
718
+
719
+ .completion-status {
720
+ margin-top: 12px;
721
+ font-size: 12px;
722
+ color: var(--text-dim);
723
+ }
724
+
725
+ /* GitHub form inside completion modal */
726
+ .github-form {
727
+ text-align: left;
728
+ display: flex;
729
+ flex-direction: column;
730
+ gap: 10px;
731
+ }
732
+
733
+ .github-form-row {
734
+ display: flex;
735
+ align-items: center;
736
+ justify-content: space-between;
737
+ gap: 12px;
738
+ }
739
+
740
+ .github-form-row label {
741
+ font-size: 12px;
742
+ color: var(--text-dim);
743
+ white-space: nowrap;
744
+ }
745
+
746
+ .github-form-row input[type="text"] {
747
+ flex: 1;
748
+ background: rgba(20, 20, 40, 0.8);
749
+ border: 1px solid var(--border-glow);
750
+ border-radius: 6px;
751
+ padding: 8px 10px;
752
+ color: var(--text-bright);
753
+ font-family: var(--font-mono);
754
+ font-size: 13px;
755
+ outline: none;
756
+ }
757
+
758
+ .github-form-row input[type="text"]:focus {
759
+ border-color: var(--accent-cyan);
760
+ }
761
+
762
+ .github-toggle {
763
+ display: flex;
764
+ align-items: center;
765
+ gap: 6px;
766
+ cursor: pointer;
767
+ }
768
+
769
+ .github-toggle input[type="checkbox"] {
770
+ accent-color: var(--accent-cyan);
771
+ }
772
+
773
+ .github-user {
774
+ font-size: 11px;
775
+ color: var(--text-dim);
776
+ font-family: var(--font-mono);
777
+ }
778
+
779
+ .completion-github-push-btn {
780
+ background: linear-gradient(135deg, var(--accent-cyan), #0891b2);
781
+ color: #000;
782
+ padding: 8px 16px;
783
+ font-size: 12px;
784
+ }
785
+
786
+ .github-success {
787
+ color: var(--accent-green);
788
+ font-size: 13px;
789
+ }
790
+
791
+ .github-link {
792
+ color: var(--accent-cyan);
793
+ text-decoration: none;
794
+ }
795
+
796
+ .github-link:hover {
797
+ text-decoration: underline;
798
+ }
799
+
800
+ .github-error {
801
+ color: var(--accent-red);
802
+ font-size: 12px;
803
+ }
804
+
805
+ /* === Scrollbar === */
806
+ ::-webkit-scrollbar {
807
+ width: 6px;
808
+ height: 6px;
809
+ }
810
+
811
+ ::-webkit-scrollbar-track {
812
+ background: transparent;
813
+ }
814
+
815
+ ::-webkit-scrollbar-thumb {
816
+ background: rgba(255, 255, 255, 0.1);
817
+ border-radius: 3px;
818
+ }
819
+
820
+ ::-webkit-scrollbar-thumb:hover {
821
+ background: rgba(255, 255, 255, 0.2);
822
+ }
823
+
824
+ /* === Responsive === */
825
+ @media (max-width: 900px) {
826
+ #app {
827
+ grid-template-columns: 1fr;
828
+ grid-template-rows: 48px 1fr 50vh 36px;
829
+ }
830
+ #chat-panel {
831
+ grid-column: 1;
832
+ grid-row: 2;
833
+ border-right: none;
834
+ border-bottom: 1px solid var(--border);
835
+ }
836
+ #preview-panel {
837
+ grid-column: 1;
838
+ grid-row: 3;
839
+ }
840
+ }