claude-remote-cli 3.0.2 → 3.0.4

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.
@@ -0,0 +1,164 @@
1
+ import { describe, it } from 'node:test';
2
+ import assert from 'node:assert/strict';
3
+ import { derivePrAction, getActionPrompt, getStatusCssVar, shouldUseDarkText } from '../frontend/src/lib/pr-state.js';
4
+ describe('derivePrAction', () => {
5
+ it('returns none when no commits ahead and no PR', () => {
6
+ const input = {
7
+ commitsAhead: 0,
8
+ prState: null,
9
+ ciPassing: 0, ciFailing: 0, ciPending: 0, ciTotal: 0,
10
+ };
11
+ const action = derivePrAction(input);
12
+ assert.equal(action.type, 'none');
13
+ assert.equal(action.color, 'none');
14
+ assert.equal(action.label, '');
15
+ });
16
+ it('returns create-pr when commits ahead but no PR', () => {
17
+ const input = {
18
+ commitsAhead: 3,
19
+ prState: null,
20
+ ciPassing: 0, ciFailing: 0, ciPending: 0, ciTotal: 0,
21
+ };
22
+ const action = derivePrAction(input);
23
+ assert.equal(action.type, 'create-pr');
24
+ assert.equal(action.color, 'accent');
25
+ assert.equal(action.label, 'Create PR');
26
+ });
27
+ it('returns ready-for-review for draft PR', () => {
28
+ const input = {
29
+ commitsAhead: 5,
30
+ prState: 'DRAFT',
31
+ ciPassing: 0, ciFailing: 0, ciPending: 0, ciTotal: 0,
32
+ };
33
+ const action = derivePrAction(input);
34
+ assert.equal(action.type, 'ready-for-review');
35
+ assert.equal(action.color, 'muted');
36
+ assert.equal(action.label, 'Ready for Review');
37
+ });
38
+ it('returns code-review for open PR with all CI passing', () => {
39
+ const input = {
40
+ commitsAhead: 2,
41
+ prState: 'OPEN',
42
+ ciPassing: 5, ciFailing: 0, ciPending: 0, ciTotal: 5,
43
+ };
44
+ const action = derivePrAction(input);
45
+ assert.equal(action.type, 'code-review');
46
+ assert.equal(action.color, 'success');
47
+ assert.equal(action.label, 'Code Review');
48
+ });
49
+ it('returns code-review for open PR with no CI checks', () => {
50
+ const input = {
51
+ commitsAhead: 1,
52
+ prState: 'OPEN',
53
+ ciPassing: 0, ciFailing: 0, ciPending: 0, ciTotal: 0,
54
+ };
55
+ const action = derivePrAction(input);
56
+ assert.equal(action.type, 'code-review');
57
+ assert.equal(action.color, 'success');
58
+ });
59
+ it('returns fix-errors for open PR with failing CI', () => {
60
+ const input = {
61
+ commitsAhead: 2,
62
+ prState: 'OPEN',
63
+ ciPassing: 6, ciFailing: 2, ciPending: 0, ciTotal: 8,
64
+ };
65
+ const action = derivePrAction(input);
66
+ assert.equal(action.type, 'fix-errors');
67
+ assert.equal(action.color, 'error');
68
+ assert.equal(action.label, 'Fix Errors 2/8');
69
+ });
70
+ it('returns checks-running for open PR with pending CI', () => {
71
+ const input = {
72
+ commitsAhead: 1,
73
+ prState: 'OPEN',
74
+ ciPassing: 3, ciFailing: 0, ciPending: 2, ciTotal: 5,
75
+ };
76
+ const action = derivePrAction(input);
77
+ assert.equal(action.type, 'checks-running');
78
+ assert.equal(action.color, 'warning');
79
+ assert.equal(action.label, 'Checks Running...');
80
+ });
81
+ it('prioritizes failing over pending CI', () => {
82
+ const input = {
83
+ commitsAhead: 1,
84
+ prState: 'OPEN',
85
+ ciPassing: 3, ciFailing: 1, ciPending: 1, ciTotal: 5,
86
+ };
87
+ const action = derivePrAction(input);
88
+ assert.equal(action.type, 'fix-errors');
89
+ assert.equal(action.label, 'Fix Errors 1/5');
90
+ });
91
+ it('returns archive-merged for merged PR', () => {
92
+ const input = {
93
+ commitsAhead: 0,
94
+ prState: 'MERGED',
95
+ ciPassing: 5, ciFailing: 0, ciPending: 0, ciTotal: 5,
96
+ };
97
+ const action = derivePrAction(input);
98
+ assert.equal(action.type, 'archive-merged');
99
+ assert.equal(action.color, 'merged');
100
+ assert.equal(action.label, 'Archive');
101
+ });
102
+ it('returns archive-closed for closed PR', () => {
103
+ const input = {
104
+ commitsAhead: 0,
105
+ prState: 'CLOSED',
106
+ ciPassing: 0, ciFailing: 0, ciPending: 0, ciTotal: 0,
107
+ };
108
+ const action = derivePrAction(input);
109
+ assert.equal(action.type, 'archive-closed');
110
+ assert.equal(action.color, 'muted');
111
+ assert.equal(action.label, 'Archive');
112
+ });
113
+ });
114
+ describe('getActionPrompt', () => {
115
+ it('returns prompt for create-pr', () => {
116
+ const prompt = getActionPrompt({ type: 'create-pr', color: 'accent', label: 'Create PR' }, 'feat/my-feature');
117
+ assert.ok(prompt);
118
+ assert.ok(prompt.includes('feat/my-feature'));
119
+ assert.ok(prompt.includes('pull request'));
120
+ });
121
+ it('returns prompt for fix-errors', () => {
122
+ const prompt = getActionPrompt({ type: 'fix-errors', color: 'error', label: 'Fix Errors 2/8' }, 'bugfix/auth');
123
+ assert.ok(prompt);
124
+ assert.ok(prompt.includes('bugfix/auth'));
125
+ assert.ok(prompt.includes('failing'));
126
+ });
127
+ it('returns prompt for code-review', () => {
128
+ const prompt = getActionPrompt({ type: 'code-review', color: 'success', label: 'Code Review' }, 'main');
129
+ assert.ok(prompt);
130
+ assert.ok(prompt.includes('Review'));
131
+ });
132
+ it('returns null for archive actions', () => {
133
+ assert.equal(getActionPrompt({ type: 'archive-merged', color: 'merged', label: 'Archive' }, 'main'), null);
134
+ assert.equal(getActionPrompt({ type: 'archive-closed', color: 'muted', label: 'Archive' }, 'main'), null);
135
+ });
136
+ it('returns null for none and checks-running', () => {
137
+ assert.equal(getActionPrompt({ type: 'none', color: 'none', label: '' }, 'main'), null);
138
+ assert.equal(getActionPrompt({ type: 'checks-running', color: 'warning', label: 'Checks Running...' }, 'main'), null);
139
+ });
140
+ });
141
+ describe('getStatusCssVar', () => {
142
+ it('maps all colors correctly', () => {
143
+ assert.equal(getStatusCssVar('accent'), 'var(--accent)');
144
+ assert.equal(getStatusCssVar('success'), 'var(--status-success)');
145
+ assert.equal(getStatusCssVar('error'), 'var(--status-error)');
146
+ assert.equal(getStatusCssVar('warning'), 'var(--status-warning)');
147
+ assert.equal(getStatusCssVar('merged'), 'var(--status-merged)');
148
+ assert.equal(getStatusCssVar('muted'), 'var(--border)');
149
+ assert.equal(getStatusCssVar('none'), 'transparent');
150
+ });
151
+ });
152
+ describe('shouldUseDarkText', () => {
153
+ it('returns true for success and warning (light backgrounds)', () => {
154
+ assert.equal(shouldUseDarkText('success'), true);
155
+ assert.equal(shouldUseDarkText('warning'), true);
156
+ });
157
+ it('returns false for dark backgrounds', () => {
158
+ assert.equal(shouldUseDarkText('accent'), false);
159
+ assert.equal(shouldUseDarkText('error'), false);
160
+ assert.equal(shouldUseDarkText('merged'), false);
161
+ assert.equal(shouldUseDarkText('muted'), false);
162
+ assert.equal(shouldUseDarkText('none'), false);
163
+ });
164
+ });
@@ -13,7 +13,7 @@ describe('PullRequest types', () => {
13
13
  updatedAt: '2026-02-24T00:00:00Z',
14
14
  additions: 10,
15
15
  deletions: 5,
16
- reviewDecision: 'APPROVED',
16
+ reviewDecision: 'APPROVED', mergeable: 'MERGEABLE',
17
17
  };
18
18
  assert.equal(pr.role, 'author');
19
19
  assert.equal(pr.state, 'OPEN');
@@ -30,7 +30,7 @@ describe('PullRequest types', () => {
30
30
  updatedAt: '2026-02-24T00:00:00Z',
31
31
  additions: 50,
32
32
  deletions: 20,
33
- reviewDecision: null,
33
+ reviewDecision: null, mergeable: null,
34
34
  };
35
35
  assert.equal(pr.role, 'reviewer');
36
36
  });
@@ -55,7 +55,7 @@ describe('PullRequest types', () => {
55
55
  updatedAt: '2026-02-24T00:00:00Z',
56
56
  additions: 0,
57
57
  deletions: 0,
58
- reviewDecision: null,
58
+ reviewDecision: null, mergeable: null,
59
59
  }],
60
60
  };
61
61
  assert.equal(response.prs.length, 1);
@@ -60,7 +60,6 @@ describe('sessions', () => {
60
60
  assert.ok(session, 'should return the session');
61
61
  assert.strictEqual(session.id, result.id);
62
62
  assert.strictEqual(session.repoName, 'test-repo');
63
- assert.strictEqual(session.mode, 'pty');
64
63
  assert.ok(session.pty, 'get should include the pty object');
65
64
  });
66
65
  it('get returns undefined for nonexistent id', () => {
@@ -101,10 +100,8 @@ describe('sessions', () => {
101
100
  createdIds.push(result.id);
102
101
  const session = sessions.get(result.id);
103
102
  assert.ok(session);
104
- assert.strictEqual(session.mode, 'pty');
105
- const ptySession = session;
106
103
  let output = '';
107
- ptySession.pty.onData((data) => {
104
+ session.pty.onData((data) => {
108
105
  output += data;
109
106
  if (output.includes('hello')) {
110
107
  done();
@@ -391,11 +388,9 @@ describe('sessions', () => {
391
388
  createdIds.push(result.id);
392
389
  const session = sessions.get(result.id);
393
390
  assert.ok(session);
394
- assert.strictEqual(session.mode, 'pty');
395
- const ptySession = session;
396
- ptySession.onPtyReplacedCallbacks.push((newPty) => {
391
+ session.onPtyReplacedCallbacks.push((newPty) => {
397
392
  assert.ok(newPty, 'should receive new PTY');
398
- assert.strictEqual(ptySession.pty, newPty, 'session.pty should be updated to new PTY');
393
+ assert.strictEqual(session.pty, newPty, 'session.pty should be updated to new PTY');
399
394
  done();
400
395
  });
401
396
  });
@@ -409,9 +404,7 @@ describe('sessions', () => {
409
404
  createdIds.push(result.id);
410
405
  const session = sessions.get(result.id);
411
406
  assert.ok(session);
412
- assert.strictEqual(session.mode, 'pty');
413
- const ptySession = session;
414
- ptySession.onPtyReplacedCallbacks.push(() => {
407
+ session.onPtyReplacedCallbacks.push(() => {
415
408
  const stillExists = sessions.get(result.id);
416
409
  assert.ok(stillExists, 'session should still exist after retry');
417
410
  done();
@@ -427,11 +420,9 @@ describe('sessions', () => {
427
420
  createdIds.push(result.id);
428
421
  const session = sessions.get(result.id);
429
422
  assert.ok(session);
430
- assert.strictEqual(session.mode, 'pty');
431
- const ptySession = session;
432
- ptySession.onPtyReplacedCallbacks.push((newPty) => {
423
+ session.onPtyReplacedCallbacks.push((newPty) => {
433
424
  assert.ok(newPty, 'should receive new PTY even with exit code 0');
434
- assert.strictEqual(ptySession.pty, newPty, 'session.pty should be updated');
425
+ assert.strictEqual(session.pty, newPty, 'session.pty should be updated');
435
426
  const stillExists = sessions.get(result.id);
436
427
  assert.ok(stillExists, 'session should still exist after retry');
437
428
  done();
@@ -461,7 +452,6 @@ describe('sessions', () => {
461
452
  createdIds.push(result.id);
462
453
  const session = sessions.get(result.id);
463
454
  assert.ok(session);
464
- assert.strictEqual(session.mode, 'pty');
465
455
  assert.ok(session.scrollback.length >= 1);
466
456
  assert.strictEqual(session.scrollback[0], 'prior output\r\n');
467
457
  });
@@ -499,7 +489,6 @@ describe('session persistence', () => {
499
489
  // Manually push some scrollback
500
490
  const session = sessions.get(s.id);
501
491
  assert.ok(session);
502
- assert.strictEqual(session.mode, 'pty');
503
492
  session.scrollback.push('hello world');
504
493
  serializeAll(configDir);
505
494
  // Check pending-sessions.json
@@ -530,7 +519,6 @@ describe('session persistence', () => {
530
519
  const originalId = s.id;
531
520
  const session = sessions.get(originalId);
532
521
  assert.ok(session);
533
- assert.strictEqual(session.mode, 'pty');
534
522
  session.scrollback.push('saved output');
535
523
  serializeAll(configDir);
536
524
  // Kill the original session
@@ -545,7 +533,6 @@ describe('session persistence', () => {
545
533
  assert.strictEqual(restoredSession.repoPath, '/tmp');
546
534
  assert.strictEqual(restoredSession.displayName, 'my-session');
547
535
  // Scrollback should be restored
548
- assert.strictEqual(restoredSession.mode, 'pty');
549
536
  assert.ok(restoredSession.scrollback.length >= 1);
550
537
  assert.strictEqual(restoredSession.scrollback[0], 'saved output');
551
538
  // pending-sessions.json should be cleaned up
@@ -610,7 +597,7 @@ describe('session persistence', () => {
610
597
  lastActivity: new Date().toISOString(),
611
598
  useTmux: true,
612
599
  tmuxSessionName: 'crc-my-session-tmux-tes',
613
- customCommand: '/bin/cat', // Use /bin/cat to avoid spawning real claude binary in test
600
+ customCommand: null,
614
601
  cwd: '/tmp',
615
602
  }],
616
603
  };
@@ -619,7 +606,6 @@ describe('session persistence', () => {
619
606
  assert.strictEqual(restored, 1);
620
607
  const session = sessions.get('tmux-test-id');
621
608
  assert.ok(session, 'restored session should exist');
622
- assert.strictEqual(session.mode, 'pty');
623
609
  assert.strictEqual(session.tmuxSessionName, 'crc-my-session-tmux-tes', 'tmuxSessionName should be preserved from serialized data');
624
610
  });
625
611
  it('restored session remains in list after PTY exits (disconnected status)', async () => {
@@ -719,7 +705,6 @@ describe('session persistence', () => {
719
705
  // Verify tmux session name survived the round trip
720
706
  const restoredTmux = sessions.get('tmux-roundtrip-id');
721
707
  assert.ok(restoredTmux);
722
- assert.strictEqual(restoredTmux.mode, 'pty');
723
708
  assert.strictEqual(restoredTmux.tmuxSessionName, 'crc-tmux-session-tmux-rou');
724
709
  assert.strictEqual(restoredTmux.displayName, 'Tmux Session');
725
710
  });
@@ -734,7 +719,6 @@ describe('session persistence', () => {
734
719
  });
735
720
  const session = sessions.get(s.id);
736
721
  assert.ok(session);
737
- assert.strictEqual(session.mode, 'pty');
738
722
  session.scrollback.push('important output');
739
723
  serializeAll(configDir);
740
724
  // Kill after serialize (mimics gracefulShutdown sequence)
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "claude-remote-cli",
3
- "version": "3.0.2",
3
+ "version": "3.0.4",
4
4
  "description": "Remote web interface for Claude Code CLI sessions",
5
5
  "type": "module",
6
6
  "main": "dist/server/index.js",
@@ -42,7 +42,6 @@
42
42
  "license": "MIT",
43
43
  "author": "Donovan Yohan",
44
44
  "dependencies": {
45
- "@anthropic-ai/claude-agent-sdk": "^0.2.77",
46
45
  "@tanstack/svelte-query": "^6.0.18",
47
46
  "@xterm/addon-fit": "^0.11.0",
48
47
  "@xterm/xterm": "^6.0.0",
@@ -1,32 +0,0 @@
1
- .pin-gate.svelte-1qp96yb{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg);padding:1rem}.pin-container.svelte-1qp96yb{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:320px;text-align:center}.pin-container.svelte-1qp96yb h1:where(.svelte-1qp96yb){font-size:1.5rem;color:var(--text)}.pin-container.svelte-1qp96yb p:where(.svelte-1qp96yb){color:var(--text-muted);font-size:.95rem}input.svelte-1qp96yb{width:100%;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1.2rem;text-align:center;outline:none;-webkit-appearance:none}input.svelte-1qp96yb:focus{border-color:var(--accent)}button.svelte-1qp96yb{width:100%;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;touch-action:manipulation}button.svelte-1qp96yb:active{opacity:.8}.error.svelte-1qp96yb{color:var(--accent);font-size:.9rem}.agent-badge.svelte-1ydsu2f{width:10px;height:10px;color:var(--text-muted);flex-shrink:0}.context-menu-trigger.svelte-1nmhce7{background:none;border:none;color:var(--text-muted);font-size:1rem;font-weight:700;cursor:pointer;padding:0 6px;border-radius:4px;touch-action:manipulation;flex-shrink:0;line-height:1;letter-spacing:1px;min-height:24px;display:inline-flex;align-items:center;transition:color .15s,background .15s}.context-menu-trigger.svelte-1nmhce7:hover{color:var(--text);background:var(--border)}.context-menu-backdrop.svelte-1nmhce7{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999}.context-menu.svelte-1nmhce7{position:fixed;list-style:none;margin:0;padding:4px 0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #0006;z-index:1000;min-width:175px}.context-menu-item.svelte-1nmhce7{padding:9px 14px;font-size:.85rem;cursor:pointer;color:var(--text);white-space:nowrap}.context-menu-item.svelte-1nmhce7:hover{background:var(--border)}.context-menu-item.svelte-1nmhce7:focus{outline:2px solid var(--accent);outline-offset:-2px}.context-menu-item--danger.svelte-1nmhce7{color:#e74c3c}.context-menu-item--danger.svelte-1nmhce7:hover{background:#e74c3c1f}.context-menu-item--disabled.svelte-1nmhce7{opacity:.4;cursor:default}.context-menu-item--disabled.svelte-1nmhce7:hover{background:none}li.svelte-ix4pl2{position:relative;display:flex;align-items:flex-start;padding:8px 10px;cursor:pointer;border-radius:6px;margin:2px 6px;font-size:.8rem;color:var(--text-muted);touch-action:manipulation;transition:background .15s,border-color .15s}li.active-session.svelte-ix4pl2{background:var(--bg)}li.active-session.svelte-ix4pl2:hover{background:var(--border)}li.active-session.selected.svelte-ix4pl2{background:var(--accent);color:#fff}li.active-session.selected.svelte-ix4pl2 .session-sub:where(.svelte-ix4pl2),li.active-session.selected.svelte-ix4pl2 .session-time:where(.svelte-ix4pl2){color:#ffffffb3}li.inactive-worktree.svelte-ix4pl2{background:transparent;border:1px solid var(--border);color:var(--text-muted);opacity:.7}li.inactive-worktree.svelte-ix4pl2:hover{opacity:1;border-color:var(--accent)}li.loading.svelte-ix4pl2{pointer-events:none;opacity:.5}li.loading.svelte-ix4pl2:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.04) 50%,transparent 100%);background-size:200% 100%;animation:svelte-ix4pl2-shimmer 1.5s ease-in-out infinite;pointer-events:none}@media(prefers-reduced-motion:reduce){li.loading.svelte-ix4pl2:after{animation:none}}@keyframes svelte-ix4pl2-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.session-info.svelte-ix4pl2{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.session-row-1.svelte-ix4pl2{display:flex;align-items:center;min-width:0}.status-dot.svelte-ix4pl2{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-right:8px}.status-dot--running.svelte-ix4pl2{background:#4ade80}.status-dot--idle.svelte-ix4pl2{background:#60a5fa}.status-dot--attention.svelte-ix4pl2{background:#f59e0b;box-shadow:0 0 6px 2px #f59e0b80;animation:svelte-ix4pl2-attention-glow 2s ease-in-out infinite}.status-dot--inactive.svelte-ix4pl2{background:#6b7280}@keyframes svelte-ix4pl2-attention-glow{0%,to{box-shadow:0 0 4px 1px #f59e0b4d}50%{box-shadow:0 0 8px 3px #f59e0b99}}.session-name.svelte-ix4pl2{flex:1;min-width:0;overflow:hidden;white-space:nowrap;font-weight:500;color:var(--text)}.session-name-text.svelte-ix4pl2{display:inline-block;white-space:nowrap;will-change:transform}.session-name.has-overflow.svelte-ix4pl2{mask-image:linear-gradient(to right,black calc(100% - 32px),transparent);-webkit-mask-image:linear-gradient(to right,black calc(100% - 32px),transparent)}li.svelte-ix4pl2:hover .session-name.has-overflow:where(.svelte-ix4pl2){mask-image:none;-webkit-mask-image:none}li.active-session.selected.svelte-ix4pl2 .session-name:where(.svelte-ix4pl2){color:#fff}li.active-session.selected.svelte-ix4pl2 .session-name.has-overflow:where(.svelte-ix4pl2){mask-image:linear-gradient(to right,white calc(100% - 32px),transparent);-webkit-mask-image:linear-gradient(to right,white calc(100% - 32px),transparent)}li.active-session.selected.svelte-ix4pl2:hover .session-name.has-overflow:where(.svelte-ix4pl2){mask-image:none;-webkit-mask-image:none}.session-row-2.svelte-ix4pl2{display:flex;align-items:center;gap:4px;min-width:0;padding-left:16px}.session-row-2.has-badge.svelte-ix4pl2{padding-left:2px}.shell-badge.svelte-ix4pl2{font-size:.55rem;font-family:monospace;font-weight:700;color:var(--text-muted);flex-shrink:0;line-height:1}li.active-session.selected.svelte-ix4pl2 .shell-badge:where(.svelte-ix4pl2){color:#ffffffb3}.pr-icon.svelte-ix4pl2{font-size:.65rem;flex-shrink:0}.pr-open.svelte-ix4pl2{color:#4ade80}.pr-merged.svelte-ix4pl2{color:#a78bfa}.pr-closed.svelte-ix4pl2{color:#f87171}.session-sub.svelte-ix4pl2{font-size:.7rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.session-row-3.svelte-ix4pl2{display:flex;align-items:center;gap:6px;min-width:0;padding-left:16px}.session-time.svelte-ix4pl2{font-size:.65rem;color:var(--text-muted);opacity:.6}.git-diff.svelte-ix4pl2{display:flex;gap:4px;font-size:.65rem;font-family:monospace}.diff-add.svelte-ix4pl2{color:#4ade80}.diff-del.svelte-ix4pl2{color:#f87171}li.active-session.selected.svelte-ix4pl2 .context-menu-trigger{color:#ffffffb3}li.active-session.selected.svelte-ix4pl2 .context-menu-trigger:hover{color:#fff;background:#ffffff26}.searchable-select.svelte-u1ddyn{position:relative}.ss-trigger.svelte-u1ddyn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 8px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.75rem;cursor:pointer;text-align:left;transition:border-color .15s}.ss-trigger.svelte-u1ddyn:focus{border-color:var(--accent);outline:none}.ss-trigger-text.svelte-u1ddyn{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.ss-placeholder.svelte-u1ddyn{color:var(--text-muted)}.ss-arrow.svelte-u1ddyn{flex-shrink:0;color:var(--text-muted);margin-left:4px}.ss-input.svelte-u1ddyn{width:100%;padding:6px 8px;background:var(--bg);border:1px solid var(--accent);border-radius:6px;color:var(--text);font-size:.75rem;outline:none;box-sizing:border-box}.ss-dropdown.svelte-u1ddyn{position:absolute;top:calc(100% + 2px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:6px;list-style:none;margin:0;padding:4px 0;z-index:100;max-height:200px;overflow-y:auto}.ss-option.svelte-u1ddyn{padding:6px 10px;font-size:.75rem;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ss-option.svelte-u1ddyn:hover{background:var(--border)}.ss-option--reset.svelte-u1ddyn{color:var(--text-muted);border-bottom:1px solid var(--border)}.ss-selected.svelte-u1ddyn{color:var(--accent)}.ss-no-results.svelte-u1ddyn{color:var(--text-muted);font-style:italic;cursor:default}.ss-no-results.svelte-u1ddyn:hover{background:transparent}.sidebar-filters.svelte-1o5d4l8{display:flex;flex-direction:column;gap:4px;padding:6px 8px;flex-shrink:0}input.svelte-1o5d4l8{padding:6px 8px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.75rem;outline:none;-webkit-appearance:none}input.svelte-1o5d4l8:focus{border-color:var(--accent)}.role-filter.svelte-1o5d4l8{display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden}.role-btn.svelte-1o5d4l8{flex:1;padding:5px 8px;background:var(--bg);border:none;border-right:1px solid var(--border);color:var(--text-muted);font-size:.7rem;cursor:pointer;transition:background .15s,color .15s}.role-btn.svelte-1o5d4l8:last-child{border-right:none}.role-btn.svelte-1o5d4l8:hover{color:var(--text)}.role-btn.active.svelte-1o5d4l8{background:var(--accent);color:#fff}li.pr-item.svelte-jhsg4e{position:relative;display:flex;align-items:flex-start;padding:8px 10px;cursor:pointer;border-radius:6px;margin:2px 6px;font-size:.8rem;color:var(--text-muted);touch-action:manipulation;transition:background .15s,border-color .15s;background:transparent;border:1px solid var(--border);opacity:.8}li.pr-item.svelte-jhsg4e:hover{opacity:1;border-color:var(--accent)}li.pr-item.active-session.svelte-jhsg4e{background:var(--bg);border-color:var(--accent);opacity:1}li.pr-item.selected.svelte-jhsg4e{background:var(--accent);border-color:var(--accent);color:#fff;opacity:1}li.pr-item.selected.svelte-jhsg4e .pr-title:where(.svelte-jhsg4e){color:#fff}li.pr-item.selected.svelte-jhsg4e .pr-meta:where(.svelte-jhsg4e),li.pr-item.selected.svelte-jhsg4e .pr-time:where(.svelte-jhsg4e){color:#ffffffb3}li.pr-item.selected.svelte-jhsg4e .role-badge:where(.svelte-jhsg4e){background:#fff3;color:#fff}.pr-info.svelte-jhsg4e{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.pr-row-1.svelte-jhsg4e{display:flex;align-items:center;min-width:0}.pr-state{font-size:.65rem;flex-shrink:0;width:16px;text-align:center;margin-right:4px}.pr-open{color:#4ade80}.pr-merged{color:#a78bfa}.pr-closed{color:#f87171}.pr-title.svelte-jhsg4e{flex:1;min-width:0;overflow:hidden;white-space:nowrap;font-weight:500;color:var(--text)}.pr-title-text.svelte-jhsg4e{display:inline-block;white-space:nowrap;will-change:transform}.pr-title.has-overflow.svelte-jhsg4e{mask-image:linear-gradient(to right,black calc(100% - 32px),transparent);-webkit-mask-image:linear-gradient(to right,black calc(100% - 32px),transparent)}li.svelte-jhsg4e:hover .pr-title.has-overflow:where(.svelte-jhsg4e){mask-image:none;-webkit-mask-image:none}.review-badge.svelte-jhsg4e{font-size:.7rem;padding:0 3px;flex-shrink:0}.review-approved.svelte-jhsg4e{color:#4ade80}.review-changes.svelte-jhsg4e{color:#f87171}.review-pending.svelte-jhsg4e{color:#f59e0b}.pr-row-2.svelte-jhsg4e{display:flex;align-items:center;gap:4px;min-width:0;padding-left:20px}.pr-meta.svelte-jhsg4e{font-size:.7rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.role-badge.svelte-jhsg4e{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:1px 5px;border-radius:3px;flex-shrink:0}.role-author.svelte-jhsg4e{background:#60a5fa26;color:#60a5fa}.role-reviewer.svelte-jhsg4e{background:#a78bfa26;color:#a78bfa}.pr-row-3.svelte-jhsg4e{display:flex;align-items:center;gap:6px;min-width:0;padding-left:20px}.pr-time.svelte-jhsg4e{font-size:.65rem;color:var(--text-muted);opacity:.6}.git-diff.svelte-jhsg4e{display:flex;gap:4px;font-size:.65rem;font-family:monospace}.diff-add.svelte-jhsg4e{color:#4ade80}.diff-del.svelte-jhsg4e{color:#f87171}li.pr-item.selected.svelte-jhsg4e .context-menu-trigger{color:#ffffffb3}li.pr-item.selected.svelte-jhsg4e .context-menu-trigger:hover{color:#fff;background:#ffffff26}.repo-group-refresh.svelte-1ekl114{background:none;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;padding:0 4px;flex-shrink:0;transition:color .15s}.repo-group-refresh.svelte-1ekl114:hover{color:var(--accent)}.repo-group-refresh.svelte-1ekl114:disabled{opacity:.5;cursor:not-allowed}.spinning.svelte-1ekl114{display:inline-block;animation:svelte-1ekl114-spin 1s linear infinite}@keyframes svelte-1ekl114-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.session-list-tabs.svelte-ynafm7{display:flex;padding:0 8px;border-bottom:1px solid var(--border)}.sidebar-tab.svelte-ynafm7{flex:1;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.7rem;padding:6px 4px;cursor:pointer;transition:color .15s,border-color .15s;text-align:center}.sidebar-tab.svelte-ynafm7:hover{color:var(--text)}.sidebar-tab.active.svelte-ynafm7{color:var(--accent);border-bottom-color:var(--accent)}.tab-count.svelte-ynafm7{display:block;opacity:.7}.session-list.svelte-ynafm7{list-style:none;flex:1;overflow-y:auto;padding:8px 0}.session-divider{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:8px 12px 4px;opacity:.6;list-style:none}.repo-group-header{display:flex;align-items:center;gap:4px;padding:6px 10px;cursor:pointer;list-style:none;transition:background .15s;border-radius:4px;margin:2px 6px}.repo-group-header:hover{background:var(--border)}.chevron{display:inline-block;font-size:.55rem;transition:transform .15s;color:var(--text-muted);flex-shrink:0}.chevron.expanded{transform:rotate(90deg)}.repo-group-name{font-size:.7rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.repo-group-root{font-size:.6rem;color:var(--text-muted);opacity:.6;flex-shrink:0}.repo-group-count{font-size:.6rem;color:var(--text-muted);opacity:.5;margin-left:auto;flex-shrink:0}.repo-group-add{background:none;border:none;color:var(--text-muted);font-size:.8rem;font-weight:600;cursor:pointer;padding:0 4px;flex-shrink:0;line-height:1;transition:color .15s;opacity:0}.repo-group-header:hover .repo-group-add{opacity:1}.repo-group-add:hover,.repo-group-add:focus-visible{color:var(--accent);opacity:1}.terminal-header{display:flex;padding:8px 12px 4px;list-style:none}.terminal-add-btn{background:none;border:1px solid var(--border);color:var(--text-muted);font-size:.7rem;padding:4px 10px;border-radius:4px;cursor:pointer;transition:color .15s,border-color .15s;width:100%}.terminal-add-btn:hover{color:var(--accent);border-color:var(--accent)}.pr-hint{font-size:.75rem;color:var(--text-muted);text-align:center;padding:20px 12px;opacity:.6;list-style:none}.pr-hint-sub{font-size:.65rem;opacity:.8;display:block;margin-top:4px}.pr-hint code{background:var(--bg);padding:1px 4px;border-radius:3px;font-size:.65rem}.sidebar.svelte-owj5vn{position:relative;display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);overflow:hidden;transition:transform .25s ease,width .2s ease,min-width .2s ease;z-index:100}.resize-handle.svelte-owj5vn{position:absolute;top:0;right:0;width:4px;height:100%;cursor:col-resize;z-index:10;transition:background .15s}.resize-handle.svelte-owj5vn:hover{background:var(--accent)}.sidebar-header.svelte-owj5vn{display:flex;align-items:center;justify-content:space-between;padding:12px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-label.svelte-owj5vn{flex:1;font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.collapse-btn.svelte-owj5vn{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:4px;flex-shrink:0;line-height:1}.collapse-btn.svelte-owj5vn:hover{color:var(--text);background:var(--border)}.sidebar.collapsed.svelte-owj5vn .sidebar-header:where(.svelte-owj5vn){justify-content:center;padding:12px 4px}.icon-btn.svelte-owj5vn{background:none;border:none;color:var(--text);font-size:1.2rem;cursor:pointer;padding:4px 6px;border-radius:4px;touch-action:manipulation;display:none}.icon-btn.svelte-owj5vn:active{background:var(--border)}.new-session-btn.svelte-owj5vn{margin:8px;padding:10px 12px;background:none;border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.875rem;cursor:pointer;touch-action:manipulation;text-align:center;flex-shrink:0}.new-session-btn.svelte-owj5vn:active{background:var(--border)}.settings-btn.svelte-owj5vn{margin:0 8px 8px;padding:10px 12px;background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:.8rem;cursor:pointer;touch-action:manipulation;text-align:center;flex-shrink:0}.settings-btn.svelte-owj5vn:active{background:var(--border)}@media(max-width:600px){.sidebar.svelte-owj5vn{position:fixed;top:0;left:0;height:100%;transform:translate(-100%);box-shadow:2px 0 12px #00000080;transition:transform .25s ease}.sidebar.open.svelte-owj5vn{transform:translate(0)}.collapse-btn.svelte-owj5vn{display:none}.icon-btn.svelte-owj5vn{display:block;font-size:1.4rem;padding:4px 8px}.resize-handle.svelte-owj5vn{display:none}}/**
2
- * Copyright (c) 2014 The xterm.js authors. All rights reserved.
3
- * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
4
- * https://github.com/chjj/term.js
5
- * @license MIT
6
- *
7
- * Permission is hereby granted, free of charge, to any person obtaining a copy
8
- * of this software and associated documentation files (the "Software"), to deal
9
- * in the Software without restriction, including without limitation the rights
10
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
- * copies of the Software, and to permit persons to whom the Software is
12
- * furnished to do so, subject to the following conditions:
13
- *
14
- * The above copyright notice and this permission notice shall be included in
15
- * all copies or substantial portions of the Software.
16
- *
17
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
- * THE SOFTWARE.
24
- *
25
- * Originally forked from (with the author's permission):
26
- * Fabrice Bellard's javascript vt100 for jslinux:
27
- * http://bellard.org/jslinux/
28
- * Copyright (c) 2011 Fabrice Bellard
29
- * The original design remains. The terminal itself
30
- * has been extended to include xterm CSI codes, among
31
- * other features.
32
- */.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .xterm-accessibility-tree:not(.debug) *::selection{color:transparent}.xterm .xterm-accessibility-tree{font-family:monospace;-webkit-user-select:text;user-select:text;white-space:pre}.xterm .xterm-accessibility-tree>div{transform-origin:left;width:fit-content}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{text-decoration:double underline}.xterm-underline-3{text-decoration:wavy underline}.xterm-underline-4{text-decoration:dotted underline}.xterm-underline-5{text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{text-decoration:overline double underline}.xterm-overline.xterm-underline-3{text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}.xterm .xterm-scrollable-element>.scrollbar{cursor:default}.xterm .xterm-scrollable-element>.scrollbar>.scra{cursor:pointer;font-size:11px!important}.xterm .xterm-scrollable-element>.visible{opacity:1;background:#0000;transition:opacity .1s linear;z-index:11}.xterm .xterm-scrollable-element>.invisible{opacity:0;pointer-events:none}.xterm .xterm-scrollable-element>.invisible.fade{transition:opacity .8s linear}.xterm .xterm-scrollable-element>.shadow{position:absolute;display:none}.xterm .xterm-scrollable-element>.shadow.top{display:block;top:0;left:3px;height:3px;width:100%;box-shadow:var(--vscode-scrollbar-shadow, #000) 0 6px 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.left{display:block;top:3px;left:0;height:100%;width:3px;box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.top-left-corner{display:block;top:0;left:0;height:3px;width:3px}.xterm .xterm-scrollable-element>.shadow.top.left{box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}.terminal-wrapper.svelte-5qgfij{display:flex;flex:1;min-height:0;position:relative;overflow:hidden}.terminal-container.svelte-5qgfij{flex:1;min-width:0;min-height:0;overflow:hidden;padding:4px}.terminal-wrapper.drag-over.svelte-5qgfij{outline:2px dashed var(--accent);outline-offset:-2px}.terminal-scrollbar.svelte-5qgfij{width:8px;background:transparent;position:relative;flex-shrink:0}.terminal-scrollbar-thumb.svelte-5qgfij{position:absolute;right:0;width:6px;background:var(--border);border-radius:3px;cursor:pointer}@media(hover:none){.terminal-wrapper.selection-mode.svelte-5qgfij .terminal-container:where(.svelte-5qgfij){outline:2px solid var(--accent);outline-offset:-2px}.terminal-container.svelte-5qgfij{touch-action:none}.terminal-scrollbar.svelte-5qgfij{width:12px}.terminal-scrollbar-thumb.svelte-5qgfij{width:8px;min-height:44px}.scroll-fabs.svelte-5qgfij{position:absolute;right:16px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:12px;z-index:1;opacity:.6;pointer-events:auto}.scroll-fab.svelte-5qgfij{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none}.scroll-fab.svelte-5qgfij:active{opacity:1;background:var(--border)}.scroll-fab-bottom.svelte-5qgfij{margin-top:4px}}.user-message.svelte-1q16011{border-left:3px solid var(--accent);padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-xs) 0;width:100%}.user-message-text.svelte-1q16011{color:var(--text);font-size:.95rem;white-space:pre-wrap;word-break:break-word}.agent-message.svelte-1r3r7jb{padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-xs) 0;width:100%;color:var(--text);font-size:.95rem;line-height:1.5;word-break:break-word}.agent-message.svelte-1r3r7jb .code-block{background:var(--card-bg);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);overflow-x:auto;font-family:var(--code-font);font-size:.85rem;margin:var(--spacing-sm) 0;white-space:pre}.agent-message.svelte-1r3r7jb .inline-code{background:var(--card-bg);border-radius:var(--radius-sm);padding:1px 4px;font-family:var(--code-font);font-size:.88em}.agent-message.svelte-1r3r7jb a{color:var(--info);text-decoration:underline}.agent-message.svelte-1r3r7jb strong{color:var(--text);font-weight:600}.file-change-card.svelte-649juz{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--card-bg);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-xs) 0;font-family:var(--code-font);font-size:.85rem;width:100%;min-width:0}.file-icon.svelte-649juz{flex-shrink:0;font-size:.9rem}.file-path.svelte-649juz{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.file-dir.svelte-649juz{color:var(--text-muted)}.file-name.svelte-649juz{color:var(--text)}.diff-stats.svelte-649juz{flex-shrink:0;display:flex;gap:var(--spacing-sm);font-weight:600}.diff-add.svelte-649juz{color:var(--diff-add)}.diff-remove.svelte-649juz{color:var(--diff-remove)}.tool-call-card.svelte-9tdk1v{background:var(--card-bg);border-radius:var(--radius-sm);margin:var(--spacing-xs) 0;overflow:hidden;width:100%}.tool-header.svelte-9tdk1v{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;min-height:44px;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;color:var(--text);cursor:pointer;font-size:.85rem;text-align:left}.tool-name.svelte-9tdk1v{font-family:var(--code-font);font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-status.svelte-9tdk1v{flex-shrink:0;font-size:.75rem;padding:1px 6px;border-radius:var(--radius-sm);font-weight:600;text-transform:uppercase}.status-success.svelte-9tdk1v{background:var(--success);color:#fff}.status-error.svelte-9tdk1v{background:var(--error);color:#fff}.status-pending.svelte-9tdk1v{background:var(--warning);color:#000}.toggle-icon.svelte-9tdk1v{flex-shrink:0;font-size:.7rem;color:var(--text-muted)}.tool-input.svelte-9tdk1v{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg);font-family:var(--code-font);font-size:.8rem;color:var(--text-muted);overflow-x:auto;white-space:pre-wrap;word-break:break-all;margin:0;border-top:1px solid var(--border)}.reasoning-panel.svelte-fizs81{margin:var(--spacing-xs) 0;border-radius:var(--radius-sm);overflow:hidden;width:100%}.reasoning-header.svelte-fizs81{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;min-height:44px;padding:var(--spacing-xs) var(--spacing-md);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;text-align:left}.reasoning-label.svelte-fizs81{flex:1;font-style:italic}.dots.svelte-fizs81{animation:svelte-fizs81-pulse 1.5s ease-in-out infinite}@keyframes svelte-fizs81-pulse{0%,to{opacity:1}50%{opacity:.3}}.toggle-icon.svelte-fizs81{flex-shrink:0;font-size:.7rem}.reasoning-content.svelte-fizs81{padding:var(--spacing-sm) var(--spacing-md);color:var(--text-muted);font-family:var(--code-font);font-size:.82rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.error-card.svelte-au1iu7{border-left:3px solid var(--error);background:var(--card-bg);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-xs) 0;width:100%}.error-body.svelte-au1iu7{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.error-text.svelte-au1iu7{flex:1;color:var(--error);font-size:.9rem;word-break:break-word}.dismiss-btn.svelte-au1iu7{flex-shrink:0;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:0;line-height:1}.dismiss-btn.svelte-au1iu7:hover{color:var(--text)}.retry-btn.svelte-au1iu7{margin-top:var(--spacing-sm);background:none;border:1px solid var(--error);color:var(--error);border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-md);font-size:.82rem;cursor:pointer;font-family:var(--code-font)}.retry-btn.svelte-au1iu7:hover{background:var(--error);color:#fff}.turn-completed.svelte-1q2w5up{display:flex;align-items:center;gap:var(--spacing-sm);margin:var(--spacing-sm) 0;width:100%}.separator-line.svelte-1q2w5up{flex:1;height:1px;background:var(--border)}.usage-info.svelte-1q2w5up{flex-shrink:0;color:var(--text-muted);font-size:.75rem;font-family:var(--code-font);padding:0 var(--spacing-sm)}.chat-view.svelte-o5aojg{flex:1;padding:var(--spacing-sm)}.empty-state.svelte-o5aojg{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:.95rem;gap:var(--spacing-sm)}.cursor-blink.svelte-o5aojg{font-family:var(--code-font);font-size:1.2rem;animation:svelte-o5aojg-blink 1s step-end infinite}@keyframes svelte-o5aojg-blink{0%,to{opacity:1}50%{opacity:0}}.message-list.svelte-o5aojg{display:flex;flex-direction:column;gap:var(--spacing-xs)}.session-started.svelte-o5aojg{padding:var(--spacing-sm) var(--spacing-md);text-align:center}.session-started-text.svelte-o5aojg{color:var(--text-muted);font-size:.82rem;font-style:italic}.working-indicator.svelte-o5aojg{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.working-dot.svelte-o5aojg{color:var(--accent);font-size:.7rem;animation:svelte-o5aojg-pulse-dot 1.5s ease-in-out infinite}@keyframes svelte-o5aojg-pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.working-text.svelte-o5aojg{color:var(--text-muted);font-size:.85rem}.chat-input-container.svelte-mnrni5{display:flex;align-items:flex-end;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--surface);border-top:1px solid var(--border);position:sticky;bottom:0}.chat-textarea.svelte-mnrni5{flex:1;background:var(--surface);border:none;color:var(--text);font-size:.95rem;font-family:inherit;resize:none;outline:none;padding:var(--spacing-sm);min-height:36px;max-height:120px;line-height:1.4}.chat-textarea.svelte-mnrni5::placeholder{color:var(--text-muted)}.chat-textarea.svelte-mnrni5:disabled{opacity:.5}.send-btn.svelte-mnrni5{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:none;background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.send-btn.disabled.svelte-mnrni5{opacity:.4;cursor:default}.send-btn.svelte-mnrni5:not(.disabled):hover{opacity:.9}.send-dots.svelte-mnrni5{font-size:1.1rem;letter-spacing:1px}.send-icon.svelte-mnrni5{display:block}.quick-replies.svelte-2y5bi6{display:flex;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.quick-replies.svelte-2y5bi6::-webkit-scrollbar{display:none}.quick-reply-btn.svelte-2y5bi6{flex-shrink:0;height:40px;padding:0 var(--spacing-md);background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--code-font);font-size:.82rem;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.quick-reply-btn.svelte-2y5bi6:hover{background:var(--surface);border-color:var(--accent)}.quick-reply-btn.svelte-2y5bi6:active{background:var(--card-bg)}.permission-card.svelte-1amwf6m{border-left:3px solid var(--accent);background:var(--card-bg);border-radius:var(--radius-sm);padding:var(--spacing-md);flex-shrink:0;width:100%}.permission-card.resolved.svelte-1amwf6m{opacity:.7}.permission-card.timed_out.svelte-1amwf6m{border-left-color:var(--text-muted);opacity:.5}.permission-header.svelte-1amwf6m{margin-bottom:var(--spacing-sm)}.permission-tool.svelte-1amwf6m{font-family:var(--code-font);font-size:.88rem;color:var(--text);word-break:break-all}.permission-actions.svelte-1amwf6m{display:flex;gap:var(--spacing-sm)}.approve-btn.svelte-1amwf6m,.deny-btn.svelte-1amwf6m{flex:1;height:48px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;border:none}.approve-btn.svelte-1amwf6m{background:var(--success);color:#fff}.approve-btn.svelte-1amwf6m:hover{opacity:.9}.deny-btn.svelte-1amwf6m{background:none;border:1px solid var(--error);color:var(--error)}.deny-btn.svelte-1amwf6m:hover{background:var(--error);color:#fff}.permission-badge.svelte-1amwf6m{font-size:.85rem;font-weight:600;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);display:inline-block}.badge-approved.svelte-1amwf6m{color:var(--success)}.badge-denied.svelte-1amwf6m{color:var(--error)}.badge-timeout.svelte-1amwf6m{color:var(--text-muted)}.cost-display.svelte-p9ddlc{color:var(--text-muted);font-size:.75rem;font-family:var(--code-font);text-align:center;padding:var(--spacing-xs) var(--spacing-md)}.session-view.svelte-oor1t0{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.fallback-banner.svelte-oor1t0{background:var(--warning);color:#000;font-size:.82rem;font-weight:600;text-align:center;padding:var(--spacing-xs) var(--spacing-md)}.tab-bar.svelte-oor1t0{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.tab.svelte-oor1t0{flex:1;height:44px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.9rem;font-weight:600;cursor:pointer;transition:color .15s,border-color .15s}.tab.active.svelte-oor1t0{color:var(--text);border-bottom-color:var(--accent)}.tab.svelte-oor1t0:hover:not(.active){color:var(--text)}.tab-content.svelte-oor1t0{flex:1;display:flex;min-height:0;overflow:hidden}.tab-panel.svelte-oor1t0{flex-direction:column;flex:1;min-height:0;overflow:hidden}.chat-scroll-area.svelte-oor1t0{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.terminal-panel.svelte-oor1t0{position:relative}.companion-status.svelte-oor1t0{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);height:100%;color:var(--text-muted);font-size:.9rem}.spinner.svelte-oor1t0{display:inline-block;width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:svelte-oor1t0-spin .8s linear infinite}@keyframes svelte-oor1t0-spin{to{transform:rotate(360deg)}}.error-text.svelte-oor1t0{color:var(--error);font-weight:600}.retry-shell-btn.svelte-oor1t0{background:none;border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-md);font-size:.85rem;cursor:pointer}.retry-shell-btn.svelte-oor1t0:hover{border-color:var(--accent)}.toolbar.svelte-k7we1m{background:var(--surface);border-top:1px solid var(--border);padding:4px;padding-bottom:calc(4px + env(safe-area-inset-bottom,0px));flex-shrink:0}.toolbar-grid.svelte-k7we1m{display:grid;grid-template-columns:repeat(6,1fr);gap:4px}.tb-btn.svelte-k7we1m{background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.85rem;padding:8px 4px;cursor:pointer;touch-action:manipulation;min-height:40px;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none}.tb-btn.svelte-k7we1m:active{background:var(--border)}.tb-enter.svelte-k7we1m{background:var(--accent);border-color:var(--accent);color:#fff}.tb-enter.svelte-k7we1m:active{opacity:.8}.mobile-header.svelte-wp0i5g{display:none;align-items:center;gap:8px;padding:8px 12px;background:var(--surface);border-bottom:1px solid var(--border);min-height:44px;flex-shrink:0}@media(max-width:768px){.mobile-header.svelte-wp0i5g{display:flex}.mobile-header.hidden.svelte-wp0i5g{display:none}}.mobile-title.svelte-wp0i5g{font-size:.95rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.icon-btn.svelte-wp0i5g{background:none;border:none;color:var(--text);font-size:1.2rem;cursor:pointer;padding:6px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;border-radius:6px;touch-action:manipulation}.icon-btn.svelte-wp0i5g:hover{background:var(--border)}.update-toast.svelte-1trivgv{position:fixed;bottom:0;left:0;right:0;z-index:150;display:flex;justify-content:center;padding:12px 12px calc(12px + env(safe-area-inset-bottom));pointer-events:none;animation:svelte-1trivgv-toast-slide-up .25s ease-out}@keyframes svelte-1trivgv-toast-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.update-toast-content.svelte-1trivgv{display:flex;flex-direction:row;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px;max-width:500px;box-shadow:0 4px 16px #0000004d;pointer-events:auto}.update-toast-text.svelte-1trivgv{flex:1;font-size:.85rem;color:var(--text)}.update-toast-actions.svelte-1trivgv{display:flex;gap:8px;flex-shrink:0}.update-toast-btn.svelte-1trivgv{padding:8px 14px;border-radius:6px;font-size:.8rem;border:none;background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap}.update-toast-btn.svelte-1trivgv:disabled{opacity:.6;cursor:not-allowed}.update-toast-dismiss.svelte-1trivgv{background:none;border:none;color:var(--text-muted);font-size:1.2rem;padding:4px 6px;cursor:pointer}.update-toast-dismiss.svelte-1trivgv:hover{color:var(--text)}.image-toast.svelte-1y8sviv{position:fixed;bottom:60px;left:50%;transform:translate(-50%);z-index:1000;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 14px;color:var(--text);font-size:13px;max-width:90vw;box-shadow:0 4px 12px #0006}.image-toast-content.svelte-1y8sviv{display:flex;align-items:center;gap:10px}.image-toast-text.svelte-1y8sviv{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60vw}.image-toast-actions.svelte-1y8sviv{display:flex;gap:6px;align-items:center;flex-shrink:0}.image-toast-insert.svelte-1y8sviv{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:4px 10px;font-size:12px;cursor:pointer}.image-toast-insert.svelte-1y8sviv:active{opacity:.8}.image-toast-dismiss.svelte-1y8sviv{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:2px 6px}.image-toast-dismiss.svelte-1y8sviv:hover{color:var(--text)}.dialog.svelte-thtd9b{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:0;width:min(480px,95vw);max-height:90vh;overflow:hidden}.dialog.svelte-thtd9b::backdrop{background:#0009}.dialog-content.svelte-thtd9b{display:flex;flex-direction:column;max-height:90vh;overflow:hidden}.dialog-title.svelte-thtd9b{font-size:1.1rem;font-weight:600;padding:16px 20px 12px;margin:0;border-bottom:1px solid var(--border);flex-shrink:0}.dialog-tabs.svelte-thtd9b{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.dialog-tab.svelte-thtd9b{flex:1;padding:10px;background:none;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.dialog-tab.active.svelte-thtd9b{color:var(--accent);border-bottom-color:var(--accent)}.dialog-tab.svelte-thtd9b:hover:not(.active){color:var(--text)}.dialog-body.svelte-thtd9b{padding:16px 20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:14px}.dialog-field.svelte-thtd9b{display:flex;flex-direction:column;gap:5px}.dialog-field--inline.svelte-thtd9b{flex-direction:row;align-items:center;gap:8px}.dialog-label.svelte-thtd9b{font-size:.85rem;color:var(--text-muted)}.dialog-label-row.svelte-thtd9b{display:flex;align-items:center;justify-content:space-between;gap:10px}.dialog-label-inline.svelte-thtd9b{font-size:.9rem;cursor:pointer}.dialog-select.svelte-thtd9b,.dialog-input.svelte-thtd9b{background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.9rem;padding:7px 10px;width:100%;box-sizing:border-box}.dialog-select.svelte-thtd9b:disabled{opacity:.5;cursor:not-allowed}.dialog-checkbox.svelte-thtd9b{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.branch-input-wrap.svelte-thtd9b{position:relative}.branch-refresh.svelte-thtd9b{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s,background .15s}.branch-refresh.svelte-thtd9b:hover:not(:disabled){color:var(--accent);border-color:var(--accent)}.branch-refresh.svelte-thtd9b:disabled{opacity:.5;cursor:not-allowed}.branch-refresh.svelte-thtd9b svg:where(.svelte-thtd9b){width:15px;height:15px}.branch-dropdown.svelte-thtd9b{position:absolute;top:calc(100% + 2px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:6px;list-style:none;margin:0;padding:4px 0;z-index:100;max-height:180px;overflow-y:auto}.branch-dropdown.svelte-thtd9b li:where(.svelte-thtd9b){padding:7px 12px;font-size:.9rem;cursor:pointer}.branch-dropdown.svelte-thtd9b li:where(.svelte-thtd9b):hover{background:var(--border)}.branch-create-new.svelte-thtd9b{color:var(--accent);border-bottom:1px solid var(--border)}.dialog-footer.svelte-thtd9b{display:flex;justify-content:flex-end;gap:10px;padding:12px 20px 16px;border-top:1px solid var(--border);flex-shrink:0}.btn.svelte-thtd9b{padding:8px 18px;border-radius:6px;font-size:.9rem;cursor:pointer;border:1px solid transparent;font-weight:500;transition:opacity .15s}.btn.svelte-thtd9b:disabled{opacity:.4;cursor:not-allowed}.btn-primary.svelte-thtd9b{background:var(--accent);color:#fff}.btn-primary.svelte-thtd9b:hover:not(:disabled){opacity:.9}.btn-ghost.svelte-thtd9b{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost.svelte-thtd9b:hover{background:var(--border);color:var(--text)}.spinning.svelte-thtd9b{animation:svelte-thtd9b-spin 1s linear infinite;transform-origin:center}@keyframes svelte-thtd9b-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dialog.svelte-fdtoa4{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:0;width:min(460px,95vw);max-height:90vh;overflow:hidden}.dialog.svelte-fdtoa4::backdrop{background:#0009}.dialog-content.svelte-fdtoa4{display:flex;flex-direction:column;max-height:90vh;overflow:hidden}.dialog-header.svelte-fdtoa4{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.dialog-title.svelte-fdtoa4{font-size:1.1rem;font-weight:600;margin:0}.close-btn.svelte-fdtoa4{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:4px 6px;border-radius:4px}.close-btn.svelte-fdtoa4:hover{background:var(--border);color:var(--text)}.dialog-body.svelte-fdtoa4{padding:16px 20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:20px}.settings-section.svelte-fdtoa4{display:flex;flex-direction:column;gap:10px}.section-title.svelte-fdtoa4{font-size:.9rem;font-weight:600;color:var(--text);margin:0}.section-desc.svelte-fdtoa4{font-size:.82rem;color:var(--text-muted);margin:0}.empty-msg.svelte-fdtoa4{font-size:.85rem;color:var(--text-muted);font-style:italic;margin:0}.roots-list.svelte-fdtoa4{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.root-item.svelte-fdtoa4{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:7px 10px}.root-path.svelte-fdtoa4{font-size:.85rem;font-family:monospace;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.remove-btn.svelte-fdtoa4{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:2px 5px;border-radius:4px;flex-shrink:0;line-height:1}.remove-btn.svelte-fdtoa4:hover{background:var(--border);color:var(--text)}.add-root-row.svelte-fdtoa4{display:flex;gap:8px}.add-root-input.svelte-fdtoa4{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.9rem;padding:7px 10px}.error-msg.svelte-fdtoa4{font-size:.82rem;color:#e74c3c;margin:0}.agent-select.svelte-fdtoa4{background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.9rem;padding:7px 10px;width:100%;box-sizing:border-box}.devtools-row.svelte-fdtoa4{display:flex;align-items:center;gap:8px}.dialog-checkbox.svelte-fdtoa4{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.devtools-label.svelte-fdtoa4{font-size:.9rem;cursor:pointer}.dialog-footer.svelte-fdtoa4{display:flex;justify-content:flex-end;gap:10px;padding:12px 20px 16px;border-top:1px solid var(--border);flex-shrink:0}.btn.svelte-fdtoa4{padding:8px 18px;border-radius:6px;font-size:.9rem;cursor:pointer;border:1px solid transparent;font-weight:500}.btn-primary.svelte-fdtoa4{background:var(--accent);color:#fff;flex-shrink:0}.btn-primary.svelte-fdtoa4:hover{opacity:.9}.btn-ghost.svelte-fdtoa4{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost.svelte-fdtoa4:hover{background:var(--border);color:var(--text)}.btn-sm.svelte-fdtoa4{padding:5px 12px;font-size:.8rem}.version-row.svelte-fdtoa4{display:flex;align-items:center;gap:10px}.version-current.svelte-fdtoa4{font-size:.9rem;font-family:monospace;color:var(--text)}.version-status.svelte-fdtoa4{font-size:.8rem;color:var(--text-muted)}.version-update-row.svelte-fdtoa4{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:8px 10px}.version-update-text.svelte-fdtoa4{font-size:.85rem;color:var(--accent)}.version-status-msg.svelte-fdtoa4{font-size:.82rem;color:var(--text-muted);margin:0}.dialog.svelte-15sco2n{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:0;width:min(400px,95vw);overflow:hidden}.dialog.svelte-15sco2n::backdrop{background:#0009}.dialog-content.svelte-15sco2n{display:flex;flex-direction:column}.dialog-title.svelte-15sco2n{font-size:1.1rem;font-weight:600;padding:16px 20px 12px;margin:0;border-bottom:1px solid var(--border)}.dialog-body.svelte-15sco2n{padding:16px 20px;display:flex;flex-direction:column;gap:8px}.confirm-msg.svelte-15sco2n{font-size:.95rem;margin:0;line-height:1.5}.wt-name.svelte-15sco2n{color:var(--text)}.wt-path.svelte-15sco2n{font-size:.82rem;color:var(--text-muted);font-family:monospace;margin:0;word-break:break-all}.warning-msg.svelte-15sco2n{font-size:.82rem;color:#e74c3c;margin:0}.error-msg.svelte-15sco2n{font-size:.85rem;color:#e74c3c;margin:0;padding:8px 10px;background:#e74c3c1a;border-radius:6px;border:1px solid rgba(231,76,60,.3)}.dialog-footer.svelte-15sco2n{display:flex;justify-content:flex-end;gap:10px;padding:12px 20px 16px;border-top:1px solid var(--border)}.btn.svelte-15sco2n{padding:8px 18px;border-radius:6px;font-size:.9rem;cursor:pointer;border:1px solid transparent;font-weight:500}.btn.svelte-15sco2n:disabled{opacity:.4;cursor:not-allowed}.btn-danger.svelte-15sco2n{background:#e74c3c;color:#fff}.btn-danger.svelte-15sco2n:hover:not(:disabled){opacity:.9}.btn-ghost.svelte-15sco2n{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost.svelte-15sco2n:hover:not(:disabled){background:var(--border);color:var(--text)}.main-app.svelte-13zv0lp{display:flex;flex-direction:row;width:100%;height:100vh;height:100dvh;overflow:hidden}.sidebar-overlay.svelte-13zv0lp{display:none}.terminal-area.svelte-13zv0lp{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;position:relative}.no-session-msg.svelte-13zv0lp{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-muted);font-size:.95rem;text-align:center;pointer-events:none}@media(max-width:600px){.main-app.svelte-13zv0lp{position:fixed;top:0;right:0;bottom:0;left:0;width:100%}.sidebar-overlay.svelte-13zv0lp{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.terminal-area.svelte-13zv0lp{width:100%}}:root{--bg: #1a1a1a;--surface: #2b2b2b;--accent: #d97757;--text: #ececec;--text-muted: #9b9b9b;--border: #3d3d3d;--sidebar-width: 240px;--toolbar-height: auto;--card-bg: #252525;--success: #4caf50;--error: #e57373;--warning: #ffb74d;--info: #64b5f6;--diff-add: #4caf50;--diff-remove: #e57373;--code-font: "SF Mono", "Cascadia Code", "Fira Code", monospace;--radius-sm: 4px;--radius-md: 8px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px}[hidden]{display:none!important}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}dialog{margin:auto}html,body{height:100%;overflow:hidden;overscroll-behavior:none;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}