fluxy-bot 0.1.21 → 0.1.22
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/client/public/fluxy_say_hi.webm +0 -0
- package/client/src/components/Onboard/OnboardWizard.tsx +26 -26
- package/client/src/styles/globals.css +56 -1
- package/dist/assets/{index-CKCTHjT9.js → index-CW83Kbey.js} +1 -1
- package/dist/assets/index-Dpj8titN.css +1 -0
- package/dist/fluxy_say_hi.webm +0 -0
- package/dist/index.html +2 -2
- package/dist/sw.js +1 -1
- package/package.json +1 -1
- package/dist/assets/index-3x-dxlA1.css +0 -1
|
Binary file
|
|
@@ -35,7 +35,7 @@ const MODELS: Record<string, { id: string; label: string }[]> = {
|
|
|
35
35
|
const TOTAL_STEPS = 6; // 0..5
|
|
36
36
|
|
|
37
37
|
const HANDLES = [
|
|
38
|
-
{ tier: 'premium', label: (n: string) => `${n}.fluxy.bot`, badge: '$5', badgeCls: 'bg-
|
|
38
|
+
{ tier: 'premium', label: (n: string) => `${n}.fluxy.bot`, badge: '$5', badgeCls: 'bg-[#AF27E3]/15 text-[#AF27E3] border-[#AF27E3]/20', highlight: true },
|
|
39
39
|
{ tier: 'at', label: (n: string) => `${n}.at.fluxy.bot`, badge: 'Free', badgeCls: 'bg-emerald-500/10 text-emerald-400 border-emerald-500/20', highlight: false },
|
|
40
40
|
] as const;
|
|
41
41
|
|
|
@@ -61,7 +61,7 @@ function ModelDropdown({ models, value, onChange }: { models: { id: string; labe
|
|
|
61
61
|
<button
|
|
62
62
|
type="button"
|
|
63
63
|
onClick={() => setOpen((o) => !o)}
|
|
64
|
-
className="w-full flex items-center justify-between bg-white/[0.03] border border-white/[0.08] text-white rounded-xl px-4 py-2.5 text-[13px] outline-none hover:border-white/15 focus:border-
|
|
64
|
+
className="w-full flex items-center justify-between bg-white/[0.03] border border-white/[0.08] text-white rounded-xl px-4 py-2.5 text-[13px] outline-none hover:border-white/15 focus:border-[#AF27E3]/30 transition-colors"
|
|
65
65
|
>
|
|
66
66
|
<span className={selected ? 'text-white' : 'text-white/20'}>
|
|
67
67
|
{selected ? selected.label : 'Choose a model...'}
|
|
@@ -76,7 +76,7 @@ function ModelDropdown({ models, value, onChange }: { models: { id: string; labe
|
|
|
76
76
|
onClick={() => { onChange(m.id); setOpen(false); }}
|
|
77
77
|
className={`w-full text-left px-4 py-2 text-[13px] transition-colors ${
|
|
78
78
|
value === m.id
|
|
79
|
-
? 'text-
|
|
79
|
+
? 'text-[#AF27E3] bg-[#AF27E3]/10'
|
|
80
80
|
: 'text-white/70 hover:bg-white/[0.04] hover:text-white'
|
|
81
81
|
}`}
|
|
82
82
|
>
|
|
@@ -495,9 +495,9 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
495
495
|
/* ── Styles ── */
|
|
496
496
|
|
|
497
497
|
const inputCls =
|
|
498
|
-
'w-full bg-white/[0.05] border border-white/[0.08] text-white rounded-xl px-4 py-3 text-base outline-none
|
|
498
|
+
'w-full bg-white/[0.05] border border-white/[0.08] text-white rounded-xl px-4 py-3 text-base outline-none input-glow placeholder:text-white/20 transition-all';
|
|
499
499
|
const inputSmCls =
|
|
500
|
-
'w-full bg-white/[0.03] border border-white/[0.08] text-white rounded-xl px-4 py-2.5 text-[13px] outline-none
|
|
500
|
+
'w-full bg-white/[0.03] border border-white/[0.08] text-white rounded-xl px-4 py-2.5 text-[13px] outline-none input-glow placeholder:text-white/20 transition-all';
|
|
501
501
|
|
|
502
502
|
return (
|
|
503
503
|
<div className="fixed inset-0 z-[200] flex items-center justify-center p-4">
|
|
@@ -516,9 +516,9 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
516
516
|
key={i}
|
|
517
517
|
className={`h-1.5 rounded-full transition-all duration-300 ${
|
|
518
518
|
i === step
|
|
519
|
-
? 'w-7 bg-
|
|
519
|
+
? 'w-7 bg-gradient-brand'
|
|
520
520
|
: i < step
|
|
521
|
-
? 'w-1.5 bg-
|
|
521
|
+
? 'w-1.5 bg-gradient-brand opacity-60'
|
|
522
522
|
: 'w-1.5 bg-white/10'
|
|
523
523
|
}`}
|
|
524
524
|
/>
|
|
@@ -538,7 +538,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
538
538
|
{/* ── Step 0: Welcome ── */}
|
|
539
539
|
{step === 0 && (
|
|
540
540
|
<div className="flex flex-col items-center text-center">
|
|
541
|
-
<
|
|
541
|
+
<video src="/fluxy_say_hi.webm" autoPlay loop muted playsInline className="h-[180px] mb-4" />
|
|
542
542
|
<h1 className="text-2xl font-bold text-white tracking-tight">
|
|
543
543
|
Welcome to Fluxy
|
|
544
544
|
</h1>
|
|
@@ -547,7 +547,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
547
547
|
</p>
|
|
548
548
|
<button
|
|
549
549
|
onClick={next}
|
|
550
|
-
className="mt-6 px-7 py-3 bg-
|
|
550
|
+
className="mt-6 px-7 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center gap-2"
|
|
551
551
|
>
|
|
552
552
|
Get Started
|
|
553
553
|
<ArrowRight className="h-4 w-4" />
|
|
@@ -577,7 +577,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
577
577
|
<button
|
|
578
578
|
onClick={next}
|
|
579
579
|
disabled={!canNext}
|
|
580
|
-
className="shrink-0 h-12 w-12 flex items-center justify-center rounded-full bg-
|
|
580
|
+
className="shrink-0 h-12 w-12 flex items-center justify-center rounded-full bg-gradient-brand hover:opacity-90 text-white transition-colors disabled:opacity-30"
|
|
581
581
|
>
|
|
582
582
|
<ArrowRight className="h-5 w-5" />
|
|
583
583
|
</button>
|
|
@@ -608,7 +608,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
608
608
|
<div className="flex gap-2 mt-4">
|
|
609
609
|
<button
|
|
610
610
|
onClick={next}
|
|
611
|
-
className="flex-1 py-3 bg-
|
|
611
|
+
className="flex-1 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2"
|
|
612
612
|
>
|
|
613
613
|
Continue
|
|
614
614
|
<ArrowRight className="h-4 w-4" />
|
|
@@ -659,7 +659,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
659
659
|
{handleStatus && botName.length > 0 && !registered && (
|
|
660
660
|
<div className="absolute right-4 top-1/2 -translate-y-1/2">
|
|
661
661
|
{handleStatus === 'checking' && (
|
|
662
|
-
<div className="w-5 h-5 border-2 border-white/10 border-t-
|
|
662
|
+
<div className="w-5 h-5 border-2 border-white/10 border-t-[#04D1FE] rounded-full animate-spin" />
|
|
663
663
|
)}
|
|
664
664
|
{handleStatus === 'invalid' && (
|
|
665
665
|
<div className="w-6 h-6 rounded-full bg-amber-500/15 flex items-center justify-center">
|
|
@@ -693,8 +693,8 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
693
693
|
? 'border-white/[0.04] bg-transparent opacity-50 cursor-not-allowed'
|
|
694
694
|
: selectedTier === h.tier
|
|
695
695
|
? h.highlight
|
|
696
|
-
? 'border-
|
|
697
|
-
: 'border-
|
|
696
|
+
? 'border-[#AF27E3]/40 bg-[#AF27E3]/[0.06]'
|
|
697
|
+
: 'border-[#AF27E3]/30 bg-white/[0.04]'
|
|
698
698
|
: 'border-white/[0.06] bg-transparent hover:border-white/10 hover:bg-white/[0.02]'
|
|
699
699
|
}`}
|
|
700
700
|
>
|
|
@@ -732,7 +732,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
732
732
|
<button
|
|
733
733
|
onClick={showChangeConfirm ? onChangeHandle : onClaimHandle}
|
|
734
734
|
disabled={registering || changingHandle}
|
|
735
|
-
className="w-full mt-4 py-3 bg-
|
|
735
|
+
className="w-full mt-4 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40"
|
|
736
736
|
>
|
|
737
737
|
{(registering || changingHandle) ? (
|
|
738
738
|
<><LoaderCircle className="h-4 w-4 animate-spin" />{showChangeConfirm ? 'Changing...' : 'Claiming...'}</>
|
|
@@ -746,7 +746,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
746
746
|
{registered && (
|
|
747
747
|
<button
|
|
748
748
|
onClick={next}
|
|
749
|
-
className="w-full mt-4 py-3 bg-
|
|
749
|
+
className="w-full mt-4 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2"
|
|
750
750
|
>
|
|
751
751
|
Continue
|
|
752
752
|
<ArrowRight className="h-4 w-4" />
|
|
@@ -930,7 +930,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
930
930
|
<button
|
|
931
931
|
onClick={next}
|
|
932
932
|
disabled={!canNext}
|
|
933
|
-
className="w-full mt-5 py-3 bg-
|
|
933
|
+
className="w-full mt-5 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40"
|
|
934
934
|
>
|
|
935
935
|
Continue
|
|
936
936
|
<ArrowRight className="h-4 w-4" />
|
|
@@ -956,7 +956,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
956
956
|
onClick={() => handleProviderChange(p.id)}
|
|
957
957
|
className={`flex-1 relative rounded-xl border transition-all duration-200 p-3 text-left ${
|
|
958
958
|
provider === p.id
|
|
959
|
-
? 'bg-white/[0.04] border-
|
|
959
|
+
? 'bg-white/[0.04] border-[#AF27E3]/40'
|
|
960
960
|
: 'bg-transparent border-white/[0.06] hover:border-white/10 hover:bg-white/[0.02]'
|
|
961
961
|
}`}
|
|
962
962
|
>
|
|
@@ -978,7 +978,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
978
978
|
<Check className="h-2.5 w-2.5 text-emerald-400" />
|
|
979
979
|
</div>
|
|
980
980
|
) : provider === p.id ? (
|
|
981
|
-
<div className="absolute top-2 right-2 w-2 h-2 rounded-full bg-
|
|
981
|
+
<div className="absolute top-2 right-2 w-2 h-2 rounded-full bg-gradient-brand" />
|
|
982
982
|
) : null}
|
|
983
983
|
</button>
|
|
984
984
|
))}
|
|
@@ -1018,7 +1018,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
1018
1018
|
|
|
1019
1019
|
<button
|
|
1020
1020
|
onClick={handleAnthropicAuth}
|
|
1021
|
-
className="w-full py-2.5 px-4 bg-
|
|
1021
|
+
className="w-full py-2.5 px-4 bg-gradient-brand hover:opacity-90 text-white text-[13px] font-medium rounded-xl transition-colors flex items-center justify-center gap-2"
|
|
1022
1022
|
>
|
|
1023
1023
|
{oauthStarted ? (
|
|
1024
1024
|
<><ExternalLink className="h-3.5 w-3.5 opacity-60" />Open authentication page again</>
|
|
@@ -1047,7 +1047,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
1047
1047
|
<button
|
|
1048
1048
|
onClick={handleAnthropicConnect}
|
|
1049
1049
|
disabled={!anthropicCode.trim() || isExchanging}
|
|
1050
|
-
className="w-full py-2.5 px-4 bg-
|
|
1050
|
+
className="w-full py-2.5 px-4 bg-gradient-brand hover:opacity-90 text-white text-[13px] font-medium rounded-xl transition-colors flex items-center justify-center gap-2 disabled:opacity-40"
|
|
1051
1051
|
>
|
|
1052
1052
|
{isExchanging ? (<><LoaderCircle className="h-3.5 w-3.5 animate-spin" />Verifying...</>) : 'Connect'}
|
|
1053
1053
|
</button>
|
|
@@ -1164,7 +1164,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
1164
1164
|
<button
|
|
1165
1165
|
onClick={next}
|
|
1166
1166
|
disabled={!canNext}
|
|
1167
|
-
className="w-full mt-4 py-3 bg-
|
|
1167
|
+
className="w-full mt-4 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40"
|
|
1168
1168
|
>
|
|
1169
1169
|
Continue
|
|
1170
1170
|
<ArrowRight className="h-4 w-4" />
|
|
@@ -1192,7 +1192,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
1192
1192
|
onClick={() => setWhisperEnabled((v) => !v)}
|
|
1193
1193
|
className={`w-full mt-5 rounded-xl border transition-all duration-200 p-4 text-left ${
|
|
1194
1194
|
whisperEnabled
|
|
1195
|
-
? 'bg-white/[0.04] border-
|
|
1195
|
+
? 'bg-white/[0.04] border-[#AF27E3]/40'
|
|
1196
1196
|
: 'bg-transparent border-white/[0.06] hover:border-white/10 hover:bg-white/[0.02]'
|
|
1197
1197
|
}`}
|
|
1198
1198
|
>
|
|
@@ -1205,7 +1205,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
1205
1205
|
</div>
|
|
1206
1206
|
</div>
|
|
1207
1207
|
<div className={`w-10 h-[22px] rounded-full transition-colors duration-200 flex items-center px-0.5 shrink-0 ${
|
|
1208
|
-
whisperEnabled ? 'bg-
|
|
1208
|
+
whisperEnabled ? 'bg-gradient-brand' : 'bg-white/[0.08]'
|
|
1209
1209
|
}`}>
|
|
1210
1210
|
<div className={`w-[18px] h-[18px] rounded-full bg-white shadow-sm transition-transform duration-200 ${
|
|
1211
1211
|
whisperEnabled ? 'translate-x-[18px]' : 'translate-x-0'
|
|
@@ -1232,7 +1232,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
1232
1232
|
<p className="text-amber-400/70 text-[11px] mt-1">Key looks too short</p>
|
|
1233
1233
|
)}
|
|
1234
1234
|
<div className="flex items-start gap-2.5 mt-3 bg-white/[0.02] border border-white/[0.06] rounded-xl px-4 py-3">
|
|
1235
|
-
<Mic className="h-4 w-4 text-
|
|
1235
|
+
<Mic className="h-4 w-4 text-[#AF27E3]/60 mt-0.5 shrink-0" />
|
|
1236
1236
|
<p className="text-white/35 text-[12px] leading-relaxed">
|
|
1237
1237
|
Users will see a microphone button in the chat. Audio is sent to OpenAI's Whisper API for transcription, then processed as a regular text message.
|
|
1238
1238
|
</p>
|
|
@@ -1243,7 +1243,7 @@ export default function OnboardWizard({ onComplete }: Props) {
|
|
|
1243
1243
|
<button
|
|
1244
1244
|
onClick={handleComplete}
|
|
1245
1245
|
disabled={saving || (whisperEnabled && (!whisperKey.startsWith('sk-') || whisperKey.length < 20))}
|
|
1246
|
-
className="w-full mt-5 py-3 bg-
|
|
1246
|
+
className="w-full mt-5 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40"
|
|
1247
1247
|
>
|
|
1248
1248
|
{saving ? (
|
|
1249
1249
|
<><LoaderCircle className="h-4 w-4 animate-spin" />Setting up...</>
|
|
@@ -46,10 +46,65 @@ body {
|
|
|
46
46
|
}
|
|
47
47
|
|
|
48
48
|
::selection {
|
|
49
|
-
background-color: rgba(
|
|
49
|
+
background-color: rgba(175, 39, 227, 0.25);
|
|
50
50
|
}
|
|
51
51
|
|
|
52
52
|
::-webkit-scrollbar { width: 6px; }
|
|
53
53
|
::-webkit-scrollbar-track { background: transparent; }
|
|
54
54
|
::-webkit-scrollbar-thumb { background: #3a3a3a; border-radius: 3px; }
|
|
55
55
|
::-webkit-scrollbar-thumb:hover { background: #4a4a4a; }
|
|
56
|
+
|
|
57
|
+
.text-gradient {
|
|
58
|
+
background-clip: text;
|
|
59
|
+
-webkit-background-clip: text;
|
|
60
|
+
color: transparent;
|
|
61
|
+
-webkit-text-fill-color: transparent;
|
|
62
|
+
background-image: linear-gradient(135deg, #04D1FE, #AF27E3, #FB4072);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
.bg-gradient-brand {
|
|
66
|
+
background-image: linear-gradient(135deg, #04D1FE, #AF27E3, #FB4072);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.glow-border {
|
|
70
|
+
box-shadow: 0 0 0 1px rgba(175, 39, 227, 0.1),
|
|
71
|
+
0 0 20px -5px rgba(175, 39, 227, 0.15);
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
.animated-border {
|
|
75
|
+
position: relative;
|
|
76
|
+
overflow: hidden;
|
|
77
|
+
}
|
|
78
|
+
.animated-border::before {
|
|
79
|
+
content: '';
|
|
80
|
+
position: absolute;
|
|
81
|
+
inset: -150%;
|
|
82
|
+
background: conic-gradient(
|
|
83
|
+
from 0deg,
|
|
84
|
+
#04D1FE,
|
|
85
|
+
#AF27E3,
|
|
86
|
+
#FB4072,
|
|
87
|
+
#04D1FE
|
|
88
|
+
);
|
|
89
|
+
animation: border-spin 3s linear infinite;
|
|
90
|
+
}
|
|
91
|
+
.animated-border > * {
|
|
92
|
+
position: relative;
|
|
93
|
+
z-index: 1;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
.animated-border-slow::before {
|
|
97
|
+
animation-duration: 5s;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
.input-glow:focus {
|
|
101
|
+
border-color: rgba(175, 39, 227, 0.4);
|
|
102
|
+
box-shadow: 0 0 0 1px rgba(175, 39, 227, 0.15),
|
|
103
|
+
0 0 20px -5px rgba(175, 39, 227, 0.25),
|
|
104
|
+
0 0 4px -1px rgba(4, 209, 254, 0.1);
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
@keyframes border-spin {
|
|
108
|
+
0% { transform: rotate(0deg); }
|
|
109
|
+
100% { transform: rotate(360deg); }
|
|
110
|
+
}
|
|
@@ -97,4 +97,4 @@ In order to be iterable, non-array objects must have a [Symbol.iterator]() metho
|
|
|
97
97
|
${C}px !important;
|
|
98
98
|
${N}px !important;
|
|
99
99
|
}
|
|
100
|
-
`),()=>{F.contains(L)&&F.removeChild(L)}},[t]),S.jsx(E9,{isPresent:t,childRef:d,sizeRef:f,pop:l,children:l===!1?e:A.cloneElement(e,{ref:g})})}const v9=({children:e,initial:t,isPresent:n,onExitComplete:r,custom:o,presenceAffectsLayout:l,mode:u,anchorX:d,anchorY:f,root:p})=>{const m=kv(x9),g=A.useId();let y=!0,E=A.useMemo(()=>(y=!1,{id:g,initial:t,isPresent:n,custom:o,onExitComplete:v=>{m.set(v,!0);for(const T of m.values())if(!T)return;r&&r()},register:v=>(m.set(v,!1),()=>m.delete(v))}),[n,m,r]);return l&&y&&(E={...E}),A.useMemo(()=>{m.forEach((v,T)=>m.set(T,!1))},[n]),A.useEffect(()=>{!n&&!m.size&&r&&r()},[n]),e=S.jsx(S9,{pop:u==="popLayout",isPresent:n,anchorX:d,anchorY:f,root:p,children:e}),S.jsx(kd.Provider,{value:E,children:e})};function x9(){return new Map}function h1(e=!0){const t=A.useContext(kd);if(t===null)return[!0,null];const{isPresent:n,onExitComplete:r,register:o}=t,l=A.useId();A.useEffect(()=>{if(e)return o(l)},[e]);const u=A.useCallback(()=>e&&r&&r(l),[l,r,e]);return!n&&r?[!1,u]:[!0]}const pc=e=>e.key||"";function j_(e){const t=[];return A.Children.forEach(e,n=>{A.isValidElement(n)&&t.push(n)}),t}const qc=({children:e,custom:t,initial:n=!0,onExitComplete:r,presenceAffectsLayout:o=!0,mode:l="sync",propagate:u=!1,anchorX:d="left",anchorY:f="top",root:p})=>{const[m,g]=h1(u),y=A.useMemo(()=>j_(e),[e]),E=u&&!m?[]:y.map(pc),v=A.useRef(!0),T=A.useRef(y),k=kv(()=>new Map),w=A.useRef(new Set),[C,N]=A.useState(y),[L,F]=A.useState(y);HO(()=>{v.current=!1,T.current=y;for(let B=0;B<L.length;B++){const W=pc(L[B]);E.includes(W)?(k.delete(W),w.current.delete(W)):k.get(W)!==!0&&k.set(W,!1)}},[L,E.length,E.join("-")]);const D=[];if(y!==C){let B=[...y];for(let W=0;W<L.length;W++){const U=L[W],X=pc(U);E.includes(X)||(B.splice(W,0,U),D.push(U))}return l==="wait"&&D.length&&(B=D),F(j_(B)),N(y),null}const{forceRender:z}=A.useContext(Av);return S.jsx(S.Fragment,{children:L.map(B=>{const W=pc(B),U=u&&!m?!1:y===L||E.includes(W),X=()=>{if(w.current.has(W))return;if(w.current.add(W),k.has(W))k.set(W,!0);else return;let Q=!0;k.forEach(te=>{te||(Q=!1)}),Q&&(z?.(),F(T.current),u&&g?.(),r&&r())};return S.jsx(v9,{isPresent:U,initial:!v.current||n?void 0:!1,custom:t,presenceAffectsLayout:o,mode:l,root:p,onExitComplete:U?void 0:X,anchorX:d,anchorY:f,children:B},W)})})},b1=A.createContext({strict:!1}),z_={animation:["animate","variants","whileHover","whileTap","exit","whileInView","whileFocus","whileDrag"],exit:["exit"],drag:["drag","dragControls"],focus:["whileFocus"],hover:["whileHover","onHoverStart","onHoverEnd"],tap:["whileTap","onTap","onTapStart","onTapCancel"],pan:["onPan","onPanStart","onPanSessionStart","onPanEnd"],inView:["whileInView","onViewportEnter","onViewportLeave"],layout:["layout","layoutId"]};let G_=!1;function w9(){if(G_)return;const e={};for(const t in z_)e[t]={isEnabled:n=>z_[t].some(r=>!!n[r])};qI(e),G_=!0}function y1(){return w9(),u8()}function T9(e){const t=y1();for(const n in e)t[n]={...t[n],...e[n]};qI(t)}const A9=new Set(["animate","exit","variants","initial","style","values","variants","transition","transformTemplate","custom","inherit","onBeforeLayoutMeasure","onAnimationStart","onAnimationComplete","onUpdate","onDragStart","onDrag","onDragEnd","onMeasureDragConstraints","onDirectionLock","onDragTransitionEnd","_dragX","_dragY","onHoverStart","onHoverEnd","onViewportEnter","onViewportLeave","globalTapTarget","propagate","ignoreStrict","viewport"]);function Yc(e){return e.startsWith("while")||e.startsWith("drag")&&e!=="draggable"||e.startsWith("layout")||e.startsWith("onTap")||e.startsWith("onPan")||e.startsWith("onLayout")||A9.has(e)}let E1=e=>!Yc(e);function k9(e){typeof e=="function"&&(E1=t=>t.startsWith("on")?!Yc(t):e(t))}try{k9(require("@emotion/is-prop-valid").default)}catch{}function R9(e,t,n){const r={};for(const o in e)o==="values"&&typeof e.values=="object"||(E1(o)||n===!0&&Yc(o)||!t&&!Yc(o)||e.draggable&&o.startsWith("onDrag"))&&(r[o]=e[o]);return r}const Nd=A.createContext({});function _9(e,t){if(_d(e)){const{initial:n,animate:r}=e;return{initial:n===!1||fl(n)?n:void 0,animate:fl(r)?r:void 0}}return e.inherit!==!1?t:{}}function N9(e){const{initial:t,animate:n}=_9(e,A.useContext(Nd));return A.useMemo(()=>({initial:t,animate:n}),[$_(t),$_(n)])}function $_(e){return Array.isArray(e)?e.join(" "):e}const ex=()=>({style:{},transform:{},transformOrigin:{},vars:{}});function S1(e,t,n){for(const r in t)!Wt(t[r])&&!JI(r,n)&&(e[r]=t[r])}function C9({transformTemplate:e},t){return A.useMemo(()=>{const n=ex();return Zv(n,t,e),Object.assign({},n.vars,n.style)},[t])}function O9(e,t){const n=e.style||{},r={};return S1(r,n,e),Object.assign(r,C9(e,t)),r}function I9(e,t){const n={},r=O9(e,t);return e.drag&&e.dragListener!==!1&&(n.draggable=!1,r.userSelect=r.WebkitUserSelect=r.WebkitTouchCallout="none",r.touchAction=e.drag===!0?"none":`pan-${e.drag==="x"?"y":"x"}`),e.tabIndex===void 0&&(e.onTap||e.onTapStart||e.whileTap)&&(n.tabIndex=0),n.style=r,n}const v1=()=>({...ex(),attrs:{}});function D9(e,t,n,r){const o=A.useMemo(()=>{const l=v1();return e1(l,t,n1(r),e.transformTemplate,e.style),{...l.attrs,style:{...l.style}}},[t]);if(e.style){const l={};S1(l,e.style,e),o.style={...l,...o.style}}return o}const L9=["animate","circle","defs","desc","ellipse","g","image","line","filter","marker","mask","metadata","path","pattern","polygon","polyline","rect","stop","switch","symbol","svg","text","tspan","use","view"];function tx(e){return typeof e!="string"||e.includes("-")?!1:!!(L9.indexOf(e)>-1||/[A-Z]/u.test(e))}function M9(e,t,n,{latestValues:r},o,l=!1,u){const f=(u??tx(e)?D9:I9)(t,r,o,e),p=R9(t,typeof e=="string",l),m=e!==A.Fragment?{...p,...f,ref:n}:{},{children:g}=t,y=A.useMemo(()=>Wt(g)?g.get():g,[g]);return A.createElement(e,{...m,children:y})}function F9({scrapeMotionValuesFromProps:e,createRenderState:t},n,r,o){return{latestValues:U9(n,r,o,e),renderState:t()}}function U9(e,t,n,r){const o={},l=r(e,{});for(const y in l)o[y]=Ac(l[y]);let{initial:u,animate:d}=e;const f=_d(e),p=HI(e);t&&p&&!f&&e.inherit!==!1&&(u===void 0&&(u=t.initial),d===void 0&&(d=t.animate));let m=n?n.initial===!1:!1;m=m||u===!1;const g=m?d:u;if(g&&typeof g!="boolean"&&!Rd(g)){const y=Array.isArray(g)?g:[g];for(let E=0;E<y.length;E++){const v=$v(e,y[E]);if(v){const{transitionEnd:T,transition:k,...w}=v;for(const C in w){let N=w[C];if(Array.isArray(N)){const L=m?N.length-1:0;N=N[L]}N!==null&&(o[C]=N)}for(const C in T)o[C]=T[C]}}}return o}const x1=e=>(t,n)=>{const r=A.useContext(Nd),o=A.useContext(kd),l=()=>F9(e,t,r,o);return n?l():kv(l)},B9=x1({scrapeMotionValuesFromProps:Qv,createRenderState:ex}),P9=x1({scrapeMotionValuesFromProps:a1,createRenderState:v1}),j9=Symbol.for("motionComponentSymbol");function z9(e,t,n){const r=A.useRef(n);A.useInsertionEffect(()=>{r.current=n});const o=A.useRef(null);return A.useCallback(l=>{l&&e.onMount?.(l),t&&(l?t.mount(l):t.unmount());const u=r.current;if(typeof u=="function")if(l){const d=u(l);typeof d=="function"&&(o.current=d)}else o.current?(o.current(),o.current=null):u(l);else u&&(u.current=l)},[t])}const w1=A.createContext({});function go(e){return e&&typeof e=="object"&&Object.prototype.hasOwnProperty.call(e,"current")}function G9(e,t,n,r,o,l){const{visualElement:u}=A.useContext(Nd),d=A.useContext(b1),f=A.useContext(kd),p=A.useContext(Jv),m=p.reducedMotion,g=p.skipAnimations,y=A.useRef(null),E=A.useRef(!1);r=r||d.renderer,!y.current&&r&&(y.current=r(e,{visualState:t,parent:u,props:n,presenceContext:f,blockInitialAnimation:f?f.initial===!1:!1,reducedMotionConfig:m,skipAnimations:g,isSVG:l}),E.current&&y.current&&(y.current.manuallyAnimateOnMount=!0));const v=y.current,T=A.useContext(w1);v&&!v.projection&&o&&(v.type==="html"||v.type==="svg")&&$9(y.current,n,o,T);const k=A.useRef(!1);A.useInsertionEffect(()=>{v&&k.current&&v.update(n,f)});const w=n[OI],C=A.useRef(!!w&&!window.MotionHandoffIsComplete?.(w)&&window.MotionHasOptimisedAnimation?.(w));return HO(()=>{E.current=!0,v&&(k.current=!0,window.MotionIsMounted=!0,v.updateFeatures(),v.scheduleRenderMicrotask(),C.current&&v.animationState&&v.animationState.animateChanges())}),A.useEffect(()=>{v&&(!C.current&&v.animationState&&v.animationState.animateChanges(),C.current&&(queueMicrotask(()=>{window.MotionHandoffMarkAsComplete?.(w)}),C.current=!1),v.enteringChildren=void 0)}),v}function $9(e,t,n,r){const{layoutId:o,layout:l,drag:u,dragConstraints:d,layoutScroll:f,layoutRoot:p,layoutCrossfade:m}=t;e.projection=new n(e.latestValues,t["data-framer-portal-id"]?void 0:T1(e.parent)),e.projection.setOptions({layoutId:o,layout:l,alwaysMeasureLayout:!!u||d&&go(d),visualElement:e,animationType:typeof l=="string"?l:"both",initialPromotionConfig:r,crossfade:m,layoutScroll:f,layoutRoot:p})}function T1(e){if(e)return e.options.allowProjection!==!1?e.projection:T1(e.parent)}function Lm(e,{forwardMotionProps:t=!1,type:n}={},r,o){r&&T9(r);const l=n?n==="svg":tx(e),u=l?P9:B9;function d(p,m){let g;const y={...A.useContext(Jv),...p,layoutId:H9(p)},{isStatic:E}=y,v=N9(p),T=u(p,E);if(!E&&$O){V9();const k=q9(y);g=k.MeasureLayout,v.visualElement=G9(e,T,y,o,k.ProjectionNode,l)}return S.jsxs(Nd.Provider,{value:v,children:[g&&v.visualElement?S.jsx(g,{visualElement:v.visualElement,...y}):null,M9(e,p,z9(T,v.visualElement,m),T,E,t,l)]})}d.displayName=`motion.${typeof e=="string"?e:`create(${e.displayName??e.name??""})`}`;const f=A.forwardRef(d);return f[j9]=e,f}function H9({layoutId:e}){const t=A.useContext(Av).id;return t&&e!==void 0?t+"-"+e:e}function V9(e,t){A.useContext(b1).strict}function q9(e){const t=y1(),{drag:n,layout:r}=t;if(!n&&!r)return{};const o={...n,...r};return{MeasureLayout:n?.isEnabled(e)||r?.isEnabled(e)?o.MeasureLayout:void 0,ProjectionNode:o.ProjectionNode}}function Y9(e,t){if(typeof Proxy>"u")return Lm;const n=new Map,r=(l,u)=>Lm(l,u,e,t),o=(l,u)=>r(l,u);return new Proxy(o,{get:(l,u)=>u==="create"?r:(n.has(u)||n.set(u,Lm(u,void 0,e,t)),n.get(u))})}const W9=(e,t)=>t.isSVG??tx(e)?new k8(t):new S8(t,{allowProjection:e!==A.Fragment});class K9 extends Dr{constructor(t){super(t),t.animationState||(t.animationState=O8(t))}updateAnimationControlsSubscription(){const{animate:t}=this.node.getProps();Rd(t)&&(this.unmountControls=t.subscribe(this.node))}mount(){this.updateAnimationControlsSubscription()}update(){const{animate:t}=this.node.getProps(),{animate:n}=this.node.prevProps||{};t!==n&&this.updateAnimationControlsSubscription()}unmount(){this.node.animationState.reset(),this.unmountControls?.()}}let X9=0;class Z9 extends Dr{constructor(){super(...arguments),this.id=X9++}update(){if(!this.node.presenceContext)return;const{isPresent:t,onExitComplete:n}=this.node.presenceContext,{isPresent:r}=this.node.prevPresenceContext||{};if(!this.node.animationState||t===r)return;const o=this.node.animationState.setActive("exit",!t);n&&!t&&o.then(()=>{n(this.id)})}mount(){const{register:t,onExitComplete:n}=this.node.presenceContext||{};n&&n(this.id),t&&(this.unmount=t(this.id))}unmount(){}}const Q9={animation:{Feature:K9},exit:{Feature:Z9}};function Dl(e){return{point:{x:e.pageX,y:e.pageY}}}const J9=e=>t=>Yv(t)&&e(t,Dl(t));function el(e,t,n,r){return ml(e,t,J9(n),r)}const A1=({current:e})=>e?e.ownerDocument.defaultView:null,H_=(e,t)=>Math.abs(e-t);function eY(e,t){const n=H_(e.x,t.x),r=H_(e.y,t.y);return Math.sqrt(n**2+r**2)}const V_=new Set(["auto","scroll"]);class k1{constructor(t,n,{transformPagePoint:r,contextWindow:o=window,dragSnapToOrigin:l=!1,distanceThreshold:u=3,element:d}={}){if(this.startEvent=null,this.lastMoveEvent=null,this.lastMoveEventInfo=null,this.handlers={},this.contextWindow=window,this.scrollPositions=new Map,this.removeScrollListeners=null,this.onElementScroll=E=>{this.handleScroll(E.target)},this.onWindowScroll=()=>{this.handleScroll(window)},this.updatePoint=()=>{if(!(this.lastMoveEvent&&this.lastMoveEventInfo))return;const E=Fm(this.lastMoveEventInfo,this.history),v=this.startEvent!==null,T=eY(E.offset,{x:0,y:0})>=this.distanceThreshold;if(!v&&!T)return;const{point:k}=E,{timestamp:w}=jt;this.history.push({...k,timestamp:w});const{onStart:C,onMove:N}=this.handlers;v||(C&&C(this.lastMoveEvent,E),this.startEvent=this.lastMoveEvent),N&&N(this.lastMoveEvent,E)},this.handlePointerMove=(E,v)=>{this.lastMoveEvent=E,this.lastMoveEventInfo=Mm(v,this.transformPagePoint),it.update(this.updatePoint,!0)},this.handlePointerUp=(E,v)=>{this.end();const{onEnd:T,onSessionEnd:k,resumeAnimation:w}=this.handlers;if((this.dragSnapToOrigin||!this.startEvent)&&w&&w(),!(this.lastMoveEvent&&this.lastMoveEventInfo))return;const C=Fm(E.type==="pointercancel"?this.lastMoveEventInfo:Mm(v,this.transformPagePoint),this.history);this.startEvent&&T&&T(E,C),k&&k(E,C)},!Yv(t))return;this.dragSnapToOrigin=l,this.handlers=n,this.transformPagePoint=r,this.distanceThreshold=u,this.contextWindow=o||window;const f=Dl(t),p=Mm(f,this.transformPagePoint),{point:m}=p,{timestamp:g}=jt;this.history=[{...m,timestamp:g}];const{onSessionStart:y}=n;y&&y(t,Fm(p,this.history)),this.removeListeners=Cl(el(this.contextWindow,"pointermove",this.handlePointerMove),el(this.contextWindow,"pointerup",this.handlePointerUp),el(this.contextWindow,"pointercancel",this.handlePointerUp)),d&&this.startScrollTracking(d)}startScrollTracking(t){let n=t.parentElement;for(;n;){const r=getComputedStyle(n);(V_.has(r.overflowX)||V_.has(r.overflowY))&&this.scrollPositions.set(n,{x:n.scrollLeft,y:n.scrollTop}),n=n.parentElement}this.scrollPositions.set(window,{x:window.scrollX,y:window.scrollY}),window.addEventListener("scroll",this.onElementScroll,{capture:!0}),window.addEventListener("scroll",this.onWindowScroll),this.removeScrollListeners=()=>{window.removeEventListener("scroll",this.onElementScroll,{capture:!0}),window.removeEventListener("scroll",this.onWindowScroll)}}handleScroll(t){const n=this.scrollPositions.get(t);if(!n)return;const r=t===window,o=r?{x:window.scrollX,y:window.scrollY}:{x:t.scrollLeft,y:t.scrollTop},l={x:o.x-n.x,y:o.y-n.y};l.x===0&&l.y===0||(r?this.lastMoveEventInfo&&(this.lastMoveEventInfo.point.x+=l.x,this.lastMoveEventInfo.point.y+=l.y):this.history.length>0&&(this.history[0].x-=l.x,this.history[0].y-=l.y),this.scrollPositions.set(t,o),it.update(this.updatePoint,!0))}updateHandlers(t){this.handlers=t}end(){this.removeListeners&&this.removeListeners(),this.removeScrollListeners&&this.removeScrollListeners(),this.scrollPositions.clear(),Nr(this.updatePoint)}}function Mm(e,t){return t?{point:t(e.point)}:e}function q_(e,t){return{x:e.x-t.x,y:e.y-t.y}}function Fm({point:e},t){return{point:e,delta:q_(e,R1(t)),offset:q_(e,tY(t)),velocity:nY(t,.1)}}function tY(e){return e[0]}function R1(e){return e[e.length-1]}function nY(e,t){if(e.length<2)return{x:0,y:0};let n=e.length-1,r=null;const o=R1(e);for(;n>=0&&(r=e[n],!(o.timestamp-r.timestamp>Xn(t)));)n--;if(!r)return{x:0,y:0};r===e[0]&&e.length>2&&o.timestamp-r.timestamp>Xn(t)*2&&(r=e[1]);const l=Pn(o.timestamp-r.timestamp);if(l===0)return{x:0,y:0};const u={x:(o.x-r.x)/l,y:(o.y-r.y)/l};return u.x===1/0&&(u.x=0),u.y===1/0&&(u.y=0),u}function aY(e,{min:t,max:n},r){return t!==void 0&&e<t?e=r?ut(t,e,r.min):Math.max(e,t):n!==void 0&&e>n&&(e=r?ut(n,e,r.max):Math.min(e,n)),e}function Y_(e,t,n){return{min:t!==void 0?e.min+t:void 0,max:n!==void 0?e.max+n-(e.max-e.min):void 0}}function rY(e,{top:t,left:n,bottom:r,right:o}){return{x:Y_(e.x,n,o),y:Y_(e.y,t,r)}}function W_(e,t){let n=t.min-e.min,r=t.max-e.max;return t.max-t.min<e.max-e.min&&([n,r]=[r,n]),{min:n,max:r}}function iY(e,t){return{x:W_(e.x,t.x),y:W_(e.y,t.y)}}function oY(e,t){let n=.5;const r=nn(e),o=nn(t);return o>r?n=cl(t.min,t.max-r,e.min):r>o&&(n=cl(e.min,e.max-o,t.min)),ha(0,1,n)}function sY(e,t){const n={};return t.min!==void 0&&(n.min=t.min-e.min),t.max!==void 0&&(n.max=t.max-e.min),n}const Dg=.35;function lY(e=Dg){return e===!1?e=0:e===!0&&(e=Dg),{x:K_(e,"left","right"),y:K_(e,"top","bottom")}}function K_(e,t,n){return{min:X_(e,t),max:X_(e,n)}}function X_(e,t){return typeof e=="number"?e:e[t]||0}const uY=new WeakMap;class cY{constructor(t){this.openDragLock=null,this.isDragging=!1,this.currentDirection=null,this.originPoint={x:0,y:0},this.constraints=!1,this.hasMutatedConstraints=!1,this.elastic=Rt(),this.latestPointerEvent=null,this.latestPanInfo=null,this.visualElement=t}start(t,{snapToCursor:n=!1,distanceThreshold:r}={}){const{presenceContext:o}=this.visualElement;if(o&&o.isPresent===!1)return;const l=g=>{n&&this.snapToCursor(Dl(g).point),this.stopAnimation()},u=(g,y)=>{const{drag:E,dragPropagation:v,onDragStart:T}=this.getProps();if(E&&!v&&(this.openDragLock&&this.openDragLock(),this.openDragLock=Pq(E),!this.openDragLock))return;this.latestPointerEvent=g,this.latestPanInfo=y,this.isDragging=!0,this.currentDirection=null,this.resolveConstraints(),this.visualElement.projection&&(this.visualElement.projection.isAnimationBlocked=!0,this.visualElement.projection.target=void 0),ua(w=>{let C=this.getAxisMotionValue(w).get()||0;if(fa.test(C)){const{projection:N}=this.visualElement;if(N&&N.layout){const L=N.layout.layoutBox[w];L&&(C=nn(L)*(parseFloat(C)/100))}}this.originPoint[w]=C}),T&&it.update(()=>T(g,y),!1,!0),Tg(this.visualElement,"transform");const{animationState:k}=this.visualElement;k&&k.setActive("whileDrag",!0)},d=(g,y)=>{this.latestPointerEvent=g,this.latestPanInfo=y;const{dragPropagation:E,dragDirectionLock:v,onDirectionLock:T,onDrag:k}=this.getProps();if(!E&&!this.openDragLock)return;const{offset:w}=y;if(v&&this.currentDirection===null){this.currentDirection=pY(w),this.currentDirection!==null&&T&&T(this.currentDirection);return}this.updateAxis("x",y.point,w),this.updateAxis("y",y.point,w),this.visualElement.render(),k&&it.update(()=>k(g,y),!1,!0)},f=(g,y)=>{this.latestPointerEvent=g,this.latestPanInfo=y,this.stop(g,y),this.latestPointerEvent=null,this.latestPanInfo=null},p=()=>{const{dragSnapToOrigin:g}=this.getProps();(g||this.constraints)&&this.startAnimation({x:0,y:0})},{dragSnapToOrigin:m}=this.getProps();this.panSession=new k1(t,{onSessionStart:l,onStart:u,onMove:d,onSessionEnd:f,resumeAnimation:p},{transformPagePoint:this.visualElement.getTransformPagePoint(),dragSnapToOrigin:m,distanceThreshold:r,contextWindow:A1(this.visualElement),element:this.visualElement.current})}stop(t,n){const r=t||this.latestPointerEvent,o=n||this.latestPanInfo,l=this.isDragging;if(this.cancel(),!l||!o||!r)return;const{velocity:u}=o;this.startAnimation(u);const{onDragEnd:d}=this.getProps();d&&it.postRender(()=>d(r,o))}cancel(){this.isDragging=!1;const{projection:t,animationState:n}=this.visualElement;t&&(t.isAnimationBlocked=!1),this.endPanSession();const{dragPropagation:r}=this.getProps();!r&&this.openDragLock&&(this.openDragLock(),this.openDragLock=null),n&&n.setActive("whileDrag",!1)}endPanSession(){this.panSession&&this.panSession.end(),this.panSession=void 0}updateAxis(t,n,r){const{drag:o}=this.getProps();if(!r||!fc(t,o,this.currentDirection))return;const l=this.getAxisMotionValue(t);let u=this.originPoint[t]+r[t];this.constraints&&this.constraints[t]&&(u=aY(u,this.constraints[t],this.elastic[t])),l.set(u)}resolveConstraints(){const{dragConstraints:t,dragElastic:n}=this.getProps(),r=this.visualElement.projection&&!this.visualElement.projection.layout?this.visualElement.projection.measure(!1):this.visualElement.projection?.layout,o=this.constraints;t&&go(t)?this.constraints||(this.constraints=this.resolveRefConstraints()):t&&r?this.constraints=rY(r.layoutBox,t):this.constraints=!1,this.elastic=lY(n),o!==this.constraints&&!go(t)&&r&&this.constraints&&!this.hasMutatedConstraints&&ua(l=>{this.constraints!==!1&&this.getAxisMotionValue(l)&&(this.constraints[l]=sY(r.layoutBox[l],this.constraints[l]))})}resolveRefConstraints(){const{dragConstraints:t,onMeasureDragConstraints:n}=this.getProps();if(!t||!go(t))return!1;const r=t.current,{projection:o}=this.visualElement;if(!o||!o.layout)return!1;const l=m8(r,o.root,this.visualElement.getTransformPagePoint());let u=iY(o.layout.layoutBox,l);if(n){const d=n(d8(u));this.hasMutatedConstraints=!!d,d&&(u=WI(d))}return u}startAnimation(t){const{drag:n,dragMomentum:r,dragElastic:o,dragTransition:l,dragSnapToOrigin:u,onDragTransitionEnd:d}=this.getProps(),f=this.constraints||{},p=ua(m=>{if(!fc(m,n,this.currentDirection))return;let g=f&&f[m]||{};u&&(g={min:0,max:0});const y=o?200:1e6,E=o?40:1e7,v={type:"inertia",velocity:r?t[m]:0,bounceStiffness:y,bounceDamping:E,timeConstant:750,restDelta:1,restSpeed:10,...l,...g};return this.startAxisValueAnimation(m,v)});return Promise.all(p).then(d)}startAxisValueAnimation(t,n){const r=this.getAxisMotionValue(t);return Tg(this.visualElement,t),r.start(Gv(t,r,0,n,this.visualElement,!1))}stopAnimation(){ua(t=>this.getAxisMotionValue(t).stop())}getAxisMotionValue(t){const n=`_drag${t.toUpperCase()}`,r=this.visualElement.getProps(),o=r[n];return o||this.visualElement.getValue(t,(r.initial?r.initial[t]:void 0)||0)}snapToCursor(t){ua(n=>{const{drag:r}=this.getProps();if(!fc(n,r,this.currentDirection))return;const{projection:o}=this.visualElement,l=this.getAxisMotionValue(n);if(o&&o.layout){const{min:u,max:d}=o.layout.layoutBox[n],f=l.get()||0;l.set(t[n]-ut(u,d,.5)+f)}})}scalePositionWithinConstraints(){if(!this.visualElement.current)return;const{drag:t,dragConstraints:n}=this.getProps(),{projection:r}=this.visualElement;if(!go(n)||!r||!this.constraints)return;this.stopAnimation();const o={x:0,y:0};ua(u=>{const d=this.getAxisMotionValue(u);if(d&&this.constraints!==!1){const f=d.get();o[u]=oY({min:f,max:f},this.constraints[u])}});const{transformTemplate:l}=this.visualElement.getProps();this.visualElement.current.style.transform=l?l({},""):"none",r.root&&r.root.updateScroll(),r.updateLayout(),this.constraints=!1,this.resolveConstraints(),ua(u=>{if(!fc(u,t,null))return;const d=this.getAxisMotionValue(u),{min:f,max:p}=this.constraints[u];d.set(ut(f,p,o[u]))}),this.visualElement.render()}addListeners(){if(!this.visualElement.current)return;uY.set(this.visualElement,this);const t=this.visualElement.current,n=el(t,"pointerdown",p=>{const{drag:m,dragListener:g=!0}=this.getProps(),y=p.target,E=y!==t&&Vq(y);m&&g&&!E&&this.start(p)});let r;const o=()=>{const{dragConstraints:p}=this.getProps();go(p)&&p.current&&(this.constraints=this.resolveRefConstraints(),r||(r=dY(t,p.current,()=>this.scalePositionWithinConstraints())))},{projection:l}=this.visualElement,u=l.addEventListener("measure",o);l&&!l.layout&&(l.root&&l.root.updateScroll(),l.updateLayout()),it.read(o);const d=ml(window,"resize",()=>this.scalePositionWithinConstraints()),f=l.addEventListener("didUpdate",(({delta:p,hasLayoutChanged:m})=>{this.isDragging&&m&&(ua(g=>{const y=this.getAxisMotionValue(g);y&&(this.originPoint[g]+=p[g].translate,y.set(y.get()+p[g].translate))}),this.visualElement.render())}));return()=>{d(),n(),u(),f&&f(),r&&r()}}getProps(){const t=this.visualElement.getProps(),{drag:n=!1,dragDirectionLock:r=!1,dragPropagation:o=!1,dragConstraints:l=!1,dragElastic:u=Dg,dragMomentum:d=!0}=t;return{...t,drag:n,dragDirectionLock:r,dragPropagation:o,dragConstraints:l,dragElastic:u,dragMomentum:d}}}function Z_(e){let t=!0;return()=>{if(t){t=!1;return}e()}}function dY(e,t,n){const r=r_(e,Z_(n)),o=r_(t,Z_(n));return()=>{r(),o()}}function fc(e,t,n){return(t===!0||t===e)&&(n===null||n===e)}function pY(e,t=10){let n=null;return Math.abs(e.y)>t?n="y":Math.abs(e.x)>t&&(n="x"),n}class fY extends Dr{constructor(t){super(t),this.removeGroupControls=zn,this.removeListeners=zn,this.controls=new cY(t)}mount(){const{dragControls:t}=this.node.getProps();t&&(this.removeGroupControls=t.subscribe(this.controls)),this.removeListeners=this.controls.addListeners()||zn}update(){const{dragControls:t}=this.node.getProps(),{dragControls:n}=this.node.prevProps||{};t!==n&&(this.removeGroupControls(),t&&(this.removeGroupControls=t.subscribe(this.controls)))}unmount(){this.removeGroupControls(),this.removeListeners(),this.controls.isDragging||this.controls.endPanSession()}}const Um=e=>(t,n)=>{e&&it.update(()=>e(t,n),!1,!0)};class mY extends Dr{constructor(){super(...arguments),this.removePointerDownListener=zn}onPointerDown(t){this.session=new k1(t,this.createPanHandlers(),{transformPagePoint:this.node.getTransformPagePoint(),contextWindow:A1(this.node)})}createPanHandlers(){const{onPanSessionStart:t,onPanStart:n,onPan:r,onPanEnd:o}=this.node.getProps();return{onSessionStart:Um(t),onStart:Um(n),onMove:Um(r),onEnd:(l,u)=>{delete this.session,o&&it.postRender(()=>o(l,u))}}}mount(){this.removePointerDownListener=el(this.node.current,"pointerdown",t=>this.onPointerDown(t))}update(){this.session&&this.session.updateHandlers(this.createPanHandlers())}unmount(){this.removePointerDownListener(),this.session&&this.session.end()}}let Bm=!1;class gY extends A.Component{componentDidMount(){const{visualElement:t,layoutGroup:n,switchLayoutGroup:r,layoutId:o}=this.props,{projection:l}=t;l&&(n.group&&n.group.add(l),r&&r.register&&o&&r.register(l),Bm&&l.root.didUpdate(),l.addEventListener("animationComplete",()=>{this.safeToRemove()}),l.setOptions({...l.options,layoutDependency:this.props.layoutDependency,onExitComplete:()=>this.safeToRemove()})),kc.hasEverUpdated=!0}getSnapshotBeforeUpdate(t){const{layoutDependency:n,visualElement:r,drag:o,isPresent:l}=this.props,{projection:u}=r;return u&&(u.isPresent=l,t.layoutDependency!==n&&u.setOptions({...u.options,layoutDependency:n}),Bm=!0,o||t.layoutDependency!==n||n===void 0||t.isPresent!==l?u.willUpdate():this.safeToRemove(),t.isPresent!==l&&(l?u.promote():u.relegate()||it.postRender(()=>{const d=u.getStack();(!d||!d.members.length)&&this.safeToRemove()}))),null}componentDidUpdate(){const{projection:t}=this.props.visualElement;t&&(t.root.didUpdate(),qv.postRender(()=>{!t.currentAnimation&&t.isLead()&&this.safeToRemove()}))}componentWillUnmount(){const{visualElement:t,layoutGroup:n,switchLayoutGroup:r}=this.props,{projection:o}=t;Bm=!0,o&&(o.scheduleCheckAfterUnmount(),n&&n.group&&n.group.remove(o),r&&r.deregister&&r.deregister(o))}safeToRemove(){const{safeToRemove:t}=this.props;t&&t()}render(){return null}}function _1(e){const[t,n]=h1(),r=A.useContext(Av);return S.jsx(gY,{...e,layoutGroup:r,switchLayoutGroup:A.useContext(w1),isPresent:t,safeToRemove:n})}const hY={pan:{Feature:mY},drag:{Feature:fY,ProjectionNode:g1,MeasureLayout:_1}};function Q_(e,t,n){const{props:r}=e;e.animationState&&r.whileHover&&e.animationState.setActive("whileHover",n==="Start");const o="onHover"+n,l=r[o];l&&it.postRender(()=>l(t,Dl(t)))}class bY extends Dr{mount(){const{current:t}=this.node;t&&(this.unmount=zq(t,(n,r)=>(Q_(this.node,r,"Start"),o=>Q_(this.node,o,"End"))))}unmount(){}}class yY extends Dr{constructor(){super(...arguments),this.isActive=!1}onFocus(){let t=!1;try{t=this.node.current.matches(":focus-visible")}catch{t=!0}!t||!this.node.animationState||(this.node.animationState.setActive("whileFocus",!0),this.isActive=!0)}onBlur(){!this.isActive||!this.node.animationState||(this.node.animationState.setActive("whileFocus",!1),this.isActive=!1)}mount(){this.unmount=Cl(ml(this.node.current,"focus",()=>this.onFocus()),ml(this.node.current,"blur",()=>this.onBlur()))}unmount(){}}function J_(e,t,n){const{props:r}=e;if(e.current instanceof HTMLButtonElement&&e.current.disabled)return;e.animationState&&r.whileTap&&e.animationState.setActive("whileTap",n==="Start");const o="onTap"+(n==="End"?"":n),l=r[o];l&&it.postRender(()=>l(t,Dl(t)))}class EY extends Dr{mount(){const{current:t}=this.node;if(!t)return;const{globalTapTarget:n,propagate:r}=this.node.props;this.unmount=Yq(t,(o,l)=>(J_(this.node,l,"Start"),(u,{success:d})=>J_(this.node,u,d?"End":"Cancel")),{useGlobalTarget:n,stopPropagation:r?.tap===!1})}unmount(){}}const Lg=new WeakMap,Pm=new WeakMap,SY=e=>{const t=Lg.get(e.target);t&&t(e)},vY=e=>{e.forEach(SY)};function xY({root:e,...t}){const n=e||document;Pm.has(n)||Pm.set(n,{});const r=Pm.get(n),o=JSON.stringify(t);return r[o]||(r[o]=new IntersectionObserver(vY,{root:e,...t})),r[o]}function wY(e,t,n){const r=xY(t);return Lg.set(e,n),r.observe(e),()=>{Lg.delete(e),r.unobserve(e)}}const TY={some:0,all:1};class AY extends Dr{constructor(){super(...arguments),this.hasEnteredView=!1,this.isInView=!1}startObserver(){this.unmount();const{viewport:t={}}=this.node.getProps(),{root:n,margin:r,amount:o="some",once:l}=t,u={root:n?n.current:void 0,rootMargin:r,threshold:typeof o=="number"?o:TY[o]},d=f=>{const{isIntersecting:p}=f;if(this.isInView===p||(this.isInView=p,l&&!p&&this.hasEnteredView))return;p&&(this.hasEnteredView=!0),this.node.animationState&&this.node.animationState.setActive("whileInView",p);const{onViewportEnter:m,onViewportLeave:g}=this.node.getProps(),y=p?m:g;y&&y(f)};return wY(this.node.current,u,d)}mount(){this.startObserver()}update(){if(typeof IntersectionObserver>"u")return;const{props:t,prevProps:n}=this.node;["amount","margin","root"].some(kY(t,n))&&this.startObserver()}unmount(){}}function kY({viewport:e={}},{viewport:t={}}={}){return n=>e[n]!==t[n]}const RY={inView:{Feature:AY},tap:{Feature:EY},focus:{Feature:yY},hover:{Feature:bY}},_Y={layout:{ProjectionNode:g1,MeasureLayout:_1}},NY={...Q9,...RY,...hY,..._Y},ui=Y9(NY,W9);function CY({images:e,index:t,onClose:n,onNavigate:r}){const o=A.useCallback(()=>{t>0&&r(t-1)},[t,r]),l=A.useCallback(()=>{t<e.length-1&&r(t+1)},[t,e.length,r]);return A.useEffect(()=>{const u=d=>{d.key==="Escape"&&n(),d.key==="ArrowLeft"&&o(),d.key==="ArrowRight"&&l()};return window.addEventListener("keydown",u),()=>window.removeEventListener("keydown",u)},[n,o,l]),S.jsx(qc,{children:S.jsxs(ui.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.15},className:"fixed inset-0 z-50 flex items-center justify-center bg-black/90",onClick:n,children:[S.jsx("button",{onClick:n,className:"absolute top-4 right-4 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:S.jsx(Kc,{className:"h-5 w-5"})}),e.length>1&&S.jsxs("div",{className:"absolute top-4 left-1/2 -translate-x-1/2 text-white/70 text-sm tabular-nums",children:[t+1," / ",e.length]}),t>0&&S.jsx("button",{onClick:u=>{u.stopPropagation(),o()},className:"absolute left-3 top-1/2 -translate-y-1/2 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:S.jsx(gM,{className:"h-6 w-6"})}),t<e.length-1&&S.jsx("button",{onClick:u=>{u.stopPropagation(),l()},className:"absolute right-3 top-1/2 -translate-y-1/2 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:S.jsx(bM,{className:"h-6 w-6"})}),S.jsx("img",{src:e[t],alt:"",className:"max-h-[85vh] max-w-[90vw] object-contain rounded-lg",onClick:u=>u.stopPropagation()})]})})}function OY({messages:e,streaming:t,streamBuffer:n,tools:r}){const o=A.useRef(null),[l,u]=A.useState(null),d=A.useCallback((m,g)=>{u({images:m,index:g})},[]);A.useEffect(()=>{o.current?.scrollIntoView({behavior:"smooth"})},[e,n,r,t]);const f=r.length>0?r[r.length-1]:null,p=f?.status==="running"?f.name:void 0;return S.jsxs("div",{className:"flex-1 overflow-y-auto overflow-x-hidden p-4 flex flex-col min-h-0",children:[S.jsx("div",{className:"flex-1"}),e.length===0&&!t&&S.jsx("div",{className:"flex items-center justify-center py-8 text-muted-foreground text-sm",children:"Start a conversation"}),S.jsxs("div",{className:"space-y-3",children:[e.map(m=>S.jsx(L5,{role:m.role,content:m.content,timestamp:m.timestamp,hasAttachments:m.hasAttachments,audioData:m.audioData,attachments:m.attachments,onImageClick:d},m.id)),t&&S.jsx(F5,{text:n,toolName:p})]}),S.jsx("div",{ref:o}),l&&S.jsx(CY,{images:l.images,index:l.index,onClose:()=>u(null),onNavigate:m=>u(g=>g?{...g,index:m}:null)})]})}function IY(e){const t=Math.floor(e/60),n=e%60;return`${t}:${n.toString().padStart(2,"0")}`}function DY(e,t=4*1024*1024){return new Promise(n=>{const r=new Image;r.onload=()=>{let{width:l,height:u}=r;if(l>1600||u>1600){const p=Math.min(1600/l,1600/u);l=Math.round(l*p),u=Math.round(u*p)}const d=document.createElement("canvas");d.width=l,d.height=u,d.getContext("2d").drawImage(r,0,0,l,u);for(const p of[.8,.6,.4,.3]){const m=d.toDataURL("image/jpeg",p);if(Math.round((m.length-23)*.75)<=t){n(m);return}}n(d.toDataURL("image/jpeg",.2))},r.onerror=()=>n(e),r.src=e})}function LY({onSend:e,onStop:t,streaming:n,whisperEnabled:r}){const[o,l]=A.useState(""),[u,d]=A.useState([]),[f,p]=A.useState(!1),[m,g]=A.useState(0),E=o.trim().length>0||u.length>0,v=A.useRef(null),T=A.useRef(null),k=A.useRef(null),w=A.useRef(null),C=A.useRef(null),N=A.useRef(0),L=A.useRef(0),F=A.useRef(null),D=A.useRef(!1),z=A.useRef(null),B=A.useRef(null),W=A.useRef([]),U=A.useRef(null);A.useEffect(()=>{const R=v.current;R&&(R.style.height="0px",R.style.height=`${Math.min(R.scrollHeight,88)}px`)},[o]),A.useEffect(()=>{if(f)return z.current=setInterval(()=>g(R=>R+1),1e3),()=>{z.current&&clearInterval(z.current)}},[f]);const X=A.useCallback(R=>{z.current&&clearInterval(z.current),F.current&&(clearTimeout(F.current),F.current=null),D.current=!1;const M=B.current,H=U.current;R||!M||M.state==="inactive"?(H?.getTracks().forEach(I=>I.stop()),B.current=null,U.current=null,W.current=[]):(M.onstop=async()=>{H?.getTracks().forEach(ue=>ue.stop());const I=new Blob(W.current,{type:"audio/webm"});if(W.current=[],B.current=null,U.current=null,I.size<1e3)return;const ce=new FileReader;ce.onloadend=async()=>{const ue=ce.result,de=ue.split(",")[1];if(de)try{const ke=await(await fetch("/api/whisper/transcribe",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({audio:de})})).json();ke.transcript?.trim()&&e(ke.transcript.trim(),void 0,ue)}catch{}},ce.readAsDataURL(I)},M.stop()),C.current&&(C.current.style.transform=""),p(!1),g(0),L.current=0},[e]),Q=A.useCallback(R=>{const M=R.type.startsWith("image/"),H=R.type==="application/pdf";if(!M&&!H)return;const I=new FileReader;I.onload=async ce=>{let ue=ce.target?.result;M&&(ue=await DY(ue)),d(de=>[...de,{id:Math.random().toString(36).slice(2),type:M?"image":"file",name:R.name,preview:ue}])},I.readAsDataURL(R)},[]),te=A.useCallback(R=>{const M=R.target.files;if(M){for(let H=0;H<M.length;H++)Q(M[H]);R.target.value=""}},[Q]),ie=A.useCallback(R=>{d(M=>M.filter(H=>H.id!==R))},[]);A.useEffect(()=>{const R=M=>{if(M.clipboardData?.items){for(const H of M.clipboardData.items)if(H.type.startsWith("image/")){M.preventDefault();const I=H.getAsFile();I&&Q(I)}}};return document.addEventListener("paste",R),()=>document.removeEventListener("paste",R)},[Q]);const ee=()=>{E&&(e(o,u.length>0?u:void 0),l(""),d([]),requestAnimationFrame(()=>v.current?.focus()))},j=A.useCallback(R=>{R.preventDefault(),N.current=R.clientX,L.current=0,R.currentTarget.setPointerCapture(R.pointerId),F.current=setTimeout(async()=>{if(r)try{const M=await navigator.mediaDevices.getUserMedia({audio:!0});U.current=M;const H=MediaRecorder.isTypeSupported("audio/webm;codecs=opus")?"audio/webm;codecs=opus":"audio/webm",I=new MediaRecorder(M,{mimeType:H});W.current=[],I.ondataavailable=ce=>{ce.data.size>0&&W.current.push(ce.data)},B.current=I,I.start(),D.current=!0,p(!0),g(0)}catch{}},200)},[]),V=A.useCallback(R=>{if(!D.current)return;const M=Math.min(0,R.clientX-N.current);if(L.current=M,C.current&&(C.current.style.transform=`translateX(${M}px)`),w.current){const H=w.current.getBoundingClientRect(),I=H.left+H.width/2;Math.abs(R.clientX-I)<36&&X(!0)}},[X]),Z=A.useCallback(()=>{F.current&&(clearTimeout(F.current),F.current=null),D.current&&X(!1)},[X]),ne=A.useCallback(()=>{F.current&&(clearTimeout(F.current),F.current=null),D.current&&X(!0)},[X]);return S.jsxs("div",{className:"shrink-0 p-3 relative",children:[S.jsxs("div",{className:`flex flex-col transition-opacity duration-100 ${f?"opacity-0 pointer-events-none":"opacity-100"}`,children:[S.jsx(qc,{children:u.length>0&&S.jsx(ui.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},transition:{duration:.15},className:"overflow-hidden",children:S.jsx("div",{className:"flex gap-2 px-3 pt-2.5 pb-2 flex-wrap bg-white/[0.04] border border-white/[0.08] rounded-2xl mb-2",children:u.map(R=>S.jsxs("div",{className:"relative group flex-shrink-0",children:[R.type==="image"?S.jsx("img",{src:R.preview,alt:R.name,className:"w-14 h-14 rounded-lg object-cover border border-white/10"}):S.jsxs("div",{className:"w-14 h-14 rounded-lg bg-white/5 border border-white/10 flex flex-col items-center justify-center gap-0.5 px-1",children:[S.jsx("svg",{className:"w-5 h-5 text-muted-foreground",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:1.5,children:S.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M19.5 14.25v-2.625a3.375 3.375 0 00-3.375-3.375h-1.5A1.125 1.125 0 0113.5 7.125v-1.5a3.375 3.375 0 00-3.375-3.375H8.25m2.25 0H5.625c-.621 0-1.125.504-1.125 1.125v17.25c0 .621.504 1.125 1.125 1.125h12.75c.621 0 1.125-.504 1.125-1.125V11.25a9 9 0 00-9-9z"})}),S.jsx("span",{className:"text-[8px] text-muted-foreground truncate w-full text-center",children:R.name.split(".").pop()})]}),S.jsx("button",{onClick:()=>ie(R.id),className:"absolute -top-1.5 -right-1.5 w-4 h-4 bg-black/80 border border-white/20 rounded-full flex items-center justify-center opacity-0 group-hover:opacity-100 transition-opacity",children:S.jsx(Kc,{className:"w-2.5 h-2.5 text-white"})})]},R.id))})})}),S.jsxs("div",{className:"flex items-end gap-2",children:[S.jsxs("div",{className:"flex-1 flex items-end bg-white rounded-2xl px-4",children:[S.jsx("textarea",{ref:v,value:o,onChange:R=>l(R.target.value),placeholder:"Type a message...",rows:1,className:"flex-1 resize-none bg-transparent text-gray-900 py-3 text-sm outline-none placeholder:text-gray-400 overflow-y-auto",style:{maxHeight:88}}),S.jsx("input",{ref:T,type:"file",className:"hidden",accept:"image/*,.pdf",multiple:!0,onChange:te}),S.jsx("input",{ref:k,type:"file",className:"hidden",accept:"image/*",capture:"environment",onChange:te}),S.jsx("button",{type:"button",onClick:()=>T.current?.click(),className:"shrink-0 p-1.5 mb-2 text-gray-400 hover:text-gray-600 transition-colors",children:S.jsx(zm,{className:"h-4 w-4"})}),S.jsx("button",{type:"button",onClick:()=>k.current?.click(),className:"shrink-0 p-1.5 mb-2 text-gray-400 hover:text-gray-600 transition-colors",children:S.jsx(dM,{className:"h-4 w-4"})})]}),n?S.jsx("button",{onClick:t,className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-destructive text-destructive-foreground transition-colors",children:S.jsx(XM,{className:"h-4 w-4"})}):E?S.jsx("button",{onClick:ee,className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-white text-gray-900 transition-colors hover:bg-gray-100",children:S.jsx(VM,{className:"h-4 w-4"})}):S.jsx("div",{className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-white text-gray-900 transition-colors hover:bg-gray-100 cursor-pointer touch-none select-none",onPointerDown:j,onPointerMove:V,onPointerUp:Z,onPointerCancel:ne,children:S.jsx(jm,{className:"h-4 w-4"})})]})]}),S.jsx(qc,{children:f&&S.jsx(ui.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.1},className:"absolute inset-0 p-3 flex items-center touch-none",children:S.jsxs("div",{className:"flex items-center w-full gap-2",children:[S.jsxs("div",{className:"flex items-center gap-2 shrink-0",children:[S.jsxs("span",{className:"relative flex h-2 w-2 shrink-0",children:[S.jsx("span",{className:"animate-ping absolute inline-flex h-full w-full rounded-full bg-destructive opacity-75"}),S.jsx("span",{className:"relative inline-flex rounded-full h-2 w-2 bg-destructive"})]}),S.jsx("span",{className:"text-sm font-medium tabular-nums",children:IY(m)})]}),S.jsxs("div",{className:"flex-1 flex items-center bg-muted rounded-full h-12 pl-1 pr-0.5",children:[S.jsx("div",{ref:w,className:"flex items-center justify-center h-9 w-9 shrink-0 rounded-full bg-destructive/10 text-destructive",children:S.jsx(lN,{className:"h-4 w-4"})}),S.jsx("div",{className:"flex-1 flex justify-center min-w-0",children:S.jsx(ui.span,{className:"text-[13px] whitespace-nowrap select-none font-medium",style:{backgroundImage:"linear-gradient(90deg, #999 0%, #999 35%, #fff 50%, #999 65%, #999 100%)",backgroundSize:"200% 100%",WebkitBackgroundClip:"text",WebkitTextFillColor:"transparent",backgroundClip:"text"},animate:{backgroundPosition:["200% center","-200% center"]},transition:{duration:2.5,repeat:1/0,ease:"linear"},children:"◄◄ slide to cancel"})}),S.jsx("div",{ref:C,className:"shrink-0 touch-none select-none will-change-transform",style:{transition:"none"},onPointerDown:j,onPointerMove:V,onPointerUp:Z,onPointerCancel:ne,children:S.jsx("div",{className:"flex items-center justify-center h-11 w-11 rounded-full bg-destructive text-destructive-foreground",children:S.jsx(jm,{className:"h-5 w-5"})})})]})]})})})]})}function MY({ws:e,clearContextRef:t,whisperEnabled:n}){const{messages:r,streaming:o,streamBuffer:l,tools:u,sendMessage:d,stopStreaming:f,clearContext:p}=dz(e);return t&&(t.current=p),S.jsxs("div",{className:"flex flex-col h-full overflow-hidden",children:[S.jsx(OY,{messages:r,streaming:o,streamBuffer:l,tools:u}),S.jsx(LY,{onSend:d,onStop:f,streaming:o,whisperEnabled:n})]})}function FY({onClick:e}){return S.jsx(ui.div,{className:"fixed bottom-6 right-6 z-50 cursor-pointer",whileHover:{scale:1.1},whileTap:{scale:.95},onClick:e,role:"button","aria-label":"Open Fluxy chat",children:S.jsx("video",{src:"/fluxy_tilts.webm",poster:"/fluxy_frame1.png",autoPlay:!0,loop:!0,muted:!0,playsInline:!0,className:"h-11 w-auto drop-shadow-lg pointer-events-none",draggable:!1})})}const UY=[{id:"anthropic",name:"Claude",subtitle:"by Anthropic",icon:"/icons/claude.png"},{id:"openai",name:"OpenAI Codex",subtitle:"ChatGPT Plus / Pro",icon:"/icons/codex.png"},{id:"ollama",name:"Ollama",subtitle:"Run locally",icon:null}],BY={anthropic:[{id:"claude-opus-4-6",label:"Opus 4.6"},{id:"claude-sonnet-4-6",label:"Sonnet 4.6"},{id:"claude-haiku-4-5-20251001",label:"Haiku 4.5"}],openai:[{id:"gpt-5.2-codex:medium",label:"GPT-5.2 Codex Medium"},{id:"gpt-5.2-codex:high",label:"GPT-5.2 Codex High"},{id:"gpt-5.2-codex:xhigh",label:"GPT-5.2 Codex Extra High"},{id:"gpt-5.3-codex:medium",label:"GPT-5.3 Codex Medium (Pro)"},{id:"gpt-5.3-codex:high",label:"GPT-5.3 Codex High (Pro)"},{id:"gpt-5.3-codex:xhigh",label:"GPT-5.3 Codex Extra High (Pro)"}],ollama:[{id:"llama3.2",label:"Llama 3.2"},{id:"mistral",label:"Mistral"},{id:"codellama",label:"Code Llama"},{id:"phi3",label:"Phi-3"}]},eN=6,tN=[{tier:"premium",label:e=>`${e}.fluxy.bot`,badge:"$5",badgeCls:"bg-primary/15 text-primary border-primary/20",highlight:!0},{tier:"at",label:e=>`${e}.at.fluxy.bot`,badge:"Free",badgeCls:"bg-emerald-500/10 text-emerald-400 border-emerald-500/20",highlight:!1}];function PY({models:e,value:t,onChange:n}){const[r,o]=A.useState(!1),l=A.useRef(null);A.useEffect(()=>{if(!r)return;const d=f=>{l.current&&!l.current.contains(f.target)&&o(!1)};return document.addEventListener("mousedown",d),()=>document.removeEventListener("mousedown",d)},[r]);const u=e.find(d=>d.id===t);return S.jsxs("div",{className:"relative",ref:l,children:[S.jsxs("button",{type:"button",onClick:()=>o(d=>!d),className:"w-full flex items-center justify-between bg-white/[0.03] border border-white/[0.08] text-white rounded-xl px-4 py-2.5 text-[13px] outline-none hover:border-white/15 focus:border-primary/30 transition-colors",children:[S.jsx("span",{className:u?"text-white":"text-white/20",children:u?u.label:"Choose a model..."}),S.jsx(hl,{className:`h-4 w-4 text-white/30 transition-transform ${r?"rotate-180":""}`})]}),r&&S.jsx("div",{className:"absolute left-0 right-0 top-full mt-1 bg-[#222] border border-white/[0.08] rounded-xl shadow-xl py-1 z-10 max-h-48 overflow-y-auto",children:e.map(d=>S.jsx("button",{onClick:()=>{n(d.id),o(!1)},className:`w-full text-left px-4 py-2 text-[13px] transition-colors ${t===d.id?"text-primary bg-primary/10":"text-white/70 hover:bg-white/[0.04] hover:text-white"}`,children:d.label},d.id))})]})}function jY({onComplete:e}){const[t,n]=A.useState(0),[r,o]=A.useState(""),[l,u]=A.useState("anthropic"),[d,f]=A.useState(""),[p,m]=A.useState(!1),[g,y]=A.useState({anthropic:"idle",openai:"idle",ollama:"connected"}),[E,v]=A.useState(!1),[T,k]=A.useState(""),[w,C]=A.useState(!1),[N,L]=A.useState(),[F,D]=A.useState(!1),[z,B]=A.useState(!1),[W,U]=A.useState(),[X,Q]=A.useState(""),[te,ie]=A.useState(""),[ee,j]=A.useState(null),[V,Z]=A.useState(""),[ne,R]=A.useState({}),[M,H]=A.useState("at"),[I,ce]=A.useState(!1),[ue,de]=A.useState(!1),[me,ke]=A.useState(""),Se=A.useRef(null),[We,mt]=A.useState(null),[gt,It]=A.useState(!1),[Dt,Sa]=A.useState(!1),[mn,Lr]=A.useState(""),[kn,Ya]=A.useState(""),[na,Mr]=A.useState(""),[Go,yi]=A.useState(!1),[ct,$o]=A.useState(!1),[oe,fe]=A.useState(""),[we,_e]=A.useState(""),[ze,Ht]=A.useState(!1),[Rn,_t]=A.useState(!1),[Ze,Lt]=A.useState(!1),[Le,Gn]=A.useState(""),Qt=A.useRef(!1),va=g[l]==="connected";A.useEffect(()=>{fetch("/api/onboard/status").then(re=>re.json()).then(re=>{re.userName&&o(re.userName),re.handle&&(ie(re.handle.username),H(re.handle.tier||"at"),mt({username:re.handle.username,tier:re.handle.tier,url:re.handle.url}),de(!0),ke(re.handle.url)),re.portalUser&&Lr(re.portalUser),re.portalConfigured&&$o(!0),re.provider&&u(re.provider),re.model&&f(re.model),re.whisperEnabled&&(Lt(!0),Gn(re.whisperKey||"")),Qt.current=!0}).catch(()=>{Qt.current=!0})},[]),A.useEffect(()=>{l!=="anthropic"||g.anthropic==="connected"||fetch("/api/auth/claude/status").then(re=>re.json()).then(re=>{re.authenticated&&y(Ae=>({...Ae,anthropic:"connected"}))}).catch(()=>{})},[l]),A.useEffect(()=>{l!=="openai"||g.openai==="connected"||fetch("/api/auth/codex/status").then(re=>re.json()).then(re=>{re.authenticated&&y(Ae=>({...Ae,openai:"connected"}))}).catch(()=>{})},[l]),A.useEffect(()=>{if(!z)return;const re=setInterval(async()=>{try{(await(await fetch("/api/auth/codex/status")).json()).authenticated&&(B(!1),y(Xa=>({...Xa,openai:"connected"})))}catch{}},2e3);return()=>clearInterval(re)},[z]),A.useEffect(()=>{if(Se.current&&clearTimeout(Se.current),!Qt.current||We&&ue&&te===We.username)return;j(null),Z(""),R({}),de(!1),ke("");const re=te.trim();if(re){if(re.length<3){j("invalid"),Z("At least 3 characters");return}return j("checking"),Se.current=setTimeout(async()=>{try{const Mt=await(await fetch(`/api/handle/check/${encodeURIComponent(re)}`)).json();if(!Mt.valid)j("invalid"),Z(Mt.error);else{const Xa={};for(const Ur of Mt.handles)Xa[Ur.tier]=Ur.available;R(Xa),j("ready");const Bl=tN.find(Ur=>Xa[Ur.tier]);Bl&&!Xa[M]&&H(Bl.tier)}}catch{j(null)}},400),()=>{Se.current&&clearTimeout(Se.current)}}},[te]);const Ei=re=>{ie(re.toLowerCase().replace(/[^a-z0-9-]/g,""))},Si=async()=>{if(!(!te||ee!=="ready"||!ne[M])){ce(!0);try{const Ae=await(await fetch("/api/handle/register",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({username:te,tier:M})})).json();Ae.ok?(de(!0),ke(Ae.url)):(Z(Ae.error||"Registration failed"),j("invalid"))}catch{Z("Could not reach server"),j("invalid")}finally{ce(!1)}}},vi=async()=>{if(!(!te||ee!=="ready"||!ne[M])){Sa(!0);try{const Ae=await(await fetch("/api/handle/change",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({username:te,tier:M})})).json();Ae.ok?(de(!0),ke(Ae.url),mt({username:te,tier:M,url:Ae.url}),It(!1)):(Z(Ae.error||"Handle change failed"),j("invalid"))}catch{Z("Could not reach server"),j("invalid")}finally{Sa(!1)}}},xa=re=>{l==="openai"&&re!=="openai"&&z&&(fetch("/api/auth/codex/cancel",{method:"POST"}),B(!1)),u(re),f(""),v(!1),k(""),L(void 0),B(!1),U(void 0)},xi=async()=>{L(void 0);try{const Ae=await(await fetch("/api/auth/claude/start",{method:"POST"})).json();Ae.success&&Ae.authUrl?(window.open(Ae.authUrl,"_blank"),v(!0)):L(Ae.error||"Failed to start authentication")}catch(re){L(re.message)}},Wa=async()=>{if(T.trim()){C(!0),L(void 0);try{const Ae=await(await fetch("/api/auth/claude/exchange",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({code:T.trim()})})).json();Ae.success?y(Mt=>({...Mt,anthropic:"connected"})):L(Ae.error||"Code exchange failed")}catch(re){L(re.message)}finally{C(!1)}}},Cd=async()=>{try{const re=await navigator.clipboard.readText();re&&k(re.trim())}catch{}},Ll=async()=>{D(!0),L(void 0);try{(await(await fetch("/api/auth/claude/status")).json()).authenticated?y(Mt=>({...Mt,anthropic:"connected"})):L("No active session found. Please authenticate first.")}catch{}finally{D(!1)}},Ho=async()=>{B(!0),U(void 0);try{const Ae=await(await fetch("/api/auth/codex/start",{method:"POST"})).json();Ae.success&&Ae.authUrl?window.open(Ae.authUrl,"_blank"):(B(!1),U(Ae.error||"Failed to start authentication"))}catch(re){B(!1),U(re.message)}},Fr=()=>{B(!1),fetch("/api/auth/codex/cancel",{method:"POST"})},Ml=kn===na,Vo=mn.trim().length>=3&&kn.length>=6&&Ml,Fl=ct?mn.trim().length>=3&&(kn.length===0||ze&&Vo):Vo,Ka=(()=>{switch(t){case 0:return!0;case 1:return r.trim().length>0;case 2:return ue;case 3:return Fl;case 4:return!!(l&&d&&va);case 5:return!0;default:return!1}})(),$n=()=>{Ka&&t<eN-1&&n(re=>re+1)},qo=()=>{t>0&&n(re=>re-1)},wi=re=>{re.key==="Enter"&&Ka&&$n()},Ul=async()=>{m(!0);try{await fetch("/api/onboard",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({userName:r.trim(),agentName:te.trim()||"Fluxy",provider:l,model:d,apiKey:"",baseUrl:l==="ollama"&&X||void 0,whisperEnabled:Ze,whisperKey:Ze?Le:"",portalUser:mn.trim(),portalPass:kn})}),e()}catch(re){console.error("Onboard failed:",re),m(!1)}},Vt="w-full bg-white/[0.05] border border-white/[0.08] text-white rounded-xl px-4 py-3 text-base outline-none focus:border-primary/40 placeholder:text-white/20 transition-colors",yt="w-full bg-white/[0.03] border border-white/[0.08] text-white rounded-xl px-4 py-2.5 text-[13px] outline-none focus:border-primary/30 placeholder:text-white/20 transition-colors";return S.jsxs("div",{className:"fixed inset-0 z-[200] flex items-center justify-center p-4",children:[S.jsx("div",{className:"absolute inset-0 bg-black/85 backdrop-blur-md"}),S.jsxs(ui.div,{initial:{opacity:0,scale:.95},animate:{opacity:1,scale:1},transition:{duration:.3},className:"relative w-full max-w-[480px] bg-[#181818] border border-white/[0.06] rounded-[24px] shadow-2xl overflow-hidden",children:[S.jsx("div",{className:"flex justify-center gap-2 pt-6",children:Array.from({length:eN},(re,Ae)=>S.jsx("div",{className:`h-1.5 rounded-full transition-all duration-300 ${Ae===t?"w-7 bg-primary":Ae<t?"w-1.5 bg-primary/60":"w-1.5 bg-white/10"}`},Ae))}),S.jsx(qc,{mode:"wait",children:S.jsxs(ui.div,{initial:{opacity:0,x:30},animate:{opacity:1,x:0},exit:{opacity:0,x:-30},transition:{duration:.2,ease:"easeOut"},className:"px-8 pt-6 pb-8",children:[t===0&&S.jsxs("div",{className:"flex flex-col items-center text-center",children:[S.jsx("img",{src:"/fluxy.png",alt:"Fluxy",className:"h-16 w-auto mb-4"}),S.jsx("h1",{className:"text-2xl font-bold text-white tracking-tight",children:"Welcome to Fluxy"}),S.jsx("p",{className:"text-white/40 text-[14px] mt-2 leading-relaxed max-w-[320px]",children:"Let's set up your AI assistant in just a few steps."}),S.jsxs("button",{onClick:$n,className:"mt-6 px-7 py-3 bg-primary hover:bg-primary/90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center gap-2",children:["Get Started",S.jsx(sa,{className:"h-4 w-4"})]})]}),t===1&&S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"What's your name?"}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1.5 leading-relaxed",children:"This is how your agent will address you."}),S.jsxs("div",{className:"mt-5 flex items-center gap-3",children:[S.jsx("input",{type:"text",value:r,onChange:re=>o(re.target.value),onKeyDown:wi,placeholder:"Enter your name",autoFocus:!0,className:Vt+" flex-1"}),S.jsx("button",{onClick:$n,disabled:!Ka,className:"shrink-0 h-12 w-12 flex items-center justify-center rounded-full bg-primary hover:bg-primary/90 text-white transition-colors disabled:opacity-30",children:S.jsx(sa,{className:"h-5 w-5"})})]})]}),t===2&&S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"Name your bot"}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1.5 leading-relaxed",children:"This is your bot's name and permanent handle — access it from anywhere."}),We&&ue&&!gt&&S.jsxs(S.Fragment,{children:[S.jsxs("div",{className:"mt-4 bg-emerald-500/8 border border-emerald-500/15 rounded-xl px-4 py-3",children:[S.jsxs("div",{className:"flex items-center gap-2",children:[S.jsx(Bs,{className:"h-4 w-4 text-emerald-400"}),S.jsx("p",{className:"text-emerald-400/90 text-[13px] font-medium",children:"Current handle"})]}),S.jsx("p",{className:"text-emerald-400/60 text-[12px] mt-1 font-mono",children:me})]}),S.jsxs("div",{className:"flex gap-2 mt-4",children:[S.jsxs("button",{onClick:$n,className:"flex-1 py-3 bg-primary hover:bg-primary/90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2",children:["Continue",S.jsx(sa,{className:"h-4 w-4"})]}),S.jsx("button",{onClick:()=>{It(!0),de(!1),ie(""),j(null),R({})},className:"px-5 py-3 bg-white/[0.04] hover:bg-white/[0.08] border border-white/[0.08] text-white/60 text-[13px] font-medium rounded-full transition-colors",children:"Change"})]})]}),gt&&!ue&&S.jsxs("div",{className:"mt-4 bg-amber-500/8 border border-amber-500/20 rounded-xl px-4 py-3",children:[S.jsx("p",{className:"text-amber-400/90 text-[13px] font-medium",children:"Changing your handle"}),S.jsxs("p",{className:"text-amber-400/60 text-[12px] mt-1",children:["Your current handle ",S.jsx("span",{className:"font-mono",children:We?.url})," will be released and become available for others."]})]}),(!We||gt||!ue)&&!(We&&ue&&!gt)&&S.jsxs(S.Fragment,{children:[S.jsxs("div",{className:"relative mt-5",children:[S.jsx("input",{type:"text",value:te,onChange:re=>Ei(re.target.value),maxLength:30,placeholder:"your-bot-name",spellCheck:!1,autoCapitalize:"none",autoCorrect:"off",autoFocus:!0,disabled:ue,className:Vt+" pr-10 font-mono"+(ue?" opacity-50":"")}),ee&&te.length>0&&!ue&&S.jsxs("div",{className:"absolute right-4 top-1/2 -translate-y-1/2",children:[ee==="checking"&&S.jsx("div",{className:"w-5 h-5 border-2 border-white/10 border-t-primary rounded-full animate-spin"}),ee==="invalid"&&S.jsx("div",{className:"w-6 h-6 rounded-full bg-amber-500/15 flex items-center justify-center",children:S.jsx("svg",{className:"w-3.5 h-3.5 text-amber-400",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:3,children:S.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M12 9v3m0 4h.01"})})})]})]}),ee==="invalid"&&V&&S.jsx("p",{className:"text-amber-400 text-[12px] mt-2",children:V}),ee==="ready"&&te.length>0&&!ue&&S.jsx("div",{className:"space-y-2 mt-4",children:tN.map(re=>{const Mt=ne[re.tier]===!1;return S.jsxs("button",{onClick:()=>!Mt&&H(re.tier),disabled:Mt,className:`w-full flex items-center justify-between px-4 py-3 rounded-xl border transition-all duration-200 text-left ${Mt?"border-white/[0.04] bg-transparent opacity-50 cursor-not-allowed":M===re.tier?re.highlight?"border-primary/40 bg-primary/[0.06]":"border-primary/30 bg-white/[0.04]":"border-white/[0.06] bg-transparent hover:border-white/10 hover:bg-white/[0.02]"}`,children:[S.jsx("span",{className:"font-mono text-[13px] text-white/70",children:re.label(te)}),Mt?S.jsx("span",{className:"text-[11px] font-medium px-2.5 py-0.5 rounded-full border bg-red-500/10 text-red-400 border-red-500/20",children:"Taken"}):S.jsx("span",{className:`text-[11px] font-medium px-2.5 py-0.5 rounded-full border ${re.badgeCls}`,children:re.badge})]},re.tier)})}),ue&&S.jsxs("div",{className:"mt-4 bg-emerald-500/8 border border-emerald-500/15 rounded-xl px-4 py-3",children:[S.jsxs("div",{className:"flex items-center gap-2",children:[S.jsx(Bs,{className:"h-4 w-4 text-emerald-400"}),S.jsx("p",{className:"text-emerald-400/90 text-[13px] font-medium",children:"Handle claimed!"})]}),S.jsx("p",{className:"text-emerald-400/60 text-[12px] mt-1 font-mono",children:me})]}),ee==="ready"&&ne[M]&&te.length>0&&!ue&&S.jsx("button",{onClick:gt?vi:Si,disabled:I||Dt,className:"w-full mt-4 py-3 bg-primary hover:bg-primary/90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:I||Dt?S.jsxs(S.Fragment,{children:[S.jsx(so,{className:"h-4 w-4 animate-spin"}),gt?"Changing...":"Claiming..."]}):S.jsxs(S.Fragment,{children:[gt?"Change Handle":"Claim & Continue",S.jsx(sa,{className:"h-4 w-4"})]})}),ue&&S.jsxs("button",{onClick:$n,className:"w-full mt-4 py-3 bg-primary hover:bg-primary/90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2",children:["Continue",S.jsx(sa,{className:"h-4 w-4"})]}),gt&&!ue&&S.jsx("button",{onClick:()=>{It(!1),ie(We.username),de(!0),ke(We.url),H(We.tier),j(null)},className:"w-full mt-2 py-2 text-white/25 hover:text-white/40 text-[12px] transition-colors",children:"Cancel — keep current handle"})]})]}),t===3&&S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"Secure your portal"}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1.5 leading-relaxed",children:"Create credentials to protect your dashboard. Anyone with your URL will need these to log in."}),ue&&me&&S.jsxs("div",{className:"mt-4 flex items-center gap-2 bg-white/[0.03] border border-white/[0.06] rounded-xl px-4 py-3",children:[S.jsx("span",{className:"font-mono text-[13px] text-white/60 truncate flex-1",children:me}),S.jsx("button",{onClick:()=>{navigator.clipboard.writeText(me),yi(!0),setTimeout(()=>yi(!1),2e3)},className:"shrink-0 text-white/30 hover:text-white/60 transition-colors",children:Go?S.jsx(Bs,{className:"h-4 w-4 text-emerald-400"}):S.jsxs("svg",{className:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:2,children:[S.jsx("rect",{x:"9",y:"9",width:"13",height:"13",rx:"2"}),S.jsx("path",{d:"M5 15H4a2 2 0 01-2-2V4a2 2 0 012-2h9a2 2 0 012 2v1"})]})})]}),ct&&S.jsx("div",{className:"mt-4 bg-white/[0.02] border border-white/[0.06] rounded-xl px-4 py-2.5",children:S.jsx("p",{className:"text-white/40 text-[12px]",children:"Credentials already set. Leave password fields empty to keep your current password, or enter your current password to change it."})}),S.jsxs("div",{className:"mt-5",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:"Username"}),S.jsx("input",{type:"text",value:mn,onChange:re=>Lr(re.target.value.replace(/\s/g,"").toLowerCase()),placeholder:"admin",autoFocus:!0,autoComplete:"username",className:Vt+" font-mono"}),mn.length>0&&mn.trim().length<3&&S.jsx("p",{className:"text-amber-400/70 text-[11px] mt-1",children:"At least 3 characters"})]}),ct&&S.jsxs("div",{className:"mt-3",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:"Current password"}),S.jsxs("div",{className:"flex items-center gap-2",children:[S.jsx("input",{type:"password",value:oe,onChange:re=>{fe(re.target.value),_e(""),Ht(!1)},placeholder:"Enter current password to change it",autoComplete:"current-password",className:Vt+" flex-1"}),oe.length>0&&!ze&&S.jsx("button",{onClick:async()=>{_t(!0),_e("");try{(await(await fetch("/api/portal/verify-password",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({password:oe})})).json()).valid?Ht(!0):_e("Incorrect password")}catch{_e("Could not verify")}finally{_t(!1)}},disabled:Rn,className:"shrink-0 px-4 py-3 bg-white/[0.06] hover:bg-white/[0.1] text-white/60 text-[13px] font-medium rounded-xl transition-colors disabled:opacity-40",children:Rn?S.jsx(so,{className:"h-4 w-4 animate-spin"}):"Verify"}),ze&&S.jsx("div",{className:"shrink-0 w-10 h-10 flex items-center justify-center",children:S.jsx(Bs,{className:"h-4 w-4 text-emerald-400"})})]}),we&&S.jsx("p",{className:"text-red-400/70 text-[11px] mt-1",children:we})]}),(!ct||ze)&&S.jsxs(S.Fragment,{children:[S.jsxs("div",{className:"mt-3",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:ct?"New password":"Password"}),S.jsx("input",{type:"password",value:kn,onChange:re=>Ya(re.target.value),placeholder:"••••••••",autoComplete:"new-password",onKeyDown:wi,className:Vt}),kn.length>0&&kn.length<6&&S.jsx("p",{className:"text-amber-400/70 text-[11px] mt-1",children:"At least 6 characters"})]}),S.jsxs("div",{className:"mt-3",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:ct?"Confirm new password":"Confirm password"}),S.jsx("input",{type:"password",value:na,onChange:re=>Mr(re.target.value),placeholder:"••••••••",autoComplete:"new-password",onKeyDown:wi,className:Vt}),na.length>0&&!Ml&&S.jsx("p",{className:"text-red-400/70 text-[11px] mt-1",children:"Passwords don't match"})]})]}),S.jsxs("button",{onClick:$n,disabled:!Ka,className:"w-full mt-5 py-3 bg-primary hover:bg-primary/90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:["Continue",S.jsx(sa,{className:"h-4 w-4"})]})]}),t===4&&S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"Choose your AI provider"}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1.5 leading-relaxed",children:"Pick one provider to power your bot, authenticate, and select a model."}),S.jsx("div",{className:"flex gap-2.5 mt-4",children:UY.map(re=>S.jsxs("button",{onClick:()=>xa(re.id),className:`flex-1 relative rounded-xl border transition-all duration-200 p-3 text-left ${l===re.id?"bg-white/[0.04] border-primary/40":"bg-transparent border-white/[0.06] hover:border-white/10 hover:bg-white/[0.02]"}`,children:[S.jsxs("div",{className:"flex flex-col items-center gap-1.5 py-0.5",children:[re.icon?S.jsx("img",{src:re.icon,alt:re.name,className:"w-8 h-8 rounded-lg"}):S.jsx("div",{className:"w-8 h-8 rounded-lg bg-white/[0.06] flex items-center justify-center text-white/50 text-sm font-bold",children:"O"}),S.jsxs("div",{className:"text-center",children:[S.jsx("div",{className:"text-[13px] font-medium text-white",children:re.name}),S.jsx("div",{className:"text-[10px] text-white/30",children:re.subtitle})]})]}),g[re.id]==="connected"?S.jsx("div",{className:"absolute top-2 right-2 w-4 h-4 rounded-full bg-emerald-500/15 flex items-center justify-center",children:S.jsx(Bs,{className:"h-2.5 w-2.5 text-emerald-400"})}):l===re.id?S.jsx("div",{className:"absolute top-2 right-2 w-2 h-2 rounded-full bg-primary"}):null]},re.id))}),S.jsx("div",{className:"border-t border-white/[0.06] mt-4 mb-3"}),l==="anthropic"&&S.jsxs("div",{className:"space-y-2.5",children:[va&&S.jsx("div",{className:"bg-emerald-500/8 border border-emerald-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-emerald-400/90 text-[12px]",children:"Connected — Anthropic subscription is active."})}),!va&&S.jsxs(S.Fragment,{children:[N&&S.jsx("div",{className:"bg-red-500/8 border border-red-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-red-400/90 text-[12px]",children:N})}),S.jsx("div",{className:"space-y-1.5",children:["Click the button below to open Anthropic's login page","Sign in with your Anthropic account — a code will be generated","Copy the code and paste it in the field below"].map((re,Ae)=>S.jsxs("div",{className:"flex items-start gap-2",children:[S.jsx("span",{className:"flex-shrink-0 w-[18px] h-[18px] rounded-full bg-white/[0.06] text-white/30 text-[10px] font-medium flex items-center justify-center mt-px",children:Ae+1}),S.jsx("p",{className:"text-white/40 text-[12px] leading-relaxed",children:re})]},Ae))}),S.jsx("button",{onClick:xi,className:"w-full py-2.5 px-4 bg-primary hover:bg-primary/90 text-white text-[13px] font-medium rounded-xl transition-colors flex items-center justify-center gap-2",children:E?S.jsxs(S.Fragment,{children:[S.jsx(AM,{className:"h-3.5 w-3.5 opacity-60"}),"Open authentication page again"]}):S.jsxs(S.Fragment,{children:["Authenticate with Anthropic",S.jsx(sa,{className:"h-3.5 w-3.5 opacity-60"})]})}),S.jsxs("div",{className:"relative",children:[S.jsx("input",{type:"text",value:T,onChange:re=>k(re.target.value),onKeyDown:re=>re.key==="Enter"&&Wa(),placeholder:"Paste your code here...",className:yt+" pr-10 font-mono"}),S.jsx("button",{onClick:Cd,className:"absolute right-3 top-1/2 -translate-y-1/2 text-white/20 hover:text-white/50 transition-colors",children:S.jsx(EM,{className:"h-3.5 w-3.5"})})]}),S.jsx("button",{onClick:Wa,disabled:!T.trim()||w,className:"w-full py-2.5 px-4 bg-primary hover:bg-primary/90 text-white text-[13px] font-medium rounded-xl transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:w?S.jsxs(S.Fragment,{children:[S.jsx(so,{className:"h-3.5 w-3.5 animate-spin"}),"Verifying..."]}):"Connect"}),S.jsxs("button",{onClick:Ll,disabled:F,className:"w-full py-1.5 text-white/25 text-[11px] hover:text-white/40 transition-colors flex items-center justify-center gap-1.5 disabled:opacity-50",children:[F?S.jsx(so,{className:"h-3 w-3 animate-spin"}):S.jsx(zM,{className:"h-3 w-3"}),F?"Checking...":"I'm already authenticated"]})]})]}),l==="openai"&&S.jsxs("div",{className:"space-y-2.5",children:[va&&S.jsx("div",{className:"bg-emerald-500/8 border border-emerald-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-emerald-400/90 text-[12px]",children:"Connected — ChatGPT subscription is active."})}),!va&&S.jsxs(S.Fragment,{children:[W&&S.jsx("div",{className:"bg-red-500/8 border border-red-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-red-400/90 text-[12px]",children:W})}),S.jsx("div",{className:"space-y-1.5",children:["Click the button below — your browser will open for ChatGPT sign-in","Sign in with your ChatGPT Plus or Pro account","Authentication completes automatically — no code to copy"].map((re,Ae)=>S.jsxs("div",{className:"flex items-start gap-2",children:[S.jsx("span",{className:"flex-shrink-0 w-[18px] h-[18px] rounded-full bg-white/[0.06] text-white/30 text-[10px] font-medium flex items-center justify-center mt-px",children:Ae+1}),S.jsx("p",{className:"text-white/40 text-[12px] leading-relaxed",children:re})]},Ae))}),S.jsx("button",{onClick:Ho,disabled:z,className:"w-full py-2.5 px-4 bg-white/[0.06] hover:bg-white/[0.09] text-white text-[13px] font-medium rounded-xl transition-colors flex items-center justify-center gap-2 disabled:opacity-60",children:z?S.jsxs(S.Fragment,{children:[S.jsx(so,{className:"h-3.5 w-3.5 animate-spin opacity-60"}),"Waiting for sign-in..."]}):S.jsxs(S.Fragment,{children:["Authenticate with ChatGPT",S.jsx(sa,{className:"h-3.5 w-3.5 opacity-60"})]})}),z&&S.jsx("button",{onClick:Fr,className:"w-full py-1.5 text-white/25 text-[11px] hover:text-white/40 transition-colors",children:"Cancel"})]})]}),l==="ollama"&&S.jsxs("div",{className:"space-y-2.5",children:[S.jsx("div",{className:"bg-emerald-500/8 border border-emerald-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-emerald-400/90 text-[12px]",children:"No authentication needed — Ollama runs locally."})}),S.jsxs("div",{children:[S.jsxs("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:["Base URL ",S.jsx("span",{className:"text-white/20",children:"(optional)"})]}),S.jsx("input",{type:"text",value:X,onChange:re=>Q(re.target.value),placeholder:"http://localhost:11434",className:yt})]})]}),va&&S.jsxs(S.Fragment,{children:[S.jsx("div",{className:"border-t border-white/[0.06] mt-4 mb-3"}),S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:"Select a model"}),S.jsx(PY,{models:BY[l]||[],value:d,onChange:f})]}),va&&S.jsxs("button",{onClick:$n,disabled:!Ka,className:"w-full mt-4 py-3 bg-primary hover:bg-primary/90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:["Continue",S.jsx(sa,{className:"h-4 w-4"})]})]}),t===5&&S.jsxs("div",{children:[S.jsxs("div",{className:"flex items-center gap-2 mb-1",children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"Voice Messages"}),S.jsx("span",{className:"text-[11px] text-white/25 font-medium bg-white/[0.04] border border-white/[0.06] rounded-full px-2.5 py-0.5",children:"Optional"})]}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1 leading-relaxed",children:"Allow users to send audio messages that are automatically transcribed."}),S.jsx("button",{onClick:()=>Lt(re=>!re),className:`w-full mt-5 rounded-xl border transition-all duration-200 p-4 text-left ${Ze?"bg-white/[0.04] border-primary/40":"bg-transparent border-white/[0.06] hover:border-white/10 hover:bg-white/[0.02]"}`,children:S.jsxs("div",{className:"flex items-center gap-3.5",children:[S.jsx("img",{src:"/icons/openai.svg",alt:"OpenAI",className:"w-10 h-10 rounded-xl bg-white/[0.04] p-1.5"}),S.jsxs("div",{className:"flex-1",children:[S.jsx("div",{className:"text-[14px] font-medium text-white",children:"OpenAI Whisper"}),S.jsx("div",{className:"text-[12px] text-white/35 mt-0.5 leading-relaxed",children:"Speech-to-text powered by OpenAI. Requires an OpenAI API key."})]}),S.jsx("div",{className:`w-10 h-[22px] rounded-full transition-colors duration-200 flex items-center px-0.5 shrink-0 ${Ze?"bg-primary":"bg-white/[0.08]"}`,children:S.jsx("div",{className:`w-[18px] h-[18px] rounded-full bg-white shadow-sm transition-transform duration-200 ${Ze?"translate-x-[18px]":"translate-x-0"}`})})]})}),Ze&&S.jsxs("div",{className:"mt-3",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:"OpenAI API Key"}),S.jsx("input",{type:"password",value:Le,onChange:re=>Gn(re.target.value.trim()),placeholder:"sk-...",autoComplete:"off",className:Vt+" font-mono text-[13px]"}),Le.length>0&&!Le.startsWith("sk-")&&S.jsx("p",{className:"text-amber-400/70 text-[11px] mt-1",children:"Key should start with sk-"}),Le.length>0&&Le.startsWith("sk-")&&Le.length<20&&S.jsx("p",{className:"text-amber-400/70 text-[11px] mt-1",children:"Key looks too short"}),S.jsxs("div",{className:"flex items-start gap-2.5 mt-3 bg-white/[0.02] border border-white/[0.06] rounded-xl px-4 py-3",children:[S.jsx(jm,{className:"h-4 w-4 text-primary/60 mt-0.5 shrink-0"}),S.jsx("p",{className:"text-white/35 text-[12px] leading-relaxed",children:"Users will see a microphone button in the chat. Audio is sent to OpenAI's Whisper API for transcription, then processed as a regular text message."})]})]}),S.jsx("button",{onClick:Ul,disabled:p||Ze&&(!Le.startsWith("sk-")||Le.length<20),className:"w-full mt-5 py-3 bg-primary hover:bg-primary/90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:p?S.jsxs(S.Fragment,{children:[S.jsx(so,{className:"h-4 w-4 animate-spin"}),"Setting up..."]}):S.jsxs(S.Fragment,{children:["Complete Setup",S.jsx(sa,{className:"h-4 w-4"})]})}),!Ze&&S.jsx("p",{className:"text-center text-white/20 text-[11px] mt-2.5",children:"You can enable this later in Settings."})]})]},t)}),t>0&&S.jsx("div",{className:"px-8 pb-5 -mt-3",children:S.jsx("button",{onClick:qo,className:"text-white/25 hover:text-white/50 text-[12px] transition-colors",children:"← Back"})})]})]})}function zY({...e}){return S.jsx(Uj,{"data-slot":"dropdown-menu",...e})}function GY({...e}){return S.jsx(Bj,{"data-slot":"dropdown-menu-trigger",...e})}function $Y({className:e,sideOffset:t=4,...n}){return S.jsx(Pj,{children:S.jsx(jj,{"data-slot":"dropdown-menu-content",sideOffset:t,className:pn("bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 max-h-(--radix-dropdown-menu-content-available-height) min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border p-1 shadow-md",e),...n})})}function HY({className:e,inset:t,variant:n="default",...r}){return S.jsx(zj,{"data-slot":"dropdown-menu-item","data-inset":t,"data-variant":n,className:pn("focus:bg-accent focus:text-accent-foreground data-[variant=destructive]:text-destructive data-[variant=destructive]:focus:bg-destructive/10 dark:data-[variant=destructive]:focus:bg-destructive/20 data-[variant=destructive]:focus:text-destructive data-[variant=destructive]:*:[svg]:!text-destructive [&_svg:not([class*='text-'])]:text-muted-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),...r})}function VY(){return S.jsx("div",{className:"flex items-center justify-center h-dvh p-6 text-center",children:S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-semibold mb-2",children:"Something went wrong"}),S.jsx("p",{className:"text-sm text-muted-foreground",children:"The dashboard encountered an error. Use the Fluxy button to continue chatting."})]})})}function qY(){const[e,t]=A.useState(!1),[n,r]=A.useState(!1),[o,l]=A.useState("Fluxy"),[u,d]=A.useState(!1),{ws:f,connected:p}=XL(),m=A.useRef(null);A.useEffect(()=>{fetch("/api/settings").then(y=>y.json()).then(y=>{y.onboard_complete!=="true"&&r(!0),y.agent_name&&l(y.agent_name),y.whisper_enabled==="true"&&d(!0)}).catch(()=>r(!0))},[]);const g=()=>{r(!1),fetch("/api/settings").then(y=>y.json()).then(y=>{y.agent_name&&l(y.agent_name),d(y.whisper_enabled==="true")}).catch(()=>{})};return S.jsxs(S.Fragment,{children:[S.jsx(t2,{fallback:S.jsx(VY,{}),children:S.jsx(iz,{onOpenOnboard:()=>r(!0),children:S.jsx(cz,{})})}),S.jsx(xC,{open:e,onOpenChange:t,children:S.jsxs(wC,{side:"right",className:"w-full sm:max-w-md !gap-0 !p-0 !border-l-0 !h-dvh overflow-hidden",onOpenAutoFocus:y=>y.preventDefault(),children:[S.jsxs("div",{className:"flex items-center gap-3 px-4 pr-12 py-3 border-b border-border shrink-0",children:[S.jsx("img",{src:"/fluxy.png",alt:o,className:"h-5 w-auto"}),S.jsx(TC,{className:"text-sm font-semibold",children:o}),S.jsx("div",{className:`h-2 w-2 rounded-full ${p?"bg-green-500":"bg-red-500"}`}),S.jsx("div",{className:"flex-1"}),S.jsxs(zY,{children:[S.jsx(GY,{asChild:!0,children:S.jsx("button",{className:"flex items-center justify-center h-7 w-7 rounded-full text-muted-foreground hover:text-foreground hover:bg-white/[0.06] transition-colors",children:S.jsx(vM,{className:"h-4 w-4"})})}),S.jsx($Y,{align:"end",sideOffset:8,children:S.jsxs(HY,{onClick:()=>m.current?.(),children:[S.jsx(lN,{className:"h-3.5 w-3.5"}),"Clear Context"]})})]}),S.jsxs(nz,{className:"sr-only",children:["Chat with your ",o," AI assistant"]})]}),S.jsx("div",{className:"flex-1 min-h-0 flex flex-col overflow-hidden",children:S.jsx(MY,{ws:f,clearContextRef:m,whisperEnabled:u})})]})}),S.jsx(FY,{onClick:()=>t(y=>!y)}),n&&S.jsx(jY,{onComplete:g})]})}WL.createRoot(document.getElementById("root")).render(S.jsx(zt.StrictMode,{children:S.jsx(qY,{})}));
|
|
100
|
+
`),()=>{F.contains(L)&&F.removeChild(L)}},[t]),S.jsx(E9,{isPresent:t,childRef:d,sizeRef:f,pop:l,children:l===!1?e:A.cloneElement(e,{ref:g})})}const v9=({children:e,initial:t,isPresent:n,onExitComplete:r,custom:o,presenceAffectsLayout:l,mode:u,anchorX:d,anchorY:f,root:p})=>{const m=kv(x9),g=A.useId();let y=!0,E=A.useMemo(()=>(y=!1,{id:g,initial:t,isPresent:n,custom:o,onExitComplete:v=>{m.set(v,!0);for(const T of m.values())if(!T)return;r&&r()},register:v=>(m.set(v,!1),()=>m.delete(v))}),[n,m,r]);return l&&y&&(E={...E}),A.useMemo(()=>{m.forEach((v,T)=>m.set(T,!1))},[n]),A.useEffect(()=>{!n&&!m.size&&r&&r()},[n]),e=S.jsx(S9,{pop:u==="popLayout",isPresent:n,anchorX:d,anchorY:f,root:p,children:e}),S.jsx(kd.Provider,{value:E,children:e})};function x9(){return new Map}function h1(e=!0){const t=A.useContext(kd);if(t===null)return[!0,null];const{isPresent:n,onExitComplete:r,register:o}=t,l=A.useId();A.useEffect(()=>{if(e)return o(l)},[e]);const u=A.useCallback(()=>e&&r&&r(l),[l,r,e]);return!n&&r?[!1,u]:[!0]}const pc=e=>e.key||"";function j_(e){const t=[];return A.Children.forEach(e,n=>{A.isValidElement(n)&&t.push(n)}),t}const qc=({children:e,custom:t,initial:n=!0,onExitComplete:r,presenceAffectsLayout:o=!0,mode:l="sync",propagate:u=!1,anchorX:d="left",anchorY:f="top",root:p})=>{const[m,g]=h1(u),y=A.useMemo(()=>j_(e),[e]),E=u&&!m?[]:y.map(pc),v=A.useRef(!0),T=A.useRef(y),k=kv(()=>new Map),w=A.useRef(new Set),[C,N]=A.useState(y),[L,F]=A.useState(y);HO(()=>{v.current=!1,T.current=y;for(let B=0;B<L.length;B++){const W=pc(L[B]);E.includes(W)?(k.delete(W),w.current.delete(W)):k.get(W)!==!0&&k.set(W,!1)}},[L,E.length,E.join("-")]);const D=[];if(y!==C){let B=[...y];for(let W=0;W<L.length;W++){const U=L[W],X=pc(U);E.includes(X)||(B.splice(W,0,U),D.push(U))}return l==="wait"&&D.length&&(B=D),F(j_(B)),N(y),null}const{forceRender:z}=A.useContext(Av);return S.jsx(S.Fragment,{children:L.map(B=>{const W=pc(B),U=u&&!m?!1:y===L||E.includes(W),X=()=>{if(w.current.has(W))return;if(w.current.add(W),k.has(W))k.set(W,!0);else return;let Q=!0;k.forEach(te=>{te||(Q=!1)}),Q&&(z?.(),F(T.current),u&&g?.(),r&&r())};return S.jsx(v9,{isPresent:U,initial:!v.current||n?void 0:!1,custom:t,presenceAffectsLayout:o,mode:l,root:p,onExitComplete:U?void 0:X,anchorX:d,anchorY:f,children:B},W)})})},b1=A.createContext({strict:!1}),z_={animation:["animate","variants","whileHover","whileTap","exit","whileInView","whileFocus","whileDrag"],exit:["exit"],drag:["drag","dragControls"],focus:["whileFocus"],hover:["whileHover","onHoverStart","onHoverEnd"],tap:["whileTap","onTap","onTapStart","onTapCancel"],pan:["onPan","onPanStart","onPanSessionStart","onPanEnd"],inView:["whileInView","onViewportEnter","onViewportLeave"],layout:["layout","layoutId"]};let G_=!1;function w9(){if(G_)return;const e={};for(const t in z_)e[t]={isEnabled:n=>z_[t].some(r=>!!n[r])};qI(e),G_=!0}function y1(){return w9(),u8()}function T9(e){const t=y1();for(const n in e)t[n]={...t[n],...e[n]};qI(t)}const A9=new Set(["animate","exit","variants","initial","style","values","variants","transition","transformTemplate","custom","inherit","onBeforeLayoutMeasure","onAnimationStart","onAnimationComplete","onUpdate","onDragStart","onDrag","onDragEnd","onMeasureDragConstraints","onDirectionLock","onDragTransitionEnd","_dragX","_dragY","onHoverStart","onHoverEnd","onViewportEnter","onViewportLeave","globalTapTarget","propagate","ignoreStrict","viewport"]);function Yc(e){return e.startsWith("while")||e.startsWith("drag")&&e!=="draggable"||e.startsWith("layout")||e.startsWith("onTap")||e.startsWith("onPan")||e.startsWith("onLayout")||A9.has(e)}let E1=e=>!Yc(e);function k9(e){typeof e=="function"&&(E1=t=>t.startsWith("on")?!Yc(t):e(t))}try{k9(require("@emotion/is-prop-valid").default)}catch{}function R9(e,t,n){const r={};for(const o in e)o==="values"&&typeof e.values=="object"||(E1(o)||n===!0&&Yc(o)||!t&&!Yc(o)||e.draggable&&o.startsWith("onDrag"))&&(r[o]=e[o]);return r}const Nd=A.createContext({});function _9(e,t){if(_d(e)){const{initial:n,animate:r}=e;return{initial:n===!1||fl(n)?n:void 0,animate:fl(r)?r:void 0}}return e.inherit!==!1?t:{}}function N9(e){const{initial:t,animate:n}=_9(e,A.useContext(Nd));return A.useMemo(()=>({initial:t,animate:n}),[$_(t),$_(n)])}function $_(e){return Array.isArray(e)?e.join(" "):e}const ex=()=>({style:{},transform:{},transformOrigin:{},vars:{}});function S1(e,t,n){for(const r in t)!Wt(t[r])&&!JI(r,n)&&(e[r]=t[r])}function C9({transformTemplate:e},t){return A.useMemo(()=>{const n=ex();return Zv(n,t,e),Object.assign({},n.vars,n.style)},[t])}function O9(e,t){const n=e.style||{},r={};return S1(r,n,e),Object.assign(r,C9(e,t)),r}function I9(e,t){const n={},r=O9(e,t);return e.drag&&e.dragListener!==!1&&(n.draggable=!1,r.userSelect=r.WebkitUserSelect=r.WebkitTouchCallout="none",r.touchAction=e.drag===!0?"none":`pan-${e.drag==="x"?"y":"x"}`),e.tabIndex===void 0&&(e.onTap||e.onTapStart||e.whileTap)&&(n.tabIndex=0),n.style=r,n}const v1=()=>({...ex(),attrs:{}});function D9(e,t,n,r){const o=A.useMemo(()=>{const l=v1();return e1(l,t,n1(r),e.transformTemplate,e.style),{...l.attrs,style:{...l.style}}},[t]);if(e.style){const l={};S1(l,e.style,e),o.style={...l,...o.style}}return o}const L9=["animate","circle","defs","desc","ellipse","g","image","line","filter","marker","mask","metadata","path","pattern","polygon","polyline","rect","stop","switch","symbol","svg","text","tspan","use","view"];function tx(e){return typeof e!="string"||e.includes("-")?!1:!!(L9.indexOf(e)>-1||/[A-Z]/u.test(e))}function M9(e,t,n,{latestValues:r},o,l=!1,u){const f=(u??tx(e)?D9:I9)(t,r,o,e),p=R9(t,typeof e=="string",l),m=e!==A.Fragment?{...p,...f,ref:n}:{},{children:g}=t,y=A.useMemo(()=>Wt(g)?g.get():g,[g]);return A.createElement(e,{...m,children:y})}function F9({scrapeMotionValuesFromProps:e,createRenderState:t},n,r,o){return{latestValues:U9(n,r,o,e),renderState:t()}}function U9(e,t,n,r){const o={},l=r(e,{});for(const y in l)o[y]=Ac(l[y]);let{initial:u,animate:d}=e;const f=_d(e),p=HI(e);t&&p&&!f&&e.inherit!==!1&&(u===void 0&&(u=t.initial),d===void 0&&(d=t.animate));let m=n?n.initial===!1:!1;m=m||u===!1;const g=m?d:u;if(g&&typeof g!="boolean"&&!Rd(g)){const y=Array.isArray(g)?g:[g];for(let E=0;E<y.length;E++){const v=$v(e,y[E]);if(v){const{transitionEnd:T,transition:k,...w}=v;for(const C in w){let N=w[C];if(Array.isArray(N)){const L=m?N.length-1:0;N=N[L]}N!==null&&(o[C]=N)}for(const C in T)o[C]=T[C]}}}return o}const x1=e=>(t,n)=>{const r=A.useContext(Nd),o=A.useContext(kd),l=()=>F9(e,t,r,o);return n?l():kv(l)},B9=x1({scrapeMotionValuesFromProps:Qv,createRenderState:ex}),P9=x1({scrapeMotionValuesFromProps:a1,createRenderState:v1}),j9=Symbol.for("motionComponentSymbol");function z9(e,t,n){const r=A.useRef(n);A.useInsertionEffect(()=>{r.current=n});const o=A.useRef(null);return A.useCallback(l=>{l&&e.onMount?.(l),t&&(l?t.mount(l):t.unmount());const u=r.current;if(typeof u=="function")if(l){const d=u(l);typeof d=="function"&&(o.current=d)}else o.current?(o.current(),o.current=null):u(l);else u&&(u.current=l)},[t])}const w1=A.createContext({});function go(e){return e&&typeof e=="object"&&Object.prototype.hasOwnProperty.call(e,"current")}function G9(e,t,n,r,o,l){const{visualElement:u}=A.useContext(Nd),d=A.useContext(b1),f=A.useContext(kd),p=A.useContext(Jv),m=p.reducedMotion,g=p.skipAnimations,y=A.useRef(null),E=A.useRef(!1);r=r||d.renderer,!y.current&&r&&(y.current=r(e,{visualState:t,parent:u,props:n,presenceContext:f,blockInitialAnimation:f?f.initial===!1:!1,reducedMotionConfig:m,skipAnimations:g,isSVG:l}),E.current&&y.current&&(y.current.manuallyAnimateOnMount=!0));const v=y.current,T=A.useContext(w1);v&&!v.projection&&o&&(v.type==="html"||v.type==="svg")&&$9(y.current,n,o,T);const k=A.useRef(!1);A.useInsertionEffect(()=>{v&&k.current&&v.update(n,f)});const w=n[OI],C=A.useRef(!!w&&!window.MotionHandoffIsComplete?.(w)&&window.MotionHasOptimisedAnimation?.(w));return HO(()=>{E.current=!0,v&&(k.current=!0,window.MotionIsMounted=!0,v.updateFeatures(),v.scheduleRenderMicrotask(),C.current&&v.animationState&&v.animationState.animateChanges())}),A.useEffect(()=>{v&&(!C.current&&v.animationState&&v.animationState.animateChanges(),C.current&&(queueMicrotask(()=>{window.MotionHandoffMarkAsComplete?.(w)}),C.current=!1),v.enteringChildren=void 0)}),v}function $9(e,t,n,r){const{layoutId:o,layout:l,drag:u,dragConstraints:d,layoutScroll:f,layoutRoot:p,layoutCrossfade:m}=t;e.projection=new n(e.latestValues,t["data-framer-portal-id"]?void 0:T1(e.parent)),e.projection.setOptions({layoutId:o,layout:l,alwaysMeasureLayout:!!u||d&&go(d),visualElement:e,animationType:typeof l=="string"?l:"both",initialPromotionConfig:r,crossfade:m,layoutScroll:f,layoutRoot:p})}function T1(e){if(e)return e.options.allowProjection!==!1?e.projection:T1(e.parent)}function Lm(e,{forwardMotionProps:t=!1,type:n}={},r,o){r&&T9(r);const l=n?n==="svg":tx(e),u=l?P9:B9;function d(p,m){let g;const y={...A.useContext(Jv),...p,layoutId:H9(p)},{isStatic:E}=y,v=N9(p),T=u(p,E);if(!E&&$O){V9();const k=q9(y);g=k.MeasureLayout,v.visualElement=G9(e,T,y,o,k.ProjectionNode,l)}return S.jsxs(Nd.Provider,{value:v,children:[g&&v.visualElement?S.jsx(g,{visualElement:v.visualElement,...y}):null,M9(e,p,z9(T,v.visualElement,m),T,E,t,l)]})}d.displayName=`motion.${typeof e=="string"?e:`create(${e.displayName??e.name??""})`}`;const f=A.forwardRef(d);return f[j9]=e,f}function H9({layoutId:e}){const t=A.useContext(Av).id;return t&&e!==void 0?t+"-"+e:e}function V9(e,t){A.useContext(b1).strict}function q9(e){const t=y1(),{drag:n,layout:r}=t;if(!n&&!r)return{};const o={...n,...r};return{MeasureLayout:n?.isEnabled(e)||r?.isEnabled(e)?o.MeasureLayout:void 0,ProjectionNode:o.ProjectionNode}}function Y9(e,t){if(typeof Proxy>"u")return Lm;const n=new Map,r=(l,u)=>Lm(l,u,e,t),o=(l,u)=>r(l,u);return new Proxy(o,{get:(l,u)=>u==="create"?r:(n.has(u)||n.set(u,Lm(u,void 0,e,t)),n.get(u))})}const W9=(e,t)=>t.isSVG??tx(e)?new k8(t):new S8(t,{allowProjection:e!==A.Fragment});class K9 extends Dr{constructor(t){super(t),t.animationState||(t.animationState=O8(t))}updateAnimationControlsSubscription(){const{animate:t}=this.node.getProps();Rd(t)&&(this.unmountControls=t.subscribe(this.node))}mount(){this.updateAnimationControlsSubscription()}update(){const{animate:t}=this.node.getProps(),{animate:n}=this.node.prevProps||{};t!==n&&this.updateAnimationControlsSubscription()}unmount(){this.node.animationState.reset(),this.unmountControls?.()}}let X9=0;class Z9 extends Dr{constructor(){super(...arguments),this.id=X9++}update(){if(!this.node.presenceContext)return;const{isPresent:t,onExitComplete:n}=this.node.presenceContext,{isPresent:r}=this.node.prevPresenceContext||{};if(!this.node.animationState||t===r)return;const o=this.node.animationState.setActive("exit",!t);n&&!t&&o.then(()=>{n(this.id)})}mount(){const{register:t,onExitComplete:n}=this.node.presenceContext||{};n&&n(this.id),t&&(this.unmount=t(this.id))}unmount(){}}const Q9={animation:{Feature:K9},exit:{Feature:Z9}};function Dl(e){return{point:{x:e.pageX,y:e.pageY}}}const J9=e=>t=>Yv(t)&&e(t,Dl(t));function el(e,t,n,r){return ml(e,t,J9(n),r)}const A1=({current:e})=>e?e.ownerDocument.defaultView:null,H_=(e,t)=>Math.abs(e-t);function eY(e,t){const n=H_(e.x,t.x),r=H_(e.y,t.y);return Math.sqrt(n**2+r**2)}const V_=new Set(["auto","scroll"]);class k1{constructor(t,n,{transformPagePoint:r,contextWindow:o=window,dragSnapToOrigin:l=!1,distanceThreshold:u=3,element:d}={}){if(this.startEvent=null,this.lastMoveEvent=null,this.lastMoveEventInfo=null,this.handlers={},this.contextWindow=window,this.scrollPositions=new Map,this.removeScrollListeners=null,this.onElementScroll=E=>{this.handleScroll(E.target)},this.onWindowScroll=()=>{this.handleScroll(window)},this.updatePoint=()=>{if(!(this.lastMoveEvent&&this.lastMoveEventInfo))return;const E=Fm(this.lastMoveEventInfo,this.history),v=this.startEvent!==null,T=eY(E.offset,{x:0,y:0})>=this.distanceThreshold;if(!v&&!T)return;const{point:k}=E,{timestamp:w}=jt;this.history.push({...k,timestamp:w});const{onStart:C,onMove:N}=this.handlers;v||(C&&C(this.lastMoveEvent,E),this.startEvent=this.lastMoveEvent),N&&N(this.lastMoveEvent,E)},this.handlePointerMove=(E,v)=>{this.lastMoveEvent=E,this.lastMoveEventInfo=Mm(v,this.transformPagePoint),it.update(this.updatePoint,!0)},this.handlePointerUp=(E,v)=>{this.end();const{onEnd:T,onSessionEnd:k,resumeAnimation:w}=this.handlers;if((this.dragSnapToOrigin||!this.startEvent)&&w&&w(),!(this.lastMoveEvent&&this.lastMoveEventInfo))return;const C=Fm(E.type==="pointercancel"?this.lastMoveEventInfo:Mm(v,this.transformPagePoint),this.history);this.startEvent&&T&&T(E,C),k&&k(E,C)},!Yv(t))return;this.dragSnapToOrigin=l,this.handlers=n,this.transformPagePoint=r,this.distanceThreshold=u,this.contextWindow=o||window;const f=Dl(t),p=Mm(f,this.transformPagePoint),{point:m}=p,{timestamp:g}=jt;this.history=[{...m,timestamp:g}];const{onSessionStart:y}=n;y&&y(t,Fm(p,this.history)),this.removeListeners=Cl(el(this.contextWindow,"pointermove",this.handlePointerMove),el(this.contextWindow,"pointerup",this.handlePointerUp),el(this.contextWindow,"pointercancel",this.handlePointerUp)),d&&this.startScrollTracking(d)}startScrollTracking(t){let n=t.parentElement;for(;n;){const r=getComputedStyle(n);(V_.has(r.overflowX)||V_.has(r.overflowY))&&this.scrollPositions.set(n,{x:n.scrollLeft,y:n.scrollTop}),n=n.parentElement}this.scrollPositions.set(window,{x:window.scrollX,y:window.scrollY}),window.addEventListener("scroll",this.onElementScroll,{capture:!0}),window.addEventListener("scroll",this.onWindowScroll),this.removeScrollListeners=()=>{window.removeEventListener("scroll",this.onElementScroll,{capture:!0}),window.removeEventListener("scroll",this.onWindowScroll)}}handleScroll(t){const n=this.scrollPositions.get(t);if(!n)return;const r=t===window,o=r?{x:window.scrollX,y:window.scrollY}:{x:t.scrollLeft,y:t.scrollTop},l={x:o.x-n.x,y:o.y-n.y};l.x===0&&l.y===0||(r?this.lastMoveEventInfo&&(this.lastMoveEventInfo.point.x+=l.x,this.lastMoveEventInfo.point.y+=l.y):this.history.length>0&&(this.history[0].x-=l.x,this.history[0].y-=l.y),this.scrollPositions.set(t,o),it.update(this.updatePoint,!0))}updateHandlers(t){this.handlers=t}end(){this.removeListeners&&this.removeListeners(),this.removeScrollListeners&&this.removeScrollListeners(),this.scrollPositions.clear(),Nr(this.updatePoint)}}function Mm(e,t){return t?{point:t(e.point)}:e}function q_(e,t){return{x:e.x-t.x,y:e.y-t.y}}function Fm({point:e},t){return{point:e,delta:q_(e,R1(t)),offset:q_(e,tY(t)),velocity:nY(t,.1)}}function tY(e){return e[0]}function R1(e){return e[e.length-1]}function nY(e,t){if(e.length<2)return{x:0,y:0};let n=e.length-1,r=null;const o=R1(e);for(;n>=0&&(r=e[n],!(o.timestamp-r.timestamp>Xn(t)));)n--;if(!r)return{x:0,y:0};r===e[0]&&e.length>2&&o.timestamp-r.timestamp>Xn(t)*2&&(r=e[1]);const l=Pn(o.timestamp-r.timestamp);if(l===0)return{x:0,y:0};const u={x:(o.x-r.x)/l,y:(o.y-r.y)/l};return u.x===1/0&&(u.x=0),u.y===1/0&&(u.y=0),u}function aY(e,{min:t,max:n},r){return t!==void 0&&e<t?e=r?ut(t,e,r.min):Math.max(e,t):n!==void 0&&e>n&&(e=r?ut(n,e,r.max):Math.min(e,n)),e}function Y_(e,t,n){return{min:t!==void 0?e.min+t:void 0,max:n!==void 0?e.max+n-(e.max-e.min):void 0}}function rY(e,{top:t,left:n,bottom:r,right:o}){return{x:Y_(e.x,n,o),y:Y_(e.y,t,r)}}function W_(e,t){let n=t.min-e.min,r=t.max-e.max;return t.max-t.min<e.max-e.min&&([n,r]=[r,n]),{min:n,max:r}}function iY(e,t){return{x:W_(e.x,t.x),y:W_(e.y,t.y)}}function oY(e,t){let n=.5;const r=nn(e),o=nn(t);return o>r?n=cl(t.min,t.max-r,e.min):r>o&&(n=cl(e.min,e.max-o,t.min)),ha(0,1,n)}function sY(e,t){const n={};return t.min!==void 0&&(n.min=t.min-e.min),t.max!==void 0&&(n.max=t.max-e.min),n}const Dg=.35;function lY(e=Dg){return e===!1?e=0:e===!0&&(e=Dg),{x:K_(e,"left","right"),y:K_(e,"top","bottom")}}function K_(e,t,n){return{min:X_(e,t),max:X_(e,n)}}function X_(e,t){return typeof e=="number"?e:e[t]||0}const uY=new WeakMap;class cY{constructor(t){this.openDragLock=null,this.isDragging=!1,this.currentDirection=null,this.originPoint={x:0,y:0},this.constraints=!1,this.hasMutatedConstraints=!1,this.elastic=Rt(),this.latestPointerEvent=null,this.latestPanInfo=null,this.visualElement=t}start(t,{snapToCursor:n=!1,distanceThreshold:r}={}){const{presenceContext:o}=this.visualElement;if(o&&o.isPresent===!1)return;const l=g=>{n&&this.snapToCursor(Dl(g).point),this.stopAnimation()},u=(g,y)=>{const{drag:E,dragPropagation:v,onDragStart:T}=this.getProps();if(E&&!v&&(this.openDragLock&&this.openDragLock(),this.openDragLock=Pq(E),!this.openDragLock))return;this.latestPointerEvent=g,this.latestPanInfo=y,this.isDragging=!0,this.currentDirection=null,this.resolveConstraints(),this.visualElement.projection&&(this.visualElement.projection.isAnimationBlocked=!0,this.visualElement.projection.target=void 0),ua(w=>{let C=this.getAxisMotionValue(w).get()||0;if(fa.test(C)){const{projection:N}=this.visualElement;if(N&&N.layout){const L=N.layout.layoutBox[w];L&&(C=nn(L)*(parseFloat(C)/100))}}this.originPoint[w]=C}),T&&it.update(()=>T(g,y),!1,!0),Tg(this.visualElement,"transform");const{animationState:k}=this.visualElement;k&&k.setActive("whileDrag",!0)},d=(g,y)=>{this.latestPointerEvent=g,this.latestPanInfo=y;const{dragPropagation:E,dragDirectionLock:v,onDirectionLock:T,onDrag:k}=this.getProps();if(!E&&!this.openDragLock)return;const{offset:w}=y;if(v&&this.currentDirection===null){this.currentDirection=pY(w),this.currentDirection!==null&&T&&T(this.currentDirection);return}this.updateAxis("x",y.point,w),this.updateAxis("y",y.point,w),this.visualElement.render(),k&&it.update(()=>k(g,y),!1,!0)},f=(g,y)=>{this.latestPointerEvent=g,this.latestPanInfo=y,this.stop(g,y),this.latestPointerEvent=null,this.latestPanInfo=null},p=()=>{const{dragSnapToOrigin:g}=this.getProps();(g||this.constraints)&&this.startAnimation({x:0,y:0})},{dragSnapToOrigin:m}=this.getProps();this.panSession=new k1(t,{onSessionStart:l,onStart:u,onMove:d,onSessionEnd:f,resumeAnimation:p},{transformPagePoint:this.visualElement.getTransformPagePoint(),dragSnapToOrigin:m,distanceThreshold:r,contextWindow:A1(this.visualElement),element:this.visualElement.current})}stop(t,n){const r=t||this.latestPointerEvent,o=n||this.latestPanInfo,l=this.isDragging;if(this.cancel(),!l||!o||!r)return;const{velocity:u}=o;this.startAnimation(u);const{onDragEnd:d}=this.getProps();d&&it.postRender(()=>d(r,o))}cancel(){this.isDragging=!1;const{projection:t,animationState:n}=this.visualElement;t&&(t.isAnimationBlocked=!1),this.endPanSession();const{dragPropagation:r}=this.getProps();!r&&this.openDragLock&&(this.openDragLock(),this.openDragLock=null),n&&n.setActive("whileDrag",!1)}endPanSession(){this.panSession&&this.panSession.end(),this.panSession=void 0}updateAxis(t,n,r){const{drag:o}=this.getProps();if(!r||!fc(t,o,this.currentDirection))return;const l=this.getAxisMotionValue(t);let u=this.originPoint[t]+r[t];this.constraints&&this.constraints[t]&&(u=aY(u,this.constraints[t],this.elastic[t])),l.set(u)}resolveConstraints(){const{dragConstraints:t,dragElastic:n}=this.getProps(),r=this.visualElement.projection&&!this.visualElement.projection.layout?this.visualElement.projection.measure(!1):this.visualElement.projection?.layout,o=this.constraints;t&&go(t)?this.constraints||(this.constraints=this.resolveRefConstraints()):t&&r?this.constraints=rY(r.layoutBox,t):this.constraints=!1,this.elastic=lY(n),o!==this.constraints&&!go(t)&&r&&this.constraints&&!this.hasMutatedConstraints&&ua(l=>{this.constraints!==!1&&this.getAxisMotionValue(l)&&(this.constraints[l]=sY(r.layoutBox[l],this.constraints[l]))})}resolveRefConstraints(){const{dragConstraints:t,onMeasureDragConstraints:n}=this.getProps();if(!t||!go(t))return!1;const r=t.current,{projection:o}=this.visualElement;if(!o||!o.layout)return!1;const l=m8(r,o.root,this.visualElement.getTransformPagePoint());let u=iY(o.layout.layoutBox,l);if(n){const d=n(d8(u));this.hasMutatedConstraints=!!d,d&&(u=WI(d))}return u}startAnimation(t){const{drag:n,dragMomentum:r,dragElastic:o,dragTransition:l,dragSnapToOrigin:u,onDragTransitionEnd:d}=this.getProps(),f=this.constraints||{},p=ua(m=>{if(!fc(m,n,this.currentDirection))return;let g=f&&f[m]||{};u&&(g={min:0,max:0});const y=o?200:1e6,E=o?40:1e7,v={type:"inertia",velocity:r?t[m]:0,bounceStiffness:y,bounceDamping:E,timeConstant:750,restDelta:1,restSpeed:10,...l,...g};return this.startAxisValueAnimation(m,v)});return Promise.all(p).then(d)}startAxisValueAnimation(t,n){const r=this.getAxisMotionValue(t);return Tg(this.visualElement,t),r.start(Gv(t,r,0,n,this.visualElement,!1))}stopAnimation(){ua(t=>this.getAxisMotionValue(t).stop())}getAxisMotionValue(t){const n=`_drag${t.toUpperCase()}`,r=this.visualElement.getProps(),o=r[n];return o||this.visualElement.getValue(t,(r.initial?r.initial[t]:void 0)||0)}snapToCursor(t){ua(n=>{const{drag:r}=this.getProps();if(!fc(n,r,this.currentDirection))return;const{projection:o}=this.visualElement,l=this.getAxisMotionValue(n);if(o&&o.layout){const{min:u,max:d}=o.layout.layoutBox[n],f=l.get()||0;l.set(t[n]-ut(u,d,.5)+f)}})}scalePositionWithinConstraints(){if(!this.visualElement.current)return;const{drag:t,dragConstraints:n}=this.getProps(),{projection:r}=this.visualElement;if(!go(n)||!r||!this.constraints)return;this.stopAnimation();const o={x:0,y:0};ua(u=>{const d=this.getAxisMotionValue(u);if(d&&this.constraints!==!1){const f=d.get();o[u]=oY({min:f,max:f},this.constraints[u])}});const{transformTemplate:l}=this.visualElement.getProps();this.visualElement.current.style.transform=l?l({},""):"none",r.root&&r.root.updateScroll(),r.updateLayout(),this.constraints=!1,this.resolveConstraints(),ua(u=>{if(!fc(u,t,null))return;const d=this.getAxisMotionValue(u),{min:f,max:p}=this.constraints[u];d.set(ut(f,p,o[u]))}),this.visualElement.render()}addListeners(){if(!this.visualElement.current)return;uY.set(this.visualElement,this);const t=this.visualElement.current,n=el(t,"pointerdown",p=>{const{drag:m,dragListener:g=!0}=this.getProps(),y=p.target,E=y!==t&&Vq(y);m&&g&&!E&&this.start(p)});let r;const o=()=>{const{dragConstraints:p}=this.getProps();go(p)&&p.current&&(this.constraints=this.resolveRefConstraints(),r||(r=dY(t,p.current,()=>this.scalePositionWithinConstraints())))},{projection:l}=this.visualElement,u=l.addEventListener("measure",o);l&&!l.layout&&(l.root&&l.root.updateScroll(),l.updateLayout()),it.read(o);const d=ml(window,"resize",()=>this.scalePositionWithinConstraints()),f=l.addEventListener("didUpdate",(({delta:p,hasLayoutChanged:m})=>{this.isDragging&&m&&(ua(g=>{const y=this.getAxisMotionValue(g);y&&(this.originPoint[g]+=p[g].translate,y.set(y.get()+p[g].translate))}),this.visualElement.render())}));return()=>{d(),n(),u(),f&&f(),r&&r()}}getProps(){const t=this.visualElement.getProps(),{drag:n=!1,dragDirectionLock:r=!1,dragPropagation:o=!1,dragConstraints:l=!1,dragElastic:u=Dg,dragMomentum:d=!0}=t;return{...t,drag:n,dragDirectionLock:r,dragPropagation:o,dragConstraints:l,dragElastic:u,dragMomentum:d}}}function Z_(e){let t=!0;return()=>{if(t){t=!1;return}e()}}function dY(e,t,n){const r=r_(e,Z_(n)),o=r_(t,Z_(n));return()=>{r(),o()}}function fc(e,t,n){return(t===!0||t===e)&&(n===null||n===e)}function pY(e,t=10){let n=null;return Math.abs(e.y)>t?n="y":Math.abs(e.x)>t&&(n="x"),n}class fY extends Dr{constructor(t){super(t),this.removeGroupControls=zn,this.removeListeners=zn,this.controls=new cY(t)}mount(){const{dragControls:t}=this.node.getProps();t&&(this.removeGroupControls=t.subscribe(this.controls)),this.removeListeners=this.controls.addListeners()||zn}update(){const{dragControls:t}=this.node.getProps(),{dragControls:n}=this.node.prevProps||{};t!==n&&(this.removeGroupControls(),t&&(this.removeGroupControls=t.subscribe(this.controls)))}unmount(){this.removeGroupControls(),this.removeListeners(),this.controls.isDragging||this.controls.endPanSession()}}const Um=e=>(t,n)=>{e&&it.update(()=>e(t,n),!1,!0)};class mY extends Dr{constructor(){super(...arguments),this.removePointerDownListener=zn}onPointerDown(t){this.session=new k1(t,this.createPanHandlers(),{transformPagePoint:this.node.getTransformPagePoint(),contextWindow:A1(this.node)})}createPanHandlers(){const{onPanSessionStart:t,onPanStart:n,onPan:r,onPanEnd:o}=this.node.getProps();return{onSessionStart:Um(t),onStart:Um(n),onMove:Um(r),onEnd:(l,u)=>{delete this.session,o&&it.postRender(()=>o(l,u))}}}mount(){this.removePointerDownListener=el(this.node.current,"pointerdown",t=>this.onPointerDown(t))}update(){this.session&&this.session.updateHandlers(this.createPanHandlers())}unmount(){this.removePointerDownListener(),this.session&&this.session.end()}}let Bm=!1;class gY extends A.Component{componentDidMount(){const{visualElement:t,layoutGroup:n,switchLayoutGroup:r,layoutId:o}=this.props,{projection:l}=t;l&&(n.group&&n.group.add(l),r&&r.register&&o&&r.register(l),Bm&&l.root.didUpdate(),l.addEventListener("animationComplete",()=>{this.safeToRemove()}),l.setOptions({...l.options,layoutDependency:this.props.layoutDependency,onExitComplete:()=>this.safeToRemove()})),kc.hasEverUpdated=!0}getSnapshotBeforeUpdate(t){const{layoutDependency:n,visualElement:r,drag:o,isPresent:l}=this.props,{projection:u}=r;return u&&(u.isPresent=l,t.layoutDependency!==n&&u.setOptions({...u.options,layoutDependency:n}),Bm=!0,o||t.layoutDependency!==n||n===void 0||t.isPresent!==l?u.willUpdate():this.safeToRemove(),t.isPresent!==l&&(l?u.promote():u.relegate()||it.postRender(()=>{const d=u.getStack();(!d||!d.members.length)&&this.safeToRemove()}))),null}componentDidUpdate(){const{projection:t}=this.props.visualElement;t&&(t.root.didUpdate(),qv.postRender(()=>{!t.currentAnimation&&t.isLead()&&this.safeToRemove()}))}componentWillUnmount(){const{visualElement:t,layoutGroup:n,switchLayoutGroup:r}=this.props,{projection:o}=t;Bm=!0,o&&(o.scheduleCheckAfterUnmount(),n&&n.group&&n.group.remove(o),r&&r.deregister&&r.deregister(o))}safeToRemove(){const{safeToRemove:t}=this.props;t&&t()}render(){return null}}function _1(e){const[t,n]=h1(),r=A.useContext(Av);return S.jsx(gY,{...e,layoutGroup:r,switchLayoutGroup:A.useContext(w1),isPresent:t,safeToRemove:n})}const hY={pan:{Feature:mY},drag:{Feature:fY,ProjectionNode:g1,MeasureLayout:_1}};function Q_(e,t,n){const{props:r}=e;e.animationState&&r.whileHover&&e.animationState.setActive("whileHover",n==="Start");const o="onHover"+n,l=r[o];l&&it.postRender(()=>l(t,Dl(t)))}class bY extends Dr{mount(){const{current:t}=this.node;t&&(this.unmount=zq(t,(n,r)=>(Q_(this.node,r,"Start"),o=>Q_(this.node,o,"End"))))}unmount(){}}class yY extends Dr{constructor(){super(...arguments),this.isActive=!1}onFocus(){let t=!1;try{t=this.node.current.matches(":focus-visible")}catch{t=!0}!t||!this.node.animationState||(this.node.animationState.setActive("whileFocus",!0),this.isActive=!0)}onBlur(){!this.isActive||!this.node.animationState||(this.node.animationState.setActive("whileFocus",!1),this.isActive=!1)}mount(){this.unmount=Cl(ml(this.node.current,"focus",()=>this.onFocus()),ml(this.node.current,"blur",()=>this.onBlur()))}unmount(){}}function J_(e,t,n){const{props:r}=e;if(e.current instanceof HTMLButtonElement&&e.current.disabled)return;e.animationState&&r.whileTap&&e.animationState.setActive("whileTap",n==="Start");const o="onTap"+(n==="End"?"":n),l=r[o];l&&it.postRender(()=>l(t,Dl(t)))}class EY extends Dr{mount(){const{current:t}=this.node;if(!t)return;const{globalTapTarget:n,propagate:r}=this.node.props;this.unmount=Yq(t,(o,l)=>(J_(this.node,l,"Start"),(u,{success:d})=>J_(this.node,u,d?"End":"Cancel")),{useGlobalTarget:n,stopPropagation:r?.tap===!1})}unmount(){}}const Lg=new WeakMap,Pm=new WeakMap,SY=e=>{const t=Lg.get(e.target);t&&t(e)},vY=e=>{e.forEach(SY)};function xY({root:e,...t}){const n=e||document;Pm.has(n)||Pm.set(n,{});const r=Pm.get(n),o=JSON.stringify(t);return r[o]||(r[o]=new IntersectionObserver(vY,{root:e,...t})),r[o]}function wY(e,t,n){const r=xY(t);return Lg.set(e,n),r.observe(e),()=>{Lg.delete(e),r.unobserve(e)}}const TY={some:0,all:1};class AY extends Dr{constructor(){super(...arguments),this.hasEnteredView=!1,this.isInView=!1}startObserver(){this.unmount();const{viewport:t={}}=this.node.getProps(),{root:n,margin:r,amount:o="some",once:l}=t,u={root:n?n.current:void 0,rootMargin:r,threshold:typeof o=="number"?o:TY[o]},d=f=>{const{isIntersecting:p}=f;if(this.isInView===p||(this.isInView=p,l&&!p&&this.hasEnteredView))return;p&&(this.hasEnteredView=!0),this.node.animationState&&this.node.animationState.setActive("whileInView",p);const{onViewportEnter:m,onViewportLeave:g}=this.node.getProps(),y=p?m:g;y&&y(f)};return wY(this.node.current,u,d)}mount(){this.startObserver()}update(){if(typeof IntersectionObserver>"u")return;const{props:t,prevProps:n}=this.node;["amount","margin","root"].some(kY(t,n))&&this.startObserver()}unmount(){}}function kY({viewport:e={}},{viewport:t={}}={}){return n=>e[n]!==t[n]}const RY={inView:{Feature:AY},tap:{Feature:EY},focus:{Feature:yY},hover:{Feature:bY}},_Y={layout:{ProjectionNode:g1,MeasureLayout:_1}},NY={...Q9,...RY,...hY,..._Y},ui=Y9(NY,W9);function CY({images:e,index:t,onClose:n,onNavigate:r}){const o=A.useCallback(()=>{t>0&&r(t-1)},[t,r]),l=A.useCallback(()=>{t<e.length-1&&r(t+1)},[t,e.length,r]);return A.useEffect(()=>{const u=d=>{d.key==="Escape"&&n(),d.key==="ArrowLeft"&&o(),d.key==="ArrowRight"&&l()};return window.addEventListener("keydown",u),()=>window.removeEventListener("keydown",u)},[n,o,l]),S.jsx(qc,{children:S.jsxs(ui.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.15},className:"fixed inset-0 z-50 flex items-center justify-center bg-black/90",onClick:n,children:[S.jsx("button",{onClick:n,className:"absolute top-4 right-4 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:S.jsx(Kc,{className:"h-5 w-5"})}),e.length>1&&S.jsxs("div",{className:"absolute top-4 left-1/2 -translate-x-1/2 text-white/70 text-sm tabular-nums",children:[t+1," / ",e.length]}),t>0&&S.jsx("button",{onClick:u=>{u.stopPropagation(),o()},className:"absolute left-3 top-1/2 -translate-y-1/2 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:S.jsx(gM,{className:"h-6 w-6"})}),t<e.length-1&&S.jsx("button",{onClick:u=>{u.stopPropagation(),l()},className:"absolute right-3 top-1/2 -translate-y-1/2 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:S.jsx(bM,{className:"h-6 w-6"})}),S.jsx("img",{src:e[t],alt:"",className:"max-h-[85vh] max-w-[90vw] object-contain rounded-lg",onClick:u=>u.stopPropagation()})]})})}function OY({messages:e,streaming:t,streamBuffer:n,tools:r}){const o=A.useRef(null),[l,u]=A.useState(null),d=A.useCallback((m,g)=>{u({images:m,index:g})},[]);A.useEffect(()=>{o.current?.scrollIntoView({behavior:"smooth"})},[e,n,r,t]);const f=r.length>0?r[r.length-1]:null,p=f?.status==="running"?f.name:void 0;return S.jsxs("div",{className:"flex-1 overflow-y-auto overflow-x-hidden p-4 flex flex-col min-h-0",children:[S.jsx("div",{className:"flex-1"}),e.length===0&&!t&&S.jsx("div",{className:"flex items-center justify-center py-8 text-muted-foreground text-sm",children:"Start a conversation"}),S.jsxs("div",{className:"space-y-3",children:[e.map(m=>S.jsx(L5,{role:m.role,content:m.content,timestamp:m.timestamp,hasAttachments:m.hasAttachments,audioData:m.audioData,attachments:m.attachments,onImageClick:d},m.id)),t&&S.jsx(F5,{text:n,toolName:p})]}),S.jsx("div",{ref:o}),l&&S.jsx(CY,{images:l.images,index:l.index,onClose:()=>u(null),onNavigate:m=>u(g=>g?{...g,index:m}:null)})]})}function IY(e){const t=Math.floor(e/60),n=e%60;return`${t}:${n.toString().padStart(2,"0")}`}function DY(e,t=4*1024*1024){return new Promise(n=>{const r=new Image;r.onload=()=>{let{width:l,height:u}=r;if(l>1600||u>1600){const p=Math.min(1600/l,1600/u);l=Math.round(l*p),u=Math.round(u*p)}const d=document.createElement("canvas");d.width=l,d.height=u,d.getContext("2d").drawImage(r,0,0,l,u);for(const p of[.8,.6,.4,.3]){const m=d.toDataURL("image/jpeg",p);if(Math.round((m.length-23)*.75)<=t){n(m);return}}n(d.toDataURL("image/jpeg",.2))},r.onerror=()=>n(e),r.src=e})}function LY({onSend:e,onStop:t,streaming:n,whisperEnabled:r}){const[o,l]=A.useState(""),[u,d]=A.useState([]),[f,p]=A.useState(!1),[m,g]=A.useState(0),E=o.trim().length>0||u.length>0,v=A.useRef(null),T=A.useRef(null),k=A.useRef(null),w=A.useRef(null),C=A.useRef(null),N=A.useRef(0),L=A.useRef(0),F=A.useRef(null),D=A.useRef(!1),z=A.useRef(null),B=A.useRef(null),W=A.useRef([]),U=A.useRef(null);A.useEffect(()=>{const R=v.current;R&&(R.style.height="0px",R.style.height=`${Math.min(R.scrollHeight,88)}px`)},[o]),A.useEffect(()=>{if(f)return z.current=setInterval(()=>g(R=>R+1),1e3),()=>{z.current&&clearInterval(z.current)}},[f]);const X=A.useCallback(R=>{z.current&&clearInterval(z.current),F.current&&(clearTimeout(F.current),F.current=null),D.current=!1;const M=B.current,H=U.current;R||!M||M.state==="inactive"?(H?.getTracks().forEach(I=>I.stop()),B.current=null,U.current=null,W.current=[]):(M.onstop=async()=>{H?.getTracks().forEach(ue=>ue.stop());const I=new Blob(W.current,{type:"audio/webm"});if(W.current=[],B.current=null,U.current=null,I.size<1e3)return;const ce=new FileReader;ce.onloadend=async()=>{const ue=ce.result,de=ue.split(",")[1];if(de)try{const ke=await(await fetch("/api/whisper/transcribe",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({audio:de})})).json();ke.transcript?.trim()&&e(ke.transcript.trim(),void 0,ue)}catch{}},ce.readAsDataURL(I)},M.stop()),C.current&&(C.current.style.transform=""),p(!1),g(0),L.current=0},[e]),Q=A.useCallback(R=>{const M=R.type.startsWith("image/"),H=R.type==="application/pdf";if(!M&&!H)return;const I=new FileReader;I.onload=async ce=>{let ue=ce.target?.result;M&&(ue=await DY(ue)),d(de=>[...de,{id:Math.random().toString(36).slice(2),type:M?"image":"file",name:R.name,preview:ue}])},I.readAsDataURL(R)},[]),te=A.useCallback(R=>{const M=R.target.files;if(M){for(let H=0;H<M.length;H++)Q(M[H]);R.target.value=""}},[Q]),ie=A.useCallback(R=>{d(M=>M.filter(H=>H.id!==R))},[]);A.useEffect(()=>{const R=M=>{if(M.clipboardData?.items){for(const H of M.clipboardData.items)if(H.type.startsWith("image/")){M.preventDefault();const I=H.getAsFile();I&&Q(I)}}};return document.addEventListener("paste",R),()=>document.removeEventListener("paste",R)},[Q]);const ee=()=>{E&&(e(o,u.length>0?u:void 0),l(""),d([]),requestAnimationFrame(()=>v.current?.focus()))},j=A.useCallback(R=>{R.preventDefault(),N.current=R.clientX,L.current=0,R.currentTarget.setPointerCapture(R.pointerId),F.current=setTimeout(async()=>{if(r)try{const M=await navigator.mediaDevices.getUserMedia({audio:!0});U.current=M;const H=MediaRecorder.isTypeSupported("audio/webm;codecs=opus")?"audio/webm;codecs=opus":"audio/webm",I=new MediaRecorder(M,{mimeType:H});W.current=[],I.ondataavailable=ce=>{ce.data.size>0&&W.current.push(ce.data)},B.current=I,I.start(),D.current=!0,p(!0),g(0)}catch{}},200)},[]),V=A.useCallback(R=>{if(!D.current)return;const M=Math.min(0,R.clientX-N.current);if(L.current=M,C.current&&(C.current.style.transform=`translateX(${M}px)`),w.current){const H=w.current.getBoundingClientRect(),I=H.left+H.width/2;Math.abs(R.clientX-I)<36&&X(!0)}},[X]),Z=A.useCallback(()=>{F.current&&(clearTimeout(F.current),F.current=null),D.current&&X(!1)},[X]),ne=A.useCallback(()=>{F.current&&(clearTimeout(F.current),F.current=null),D.current&&X(!0)},[X]);return S.jsxs("div",{className:"shrink-0 p-3 relative",children:[S.jsxs("div",{className:`flex flex-col transition-opacity duration-100 ${f?"opacity-0 pointer-events-none":"opacity-100"}`,children:[S.jsx(qc,{children:u.length>0&&S.jsx(ui.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},transition:{duration:.15},className:"overflow-hidden",children:S.jsx("div",{className:"flex gap-2 px-3 pt-2.5 pb-2 flex-wrap bg-white/[0.04] border border-white/[0.08] rounded-2xl mb-2",children:u.map(R=>S.jsxs("div",{className:"relative group flex-shrink-0",children:[R.type==="image"?S.jsx("img",{src:R.preview,alt:R.name,className:"w-14 h-14 rounded-lg object-cover border border-white/10"}):S.jsxs("div",{className:"w-14 h-14 rounded-lg bg-white/5 border border-white/10 flex flex-col items-center justify-center gap-0.5 px-1",children:[S.jsx("svg",{className:"w-5 h-5 text-muted-foreground",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:1.5,children:S.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M19.5 14.25v-2.625a3.375 3.375 0 00-3.375-3.375h-1.5A1.125 1.125 0 0113.5 7.125v-1.5a3.375 3.375 0 00-3.375-3.375H8.25m2.25 0H5.625c-.621 0-1.125.504-1.125 1.125v17.25c0 .621.504 1.125 1.125 1.125h12.75c.621 0 1.125-.504 1.125-1.125V11.25a9 9 0 00-9-9z"})}),S.jsx("span",{className:"text-[8px] text-muted-foreground truncate w-full text-center",children:R.name.split(".").pop()})]}),S.jsx("button",{onClick:()=>ie(R.id),className:"absolute -top-1.5 -right-1.5 w-4 h-4 bg-black/80 border border-white/20 rounded-full flex items-center justify-center opacity-0 group-hover:opacity-100 transition-opacity",children:S.jsx(Kc,{className:"w-2.5 h-2.5 text-white"})})]},R.id))})})}),S.jsxs("div",{className:"flex items-end gap-2",children:[S.jsxs("div",{className:"flex-1 flex items-end bg-white rounded-2xl px-4",children:[S.jsx("textarea",{ref:v,value:o,onChange:R=>l(R.target.value),placeholder:"Type a message...",rows:1,className:"flex-1 resize-none bg-transparent text-gray-900 py-3 text-sm outline-none placeholder:text-gray-400 overflow-y-auto",style:{maxHeight:88}}),S.jsx("input",{ref:T,type:"file",className:"hidden",accept:"image/*,.pdf",multiple:!0,onChange:te}),S.jsx("input",{ref:k,type:"file",className:"hidden",accept:"image/*",capture:"environment",onChange:te}),S.jsx("button",{type:"button",onClick:()=>T.current?.click(),className:"shrink-0 p-1.5 mb-2 text-gray-400 hover:text-gray-600 transition-colors",children:S.jsx(zm,{className:"h-4 w-4"})}),S.jsx("button",{type:"button",onClick:()=>k.current?.click(),className:"shrink-0 p-1.5 mb-2 text-gray-400 hover:text-gray-600 transition-colors",children:S.jsx(dM,{className:"h-4 w-4"})})]}),n?S.jsx("button",{onClick:t,className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-destructive text-destructive-foreground transition-colors",children:S.jsx(XM,{className:"h-4 w-4"})}):E?S.jsx("button",{onClick:ee,className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-white text-gray-900 transition-colors hover:bg-gray-100",children:S.jsx(VM,{className:"h-4 w-4"})}):S.jsx("div",{className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-white text-gray-900 transition-colors hover:bg-gray-100 cursor-pointer touch-none select-none",onPointerDown:j,onPointerMove:V,onPointerUp:Z,onPointerCancel:ne,children:S.jsx(jm,{className:"h-4 w-4"})})]})]}),S.jsx(qc,{children:f&&S.jsx(ui.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.1},className:"absolute inset-0 p-3 flex items-center touch-none",children:S.jsxs("div",{className:"flex items-center w-full gap-2",children:[S.jsxs("div",{className:"flex items-center gap-2 shrink-0",children:[S.jsxs("span",{className:"relative flex h-2 w-2 shrink-0",children:[S.jsx("span",{className:"animate-ping absolute inline-flex h-full w-full rounded-full bg-destructive opacity-75"}),S.jsx("span",{className:"relative inline-flex rounded-full h-2 w-2 bg-destructive"})]}),S.jsx("span",{className:"text-sm font-medium tabular-nums",children:IY(m)})]}),S.jsxs("div",{className:"flex-1 flex items-center bg-muted rounded-full h-12 pl-1 pr-0.5",children:[S.jsx("div",{ref:w,className:"flex items-center justify-center h-9 w-9 shrink-0 rounded-full bg-destructive/10 text-destructive",children:S.jsx(lN,{className:"h-4 w-4"})}),S.jsx("div",{className:"flex-1 flex justify-center min-w-0",children:S.jsx(ui.span,{className:"text-[13px] whitespace-nowrap select-none font-medium",style:{backgroundImage:"linear-gradient(90deg, #999 0%, #999 35%, #fff 50%, #999 65%, #999 100%)",backgroundSize:"200% 100%",WebkitBackgroundClip:"text",WebkitTextFillColor:"transparent",backgroundClip:"text"},animate:{backgroundPosition:["200% center","-200% center"]},transition:{duration:2.5,repeat:1/0,ease:"linear"},children:"◄◄ slide to cancel"})}),S.jsx("div",{ref:C,className:"shrink-0 touch-none select-none will-change-transform",style:{transition:"none"},onPointerDown:j,onPointerMove:V,onPointerUp:Z,onPointerCancel:ne,children:S.jsx("div",{className:"flex items-center justify-center h-11 w-11 rounded-full bg-destructive text-destructive-foreground",children:S.jsx(jm,{className:"h-5 w-5"})})})]})]})})})]})}function MY({ws:e,clearContextRef:t,whisperEnabled:n}){const{messages:r,streaming:o,streamBuffer:l,tools:u,sendMessage:d,stopStreaming:f,clearContext:p}=dz(e);return t&&(t.current=p),S.jsxs("div",{className:"flex flex-col h-full overflow-hidden",children:[S.jsx(OY,{messages:r,streaming:o,streamBuffer:l,tools:u}),S.jsx(LY,{onSend:d,onStop:f,streaming:o,whisperEnabled:n})]})}function FY({onClick:e}){return S.jsx(ui.div,{className:"fixed bottom-6 right-6 z-50 cursor-pointer",whileHover:{scale:1.1},whileTap:{scale:.95},onClick:e,role:"button","aria-label":"Open Fluxy chat",children:S.jsx("video",{src:"/fluxy_tilts.webm",poster:"/fluxy_frame1.png",autoPlay:!0,loop:!0,muted:!0,playsInline:!0,className:"h-11 w-auto drop-shadow-lg pointer-events-none",draggable:!1})})}const UY=[{id:"anthropic",name:"Claude",subtitle:"by Anthropic",icon:"/icons/claude.png"},{id:"openai",name:"OpenAI Codex",subtitle:"ChatGPT Plus / Pro",icon:"/icons/codex.png"},{id:"ollama",name:"Ollama",subtitle:"Run locally",icon:null}],BY={anthropic:[{id:"claude-opus-4-6",label:"Opus 4.6"},{id:"claude-sonnet-4-6",label:"Sonnet 4.6"},{id:"claude-haiku-4-5-20251001",label:"Haiku 4.5"}],openai:[{id:"gpt-5.2-codex:medium",label:"GPT-5.2 Codex Medium"},{id:"gpt-5.2-codex:high",label:"GPT-5.2 Codex High"},{id:"gpt-5.2-codex:xhigh",label:"GPT-5.2 Codex Extra High"},{id:"gpt-5.3-codex:medium",label:"GPT-5.3 Codex Medium (Pro)"},{id:"gpt-5.3-codex:high",label:"GPT-5.3 Codex High (Pro)"},{id:"gpt-5.3-codex:xhigh",label:"GPT-5.3 Codex Extra High (Pro)"}],ollama:[{id:"llama3.2",label:"Llama 3.2"},{id:"mistral",label:"Mistral"},{id:"codellama",label:"Code Llama"},{id:"phi3",label:"Phi-3"}]},eN=6,tN=[{tier:"premium",label:e=>`${e}.fluxy.bot`,badge:"$5",badgeCls:"bg-[#AF27E3]/15 text-[#AF27E3] border-[#AF27E3]/20",highlight:!0},{tier:"at",label:e=>`${e}.at.fluxy.bot`,badge:"Free",badgeCls:"bg-emerald-500/10 text-emerald-400 border-emerald-500/20",highlight:!1}];function PY({models:e,value:t,onChange:n}){const[r,o]=A.useState(!1),l=A.useRef(null);A.useEffect(()=>{if(!r)return;const d=f=>{l.current&&!l.current.contains(f.target)&&o(!1)};return document.addEventListener("mousedown",d),()=>document.removeEventListener("mousedown",d)},[r]);const u=e.find(d=>d.id===t);return S.jsxs("div",{className:"relative",ref:l,children:[S.jsxs("button",{type:"button",onClick:()=>o(d=>!d),className:"w-full flex items-center justify-between bg-white/[0.03] border border-white/[0.08] text-white rounded-xl px-4 py-2.5 text-[13px] outline-none hover:border-white/15 focus:border-[#AF27E3]/30 transition-colors",children:[S.jsx("span",{className:u?"text-white":"text-white/20",children:u?u.label:"Choose a model..."}),S.jsx(hl,{className:`h-4 w-4 text-white/30 transition-transform ${r?"rotate-180":""}`})]}),r&&S.jsx("div",{className:"absolute left-0 right-0 top-full mt-1 bg-[#222] border border-white/[0.08] rounded-xl shadow-xl py-1 z-10 max-h-48 overflow-y-auto",children:e.map(d=>S.jsx("button",{onClick:()=>{n(d.id),o(!1)},className:`w-full text-left px-4 py-2 text-[13px] transition-colors ${t===d.id?"text-[#AF27E3] bg-[#AF27E3]/10":"text-white/70 hover:bg-white/[0.04] hover:text-white"}`,children:d.label},d.id))})]})}function jY({onComplete:e}){const[t,n]=A.useState(0),[r,o]=A.useState(""),[l,u]=A.useState("anthropic"),[d,f]=A.useState(""),[p,m]=A.useState(!1),[g,y]=A.useState({anthropic:"idle",openai:"idle",ollama:"connected"}),[E,v]=A.useState(!1),[T,k]=A.useState(""),[w,C]=A.useState(!1),[N,L]=A.useState(),[F,D]=A.useState(!1),[z,B]=A.useState(!1),[W,U]=A.useState(),[X,Q]=A.useState(""),[te,ie]=A.useState(""),[ee,j]=A.useState(null),[V,Z]=A.useState(""),[ne,R]=A.useState({}),[M,H]=A.useState("at"),[I,ce]=A.useState(!1),[ue,de]=A.useState(!1),[me,ke]=A.useState(""),Se=A.useRef(null),[We,mt]=A.useState(null),[gt,It]=A.useState(!1),[Dt,Sa]=A.useState(!1),[mn,Lr]=A.useState(""),[kn,Ya]=A.useState(""),[na,Mr]=A.useState(""),[Go,yi]=A.useState(!1),[ct,$o]=A.useState(!1),[oe,fe]=A.useState(""),[we,_e]=A.useState(""),[ze,Ht]=A.useState(!1),[Rn,_t]=A.useState(!1),[Ze,Lt]=A.useState(!1),[Le,Gn]=A.useState(""),Qt=A.useRef(!1),va=g[l]==="connected";A.useEffect(()=>{fetch("/api/onboard/status").then(re=>re.json()).then(re=>{re.userName&&o(re.userName),re.handle&&(ie(re.handle.username),H(re.handle.tier||"at"),mt({username:re.handle.username,tier:re.handle.tier,url:re.handle.url}),de(!0),ke(re.handle.url)),re.portalUser&&Lr(re.portalUser),re.portalConfigured&&$o(!0),re.provider&&u(re.provider),re.model&&f(re.model),re.whisperEnabled&&(Lt(!0),Gn(re.whisperKey||"")),Qt.current=!0}).catch(()=>{Qt.current=!0})},[]),A.useEffect(()=>{l!=="anthropic"||g.anthropic==="connected"||fetch("/api/auth/claude/status").then(re=>re.json()).then(re=>{re.authenticated&&y(Ae=>({...Ae,anthropic:"connected"}))}).catch(()=>{})},[l]),A.useEffect(()=>{l!=="openai"||g.openai==="connected"||fetch("/api/auth/codex/status").then(re=>re.json()).then(re=>{re.authenticated&&y(Ae=>({...Ae,openai:"connected"}))}).catch(()=>{})},[l]),A.useEffect(()=>{if(!z)return;const re=setInterval(async()=>{try{(await(await fetch("/api/auth/codex/status")).json()).authenticated&&(B(!1),y(Xa=>({...Xa,openai:"connected"})))}catch{}},2e3);return()=>clearInterval(re)},[z]),A.useEffect(()=>{if(Se.current&&clearTimeout(Se.current),!Qt.current||We&&ue&&te===We.username)return;j(null),Z(""),R({}),de(!1),ke("");const re=te.trim();if(re){if(re.length<3){j("invalid"),Z("At least 3 characters");return}return j("checking"),Se.current=setTimeout(async()=>{try{const Mt=await(await fetch(`/api/handle/check/${encodeURIComponent(re)}`)).json();if(!Mt.valid)j("invalid"),Z(Mt.error);else{const Xa={};for(const Ur of Mt.handles)Xa[Ur.tier]=Ur.available;R(Xa),j("ready");const Bl=tN.find(Ur=>Xa[Ur.tier]);Bl&&!Xa[M]&&H(Bl.tier)}}catch{j(null)}},400),()=>{Se.current&&clearTimeout(Se.current)}}},[te]);const Ei=re=>{ie(re.toLowerCase().replace(/[^a-z0-9-]/g,""))},Si=async()=>{if(!(!te||ee!=="ready"||!ne[M])){ce(!0);try{const Ae=await(await fetch("/api/handle/register",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({username:te,tier:M})})).json();Ae.ok?(de(!0),ke(Ae.url)):(Z(Ae.error||"Registration failed"),j("invalid"))}catch{Z("Could not reach server"),j("invalid")}finally{ce(!1)}}},vi=async()=>{if(!(!te||ee!=="ready"||!ne[M])){Sa(!0);try{const Ae=await(await fetch("/api/handle/change",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({username:te,tier:M})})).json();Ae.ok?(de(!0),ke(Ae.url),mt({username:te,tier:M,url:Ae.url}),It(!1)):(Z(Ae.error||"Handle change failed"),j("invalid"))}catch{Z("Could not reach server"),j("invalid")}finally{Sa(!1)}}},xa=re=>{l==="openai"&&re!=="openai"&&z&&(fetch("/api/auth/codex/cancel",{method:"POST"}),B(!1)),u(re),f(""),v(!1),k(""),L(void 0),B(!1),U(void 0)},xi=async()=>{L(void 0);try{const Ae=await(await fetch("/api/auth/claude/start",{method:"POST"})).json();Ae.success&&Ae.authUrl?(window.open(Ae.authUrl,"_blank"),v(!0)):L(Ae.error||"Failed to start authentication")}catch(re){L(re.message)}},Wa=async()=>{if(T.trim()){C(!0),L(void 0);try{const Ae=await(await fetch("/api/auth/claude/exchange",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({code:T.trim()})})).json();Ae.success?y(Mt=>({...Mt,anthropic:"connected"})):L(Ae.error||"Code exchange failed")}catch(re){L(re.message)}finally{C(!1)}}},Cd=async()=>{try{const re=await navigator.clipboard.readText();re&&k(re.trim())}catch{}},Ll=async()=>{D(!0),L(void 0);try{(await(await fetch("/api/auth/claude/status")).json()).authenticated?y(Mt=>({...Mt,anthropic:"connected"})):L("No active session found. Please authenticate first.")}catch{}finally{D(!1)}},Ho=async()=>{B(!0),U(void 0);try{const Ae=await(await fetch("/api/auth/codex/start",{method:"POST"})).json();Ae.success&&Ae.authUrl?window.open(Ae.authUrl,"_blank"):(B(!1),U(Ae.error||"Failed to start authentication"))}catch(re){B(!1),U(re.message)}},Fr=()=>{B(!1),fetch("/api/auth/codex/cancel",{method:"POST"})},Ml=kn===na,Vo=mn.trim().length>=3&&kn.length>=6&&Ml,Fl=ct?mn.trim().length>=3&&(kn.length===0||ze&&Vo):Vo,Ka=(()=>{switch(t){case 0:return!0;case 1:return r.trim().length>0;case 2:return ue;case 3:return Fl;case 4:return!!(l&&d&&va);case 5:return!0;default:return!1}})(),$n=()=>{Ka&&t<eN-1&&n(re=>re+1)},qo=()=>{t>0&&n(re=>re-1)},wi=re=>{re.key==="Enter"&&Ka&&$n()},Ul=async()=>{m(!0);try{await fetch("/api/onboard",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({userName:r.trim(),agentName:te.trim()||"Fluxy",provider:l,model:d,apiKey:"",baseUrl:l==="ollama"&&X||void 0,whisperEnabled:Ze,whisperKey:Ze?Le:"",portalUser:mn.trim(),portalPass:kn})}),e()}catch(re){console.error("Onboard failed:",re),m(!1)}},Vt="w-full bg-white/[0.05] border border-white/[0.08] text-white rounded-xl px-4 py-3 text-base outline-none input-glow placeholder:text-white/20 transition-all",yt="w-full bg-white/[0.03] border border-white/[0.08] text-white rounded-xl px-4 py-2.5 text-[13px] outline-none input-glow placeholder:text-white/20 transition-all";return S.jsxs("div",{className:"fixed inset-0 z-[200] flex items-center justify-center p-4",children:[S.jsx("div",{className:"absolute inset-0 bg-black/85 backdrop-blur-md"}),S.jsxs(ui.div,{initial:{opacity:0,scale:.95},animate:{opacity:1,scale:1},transition:{duration:.3},className:"relative w-full max-w-[480px] bg-[#181818] border border-white/[0.06] rounded-[24px] shadow-2xl overflow-hidden",children:[S.jsx("div",{className:"flex justify-center gap-2 pt-6",children:Array.from({length:eN},(re,Ae)=>S.jsx("div",{className:`h-1.5 rounded-full transition-all duration-300 ${Ae===t?"w-7 bg-gradient-brand":Ae<t?"w-1.5 bg-gradient-brand opacity-60":"w-1.5 bg-white/10"}`},Ae))}),S.jsx(qc,{mode:"wait",children:S.jsxs(ui.div,{initial:{opacity:0,x:30},animate:{opacity:1,x:0},exit:{opacity:0,x:-30},transition:{duration:.2,ease:"easeOut"},className:"px-8 pt-6 pb-8",children:[t===0&&S.jsxs("div",{className:"flex flex-col items-center text-center",children:[S.jsx("video",{src:"/fluxy_say_hi.webm",autoPlay:!0,loop:!0,muted:!0,playsInline:!0,className:"h-[180px] mb-4"}),S.jsx("h1",{className:"text-2xl font-bold text-white tracking-tight",children:"Welcome to Fluxy"}),S.jsx("p",{className:"text-white/40 text-[14px] mt-2 leading-relaxed max-w-[320px]",children:"Let's set up your AI assistant in just a few steps."}),S.jsxs("button",{onClick:$n,className:"mt-6 px-7 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center gap-2",children:["Get Started",S.jsx(sa,{className:"h-4 w-4"})]})]}),t===1&&S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"What's your name?"}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1.5 leading-relaxed",children:"This is how your agent will address you."}),S.jsxs("div",{className:"mt-5 flex items-center gap-3",children:[S.jsx("input",{type:"text",value:r,onChange:re=>o(re.target.value),onKeyDown:wi,placeholder:"Enter your name",autoFocus:!0,className:Vt+" flex-1"}),S.jsx("button",{onClick:$n,disabled:!Ka,className:"shrink-0 h-12 w-12 flex items-center justify-center rounded-full bg-gradient-brand hover:opacity-90 text-white transition-colors disabled:opacity-30",children:S.jsx(sa,{className:"h-5 w-5"})})]})]}),t===2&&S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"Name your bot"}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1.5 leading-relaxed",children:"This is your bot's name and permanent handle — access it from anywhere."}),We&&ue&&!gt&&S.jsxs(S.Fragment,{children:[S.jsxs("div",{className:"mt-4 bg-emerald-500/8 border border-emerald-500/15 rounded-xl px-4 py-3",children:[S.jsxs("div",{className:"flex items-center gap-2",children:[S.jsx(Bs,{className:"h-4 w-4 text-emerald-400"}),S.jsx("p",{className:"text-emerald-400/90 text-[13px] font-medium",children:"Current handle"})]}),S.jsx("p",{className:"text-emerald-400/60 text-[12px] mt-1 font-mono",children:me})]}),S.jsxs("div",{className:"flex gap-2 mt-4",children:[S.jsxs("button",{onClick:$n,className:"flex-1 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2",children:["Continue",S.jsx(sa,{className:"h-4 w-4"})]}),S.jsx("button",{onClick:()=>{It(!0),de(!1),ie(""),j(null),R({})},className:"px-5 py-3 bg-white/[0.04] hover:bg-white/[0.08] border border-white/[0.08] text-white/60 text-[13px] font-medium rounded-full transition-colors",children:"Change"})]})]}),gt&&!ue&&S.jsxs("div",{className:"mt-4 bg-amber-500/8 border border-amber-500/20 rounded-xl px-4 py-3",children:[S.jsx("p",{className:"text-amber-400/90 text-[13px] font-medium",children:"Changing your handle"}),S.jsxs("p",{className:"text-amber-400/60 text-[12px] mt-1",children:["Your current handle ",S.jsx("span",{className:"font-mono",children:We?.url})," will be released and become available for others."]})]}),(!We||gt||!ue)&&!(We&&ue&&!gt)&&S.jsxs(S.Fragment,{children:[S.jsxs("div",{className:"relative mt-5",children:[S.jsx("input",{type:"text",value:te,onChange:re=>Ei(re.target.value),maxLength:30,placeholder:"your-bot-name",spellCheck:!1,autoCapitalize:"none",autoCorrect:"off",autoFocus:!0,disabled:ue,className:Vt+" pr-10 font-mono"+(ue?" opacity-50":"")}),ee&&te.length>0&&!ue&&S.jsxs("div",{className:"absolute right-4 top-1/2 -translate-y-1/2",children:[ee==="checking"&&S.jsx("div",{className:"w-5 h-5 border-2 border-white/10 border-t-[#04D1FE] rounded-full animate-spin"}),ee==="invalid"&&S.jsx("div",{className:"w-6 h-6 rounded-full bg-amber-500/15 flex items-center justify-center",children:S.jsx("svg",{className:"w-3.5 h-3.5 text-amber-400",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:3,children:S.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M12 9v3m0 4h.01"})})})]})]}),ee==="invalid"&&V&&S.jsx("p",{className:"text-amber-400 text-[12px] mt-2",children:V}),ee==="ready"&&te.length>0&&!ue&&S.jsx("div",{className:"space-y-2 mt-4",children:tN.map(re=>{const Mt=ne[re.tier]===!1;return S.jsxs("button",{onClick:()=>!Mt&&H(re.tier),disabled:Mt,className:`w-full flex items-center justify-between px-4 py-3 rounded-xl border transition-all duration-200 text-left ${Mt?"border-white/[0.04] bg-transparent opacity-50 cursor-not-allowed":M===re.tier?re.highlight?"border-[#AF27E3]/40 bg-[#AF27E3]/[0.06]":"border-[#AF27E3]/30 bg-white/[0.04]":"border-white/[0.06] bg-transparent hover:border-white/10 hover:bg-white/[0.02]"}`,children:[S.jsx("span",{className:"font-mono text-[13px] text-white/70",children:re.label(te)}),Mt?S.jsx("span",{className:"text-[11px] font-medium px-2.5 py-0.5 rounded-full border bg-red-500/10 text-red-400 border-red-500/20",children:"Taken"}):S.jsx("span",{className:`text-[11px] font-medium px-2.5 py-0.5 rounded-full border ${re.badgeCls}`,children:re.badge})]},re.tier)})}),ue&&S.jsxs("div",{className:"mt-4 bg-emerald-500/8 border border-emerald-500/15 rounded-xl px-4 py-3",children:[S.jsxs("div",{className:"flex items-center gap-2",children:[S.jsx(Bs,{className:"h-4 w-4 text-emerald-400"}),S.jsx("p",{className:"text-emerald-400/90 text-[13px] font-medium",children:"Handle claimed!"})]}),S.jsx("p",{className:"text-emerald-400/60 text-[12px] mt-1 font-mono",children:me})]}),ee==="ready"&&ne[M]&&te.length>0&&!ue&&S.jsx("button",{onClick:gt?vi:Si,disabled:I||Dt,className:"w-full mt-4 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:I||Dt?S.jsxs(S.Fragment,{children:[S.jsx(so,{className:"h-4 w-4 animate-spin"}),gt?"Changing...":"Claiming..."]}):S.jsxs(S.Fragment,{children:[gt?"Change Handle":"Claim & Continue",S.jsx(sa,{className:"h-4 w-4"})]})}),ue&&S.jsxs("button",{onClick:$n,className:"w-full mt-4 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2",children:["Continue",S.jsx(sa,{className:"h-4 w-4"})]}),gt&&!ue&&S.jsx("button",{onClick:()=>{It(!1),ie(We.username),de(!0),ke(We.url),H(We.tier),j(null)},className:"w-full mt-2 py-2 text-white/25 hover:text-white/40 text-[12px] transition-colors",children:"Cancel — keep current handle"})]})]}),t===3&&S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"Secure your portal"}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1.5 leading-relaxed",children:"Create credentials to protect your dashboard. Anyone with your URL will need these to log in."}),ue&&me&&S.jsxs("div",{className:"mt-4 flex items-center gap-2 bg-white/[0.03] border border-white/[0.06] rounded-xl px-4 py-3",children:[S.jsx("span",{className:"font-mono text-[13px] text-white/60 truncate flex-1",children:me}),S.jsx("button",{onClick:()=>{navigator.clipboard.writeText(me),yi(!0),setTimeout(()=>yi(!1),2e3)},className:"shrink-0 text-white/30 hover:text-white/60 transition-colors",children:Go?S.jsx(Bs,{className:"h-4 w-4 text-emerald-400"}):S.jsxs("svg",{className:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:2,children:[S.jsx("rect",{x:"9",y:"9",width:"13",height:"13",rx:"2"}),S.jsx("path",{d:"M5 15H4a2 2 0 01-2-2V4a2 2 0 012-2h9a2 2 0 012 2v1"})]})})]}),ct&&S.jsx("div",{className:"mt-4 bg-white/[0.02] border border-white/[0.06] rounded-xl px-4 py-2.5",children:S.jsx("p",{className:"text-white/40 text-[12px]",children:"Credentials already set. Leave password fields empty to keep your current password, or enter your current password to change it."})}),S.jsxs("div",{className:"mt-5",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:"Username"}),S.jsx("input",{type:"text",value:mn,onChange:re=>Lr(re.target.value.replace(/\s/g,"").toLowerCase()),placeholder:"admin",autoFocus:!0,autoComplete:"username",className:Vt+" font-mono"}),mn.length>0&&mn.trim().length<3&&S.jsx("p",{className:"text-amber-400/70 text-[11px] mt-1",children:"At least 3 characters"})]}),ct&&S.jsxs("div",{className:"mt-3",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:"Current password"}),S.jsxs("div",{className:"flex items-center gap-2",children:[S.jsx("input",{type:"password",value:oe,onChange:re=>{fe(re.target.value),_e(""),Ht(!1)},placeholder:"Enter current password to change it",autoComplete:"current-password",className:Vt+" flex-1"}),oe.length>0&&!ze&&S.jsx("button",{onClick:async()=>{_t(!0),_e("");try{(await(await fetch("/api/portal/verify-password",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({password:oe})})).json()).valid?Ht(!0):_e("Incorrect password")}catch{_e("Could not verify")}finally{_t(!1)}},disabled:Rn,className:"shrink-0 px-4 py-3 bg-white/[0.06] hover:bg-white/[0.1] text-white/60 text-[13px] font-medium rounded-xl transition-colors disabled:opacity-40",children:Rn?S.jsx(so,{className:"h-4 w-4 animate-spin"}):"Verify"}),ze&&S.jsx("div",{className:"shrink-0 w-10 h-10 flex items-center justify-center",children:S.jsx(Bs,{className:"h-4 w-4 text-emerald-400"})})]}),we&&S.jsx("p",{className:"text-red-400/70 text-[11px] mt-1",children:we})]}),(!ct||ze)&&S.jsxs(S.Fragment,{children:[S.jsxs("div",{className:"mt-3",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:ct?"New password":"Password"}),S.jsx("input",{type:"password",value:kn,onChange:re=>Ya(re.target.value),placeholder:"••••••••",autoComplete:"new-password",onKeyDown:wi,className:Vt}),kn.length>0&&kn.length<6&&S.jsx("p",{className:"text-amber-400/70 text-[11px] mt-1",children:"At least 6 characters"})]}),S.jsxs("div",{className:"mt-3",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:ct?"Confirm new password":"Confirm password"}),S.jsx("input",{type:"password",value:na,onChange:re=>Mr(re.target.value),placeholder:"••••••••",autoComplete:"new-password",onKeyDown:wi,className:Vt}),na.length>0&&!Ml&&S.jsx("p",{className:"text-red-400/70 text-[11px] mt-1",children:"Passwords don't match"})]})]}),S.jsxs("button",{onClick:$n,disabled:!Ka,className:"w-full mt-5 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:["Continue",S.jsx(sa,{className:"h-4 w-4"})]})]}),t===4&&S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"Choose your AI provider"}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1.5 leading-relaxed",children:"Pick one provider to power your bot, authenticate, and select a model."}),S.jsx("div",{className:"flex gap-2.5 mt-4",children:UY.map(re=>S.jsxs("button",{onClick:()=>xa(re.id),className:`flex-1 relative rounded-xl border transition-all duration-200 p-3 text-left ${l===re.id?"bg-white/[0.04] border-[#AF27E3]/40":"bg-transparent border-white/[0.06] hover:border-white/10 hover:bg-white/[0.02]"}`,children:[S.jsxs("div",{className:"flex flex-col items-center gap-1.5 py-0.5",children:[re.icon?S.jsx("img",{src:re.icon,alt:re.name,className:"w-8 h-8 rounded-lg"}):S.jsx("div",{className:"w-8 h-8 rounded-lg bg-white/[0.06] flex items-center justify-center text-white/50 text-sm font-bold",children:"O"}),S.jsxs("div",{className:"text-center",children:[S.jsx("div",{className:"text-[13px] font-medium text-white",children:re.name}),S.jsx("div",{className:"text-[10px] text-white/30",children:re.subtitle})]})]}),g[re.id]==="connected"?S.jsx("div",{className:"absolute top-2 right-2 w-4 h-4 rounded-full bg-emerald-500/15 flex items-center justify-center",children:S.jsx(Bs,{className:"h-2.5 w-2.5 text-emerald-400"})}):l===re.id?S.jsx("div",{className:"absolute top-2 right-2 w-2 h-2 rounded-full bg-gradient-brand"}):null]},re.id))}),S.jsx("div",{className:"border-t border-white/[0.06] mt-4 mb-3"}),l==="anthropic"&&S.jsxs("div",{className:"space-y-2.5",children:[va&&S.jsx("div",{className:"bg-emerald-500/8 border border-emerald-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-emerald-400/90 text-[12px]",children:"Connected — Anthropic subscription is active."})}),!va&&S.jsxs(S.Fragment,{children:[N&&S.jsx("div",{className:"bg-red-500/8 border border-red-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-red-400/90 text-[12px]",children:N})}),S.jsx("div",{className:"space-y-1.5",children:["Click the button below to open Anthropic's login page","Sign in with your Anthropic account — a code will be generated","Copy the code and paste it in the field below"].map((re,Ae)=>S.jsxs("div",{className:"flex items-start gap-2",children:[S.jsx("span",{className:"flex-shrink-0 w-[18px] h-[18px] rounded-full bg-white/[0.06] text-white/30 text-[10px] font-medium flex items-center justify-center mt-px",children:Ae+1}),S.jsx("p",{className:"text-white/40 text-[12px] leading-relaxed",children:re})]},Ae))}),S.jsx("button",{onClick:xi,className:"w-full py-2.5 px-4 bg-gradient-brand hover:opacity-90 text-white text-[13px] font-medium rounded-xl transition-colors flex items-center justify-center gap-2",children:E?S.jsxs(S.Fragment,{children:[S.jsx(AM,{className:"h-3.5 w-3.5 opacity-60"}),"Open authentication page again"]}):S.jsxs(S.Fragment,{children:["Authenticate with Anthropic",S.jsx(sa,{className:"h-3.5 w-3.5 opacity-60"})]})}),S.jsxs("div",{className:"relative",children:[S.jsx("input",{type:"text",value:T,onChange:re=>k(re.target.value),onKeyDown:re=>re.key==="Enter"&&Wa(),placeholder:"Paste your code here...",className:yt+" pr-10 font-mono"}),S.jsx("button",{onClick:Cd,className:"absolute right-3 top-1/2 -translate-y-1/2 text-white/20 hover:text-white/50 transition-colors",children:S.jsx(EM,{className:"h-3.5 w-3.5"})})]}),S.jsx("button",{onClick:Wa,disabled:!T.trim()||w,className:"w-full py-2.5 px-4 bg-gradient-brand hover:opacity-90 text-white text-[13px] font-medium rounded-xl transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:w?S.jsxs(S.Fragment,{children:[S.jsx(so,{className:"h-3.5 w-3.5 animate-spin"}),"Verifying..."]}):"Connect"}),S.jsxs("button",{onClick:Ll,disabled:F,className:"w-full py-1.5 text-white/25 text-[11px] hover:text-white/40 transition-colors flex items-center justify-center gap-1.5 disabled:opacity-50",children:[F?S.jsx(so,{className:"h-3 w-3 animate-spin"}):S.jsx(zM,{className:"h-3 w-3"}),F?"Checking...":"I'm already authenticated"]})]})]}),l==="openai"&&S.jsxs("div",{className:"space-y-2.5",children:[va&&S.jsx("div",{className:"bg-emerald-500/8 border border-emerald-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-emerald-400/90 text-[12px]",children:"Connected — ChatGPT subscription is active."})}),!va&&S.jsxs(S.Fragment,{children:[W&&S.jsx("div",{className:"bg-red-500/8 border border-red-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-red-400/90 text-[12px]",children:W})}),S.jsx("div",{className:"space-y-1.5",children:["Click the button below — your browser will open for ChatGPT sign-in","Sign in with your ChatGPT Plus or Pro account","Authentication completes automatically — no code to copy"].map((re,Ae)=>S.jsxs("div",{className:"flex items-start gap-2",children:[S.jsx("span",{className:"flex-shrink-0 w-[18px] h-[18px] rounded-full bg-white/[0.06] text-white/30 text-[10px] font-medium flex items-center justify-center mt-px",children:Ae+1}),S.jsx("p",{className:"text-white/40 text-[12px] leading-relaxed",children:re})]},Ae))}),S.jsx("button",{onClick:Ho,disabled:z,className:"w-full py-2.5 px-4 bg-white/[0.06] hover:bg-white/[0.09] text-white text-[13px] font-medium rounded-xl transition-colors flex items-center justify-center gap-2 disabled:opacity-60",children:z?S.jsxs(S.Fragment,{children:[S.jsx(so,{className:"h-3.5 w-3.5 animate-spin opacity-60"}),"Waiting for sign-in..."]}):S.jsxs(S.Fragment,{children:["Authenticate with ChatGPT",S.jsx(sa,{className:"h-3.5 w-3.5 opacity-60"})]})}),z&&S.jsx("button",{onClick:Fr,className:"w-full py-1.5 text-white/25 text-[11px] hover:text-white/40 transition-colors",children:"Cancel"})]})]}),l==="ollama"&&S.jsxs("div",{className:"space-y-2.5",children:[S.jsx("div",{className:"bg-emerald-500/8 border border-emerald-500/15 rounded-lg px-3.5 py-2.5",children:S.jsx("p",{className:"text-emerald-400/90 text-[12px]",children:"No authentication needed — Ollama runs locally."})}),S.jsxs("div",{children:[S.jsxs("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:["Base URL ",S.jsx("span",{className:"text-white/20",children:"(optional)"})]}),S.jsx("input",{type:"text",value:X,onChange:re=>Q(re.target.value),placeholder:"http://localhost:11434",className:yt})]})]}),va&&S.jsxs(S.Fragment,{children:[S.jsx("div",{className:"border-t border-white/[0.06] mt-4 mb-3"}),S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:"Select a model"}),S.jsx(PY,{models:BY[l]||[],value:d,onChange:f})]}),va&&S.jsxs("button",{onClick:$n,disabled:!Ka,className:"w-full mt-4 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:["Continue",S.jsx(sa,{className:"h-4 w-4"})]})]}),t===5&&S.jsxs("div",{children:[S.jsxs("div",{className:"flex items-center gap-2 mb-1",children:[S.jsx("h1",{className:"text-xl font-bold text-white tracking-tight",children:"Voice Messages"}),S.jsx("span",{className:"text-[11px] text-white/25 font-medium bg-white/[0.04] border border-white/[0.06] rounded-full px-2.5 py-0.5",children:"Optional"})]}),S.jsx("p",{className:"text-white/40 text-[13px] mt-1 leading-relaxed",children:"Allow users to send audio messages that are automatically transcribed."}),S.jsx("button",{onClick:()=>Lt(re=>!re),className:`w-full mt-5 rounded-xl border transition-all duration-200 p-4 text-left ${Ze?"bg-white/[0.04] border-[#AF27E3]/40":"bg-transparent border-white/[0.06] hover:border-white/10 hover:bg-white/[0.02]"}`,children:S.jsxs("div",{className:"flex items-center gap-3.5",children:[S.jsx("img",{src:"/icons/openai.svg",alt:"OpenAI",className:"w-10 h-10 rounded-xl bg-white/[0.04] p-1.5"}),S.jsxs("div",{className:"flex-1",children:[S.jsx("div",{className:"text-[14px] font-medium text-white",children:"OpenAI Whisper"}),S.jsx("div",{className:"text-[12px] text-white/35 mt-0.5 leading-relaxed",children:"Speech-to-text powered by OpenAI. Requires an OpenAI API key."})]}),S.jsx("div",{className:`w-10 h-[22px] rounded-full transition-colors duration-200 flex items-center px-0.5 shrink-0 ${Ze?"bg-gradient-brand":"bg-white/[0.08]"}`,children:S.jsx("div",{className:`w-[18px] h-[18px] rounded-full bg-white shadow-sm transition-transform duration-200 ${Ze?"translate-x-[18px]":"translate-x-0"}`})})]})}),Ze&&S.jsxs("div",{className:"mt-3",children:[S.jsx("label",{className:"text-[12px] text-white/40 font-medium mb-1.5 block",children:"OpenAI API Key"}),S.jsx("input",{type:"password",value:Le,onChange:re=>Gn(re.target.value.trim()),placeholder:"sk-...",autoComplete:"off",className:Vt+" font-mono text-[13px]"}),Le.length>0&&!Le.startsWith("sk-")&&S.jsx("p",{className:"text-amber-400/70 text-[11px] mt-1",children:"Key should start with sk-"}),Le.length>0&&Le.startsWith("sk-")&&Le.length<20&&S.jsx("p",{className:"text-amber-400/70 text-[11px] mt-1",children:"Key looks too short"}),S.jsxs("div",{className:"flex items-start gap-2.5 mt-3 bg-white/[0.02] border border-white/[0.06] rounded-xl px-4 py-3",children:[S.jsx(jm,{className:"h-4 w-4 text-[#AF27E3]/60 mt-0.5 shrink-0"}),S.jsx("p",{className:"text-white/35 text-[12px] leading-relaxed",children:"Users will see a microphone button in the chat. Audio is sent to OpenAI's Whisper API for transcription, then processed as a regular text message."})]})]}),S.jsx("button",{onClick:Ul,disabled:p||Ze&&(!Le.startsWith("sk-")||Le.length<20),className:"w-full mt-5 py-3 bg-gradient-brand hover:opacity-90 text-white text-[14px] font-semibold rounded-full transition-colors flex items-center justify-center gap-2 disabled:opacity-40",children:p?S.jsxs(S.Fragment,{children:[S.jsx(so,{className:"h-4 w-4 animate-spin"}),"Setting up..."]}):S.jsxs(S.Fragment,{children:["Complete Setup",S.jsx(sa,{className:"h-4 w-4"})]})}),!Ze&&S.jsx("p",{className:"text-center text-white/20 text-[11px] mt-2.5",children:"You can enable this later in Settings."})]})]},t)}),t>0&&S.jsx("div",{className:"px-8 pb-5 -mt-3",children:S.jsx("button",{onClick:qo,className:"text-white/25 hover:text-white/50 text-[12px] transition-colors",children:"← Back"})})]})]})}function zY({...e}){return S.jsx(Uj,{"data-slot":"dropdown-menu",...e})}function GY({...e}){return S.jsx(Bj,{"data-slot":"dropdown-menu-trigger",...e})}function $Y({className:e,sideOffset:t=4,...n}){return S.jsx(Pj,{children:S.jsx(jj,{"data-slot":"dropdown-menu-content",sideOffset:t,className:pn("bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 max-h-(--radix-dropdown-menu-content-available-height) min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border p-1 shadow-md",e),...n})})}function HY({className:e,inset:t,variant:n="default",...r}){return S.jsx(zj,{"data-slot":"dropdown-menu-item","data-inset":t,"data-variant":n,className:pn("focus:bg-accent focus:text-accent-foreground data-[variant=destructive]:text-destructive data-[variant=destructive]:focus:bg-destructive/10 dark:data-[variant=destructive]:focus:bg-destructive/20 data-[variant=destructive]:focus:text-destructive data-[variant=destructive]:*:[svg]:!text-destructive [&_svg:not([class*='text-'])]:text-muted-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),...r})}function VY(){return S.jsx("div",{className:"flex items-center justify-center h-dvh p-6 text-center",children:S.jsxs("div",{children:[S.jsx("h1",{className:"text-xl font-semibold mb-2",children:"Something went wrong"}),S.jsx("p",{className:"text-sm text-muted-foreground",children:"The dashboard encountered an error. Use the Fluxy button to continue chatting."})]})})}function qY(){const[e,t]=A.useState(!1),[n,r]=A.useState(!1),[o,l]=A.useState("Fluxy"),[u,d]=A.useState(!1),{ws:f,connected:p}=XL(),m=A.useRef(null);A.useEffect(()=>{fetch("/api/settings").then(y=>y.json()).then(y=>{y.onboard_complete!=="true"&&r(!0),y.agent_name&&l(y.agent_name),y.whisper_enabled==="true"&&d(!0)}).catch(()=>r(!0))},[]);const g=()=>{r(!1),fetch("/api/settings").then(y=>y.json()).then(y=>{y.agent_name&&l(y.agent_name),d(y.whisper_enabled==="true")}).catch(()=>{})};return S.jsxs(S.Fragment,{children:[S.jsx(t2,{fallback:S.jsx(VY,{}),children:S.jsx(iz,{onOpenOnboard:()=>r(!0),children:S.jsx(cz,{})})}),S.jsx(xC,{open:e,onOpenChange:t,children:S.jsxs(wC,{side:"right",className:"w-full sm:max-w-md !gap-0 !p-0 !border-l-0 !h-dvh overflow-hidden",onOpenAutoFocus:y=>y.preventDefault(),children:[S.jsxs("div",{className:"flex items-center gap-3 px-4 pr-12 py-3 border-b border-border shrink-0",children:[S.jsx("img",{src:"/fluxy.png",alt:o,className:"h-5 w-auto"}),S.jsx(TC,{className:"text-sm font-semibold",children:o}),S.jsx("div",{className:`h-2 w-2 rounded-full ${p?"bg-green-500":"bg-red-500"}`}),S.jsx("div",{className:"flex-1"}),S.jsxs(zY,{children:[S.jsx(GY,{asChild:!0,children:S.jsx("button",{className:"flex items-center justify-center h-7 w-7 rounded-full text-muted-foreground hover:text-foreground hover:bg-white/[0.06] transition-colors",children:S.jsx(vM,{className:"h-4 w-4"})})}),S.jsx($Y,{align:"end",sideOffset:8,children:S.jsxs(HY,{onClick:()=>m.current?.(),children:[S.jsx(lN,{className:"h-3.5 w-3.5"}),"Clear Context"]})})]}),S.jsxs(nz,{className:"sr-only",children:["Chat with your ",o," AI assistant"]})]}),S.jsx("div",{className:"flex-1 min-h-0 flex flex-col overflow-hidden",children:S.jsx(MY,{ws:f,clearContextRef:m,whisperEnabled:u})})]})}),S.jsx(FY,{onClick:()=>t(y=>!y)}),n&&S.jsx(jY,{onComplete:g})]})}WL.createRoot(document.getElementById("root")).render(S.jsx(zt.StrictMode,{children:S.jsx(qY,{})}));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-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;--tw-content:""}}}@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-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--color-amber-400:oklch(82.8% .189 84.429);--color-amber-500:oklch(76.9% .188 70.08);--color-green-500:oklch(72.3% .219 149.579);--color-emerald-400:oklch(76.5% .177 163.223);--color-emerald-500:oklch(69.6% .17 162.48);--color-slate-500:oklch(55.4% .046 257.417);--color-slate-800:oklch(27.9% .041 260.031);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-900:oklch(21% .034 264.665);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--container-lg:32rem;--container-6xl:72rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-widest:.1em;--leading-tight:1.25;--leading-relaxed:1.625;--radius-xs:.125rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--drop-shadow-lg:0 4px 4px #00000026;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-ping:ping 1s cubic-bezier(0, 0, .2, 1) infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--animate-bounce:bounce 1s infinite;--blur-md:12px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-background:#212121;--color-foreground:#f5f5f5}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.\@container\/card-header{container:card-header/inline-size}.pointer-events-none{pointer-events:none}.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}.inset-0{inset:calc(var(--spacing) * 0)}.inset-x-0{inset-inline:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.-top-0\.5{top:calc(var(--spacing) * -.5)}.-top-1\.5{top:calc(var(--spacing) * -1.5)}.top-0{top:calc(var(--spacing) * 0)}.top-1\/2{top:50%}.top-2{top:calc(var(--spacing) * 2)}.top-4{top:calc(var(--spacing) * 4)}.top-\[50\%\]{top:50%}.top-full{top:100%}.-right-0\.5{right:calc(var(--spacing) * -.5)}.-right-1\.5{right:calc(var(--spacing) * -1.5)}.right-0{right:calc(var(--spacing) * 0)}.right-2{right:calc(var(--spacing) * 2)}.right-3{right:calc(var(--spacing) * 3)}.right-4{right:calc(var(--spacing) * 4)}.right-6{right:calc(var(--spacing) * 6)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-6{bottom:calc(var(--spacing) * 6)}.left-0{left:calc(var(--spacing) * 0)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing) * 2)}.left-3{left:calc(var(--spacing) * 3)}.left-\[50\%\]{left:50%}.z-10{z-index:10}.z-50{z-index:50}.z-\[200\]{z-index:200}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.mx-1\.5{margin-inline:calc(var(--spacing) * 1.5)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.my-1\.5{margin-block:calc(var(--spacing) * 1.5)}.my-2{margin-block:calc(var(--spacing) * 2)}.-mt-3{margin-top:calc(var(--spacing) * -3)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-2\.5{margin-top:calc(var(--spacing) * 2.5)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-auto{margin-top:auto}.mt-px{margin-top:1px}.mr-1\.5{margin-right:calc(var(--spacing) * 1.5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.ml-0\.5{margin-left:calc(var(--spacing) * .5)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.field-sizing-content{field-sizing:content}.aspect-square{aspect-ratio:1}.size-2{width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.size-2\.5{width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.size-3\.5{width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.size-4{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.size-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-full{width:100%;height:100%}.\!h-dvh{height:100dvh!important}.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-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-28{height:calc(var(--spacing) * 28)}.h-\[18px\]{height:18px}.h-\[22px\]{height:22px}.h-\[180px\]{height:180px}.h-\[calc\(100\%-1px\)\]{height:calc(100% - 1px)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-dvh{height:100dvh}.h-full{height:100%}.h-px{height:1px}.max-h-\(--radix-dropdown-menu-content-available-height\){max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-\(--radix-select-content-available-height\){max-height:var(--radix-select-content-available-height)}.max-h-48{max-height:calc(var(--spacing) * 48)}.max-h-\[85vh\]{max-height:85vh}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-16{min-height:calc(var(--spacing) * 16)}.min-h-\[200px\]{min-height:200px}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2{width:calc(var(--spacing) * 2)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-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-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-28{width:calc(var(--spacing) * 28)}.w-52{width:calc(var(--spacing) * 52)}.w-72{width:calc(var(--spacing) * 72)}.w-\[18px\]{width:18px}.w-auto{width:auto}.w-fit{width:fit-content}.w-full{width:100%}.max-w-6xl{max-width:var(--container-6xl)}.max-w-10{max-width:calc(var(--spacing) * 10)}.max-w-\[75\%\]{max-width:75%}.max-w-\[90vw\]{max-width:90vw}.max-w-\[320px\]{max-width:320px}.max-w-\[480px\]{max-width:480px}.max-w-\[calc\(100\%-2rem\)\]{max-width:calc(100% - 2rem)}.max-w-none{max-width:none}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[180px\]{min-width:180px}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.origin-\(--radix-dropdown-menu-content-transform-origin\){transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\(--radix-select-content-transform-origin\){transform-origin:var(--radix-select-content-transform-origin)}.origin-\(--radix-tooltip-content-transform-origin\){transform-origin:var(--radix-tooltip-content-transform-origin)}.-translate-x-1\/2{--tw-translate-x: -50% ;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-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-\[18px\]{--tw-translate-x:18px;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)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[calc\(-50\%_-_2px\)\]{--tw-translate-y: calc(-50% - 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-45{rotate:45deg}.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-bounce{animation:var(--animate-bounce)}.animate-ping{animation:var(--animate-ping)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.resize{resize:both}.resize-none{resize:none}.scroll-my-1{scroll-margin-block:calc(var(--spacing) * 1)}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.auto-rows-min{grid-auto-rows:min-content}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.\!gap-0{gap:calc(var(--spacing) * 0)!important}.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-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-3\.5{gap:calc(var(--spacing) * 3.5)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}: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-2\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}:where(.-space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * -2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * -2) * calc(1 - var(--tw-space-x-reverse)))}.self-start{align-self:flex-start}.justify-self-end{justify-self:flex-end}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.75rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[2px\]{border-radius:2px}.rounded-\[24px\]{border-radius:24px}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-xs{border-radius:var(--radius-xs)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-\[1\.5px\]{border-style:var(--tw-border-style);border-width:1.5px}.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-0{border-left-style:var(--tw-border-style)!important;border-left-width:0!important}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-\[\#AF27E3\]\/20{border-color:#af27e333}.border-\[\#AF27E3\]\/30{border-color:#af27e34d}.border-\[\#AF27E3\]\/40{border-color:#af27e366}.border-amber-500\/20{border-color:#f99c0033}@supports (color:color-mix(in lab,red,red)){.border-amber-500\/20{border-color:color-mix(in oklab,var(--color-amber-500) 20%,transparent)}}.border-border{border-color:#3a3a3a}.border-emerald-500\/15{border-color:#00bb7f26}@supports (color:color-mix(in lab,red,red)){.border-emerald-500\/15{border-color:color-mix(in oklab,var(--color-emerald-500) 15%,transparent)}}.border-emerald-500\/20{border-color:#00bb7f33}@supports (color:color-mix(in lab,red,red)){.border-emerald-500\/20{border-color:color-mix(in oklab,var(--color-emerald-500) 20%,transparent)}}.border-input{border-color:#3a3a3a}.border-muted-foreground\/30{border-color:#9999994d}.border-red-500\/15{border-color:#fb2c3626}@supports (color:color-mix(in lab,red,red)){.border-red-500\/15{border-color:color-mix(in oklab,var(--color-red-500) 15%,transparent)}}.border-red-500\/20{border-color:#fb2c3633}@supports (color:color-mix(in lab,red,red)){.border-red-500\/20{border-color:color-mix(in oklab,var(--color-red-500) 20%,transparent)}}.border-slate-800{border-color:var(--color-slate-800)}.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-white\/\[0\.04\]{border-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.04\]{border-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.border-white\/\[0\.06\]{border-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.06\]{border-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.border-white\/\[0\.08\]{border-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.08\]{border-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.border-t-\[\#04D1FE\]{border-top-color:#04d1fe}.border-t-primary{border-top-color:#3c8fff}.border-t-transparent{border-top-color:#0000}.border-l-transparent{border-left-color:#0000}.bg-\[\#222\]{background-color:#222}.bg-\[\#181818\]{background-color:#181818}.bg-\[\#AF27E3\]\/10{background-color:#af27e31a}.bg-\[\#AF27E3\]\/15{background-color:#af27e326}.bg-\[\#AF27E3\]\/\[0\.06\]{background-color:#af27e30f}.bg-accent{background-color:#333}.bg-amber-500\/8{background-color:#f99c0014}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/8{background-color:color-mix(in oklab,var(--color-amber-500) 8%,transparent)}}.bg-amber-500\/15{background-color:#f99c0026}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/15{background-color:color-mix(in oklab,var(--color-amber-500) 15%,transparent)}}.bg-background{background-color:#212121}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab,red,red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black) 40%,transparent)}}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:color-mix(in oklab,var(--color-black) 80%,transparent)}}.bg-black\/85{background-color:#000000d9}@supports (color:color-mix(in lab,red,red)){.bg-black\/85{background-color:color-mix(in oklab,var(--color-black) 85%,transparent)}}.bg-black\/90{background-color:#000000e6}@supports (color:color-mix(in lab,red,red)){.bg-black\/90{background-color:color-mix(in oklab,var(--color-black) 90%,transparent)}}.bg-border{background-color:#3a3a3a}.bg-card{background-color:#2a2a2a}.bg-destructive{background-color:#fd486b}.bg-destructive\/10{background-color:#fd486b1a}.bg-destructive\/15{background-color:#fd486b26}.bg-emerald-500\/8{background-color:#00bb7f14}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/8{background-color:color-mix(in oklab,var(--color-emerald-500) 8%,transparent)}}.bg-emerald-500\/10{background-color:#00bb7f1a}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/10{background-color:color-mix(in oklab,var(--color-emerald-500) 10%,transparent)}}.bg-emerald-500\/15{background-color:#00bb7f26}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/15{background-color:color-mix(in oklab,var(--color-emerald-500) 15%,transparent)}}.bg-foreground{background-color:#f5f5f5}.bg-green-500{background-color:var(--color-green-500)}.bg-muted{background-color:#333}.bg-muted-foreground{background-color:#999}.bg-muted-foreground\/60{background-color:#9999}.bg-popover{background-color:#2a2a2a}.bg-primary{background-color:#3c8fff}.bg-red-500{background-color:var(--color-red-500)}.bg-red-500\/8{background-color:#fb2c3614}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/8{background-color:color-mix(in oklab,var(--color-red-500) 8%,transparent)}}.bg-red-500\/10{background-color:#fb2c361a}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/10{background-color:color-mix(in oklab,var(--color-red-500) 10%,transparent)}}.bg-secondary{background-color:#333}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/5{background-color:#ffffff0d}@supports (color:color-mix(in lab,red,red)){.bg-white\/5{background-color:color-mix(in oklab,var(--color-white) 5%,transparent)}}.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\/20{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.bg-white\/20{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.bg-white\/70{background-color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.bg-white\/70{background-color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.bg-white\/\[0\.02\]{background-color:#ffffff05}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.02\]{background-color:color-mix(in oklab,var(--color-white) 2%,transparent)}}.bg-white\/\[0\.03\]{background-color:#ffffff08}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.03\]{background-color:color-mix(in oklab,var(--color-white) 3%,transparent)}}.bg-white\/\[0\.04\]{background-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.04\]{background-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.bg-white\/\[0\.05\]{background-color:#ffffff0d}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.05\]{background-color:color-mix(in oklab,var(--color-white) 5%,transparent)}}.bg-white\/\[0\.06\]{background-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.06\]{background-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.bg-white\/\[0\.08\]{background-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.08\]{background-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.fill-current{fill:currentColor}.fill-foreground{fill:#f5f5f5}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.\!p-0{padding:calc(var(--spacing) * 0)!important}.p-0{padding:calc(var(--spacing) * 0)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.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)}.p-\[3px\]{padding:3px}.p-px{padding:1px}.px-0\.5{padding-inline:calc(var(--spacing) * .5)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-3\.5{padding-inline:calc(var(--spacing) * 3.5)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-7{padding-inline:calc(var(--spacing) * 7)}.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-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.pt-2\.5{padding-top:calc(var(--spacing) * 2.5)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pt-8{padding-top:calc(var(--spacing) * 8)}.pr-0\.5{padding-right:calc(var(--spacing) * .5)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pr-8{padding-right:calc(var(--spacing) * 8)}.pr-10{padding-right:calc(var(--spacing) * 10)}.pr-12{padding-right:calc(var(--spacing) * 12)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.pb-8{padding-bottom:calc(var(--spacing) * 8)}.pl-1{padding-left:calc(var(--spacing) * 1)}.pl-2{padding-left:calc(var(--spacing) * 2)}.pl-4{padding-left:calc(var(--spacing) * 4)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.8rem\]{font-size:.8rem}.text-\[8px\]{font-size:8px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.leading-\[1\.1\]{--tw-leading:1.1;line-height:1.1}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.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-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-balance{text-wrap:balance}.break-words{overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.text-\[\#AF27E3\]{color:#af27e3}.text-\[\#AF27E3\]\/60{color:#af27e399}.text-amber-400{color:var(--color-amber-400)}.text-amber-400\/60{color:#fcbb0099}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/60{color:color-mix(in oklab,var(--color-amber-400) 60%,transparent)}}.text-amber-400\/70{color:#fcbb00b3}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/70{color:color-mix(in oklab,var(--color-amber-400) 70%,transparent)}}.text-amber-400\/90{color:#fcbb00e6}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/90{color:color-mix(in oklab,var(--color-amber-400) 90%,transparent)}}.text-background{color:#212121}.text-card-foreground{color:#f5f5f5}.text-destructive{color:#fd486b}.text-destructive-foreground{color:#fff}.text-emerald-400{color:var(--color-emerald-400)}.text-emerald-400\/60{color:#00d29499}@supports (color:color-mix(in lab,red,red)){.text-emerald-400\/60{color:color-mix(in oklab,var(--color-emerald-400) 60%,transparent)}}.text-emerald-400\/90{color:#00d294e6}@supports (color:color-mix(in lab,red,red)){.text-emerald-400\/90{color:color-mix(in oklab,var(--color-emerald-400) 90%,transparent)}}.text-foreground{color:#f5f5f5}.text-foreground\/60{color:#f5f5f599}.text-foreground\/80{color:#f5f5f5cc}.text-gray-400{color:var(--color-gray-400)}.text-gray-900{color:var(--color-gray-900)}.text-muted-foreground{color:#999}.text-muted-foreground\/50{color:#99999980}.text-popover-foreground{color:#f5f5f5}.text-primary{color:#3c8fff}.text-primary-foreground{color:#fff}.text-primary-foreground\/60{color:#fff9}.text-red-400{color:var(--color-red-400)}.text-red-400\/70{color:#ff6568b3}@supports (color:color-mix(in lab,red,red)){.text-red-400\/70{color:color-mix(in oklab,var(--color-red-400) 70%,transparent)}}.text-red-400\/90{color:#ff6568e6}@supports (color:color-mix(in lab,red,red)){.text-red-400\/90{color:color-mix(in oklab,var(--color-red-400) 90%,transparent)}}.text-secondary-foreground{color:#f5f5f5}.text-slate-500{color:var(--color-slate-500)}.text-white{color:var(--color-white)}.text-white\/20{color:#fff3}@supports (color:color-mix(in lab,red,red)){.text-white\/20{color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.text-white\/25{color:#ffffff40}@supports (color:color-mix(in lab,red,red)){.text-white\/25{color:color-mix(in oklab,var(--color-white) 25%,transparent)}}.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\/35{color:#ffffff59}@supports (color:color-mix(in lab,red,red)){.text-white\/35{color:color-mix(in oklab,var(--color-white) 35%,transparent)}}.text-white\/40{color:#fff6}@supports (color:color-mix(in lab,red,red)){.text-white\/40{color:color-mix(in oklab,var(--color-white) 40%,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\/60{color:#fff9}@supports (color:color-mix(in lab,red,red)){.text-white\/60{color:color-mix(in oklab,var(--color-white) 60%,transparent)}}.text-white\/70{color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.text-white\/70{color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.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,)}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-100{opacity:1}.opacity-\[0\.06\]{opacity:.06}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-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)}.shadow-xs{--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-0{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(0px + 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)}.ring-background{--tw-ring-color:#212121}.ring-offset-background{--tw-ring-offset-color:#212121}.outline-hidden{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.outline-hidden{outline-offset:2px;outline:2px solid #0000}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.drop-shadow-lg{--tw-drop-shadow-size:drop-shadow(0 4px 4px var(--tw-drop-shadow-color,#00000026));--tw-drop-shadow:drop-shadow(var(--drop-shadow-lg));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-md{--tw-backdrop-blur:blur(var(--blur-md));-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-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[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-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.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)}.will-change-transform{will-change:transform}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media(hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.group-has-data-\[size\=lg\]\/avatar-group\:size-10:is(:where(.group\/avatar-group):has([data-size=lg]) *){width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.group-has-data-\[size\=sm\]\/avatar-group\:size-6:is(:where(.group\/avatar-group):has([data-size=sm]) *){width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.group-data-\[orientation\=horizontal\]\/tabs\:h-9:is(:where(.group\/tabs)[data-orientation=horizontal] *){height:calc(var(--spacing) * 9)}.group-data-\[orientation\=vertical\]\/tabs\:h-fit:is(:where(.group\/tabs)[data-orientation=vertical] *){height:fit-content}.group-data-\[orientation\=vertical\]\/tabs\:w-full:is(:where(.group\/tabs)[data-orientation=vertical] *){width:100%}.group-data-\[orientation\=vertical\]\/tabs\:flex-col:is(:where(.group\/tabs)[data-orientation=vertical] *){flex-direction:column}.group-data-\[orientation\=vertical\]\/tabs\:justify-start:is(:where(.group\/tabs)[data-orientation=vertical] *){justify-content:flex-start}.group-data-\[size\=default\]\/avatar\:size-2\.5:is(:where(.group\/avatar)[data-size=default] *){width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.group-data-\[size\=default\]\/switch\:size-4:is(:where(.group\/switch)[data-size=default] *){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.group-data-\[size\=lg\]\/avatar\:size-3:is(:where(.group\/avatar)[data-size=lg] *){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.group-data-\[size\=sm\]\/avatar\:size-2:is(:where(.group\/avatar)[data-size=sm] *){width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.group-data-\[size\=sm\]\/avatar\:text-xs:is(:where(.group\/avatar)[data-size=sm] *){font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.group-data-\[size\=sm\]\/switch\:size-3:is(:where(.group\/switch)[data-size=sm] *){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.group-data-\[variant\=line\]\/tabs-list\:bg-transparent:is(:where(.group\/tabs-list)[data-variant=line] *){background-color:#0000}.selection\:bg-primary ::selection{background-color:#3c8fff}.selection\:bg-primary::selection{background-color:#3c8fff}.selection\:text-primary-foreground ::selection{color:#fff}.selection\:text-primary-foreground::selection{color:#fff}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:calc(var(--spacing) * 7)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:#f5f5f5}.placeholder\:text-gray-400::placeholder{color:var(--color-gray-400)}.placeholder\:text-muted-foreground::placeholder{color:#999}.placeholder\:text-white\/20::placeholder{color:#fff3}@supports (color:color-mix(in lab,red,red)){.placeholder\:text-white\/20::placeholder{color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:bg-foreground:after{content:var(--tw-content);background-color:#f5f5f5}.after\:opacity-0:after{content:var(--tw-content);opacity:0}.after\:transition-opacity:after{content:var(--tw-content);transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.group-data-\[orientation\=horizontal\]\/tabs\:after\:inset-x-0:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);inset-inline:calc(var(--spacing) * 0)}.group-data-\[orientation\=horizontal\]\/tabs\:after\:bottom-\[-5px\]:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);bottom:-5px}.group-data-\[orientation\=horizontal\]\/tabs\:after\:h-0\.5:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);height:calc(var(--spacing) * .5)}.group-data-\[orientation\=vertical\]\/tabs\:after\:inset-y-0:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);inset-block:calc(var(--spacing) * 0)}.group-data-\[orientation\=vertical\]\/tabs\:after\:-right-1:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);right:calc(var(--spacing) * -1)}.group-data-\[orientation\=vertical\]\/tabs\:after\:w-0\.5:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);width:calc(var(--spacing) * .5)}@media(hover:hover){.hover\:border-white\/10:hover{border-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:border-white\/10:hover{border-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.hover\:border-white\/15:hover{border-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.hover\:border-white\/15:hover{border-color:color-mix(in oklab,var(--color-white) 15%,transparent)}}.hover\:bg-accent:hover{background-color:#333}.hover\:bg-destructive\/90:hover{background-color:#fd486be6}.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:bg-primary\/90:hover{background-color:#3c8fffe6}.hover\:bg-secondary\/80:hover{background-color:#333c}.hover\:bg-white\/20:hover{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/20:hover{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.hover\:bg-white\/30:hover{background-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/30:hover{background-color:color-mix(in oklab,var(--color-white) 30%,transparent)}}.hover\:bg-white\/\[0\.1\]:hover{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.1\]:hover{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.hover\:bg-white\/\[0\.02\]:hover{background-color:#ffffff05}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.02\]:hover{background-color:color-mix(in oklab,var(--color-white) 2%,transparent)}}.hover\:bg-white\/\[0\.04\]:hover{background-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.04\]:hover{background-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.hover\:bg-white\/\[0\.06\]:hover{background-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.06\]:hover{background-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.hover\:bg-white\/\[0\.08\]:hover{background-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.08\]:hover{background-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.hover\:bg-white\/\[0\.09\]:hover{background-color:#ffffff17}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.09\]:hover{background-color:color-mix(in oklab,var(--color-white) 9%,transparent)}}.hover\:text-accent-foreground:hover,.hover\:text-foreground:hover{color:#f5f5f5}.hover\:text-gray-600:hover{color:var(--color-gray-600)}.hover\:text-white:hover{color:var(--color-white)}.hover\:text-white\/40:hover{color:#fff6}@supports (color:color-mix(in lab,red,red)){.hover\:text-white\/40:hover{color:color-mix(in oklab,var(--color-white) 40%,transparent)}}.hover\:text-white\/50:hover{color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.hover\:text-white\/50:hover{color:color-mix(in oklab,var(--color-white) 50%,transparent)}}.hover\:text-white\/60:hover{color:#fff9}@supports (color:color-mix(in lab,red,red)){.hover\:text-white\/60:hover{color:color-mix(in oklab,var(--color-white) 60%,transparent)}}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-80:hover{opacity:.8}.hover\:opacity-90:hover{opacity:.9}.hover\:opacity-100:hover{opacity:1}.hover\:brightness-110:hover{--tw-brightness:brightness(110%);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,)}}.focus\:border-\[\#AF27E3\]\/30:focus{border-color:#af27e34d}.focus\:bg-accent:focus{background-color:#333}.focus\:text-accent-foreground:focus{color:#f5f5f5}.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-ring:focus{--tw-ring-color:#3c8fff}.focus\:ring-offset-2:focus{--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\:outline-hidden:focus{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.focus\:outline-hidden:focus{outline-offset:2px;outline:2px solid #0000}}.focus-visible\:border-ring:focus-visible{border-color:#3c8fff}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:oklab(67.0267% .20922 .0534847/.2)}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:oklab(65.65% -.0412982 -.180011/.5)}.focus-visible\:outline-1:focus-visible{outline-style:var(--tw-outline-style);outline-width:1px}.focus-visible\:outline-ring:focus-visible{outline-color:#3c8fff}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}.has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\]:has([data-slot=card-action]){grid-template-columns:1fr auto}.has-\[\>svg\]\:px-1\.5:has(>svg){padding-inline:calc(var(--spacing) * 1.5)}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing) * 2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing) * 3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing) * 4)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:#fd486b}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:oklab(67.0267% .20922 .0534847/.2)}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[inset\]\:pl-8[data-inset]{padding-left:calc(var(--spacing) * 8)}.data-\[orientation\=horizontal\]\:h-px[data-orientation=horizontal]{height:1px}.data-\[orientation\=horizontal\]\:w-full[data-orientation=horizontal]{width:100%}.data-\[orientation\=horizontal\]\:flex-col[data-orientation=horizontal]{flex-direction:column}.data-\[orientation\=vertical\]\:h-full[data-orientation=vertical]{height:100%}.data-\[orientation\=vertical\]\:w-px[data-orientation=vertical]{width:1px}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:#999}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[size\=default\]\:h-9[data-size=default]{height:calc(var(--spacing) * 9)}.data-\[size\=default\]\:h-\[1\.15rem\][data-size=default]{height:1.15rem}.data-\[size\=default\]\:w-8[data-size=default]{width:calc(var(--spacing) * 8)}.data-\[size\=lg\]\:size-10[data-size=lg]{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.data-\[size\=sm\]\:size-6[data-size=sm]{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.data-\[size\=sm\]\:h-3\.5[data-size=sm]{height:calc(var(--spacing) * 3.5)}.data-\[size\=sm\]\:h-8[data-size=sm]{height:calc(var(--spacing) * 8)}.data-\[size\=sm\]\:w-6[data-size=sm]{width:calc(var(--spacing) * 6)}:is(.\*\:data-\[slot\=avatar\]\:ring-2>*)[data-slot=avatar]{--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)}:is(.\*\:data-\[slot\=avatar\]\:ring-background>*)[data-slot=avatar]{--tw-ring-color:#212121}:is(.\*\:data-\[slot\=select-value\]\:line-clamp-1>*)[data-slot=select-value]{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}:is(.\*\:data-\[slot\=select-value\]\:flex>*)[data-slot=select-value]{display:flex}:is(.\*\:data-\[slot\=select-value\]\:items-center>*)[data-slot=select-value]{align-items:center}:is(.\*\:data-\[slot\=select-value\]\:gap-2>*)[data-slot=select-value]{gap:calc(var(--spacing) * 2)}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:#212121}.data-\[state\=active\]\:bg-primary[data-state=active]{background-color:#3c8fff}.data-\[state\=active\]\:text-foreground[data-state=active]{color:#f5f5f5}.data-\[state\=active\]\:text-primary-foreground[data-state=active]{color:#fff}.data-\[state\=active\]\:shadow-none[data-state=active]{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=default\]\/tabs-list\:data-\[state\=active\]\:shadow-sm:is(:where(.group\/tabs-list)[data-variant=default] *)[data-state=active]{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:bg-transparent:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{background-color:#0000}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:shadow-none:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:after\:opacity-100:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]:after{content:var(--tw-content);opacity:1}.data-\[state\=checked\]\:translate-x-\[calc\(100\%-2px\)\][data-state=checked]{--tw-translate-x: calc(100% - 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:#3c8fff}.data-\[state\=closed\]\:duration-300[data-state=closed]{--tw-duration:.3s;transition-duration:.3s}.data-\[state\=open\]\:bg-accent[data-state=open],.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:#333}.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:#f5f5f5}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:#999}.data-\[state\=open\]\:duration-500[data-state=open]{--tw-duration:.5s;transition-duration:.5s}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:#3a3a3a}.data-\[variant\=destructive\]\:text-destructive[data-variant=destructive]{color:#fd486b}.data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant=destructive]:focus{background-color:#fd486b1a}.data-\[variant\=destructive\]\:focus\:text-destructive[data-variant=destructive]:focus{color:#fd486b}.data-\[variant\=line\]\:rounded-none[data-variant=line]{border-radius:0}@media(min-width:40rem){.sm\:mt-4{margin-top:calc(var(--spacing) * 4)}.sm\:mb-6{margin-bottom:calc(var(--spacing) * 6)}.sm\:block{display:block}.sm\:h-2\.5{height:calc(var(--spacing) * 2.5)}.sm\:w-2\.5{width:calc(var(--spacing) * 2.5)}.sm\:w-16{width:calc(var(--spacing) * 16)}.sm\:max-w-lg{max-width:var(--container-lg)}.sm\:max-w-md{max-width:var(--container-md)}.sm\:max-w-sm{max-width:var(--container-sm)}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:items-start{align-items:flex-start}.sm\:justify-between{justify-content:space-between}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2{gap:calc(var(--spacing) * 2)}.sm\:gap-3{gap:calc(var(--spacing) * 3)}.sm\:gap-4{gap:calc(var(--spacing) * 4)}:where(.sm\: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(.sm\:space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}.sm\:p-6{padding:calc(var(--spacing) * 6)}.sm\:px-4{padding-inline:calc(var(--spacing) * 4)}.sm\:py-2{padding-block:calc(var(--spacing) * 2)}.sm\:text-left{text-align:left}.sm\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.sm\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.sm\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.sm\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.sm\:text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}}@media(min-width:48rem){.md\:block{display:block}.md\:flex{display:flex}.md\:hidden{display:none}.md\:p-6{padding:calc(var(--spacing) * 6)}.md\:px-6{padding-inline:calc(var(--spacing) * 6)}.md\:py-4{padding-block:calc(var(--spacing) * 4)}.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}@media(min-width:64rem){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.dark\:border-input:is(.dark *){border-color:#3a3a3a}.dark\:bg-destructive\/60:is(.dark *){background-color:#fd486b99}.dark\:bg-input\/30:is(.dark *){background-color:#3a3a3a4d}.dark\:text-muted-foreground:is(.dark *){color:#999}@media(hover:hover){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:#33333380}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:#3a3a3a80}.dark\:hover\:text-foreground:is(.dark *):hover{color:#f5f5f5}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible,.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:oklab(67.0267% .20922 .0534847/.4)}.dark\:data-\[state\=active\]\:border-input:is(.dark *)[data-state=active]{border-color:#3a3a3a}.dark\:data-\[state\=active\]\:bg-input\/30:is(.dark *)[data-state=active]{background-color:#3a3a3a4d}.dark\:data-\[state\=active\]\:text-foreground:is(.dark *)[data-state=active]{color:#f5f5f5}.dark\:group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:border-transparent:is(.dark *):is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{border-color:#0000}.dark\:group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:bg-transparent:is(.dark *):is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{background-color:#0000}.dark\:data-\[state\=checked\]\:bg-primary-foreground:is(.dark *)[data-state=checked]{background-color:#fff}.dark\:data-\[state\=unchecked\]\:bg-foreground:is(.dark *)[data-state=unchecked]{background-color:#f5f5f5}.dark\:data-\[state\=unchecked\]\:bg-input\/80:is(.dark *)[data-state=unchecked]{background-color:#3a3a3acc}.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:is(.dark *)[data-variant=destructive]:focus{background-color:#fd486b33}.\[\&_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-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground svg:not([class*=text-]){color:#999}.\[\.border-b\]\:pb-6.border-b{padding-bottom:calc(var(--spacing) * 6)}.\[\.border-t\]\:pt-6.border-t{padding-top:calc(var(--spacing) * 6)}:is(.\*\:\[span\]\:last\:flex>*):is(span):last-child{display:flex}:is(.\*\:\[span\]\:last\:items-center>*):is(span):last-child{align-items:center}:is(.\*\:\[span\]\:last\:gap-2>*):is(span):last-child{gap:calc(var(--spacing) * 2)}:is(.data-\[variant\=destructive\]\:\*\:\[svg\]\:\!text-destructive[data-variant=destructive]>*):is(svg){color:#fd486b!important}.\[\&\>\*\:first-child\]\:mt-0>:first-child{margin-top:calc(var(--spacing) * 0)}.\[\&\>\*\:last-child\]\:mb-0>:last-child{margin-bottom:calc(var(--spacing) * 0)}.\[\&\>svg\]\:pointer-events-none>svg{pointer-events:none}.\[\&\>svg\]\:size-3>svg{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&\>svg\]\:size-4>svg{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.group-has-data-\[size\=lg\]\/avatar-group\:\[\&\>svg\]\:size-5:is(:where(.group\/avatar-group):has([data-size=lg]) *)>svg{width:calc(var(--spacing) * 5);height:calc(var(--spacing) * 5)}.group-has-data-\[size\=sm\]\/avatar-group\:\[\&\>svg\]\:size-3:is(:where(.group\/avatar-group):has([data-size=sm]) *)>svg{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.group-data-\[size\=default\]\/avatar\:\[\&\>svg\]\:size-2:is(:where(.group\/avatar)[data-size=default] *)>svg,.group-data-\[size\=lg\]\/avatar\:\[\&\>svg\]\:size-2:is(:where(.group\/avatar)[data-size=lg] *)>svg{width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.group-data-\[size\=sm\]\/avatar\:\[\&\>svg\]\:hidden:is(:where(.group\/avatar)[data-size=sm] *)>svg{display:none}@media(hover:hover){a.\[a\&\]\:hover\:bg-accent:hover{background-color:#333}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:#fd486be6}a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:#3c8fffe6}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:#333333e6}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:#f5f5f5}a.\[a\&\]\:hover\:underline:hover{text-decoration-line:underline}}}body{background-color:var(--color-background);color:var(--color-foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background-color:#af27e340}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4a4a4a}.text-gradient{color:#0000;-webkit-text-fill-color:transparent;background-image:linear-gradient(135deg,#04d1fe,#af27e3,#fb4072);-webkit-background-clip:text;background-clip:text}.bg-gradient-brand{background-image:linear-gradient(135deg,#04d1fe,#af27e3,#fb4072)}.glow-border{box-shadow:0 0 0 1px #af27e31a,0 0 20px -5px #af27e326}.animated-border{position:relative;overflow:hidden}.animated-border:before{content:"";background:conic-gradient(#04d1fe,#af27e3,#fb4072,#04d1fe);animation:3s linear infinite border-spin;position:absolute;inset:-150%}.animated-border>*{z-index:1;position:relative}.animated-border-slow:before{animation-duration:5s}.input-glow:focus{border-color:#af27e366;box-shadow:0 0 0 1px #af27e326,0 0 20px -5px #af27e340,0 0 4px -1px #04d1fe1a}@keyframes border-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@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-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-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-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}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes spin{to{transform:rotate(360deg)}}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}@keyframes pulse{50%{opacity:.5}}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}
|
|
Binary file
|
package/dist/index.html
CHANGED
|
@@ -5,8 +5,8 @@
|
|
|
5
5
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, interactive-widget=resizes-content" />
|
|
6
6
|
<meta name="theme-color" content="#212121" />
|
|
7
7
|
<title>Fluxy</title>
|
|
8
|
-
<script type="module" crossorigin src="/assets/index-
|
|
9
|
-
<link rel="stylesheet" crossorigin href="/assets/index-
|
|
8
|
+
<script type="module" crossorigin src="/assets/index-CW83Kbey.js"></script>
|
|
9
|
+
<link rel="stylesheet" crossorigin href="/assets/index-Dpj8titN.css">
|
|
10
10
|
<link rel="manifest" href="/manifest.webmanifest"><script id="vite-plugin-pwa:register-sw" src="/registerSW.js"></script></head>
|
|
11
11
|
<body class="bg-background text-foreground">
|
|
12
12
|
<div id="root"></div>
|
package/dist/sw.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
if(!self.define){let e,
|
|
1
|
+
if(!self.define){let e,i={};const s=(s,n)=>(s=new URL(s+".js",n).href,i[s]||new Promise(i=>{if("document"in self){const e=document.createElement("script");e.src=s,e.onload=i,document.head.appendChild(e)}else e=s,importScripts(s),i()}).then(()=>{let e=i[s];if(!e)throw new Error(`Module ${s} didn’t register its module`);return e}));self.define=(n,t)=>{const r=e||("document"in self?document.currentScript.src:"")||location.href;if(i[r])return;let o={};const l=e=>s(e,r),c={module:{uri:r},exports:o,require:l};i[r]=Promise.all(n.map(e=>c[e]||l(e))).then(e=>(t(...e),o))}}define(["./workbox-8c29f6e4"],function(e){"use strict";self.skipWaiting(),e.clientsClaim(),e.precacheAndRoute([{url:"registerSW.js",revision:"1872c500de691dce40960bb85481de07"},{url:"index.html",revision:"073d184a4b23dccfb47be00138ff218f"},{url:"assets/index-Dpj8titN.css",revision:null},{url:"assets/index-CW83Kbey.js",revision:null},{url:"manifest.webmanifest",revision:"f73683d89ca6b3b7b63451130e165f71"}],{}),e.cleanupOutdatedCaches(),e.registerRoute(new e.NavigationRoute(e.createHandlerBoundToURL("index.html")))});
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-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;--tw-content:""}}}@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-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--color-amber-400:oklch(82.8% .189 84.429);--color-amber-500:oklch(76.9% .188 70.08);--color-green-500:oklch(72.3% .219 149.579);--color-emerald-400:oklch(76.5% .177 163.223);--color-emerald-500:oklch(69.6% .17 162.48);--color-slate-500:oklch(55.4% .046 257.417);--color-slate-800:oklch(27.9% .041 260.031);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-900:oklch(21% .034 264.665);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--container-lg:32rem;--container-6xl:72rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-widest:.1em;--leading-tight:1.25;--leading-relaxed:1.625;--radius-xs:.125rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--drop-shadow-lg:0 4px 4px #00000026;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-ping:ping 1s cubic-bezier(0, 0, .2, 1) infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--animate-bounce:bounce 1s infinite;--blur-md:12px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-background:#212121;--color-foreground:#f5f5f5}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.\@container\/card-header{container:card-header/inline-size}.pointer-events-none{pointer-events:none}.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}.inset-0{inset:calc(var(--spacing) * 0)}.inset-x-0{inset-inline:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.-top-0\.5{top:calc(var(--spacing) * -.5)}.-top-1\.5{top:calc(var(--spacing) * -1.5)}.top-0{top:calc(var(--spacing) * 0)}.top-1\/2{top:50%}.top-2{top:calc(var(--spacing) * 2)}.top-4{top:calc(var(--spacing) * 4)}.top-\[50\%\]{top:50%}.top-full{top:100%}.-right-0\.5{right:calc(var(--spacing) * -.5)}.-right-1\.5{right:calc(var(--spacing) * -1.5)}.right-0{right:calc(var(--spacing) * 0)}.right-2{right:calc(var(--spacing) * 2)}.right-3{right:calc(var(--spacing) * 3)}.right-4{right:calc(var(--spacing) * 4)}.right-6{right:calc(var(--spacing) * 6)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-6{bottom:calc(var(--spacing) * 6)}.left-0{left:calc(var(--spacing) * 0)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing) * 2)}.left-3{left:calc(var(--spacing) * 3)}.left-\[50\%\]{left:50%}.z-10{z-index:10}.z-50{z-index:50}.z-\[200\]{z-index:200}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.mx-1\.5{margin-inline:calc(var(--spacing) * 1.5)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.my-1\.5{margin-block:calc(var(--spacing) * 1.5)}.my-2{margin-block:calc(var(--spacing) * 2)}.-mt-3{margin-top:calc(var(--spacing) * -3)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-2\.5{margin-top:calc(var(--spacing) * 2.5)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-auto{margin-top:auto}.mt-px{margin-top:1px}.mr-1\.5{margin-right:calc(var(--spacing) * 1.5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.ml-0\.5{margin-left:calc(var(--spacing) * .5)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.field-sizing-content{field-sizing:content}.aspect-square{aspect-ratio:1}.size-2{width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.size-2\.5{width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.size-3\.5{width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.size-4{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.size-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-full{width:100%;height:100%}.\!h-dvh{height:100dvh!important}.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-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-16{height:calc(var(--spacing) * 16)}.h-28{height:calc(var(--spacing) * 28)}.h-\[18px\]{height:18px}.h-\[22px\]{height:22px}.h-\[calc\(100\%-1px\)\]{height:calc(100% - 1px)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-dvh{height:100dvh}.h-full{height:100%}.h-px{height:1px}.max-h-\(--radix-dropdown-menu-content-available-height\){max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-\(--radix-select-content-available-height\){max-height:var(--radix-select-content-available-height)}.max-h-48{max-height:calc(var(--spacing) * 48)}.max-h-\[85vh\]{max-height:85vh}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-16{min-height:calc(var(--spacing) * 16)}.min-h-\[200px\]{min-height:200px}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2{width:calc(var(--spacing) * 2)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-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-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-28{width:calc(var(--spacing) * 28)}.w-52{width:calc(var(--spacing) * 52)}.w-72{width:calc(var(--spacing) * 72)}.w-\[18px\]{width:18px}.w-auto{width:auto}.w-fit{width:fit-content}.w-full{width:100%}.max-w-6xl{max-width:var(--container-6xl)}.max-w-10{max-width:calc(var(--spacing) * 10)}.max-w-\[75\%\]{max-width:75%}.max-w-\[90vw\]{max-width:90vw}.max-w-\[320px\]{max-width:320px}.max-w-\[480px\]{max-width:480px}.max-w-\[calc\(100\%-2rem\)\]{max-width:calc(100% - 2rem)}.max-w-none{max-width:none}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[180px\]{min-width:180px}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.origin-\(--radix-dropdown-menu-content-transform-origin\){transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\(--radix-select-content-transform-origin\){transform-origin:var(--radix-select-content-transform-origin)}.origin-\(--radix-tooltip-content-transform-origin\){transform-origin:var(--radix-tooltip-content-transform-origin)}.-translate-x-1\/2{--tw-translate-x: -50% ;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-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-\[18px\]{--tw-translate-x:18px;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)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[calc\(-50\%_-_2px\)\]{--tw-translate-y: calc(-50% - 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-45{rotate:45deg}.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-bounce{animation:var(--animate-bounce)}.animate-ping{animation:var(--animate-ping)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.resize{resize:both}.resize-none{resize:none}.scroll-my-1{scroll-margin-block:calc(var(--spacing) * 1)}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.auto-rows-min{grid-auto-rows:min-content}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.\!gap-0{gap:calc(var(--spacing) * 0)!important}.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-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-3\.5{gap:calc(var(--spacing) * 3.5)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}: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-2\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}:where(.-space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * -2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * -2) * calc(1 - var(--tw-space-x-reverse)))}.self-start{align-self:flex-start}.justify-self-end{justify-self:flex-end}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.75rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[2px\]{border-radius:2px}.rounded-\[24px\]{border-radius:24px}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-xs{border-radius:var(--radius-xs)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-\[1\.5px\]{border-style:var(--tw-border-style);border-width:1.5px}.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-0{border-left-style:var(--tw-border-style)!important;border-left-width:0!important}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-amber-500\/20{border-color:#f99c0033}@supports (color:color-mix(in lab,red,red)){.border-amber-500\/20{border-color:color-mix(in oklab,var(--color-amber-500) 20%,transparent)}}.border-border{border-color:#3a3a3a}.border-emerald-500\/15{border-color:#00bb7f26}@supports (color:color-mix(in lab,red,red)){.border-emerald-500\/15{border-color:color-mix(in oklab,var(--color-emerald-500) 15%,transparent)}}.border-emerald-500\/20{border-color:#00bb7f33}@supports (color:color-mix(in lab,red,red)){.border-emerald-500\/20{border-color:color-mix(in oklab,var(--color-emerald-500) 20%,transparent)}}.border-input{border-color:#3a3a3a}.border-muted-foreground\/30{border-color:#9999994d}.border-primary\/20{border-color:#3c8fff33}.border-primary\/30{border-color:#3c8fff4d}.border-primary\/40{border-color:#3c8fff66}.border-red-500\/15{border-color:#fb2c3626}@supports (color:color-mix(in lab,red,red)){.border-red-500\/15{border-color:color-mix(in oklab,var(--color-red-500) 15%,transparent)}}.border-red-500\/20{border-color:#fb2c3633}@supports (color:color-mix(in lab,red,red)){.border-red-500\/20{border-color:color-mix(in oklab,var(--color-red-500) 20%,transparent)}}.border-slate-800{border-color:var(--color-slate-800)}.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-white\/\[0\.04\]{border-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.04\]{border-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.border-white\/\[0\.06\]{border-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.06\]{border-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.border-white\/\[0\.08\]{border-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.08\]{border-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.border-t-primary{border-top-color:#3c8fff}.border-t-transparent{border-top-color:#0000}.border-l-transparent{border-left-color:#0000}.bg-\[\#222\]{background-color:#222}.bg-\[\#181818\]{background-color:#181818}.bg-accent{background-color:#333}.bg-amber-500\/8{background-color:#f99c0014}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/8{background-color:color-mix(in oklab,var(--color-amber-500) 8%,transparent)}}.bg-amber-500\/15{background-color:#f99c0026}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/15{background-color:color-mix(in oklab,var(--color-amber-500) 15%,transparent)}}.bg-background{background-color:#212121}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab,red,red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black) 40%,transparent)}}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:color-mix(in oklab,var(--color-black) 80%,transparent)}}.bg-black\/85{background-color:#000000d9}@supports (color:color-mix(in lab,red,red)){.bg-black\/85{background-color:color-mix(in oklab,var(--color-black) 85%,transparent)}}.bg-black\/90{background-color:#000000e6}@supports (color:color-mix(in lab,red,red)){.bg-black\/90{background-color:color-mix(in oklab,var(--color-black) 90%,transparent)}}.bg-border{background-color:#3a3a3a}.bg-card{background-color:#2a2a2a}.bg-destructive{background-color:#fd486b}.bg-destructive\/10{background-color:#fd486b1a}.bg-destructive\/15{background-color:#fd486b26}.bg-emerald-500\/8{background-color:#00bb7f14}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/8{background-color:color-mix(in oklab,var(--color-emerald-500) 8%,transparent)}}.bg-emerald-500\/10{background-color:#00bb7f1a}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/10{background-color:color-mix(in oklab,var(--color-emerald-500) 10%,transparent)}}.bg-emerald-500\/15{background-color:#00bb7f26}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/15{background-color:color-mix(in oklab,var(--color-emerald-500) 15%,transparent)}}.bg-foreground{background-color:#f5f5f5}.bg-green-500{background-color:var(--color-green-500)}.bg-muted{background-color:#333}.bg-muted-foreground{background-color:#999}.bg-muted-foreground\/60{background-color:#9999}.bg-popover{background-color:#2a2a2a}.bg-primary{background-color:#3c8fff}.bg-primary\/10{background-color:#3c8fff1a}.bg-primary\/15{background-color:#3c8fff26}.bg-primary\/60{background-color:#3c8fff99}.bg-primary\/\[0\.06\]{background-color:#3c8fff0f}.bg-red-500{background-color:var(--color-red-500)}.bg-red-500\/8{background-color:#fb2c3614}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/8{background-color:color-mix(in oklab,var(--color-red-500) 8%,transparent)}}.bg-red-500\/10{background-color:#fb2c361a}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/10{background-color:color-mix(in oklab,var(--color-red-500) 10%,transparent)}}.bg-secondary{background-color:#333}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/5{background-color:#ffffff0d}@supports (color:color-mix(in lab,red,red)){.bg-white\/5{background-color:color-mix(in oklab,var(--color-white) 5%,transparent)}}.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\/20{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.bg-white\/20{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.bg-white\/70{background-color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.bg-white\/70{background-color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.bg-white\/\[0\.02\]{background-color:#ffffff05}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.02\]{background-color:color-mix(in oklab,var(--color-white) 2%,transparent)}}.bg-white\/\[0\.03\]{background-color:#ffffff08}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.03\]{background-color:color-mix(in oklab,var(--color-white) 3%,transparent)}}.bg-white\/\[0\.04\]{background-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.04\]{background-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.bg-white\/\[0\.05\]{background-color:#ffffff0d}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.05\]{background-color:color-mix(in oklab,var(--color-white) 5%,transparent)}}.bg-white\/\[0\.06\]{background-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.06\]{background-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.bg-white\/\[0\.08\]{background-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.08\]{background-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.fill-current{fill:currentColor}.fill-foreground{fill:#f5f5f5}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.\!p-0{padding:calc(var(--spacing) * 0)!important}.p-0{padding:calc(var(--spacing) * 0)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.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)}.p-\[3px\]{padding:3px}.p-px{padding:1px}.px-0\.5{padding-inline:calc(var(--spacing) * .5)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-3\.5{padding-inline:calc(var(--spacing) * 3.5)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-7{padding-inline:calc(var(--spacing) * 7)}.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-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.pt-2\.5{padding-top:calc(var(--spacing) * 2.5)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pt-8{padding-top:calc(var(--spacing) * 8)}.pr-0\.5{padding-right:calc(var(--spacing) * .5)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pr-8{padding-right:calc(var(--spacing) * 8)}.pr-10{padding-right:calc(var(--spacing) * 10)}.pr-12{padding-right:calc(var(--spacing) * 12)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.pb-8{padding-bottom:calc(var(--spacing) * 8)}.pl-1{padding-left:calc(var(--spacing) * 1)}.pl-2{padding-left:calc(var(--spacing) * 2)}.pl-4{padding-left:calc(var(--spacing) * 4)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.8rem\]{font-size:.8rem}.text-\[8px\]{font-size:8px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.leading-\[1\.1\]{--tw-leading:1.1;line-height:1.1}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.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-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-balance{text-wrap:balance}.break-words{overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.text-amber-400{color:var(--color-amber-400)}.text-amber-400\/60{color:#fcbb0099}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/60{color:color-mix(in oklab,var(--color-amber-400) 60%,transparent)}}.text-amber-400\/70{color:#fcbb00b3}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/70{color:color-mix(in oklab,var(--color-amber-400) 70%,transparent)}}.text-amber-400\/90{color:#fcbb00e6}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/90{color:color-mix(in oklab,var(--color-amber-400) 90%,transparent)}}.text-background{color:#212121}.text-card-foreground{color:#f5f5f5}.text-destructive{color:#fd486b}.text-destructive-foreground{color:#fff}.text-emerald-400{color:var(--color-emerald-400)}.text-emerald-400\/60{color:#00d29499}@supports (color:color-mix(in lab,red,red)){.text-emerald-400\/60{color:color-mix(in oklab,var(--color-emerald-400) 60%,transparent)}}.text-emerald-400\/90{color:#00d294e6}@supports (color:color-mix(in lab,red,red)){.text-emerald-400\/90{color:color-mix(in oklab,var(--color-emerald-400) 90%,transparent)}}.text-foreground{color:#f5f5f5}.text-foreground\/60{color:#f5f5f599}.text-foreground\/80{color:#f5f5f5cc}.text-gray-400{color:var(--color-gray-400)}.text-gray-900{color:var(--color-gray-900)}.text-muted-foreground{color:#999}.text-muted-foreground\/50{color:#99999980}.text-popover-foreground{color:#f5f5f5}.text-primary{color:#3c8fff}.text-primary-foreground{color:#fff}.text-primary-foreground\/60{color:#fff9}.text-primary\/60{color:#3c8fff99}.text-red-400{color:var(--color-red-400)}.text-red-400\/70{color:#ff6568b3}@supports (color:color-mix(in lab,red,red)){.text-red-400\/70{color:color-mix(in oklab,var(--color-red-400) 70%,transparent)}}.text-red-400\/90{color:#ff6568e6}@supports (color:color-mix(in lab,red,red)){.text-red-400\/90{color:color-mix(in oklab,var(--color-red-400) 90%,transparent)}}.text-secondary-foreground{color:#f5f5f5}.text-slate-500{color:var(--color-slate-500)}.text-white{color:var(--color-white)}.text-white\/20{color:#fff3}@supports (color:color-mix(in lab,red,red)){.text-white\/20{color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.text-white\/25{color:#ffffff40}@supports (color:color-mix(in lab,red,red)){.text-white\/25{color:color-mix(in oklab,var(--color-white) 25%,transparent)}}.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\/35{color:#ffffff59}@supports (color:color-mix(in lab,red,red)){.text-white\/35{color:color-mix(in oklab,var(--color-white) 35%,transparent)}}.text-white\/40{color:#fff6}@supports (color:color-mix(in lab,red,red)){.text-white\/40{color:color-mix(in oklab,var(--color-white) 40%,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\/60{color:#fff9}@supports (color:color-mix(in lab,red,red)){.text-white\/60{color:color-mix(in oklab,var(--color-white) 60%,transparent)}}.text-white\/70{color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.text-white\/70{color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.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,)}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-100{opacity:1}.opacity-\[0\.06\]{opacity:.06}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-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)}.shadow-xs{--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-0{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(0px + 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)}.ring-background{--tw-ring-color:#212121}.ring-offset-background{--tw-ring-offset-color:#212121}.outline-hidden{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.outline-hidden{outline-offset:2px;outline:2px solid #0000}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.drop-shadow-lg{--tw-drop-shadow-size:drop-shadow(0 4px 4px var(--tw-drop-shadow-color,#00000026));--tw-drop-shadow:drop-shadow(var(--drop-shadow-lg));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-md{--tw-backdrop-blur:blur(var(--blur-md));-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-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[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-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.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)}.will-change-transform{will-change:transform}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media(hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.group-has-data-\[size\=lg\]\/avatar-group\:size-10:is(:where(.group\/avatar-group):has([data-size=lg]) *){width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.group-has-data-\[size\=sm\]\/avatar-group\:size-6:is(:where(.group\/avatar-group):has([data-size=sm]) *){width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.group-data-\[orientation\=horizontal\]\/tabs\:h-9:is(:where(.group\/tabs)[data-orientation=horizontal] *){height:calc(var(--spacing) * 9)}.group-data-\[orientation\=vertical\]\/tabs\:h-fit:is(:where(.group\/tabs)[data-orientation=vertical] *){height:fit-content}.group-data-\[orientation\=vertical\]\/tabs\:w-full:is(:where(.group\/tabs)[data-orientation=vertical] *){width:100%}.group-data-\[orientation\=vertical\]\/tabs\:flex-col:is(:where(.group\/tabs)[data-orientation=vertical] *){flex-direction:column}.group-data-\[orientation\=vertical\]\/tabs\:justify-start:is(:where(.group\/tabs)[data-orientation=vertical] *){justify-content:flex-start}.group-data-\[size\=default\]\/avatar\:size-2\.5:is(:where(.group\/avatar)[data-size=default] *){width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.group-data-\[size\=default\]\/switch\:size-4:is(:where(.group\/switch)[data-size=default] *){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.group-data-\[size\=lg\]\/avatar\:size-3:is(:where(.group\/avatar)[data-size=lg] *){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.group-data-\[size\=sm\]\/avatar\:size-2:is(:where(.group\/avatar)[data-size=sm] *){width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.group-data-\[size\=sm\]\/avatar\:text-xs:is(:where(.group\/avatar)[data-size=sm] *){font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.group-data-\[size\=sm\]\/switch\:size-3:is(:where(.group\/switch)[data-size=sm] *){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.group-data-\[variant\=line\]\/tabs-list\:bg-transparent:is(:where(.group\/tabs-list)[data-variant=line] *){background-color:#0000}.selection\:bg-primary ::selection{background-color:#3c8fff}.selection\:bg-primary::selection{background-color:#3c8fff}.selection\:text-primary-foreground ::selection{color:#fff}.selection\:text-primary-foreground::selection{color:#fff}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:calc(var(--spacing) * 7)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:#f5f5f5}.placeholder\:text-gray-400::placeholder{color:var(--color-gray-400)}.placeholder\:text-muted-foreground::placeholder{color:#999}.placeholder\:text-white\/20::placeholder{color:#fff3}@supports (color:color-mix(in lab,red,red)){.placeholder\:text-white\/20::placeholder{color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:bg-foreground:after{content:var(--tw-content);background-color:#f5f5f5}.after\:opacity-0:after{content:var(--tw-content);opacity:0}.after\:transition-opacity:after{content:var(--tw-content);transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.group-data-\[orientation\=horizontal\]\/tabs\:after\:inset-x-0:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);inset-inline:calc(var(--spacing) * 0)}.group-data-\[orientation\=horizontal\]\/tabs\:after\:bottom-\[-5px\]:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);bottom:-5px}.group-data-\[orientation\=horizontal\]\/tabs\:after\:h-0\.5:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);height:calc(var(--spacing) * .5)}.group-data-\[orientation\=vertical\]\/tabs\:after\:inset-y-0:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);inset-block:calc(var(--spacing) * 0)}.group-data-\[orientation\=vertical\]\/tabs\:after\:-right-1:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);right:calc(var(--spacing) * -1)}.group-data-\[orientation\=vertical\]\/tabs\:after\:w-0\.5:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);width:calc(var(--spacing) * .5)}@media(hover:hover){.hover\:border-white\/10:hover{border-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:border-white\/10:hover{border-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.hover\:border-white\/15:hover{border-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.hover\:border-white\/15:hover{border-color:color-mix(in oklab,var(--color-white) 15%,transparent)}}.hover\:bg-accent:hover{background-color:#333}.hover\:bg-destructive\/90:hover{background-color:#fd486be6}.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:bg-primary\/90:hover{background-color:#3c8fffe6}.hover\:bg-secondary\/80:hover{background-color:#333c}.hover\:bg-white\/20:hover{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/20:hover{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.hover\:bg-white\/30:hover{background-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/30:hover{background-color:color-mix(in oklab,var(--color-white) 30%,transparent)}}.hover\:bg-white\/\[0\.1\]:hover{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.1\]:hover{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.hover\:bg-white\/\[0\.02\]:hover{background-color:#ffffff05}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.02\]:hover{background-color:color-mix(in oklab,var(--color-white) 2%,transparent)}}.hover\:bg-white\/\[0\.04\]:hover{background-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.04\]:hover{background-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.hover\:bg-white\/\[0\.06\]:hover{background-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.06\]:hover{background-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.hover\:bg-white\/\[0\.08\]:hover{background-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.08\]:hover{background-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.hover\:bg-white\/\[0\.09\]:hover{background-color:#ffffff17}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.09\]:hover{background-color:color-mix(in oklab,var(--color-white) 9%,transparent)}}.hover\:text-accent-foreground:hover,.hover\:text-foreground:hover{color:#f5f5f5}.hover\:text-gray-600:hover{color:var(--color-gray-600)}.hover\:text-white:hover{color:var(--color-white)}.hover\:text-white\/40:hover{color:#fff6}@supports (color:color-mix(in lab,red,red)){.hover\:text-white\/40:hover{color:color-mix(in oklab,var(--color-white) 40%,transparent)}}.hover\:text-white\/50:hover{color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.hover\:text-white\/50:hover{color:color-mix(in oklab,var(--color-white) 50%,transparent)}}.hover\:text-white\/60:hover{color:#fff9}@supports (color:color-mix(in lab,red,red)){.hover\:text-white\/60:hover{color:color-mix(in oklab,var(--color-white) 60%,transparent)}}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-80:hover{opacity:.8}.hover\:opacity-100:hover{opacity:1}.hover\:brightness-110:hover{--tw-brightness:brightness(110%);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,)}}.focus\:border-primary\/30:focus{border-color:#3c8fff4d}.focus\:border-primary\/40:focus{border-color:#3c8fff66}.focus\:bg-accent:focus{background-color:#333}.focus\:text-accent-foreground:focus{color:#f5f5f5}.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-ring:focus{--tw-ring-color:#3c8fff}.focus\:ring-offset-2:focus{--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\:outline-hidden:focus{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.focus\:outline-hidden:focus{outline-offset:2px;outline:2px solid #0000}}.focus-visible\:border-ring:focus-visible{border-color:#3c8fff}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:oklab(67.0267% .20922 .0534847/.2)}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:oklab(65.65% -.0412982 -.180011/.5)}.focus-visible\:outline-1:focus-visible{outline-style:var(--tw-outline-style);outline-width:1px}.focus-visible\:outline-ring:focus-visible{outline-color:#3c8fff}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}.has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\]:has([data-slot=card-action]){grid-template-columns:1fr auto}.has-\[\>svg\]\:px-1\.5:has(>svg){padding-inline:calc(var(--spacing) * 1.5)}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing) * 2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing) * 3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing) * 4)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:#fd486b}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:oklab(67.0267% .20922 .0534847/.2)}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[inset\]\:pl-8[data-inset]{padding-left:calc(var(--spacing) * 8)}.data-\[orientation\=horizontal\]\:h-px[data-orientation=horizontal]{height:1px}.data-\[orientation\=horizontal\]\:w-full[data-orientation=horizontal]{width:100%}.data-\[orientation\=horizontal\]\:flex-col[data-orientation=horizontal]{flex-direction:column}.data-\[orientation\=vertical\]\:h-full[data-orientation=vertical]{height:100%}.data-\[orientation\=vertical\]\:w-px[data-orientation=vertical]{width:1px}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:#999}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[size\=default\]\:h-9[data-size=default]{height:calc(var(--spacing) * 9)}.data-\[size\=default\]\:h-\[1\.15rem\][data-size=default]{height:1.15rem}.data-\[size\=default\]\:w-8[data-size=default]{width:calc(var(--spacing) * 8)}.data-\[size\=lg\]\:size-10[data-size=lg]{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.data-\[size\=sm\]\:size-6[data-size=sm]{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.data-\[size\=sm\]\:h-3\.5[data-size=sm]{height:calc(var(--spacing) * 3.5)}.data-\[size\=sm\]\:h-8[data-size=sm]{height:calc(var(--spacing) * 8)}.data-\[size\=sm\]\:w-6[data-size=sm]{width:calc(var(--spacing) * 6)}:is(.\*\:data-\[slot\=avatar\]\:ring-2>*)[data-slot=avatar]{--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)}:is(.\*\:data-\[slot\=avatar\]\:ring-background>*)[data-slot=avatar]{--tw-ring-color:#212121}:is(.\*\:data-\[slot\=select-value\]\:line-clamp-1>*)[data-slot=select-value]{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}:is(.\*\:data-\[slot\=select-value\]\:flex>*)[data-slot=select-value]{display:flex}:is(.\*\:data-\[slot\=select-value\]\:items-center>*)[data-slot=select-value]{align-items:center}:is(.\*\:data-\[slot\=select-value\]\:gap-2>*)[data-slot=select-value]{gap:calc(var(--spacing) * 2)}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:#212121}.data-\[state\=active\]\:bg-primary[data-state=active]{background-color:#3c8fff}.data-\[state\=active\]\:text-foreground[data-state=active]{color:#f5f5f5}.data-\[state\=active\]\:text-primary-foreground[data-state=active]{color:#fff}.data-\[state\=active\]\:shadow-none[data-state=active]{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=default\]\/tabs-list\:data-\[state\=active\]\:shadow-sm:is(:where(.group\/tabs-list)[data-variant=default] *)[data-state=active]{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:bg-transparent:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{background-color:#0000}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:shadow-none:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:after\:opacity-100:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]:after{content:var(--tw-content);opacity:1}.data-\[state\=checked\]\:translate-x-\[calc\(100\%-2px\)\][data-state=checked]{--tw-translate-x: calc(100% - 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:#3c8fff}.data-\[state\=closed\]\:duration-300[data-state=closed]{--tw-duration:.3s;transition-duration:.3s}.data-\[state\=open\]\:bg-accent[data-state=open],.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:#333}.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:#f5f5f5}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:#999}.data-\[state\=open\]\:duration-500[data-state=open]{--tw-duration:.5s;transition-duration:.5s}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:#3a3a3a}.data-\[variant\=destructive\]\:text-destructive[data-variant=destructive]{color:#fd486b}.data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant=destructive]:focus{background-color:#fd486b1a}.data-\[variant\=destructive\]\:focus\:text-destructive[data-variant=destructive]:focus{color:#fd486b}.data-\[variant\=line\]\:rounded-none[data-variant=line]{border-radius:0}@media(min-width:40rem){.sm\:mt-4{margin-top:calc(var(--spacing) * 4)}.sm\:mb-6{margin-bottom:calc(var(--spacing) * 6)}.sm\:block{display:block}.sm\:h-2\.5{height:calc(var(--spacing) * 2.5)}.sm\:w-2\.5{width:calc(var(--spacing) * 2.5)}.sm\:w-16{width:calc(var(--spacing) * 16)}.sm\:max-w-lg{max-width:var(--container-lg)}.sm\:max-w-md{max-width:var(--container-md)}.sm\:max-w-sm{max-width:var(--container-sm)}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:items-start{align-items:flex-start}.sm\:justify-between{justify-content:space-between}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2{gap:calc(var(--spacing) * 2)}.sm\:gap-3{gap:calc(var(--spacing) * 3)}.sm\:gap-4{gap:calc(var(--spacing) * 4)}:where(.sm\: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(.sm\:space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}.sm\:p-6{padding:calc(var(--spacing) * 6)}.sm\:px-4{padding-inline:calc(var(--spacing) * 4)}.sm\:py-2{padding-block:calc(var(--spacing) * 2)}.sm\:text-left{text-align:left}.sm\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.sm\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.sm\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.sm\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.sm\:text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}}@media(min-width:48rem){.md\:block{display:block}.md\:flex{display:flex}.md\:hidden{display:none}.md\:p-6{padding:calc(var(--spacing) * 6)}.md\:px-6{padding-inline:calc(var(--spacing) * 6)}.md\:py-4{padding-block:calc(var(--spacing) * 4)}.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}@media(min-width:64rem){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.dark\:border-input:is(.dark *){border-color:#3a3a3a}.dark\:bg-destructive\/60:is(.dark *){background-color:#fd486b99}.dark\:bg-input\/30:is(.dark *){background-color:#3a3a3a4d}.dark\:text-muted-foreground:is(.dark *){color:#999}@media(hover:hover){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:#33333380}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:#3a3a3a80}.dark\:hover\:text-foreground:is(.dark *):hover{color:#f5f5f5}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible,.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:oklab(67.0267% .20922 .0534847/.4)}.dark\:data-\[state\=active\]\:border-input:is(.dark *)[data-state=active]{border-color:#3a3a3a}.dark\:data-\[state\=active\]\:bg-input\/30:is(.dark *)[data-state=active]{background-color:#3a3a3a4d}.dark\:data-\[state\=active\]\:text-foreground:is(.dark *)[data-state=active]{color:#f5f5f5}.dark\:group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:border-transparent:is(.dark *):is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{border-color:#0000}.dark\:group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:bg-transparent:is(.dark *):is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{background-color:#0000}.dark\:data-\[state\=checked\]\:bg-primary-foreground:is(.dark *)[data-state=checked]{background-color:#fff}.dark\:data-\[state\=unchecked\]\:bg-foreground:is(.dark *)[data-state=unchecked]{background-color:#f5f5f5}.dark\:data-\[state\=unchecked\]\:bg-input\/80:is(.dark *)[data-state=unchecked]{background-color:#3a3a3acc}.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:is(.dark *)[data-variant=destructive]:focus{background-color:#fd486b33}.\[\&_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-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground svg:not([class*=text-]){color:#999}.\[\.border-b\]\:pb-6.border-b{padding-bottom:calc(var(--spacing) * 6)}.\[\.border-t\]\:pt-6.border-t{padding-top:calc(var(--spacing) * 6)}:is(.\*\:\[span\]\:last\:flex>*):is(span):last-child{display:flex}:is(.\*\:\[span\]\:last\:items-center>*):is(span):last-child{align-items:center}:is(.\*\:\[span\]\:last\:gap-2>*):is(span):last-child{gap:calc(var(--spacing) * 2)}:is(.data-\[variant\=destructive\]\:\*\:\[svg\]\:\!text-destructive[data-variant=destructive]>*):is(svg){color:#fd486b!important}.\[\&\>\*\:first-child\]\:mt-0>:first-child{margin-top:calc(var(--spacing) * 0)}.\[\&\>\*\:last-child\]\:mb-0>:last-child{margin-bottom:calc(var(--spacing) * 0)}.\[\&\>svg\]\:pointer-events-none>svg{pointer-events:none}.\[\&\>svg\]\:size-3>svg{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&\>svg\]\:size-4>svg{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.group-has-data-\[size\=lg\]\/avatar-group\:\[\&\>svg\]\:size-5:is(:where(.group\/avatar-group):has([data-size=lg]) *)>svg{width:calc(var(--spacing) * 5);height:calc(var(--spacing) * 5)}.group-has-data-\[size\=sm\]\/avatar-group\:\[\&\>svg\]\:size-3:is(:where(.group\/avatar-group):has([data-size=sm]) *)>svg{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.group-data-\[size\=default\]\/avatar\:\[\&\>svg\]\:size-2:is(:where(.group\/avatar)[data-size=default] *)>svg,.group-data-\[size\=lg\]\/avatar\:\[\&\>svg\]\:size-2:is(:where(.group\/avatar)[data-size=lg] *)>svg{width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.group-data-\[size\=sm\]\/avatar\:\[\&\>svg\]\:hidden:is(:where(.group\/avatar)[data-size=sm] *)>svg{display:none}@media(hover:hover){a.\[a\&\]\:hover\:bg-accent:hover{background-color:#333}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:#fd486be6}a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:#3c8fffe6}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:#333333e6}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:#f5f5f5}a.\[a\&\]\:hover\:underline:hover{text-decoration-line:underline}}}body{background-color:var(--color-background);color:var(--color-foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background-color:#3c8fff40}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4a4a4a}@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-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-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-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}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes spin{to{transform:rotate(360deg)}}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}@keyframes pulse{50%{opacity:.5}}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}
|