@floegence/floe-webapp-core 0.1.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/dist/app/FloeApp.d.ts +37 -0
- package/dist/app/FloeProvider.d.ts +17 -0
- package/dist/app/index.d.ts +2 -0
- package/dist/components/deck/DeckCell.d.ts +17 -0
- package/dist/components/deck/DeckGrid.d.ts +14 -0
- package/dist/components/deck/DeckTopBar.d.ts +9 -0
- package/dist/components/deck/DropZonePreview.d.ts +10 -0
- package/dist/components/deck/LayoutSelector.d.ts +7 -0
- package/dist/components/deck/WidgetFrame.d.ts +14 -0
- package/dist/components/deck/WidgetPalette.d.ts +7 -0
- package/dist/components/deck/WidgetResizeHandle.d.ts +9 -0
- package/dist/components/deck/WidgetTypeSwitcher.d.ts +9 -0
- package/dist/components/deck/index.d.ts +9 -0
- package/dist/components/icons/index.d.ts +29 -0
- package/dist/components/index.d.ts +5 -0
- package/dist/components/launchpad/Launchpad.d.ts +15 -0
- package/dist/components/launchpad/LaunchpadGrid.d.ts +8 -0
- package/dist/components/launchpad/LaunchpadItem.d.ts +18 -0
- package/dist/components/launchpad/LaunchpadPagination.d.ts +6 -0
- package/dist/components/launchpad/LaunchpadSearch.d.ts +6 -0
- package/dist/components/launchpad/index.d.ts +10 -0
- package/dist/components/layout/ActivityBar.d.ts +24 -0
- package/dist/components/layout/BottomBar.d.ts +27 -0
- package/dist/components/layout/MobileTabBar.d.ts +19 -0
- package/dist/components/layout/Panel.d.ts +27 -0
- package/dist/components/layout/ResizeHandle.d.ts +9 -0
- package/dist/components/layout/Shell.d.ts +23 -0
- package/dist/components/layout/Sidebar.d.ts +33 -0
- package/dist/components/layout/TopBar.d.ts +11 -0
- package/dist/components/layout/index.d.ts +9 -0
- package/dist/components/loading/LoadingOverlay.d.ts +10 -0
- package/dist/components/loading/Skeleton.d.ts +21 -0
- package/dist/components/loading/SnakeLoader.d.ts +9 -0
- package/dist/components/loading/index.d.ts +3 -0
- package/dist/components/ui/Button.d.ts +12 -0
- package/dist/components/ui/Card.d.ts +79 -0
- package/dist/components/ui/CommandPalette.d.ts +4 -0
- package/dist/components/ui/Dialog.d.ts +29 -0
- package/dist/components/ui/Dropdown.d.ts +35 -0
- package/dist/components/ui/FloatingWindow.d.ts +45 -0
- package/dist/components/ui/Input.d.ts +16 -0
- package/dist/components/ui/Tooltip.d.ts +12 -0
- package/dist/components/ui/index.d.ts +8 -0
- package/dist/context/CommandContext.d.ts +30 -0
- package/dist/context/ComponentRegistry.d.ts +90 -0
- package/dist/context/DeckContext.d.ts +88 -0
- package/dist/context/FloeConfigContext.d.ts +133 -0
- package/dist/context/LayoutContext.d.ts +20 -0
- package/dist/context/NotificationContext.d.ts +32 -0
- package/dist/context/ThemeContext.d.ts +12 -0
- package/dist/context/WidgetRegistry.d.ts +37 -0
- package/dist/context/createSimpleContext.d.ts +15 -0
- package/dist/context/index.d.ts +9 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/useDebounce.d.ts +5 -0
- package/dist/hooks/useDeckDrag.d.ts +6 -0
- package/dist/hooks/useKeybind.d.ts +4 -0
- package/dist/hooks/useMediaQuery.d.ts +5 -0
- package/dist/hooks/usePersisted.d.ts +5 -0
- package/dist/hooks/useResizeObserver.d.ts +9 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +226 -0
- package/dist/index10.js +92 -0
- package/dist/index11.js +101 -0
- package/dist/index12.js +113 -0
- package/dist/index13.js +82 -0
- package/dist/index14.js +123 -0
- package/dist/index15.js +106 -0
- package/dist/index16.js +131 -0
- package/dist/index17.js +152 -0
- package/dist/index18.js +41 -0
- package/dist/index19.js +61 -0
- package/dist/index2.js +215 -0
- package/dist/index20.js +79 -0
- package/dist/index21.js +162 -0
- package/dist/index22.js +293 -0
- package/dist/index23.js +136 -0
- package/dist/index24.js +45 -0
- package/dist/index25.js +146 -0
- package/dist/index26.js +258 -0
- package/dist/index27.js +92 -0
- package/dist/index28.js +42 -0
- package/dist/index29.js +71 -0
- package/dist/index3.js +94 -0
- package/dist/index30.js +280 -0
- package/dist/index31.js +154 -0
- package/dist/index32.js +31 -0
- package/dist/index33.js +50 -0
- package/dist/index34.js +15 -0
- package/dist/index35.js +32 -0
- package/dist/index36.js +51 -0
- package/dist/index37.js +41 -0
- package/dist/index38.js +28 -0
- package/dist/index39.js +176 -0
- package/dist/index4.js +55 -0
- package/dist/index40.js +43 -0
- package/dist/index41.js +69 -0
- package/dist/index42.js +99 -0
- package/dist/index43.js +120 -0
- package/dist/index44.js +141 -0
- package/dist/index45.js +42 -0
- package/dist/index46.js +386 -0
- package/dist/index47.js +16 -0
- package/dist/index48.js +13 -0
- package/dist/index49.js +19 -0
- package/dist/index5.js +48 -0
- package/dist/index50.js +13 -0
- package/dist/index51.js +11 -0
- package/dist/index52.js +59 -0
- package/dist/index53.js +8 -0
- package/dist/index54.js +6 -0
- package/dist/index55.js +48 -0
- package/dist/index56.js +29 -0
- package/dist/index57.js +35 -0
- package/dist/index58.js +94 -0
- package/dist/index59.js +25 -0
- package/dist/index6.js +73 -0
- package/dist/index60.js +49 -0
- package/dist/index61.js +17 -0
- package/dist/index62.js +38 -0
- package/dist/index63.js +67 -0
- package/dist/index64.js +87 -0
- package/dist/index65.js +17 -0
- package/dist/index66.js +2266 -0
- package/dist/index7.js +112 -0
- package/dist/index8.js +66 -0
- package/dist/index9.js +33 -0
- package/dist/styles/build.d.ts +1 -0
- package/dist/styles/themes/index.d.ts +9 -0
- package/dist/styles.css +1 -0
- package/dist/styles.js +1 -0
- package/dist/utils/animations.d.ts +222 -0
- package/dist/utils/bodyStyleLock.d.ts +9 -0
- package/dist/utils/cn.d.ts +5 -0
- package/dist/utils/defer.d.ts +5 -0
- package/dist/utils/gridCollision.d.ts +31 -0
- package/dist/utils/gridLayout.d.ts +38 -0
- package/dist/utils/index.d.ts +8 -0
- package/dist/utils/keybind.d.ts +22 -0
- package/dist/utils/persist.d.ts +17 -0
- package/dist/widgets/MetricsWidget.d.ts +5 -0
- package/dist/widgets/SidebarWidget.d.ts +11 -0
- package/dist/widgets/TerminalWidget.d.ts +5 -0
- package/dist/widgets/index.d.ts +3 -0
- package/package.json +40 -0
package/dist/index7.js
ADDED
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { delegateEvents as A, template as f, insert as o, createComponent as c, effect as w, className as m, Dynamic as C, memo as S, setAttribute as k, use as _ } from "solid-js/web";
|
|
2
|
+
import { createSignal as $, onMount as I, onCleanup as L, Show as h, For as F } from "solid-js";
|
|
3
|
+
import { cn as v } from "./index53.js";
|
|
4
|
+
var W = /* @__PURE__ */ f('<div class="absolute left-0 top-0 bottom-0 w-8 bg-gradient-to-r from-background to-transparent z-10 pointer-events-none">'), M = /* @__PURE__ */ f('<div class="absolute right-0 top-0 bottom-0 w-8 bg-gradient-to-l from-background to-transparent z-10 pointer-events-none">'), R = /* @__PURE__ */ f('<nav><div class="relative h-14"><div class="h-full flex items-center overflow-x-auto scrollbar-hide snap-x snap-mandatory"style=-webkit-overflow-scrolling:touch>'), j = /* @__PURE__ */ f("<span>"), q = /* @__PURE__ */ f('<div class="absolute bottom-0 left-1/2 -translate-x-1/2 w-8 h-0.5 bg-primary rounded-t">'), z = /* @__PURE__ */ f("<button type=button role=tab><div></div><span>");
|
|
5
|
+
function N(e) {
|
|
6
|
+
let n;
|
|
7
|
+
const [l, u] = $(!1), [b, t] = $(!1);
|
|
8
|
+
let i = null;
|
|
9
|
+
const s = () => {
|
|
10
|
+
n && (u(n.scrollLeft > 0), t(n.scrollLeft < n.scrollWidth - n.clientWidth - 1));
|
|
11
|
+
}, g = () => {
|
|
12
|
+
if (i === null) {
|
|
13
|
+
if (typeof requestAnimationFrame > "u") {
|
|
14
|
+
s();
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
i = requestAnimationFrame(() => {
|
|
18
|
+
i = null, s();
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
return I(() => {
|
|
23
|
+
s();
|
|
24
|
+
const a = e.items.findIndex((r) => r.id === e.activeId);
|
|
25
|
+
if (a > 0 && n) {
|
|
26
|
+
const r = n.scrollWidth / e.items.length;
|
|
27
|
+
n.scrollLeft = Math.max(0, r * a - n.clientWidth / 2 + r / 2);
|
|
28
|
+
}
|
|
29
|
+
}), L(() => {
|
|
30
|
+
i !== null && typeof cancelAnimationFrame < "u" && (cancelAnimationFrame(i), i = null);
|
|
31
|
+
}), (() => {
|
|
32
|
+
var a = R(), r = a.firstChild, d = r.firstChild;
|
|
33
|
+
o(r, c(h, {
|
|
34
|
+
get when() {
|
|
35
|
+
return l();
|
|
36
|
+
},
|
|
37
|
+
get children() {
|
|
38
|
+
return W();
|
|
39
|
+
}
|
|
40
|
+
}), d), o(r, c(h, {
|
|
41
|
+
get when() {
|
|
42
|
+
return b();
|
|
43
|
+
},
|
|
44
|
+
get children() {
|
|
45
|
+
return M();
|
|
46
|
+
}
|
|
47
|
+
}), d), d.addEventListener("scroll", g);
|
|
48
|
+
var y = n;
|
|
49
|
+
return typeof y == "function" ? _(y, d) : n = d, o(d, c(F, {
|
|
50
|
+
get each() {
|
|
51
|
+
return e.items;
|
|
52
|
+
},
|
|
53
|
+
children: (x) => c(E, {
|
|
54
|
+
item: x,
|
|
55
|
+
get isActive() {
|
|
56
|
+
return e.activeId === x.id;
|
|
57
|
+
},
|
|
58
|
+
onClick: () => {
|
|
59
|
+
e.onSelect(x.id), "vibrate" in navigator && navigator.vibrate(10);
|
|
60
|
+
}
|
|
61
|
+
})
|
|
62
|
+
})), w(() => m(a, v(
|
|
63
|
+
// Same safe-area rule as TopBar: keep the visual bar height stable, and
|
|
64
|
+
// add safe-area padding on an outer wrapper (avoid squeezing content).
|
|
65
|
+
"relative shrink-0 bg-background border-t border-border safe-bottom safe-left safe-right",
|
|
66
|
+
e.class
|
|
67
|
+
))), a;
|
|
68
|
+
})();
|
|
69
|
+
}
|
|
70
|
+
function E(e) {
|
|
71
|
+
const n = () => typeof e.item.badge == "function" ? e.item.badge() : e.item.badge;
|
|
72
|
+
return (() => {
|
|
73
|
+
var l = z(), u = l.firstChild, b = u.nextSibling;
|
|
74
|
+
return l.$$click = () => e.onClick(), o(u, c(C, {
|
|
75
|
+
get component() {
|
|
76
|
+
return e.item.icon;
|
|
77
|
+
},
|
|
78
|
+
class: "w-6 h-6"
|
|
79
|
+
}), null), o(u, c(h, {
|
|
80
|
+
get when() {
|
|
81
|
+
return n();
|
|
82
|
+
},
|
|
83
|
+
get children() {
|
|
84
|
+
var t = j();
|
|
85
|
+
return o(t, (() => {
|
|
86
|
+
var i = S(() => typeof n() == "number" && n() > 99);
|
|
87
|
+
return () => i() ? "99+" : n();
|
|
88
|
+
})()), w(() => m(t, v("absolute -top-1 -right-2 min-w-4 h-4 px-1", "flex items-center justify-center", "text-[10px] font-medium rounded-full", "bg-primary text-primary-foreground"))), t;
|
|
89
|
+
}
|
|
90
|
+
}), null), o(b, () => e.item.label), o(l, c(h, {
|
|
91
|
+
get when() {
|
|
92
|
+
return e.isActive;
|
|
93
|
+
},
|
|
94
|
+
get children() {
|
|
95
|
+
return q();
|
|
96
|
+
}
|
|
97
|
+
}), null), w((t) => {
|
|
98
|
+
var i = v("relative flex-shrink-0 flex flex-col items-center justify-center", "min-w-16 h-full px-4 snap-center", "transition-all duration-150", "focus:outline-none focus-visible:bg-muted", e.isActive ? "text-primary" : "text-muted-foreground active:text-foreground"), s = e.item.label, g = e.isActive, a = v("relative transition-transform duration-150", e.isActive && "scale-110"), r = v("mt-1 text-[10px] font-medium truncate max-w-full", e.isActive && "font-semibold");
|
|
99
|
+
return i !== t.e && m(l, t.e = i), s !== t.t && k(l, "aria-label", t.t = s), g !== t.a && k(l, "aria-selected", t.a = g), a !== t.o && m(u, t.o = a), r !== t.i && m(b, t.i = r), t;
|
|
100
|
+
}, {
|
|
101
|
+
e: void 0,
|
|
102
|
+
t: void 0,
|
|
103
|
+
a: void 0,
|
|
104
|
+
o: void 0,
|
|
105
|
+
i: void 0
|
|
106
|
+
}), l;
|
|
107
|
+
})();
|
|
108
|
+
}
|
|
109
|
+
A(["click"]);
|
|
110
|
+
export {
|
|
111
|
+
N as MobileTabBar
|
|
112
|
+
};
|
package/dist/index8.js
ADDED
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { delegateEvents as D, template as A, effect as C, className as b, setAttribute as F, use as x } from "solid-js/web";
|
|
2
|
+
import { createSignal as S, onCleanup as q } from "solid-js";
|
|
3
|
+
import { cn as P } from "./index53.js";
|
|
4
|
+
import { lockBodyStyle as E } from "./index57.js";
|
|
5
|
+
var H = /* @__PURE__ */ A("<div role=separator style=touch-action:none><div>");
|
|
6
|
+
function O(i) {
|
|
7
|
+
const [u, d] = S(!1);
|
|
8
|
+
let e = 0, r = 0, c = null, n, s = null, o = null;
|
|
9
|
+
const m = (t) => {
|
|
10
|
+
if (!t) {
|
|
11
|
+
o == null || o(), o = null;
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
o == null || o(), o = E({
|
|
15
|
+
cursor: i.direction === "horizontal" ? "col-resize" : "row-resize",
|
|
16
|
+
"user-select": "none"
|
|
17
|
+
});
|
|
18
|
+
}, p = () => {
|
|
19
|
+
if (!u()) return;
|
|
20
|
+
s !== null && typeof cancelAnimationFrame < "u" && (cancelAnimationFrame(s), s = null);
|
|
21
|
+
const t = r - e;
|
|
22
|
+
t !== 0 && (i.onResize(t), e = r), d(!1), c = null, m(!1);
|
|
23
|
+
}, g = (t) => i.direction === "horizontal" ? t.clientX : t.clientY, I = (t) => {
|
|
24
|
+
t.pointerType === "mouse" && t.button !== 0 || (t.preventDefault(), c = t.pointerId, d(!0), e = g(t), r = e, m(!0), n == null || n.setPointerCapture(t.pointerId));
|
|
25
|
+
}, $ = (t) => {
|
|
26
|
+
if (!(!u() || c !== t.pointerId) && (r = g(t), s === null)) {
|
|
27
|
+
if (typeof requestAnimationFrame > "u") {
|
|
28
|
+
const l = r - e;
|
|
29
|
+
l !== 0 && (i.onResize(l), e = r);
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
s = requestAnimationFrame(() => {
|
|
33
|
+
if (s = null, !u()) return;
|
|
34
|
+
const l = r - e;
|
|
35
|
+
l !== 0 && (i.onResize(l), e = r);
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
}, v = (t) => {
|
|
39
|
+
if (c === t.pointerId) {
|
|
40
|
+
try {
|
|
41
|
+
n == null || n.releasePointerCapture(t.pointerId);
|
|
42
|
+
} catch {
|
|
43
|
+
}
|
|
44
|
+
p();
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
q(() => p());
|
|
48
|
+
const f = () => i.direction === "horizontal";
|
|
49
|
+
return (() => {
|
|
50
|
+
var t = H(), l = t.firstChild;
|
|
51
|
+
t.addEventListener("pointercancel", v), t.$$pointerup = v, t.$$pointermove = $, t.$$pointerdown = I;
|
|
52
|
+
var h = n;
|
|
53
|
+
return typeof h == "function" ? x(h, t) : n = t, C((a) => {
|
|
54
|
+
var z = P("absolute z-20 group", f() ? "top-0 right-0 w-1 h-full cursor-col-resize hover:w-1.5" : "left-0 top-0 h-1 w-full cursor-row-resize hover:h-1.5", "transition-all duration-100", u() && "bg-primary", !u() && "hover:bg-primary/50", i.class), y = f() ? "vertical" : "horizontal", w = P("absolute opacity-0 group-hover:opacity-100 transition-opacity duration-150", f() ? "top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2 w-0.5 h-8 rounded-full bg-muted-foreground/30" : "left-1/2 top-1/2 -translate-x-1/2 -translate-y-1/2 h-0.5 w-8 rounded-full bg-muted-foreground/30");
|
|
55
|
+
return z !== a.e && b(t, a.e = z), y !== a.t && F(t, "aria-orientation", a.t = y), w !== a.a && b(l, a.a = w), a;
|
|
56
|
+
}, {
|
|
57
|
+
e: void 0,
|
|
58
|
+
t: void 0,
|
|
59
|
+
a: void 0
|
|
60
|
+
}), t;
|
|
61
|
+
})();
|
|
62
|
+
}
|
|
63
|
+
D(["pointerdown", "pointermove", "pointerup"]);
|
|
64
|
+
export {
|
|
65
|
+
O as ResizeHandle
|
|
66
|
+
};
|
package/dist/index9.js
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { template as n, insert as t, effect as l, className as a, memo as m } from "solid-js/web";
|
|
2
|
+
import "solid-js";
|
|
3
|
+
import { cn as c } from "./index53.js";
|
|
4
|
+
var o = /* @__PURE__ */ n("<div>"), u = /* @__PURE__ */ n("<div><span class=truncate>"), s = /* @__PURE__ */ n('<div class="flex items-center gap-1 ml-2">');
|
|
5
|
+
function $(r) {
|
|
6
|
+
return (() => {
|
|
7
|
+
var e = o();
|
|
8
|
+
return t(e, () => r.children), l(() => a(e, c("flex flex-col h-full overflow-hidden", "bg-card text-card-foreground", r.class))), e;
|
|
9
|
+
})();
|
|
10
|
+
}
|
|
11
|
+
function b(r) {
|
|
12
|
+
return (() => {
|
|
13
|
+
var e = u(), d = e.firstChild;
|
|
14
|
+
return t(d, () => r.children), t(e, (() => {
|
|
15
|
+
var f = m(() => !!r.actions);
|
|
16
|
+
return () => f() && (() => {
|
|
17
|
+
var i = s();
|
|
18
|
+
return t(i, () => r.actions), i;
|
|
19
|
+
})();
|
|
20
|
+
})(), null), l(() => a(e, c("flex items-center justify-between px-3 py-2", "border-b border-border", "text-sm font-medium", r.class))), e;
|
|
21
|
+
})();
|
|
22
|
+
}
|
|
23
|
+
function h(r) {
|
|
24
|
+
return (() => {
|
|
25
|
+
var e = o();
|
|
26
|
+
return t(e, () => r.children), l(() => a(e, c("flex-1 overflow-auto", !r.noPadding && "p-3", r.class))), e;
|
|
27
|
+
})();
|
|
28
|
+
}
|
|
29
|
+
export {
|
|
30
|
+
$ as Panel,
|
|
31
|
+
h as PanelContent,
|
|
32
|
+
b as PanelHeader
|
|
33
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import './globals.css';
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export type ThemeType = 'light' | 'dark' | 'system';
|
|
2
|
+
export interface FloeTheme {
|
|
3
|
+
name: string;
|
|
4
|
+
displayName: string;
|
|
5
|
+
type: 'light' | 'dark';
|
|
6
|
+
}
|
|
7
|
+
export declare const builtInThemes: FloeTheme[];
|
|
8
|
+
export declare function getSystemTheme(): 'light' | 'dark';
|
|
9
|
+
export declare function applyTheme(theme: ThemeType): void;
|
package/dist/styles.css
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
/*! 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-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-scroll-snap-strictness:proximity;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-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-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-200:oklch(88.5% .062 18.334);--color-red-300:oklch(80.8% .114 19.571);--color-red-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--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-blue-500:oklch(62.3% .214 259.815);--color-purple-500:oklch(62.7% .265 303.9);--color-slate-200:oklch(92.9% .013 255.508);--color-slate-300:oklch(86.9% .022 252.894);--color-slate-400:oklch(70.4% .04 256.788);--color-slate-600:oklch(44.6% .043 257.281);--color-zinc-100:oklch(96.7% .001 286.375);--color-zinc-900:oklch(21% .006 285.885);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--container-xl:36rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wider:.05em;--radius-sm:calc(var(--radius) - 4px);--radius-md:calc(var(--radius) - 2px);--radius-lg:var(--radius);--radius-xl:calc(var(--radius) + 4px);--radius-2xl:1rem;--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-sm:8px;--blur-xl:24px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@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}*{border-color:var(--border);scrollbar-width:thin;scrollbar-color:var(--muted)transparent}::-webkit-scrollbar{width:.5rem;height:.5rem}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--muted);border-radius:9999px}::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}@supports (color:color-mix(in lab,red,red)){::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--muted-foreground)50%,transparent)}}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv02","cv03","cv04","cv11";overscroll-behavior:none;height:100%}body{overscroll-behavior:none;background-color:var(--background);height:100%;color:var(--foreground);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}#root{height:100%}code,pre,.font-mono{font-family:JetBrains Mono,Fira Code,SF Mono,Menlo,Monaco,Consolas,monospace}:focus-visible{box-shadow:0 0 0 2px var(--background),0 0 0 4px var(--ring);outline:none}:focus:not(:focus-visible){outline:none}::selection{background:var(--primary)}@supports (color:color-mix(in lab,red,red)){::selection{background:color-mix(in srgb,var(--primary)20%,transparent)}}::selection{color:var(--foreground)}}@layer components;@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing)*0)}.inset-1{inset:calc(var(--spacing)*1)}.inset-\[1px\]{top:1px;right:1px;bottom:1px;left:1px}.-top-1{top:calc(var(--spacing)*-1)}.-top-1\/2{top:-50%}.top-0{top:calc(var(--spacing)*0)}.top-0\.5{top:calc(var(--spacing)*.5)}.top-1\/2{top:50%}.top-2{top:calc(var(--spacing)*2)}.top-\[20\%\]{top:20%}.top-full{top:100%}.-right-1\/2{right:-50%}.-right-2{right:calc(var(--spacing)*-2)}.right-0{right:calc(var(--spacing)*0)}.right-0\.5{right:calc(var(--spacing)*.5)}.right-2{right:calc(var(--spacing)*2)}.right-2\.5{right:calc(var(--spacing)*2.5)}.right-4{right:calc(var(--spacing)*4)}.right-full{right:100%}.-bottom-1\/2{bottom:-50%}.bottom-0{bottom:calc(var(--spacing)*0)}.bottom-2{bottom:calc(var(--spacing)*2)}.bottom-4{bottom:calc(var(--spacing)*4)}.bottom-full{bottom:100%}.-left-1\.5{left:calc(var(--spacing)*-1.5)}.-left-1\/2{left:-50%}.left-0{left:calc(var(--spacing)*0)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing)*2)}.left-2\.5{left:calc(var(--spacing)*2.5)}.left-3{left:calc(var(--spacing)*3)}.left-full{left:100%}.-z-10{z-index:-10}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-\[9998\]{z-index:9998}.z-\[9999\]{z-index:9999}.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-2{margin-inline:calc(var(--spacing)*2)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing)*1)}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-2{margin-top:calc(var(--spacing)*2)}.-mr-1{margin-right:calc(var(--spacing)*-1)}.mr-1{margin-right:calc(var(--spacing)*1)}.mr-1\.5{margin-right:calc(var(--spacing)*1.5)}.mr-2{margin-right: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)}.ml-2{margin-left:calc(var(--spacing)*2)}.ml-4{margin-left:calc(var(--spacing)*4)}.ml-auto{margin-left:auto}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.h-0{height:calc(var(--spacing)*0)}.h-0\.5{height:calc(var(--spacing)*.5)}.h-1{height:calc(var(--spacing)*1)}.h-1\.5{height:calc(var(--spacing)*1.5)}.h-2{height:calc(var(--spacing)*2)}.h-2\.5{height:calc(var(--spacing)*2.5)}.h-3{height:calc(var(--spacing)*3)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.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-14{height:calc(var(--spacing)*14)}.h-16{height:calc(var(--spacing)*16)}.h-24{height:calc(var(--spacing)*24)}.h-\[100dvh\]{height:100dvh}.h-\[calc\(100\%-48px\)\]{height:calc(100% - 48px)}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-64{max-height:calc(var(--spacing)*64)}.max-h-80{max-height:calc(var(--spacing)*80)}.max-h-\[85vh\]{max-height:85vh}.max-h-\[240px\]{max-height:240px}.max-h-\[300px\]{max-height:300px}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-16{min-height:calc(var(--spacing)*16)}.w-0{width:calc(var(--spacing)*0)}.w-0\.5{width:calc(var(--spacing)*.5)}.w-1{width:calc(var(--spacing)*1)}.w-1\.5{width:calc(var(--spacing)*1.5)}.w-1\/3{width:33.3333%}.w-1\/4{width:25%}.w-2{width:calc(var(--spacing)*2)}.w-2\.5{width:calc(var(--spacing)*2.5)}.w-2\/3{width:66.6667%}.w-3{width:calc(var(--spacing)*3)}.w-3\.5{width:calc(var(--spacing)*3.5)}.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-9{width:calc(var(--spacing)*9)}.w-10{width:calc(var(--spacing)*10)}.w-12{width:calc(var(--spacing)*12)}.w-14{width:calc(var(--spacing)*14)}.w-16{width:calc(var(--spacing)*16)}.w-24{width:calc(var(--spacing)*24)}.w-64{width:calc(var(--spacing)*64)}.w-72{width:calc(var(--spacing)*72)}.w-80{width:calc(var(--spacing)*80)}.w-full{width:100%}.max-w-\[80px\]{max-width:80px}.max-w-\[85vw\]{max-width:85vw}.max-w-\[120px\]{max-width:120px}.max-w-full{max-width:100%}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.max-w-xl{max-width:var(--container-xl)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-3\.5{min-width:calc(var(--spacing)*3.5)}.min-w-4{min-width:calc(var(--spacing)*4)}.min-w-16{min-width:calc(var(--spacing)*16)}.min-w-36{min-width:calc(var(--spacing)*36)}.min-w-\[160px\]{min-width:160px}.min-w-\[180px\]{min-width:180px}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-x-full{--tw-translate-x:-100%;translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-0{--tw-translate-x:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-full{--tw-translate-x:100%;translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x)var(--tw-translate-y)}.scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-\[1\.02\]{scale:1.02}.rotate-90{rotate:90deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.animate-\[gradient-rotate_3s_linear_infinite\]{animation:3s linear infinite gradient-rotate}.animate-\[shimmer_2s_infinite\]{animation:2s infinite shimmer}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-col-resize{cursor:col-resize}.cursor-ew-resize{cursor:ew-resize}.cursor-grab{cursor:grab}.cursor-grabbing{cursor:grabbing}.cursor-move{cursor:move}.cursor-nesw-resize{cursor:nesw-resize}.cursor-not-allowed{cursor:not-allowed}.cursor-ns-resize{cursor:ns-resize}.cursor-nwse-resize{cursor:nwse-resize}.cursor-pointer{cursor:pointer}.cursor-row-resize{cursor:row-resize}.resize{resize:both}.resize-y{resize:vertical}.snap-x{scroll-snap-type:x var(--tw-scroll-snap-strictness)}.snap-mandatory{--tw-scroll-snap-strictness:mandatory}.snap-center{scroll-snap-align:center}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.place-items-center{place-items:center}.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\.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)}: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)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overscroll-contain{overscroll-behavior:contain}.overscroll-none{overscroll-behavior:none}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[7px\]{border-radius:7px}.rounded-\[10px\]{border-radius:10px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-none{border-radius:0}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.rounded-t-md{border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.rounded-r{border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-4{border-style:var(--tw-border-style);border-width:4px}.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-dashed{--tw-border-style:dashed;border-style:dashed}.border-red-400{border-color:var(--color-red-400)}.border-slate-400{border-color:var(--color-slate-400)}.border-transparent{border-color:#0000}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.border-white\/10{border-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.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-x-transparent{border-inline-color:#0000}.border-y-transparent{border-block-color:#0000}.border-t-transparent{border-top-color:#0000}.border-r-transparent{border-right-color:#0000}.border-b-transparent{border-bottom-color:#0000}.border-l-transparent{border-left-color:#0000}.bg-black\/20{background-color:#0003}@supports (color:color-mix(in lab,red,red)){.bg-black\/20{background-color:color-mix(in oklab,var(--color-black)20%,transparent)}}.bg-black\/70{background-color:#000000b3}@supports (color:color-mix(in lab,red,red)){.bg-black\/70{background-color:color-mix(in oklab,var(--color-black)70%,transparent)}}.bg-red-200\/60{background-color:#ffcaca99}@supports (color:color-mix(in lab,red,red)){.bg-red-200\/60{background-color:color-mix(in oklab,var(--color-red-200)60%,transparent)}}.bg-slate-200\/60{background-color:#e2e8f099}@supports (color:color-mix(in lab,red,red)){.bg-slate-200\/60{background-color:color-mix(in oklab,var(--color-slate-200)60%,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\/40{background-color:#fff6}@supports (color:color-mix(in lab,red,red)){.bg-white\/40{background-color:color-mix(in oklab,var(--color-white)40%,transparent)}}.bg-zinc-900{background-color:var(--color-zinc-900)}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-l{--tw-gradient-position:to left in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-red-300\/40{--tw-gradient-from:#ffa3a366}@supports (color:color-mix(in lab,red,red)){.from-red-300\/40{--tw-gradient-from:color-mix(in oklab,var(--color-red-300)40%,transparent)}}.from-red-300\/40{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-slate-300\/40{--tw-gradient-from:#cad5e266}@supports (color:color-mix(in lab,red,red)){.from-slate-300\/40{--tw-gradient-from:color-mix(in oklab,var(--color-slate-300)40%,transparent)}}.from-slate-300\/40{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-transparent{--tw-gradient-from:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.via-transparent{--tw-gradient-via:transparent;--tw-gradient-via-stops:var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-via)var(--tw-gradient-via-position),var(--tw-gradient-to)var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.via-white\/10{--tw-gradient-via:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.via-white\/10{--tw-gradient-via:color-mix(in oklab,var(--color-white)10%,transparent)}}.via-white\/10{--tw-gradient-via-stops:var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-via)var(--tw-gradient-via-position),var(--tw-gradient-to)var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-red-400\/20{--tw-gradient-to:#ff656833}@supports (color:color-mix(in lab,red,red)){.to-red-400\/20{--tw-gradient-to:color-mix(in oklab,var(--color-red-400)20%,transparent)}}.to-red-400\/20{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-slate-400\/20{--tw-gradient-to:#90a1b933}@supports (color:color-mix(in lab,red,red)){.to-slate-400\/20{--tw-gradient-to:color-mix(in oklab,var(--color-slate-400)20%,transparent)}}.to-slate-400\/20{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.p-0\.5{padding:calc(var(--spacing)*.5)}.p-1{padding:calc(var(--spacing)*1)}.p-2{padding:calc(var(--spacing)*2)}.p-2\.5{padding:calc(var(--spacing)*2.5)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-8{padding:calc(var(--spacing)*8)}.p-\[2px\]{padding:2px}.px-1{padding-inline:calc(var(--spacing)*1)}.px-1\.5{padding-inline:calc(var(--spacing)*1.5)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-2\.5{padding-inline:calc(var(--spacing)*2.5)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-8{padding-inline:calc(var(--spacing)*8)}.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-8{padding-block:calc(var(--spacing)*8)}.pt-0{padding-top:calc(var(--spacing)*0)}.pt-1{padding-top:calc(var(--spacing)*1)}.pt-8{padding-top:calc(var(--spacing)*8)}.pr-4{padding-right:calc(var(--spacing)*4)}.pr-10{padding-right:calc(var(--spacing)*10)}.pb-4{padding-bottom:calc(var(--spacing)*4)}.pb-8{padding-bottom:calc(var(--spacing)*8)}.pl-10{padding-left:calc(var(--spacing)*10)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[9px\]{font-size:9px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.leading-none{--tw-leading:1;line-height:1}.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-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)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.text-blue-500{color:var(--color-blue-500)}.text-green-400{color:var(--color-green-400)}.text-green-500{color:var(--color-green-500)}.text-purple-500{color:var(--color-purple-500)}.text-red-400{color:var(--color-red-400)}.text-white{color:var(--color-white)}.text-white\/30{color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.text-white\/30{color:color-mix(in oklab,var(--color-white)30%,transparent)}}.text-white\/50{color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.text-white\/50{color:color-mix(in oklab,var(--color-white)50%,transparent)}}.text-white\/90{color:#ffffffe6}@supports (color:color-mix(in lab,red,red)){.text-white\/90{color:color-mix(in oklab,var(--color-white)90%,transparent)}}.text-yellow-500{color:var(--color-yellow-500)}.text-zinc-100{color:var(--color-zinc-100)}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-75{opacity:.75}.opacity-100{opacity:1}.shadow{--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-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_30px_-5px_var\(--primary\)\]{--tw-shadow:0 0 30px -5px var(--tw-shadow-color,var(--primary));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_4px_16px_rgba\(0\,0\,0\,0\.12\)\]{--tw-shadow:0 4px 16px var(--tw-shadow-color,#0000001f);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-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-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a),0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-2{--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)}.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-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.backdrop-blur-xl{--tw-backdrop-blur:blur(var(--blur-xl));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-shadow{transition-property:box-shadow;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-75{--tw-duration:75ms;transition-duration:75ms}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.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}@media(hover:hover){.group-hover\:scale-105:is(:where(.group):hover *){--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.placeholder\:text-white\/50::placeholder{color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.placeholder\:text-white\/50::placeholder{color:color-mix(in oklab,var(--color-white)50%,transparent)}}@media(hover:hover){.hover\:h-1\.5:hover{height:calc(var(--spacing)*1.5)}.hover\:w-1\.5:hover{width:calc(var(--spacing)*1.5)}.hover\:-translate-y-1:hover{--tw-translate-y:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.hover\:bg-white\/10:hover{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/10:hover{background-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.hover\:bg-white\/60:hover{background-color:#fff9}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/60:hover{background-color:color-mix(in oklab,var(--color-white)60%,transparent)}}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-md:hover{--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)}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a),0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:ring-1:hover{--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\:border-white\/30:focus{border-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.focus\:border-white\/30:focus{border-color:color-mix(in oklab,var(--color-white)30%,transparent)}}.focus\:bg-white\/15:focus{background-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.focus\:bg-white\/15:focus{background-color:color-mix(in oklab,var(--color-white)15%,transparent)}}.focus\:ring-1:focus{--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\:ring-2:focus{--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\:ring-white\/20:focus{--tw-ring-color:#fff3}@supports (color:color-mix(in lab,red,red)){.focus\:ring-white\/20:focus{--tw-ring-color:color-mix(in oklab,var(--color-white)20%,transparent)}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:bg-white\/10:focus-visible{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.focus-visible\:bg-white\/10:focus-visible{background-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.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-white\/30:focus-visible{--tw-ring-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-white\/30:focus-visible{--tw-ring-color:color-mix(in oklab,var(--color-white)30%,transparent)}}.focus-visible\:ring-white\/50:focus-visible{--tw-ring-color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-white\/50:focus-visible{--tw-ring-color:color-mix(in oklab,var(--color-white)50%,transparent)}}.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-transparent:focus-visible{--tw-ring-offset-color:transparent}.focus-visible\:ring-inset:focus-visible{--tw-ring-inset:inset}.active\:scale-95:active{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x)var(--tw-scale-y)}.active\:scale-\[0\.98\]:active{scale:.98}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media(min-width:40rem){.sm\:inline{display:inline}}@media(min-width:48rem){.md\:-left-2\.5{left:calc(var(--spacing)*-2.5)}.md\:block{display:block}.md\:inline{display:inline}.md\:w-14{width:calc(var(--spacing)*14)}.md\:gap-2{gap:calc(var(--spacing)*2)}.md\:py-2{padding-block:calc(var(--spacing)*2)}}@media(prefers-color-scheme:dark){.dark\:border-red-400{border-color:var(--color-red-400)}.dark\:border-slate-400{border-color:var(--color-slate-400)}.dark\:bg-red-500\/30{background-color:#fb2c364d}@supports (color:color-mix(in lab,red,red)){.dark\:bg-red-500\/30{background-color:color-mix(in oklab,var(--color-red-500)30%,transparent)}}.dark\:bg-slate-600\/40{background-color:#45556c66}@supports (color:color-mix(in lab,red,red)){.dark\:bg-slate-600\/40{background-color:color-mix(in oklab,var(--color-slate-600)40%,transparent)}}.dark\:from-red-400\/20{--tw-gradient-from:#ff656833}@supports (color:color-mix(in lab,red,red)){.dark\:from-red-400\/20{--tw-gradient-from:color-mix(in oklab,var(--color-red-400)20%,transparent)}}.dark\:from-red-400\/20{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.dark\:from-slate-400\/20{--tw-gradient-from:#90a1b933}@supports (color:color-mix(in lab,red,red)){.dark\:from-slate-400\/20{--tw-gradient-from:color-mix(in oklab,var(--color-slate-400)20%,transparent)}}.dark\:from-slate-400\/20{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.dark\:via-transparent{--tw-gradient-via:transparent;--tw-gradient-via-stops:var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-via)var(--tw-gradient-via-position),var(--tw-gradient-to)var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.dark\:to-red-300\/10{--tw-gradient-to:#ffa3a31a}@supports (color:color-mix(in lab,red,red)){.dark\:to-red-300\/10{--tw-gradient-to:color-mix(in oklab,var(--color-red-300)10%,transparent)}}.dark\:to-red-300\/10{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.dark\:to-slate-300\/10{--tw-gradient-to:#cad5e21a}@supports (color:color-mix(in lab,red,red)){.dark\:to-slate-300\/10{--tw-gradient-to:color-mix(in oklab,var(--color-slate-300)10%,transparent)}}.dark\:to-slate-300\/10{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.dark\:shadow-\[0_4px_16px_rgba\(255\,255\,255\,0\.08\)\]{--tw-shadow:0 4px 16px var(--tw-shadow-color,#ffffff14);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.bg-background{background-color:var(--background)}.bg-foreground{background-color:var(--foreground)}.bg-primary{background-color:var(--primary)}.bg-primary-foreground{background-color:var(--primary-foreground)}.bg-secondary{background-color:var(--secondary)}.bg-secondary-foreground{background-color:var(--secondary-foreground)}.bg-muted{background-color:var(--muted)}.bg-muted-foreground{background-color:var(--muted-foreground)}.bg-accent{background-color:var(--accent)}.bg-accent-foreground{background-color:var(--accent-foreground)}.bg-card{background-color:var(--card)}.bg-card-foreground{background-color:var(--card-foreground)}.bg-popover{background-color:var(--popover)}.bg-popover-foreground{background-color:var(--popover-foreground)}.bg-border{background-color:var(--border)}.bg-input{background-color:var(--input)}.bg-ring{background-color:var(--ring)}.bg-success{background-color:var(--success)}.bg-success-foreground{background-color:var(--success-foreground)}.bg-warning{background-color:var(--warning)}.bg-warning-foreground{background-color:var(--warning-foreground)}.bg-error{background-color:var(--error)}.bg-error-foreground{background-color:var(--error-foreground)}.bg-destructive{background-color:var(--error)}.bg-destructive-foreground{background-color:var(--error-foreground)}.bg-info{background-color:var(--info)}.bg-info-foreground{background-color:var(--info-foreground)}.bg-sidebar{background-color:var(--sidebar)}.bg-sidebar-foreground{background-color:var(--sidebar-foreground)}.bg-sidebar-primary{background-color:var(--sidebar-primary)}.bg-sidebar-primary-foreground{background-color:var(--sidebar-primary-foreground)}.bg-sidebar-accent{background-color:var(--sidebar-accent)}.bg-sidebar-accent-foreground{background-color:var(--sidebar-accent-foreground)}.bg-sidebar-border{background-color:var(--sidebar-border)}.bg-sidebar-ring{background-color:var(--sidebar-ring)}.bg-activity-bar{background-color:var(--activity-bar)}.bg-activity-bar-foreground{background-color:var(--activity-bar-foreground)}.bg-activity-bar-foreground-active{background-color:var(--activity-bar-foreground-active)}.bg-activity-bar-badge{background-color:var(--activity-bar-badge)}.bg-activity-bar-badge-foreground{background-color:var(--activity-bar-badge-foreground)}.bg-terminal-background{background-color:var(--terminal-background)}.bg-terminal-foreground{background-color:var(--terminal-foreground)}.text-background{color:var(--background)}.text-foreground{color:var(--foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-secondary{color:var(--secondary)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-muted{color:var(--muted)}.text-muted-foreground{color:var(--muted-foreground)}.text-accent{color:var(--accent)}.text-accent-foreground{color:var(--accent-foreground)}.text-card{color:var(--card)}.text-card-foreground{color:var(--card-foreground)}.text-popover{color:var(--popover)}.text-popover-foreground{color:var(--popover-foreground)}.text-border{color:var(--border)}.text-input{color:var(--input)}.text-ring{color:var(--ring)}.text-success{color:var(--success)}.text-success-foreground{color:var(--success-foreground)}.text-warning{color:var(--warning)}.text-warning-foreground{color:var(--warning-foreground)}.text-error{color:var(--error)}.text-error-foreground{color:var(--error-foreground)}.text-destructive{color:var(--error)}.text-destructive-foreground{color:var(--error-foreground)}.text-info{color:var(--info)}.text-info-foreground{color:var(--info-foreground)}.text-sidebar{color:var(--sidebar)}.text-sidebar-foreground{color:var(--sidebar-foreground)}.text-sidebar-primary{color:var(--sidebar-primary)}.text-sidebar-primary-foreground{color:var(--sidebar-primary-foreground)}.text-sidebar-accent{color:var(--sidebar-accent)}.text-sidebar-accent-foreground{color:var(--sidebar-accent-foreground)}.text-sidebar-border{color:var(--sidebar-border)}.text-sidebar-ring{color:var(--sidebar-ring)}.text-activity-bar{color:var(--activity-bar)}.text-activity-bar-foreground{color:var(--activity-bar-foreground)}.text-activity-bar-foreground-active{color:var(--activity-bar-foreground-active)}.text-activity-bar-badge{color:var(--activity-bar-badge)}.text-activity-bar-badge-foreground{color:var(--activity-bar-badge-foreground)}.text-terminal-background{color:var(--terminal-background)}.text-terminal-foreground{color:var(--terminal-foreground)}.border-border{border-color:var(--border)}.border-input{border-color:var(--input)}.border-ring{border-color:var(--ring)}.border-primary{border-color:var(--primary)}.border-secondary{border-color:var(--secondary)}.border-muted{border-color:var(--muted)}.border-accent{border-color:var(--accent)}.border-sidebar-border{border-color:var(--sidebar-border)}.ring-ring{--tw-ring-color:var(--ring)}.ring-primary{--tw-ring-color:var(--primary)}.ring-sidebar-ring{--tw-ring-color:var(--sidebar-ring)}.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 srgb,var(--primary)90%,transparent)}}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in srgb,var(--secondary)80%,transparent)}}.hover\:bg-accent:hover,.hover\:bg-accent\/50:hover{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-accent\/50:hover{background-color:color-mix(in srgb,var(--accent)50%,transparent)}}.hover\:bg-muted:hover{background-color:var(--muted)}.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}.hover\:bg-error\/90:hover{background-color:var(--error)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-error\/90:hover{background-color:color-mix(in srgb,var(--error)90%,transparent)}}.hover\:bg-destructive\/10:hover{background-color:var(--error)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/10:hover{background-color:color-mix(in srgb,var(--error)10%,transparent)}}.hover\:text-destructive:hover{color:var(--error)}.bg-background\/60{background-color:var(--background)}@supports (color:color-mix(in lab,red,red)){.bg-background\/60{background-color:color-mix(in srgb,var(--background)60%,transparent)}}.bg-background\/80{background-color:var(--background)}@supports (color:color-mix(in lab,red,red)){.bg-background\/80{background-color:color-mix(in srgb,var(--background)80%,transparent)}}.bg-muted\/40{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/40{background-color:color-mix(in srgb,var(--muted)40%,transparent)}}.bg-muted\/50{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/50{background-color:color-mix(in srgb,var(--muted)50%,transparent)}}.bg-muted\/70{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/70{background-color:color-mix(in srgb,var(--muted)70%,transparent)}}.bg-muted\/80{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/80{background-color:color-mix(in srgb,var(--muted)80%,transparent)}}.bg-muted-foreground\/30{background-color:var(--muted-foreground)}@supports (color:color-mix(in lab,red,red)){.bg-muted-foreground\/30{background-color:color-mix(in srgb,var(--muted-foreground)30%,transparent)}}.bg-primary\/70{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/70{background-color:color-mix(in srgb,var(--primary)70%,transparent)}}.bg-accent\/40{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.bg-accent\/40{background-color:color-mix(in srgb,var(--accent)40%,transparent)}}.bg-accent\/80{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.bg-accent\/80{background-color:color-mix(in srgb,var(--accent)80%,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 srgb,var(--muted-foreground)70%,transparent)}}.placeholder\:text-muted-foreground\/60::placeholder{color:var(--muted-foreground)}@supports (color:color-mix(in lab,red,red)){.placeholder\:text-muted-foreground\/60::placeholder{color:color-mix(in srgb,var(--muted-foreground)60%,transparent)}}.hover\:bg-primary\/50:hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/50:hover{background-color:color-mix(in srgb,var(--primary)50%,transparent)}}.hover\:bg-muted\/70:hover{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-muted\/70:hover{background-color:color-mix(in srgb,var(--muted)70%,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 srgb,var(--muted)80%,transparent)}}.hover\:bg-accent\/40:hover{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-accent\/40:hover{background-color:color-mix(in srgb,var(--accent)40%,transparent)}}.hover\:bg-sidebar-accent\/80:hover{background-color:var(--sidebar-accent)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-sidebar-accent\/80:hover{background-color:color-mix(in srgb,var(--sidebar-accent)80%,transparent)}}.hover\:border-border\/50:hover{border-color:var(--border)}@supports (color:color-mix(in lab,red,red)){.hover\:border-border\/50:hover{border-color:color-mix(in srgb,var(--border)50%,transparent)}}.border-border\/50{border-color:var(--border)}@supports (color:color-mix(in lab,red,red)){.border-border\/50{border-color:color-mix(in srgb,var(--border)50%,transparent)}}.from-primary{--tw-gradient-from:var(--primary);--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-primary\/70{--tw-gradient-to:var(--primary)}@supports (color:color-mix(in lab,red,red)){.to-primary\/70{--tw-gradient-to:color-mix(in srgb,var(--primary)70%,transparent)}}.animate-in{animation:.2s ease-out animate-in}.animate-out{animation:.15s ease-in animate-out}.slide-in-from-top{--tw-enter-translate-y:-100%}.slide-in-from-bottom{--tw-enter-translate-y:100%}.slide-in-from-left{--tw-enter-translate-x:-100%}.slide-in-from-right{--tw-enter-translate-x:100%}.slide-in-from-top-2{--tw-enter-translate-y:-.5rem}.slide-in-from-top-4{--tw-enter-translate-y:-1rem}.fade-in{--tw-enter-opacity:0}.zoom-in-95{--tw-enter-scale:.95}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}.safe-bottom{padding-bottom:env(safe-area-inset-bottom,0)}.safe-top{padding-top:env(safe-area-inset-top,0)}.safe-left{padding-left:env(safe-area-inset-left,0)}.safe-right{padding-right:env(safe-area-inset-right,0)}}:root,.light{color-scheme:light;--background:#fbfaf9;--foreground:#141f2e;--primary:#141f2e;--primary-foreground:#fafafa;--secondary:#f1f0ee;--secondary-foreground:#2e3f56;--muted:#f1f0ee;--muted-foreground:#5e718d;--accent:#f2f0ed;--accent-foreground:#141f2e;--border:#e3e1de;--input:#e3e1de;--ring:#141f2e;--card:#fdfdfc;--card-foreground:#141f2e;--popover:#fdfdfc;--popover-foreground:#141f2e;--success:oklch(68% .16 150);--success-foreground:#fff;--warning:oklch(78% .14 80);--warning-foreground:#18181b;--error:oklch(65% .2 25);--error-foreground:#fff;--info:oklch(65% .13 250);--info-foreground:#fff;--sidebar:#faf9f8;--sidebar-foreground:#141f2e;--sidebar-primary:#141f2e;--sidebar-primary-foreground:#fafafa;--sidebar-accent:#f2f0ed;--sidebar-accent-foreground:#141f2e;--sidebar-border:#e8e6e3;--sidebar-ring:#141f2e;--activity-bar:#f6f5f4;--activity-bar-foreground:#5e718d;--activity-bar-foreground-active:#141f2e;--activity-bar-badge:#141f2e;--activity-bar-badge-foreground:#fafafa;--terminal-background:#141f2e;--terminal-foreground:#ebebeb;--chart-1:#141f2e;--chart-2:#a89d8a;--chart-3:oklch(65% .13 250);--chart-4:oklch(68% .16 150);--chart-5:oklch(78% .14 80);--radius:.375rem}.dark{color-scheme:dark;--background:#0e121b;--foreground:#f9fafb;--primary:#f9fafb;--primary-foreground:#121621;--secondary:#1b212d;--secondary-foreground:#f9fafb;--muted:#1b212d;--muted-foreground:#8596ad;--accent:#1f2533;--accent-foreground:#f9fafb;--border:#252b37;--input:#1b212d;--ring:#9fafc6;--card:#121721;--card-foreground:#f9fafb;--popover:#121721;--popover-foreground:#f9fafb;--success:oklch(72% .19 150);--success-foreground:#121621;--warning:oklch(82% .16 80);--warning-foreground:#121621;--error:oklch(70% .22 25);--error-foreground:#fff;--info:oklch(70% .15 250);--info-foreground:#fff;--sidebar:#121721;--sidebar-foreground:#f9fafb;--sidebar-primary:#3077e8;--sidebar-primary-foreground:#fff;--sidebar-accent:#1f2533;--sidebar-accent-foreground:#f9fafb;--sidebar-border:#252b37;--sidebar-ring:#3077e8;--activity-bar:#10141e;--activity-bar-foreground:#7588a3;--activity-bar-foreground-active:#f9fafb;--activity-bar-badge:#3077e8;--activity-bar-badge-foreground:#fff;--terminal-background:#0c1018;--terminal-foreground:#e8ebee;--chart-1:#f9fafb;--chart-2:#8596ad;--chart-3:oklch(70% .15 250);--chart-4:oklch(72% .19 150);--chart-5:oklch(82% .16 80)}@keyframes animate-in{0%{opacity:var(--tw-enter-opacity,1);transform:translate(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0))scale(var(--tw-enter-scale,1))}}@keyframes animate-out{to{opacity:var(--tw-exit-opacity,0);transform:translate(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0))scale(var(--tw-exit-scale,1))}}@keyframes snake-move{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}@keyframes gradient-shift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes morph{0%,to{border-radius:60% 40% 30% 70%/60% 30% 70% 40%;transform:translate(0)rotate(0)}25%{border-radius:30% 60% 70% 40%/50% 60% 30%;transform:translate(10%,10%)rotate(90deg)}50%{border-radius:50% 60% 30%/30% 60% 70% 40%;transform:translateY(20%)rotate(180deg)}75%{border-radius:60% 40% 60% 30%/60% 30% 40% 70%;transform:translate(-10%,10%)rotate(270deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 5px var(--primary),0 0 20px var(--primary)}50%{box-shadow:0 0 20px var(--primary),0 0 40px var(--primary)}}@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-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-scroll-snap-strictness{syntax:"*";inherits:false;initial-value:proximity}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-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-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes pulse{50%{opacity:.5}}
|
package/dist/styles.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
|
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Animation presets for Motion (Framer Motion for Solid)
|
|
3
|
+
*/
|
|
4
|
+
export declare const springConfig: {
|
|
5
|
+
default: {
|
|
6
|
+
stiffness: number;
|
|
7
|
+
damping: number;
|
|
8
|
+
};
|
|
9
|
+
gentle: {
|
|
10
|
+
stiffness: number;
|
|
11
|
+
damping: number;
|
|
12
|
+
};
|
|
13
|
+
snappy: {
|
|
14
|
+
stiffness: number;
|
|
15
|
+
damping: number;
|
|
16
|
+
};
|
|
17
|
+
bouncy: {
|
|
18
|
+
stiffness: number;
|
|
19
|
+
damping: number;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
export declare const duration: {
|
|
23
|
+
instant: number;
|
|
24
|
+
fast: number;
|
|
25
|
+
normal: number;
|
|
26
|
+
slow: number;
|
|
27
|
+
slower: number;
|
|
28
|
+
};
|
|
29
|
+
export declare const easing: {
|
|
30
|
+
easeOut: readonly [0.33, 1, 0.68, 1];
|
|
31
|
+
easeIn: readonly [0.32, 0, 0.67, 0];
|
|
32
|
+
easeInOut: readonly [0.65, 0, 0.35, 1];
|
|
33
|
+
spring: readonly [0.175, 0.885, 0.32, 1.275];
|
|
34
|
+
};
|
|
35
|
+
/**
|
|
36
|
+
* Common animation variants
|
|
37
|
+
*/
|
|
38
|
+
export declare const fadeIn: {
|
|
39
|
+
initial: {
|
|
40
|
+
opacity: number;
|
|
41
|
+
};
|
|
42
|
+
animate: {
|
|
43
|
+
opacity: number;
|
|
44
|
+
};
|
|
45
|
+
exit: {
|
|
46
|
+
opacity: number;
|
|
47
|
+
};
|
|
48
|
+
transition: {
|
|
49
|
+
duration: number;
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
export declare const slideInFromLeft: {
|
|
53
|
+
initial: {
|
|
54
|
+
x: number;
|
|
55
|
+
opacity: number;
|
|
56
|
+
};
|
|
57
|
+
animate: {
|
|
58
|
+
x: number;
|
|
59
|
+
opacity: number;
|
|
60
|
+
};
|
|
61
|
+
exit: {
|
|
62
|
+
x: number;
|
|
63
|
+
opacity: number;
|
|
64
|
+
};
|
|
65
|
+
transition: {
|
|
66
|
+
duration: number;
|
|
67
|
+
ease: readonly [0.33, 1, 0.68, 1];
|
|
68
|
+
};
|
|
69
|
+
};
|
|
70
|
+
export declare const slideInFromRight: {
|
|
71
|
+
initial: {
|
|
72
|
+
x: number;
|
|
73
|
+
opacity: number;
|
|
74
|
+
};
|
|
75
|
+
animate: {
|
|
76
|
+
x: number;
|
|
77
|
+
opacity: number;
|
|
78
|
+
};
|
|
79
|
+
exit: {
|
|
80
|
+
x: number;
|
|
81
|
+
opacity: number;
|
|
82
|
+
};
|
|
83
|
+
transition: {
|
|
84
|
+
duration: number;
|
|
85
|
+
ease: readonly [0.33, 1, 0.68, 1];
|
|
86
|
+
};
|
|
87
|
+
};
|
|
88
|
+
export declare const slideInFromTop: {
|
|
89
|
+
initial: {
|
|
90
|
+
y: number;
|
|
91
|
+
opacity: number;
|
|
92
|
+
};
|
|
93
|
+
animate: {
|
|
94
|
+
y: number;
|
|
95
|
+
opacity: number;
|
|
96
|
+
};
|
|
97
|
+
exit: {
|
|
98
|
+
y: number;
|
|
99
|
+
opacity: number;
|
|
100
|
+
};
|
|
101
|
+
transition: {
|
|
102
|
+
duration: number;
|
|
103
|
+
ease: readonly [0.33, 1, 0.68, 1];
|
|
104
|
+
};
|
|
105
|
+
};
|
|
106
|
+
export declare const slideInFromBottom: {
|
|
107
|
+
initial: {
|
|
108
|
+
y: number;
|
|
109
|
+
opacity: number;
|
|
110
|
+
};
|
|
111
|
+
animate: {
|
|
112
|
+
y: number;
|
|
113
|
+
opacity: number;
|
|
114
|
+
};
|
|
115
|
+
exit: {
|
|
116
|
+
y: number;
|
|
117
|
+
opacity: number;
|
|
118
|
+
};
|
|
119
|
+
transition: {
|
|
120
|
+
duration: number;
|
|
121
|
+
ease: readonly [0.33, 1, 0.68, 1];
|
|
122
|
+
};
|
|
123
|
+
};
|
|
124
|
+
export declare const scaleIn: {
|
|
125
|
+
initial: {
|
|
126
|
+
scale: number;
|
|
127
|
+
opacity: number;
|
|
128
|
+
};
|
|
129
|
+
animate: {
|
|
130
|
+
scale: number;
|
|
131
|
+
opacity: number;
|
|
132
|
+
};
|
|
133
|
+
exit: {
|
|
134
|
+
scale: number;
|
|
135
|
+
opacity: number;
|
|
136
|
+
};
|
|
137
|
+
transition: {
|
|
138
|
+
duration: number;
|
|
139
|
+
ease: readonly [0.33, 1, 0.68, 1];
|
|
140
|
+
};
|
|
141
|
+
};
|
|
142
|
+
export declare const popIn: {
|
|
143
|
+
initial: {
|
|
144
|
+
scale: number;
|
|
145
|
+
opacity: number;
|
|
146
|
+
};
|
|
147
|
+
animate: {
|
|
148
|
+
scale: number;
|
|
149
|
+
opacity: number;
|
|
150
|
+
};
|
|
151
|
+
exit: {
|
|
152
|
+
scale: number;
|
|
153
|
+
opacity: number;
|
|
154
|
+
};
|
|
155
|
+
transition: {
|
|
156
|
+
stiffness: number;
|
|
157
|
+
damping: number;
|
|
158
|
+
type: string;
|
|
159
|
+
};
|
|
160
|
+
};
|
|
161
|
+
/**
|
|
162
|
+
* Sidebar animation
|
|
163
|
+
*/
|
|
164
|
+
export declare const sidebarVariants: {
|
|
165
|
+
open: {
|
|
166
|
+
width: number;
|
|
167
|
+
transition: {
|
|
168
|
+
duration: number;
|
|
169
|
+
ease: readonly [0.33, 1, 0.68, 1];
|
|
170
|
+
};
|
|
171
|
+
};
|
|
172
|
+
collapsed: {
|
|
173
|
+
width: number;
|
|
174
|
+
transition: {
|
|
175
|
+
duration: number;
|
|
176
|
+
ease: readonly [0.33, 1, 0.68, 1];
|
|
177
|
+
};
|
|
178
|
+
};
|
|
179
|
+
closed: {
|
|
180
|
+
width: number;
|
|
181
|
+
transition: {
|
|
182
|
+
duration: number;
|
|
183
|
+
ease: readonly [0.33, 1, 0.68, 1];
|
|
184
|
+
};
|
|
185
|
+
};
|
|
186
|
+
};
|
|
187
|
+
/**
|
|
188
|
+
* Panel resize animation
|
|
189
|
+
*/
|
|
190
|
+
export declare const panelResize: {
|
|
191
|
+
transition: {
|
|
192
|
+
duration: number;
|
|
193
|
+
ease: readonly [0.33, 1, 0.68, 1];
|
|
194
|
+
};
|
|
195
|
+
};
|
|
196
|
+
/**
|
|
197
|
+
* List item stagger animation
|
|
198
|
+
*/
|
|
199
|
+
export declare const listContainer: {
|
|
200
|
+
animate: {
|
|
201
|
+
transition: {
|
|
202
|
+
staggerChildren: number;
|
|
203
|
+
};
|
|
204
|
+
};
|
|
205
|
+
};
|
|
206
|
+
export declare const listItem: {
|
|
207
|
+
initial: {
|
|
208
|
+
opacity: number;
|
|
209
|
+
y: number;
|
|
210
|
+
};
|
|
211
|
+
animate: {
|
|
212
|
+
opacity: number;
|
|
213
|
+
y: number;
|
|
214
|
+
};
|
|
215
|
+
exit: {
|
|
216
|
+
opacity: number;
|
|
217
|
+
y: number;
|
|
218
|
+
};
|
|
219
|
+
transition: {
|
|
220
|
+
duration: number;
|
|
221
|
+
};
|
|
222
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
type CssPropertyName = string;
|
|
2
|
+
/**
|
|
3
|
+
* Apply inline styles to `document.body` with proper restore semantics.
|
|
4
|
+
*
|
|
5
|
+
* - Supports nested locks (ref-count via stack per property).
|
|
6
|
+
* - Restores the previous inline value when the last lock is released.
|
|
7
|
+
*/
|
|
8
|
+
export declare function lockBodyStyle(styles: Record<CssPropertyName, string>): () => void;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Grid collision detection utilities for workspace layout
|
|
3
|
+
*/
|
|
4
|
+
export interface GridPosition {
|
|
5
|
+
col: number;
|
|
6
|
+
row: number;
|
|
7
|
+
colSpan: number;
|
|
8
|
+
rowSpan: number;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Check if two grid positions overlap using AABB collision detection
|
|
12
|
+
*/
|
|
13
|
+
export declare function checkCollision(a: GridPosition, b: GridPosition): boolean;
|
|
14
|
+
/**
|
|
15
|
+
* Check if a position collides with any widget in the list (excluding self)
|
|
16
|
+
*/
|
|
17
|
+
export declare function hasCollision(position: GridPosition, widgets: Array<{
|
|
18
|
+
id: string;
|
|
19
|
+
position: GridPosition;
|
|
20
|
+
}>, excludeId?: string): boolean;
|
|
21
|
+
/**
|
|
22
|
+
* Find a valid position for a new widget by scanning the grid
|
|
23
|
+
*/
|
|
24
|
+
export declare function findFreePosition(widgets: Array<{
|
|
25
|
+
id: string;
|
|
26
|
+
position: GridPosition;
|
|
27
|
+
}>, colSpan: number, rowSpan: number, maxCols?: number): GridPosition;
|
|
28
|
+
/**
|
|
29
|
+
* Constrain a position to valid grid bounds
|
|
30
|
+
*/
|
|
31
|
+
export declare function constrainPosition(position: GridPosition, minColSpan?: number, minRowSpan?: number, maxCols?: number): GridPosition;
|