codexmate 0.0.19 → 0.0.21

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 (102) hide show
  1. package/README.en.md +349 -255
  2. package/README.md +284 -248
  3. package/cli/agents-files.js +162 -0
  4. package/cli/archive-helpers.js +446 -0
  5. package/cli/auth-profiles.js +359 -0
  6. package/cli/builtin-proxy.js +580 -0
  7. package/cli/claude-proxy.js +998 -0
  8. package/cli/config-bootstrap.js +384 -0
  9. package/cli/config-health.js +338 -0
  10. package/cli/openclaw-config.js +629 -0
  11. package/cli/skills.js +1141 -0
  12. package/cli/zip-commands.js +510 -0
  13. package/cli.js +13129 -12973
  14. package/lib/cli-file-utils.js +151 -151
  15. package/lib/cli-models-utils.js +419 -152
  16. package/lib/cli-network-utils.js +164 -148
  17. package/lib/cli-path-utils.js +69 -0
  18. package/lib/cli-session-utils.js +121 -121
  19. package/lib/cli-sessions.js +386 -0
  20. package/lib/cli-utils.js +155 -155
  21. package/lib/download-artifacts.js +77 -0
  22. package/lib/mcp-stdio.js +440 -440
  23. package/lib/task-orchestrator.js +869 -0
  24. package/lib/text-diff.js +303 -303
  25. package/lib/workflow-engine.js +340 -340
  26. package/package.json +74 -63
  27. package/res/json5.min.js +1 -1
  28. package/res/vue.global.prod.js +13 -0
  29. package/web-ui/app.js +530 -5548
  30. package/web-ui/index.html +33 -2246
  31. package/web-ui/logic.agents-diff.mjs +386 -0
  32. package/web-ui/logic.claude.mjs +168 -0
  33. package/web-ui/logic.mjs +5 -793
  34. package/web-ui/logic.runtime.mjs +124 -0
  35. package/web-ui/logic.sessions.mjs +581 -0
  36. package/web-ui/modules/api.mjs +90 -0
  37. package/web-ui/modules/app.computed.dashboard.mjs +113 -0
  38. package/web-ui/modules/app.computed.index.mjs +15 -0
  39. package/web-ui/modules/app.computed.main-tabs.mjs +195 -0
  40. package/web-ui/modules/app.computed.session.mjs +507 -0
  41. package/web-ui/modules/app.constants.mjs +15 -0
  42. package/web-ui/modules/app.methods.agents.mjs +493 -0
  43. package/web-ui/modules/app.methods.claude-config.mjs +174 -0
  44. package/web-ui/modules/app.methods.codex-config.mjs +640 -0
  45. package/web-ui/modules/app.methods.index.mjs +88 -0
  46. package/web-ui/modules/app.methods.install.mjs +149 -0
  47. package/web-ui/modules/app.methods.navigation.mjs +619 -0
  48. package/web-ui/modules/app.methods.openclaw-core.mjs +814 -0
  49. package/web-ui/modules/app.methods.openclaw-editing.mjs +372 -0
  50. package/web-ui/modules/app.methods.openclaw-persist.mjs +369 -0
  51. package/web-ui/modules/app.methods.providers.mjs +363 -0
  52. package/web-ui/modules/app.methods.runtime.mjs +323 -0
  53. package/web-ui/modules/app.methods.session-actions.mjs +520 -0
  54. package/web-ui/modules/app.methods.session-browser.mjs +626 -0
  55. package/web-ui/modules/app.methods.session-timeline.mjs +448 -0
  56. package/web-ui/modules/app.methods.session-trash.mjs +422 -0
  57. package/web-ui/modules/app.methods.startup-claude.mjs +412 -0
  58. package/web-ui/modules/app.methods.task-orchestration.mjs +471 -0
  59. package/web-ui/modules/config-mode.computed.mjs +126 -124
  60. package/web-ui/modules/skills.computed.mjs +107 -107
  61. package/web-ui/modules/skills.methods.mjs +481 -481
  62. package/web-ui/partials/index/layout-footer.html +13 -0
  63. package/web-ui/partials/index/layout-header.html +402 -0
  64. package/web-ui/partials/index/modal-config-template-agents.html +125 -0
  65. package/web-ui/partials/index/modal-confirm-toast.html +32 -0
  66. package/web-ui/partials/index/modal-health-check.html +72 -0
  67. package/web-ui/partials/index/modal-openclaw-config.html +280 -0
  68. package/web-ui/partials/index/modal-skills.html +184 -0
  69. package/web-ui/partials/index/modals-basic.html +156 -0
  70. package/web-ui/partials/index/panel-config-claude.html +126 -0
  71. package/web-ui/partials/index/panel-config-codex.html +237 -0
  72. package/web-ui/partials/index/panel-config-openclaw.html +78 -0
  73. package/web-ui/partials/index/panel-docs.html +130 -0
  74. package/web-ui/partials/index/panel-market.html +174 -0
  75. package/web-ui/partials/index/panel-orchestration.html +397 -0
  76. package/web-ui/partials/index/panel-sessions.html +292 -0
  77. package/web-ui/partials/index/panel-settings.html +190 -0
  78. package/web-ui/partials/index/panel-usage.html +213 -0
  79. package/web-ui/session-helpers.mjs +559 -362
  80. package/web-ui/source-bundle.cjs +233 -0
  81. package/web-ui/styles/base-theme.css +271 -0
  82. package/web-ui/styles/controls-forms.css +360 -0
  83. package/web-ui/styles/docs-panel.css +182 -0
  84. package/web-ui/styles/feedback.css +108 -0
  85. package/web-ui/styles/health-check-dialog.css +144 -0
  86. package/web-ui/styles/layout-shell.css +376 -0
  87. package/web-ui/styles/modals-core.css +464 -0
  88. package/web-ui/styles/navigation-panels.css +348 -0
  89. package/web-ui/styles/openclaw-structured.css +266 -0
  90. package/web-ui/styles/responsive.css +450 -0
  91. package/web-ui/styles/sessions-list.css +400 -0
  92. package/web-ui/styles/sessions-preview.css +411 -0
  93. package/web-ui/styles/sessions-toolbar-trash.css +243 -0
  94. package/web-ui/styles/sessions-usage.css +628 -0
  95. package/web-ui/styles/skills-list.css +296 -0
  96. package/web-ui/styles/skills-market.css +335 -0
  97. package/web-ui/styles/task-orchestration.css +776 -0
  98. package/web-ui/styles/titles-cards.css +408 -0
  99. package/web-ui/styles.css +18 -4668
  100. package/web-ui.html +17 -17
  101. package/res/screenshot.png +0 -0
  102. package/res/vue.global.js +0 -18552
@@ -0,0 +1,296 @@
1
+ .skills-hint-line,
2
+ .hint-single-line {
3
+ display: block;
4
+ white-space: nowrap;
5
+ overflow: hidden;
6
+ text-overflow: ellipsis;
7
+ max-width: 100%;
8
+ }
9
+
10
+ .skill-list {
11
+ display: flex;
12
+ flex-direction: column;
13
+ gap: var(--spacing-xs);
14
+ margin-bottom: var(--spacing-sm);
15
+ max-height: min(52vh, 440px);
16
+ overflow-y: auto;
17
+ padding-right: 0;
18
+ scrollbar-width: none;
19
+ -ms-overflow-style: none;
20
+ }
21
+
22
+ .skill-list::-webkit-scrollbar {
23
+ width: 0;
24
+ height: 0;
25
+ }
26
+
27
+ .skill-list::-webkit-scrollbar-track {
28
+ background: transparent;
29
+ }
30
+
31
+ .skill-list::-webkit-scrollbar-thumb {
32
+ background: transparent;
33
+ border: 0;
34
+ }
35
+
36
+ .skill-list::-webkit-scrollbar-thumb:hover {
37
+ background: transparent;
38
+ }
39
+
40
+ .skill-item {
41
+ display: flex;
42
+ align-items: flex-start;
43
+ gap: var(--spacing-xs);
44
+ border: 1px dashed var(--color-border-soft);
45
+ border-radius: var(--radius-sm);
46
+ padding: var(--spacing-xs);
47
+ background: var(--color-surface-alt);
48
+ transition: border-color var(--transition-fast) var(--ease-spring), background-color var(--transition-fast) var(--ease-spring);
49
+ }
50
+
51
+ .skill-item-main {
52
+ min-width: 0;
53
+ display: flex;
54
+ flex-direction: column;
55
+ gap: 6px;
56
+ flex: 1;
57
+ }
58
+
59
+ .skill-item-title {
60
+ font-size: var(--font-size-secondary);
61
+ font-weight: var(--font-weight-secondary);
62
+ color: var(--color-text-secondary);
63
+ }
64
+
65
+ .skill-item-description {
66
+ font-size: var(--font-size-caption);
67
+ line-height: 1.45;
68
+ color: var(--color-text-tertiary);
69
+ }
70
+
71
+ .skill-item-meta {
72
+ display: flex;
73
+ flex-wrap: wrap;
74
+ gap: var(--spacing-xs);
75
+ align-items: center;
76
+ min-width: 0;
77
+ }
78
+
79
+ .skill-item-path {
80
+ font-family: var(--font-family-mono);
81
+ font-size: var(--font-size-caption);
82
+ color: var(--color-text-tertiary);
83
+ word-break: break-all;
84
+ }
85
+
86
+ .skill-item:hover {
87
+ border-color: rgba(201, 94, 75, 0.35);
88
+ }
89
+
90
+ .skill-item.selected {
91
+ border-color: rgba(201, 94, 75, 0.55);
92
+ background: linear-gradient(to bottom, rgba(201, 94, 75, 0.10) 0%, rgba(201, 94, 75, 0.04) 100%);
93
+ }
94
+
95
+ .skills-empty-state {
96
+ margin-bottom: var(--spacing-sm);
97
+ border: 1px dashed var(--color-border-soft);
98
+ border-radius: var(--radius-sm);
99
+ background: linear-gradient(to bottom, rgba(255, 255, 255, 0.78) 0%, rgba(255, 255, 255, 0.58) 100%);
100
+ color: var(--color-text-tertiary);
101
+ font-size: var(--font-size-secondary);
102
+ text-align: center;
103
+ padding: 18px 12px;
104
+ }
105
+
106
+ .skills-import-block {
107
+ margin-bottom: var(--spacing-sm);
108
+ }
109
+
110
+ .skills-import-title {
111
+ font-size: var(--font-size-body);
112
+ font-weight: var(--font-weight-secondary);
113
+ color: var(--color-text-secondary);
114
+ }
115
+
116
+ .skills-import-list {
117
+ max-height: min(28vh, 260px);
118
+ }
119
+
120
+ .skills-import-empty {
121
+ margin-bottom: 0;
122
+ }
123
+
124
+ .list-row {
125
+ display: flex;
126
+ flex-wrap: wrap;
127
+ gap: var(--spacing-xs);
128
+ align-items: center;
129
+ margin-bottom: var(--spacing-xs);
130
+ }
131
+
132
+ .list-row:last-child {
133
+ margin-bottom: 0;
134
+ }
135
+
136
+ .list-row .form-input {
137
+ flex: 1;
138
+ min-width: 140px;
139
+ }
140
+
141
+ .btn-mini {
142
+ padding: 6px 10px;
143
+ border-radius: var(--radius-sm);
144
+ border: 1px solid var(--color-border-soft);
145
+ background: linear-gradient(to bottom, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.85) 100%);
146
+ font-size: var(--font-size-caption);
147
+ font-weight: var(--font-weight-secondary);
148
+ color: var(--color-text-secondary);
149
+ cursor: pointer;
150
+ transition: all var(--transition-fast) var(--ease-spring);
151
+ box-shadow: var(--shadow-subtle);
152
+ }
153
+
154
+ .btn-mini:hover {
155
+ border-color: var(--color-brand);
156
+ color: var(--color-brand);
157
+ transform: translateY(-1px);
158
+ }
159
+
160
+ .btn-mini.delete {
161
+ color: var(--color-error);
162
+ border-color: rgba(193, 72, 59, 0.35);
163
+ }
164
+
165
+ .btn-mini.delete:hover {
166
+ border-color: rgba(193, 72, 59, 0.7);
167
+ color: var(--color-error);
168
+ }
169
+
170
+ .btn-group {
171
+ display: flex;
172
+ gap: var(--spacing-sm);
173
+ margin-top: var(--spacing-md);
174
+ }
175
+
176
+ .btn {
177
+ flex: 1;
178
+ padding: 14px var(--spacing-sm);
179
+ border-radius: var(--radius-sm);
180
+ font-size: var(--font-size-body);
181
+ font-weight: var(--font-weight-secondary);
182
+ cursor: pointer;
183
+ transition: all var(--transition-fast) var(--ease-spring);
184
+ border: 1px solid var(--color-border-soft);
185
+ background: linear-gradient(to bottom, var(--color-surface) 0%, rgba(255, 255, 255, 0.95) 100%);
186
+ color: var(--color-text-secondary);
187
+ box-shadow: var(--shadow-subtle);
188
+ letter-spacing: -0.01em;
189
+ }
190
+
191
+ .btn:active {
192
+ transform: scale(0.985);
193
+ }
194
+
195
+ .btn-cancel {
196
+ background: linear-gradient(to bottom, var(--color-bg) 0%, rgba(247, 241, 232, 0.8) 100%);
197
+ color: var(--color-text-primary);
198
+ border: 1px solid var(--color-border-soft);
199
+ }
200
+
201
+ .btn-cancel:hover {
202
+ background: linear-gradient(to bottom, var(--color-border) 0%, rgba(208, 196, 182, 0.5) 100%);
203
+ }
204
+
205
+ .btn-confirm {
206
+ background: linear-gradient(135deg, var(--color-brand) 0%, var(--color-brand-dark) 100%);
207
+ color: white;
208
+ box-shadow: 0 2px 4px rgba(210, 107, 90, 0.2);
209
+ border: none;
210
+ }
211
+
212
+ .btn-confirm:hover {
213
+ box-shadow: 0 4px 8px rgba(210, 107, 90, 0.25);
214
+ filter: brightness(1.05);
215
+ }
216
+
217
+ .btn-confirm.secondary {
218
+ background: linear-gradient(135deg, var(--color-success) 0%, rgba(90, 139, 106, 0.85) 100%);
219
+ box-shadow: 0 2px 4px rgba(90, 139, 106, 0.2);
220
+ border: none;
221
+ }
222
+
223
+ .btn-confirm.secondary:hover {
224
+ box-shadow: 0 4px 8px rgba(90, 139, 106, 0.25);
225
+ filter: brightness(1.05);
226
+ }
227
+
228
+ .btn-confirm.btn-danger {
229
+ background: linear-gradient(135deg, #c75642 0%, #9f392c 100%);
230
+ box-shadow: 0 2px 4px rgba(163, 51, 38, 0.24);
231
+ }
232
+
233
+ .btn-confirm.btn-danger:hover {
234
+ box-shadow: 0 4px 10px rgba(163, 51, 38, 0.28);
235
+ filter: brightness(1.04);
236
+ }
237
+
238
+ /* ============================================
239
+ 模型列表
240
+ ============================================ */
241
+ .model-list {
242
+ max-height: 200px;
243
+ overflow-y: auto;
244
+ border: 1px solid rgba(208, 196, 182, 0.4);
245
+ border-radius: var(--radius-sm);
246
+ margin-bottom: var(--spacing-sm);
247
+ scrollbar-width: none;
248
+ background: linear-gradient(to bottom, var(--color-surface) 0%, rgba(255, 255, 255, 0.8) 100%);
249
+ box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.02);
250
+ }
251
+
252
+ .model-list::-webkit-scrollbar {
253
+ display: none;
254
+ }
255
+
256
+ .model-item {
257
+ display: flex;
258
+ justify-content: space-between;
259
+ align-items: center;
260
+ padding: 11px var(--spacing-sm);
261
+ border-bottom: 1px solid rgba(208, 196, 182, 0.3);
262
+ font-size: var(--font-size-body);
263
+ color: var(--color-text-primary);
264
+ transition: all var(--transition-fast) var(--ease-spring);
265
+ letter-spacing: -0.005em;
266
+ }
267
+
268
+ .model-item:last-child {
269
+ border-bottom: none;
270
+ }
271
+
272
+ .model-item:hover {
273
+ background: linear-gradient(to right, rgba(247, 241, 232, 0.6) 0%, rgba(247, 241, 232, 0.3) 100%);
274
+ }
275
+
276
+ .btn-remove-model {
277
+ font-size: var(--font-size-caption);
278
+ font-weight: var(--font-weight-caption);
279
+ color: var(--color-text-tertiary);
280
+ cursor: pointer;
281
+ padding: 5px 10px;
282
+ border-radius: var(--radius-full);
283
+ transition: all var(--transition-fast) var(--ease-spring);
284
+ background: transparent;
285
+ border: 1px solid rgba(139, 118, 104, 0.2);
286
+ letter-spacing: 0.03em;
287
+ }
288
+
289
+ .btn-remove-model:hover {
290
+ background: linear-gradient(135deg, var(--color-error) 0%, rgba(200, 74, 58, 0.9) 100%);
291
+ color: white;
292
+ transform: scale(1.08);
293
+ box-shadow: 0 2px 6px rgba(200, 74, 58, 0.25);
294
+ border-color: transparent;
295
+ }
296
+
@@ -0,0 +1,335 @@
1
+ .agent-list {
2
+ display: flex;
3
+ flex-direction: column;
4
+ gap: var(--spacing-xs);
5
+ }
6
+
7
+ .agent-item {
8
+ border: 1px dashed var(--color-border-soft);
9
+ border-radius: var(--radius-sm);
10
+ padding: var(--spacing-xs);
11
+ background: var(--color-surface-alt);
12
+ }
13
+
14
+ .agent-header {
15
+ display: flex;
16
+ flex-wrap: wrap;
17
+ gap: var(--spacing-xs);
18
+ align-items: center;
19
+ margin-bottom: 6px;
20
+ }
21
+
22
+ .agent-name {
23
+ font-weight: var(--font-weight-secondary);
24
+ color: var(--color-text-secondary);
25
+ }
26
+
27
+ .agent-id {
28
+ font-size: var(--font-size-caption);
29
+ color: var(--color-text-tertiary);
30
+ }
31
+
32
+ .agent-meta {
33
+ display: flex;
34
+ flex-wrap: wrap;
35
+ gap: 8px;
36
+ font-size: var(--font-size-caption);
37
+ color: var(--color-text-secondary);
38
+ }
39
+
40
+ .skill-toolbar {
41
+ display: flex;
42
+ align-items: center;
43
+ justify-content: space-between;
44
+ gap: var(--spacing-xs);
45
+ margin-bottom: 10px;
46
+ flex-wrap: wrap;
47
+ }
48
+
49
+ .skill-select-all {
50
+ display: inline-flex;
51
+ align-items: center;
52
+ gap: 8px;
53
+ font-size: var(--font-size-secondary);
54
+ color: var(--color-text-secondary);
55
+ user-select: none;
56
+ }
57
+
58
+ .skill-toolbar-count {
59
+ font-size: var(--font-size-caption);
60
+ color: var(--color-text-tertiary);
61
+ }
62
+
63
+ .skills-modal {
64
+ width: min(96vw, 920px);
65
+ }
66
+
67
+ .skills-modal-header {
68
+ align-items: flex-start;
69
+ margin-bottom: var(--spacing-xs);
70
+ }
71
+
72
+ .skills-modal-subtitle {
73
+ margin-top: 6px;
74
+ font-size: var(--font-size-caption);
75
+ color: var(--color-text-tertiary);
76
+ line-height: 1.45;
77
+ }
78
+
79
+ .skills-modal-actions {
80
+ display: flex;
81
+ flex-direction: row;
82
+ align-items: center;
83
+ gap: 8px;
84
+ }
85
+
86
+ .skills-root-box {
87
+ border: 1px solid var(--color-border-soft);
88
+ border-radius: var(--radius-sm);
89
+ background: linear-gradient(to bottom, rgba(255, 255, 255, 0.86) 0%, rgba(255, 255, 255, 0.66) 100%);
90
+ padding: 10px 12px;
91
+ font-family: var(--font-family-mono);
92
+ font-size: var(--font-size-caption);
93
+ color: var(--color-text-secondary);
94
+ word-break: break-all;
95
+ }
96
+
97
+ .skills-root-group {
98
+ margin-bottom: var(--spacing-xs);
99
+ }
100
+
101
+ .skills-summary-strip {
102
+ display: grid;
103
+ grid-template-columns: repeat(4, minmax(0, 1fr));
104
+ gap: var(--spacing-xs);
105
+ margin-bottom: var(--spacing-sm);
106
+ }
107
+
108
+ .skills-summary-item {
109
+ border: 1px solid rgba(160, 145, 130, 0.2);
110
+ border-radius: var(--radius-sm);
111
+ background: linear-gradient(to bottom, rgba(255, 255, 255, 0.93) 0%, rgba(255, 255, 255, 0.78) 100%);
112
+ padding: 10px 12px;
113
+ min-width: 0;
114
+ box-shadow: var(--shadow-subtle);
115
+ display: flex;
116
+ flex-direction: column;
117
+ gap: 2px;
118
+ }
119
+
120
+ .skills-summary-label {
121
+ font-size: var(--font-size-caption);
122
+ color: var(--color-text-tertiary);
123
+ }
124
+
125
+ .skills-summary-value {
126
+ font-size: var(--font-size-large);
127
+ color: var(--color-text-secondary);
128
+ line-height: 1.2;
129
+ }
130
+
131
+ .skills-panel {
132
+ border: 1px solid rgba(160, 145, 130, 0.24);
133
+ border-radius: var(--radius-md);
134
+ padding: 12px;
135
+ background: linear-gradient(to bottom, rgba(255, 255, 255, 0.88) 0%, rgba(255, 255, 255, 0.72) 100%);
136
+ margin-bottom: var(--spacing-sm);
137
+ }
138
+
139
+ .skills-panel-header {
140
+ display: flex;
141
+ justify-content: space-between;
142
+ align-items: flex-start;
143
+ gap: var(--spacing-xs);
144
+ margin-bottom: 10px;
145
+ }
146
+
147
+ .skills-panel-title-wrap {
148
+ min-width: 0;
149
+ }
150
+
151
+ .skills-panel-title {
152
+ font-size: var(--font-size-body);
153
+ font-weight: var(--font-weight-primary);
154
+ color: var(--color-text-secondary);
155
+ }
156
+
157
+ .skills-panel-note {
158
+ margin-top: 4px;
159
+ font-size: var(--font-size-caption);
160
+ color: var(--color-text-tertiary);
161
+ line-height: 1.45;
162
+ }
163
+
164
+ .market-overview-section {
165
+ margin-bottom: var(--spacing-sm);
166
+ }
167
+
168
+ .market-overview-header {
169
+ gap: var(--spacing-sm);
170
+ align-items: flex-start;
171
+ }
172
+
173
+ .market-header-actions {
174
+ flex-wrap: wrap;
175
+ }
176
+
177
+ .market-target-switch {
178
+ display: flex;
179
+ flex-wrap: wrap;
180
+ gap: 8px;
181
+ margin-bottom: var(--spacing-sm);
182
+ }
183
+
184
+ .market-target-switch-compact {
185
+ justify-content: flex-end;
186
+ margin-bottom: 0;
187
+ }
188
+
189
+ .market-target-chip {
190
+ border: 1px solid rgba(160, 145, 130, 0.28);
191
+ border-radius: 999px;
192
+ background: rgba(255, 255, 255, 0.92);
193
+ color: var(--color-text-secondary);
194
+ padding: 8px 14px;
195
+ font-size: var(--font-size-caption);
196
+ font-weight: var(--font-weight-secondary);
197
+ cursor: pointer;
198
+ transition: border-color var(--transition-fast) var(--ease-smooth), background var(--transition-fast) var(--ease-smooth), color var(--transition-fast) var(--ease-smooth), box-shadow var(--transition-fast) var(--ease-smooth);
199
+ }
200
+
201
+ .market-target-chip:disabled,
202
+ .market-target-chip[disabled] {
203
+ cursor: not-allowed;
204
+ opacity: 0.64;
205
+ pointer-events: none;
206
+ box-shadow: none;
207
+ }
208
+
209
+ .market-target-chip.active {
210
+ border-color: rgba(208, 88, 58, 0.4);
211
+ background: linear-gradient(to bottom, rgba(255, 243, 236, 0.98) 0%, rgba(255, 232, 220, 0.86) 100%);
212
+ color: #8c3a1f;
213
+ box-shadow: var(--shadow-subtle);
214
+ }
215
+
216
+ .market-root-box {
217
+ margin-bottom: var(--spacing-sm);
218
+ }
219
+
220
+ .market-grid {
221
+ display: grid;
222
+ grid-template-columns: repeat(2, minmax(0, 1fr));
223
+ gap: var(--spacing-sm);
224
+ }
225
+
226
+ .market-panel {
227
+ margin-bottom: 0;
228
+ min-width: 0;
229
+ }
230
+
231
+ .market-actions-panel {
232
+ grid-column: 1 / -1;
233
+ }
234
+
235
+ .market-panel-wide {
236
+ grid-column: 1 / -1;
237
+ }
238
+
239
+ .market-preview-list {
240
+ display: grid;
241
+ gap: 10px;
242
+ }
243
+
244
+ .market-preview-item {
245
+ display: flex;
246
+ align-items: flex-start;
247
+ justify-content: space-between;
248
+ gap: var(--spacing-xs);
249
+ padding: 10px 12px;
250
+ border: 1px solid rgba(160, 145, 130, 0.18);
251
+ border-radius: var(--radius-sm);
252
+ background: rgba(255, 255, 255, 0.64);
253
+ }
254
+
255
+ .market-preview-main {
256
+ min-width: 0;
257
+ display: flex;
258
+ flex-direction: column;
259
+ gap: 4px;
260
+ }
261
+
262
+ .market-preview-title {
263
+ font-size: var(--font-size-body);
264
+ font-weight: var(--font-weight-secondary);
265
+ color: var(--color-text-secondary);
266
+ overflow-wrap: anywhere;
267
+ }
268
+
269
+ .market-preview-meta {
270
+ font-size: var(--font-size-caption);
271
+ color: var(--color-text-tertiary);
272
+ line-height: 1.45;
273
+ overflow-wrap: anywhere;
274
+ }
275
+
276
+ .market-action-grid {
277
+ display: grid;
278
+ grid-template-columns: repeat(3, minmax(0, 1fr));
279
+ gap: var(--spacing-xs);
280
+ }
281
+
282
+ .market-action-card {
283
+ border: 1px solid rgba(160, 145, 130, 0.24);
284
+ border-radius: var(--radius-sm);
285
+ background: linear-gradient(to bottom, rgba(255, 255, 255, 0.96) 0%, rgba(255, 248, 242, 0.84) 100%);
286
+ color: var(--color-text-secondary);
287
+ text-align: left;
288
+ padding: 14px;
289
+ display: flex;
290
+ flex-direction: column;
291
+ gap: 6px;
292
+ cursor: pointer;
293
+ transition: transform var(--transition-fast) var(--ease-smooth), box-shadow var(--transition-fast) var(--ease-smooth), border-color var(--transition-fast) var(--ease-smooth);
294
+ }
295
+
296
+ .market-action-card:hover:not(:disabled) {
297
+ transform: translateY(-1px);
298
+ border-color: rgba(208, 88, 58, 0.34);
299
+ box-shadow: var(--shadow-subtle);
300
+ }
301
+
302
+ .market-action-card:disabled {
303
+ cursor: not-allowed;
304
+ opacity: 0.64;
305
+ }
306
+
307
+ .market-action-title {
308
+ font-size: var(--font-size-body);
309
+ font-weight: var(--font-weight-secondary);
310
+ }
311
+
312
+ .market-action-copy {
313
+ font-size: var(--font-size-caption);
314
+ color: var(--color-text-tertiary);
315
+ line-height: 1.45;
316
+ }
317
+
318
+ .skills-filter-row {
319
+ display: flex;
320
+ gap: var(--spacing-xs);
321
+ margin-bottom: 10px;
322
+ align-items: center;
323
+ flex-wrap: wrap;
324
+ }
325
+
326
+ .skills-filter-row .form-input {
327
+ flex: 1;
328
+ min-width: 220px;
329
+ }
330
+
331
+ .skills-status-select {
332
+ width: 210px;
333
+ flex: 0 0 auto;
334
+ }
335
+