agent-scope 0.5.1 → 0.5.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 (42) hide show
  1. package/README.md +10 -5
  2. package/dist/cli.js +1 -1
  3. package/dist/public/404/index.html +1 -1
  4. package/dist/public/404.html +1 -1
  5. package/dist/public/__next.__PAGE__.txt +2 -2
  6. package/dist/public/__next._full.txt +3 -3
  7. package/dist/public/__next._head.txt +1 -1
  8. package/dist/public/__next._index.txt +2 -2
  9. package/dist/public/__next._tree.txt +2 -2
  10. package/dist/public/_next/static/chunks/bfa1988f6340e536.css +2 -0
  11. package/dist/public/_next/static/chunks/d9f65f2b51efa168.js +2 -0
  12. package/dist/public/_not-found/__next._full.txt +2 -2
  13. package/dist/public/_not-found/__next._head.txt +1 -1
  14. package/dist/public/_not-found/__next._index.txt +2 -2
  15. package/dist/public/_not-found/__next._not-found.__PAGE__.txt +1 -1
  16. package/dist/public/_not-found/__next._not-found.txt +1 -1
  17. package/dist/public/_not-found/__next._tree.txt +2 -2
  18. package/dist/public/_not-found/index.html +1 -1
  19. package/dist/public/_not-found/index.txt +2 -2
  20. package/dist/public/index.html +1 -1
  21. package/dist/public/index.txt +3 -3
  22. package/dist/server/routes/live.d.ts +9 -0
  23. package/dist/server/routes/live.d.ts.map +1 -0
  24. package/dist/server/routes/live.js +53 -0
  25. package/dist/server/routes/live.js.map +1 -0
  26. package/dist/server/routes/observability.d.ts +6 -0
  27. package/dist/server/routes/observability.d.ts.map +1 -0
  28. package/dist/server/routes/observability.js +18 -0
  29. package/dist/server/routes/observability.js.map +1 -0
  30. package/dist/server/routes/plan.d.ts +7 -0
  31. package/dist/server/routes/plan.d.ts.map +1 -0
  32. package/dist/server/routes/plan.js +134 -0
  33. package/dist/server/routes/plan.js.map +1 -0
  34. package/dist/server/server.d.ts.map +1 -1
  35. package/dist/server/server.js +14 -268
  36. package/dist/server/server.js.map +1 -1
  37. package/package.json +1 -1
  38. package/dist/public/_next/static/chunks/9d942f371db80ae5.css +0 -2
  39. package/dist/public/_next/static/chunks/ac8ad6bf034ff528.js +0 -2
  40. /package/dist/public/_next/static/{u4-iykRCgYzYIvXiFEi6J → UOQywBBR87e2cRZshQP60}/_buildManifest.js +0 -0
  41. /package/dist/public/_next/static/{u4-iykRCgYzYIvXiFEi6J → UOQywBBR87e2cRZshQP60}/_clientMiddlewareManifest.json +0 -0
  42. /package/dist/public/_next/static/{u4-iykRCgYzYIvXiFEi6J → UOQywBBR87e2cRZshQP60}/_ssgManifest.js +0 -0
@@ -1,282 +1,29 @@
1
1
  import Fastify from 'fastify';
2
2
  import cors from '@fastify/cors';
3
3
  import staticPlugin from '@fastify/static';
4
- import { readFileSync, existsSync } from 'fs';
4
+ import { existsSync } from 'fs';
5
5
  import { join, dirname } from 'path';
6
6
  import { fileURLToPath } from 'url';
7
- import { parseQueue } from '../core/queueParser.js';
8
- import { parseLog } from '../core/logParser.js';
9
- import { computeSnapshot } from '../core/stateEngine.js';
10
- import { computePlanInsights, computeLiveInsights } from '../core/insightsEngine.js';
11
- import { readSessions } from '../core/todoReader.js';
12
- import { parseQualityTimeline } from '../core/qualityTimeline.js';
13
- import { buildContextHealth } from '../core/contextHealth.js';
14
- import { detectWorktrees, enrichWorktreeStatus } from '../core/worktreeDetector.js';
15
- import { mapTasksToWorktrees } from '../core/worktreeMapper.js';
16
7
  import { createWatcher } from './watcher.js';
8
+ import { liveRoutes } from './routes/live.js';
9
+ import { planRoutes } from './routes/plan.js';
10
+ import { observabilityRoutes } from './routes/observability.js';
17
11
  const __filename = fileURLToPath(import.meta.url);
18
12
  const __dirname = dirname(__filename);
19
13
  export async function startServer(options) {
20
14
  const { claudeDir, port, agentScopeDir } = options;
21
- const fastify = Fastify({
22
- logger: false,
23
- ignoreTrailingSlash: true
24
- });
25
- // Enable CORS
26
- await fastify.register(cors, {
27
- origin: true
28
- });
29
- // Setup file watcher
30
- const { watcher, emitter } = createWatcher({
31
- claudeDir,
32
- agentScopeDir
33
- });
34
- // Track SSE clients
35
- const sseClients = new Set();
36
- emitter.on('change', (event) => {
37
- for (const send of sseClients) {
38
- send(event);
39
- }
40
- });
41
- // Cleanup on server close
42
- fastify.addHook('onClose', async () => {
43
- await watcher.close();
44
- });
45
- // Health check endpoint
46
- fastify.get('/health', async () => {
47
- const hasLive = existsSync(join(claudeDir, 'tasks')) || existsSync(join(claudeDir, 'todos'));
48
- const hasPlan = agentScopeDir ? existsSync(join(agentScopeDir, 'queue.md')) : false;
49
- return { status: 'ok', modes: { live: hasLive, plan: hasPlan } };
50
- });
51
- // SSE endpoint for real-time updates
52
- fastify.get('/events', async (_request, reply) => {
53
- reply.raw.writeHead(200, {
54
- 'Content-Type': 'text/event-stream',
55
- 'Cache-Control': 'no-cache',
56
- 'Connection': 'keep-alive',
57
- 'Access-Control-Allow-Origin': '*'
58
- });
59
- // Send initial connection event
60
- reply.raw.write(`data: ${JSON.stringify({ type: 'connected', timestamp: new Date().toISOString() })}\n\n`);
61
- const send = (event) => {
62
- reply.raw.write(`data: ${JSON.stringify(event)}\n\n`);
63
- };
64
- sseClients.add(send);
65
- // Keep-alive ping every 30s
66
- const pingInterval = setInterval(() => {
67
- reply.raw.write(`: ping\n\n`);
68
- }, 30000);
69
- _request.raw.on('close', () => {
70
- sseClients.delete(send);
71
- clearInterval(pingInterval);
72
- });
73
- // Don't end the response - keep it open for SSE
74
- await new Promise(() => { }); // never resolves
75
- });
76
- // Live mode: List all sessions
77
- fastify.get('/sessions', async () => {
78
- const sessions = readSessions(claudeDir).map(s => ({
79
- ...s,
80
- contextHealth: buildContextHealth(s),
81
- }));
82
- return { sessions };
83
- });
84
- // Live mode: Get tasks for a specific session
85
- fastify.get('/sessions/:id', async (request) => {
86
- const sessions = readSessions(claudeDir);
87
- const found = sessions.find(s => s.id === request.params.id);
88
- if (!found) {
89
- return { session: null, error: 'Session not found' };
90
- }
91
- const session = { ...found, contextHealth: buildContextHealth(found) };
92
- return { session };
93
- });
94
- // Plan mode: Snapshot endpoint (existing functionality)
95
- fastify.get('/snapshot', async () => {
96
- if (!agentScopeDir) {
97
- return {
98
- snapshot: null,
99
- queueErrors: ['Plan mode not configured. Run "agent-scope init" first.'],
100
- logErrors: [],
101
- meta: { generatedAt: new Date().toISOString(), totalTasks: 0 }
102
- };
103
- }
104
- const queuePath = join(agentScopeDir, 'queue.md');
105
- const logPath = join(agentScopeDir, 'execution.log');
106
- if (!existsSync(queuePath)) {
107
- return {
108
- snapshot: null,
109
- queueErrors: ['queue.md not found'],
110
- logErrors: [],
111
- meta: { generatedAt: new Date().toISOString(), totalTasks: 0 }
112
- };
113
- }
114
- // Read config for queue parse patterns
115
- const configPath = join(agentScopeDir, 'config.json');
116
- let queueParseConfig;
117
- if (existsSync(configPath)) {
118
- try {
119
- const configData = JSON.parse(readFileSync(configPath, 'utf-8'));
120
- if (configData.taskModel) {
121
- queueParseConfig = {
122
- id: configData.taskModel.id,
123
- headings: configData.taskModel.headings,
124
- fields: configData.taskModel.fields
125
- };
126
- }
127
- }
128
- catch { /* use defaults */ }
129
- }
130
- // Read and parse queue
131
- const queueContent = readFileSync(queuePath, 'utf-8');
132
- const queueResult = parseQueue(queueContent, queueParseConfig);
133
- if (queueResult.errors.length > 0) {
134
- return {
135
- snapshot: null,
136
- queueErrors: queueResult.errors,
137
- logErrors: [],
138
- meta: { generatedAt: new Date().toISOString(), totalTasks: 0 }
139
- };
140
- }
141
- // Read and parse log
142
- let logResult = parseLog('');
143
- if (existsSync(logPath)) {
144
- const logContent = readFileSync(logPath, 'utf-8');
145
- logResult = parseLog(logContent);
146
- }
147
- // Compute snapshot
148
- let snapshot = null;
149
- try {
150
- snapshot = computeSnapshot(queueResult.tasks, logResult.events);
151
- }
152
- catch (error) {
153
- return {
154
- snapshot: null,
155
- queueErrors: [`Failed to compute snapshot: ${error}`],
156
- logErrors: logResult.errors,
157
- meta: { generatedAt: new Date().toISOString(), totalTasks: queueResult.tasks.length }
158
- };
159
- }
160
- return {
161
- snapshot,
162
- queueErrors: [],
163
- logErrors: logResult.errors,
164
- meta: { generatedAt: new Date().toISOString(), totalTasks: queueResult.tasks.length }
165
- };
166
- });
167
- // Insights endpoint - analytics for both Live and Plan modes
168
- fastify.get('/insights', async () => {
169
- const hasLive = existsSync(join(claudeDir, 'tasks')) || existsSync(join(claudeDir, 'todos'));
170
- const hasPlan = agentScopeDir ? existsSync(join(agentScopeDir, 'queue.md')) : false;
171
- const response = {
172
- mode: hasLive && hasPlan ? 'both' : hasLive ? 'live' : 'plan',
173
- generatedAt: new Date().toISOString(),
174
- };
175
- // Compute Live insights
176
- if (hasLive) {
177
- const sessions = readSessions(claudeDir);
178
- response.live = computeLiveInsights(sessions);
179
- }
180
- // Compute Plan insights
181
- if (hasPlan && agentScopeDir) {
182
- const queuePath = join(agentScopeDir, 'queue.md');
183
- const logPath = join(agentScopeDir, 'execution.log');
184
- if (existsSync(queuePath)) {
185
- // Read config for queue parse patterns
186
- const configPath = join(agentScopeDir, 'config.json');
187
- let queueParseConfig;
188
- if (existsSync(configPath)) {
189
- try {
190
- const configData = JSON.parse(readFileSync(configPath, 'utf-8'));
191
- if (configData.taskModel) {
192
- queueParseConfig = {
193
- id: configData.taskModel.id,
194
- headings: configData.taskModel.headings,
195
- fields: configData.taskModel.fields
196
- };
197
- }
198
- }
199
- catch { /* use defaults */ }
200
- }
201
- // Parse queue
202
- const queueContent = readFileSync(queuePath, 'utf-8');
203
- const queueResult = parseQueue(queueContent, queueParseConfig);
204
- if (queueResult.errors.length === 0) {
205
- // Parse log
206
- let logResult = parseLog('');
207
- if (existsSync(logPath)) {
208
- const logContent = readFileSync(logPath, 'utf-8');
209
- logResult = parseLog(logContent);
210
- }
211
- // Compute snapshot first, then insights
212
- try {
213
- const snapshot = computeSnapshot(queueResult.tasks, logResult.events);
214
- response.plan = computePlanInsights(snapshot.tasks, logResult.events);
215
- }
216
- catch { /* skip plan insights on error */ }
217
- }
218
- }
219
- }
220
- return response;
221
- });
222
- // Worktree Observability: list all worktrees with task associations
223
- fastify.get('/worktrees', async () => {
224
- try {
225
- const raw = await detectWorktrees(process.cwd());
226
- const enriched = await Promise.all(raw.map(w => enrichWorktreeStatus(w)));
227
- const sessions = readSessions(claudeDir);
228
- const worktrees = mapTasksToWorktrees(sessions, enriched);
229
- return { worktrees };
230
- }
231
- catch {
232
- return { worktrees: [] };
233
- }
234
- });
235
- // Quality Gates: timeline endpoint
236
- fastify.get('/quality-timeline', async (request) => {
237
- if (!agentScopeDir) {
238
- return { events: [] };
239
- }
240
- const logPath = join(agentScopeDir, 'execution.log');
241
- if (!existsSync(logPath)) {
242
- return { events: [] };
243
- }
244
- let logContent;
245
- try {
246
- logContent = readFileSync(logPath, 'utf-8');
247
- }
248
- catch {
249
- return { events: [] };
250
- }
251
- let events = parseQualityTimeline(logContent);
252
- const { taskId } = request.query;
253
- if (taskId) {
254
- events = events.filter(e => e.taskId === taskId);
255
- }
256
- return { events };
257
- });
258
- // Claude Code insights report endpoint
259
- fastify.get('/claude-insights', async (_request, reply) => {
260
- const reportPath = join(claudeDir, 'usage-data', 'report.html');
261
- if (!existsSync(reportPath)) {
262
- return reply.code(404).send({
263
- error: 'Claude insights report not found',
264
- hint: 'Run /insight command in Claude Code to generate the report'
265
- });
266
- }
267
- reply.type('text/html');
268
- return reply.sendFile('usage-data/report.html', join(claudeDir));
269
- });
270
- // Serve static files and SPA
15
+ const fastify = Fastify({ logger: false, ignoreTrailingSlash: true });
16
+ await fastify.register(cors, { origin: true });
17
+ const { watcher, emitter } = createWatcher({ claudeDir, agentScopeDir });
18
+ fastify.addHook('onClose', async () => { await watcher.close(); });
19
+ await fastify.register(liveRoutes, { claudeDir, agentScopeDir, emitter });
20
+ await fastify.register(planRoutes, { claudeDir, agentScopeDir });
21
+ await fastify.register(observabilityRoutes, { claudeDir });
22
+ // Serve static dashboard + SPA fallback
271
23
  const publicPath = join(__dirname, '../public');
272
24
  if (existsSync(publicPath)) {
273
- await fastify.register(staticPlugin, {
274
- root: publicPath,
275
- prefix: '/'
276
- });
277
- fastify.get('/', async (_request, reply) => {
278
- return reply.sendFile('index.html');
279
- });
25
+ await fastify.register(staticPlugin, { root: publicPath, prefix: '/' });
26
+ fastify.get('/', async (_request, reply) => reply.sendFile('index.html'));
280
27
  fastify.setNotFoundHandler(async (_request, reply) => {
281
28
  if (_request.url.startsWith('/api/') || _request.url.match(/\.\w+$/)) {
282
29
  return reply.code(404).send({ error: 'Not found' });
@@ -284,7 +31,6 @@ export async function startServer(options) {
284
31
  return reply.sendFile('index.html');
285
32
  });
286
33
  }
287
- // Start server
288
34
  try {
289
35
  await fastify.listen({ port, host: '0.0.0.0' });
290
36
  }
@@ -1 +1 @@
1
- {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/server/server.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/server/server.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "agent-scope",
3
- "version": "0.5.1",
3
+ "version": "0.5.2",
4
4
  "description": "Deterministic, local, passive execution observer for AI agent workflows",
5
5
  "type": "module",
6
6
  "bin": {
@@ -1,2 +0,0 @@
1
- @import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap";
2
- *,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:JetBrains Mono,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--font-size:16px;--background:#fff;--foreground:#0a0a0a;--card:#fff;--card-foreground:#0a0a0a;--popover:#fff;--popover-foreground:#0a0a0a;--primary:#030213;--primary-foreground:#fff;--secondary:#f0f0f3;--secondary-foreground:#030213;--muted:#ececf0;--muted-foreground:#717182;--accent:#e9ebef;--accent-foreground:#030213;--destructive:#d4183d;--destructive-foreground:#fff;--border:#0000001a;--input:transparent;--input-background:#f3f3f5;--ring:#b0b0b0;--radius:.625rem;--chart-1:#e06030;--chart-2:#2aa08a;--chart-3:#3a6080;--chart-4:#d0a030;--chart-5:#c09030;--sidebar:#f8f8f8;--sidebar-foreground:#0a0a0a;--sidebar-primary:#030213;--sidebar-primary-foreground:#f8f8f8;--sidebar-accent:#f0f0f0;--sidebar-accent-foreground:#1a1a1a;--sidebar-border:#e0e0e0;--sidebar-ring:#b0b0b0}.dark{--background:#1a1a1a;--foreground:#f5f5f5;--card:#1a1a1a;--card-foreground:#f5f5f5;--popover:#1a1a1a;--popover-foreground:#f5f5f5;--primary:#f5f5f5;--primary-foreground:#1a1a1a;--secondary:#2a2a2a;--secondary-foreground:#f5f5f5;--muted:#2a2a2a;--muted-foreground:#a0a0a0;--accent:#2a2a2a;--accent-foreground:#f5f5f5;--destructive:#7f1d1d;--destructive-foreground:#ef4444;--border:#2a2a2a;--input:#2a2a2a;--ring:#555;--chart-1:#3b82f6;--chart-2:#22c55e;--chart-3:#f59e0b;--chart-4:#a855f7;--chart-5:#ef4444;--sidebar:#1e1e1e;--sidebar-foreground:#f5f5f5;--sidebar-primary:#3b82f6;--sidebar-primary-foreground:#f5f5f5;--sidebar-accent:#2a2a2a;--sidebar-accent-foreground:#f5f5f5;--sidebar-border:#2a2a2a;--sidebar-ring:#555}*{border-color:var(--border)}html{font-size:var(--font-size)}body{color:var(--foreground);background:var(--background);font-feature-settings:"rlig" 1,"calt" 1;font-family:JetBrains Mono,monospace}.absolute{position:absolute}.relative{position:relative}.left-3{left:.75rem}.top-1\/2{top:50%}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-auto{margin-left:auto}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-8{margin-top:2rem}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.size-16{width:4rem;height:4rem}.size-2{width:.5rem;height:.5rem}.size-2\.5{width:.625rem;height:.625rem}.size-3{width:.75rem;height:.75rem}.size-3\.5{width:.875rem;height:.875rem}.size-4{width:1rem;height:1rem}.size-full{width:100%;height:100%}.h-1\.5{height:.375rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-8{height:2rem}.h-full{height:100%}.h-screen{height:100vh}.w-0{width:0}.w-1\/2{width:50%}.w-2\.5{width:.625rem}.w-48{width:12rem}.w-\[220px\]{width:220px}.w-\[25\%\]{width:25%}.w-\[350px\]{width:350px}.w-full{width:100%}.min-w-0{min-width:0}.min-w-\[250px\]{min-width:250px}.min-w-\[280px\]{min-width:280px}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.max-w-\[120px\]{max-width:120px}.flex-1{flex:1}.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y))rotate(var(--tw-rotate))skewX(var(--tw-skew-x))skewY(var(--tw-skew-y))scaleX(var(--tw-scale-x))scaleY(var(--tw-scale-y))}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}.animate-ping{animation:1s cubic-bezier(0,0,.2,1) infinite ping}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;user-select:none}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem*calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem*var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem*calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem*var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem*calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem*var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem*calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem*var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.\!overflow-y-auto{overflow-y:auto!important}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.whitespace-pre-wrap{white-space:pre-wrap}.rounded{border-radius:.25rem}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.border{border-width:1px}.border-0{border-width:0}.border-b{border-bottom-width:1px}.border-l{border-left-width:1px}.border-r{border-right-width:1px}.border-r-0{border-right-width:0}.border-t{border-top-width:1px}.border-border{border-color:var(--border)}.border-destructive{border-color:var(--destructive)}.border-ring{border-color:var(--ring)}.border-sidebar-border{border-color:var(--sidebar-border)}.border-transparent{border-color:#0000}.border-l-transparent{border-left-color:#0000}.border-t-transparent{border-top-color:#0000}.bg-accent{background-color:var(--accent)}.bg-background{background-color:var(--background)}.bg-border{background-color:var(--border)}.bg-card{background-color:var(--card)}.bg-chart-1{background-color:var(--chart-1)}.bg-chart-2{background-color:var(--chart-2)}.bg-chart-3{background-color:var(--chart-3)}.bg-chart-4{background-color:var(--chart-4)}.bg-chart-5{background-color:var(--chart-5)}.bg-muted{background-color:var(--muted)}.bg-muted-foreground{background-color:var(--muted-foreground)}.bg-sidebar{background-color:var(--sidebar)}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-px{padding:1px}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-3{padding-bottom:.75rem}.pl-8{padding-left:2rem}.pr-1{padding-right:.25rem}.pr-3{padding-right:.75rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:JetBrains Mono,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[10px\]{font-size:10px}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.tracking-wide{letter-spacing:.025em}.text-chart-1{color:var(--chart-1)}.text-chart-2{color:var(--chart-2)}.text-chart-3{color:var(--chart-3)}.text-chart-4{color:var(--chart-4)}.text-chart-5{color:var(--chart-5)}.text-destructive-foreground{color:var(--destructive-foreground)}.text-foreground{color:var(--foreground)}.text-muted-foreground{color:var(--muted-foreground)}.text-primary{color:var(--primary)}.placeholder-muted-foreground::placeholder{color:var(--muted-foreground)}.opacity-75{opacity:.75}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline-none{outline-offset:2px;outline:2px solid #0000}.filter{filter:var(--tw-blur)var(--tw-brightness)var(--tw-contrast)var(--tw-grayscale)var(--tw-hue-rotate)var(--tw-invert)var(--tw-saturate)var(--tw-sepia)var(--tw-drop-shadow)}.transition-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-300{transition-duration:.3s}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--sidebar)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}@keyframes blink-caret{0%,to{border-color:#0000}50%{border-color:var(--muted-foreground)}}.typing-cursor{border-right:2px solid var(--muted-foreground);animation:.8s step-end infinite blink-caret}.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-sidebar-accent:hover{background-color:var(--sidebar-accent)}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:underline:hover{text-decoration-line:underline}.focus\:border-ring:focus{border-color:var(--ring)}.focus\:outline-none:focus{outline-offset:2px;outline:2px solid #0000}.focus-visible\:outline-1:focus-visible{outline-width:1px}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset)0 0 0 calc(3px + var(--tw-ring-offset-width))var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.\[\&\>div\]\:\!block>div{display:block!important}