coding-agent-harness 1.0.4 → 1.0.5

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 (100) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/LICENSE +661 -21
  3. package/LICENSE-EXCEPTION.md +37 -0
  4. package/README.md +33 -1
  5. package/README.zh-CN.md +23 -1
  6. package/SKILL.md +9 -8
  7. package/docs-release/architecture/overview.md +1 -1
  8. package/docs-release/architecture/overview.zh-CN.md +1 -1
  9. package/docs-release/architecture/system-explainer/01-system-overview.md +217 -0
  10. package/docs-release/architecture/system-explainer/02-module-dependency.md +257 -0
  11. package/docs-release/architecture/system-explainer/03-task-lifecycle.md +304 -0
  12. package/docs-release/architecture/system-explainer/04-check-and-governance.md +239 -0
  13. package/docs-release/architecture/system-explainer/05-data-flow.md +276 -0
  14. package/docs-release/architecture/system-explainer/06-preset-and-migration.md +303 -0
  15. package/docs-release/architecture/system-explainer/README.md +67 -0
  16. package/docs-release/architecture/system-explainer/en-US/01-system-overview.md +226 -0
  17. package/docs-release/architecture/system-explainer/en-US/02-module-dependency.md +263 -0
  18. package/docs-release/architecture/system-explainer/en-US/03-task-lifecycle.md +319 -0
  19. package/docs-release/architecture/system-explainer/en-US/04-check-and-governance.md +250 -0
  20. package/docs-release/architecture/system-explainer/en-US/05-data-flow.md +290 -0
  21. package/docs-release/architecture/system-explainer/en-US/06-preset-and-migration.md +323 -0
  22. package/docs-release/architecture/system-explainer/en-US/README.md +70 -0
  23. package/docs-release/guides/agent-installation.en-US.md +8 -7
  24. package/docs-release/guides/agent-installation.md +9 -7
  25. package/docs-release/guides/preset-development.md +26 -2
  26. package/docs-release/guides/task-state-machine.en-US.md +30 -13
  27. package/docs-release/guides/task-state-machine.md +30 -13
  28. package/examples/minimal-project/docs/09-PLANNING/TASKS/demo-task/INDEX.md +60 -0
  29. package/package.json +3 -2
  30. package/references/harness-ledger.md +1 -1
  31. package/scripts/commands/migration-command.mjs +30 -0
  32. package/scripts/commands/task-command.mjs +26 -25
  33. package/scripts/harness.mjs +7 -3
  34. package/scripts/lib/capability-registry.mjs +17 -21
  35. package/scripts/lib/check-module-parallel.mjs +9 -16
  36. package/scripts/lib/check-profiles.mjs +35 -81
  37. package/scripts/lib/check-task-contracts.mjs +13 -5
  38. package/scripts/lib/core-shared.mjs +55 -2
  39. package/scripts/lib/dashboard-data.mjs +126 -18
  40. package/scripts/lib/dashboard-workbench.mjs +80 -1
  41. package/scripts/lib/dashboard-writer.mjs +6 -2
  42. package/scripts/lib/git-status-summary.mjs +1 -1
  43. package/scripts/lib/governance-sync.mjs +180 -83
  44. package/scripts/lib/harness-core.mjs +1 -0
  45. package/scripts/lib/markdown-utils.mjs +33 -0
  46. package/scripts/lib/migration-planner.mjs +4 -6
  47. package/scripts/lib/phase-kind.mjs +50 -0
  48. package/scripts/lib/preset-engine.mjs +5 -8
  49. package/scripts/lib/preset-registry.mjs +188 -39
  50. package/scripts/lib/review-confirm-git-gate.mjs +1 -1
  51. package/scripts/lib/status-builder.mjs +88 -0
  52. package/scripts/lib/status-dashboard-renderer.mjs +7 -4
  53. package/scripts/lib/task-audit-metadata.mjs +385 -0
  54. package/scripts/lib/task-audit-migration.mjs +350 -0
  55. package/scripts/lib/task-completion-consistency.mjs +11 -1
  56. package/scripts/lib/task-lifecycle/create-task-helpers.mjs +67 -0
  57. package/scripts/lib/task-lifecycle/phase-sync.mjs +88 -0
  58. package/scripts/lib/task-lifecycle/review-confirm.mjs +40 -29
  59. package/scripts/lib/task-lifecycle/review-gates.mjs +13 -10
  60. package/scripts/lib/task-lifecycle/review-submission.mjs +63 -0
  61. package/scripts/lib/task-lifecycle/scaffold-provenance.mjs +49 -0
  62. package/scripts/lib/task-lifecycle/template-files.mjs +53 -0
  63. package/scripts/lib/task-lifecycle.mjs +114 -147
  64. package/scripts/lib/task-metadata.mjs +118 -0
  65. package/scripts/lib/task-review-model.mjs +54 -68
  66. package/scripts/lib/task-scanner.mjs +70 -143
  67. package/skills/preset-creator/references/complex-task-skeleton/brief.md +11 -0
  68. package/templates/AGENTS.md.template +7 -5
  69. package/templates/dashboard/assets/app-src/00-state.js +12 -0
  70. package/templates/dashboard/assets/app-src/10-router.js +3 -0
  71. package/templates/dashboard/assets/app-src/20-overview.js +7 -3
  72. package/templates/dashboard/assets/app-src/35-task-detail.js +46 -6
  73. package/templates/dashboard/assets/app-src/55-presets.js +375 -0
  74. package/templates/dashboard/assets/app-src/60-shared.js +3 -1
  75. package/templates/dashboard/assets/app-src/90-bindings.js +131 -0
  76. package/templates/dashboard/assets/app.css +583 -0
  77. package/templates/dashboard/assets/app.css.manifest.json +1 -0
  78. package/templates/dashboard/assets/app.js +578 -10
  79. package/templates/dashboard/assets/app.manifest.json +1 -0
  80. package/templates/dashboard/assets/css-src/00-foundation.css +4 -0
  81. package/templates/dashboard/assets/css-src/40-detail-modules-migration.css +62 -0
  82. package/templates/dashboard/assets/css-src/45-presets.css +516 -0
  83. package/templates/dashboard/assets/i18n.js +140 -2
  84. package/templates/planning/INDEX.md +87 -0
  85. package/templates/planning/brief.md +1 -1
  86. package/templates/planning/module_session_prompt.md +1 -0
  87. package/templates/planning/review.md +0 -18
  88. package/templates/planning/task_plan.md +4 -43
  89. package/templates/planning/visual_map.md +13 -9
  90. package/templates/planning/visual_map.simple.md +52 -0
  91. package/templates/reference/execution-workflow-standard.md +29 -2
  92. package/templates-zh-CN/AGENTS.md.template +7 -5
  93. package/templates-zh-CN/planning/INDEX.md +87 -0
  94. package/templates-zh-CN/planning/brief.md +1 -1
  95. package/templates-zh-CN/planning/module_session_prompt.md +1 -0
  96. package/templates-zh-CN/planning/review.md +0 -18
  97. package/templates-zh-CN/planning/task_plan.md +3 -63
  98. package/templates-zh-CN/planning/visual_map.md +14 -7
  99. package/templates-zh-CN/planning/visual_map.simple.md +48 -0
  100. package/templates-zh-CN/reference/execution-workflow-standard.md +31 -6
@@ -7,6 +7,7 @@
7
7
  "app-src/40-modules.js",
8
8
  "app-src/45-review.js",
9
9
  "app-src/50-migration.js",
10
+ "app-src/55-presets.js",
10
11
  "app-src/60-shared.js",
11
12
  "app-src/90-bindings.js"
12
13
  ]
@@ -294,6 +294,10 @@ button, input, select {
294
294
  animation: pulse-warn 4s infinite;
295
295
  }
296
296
 
297
+ .status-primary.snapshot {
298
+ border-color: rgba(71, 85, 105, 0.3);
299
+ }
300
+
297
301
  .status-primary.fail {
298
302
  border-color: rgba(225, 29, 72, 0.3);
299
303
  animation: pulse-fail 4s infinite;
@@ -36,6 +36,23 @@
36
36
  font-size: 16px;
37
37
  }
38
38
 
39
+ .phase-kind-group {
40
+ display: grid;
41
+ grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
42
+ grid-column: 1 / -1;
43
+ gap: 12px;
44
+ }
45
+
46
+ .phase-kind-group h3 {
47
+ grid-column: 1 / -1;
48
+ margin: 4px 0 0;
49
+ color: var(--muted);
50
+ font-size: 12px;
51
+ font-weight: 800;
52
+ text-transform: uppercase;
53
+ letter-spacing: 0;
54
+ }
55
+
39
56
  .phase-step {
40
57
  background: var(--paper);
41
58
  border: 1px solid var(--line);
@@ -46,6 +63,22 @@
46
63
  cursor: pointer;
47
64
  }
48
65
 
66
+ .phase-step.init {
67
+ border-left: 4px solid #64748b;
68
+ }
69
+
70
+ .phase-step.execution {
71
+ border-left: 4px solid var(--accent);
72
+ }
73
+
74
+ .phase-step.gate {
75
+ border-left: 4px solid #9f7aea;
76
+ }
77
+
78
+ .phase-step.other {
79
+ border-left: 4px solid var(--warn);
80
+ }
81
+
49
82
  .card-header-actions {
50
83
  display: flex;
51
84
  align-items: center;
@@ -64,6 +97,19 @@
64
97
  font-weight: 800;
65
98
  }
66
99
 
100
+ .phase-step-head {
101
+ display: flex;
102
+ align-items: center;
103
+ justify-content: space-between;
104
+ gap: 8px;
105
+ }
106
+
107
+ .phase-step-head span {
108
+ color: var(--muted);
109
+ font-size: 12px;
110
+ white-space: nowrap;
111
+ }
112
+
67
113
  .phase-step p {
68
114
  color: var(--muted);
69
115
  min-height: 42px;
@@ -72,6 +118,22 @@
72
118
  line-height: 1.4;
73
119
  }
74
120
 
121
+ .phase-meta {
122
+ display: flex;
123
+ flex-wrap: wrap;
124
+ gap: 6px;
125
+ margin-top: 8px;
126
+ }
127
+
128
+ .phase-exit-command {
129
+ display: block;
130
+ margin-top: 10px;
131
+ overflow-wrap: anywhere;
132
+ color: var(--ink);
133
+ font-size: 11px;
134
+ line-height: 1.4;
135
+ }
136
+
75
137
  .detail-grid {
76
138
  display: grid;
77
139
  grid-template-columns: minmax(0, 1.8fr) minmax(280px, 360px);
@@ -0,0 +1,516 @@
1
+ /* Preset Workbench */
2
+ .presets-page {
3
+ min-width: 0;
4
+ }
5
+
6
+ .preset-command-center,
7
+ .preset-collection-panel,
8
+ .preset-detail-panel,
9
+ .preset-layer-panel,
10
+ .preset-context-actions,
11
+ .preset-context-actions .side-panel {
12
+ min-width: 0;
13
+ }
14
+
15
+ .preset-count-pill {
16
+ border: 1px solid var(--line);
17
+ border-radius: 999px;
18
+ background: var(--paper-2);
19
+ color: var(--muted);
20
+ font-size: 12px;
21
+ font-weight: 800;
22
+ padding: 7px 11px;
23
+ }
24
+
25
+ .preset-priority-strip {
26
+ display: grid;
27
+ grid-template-columns: repeat(3, minmax(0, 1fr));
28
+ gap: 10px;
29
+ margin: 18px 0;
30
+ }
31
+
32
+ .preset-priority-step {
33
+ display: flex;
34
+ align-items: center;
35
+ gap: 10px;
36
+ border: 1px solid var(--line);
37
+ border-radius: 8px;
38
+ background: var(--paper-2);
39
+ padding: 10px 12px;
40
+ min-width: 0;
41
+ }
42
+
43
+ .preset-priority-step span {
44
+ display: inline-grid;
45
+ place-items: center;
46
+ width: 22px;
47
+ height: 22px;
48
+ border-radius: 999px;
49
+ background: var(--accent);
50
+ color: white;
51
+ font-size: 12px;
52
+ font-weight: 900;
53
+ flex: 0 0 auto;
54
+ }
55
+
56
+ .preset-priority-step strong {
57
+ font-size: 13px;
58
+ overflow-wrap: anywhere;
59
+ }
60
+
61
+ .preset-toolbar {
62
+ display: grid;
63
+ grid-template-columns: minmax(220px, 1fr) auto;
64
+ gap: 14px;
65
+ align-items: center;
66
+ }
67
+
68
+ .preset-source-tabs {
69
+ display: flex;
70
+ flex-wrap: wrap;
71
+ gap: 8px;
72
+ justify-content: flex-end;
73
+ }
74
+
75
+ .preset-source-tabs button {
76
+ display: inline-flex;
77
+ align-items: center;
78
+ gap: 8px;
79
+ border: 1px solid var(--line);
80
+ background: var(--paper);
81
+ color: var(--ink);
82
+ border-radius: 8px;
83
+ padding: 9px 12px;
84
+ font-size: 12px;
85
+ font-weight: 800;
86
+ }
87
+
88
+ .preset-source-tabs button.active {
89
+ border-color: var(--accent);
90
+ background: var(--paper-2);
91
+ box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent);
92
+ }
93
+
94
+ .preset-workspace {
95
+ display: grid;
96
+ grid-template-columns: minmax(300px, 0.82fr) minmax(420px, 1.25fr) minmax(300px, 0.86fr);
97
+ gap: 18px;
98
+ align-items: start;
99
+ }
100
+
101
+ .preset-panel-heading {
102
+ display: flex;
103
+ justify-content: space-between;
104
+ gap: 12px;
105
+ align-items: flex-start;
106
+ margin-bottom: 14px;
107
+ }
108
+
109
+ .preset-panel-heading h3 {
110
+ margin: 0;
111
+ font-size: 16px;
112
+ line-height: 1.2;
113
+ }
114
+
115
+ .preset-panel-heading p,
116
+ .preset-helper,
117
+ .preset-action-group p {
118
+ margin: 4px 0 0;
119
+ color: var(--muted);
120
+ font-size: 12px;
121
+ line-height: 1.45;
122
+ }
123
+
124
+ .preset-catalog-list {
125
+ display: grid;
126
+ gap: 12px;
127
+ }
128
+
129
+ .preset-card {
130
+ border: 1px solid var(--line);
131
+ border-radius: 8px;
132
+ background: var(--paper);
133
+ padding: 14px;
134
+ display: grid;
135
+ gap: 10px;
136
+ min-width: 0;
137
+ }
138
+
139
+ .preset-card.active {
140
+ border-color: var(--accent);
141
+ background: var(--paper-2);
142
+ box-shadow: inset 3px 0 0 var(--accent);
143
+ }
144
+
145
+ .preset-card.shadowed {
146
+ opacity: 0.78;
147
+ }
148
+
149
+ .preset-card-topline {
150
+ display: flex;
151
+ justify-content: space-between;
152
+ gap: 10px;
153
+ align-items: flex-start;
154
+ min-width: 0;
155
+ }
156
+
157
+ .preset-card-tools,
158
+ .preset-detail-badges {
159
+ display: flex;
160
+ flex-wrap: wrap;
161
+ gap: 6px;
162
+ justify-content: flex-end;
163
+ flex: 0 1 auto;
164
+ }
165
+
166
+ .preset-card-select,
167
+ .preset-card-body,
168
+ .preset-layer-row {
169
+ appearance: none;
170
+ border: 0;
171
+ background: transparent;
172
+ color: inherit;
173
+ padding: 0;
174
+ text-align: left;
175
+ cursor: pointer;
176
+ min-width: 0;
177
+ }
178
+
179
+ .preset-card-select {
180
+ flex: 1 1 auto;
181
+ }
182
+
183
+ .card-id {
184
+ display: block;
185
+ font-size: 15px;
186
+ font-weight: 850;
187
+ line-height: 1.25;
188
+ overflow-wrap: anywhere;
189
+ }
190
+
191
+ .preset-card-body {
192
+ display: block;
193
+ width: 100%;
194
+ }
195
+
196
+ .preset-card-body span,
197
+ .preset-detail-panel p {
198
+ display: block;
199
+ margin: 0;
200
+ color: var(--muted);
201
+ font-size: 13px;
202
+ line-height: 1.55;
203
+ overflow-wrap: anywhere;
204
+ }
205
+
206
+ .preset-card-meta {
207
+ display: flex;
208
+ flex-wrap: wrap;
209
+ gap: 8px;
210
+ color: var(--muted);
211
+ font-size: 11px;
212
+ font-weight: 800;
213
+ }
214
+
215
+ .preset-source-badge.project {
216
+ border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
217
+ }
218
+
219
+ .copy-inline {
220
+ appearance: none;
221
+ border: 1px solid var(--line);
222
+ background: var(--paper);
223
+ color: var(--ink);
224
+ border-radius: 7px;
225
+ padding: 5px 8px;
226
+ font-size: 11px;
227
+ font-weight: 800;
228
+ line-height: 1.1;
229
+ cursor: pointer;
230
+ white-space: nowrap;
231
+ }
232
+
233
+ .copy-inline:hover,
234
+ .preset-card-select:hover .card-id,
235
+ .preset-card-body:hover span,
236
+ .preset-layer-row:hover strong {
237
+ color: var(--accent);
238
+ }
239
+
240
+ .preset-detail-hero {
241
+ display: grid;
242
+ grid-template-columns: minmax(0, 1fr) auto;
243
+ gap: 18px;
244
+ align-items: start;
245
+ padding-bottom: 16px;
246
+ border-bottom: 1px solid var(--line);
247
+ }
248
+
249
+ .preset-detail-title-row {
250
+ display: flex;
251
+ flex-wrap: wrap;
252
+ gap: 10px;
253
+ align-items: center;
254
+ }
255
+
256
+ .preset-detail-title-row h3 {
257
+ margin: 0;
258
+ font-size: 22px;
259
+ line-height: 1.15;
260
+ overflow-wrap: anywhere;
261
+ }
262
+
263
+ .preset-detail-list {
264
+ display: grid;
265
+ grid-template-columns: repeat(2, minmax(0, 1fr));
266
+ gap: 0;
267
+ margin: 16px 0;
268
+ border: 1px solid var(--line);
269
+ border-radius: 8px;
270
+ overflow: hidden;
271
+ }
272
+
273
+ .preset-detail-list div {
274
+ display: grid;
275
+ gap: 4px;
276
+ padding: 11px 12px;
277
+ border-right: 1px solid var(--line);
278
+ border-bottom: 1px solid var(--line);
279
+ min-width: 0;
280
+ }
281
+
282
+ .preset-detail-list div:nth-child(2n) {
283
+ border-right: 0;
284
+ }
285
+
286
+ .preset-detail-list dt {
287
+ color: var(--muted);
288
+ font-size: 11px;
289
+ font-weight: 800;
290
+ }
291
+
292
+ .preset-detail-list dd {
293
+ margin: 0;
294
+ font-size: 14px;
295
+ font-weight: 850;
296
+ line-height: 1.3;
297
+ overflow-wrap: anywhere;
298
+ }
299
+
300
+ .preset-path-block {
301
+ display: grid;
302
+ gap: 8px;
303
+ margin-top: 14px;
304
+ }
305
+
306
+ .preset-path-block > span {
307
+ color: var(--muted);
308
+ font-size: 11px;
309
+ font-weight: 800;
310
+ }
311
+
312
+ .preset-manifest-path {
313
+ display: block;
314
+ max-width: 100%;
315
+ white-space: normal;
316
+ overflow-wrap: anywhere;
317
+ word-break: break-word;
318
+ border: 1px solid var(--line);
319
+ background: var(--paper-2);
320
+ border-radius: 8px;
321
+ padding: 8px;
322
+ color: var(--muted);
323
+ font-size: 11px;
324
+ line-height: 1.45;
325
+ }
326
+
327
+ .preset-command-list {
328
+ display: grid;
329
+ gap: 8px;
330
+ margin-top: 14px;
331
+ }
332
+
333
+ .preset-command-row {
334
+ display: grid;
335
+ grid-template-columns: minmax(0, 1fr) auto;
336
+ gap: 8px;
337
+ align-items: center;
338
+ border: 1px solid var(--line);
339
+ background: var(--paper-2);
340
+ border-radius: 8px;
341
+ padding: 8px;
342
+ min-width: 0;
343
+ }
344
+
345
+ .preset-command-row code {
346
+ white-space: normal;
347
+ overflow-wrap: anywhere;
348
+ }
349
+
350
+ .preset-command-warning,
351
+ .preset-confirm-warning {
352
+ border: 1px solid var(--line);
353
+ border-radius: 8px;
354
+ background: var(--paper-2);
355
+ color: var(--muted);
356
+ font-size: 12px;
357
+ line-height: 1.45;
358
+ padding: 10px;
359
+ }
360
+
361
+ .preset-confirm-warning {
362
+ color: #b91c1c;
363
+ }
364
+
365
+ .preset-layer-list {
366
+ display: grid;
367
+ gap: 8px;
368
+ }
369
+
370
+ .preset-layer-row {
371
+ display: grid;
372
+ grid-template-columns: auto minmax(0, 1fr) auto;
373
+ gap: 10px;
374
+ align-items: center;
375
+ border: 1px solid var(--line);
376
+ border-radius: 8px;
377
+ background: var(--paper);
378
+ padding: 10px;
379
+ }
380
+
381
+ .preset-layer-row.active {
382
+ border-color: var(--accent);
383
+ background: var(--paper-2);
384
+ }
385
+
386
+ .preset-layer-rank {
387
+ display: inline-grid;
388
+ place-items: center;
389
+ width: 24px;
390
+ height: 24px;
391
+ border-radius: 999px;
392
+ background: var(--paper-2);
393
+ color: var(--muted);
394
+ font-size: 12px;
395
+ font-weight: 900;
396
+ }
397
+
398
+ .preset-layer-row strong,
399
+ .preset-layer-row small {
400
+ display: block;
401
+ overflow-wrap: anywhere;
402
+ }
403
+
404
+ .preset-layer-row small {
405
+ color: var(--muted);
406
+ font-size: 11px;
407
+ margin-top: 2px;
408
+ }
409
+
410
+ .preset-roots {
411
+ display: grid;
412
+ gap: 10px;
413
+ margin-top: 14px;
414
+ }
415
+
416
+ .preset-roots div {
417
+ display: grid;
418
+ gap: 6px;
419
+ min-width: 0;
420
+ }
421
+
422
+ .preset-roots strong {
423
+ font-size: 12px;
424
+ }
425
+
426
+ .preset-action-panel {
427
+ display: grid;
428
+ gap: 12px;
429
+ }
430
+
431
+ .preset-action-group {
432
+ display: grid;
433
+ gap: 10px;
434
+ border-top: 1px solid var(--line);
435
+ padding-top: 14px;
436
+ min-width: 0;
437
+ }
438
+
439
+ .preset-action-group h4 {
440
+ margin: 0;
441
+ font-size: 13px;
442
+ font-weight: 850;
443
+ }
444
+
445
+ .preset-action-group label {
446
+ display: grid;
447
+ gap: 6px;
448
+ font-size: 12px;
449
+ font-weight: 800;
450
+ color: var(--muted);
451
+ }
452
+
453
+ .preset-action-group input,
454
+ .preset-action-group select {
455
+ width: 100%;
456
+ min-width: 0;
457
+ }
458
+
459
+ .preset-action-group .check-row {
460
+ display: flex;
461
+ align-items: center;
462
+ gap: 8px;
463
+ }
464
+
465
+ .preset-action-group .check-row input {
466
+ width: auto;
467
+ }
468
+
469
+ .preset-confirm-row {
470
+ display: grid;
471
+ grid-template-columns: minmax(0, 1fr) auto;
472
+ gap: 8px;
473
+ align-items: end;
474
+ }
475
+
476
+ .preset-action-group.danger button:not(:disabled):last-child {
477
+ border-color: #b91c1c;
478
+ color: #b91c1c;
479
+ }
480
+
481
+ @media (max-width: 1400px) {
482
+ .preset-workspace {
483
+ grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr);
484
+ }
485
+
486
+ .preset-context-actions {
487
+ grid-column: 1 / -1;
488
+ display: grid;
489
+ grid-template-columns: repeat(2, minmax(0, 1fr));
490
+ gap: 14px;
491
+ }
492
+ }
493
+
494
+ @media (max-width: 760px) {
495
+ .preset-toolbar,
496
+ .preset-priority-strip,
497
+ .preset-workspace,
498
+ .preset-context-actions,
499
+ .preset-detail-hero,
500
+ .preset-detail-list,
501
+ .preset-command-row,
502
+ .preset-confirm-row {
503
+ grid-template-columns: 1fr;
504
+ }
505
+
506
+ .preset-source-tabs,
507
+ .preset-card-tools,
508
+ .preset-detail-badges {
509
+ justify-content: flex-start;
510
+ }
511
+
512
+ .preset-detail-list div,
513
+ .preset-detail-list div:nth-child(2n) {
514
+ border-right: 0;
515
+ }
516
+ }