codekin 0.1.3
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.
Potentially problematic release.
This version of codekin might be problematic. Click here for more details.
- package/README.md +83 -0
- package/bin/codekin.mjs +372 -0
- package/dist/assets/index-BrKgETi_.css +1 -0
- package/dist/assets/index-C8gwtjTl.js +105 -0
- package/dist/data/repos.json +33 -0
- package/dist/favicon.svg +15 -0
- package/dist/index.html +14 -0
- package/package.json +53 -0
- package/server/dist/auth-routes.d.ts +12 -0
- package/server/dist/auth-routes.js +29 -0
- package/server/dist/auth-routes.js.map +1 -0
- package/server/dist/claude-process.d.ts +103 -0
- package/server/dist/claude-process.js +524 -0
- package/server/dist/claude-process.js.map +1 -0
- package/server/dist/config.d.ts +27 -0
- package/server/dist/config.js +54 -0
- package/server/dist/config.js.map +1 -0
- package/server/dist/crypto-utils.d.ts +12 -0
- package/server/dist/crypto-utils.js +22 -0
- package/server/dist/crypto-utils.js.map +1 -0
- package/server/dist/session-archive.d.ts +53 -0
- package/server/dist/session-archive.js +160 -0
- package/server/dist/session-archive.js.map +1 -0
- package/server/dist/session-manager.d.ts +226 -0
- package/server/dist/session-manager.js +1476 -0
- package/server/dist/session-manager.js.map +1 -0
- package/server/dist/session-routes.d.ts +12 -0
- package/server/dist/session-routes.js +207 -0
- package/server/dist/session-routes.js.map +1 -0
- package/server/dist/stepflow-handler.d.ts +141 -0
- package/server/dist/stepflow-handler.js +445 -0
- package/server/dist/stepflow-handler.js.map +1 -0
- package/server/dist/stepflow-prompt.d.ts +29 -0
- package/server/dist/stepflow-prompt.js +119 -0
- package/server/dist/stepflow-prompt.js.map +1 -0
- package/server/dist/stepflow-types.d.ts +249 -0
- package/server/dist/stepflow-types.js +30 -0
- package/server/dist/stepflow-types.js.map +1 -0
- package/server/dist/types.d.ts +362 -0
- package/server/dist/types.js +9 -0
- package/server/dist/types.js.map +1 -0
- package/server/dist/upload-routes.d.ts +12 -0
- package/server/dist/upload-routes.js +217 -0
- package/server/dist/upload-routes.js.map +1 -0
- package/server/dist/webhook-config.d.ts +9 -0
- package/server/dist/webhook-config.js +55 -0
- package/server/dist/webhook-config.js.map +1 -0
- package/server/dist/webhook-dedup.d.ts +21 -0
- package/server/dist/webhook-dedup.js +122 -0
- package/server/dist/webhook-dedup.js.map +1 -0
- package/server/dist/webhook-github.d.ts +50 -0
- package/server/dist/webhook-github.js +175 -0
- package/server/dist/webhook-github.js.map +1 -0
- package/server/dist/webhook-handler.d.ts +69 -0
- package/server/dist/webhook-handler.js +368 -0
- package/server/dist/webhook-handler.js.map +1 -0
- package/server/dist/webhook-prompt.d.ts +5 -0
- package/server/dist/webhook-prompt.js +67 -0
- package/server/dist/webhook-prompt.js.map +1 -0
- package/server/dist/webhook-rate-limiter.d.ts +30 -0
- package/server/dist/webhook-rate-limiter.js +78 -0
- package/server/dist/webhook-rate-limiter.js.map +1 -0
- package/server/dist/webhook-routes.d.ts +16 -0
- package/server/dist/webhook-routes.js +58 -0
- package/server/dist/webhook-routes.js.map +1 -0
- package/server/dist/webhook-types.d.ts +98 -0
- package/server/dist/webhook-types.js +2 -0
- package/server/dist/webhook-types.js.map +1 -0
- package/server/dist/webhook-workspace.d.ts +11 -0
- package/server/dist/webhook-workspace.js +124 -0
- package/server/dist/webhook-workspace.js.map +1 -0
- package/server/dist/workflow-config.d.ts +24 -0
- package/server/dist/workflow-config.js +66 -0
- package/server/dist/workflow-config.js.map +1 -0
- package/server/dist/workflow-engine.d.ts +130 -0
- package/server/dist/workflow-engine.js +529 -0
- package/server/dist/workflow-engine.js.map +1 -0
- package/server/dist/workflow-loader.d.ts +31 -0
- package/server/dist/workflow-loader.js +297 -0
- package/server/dist/workflow-loader.js.map +1 -0
- package/server/dist/workflow-routes.d.ts +14 -0
- package/server/dist/workflow-routes.js +222 -0
- package/server/dist/workflow-routes.js.map +1 -0
- package/server/dist/ws-server.d.ts +14 -0
- package/server/dist/ws-server.js +441 -0
- package/server/dist/ws-server.js.map +1 -0
package/README.md
ADDED
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
# Codekin
|
|
2
|
+
|
|
3
|
+
Web UI for Claude Code sessions — multi-session support, WebSocket streaming, file uploads, and slash-command skills.
|
|
4
|
+
|
|
5
|
+
## Install
|
|
6
|
+
|
|
7
|
+
**Prerequisites:**
|
|
8
|
+
- macOS or Linux
|
|
9
|
+
- [Claude Code CLI](https://github.com/anthropics/claude-code) installed and authenticated (`claude` must be in your PATH)
|
|
10
|
+
|
|
11
|
+
**One-liner:**
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
curl -fsSL https://codekin.dev/install.sh | bash
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
This will:
|
|
18
|
+
1. Install Node.js 20+ if needed (via nvm)
|
|
19
|
+
2. Install the `codekin` npm package globally
|
|
20
|
+
3. Prompt for your `ANTHROPIC_API_KEY` if not already set
|
|
21
|
+
4. Generate an auth token
|
|
22
|
+
5. Install and start a persistent background service
|
|
23
|
+
6. Print your access URL
|
|
24
|
+
|
|
25
|
+
Open the printed URL in your browser and you're ready to go.
|
|
26
|
+
|
|
27
|
+
## Usage
|
|
28
|
+
|
|
29
|
+
```bash
|
|
30
|
+
codekin token # Print your access URL at any time
|
|
31
|
+
codekin service status # Check whether the service is running
|
|
32
|
+
codekin service install # (Re-)install the background service
|
|
33
|
+
codekin service uninstall # Remove the background service
|
|
34
|
+
codekin start # Run in foreground (for debugging)
|
|
35
|
+
codekin setup --regenerate # Generate a new auth token
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
## Features
|
|
39
|
+
|
|
40
|
+
- **Multi-session terminal** — Open and switch between multiple Claude Code sessions, one per repo
|
|
41
|
+
- **Repo browser** — Auto-discovers local repos and GitHub org repos
|
|
42
|
+
- **Screenshot upload** — Drag-and-drop or paste images; the file path is sent to Claude so it can read them natively
|
|
43
|
+
- **Skill browser** — Browse and invoke `/skills` defined in each repo's `.claude/skills/`
|
|
44
|
+
- **Command palette** — `Ctrl+K` to quickly search repos, skills, and actions
|
|
45
|
+
|
|
46
|
+
## Upgrade
|
|
47
|
+
|
|
48
|
+
Re-run the install script — it's idempotent and will upgrade to the latest version:
|
|
49
|
+
|
|
50
|
+
```bash
|
|
51
|
+
curl -fsSL https://codekin.dev/install.sh | bash
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
Or upgrade manually:
|
|
55
|
+
|
|
56
|
+
```bash
|
|
57
|
+
npm install -g codekin
|
|
58
|
+
codekin service install
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
## Uninstall
|
|
62
|
+
|
|
63
|
+
```bash
|
|
64
|
+
codekin service uninstall
|
|
65
|
+
npm uninstall -g codekin
|
|
66
|
+
rm -rf ~/.config/codekin ~/.codekin
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
## Configuration
|
|
70
|
+
|
|
71
|
+
All configuration lives in `~/.config/codekin/env`. Edit this file to override defaults, then restart the service with `codekin service install`.
|
|
72
|
+
|
|
73
|
+
| Variable | Default | Description |
|
|
74
|
+
|---|---|---|
|
|
75
|
+
| `PORT` | `32352` | Server port |
|
|
76
|
+
| `ANTHROPIC_API_KEY` | — | Required. Your Claude API key |
|
|
77
|
+
| `REPOS_ROOT` | `~/repos` | Root directory scanned for local repositories |
|
|
78
|
+
| `GH_ORG` | — | Comma-separated GitHub orgs for repo listing |
|
|
79
|
+
| `GROQ_API_KEY` | — | Optional. Enables automatic session naming |
|
|
80
|
+
|
|
81
|
+
## Manual / Advanced Setup
|
|
82
|
+
|
|
83
|
+
For remote servers, custom nginx, or other advanced setups, see [docs/INSTALL-DISTRIBUTION.md](docs/INSTALL-DISTRIBUTION.md).
|
package/bin/codekin.mjs
ADDED
|
@@ -0,0 +1,372 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* Codekin CLI
|
|
4
|
+
*
|
|
5
|
+
* Usage:
|
|
6
|
+
* codekin start Run server in foreground
|
|
7
|
+
* codekin setup First-time setup wizard
|
|
8
|
+
* codekin service install Install + start background service
|
|
9
|
+
* codekin service uninstall Remove background service
|
|
10
|
+
* codekin service status Show service status
|
|
11
|
+
* codekin token Print access URL with auth token
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
import { execSync, execFileSync, spawnSync } from 'child_process'
|
|
15
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync, chmodSync } from 'fs'
|
|
16
|
+
import { createInterface } from 'readline'
|
|
17
|
+
import { homedir, platform } from 'os'
|
|
18
|
+
import { join, dirname } from 'path'
|
|
19
|
+
import { fileURLToPath } from 'url'
|
|
20
|
+
import { randomBytes } from 'crypto'
|
|
21
|
+
|
|
22
|
+
const __dirname = dirname(fileURLToPath(import.meta.url))
|
|
23
|
+
const PACKAGE_ROOT = join(__dirname, '..')
|
|
24
|
+
const CONFIG_DIR = join(homedir(), '.config', 'codekin')
|
|
25
|
+
const TOKEN_FILE = join(CONFIG_DIR, 'token')
|
|
26
|
+
const ENV_FILE = join(CONFIG_DIR, 'env')
|
|
27
|
+
const DEFAULT_PORT = 32352
|
|
28
|
+
|
|
29
|
+
// ---------------------------------------------------------------------------
|
|
30
|
+
// Helpers
|
|
31
|
+
// ---------------------------------------------------------------------------
|
|
32
|
+
|
|
33
|
+
function ensureConfigDir() {
|
|
34
|
+
mkdirSync(CONFIG_DIR, { recursive: true })
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
function readToken() {
|
|
38
|
+
if (existsSync(TOKEN_FILE)) return readFileSync(TOKEN_FILE, 'utf-8').trim()
|
|
39
|
+
return null
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
function readEnvFile() {
|
|
43
|
+
if (!existsSync(ENV_FILE)) return {}
|
|
44
|
+
const vars = {}
|
|
45
|
+
for (const line of readFileSync(ENV_FILE, 'utf-8').split('\n')) {
|
|
46
|
+
const trimmed = line.trim()
|
|
47
|
+
if (!trimmed || trimmed.startsWith('#')) continue
|
|
48
|
+
const eq = trimmed.indexOf('=')
|
|
49
|
+
if (eq === -1) continue
|
|
50
|
+
vars[trimmed.slice(0, eq)] = trimmed.slice(eq + 1)
|
|
51
|
+
}
|
|
52
|
+
return vars
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function writeEnvFile(vars) {
|
|
56
|
+
const lines = Object.entries(vars).map(([k, v]) => `${k}=${v}`)
|
|
57
|
+
writeFileSync(ENV_FILE, lines.join('\n') + '\n')
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
function getPort() {
|
|
61
|
+
const env = readEnvFile()
|
|
62
|
+
return parseInt(env.PORT || String(DEFAULT_PORT), 10)
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
function printAccessUrl() {
|
|
66
|
+
const token = readToken()
|
|
67
|
+
const port = getPort()
|
|
68
|
+
if (token) {
|
|
69
|
+
console.log(`\nCodekin is running at: http://localhost:${port}?token=${token}\n`)
|
|
70
|
+
} else {
|
|
71
|
+
console.log(`\nCodekin is running at: http://localhost:${port}\n`)
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
function ask(rl, question) {
|
|
76
|
+
return new Promise(resolve => rl.question(question, resolve))
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
function findServerScript() {
|
|
80
|
+
// Prefer pre-compiled JS, fall back to tsx for dev
|
|
81
|
+
const compiled = join(PACKAGE_ROOT, 'server', 'dist', 'ws-server.js')
|
|
82
|
+
if (existsSync(compiled)) return { script: compiled, runner: process.execPath }
|
|
83
|
+
const ts = join(PACKAGE_ROOT, 'server', 'ws-server.ts')
|
|
84
|
+
if (existsSync(ts)) return { script: ts, runner: 'tsx' }
|
|
85
|
+
throw new Error('Server script not found. Run npm run build first.')
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
function findFrontendDist() {
|
|
89
|
+
const dist = join(PACKAGE_ROOT, 'dist')
|
|
90
|
+
if (existsSync(dist)) return dist
|
|
91
|
+
return null
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
// ---------------------------------------------------------------------------
|
|
95
|
+
// Commands
|
|
96
|
+
// ---------------------------------------------------------------------------
|
|
97
|
+
|
|
98
|
+
async function cmdSetup({ regenerate = false } = {}) {
|
|
99
|
+
ensureConfigDir()
|
|
100
|
+
|
|
101
|
+
const rl = createInterface({ input: process.stdin, output: process.stdout })
|
|
102
|
+
|
|
103
|
+
console.log('\n-- Codekin Setup --\n')
|
|
104
|
+
|
|
105
|
+
// API key
|
|
106
|
+
const existing = readEnvFile()
|
|
107
|
+
let apiKey = process.env.ANTHROPIC_API_KEY || existing.ANTHROPIC_API_KEY || ''
|
|
108
|
+
if (!apiKey) {
|
|
109
|
+
apiKey = (await ask(rl, 'ANTHROPIC_API_KEY: ')).trim()
|
|
110
|
+
if (!apiKey) {
|
|
111
|
+
console.error('API key is required.')
|
|
112
|
+
rl.close()
|
|
113
|
+
process.exit(1)
|
|
114
|
+
}
|
|
115
|
+
} else {
|
|
116
|
+
console.log('ANTHROPIC_API_KEY: (already set)')
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
// Auth token
|
|
120
|
+
const existingToken = readToken()
|
|
121
|
+
if (existingToken && !regenerate) {
|
|
122
|
+
console.log('Auth token: (already exists, use --regenerate to replace)')
|
|
123
|
+
} else {
|
|
124
|
+
const token = randomBytes(32).toString('hex')
|
|
125
|
+
writeFileSync(TOKEN_FILE, token + '\n', { mode: 0o600 })
|
|
126
|
+
console.log('Auth token: generated')
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
// Write env file
|
|
130
|
+
const frontendDist = findFrontendDist()
|
|
131
|
+
const envVars = {
|
|
132
|
+
...existing,
|
|
133
|
+
ANTHROPIC_API_KEY: apiKey,
|
|
134
|
+
AUTH_TOKEN_FILE: TOKEN_FILE,
|
|
135
|
+
}
|
|
136
|
+
if (frontendDist) envVars.FRONTEND_DIST = frontendDist
|
|
137
|
+
writeEnvFile(envVars)
|
|
138
|
+
console.log(`Config saved to ${CONFIG_DIR}`)
|
|
139
|
+
|
|
140
|
+
rl.close()
|
|
141
|
+
printAccessUrl()
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
function cmdToken() {
|
|
145
|
+
const token = readToken()
|
|
146
|
+
if (!token) {
|
|
147
|
+
console.error('No token found. Run: codekin setup')
|
|
148
|
+
process.exit(1)
|
|
149
|
+
}
|
|
150
|
+
printAccessUrl()
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
function cmdStart() {
|
|
154
|
+
const { script, runner } = findServerScript()
|
|
155
|
+
const frontendDist = findFrontendDist()
|
|
156
|
+
const env = {
|
|
157
|
+
...process.env,
|
|
158
|
+
...readEnvFile(),
|
|
159
|
+
}
|
|
160
|
+
if (frontendDist && !env.FRONTEND_DIST) env.FRONTEND_DIST = frontendDist
|
|
161
|
+
|
|
162
|
+
console.log(`Starting Codekin server (${script})...`)
|
|
163
|
+
printAccessUrl()
|
|
164
|
+
|
|
165
|
+
const result = spawnSync(runner, [script], {
|
|
166
|
+
env,
|
|
167
|
+
stdio: 'inherit',
|
|
168
|
+
})
|
|
169
|
+
process.exit(result.status ?? 0)
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
// ---------------------------------------------------------------------------
|
|
173
|
+
// Service: macOS (launchd)
|
|
174
|
+
// ---------------------------------------------------------------------------
|
|
175
|
+
|
|
176
|
+
const LAUNCHD_LABEL = 'ai.codekin'
|
|
177
|
+
const LAUNCHD_PLIST = join(homedir(), 'Library', 'LaunchAgents', `${LAUNCHD_LABEL}.plist`)
|
|
178
|
+
|
|
179
|
+
function buildPlist() {
|
|
180
|
+
const { script, runner } = findServerScript()
|
|
181
|
+
const envVars = readEnvFile()
|
|
182
|
+
const envEntries = Object.entries(envVars)
|
|
183
|
+
.map(([k, v]) => `\t\t<key>${k}</key>\n\t\t<string>${v}</string>`)
|
|
184
|
+
.join('\n')
|
|
185
|
+
|
|
186
|
+
return `<?xml version="1.0" encoding="UTF-8"?>
|
|
187
|
+
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
188
|
+
<plist version="1.0">
|
|
189
|
+
<dict>
|
|
190
|
+
\t<key>Label</key>
|
|
191
|
+
\t<string>${LAUNCHD_LABEL}</string>
|
|
192
|
+
\t<key>ProgramArguments</key>
|
|
193
|
+
\t<array>
|
|
194
|
+
\t\t<string>${runner}</string>
|
|
195
|
+
\t\t<string>${script}</string>
|
|
196
|
+
\t</array>
|
|
197
|
+
\t<key>EnvironmentVariables</key>
|
|
198
|
+
\t<dict>
|
|
199
|
+
${envEntries}
|
|
200
|
+
\t</dict>
|
|
201
|
+
\t<key>RunAtLoad</key>
|
|
202
|
+
\t<true/>
|
|
203
|
+
\t<key>KeepAlive</key>
|
|
204
|
+
\t<true/>
|
|
205
|
+
\t<key>StandardOutPath</key>
|
|
206
|
+
\t<string>${join(homedir(), '.codekin', 'server.log')}</string>
|
|
207
|
+
\t<key>StandardErrorPath</key>
|
|
208
|
+
\t<string>${join(homedir(), '.codekin', 'server.log')}</string>
|
|
209
|
+
</dict>
|
|
210
|
+
</plist>
|
|
211
|
+
`
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
function serviceInstallMac() {
|
|
215
|
+
mkdirSync(dirname(LAUNCHD_PLIST), { recursive: true })
|
|
216
|
+
mkdirSync(join(homedir(), '.codekin'), { recursive: true })
|
|
217
|
+
|
|
218
|
+
// Unload existing if present
|
|
219
|
+
if (existsSync(LAUNCHD_PLIST)) {
|
|
220
|
+
spawnSync('launchctl', ['unload', LAUNCHD_PLIST], { stdio: 'inherit' })
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
writeFileSync(LAUNCHD_PLIST, buildPlist())
|
|
224
|
+
const result = spawnSync('launchctl', ['load', LAUNCHD_PLIST], { stdio: 'inherit' })
|
|
225
|
+
if (result.status === 0) {
|
|
226
|
+
console.log('Codekin service installed and started.')
|
|
227
|
+
printAccessUrl()
|
|
228
|
+
} else {
|
|
229
|
+
console.error('Failed to load launchd service.')
|
|
230
|
+
process.exit(1)
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
function serviceUninstallMac() {
|
|
235
|
+
if (!existsSync(LAUNCHD_PLIST)) {
|
|
236
|
+
console.log('Service not installed.')
|
|
237
|
+
return
|
|
238
|
+
}
|
|
239
|
+
spawnSync('launchctl', ['unload', LAUNCHD_PLIST], { stdio: 'inherit' })
|
|
240
|
+
import('fs').then(fs => fs.unlinkSync(LAUNCHD_PLIST))
|
|
241
|
+
console.log('Codekin service removed.')
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
function serviceStatusMac() {
|
|
245
|
+
const result = spawnSync('launchctl', ['list', LAUNCHD_LABEL], { encoding: 'utf-8' })
|
|
246
|
+
if (result.status === 0) {
|
|
247
|
+
console.log('Codekin service is running.')
|
|
248
|
+
printAccessUrl()
|
|
249
|
+
} else {
|
|
250
|
+
console.log('Codekin service is not running.')
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
// ---------------------------------------------------------------------------
|
|
255
|
+
// Service: Linux (systemd --user)
|
|
256
|
+
// ---------------------------------------------------------------------------
|
|
257
|
+
|
|
258
|
+
const SYSTEMD_SERVICE_DIR = join(homedir(), '.config', 'systemd', 'user')
|
|
259
|
+
const SYSTEMD_SERVICE_FILE = join(SYSTEMD_SERVICE_DIR, 'codekin.service')
|
|
260
|
+
|
|
261
|
+
function buildSystemdUnit() {
|
|
262
|
+
const { script, runner } = findServerScript()
|
|
263
|
+
return `[Unit]
|
|
264
|
+
Description=Codekin - Web UI for Claude Code
|
|
265
|
+
After=network.target
|
|
266
|
+
|
|
267
|
+
[Service]
|
|
268
|
+
Type=simple
|
|
269
|
+
ExecStart=${runner} ${script}
|
|
270
|
+
EnvironmentFile=${ENV_FILE}
|
|
271
|
+
Restart=always
|
|
272
|
+
RestartSec=5
|
|
273
|
+
|
|
274
|
+
[Install]
|
|
275
|
+
WantedBy=default.target
|
|
276
|
+
`
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
function serviceInstallLinux() {
|
|
280
|
+
mkdirSync(SYSTEMD_SERVICE_DIR, { recursive: true })
|
|
281
|
+
mkdirSync(join(homedir(), '.codekin'), { recursive: true })
|
|
282
|
+
|
|
283
|
+
writeFileSync(SYSTEMD_SERVICE_FILE, buildSystemdUnit())
|
|
284
|
+
|
|
285
|
+
spawnSync('systemctl', ['--user', 'daemon-reload'], { stdio: 'inherit' })
|
|
286
|
+
const result = spawnSync('systemctl', ['--user', 'enable', '--now', 'codekin'], { stdio: 'inherit' })
|
|
287
|
+
|
|
288
|
+
// Enable linger so service survives logout (best-effort)
|
|
289
|
+
spawnSync('loginctl', ['enable-linger', process.env.USER || ''], { stdio: 'pipe' })
|
|
290
|
+
|
|
291
|
+
if (result.status === 0) {
|
|
292
|
+
console.log('Codekin service installed and started.')
|
|
293
|
+
printAccessUrl()
|
|
294
|
+
} else {
|
|
295
|
+
console.error('Failed to start systemd service. Check: journalctl --user -u codekin')
|
|
296
|
+
process.exit(1)
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
function serviceUninstallLinux() {
|
|
301
|
+
spawnSync('systemctl', ['--user', 'disable', '--now', 'codekin'], { stdio: 'inherit' })
|
|
302
|
+
if (existsSync(SYSTEMD_SERVICE_FILE)) {
|
|
303
|
+
import('fs').then(fs => fs.unlinkSync(SYSTEMD_SERVICE_FILE))
|
|
304
|
+
}
|
|
305
|
+
spawnSync('systemctl', ['--user', 'daemon-reload'], { stdio: 'inherit' })
|
|
306
|
+
console.log('Codekin service removed.')
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
function serviceStatusLinux() {
|
|
310
|
+
const result = spawnSync('systemctl', ['--user', 'is-active', 'codekin'], { encoding: 'utf-8' })
|
|
311
|
+
const active = result.stdout.trim() === 'active'
|
|
312
|
+
if (active) {
|
|
313
|
+
console.log('Codekin service is running.')
|
|
314
|
+
printAccessUrl()
|
|
315
|
+
} else {
|
|
316
|
+
console.log('Codekin service is not running.')
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
// ---------------------------------------------------------------------------
|
|
321
|
+
// Service dispatch
|
|
322
|
+
// ---------------------------------------------------------------------------
|
|
323
|
+
|
|
324
|
+
function serviceDispatch(action) {
|
|
325
|
+
const os = platform()
|
|
326
|
+
if (os === 'darwin') {
|
|
327
|
+
if (action === 'install') serviceInstallMac()
|
|
328
|
+
else if (action === 'uninstall') serviceUninstallMac()
|
|
329
|
+
else if (action === 'status') serviceStatusMac()
|
|
330
|
+
} else if (os === 'linux') {
|
|
331
|
+
if (action === 'install') serviceInstallLinux()
|
|
332
|
+
else if (action === 'uninstall') serviceUninstallLinux()
|
|
333
|
+
else if (action === 'status') serviceStatusLinux()
|
|
334
|
+
} else {
|
|
335
|
+
console.error(`Service management is not supported on ${os}. Use 'codekin start' for foreground mode.`)
|
|
336
|
+
process.exit(1)
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
// ---------------------------------------------------------------------------
|
|
341
|
+
// Entry point
|
|
342
|
+
// ---------------------------------------------------------------------------
|
|
343
|
+
|
|
344
|
+
const args = process.argv.slice(2)
|
|
345
|
+
const cmd = args[0]
|
|
346
|
+
|
|
347
|
+
if (cmd === 'start') {
|
|
348
|
+
cmdStart()
|
|
349
|
+
} else if (cmd === 'setup') {
|
|
350
|
+
await cmdSetup({ regenerate: args.includes('--regenerate') })
|
|
351
|
+
} else if (cmd === 'token') {
|
|
352
|
+
cmdToken()
|
|
353
|
+
} else if (cmd === 'service') {
|
|
354
|
+
const action = args[1]
|
|
355
|
+
if (!['install', 'uninstall', 'status'].includes(action)) {
|
|
356
|
+
console.error('Usage: codekin service <install|uninstall|status>')
|
|
357
|
+
process.exit(1)
|
|
358
|
+
}
|
|
359
|
+
serviceDispatch(action)
|
|
360
|
+
} else {
|
|
361
|
+
console.log(`Codekin - Web UI for Claude Code
|
|
362
|
+
|
|
363
|
+
Usage:
|
|
364
|
+
codekin start Run server in foreground
|
|
365
|
+
codekin setup First-time setup wizard
|
|
366
|
+
codekin setup --regenerate Regenerate auth token
|
|
367
|
+
codekin service install Install + start background service
|
|
368
|
+
codekin service uninstall Remove background service
|
|
369
|
+
codekin service status Show service status
|
|
370
|
+
codekin token Print access URL with auth token
|
|
371
|
+
`)
|
|
372
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@import"https://fonts.googleapis.com/css2?family=Inconsolata:wght@300..700&family=Lato:wght@300;400;700&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-space-y-reverse:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:"Lato", sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-lg:32rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wide:.025em;--tracking-wider:.05em;--tracking-widest:.1em;--leading-snug:1.375;--leading-relaxed:1.625;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-primary-2:#fcedcc;--color-primary-3:#f8dca0;--color-primary-4:#f0c56e;--color-primary-5:#e4ae42;--color-primary-6:#cf9a2d;--color-primary-7:#9d7440;--color-primary-8:#9e7335;--color-primary-9:#7d5b2a;--color-primary-10:#5c4420;--color-primary-11:#3a2c15;--color-accent-2:#d0f0f5;--color-accent-3:#a5e0ea;--color-accent-4:#74cbda;--color-accent-5:#45b5c9;--color-accent-6:#2d9bb0;--color-accent-7:#248192;--color-accent-8:#1d6876;--color-accent-9:#17515c;--color-accent-11:#0c282e;--color-neutral-1:#dce4e5;--color-neutral-2:#c6d4d5;--color-neutral-3:#b8ccce;--color-neutral-4:#94aeb1;--color-neutral-5:#748d91;--color-neutral-6:#5c7377;--color-neutral-7:#465c60;--color-neutral-8:#354a4e;--color-neutral-9:#263a3e;--color-neutral-10:#1a2c30;--color-neutral-11:#101e21;--color-neutral-12:#090e0f;--color-error-2:#fddcdc;--color-error-4:#f28a8a;--color-error-5:#e86060;--color-error-7:#c03636;--color-error-8:#a12c2c;--color-error-9:#822323;--color-error-10:#631b1b;--color-warning-2:#fdf1c8;--color-warning-3:#fae295;--color-warning-4:#f4ce5e;--color-warning-5:#e8b830;--color-warning-6:#d0a020;--color-warning-7:#b08618;--color-warning-8:#906d12;--color-warning-9:#73560e;--color-warning-10:#56400a;--color-warning-11:#382a07;--color-success-2:#d0f2e2;--color-success-3:#a0e4c4;--color-success-4:#6dd1a2;--color-success-5:#40bc80;--color-success-6:#2da368;--color-success-7:#248854;--color-success-8:#1d6e43;--color-success-9:#175634;--color-success-10:#114027}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);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}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-3{top:calc(var(--spacing) * 3)}.right-0{right:calc(var(--spacing) * 0)}.right-3{right:calc(var(--spacing) * 3)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-3{bottom:calc(var(--spacing) * 3)}.bottom-full{bottom:100%}.left-0{left:calc(var(--spacing) * 0)}.left-1\/2{left:50%}.left-full{left:100%}.isolate{isolation:isolate}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mx-3{margin-inline:calc(var(--spacing) * 3)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-auto{margin-top:auto}.mt-px{margin-top:1px}.mr-1{margin-right:calc(var(--spacing) * 1)}.mr-4{margin-right:calc(var(--spacing) * 4)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.ml-0\.5{margin-left:calc(var(--spacing) * .5)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-3{margin-left:calc(var(--spacing) * 3)}.ml-auto{margin-left:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-1{height:calc(var(--spacing) * 1)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-4{height:calc(var(--spacing) * 4)}.h-10{height:calc(var(--spacing) * 10)}.h-full{height:100%}.max-h-60{max-height:calc(var(--spacing) * 60)}.max-h-64{max-height:calc(var(--spacing) * 64)}.max-h-72{max-height:calc(var(--spacing) * 72)}.max-h-\[90vh\]{max-height:90vh}.max-h-\[200px\]{max-height:200px}.max-h-\[240px\]{max-height:240px}.max-h-\[300px\]{max-height:300px}.min-h-0{min-height:calc(var(--spacing) * 0)}.w-1{width:calc(var(--spacing) * 1)}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2{width:calc(var(--spacing) * 2)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-4{width:calc(var(--spacing) * 4)}.w-8{width:calc(var(--spacing) * 8)}.w-10{width:calc(var(--spacing) * 10)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-20{width:calc(var(--spacing) * 20)}.w-56{width:calc(var(--spacing) * 56)}.w-64{width:calc(var(--spacing) * 64)}.w-72{width:calc(var(--spacing) * 72)}.w-\[286px\]{width:286px}.w-\[480px\]{width:480px}.w-full{width:100%}.max-w-\[80\%\]{max-width:80%}.max-w-\[150px\]{max-width:150px}.max-w-\[180px\]{max-width:180px}.max-w-\[400px\]{max-width:400px}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.max-w-none{max-width:none}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[160px\]{min-width:160px}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-90{rotate:90deg}.animate-\[spin_3s_linear_infinite\]{animation:3s linear infinite spin}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-col-resize{cursor:col-resize}.cursor-pointer{cursor:pointer}.cursor-row-resize{cursor:row-resize}.cursor-wait{cursor:wait}.resize{resize:both}.resize-none{resize:none}.list-none{list-style-type:none}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}:where(.space-y-0\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * .5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * .5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}.gap-x-4{column-gap:calc(var(--spacing) * 4)}.gap-y-0\.5{row-gap:calc(var(--spacing) * .5)}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-neutral-8\/40>:not(:last-child)){border-color:#354a4e66}@supports (color:color-mix(in lab,red,red)){:where(.divide-neutral-8\/40>:not(:last-child)){border-color:color-mix(in oklab,var(--color-neutral-8) 40%,transparent)}}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-accent-5{border-color:var(--color-accent-5)}.border-accent-6{border-color:var(--color-accent-6)}.border-accent-6\/60{border-color:#2d9bb099}@supports (color:color-mix(in lab,red,red)){.border-accent-6\/60{border-color:color-mix(in oklab,var(--color-accent-6) 60%,transparent)}}.border-accent-7\/60{border-color:#24819299}@supports (color:color-mix(in lab,red,red)){.border-accent-7\/60{border-color:color-mix(in oklab,var(--color-accent-7) 60%,transparent)}}.border-error-7{border-color:var(--color-error-7)}.border-error-7\/60{border-color:#c0363699}@supports (color:color-mix(in lab,red,red)){.border-error-7\/60{border-color:color-mix(in oklab,var(--color-error-7) 60%,transparent)}}.border-error-8\/50{border-color:#a12c2c80}@supports (color:color-mix(in lab,red,red)){.border-error-8\/50{border-color:color-mix(in oklab,var(--color-error-8) 50%,transparent)}}.border-error-9\/50{border-color:#82232380}@supports (color:color-mix(in lab,red,red)){.border-error-9\/50{border-color:color-mix(in oklab,var(--color-error-9) 50%,transparent)}}.border-neutral-5{border-color:var(--color-neutral-5)}.border-neutral-6{border-color:var(--color-neutral-6)}.border-neutral-6\/40{border-color:#5c737766}@supports (color:color-mix(in lab,red,red)){.border-neutral-6\/40{border-color:color-mix(in oklab,var(--color-neutral-6) 40%,transparent)}}.border-neutral-7{border-color:var(--color-neutral-7)}.border-neutral-7\/30{border-color:#465c604d}@supports (color:color-mix(in lab,red,red)){.border-neutral-7\/30{border-color:color-mix(in oklab,var(--color-neutral-7) 30%,transparent)}}.border-neutral-7\/50{border-color:#465c6080}@supports (color:color-mix(in lab,red,red)){.border-neutral-7\/50{border-color:color-mix(in oklab,var(--color-neutral-7) 50%,transparent)}}.border-neutral-7\/60{border-color:#465c6099}@supports (color:color-mix(in lab,red,red)){.border-neutral-7\/60{border-color:color-mix(in oklab,var(--color-neutral-7) 60%,transparent)}}.border-neutral-8{border-color:var(--color-neutral-8)}.border-neutral-8\/30{border-color:#354a4e4d}@supports (color:color-mix(in lab,red,red)){.border-neutral-8\/30{border-color:color-mix(in oklab,var(--color-neutral-8) 30%,transparent)}}.border-neutral-8\/40{border-color:#354a4e66}@supports (color:color-mix(in lab,red,red)){.border-neutral-8\/40{border-color:color-mix(in oklab,var(--color-neutral-8) 40%,transparent)}}.border-neutral-8\/50{border-color:#354a4e80}@supports (color:color-mix(in lab,red,red)){.border-neutral-8\/50{border-color:color-mix(in oklab,var(--color-neutral-8) 50%,transparent)}}.border-neutral-8\/60{border-color:#354a4e99}@supports (color:color-mix(in lab,red,red)){.border-neutral-8\/60{border-color:color-mix(in oklab,var(--color-neutral-8) 60%,transparent)}}.border-neutral-9{border-color:var(--color-neutral-9)}.border-neutral-9\/50{border-color:#263a3e80}@supports (color:color-mix(in lab,red,red)){.border-neutral-9\/50{border-color:color-mix(in oklab,var(--color-neutral-9) 50%,transparent)}}.border-neutral-10{border-color:var(--color-neutral-10)}.border-primary-6{border-color:var(--color-primary-6)}.border-primary-7{border-color:var(--color-primary-7)}.border-primary-9\/50{border-color:#7d5b2a80}@supports (color:color-mix(in lab,red,red)){.border-primary-9\/50{border-color:color-mix(in oklab,var(--color-primary-9) 50%,transparent)}}.border-success-7{border-color:var(--color-success-7)}.border-success-7\/60{border-color:#24885499}@supports (color:color-mix(in lab,red,red)){.border-success-7\/60{border-color:color-mix(in oklab,var(--color-success-7) 60%,transparent)}}.border-transparent{border-color:#0000}.border-warning-6{border-color:var(--color-warning-6)}.border-warning-7{border-color:var(--color-warning-7)}.border-warning-7\/60{border-color:#b0861899}@supports (color:color-mix(in lab,red,red)){.border-warning-7\/60{border-color:color-mix(in oklab,var(--color-warning-7) 60%,transparent)}}.border-warning-8\/40{border-color:#906d1266}@supports (color:color-mix(in lab,red,red)){.border-warning-8\/40{border-color:color-mix(in oklab,var(--color-warning-8) 40%,transparent)}}.border-warning-8\/50{border-color:#906d1280}@supports (color:color-mix(in lab,red,red)){.border-warning-8\/50{border-color:color-mix(in oklab,var(--color-warning-8) 50%,transparent)}}.border-warning-9\/50{border-color:#73560e80}@supports (color:color-mix(in lab,red,red)){.border-warning-9\/50{border-color:color-mix(in oklab,var(--color-warning-9) 50%,transparent)}}.bg-accent-2{background-color:var(--color-accent-2)}.bg-accent-3{background-color:var(--color-accent-3)}.bg-accent-4{background-color:var(--color-accent-4)}.bg-accent-6{background-color:var(--color-accent-6)}.bg-accent-7{background-color:var(--color-accent-7)}.bg-accent-8{background-color:var(--color-accent-8)}.bg-accent-8\/50{background-color:#1d687680}@supports (color:color-mix(in lab,red,red)){.bg-accent-8\/50{background-color:color-mix(in oklab,var(--color-accent-8) 50%,transparent)}}.bg-accent-9\/30{background-color:#17515c4d}@supports (color:color-mix(in lab,red,red)){.bg-accent-9\/30{background-color:color-mix(in oklab,var(--color-accent-9) 30%,transparent)}}.bg-accent-9\/40{background-color:#17515c66}@supports (color:color-mix(in lab,red,red)){.bg-accent-9\/40{background-color:color-mix(in oklab,var(--color-accent-9) 40%,transparent)}}.bg-accent-11\/20{background-color:#0c282e33}@supports (color:color-mix(in lab,red,red)){.bg-accent-11\/20{background-color:color-mix(in oklab,var(--color-accent-11) 20%,transparent)}}.bg-black\/60{background-color:#0009}@supports (color:color-mix(in lab,red,red)){.bg-black\/60{background-color:color-mix(in oklab,var(--color-black) 60%,transparent)}}.bg-error-5{background-color:var(--color-error-5)}.bg-error-7{background-color:var(--color-error-7)}.bg-error-8{background-color:var(--color-error-8)}.bg-error-9\/40{background-color:#82232366}@supports (color:color-mix(in lab,red,red)){.bg-error-9\/40{background-color:color-mix(in oklab,var(--color-error-9) 40%,transparent)}}.bg-error-10\/30{background-color:#631b1b4d}@supports (color:color-mix(in lab,red,red)){.bg-error-10\/30{background-color:color-mix(in oklab,var(--color-error-10) 30%,transparent)}}.bg-error-10\/50{background-color:#631b1b80}@supports (color:color-mix(in lab,red,red)){.bg-error-10\/50{background-color:color-mix(in oklab,var(--color-error-10) 50%,transparent)}}.bg-neutral-5{background-color:var(--color-neutral-5)}.bg-neutral-6{background-color:var(--color-neutral-6)}.bg-neutral-7{background-color:var(--color-neutral-7)}.bg-neutral-7\/50{background-color:#465c6080}@supports (color:color-mix(in lab,red,red)){.bg-neutral-7\/50{background-color:color-mix(in oklab,var(--color-neutral-7) 50%,transparent)}}.bg-neutral-8{background-color:var(--color-neutral-8)}.bg-neutral-8\/30{background-color:#354a4e4d}@supports (color:color-mix(in lab,red,red)){.bg-neutral-8\/30{background-color:color-mix(in oklab,var(--color-neutral-8) 30%,transparent)}}.bg-neutral-8\/40{background-color:#354a4e66}@supports (color:color-mix(in lab,red,red)){.bg-neutral-8\/40{background-color:color-mix(in oklab,var(--color-neutral-8) 40%,transparent)}}.bg-neutral-8\/90{background-color:#354a4ee6}@supports (color:color-mix(in lab,red,red)){.bg-neutral-8\/90{background-color:color-mix(in oklab,var(--color-neutral-8) 90%,transparent)}}.bg-neutral-9{background-color:var(--color-neutral-9)}.bg-neutral-9\/40{background-color:#263a3e66}@supports (color:color-mix(in lab,red,red)){.bg-neutral-9\/40{background-color:color-mix(in oklab,var(--color-neutral-9) 40%,transparent)}}.bg-neutral-9\/60{background-color:#263a3e99}@supports (color:color-mix(in lab,red,red)){.bg-neutral-9\/60{background-color:color-mix(in oklab,var(--color-neutral-9) 60%,transparent)}}.bg-neutral-9\/70{background-color:#263a3eb3}@supports (color:color-mix(in lab,red,red)){.bg-neutral-9\/70{background-color:color-mix(in oklab,var(--color-neutral-9) 70%,transparent)}}.bg-neutral-9\/80{background-color:#263a3ecc}@supports (color:color-mix(in lab,red,red)){.bg-neutral-9\/80{background-color:color-mix(in oklab,var(--color-neutral-9) 80%,transparent)}}.bg-neutral-9\/90{background-color:#263a3ee6}@supports (color:color-mix(in lab,red,red)){.bg-neutral-9\/90{background-color:color-mix(in oklab,var(--color-neutral-9) 90%,transparent)}}.bg-neutral-10{background-color:var(--color-neutral-10)}.bg-neutral-10\/30{background-color:#1a2c304d}@supports (color:color-mix(in lab,red,red)){.bg-neutral-10\/30{background-color:color-mix(in oklab,var(--color-neutral-10) 30%,transparent)}}.bg-neutral-10\/50{background-color:#1a2c3080}@supports (color:color-mix(in lab,red,red)){.bg-neutral-10\/50{background-color:color-mix(in oklab,var(--color-neutral-10) 50%,transparent)}}.bg-neutral-10\/60{background-color:#1a2c3099}@supports (color:color-mix(in lab,red,red)){.bg-neutral-10\/60{background-color:color-mix(in oklab,var(--color-neutral-10) 60%,transparent)}}.bg-neutral-10\/90{background-color:#1a2c30e6}@supports (color:color-mix(in lab,red,red)){.bg-neutral-10\/90{background-color:color-mix(in oklab,var(--color-neutral-10) 90%,transparent)}}.bg-neutral-11{background-color:var(--color-neutral-11)}.bg-neutral-11\/20{background-color:#101e2133}@supports (color:color-mix(in lab,red,red)){.bg-neutral-11\/20{background-color:color-mix(in oklab,var(--color-neutral-11) 20%,transparent)}}.bg-neutral-11\/40{background-color:#101e2166}@supports (color:color-mix(in lab,red,red)){.bg-neutral-11\/40{background-color:color-mix(in oklab,var(--color-neutral-11) 40%,transparent)}}.bg-neutral-11\/50{background-color:#101e2180}@supports (color:color-mix(in lab,red,red)){.bg-neutral-11\/50{background-color:color-mix(in oklab,var(--color-neutral-11) 50%,transparent)}}.bg-neutral-11\/60{background-color:#101e2199}@supports (color:color-mix(in lab,red,red)){.bg-neutral-11\/60{background-color:color-mix(in oklab,var(--color-neutral-11) 60%,transparent)}}.bg-neutral-11\/80{background-color:#101e21cc}@supports (color:color-mix(in lab,red,red)){.bg-neutral-11\/80{background-color:color-mix(in oklab,var(--color-neutral-11) 80%,transparent)}}.bg-neutral-12{background-color:var(--color-neutral-12)}.bg-neutral-12\/80{background-color:#090e0fcc}@supports (color:color-mix(in lab,red,red)){.bg-neutral-12\/80{background-color:color-mix(in oklab,var(--color-neutral-12) 80%,transparent)}}.bg-primary-5{background-color:var(--color-primary-5)}.bg-primary-8{background-color:var(--color-primary-8)}.bg-primary-9{background-color:var(--color-primary-9)}.bg-primary-9\/30{background-color:#7d5b2a4d}@supports (color:color-mix(in lab,red,red)){.bg-primary-9\/30{background-color:color-mix(in oklab,var(--color-primary-9) 30%,transparent)}}.bg-primary-10\/30{background-color:#5c44204d}@supports (color:color-mix(in lab,red,red)){.bg-primary-10\/30{background-color:color-mix(in oklab,var(--color-primary-10) 30%,transparent)}}.bg-primary-10\/50{background-color:#5c442080}@supports (color:color-mix(in lab,red,red)){.bg-primary-10\/50{background-color:color-mix(in oklab,var(--color-primary-10) 50%,transparent)}}.bg-primary-11\/60{background-color:#3a2c1599}@supports (color:color-mix(in lab,red,red)){.bg-primary-11\/60{background-color:color-mix(in oklab,var(--color-primary-11) 60%,transparent)}}.bg-primary-11\/80{background-color:#3a2c15cc}@supports (color:color-mix(in lab,red,red)){.bg-primary-11\/80{background-color:color-mix(in oklab,var(--color-primary-11) 80%,transparent)}}.bg-success-3{background-color:var(--color-success-3)}.bg-success-5{background-color:var(--color-success-5)}.bg-success-6{background-color:var(--color-success-6)}.bg-success-7{background-color:var(--color-success-7)}.bg-success-8\/40{background-color:#1d6e4366}@supports (color:color-mix(in lab,red,red)){.bg-success-8\/40{background-color:color-mix(in oklab,var(--color-success-8) 40%,transparent)}}.bg-success-9\/30{background-color:#1756344d}@supports (color:color-mix(in lab,red,red)){.bg-success-9\/30{background-color:color-mix(in oklab,var(--color-success-9) 30%,transparent)}}.bg-success-10\/50{background-color:#11402780}@supports (color:color-mix(in lab,red,red)){.bg-success-10\/50{background-color:color-mix(in oklab,var(--color-success-10) 50%,transparent)}}.bg-transparent{background-color:#0000}.bg-warning-3{background-color:var(--color-warning-3)}.bg-warning-5{background-color:var(--color-warning-5)}.bg-warning-6{background-color:var(--color-warning-6)}.bg-warning-8{background-color:var(--color-warning-8)}.bg-warning-9\/30{background-color:#73560e4d}@supports (color:color-mix(in lab,red,red)){.bg-warning-9\/30{background-color:color-mix(in oklab,var(--color-warning-9) 30%,transparent)}}.bg-warning-9\/40{background-color:#73560e66}@supports (color:color-mix(in lab,red,red)){.bg-warning-9\/40{background-color:color-mix(in oklab,var(--color-warning-9) 40%,transparent)}}.bg-warning-10\/40{background-color:#56400a66}@supports (color:color-mix(in lab,red,red)){.bg-warning-10\/40{background-color:color-mix(in oklab,var(--color-warning-10) 40%,transparent)}}.bg-warning-10\/50{background-color:#56400a80}@supports (color:color-mix(in lab,red,red)){.bg-warning-10\/50{background-color:color-mix(in oklab,var(--color-warning-10) 50%,transparent)}}.bg-warning-11\/20{background-color:#382a0733}@supports (color:color-mix(in lab,red,red)){.bg-warning-11\/20{background-color:color-mix(in oklab,var(--color-warning-11) 20%,transparent)}}.bg-warning-11\/30{background-color:#382a074d}@supports (color:color-mix(in lab,red,red)){.bg-warning-11\/30{background-color:color-mix(in oklab,var(--color-warning-11) 30%,transparent)}}.p-0\.5{padding:calc(var(--spacing) * .5)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-2\.5{padding:calc(var(--spacing) * 2.5)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.px-0\.5{padding-inline:calc(var(--spacing) * .5)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-3\.5{padding-inline:calc(var(--spacing) * 3.5)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.pt-0\.5{padding-top:calc(var(--spacing) * .5)}.pt-1{padding-top:calc(var(--spacing) * 1)}.pt-1\.5{padding-top:calc(var(--spacing) * 1.5)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-2\.5{padding-top:calc(var(--spacing) * 2.5)}.pt-3{padding-top:calc(var(--spacing) * 3)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pt-\[20vh\]{padding-top:20vh}.pr-1{padding-right:calc(var(--spacing) * 1)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pr-3{padding-right:calc(var(--spacing) * 3)}.pb-0\.5{padding-bottom:calc(var(--spacing) * .5)}.pb-1{padding-bottom:calc(var(--spacing) * 1)}.pb-1\.5{padding-bottom:calc(var(--spacing) * 1.5)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-2\.5{padding-bottom:calc(var(--spacing) * 2.5)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.pl-1{padding-left:calc(var(--spacing) * 1)}.pl-3{padding-left:calc(var(--spacing) * 3)}.pl-4{padding-left:calc(var(--spacing) * 4)}.pl-10{padding-left:calc(var(--spacing) * 10)}.pl-12{padding-left:calc(var(--spacing) * 12)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[16px\]{font-size:16px}.text-\[17px\]{font-size:17px}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.text-accent-2{color:var(--color-accent-2)}.text-accent-3{color:var(--color-accent-3)}.text-accent-4{color:var(--color-accent-4)}.text-accent-6{color:var(--color-accent-6)}.text-error-2{color:var(--color-error-2)}.text-error-4{color:var(--color-error-4)}.text-error-5{color:var(--color-error-5)}.text-neutral-1{color:var(--color-neutral-1)}.text-neutral-2{color:var(--color-neutral-2)}.text-neutral-3{color:var(--color-neutral-3)}.text-neutral-4{color:var(--color-neutral-4)}.text-neutral-5{color:var(--color-neutral-5)}.text-neutral-6{color:var(--color-neutral-6)}.text-neutral-7{color:var(--color-neutral-7)}.text-primary-3{color:var(--color-primary-3)}.text-primary-4{color:var(--color-primary-4)}.text-primary-5{color:var(--color-primary-5)}.text-primary-6{color:var(--color-primary-6)}.text-primary-7{color:var(--color-primary-7)}.text-success-2{color:var(--color-success-2)}.text-success-4{color:var(--color-success-4)}.text-success-5{color:var(--color-success-5)}.text-success-6{color:var(--color-success-6)}.text-transparent{color:#0000}.text-warning-2{color:var(--color-warning-2)}.text-warning-3{color:var(--color-warning-3)}.text-warning-4{color:var(--color-warning-4)}.text-warning-5{color:var(--color-warning-5)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.line-through{text-decoration-line:line-through}.underline{text-decoration-line:underline}.underline-offset-2{text-underline-offset:2px}.placeholder-neutral-5::placeholder{color:var(--color-neutral-5)}.placeholder-neutral-8::placeholder{color:var(--color-neutral-8)}.opacity-0{opacity:0}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-100\!{opacity:1!important}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.blur{--tw-blur:blur(8px);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,)}.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,)}.backdrop-blur{--tw-backdrop-blur:blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media(hover:hover){.group-hover\:text-accent-5:is(:where(.group):hover *){color:var(--color-accent-5)}.group-hover\:text-neutral-1:is(:where(.group):hover *){color:var(--color-neutral-1)}.group-hover\:text-neutral-3:is(:where(.group):hover *){color:var(--color-neutral-3)}.group-hover\:text-neutral-4:is(:where(.group):hover *){color:var(--color-neutral-4)}.group-hover\:text-neutral-5:is(:where(.group):hover *){color:var(--color-neutral-5)}.group-hover\:text-neutral-6:is(:where(.group):hover *){color:var(--color-neutral-6)}.group-hover\:text-primary-5:is(:where(.group):hover *){color:var(--color-primary-5)}.group-hover\:opacity-100:is(:where(.group):hover *),.group-hover\/header\:opacity-100:is(:where(.group\/header):hover *),.group-hover\/repo\:opacity-100:is(:where(.group\/repo):hover *){opacity:1}}.placeholder\:text-neutral-5::placeholder{color:var(--color-neutral-5)}.last\:border-b-0:last-child{border-bottom-style:var(--tw-border-style);border-bottom-width:0}@media(hover:hover){.hover\:border-neutral-6:hover{border-color:var(--color-neutral-6)}.hover\:border-primary-7:hover{border-color:var(--color-primary-7)}.hover\:bg-accent-6:hover{background-color:var(--color-accent-6)}.hover\:bg-error-9\/50:hover{background-color:#82232380}@supports (color:color-mix(in lab,red,red)){.hover\:bg-error-9\/50:hover{background-color:color-mix(in oklab,var(--color-error-9) 50%,transparent)}}.hover\:bg-neutral-6:hover{background-color:var(--color-neutral-6)}.hover\:bg-neutral-6\/25:hover{background-color:#5c737740}@supports (color:color-mix(in lab,red,red)){.hover\:bg-neutral-6\/25:hover{background-color:color-mix(in oklab,var(--color-neutral-6) 25%,transparent)}}.hover\:bg-neutral-6\/50:hover{background-color:#5c737780}@supports (color:color-mix(in lab,red,red)){.hover\:bg-neutral-6\/50:hover{background-color:color-mix(in oklab,var(--color-neutral-6) 50%,transparent)}}.hover\:bg-neutral-7:hover{background-color:var(--color-neutral-7)}.hover\:bg-neutral-7\/20:hover{background-color:#465c6033}@supports (color:color-mix(in lab,red,red)){.hover\:bg-neutral-7\/20:hover{background-color:color-mix(in oklab,var(--color-neutral-7) 20%,transparent)}}.hover\:bg-neutral-8:hover{background-color:var(--color-neutral-8)}.hover\:bg-neutral-8\/50:hover{background-color:#354a4e80}@supports (color:color-mix(in lab,red,red)){.hover\:bg-neutral-8\/50:hover{background-color:color-mix(in oklab,var(--color-neutral-8) 50%,transparent)}}.hover\:bg-neutral-8\/60:hover{background-color:#354a4e99}@supports (color:color-mix(in lab,red,red)){.hover\:bg-neutral-8\/60:hover{background-color:color-mix(in oklab,var(--color-neutral-8) 60%,transparent)}}.hover\:bg-neutral-8\/90:hover{background-color:#354a4ee6}@supports (color:color-mix(in lab,red,red)){.hover\:bg-neutral-8\/90:hover{background-color:color-mix(in oklab,var(--color-neutral-8) 90%,transparent)}}.hover\:bg-neutral-9:hover{background-color:var(--color-neutral-9)}.hover\:bg-neutral-10\/50:hover{background-color:#1a2c3080}@supports (color:color-mix(in lab,red,red)){.hover\:bg-neutral-10\/50:hover{background-color:color-mix(in oklab,var(--color-neutral-10) 50%,transparent)}}.hover\:bg-primary-7:hover{background-color:var(--color-primary-7)}.hover\:bg-primary-7\/40:hover{background-color:#9d744066}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary-7\/40:hover{background-color:color-mix(in oklab,var(--color-primary-7) 40%,transparent)}}.hover\:bg-primary-7\/50:hover{background-color:#9d744080}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary-7\/50:hover{background-color:color-mix(in oklab,var(--color-primary-7) 50%,transparent)}}.hover\:bg-primary-8:hover{background-color:var(--color-primary-8)}.hover\:bg-primary-9\/40:hover{background-color:#7d5b2a66}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary-9\/40:hover{background-color:color-mix(in oklab,var(--color-primary-9) 40%,transparent)}}.hover\:bg-primary-9\/50:hover{background-color:#7d5b2a80}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary-9\/50:hover{background-color:color-mix(in oklab,var(--color-primary-9) 50%,transparent)}}.hover\:bg-success-9\/50:hover{background-color:#17563480}@supports (color:color-mix(in lab,red,red)){.hover\:bg-success-9\/50:hover{background-color:color-mix(in oklab,var(--color-success-9) 50%,transparent)}}.hover\:bg-warning-8\/50:hover{background-color:#906d1280}@supports (color:color-mix(in lab,red,red)){.hover\:bg-warning-8\/50:hover{background-color:color-mix(in oklab,var(--color-warning-8) 50%,transparent)}}.hover\:bg-warning-9\/50:hover{background-color:#73560e80}@supports (color:color-mix(in lab,red,red)){.hover\:bg-warning-9\/50:hover{background-color:color-mix(in oklab,var(--color-warning-9) 50%,transparent)}}.hover\:text-accent-3:hover{color:var(--color-accent-3)}.hover\:text-error-4:hover{color:var(--color-error-4)}.hover\:text-error-5:hover{color:var(--color-error-5)}.hover\:text-neutral-1:hover{color:var(--color-neutral-1)}.hover\:text-neutral-2:hover{color:var(--color-neutral-2)}.hover\:text-neutral-3:hover{color:var(--color-neutral-3)}.hover\:text-primary-3:hover{color:var(--color-primary-3)}.hover\:text-success-3:hover{color:var(--color-success-3)}.hover\:text-warning-4:hover{color:var(--color-warning-4)}}.focus\:border-accent-6:focus{border-color:var(--color-accent-6)}.focus\:border-primary-7:focus{border-color:var(--color-primary-7)}.focus\:border-primary-8\/50:focus{border-color:#9e733580}@supports (color:color-mix(in lab,red,red)){.focus\:border-primary-8\/50:focus{border-color:color-mix(in oklab,var(--color-primary-8) 50%,transparent)}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.active\:bg-primary-6\/60:active{background-color:#cf9a2d99}@supports (color:color-mix(in lab,red,red)){.active\:bg-primary-6\/60:active{background-color:color-mix(in oklab,var(--color-primary-6) 60%,transparent)}}.active\:bg-primary-7\/60:active{background-color:#9d744099}@supports (color:color-mix(in lab,red,red)){.active\:bg-primary-7\/60:active{background-color:color-mix(in oklab,var(--color-primary-7) 60%,transparent)}}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-50:disabled{opacity:.5}.aria-selected\:bg-primary-8\/20[aria-selected=true]{background-color:#9e733533}@supports (color:color-mix(in lab,red,red)){.aria-selected\:bg-primary-8\/20[aria-selected=true]{background-color:color-mix(in oklab,var(--color-primary-8) 20%,transparent)}}.aria-selected\:text-primary-4[aria-selected=true]{color:var(--color-primary-4)}.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{padding-inline:calc(var(--spacing) * 2)}.\[\&_\[cmdk-group-heading\]\]\:pt-2 [cmdk-group-heading]{padding-top:calc(var(--spacing) * 2)}.\[\&_\[cmdk-group-heading\]\]\:pb-1 [cmdk-group-heading]{padding-bottom:calc(var(--spacing) * 1)}.\[\&_\[cmdk-group-heading\]\]\:text-\[10px\] [cmdk-group-heading]{font-size:10px}.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.\[\&_\[cmdk-group-heading\]\]\:tracking-wider [cmdk-group-heading]{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.\[\&_\[cmdk-group-heading\]\]\:text-neutral-5 [cmdk-group-heading]{color:var(--color-neutral-5)}.\[\&_\[cmdk-group-heading\]\]\:uppercase [cmdk-group-heading]{text-transform:uppercase}}.terminal-area{--color-primary-1:#fef9f1;--color-primary-2:#faefd8;--color-primary-3:#f5e1b6;--color-primary-4:#eccc8e;--color-primary-5:#deb769;--color-primary-6:#cba557;--color-primary-7:#96754b;--color-primary-8:#977443;--color-primary-9:#775c35;--color-primary-10:#584528;--color-primary-11:#382c1a;--color-primary-12:#1d170d;--color-secondary-1:#fef6f3;--color-secondary-2:#fbe9e2;--color-secondary-3:#f2d3c3;--color-secondary-4:#e4b8a2;--color-secondary-5:#d09984;--color-secondary-6:#b5826b;--color-secondary-7:#93604b;--color-secondary-8:#774e3c;--color-secondary-9:#5d3c2e;--color-secondary-10:#452d22;--color-secondary-11:#2f1e17;--color-secondary-12:#1a110d;--color-accent-1:#f4f9f8;--color-accent-2:#ddf0ee;--color-accent-3:#bae1dc;--color-accent-4:#93ccc6;--color-accent-5:#6cb7af;--color-accent-6:#559f97;--color-accent-7:#42847d;--color-accent-8:#356b65;--color-accent-9:#29524d;--color-accent-10:#1e3c39;--color-accent-11:#152928;--color-accent-12:#0c1918;--color-neutral-1:#e2e1de;--color-neutral-2:#d1cfcb;--color-neutral-3:#cccac5;--color-neutral-4:#b0ada7;--color-neutral-5:#93918c;--color-neutral-6:#777571;--color-neutral-7:#555350;--color-neutral-8:#424040;--color-neutral-9:#333130;--color-neutral-10:#272524;--color-neutral-11:#1b1a18;--color-neutral-12:#0f0e0d;--color-error-1:#fdf5f5;--color-error-2:#f9e1e1;--color-error-3:#f1c0c0;--color-error-4:#e69b9b;--color-error-5:#d97777;--color-error-6:#ca5f5f;--color-error-7:#ad3e3e;--color-error-8:#913333;--color-error-9:#752929;--color-error-10:#591f1f;--color-error-11:#3a1515;--color-error-12:#1f0b0b;--color-warning-1:#fefbf1;--color-warning-2:#fbf2d6;--color-warning-3:#f7e5ae;--color-warning-4:#eed382;--color-warning-5:#e2bf5d;--color-warning-6:#ccaa4e;--color-warning-7:#a8862e;--color-warning-8:#896d24;--color-warning-9:#6d561c;--color-warning-10:#524015;--color-warning-11:#352a0e;--color-warning-12:#1c1608;--color-success-1:#f4faf5;--color-success-2:#daf2e5;--color-success-3:#b5e2ca;--color-success-4:#8ccfab;--color-success-5:#66bb8e;--color-success-6:#53a578;--color-success-7:#3f8559;--color-success-8:#326c48;--color-success-9:#275438;--color-success-10:#1d3f2a;--color-success-11:#142b1d;--color-success-12:#0b1811;--color-info-1:#f3f9f9;--color-info-2:#daecf0;--color-info-3:#b2d9e0;--color-info-4:#87c1cd;--color-info-5:#5ea8b8;--color-info-6:#478fa0;--color-info-7:#387486;--color-info-8:#2d5d6c;--color-info-9:#234854;--color-info-10:#1a353e;--color-info-11:#12242b;--color-info-12:#0a1519}[data-theme=light]{--color-neutral-1:#0f0e0d;--color-neutral-2:#1b1a18;--color-neutral-3:#272524;--color-neutral-4:#424040;--color-neutral-5:#555350;--color-neutral-6:#777571;--color-neutral-7:#c8c7c4;--color-neutral-8:#f0ede8;--color-neutral-9:#f5f3ee;--color-neutral-10:#f8f6f2;--color-neutral-11:#faf9f6;--color-neutral-12:#fdfcfa;--color-primary-1:#3a2c15;--color-primary-2:#5c4420;--color-primary-3:#7d5b2a;--color-primary-4:#9e7335;--color-primary-5:#b7884a;--color-primary-6:#cf9a2d;--color-primary-7:#c39538;--color-primary-8:#f0c56e;--color-primary-9:#f8dca0;--color-primary-10:#fcedcc;--color-primary-11:#fef3dc;--color-primary-12:#fef8ec;--color-secondary-1:#321d14;--color-secondary-2:#4a2b1e;--color-secondary-3:#633a29;--color-secondary-4:#7f4b35;--color-secondary-5:#9c5d42;--color-secondary-6:#b8704f;--color-secondary-7:#d4896a;--color-secondary-8:#e8ab8d;--color-secondary-9:#f5cbb5;--color-secondary-10:#fce6da;--color-secondary-11:#fef0e8;--color-secondary-12:#fef5f0;--color-accent-1:#07171a;--color-accent-2:#113c44;--color-accent-3:#17515c;--color-accent-4:#1d6876;--color-accent-5:#248192;--color-accent-6:#2d9bb0;--color-accent-7:#45b5c9;--color-accent-8:#74cbda;--color-accent-9:#a5e0ea;--color-accent-10:#d0f0f5;--color-accent-11:#e5f7fa;--color-accent-12:#eef9fb;--color-error-1:#230a0a;--color-error-2:#631b1b;--color-error-3:#822323;--color-error-4:#a12c2c;--color-error-5:#c03636;--color-error-6:#d94444;--color-error-7:#e86060;--color-error-8:#f28a8a;--color-error-9:#f9b5b5;--color-error-10:#fddcdc;--color-error-11:#feeded;--color-error-12:#fef2f2;--color-warning-1:#1e1604;--color-warning-2:#56400a;--color-warning-3:#73560e;--color-warning-4:#906d12;--color-warning-5:#b08618;--color-warning-6:#d0a020;--color-warning-7:#e8b830;--color-warning-8:#f4ce5e;--color-warning-9:#fae295;--color-warning-10:#fdf1c8;--color-warning-11:#fef8e5;--color-warning-12:#fefaec;--color-success-1:#07180e;--color-success-2:#114027;--color-success-3:#175634;--color-success-4:#1d6e43;--color-success-5:#248854;--color-success-6:#2da368;--color-success-7:#40bc80;--color-success-8:#6dd1a2;--color-success-9:#a0e4c4;--color-success-10:#d0f2e2;--color-success-11:#e5f8ef;--color-success-12:#effaf5;--color-info-1:#07151a;--color-info-2:#113644;--color-info-3:#17495c;--color-info-4:#1d5e76;--color-info-5:#247592;--color-info-6:#2d8fb0;--color-info-7:#40a9c8;--color-info-8:#6dc2da;--color-info-9:#a0d9ea;--color-info-10:#d0edf5;--color-info-11:#e5f4fa;--color-info-12:#eff8fb;font-weight:465}[data-theme=light] .app-logo-circle{background-color:#ffffff8c}[data-theme=dark] .app-logo-circle{background-color:var(--color-primary-2)}[data-theme=light] .app-right-sidebar{background-color:var(--color-neutral-7)}[data-theme=light] .app-left-sidebar{background-color:var(--color-neutral-9)}[data-theme=light] .app-left-sidebar button:hover{background-color:#748d912e}@supports (color:color-mix(in lab,red,red)){[data-theme=light] .app-left-sidebar button:hover{background-color:color-mix(in srgb,var(--color-neutral-5) 18%,transparent)}}[data-theme=light] .app-new-session-btn:hover{background-color:#748d912e}@supports (color:color-mix(in lab,red,red)){[data-theme=light] .app-new-session-btn:hover{background-color:color-mix(in srgb,var(--color-neutral-5) 18%,transparent)}}[data-theme=light] .app-session-tab:hover{background-color:#748d912e}@supports (color:color-mix(in lab,red,red)){[data-theme=light] .app-session-tab:hover{background-color:color-mix(in srgb,var(--color-neutral-5) 18%,transparent)}}[data-theme=light] .app-input-bar{background-color:var(--color-neutral-10)}[data-theme=light] .app-thinking-badge{background-color:#465c60e6}@supports (color:color-mix(in lab,red,red)){[data-theme=light] .app-thinking-badge{background-color:color-mix(in srgb,var(--color-neutral-7) 90%,transparent)}}[data-theme=light] .terminal-area .user-bubble{background-color:#354a4ecc}@supports (color:color-mix(in lab,red,red)){[data-theme=light] .terminal-area .user-bubble{background-color:color-mix(in srgb,var(--color-neutral-8) 80%,transparent)}}[data-theme=light] .terminal-area{--color-neutral-1:#0f0e0d;--color-neutral-2:#1b1a18;--color-neutral-3:#333131;--color-neutral-4:#424040;--color-neutral-5:#777571;--color-neutral-6:#93918c;--color-neutral-7:#e4e2de;--color-neutral-8:#eeebe6;--color-neutral-9:#f3f1ec;--color-neutral-10:#f7f5f0;--color-neutral-11:#faf9f6;--color-neutral-12:#fdf9f4;--color-primary-1:#382c1a;--color-primary-2:#584528;--color-primary-3:#775c35;--color-primary-4:#977443;--color-primary-5:#af8958;--color-primary-6:#cba557;--color-primary-7:#be9d5a;--color-primary-8:#eccc8e;--color-primary-9:#f5e1b6;--color-primary-10:#faefd8;--color-primary-11:#fdf5e8;--color-primary-12:#fef9f1;--color-accent-1:#0c1918;--color-accent-2:#1e3c39;--color-accent-3:#29524d;--color-accent-4:#356b65;--color-accent-5:#42847d;--color-accent-6:#559f97;--color-accent-7:#6cb7af;--color-accent-8:#93ccc6;--color-accent-9:#bae1dc;--color-accent-10:#ddf0ee;--color-accent-11:#edf8f7;--color-accent-12:#f4f9f8;--color-error-1:#1f0b0b;--color-error-2:#591f1f;--color-error-3:#752929;--color-error-4:#913333;--color-error-5:#ad3e3e;--color-error-6:#ca5f5f;--color-error-7:#d97777;--color-error-8:#e69b9b;--color-error-9:#f1c0c0;--color-error-10:#f9e1e1;--color-error-11:#fceeed;--color-error-12:#fdf5f5;--color-warning-1:#1c1608;--color-warning-2:#524015;--color-warning-3:#6d561c;--color-warning-4:#896d24;--color-warning-5:#a8862e;--color-warning-6:#ccaa4e;--color-warning-7:#e2bf5d;--color-warning-8:#eed382;--color-warning-9:#f7e5ae;--color-warning-10:#fbf2d6;--color-warning-11:#fdf8e8;--color-warning-12:#fefbf1;--color-success-1:#0b1811;--color-success-2:#1d3f2a;--color-success-3:#275438;--color-success-4:#326c48;--color-success-5:#3f8559;--color-success-6:#53a578;--color-success-7:#66bb8e;--color-success-8:#8ccfab;--color-success-9:#b5e2ca;--color-success-10:#daf2e5;--color-success-11:#ecf9f2;--color-success-12:#f4faf5}html,body,#root{height:100%;margin:0;font-family:Lato,sans-serif;overflow:hidden}.chat-scroll::-webkit-scrollbar{width:6px}.chat-scroll::-webkit-scrollbar-track{background:0 0}.chat-scroll::-webkit-scrollbar-thumb{background:#304346}@supports (color:color-mix(in lab,red,red)){.chat-scroll::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--color-neutral-8),black 10%)}}.chat-scroll::-webkit-scrollbar-thumb{border-radius:3px}.chat-scroll::-webkit-scrollbar-thumb:hover{background:var(--color-neutral-6)}.approvals-scroll::-webkit-scrollbar{width:5px}.approvals-scroll::-webkit-scrollbar-track{background:0 0}.approvals-scroll::-webkit-scrollbar-thumb{background:#304346}@supports (color:color-mix(in lab,red,red)){.approvals-scroll::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--color-neutral-8),black 10%)}}.approvals-scroll::-webkit-scrollbar-thumb{border-radius:3px}.approvals-scroll::-webkit-scrollbar-thumb:hover{background:var(--color-neutral-6)}.prose.prose-themed code{font-family:Inconsolata,monospace}.prose.prose-themed pre{background:var(--color-neutral-11);border:1px solid var(--color-neutral-9)}.prose.prose-themed a{text-underline-offset:2px;text-decoration:underline}.prose.prose-themed p{margin-top:.5em;margin-bottom:.5em}.prose.prose-themed h1,.prose.prose-themed h2,.prose.prose-themed h3,.prose.prose-themed h4{margin-top:1em;margin-bottom:.5em}.prose.prose-themed ul,.prose.prose-themed ol{margin-top:.25em;margin-bottom:.25em}.prose.prose-themed table{border-collapse:collapse}.prose.prose-themed th,.prose.prose-themed td{border:1px solid var(--color-neutral-9);padding:.25em .75em}[data-theme=dark] .prose.prose-themed{--tw-prose-body:var(--color-neutral-2);--tw-prose-headings:var(--color-neutral-1);--tw-prose-links:var(--color-accent-5);--tw-prose-bold:var(--color-neutral-1);--tw-prose-code:var(--color-accent-4);--tw-prose-pre-bg:var(--color-neutral-11);--tw-prose-pre-code:var(--color-neutral-2);--tw-prose-quotes:var(--color-neutral-3);--tw-prose-quote-borders:var(--color-neutral-8);--tw-prose-hr:var(--color-neutral-9);--tw-prose-th-borders:var(--color-neutral-8);--tw-prose-td-borders:var(--color-neutral-9);color:var(--color-neutral-2)}[data-theme=light] .prose.prose-themed{--tw-prose-body:var(--color-neutral-2);--tw-prose-headings:var(--color-neutral-1);--tw-prose-links:var(--color-accent-5);--tw-prose-bold:var(--color-neutral-1);--tw-prose-code:var(--color-accent-4);--tw-prose-pre-bg:var(--color-neutral-9);--tw-prose-pre-code:var(--color-neutral-2);--tw-prose-quotes:var(--color-neutral-3);--tw-prose-quote-borders:var(--color-neutral-7);--tw-prose-hr:var(--color-neutral-8);--tw-prose-th-borders:var(--color-neutral-7);--tw-prose-td-borders:var(--color-neutral-8);color:var(--color-neutral-2)}.prose.prose-invert{--tw-prose-body:var(--color-neutral-2);--tw-prose-headings:var(--color-neutral-1);--tw-prose-links:var(--color-accent-5);--tw-prose-bold:var(--color-neutral-1);--tw-prose-code:var(--color-accent-4);--tw-prose-pre-bg:var(--color-neutral-11);--tw-prose-pre-code:var(--color-neutral-2);--tw-prose-quotes:var(--color-neutral-3);--tw-prose-quote-borders:var(--color-neutral-8);--tw-prose-hr:var(--color-neutral-9);--tw-prose-th-borders:var(--color-neutral-8);--tw-prose-td-borders:var(--color-neutral-9)}.prose.prose-invert code{font-family:Inconsolata,monospace}.prose.prose-invert pre{background:var(--color-neutral-11);border:1px solid var(--color-neutral-9)}.prose.prose-invert a{text-underline-offset:2px;text-decoration:underline}.prose.prose-invert p{margin-top:.5em;margin-bottom:.5em}.prose.prose-invert h1,.prose.prose-invert h2,.prose.prose-invert h3,.prose.prose-invert h4{margin-top:1em;margin-bottom:.5em}.prose.prose-invert ul,.prose.prose-invert ol{margin-top:.25em;margin-bottom:.25em}.prose.prose-invert table{border-collapse:collapse}.prose.prose-invert th,.prose.prose-invert td{border:1px solid var(--color-neutral-9);padding:.25em .75em}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}
|