@hir4ta/memoria 0.14.2 → 0.15.0
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.
- package/.claude-plugin/plugin.json +1 -1
- package/.mcp.json +19 -0
- package/README.ja.md +26 -2
- package/README.md +57 -8
- package/bin/memoria.js +26 -5
- package/dist/lib/db.js +178 -9
- package/dist/public/assets/index-DdzOYdPy.css +1 -0
- package/dist/public/assets/{index-CpMhKAZt.js → index-Dj5o1jSO.js} +66 -61
- package/dist/public/assets/{react-force-graph-2d-D56jdA7v.js → react-force-graph-2d-D4L464-l.js} +1 -1
- package/dist/public/index.html +2 -2
- package/dist/server.js +195 -4
- package/dist/servers/db-server.js +30272 -0
- package/dist/servers/search-server.js +30357 -0
- package/hooks/hooks.json +1 -1
- package/hooks/pre-compact.sh +26 -7
- package/hooks/session-end.sh +93 -18
- package/hooks/session-start.sh +21 -0
- package/hooks/user-prompt-submit.sh +52 -0
- package/package.json +6 -2
- package/servers/db-server.ts +538 -0
- package/servers/search-server.ts +652 -0
- package/skills/harvest/skill.md +5 -1
- package/skills/init/skill.md +32 -5
- package/skills/plan/skill.md +4 -3
- package/skills/report/skill.md +5 -1
- package/skills/resume/skill.md +11 -4
- package/skills/review/skill.md +21 -1
- package/skills/save/skill.md +29 -64
- package/skills/search/skill.md +23 -16
- package/skills/using-memoria/skill.md +3 -1
- package/dist/public/assets/index-J1A9Ovuz.css +0 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "memoria",
|
|
3
3
|
"description": "A plugin that provides long-term memory for Claude Code. It automatically saves context lost during auto-compact, offering features for session restoration, recording technical decisions, and learning developer patterns.",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.15.0",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "hir4ta"
|
|
7
7
|
},
|
package/.mcp.json
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"mcpServers": {
|
|
3
|
+
"memoria-search": {
|
|
4
|
+
"command": "node",
|
|
5
|
+
"args": ["${CLAUDE_PLUGIN_ROOT}/dist/servers/search-server.js"],
|
|
6
|
+
"env": {
|
|
7
|
+
"MEMORIA_PROJECT_PATH": "${cwd}",
|
|
8
|
+
"MEMORIA_DATA_DIR": "${MEMORIA_DATA_DIR:-}"
|
|
9
|
+
}
|
|
10
|
+
},
|
|
11
|
+
"memoria-db": {
|
|
12
|
+
"command": "node",
|
|
13
|
+
"args": ["${CLAUDE_PLUGIN_ROOT}/dist/servers/db-server.js"],
|
|
14
|
+
"env": {
|
|
15
|
+
"MEMORIA_DATA_DIR": "${MEMORIA_DATA_DIR:-}"
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
package/README.ja.md
CHANGED
|
@@ -189,6 +189,24 @@ npx @hir4ta/memoria --dashboard --port 8080
|
|
|
189
189
|
|
|
190
190
|
ダッシュボードは日本語と英語に対応しています。ヘッダーの言語切り替えボタン(EN/JA)をクリックして切り替えできます。設定はlocalStorageに保存されます。
|
|
191
191
|
|
|
192
|
+
### MCPツール
|
|
193
|
+
|
|
194
|
+
memoriaはMCPサーバーを提供し、Claude Codeから直接呼び出せる検索・データベースツールを提供:
|
|
195
|
+
|
|
196
|
+
| サーバー | ツール | 説明 |
|
|
197
|
+
|---------|--------|------|
|
|
198
|
+
| memoria-search | `memoria_search` | 統合検索(FTS5、タグエイリアス解決) |
|
|
199
|
+
| memoria-search | `memoria_get_session` | セッション詳細取得 |
|
|
200
|
+
| memoria-search | `memoria_get_decision` | 決定詳細取得 |
|
|
201
|
+
| memoria-db | `memoria_list_projects` | 全プロジェクト一覧 |
|
|
202
|
+
| memoria-db | `memoria_cross_project_search` | クロスプロジェクト検索 |
|
|
203
|
+
|
|
204
|
+
### サブエージェント
|
|
205
|
+
|
|
206
|
+
| エージェント | 説明 |
|
|
207
|
+
|-------------|------|
|
|
208
|
+
| `memoria-reviewer` | ルールベースのコードレビュー(独立コンテキスト) |
|
|
209
|
+
|
|
192
210
|
## 仕組み
|
|
193
211
|
|
|
194
212
|
```mermaid
|
|
@@ -252,9 +270,9 @@ memoriaは**ハイブリッドストレージ**方式でプライバシーと共
|
|
|
252
270
|
|
|
253
271
|
### ディレクトリ構成
|
|
254
272
|
|
|
273
|
+
**プロジェクト内** (`.memoria/`) - Git管理、チーム共有:
|
|
255
274
|
```text
|
|
256
275
|
.memoria/
|
|
257
|
-
├── local.db # SQLite(ローカル専用、.gitignore)
|
|
258
276
|
├── tags.json # タグマスターファイル(93タグ、表記揺れ防止)
|
|
259
277
|
├── sessions/ # セッションメタデータ
|
|
260
278
|
│ └── YYYY/MM/
|
|
@@ -269,7 +287,13 @@ memoriaは**ハイブリッドストレージ**方式でプライバシーと共
|
|
|
269
287
|
└── reports/ # 週次レポート (YYYY-MM)
|
|
270
288
|
```
|
|
271
289
|
|
|
272
|
-
|
|
290
|
+
**グローバル** (`~/.claude/memoria/`) - ローカル専用、クロスプロジェクト:
|
|
291
|
+
```text
|
|
292
|
+
~/.claude/memoria/
|
|
293
|
+
└── global.db # SQLite(全プロジェクトのinteractions)
|
|
294
|
+
```
|
|
295
|
+
|
|
296
|
+
環境変数 `MEMORIA_DATA_DIR` でDBの場所をカスタマイズ可能。
|
|
273
297
|
|
|
274
298
|
### セッションJSONスキーマ
|
|
275
299
|
|
package/README.md
CHANGED
|
@@ -189,6 +189,24 @@ npx @hir4ta/memoria --dashboard --port 8080
|
|
|
189
189
|
|
|
190
190
|
The dashboard supports English and Japanese. Click the language toggle (EN/JA) in the header to switch. The preference is saved to localStorage.
|
|
191
191
|
|
|
192
|
+
### MCP Tools
|
|
193
|
+
|
|
194
|
+
memoria provides MCP servers with search and database tools callable directly from Claude Code:
|
|
195
|
+
|
|
196
|
+
| Server | Tool | Description |
|
|
197
|
+
|--------|------|-------------|
|
|
198
|
+
| memoria-search | `memoria_search` | Unified search (FTS5, tag alias resolution) |
|
|
199
|
+
| memoria-search | `memoria_get_session` | Get session details |
|
|
200
|
+
| memoria-search | `memoria_get_decision` | Get decision details |
|
|
201
|
+
| memoria-db | `memoria_list_projects` | List all projects |
|
|
202
|
+
| memoria-db | `memoria_cross_project_search` | Cross-project search |
|
|
203
|
+
|
|
204
|
+
### Subagents
|
|
205
|
+
|
|
206
|
+
| Agent | Description |
|
|
207
|
+
|-------|-------------|
|
|
208
|
+
| `memoria-reviewer` | Rule-based code review (isolated context) |
|
|
209
|
+
|
|
192
210
|
## How It Works
|
|
193
211
|
|
|
194
212
|
```mermaid
|
|
@@ -238,27 +256,42 @@ flowchart TB
|
|
|
238
256
|
|
|
239
257
|
## Data Storage
|
|
240
258
|
|
|
241
|
-
memoria uses a **hybrid storage** approach for privacy and
|
|
259
|
+
memoria uses a **hybrid storage** approach for privacy, collaboration, and cross-project knowledge sharing:
|
|
242
260
|
|
|
243
|
-
| Storage | Purpose | Sharing |
|
|
244
|
-
|
|
245
|
-
| **JSON** | Summaries, decisions, patterns, rules | Git-managed (team shared) |
|
|
246
|
-
| **SQLite** | Interactions, backups | Local only (
|
|
261
|
+
| Storage | Location | Purpose | Sharing |
|
|
262
|
+
|---------|----------|---------|---------|
|
|
263
|
+
| **JSON** | `.memoria/` | Summaries, decisions, patterns, rules | Git-managed (team shared) |
|
|
264
|
+
| **SQLite** | `~/.claude/memoria/global.db` | Interactions, backups | Local only (cross-project) |
|
|
247
265
|
|
|
248
266
|
**Why hybrid?**
|
|
249
267
|
- **Privacy**: Conversation history (interactions) stays local to each developer
|
|
268
|
+
- **Cross-project**: Global database enables knowledge sharing across all your projects
|
|
250
269
|
- **Lightweight**: JSON files reduced from 100KB+ to ~5KB (interactions excluded)
|
|
251
270
|
- **Future-ready**: Embeddings table prepared for semantic search
|
|
252
271
|
|
|
272
|
+
### Global Database
|
|
273
|
+
|
|
274
|
+
Interactions are stored in a **global SQLite database** at `~/.claude/memoria/global.db`. This enables:
|
|
275
|
+
- **Cross-project search**: Find related work from any project
|
|
276
|
+
- **Unified history**: View all interactions across projects in the dashboard
|
|
277
|
+
- **Project filtering**: Filter by `project_path` or `repository` in the dashboard
|
|
278
|
+
|
|
279
|
+
To customize the database location, set the `MEMORIA_DATA_DIR` environment variable:
|
|
280
|
+
|
|
281
|
+
```bash
|
|
282
|
+
# Custom location (defaults to ~/.claude/memoria/)
|
|
283
|
+
export MEMORIA_DATA_DIR="$HOME/.local/share/memoria"
|
|
284
|
+
```
|
|
285
|
+
|
|
253
286
|
### Directory Structure
|
|
254
287
|
|
|
288
|
+
**Project-local (`.memoria/`)** - Git-managed, team-shared:
|
|
255
289
|
```text
|
|
256
290
|
.memoria/
|
|
257
|
-
├── local.db # SQLite (local only, .gitignore)
|
|
258
291
|
├── tags.json # Tag master file (93 tags, prevents notation variations)
|
|
259
292
|
├── sessions/ # Session metadata (YYYY/MM)
|
|
260
293
|
│ └── YYYY/MM/
|
|
261
|
-
│ └── {id}.json # Metadata only (interactions in SQLite)
|
|
294
|
+
│ └── {id}.json # Metadata only (interactions in global SQLite)
|
|
262
295
|
├── decisions/ # Technical decisions (from /save)
|
|
263
296
|
│ └── YYYY/MM/
|
|
264
297
|
│ └── {id}.json
|
|
@@ -269,7 +302,13 @@ memoria uses a **hybrid storage** approach for privacy and collaboration:
|
|
|
269
302
|
└── reports/ # Weekly reports (YYYY-MM)
|
|
270
303
|
```
|
|
271
304
|
|
|
272
|
-
|
|
305
|
+
**Global (`~/.claude/memoria/`)** - Local only, cross-project:
|
|
306
|
+
```text
|
|
307
|
+
~/.claude/memoria/
|
|
308
|
+
└── global.db # SQLite with interactions from ALL projects
|
|
309
|
+
```
|
|
310
|
+
|
|
311
|
+
Each interaction in the global database includes `project_path` and `repository` fields for filtering.
|
|
273
312
|
|
|
274
313
|
### Session JSON Schema
|
|
275
314
|
|
|
@@ -366,6 +405,16 @@ Tags are selected from `.memoria/tags.json` to prevent notation variations (e.g.
|
|
|
366
405
|
- **cloud**: serverless, microservices, edge, wasm
|
|
367
406
|
- And more...
|
|
368
407
|
|
|
408
|
+
## Versioning
|
|
409
|
+
|
|
410
|
+
This project follows [Semantic Versioning](https://semver.org/).
|
|
411
|
+
|
|
412
|
+
**⚠️ While in 0.x (pre-1.0), breaking changes may occur between minor versions.**
|
|
413
|
+
|
|
414
|
+
If you encounter issues after an update:
|
|
415
|
+
1. Check the [releases](https://github.com/hir4ta/memoria/releases) for migration notes
|
|
416
|
+
2. Re-initialize with `npx @hir4ta/memoria --init` if needed
|
|
417
|
+
|
|
369
418
|
## License
|
|
370
419
|
|
|
371
420
|
MIT
|
package/bin/memoria.js
CHANGED
|
@@ -2,12 +2,13 @@
|
|
|
2
2
|
|
|
3
3
|
import { fork } from "node:child_process";
|
|
4
4
|
import fs from "node:fs";
|
|
5
|
+
import { homedir } from "node:os";
|
|
5
6
|
import path from "node:path";
|
|
6
7
|
import { fileURLToPath } from "node:url";
|
|
7
8
|
|
|
8
9
|
// Suppress Node.js SQLite experimental warning (must be before dynamic import)
|
|
9
10
|
const originalEmit = process.emit;
|
|
10
|
-
process.emit =
|
|
11
|
+
process.emit = (name, data, ...args) => {
|
|
11
12
|
if (
|
|
12
13
|
name === "warning" &&
|
|
13
14
|
data?.name === "ExperimentalWarning" &&
|
|
@@ -55,13 +56,24 @@ function checkMemoriaDir() {
|
|
|
55
56
|
}
|
|
56
57
|
}
|
|
57
58
|
|
|
59
|
+
function getGlobalDbDir() {
|
|
60
|
+
const envDir = process.env.MEMORIA_DATA_DIR;
|
|
61
|
+
if (envDir) {
|
|
62
|
+
return envDir;
|
|
63
|
+
}
|
|
64
|
+
return path.join(homedir(), ".claude", "memoria");
|
|
65
|
+
}
|
|
66
|
+
|
|
58
67
|
function initMemoria() {
|
|
59
68
|
const memoriaDir = path.join(projectRoot, ".memoria");
|
|
60
69
|
const sessionsDir = path.join(memoriaDir, "sessions");
|
|
61
70
|
const rulesDir = path.join(memoriaDir, "rules");
|
|
62
71
|
const patternsDir = path.join(memoriaDir, "patterns");
|
|
63
72
|
const tagsPath = path.join(memoriaDir, "tags.json");
|
|
64
|
-
|
|
73
|
+
|
|
74
|
+
// Global database path
|
|
75
|
+
const globalDbDir = getGlobalDbDir();
|
|
76
|
+
const globalDbPath = path.join(globalDbDir, "global.db");
|
|
65
77
|
|
|
66
78
|
// Check if already initialized
|
|
67
79
|
if (fs.existsSync(memoriaDir)) {
|
|
@@ -99,11 +111,18 @@ function initMemoria() {
|
|
|
99
111
|
);
|
|
100
112
|
fs.writeFileSync(path.join(rulesDir, "dev-rules.json"), rulesTemplate);
|
|
101
113
|
|
|
102
|
-
// Initialize SQLite database
|
|
114
|
+
// Initialize global SQLite database
|
|
103
115
|
const schemaPath = path.join(packageDir, "lib", "schema.sql");
|
|
104
116
|
try {
|
|
105
|
-
|
|
117
|
+
// Create global db directory if not exists
|
|
118
|
+
if (!fs.existsSync(globalDbDir)) {
|
|
119
|
+
fs.mkdirSync(globalDbDir, { recursive: true });
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
const db = new DatabaseSync(globalDbPath);
|
|
106
123
|
db.exec("PRAGMA journal_mode = WAL");
|
|
124
|
+
db.exec("PRAGMA busy_timeout = 5000");
|
|
125
|
+
db.exec("PRAGMA synchronous = NORMAL");
|
|
107
126
|
if (fs.existsSync(schemaPath)) {
|
|
108
127
|
const schema = fs.readFileSync(schemaPath, "utf-8");
|
|
109
128
|
db.exec(schema);
|
|
@@ -124,7 +143,9 @@ Created:
|
|
|
124
143
|
${tagsPath}
|
|
125
144
|
${rulesDir}/review-guidelines.json
|
|
126
145
|
${rulesDir}/dev-rules.json
|
|
127
|
-
|
|
146
|
+
|
|
147
|
+
Global database initialized:
|
|
148
|
+
${globalDbPath}
|
|
128
149
|
|
|
129
150
|
You can now use memoria with Claude Code in this project.
|
|
130
151
|
`);
|
package/dist/lib/db.js
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
// lib/db.ts
|
|
2
2
|
import { execSync } from "node:child_process";
|
|
3
|
-
import { existsSync, readFileSync } from "node:fs";
|
|
3
|
+
import { existsSync, mkdirSync, readFileSync } from "node:fs";
|
|
4
|
+
import { homedir } from "node:os";
|
|
4
5
|
import { dirname, join } from "node:path";
|
|
5
6
|
import { fileURLToPath } from "node:url";
|
|
6
7
|
var originalEmit = process.emit;
|
|
7
|
-
process.emit =
|
|
8
|
+
process.emit = (name, data, ...args) => {
|
|
8
9
|
if (name === "warning" && typeof data === "object" && data?.name === "ExperimentalWarning" && data?.message?.includes("SQLite")) {
|
|
9
10
|
return false;
|
|
10
11
|
}
|
|
@@ -24,13 +25,43 @@ function getCurrentUser() {
|
|
|
24
25
|
}
|
|
25
26
|
}
|
|
26
27
|
}
|
|
28
|
+
function getGlobalDbDir() {
|
|
29
|
+
const envDir = process.env.MEMORIA_DATA_DIR;
|
|
30
|
+
if (envDir) {
|
|
31
|
+
return envDir;
|
|
32
|
+
}
|
|
33
|
+
return join(homedir(), ".claude", "memoria");
|
|
34
|
+
}
|
|
35
|
+
function getGlobalDbPath() {
|
|
36
|
+
return join(getGlobalDbDir(), "global.db");
|
|
37
|
+
}
|
|
27
38
|
function getDbPath(memoriaDir) {
|
|
28
39
|
return join(memoriaDir, "local.db");
|
|
29
40
|
}
|
|
41
|
+
function configurePragmas(db) {
|
|
42
|
+
db.exec("PRAGMA journal_mode = WAL");
|
|
43
|
+
db.exec("PRAGMA busy_timeout = 5000");
|
|
44
|
+
db.exec("PRAGMA synchronous = NORMAL");
|
|
45
|
+
}
|
|
46
|
+
function initGlobalDatabase() {
|
|
47
|
+
const dbDir = getGlobalDbDir();
|
|
48
|
+
if (!existsSync(dbDir)) {
|
|
49
|
+
mkdirSync(dbDir, { recursive: true });
|
|
50
|
+
}
|
|
51
|
+
const dbPath = getGlobalDbPath();
|
|
52
|
+
const db = new DatabaseSync(dbPath);
|
|
53
|
+
configurePragmas(db);
|
|
54
|
+
const schemaPath = join(__dirname, "schema.sql");
|
|
55
|
+
if (existsSync(schemaPath)) {
|
|
56
|
+
const schema = readFileSync(schemaPath, "utf-8");
|
|
57
|
+
db.exec(schema);
|
|
58
|
+
}
|
|
59
|
+
return db;
|
|
60
|
+
}
|
|
30
61
|
function initDatabase(memoriaDir) {
|
|
31
62
|
const dbPath = getDbPath(memoriaDir);
|
|
32
63
|
const db = new DatabaseSync(dbPath);
|
|
33
|
-
db
|
|
64
|
+
configurePragmas(db);
|
|
34
65
|
const schemaPath = join(__dirname, "schema.sql");
|
|
35
66
|
if (existsSync(schemaPath)) {
|
|
36
67
|
const schema = readFileSync(schemaPath, "utf-8");
|
|
@@ -38,25 +69,69 @@ function initDatabase(memoriaDir) {
|
|
|
38
69
|
}
|
|
39
70
|
return db;
|
|
40
71
|
}
|
|
72
|
+
function openGlobalDatabase() {
|
|
73
|
+
const dbPath = getGlobalDbPath();
|
|
74
|
+
if (!existsSync(dbPath)) {
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
77
|
+
const db = new DatabaseSync(dbPath);
|
|
78
|
+
configurePragmas(db);
|
|
79
|
+
return db;
|
|
80
|
+
}
|
|
41
81
|
function openDatabase(memoriaDir) {
|
|
42
82
|
const dbPath = getDbPath(memoriaDir);
|
|
43
83
|
if (!existsSync(dbPath)) {
|
|
44
84
|
return null;
|
|
45
85
|
}
|
|
46
86
|
const db = new DatabaseSync(dbPath);
|
|
47
|
-
db
|
|
87
|
+
configurePragmas(db);
|
|
48
88
|
return db;
|
|
49
89
|
}
|
|
90
|
+
function getRepositoryInfo(projectPath) {
|
|
91
|
+
const result = {
|
|
92
|
+
repository: null,
|
|
93
|
+
repository_url: null,
|
|
94
|
+
repository_root: null
|
|
95
|
+
};
|
|
96
|
+
try {
|
|
97
|
+
execSync("git rev-parse --git-dir", {
|
|
98
|
+
cwd: projectPath,
|
|
99
|
+
encoding: "utf-8",
|
|
100
|
+
stdio: ["pipe", "pipe", "pipe"]
|
|
101
|
+
});
|
|
102
|
+
result.repository_root = execSync("git rev-parse --show-toplevel", {
|
|
103
|
+
cwd: projectPath,
|
|
104
|
+
encoding: "utf-8"
|
|
105
|
+
}).trim();
|
|
106
|
+
try {
|
|
107
|
+
result.repository_url = execSync("git remote get-url origin", {
|
|
108
|
+
cwd: projectPath,
|
|
109
|
+
encoding: "utf-8"
|
|
110
|
+
}).trim();
|
|
111
|
+
const match = result.repository_url.match(/[:/]([^/]+\/[^/]+?)(\.git)?$/);
|
|
112
|
+
if (match) {
|
|
113
|
+
result.repository = match[1].replace(/\.git$/, "");
|
|
114
|
+
}
|
|
115
|
+
} catch {
|
|
116
|
+
}
|
|
117
|
+
} catch {
|
|
118
|
+
}
|
|
119
|
+
return result;
|
|
120
|
+
}
|
|
50
121
|
function insertInteractions(db, interactions) {
|
|
51
122
|
const insert = db.prepare(`
|
|
52
|
-
INSERT INTO interactions (session_id, owner, role, content, thinking, tool_calls, timestamp, is_compact_summary)
|
|
53
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
|
|
123
|
+
INSERT INTO interactions (session_id, project_path, repository, repository_url, repository_root, owner, role, content, thinking, tool_calls, timestamp, is_compact_summary)
|
|
124
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
54
125
|
`);
|
|
55
126
|
db.exec("BEGIN TRANSACTION");
|
|
56
127
|
try {
|
|
57
128
|
for (const item of interactions) {
|
|
58
129
|
insert.run(
|
|
59
130
|
item.session_id,
|
|
131
|
+
item.project_path,
|
|
132
|
+
item.repository || null,
|
|
133
|
+
item.repository_url || null,
|
|
134
|
+
item.repository_root || null,
|
|
60
135
|
item.owner,
|
|
61
136
|
item.role,
|
|
62
137
|
item.content,
|
|
@@ -134,10 +209,15 @@ function hasInteractions(db, sessionId, owner) {
|
|
|
134
209
|
}
|
|
135
210
|
function insertPreCompactBackup(db, backup) {
|
|
136
211
|
const stmt = db.prepare(`
|
|
137
|
-
INSERT INTO pre_compact_backups (session_id, owner, interactions)
|
|
138
|
-
VALUES (?, ?, ?)
|
|
212
|
+
INSERT INTO pre_compact_backups (session_id, project_path, owner, interactions)
|
|
213
|
+
VALUES (?, ?, ?, ?)
|
|
139
214
|
`);
|
|
140
|
-
stmt.run(
|
|
215
|
+
stmt.run(
|
|
216
|
+
backup.session_id,
|
|
217
|
+
backup.project_path,
|
|
218
|
+
backup.owner,
|
|
219
|
+
backup.interactions
|
|
220
|
+
);
|
|
141
221
|
}
|
|
142
222
|
function getLatestBackup(db, sessionId) {
|
|
143
223
|
const stmt = db.prepare(`
|
|
@@ -184,23 +264,112 @@ function getDbStats(db) {
|
|
|
184
264
|
backups: backupsCount.count
|
|
185
265
|
};
|
|
186
266
|
}
|
|
267
|
+
function getInteractionsByProject(db, projectPath) {
|
|
268
|
+
const stmt = db.prepare(`
|
|
269
|
+
SELECT * FROM interactions
|
|
270
|
+
WHERE project_path = ?
|
|
271
|
+
ORDER BY timestamp ASC
|
|
272
|
+
`);
|
|
273
|
+
return stmt.all(projectPath);
|
|
274
|
+
}
|
|
275
|
+
function getInteractionsByRepository(db, repository) {
|
|
276
|
+
const stmt = db.prepare(`
|
|
277
|
+
SELECT * FROM interactions
|
|
278
|
+
WHERE repository = ?
|
|
279
|
+
ORDER BY timestamp ASC
|
|
280
|
+
`);
|
|
281
|
+
return stmt.all(repository);
|
|
282
|
+
}
|
|
283
|
+
function getUniqueProjects(db) {
|
|
284
|
+
const stmt = db.prepare(`
|
|
285
|
+
SELECT DISTINCT project_path FROM interactions
|
|
286
|
+
ORDER BY project_path
|
|
287
|
+
`);
|
|
288
|
+
const rows = stmt.all();
|
|
289
|
+
return rows.map((r) => r.project_path);
|
|
290
|
+
}
|
|
291
|
+
function getUniqueRepositories(db) {
|
|
292
|
+
const stmt = db.prepare(`
|
|
293
|
+
SELECT DISTINCT repository FROM interactions
|
|
294
|
+
WHERE repository IS NOT NULL
|
|
295
|
+
ORDER BY repository
|
|
296
|
+
`);
|
|
297
|
+
const rows = stmt.all();
|
|
298
|
+
return rows.map((r) => r.repository);
|
|
299
|
+
}
|
|
300
|
+
function deleteInteractionsByProject(db, projectPath) {
|
|
301
|
+
const stmt = db.prepare("DELETE FROM interactions WHERE project_path = ?");
|
|
302
|
+
const result = stmt.run(projectPath);
|
|
303
|
+
return result.changes;
|
|
304
|
+
}
|
|
305
|
+
function deleteInteractionsBefore(db, beforeDate) {
|
|
306
|
+
const stmt = db.prepare("DELETE FROM interactions WHERE timestamp < ?");
|
|
307
|
+
const result = stmt.run(beforeDate);
|
|
308
|
+
return result.changes;
|
|
309
|
+
}
|
|
310
|
+
function deleteBackupsByProject(db, projectPath) {
|
|
311
|
+
const stmt = db.prepare(
|
|
312
|
+
"DELETE FROM pre_compact_backups WHERE project_path = ?"
|
|
313
|
+
);
|
|
314
|
+
const result = stmt.run(projectPath);
|
|
315
|
+
return result.changes;
|
|
316
|
+
}
|
|
317
|
+
function countInteractions(db, filter) {
|
|
318
|
+
const conditions = [];
|
|
319
|
+
const params = [];
|
|
320
|
+
if (filter.sessionId) {
|
|
321
|
+
conditions.push("session_id = ?");
|
|
322
|
+
params.push(filter.sessionId);
|
|
323
|
+
}
|
|
324
|
+
if (filter.projectPath) {
|
|
325
|
+
conditions.push("project_path = ?");
|
|
326
|
+
params.push(filter.projectPath);
|
|
327
|
+
}
|
|
328
|
+
if (filter.repository) {
|
|
329
|
+
conditions.push("repository = ?");
|
|
330
|
+
params.push(filter.repository);
|
|
331
|
+
}
|
|
332
|
+
if (filter.before) {
|
|
333
|
+
conditions.push("timestamp < ?");
|
|
334
|
+
params.push(filter.before);
|
|
335
|
+
}
|
|
336
|
+
const whereClause = conditions.length > 0 ? `WHERE ${conditions.join(" AND ")}` : "";
|
|
337
|
+
const stmt = db.prepare(
|
|
338
|
+
`SELECT COUNT(*) as count FROM interactions ${whereClause}`
|
|
339
|
+
);
|
|
340
|
+
const result = stmt.get(...params);
|
|
341
|
+
return result.count;
|
|
342
|
+
}
|
|
187
343
|
export {
|
|
344
|
+
countInteractions,
|
|
188
345
|
deleteBackups,
|
|
346
|
+
deleteBackupsByProject,
|
|
189
347
|
deleteInteractions,
|
|
348
|
+
deleteInteractionsBefore,
|
|
349
|
+
deleteInteractionsByProject,
|
|
190
350
|
getAllBackups,
|
|
191
351
|
getCurrentUser,
|
|
192
352
|
getDbPath,
|
|
193
353
|
getDbStats,
|
|
354
|
+
getGlobalDbDir,
|
|
355
|
+
getGlobalDbPath,
|
|
194
356
|
getInteractions,
|
|
195
357
|
getInteractionsByOwner,
|
|
358
|
+
getInteractionsByProject,
|
|
359
|
+
getInteractionsByRepository,
|
|
196
360
|
getInteractionsBySessionIds,
|
|
197
361
|
getInteractionsBySessionIdsAndOwner,
|
|
198
362
|
getLatestBackup,
|
|
363
|
+
getRepositoryInfo,
|
|
364
|
+
getUniqueProjects,
|
|
365
|
+
getUniqueRepositories,
|
|
199
366
|
hasInteractions,
|
|
200
367
|
hasInteractionsForSessionIds,
|
|
201
368
|
initDatabase,
|
|
369
|
+
initGlobalDatabase,
|
|
202
370
|
insertInteractions,
|
|
203
371
|
insertPreCompactBackup,
|
|
204
372
|
openDatabase,
|
|
373
|
+
openGlobalDatabase,
|
|
205
374
|
searchInteractions
|
|
206
375
|
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600&family=Quicksand:wght@400;500;600&display=swap";/*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */@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-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking: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-outline-style:solid;--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;--tw-content:"";--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0}}}@layer theme{:root,:host{--color-red-500:oklch(63.7% .237 25.331);--color-orange-200:oklch(90.1% .076 70.697);--color-orange-400:oklch(75% .183 55.934);--color-orange-500:oklch(70.5% .213 47.604);--color-orange-600:oklch(64.6% .222 41.116);--color-amber-50:oklch(98.7% .022 95.277);--color-amber-100:oklch(96.2% .059 95.617);--color-amber-200:oklch(92.4% .12 95.746);--color-amber-300:oklch(87.9% .169 91.605);--color-amber-400:oklch(82.8% .189 84.429);--color-amber-500:oklch(76.9% .188 70.08);--color-amber-600:oklch(66.6% .179 58.318);--color-amber-700:oklch(55.5% .163 48.998);--color-amber-800:oklch(47.3% .137 46.201);--color-amber-900:oklch(41.4% .112 45.904);--color-amber-950:oklch(27.9% .077 45.635);--color-yellow-500:oklch(79.5% .184 86.047);--color-green-400:oklch(79.2% .209 151.711);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-emerald-50:oklch(97.9% .021 166.113);--color-emerald-200:oklch(90.5% .093 164.15);--color-emerald-300:oklch(84.5% .143 164.978);--color-emerald-400:oklch(76.5% .177 163.223);--color-emerald-600:oklch(59.6% .145 163.225);--color-emerald-700:oklch(50.8% .118 165.612);--color-emerald-800:oklch(43.2% .095 166.913);--color-emerald-950:oklch(26.2% .051 172.552);--color-blue-500:oklch(62.3% .214 259.815);--color-indigo-500:oklch(58.5% .233 277.117);--color-purple-500:oklch(62.7% .265 303.9);--color-rose-50:oklch(96.9% .015 12.422);--color-rose-200:oklch(89.2% .058 10.001);--color-rose-300:oklch(81% .117 11.638);--color-rose-400:oklch(71.2% .194 13.428);--color-rose-600:oklch(58.6% .253 17.585);--color-rose-700:oklch(51.4% .222 16.935);--color-rose-800:oklch(45.5% .188 13.697);--color-rose-950:oklch(27.1% .105 12.094);--color-slate-300:oklch(86.9% .022 252.894);--color-gray-500:oklch(55.1% .027 264.364);--color-stone-50:oklch(98.5% .001 106.423);--color-stone-100:oklch(97% .001 106.424);--color-stone-200:oklch(92.3% .003 48.717);--color-stone-300:oklch(86.9% .005 56.366);--color-stone-400:oklch(70.9% .01 56.259);--color-stone-500:oklch(55.3% .013 58.071);--color-stone-600:oklch(44.4% .011 73.639);--color-stone-700:oklch(37.4% .01 67.558);--color-stone-800:oklch(26.8% .007 34.298);--color-stone-900:oklch(21.6% .006 56.043);--color-stone-950:oklch(14.7% .004 49.25);--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wide:.025em;--leading-relaxed:1.625;--animate-pulse:pulse 2s cubic-bezier(.4,0,.6,1)infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono)}}@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%;-moz-tab-size:4;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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}html,body,#root{height:100%}*{border-color:var(--border);outline-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){*{outline-color:color-mix(in oklab,var(--ring)50%,transparent)}}body{background-color:var(--background);color:var(--foreground);font-family:var(--font-geist-sans);background-image:radial-gradient(900px 420px at 8% -10%,#ffebd499,#0000 65%),radial-gradient(800px 420px at 90% 0,#dbe9ff80,#0000 70%),linear-gradient(#fcf8f1,#f6f1e7);background-image:radial-gradient(900px 420px at 8% -10%,color(xyz 0.83 0.854 0.732 / 0.6),#0000 65%),radial-gradient(800px 420px at 90% 0,color(xyz 0.765 0.805 1.158 / 0.502),#0000 70%),linear-gradient(#fcf8f1,#f6f1e7);background-attachment:fixed}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.02em}}@layer components;@layer utilities{.\@container\/card-header{container:card-header/inline-size}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.top-0{top:calc(var(--spacing)*0)}.right-0{right:calc(var(--spacing)*0)}.right-2{right:calc(var(--spacing)*2)}.left-0{left:calc(var(--spacing)*0)}.left-3{left:calc(var(--spacing)*3)}.z-50{z-index:50}.col-span-2{grid-column:span 2/span 2}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.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-1{margin-inline:calc(var(--spacing)*-1)}.-mx-8{margin-inline:calc(var(--spacing)*-8)}.mx-4{margin-inline:calc(var(--spacing)*4)}.-my-8{margin-block:calc(var(--spacing)*-8)}.my-1{margin-block:calc(var(--spacing)*1)}.my-1\.5{margin-block:calc(var(--spacing)*1.5)}.my-2{margin-block:calc(var(--spacing)*2)}.my-3{margin-block:calc(var(--spacing)*3)}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-2\.5{margin-top:calc(var(--spacing)*2.5)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mr-1{margin-right:calc(var(--spacing)*1)}.mr-2{margin-right:calc(var(--spacing)*2)}.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-4{margin-bottom:calc(var(--spacing)*4)}.ml-1{margin-left:calc(var(--spacing)*1)}.ml-2{margin-left:calc(var(--spacing)*2)}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.field-sizing-content{field-sizing:content}.size-2\.5{width:calc(var(--spacing)*2.5);height:calc(var(--spacing)*2.5)}.size-3\.5{width:calc(var(--spacing)*3.5);height:calc(var(--spacing)*3.5)}.size-4{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.size-9{width:calc(var(--spacing)*9);height:calc(var(--spacing)*9)}.h-0\.5{height:calc(var(--spacing)*.5)}.h-1\.5{height:calc(var(--spacing)*1.5)}.h-3{height:calc(var(--spacing)*3)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-7{height:calc(var(--spacing)*7)}.h-8{height:calc(var(--spacing)*8)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-12{height:calc(var(--spacing)*12)}.h-20{height:calc(var(--spacing)*20)}.h-\[200px\]{height:200px}.h-\[300px\]{height:300px}.h-\[600px\]{height:600px}.h-\[calc\(100\%\+64px\)\]{height:calc(100% + 64px)}.h-\[calc\(100\%-1px\)\]{height:calc(100% - 1px)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-\(--radix-select-content-available-height\){max-height:var(--radix-select-content-available-height)}.max-h-48{max-height:calc(var(--spacing)*48)}.max-h-96{max-height:calc(var(--spacing)*96)}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-16{min-height:calc(var(--spacing)*16)}.min-h-\[60px\]{min-height:60px}.min-h-\[80px\]{min-height:80px}.min-h-screen{min-height:100vh}.w-1\.5{width:calc(var(--spacing)*1.5)}.w-3{width:calc(var(--spacing)*3)}.w-3\/4{width:75%}.w-4{width:calc(var(--spacing)*4)}.w-5{width:calc(var(--spacing)*5)}.w-6{width:calc(var(--spacing)*6)}.w-7{width:calc(var(--spacing)*7)}.w-8{width:calc(var(--spacing)*8)}.w-12{width:calc(var(--spacing)*12)}.w-14{width:calc(var(--spacing)*14)}.w-16{width:calc(var(--spacing)*16)}.w-20{width:calc(var(--spacing)*20)}.w-24{width:calc(var(--spacing)*24)}.w-48{width:calc(var(--spacing)*48)}.w-56{width:calc(var(--spacing)*56)}.w-60{width:calc(var(--spacing)*60)}.w-64{width:calc(var(--spacing)*64)}.w-\[30\%\]{width:30%}.w-\[180px\]{width:180px}.w-fit{width:fit-content}.w-full{width:100%}.max-w-\[85\%\]{max-width:85%}.max-w-none{max-width:none}.max-w-sm{max-width:var(--container-sm)}.max-w-xs{max-width:var(--container-xs)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[300px\]{min-width:300px}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.min-w-full{min-width:100%}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.origin-\(--radix-select-content-transform-origin\){transform-origin:var(--radix-select-content-transform-origin)}.origin-\(--radix-tooltip-content-transform-origin\){transform-origin:var(--radix-tooltip-content-transform-origin)}.translate-y-\[calc\(-50\%_-_2px\)\]{--tw-translate-y: calc(-50% - 2px) ;translate:var(--tw-translate-x)var(--tw-translate-y)}.rotate-45{rotate:45deg}.animate-in{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.animate-pulse{animation:var(--animate-pulse)}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize{resize:both}.scroll-my-1{scroll-margin-block:calc(var(--spacing)*1)}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.auto-rows-min{grid-auto-rows:min-content}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.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-start{justify-content:flex-start}.gap-0{gap:calc(var(--spacing)*0)}.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)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}: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)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}.self-start{align-self:flex-start}.justify-self-end{justify-self:flex-end}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:calc(var(--radius) + 8px)}.rounded-\[2px\]{border-radius:2px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.rounded-r-lg{border-top-right-radius:var(--radius);border-bottom-right-radius:var(--radius)}.rounded-br-sm{border-bottom-right-radius:calc(var(--radius) - 4px)}.rounded-bl-sm{border-bottom-left-radius:calc(var(--radius) - 4px)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-amber-200{border-color:var(--color-amber-200)}.border-amber-300{border-color:var(--color-amber-300)}.border-border,.border-border\/70{border-color:var(--border)}@supports (color:color-mix(in lab,red,red)){.border-border\/70{border-color:color-mix(in oklab,var(--border)70%,transparent)}}.border-destructive\/20{border-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.border-destructive\/20{border-color:color-mix(in oklab,var(--destructive)20%,transparent)}}.border-emerald-200{border-color:var(--color-emerald-200)}.border-input{border-color:var(--input)}.border-rose-200{border-color:var(--color-rose-200)}.border-stone-200{border-color:var(--color-stone-200)}.border-stone-300{border-color:var(--color-stone-300)}.border-stone-700\/50{border-color:#44403b80}@supports (color:color-mix(in lab,red,red)){.border-stone-700\/50{border-color:color-mix(in oklab,var(--color-stone-700)50%,transparent)}}.border-transparent{border-color:#0000}.border-white\/20{border-color:#fff3}@supports (color:color-mix(in lab,red,red)){.border-white\/20{border-color:color-mix(in oklab,var(--color-white)20%,transparent)}}.border-white\/30{border-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.border-white\/30{border-color:color-mix(in oklab,var(--color-white)30%,transparent)}}.border-l-blue-500{border-left-color:var(--color-blue-500)}.border-l-gray-500{border-left-color:var(--color-gray-500)}.border-l-green-500{border-left-color:var(--color-green-500)}.border-l-indigo-500{border-left-color:var(--color-indigo-500)}.border-l-orange-500{border-left-color:var(--color-orange-500)}.border-l-purple-500{border-left-color:var(--color-purple-500)}.border-l-red-500{border-left-color:var(--color-red-500)}.border-l-yellow-500{border-left-color:var(--color-yellow-500)}.bg-\[\#1a1816\]\/60{background-color:#1a181699}.bg-\[\#39414B\]{background-color:#39414b}.bg-\[\#F5F5F0\]{background-color:#f5f5f0}.bg-amber-50{background-color:var(--color-amber-50)}.bg-amber-100{background-color:var(--color-amber-100)}.bg-amber-400{background-color:var(--color-amber-400)}.bg-amber-500{background-color:var(--color-amber-500)}.bg-blue-500{background-color:var(--color-blue-500)}.bg-border{background-color:var(--border)}.bg-card{background-color:var(--card)}.bg-destructive,.bg-destructive\/10{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/10{background-color:color-mix(in oklab,var(--destructive)10%,transparent)}}.bg-emerald-50{background-color:var(--color-emerald-50)}.bg-foreground{background-color:var(--foreground)}.bg-green-500{background-color:var(--color-green-500)}.bg-muted,.bg-muted\/30{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/30{background-color:color-mix(in oklab,var(--muted)30%,transparent)}}.bg-muted\/50{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/50{background-color:color-mix(in oklab,var(--muted)50%,transparent)}}.bg-popover{background-color:var(--popover)}.bg-primary{background-color:var(--primary)}.bg-red-500{background-color:var(--color-red-500)}.bg-rose-50{background-color:var(--color-rose-50)}.bg-secondary,.bg-secondary\/80{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){.bg-secondary\/80{background-color:color-mix(in oklab,var(--secondary)80%,transparent)}}.bg-slate-300{background-color:var(--color-slate-300)}.bg-stone-100{background-color:var(--color-stone-100)}.bg-stone-200{background-color:var(--color-stone-200)}.bg-stone-700{background-color:var(--color-stone-700)}.bg-stone-800\/80{background-color:#292524cc}@supports (color:color-mix(in lab,red,red)){.bg-stone-800\/80{background-color:color-mix(in oklab,var(--color-stone-800)80%,transparent)}}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.bg-white\/15{background-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.bg-white\/15{background-color:color-mix(in oklab,var(--color-white)15%,transparent)}}.bg-white\/80{background-color:#fffc}@supports (color:color-mix(in lab,red,red)){.bg-white\/80{background-color:color-mix(in oklab,var(--color-white)80%,transparent)}}.fill-foreground{fill:var(--foreground)}.p-0{padding:calc(var(--spacing)*0)}.p-1{padding:calc(var(--spacing)*1)}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-\[3px\]{padding:3px}.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-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-8{padding-inline:calc(var(--spacing)*8)}.py-0{padding-block:calc(var(--spacing)*0)}.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-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)}.py-10{padding-block:calc(var(--spacing)*10)}.py-12{padding-block:calc(var(--spacing)*12)}.pt-0{padding-top:calc(var(--spacing)*0)}.pt-2{padding-top:calc(var(--spacing)*2)}.pt-4{padding-top:calc(var(--spacing)*4)}.pt-\[70px\]{padding-top:70px}.pr-8{padding-right:calc(var(--spacing)*8)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-3{padding-bottom:calc(var(--spacing)*3)}.pb-4{padding-bottom:calc(var(--spacing)*4)}.pl-2{padding-left:calc(var(--spacing)*2)}.pl-3{padding-left:calc(var(--spacing)*3)}.pl-8{padding-left:calc(var(--spacing)*8)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-geist-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.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-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.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-\[0\.2em\]{--tw-tracking:.2em;letter-spacing:.2em}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.text-balance{text-wrap:balance}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.text-\[\#C15F3C\]{color:#c15f3c}.text-amber-500{color:var(--color-amber-500)}.text-amber-600{color:var(--color-amber-600)}.text-amber-700{color:var(--color-amber-700)}.text-amber-800{color:var(--color-amber-800)}.text-amber-900{color:var(--color-amber-900)}.text-background{color:var(--background)}.text-card-foreground{color:var(--card-foreground)}.text-destructive{color:var(--destructive)}.text-emerald-600{color:var(--color-emerald-600)}.text-emerald-700{color:var(--color-emerald-700)}.text-emerald-800{color:var(--color-emerald-800)}.text-foreground,.text-foreground\/60{color:var(--foreground)}@supports (color:color-mix(in lab,red,red)){.text-foreground\/60{color:color-mix(in oklab,var(--foreground)60%,transparent)}}.text-green-600{color:var(--color-green-600)}.text-muted-foreground{color:var(--muted-foreground)}.text-orange-200{color:var(--color-orange-200)}.text-orange-600{color:var(--color-orange-600)}.text-popover-foreground{color:var(--popover-foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-rose-600{color:var(--color-rose-600)}.text-rose-700{color:var(--color-rose-700)}.text-rose-800{color:var(--color-rose-800)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-stone-100{color:var(--color-stone-100)}.text-stone-200{color:var(--color-stone-200)}.text-stone-300{color:var(--color-stone-300)}.text-stone-400{color:var(--color-stone-400)}.text-stone-500{color:var(--color-stone-500)}.text-stone-600{color:var(--color-stone-600)}.text-stone-700{color:var(--color-stone-700)}.text-stone-800{color:var(--color-stone-800)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-50{opacity:.5}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px 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-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px 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-xs{--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline-hidden{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.outline-hidden{outline-offset:2px;outline:2px solid #0000}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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,)}.transition-\[color\,box-shadow\]{transition-property:color,box-shadow;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))}.fade-in-0{--tw-enter-opacity:0}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.zoom-in-95{--tw-enter-scale:.95}.group-data-\[orientation\=horizontal\]\/tabs\:h-9:is(:where(.group\/tabs)[data-orientation=horizontal] *){height:calc(var(--spacing)*9)}.group-data-\[orientation\=vertical\]\/tabs\:h-fit:is(:where(.group\/tabs)[data-orientation=vertical] *){height:fit-content}.group-data-\[orientation\=vertical\]\/tabs\:w-full:is(:where(.group\/tabs)[data-orientation=vertical] *){width:100%}.group-data-\[orientation\=vertical\]\/tabs\:flex-col:is(:where(.group\/tabs)[data-orientation=vertical] *){flex-direction:column}.group-data-\[orientation\=vertical\]\/tabs\:justify-start:is(:where(.group\/tabs)[data-orientation=vertical] *){justify-content:flex-start}.group-data-\[variant\=line\]\/tabs-list\:bg-transparent:is(:where(.group\/tabs-list)[data-variant=line] *){background-color:#0000}.selection\:bg-primary ::selection{background-color:var(--primary)}.selection\:bg-primary::selection{background-color:var(--primary)}.selection\:text-primary-foreground ::selection{color:var(--primary-foreground)}.selection\:text-primary-foreground::selection{color:var(--primary-foreground)}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:calc(var(--spacing)*7)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:var(--foreground)}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:bg-foreground:after{content:var(--tw-content);background-color:var(--foreground)}.after\:opacity-0:after{content:var(--tw-content);opacity:0}.after\:transition-opacity:after{content:var(--tw-content);transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.group-data-\[orientation\=horizontal\]\/tabs\:after\:inset-x-0:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);inset-inline:calc(var(--spacing)*0)}.group-data-\[orientation\=horizontal\]\/tabs\:after\:bottom-\[-5px\]:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);bottom:-5px}.group-data-\[orientation\=horizontal\]\/tabs\:after\:h-0\.5:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);height:calc(var(--spacing)*.5)}.group-data-\[orientation\=vertical\]\/tabs\:after\:inset-y-0:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);inset-block:calc(var(--spacing)*0)}.group-data-\[orientation\=vertical\]\/tabs\:after\:-right-1:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);right:calc(var(--spacing)*-1)}.group-data-\[orientation\=vertical\]\/tabs\:after\:w-0\.5:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);width:calc(var(--spacing)*.5)}@media(hover:hover){.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-amber-200:hover{background-color:var(--color-amber-200)}.hover\:bg-destructive\/10:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/10:hover{background-color:color-mix(in oklab,var(--destructive)10%,transparent)}}.hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--destructive)90%,transparent)}}.hover\:bg-muted\/50:hover{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-muted\/50:hover{background-color:color-mix(in oklab,var(--muted)50%,transparent)}}.hover\:bg-muted\/80:hover{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-muted\/80:hover{background-color:color-mix(in oklab,var(--muted)80%,transparent)}}.hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--primary)90%,transparent)}}.hover\:bg-secondary:hover{background-color:var(--secondary)}.hover\:bg-stone-50:hover{background-color:var(--color-stone-50)}.hover\:bg-stone-100:hover{background-color:var(--color-stone-100)}.hover\:bg-white:hover{background-color:var(--color-white)}.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}.hover\:text-destructive:hover{color:var(--destructive)}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:text-stone-700:hover{color:var(--color-stone-700)}.hover\:text-stone-900:hover{color:var(--color-stone-900)}.hover\:underline:hover{text-decoration-line:underline}}.focus\:bg-accent:focus{background-color:var(--accent)}.focus\:text-accent-foreground:focus{color:var(--accent-foreground)}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(3px + 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)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:color-mix(in oklab,var(--destructive)20%,transparent)}}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:color-mix(in oklab,var(--ring)50%,transparent)}}.focus-visible\:outline-1:focus-visible{outline-style:var(--tw-outline-style);outline-width:1px}.focus-visible\:outline-ring:focus-visible{outline-color:var(--ring)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\]:has([data-slot=card-action]){grid-template-columns:1fr auto}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing)*2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing)*3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing)*4)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:color-mix(in oklab,var(--destructive)20%,transparent)}}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[orientation\=horizontal\]\:flex-col[data-orientation=horizontal]{flex-direction:column}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:var(--muted-foreground)}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:calc(2*var(--spacing)*-1)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:calc(2*var(--spacing))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:calc(2*var(--spacing)*-1)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:calc(2*var(--spacing))}.data-\[size\=default\]\:h-9[data-size=default]{height:calc(var(--spacing)*9)}.data-\[size\=sm\]\:h-8[data-size=sm]{height:calc(var(--spacing)*8)}:is(.\*\:data-\[slot\=select-value\]\:line-clamp-1>*)[data-slot=select-value]{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}:is(.\*\:data-\[slot\=select-value\]\:flex>*)[data-slot=select-value]{display:flex}:is(.\*\:data-\[slot\=select-value\]\:items-center>*)[data-slot=select-value]{align-items:center}:is(.\*\:data-\[slot\=select-value\]\:gap-2>*)[data-slot=select-value]{gap:calc(var(--spacing)*2)}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:var(--background)}.data-\[state\=active\]\:text-foreground[data-state=active]{color:var(--foreground)}.group-data-\[variant\=default\]\/tabs-list\:data-\[state\=active\]\:shadow-sm:is(:where(.group\/tabs-list)[data-variant=default] *)[data-state=active]{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px 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)}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:bg-transparent:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{background-color:#0000}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:shadow-none:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:after\:opacity-100:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]:after{content:var(--tw-content);opacity:1}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation:exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=inactive\]\:hidden[data-state=inactive]{display:none}.data-\[state\=open\]\:animate-in[data-state=open]{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[variant\=line\]\:rounded-none[data-variant=line]{border-radius:0}@media(min-width:48rem){.md\:col-span-2{grid-column:span 2/span 2}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}@media(min-width:64rem){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.lg\:grid-cols-\[1fr_300px\]{grid-template-columns:1fr 300px}}.dark\:border-amber-800:is(.dark *){border-color:var(--color-amber-800)}.dark\:border-emerald-800:is(.dark *){border-color:var(--color-emerald-800)}.dark\:border-rose-800:is(.dark *){border-color:var(--color-rose-800)}.dark\:border-stone-600:is(.dark *){border-color:var(--color-stone-600)}.dark\:border-stone-700:is(.dark *){border-color:var(--color-stone-700)}.dark\:bg-amber-950\/20:is(.dark *){background-color:#46190133}@supports (color:color-mix(in lab,red,red)){.dark\:bg-amber-950\/20:is(.dark *){background-color:color-mix(in oklab,var(--color-amber-950)20%,transparent)}}.dark\:bg-amber-950\/30:is(.dark *){background-color:#4619014d}@supports (color:color-mix(in lab,red,red)){.dark\:bg-amber-950\/30:is(.dark *){background-color:color-mix(in oklab,var(--color-amber-950)30%,transparent)}}.dark\:bg-amber-950\/40:is(.dark *){background-color:#46190166}@supports (color:color-mix(in lab,red,red)){.dark\:bg-amber-950\/40:is(.dark *){background-color:color-mix(in oklab,var(--color-amber-950)40%,transparent)}}.dark\:bg-amber-950\/50:is(.dark *){background-color:#46190180}@supports (color:color-mix(in lab,red,red)){.dark\:bg-amber-950\/50:is(.dark *){background-color:color-mix(in oklab,var(--color-amber-950)50%,transparent)}}.dark\:bg-destructive\/60:is(.dark *){background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-destructive\/60:is(.dark *){background-color:color-mix(in oklab,var(--destructive)60%,transparent)}}.dark\:bg-emerald-950\/30:is(.dark *){background-color:#002c224d}@supports (color:color-mix(in lab,red,red)){.dark\:bg-emerald-950\/30:is(.dark *){background-color:color-mix(in oklab,var(--color-emerald-950)30%,transparent)}}.dark\:bg-input\/30:is(.dark *){background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-input\/30:is(.dark *){background-color:color-mix(in oklab,var(--input)30%,transparent)}}.dark\:bg-rose-950\/30:is(.dark *){background-color:#4d02184d}@supports (color:color-mix(in lab,red,red)){.dark\:bg-rose-950\/30:is(.dark *){background-color:color-mix(in oklab,var(--color-rose-950)30%,transparent)}}.dark\:bg-stone-600:is(.dark *){background-color:var(--color-stone-600)}.dark\:bg-stone-700:is(.dark *){background-color:var(--color-stone-700)}.dark\:bg-stone-800:is(.dark *){background-color:var(--color-stone-800)}.dark\:bg-stone-900:is(.dark *){background-color:var(--color-stone-900)}.dark\:bg-stone-950:is(.dark *){background-color:var(--color-stone-950)}.dark\:text-amber-100:is(.dark *){color:var(--color-amber-100)}.dark\:text-amber-200:is(.dark *){color:var(--color-amber-200)}.dark\:text-amber-300:is(.dark *){color:var(--color-amber-300)}.dark\:text-amber-400:is(.dark *){color:var(--color-amber-400)}.dark\:text-amber-500:is(.dark *){color:var(--color-amber-500)}.dark\:text-emerald-200:is(.dark *){color:var(--color-emerald-200)}.dark\:text-emerald-300:is(.dark *){color:var(--color-emerald-300)}.dark\:text-emerald-400:is(.dark *){color:var(--color-emerald-400)}.dark\:text-green-400:is(.dark *){color:var(--color-green-400)}.dark\:text-muted-foreground:is(.dark *){color:var(--muted-foreground)}.dark\:text-orange-400:is(.dark *){color:var(--color-orange-400)}.dark\:text-rose-200:is(.dark *){color:var(--color-rose-200)}.dark\:text-rose-300:is(.dark *){color:var(--color-rose-300)}.dark\:text-rose-400:is(.dark *){color:var(--color-rose-400)}.dark\:text-stone-100:is(.dark *){color:var(--color-stone-100)}.dark\:text-stone-200:is(.dark *){color:var(--color-stone-200)}.dark\:text-stone-300:is(.dark *){color:var(--color-stone-300)}.dark\:text-stone-400:is(.dark *){color:var(--color-stone-400)}@media(hover:hover){.dark\:hover\:bg-amber-900\/50:is(.dark *):hover{background-color:#7b330680}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-amber-900\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--color-amber-900)50%,transparent)}}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--input)50%,transparent)}}.dark\:hover\:bg-stone-800:is(.dark *):hover{background-color:var(--color-stone-800)}.dark\:hover\:text-foreground:is(.dark *):hover{color:var(--foreground)}.dark\:hover\:text-stone-100:is(.dark *):hover{color:var(--color-stone-100)}.dark\:hover\:text-stone-200:is(.dark *):hover{color:var(--color-stone-200)}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:color-mix(in oklab,var(--destructive)40%,transparent)}}.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab,var(--destructive)40%,transparent)}}.dark\:data-\[state\=active\]\:border-input:is(.dark *)[data-state=active]{border-color:var(--input)}.dark\:data-\[state\=active\]\:bg-input\/30:is(.dark *)[data-state=active]{background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:data-\[state\=active\]\:bg-input\/30:is(.dark *)[data-state=active]{background-color:color-mix(in oklab,var(--input)30%,transparent)}}.dark\:data-\[state\=active\]\:text-foreground:is(.dark *)[data-state=active]{color:var(--foreground)}.dark\:group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:border-transparent:is(.dark *):is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{border-color:#0000}.dark\:group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:bg-transparent:is(.dark *):is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{background-color:#0000}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground svg:not([class*=text-]){color:var(--muted-foreground)}.\[\.border-b\]\:pb-6.border-b{padding-bottom:calc(var(--spacing)*6)}.\[\.border-t\]\:pt-6.border-t{padding-top:calc(var(--spacing)*6)}:is(.\*\:\[span\]\:last\:flex>*):is(span):last-child{display:flex}:is(.\*\:\[span\]\:last\:items-center>*):is(span):last-child{align-items:center}:is(.\*\:\[span\]\:last\:gap-2>*):is(span):last-child{gap:calc(var(--spacing)*2)}.\[\&\>code\]\:border-0>code{border-style:var(--tw-border-style);border-width:0}.\[\&\>code\]\:bg-transparent>code{background-color:#0000}.\[\&\>code\]\:p-0>code{padding:calc(var(--spacing)*0)}.\[\&\>code\]\:text-inherit>code{color:inherit}.\[\&\>svg\]\:pointer-events-none>svg{pointer-events:none}.\[\&\>svg\]\:size-3>svg{width:calc(var(--spacing)*3);height:calc(var(--spacing)*3)}@media(hover:hover){a.\[a\&\]\:hover\:bg-accent:hover{background-color:var(--accent)}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--destructive)90%,transparent)}}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:color-mix(in oklab,var(--secondary)90%,transparent)}}a.\[a\&\]\:hover\:bg-stone-600:hover{background-color:var(--color-stone-600)}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:var(--accent-foreground)}a.\[a\&\]\:hover\:underline:hover{text-decoration-line:underline}a.dark\:\[a\&\]\:hover\:bg-stone-500:is(.dark *):hover{background-color:var(--color-stone-500)}}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}:root{--radius:.625rem;--background:oklch(100% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--primary:oklch(20.5% 0 0);--primary-foreground:oklch(98.5% 0 0);--secondary:oklch(97% 0 0);--secondary-foreground:oklch(20.5% 0 0);--muted:oklch(97% 0 0);--muted-foreground:oklch(55.6% 0 0);--accent:oklch(97% 0 0);--accent-foreground:oklch(20.5% 0 0);--destructive:oklch(57.7% .245 27.325);--border:oklch(92.2% 0 0);--input:oklch(92.2% 0 0);--ring:oklch(70.8% 0 0);--chart-1:oklch(64.6% .222 41.116);--chart-2:oklch(60% .118 184.704);--chart-3:oklch(39.8% .07 227.392);--chart-4:oklch(82.8% .189 84.429);--chart-5:oklch(76.9% .188 70.08);--sidebar:oklch(98.5% 0 0);--sidebar-foreground:oklch(14.5% 0 0);--sidebar-primary:oklch(20.5% 0 0);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(97% 0 0);--sidebar-accent-foreground:oklch(20.5% 0 0);--sidebar-border:oklch(92.2% 0 0);--sidebar-ring:oklch(70.8% 0 0);--font-geist-sans:"Nunito",ui-sans-serif,system-ui,sans-serif;--font-geist-mono:ui-monospace,monospace;--font-display:"Quicksand",ui-sans-serif,system-ui,sans-serif}.dark{--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(20.5% 0 0);--card-foreground:oklch(98.5% 0 0);--popover:oklch(20.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--primary:oklch(92.2% 0 0);--primary-foreground:oklch(20.5% 0 0);--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--destructive:oklch(70.4% .191 22.216);--border:oklch(100% 0 0/.1);--input:oklch(100% 0 0/.15);--ring:oklch(55.6% 0 0);--chart-1:oklch(48.8% .243 264.376);--chart-2:oklch(69.6% .17 162.48);--chart-3:oklch(76.9% .188 70.08);--chart-4:oklch(62.7% .265 303.9);--chart-5:oklch(64.5% .246 16.439);--sidebar:oklch(20.5% 0 0);--sidebar-foreground:oklch(98.5% 0 0);--sidebar-primary:oklch(48.8% .243 264.376);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(26.9% 0 0);--sidebar-accent-foreground:oklch(98.5% 0 0);--sidebar-border:oklch(100% 0 0/.1);--sidebar-ring:oklch(55.6% 0 0)}@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-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-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-outline-style{syntax:"*";inherits:false;initial-value:solid}@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}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes pulse{50%{opacity:.5}}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0));filter:blur(var(--tw-enter-blur,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0)scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1))rotate(var(--tw-exit-rotate,0));filter:blur(var(--tw-exit-blur,0))}}
|