diffhub 0.1.21 → 0.1.23
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/.next/standalone/apps/cli/.next/BUILD_ID +1 -1
- package/.next/standalone/apps/cli/.next/app-path-routes-manifest.json +2 -0
- package/.next/standalone/apps/cli/.next/build-manifest.json +3 -3
- package/.next/standalone/apps/cli/.next/prerender-manifest.json +3 -3
- package/.next/standalone/apps/cli/.next/routes-manifest.json +12 -0
- package/.next/standalone/apps/cli/.next/server/app/_global-error.html +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_global-error.rsc +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_not-found.html +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_not-found.rsc +2 -2
- package/.next/standalone/apps/cli/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
- package/.next/standalone/apps/cli/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
- package/.next/standalone/apps/cli/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/standalone/apps/cli/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/apps/cli/.next/server/app/api/watch/route/app-paths-manifest.json +3 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch/route/build-manifest.json +9 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch/route/server-reference-manifest.json +4 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch/route.js +7 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch/route.js.map +5 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch/route.js.nft.json +1 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch/route_client-reference-manifest.js +3 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch-events/route/app-paths-manifest.json +3 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch-events/route/build-manifest.json +9 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch-events/route/server-reference-manifest.json +4 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch-events/route.js +8 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch-events/route.js.map +5 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch-events/route.js.nft.json +1 -0
- package/.next/standalone/apps/cli/.next/server/app/api/watch-events/route_client-reference-manifest.js +3 -0
- package/.next/standalone/apps/cli/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/standalone/apps/cli/.next/server/app-paths-manifest.json +2 -0
- package/.next/standalone/apps/cli/.next/server/chunks/[root-of-the-server]__05nbqqx._.js +4 -0
- package/.next/standalone/apps/cli/.next/server/chunks/[root-of-the-server]__05wbal-._.js +2 -2
- package/.next/standalone/apps/cli/.next/server/chunks/[root-of-the-server]__09h-x6c._.js +1 -1
- package/.next/standalone/apps/cli/.next/server/chunks/[root-of-the-server]__0c~ts~e._.js +2 -2
- package/.next/standalone/apps/cli/.next/server/chunks/[root-of-the-server]__0f2zsso._.js +2 -2
- package/.next/standalone/apps/cli/.next/server/chunks/[root-of-the-server]__0nnjixg._.js +2 -2
- package/.next/standalone/apps/cli/.next/server/chunks/[root-of-the-server]__0qe921e._.js +3 -0
- package/.next/standalone/apps/cli/.next/server/chunks/[root-of-the-server]__101690.._.js +9 -0
- package/.next/standalone/apps/cli/.next/server/chunks/apps_cli__next-internal_server_app_api_watch-events_route_actions_0i.gzl8.js +3 -0
- package/.next/standalone/apps/cli/.next/server/chunks/apps_cli__next-internal_server_app_api_watch_route_actions_11u4ntq.js +3 -0
- package/.next/standalone/apps/cli/.next/server/chunks/ssr/_07okxca._.js +4 -4
- package/.next/standalone/apps/cli/.next/server/chunks/ssr/_13g0g_e._.js +1 -1
- package/.next/standalone/apps/cli/.next/server/functions-config-manifest.json +3 -1
- package/.next/standalone/apps/cli/.next/server/middleware-build-manifest.js +3 -3
- package/.next/standalone/apps/cli/.next/server/pages/404.html +1 -1
- package/.next/standalone/apps/cli/.next/server/pages/500.html +1 -1
- package/.next/standalone/apps/cli/.next/server/server-reference-manifest.js +1 -1
- package/.next/standalone/apps/cli/.next/server/server-reference-manifest.json +1 -1
- package/.next/standalone/apps/cli/.next/static/chunks/0sf7ki_q88l_a.css +3 -0
- package/.next/standalone/apps/cli/.next/static/chunks/{0fppn0k28p91w.js → 0vm79-lt-4syt.js} +5 -5
- package/.next/standalone/apps/cli/package.json +1 -1
- package/README.md +2 -2
- package/bin/diffhub.mjs +275 -5
- package/package.json +1 -1
- package/.next/standalone/apps/cli/.next/static/chunks/0rqn~w2w6yi6a.css +0 -3
- /package/.next/standalone/apps/cli/.next/static/{6cVCja64K961lBaYeFXnt → XaFUoKZbR-bS9r4T4fiPI}/_buildManifest.js +0 -0
- /package/.next/standalone/apps/cli/.next/static/{6cVCja64K961lBaYeFXnt → XaFUoKZbR-bS9r4T4fiPI}/_clientMiddlewareManifest.js +0 -0
- /package/.next/standalone/apps/cli/.next/static/{6cVCja64K961lBaYeFXnt → XaFUoKZbR-bS9r4T4fiPI}/_ssgManifest.js +0 -0
package/README.md
CHANGED
|
@@ -48,7 +48,7 @@ diffhub --no-open
|
|
|
48
48
|
- **Whitespace filtering** — ignore whitespace-only changes from the top bar when reviewing formatting-heavy diffs
|
|
49
49
|
- **Inline AI comments** — add `[must-fix]`, `[suggestion]`, `[nit]`, or `[question]` notes on any diff line; copy all comments as a formatted prompt
|
|
50
50
|
- **"Open in" context menu** — right-click any file to open in Zed, VS Code, Ghostty, Terminal, Finder, or copy the path
|
|
51
|
-
- **Live refresh** —
|
|
51
|
+
- **Live refresh** — watches local file changes and updates the diff automatically; force refresh with `r`
|
|
52
52
|
- **File sidebar** — filter files with `/`, see per-file `+`/`-` stats at a glance
|
|
53
53
|
|
|
54
54
|
## Development notes
|
|
@@ -64,7 +64,7 @@ diffhub --no-open
|
|
|
64
64
|
| `j` / `k` | Next / previous file |
|
|
65
65
|
| `s` | Toggle split / unified view |
|
|
66
66
|
| `/` | Focus file filter |
|
|
67
|
-
| `r` |
|
|
67
|
+
| `r` | Force refresh diff |
|
|
68
68
|
|
|
69
69
|
## Options
|
|
70
70
|
|
package/bin/diffhub.mjs
CHANGED
|
@@ -14,7 +14,7 @@ import {
|
|
|
14
14
|
} from "node:fs";
|
|
15
15
|
import { createServer } from "node:net";
|
|
16
16
|
import { tmpdir } from "node:os";
|
|
17
|
-
import { join, resolve } from "node:path";
|
|
17
|
+
import { dirname, join, resolve } from "node:path";
|
|
18
18
|
import { promisify } from "node:util";
|
|
19
19
|
import {
|
|
20
20
|
findMissingStandaloneNodeModuleAliases,
|
|
@@ -23,6 +23,7 @@ import {
|
|
|
23
23
|
|
|
24
24
|
const execFile = promisify(execFileCb);
|
|
25
25
|
const __dirname = import.meta.dirname;
|
|
26
|
+
const __filename = import.meta.filename;
|
|
26
27
|
const PREFERRED_BASE_BRANCHES = ["main", "master", "develop", "dev"];
|
|
27
28
|
|
|
28
29
|
// Fast-fail on unsupported Node.js versions
|
|
@@ -147,11 +148,19 @@ const getCmuxWriterPidPath = (repoPath) => {
|
|
|
147
148
|
return join(tmpdir(), `diffhub-cmux-writer-${hash}.pid`);
|
|
148
149
|
};
|
|
149
150
|
|
|
151
|
+
const getCmuxWatchEventsPidPath = (repoPath) => {
|
|
152
|
+
const hash = createHash("md5").update(repoPath).digest("hex").slice(0, 8);
|
|
153
|
+
return join(tmpdir(), `diffhub-cmux-watch-events-${hash}.pid`);
|
|
154
|
+
};
|
|
155
|
+
|
|
150
156
|
const createServerBootId = (repoPath, baseBranch) =>
|
|
151
157
|
createHash("sha1")
|
|
152
158
|
.update(`${repoPath}:${baseBranch}:${Date.now()}:${Math.random()}`)
|
|
153
159
|
.digest("hex");
|
|
154
160
|
|
|
161
|
+
const createWatchToken = () =>
|
|
162
|
+
createHash("sha1").update(`watch:${process.pid}:${Date.now()}:${Math.random()}`).digest("hex");
|
|
163
|
+
|
|
155
164
|
const clearRepoSnapshotFiles = (repoPath) => {
|
|
156
165
|
const prefix = `diffhub-snapshot-${createHash("sha1").update(repoPath).digest("hex")}-`;
|
|
157
166
|
for (const entry of readdirSync(tmpdir())) {
|
|
@@ -307,6 +316,36 @@ const resolveBaseBranch = async (repoPath, explicitBaseBranch) => {
|
|
|
307
316
|
return "origin/main";
|
|
308
317
|
};
|
|
309
318
|
|
|
319
|
+
const getGitDirectory = (repoPath) =>
|
|
320
|
+
execFileSync("git", ["rev-parse", "--path-format=absolute", "--git-dir"], {
|
|
321
|
+
cwd: repoPath,
|
|
322
|
+
encoding: "utf-8",
|
|
323
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
324
|
+
}).trim();
|
|
325
|
+
|
|
326
|
+
const getTrackedWatchDirectories = (repoPath) => {
|
|
327
|
+
const rawFiles = execFileSync("git", ["ls-files", "-z"], {
|
|
328
|
+
cwd: repoPath,
|
|
329
|
+
encoding: "utf-8",
|
|
330
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
331
|
+
});
|
|
332
|
+
const directories = new Set([repoPath]);
|
|
333
|
+
|
|
334
|
+
for (const file of rawFiles.split("\0")) {
|
|
335
|
+
if (!file) {
|
|
336
|
+
continue;
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
const relativeDirectory = dirname(file);
|
|
340
|
+
const directory = relativeDirectory === "." ? repoPath : join(repoPath, relativeDirectory);
|
|
341
|
+
if (existsSync(directory)) {
|
|
342
|
+
directories.add(directory);
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
|
|
346
|
+
return [...directories];
|
|
347
|
+
};
|
|
348
|
+
|
|
310
349
|
const buildSnapshot = async (repoPath, explicitBaseBranch, mode, serverBootId) => {
|
|
311
350
|
const branchOutput = await runGitSnapshotCommand(repoPath, ["rev-parse", "--abbrev-ref", "HEAD"]);
|
|
312
351
|
const branch = branchOutput.trim();
|
|
@@ -480,6 +519,89 @@ const startSnapshotWriter = async (repoPath, explicitBaseBranch, serverBootId) =
|
|
|
480
519
|
};
|
|
481
520
|
};
|
|
482
521
|
|
|
522
|
+
const postWatchEvent = async (port, token, event, path) => {
|
|
523
|
+
const response = await fetch(`http://127.0.0.1:${port}/api/watch-events`, {
|
|
524
|
+
body: JSON.stringify({ event, path }),
|
|
525
|
+
headers: {
|
|
526
|
+
Connection: "close",
|
|
527
|
+
"Content-Type": "application/json",
|
|
528
|
+
"x-diffhub-watch-token": token,
|
|
529
|
+
},
|
|
530
|
+
method: "POST",
|
|
531
|
+
});
|
|
532
|
+
|
|
533
|
+
if (!response.ok) {
|
|
534
|
+
throw new Error(`watch event POST failed with ${response.status}`);
|
|
535
|
+
}
|
|
536
|
+
};
|
|
537
|
+
|
|
538
|
+
const startWatchEventForwarder = (repoPath, port, token) => {
|
|
539
|
+
const gitDir = getGitDirectory(repoPath);
|
|
540
|
+
const watchTargets = [
|
|
541
|
+
...getTrackedWatchDirectories(repoPath),
|
|
542
|
+
join(gitDir, "HEAD"),
|
|
543
|
+
join(gitDir, "index"),
|
|
544
|
+
join(gitDir, "packed-refs"),
|
|
545
|
+
].filter(existsSync);
|
|
546
|
+
|
|
547
|
+
let sendTimer = null;
|
|
548
|
+
let pendingEvent = null;
|
|
549
|
+
|
|
550
|
+
const sendPendingEvent = async (nextEvent) => {
|
|
551
|
+
try {
|
|
552
|
+
await postWatchEvent(port, token, nextEvent.event, nextEvent.path);
|
|
553
|
+
} catch (error) {
|
|
554
|
+
console.error("[diffhub] failed to forward watch event", { error });
|
|
555
|
+
}
|
|
556
|
+
};
|
|
557
|
+
|
|
558
|
+
const flushPendingEvent = () => {
|
|
559
|
+
const nextEvent = pendingEvent;
|
|
560
|
+
pendingEvent = null;
|
|
561
|
+
sendTimer = null;
|
|
562
|
+
|
|
563
|
+
if (!nextEvent) {
|
|
564
|
+
return;
|
|
565
|
+
}
|
|
566
|
+
|
|
567
|
+
void sendPendingEvent(nextEvent);
|
|
568
|
+
};
|
|
569
|
+
|
|
570
|
+
const scheduleEvent = (event, path = null) => {
|
|
571
|
+
pendingEvent = { event, path };
|
|
572
|
+
if (sendTimer) {
|
|
573
|
+
clearTimeout(sendTimer);
|
|
574
|
+
}
|
|
575
|
+
|
|
576
|
+
sendTimer = setTimeout(flushPendingEvent, 150);
|
|
577
|
+
};
|
|
578
|
+
|
|
579
|
+
const watcher = watch(watchTargets, {
|
|
580
|
+
atomic: true,
|
|
581
|
+
depth: 0,
|
|
582
|
+
ignoreInitial: true,
|
|
583
|
+
ignored: (pathToCheck) => shouldIgnoreWatchPath(pathToCheck, repoPath),
|
|
584
|
+
persistent: true,
|
|
585
|
+
});
|
|
586
|
+
|
|
587
|
+
watcher.on("add", (path) => scheduleEvent("add", path));
|
|
588
|
+
watcher.on("addDir", (path) => scheduleEvent("addDir", path));
|
|
589
|
+
watcher.on("change", (path) => scheduleEvent("change", path));
|
|
590
|
+
watcher.on("unlink", (path) => scheduleEvent("unlink", path));
|
|
591
|
+
watcher.on("unlinkDir", (path) => scheduleEvent("unlinkDir", path));
|
|
592
|
+
watcher.on("error", (error) => {
|
|
593
|
+
console.error("[diffhub] watch event forwarder failed", { error });
|
|
594
|
+
});
|
|
595
|
+
|
|
596
|
+
return async () => {
|
|
597
|
+
if (sendTimer) {
|
|
598
|
+
clearTimeout(sendTimer);
|
|
599
|
+
sendTimer = null;
|
|
600
|
+
}
|
|
601
|
+
await watcher.close();
|
|
602
|
+
};
|
|
603
|
+
};
|
|
604
|
+
|
|
483
605
|
const listSnapshotWriterProcesses = async (repoPath) => {
|
|
484
606
|
try {
|
|
485
607
|
const { stdout } = await execFile("ps", ["-axo", "pid=,command="], {
|
|
@@ -594,6 +716,115 @@ const stopSnapshotWriterProcess = async (repoPath) => {
|
|
|
594
716
|
}
|
|
595
717
|
};
|
|
596
718
|
|
|
719
|
+
const listWatchEventProcesses = async (repoPath) => {
|
|
720
|
+
try {
|
|
721
|
+
const { stdout } = await execFile("ps", ["-axo", "pid=,command="], {
|
|
722
|
+
encoding: "utf-8",
|
|
723
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
724
|
+
});
|
|
725
|
+
|
|
726
|
+
const repoMatcher = `--repo ${repoPath}`;
|
|
727
|
+
return stdout
|
|
728
|
+
.split("\n")
|
|
729
|
+
.map((line) => line.trim())
|
|
730
|
+
.filter(Boolean)
|
|
731
|
+
.map((line) => {
|
|
732
|
+
const firstSpace = line.indexOf(" ");
|
|
733
|
+
if (firstSpace === -1) {
|
|
734
|
+
return null;
|
|
735
|
+
}
|
|
736
|
+
|
|
737
|
+
const pid = Number.parseInt(line.slice(0, firstSpace), 10);
|
|
738
|
+
const command = line.slice(firstSpace + 1);
|
|
739
|
+
if (
|
|
740
|
+
!Number.isInteger(pid) ||
|
|
741
|
+
pid <= 0 ||
|
|
742
|
+
pid === process.pid ||
|
|
743
|
+
!command.includes("internal-watch-events") ||
|
|
744
|
+
!command.includes(repoMatcher)
|
|
745
|
+
) {
|
|
746
|
+
return null;
|
|
747
|
+
}
|
|
748
|
+
|
|
749
|
+
return { command, pid };
|
|
750
|
+
})
|
|
751
|
+
.filter(Boolean);
|
|
752
|
+
} catch {
|
|
753
|
+
return [];
|
|
754
|
+
}
|
|
755
|
+
};
|
|
756
|
+
|
|
757
|
+
const stopWatchEventsProcess = async (repoPath) => {
|
|
758
|
+
const pidPath = getCmuxWatchEventsPidPath(repoPath);
|
|
759
|
+
const targetPids = new Set();
|
|
760
|
+
|
|
761
|
+
try {
|
|
762
|
+
const pid = Number.parseInt(readFileSync(pidPath, "utf-8").trim(), 10);
|
|
763
|
+
if (Number.isInteger(pid) && pid > 0 && pid !== process.pid) {
|
|
764
|
+
targetPids.add(pid);
|
|
765
|
+
}
|
|
766
|
+
} catch {
|
|
767
|
+
// empty
|
|
768
|
+
}
|
|
769
|
+
|
|
770
|
+
const runningWatchers = await listWatchEventProcesses(repoPath);
|
|
771
|
+
for (const watcher of runningWatchers) {
|
|
772
|
+
targetPids.add(watcher.pid);
|
|
773
|
+
}
|
|
774
|
+
|
|
775
|
+
for (const pid of targetPids) {
|
|
776
|
+
try {
|
|
777
|
+
process.kill(pid, "SIGTERM");
|
|
778
|
+
} catch {
|
|
779
|
+
// empty
|
|
780
|
+
}
|
|
781
|
+
}
|
|
782
|
+
|
|
783
|
+
const remainingPids = [...targetPids];
|
|
784
|
+
const exited = await waitForProcessesToExit(remainingPids);
|
|
785
|
+
if (!exited) {
|
|
786
|
+
for (const pid of remainingPids) {
|
|
787
|
+
try {
|
|
788
|
+
process.kill(pid, "SIGKILL");
|
|
789
|
+
} catch {
|
|
790
|
+
// empty
|
|
791
|
+
}
|
|
792
|
+
}
|
|
793
|
+
|
|
794
|
+
await waitForProcessesToExit(remainingPids, 1000);
|
|
795
|
+
}
|
|
796
|
+
|
|
797
|
+
try {
|
|
798
|
+
unlinkSync(pidPath);
|
|
799
|
+
} catch {
|
|
800
|
+
// empty
|
|
801
|
+
}
|
|
802
|
+
};
|
|
803
|
+
|
|
804
|
+
const startWatchEventsProcess = (repoPath, port, token) => {
|
|
805
|
+
const child = spawn(
|
|
806
|
+
process.execPath,
|
|
807
|
+
[
|
|
808
|
+
__filename,
|
|
809
|
+
"internal-watch-events",
|
|
810
|
+
"--repo",
|
|
811
|
+
repoPath,
|
|
812
|
+
"--port",
|
|
813
|
+
String(port),
|
|
814
|
+
"--token",
|
|
815
|
+
token,
|
|
816
|
+
],
|
|
817
|
+
{
|
|
818
|
+
detached: true,
|
|
819
|
+
stdio: "ignore",
|
|
820
|
+
},
|
|
821
|
+
);
|
|
822
|
+
|
|
823
|
+
child.unref();
|
|
824
|
+
writeFileSync(getCmuxWatchEventsPidPath(repoPath), `${child.pid ?? ""}\n`);
|
|
825
|
+
return child;
|
|
826
|
+
};
|
|
827
|
+
|
|
597
828
|
const REPO_POINTER = "/tmp/diffhub-active-repo";
|
|
598
829
|
|
|
599
830
|
const readRepoPointer = () => {
|
|
@@ -734,8 +965,10 @@ const startServer = (repoPath, baseBranch, port, options = {}) => {
|
|
|
734
965
|
cmux = false,
|
|
735
966
|
detached = false,
|
|
736
967
|
disableWatch,
|
|
968
|
+
externalWatcher = false,
|
|
737
969
|
logPath,
|
|
738
970
|
serverBootId = createServerBootId(repoPath, baseBranch),
|
|
971
|
+
watchToken,
|
|
739
972
|
} = options;
|
|
740
973
|
const shouldDisableWatch = disableWatch ?? Boolean(logPath);
|
|
741
974
|
let stdio = ["ignore", "inherit", "inherit"];
|
|
@@ -759,7 +992,9 @@ const startServer = (repoPath, baseBranch, port, options = {}) => {
|
|
|
759
992
|
...process.env,
|
|
760
993
|
...(baseBranch ? { DIFFHUB_BASE: baseBranch } : {}),
|
|
761
994
|
...(cmux ? { DIFFHUB_CMUX: "1" } : {}),
|
|
995
|
+
...(externalWatcher ? { DIFFHUB_EXTERNAL_WATCHER: "1" } : {}),
|
|
762
996
|
...(shouldDisablePrerender ? { DIFFHUB_DISABLE_PRERENDER: "1" } : {}),
|
|
997
|
+
...(watchToken ? { DIFFHUB_WATCH_TOKEN: watchToken } : {}),
|
|
763
998
|
DIFFHUB_REPO: repoPath,
|
|
764
999
|
DIFFHUB_SERVER_BOOT_ID: serverBootId,
|
|
765
1000
|
HOSTNAME: "127.0.0.1",
|
|
@@ -862,6 +1097,25 @@ const internalSnapshotWriterAction = async (opts) => {
|
|
|
862
1097
|
process.on("SIGTERM", cleanup);
|
|
863
1098
|
};
|
|
864
1099
|
|
|
1100
|
+
const internalWatchEventsAction = (opts) => {
|
|
1101
|
+
const repoPath = validateRepo(resolve(opts.repo));
|
|
1102
|
+
const port = Number.parseInt(opts.port, 10);
|
|
1103
|
+
if (!Number.isInteger(port) || port <= 0) {
|
|
1104
|
+
console.error("❌ Invalid port:", opts.port);
|
|
1105
|
+
process.exit(1);
|
|
1106
|
+
}
|
|
1107
|
+
|
|
1108
|
+
const stopWatchEventForwarder = startWatchEventForwarder(repoPath, port, opts.token);
|
|
1109
|
+
|
|
1110
|
+
const cleanup = async () => {
|
|
1111
|
+
await stopWatchEventForwarder();
|
|
1112
|
+
process.exit(0);
|
|
1113
|
+
};
|
|
1114
|
+
|
|
1115
|
+
process.on("SIGINT", cleanup);
|
|
1116
|
+
process.on("SIGTERM", cleanup);
|
|
1117
|
+
};
|
|
1118
|
+
|
|
865
1119
|
// -- serve action (default) --------------------------------------------------
|
|
866
1120
|
|
|
867
1121
|
const serveAction = async (opts) => {
|
|
@@ -933,26 +1187,34 @@ const cmuxAction = async (opts) => {
|
|
|
933
1187
|
const serverLogPath = getCmuxServerLogPath(repoPath);
|
|
934
1188
|
const restoreRepoPointer = syncCmuxRepoPointer(repoPath);
|
|
935
1189
|
const serverBootId = createServerBootId(repoPath, baseBranch);
|
|
1190
|
+
const watchToken = createWatchToken();
|
|
936
1191
|
|
|
937
1192
|
await stopListeningProcesses(port);
|
|
938
1193
|
await stopSnapshotWriterProcess(repoPath);
|
|
1194
|
+
await stopWatchEventsProcess(repoPath);
|
|
939
1195
|
clearRepoSnapshotFiles(repoPath);
|
|
940
1196
|
|
|
941
1197
|
await cmuxNotify("diffhub", "Starting server...");
|
|
942
1198
|
|
|
943
|
-
//
|
|
944
|
-
//
|
|
945
|
-
//
|
|
946
|
-
// The server's built-in fs.watch + async spawn pipeline works reliably.
|
|
1199
|
+
// Keep chokidar out of the standalone Next server. A separate helper watches
|
|
1200
|
+
// files and forwards local events into the server, so git spawning and
|
|
1201
|
+
// FSEvents live in different processes.
|
|
947
1202
|
const { bootId, server } = startServer(repoPath, baseBranch, port, {
|
|
948
1203
|
cmux: true,
|
|
949
1204
|
detached: true,
|
|
950
1205
|
disableWatch: false,
|
|
1206
|
+
externalWatcher: true,
|
|
951
1207
|
logPath: serverLogPath,
|
|
952
1208
|
serverBootId,
|
|
1209
|
+
watchToken,
|
|
953
1210
|
});
|
|
1211
|
+
let watchEventsProcess = null;
|
|
954
1212
|
|
|
955
1213
|
const cleanup = () => {
|
|
1214
|
+
if (watchEventsProcess && !watchEventsProcess.killed) {
|
|
1215
|
+
watchEventsProcess.kill();
|
|
1216
|
+
}
|
|
1217
|
+
rmSync(getCmuxWatchEventsPidPath(repoPath), { force: true });
|
|
956
1218
|
server.kill();
|
|
957
1219
|
restoreRepoPointer();
|
|
958
1220
|
process.exit(0);
|
|
@@ -968,6 +1230,7 @@ const cmuxAction = async (opts) => {
|
|
|
968
1230
|
return;
|
|
969
1231
|
}
|
|
970
1232
|
|
|
1233
|
+
watchEventsProcess = startWatchEventsProcess(repoPath, port, watchToken);
|
|
971
1234
|
await cmuxNotify("diffhub", `Opening diff: ${repoPath}`);
|
|
972
1235
|
|
|
973
1236
|
const surfaceRef = await cmuxOpenSplit(url);
|
|
@@ -1014,4 +1277,11 @@ program
|
|
|
1014
1277
|
.requiredOption("--boot-id <id>", "Boot identifier for snapshot generation")
|
|
1015
1278
|
.action(internalSnapshotWriterAction);
|
|
1016
1279
|
|
|
1280
|
+
program
|
|
1281
|
+
.command("internal-watch-events")
|
|
1282
|
+
.option("-r, --repo <path>", "Git repository path")
|
|
1283
|
+
.requiredOption("--port <port>", "DiffHub server port")
|
|
1284
|
+
.requiredOption("--token <token>", "Watch event authentication token")
|
|
1285
|
+
.action(internalWatchEventsAction);
|
|
1286
|
+
|
|
1017
1287
|
program.parse(process.argv);
|
package/package.json
CHANGED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
@font-face{font-family:glide;src:url(../media/glide_variable-s.p.0fx44xqf9f43h.woff2)format("woff2");font-display:swap;font-weight:400 900;font-style:normal}@font-face{font-family:glide;src:url(../media/glide_variable_italic-s.p.093qg0eh0wzav.woff2)format("woff2");font-display:swap;font-weight:400 900;font-style:italic}@font-face{font-family:glide Fallback;src:local(Arial);ascent-override:83.47%;descent-override:14.85%;line-gap-override:19.66%;size-adjust:101.72%}.glide_d2f847e3-module__jCZlzq__className{font-family:glide,glide Fallback}.glide_d2f847e3-module__jCZlzq__variable{--font-glide:"glide", "glide Fallback"}
|
|
2
|
-
@font-face{font-family:operatorMono;src:url(../media/operator_mono_book-s.p.0ao75o~.if_c5.woff2)format("woff2");font-display:swap;font-weight:400;font-style:normal}@font-face{font-family:operatorMono;src:url(../media/operator_mono_book_italic-s.p.17ittyvlvy8jk.woff2)format("woff2");font-display:swap;font-weight:400;font-style:italic}@font-face{font-family:operatorMono;src:url(../media/operator_mono_medium-s.p.0lzlpc.qkabu3.woff2)format("woff2");font-display:swap;font-weight:500;font-style:normal}@font-face{font-family:operatorMono;src:url(../media/operator_mono_medium_italic-s.p.0~p9vm-1dhank.woff2)format("woff2");font-display:swap;font-weight:500;font-style:italic}@font-face{font-family:operatorMono Fallback;src:local(Arial);ascent-override:79.65%;descent-override:19.91%;line-gap-override:0.0%;size-adjust:120.53%}.operatormono_ed74845e-module__g9tX8G__className{font-family:operatorMono,operatorMono Fallback}.operatormono_ed74845e-module__g9tX8G__variable{--font-operator-mono:"operatorMono", "operatorMono Fallback"}
|
|
3
|
-
@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-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-duration:initial;--tw-ease:initial;--tw-content:"";--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-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{--font-mono:var(--font-operator-mono), ui-monospace, monospace;--color-red-50:#fef2f2;--color-red-100:#ffe2e2;--color-red-200:#ffcaca;--color-red-300:#ffa3a3;--color-red-400:#ff6568;--color-red-500:#fb2c36;--color-red-600:#e40014;--color-red-700:#bf000f;--color-red-800:#9f0712;--color-red-950:#460809;--color-amber-400:#fcbb00;--color-amber-500:#f99c00;--color-amber-600:#dd7400;--color-yellow-50:#fefce8;--color-yellow-100:#fef9c2;--color-yellow-200:#fff085;--color-yellow-300:#ffe02a;--color-yellow-400:#fac800;--color-yellow-500:#edb200;--color-yellow-600:#cd8900;--color-yellow-700:#a36100;--color-yellow-800:#874b00;--color-yellow-950:#432004;--color-green-50:#f0fdf4;--color-green-100:#dcfce7;--color-green-200:#b9f8cf;--color-green-300:#7bf1a8;--color-green-400:#05df72;--color-green-500:#00c758;--color-green-600:#00a544;--color-green-700:#008138;--color-green-800:#016630;--color-green-950:#032e15;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--container-md:28rem;--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:calc(1.5 / 1);--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;--tracking-tight:-.025em;--leading-tight:1.25;--leading-snug:1.375;--leading-relaxed:1.625;--radius-md:calc(var(--radius) * .8);--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--blur-xs:4px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-glide), ui-sans-serif, system-ui, sans-serif;--default-mono-font-family:var(--font-operator-mono), ui-monospace, monospace}@supports (color:lab(0% 0 0)){:root,:host{--color-red-50:lab(96.5005% 4.18508 1.52328);--color-red-100:lab(92.243% 10.2865 3.83865);--color-red-200:lab(86.017% 19.8815 7.75869);--color-red-300:lab(76.5514% 36.422 15.5335);--color-red-400:lab(63.7053% 60.745 31.3109);--color-red-500:lab(55.4814% 75.0732 48.8528);--color-red-600:lab(48.4493% 77.4328 61.5452);--color-red-700:lab(40.4273% 67.2623 53.7441);--color-red-800:lab(33.7174% 55.8993 41.0293);--color-red-950:lab(13.003% 29.04 16.7519);--color-amber-400:lab(80.1641% 16.6016 99.2089);--color-amber-500:lab(72.7183% 31.8672 97.9407);--color-amber-600:lab(60.3514% 40.5624 87.1228);--color-yellow-50:lab(98.6846% -1.79055 9.7766);--color-yellow-100:lab(97.3564% -4.51407 27.344);--color-yellow-200:lab(94.3433% -5.00429 52.9663);--color-yellow-300:lab(89.7033% -.480294 84.4917);--color-yellow-400:lab(83.2664% 8.65132 106.895);--color-yellow-500:lab(76.3898% 14.5258 98.4589);--color-yellow-600:lab(62.7799% 22.4197 86.1544);--color-yellow-700:lab(47.8202% 25.2426 66.5015);--color-yellow-800:lab(38.7484% 23.5833 51.4916);--color-yellow-950:lab(16.8146% 15.7422 23.1133);--color-green-50:lab(98.1563% -5.60117 2.75915);--color-green-100:lab(96.1861% -13.8464 6.52365);--color-green-200:lab(92.4222% -26.4702 12.9427);--color-green-300:lab(86.9953% -47.2691 25.0054);--color-green-400:lab(78.503% -64.9265 39.7492);--color-green-500:lab(70.5521% -66.5147 45.8073);--color-green-600:lab(59.0978% -58.6621 41.2579);--color-green-700:lab(47.0329% -47.0239 31.4788);--color-green-800:lab(37.4616% -36.7971 22.9692);--color-green-950:lab(15.6845% -20.4225 11.7249)}}}@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;-webkit-text-decoration:inherit;-webkit-text-decoration: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}*{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);font-family:var(--font-glide), ui-sans-serif, system-ui, sans-serif;color:var(--foreground)}kbd{border:1px solid var(--border);background:var(--muted);min-width:16px;font-size:10px;font-family:var(--font-mono);color:var(--muted-foreground);border-radius:4px;justify-content:center;align-items:center;padding:1px 4px;line-height:1.4;display:inline-flex}.diffhub-gutter-btn{background:var(--primary);width:20px;height:20px;color:var(--primary-foreground);cursor:pointer;border:none;border-radius:3px;justify-content:center;align-items:center;font-size:14px;font-weight:700;line-height:1;animation:80ms ease-out both diffhub-gutter-in;display:flex}.diffhub-gutter-btn:hover{background:var(--primary)}@supports (color:color-mix(in lab, red, red)){.diffhub-gutter-btn:hover{background:color-mix(in srgb, var(--primary) 85%, black)}}@keyframes diffhub-gutter-in{0%{opacity:0}to{opacity:1}}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-3{top:calc(var(--spacing) * 3)}.top-\[52px\]{top:52px}.top-full{top:100%}.right-0{right:calc(var(--spacing) * 0)}.right-2{right:calc(var(--spacing) * 2)}.right-3{right:calc(var(--spacing) * 3)}.left-0{left:calc(var(--spacing) * 0)}.left-2\.5{left:calc(var(--spacing) * 2.5)}.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-4{margin-inline:calc(var(--spacing) * 4)}.my-1{margin-block:calc(var(--spacing) * 1)}.my-4{margin-block:calc(var(--spacing) * 4)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.-ml-1{margin-left:calc(var(--spacing) * -1)}.block{display:block}.flex{display:flex}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.size-2\.5{width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.size-11{width:calc(var(--spacing) * 11);height:calc(var(--spacing) * 11)}.h-2{height:calc(var(--spacing) * 2)}.h-5{height:calc(var(--spacing) * 5)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-\[22px\]{height:22px}.h-\[52px\]{height:52px}.h-\[var\(--field-height\)\]{height:var(--field-height)}.h-\[var\(--field-height-sm\)\]{height:var(--field-height-sm)}.h-full{height:100%}.h-svh{height:100svh}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-svh{min-height:100svh}.w-\(--sidebar-width\){width:var(--sidebar-width)}.w-6{width:calc(var(--spacing) * 6)}.w-\[5px\]{width:5px}.w-fit{width:fit-content}.w-full{width:100%}.max-w-md{max-width:var(--container-md)}.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-\[200px\]{min-width:200px}.flex-1{flex:1}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.origin-\(--transform-origin\){transform-origin:var(--transform-origin)}.translate-y-\[calc\(-50\%-2px\)\]{--tw-translate-y:calc(-50% - 2px);translate:var(--tw-translate-x) var(--tw-translate-y)}.-rotate-90{rotate:-90deg}.rotate-45{rotate:45deg}.rotate-180{rotate:180deg}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-col-resize{cursor:col-resize}.cursor-pointer{cursor:pointer}.resize{resize:both}.resize-none{resize:none}.scroll-mt-\[52px\]{scroll-margin-top:52px}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-baseline{align-items:baseline}.items-center{align-items:center}.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{gap:calc(var(--spacing) * 0)}.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)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-\[2px\]{border-radius:2px}.rounded-\[min\(var\(--radius-md\)\,10px\)\]{border-radius:min(var(--radius-md), 10px)}.rounded-\[min\(var\(--radius-md\)\,12px\)\]{border-radius:min(var(--radius-md), 12px)}.rounded-\[var\(--field-radius\)\]{border-radius:var(--field-radius)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) * .8)}.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-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-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-amber-500\/30{border-color:#f99c004d}@supports (color:color-mix(in lab, red, red)){.border-amber-500\/30{border-color:color-mix(in oklab, var(--color-amber-500) 30%, transparent)}}.border-border,.border-border\/40{border-color:var(--border)}@supports (color:color-mix(in lab, red, red)){.border-border\/40{border-color:color-mix(in oklab, var(--border) 40%, transparent)}}.border-destructive\/30{border-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.border-destructive\/30{border-color:color-mix(in oklab, var(--destructive) 30%, transparent)}}.border-green-200{border-color:var(--color-green-200)}.border-input{border-color:var(--input)}.border-red-200{border-color:var(--color-red-200)}.border-sidebar-border,.border-sidebar-border\/60{border-color:var(--sidebar-border)}@supports (color:color-mix(in lab, red, red)){.border-sidebar-border\/60{border-color:color-mix(in oklab, var(--sidebar-border) 60%, transparent)}}.border-transparent{border-color:#0000}.border-yellow-200{border-color:var(--color-yellow-200)}.border-l-destructive{border-left-color:var(--destructive)}.border-l-diff-green{border-left-color:var(--diff-green)}.border-l-diff-purple{border-left-color:var(--diff-purple)}.border-l-muted-foreground\/40{border-left-color:var(--muted-foreground)}@supports (color:color-mix(in lab, red, red)){.border-l-muted-foreground\/40{border-left-color:color-mix(in oklab, var(--muted-foreground) 40%, transparent)}}.border-l-ring\/40{border-left-color:var(--ring)}@supports (color:color-mix(in lab, red, red)){.border-l-ring\/40{border-left-color:color-mix(in oklab, var(--ring) 40%, transparent)}}.bg-amber-500\/10{background-color:#f99c001a}@supports (color:color-mix(in lab, red, red)){.bg-amber-500\/10{background-color:color-mix(in oklab, var(--color-amber-500) 10%, transparent)}}.bg-background{background-color:var(--background)}.bg-black\/10{background-color:#0000001a}@supports (color:color-mix(in lab, red, red)){.bg-black\/10{background-color:color-mix(in oklab, var(--color-black) 10%, transparent)}}.bg-card{background-color:var(--card)}.bg-destructive\/5{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.bg-destructive\/5{background-color:color-mix(in oklab, var(--destructive) 5%, transparent)}}.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-destructive\/15{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.bg-destructive\/15{background-color:color-mix(in oklab, var(--destructive) 15%, transparent)}}.bg-destructive\/20{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.bg-destructive\/20{background-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.bg-diff-green\/5{background-color:var(--diff-green)}@supports (color:color-mix(in lab, red, red)){.bg-diff-green\/5{background-color:color-mix(in oklab, var(--diff-green) 5%, transparent)}}.bg-diff-green\/15{background-color:var(--diff-green)}@supports (color:color-mix(in lab, red, red)){.bg-diff-green\/15{background-color:color-mix(in oklab, var(--diff-green) 15%, transparent)}}.bg-diff-green\/20{background-color:var(--diff-green)}@supports (color:color-mix(in lab, red, red)){.bg-diff-green\/20{background-color:color-mix(in oklab, var(--diff-green) 20%, transparent)}}.bg-diff-purple\/10{background-color:var(--diff-purple)}@supports (color:color-mix(in lab, red, red)){.bg-diff-purple\/10{background-color:color-mix(in oklab, var(--diff-purple) 10%, transparent)}}.bg-foreground{background-color:var(--foreground)}.bg-green-600{background-color:var(--color-green-600)}.bg-muted,.bg-muted\/20{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.bg-muted\/20{background-color:color-mix(in oklab, var(--muted) 20%, transparent)}}.bg-muted\/40{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.bg-muted\/40{background-color:color-mix(in oklab, var(--muted) 40%, transparent)}}.bg-popover{background-color:var(--popover)}.bg-primary{background-color:var(--primary)}.bg-red-600{background-color:var(--color-red-600)}.bg-secondary{background-color:var(--secondary)}.bg-sidebar{background-color:var(--sidebar)}.bg-sidebar-accent{background-color:var(--sidebar-accent)}.bg-transparent{background-color:#0000}.bg-yellow-600{background-color:var(--color-yellow-600)}.bg-clip-padding{background-clip:padding-box}.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-6{padding:calc(var(--spacing) * 6)}.px-0{padding-inline:calc(var(--spacing) * 0)}.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-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-\[var\(--field-padding-x\)\]{padding-inline:var(--field-padding-x)}.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-2\.5{padding-block:calc(var(--spacing) * 2.5)}.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-\[var\(--field-padding-y\)\]{padding-block:var(--field-padding-y)}.pr-7{padding-right:calc(var(--spacing) * 7)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pl-7{padding-left:calc(var(--spacing) * 7)}.text-center{text-align:center}.text-left{text-align:left}.font-heading{font-family:var(--font-glide), ui-sans-serif, system-ui, sans-serif}.font-mono{font-family:var(--font-operator-mono), ui-monospace, monospace}.font-sans{font-family:var(--font-glide), ui-sans-serif, system-ui, sans-serif}.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-sm\/relaxed{font-size:var(--text-sm);line-height:var(--leading-relaxed)}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.8rem\]{font-size:.8rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.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-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-balance{text-wrap:balance}.whitespace-nowrap{white-space:nowrap}.text-amber-600{color:var(--color-amber-600)}.text-background{color:var(--background)}.text-destructive{color:var(--destructive)}.text-diff-green{color:var(--diff-green)}.text-diff-purple{color:var(--diff-purple)}.text-foreground{color:var(--foreground)}.text-green-700{color:var(--color-green-700)}.text-muted-foreground,.text-muted-foreground\/50{color:var(--muted-foreground)}@supports (color:color-mix(in lab, red, red)){.text-muted-foreground\/50{color:color-mix(in oklab, var(--muted-foreground) 50%, transparent)}}.text-muted-foreground\/60{color:var(--muted-foreground)}@supports (color:color-mix(in lab, red, red)){.text-muted-foreground\/60{color:color-mix(in oklab, var(--muted-foreground) 60%, transparent)}}.text-muted-foreground\/70{color:var(--muted-foreground)}@supports (color:color-mix(in lab, red, red)){.text-muted-foreground\/70{color:color-mix(in oklab, var(--muted-foreground) 70%, transparent)}}.text-popover-foreground{color:var(--popover-foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-red-700{color:var(--color-red-700)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-sidebar-accent-foreground{color:var(--sidebar-accent-foreground)}.text-sidebar-foreground,.text-sidebar-foreground\/30{color:var(--sidebar-foreground)}@supports (color:color-mix(in lab, red, red)){.text-sidebar-foreground\/30{color:color-mix(in oklab, var(--sidebar-foreground) 30%, transparent)}}.text-sidebar-foreground\/40{color:var(--sidebar-foreground)}@supports (color:color-mix(in lab, red, red)){.text-sidebar-foreground\/40{color:color-mix(in oklab, var(--sidebar-foreground) 40%, transparent)}}.text-sidebar-foreground\/50{color:var(--sidebar-foreground)}@supports (color:color-mix(in lab, red, red)){.text-sidebar-foreground\/50{color:color-mix(in oklab, var(--sidebar-foreground) 50%, transparent)}}.text-sidebar-foreground\/60{color:var(--sidebar-foreground)}@supports (color:color-mix(in lab, red, red)){.text-sidebar-foreground\/60{color:color-mix(in oklab, var(--sidebar-foreground) 60%, transparent)}}.text-white{color:var(--color-white)}.text-yellow-700{color:var(--color-yellow-700)}.italic{font-style:italic}.underline-offset-4{text-underline-offset:4px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-0{opacity:0}.opacity-80{opacity:.8}.opacity-100{opacity:1}.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-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-input{--tw-shadow-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.shadow-input{--tw-shadow-color:color-mix(in oklab, var(--input) var(--tw-shadow-alpha), transparent)}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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,)}.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-\[color\,background-color\,border-color\,box-shadow\,opacity\,transform\]{transition-property:color,background-color,border-color,box-shadow,opacity,transform;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[left\,right\,width\]{transition-property:left,right,width;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[width\]{transition-property:width;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))}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-linear{--tw-ease:linear;transition-timing-function:linear}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.running{animation-play-state:running}@media (hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.group-data-\[collapsible\=icon\]\:w-\(--sidebar-width-icon\):is(:where(.group)[data-collapsible=icon] *){width:var(--sidebar-width-icon)}.group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)\+\(--spacing\(4\)\)\)\]:is(:where(.group)[data-collapsible=icon] *){width:calc(var(--sidebar-width-icon) + (calc(var(--spacing) * 4)))}.group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)\+\(--spacing\(4\)\)\+2px\)\]:is(:where(.group)[data-collapsible=icon] *){width:calc(var(--sidebar-width-icon) + (calc(var(--spacing) * 4)) + 2px)}.group-data-\[collapsible\=icon\]\:overflow-hidden:is(:where(.group)[data-collapsible=icon] *){overflow:hidden}.group-data-\[collapsible\=offcanvas\]\:right-\[calc\(var\(--sidebar-width\)\*-1\)\]:is(:where(.group)[data-collapsible=offcanvas] *){right:calc(var(--sidebar-width) * -1)}.group-data-\[collapsible\=offcanvas\]\:left-\[calc\(var\(--sidebar-width\)\*-1\)\]:is(:where(.group)[data-collapsible=offcanvas] *){left:calc(var(--sidebar-width) * -1)}.group-data-\[collapsible\=offcanvas\]\:w-0:is(:where(.group)[data-collapsible=offcanvas] *){width:calc(var(--spacing) * 0)}.group-data-\[side\=left\]\:border-r:is(:where(.group)[data-side=left] *){border-right-style:var(--tw-border-style);border-right-width:1px}.group-data-\[side\=right\]\:rotate-180:is(:where(.group)[data-side=right] *){rotate:180deg}.group-data-\[side\=right\]\:border-l:is(:where(.group)[data-side=right] *){border-left-style:var(--tw-border-style);border-left-width:1px}.group-data-\[variant\=floating\]\:rounded-lg:is(:where(.group)[data-variant=floating] *){border-radius:var(--radius)}.group-data-\[variant\=floating\]\:border:is(:where(.group)[data-variant=floating] *){border-style:var(--tw-border-style);border-width:1px}.group-data-\[variant\=floating\]\:border-sidebar-border:is(:where(.group)[data-variant=floating] *){border-color:var(--sidebar-border)}.group-data-\[variant\=floating\]\:shadow-sm:is(:where(.group)[data-variant=floating] *){--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)}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}.placeholder\:text-sidebar-foreground\/40::placeholder{color:var(--sidebar-foreground)}@supports (color:color-mix(in lab, red, red)){.placeholder\:text-sidebar-foreground\/40::placeholder{color:color-mix(in oklab, var(--sidebar-foreground) 40%, transparent)}}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:inset-y-0:after{content:var(--tw-content);inset-block:calc(var(--spacing) * 0)}.after\:left-1\/2:after{content:var(--tw-content);left:50%}.after\:w-px:after{content:var(--tw-content);width:1px}.after\:-translate-x-1\/2:after{content:var(--tw-content);--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.after\:transition-colors:after{content:var(--tw-content);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))}@media (hover:hover){.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-green-50:hover{background-color:var(--color-green-50)}.hover\:bg-green-700:hover{background-color:var(--color-green-700)}.hover\:bg-muted:hover{background-color:var(--muted)}.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-red-50:hover{background-color:var(--color-red-50)}.hover\:bg-red-700:hover{background-color:var(--color-red-700)}.hover\:bg-secondary:hover,.hover\:bg-secondary\/50:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-secondary\/50:hover{background-color:color-mix(in oklab, var(--secondary) 50%, transparent)}}.hover\:bg-secondary\/85:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-secondary\/85:hover{background-color:color-mix(in oklab, var(--secondary) 85%, transparent)}}.hover\:bg-sidebar-accent:hover{background-color:var(--sidebar-accent)}.hover\:bg-transparent:hover{background-color:#0000}.hover\:bg-yellow-50:hover{background-color:var(--color-yellow-50)}.hover\:bg-yellow-700:hover{background-color:var(--color-yellow-700)}.hover\:text-destructive:hover{color:var(--destructive)}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:text-sidebar-accent-foreground:hover{color:var(--sidebar-accent-foreground)}.hover\:text-sidebar-foreground:hover{color:var(--sidebar-foreground)}.hover\:underline:hover{text-decoration-line:underline}.hover\:after\:bg-sidebar-border:hover:after{content:var(--tw-content);background-color:var(--sidebar-border)}}.focus\:border-sidebar-ring\/50:focus{border-color:var(--sidebar-ring)}@supports (color:color-mix(in lab, red, red)){.focus\:border-sidebar-ring\/50:focus{border-color:color-mix(in oklab, var(--sidebar-ring) 50%, transparent)}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:border-green-600:focus-visible{border-color:var(--color-green-600)}.focus-visible\:border-red-600:focus-visible{border-color:var(--color-red-600)}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:border-yellow-600:focus-visible{border-color:var(--color-yellow-600)}.focus-visible\:ring-1:focus-visible{--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)}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + 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-green-500\/30:focus-visible{--tw-ring-color:#00c7584d}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-green-500\/30:focus-visible{--tw-ring-color:color-mix(in oklab, var(--color-green-500) 30%, transparent)}}.focus-visible\:ring-red-500\/30:focus-visible{--tw-ring-color:#fb2c364d}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-red-500\/30:focus-visible{--tw-ring-color:color-mix(in oklab, var(--color-red-500) 30%, transparent)}}.focus-visible\:ring-ring\/15:focus-visible{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-ring\/15:focus-visible{--tw-ring-color:color-mix(in oklab, var(--ring) 15%, 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\:ring-sidebar-ring:focus-visible{--tw-ring-color:var(--sidebar-ring)}.focus-visible\:ring-yellow-500\/30:focus-visible{--tw-ring-color:#edb2004d}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-yellow-500\/30:focus-visible{--tw-ring-color:color-mix(in oklab, var(--color-yellow-500) 30%, transparent)}}.focus-visible\:ring-offset-1:focus-visible{--tw-ring-offset-width:1px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color:var(--background)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.active\:bg-green-100:active{background-color:var(--color-green-100)}.active\:bg-green-800:active{background-color:var(--color-green-800)}.active\:bg-muted\/80:active{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.active\:bg-muted\/80:active{background-color:color-mix(in oklab, var(--muted) 80%, transparent)}}.active\:bg-primary\/95:active{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.active\:bg-primary\/95:active{background-color:color-mix(in oklab, var(--primary) 95%, transparent)}}.active\:bg-red-100:active{background-color:var(--color-red-100)}.active\:bg-red-800:active{background-color:var(--color-red-800)}.active\:bg-secondary\/75:active{background-color:var(--secondary)}@supports (color:color-mix(in lab, red, red)){.active\:bg-secondary\/75:active{background-color:color-mix(in oklab, var(--secondary) 75%, transparent)}}.active\:bg-transparent:active{background-color:#0000}.active\:bg-yellow-100:active{background-color:var(--color-yellow-100)}.active\:bg-yellow-800:active{background-color:var(--color-yellow-800)}.active\:opacity-80:active{opacity:.8}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-45:disabled{opacity:.45}:where([data-slot=button-group]) .in-data-\[slot\=button-group\]\:rounded-lg{border-radius:var(--radius)}.has-data-\[icon\=inline-end\]\:pr-2:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 2)}.has-data-\[icon\=inline-end\]\:pr-2\.5:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 2.5)}.has-data-\[icon\=inline-end\]\:pr-3\.5:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 3.5)}.has-data-\[icon\=inline-start\]\:pl-2:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 2)}.has-data-\[icon\=inline-start\]\:pl-2\.5:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 2.5)}.has-data-\[icon\=inline-start\]\:pl-3\.5:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 3.5)}.has-data-\[slot\=kbd\]\:pr-1\.5:has([data-slot=kbd]){padding-right:calc(var(--spacing) * 1.5)}.has-data-\[variant\=inset\]\:bg-sidebar:has([data-variant=inset]){background-color:var(--sidebar)}.aria-disabled\:pointer-events-none[aria-disabled=true]{pointer-events:none}.aria-disabled\:cursor-not-allowed[aria-disabled=true]{cursor:not-allowed}.aria-disabled\:opacity-45[aria-disabled=true]{opacity:.45}.aria-expanded\:bg-muted[aria-expanded=true]{background-color:var(--muted)}.aria-expanded\:bg-secondary[aria-expanded=true]{background-color:var(--secondary)}.aria-expanded\:bg-transparent[aria-expanded=true]{background-color:#0000}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-2[aria-invalid=true]{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + 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)}.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)}}.aria-pressed\:bg-green-100[aria-pressed=true]{background-color:var(--color-green-100)}.aria-pressed\:bg-green-800[aria-pressed=true]{background-color:var(--color-green-800)}.aria-pressed\:bg-muted\/80[aria-pressed=true]{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.aria-pressed\:bg-muted\/80[aria-pressed=true]{background-color:color-mix(in oklab, var(--muted) 80%, transparent)}}.aria-pressed\:bg-primary\/95[aria-pressed=true]{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.aria-pressed\:bg-primary\/95[aria-pressed=true]{background-color:color-mix(in oklab, var(--primary) 95%, transparent)}}.aria-pressed\:bg-red-100[aria-pressed=true]{background-color:var(--color-red-100)}.aria-pressed\:bg-red-800[aria-pressed=true]{background-color:var(--color-red-800)}.aria-pressed\:bg-secondary\/75[aria-pressed=true]{background-color:var(--secondary)}@supports (color:color-mix(in lab, red, red)){.aria-pressed\:bg-secondary\/75[aria-pressed=true]{background-color:color-mix(in oklab, var(--secondary) 75%, transparent)}}.aria-pressed\:bg-yellow-100[aria-pressed=true]{background-color:var(--color-yellow-100)}.aria-pressed\:bg-yellow-800[aria-pressed=true]{background-color:var(--color-yellow-800)}.aria-pressed\:underline[aria-pressed=true]{text-decoration-line:underline}.aria-pressed\:opacity-80[aria-pressed=true]{opacity:.8}.data-ending-style\:opacity-0[data-ending-style],.data-starting-style\:opacity-0[data-starting-style]{opacity:0}.data-\[side\=bottom\]\:inset-x-0[data-side=bottom]{inset-inline:calc(var(--spacing) * 0)}.data-\[side\=bottom\]\:top-1[data-side=bottom]{top:calc(var(--spacing) * 1)}.data-\[side\=bottom\]\:bottom-0[data-side=bottom]{bottom:calc(var(--spacing) * 0)}.data-\[side\=bottom\]\:h-auto[data-side=bottom]{height:auto}.data-\[side\=bottom\]\:border-t[data-side=bottom]{border-top-style:var(--tw-border-style);border-top-width:1px}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:calc(2*var(--spacing)*-1)}.data-\[side\=bottom\]\:data-ending-style\:translate-y-\[2\.5rem\][data-side=bottom][data-ending-style],.data-\[side\=bottom\]\:data-starting-style\:translate-y-\[2\.5rem\][data-side=bottom][data-starting-style]{--tw-translate-y:2.5rem;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=inline-end\]\:top-1\/2\![data-side=inline-end]{top:50%!important}.data-\[side\=inline-end\]\:-left-1[data-side=inline-end]{left:calc(var(--spacing) * -1)}.data-\[side\=inline-end\]\:-translate-y-1\/2[data-side=inline-end]{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=inline-end\]\:slide-in-from-left-2[data-side=inline-end]{--tw-enter-translate-x:calc(2*var(--spacing)*-1)}.data-\[side\=inline-start\]\:top-1\/2\![data-side=inline-start]{top:50%!important}.data-\[side\=inline-start\]\:-right-1[data-side=inline-start]{right:calc(var(--spacing) * -1)}.data-\[side\=inline-start\]\:-translate-y-1\/2[data-side=inline-start]{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=inline-start\]\:slide-in-from-right-2[data-side=inline-start]{--tw-enter-translate-x:calc(2*var(--spacing))}.data-\[side\=left\]\:inset-y-0[data-side=left]{inset-block:calc(var(--spacing) * 0)}.data-\[side\=left\]\:top-1\/2\![data-side=left]{top:50%!important}.data-\[side\=left\]\:-right-1[data-side=left]{right:calc(var(--spacing) * -1)}.data-\[side\=left\]\:left-0[data-side=left]{left:calc(var(--spacing) * 0)}.data-\[side\=left\]\:h-full[data-side=left]{height:100%}.data-\[side\=left\]\:w-3\/4[data-side=left]{width:75%}.data-\[side\=left\]\:-translate-y-1\/2[data-side=left]{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=left\]\:border-r[data-side=left]{border-right-style:var(--tw-border-style);border-right-width:1px}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:calc(2*var(--spacing))}.data-\[side\=left\]\:data-ending-style\:translate-x-\[-2\.5rem\][data-side=left][data-ending-style],.data-\[side\=left\]\:data-starting-style\:translate-x-\[-2\.5rem\][data-side=left][data-starting-style]{--tw-translate-x:-2.5rem;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:inset-y-0[data-side=right]{inset-block:calc(var(--spacing) * 0)}.data-\[side\=right\]\:top-1\/2\![data-side=right]{top:50%!important}.data-\[side\=right\]\:right-0[data-side=right]{right:calc(var(--spacing) * 0)}.data-\[side\=right\]\:-left-1[data-side=right]{left:calc(var(--spacing) * -1)}.data-\[side\=right\]\:h-full[data-side=right]{height:100%}.data-\[side\=right\]\:w-3\/4[data-side=right]{width:75%}.data-\[side\=right\]\:-translate-y-1\/2[data-side=right]{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:border-l[data-side=right]{border-left-style:var(--tw-border-style);border-left-width:1px}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:calc(2*var(--spacing)*-1)}.data-\[side\=right\]\:data-ending-style\:translate-x-\[2\.5rem\][data-side=right][data-ending-style],.data-\[side\=right\]\:data-starting-style\:translate-x-\[2\.5rem\][data-side=right][data-starting-style]{--tw-translate-x:2.5rem;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:inset-x-0[data-side=top]{inset-inline:calc(var(--spacing) * 0)}.data-\[side\=top\]\:top-0[data-side=top]{top:calc(var(--spacing) * 0)}.data-\[side\=top\]\:-bottom-2\.5[data-side=top]{bottom:calc(var(--spacing) * -2.5)}.data-\[side\=top\]\:h-auto[data-side=top]{height:auto}.data-\[side\=top\]\:border-b[data-side=top]{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:calc(2*var(--spacing))}.data-\[side\=top\]\:data-ending-style\:translate-y-\[-2\.5rem\][data-side=top][data-ending-style],.data-\[side\=top\]\:data-starting-style\:translate-y-\[-2\.5rem\][data-side=top][data-starting-style]{--tw-translate-y:-2.5rem;translate:var(--tw-translate-x) var(--tw-translate-y)}:is(.\*\*\:data-\[slot\=kbd\]\:relative *)[data-slot=kbd]{position:relative}:is(.\*\*\:data-\[slot\=kbd\]\:isolate *)[data-slot=kbd]{isolation:isolate}:is(.\*\*\:data-\[slot\=kbd\]\:z-50 *)[data-slot=kbd]{z-index:50}:is(.\*\*\:data-\[slot\=kbd\]\:rounded-sm *)[data-slot=kbd]{border-radius:calc(var(--radius) * .6)}.data-\[state\=delayed-open\]\:animate-in[data-state=delayed-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\=delayed-open\]\:fade-in-0[data-state=delayed-open]{--tw-enter-opacity:0}.data-\[state\=delayed-open\]\:zoom-in-95[data-state=delayed-open]{--tw-enter-scale:.95}@supports ((-webkit-backdrop-filter:var(--tw)) or (backdrop-filter:var(--tw))){.supports-backdrop-filter\:backdrop-blur-xs{--tw-backdrop-blur:blur(var(--blur-xs));-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,)}}@media (min-width:40rem){.data-\[side\=left\]\:sm\:max-w-sm[data-side=left],.data-\[side\=right\]\:sm\:max-w-sm[data-side=right]{max-width:var(--container-sm)}}@media (min-width:48rem){.md\:block{display:block}.md\:flex{display:flex}.md\:p-12{padding:calc(var(--spacing) * 12)}.md\:peer-data-\[variant\=inset\]\:m-2:is(:where(.peer)[data-variant=inset]~*){margin:calc(var(--spacing) * 2)}.md\:peer-data-\[variant\=inset\]\:ml-0:is(:where(.peer)[data-variant=inset]~*){margin-left:calc(var(--spacing) * 0)}.md\:peer-data-\[variant\=inset\]\:rounded-xl:is(:where(.peer)[data-variant=inset]~*){border-radius:calc(var(--radius) * 1.4)}.md\:peer-data-\[variant\=inset\]\:shadow-sm:is(:where(.peer)[data-variant=inset]~*){--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)}.md\:peer-data-\[variant\=inset\]\:peer-data-\[state\=collapsed\]\:ml-2:is(:where(.peer)[data-variant=inset]~*):is(:where(.peer)[data-state=collapsed]~*){margin-left:calc(var(--spacing) * 2)}}.dark\:border-green-800:is(.dark *){border-color:var(--color-green-800)}.dark\:border-input:is(.dark *){border-color:var(--input)}.dark\:border-red-800:is(.dark *){border-color:var(--color-red-800)}.dark\:border-yellow-800:is(.dark *){border-color:var(--color-yellow-800)}.dark\:bg-green-500:is(.dark *){background-color:var(--color-green-500)}.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-red-500:is(.dark *){background-color:var(--color-red-500)}.dark\:bg-yellow-500:is(.dark *){background-color:var(--color-yellow-500)}.dark\:text-amber-400:is(.dark *){color:var(--color-amber-400)}.dark\:text-green-300:is(.dark *){color:var(--color-green-300)}.dark\:text-red-300:is(.dark *){color:var(--color-red-300)}.dark\:text-yellow-300:is(.dark *){color:var(--color-yellow-300)}.dark\:text-yellow-950:is(.dark *){color:var(--color-yellow-950)}.dark\:shadow-none:is(.dark *){--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)}@media (hover:hover){.dark\:hover\:bg-green-400:is(.dark *):hover{background-color:var(--color-green-400)}.dark\:hover\:bg-green-950\/60:is(.dark *):hover{background-color:#032e1599}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-green-950\/60:is(.dark *):hover{background-color:color-mix(in oklab, var(--color-green-950) 60%, 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-muted\/50:is(.dark *):hover{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-muted\/50:is(.dark *):hover{background-color:color-mix(in oklab, var(--muted) 50%, transparent)}}.dark\:hover\:bg-red-400:is(.dark *):hover{background-color:var(--color-red-400)}.dark\:hover\:bg-red-950\/60:is(.dark *):hover{background-color:#46080999}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-red-950\/60:is(.dark *):hover{background-color:color-mix(in oklab, var(--color-red-950) 60%, transparent)}}.dark\:hover\:bg-yellow-400:is(.dark *):hover{background-color:var(--color-yellow-400)}.dark\:hover\:bg-yellow-950\/60:is(.dark *):hover{background-color:#43200499}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-yellow-950\/60:is(.dark *):hover{background-color:color-mix(in oklab, var(--color-yellow-950) 60%, transparent)}}}.dark\:active\:bg-green-300:is(.dark *):active{background-color:var(--color-green-300)}.dark\:active\:bg-green-950:is(.dark *):active{background-color:var(--color-green-950)}.dark\:active\:bg-input\/60:is(.dark *):active{background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:active\:bg-input\/60:is(.dark *):active{background-color:color-mix(in oklab, var(--input) 60%, transparent)}}.dark\:active\:bg-muted\/60:is(.dark *):active{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.dark\:active\:bg-muted\/60:is(.dark *):active{background-color:color-mix(in oklab, var(--muted) 60%, transparent)}}.dark\:active\:bg-red-300:is(.dark *):active{background-color:var(--color-red-300)}.dark\:active\:bg-red-950:is(.dark *):active{background-color:var(--color-red-950)}.dark\:active\:bg-yellow-300:is(.dark *):active{background-color:var(--color-yellow-300)}.dark\:active\:bg-yellow-950:is(.dark *):active{background-color:var(--color-yellow-950)}.dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid=true]{border-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid=true]{border-color:color-mix(in oklab, var(--destructive) 50%, 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\:aria-pressed\:bg-green-300:is(.dark *)[aria-pressed=true]{background-color:var(--color-green-300)}.dark\:aria-pressed\:bg-green-950:is(.dark *)[aria-pressed=true]{background-color:var(--color-green-950)}.dark\:aria-pressed\:bg-input\/60:is(.dark *)[aria-pressed=true]{background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:aria-pressed\:bg-input\/60:is(.dark *)[aria-pressed=true]{background-color:color-mix(in oklab, var(--input) 60%, transparent)}}.dark\:aria-pressed\:bg-muted\/60:is(.dark *)[aria-pressed=true]{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.dark\:aria-pressed\:bg-muted\/60:is(.dark *)[aria-pressed=true]{background-color:color-mix(in oklab, var(--muted) 60%, transparent)}}.dark\:aria-pressed\:bg-red-300:is(.dark *)[aria-pressed=true]{background-color:var(--color-red-300)}.dark\:aria-pressed\:bg-red-950:is(.dark *)[aria-pressed=true]{background-color:var(--color-red-950)}.dark\:aria-pressed\:bg-yellow-300:is(.dark *)[aria-pressed=true]{background-color:var(--color-yellow-300)}.dark\:aria-pressed\:bg-yellow-950:is(.dark *)[aria-pressed=true]{background-color:var(--color-yellow-950)}.data-open\:animate-in:where([data-state=open]),.data-open\:animate-in:where([data-open]:not([data-open=false])){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-open\:fade-in-0:where([data-state=open]),.data-open\:fade-in-0:where([data-open]:not([data-open=false])){--tw-enter-opacity:0}.data-open\:zoom-in-95:where([data-state=open]),.data-open\:zoom-in-95:where([data-open]:not([data-open=false])){--tw-enter-scale:.95}.data-closed\:animate-out:where([data-state=closed]),.data-closed\:animate-out:where([data-closed]:not([data-closed=false])){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-closed\:fade-out-0:where([data-state=closed]),.data-closed\:fade-out-0:where([data-closed]:not([data-closed=false])){--tw-exit-opacity:0}.data-closed\:zoom-out-95:where([data-state=closed]),.data-closed\:zoom-out-95:where([data-closed]:not([data-closed=false])){--tw-exit-scale:.95}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3\.5 svg:not([class*=size-]){width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-6 svg:not([class*=size-]){width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.\[\&\>a\]\:underline>a{text-decoration-line:underline}.\[\&\>a\]\:underline-offset-4>a{text-underline-offset:4px}.\[\&\>a\:hover\]\:text-primary>a:hover{color:var(--primary)}.\[\&\>button\]\:hidden>button{display:none}}@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{--background:#fff;--foreground:#0a0a0a;--card:#fff;--card-foreground:#0a0a0a;--popover:#fff;--popover-foreground:#0a0a0a;--primary:#171717;--primary-foreground:#fafafa;--secondary:#f5f5f5;--secondary-foreground:#171717;--muted:#f5f5f5;--muted-foreground:#737373;--accent:#f5f5f5;--accent-foreground:#171717;--destructive:#e40014;--border:#e5e5e5;--input:#e5e5e5;--ring:#a1a1a1;--chart-1:#d4d4d4;--chart-2:#737373;--chart-3:#525252;--chart-4:#404040;--chart-5:#262626;--radius:.625rem;--sidebar:#fafafa;--sidebar-foreground:#0a0a0a;--sidebar-primary:#171717;--sidebar-primary-foreground:#fafafa;--sidebar-accent:#f5f5f5;--sidebar-accent-foreground:#171717;--sidebar-border:#e5e5e5;--sidebar-ring:#a1a1a1;--diff-green:#1a7f37;--diff-purple:#c3a5f9;--diff-selected:#e8e8e8;--diff-success:#1a7f37}@supports (color:lab(0% 0 0)){:root{--background:lab(100% 0 0);--foreground:lab(2.75381% 0 0);--card:lab(100% 0 0);--card-foreground:lab(2.75381% 0 0);--popover:lab(100% 0 0);--popover-foreground:lab(2.75381% 0 0);--primary:lab(7.78201% -.0000149012 0);--primary-foreground:lab(98.26% 0 0);--secondary:lab(96.52% -.0000298023 .0000119209);--secondary-foreground:lab(7.78201% -.0000149012 0);--muted:lab(96.52% -.0000298023 .0000119209);--muted-foreground:lab(48.496% 0 0);--accent:lab(96.52% -.0000298023 .0000119209);--accent-foreground:lab(7.78201% -.0000149012 0);--destructive:lab(48.4493% 77.4328 61.5452);--border:lab(90.952% 0 -.0000119209);--input:lab(90.952% 0 -.0000119209);--ring:lab(66.128% -.0000298023 .0000119209);--chart-1:lab(84.92% 0 -.0000119209);--chart-2:lab(48.496% 0 0);--chart-3:lab(34.924% 0 0);--chart-4:lab(27.036% 0 0);--chart-5:lab(15.204% 0 -.00000596046);--sidebar:lab(98.26% 0 0);--sidebar-foreground:lab(2.75381% 0 0);--sidebar-primary:lab(7.78201% -.0000149012 0);--sidebar-primary-foreground:lab(98.26% 0 0);--sidebar-accent:lab(96.52% -.0000298023 .0000119209);--sidebar-accent-foreground:lab(7.78201% -.0000149012 0);--sidebar-border:lab(90.952% 0 -.0000119209);--sidebar-ring:lab(66.128% -.0000298023 .0000119209);--diff-purple:lab(72.9152% 23.5845 -37.791);--diff-selected:lab(91.88% .0000298023 -.0000119209)}}.dark{--background:#0a0a0a;--foreground:#fafafa;--card:#171717;--card-foreground:#fafafa;--popover:#171717;--popover-foreground:#fafafa;--primary:#e5e5e5;--primary-foreground:#171717;--secondary:#262626;--secondary-foreground:#fafafa;--muted:#262626;--muted-foreground:#a1a1a1;--accent:#262626;--accent-foreground:#fafafa;--destructive:#ff6568;--border:#ffffff1a;--input:#ffffff26;--ring:#737373;--chart-1:#d4d4d4;--chart-2:#737373;--chart-3:#525252;--chart-4:#404040;--chart-5:#262626;--sidebar:#171717;--sidebar-foreground:#fafafa;--sidebar-primary:#e5e5e5;--sidebar-primary-foreground:#fafafa;--sidebar-accent:#262626;--sidebar-accent-foreground:#fafafa;--sidebar-border:#ffffff1a;--sidebar-ring:#737373;--diff-green:#3fb950;--diff-purple:#c3a5f9;--diff-selected:#262626;--diff-success:#3fb950}@supports (color:lab(0% 0 0)){.dark{--background:lab(2.75381% 0 0);--foreground:lab(98.26% 0 0);--card:lab(7.78201% -.0000149012 0);--card-foreground:lab(98.26% 0 0);--popover:lab(7.78201% -.0000149012 0);--popover-foreground:lab(98.26% 0 0);--primary:lab(90.952% 0 -.0000119209);--primary-foreground:lab(7.78201% -.0000149012 0);--secondary:lab(15.204% 0 -.00000596046);--secondary-foreground:lab(98.26% 0 0);--muted:lab(15.204% 0 -.00000596046);--muted-foreground:lab(66.128% -.0000298023 .0000119209);--accent:lab(15.204% 0 -.00000596046);--accent-foreground:lab(98.26% 0 0);--destructive:lab(63.7053% 60.745 31.3109);--border:lab(100% 0 0/.1);--input:lab(100% 0 0/.15);--ring:lab(48.496% 0 0);--chart-1:lab(84.92% 0 -.0000119209);--chart-2:lab(48.496% 0 0);--chart-3:lab(34.924% 0 0);--chart-4:lab(27.036% 0 0);--chart-5:lab(15.204% 0 -.00000596046);--sidebar:lab(7.78201% -.0000149012 0);--sidebar-foreground:lab(98.26% 0 0);--sidebar-primary:lab(90.952% 0 -.0000119209);--sidebar-primary-foreground:lab(98.26% 0 0);--sidebar-accent:lab(15.204% 0 -.00000596046);--sidebar-accent-foreground:lab(98.26% 0 0);--sidebar-border:lab(100% 0 0/.1);--sidebar-ring:lab(48.496% 0 0);--diff-purple:lab(72.9152% 23.5845 -37.791);--diff-selected:lab(15.204% 0 -.00000596046)}}@keyframes diffhub-menu-in{0%{opacity:0;transform:translateY(-4px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.diffhub-menu-animate{animation:.12s ease-out forwards diffhub-menu-in}@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-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-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@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}}@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))}}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|