@chenpu17/cc-gw 0.8.13 → 0.8.14
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/package.json +5 -5
- package/src/web/dist/assets/{About-BtrUwqVl.js → About-pcECYYVj.js} +1 -1
- package/src/web/dist/assets/{ApiKeys-BgtU9Z5t.js → ApiKeys-IDt4ZfLj.js} +1 -1
- package/src/web/dist/assets/{ConfirmDialog-BHrsB4gR.js → ConfirmDialog-oYHVEpGJ.js} +1 -1
- package/src/web/dist/assets/{Dashboard-DIguazuF.js → Dashboard-BiCTswfM.js} +1 -1
- package/src/web/dist/assets/{DialogShell-DcG-SXEV.js → DialogShell-DcOGCV8m.js} +1 -1
- package/src/web/dist/assets/{Events-mZNIWc7c.js → Events-CCYCOF1f.js} +1 -1
- package/src/web/dist/assets/{Help-BHbnZJeo.js → Help-BW1R1cf1.js} +2 -2
- package/src/web/dist/assets/{Login-DugtPFxy.js → Login-Dn8fbfFq.js} +1 -1
- package/src/web/dist/assets/{Logs-BJBm-efJ.js → Logs-D2FFPpBP.js} +1 -1
- package/src/web/dist/assets/{ModelManagement-C32W7nDe.js → ModelManagement-BHSUJ4Dg.js} +1 -1
- package/src/web/dist/assets/{PageHeader--Lg_YQVw.js → PageHeader-DCqHI67a.js} +1 -1
- package/src/web/dist/assets/{PageSection-DIAhP18t.js → PageSection-CuZMzA0E.js} +1 -1
- package/src/web/dist/assets/{PageState-DKba6Ew1.js → PageState-B03H5AV0.js} +1 -1
- package/src/web/dist/assets/{Profiler-DTPqRwx7.js → Profiler-CEpu2dMu.js} +1 -1
- package/src/web/dist/assets/{RoutingManagement-B9Z0l4LZ.js → RoutingManagement-DahJxjA7.js} +1 -1
- package/src/web/dist/assets/{Settings-Ddx0C5eQ.js → Settings-Vp7jGxIW.js} +1 -1
- package/src/web/dist/assets/{Skeleton-cyuMRxwQ.js → Skeleton-i1PjWApN.js} +1 -1
- package/src/web/dist/assets/{app-BG16DmZH.js → app-COiQeF3y.js} +3 -3
- package/src/web/dist/assets/{card-CwTuH2Iq.js → card-ChFVaqLf.js} +1 -1
- package/src/web/dist/assets/{charts-core-D9OugzV_.js → charts-core-DzWzxST6.js} +1 -1
- package/src/web/dist/assets/{charts-engine-DleyglMn.js → charts-engine-Ds7lwC51.js} +1 -1
- package/src/web/dist/assets/{charts-react-BqhUp1x_.js → charts-react-D0nWbUCA.js} +1 -1
- package/src/web/dist/assets/{gateway-CExOTXeI.js → gateway-BU3dR2tm.js} +1 -1
- package/src/web/dist/assets/{global-CKvMKvrn.js → global-B-NXh5qD.js} +1 -1
- package/src/web/dist/assets/global-B_hBylxt.css +1 -0
- package/src/web/dist/assets/{i18n-B3N4Df3E.js → i18n-Bl2BcCDG.js} +1 -1
- package/src/web/dist/assets/{input-scp9nKJc.js → input-DW7jGTgj.js} +1 -1
- package/src/web/dist/assets/{label-fMXEnAEx.js → label-Ci1io7XA.js} +1 -1
- package/src/web/dist/assets/landing-BMe5-cHU.js +17 -0
- package/src/web/dist/assets/live-en-api-keys-Bx8N-eoh.png +0 -0
- package/src/web/dist/assets/live-en-dashboard-CJoX7IQT.png +0 -0
- package/src/web/dist/assets/live-en-events-DJwaP-WW.png +0 -0
- package/src/web/dist/assets/live-en-logs-BGGL53ab.png +0 -0
- package/src/web/dist/assets/live-en-model-management-BpjNblfR.png +0 -0
- package/src/web/dist/assets/package-D5lk1iqk.js +1 -0
- package/src/web/dist/assets/{popover-BGSWKBlu.js → popover-CQHCVE2z.js} +1 -1
- package/src/web/dist/assets/{query-Cpxr1dul.js → query-BbGWgOFk.js} +1 -1
- package/src/web/dist/assets/{queryKeys-DTnZc8Yy.js → queryKeys-ucXCzh0P.js} +1 -1
- package/src/web/dist/assets/{radix-bG5h1Ymq.js → radix-mHySgtou.js} +1 -1
- package/src/web/dist/assets/{router-DspBTS8b.js → router-CL3rf_uf.js} +1 -1
- package/src/web/dist/assets/{select-BjYpeVvo.js → select-BchX45jJ.js} +1 -1
- package/src/web/dist/assets/{switch-CgwYcn5P.js → switch-CT24uL_Q.js} +1 -1
- package/src/web/dist/assets/{table-BtnjYcvG.js → table-DdvG93mx.js} +1 -1
- package/src/web/dist/assets/{useApiQuery-jSeDDFuv.js → useApiQuery-tbd4JJaZ.js} +1 -1
- package/src/web/dist/assets/{useAppMutation-ChCrgiP6.js → useAppMutation-SONU2xFC.js} +1 -1
- package/src/web/dist/assets/useModelManagementState-DcQ0Ac-x.js +1 -0
- package/src/web/dist/assets/{vendor-LWJeAdU1.js → vendor-z22RpOY0.js} +86 -66
- package/src/web/dist/index.html +8 -8
- package/src/web/dist/landing.html +11 -11
- package/src/web/dist/assets/global-CUpRxoFd.css +0 -1
- package/src/web/dist/assets/landing-CHY6qfgq.js +0 -5
- package/src/web/dist/assets/package-BMIMFcQR.js +0 -1
- package/src/web/dist/assets/useModelManagementState-9RhvWh8Y.js +0 -1
package/src/web/dist/index.html
CHANGED
|
@@ -8,14 +8,14 @@
|
|
|
8
8
|
<link rel="apple-touch-icon" href="/cc-gw-mark.svg" />
|
|
9
9
|
<link rel="manifest" href="/site.webmanifest" />
|
|
10
10
|
<title>cc-gw 控制台</title>
|
|
11
|
-
<script type="module" crossorigin src="/assets/app-
|
|
12
|
-
<link rel="modulepreload" crossorigin href="/assets/vendor-
|
|
13
|
-
<link rel="modulepreload" crossorigin href="/assets/global-
|
|
14
|
-
<link rel="modulepreload" crossorigin href="/assets/query-
|
|
15
|
-
<link rel="modulepreload" crossorigin href="/assets/i18n-
|
|
16
|
-
<link rel="modulepreload" crossorigin href="/assets/router-
|
|
17
|
-
<link rel="modulepreload" crossorigin href="/assets/radix-
|
|
18
|
-
<link rel="stylesheet" crossorigin href="/assets/global-
|
|
11
|
+
<script type="module" crossorigin src="/assets/app-COiQeF3y.js"></script>
|
|
12
|
+
<link rel="modulepreload" crossorigin href="/assets/vendor-z22RpOY0.js">
|
|
13
|
+
<link rel="modulepreload" crossorigin href="/assets/global-B-NXh5qD.js">
|
|
14
|
+
<link rel="modulepreload" crossorigin href="/assets/query-BbGWgOFk.js">
|
|
15
|
+
<link rel="modulepreload" crossorigin href="/assets/i18n-Bl2BcCDG.js">
|
|
16
|
+
<link rel="modulepreload" crossorigin href="/assets/router-CL3rf_uf.js">
|
|
17
|
+
<link rel="modulepreload" crossorigin href="/assets/radix-mHySgtou.js">
|
|
18
|
+
<link rel="stylesheet" crossorigin href="/assets/global-B_hBylxt.css">
|
|
19
19
|
</head>
|
|
20
20
|
<body class="bg-slate-50 text-slate-900 dark:bg-slate-900 dark:text-slate-50">
|
|
21
21
|
<div id="root"></div>
|
|
@@ -8,25 +8,25 @@
|
|
|
8
8
|
<meta name="apple-mobile-web-app-title" content="cc-gw" />
|
|
9
9
|
<meta
|
|
10
10
|
name="description"
|
|
11
|
-
content="cc-gw
|
|
11
|
+
content="cc-gw is a local-first AI gateway. 把 Claude Code、OpenAI SDK、Anthropic SDK 全部指向同一个本地入口,换模型、换 provider、查日志,再也不用翻业务代码。"
|
|
12
12
|
/>
|
|
13
13
|
<meta name="theme-color" content="#0f172a" />
|
|
14
14
|
<link rel="icon" type="image/svg+xml" href="/cc-gw-mark.svg" />
|
|
15
15
|
<link rel="apple-touch-icon" href="/cc-gw-mark.svg" />
|
|
16
16
|
<link rel="manifest" href="/site.webmanifest" />
|
|
17
|
-
<meta property="og:title" content="cc-gw |
|
|
17
|
+
<meta property="og:title" content="cc-gw | 你的 API Key 不该躺在 30 个 .env 里" />
|
|
18
18
|
<meta
|
|
19
19
|
property="og:description"
|
|
20
|
-
content="
|
|
20
|
+
content="A local-first AI gateway. One endpoint for Claude Code, OpenAI SDK, and Anthropic SDK. Switch models, swap providers, and trace requests without touching your code."
|
|
21
21
|
/>
|
|
22
22
|
<meta property="og:type" content="website" />
|
|
23
23
|
<meta property="og:image" content="/cc-gw-social-card.png" />
|
|
24
24
|
<meta property="og:image:alt" content="cc-gw landing share card showing a local-first AI gateway and daily control console" />
|
|
25
25
|
<meta name="twitter:card" content="summary_large_image" />
|
|
26
|
-
<meta name="twitter:title" content="cc-gw |
|
|
26
|
+
<meta name="twitter:title" content="cc-gw | 你的 API Key 不该躺在 30 个 .env 里" />
|
|
27
27
|
<meta
|
|
28
28
|
name="twitter:description"
|
|
29
|
-
content="
|
|
29
|
+
content="A local-first AI gateway. One endpoint for Claude Code, OpenAI SDK, and Anthropic SDK. Switch models, swap providers, and trace requests without touching your code."
|
|
30
30
|
/>
|
|
31
31
|
<meta name="twitter:image" content="/cc-gw-social-card.png" />
|
|
32
32
|
<meta name="twitter:image:alt" content="cc-gw landing share card showing a local-first AI gateway and daily control console" />
|
|
@@ -41,13 +41,13 @@
|
|
|
41
41
|
"description": "Local-first AI gateway for personal developers and small teams who want to centralize provider configuration, routing, logs, profiler, and API key management."
|
|
42
42
|
}
|
|
43
43
|
</script>
|
|
44
|
-
<title>cc-gw |
|
|
45
|
-
<script type="module" crossorigin src="/assets/landing-
|
|
46
|
-
<link rel="modulepreload" crossorigin href="/assets/vendor-
|
|
47
|
-
<link rel="modulepreload" crossorigin href="/assets/global-
|
|
44
|
+
<title>cc-gw | 你的 API Key 不该躺在 30 个 .env 里 · local-first AI gateway</title>
|
|
45
|
+
<script type="module" crossorigin src="/assets/landing-BMe5-cHU.js"></script>
|
|
46
|
+
<link rel="modulepreload" crossorigin href="/assets/vendor-z22RpOY0.js">
|
|
47
|
+
<link rel="modulepreload" crossorigin href="/assets/global-B-NXh5qD.js">
|
|
48
48
|
<link rel="modulepreload" crossorigin href="/assets/clipboard-CALi6bTW.js">
|
|
49
|
-
<link rel="modulepreload" crossorigin href="/assets/package-
|
|
50
|
-
<link rel="stylesheet" crossorigin href="/assets/global-
|
|
49
|
+
<link rel="modulepreload" crossorigin href="/assets/package-D5lk1iqk.js">
|
|
50
|
+
<link rel="stylesheet" crossorigin href="/assets/global-B_hBylxt.css">
|
|
51
51
|
</head>
|
|
52
52
|
<body class="bg-slate-50 text-slate-900">
|
|
53
53
|
<div id="landing-root"></div>
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,SF Pro Display,ui-sans-serif,system-ui,-apple-system,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:Inter,SF Mono,IBM Plex Mono,JetBrains Mono,ui-monospace,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 220 14% 96%;--foreground: 224 71% 4%;--card: 0 0% 100%;--card-foreground: 224 71% 4%;--popover: 0 0% 100%;--popover-foreground: 224 71% 4%;--primary: 234 89% 54%;--primary-foreground: 0 0% 100%;--secondary: 220 13% 95%;--secondary-foreground: 224 71% 4%;--muted: 220 13% 91%;--muted-foreground: 220 9% 46%;--accent: 220 13% 95%;--accent-foreground: 234 89% 54%;--destructive: 0 84% 60%;--destructive-foreground: 0 0% 100%;--border: 220 13% 91%;--input: 220 13% 91%;--ring: 234 89% 54%;--radius: .5rem;--success: 152 69% 31%;--success-bg: 152 68% 96%;--warning: 38 92% 50%;--warning-bg: 48 96% 96%;--error: 0 84% 60%;--error-bg: 0 86% 97%;--info: 234 89% 54%;--info-bg: 234 85% 97%;--chart-1: 234 89% 54%;--chart-2: 152 69% 31%;--chart-3: 38 92% 50%;--chart-4: 0 84% 60%;--chart-5: 280 67% 51%;--surface-shadow: 0 1px 3px rgba(0, 0, 0, .02), 0 4px 12px rgba(0, 0, 0, .04);--surface-shadow-lg: 0 2px 6px rgba(0, 0, 0, .03), 0 8px 24px rgba(0, 0, 0, .06);--surface-border: rgba(0, 0, 0, .06)}.dark,[data-theme=dark]{--background: 224 71% 4%;--foreground: 210 20% 98%;--card: 224 48% 8%;--card-foreground: 210 20% 98%;--popover: 224 48% 8%;--popover-foreground: 210 20% 98%;--primary: 234 89% 74%;--primary-foreground: 224 71% 4%;--secondary: 215 28% 14%;--secondary-foreground: 210 20% 98%;--muted: 215 28% 17%;--muted-foreground: 218 11% 58%;--accent: 215 28% 17%;--accent-foreground: 234 89% 74%;--destructive: 0 72% 65%;--destructive-foreground: 0 0% 100%;--border: 215 28% 17%;--input: 215 28% 17%;--ring: 234 89% 74%;--chart-1: 234 89% 74%;--chart-2: 152 60% 50%;--chart-3: 38 92% 60%;--chart-4: 0 72% 65%;--chart-5: 280 67% 65%;--surface-shadow: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--surface-shadow-lg: 0 4px 12px rgba(0, 0, 0, .4), 0 1px 3px rgba(0, 0, 0, .2);--surface-border: rgba(255, 255, 255, .08)}*{border-color:hsl(var(--border))}html,body,#root{height:100%;width:100%;overflow-x:hidden}body{background-color:hsl(var(--background));color:hsl(var(--foreground));font-family:Inter,SF Pro Display,PingFang SC,Noto Sans SC,system-ui,-apple-system,sans-serif;font-feature-settings:"rlig" 1,"calt" 1,"cv11" 1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.inset-x-6{left:1.5rem;right:1.5rem}.inset-y-0{top:0;bottom:0}.-right-1{right:-.25rem}.-top-1{top:-.25rem}.bottom-4{bottom:1rem}.left-0{left:0}.left-2{left:.5rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-3{right:.75rem}.right-4{right:1rem}.right-6{right:1.5rem}.top-0{top:0}.top-20{top:5rem}.top-3{top:.75rem}.top-4{top:1rem}.top-6{top:1.5rem}.top-\[-3px\]{top:-3px}.top-\[-6px\]{top:-6px}.top-\[50\%\]{top:50%}.top-full{top:100%}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-\[100\]{z-index:100}.m-4{margin:1rem}.m-5{margin:1.25rem}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-2\.5{margin-bottom:.625rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.ml-3{margin-left:.75rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-1\.5{margin-right:.375rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-2\.5{margin-top:.625rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-7{margin-top:1.75rem}.mt-8{margin-top:2rem}.line-clamp-1{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-20{height:5rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-36{height:9rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[280px\]{height:280px}.h-\[320px\]{height:320px}.h-\[40vh\]{height:40vh}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-40{max-height:10rem}.max-h-56{max-height:14rem}.max-h-60{max-height:15rem}.max-h-64{max-height:16rem}.max-h-72{max-height:18rem}.max-h-80{max-height:20rem}.max-h-96{max-height:24rem}.max-h-\[240px\]{max-height:240px}.max-h-\[340px\]{max-height:340px}.max-h-\[420px\]{max-height:420px}.max-h-\[78vh\]{max-height:78vh}.max-h-\[85vh\]{max-height:85vh}.max-h-screen{max-height:100vh}.min-h-0{min-height:0px}.min-h-10{min-height:2.5rem}.min-h-\[116px\]{min-height:116px}.min-h-\[120px\]{min-height:120px}.min-h-\[160px\]{min-height:160px}.min-h-\[180px\]{min-height:180px}.min-h-\[188px\]{min-height:188px}.min-h-\[200px\]{min-height:200px}.min-h-\[220px\]{min-height:220px}.min-h-\[240px\]{min-height:240px}.min-h-\[260px\]{min-height:260px}.min-h-\[280px\]{min-height:280px}.min-h-\[320px\]{min-height:320px}.min-h-\[76px\]{min-height:76px}.min-h-\[80px\]{min-height:80px}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-20{width:5rem}.w-24{width:6rem}.w-28{width:7rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-80{width:20rem}.w-9{width:2.25rem}.w-\[132px\]{width:132px}.w-\[190px\]{width:190px}.w-\[1px\]{width:1px}.w-\[220px\]{width:220px}.w-\[3px\]{width:3px}.w-\[80px\]{width:80px}.w-\[min\(96vw\,1200px\)\]{width:min(96vw,1200px)}.w-\[var\(--radix-popover-trigger-width\)\]{width:var(--radix-popover-trigger-width)}.w-full{width:100%}.w-max{width:-moz-max-content;width:max-content}.min-w-0{min-width:0px}.min-w-10{min-width:2.5rem}.min-w-14{min-width:3.5rem}.min-w-5{min-width:1.25rem}.min-w-\[1480px\]{min-width:1480px}.min-w-\[8rem\]{min-width:8rem}.min-w-\[980px\]{min-width:980px}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.min-w-full{min-width:100%}.min-w-max{min-width:-moz-max-content;min-width:max-content}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-\[100px\]{max-width:100px}.max-w-\[1200px\]{max-width:1200px}.max-w-\[120px\]{max-width:120px}.max-w-\[130px\]{max-width:130px}.max-w-\[180px\]{max-width:180px}.max-w-\[220px\]{max-width:220px}.max-w-\[90px\]{max-width:90px}.max-w-full{max-width:100%}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-xl{max-width:36rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.flex-none{flex:none}.flex-shrink-0,.shrink-0{flex-shrink:0}.grow{flex-grow:1}.caption-bottom{caption-side:bottom}.border-collapse{border-collapse:collapse}.-translate-x-1\/2,.translate-x-\[-50\%\]{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.select-all{-webkit-user-select:all;-moz-user-select:all;user-select:all}.list-none{list-style-type:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-\[1fr_auto\]{grid-template-columns:1fr auto}.grid-cols-\[minmax\(0\,1fr\)_auto_minmax\(0\,1fr\)_auto\]{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr) auto}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0{gap:0px}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-x-2{-moz-column-gap:.5rem;column-gap:.5rem}.gap-x-3{-moz-column-gap:.75rem;column-gap:.75rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-y-2{row-gap:.5rem}.gap-y-3{row-gap:.75rem}.gap-y-5{row-gap:1.25rem}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-2\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.625rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.625rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-border\/50>:not([hidden])~:not([hidden]){border-color:hsl(var(--border) / .5)}.self-start{align-self:flex-start}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-wrap{white-space:pre-wrap}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-\[0\.75rem\]{border-radius:.75rem}.rounded-\[0\.85rem\]{border-radius:.85rem}.rounded-\[0\.8rem\]{border-radius:.8rem}.rounded-\[0\.95rem\]{border-radius:.95rem}.rounded-\[0\.9rem\]{border-radius:.9rem}.rounded-\[1\.05rem\]{border-radius:1.05rem}.rounded-\[1\.15rem\]{border-radius:1.15rem}.rounded-\[1\.1rem\]{border-radius:1.1rem}.rounded-\[1\.25rem\]{border-radius:1.25rem}.rounded-\[1\.2rem\]{border-radius:1.2rem}.rounded-\[1\.35rem\]{border-radius:1.35rem}.rounded-\[1\.45rem\]{border-radius:1.45rem}.rounded-\[1\.4rem\]{border-radius:1.4rem}.rounded-\[1\.5rem\]{border-radius:1.5rem}.rounded-\[1\.6rem\]{border-radius:1.6rem}.rounded-\[1\.7rem\]{border-radius:1.7rem}.rounded-\[1\.8rem\]{border-radius:1.8rem}.rounded-\[1rem\]{border-radius:1rem}.rounded-\[2rem\]{border-radius:2rem}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-lg{border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l{border-left-width:1px}.border-l-2{border-left-width:2px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-\[color\:var\(--surface-border\)\]{border-color:var(--surface-border)}.border-\[hsl\(var\(--success\)\/0\.2\)\]{border-color:hsl(var(--success)/.2)}.border-amber-200{--tw-border-opacity: 1;border-color:rgb(253 230 138 / var(--tw-border-opacity, 1))}.border-amber-300{--tw-border-opacity: 1;border-color:rgb(252 211 77 / var(--tw-border-opacity, 1))}.border-amber-400{--tw-border-opacity: 1;border-color:rgb(251 191 36 / var(--tw-border-opacity, 1))}.border-border{border-color:hsl(var(--border))}.border-border\/30{border-color:hsl(var(--border) / .3)}.border-border\/45{border-color:hsl(var(--border) / .45)}.border-border\/50{border-color:hsl(var(--border) / .5)}.border-border\/55{border-color:hsl(var(--border) / .55)}.border-border\/60{border-color:hsl(var(--border) / .6)}.border-border\/65{border-color:hsl(var(--border) / .65)}.border-border\/70{border-color:hsl(var(--border) / .7)}.border-destructive\/15{border-color:hsl(var(--destructive) / .15)}.border-destructive\/20{border-color:hsl(var(--destructive) / .2)}.border-destructive\/25{border-color:hsl(var(--destructive) / .25)}.border-destructive\/30{border-color:hsl(var(--destructive) / .3)}.border-destructive\/40{border-color:hsl(var(--destructive) / .4)}.border-destructive\/50{border-color:hsl(var(--destructive) / .5)}.border-emerald-100{--tw-border-opacity: 1;border-color:rgb(209 250 229 / var(--tw-border-opacity, 1))}.border-emerald-100\/80{border-color:#d1fae5cc}.border-emerald-300{--tw-border-opacity: 1;border-color:rgb(110 231 183 / var(--tw-border-opacity, 1))}.border-indigo-100{--tw-border-opacity: 1;border-color:rgb(224 231 255 / var(--tw-border-opacity, 1))}.border-indigo-600{--tw-border-opacity: 1;border-color:rgb(79 70 229 / var(--tw-border-opacity, 1))}.border-input{border-color:hsl(var(--input))}.border-primary{border-color:hsl(var(--primary))}.border-primary\/10{border-color:hsl(var(--primary) / .1)}.border-primary\/15{border-color:hsl(var(--primary) / .15)}.border-primary\/20{border-color:hsl(var(--primary) / .2)}.border-primary\/30{border-color:hsl(var(--primary) / .3)}.border-red-200{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1))}.border-red-300{--tw-border-opacity: 1;border-color:rgb(252 165 165 / var(--tw-border-opacity, 1))}.border-rose-100{--tw-border-opacity: 1;border-color:rgb(255 228 230 / var(--tw-border-opacity, 1))}.border-rose-100\/80{border-color:#ffe4e6cc}.border-rose-300{--tw-border-opacity: 1;border-color:rgb(253 164 175 / var(--tw-border-opacity, 1))}.border-sky-200{--tw-border-opacity: 1;border-color:rgb(186 230 253 / var(--tw-border-opacity, 1))}.border-slate-100{--tw-border-opacity: 1;border-color:rgb(241 245 249 / var(--tw-border-opacity, 1))}.border-slate-200{--tw-border-opacity: 1;border-color:rgb(226 232 240 / var(--tw-border-opacity, 1))}.border-slate-200\/70{border-color:#e2e8f0b3}.border-slate-300{--tw-border-opacity: 1;border-color:rgb(203 213 225 / var(--tw-border-opacity, 1))}.border-slate-800\/20{border-color:#1e293b33}.border-slate-900\/10{border-color:#0f172a1a}.border-transparent{border-color:transparent}.border-violet-200{--tw-border-opacity: 1;border-color:rgb(221 214 254 / var(--tw-border-opacity, 1))}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.border-white\/10{border-color:#ffffff1a}.border-white\/20{border-color:#fff3}.border-white\/45{border-color:#ffffff73}.border-white\/65{border-color:#ffffffa6}.border-white\/70{border-color:#ffffffb3}.border-white\/75{border-color:#ffffffbf}.border-white\/80{border-color:#fffc}.border-l-amber-500{--tw-border-opacity: 1;border-left-color:rgb(245 158 11 / var(--tw-border-opacity, 1))}.border-l-destructive{border-left-color:hsl(var(--destructive))}.border-l-emerald-500{--tw-border-opacity: 1;border-left-color:rgb(16 185 129 / var(--tw-border-opacity, 1))}.border-l-transparent{border-left-color:transparent}.border-t-transparent{border-top-color:transparent}.bg-\[\#1E1E2E\]{--tw-bg-opacity: 1;background-color:rgb(30 30 46 / var(--tw-bg-opacity, 1))}.bg-\[hsl\(var\(--success-bg\)\)\]{background-color:hsl(var(--success-bg))}.bg-accent{background-color:hsl(var(--accent))}.bg-accent\/90{background-color:hsl(var(--accent) / .9)}.bg-amber-100{--tw-bg-opacity: 1;background-color:rgb(254 243 199 / var(--tw-bg-opacity, 1))}.bg-amber-200{--tw-bg-opacity: 1;background-color:rgb(253 230 138 / var(--tw-bg-opacity, 1))}.bg-amber-50{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.bg-amber-500{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity, 1))}.bg-background{background-color:hsl(var(--background))}.bg-background\/50{background-color:hsl(var(--background) / .5)}.bg-background\/60{background-color:hsl(var(--background) / .6)}.bg-background\/70{background-color:hsl(var(--background) / .7)}.bg-background\/80{background-color:hsl(var(--background) / .8)}.bg-background\/85{background-color:hsl(var(--background) / .85)}.bg-background\/95{background-color:hsl(var(--background) / .95)}.bg-blue-200{--tw-bg-opacity: 1;background-color:rgb(191 219 254 / var(--tw-bg-opacity, 1))}.bg-border{background-color:hsl(var(--border))}.bg-border\/55{background-color:hsl(var(--border) / .55)}.bg-card{background-color:hsl(var(--card))}.bg-card\/85{background-color:hsl(var(--card) / .85)}.bg-card\/90{background-color:hsl(var(--card) / .9)}.bg-card\/95{background-color:hsl(var(--card) / .95)}.bg-destructive{background-color:hsl(var(--destructive))}.bg-destructive\/10{background-color:hsl(var(--destructive) / .1)}.bg-destructive\/5{background-color:hsl(var(--destructive) / .05)}.bg-emerald-100{--tw-bg-opacity: 1;background-color:rgb(209 250 229 / var(--tw-bg-opacity, 1))}.bg-emerald-50{--tw-bg-opacity: 1;background-color:rgb(236 253 245 / var(--tw-bg-opacity, 1))}.bg-emerald-50\/50{background-color:#ecfdf580}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.bg-emerald-500\/10{background-color:#10b9811a}.bg-emerald-600{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity, 1))}.bg-indigo-100{--tw-bg-opacity: 1;background-color:rgb(224 231 255 / var(--tw-bg-opacity, 1))}.bg-indigo-50{--tw-bg-opacity: 1;background-color:rgb(238 242 255 / var(--tw-bg-opacity, 1))}.bg-indigo-50\/80{background-color:#eef2ffcc}.bg-indigo-500{--tw-bg-opacity: 1;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))}.bg-indigo-600{--tw-bg-opacity: 1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.bg-muted{background-color:hsl(var(--muted))}.bg-muted-foreground\/70{background-color:hsl(var(--muted-foreground) / .7)}.bg-muted\/30{background-color:hsl(var(--muted) / .3)}.bg-muted\/50{background-color:hsl(var(--muted) / .5)}.bg-pink-100{--tw-bg-opacity: 1;background-color:rgb(252 231 243 / var(--tw-bg-opacity, 1))}.bg-popover{background-color:hsl(var(--popover))}.bg-primary{background-color:hsl(var(--primary))}.bg-primary\/10{background-color:hsl(var(--primary) / .1)}.bg-primary\/20{background-color:hsl(var(--primary) / .2)}.bg-primary\/5{background-color:hsl(var(--primary) / .05)}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-rose-50{--tw-bg-opacity: 1;background-color:rgb(255 241 242 / var(--tw-bg-opacity, 1))}.bg-rose-50\/50{background-color:#fff1f280}.bg-secondary{background-color:hsl(var(--secondary))}.bg-secondary\/20{background-color:hsl(var(--secondary) / .2)}.bg-secondary\/30{background-color:hsl(var(--secondary) / .3)}.bg-secondary\/35{background-color:hsl(var(--secondary) / .35)}.bg-secondary\/40{background-color:hsl(var(--secondary) / .4)}.bg-secondary\/45{background-color:hsl(var(--secondary) / .45)}.bg-secondary\/50{background-color:hsl(var(--secondary) / .5)}.bg-secondary\/55{background-color:hsl(var(--secondary) / .55)}.bg-secondary\/60{background-color:hsl(var(--secondary) / .6)}.bg-secondary\/65{background-color:hsl(var(--secondary) / .65)}.bg-secondary\/70{background-color:hsl(var(--secondary) / .7)}.bg-secondary\/80{background-color:hsl(var(--secondary) / .8)}.bg-sky-50{--tw-bg-opacity: 1;background-color:rgb(240 249 255 / var(--tw-bg-opacity, 1))}.bg-slate-100{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.bg-slate-200{--tw-bg-opacity: 1;background-color:rgb(226 232 240 / var(--tw-bg-opacity, 1))}.bg-slate-50{--tw-bg-opacity: 1;background-color:rgb(248 250 252 / var(--tw-bg-opacity, 1))}.bg-slate-950{--tw-bg-opacity: 1;background-color:rgb(2 6 23 / var(--tw-bg-opacity, 1))}.bg-slate-950\/95{background-color:#020617f2}.bg-transparent{background-color:transparent}.bg-violet-100{--tw-bg-opacity: 1;background-color:rgb(237 233 254 / var(--tw-bg-opacity, 1))}.bg-violet-50{--tw-bg-opacity: 1;background-color:rgb(245 243 255 / var(--tw-bg-opacity, 1))}.bg-violet-500{--tw-bg-opacity: 1;background-color:rgb(139 92 246 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/10{background-color:#ffffff1a}.bg-white\/5{background-color:#ffffff0d}.bg-white\/70{background-color:#ffffffb3}.bg-white\/80{background-color:#fffc}.bg-\[linear-gradient\(135deg\,hsl\(var\(--accent\)\/0\.55\)_0\%\,rgba\(255\,255\,255\,0\.7\)_100\%\)\]{background-image:linear-gradient(135deg,hsl(var(--accent)/.55),#ffffffb3)}.bg-\[linear-gradient\(135deg\,hsl\(var\(--primary\)\/0\.08\)\,hsl\(var\(--accent\)\/0\.72\)\)\]{background-image:linear-gradient(135deg,hsl(var(--primary)/.08),hsl(var(--accent)/.72))}.bg-\[linear-gradient\(135deg\,hsl\(var\(--primary\)\/0\.1\)\,rgba\(255\,255\,255\,0\.78\)\)\]{background-image:linear-gradient(135deg,hsl(var(--primary)/.1),#ffffffc7)}.bg-\[linear-gradient\(135deg\,hsl\(var\(--primary\)\/0\.1\)\,rgba\(255\,255\,255\,0\.95\)_46\%\,rgba\(236\,253\,245\,0\.74\)\)\]{background-image:linear-gradient(135deg,hsl(var(--primary)/.1),#fffffff2 46%,#ecfdf5bd)}.bg-\[linear-gradient\(135deg\,hsl\(var\(--primary\)\/0\.14\)\,hsl\(var\(--primary\)\/0\.04\)\)\]{background-image:linear-gradient(135deg,hsl(var(--primary)/.14),hsl(var(--primary)/.04))}.bg-\[linear-gradient\(135deg\,rgba\(255\,255\,255\,0\.98\)\,hsl\(var\(--primary\)\/0\.08\)\)\]{background-image:linear-gradient(135deg,#fffffffa,hsl(var(--primary)/.08))}.bg-\[linear-gradient\(135deg\,rgba\(255\,255\,255\,0\.98\)\,hsl\(var\(--primary\)\/0\.08\)\,rgba\(236\,253\,245\,0\.8\)\)\]{background-image:linear-gradient(135deg,#fffffffa,hsl(var(--primary)/.08),#ecfdf5cc)}.bg-\[linear-gradient\(145deg\,rgba\(236\,253\,245\,0\.98\)_0\%\,rgba\(255\,255\,255\,0\.94\)_100\%\)\]{background-image:linear-gradient(145deg,#ecfdf5fa,#fffffff0)}.bg-\[linear-gradient\(145deg\,rgba\(254\,242\,242\,0\.98\)_0\%\,rgba\(255\,255\,255\,0\.94\)_100\%\)\]{background-image:linear-gradient(145deg,#fef2f2fa,#fffffff0)}.bg-\[linear-gradient\(180deg\,rgba\(255\,255\,255\,0\.78\)_0\%\,rgba\(255\,255\,255\,0\.46\)_100\%\)\]{background-image:linear-gradient(180deg,#ffffffc7,#ffffff75)}.bg-\[linear-gradient\(180deg\,rgba\(255\,255\,255\,0\.97\)_0\%\,rgba\(250\,251\,253\,0\.94\)_100\%\)\]{background-image:linear-gradient(180deg,#fffffff7,#fafbfdf0)}.bg-\[radial-gradient\(circle_at_top\,\#eef4ff_0\%\,\#f8fbff_26\%\,\#ffffff_62\%\)\]{background-image:radial-gradient(circle at top,#eef4ff,#f8fbff 26%,#fff 62%)}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-emerald-100{--tw-gradient-from: #d1fae5 var(--tw-gradient-from-position);--tw-gradient-to: rgb(209 250 229 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-100{--tw-gradient-from: #e0e7ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(224 231 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-200\/60{--tw-gradient-from: rgb(199 210 254 / .6) var(--tw-gradient-from-position);--tw-gradient-to: rgb(199 210 254 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-50{--tw-gradient-from: #eef2ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(238 242 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-600{--tw-gradient-from: #4f46e5 var(--tw-gradient-from-position);--tw-gradient-to: rgb(79 70 229 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-700{--tw-gradient-from: #4338ca var(--tw-gradient-from-position);--tw-gradient-to: rgb(67 56 202 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-50{--tw-gradient-from: #f8fafc var(--tw-gradient-from-position);--tw-gradient-to: rgb(248 250 252 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-violet-100{--tw-gradient-from: #ede9fe var(--tw-gradient-from-position);--tw-gradient-to: rgb(237 233 254 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-white{--tw-gradient-from: #fff var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-violet-200\/45{--tw-gradient-to: rgb(221 214 254 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), rgb(221 214 254 / .45) var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-violet-600{--tw-gradient-to: rgb(124 58 237 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #7c3aed var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-white{--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #fff var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-cyan-100{--tw-gradient-to: #cffafe var(--tw-gradient-to-position)}.to-cyan-200\/55{--tw-gradient-to: rgb(165 243 252 / .55) var(--tw-gradient-to-position)}.to-cyan-50{--tw-gradient-to: #ecfeff var(--tw-gradient-to-position)}.to-cyan-600{--tw-gradient-to: #0891b2 var(--tw-gradient-to-position)}.to-fuchsia-100{--tw-gradient-to: #fae8ff var(--tw-gradient-to-position)}.to-slate-50{--tw-gradient-to: #f8fafc var(--tw-gradient-to-position)}.to-violet-100{--tw-gradient-to: #ede9fe var(--tw-gradient-to-position)}.to-violet-600{--tw-gradient-to: #7c3aed var(--tw-gradient-to-position)}.to-white{--tw-gradient-to: #fff var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.fill-current{fill:currentColor}.object-cover{-o-object-fit:cover;object-fit:cover}.object-top{-o-object-position:top;object-position:top}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-12{padding:3rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-7{padding:1.75rem}.p-\[1px\]{padding:1px}.px-0{padding-left:0;padding-right:0}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-3\.5{padding-left:.875rem;padding-right:.875rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-14{padding-top:3.5rem;padding-bottom:3.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-0{padding-bottom:0}.pb-1{padding-bottom:.25rem}.pb-10{padding-bottom:2.5rem}.pb-2\.5{padding-bottom:.625rem}.pb-24{padding-bottom:6rem}.pb-4{padding-bottom:1rem}.pb-5{padding-bottom:1.25rem}.pl-4{padding-left:1rem}.pl-8{padding-left:2rem}.pr-14{padding-right:3.5rem}.pr-2{padding-right:.5rem}.pr-3{padding-right:.75rem}.pr-8{padding-right:2rem}.pt-0{padding-top:0}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-middle{vertical-align:middle}.font-mono{font-family:Inter,SF Mono,IBM Plex Mono,JetBrains Mono,ui-monospace,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[0\.95em\]{font-size:.95em}.text-\[1\.02rem\]{font-size:1.02rem}.text-\[1\.75rem\]{font-size:1.75rem}.text-\[1\.85rem\]{font-size:1.85rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[2\.25rem\]{font-size:2.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.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)}.leading-5{line-height:1.25rem}.leading-6{line-height:1.5rem}.leading-7{line-height:1.75rem}.leading-8{line-height:2rem}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-\[-0\.01em\]{letter-spacing:-.01em}.tracking-\[-0\.02em\]{letter-spacing:-.02em}.tracking-\[-0\.03em\]{letter-spacing:-.03em}.tracking-\[-0\.04em\]{letter-spacing:-.04em}.tracking-\[0\.08em\]{letter-spacing:.08em}.tracking-\[0\.14em\]{letter-spacing:.14em}.tracking-\[0\.16em\]{letter-spacing:.16em}.tracking-\[0\.18em\]{letter-spacing:.18em}.tracking-\[0\.22em\]{letter-spacing:.22em}.tracking-\[0\.34em\]{letter-spacing:.34em}.tracking-\[0\.3em\]{letter-spacing:.3em}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-\[hsl\(var\(--success\)\/1\)\]{color:hsl(var(--success)/1)}.text-accent-foreground{color:hsl(var(--accent-foreground))}.text-amber-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-amber-700{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity, 1))}.text-amber-800{--tw-text-opacity: 1;color:rgb(146 64 14 / var(--tw-text-opacity, 1))}.text-amber-900{--tw-text-opacity: 1;color:rgb(120 53 15 / var(--tw-text-opacity, 1))}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-border{color:hsl(var(--border))}.text-card-foreground{color:hsl(var(--card-foreground))}.text-destructive{color:hsl(var(--destructive))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-emerald-300{--tw-text-opacity: 1;color:rgb(110 231 183 / var(--tw-text-opacity, 1))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-emerald-500{--tw-text-opacity: 1;color:rgb(16 185 129 / var(--tw-text-opacity, 1))}.text-emerald-600{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.text-emerald-700{--tw-text-opacity: 1;color:rgb(4 120 87 / var(--tw-text-opacity, 1))}.text-emerald-800{--tw-text-opacity: 1;color:rgb(6 95 70 / var(--tw-text-opacity, 1))}.text-emerald-950{--tw-text-opacity: 1;color:rgb(2 44 34 / var(--tw-text-opacity, 1))}.text-foreground{color:hsl(var(--foreground))}.text-foreground\/50{color:hsl(var(--foreground) / .5)}.text-foreground\/90{color:hsl(var(--foreground) / .9)}.text-indigo-200{--tw-text-opacity: 1;color:rgb(199 210 254 / var(--tw-text-opacity, 1))}.text-indigo-300{--tw-text-opacity: 1;color:rgb(165 180 252 / var(--tw-text-opacity, 1))}.text-indigo-500{--tw-text-opacity: 1;color:rgb(99 102 241 / var(--tw-text-opacity, 1))}.text-indigo-600{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.text-indigo-700{--tw-text-opacity: 1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-muted-foreground\/50{color:hsl(var(--muted-foreground) / .5)}.text-muted-foreground\/60{color:hsl(var(--muted-foreground) / .6)}.text-muted-foreground\/70{color:hsl(var(--muted-foreground) / .7)}.text-muted-foreground\/75{color:hsl(var(--muted-foreground) / .75)}.text-muted-foreground\/80{color:hsl(var(--muted-foreground) / .8)}.text-pink-700{--tw-text-opacity: 1;color:rgb(190 24 93 / var(--tw-text-opacity, 1))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-primary\/70{color:hsl(var(--primary) / .7)}.text-primary\/75{color:hsl(var(--primary) / .75)}.text-primary\/80{color:hsl(var(--primary) / .8)}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-rose-500{--tw-text-opacity: 1;color:rgb(244 63 94 / var(--tw-text-opacity, 1))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-sky-700{--tw-text-opacity: 1;color:rgb(3 105 161 / var(--tw-text-opacity, 1))}.text-slate-100{--tw-text-opacity: 1;color:rgb(241 245 249 / var(--tw-text-opacity, 1))}.text-slate-200{--tw-text-opacity: 1;color:rgb(226 232 240 / var(--tw-text-opacity, 1))}.text-slate-300{--tw-text-opacity: 1;color:rgb(203 213 225 / var(--tw-text-opacity, 1))}.text-slate-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.text-slate-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.text-slate-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity, 1))}.text-slate-700{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity, 1))}.text-slate-800{--tw-text-opacity: 1;color:rgb(30 41 59 / var(--tw-text-opacity, 1))}.text-slate-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.text-slate-950{--tw-text-opacity: 1;color:rgb(2 6 23 / var(--tw-text-opacity, 1))}.text-transparent{color:transparent}.text-violet-600{--tw-text-opacity: 1;color:rgb(124 58 237 / var(--tw-text-opacity, 1))}.text-violet-700{--tw-text-opacity: 1;color:rgb(109 40 217 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.line-through{text-decoration-line:line-through}.underline-offset-4{text-underline-offset:4px}.accent-\[hsl\(var\(--primary\)\)\],.accent-primary{accent-color:hsl(var(--primary))}.opacity-0{opacity:0}.opacity-45{opacity:.45}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-80{opacity:.8}.shadow-\[0_10px_22px_-14px_hsl\(var\(--primary\)\/0\.7\)\]{--tw-shadow: 0 10px 22px -14px hsl(var(--primary)/.7);--tw-shadow-colored: 0 10px 22px -14px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_10px_24px_-20px_rgba\(15\,23\,42\,0\.18\)\]{--tw-shadow: 0 10px 24px -20px rgba(15,23,42,.18);--tw-shadow-colored: 0 10px 24px -20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_10px_24px_-22px_rgba\(15\,23\,42\,0\.28\)\]{--tw-shadow: 0 10px 24px -22px rgba(15,23,42,.28);--tw-shadow-colored: 0 10px 24px -22px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_10px_30px_-24px_rgba\(15\,23\,42\,0\.18\)\]{--tw-shadow: 0 10px 30px -24px rgba(15,23,42,.18);--tw-shadow-colored: 0 10px 30px -24px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_12px_28px_-24px_rgba\(15\,23\,42\,0\.32\)\]{--tw-shadow: 0 12px 28px -24px rgba(15,23,42,.32);--tw-shadow-colored: 0 12px 28px -24px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_12px_28px_rgba\(15\,23\,42\,0\.06\)\]{--tw-shadow: 0 12px 28px rgba(15,23,42,.06);--tw-shadow-colored: 0 12px 28px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_14px_32px_-30px_rgba\(15\,23\,42\,0\.2\)\]{--tw-shadow: 0 14px 32px -30px rgba(15,23,42,.2);--tw-shadow-colored: 0 14px 32px -30px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_14px_34px_-28px_rgba\(15\,23\,42\,0\.3\)\]{--tw-shadow: 0 14px 34px -28px rgba(15,23,42,.3);--tw-shadow-colored: 0 14px 34px -28px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_14px_34px_-30px_rgba\(59\,130\,246\,0\.32\)\]{--tw-shadow: 0 14px 34px -30px rgba(59,130,246,.32);--tw-shadow-colored: 0 14px 34px -30px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_16px_36px_-30px_rgba\(15\,23\,42\,0\.24\)\]{--tw-shadow: 0 16px 36px -30px rgba(15,23,42,.24);--tw-shadow-colored: 0 16px 36px -30px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_16px_40px_-34px_rgba\(15\,23\,42\,0\.18\)\]{--tw-shadow: 0 16px 40px -34px rgba(15,23,42,.18);--tw-shadow-colored: 0 16px 40px -34px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_16px_40px_-34px_rgba\(15\,23\,42\,0\.2\)\]{--tw-shadow: 0 16px 40px -34px rgba(15,23,42,.2);--tw-shadow-colored: 0 16px 40px -34px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_36px_-20px_rgba\(79\,70\,229\,0\.6\)\]{--tw-shadow: 0 18px 36px -20px rgba(79,70,229,.6);--tw-shadow-colored: 0 18px 36px -20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_38px_-34px_rgba\(15\,23\,42\,0\.2\)\]{--tw-shadow: 0 18px 38px -34px rgba(15,23,42,.2);--tw-shadow-colored: 0 18px 38px -34px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_40px_-24px_rgba\(79\,70\,229\,0\.55\)\]{--tw-shadow: 0 18px 40px -24px rgba(79,70,229,.55);--tw-shadow-colored: 0 18px 40px -24px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_40px_-30px_rgba\(15\,23\,42\,0\.22\)\]{--tw-shadow: 0 18px 40px -30px rgba(15,23,42,.22);--tw-shadow-colored: 0 18px 40px -30px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_40px_-30px_rgba\(15\,23\,42\,0\.28\)\]{--tw-shadow: 0 18px 40px -30px rgba(15,23,42,.28);--tw-shadow-colored: 0 18px 40px -30px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_40px_-34px_rgba\(15\,23\,42\,0\.18\)\]{--tw-shadow: 0 18px 40px -34px rgba(15,23,42,.18);--tw-shadow-colored: 0 18px 40px -34px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_42px_-36px_rgba\(15\,23\,42\,0\.24\)\]{--tw-shadow: 0 18px 42px -36px rgba(15,23,42,.24);--tw-shadow-colored: 0 18px 42px -36px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_42px_-38px_rgba\(15\,23\,42\,0\.22\)\]{--tw-shadow: 0 18px 42px -38px rgba(15,23,42,.22);--tw-shadow-colored: 0 18px 42px -38px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_42px_-38px_rgba\(15\,23\,42\,0\.24\)\]{--tw-shadow: 0 18px 42px -38px rgba(15,23,42,.24);--tw-shadow-colored: 0 18px 42px -38px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_42px_rgba\(15\,23\,42\,0\.06\)\]{--tw-shadow: 0 18px 42px rgba(15,23,42,.06);--tw-shadow-colored: 0 18px 42px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_44px_-34px_rgba\(15\,23\,42\,0\.22\)\]{--tw-shadow: 0 18px 44px -34px rgba(15,23,42,.22);--tw-shadow-colored: 0 18px 44px -34px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_44px_-34px_rgba\(15\,23\,42\,0\.26\)\]{--tw-shadow: 0 18px 44px -34px rgba(15,23,42,.26);--tw-shadow-colored: 0 18px 44px -34px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_46px_-34px_rgba\(15\,23\,42\,0\.16\)\]{--tw-shadow: 0 18px 46px -34px rgba(15,23,42,.16);--tw-shadow-colored: 0 18px 46px -34px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_46px_-34px_rgba\(16\,185\,129\,0\.22\)\]{--tw-shadow: 0 18px 46px -34px rgba(16,185,129,.22);--tw-shadow-colored: 0 18px 46px -34px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_48px_-36px_rgba\(15\,23\,42\,0\.22\)\]{--tw-shadow: 0 18px 48px -36px rgba(15,23,42,.22);--tw-shadow-colored: 0 18px 48px -36px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_18px_48px_-36px_rgba\(15\,23\,42\,0\.26\)\]{--tw-shadow: 0 18px 48px -36px rgba(15,23,42,.26);--tw-shadow-colored: 0 18px 48px -36px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_20px_48px_-40px_rgba\(15\,23\,42\,0\.24\)\]{--tw-shadow: 0 20px 48px -40px rgba(15,23,42,.24);--tw-shadow-colored: 0 20px 48px -40px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_20px_48px_-42px_rgba\(15\,23\,42\,0\.24\)\]{--tw-shadow: 0 20px 48px -42px rgba(15,23,42,.24);--tw-shadow-colored: 0 20px 48px -42px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_20px_48px_-42px_rgba\(15\,23\,42\,0\.26\)\]{--tw-shadow: 0 20px 48px -42px rgba(15,23,42,.26);--tw-shadow-colored: 0 20px 48px -42px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_20px_50px_-36px_rgba\(15\,23\,42\,0\.26\)\]{--tw-shadow: 0 20px 50px -36px rgba(15,23,42,.26);--tw-shadow-colored: 0 20px 50px -36px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_20px_50px_-42px_rgba\(15\,23\,42\,0\.24\)\]{--tw-shadow: 0 20px 50px -42px rgba(15,23,42,.24);--tw-shadow-colored: 0 20px 50px -42px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_22px_56px_-38px_rgba\(15\,23\,42\,0\.28\)\]{--tw-shadow: 0 22px 56px -38px rgba(15,23,42,.28);--tw-shadow-colored: 0 22px 56px -38px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_22px_56px_-40px_rgba\(15\,23\,42\,0\.24\)\]{--tw-shadow: 0 22px 56px -40px rgba(15,23,42,.24);--tw-shadow-colored: 0 22px 56px -40px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_22px_56px_-46px_rgba\(15\,23\,42\,0\.22\)\]{--tw-shadow: 0 22px 56px -46px rgba(15,23,42,.22);--tw-shadow-colored: 0 22px 56px -46px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_22px_56px_-46px_rgba\(15\,23\,42\,0\.24\)\]{--tw-shadow: 0 22px 56px -46px rgba(15,23,42,.24);--tw-shadow-colored: 0 22px 56px -46px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_24px_64px_-38px_rgba\(15\,23\,42\,0\.5\)\]{--tw-shadow: 0 24px 64px -38px rgba(15,23,42,.5);--tw-shadow-colored: 0 24px 64px -38px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_24px_64px_-48px_rgba\(15\,23\,42\,0\.22\)\]{--tw-shadow: 0 24px 64px -48px rgba(15,23,42,.22);--tw-shadow-colored: 0 24px 64px -48px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_28px_80px_-44px_rgba\(15\,23\,42\,0\.5\)\]{--tw-shadow: 0 28px 80px -44px rgba(15,23,42,.5);--tw-shadow-colored: 0 28px 80px -44px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_30px_80px_-44px_rgba\(15\,23\,42\,0\.24\)\]{--tw-shadow: 0 30px 80px -44px rgba(15,23,42,.24);--tw-shadow-colored: 0 30px 80px -44px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_32px_80px_-40px_rgba\(15\,23\,42\,0\.34\)\]{--tw-shadow: 0 32px 80px -40px rgba(15,23,42,.34);--tw-shadow-colored: 0 32px 80px -40px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_3px_10px_rgba\(15\,23\,42\,0\.18\)\]{--tw-shadow: 0 3px 10px rgba(15,23,42,.18);--tw-shadow-colored: 0 3px 10px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[inset_0_0_0_1px_rgba\(15\,23\,42\,0\.06\)\]{--tw-shadow: inset 0 0 0 1px rgba(15,23,42,.06);--tw-shadow-colored: inset 0 0 0 1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.55\)\]{--tw-shadow: inset 0 1px 0 rgba(255,255,255,.55);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.58\)\]{--tw-shadow: inset 0 1px 0 rgba(255,255,255,.58);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.6\)\]{--tw-shadow: inset 0 1px 0 rgba(255,255,255,.6);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.62\)\]{--tw-shadow: inset 0 1px 0 rgba(255,255,255,.62);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.68\)\]{--tw-shadow: inset 0 1px 0 rgba(255,255,255,.68);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.7\)\]{--tw-shadow: inset 0 1px 0 rgba(255,255,255,.7);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[var\(--surface-shadow\)\]{--tw-shadow-color: var(--surface-shadow);--tw-shadow: var(--tw-shadow-colored)}.shadow-\[var\(--surface-shadow-lg\)\]{--tw-shadow-color: var(--surface-shadow-lg);--tw-shadow: var(--tw-shadow-colored)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-1{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-amber-200\/50{--tw-ring-color: rgb(253 230 138 / .5)}.ring-destructive\/20{--tw-ring-color: hsl(var(--destructive) / .2)}.ring-destructive\/30{--tw-ring-color: hsl(var(--destructive) / .3)}.ring-primary\/10{--tw-ring-color: hsl(var(--primary) / .1)}.ring-ring{--tw-ring-color: hsl(var(--ring))}.ring-slate-200\/70{--tw-ring-color: rgb(226 232 240 / .7)}.ring-slate-900\/5{--tw-ring-color: rgb(15 23 42 / .05)}.ring-violet-500\/35{--tw-ring-color: rgb(139 92 246 / .35)}.ring-white{--tw-ring-opacity: 1;--tw-ring-color: rgb(255 255 255 / var(--tw-ring-opacity, 1))}.ring-white\/10{--tw-ring-color: rgb(255 255 255 / .1)}.ring-white\/70{--tw-ring-color: rgb(255 255 255 / .7)}.ring-offset-2{--tw-ring-offset-width: 2px}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.blur-3xl{--tw-blur: blur(64px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur: blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-xl{--tw-backdrop-blur: blur(24px);-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,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.animate-in{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.fade-in,.fade-in-0{--tw-enter-opacity: 0}.zoom-in-95{--tw-enter-scale: .95}.slide-in-from-left{--tw-enter-translate-x: -100%}.slide-in-from-top-2{--tw-enter-translate-y: -.5rem}.duration-150{animation-duration:.15s}.duration-200{animation-duration:.2s}.running{animation-play-state:running}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background-color:transparent}::-webkit-scrollbar-thumb{border-radius:9999px;background-color:hsl(var(--border))}::-webkit-scrollbar-thumb:hover{background-color:hsl(var(--muted-foreground) / .4)}*:focus-visible{outline:2px solid transparent;outline-offset:2px;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-color: hsl(var(--primary));--tw-ring-offset-width: 2px;--tw-ring-offset-color: hsl(var(--background))}::-moz-selection{background-color:hsl(var(--primary) / .15);color:hsl(var(--foreground))}::selection{background-color:hsl(var(--primary) / .15);color:hsl(var(--foreground))}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .2s ease-out}.animate-slide-in{animation:slideInUp .25s ease-out}.metric-number{font-family:Inter,SF Mono,IBM Plex Mono,JetBrains Mono,ui-monospace,monospace;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.table-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}@media (hover: none) and (pointer: coarse){button,a,[role=button]{min-height:44px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.animate-toast-in{animation:toastIn .3s ease-out}.animate-toast-out{animation:toastOut .2s ease-in forwards}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::file-selector-button{color:hsl(var(--foreground))}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground\/50::-moz-placeholder{color:hsl(var(--muted-foreground) / .5)}.placeholder\:text-muted-foreground\/50::placeholder{color:hsl(var(--muted-foreground) / .5)}.placeholder\:text-muted-foreground\/70::-moz-placeholder{color:hsl(var(--muted-foreground) / .7)}.placeholder\:text-muted-foreground\/70::placeholder{color:hsl(var(--muted-foreground) / .7)}.before\:h-1\.5:before{content:var(--tw-content);height:.375rem}.before\:w-1\.5:before{content:var(--tw-content);width:.375rem}.before\:rounded-full:before{content:var(--tw-content);border-radius:9999px}.before\:bg-emerald-500:before{content:var(--tw-content);--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.focus-within\:bg-accent:focus-within{background-color:hsl(var(--accent))}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-border\/60:hover{border-color:hsl(var(--border) / .6)}.hover\:border-primary\/20:hover{border-color:hsl(var(--primary) / .2)}.hover\:border-slate-400:hover{--tw-border-opacity: 1;border-color:rgb(148 163 184 / var(--tw-border-opacity, 1))}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-accent\/50:hover{background-color:hsl(var(--accent) / .5)}.hover\:bg-accent\/80:hover{background-color:hsl(var(--accent) / .8)}.hover\:bg-destructive\/10:hover{background-color:hsl(var(--destructive) / .1)}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive) / .9)}.hover\:bg-indigo-500:hover{--tw-bg-opacity: 1;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))}.hover\:bg-muted\/50:hover{background-color:hsl(var(--muted) / .5)}.hover\:bg-primary\/5:hover{background-color:hsl(var(--primary) / .05)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary) / .9)}.hover\:bg-red-100:hover{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.hover\:bg-secondary:hover{background-color:hsl(var(--secondary))}.hover\:bg-secondary\/45:hover{background-color:hsl(var(--secondary) / .45)}.hover\:bg-secondary\/50:hover{background-color:hsl(var(--secondary) / .5)}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary) / .8)}.hover\:bg-slate-100:hover{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.hover\:bg-transparent:hover{background-color:transparent}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-white\/15:hover{background-color:#ffffff26}.hover\:from-indigo-500:hover{--tw-gradient-from: #6366f1 var(--tw-gradient-from-position);--tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:to-violet-500:hover{--tw-gradient-to: #8b5cf6 var(--tw-gradient-to-position)}.hover\:text-destructive:hover{color:hsl(var(--destructive))}.hover\:text-foreground:hover{color:hsl(var(--foreground))}.hover\:text-primary\/80:hover{color:hsl(var(--primary) / .8)}.hover\:text-red-700:hover{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.hover\:text-red-800:hover{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.hover\:text-slate-700:hover{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity, 1))}.hover\:text-slate-900:hover{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.hover\:text-slate-950:hover{--tw-text-opacity: 1;color:rgb(2 6 23 / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-\[0_20px_38px_-32px_rgba\(59\,130\,246\,0\.18\)\]:hover{--tw-shadow: 0 20px 38px -32px rgba(59,130,246,.18);--tw-shadow-colored: 0 20px 38px -32px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-\[0_22px_48px_-40px_rgba\(59\,130\,246\,0\.18\)\]:hover{--tw-shadow: 0 22px 48px -40px rgba(59,130,246,.18);--tw-shadow-colored: 0 22px 48px -40px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-\[0_24px_48px_-38px_rgba\(59\,130\,246\,0\.2\)\]:hover{--tw-shadow: 0 24px 48px -38px rgba(59,130,246,.2);--tw-shadow-colored: 0 24px 48px -38px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-\[0_24px_54px_-34px_rgba\(15\,23\,42\,0\.3\)\]:hover{--tw-shadow: 0 24px 54px -34px rgba(15,23,42,.3);--tw-shadow-colored: 0 24px 54px -34px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-\[var\(--surface-shadow-lg\)\]:hover{--tw-shadow-color: var(--surface-shadow-lg);--tw-shadow: var(--tw-shadow-colored)}.focus\:not-sr-only:focus{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip:auto;white-space:normal}.focus\:absolute:focus{position:absolute}.focus\:z-50:focus{z-index:50}.focus\:m-4:focus{margin:1rem}.focus\:rounded-md:focus{border-radius:calc(var(--radius) - 2px)}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:bg-accent\/80:focus{background-color:hsl(var(--accent) / .8)}.focus\:bg-primary:focus{background-color:hsl(var(--primary))}.focus\:px-4:focus{padding-left:1rem;padding-right:1rem}.focus\:py-2:focus{padding-top:.5rem;padding-bottom:.5rem}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:text-primary-foreground:focus{color:hsl(var(--primary-foreground))}.focus\:opacity-100:focus{opacity:1}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.group[open] .group-open\:bg-primary\/10{background-color:hsl(var(--primary) / .1)}.group[open] .group-open\:text-primary{color:hsl(var(--primary))}.group:hover .group-hover\:opacity-100{opacity:1}.group.destructive .group-\[\.destructive\]\:border-destructive\/20{border-color:hsl(var(--destructive) / .2)}.group.destructive .group-\[\.destructive\]\:text-destructive{color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:hover\:border-destructive\/30:hover{border-color:hsl(var(--destructive) / .3)}.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive\/10:hover{background-color:hsl(var(--destructive) / .1)}.group.destructive .group-\[\.destructive\]\:hover\:text-destructive:hover{color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:focus\:ring-destructive:focus{--tw-ring-color: hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:focus\:ring-red-400:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(248 113 113 / var(--tw-ring-opacity, 1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-offset-red-600:focus{--tw-ring-offset-color: #dc2626}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:translate-x-5[data-state=checked]{--tw-translate-x: 1.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked],.data-\[swipe\=cancel\]\:translate-x-0[data-swipe=cancel]{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end]{--tw-translate-x: var(--radix-toast-swipe-end-x);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{--tw-translate-x: var(--radix-toast-swipe-move-x);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=active\]\:border-primary[data-state=active]{border-color:hsl(var(--primary))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=open\]\:bg-accent\/80[data-state=open]{background-color:hsl(var(--accent) / .8)}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:hsl(var(--muted))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:hsl(var(--input))}.data-\[state\=active\]\:font-semibold[data-state=active]{font-weight:600}.data-\[state\=active\]\:text-foreground[data-state=active]{color:hsl(var(--foreground))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[swipe\=move\]\:transition-none[data-swipe=move]{transition-property:none}.data-\[state\=open\]\:animate-in[data-state=open]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.data-\[state\=closed\]\:animate-out[data-state=closed],.data-\[swipe\=end\]\:animate-out[data-swipe=end]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity: initial;--tw-exit-scale: initial;--tw-exit-rotate: initial;--tw-exit-translate-x: initial;--tw-exit-translate-y: initial}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity: 0}.data-\[state\=closed\]\:fade-out-80[data-state=closed]{--tw-exit-opacity: .8}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity: 0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale: .95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale: .95}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y: -.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x: .5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x: -.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y: .5rem}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x: -50%}.data-\[state\=closed\]\:slide-out-to-right-full[data-state=closed]{--tw-exit-translate-x: 100%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y: -48%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x: -50%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y: -48%}.data-\[state\=open\]\:slide-in-from-top-full[data-state=open]{--tw-enter-translate-y: -100%}.data-\[state\=inactive\]\:hover\:text-foreground:hover[data-state=inactive]{color:hsl(var(--foreground))}.dark\:border-amber-700:is([data-theme=dark] *){--tw-border-opacity: 1;border-color:rgb(180 83 9 / var(--tw-border-opacity, 1))}.dark\:border-amber-800:is([data-theme=dark] *){--tw-border-opacity: 1;border-color:rgb(146 64 14 / var(--tw-border-opacity, 1))}.dark\:border-border:is([data-theme=dark] *){border-color:hsl(var(--border))}.dark\:border-emerald-700:is([data-theme=dark] *){--tw-border-opacity: 1;border-color:rgb(4 120 87 / var(--tw-border-opacity, 1))}.dark\:border-red-400\/20:is([data-theme=dark] *){border-color:#f8717133}.dark\:border-red-700:is([data-theme=dark] *){--tw-border-opacity: 1;border-color:rgb(185 28 28 / var(--tw-border-opacity, 1))}.dark\:border-sky-400\/20:is([data-theme=dark] *){border-color:#38bdf833}.dark\:border-violet-400\/20:is([data-theme=dark] *){border-color:#a78bfa33}.dark\:border-white\/10:is([data-theme=dark] *){border-color:#ffffff1a}.dark\:\!bg-card:is([data-theme=dark] *){background-color:hsl(var(--card))!important}.dark\:\!bg-slate-950\/90:is([data-theme=dark] *){background-color:#020617e6!important}.dark\:bg-amber-950:is([data-theme=dark] *){--tw-bg-opacity: 1;background-color:rgb(69 26 3 / var(--tw-bg-opacity, 1))}.dark\:bg-amber-950\/30:is([data-theme=dark] *){background-color:#451a034d}.dark\:bg-amber-950\/40:is([data-theme=dark] *){background-color:#451a0366}.dark\:bg-emerald-950:is([data-theme=dark] *){--tw-bg-opacity: 1;background-color:rgb(2 44 34 / var(--tw-bg-opacity, 1))}.dark\:bg-emerald-950\/30:is([data-theme=dark] *){background-color:#022c224d}.dark\:bg-emerald-950\/40:is([data-theme=dark] *){background-color:#022c2266}.dark\:bg-emerald-950\/85:is([data-theme=dark] *){background-color:#022c22d9}.dark\:bg-indigo-950\/40:is([data-theme=dark] *){background-color:#1e1b4b66}.dark\:bg-pink-950\/40:is([data-theme=dark] *){background-color:#50072466}.dark\:bg-red-950:is([data-theme=dark] *){--tw-bg-opacity: 1;background-color:rgb(69 10 10 / var(--tw-bg-opacity, 1))}.dark\:bg-red-950\/40:is([data-theme=dark] *){background-color:#450a0a66}.dark\:bg-secondary:is([data-theme=dark] *){background-color:hsl(var(--secondary))}.dark\:bg-slate-900:is([data-theme=dark] *){--tw-bg-opacity: 1;background-color:rgb(15 23 42 / var(--tw-bg-opacity, 1))}.dark\:bg-slate-900\/\[0\.34\]:is([data-theme=dark] *){background-color:#0f172a57}.dark\:bg-slate-900\/\[0\.42\]:is([data-theme=dark] *){background-color:#0f172a6b}.dark\:bg-slate-900\/\[0\.52\]:is([data-theme=dark] *){background-color:#0f172a85}.dark\:bg-slate-900\/\[0\.56\]:is([data-theme=dark] *){background-color:#0f172a8f}.dark\:bg-slate-900\/\[0\.58\]:is([data-theme=dark] *){background-color:#0f172a94}.dark\:bg-slate-900\/\[0\.5\]:is([data-theme=dark] *){background-color:#0f172a80}.dark\:bg-slate-950\/50:is([data-theme=dark] *){background-color:#02061780}.dark\:bg-slate-950\/90:is([data-theme=dark] *){background-color:#020617e6}.dark\:bg-slate-950\/\[0\.38\]:is([data-theme=dark] *){background-color:#02061761}.dark\:bg-slate-950\/\[0\.58\]:is([data-theme=dark] *){background-color:#02061794}.dark\:bg-slate-950\/\[0\.62\]:is([data-theme=dark] *){background-color:#0206179e}.dark\:bg-violet-950\/40:is([data-theme=dark] *){background-color:#2e106566}.dark\:\!bg-none:is([data-theme=dark] *){background-image:none!important}.dark\:bg-\[linear-gradient\(135deg\,rgba\(14\,165\,233\,0\.12\)\,rgba\(15\,23\,42\,0\.72\)\)\]:is([data-theme=dark] *){background-image:linear-gradient(135deg,#0ea5e91f,#0f172ab8)}.dark\:bg-\[linear-gradient\(135deg\,rgba\(14\,165\,233\,0\.14\)\,rgba\(15\,23\,42\,0\.72\)\)\]:is([data-theme=dark] *){background-image:linear-gradient(135deg,#0ea5e924,#0f172ab8)}.dark\:bg-\[linear-gradient\(180deg\,rgba\(15\,23\,42\,0\.78\)_0\%\,rgba\(2\,6\,23\,0\.52\)_100\%\)\]:is([data-theme=dark] *){background-image:linear-gradient(180deg,#0f172ac7,#02061785)}.dark\:bg-\[linear-gradient\(180deg\,rgba\(15\,23\,42\,0\.92\)_0\%\,rgba\(2\,6\,23\,0\.88\)_100\%\)\]:is([data-theme=dark] *){background-image:linear-gradient(180deg,#0f172aeb,#020617e0)}.dark\:text-amber-200:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(253 230 138 / var(--tw-text-opacity, 1))}.dark\:text-amber-300:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(252 211 77 / var(--tw-text-opacity, 1))}.dark\:text-amber-400:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity, 1))}.dark\:text-emerald-100:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(209 250 229 / var(--tw-text-opacity, 1))}.dark\:text-emerald-200:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(167 243 208 / var(--tw-text-opacity, 1))}.dark\:text-emerald-400:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.dark\:text-indigo-400:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(129 140 248 / var(--tw-text-opacity, 1))}.dark\:text-pink-400:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(244 114 182 / var(--tw-text-opacity, 1))}.dark\:text-red-200:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(254 202 202 / var(--tw-text-opacity, 1))}.dark\:text-red-300:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.dark\:text-red-400:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.dark\:text-sky-100:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(224 242 254 / var(--tw-text-opacity, 1))}.dark\:text-sky-200:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(186 230 253 / var(--tw-text-opacity, 1))}.dark\:text-sky-200\/75:is([data-theme=dark] *){color:#bae6fdbf}.dark\:text-sky-200\/80:is([data-theme=dark] *){color:#bae6fdcc}.dark\:text-slate-300:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(203 213 225 / var(--tw-text-opacity, 1))}.dark\:text-slate-400:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.dark\:text-slate-50:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(248 250 252 / var(--tw-text-opacity, 1))}.dark\:text-violet-200:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(221 214 254 / var(--tw-text-opacity, 1))}.dark\:text-violet-400:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(167 139 250 / var(--tw-text-opacity, 1))}.dark\:shadow-\[0_12px_28px_rgba\(0\,0\,0\,0\.28\)\]:is([data-theme=dark] *){--tw-shadow: 0 12px 28px rgba(0,0,0,.28);--tw-shadow-colored: 0 12px 28px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.dark\:shadow-\[0_16px_36px_-30px_rgba\(0\,0\,0\,0\.32\)\]:is([data-theme=dark] *){--tw-shadow: 0 16px 36px -30px rgba(0,0,0,.32);--tw-shadow-colored: 0 16px 36px -30px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.dark\:shadow-\[0_18px_42px_-36px_rgba\(0\,0\,0\,0\.72\)\]:is([data-theme=dark] *){--tw-shadow: 0 18px 42px -36px rgba(0,0,0,.72);--tw-shadow-colored: 0 18px 42px -36px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.dark\:shadow-\[0_24px_64px_-48px_rgba\(0\,0\,0\,0\.7\)\]:is([data-theme=dark] *){--tw-shadow: 0 24px 64px -48px rgba(0,0,0,.7);--tw-shadow-colored: 0 24px 64px -48px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.dark\:shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.04\)\]:is([data-theme=dark] *){--tw-shadow: inset 0 1px 0 rgba(255,255,255,.04);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.dark\:shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.05\)\]:is([data-theme=dark] *){--tw-shadow: inset 0 1px 0 rgba(255,255,255,.05);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.dark\:shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.06\)\]:is([data-theme=dark] *){--tw-shadow: inset 0 1px 0 rgba(255,255,255,.06);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.dark\:shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.08\)\]:is([data-theme=dark] *){--tw-shadow: inset 0 1px 0 rgba(255,255,255,.08);--tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.dark\:ring-amber-500\/20:is([data-theme=dark] *){--tw-ring-color: rgb(245 158 11 / .2)}.dark\:ring-white\/10:is([data-theme=dark] *){--tw-ring-color: rgb(255 255 255 / .1)}.dark\:hover\:bg-red-500\/20:hover:is([data-theme=dark] *){background-color:#ef444433}.dark\:hover\:text-red-200:hover:is([data-theme=dark] *){--tw-text-opacity: 1;color:rgb(254 202 202 / var(--tw-text-opacity, 1))}.dark\:hover\:shadow-\[0_24px_48px_-38px_rgba\(59\,130\,246\,0\.28\)\]:hover:is([data-theme=dark] *){--tw-shadow: 0 24px 48px -38px rgba(59,130,246,.28);--tw-shadow-colored: 0 24px 48px -38px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}@media (min-width: 640px){.sm\:bottom-0{bottom:0}.sm\:right-0{right:0}.sm\:top-auto{top:auto}.sm\:col-span-2{grid-column:span 2 / span 2}.sm\:mt-2\.5{margin-top:.625rem}.sm\:line-clamp-1{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.sm\:block{display:block}.sm\:inline{display:inline}.sm\:flex{display:flex}.sm\:inline-flex{display:inline-flex}.sm\:grid{display:grid}.sm\:h-8{height:2rem}.sm\:max-h-\[440px\]{max-height:440px}.sm\:w-56{width:14rem}.sm\:w-7{width:1.75rem}.sm\:w-8{width:2rem}.sm\:w-9{width:2.25rem}.sm\:w-\[168px\]{width:168px}.sm\:w-auto{width:auto}.sm\:max-w-\[520px\]{max-width:520px}.sm\:flex-none{flex:none}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-\[auto_minmax\(0\,1fr\)\]{grid-template-columns:auto minmax(0,1fr)}.sm\:flex-row{flex-direction:row}.sm\:flex-col{flex-direction:column}.sm\:flex-wrap{flex-wrap:wrap}.sm\:items-start{align-items:flex-start}.sm\:items-end{align-items:flex-end}.sm\:items-center{align-items:center}.sm\:justify-end{justify-content:flex-end}.sm\:justify-between{justify-content:space-between}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:self-auto{align-self:auto}.sm\:rounded-\[0\.85rem\]{border-radius:.85rem}.sm\:p-3\.5{padding:.875rem}.sm\:p-5{padding:1.25rem}.sm\:p-6{padding:1.5rem}.sm\:px-3{padding-left:.75rem;padding-right:.75rem}.sm\:px-3\.5{padding-left:.875rem;padding-right:.875rem}.sm\:px-8{padding-left:2rem;padding-right:2rem}.sm\:py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.sm\:text-left{text-align:left}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-\[13px\]{font-size:13px}.sm\:text-\[15px\]{font-size:15px}.sm\:text-\[2\.75rem\]{font-size:2.75rem}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}.sm\:text-xs{font-size:.75rem;line-height:1rem}.sm\:leading-5{line-height:1.25rem}.sm\:leading-7{line-height:1.75rem}.data-\[state\=open\]\:sm\:slide-in-from-bottom-full[data-state=open]{--tw-enter-translate-y: 100%}}@media (min-width: 768px){.md\:col-span-2{grid-column:span 2 / span 2}.md\:block{display:block}.md\:flex{display:flex}.md\:inline-flex{display:inline-flex}.md\:grid{display:grid}.md\:hidden{display:none}.md\:w-48{width:12rem}.md\:w-\[160px\]{width:160px}.md\:w-\[220px\]{width:220px}.md\:w-auto{width:auto}.md\:max-w-\[420px\]{max-width:420px}.md\:max-w-xl{max-width:36rem}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-\[minmax\(0\,1fr\)_auto_minmax\(0\,1fr\)_auto\]{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr) auto}.md\:flex-row{flex-direction:row}.md\:flex-wrap{flex-wrap:wrap}.md\:items-start{align-items:flex-start}.md\:items-center{align-items:center}.md\:justify-between{justify-content:space-between}.md\:px-0{padding-left:0;padding-right:0}}@media (min-width: 1024px){.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:mx-0{margin-left:0;margin-right:0}.lg\:ml-3{margin-left:.75rem}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:h-\[calc\(100vh-64px\)\]{height:calc(100vh - 64px)}.lg\:max-h-none{max-height:none}.lg\:min-h-0{min-height:0px}.lg\:w-\[300px\]{width:300px}.lg\:w-auto{width:auto}.lg\:max-w-3xl{max-width:48rem}.lg\:max-w-\[680px\]{max-width:680px}.lg\:flex-1{flex:1 1 0%}.lg\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-\[1\.4fr_repeat\(3\,minmax\(0\,1fr\)\)\]{grid-template-columns:1.4fr repeat(3,minmax(0,1fr))}.lg\:grid-cols-\[1fr_auto\]{grid-template-columns:1fr auto}.lg\:grid-cols-\[80px_minmax\(0\,0\.8fr\)_minmax\(0\,1\.1fr\)\]{grid-template-columns:80px minmax(0,.8fr) minmax(0,1.1fr)}.lg\:grid-cols-\[minmax\(0\,0\.82fr\)_auto\]{grid-template-columns:minmax(0,.82fr) auto}.lg\:grid-cols-\[minmax\(0\,1\.2fr\)_minmax\(300px\,0\.8fr\)\]{grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr)}.lg\:grid-cols-\[minmax\(0\,1fr\)_auto\]{grid-template-columns:minmax(0,1fr) auto}.lg\:grid-cols-\[minmax\(0\,1fr\)_minmax\(0\,0\.85fr\)\]{grid-template-columns:minmax(0,1fr) minmax(0,.85fr)}.lg\:grid-cols-\[minmax\(0\,1fr\)_minmax\(280px\,0\.6fr\)\]{grid-template-columns:minmax(0,1fr) minmax(280px,.6fr)}.lg\:grid-cols-\[minmax\(0\,1fr\)_minmax\(400px\,0\.8fr\)\]{grid-template-columns:minmax(0,1fr) minmax(400px,.8fr)}.lg\:flex-row{flex-direction:row}.lg\:flex-col{flex-direction:column}.lg\:flex-wrap{flex-wrap:wrap}.lg\:items-start{align-items:flex-start}.lg\:items-end{align-items:flex-end}.lg\:items-center{align-items:center}.lg\:justify-end{justify-content:flex-end}.lg\:justify-between{justify-content:space-between}.lg\:gap-0{gap:0px}.lg\:justify-self-start{justify-self:start}.lg\:overflow-hidden{overflow:hidden}.lg\:overflow-visible{overflow:visible}.lg\:px-10{padding-left:2.5rem;padding-right:2.5rem}.lg\:px-6{padding-left:1.5rem;padding-right:1.5rem}.lg\:py-14{padding-top:3.5rem;padding-bottom:3.5rem}.lg\:py-6{padding-top:1.5rem;padding-bottom:1.5rem}.lg\:pb-0{padding-bottom:0}.lg\:text-right{text-align:right}}@media (min-width: 1280px){.xl\:sticky{position:sticky}.xl\:top-24{top:6rem}.xl\:col-span-1{grid-column:span 1 / span 1}.xl\:col-span-2{grid-column:span 2 / span 2}.xl\:block{display:block}.xl\:hidden{display:none}.xl\:max-h-none{max-height:none}.xl\:w-auto{width:auto}.xl\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.xl\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.xl\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.xl\:grid-cols-\[200px_1fr\]{grid-template-columns:200px 1fr}.xl\:grid-cols-\[280px_minmax\(0\,1fr\)\]{grid-template-columns:280px minmax(0,1fr)}.xl\:grid-cols-\[minmax\(0\,0\.95fr\)_auto_auto\]{grid-template-columns:minmax(0,.95fr) auto auto}.xl\:grid-cols-\[minmax\(0\,0\.9fr\)_minmax\(0\,1\.1fr\)\]{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr)}.xl\:grid-cols-\[minmax\(0\,1\.04fr\)_minmax\(420px\,0\.96fr\)\]{grid-template-columns:minmax(0,1.04fr) minmax(420px,.96fr)}.xl\:grid-cols-\[minmax\(0\,1\.2fr\)_minmax\(300px\,0\.8fr\)\]{grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr)}.xl\:grid-cols-\[minmax\(0\,1\.35fr\)_minmax\(320px\,0\.85fr\)\]{grid-template-columns:minmax(0,1.35fr) minmax(320px,.85fr)}.xl\:grid-cols-\[minmax\(0\,1fr\)_280px\]{grid-template-columns:minmax(0,1fr) 280px}.xl\:flex-row{flex-direction:row}.xl\:flex-nowrap{flex-wrap:nowrap}.xl\:items-start{align-items:flex-start}.xl\:items-center{align-items:center}.xl\:justify-start{justify-content:flex-start}.xl\:justify-self-end{justify-self:end}.xl\:justify-self-center{justify-self:center}.xl\:px-10{padding-left:2.5rem;padding-right:2.5rem}.xl\:px-8{padding-left:2rem;padding-right:2rem}.xl\:py-9{padding-top:2.25rem;padding-bottom:2.25rem}.xl\:pl-4{padding-left:1rem}.xl\:text-\[1\.08rem\]{font-size:1.08rem}.xl\:text-\[3rem\]{font-size:3rem}.xl\:leading-\[1\.05\]{line-height:1.05}}@media (min-width: 1536px){.\32xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.\32xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&\>svg\]\:size-4>svg{width:1rem;height:1rem}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0px}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-width:0px}.\[\&_tr\]\:border-b tr{border-bottom-width:1px}.\[\&_tr\]\:border-border tr{border-color:hsl(var(--border))}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import{B as A,c as x}from"./global-CKvMKvrn.js";import{r as m,j as e,aa as C,ab as c,ac as f,ad as j,T as u,ae as h,O as I,af as S,ag as w,a9 as K,q as P}from"./vendor-LWJeAdU1.js";import{c as v}from"./clipboard-CALi6bTW.js";import{p as D}from"./package-BMIMFcQR.js";const p="/assets/live-dashboard-B7vLOY_S.png",R="/assets/live-logs-PRpgTV6S.png",L="/assets/live-model-management-xkBDeuLk.png",O="/assets/live-api-keys-CJUuaCev.png",T="/assets/live-events-D_njD291.png",N=D.version,g=[{href:"#architecture",label:"痛点"},{href:"#features",label:"收益"},{href:"#quickstart",label:"开始"},{href:"#console",label:"控制台"},{href:"#fit",label:"适合谁"},{href:"#faq",label:"FAQ"}],q=["OpenAI SDK","Anthropic SDK","Claude Code","cURL","LangChain","Vercel AI SDK"],B=[{value:"1 个",label:"团队统一入口"},{value:"少改",label:"业务代码少被打扰"},{value:"可查",label:"日志链路可追踪"},{value:"本地",label:"轻量自托管优先"}],F=["不用在每个项目里重复配置 baseURL 和 API Key","出问题先看日志、链路和 Profiler,不再靠猜","换 provider、模型和路由时,尽量不打扰业务代码"],U=[{title:"个人开发者",body:"你同时在用 Claude Code、OpenAI SDK 和几个脚本工具,已经不想再维护多套 Key 与地址。"},{title:"AI 产品小队",body:"团队开始共享模型调用,想统一入口、路由和日志,但还不想先上复杂平台。"},{title:"1-100 人研发团队",body:"需要给多个环境、多个客户端和不同成员分配调用权限,同时保留轻量自托管的灵活性。"}],W=[{icon:u,title:"换模型,不再到处改配置",body:"客户端继续请求同一个入口,模型映射、Provider 切换和路由策略交给网关处理。"},{icon:I,title:"排查问题,不再只能靠猜",body:"请求日志、上游链路、TTFT/TPOT、Token usage 和事件记录都能在控制台看到。"},{icon:j,title:"Key 管理,不再散落在脚本里",body:"为不同客户端、环境或成员创建独立 Key,方便审计、停用和隔离风险。"},{icon:c,title:"先本地跑,再给团队共享",body:"npm 安装即可启动,个人先试,团队需要时再迁到共享机器或轻量自托管实例。"}],E=[{icon:f,eyebrow:"01",title:"先接一个你已经在用的客户端",body:"从 Claude Code、OpenAI SDK 或 Anthropic SDK 里挑一个,不需要先迁所有项目。",detail:"目标是让第一个真实请求先跑通,并进入控制台可观测范围。"},{icon:j,eyebrow:"02",title:"把密钥和访问范围收回来",body:"给不同成员、环境或工具分开 API Key,避免继续共享同一个万能 Key。",detail:"这样做之后,停用、排查和审计都会轻很多。"},{icon:u,eyebrow:"03",title:"开始通过路由和日志持续调优",body:"模型切换、Provider 替换和请求追踪都逐步从业务代码外迁到网关层。",detail:"一旦流量和协作变复杂,价值会明显放大。"}],M=["客户端开始只认一个统一入口,而不是多套 base URL","调用问题能先在控制台定位,而不是在客户端里盲猜","模型和 Provider 的演进不必每次都打扰业务代码"],z=[{title:"先在本地跑起来",body:"不用先改团队流程,也不要求大家安装 Rust。先让一个统一入口可用。",code:`npm install -g @chenpu17/cc-gw
|
|
2
|
-
cc-gw start --foreground --port 4100`},{title:"接入一个现有客户端",body:"先选 Claude Code、OpenAI SDK 或 Anthropic SDK 中的一个,把 base URL 指到 cc-gw。",code:`baseURL = 'http://127.0.0.1:4100/openai/v1'
|
|
3
|
-
# 或 http://127.0.0.1:4100/anthropic`},{title:"开始用控制台接管日常",body:"请求进来后,再慢慢管理路由、日志、API Keys、事件和 Profiler。",code:`Product site: http://127.0.0.1:4100/
|
|
4
|
-
Console: http://127.0.0.1:4100/ui/`}],G=[{question:"我只有一个人用,也需要 cc-gw 吗?",answer:"如果你只有一个脚本、一个 provider,可能暂时不需要。但只要你同时用 Claude Code、OpenAI SDK、Anthropic SDK,或者经常切模型和 Key,一个统一入口就会省很多维护成本。"},{question:"它会不会绑死某个模型供应商?",answer:"不会。cc-gw 的价值正是把 Provider 和客户端解耦。客户端面对 cc-gw,背后的 OpenAI / Anthropic 兼容 Provider、模型映射和路由规则都可以继续调整。"},{question:"它是企业级 AI 平台吗?",answer:"不是。它更适合个人开发者、AI 产品小队和 1-100 人研发团队,用轻量方式先解决入口、日志、路由、Key 管理和排查问题,而不是做大型治理平台。"}],b=[{id:"dashboard",label:"Dashboard",shot:p},{id:"logs",label:"Logs",shot:R},{id:"models",label:"Models & Routing",shot:L},{id:"apikeys",label:"API Keys",shot:O},{id:"events",label:"Events",shot:T}];function o({id:a,eyebrow:l,title:r,description:d,children:i,className:s}){return e.jsxs("section",{id:a,className:x("mx-auto w-full max-w-6xl px-6 py-14 sm:px-8 lg:px-10",s),children:[e.jsxs("div",{className:"max-w-3xl",children:[e.jsx("div",{className:"text-sm font-semibold uppercase tracking-[0.16em] text-indigo-600",children:l}),e.jsx("h2",{className:"mt-3 text-2xl font-semibold tracking-tight text-slate-950 sm:text-3xl",children:r}),e.jsx("p",{className:"mt-4 text-base leading-8 text-slate-600 sm:text-lg",children:d})]}),e.jsx("div",{className:"mt-8",children:i})]})}function Q({href:a,children:l}){return e.jsx("a",{href:a,className:"rounded-full px-3 py-2 text-sm font-medium text-slate-600 transition hover:bg-slate-100 hover:text-slate-950",children:l})}function $(a){if(a.trimStart().startsWith("#"))return e.jsx("span",{className:"text-slate-400",children:a});const l=a.match(/^(\w+)(\s*=\s*)(.+)$/);if(l){const i=l[1]??"",s=l[2]??"",t=l[3]??"",n=t.startsWith("'")||t.startsWith('"');return e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"text-indigo-300",children:i}),e.jsx("span",{className:"text-slate-100",children:s}),e.jsx("span",{className:n?"text-emerald-400":"text-slate-100",children:t})]})}const r=a.match(/^([A-Za-z][A-Za-z\s]*:\s+)(.+)$/);if(r)return e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"text-indigo-300",children:r[1]}),e.jsx("span",{className:"text-emerald-400",children:r[2]})]});const d=a.split(/(--[\w-]+)/g);return d.length>1?e.jsx(e.Fragment,{children:d.map((i,s)=>i.startsWith("--")?e.jsx("span",{className:"text-indigo-300",children:i},s):e.jsx("span",{className:"text-slate-100",children:i},s))}):e.jsx("span",{className:"text-slate-100",children:a})}function H({code:a,label:l,className:r}){const[d,i]=m.useState(!1);async function s(){await v(a),i(!0),window.setTimeout(()=>i(!1),1800)}return e.jsxs("div",{className:x("relative min-w-0",r),children:[e.jsxs("button",{type:"button","aria-label":`复制 ${l}`,onClick:s,className:"absolute right-3 top-3 inline-flex items-center gap-1.5 rounded-xl border border-white/10 bg-white/10 px-2.5 py-1 text-[11px] font-semibold text-slate-100 transition hover:bg-white/15 sm:px-3 sm:py-1.5 sm:text-xs",children:[d?e.jsx(c,{className:"h-3.5 w-3.5"}):e.jsx(w,{className:"h-3.5 w-3.5"}),d?"已复制":"复制"]}),e.jsx("pre",{className:"max-w-full overflow-x-auto rounded-2xl bg-slate-950 p-4 text-xs leading-6 sm:p-5 sm:text-sm sm:leading-7",children:e.jsx("code",{children:a.split(`
|
|
5
|
-
`).map((t,n)=>e.jsx("span",{className:"block",children:$(t)},n))})})]})}function J(){const[a,l]=m.useState(!1),r="npm install -g @chenpu17/cc-gw";async function d(){await v(r),l(!0),window.setTimeout(()=>l(!1),1800)}return e.jsxs("div",{className:"inline-flex items-center gap-3 rounded-2xl border border-slate-200 bg-slate-50 pl-4 pr-2 py-2",children:[e.jsx("span",{className:"select-all font-mono text-sm text-slate-700",children:r}),e.jsxs("span",{className:"rounded-full bg-slate-100 px-2 py-1 text-xs font-medium text-slate-500",children:["v",N]}),e.jsx("button",{type:"button","aria-label":"复制安装命令",onClick:d,className:"inline-flex h-7 w-7 items-center justify-center rounded-xl bg-white text-slate-500 shadow-sm transition hover:bg-slate-100 hover:text-slate-700",children:a?e.jsx(c,{className:"h-3.5 w-3.5 text-emerald-500"}):e.jsx(w,{className:"h-3.5 w-3.5"})})]})}function V(){var i;const[a,l]=m.useState("dashboard"),[r,d]=m.useState(null);return e.jsxs("div",{className:"min-h-screen bg-[radial-gradient(circle_at_top,#eef4ff_0%,#f8fbff_26%,#ffffff_62%)] text-slate-950",children:[e.jsxs("header",{className:"sticky top-0 z-20 border-b border-white/70 bg-white/88 backdrop-blur-xl",children:[e.jsxs("div",{className:"mx-auto flex w-full max-w-6xl items-center justify-between px-6 py-4 sm:px-8 lg:px-10",children:[e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(A,{className:"h-11 w-11 shadow-[0_18px_40px_-24px_rgba(79,70,229,0.55)]",title:"cc-gw"}),e.jsxs("div",{children:[e.jsx("div",{className:"text-lg font-semibold tracking-tight",children:"cc-gw"}),e.jsx("div",{className:"text-xs text-slate-500",children:"AI gateway for builders"})]})]}),e.jsx("nav",{className:"hidden items-center gap-1 md:flex",children:g.map(s=>e.jsx(Q,{href:s.href,children:s.label},s.href))}),e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("a",{href:"/ui/",className:"hidden rounded-full border border-slate-300 bg-white px-4 py-2 text-sm font-medium text-slate-700 transition hover:border-slate-400 hover:text-slate-950 sm:inline-flex",children:"打开控制台"}),e.jsxs("a",{href:"https://github.com/chenpu17/cc-gw2",className:"inline-flex items-center gap-2 rounded-full bg-indigo-600 px-4 py-2 text-sm font-medium text-white transition hover:bg-indigo-500",children:["GitHub",e.jsx(C,{className:"h-4 w-4"})]})]})]}),e.jsx("nav",{"aria-label":"移动端页面导航",className:"flex gap-2 overflow-x-auto border-t border-slate-200/70 px-4 py-2 md:hidden",children:[...g,{href:"/ui/",label:"打开控制台"}].map(s=>e.jsx("a",{href:s.href,className:"shrink-0 rounded-full bg-slate-100 px-3 py-1.5 text-sm font-medium text-slate-700",children:s.label},s.href))})]}),e.jsxs("main",{children:[e.jsx("section",{className:"mx-auto w-full max-w-6xl px-6 py-12 sm:px-8 lg:px-10 lg:py-14",children:e.jsx("div",{className:"overflow-hidden rounded-[2rem] border border-white/70 bg-white/78 px-6 py-8 shadow-[0_30px_80px_-44px_rgba(15,23,42,0.24)] ring-1 ring-slate-900/5 backdrop-blur xl:px-8 xl:py-9",children:e.jsxs("div",{className:"grid gap-8 xl:grid-cols-[minmax(0,1.04fr)_minmax(420px,0.96fr)] xl:items-center",children:[e.jsxs("div",{children:[e.jsx("div",{className:"inline-flex items-center rounded-full border border-indigo-100 bg-indigo-50/80 px-4 py-2 text-sm font-semibold text-indigo-700 shadow-sm",children:"Local-first · Open Source · Rust-powered"}),e.jsxs("h1",{className:"mt-5 max-w-4xl text-[2.25rem] font-bold tracking-[-0.04em] text-slate-950 sm:text-[2.75rem] xl:text-[3rem] xl:leading-[1.05]",children:["别再让 AI 配置",e.jsx("span",{className:"block bg-gradient-to-r from-indigo-700 via-violet-600 to-cyan-600 bg-clip-text text-transparent",children:"散落在每个项目里"})]}),e.jsx("p",{className:"mt-5 max-w-2xl text-[1.02rem] leading-8 text-slate-600 xl:text-[1.08rem]",children:"cc-gw 帮你把 Claude Code、OpenAI SDK、Anthropic SDK 和内部工具统一到一个本地优先入口。Key、路由、日志和排查都回到控制台里管理。"}),e.jsx("div",{className:"mt-5 hidden gap-2.5 md:grid md:max-w-xl",children:F.map(s=>e.jsxs("div",{className:"flex items-center gap-3 rounded-2xl border border-slate-200/70 bg-white/80 px-4 py-3 text-sm text-slate-700 shadow-[0_10px_30px_-24px_rgba(15,23,42,0.18)]",children:[e.jsx(c,{className:"h-4 w-4 shrink-0 text-emerald-500"}),e.jsx("span",{children:s})]},s))}),e.jsxs("div",{className:"mt-7 flex flex-wrap items-center gap-3",children:[e.jsxs("a",{href:"https://www.npmjs.com/package/@chenpu17/cc-gw",className:"inline-flex items-center justify-center gap-2 rounded-2xl bg-gradient-to-r from-indigo-600 to-violet-600 px-5 py-3 text-sm font-semibold text-white shadow-[0_18px_36px_-20px_rgba(79,70,229,0.6)] transition hover:from-indigo-500 hover:to-violet-500",children:[e.jsx(f,{className:"h-4 w-4"}),"3 分钟开始接入"]}),e.jsx("a",{href:"/ui/",className:"inline-flex items-center justify-center rounded-2xl border border-slate-300 bg-white px-5 py-3 text-sm font-semibold text-slate-800 transition hover:border-slate-400",children:"先看控制台 →"})]}),e.jsx("p",{className:"mt-3 text-sm text-slate-500",children:"不用先改团队流程。先接一个客户端,看到价值后再慢慢迁移。"}),e.jsx("div",{className:"mt-5",children:e.jsx(J,{})}),e.jsxs("div",{className:"mt-5",children:[e.jsx("div",{className:"text-xs font-semibold uppercase tracking-[0.16em] text-slate-400",children:"Works with"}),e.jsx("div",{className:"mt-3 flex flex-wrap gap-2",children:q.map(s=>e.jsx("div",{className:"rounded-full border border-slate-200 bg-slate-50/88 px-3 py-1.5 text-sm text-slate-700",children:s},s))})]})]}),e.jsxs("div",{className:"relative xl:pl-4",children:[e.jsx("div",{className:"absolute inset-x-6 top-0 h-36 rounded-full bg-gradient-to-r from-indigo-200/60 via-violet-200/45 to-cyan-200/55 blur-3xl"}),e.jsxs("div",{className:"relative rounded-[2rem] border border-white/80 bg-gradient-to-b from-white to-slate-50 p-3 shadow-[0_32px_80px_-40px_rgba(15,23,42,0.34)] ring-1 ring-slate-900/5",children:[e.jsxs("div",{className:"flex items-center gap-1.5 border-b border-slate-100 px-4 py-3",children:[e.jsx("div",{className:"h-3 w-3 rounded-full bg-slate-200"}),e.jsx("div",{className:"h-3 w-3 rounded-full bg-slate-200"}),e.jsx("div",{className:"h-3 w-3 rounded-full bg-slate-200"}),e.jsx("div",{className:"ml-3 flex-1 rounded-md bg-slate-100 px-3 py-1 text-xs text-slate-400",children:"http://127.0.0.1:4100/ui/"})]}),e.jsx("img",{src:p,alt:"cc-gw dashboard screenshot",className:"max-h-[340px] w-full rounded-[1.25rem] object-cover object-top sm:max-h-[440px] xl:max-h-none"})]}),e.jsxs("div",{className:"mt-4 hidden gap-3 sm:grid sm:grid-cols-2",children:[e.jsxs("div",{className:"rounded-2xl border border-white/80 bg-white/88 p-4 shadow-[0_18px_40px_-30px_rgba(15,23,42,0.28)]",children:[e.jsx("div",{className:"text-xs font-semibold uppercase tracking-[0.16em] text-slate-400",children:"Live Ops"}),e.jsx("div",{className:"mt-2 text-3xl font-bold tracking-tight text-slate-950",children:"12"}),e.jsx("div",{className:"mt-1 text-sm text-slate-600",children:"Active Requests right now"})]}),e.jsxs("div",{className:"rounded-2xl border border-white/80 bg-gradient-to-br from-indigo-50 via-white to-cyan-50 p-4 shadow-[0_18px_40px_-30px_rgba(15,23,42,0.22)]",children:[e.jsx("div",{className:"text-xs font-semibold uppercase tracking-[0.16em] text-slate-400",children:"Included"}),e.jsx("div",{className:"mt-2 text-sm font-semibold text-slate-900",children:"Logs · Routing · API Keys · Profiler"}),e.jsx("div",{className:"mt-1 text-sm text-slate-600",children:"不是单纯转发,而是可管理的团队入口。"})]})]})]})]})})}),e.jsx("div",{className:"py-6",children:e.jsx("div",{className:"mx-auto grid max-w-6xl gap-4 px-6 sm:grid-cols-2 sm:px-8 xl:grid-cols-4 xl:px-10",children:B.map(({value:s,label:t})=>e.jsxs("div",{className:"rounded-[1.4rem] border border-white/75 bg-white/82 px-6 py-5 shadow-[0_20px_50px_-36px_rgba(15,23,42,0.26)] ring-1 ring-slate-900/5",children:[e.jsx("div",{className:"text-3xl font-bold tracking-tight text-slate-950",children:s}),e.jsx("div",{className:"mt-1 text-sm text-slate-500",children:t})]},t))})}),e.jsx(o,{eyebrow:"Day One",title:"从用户视角看,cc-gw 的第一天应该是轻量、可见、可回退的",description:"不是先重构整套 AI 平台,而是先让一个客户端进来、一个入口稳定下来、一次排查变得更简单。",className:"pt-4",children:e.jsxs("div",{className:"grid gap-5 lg:grid-cols-[minmax(0,1.2fr)_minmax(300px,0.8fr)]",children:[e.jsx("div",{className:"grid gap-4",children:E.map(({icon:s,eyebrow:t,title:n,body:_,detail:k})=>e.jsxs("div",{className:"grid gap-4 rounded-[1.6rem] border border-white/80 bg-white/88 p-5 shadow-[0_18px_48px_-36px_rgba(15,23,42,0.22)] sm:grid-cols-[auto_minmax(0,1fr)] sm:items-start",children:[e.jsx("div",{className:"flex h-12 w-12 items-center justify-center rounded-2xl bg-gradient-to-br from-indigo-100 to-cyan-100 text-indigo-600",children:e.jsx(s,{className:"h-5 w-5"})}),e.jsxs("div",{className:"min-w-0",children:[e.jsx("div",{className:"text-[11px] font-semibold uppercase tracking-[0.18em] text-indigo-500",children:t}),e.jsx("h3",{className:"mt-2 text-lg font-semibold text-slate-950",children:n}),e.jsx("p",{className:"mt-2 text-sm leading-7 text-slate-600",children:_}),e.jsx("div",{className:"mt-3 rounded-2xl bg-slate-50 px-4 py-3 text-sm leading-6 text-slate-500 ring-1 ring-slate-200/70",children:k})]})]},n))}),e.jsxs("div",{className:"rounded-[1.8rem] border border-slate-900/10 bg-slate-950 px-6 py-6 text-white shadow-[0_24px_64px_-38px_rgba(15,23,42,0.5)]",children:[e.jsx("div",{className:"inline-flex items-center rounded-full border border-white/10 bg-white/5 px-3 py-1 text-[11px] font-semibold uppercase tracking-[0.16em] text-indigo-200",children:"What You Get"}),e.jsx("h3",{className:"mt-4 text-2xl font-semibold tracking-tight",children:"不是更重的治理系统,而是更顺手的 AI 工作台"}),e.jsx("p",{className:"mt-3 text-sm leading-7 text-slate-300",children:"对个人开发者和小团队来说,价值不是“功能全”,而是接入当天就能少踩坑、少改配置、少猜问题。"}),e.jsx("div",{className:"mt-5 space-y-3",children:M.map(s=>e.jsxs("div",{className:"flex items-start gap-3 rounded-2xl border border-white/10 bg-white/5 px-4 py-3",children:[e.jsx(c,{className:"mt-0.5 h-4 w-4 shrink-0 text-emerald-300"}),e.jsx("span",{className:"text-sm leading-6 text-slate-200",children:s})]},s))}),e.jsx("div",{className:"mt-6 grid gap-3 sm:grid-cols-3 lg:grid-cols-1",children:[{value:"3-10 分钟",label:"通常能完成第一次接入"},{value:"1 个入口",label:"客户端开始收口到同一地址"},{value:"先本地",label:"看到价值后再考虑共享部署"}].map(s=>e.jsxs("div",{className:"rounded-2xl bg-white/6 px-4 py-3 ring-1 ring-white/10",children:[e.jsx("div",{className:"text-lg font-semibold text-white",children:s.value}),e.jsx("div",{className:"mt-1 text-xs text-slate-300",children:s.label})]},s.label))})]})]})}),e.jsx(o,{id:"architecture",eyebrow:"Why",title:"AI 接入一多,最先乱的不是模型,而是日常维护",description:"用户真正遇到的问题,通常不是“能不能调通”,而是调通之后配置散落、Key 难管、日志难查、模型切换牵一发动全身。",children:e.jsxs("div",{className:"grid gap-5 lg:grid-cols-2",children:[e.jsxs("div",{className:"rounded-[1.6rem] border border-rose-100 bg-white/88 p-6 shadow-[0_18px_44px_-34px_rgba(15,23,42,0.22)]",children:[e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-xl bg-rose-50 text-rose-500",children:e.jsx(h,{className:"h-5 w-5"})}),e.jsxs("div",{children:[e.jsx("p",{className:"text-xs font-semibold uppercase tracking-[0.16em] text-rose-500",children:"Before"}),e.jsx("h3",{className:"text-lg font-semibold text-slate-950",children:"没有统一入口时"})]})]}),e.jsx("div",{className:"mt-5 space-y-4",children:[{title:"配置到处复制",body:"每个项目、脚本、客户端都有自己的 base URL、Key 和模型名,时间一久没人敢动。"},{title:"报错难以定位",body:"到底是客户端 payload、协议转换、上游模型,还是 Key 权限问题?没有统一日志就只能猜。"},{title:"切换成本太高",body:"想换 Provider、改默认模型或拆环境,经常要动业务代码、环境变量和多人本地配置。"}].map(s=>e.jsxs("div",{className:"rounded-2xl border border-rose-100/80 bg-rose-50/50 px-4 py-4",children:[e.jsx("h4",{className:"text-sm font-semibold text-slate-950",children:s.title}),e.jsx("p",{className:"mt-1.5 text-sm leading-7 text-slate-600",children:s.body})]},s.title))})]}),e.jsxs("div",{className:"rounded-[1.6rem] border border-emerald-100 bg-white/88 p-6 shadow-[0_18px_44px_-34px_rgba(15,23,42,0.22)]",children:[e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-xl bg-emerald-50 text-emerald-500",children:e.jsx(c,{className:"h-5 w-5"})}),e.jsxs("div",{children:[e.jsx("p",{className:"text-xs font-semibold uppercase tracking-[0.16em] text-emerald-500",children:"After"}),e.jsx("h3",{className:"text-lg font-semibold text-slate-950",children:"有了 cc-gw 之后"})]})]}),e.jsx("div",{className:"mt-5 space-y-4",children:[{title:"客户端只认一个入口",body:"Claude Code、OpenAI SDK、Anthropic SDK 和内部工具都先接到 cc-gw,配置明显收敛。"},{title:"日志和链路有地方看",body:"请求是否进来、打到了哪里、哪里慢、哪里错,都可以先从控制台开始排查。"},{title:"路由演进不打扰业务",body:"改默认模型、切 Provider、拆 endpoint 或按客户端分 Key,都尽量留在网关层完成。"}].map(s=>e.jsxs("div",{className:"rounded-2xl border border-emerald-100/80 bg-emerald-50/50 px-4 py-4",children:[e.jsx("h4",{className:"text-sm font-semibold text-slate-950",children:s.title}),e.jsx("p",{className:"mt-1.5 text-sm leading-7 text-slate-600",children:s.body})]},s.title))})]})]})}),e.jsx(o,{id:"features",eyebrow:"Benefits",title:"它先解决的是接入后的维护成本,不是再发明一套平台流程",description:"当你已经开始同时接多个模型、多个客户端和多个环境时,cc-gw 的价值体现在收口入口、保留观测性,并把变更尽量留在网关层。",children:e.jsx("div",{className:"grid gap-4 md:grid-cols-2",children:W.map(({icon:s,title:t,body:n})=>e.jsxs("div",{className:"rounded-[1.5rem] border border-white/80 bg-white/88 p-6 shadow-[0_18px_44px_-34px_rgba(15,23,42,0.26)] transition-shadow hover:shadow-[0_24px_54px_-34px_rgba(15,23,42,0.3)]",children:[e.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-xl bg-gradient-to-br from-indigo-100 to-cyan-100 text-indigo-600",children:e.jsx(s,{className:"h-5 w-5"})}),e.jsx("div",{className:"mt-4 text-lg font-semibold text-slate-950",children:t}),e.jsx("p",{className:"mt-2 text-sm leading-7 text-slate-600",children:n})]},t))})}),e.jsx(o,{id:"quickstart",eyebrow:"Quick Start",title:"先接一个客户端,马上看到价值",description:"不用一次性迁完整个团队。先从一个常用客户端开始,把请求、日志和路由接进控制台。",className:"pt-2",children:e.jsx("div",{className:"space-y-4",children:z.map((s,t)=>e.jsxs("div",{className:"grid gap-5 rounded-[1.6rem] border border-white/80 bg-white/88 p-5 shadow-[0_18px_48px_-36px_rgba(15,23,42,0.26)] lg:grid-cols-[80px_minmax(0,0.8fr)_minmax(0,1.1fr)] lg:items-start",children:[e.jsxs("div",{className:"flex h-14 w-14 items-center justify-center rounded-2xl bg-gradient-to-br from-indigo-100 to-violet-100 text-lg font-semibold text-indigo-700",children:["0",t+1]}),e.jsxs("div",{children:[e.jsx("div",{className:"text-lg font-semibold text-slate-950",children:s.title}),e.jsx("p",{className:"mt-3 text-sm leading-7 text-slate-600",children:s.body})]}),e.jsx(H,{label:`${s.title}代码`,code:s.code})]},s.title))})}),e.jsx(o,{id:"console",eyebrow:"Console",title:"控制台不是摆设,是你每天排查和切换的地方",description:"请求进来之后,你能看到趋势、过滤日志、调整路由、管理 API Keys,并用 Profiler 追踪慢请求和异常。",children:e.jsxs("div",{className:"overflow-hidden rounded-[1.7rem] border border-white/80 bg-white/88 shadow-[0_22px_56px_-38px_rgba(15,23,42,0.28)] ring-1 ring-slate-900/5",children:[e.jsx("div",{className:"flex flex-wrap gap-1 border-b border-slate-100 px-4 pt-4",children:b.map(s=>e.jsx("button",{type:"button",onClick:()=>l(s.id),className:x("rounded-t-lg px-4 py-2 text-sm font-medium transition-colors",a===s.id?"border-b-2 border-indigo-600 bg-indigo-50 text-indigo-700":"text-slate-500 hover:text-slate-900"),children:s.label},s.id))}),e.jsx("div",{className:"p-4",children:e.jsx("img",{src:((i=b.find(s=>s.id===a))==null?void 0:i.shot)??p,alt:a,className:"w-full rounded-xl border border-slate-100"})}),e.jsx("div",{className:"grid gap-3 px-4 pb-4 md:grid-cols-3",children:["先看请求有没有进来,再看它去了哪个上游、用了多少 Token、哪里慢。","业务代码只面对一个入口,协议兼容和模型路由留给网关慢慢演进。","更像小团队自己的 AI 调用工作台,而不是只会转发请求的代理。"].map(s=>e.jsx("div",{className:"rounded-xl border border-slate-100 bg-gradient-to-br from-slate-50 to-white px-4 py-3 text-sm leading-6 text-slate-600",children:s},s))})]})}),e.jsxs(o,{id:"fit",eyebrow:"Fit",title:"什么时候它会明显省事,什么时候你其实还不需要它",description:"如果你的 AI 接入已经开始扩张,但又没到要上组织级治理平台的程度,cc-gw 往往正好卡在那个合适的区间。",children:[e.jsx("div",{className:"mb-5 grid gap-4 lg:grid-cols-3",children:U.map(s=>e.jsxs("div",{className:"rounded-[1.45rem] border border-white/80 bg-white/88 p-5 shadow-[0_18px_40px_-34px_rgba(15,23,42,0.18)]",children:[e.jsx("p",{className:"text-sm font-semibold text-slate-950",children:s.title}),e.jsx("p",{className:"mt-2 text-sm leading-7 text-slate-600",children:s.body})]},s.title))}),e.jsxs("div",{className:"grid gap-5 lg:grid-cols-2",children:[e.jsxs("div",{className:"rounded-[1.6rem] border border-emerald-100 bg-emerald-50/72 p-7 shadow-[0_18px_46px_-34px_rgba(16,185,129,0.22)]",children:[e.jsxs("div",{className:"mb-4 flex items-center gap-2",children:[e.jsx("div",{className:"flex h-8 w-8 items-center justify-center rounded-lg bg-emerald-100",children:e.jsx(c,{className:"h-4 w-4 text-emerald-600"})}),e.jsx("h3",{className:"text-base font-semibold text-slate-900",children:"适合谁"})]}),e.jsx("ul",{className:"space-y-2.5",children:["个人开发者、AI 产品小队","1-100 人的软件研发团队","正在用多个 AI provider 的团队","觉得 key、baseURL 和模型配置越来越乱","想要先收口再慢慢治理的团队"].map(s=>e.jsxs("li",{className:"flex items-start gap-2.5 text-sm text-slate-700",children:[e.jsx(c,{className:"mt-0.5 h-4 w-4 shrink-0 text-emerald-500"}),s]},s))})]}),e.jsxs("div",{className:"rounded-[1.6rem] border border-slate-200 bg-white/78 p-7 shadow-[0_18px_46px_-34px_rgba(15,23,42,0.16)]",children:[e.jsxs("div",{className:"mb-4 flex items-center gap-2",children:[e.jsx("div",{className:"flex h-8 w-8 items-center justify-center rounded-lg bg-slate-200",children:e.jsx(h,{className:"h-4 w-4 text-slate-500"})}),e.jsx("h3",{className:"text-base font-semibold text-slate-900",children:"不适合谁"})]}),e.jsx("ul",{className:"space-y-2.5",children:["需要跨 BU 统一治理的大企业","需要复杂审批流程和审计流转","企业 SSO 与组织级策略中台","需要 HA/高可用集群部署","Compliance-first 的金融/医疗场景"].map(s=>e.jsxs("li",{className:"flex items-start gap-2.5 text-sm text-slate-700",children:[e.jsx(h,{className:"mt-0.5 h-4 w-4 shrink-0 text-slate-400"}),s]},s))})]})]})]}),e.jsxs(o,{id:"faq",eyebrow:"FAQ",title:"常见问题",description:"从是否值得试、是否会绑死、是否过重这几个用户关心的问题开始。",className:"pb-24",children:[e.jsx("div",{className:"grid gap-4",children:G.map((s,t)=>e.jsxs("div",{className:"overflow-hidden rounded-[1.35rem] border border-white/80 bg-white/88 shadow-[0_16px_40px_-34px_rgba(15,23,42,0.2)]",children:[e.jsxs("button",{type:"button",onClick:()=>d(r===t?null:t),className:"flex w-full items-center justify-between px-6 py-5 text-left",children:[e.jsx("span",{className:"text-base font-semibold text-slate-900",children:s.question}),e.jsx(S,{className:x("h-5 w-5 text-slate-400 transition-transform",r===t&&"rotate-180")})]}),r===t&&e.jsx("div",{className:"px-6 pb-5 text-sm leading-7 text-slate-600",children:s.answer})]},s.question))}),e.jsx("div",{className:"relative mt-8 overflow-hidden rounded-[1.8rem] border border-slate-800/20 bg-slate-950 px-8 py-10 text-white shadow-[0_28px_80px_-44px_rgba(15,23,42,0.5)]",style:{backgroundImage:"radial-gradient(circle at top left, rgba(129,140,248,0.2), transparent 32%), radial-gradient(circle at bottom right, rgba(34,211,238,0.12), transparent 28%), radial-gradient(rgba(255,255,255,0.07) 1px, transparent 1px)",backgroundSize:"auto, auto, 24px 24px"},children:e.jsxs("div",{className:"relative grid gap-8 lg:grid-cols-[1fr_auto] lg:items-end",children:[e.jsxs("div",{children:[e.jsx("div",{className:"text-3xl font-semibold tracking-tight",children:"先把 AI 调用管顺,再慢慢扩展团队协作。"}),e.jsx("p",{className:"mt-4 max-w-3xl text-base leading-8 text-slate-300",children:"不需要一开始就建设企业级平台。先用 cc-gw 把入口、路由、日志和 Key 管理收回来,今天就能开始。"})]}),e.jsxs("div",{className:"flex flex-col gap-3 sm:flex-row lg:flex-col",children:[e.jsx("a",{href:"https://www.npmjs.com/package/@chenpu17/cc-gw",className:"inline-flex items-center justify-center rounded-2xl bg-white px-5 py-3 text-sm font-semibold text-slate-950 transition hover:bg-slate-100",children:"npm 安装"}),e.jsx("a",{href:"/ui/",className:"inline-flex items-center justify-center rounded-2xl border border-white/20 bg-white/5 px-5 py-3 text-sm font-semibold text-white transition hover:bg-white/10",children:"打开控制台"})]})]})})]})]}),e.jsx("footer",{className:"border-t border-white/80 bg-white/70",children:e.jsxs("div",{className:"mx-auto flex w-full max-w-5xl flex-col gap-4 px-6 py-8 text-sm text-slate-500 sm:px-8 lg:flex-row lg:items-center lg:justify-between lg:px-10",children:[e.jsxs("div",{children:[e.jsx("div",{children:"cc-gw · Local-first AI gateway for personal developers and small software teams."}),e.jsxs("div",{className:"mt-1 text-xs",children:["v",N]})]}),e.jsxs("div",{className:"flex flex-wrap gap-4",children:[e.jsx("a",{href:"/ui/",className:"hover:text-slate-900",children:"控制台"}),e.jsx("a",{href:"https://www.npmjs.com/package/@chenpu17/cc-gw",className:"hover:text-slate-900",children:"npm"}),e.jsx("a",{href:"https://github.com/chenpu17/cc-gw2",className:"hover:text-slate-900",children:"GitHub"}),e.jsx("a",{href:"https://github.com/chenpu17/cc-gw2/releases",className:"hover:text-slate-900",children:"Changelog"})]})]})})]})}const y=document.getElementById("landing-root");if(!y)throw new Error("Root element #landing-root not found");K.createRoot(y).render(e.jsx(P.StrictMode,{children:e.jsx(V,{})}));
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
const o="0.8.13",s={version:o};export{s as p};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{r as m}from"./vendor-LWJeAdU1.js";import{u as qt,a as Bt}from"./query-Cpxr1dul.js";import{g as H,b as G,u as Nt,t as re,c as ie}from"./app-BG16DmZH.js";import{g as F}from"./gateway-CExOTXeI.js";import{q as U}from"./queryKeys-DTnZc8Yy.js";import{u as $e}from"./useAppMutation-ChCrgiP6.js";import{u as Ut}from"./useApiQuery-jSeDDFuv.js";import{u as Vt}from"./i18n-B3N4Df3E.js";const _={savePreset(n,i){return H(G.post(`/api/routing-presets/${n}`,{name:i}))},applyPreset(n,i){return H(G.post(`/api/routing-presets/${n}/apply`,{name:i}))},deletePreset(n,i){return H(G.delete(`/api/routing-presets/${n}/${encodeURIComponent(i)}`))},testProvider(n,i){return H(G.post(`/api/providers/${n}/test`,i))}},Zt=["claude-sonnet-4-5-20250929","claude-sonnet-4-5-20250929-thinking","claude-sonnet-4-20250514","claude-opus-4-1-20250805","claude-opus-4-1-20250805-thinking","claude-haiku-4-5-20251001","claude-haiku-4-5-20251001-thinking","claude-3-5-haiku-20241022"],en=["gpt-4o-mini","gpt-4o","o4-mini","o4-large","gpt-5-codex"];function O(){return typeof crypto<"u"&&typeof crypto.randomUUID=="function"?crypto.randomUUID():Math.random().toString(36).slice(2,10)}function J(n,i){var p;return(p=n==null?void 0:n.customEndpoints)!=null&&p.length?n.customEndpoints:i}function le(n){return n?Object.entries(n).map(([i,p])=>({id:O(),source:i,target:p})):[]}function ue(n,i){var h,f,g;if(!n)return{};const p={},d=n.endpointRouting??{};p.anthropic=le(((h=d.anthropic)==null?void 0:h.modelRoutes)??n.modelRoutes??{}),p.openai=le(((f=d.openai)==null?void 0:f.modelRoutes)??{});for(const y of J(n,i))(g=y.routing)!=null&&g.modelRoutes?p[y.id]=le(y.routing.modelRoutes):p[y.id]=[];return p}function Fe(n,i,p){var f,g,y;const d=J(n,i).find(j=>j.id===p);if(d)return((f=d.routing)==null?void 0:f.modelRoutes)??{};const h=n.endpointRouting??{};return p==="anthropic"?((g=h.anthropic)==null?void 0:g.modelRoutes)??n.modelRoutes??{}:p==="openai"?((y=h.openai)==null?void 0:y.modelRoutes)??{}:{}}function Qt(n){const i={};for(const p of n){const d=p.source.trim(),h=p.target.trim();d&&h&&(i[d]=h)}return i}function je(n,i){return JSON.stringify(Qt(n))!==JSON.stringify(i)}function tn(n,i){if(n==="anthropic")return!0;const p=i.find(d=>d.id===n);return p?p.paths&&p.paths.length>0?p.paths.some(d=>d.protocol==="anthropic"):p.protocol==="anthropic":!1}function nn(n,i,p){var h,f,g;if(!i)return;if(n==="anthropic"||n==="openai")return(f=(h=i.endpointRouting)==null?void 0:h[n])==null?void 0:f.validation;const d=J(i,p).find(y=>y.id===n);return(g=d==null?void 0:d.routing)==null?void 0:g.validation}function sn(n,i,p){var h,f,g;if(!i)return;if(n==="anthropic"||n==="openai")return(f=(h=i.endpointRouting)==null?void 0:h[n])==null?void 0:f.compatibility;const d=J(i,p).find(y=>y.id===n);return(g=d==null?void 0:d.routing)==null?void 0:g.compatibility}function zt(n,i){const p=[{key:"providers",label:n("modelManagement.tabs.providers"),description:n("modelManagement.tabs.providersDesc"),isSystem:!0,canDelete:!1},{key:"anthropic",label:n("modelManagement.tabs.anthropic"),description:n("modelManagement.tabs.anthropicDesc"),isSystem:!0,canDelete:!1,protocols:["anthropic"]},{key:"openai",label:n("modelManagement.tabs.openai"),description:n("modelManagement.tabs.openaiDesc"),isSystem:!0,canDelete:!1,protocols:["openai-auto","openai-chat","openai-responses"]}],d=i.map(h=>{let f=n("modelManagement.tabs.customEndpoint"),g=[];if(h.paths&&h.paths.length>0)f=`${n("modelManagement.tabs.customEndpoint")}: ${h.paths.map(y=>`${y.path} (${y.protocol})`).join(", ")}`,g=[...new Set(h.paths.map(y=>y.protocol))];else if(h.path){const y=h.protocol||"anthropic";f=`${n("modelManagement.tabs.customEndpoint")}: ${h.path} (${y})`,g=[y]}return{key:h.id,label:h.label||h.id,description:f,isSystem:!1,canDelete:h.deletable!==!1,protocols:g}});return[...p,...d]}function At(n){return n.label&&n.label.trim().length>0?`${n.label} (${n.id})`:n.id}function Ie(n,i){var d,h,f;const p={anthropic:((d=n.routingPresets)==null?void 0:d.anthropic)??[],openai:((h=n.routingPresets)==null?void 0:h.openai)??[]};for(const g of i){const y=(f=n.customEndpoints)==null?void 0:f.find(j=>j.id===g.id);p[g.id]=(y==null?void 0:y.routingPresets)??g.routingPresets??[]}return p}function on(){var Oe;const{t:n}=Vt(),{pushToast:i}=Nt(),p=qt(),d=Ut(U.config.full(),F.configRequest()),f=((Oe=Bt({queryKey:U.customEndpoints.all(),queryFn:ie.list,refetchInterval:1e4}).data)==null?void 0:Oe.endpoints)??[],g=m.useMemo(()=>zt(n,f),[f,n]),[y,j]=m.useState("providers"),[l,k]=m.useState(null),[Le,W]=m.useState(!1),[X,Y]=m.useState("create"),[V,Z]=m.useState(void 0),[qe,ee]=m.useState(void 0),[Be,de]=m.useState(null),[Ne,te]=m.useState(!1),[I,D]=m.useState({}),[Ue,T]=m.useState({}),[Ve,ce]=m.useState(null),[me,ne]=m.useState({}),[pe,fe]=m.useState({}),[Qe,Q]=m.useState({}),[ze,ge]=m.useState(null),[Ae,he]=m.useState(null),[Ke,ye]=m.useState(null),[He,ve]=m.useState(!1),[se,Ee]=m.useState(null),[z,oe]=m.useState(!0),[be,Re]=m.useState({}),[Ge,Se]=m.useState(!1),[_e,Me]=m.useState(!1),[Je,We]=m.useState({}),[Xe,Ye]=m.useState(null),[c,we]=m.useState(null),[Ze,Ce]=m.useState(!1),[ae,et]=m.useState(""),[A,tt]=m.useState("all"),nt=m.useMemo(()=>g.filter(e=>e.isSystem),[g]),st=m.useMemo(()=>g.filter(e=>!e.isSystem),[g]),ot=m.useMemo(()=>g.find(e=>e.key===y)??g[0]??null,[y,g]),x=(l==null?void 0:l.providers)??[],at=x.length,rt=m.useMemo(()=>x.filter(e=>{var r;if(!(A==="all"||(e.type??"custom")===A))return!1;const t=ae.trim().toLowerCase();return t?[e.id,e.label??"",e.baseUrl,e.defaultModel??"",...((r=e.models)==null?void 0:r.map(a=>a.id))??[]].join(" ").toLowerCase().includes(t):!0}),[ae,A,x]),N=m.useMemo(()=>[{key:"anthropic-beta",value:"claude-code-20250219,interleaved-thinking-2025-05-14,fine-grained-tool-streaming-2025-05-14",label:n("providers.testDialog.options.beta.label"),description:n("providers.testDialog.options.beta.description")}],[n]);m.useEffect(()=>{if(!d.data)return;const e=d.data;k(e),D(s=>{const t=ue(e,f);if(!s||Object.keys(s).length===0)return t;const o={...t};for(const[r,a]of Object.entries(s)){if(!(r in t))continue;const u=Fe(e,f,r);je(a,u)&&(o[r]=a)}return o}),T({}),ne(Ie(e,f))},[d.data,f]),m.useEffect(()=>{!d.isError||!d.error||i({title:n("providers.toast.loadFailure",{message:d.error.message}),variant:"error"})},[d.error,d.isError,i,n]),m.useEffect(()=>{g.some(e=>e.key===y)||j("providers")},[y,g]);const it=m.useMemo(()=>{const e=new Map;for(const s of x){if(!s.defaultModel||!s.models)continue;const t=s.models.find(o=>o.id===s.defaultModel);t&&e.set(s.id,At(t))}return e},[x]),lt=m.useMemo(()=>{const e=[],s=new Set;for(const t of x){const o=t.label&&t.label!==t.id?`${t.label} (${t.id})`:t.id,r=t.models??[];if(r.length>0)for(const u of r){const v=`${t.id}:${u.id}`;s.has(v)||(s.add(v),e.push({value:v,label:`${o} · ${u.label??u.id}`}))}else if(t.defaultModel){const u=`${t.id}:${t.defaultModel}`;s.has(u)||(s.add(u),e.push({value:u,label:`${o} · ${t.defaultModel}`}))}const a=`${t.id}:*`;s.has(a)||(s.add(a),e.push({value:a,label:n("settings.routing.providerPassthroughOption",{provider:o})}))}for(const t of Object.values(I).flat()){const o=t.target.trim();o&&!s.has(o)&&(s.add(o),e.push({value:o,label:o}))}return e},[x,I,n]),ut=()=>{ee(void 0),te(!0)},dt=e=>{ee(e),te(!0)},ct=e=>l?Fe(l,f,e):{},mt=m.useMemo(()=>{const e={};for(const s of g){if(s.key==="providers")continue;const t=I[s.key]||[];e[s.key]=je(t,ct(s.key))}return e},[l,f,I,g]),Pe=(e,s)=>{ne(t=>({...t,[e]:s})),k(t=>{if(!t)return t;if(e==="anthropic"||e==="openai")return{...t,routingPresets:{...t.routingPresets,[e]:s}};const o=[...t.customEndpoints??[]],r=o.findIndex(a=>a.id===e);return r===-1?t:(o[r]={...o[r],routingPresets:s},{...t,customEndpoints:o})})},$=()=>l?!0:(i({title:n("settings.toast.missingConfig"),variant:"error"}),d.refetch(),!1),pt=(e,s)=>{fe(t=>({...t,[e]:s})),s.trim()&&Q(t=>({...t,[e]:null}))},ft=async e=>{if(!$())return;const s=(pe[e]??"").trim();if(!s){Q(t=>({...t,[e]:n("modelManagement.validation.presetName")}));return}if((me[e]??[]).some(t=>t.name.toLowerCase()===s.toLowerCase())){Q(t=>({...t,[e]:n("modelManagement.validation.presetDuplicate",{name:s})}));return}ge(e);try{const o=(await _.savePreset(e,s)).presets??[];Pe(e,o),fe(r=>({...r,[e]:""})),Q(r=>({...r,[e]:null})),i({title:n("modelManagement.toast.presetSaved",{name:s}),variant:"success"})}catch(t){i({title:n("modelManagement.toast.presetSaveFailure",{message:t instanceof Error?t.message:"unknown"}),variant:"error"})}finally{ge(null),d.refetch()}},gt=async(e,s)=>{if($()){he({endpoint:e,name:s.name});try{const o=(await _.applyPreset(e,s.name)).config;if(o)k(o),D(ue(o,f)),ne(Ie(o,f));else{const r=s.modelRoutes??{};D(a=>({...a,[e]:Object.entries(r).map(([u,v])=>({id:O(),source:u,target:v}))})),k(a=>{var v,b,S,R;if(!a)return a;const u=(a.customEndpoints??[]).findIndex(E=>E.id===e);if(u!==-1){const E=[...a.customEndpoints??[]],M=E[u];return E[u]={...M,routing:{defaults:((v=M.routing)==null?void 0:v.defaults)??a.defaults,...M.routing??{},modelRoutes:r}},{...a,customEndpoints:E}}return e==="anthropic"||e==="openai"?{...a,endpointRouting:{...a.endpointRouting??{},[e]:{defaults:((S=(b=a.endpointRouting)==null?void 0:b[e])==null?void 0:S.defaults)??a.defaults,...((R=a.endpointRouting)==null?void 0:R[e])??{},modelRoutes:r}},modelRoutes:e==="anthropic"?r:a.modelRoutes??{}}:a})}e!=="anthropic"&&e!=="openai"&&await p.invalidateQueries({queryKey:U.customEndpoints.all()}),i({title:n("modelManagement.toast.presetApplySuccess",{name:s.name}),variant:"success"})}catch(t){i({title:n("modelManagement.toast.presetApplyFailure",{message:t instanceof Error?t.message:"unknown"}),variant:"error"})}finally{he(null),d.refetch()}}},ht=async(e,s)=>{if($()){ye({endpoint:e,name:s.name});try{const t=await _.deletePreset(e,s.name);Pe(e,t.presets??[]),i({title:n("modelManagement.toast.presetDeleteSuccess",{name:s.name}),variant:"success"})}catch(t){i({title:n("modelManagement.toast.presetDeleteFailure",{message:t instanceof Error?t.message:"unknown"}),variant:"error"})}finally{ye(null),d.refetch()}}},yt=()=>{$()&&(Y("create"),Z(void 0),W(!0))},vt=e=>{$()&&(Y("edit"),Z(e),W(!0))},Et=async e=>{if(!l)throw new Error(n("settings.toast.missingConfig"));const s=X==="create"?[...x,e]:x.map(o=>V&&o.id===V.id?{...e,id:V.id}:o),t={...l,providers:s};await F.saveConfig(t),k(t),D(ue(t,f)),d.refetch(),i({title:X==="create"?n("providers.toast.createSuccess",{name:e.label||e.id}):n("providers.toast.updateSuccess",{name:e.label||e.id}),variant:"success"})},bt=async e=>{const s=f.find(t=>t.id===e);if(!(!s||s.deletable===!1))try{await ie.delete(e),await p.invalidateQueries({queryKey:U.customEndpoints.all()}),i({title:n("modelManagement.deleteEndpointSuccess"),variant:"success"}),y===e&&j("providers")}catch(t){const o=re(t);i({title:n("modelManagement.deleteEndpointError",{error:o.message}),variant:"error"})}},ke=async(e,s)=>{de(e.id);try{const t=s&&(s.headers||s.query)?{headers:s.headers&&Object.keys(s.headers).length>0?s.headers:void 0,query:s.query&&s.query.trim().length>0?s.query.trim():void 0}:void 0,o=await _.testProvider(e.id,t);if(o.ok){i({title:n("providers.toast.testSuccess"),description:n("providers.toast.testSuccessDesc",{status:o.status,duration:o.durationMs?`${o.durationMs} ms`:"—"}),variant:"success"});return}i({title:n("providers.toast.testFailure",{message:`${o.status} ${o.statusText}`}),variant:"error"})}catch(t){i({title:n("providers.toast.testFailure",{message:t instanceof Error?t.message:"unknown"}),variant:"error"})}finally{de(null)}},Rt=e=>{if(e.type!=="anthropic"){ke(e);return}const s=e.extraHeaders??{},t=new Map(N.map(a=>[a.key.toLowerCase(),a])),o={};let r=!0;for(const a of N){const u=Object.entries(s).find(([S])=>S.toLowerCase()===a.key.toLowerCase());if(!u)continue;const[v,b]=u;String(b??"")!==a.value&&(r=!1,o[v]=String(b??""))}for(const[a,u]of Object.entries(s))t.has(a.toLowerCase())||(o[a]=String(u??""));Re(o),oe(r),Ee(e),ve(!0)},De=()=>{ve(!1),Ee(null),oe(!0),Re({})},St=async()=>{if(!se)return;const e={};if(z)for(const o of N)e[o.key]=o.value;const s=new Map(N.map(o=>[o.key.toLowerCase(),o]));for(const[o,r]of Object.entries(be))s.get(o.toLowerCase())&&z||(e[o]=r);const t=se;De(),await ke(t,{headers:Object.keys(e).length>0?e:void 0,query:z?"beta=true":void 0})},xe=async e=>{var b,S,R,E,M,P,L,K;if(!$())return;const s=x.filter(w=>w.id!==e.id),t=w=>{const C={};if(!w)return C;for(const[q,B]of Object.entries(w)){if(!B)continue;const[Te]=B.split(":");Te&&Te===e.id||B===e.id||(C[q]=B)}return C},o=(l==null?void 0:l.endpointRouting)??{},r=t(((b=o.anthropic)==null?void 0:b.modelRoutes)??(l==null?void 0:l.modelRoutes)??{}),a=t(((S=o.openai)==null?void 0:S.modelRoutes)??{}),u=((l==null?void 0:l.customEndpoints)??f).map(w=>{const C=w.routing,q=C==null?void 0:C.modelRoutes;return q?{...w,routing:{...C,defaults:C.defaults??l.defaults,modelRoutes:t(q)}}:w}),v={...l,providers:s,modelRoutes:r,customEndpoints:u,endpointRouting:{anthropic:{defaults:((R=o.anthropic)==null?void 0:R.defaults)??l.defaults,modelRoutes:r,validation:(E=o.anthropic)==null?void 0:E.validation,compatibility:(M=o.anthropic)==null?void 0:M.compatibility},openai:{defaults:((P=o.openai)==null?void 0:P.defaults)??l.defaults,modelRoutes:a,validation:(L=o.openai)==null?void 0:L.validation,compatibility:(K=o.openai)==null?void 0:K.compatibility}}};try{await F.saveConfig(v),k(v),D({anthropic:Object.entries(r).map(([w,C])=>({id:O(),source:w,target:C})),openai:Object.entries(a).map(([w,C])=>({id:O(),source:w,target:C})),...Object.fromEntries(u.map(w=>{var C;return[w.id,Object.entries(((C=w.routing)==null?void 0:C.modelRoutes)??{}).map(([q,B])=>({id:O(),source:q,target:B}))]}))}),i({title:n("providers.toast.deleteSuccess",{name:e.label||e.id}),variant:"success"}),d.refetch()}catch(w){i({title:n("providers.toast.deleteFailure",{message:w instanceof Error?w.message:"unknown"}),variant:"error"})}},Mt=async()=>{if(c){Ce(!0);try{c.kind==="provider"?await xe(c.provider):c.kind==="preset"?await ht(c.endpoint,c.preset):await bt(c.endpoint.id),we(null)}finally{Ce(!1)}}},wt=e=>{D(s=>({...s,[e]:[...s[e]||[],{id:O(),source:"",target:""}]})),T(s=>({...s,[e]:null}))},Ct=async(e,s)=>{var t,o;if($()){Se(!0);try{if(e==="anthropic"||e==="openai"){const r=e,a=l.endpointRouting?{...l.endpointRouting}:{},u=a[r]??{defaults:l.defaults,modelRoutes:(r==="anthropic"?l.modelRoutes:{})??{}},v={defaults:u.defaults??l.defaults,modelRoutes:u.modelRoutes??{},compatibility:u.compatibility},b=s==="off"?void 0:{...u.validation??{},mode:s,allowExperimentalBlocks:((t=u.validation)==null?void 0:t.allowExperimentalBlocks)??!0},S={...l,endpointRouting:{...a,[r]:b?{...v,validation:b}:{...v}}};await F.saveConfig(S),k(S)}else{const r=[...l.customEndpoints??[]],a=r.findIndex(R=>R.id===e);if(a===-1)throw new Error(n("modelManagement.toast.endpointNotFound"));const u=r[a],v=u.routing??{defaults:l.defaults,modelRoutes:{}},b=s==="off"?void 0:{...v.validation??{},mode:s,allowExperimentalBlocks:((o=v.validation)==null?void 0:o.allowExperimentalBlocks)??!0};r[a]={...u,routing:b?{...v,validation:b}:{defaults:v.defaults,modelRoutes:v.modelRoutes,compatibility:v.compatibility}};const S={...l,customEndpoints:r};await F.saveConfig(S),k(S)}i({title:n("modelManagement.toast.validationModeSaved",{mode:n(`modelManagement.claudeValidation.options.${s}.label`)}),variant:"success"}),d.refetch()}catch(r){const a=re(r);i({title:n("modelManagement.toast.validationModeFailure",{message:a.message}),variant:"error"})}finally{Se(!1)}}},Pt=async(e,s)=>{if($()){Me(!0);try{if(e==="anthropic"||e==="openai"){const t=e,o=l.endpointRouting?{...l.endpointRouting}:{},r=o[t]??{defaults:l.defaults,modelRoutes:(t==="anthropic"?l.modelRoutes:{})??{}},a={defaults:r.defaults??l.defaults,modelRoutes:r.modelRoutes??{},validation:r.validation},u={...l,endpointRouting:{...o,[t]:s?{...a,compatibility:{enabled:!0}}:{...a}}};await F.saveConfig(u),k(u)}else{const t=[...l.customEndpoints??[]],o=t.findIndex(v=>v.id===e);if(o===-1)throw new Error(n("modelManagement.toast.endpointNotFound"));const r=t[o],a=r.routing??{defaults:l.defaults,modelRoutes:{}};t[o]={...r,routing:s?{...a,compatibility:{enabled:!0}}:{defaults:a.defaults,modelRoutes:a.modelRoutes,validation:a.validation}};const u={...l,customEndpoints:t};await F.saveConfig(u),k(u)}i({title:n("modelManagement.toast.compatibilitySaved",{state:n(s?"common.enabled":"common.disabled")}),variant:"success"}),d.refetch()}catch(t){const o=re(t);i({title:n("modelManagement.toast.compatibilitySaveFailure",{message:o.message}),variant:"error"})}finally{Me(!1)}}},kt=(e,s)=>{D(t=>{const o=t[e]||[];return o.some(r=>r.source.trim()===s.trim())?t:{...t,[e]:[...o,{id:O(),source:s,target:""}]}}),T(t=>({...t,[e]:null}))},Dt=(e,s,t,o)=>{D(r=>({...r,[e]:(r[e]||[]).map(a=>a.id===s?{...a,[t]:o}:a)})),T(r=>({...r,[e]:null}))},xt=(e,s)=>{D(t=>({...t,[e]:(t[e]||[]).filter(o=>o.id!==s)})),T(t=>({...t,[e]:null}))},Ot=e=>{var t;if(!l)return;const s=(l.customEndpoints??f).find(o=>o.id===e);if(s)D(o=>{var r;return{...o,[e]:Object.entries(((r=s.routing)==null?void 0:r.modelRoutes)??{}).map(([a,u])=>({id:O(),source:a,target:u}))}});else{const o=l.endpointRouting??{},r=e,a=r==="anthropic"?l.modelRoutes??{}:{},u=((t=o[r])==null?void 0:t.modelRoutes)??a;D(v=>({...v,[e]:Object.entries(u).map(([b,S])=>({id:O(),source:b,target:S}))}))}T(o=>({...o,[e]:null}))},Tt=$e({mutationFn:async e=>(await F.saveConfig(e.nextConfig),e)}),$t=$e({mutationFn:async e=>(await ie.update(e.endpoint,{routing:e.routing}),e)}),Ft=async e=>{var o,r,a,u,v,b,S;if(!$())return;const s=I[e]||[],t={};for(const R of s){const E=R.source.trim(),M=R.target.trim();if(!(!E&&!M)){if(!E||!M){T(P=>({...P,[e]:n("settings.validation.routePair")}));return}if(t[E]){T(P=>({...P,[e]:n("settings.validation.routeDuplicate",{model:E})}));return}t[E]=M}}T(R=>({...R,[e]:null})),ce(e);try{const R=f.find(E=>E.id===e);if(R){const E={...R.routing??{},modelRoutes:t,defaults:((o=R.routing)==null?void 0:o.defaults)||l.defaults};await $t.mutateAsync({endpoint:e,routing:E}),k(M=>{if(!M)return M;const P=[...M.customEndpoints??[]],L=P.findIndex(K=>K.id===e);return L===-1?M:(P[L]={...P[L],routing:E},{...M,customEndpoints:P})}),await p.invalidateQueries({queryKey:U.customEndpoints.all()})}else{const E={...l,endpointRouting:{...l.endpointRouting??{},[e]:{defaults:((a=(r=l.endpointRouting)==null?void 0:r[e])==null?void 0:a.defaults)??l.defaults,modelRoutes:t,validation:(v=(u=l.endpointRouting)==null?void 0:u[e])==null?void 0:v.validation,compatibility:(S=(b=l.endpointRouting)==null?void 0:b[e])==null?void 0:S.compatibility}},modelRoutes:e==="anthropic"?t:l.modelRoutes??{}};await Tt.mutateAsync({endpoint:e,nextConfig:E}),k(E)}D(E=>({...E,[e]:Object.entries(t).map(([M,P])=>({id:O(),source:M,target:P}))})),i({title:n("modelManagement.toast.routesSaved"),variant:"success"}),d.refetch()}catch(R){i({title:n("modelManagement.toast.routesSaveFailure",{message:R instanceof Error?R.message:"unknown"}),variant:"error"})}finally{ce(null)}},jt=(c==null?void 0:c.kind)==="provider"?n("providers.actions.delete"):(c==null?void 0:c.kind)==="preset"?n("modelManagement.presets.delete"):(c==null?void 0:c.kind)==="endpoint"?n("common.delete"):"",It=(c==null?void 0:c.kind)==="provider"?n("providers.confirm.delete",{name:c.provider.label||c.provider.id}):(c==null?void 0:c.kind)==="preset"?n("modelManagement.confirm.deletePreset",{name:c.preset.name}):(c==null?void 0:c.kind)==="endpoint"?n("modelManagement.deleteEndpointConfirm",{label:c.endpoint.label}):"",Lt=(c==null?void 0:c.kind)==="provider"?c.provider.label||c.provider.id:(c==null?void 0:c.kind)==="preset"?c.preset.name:(c==null?void 0:c.kind)==="endpoint"?c.endpoint.label:"";return{activeTab:y,activeTabInfo:ot,anthropicTestHeaderOptions:N,applyingPreset:Ae,config:l,configQuery:d,confirmAction:c,confirmDialogDescription:It,confirmDialogName:Lt,confirmDialogTitle:jt,confirmingAction:Ze,customEndpoints:f,customTabs:st,defaultLabels:it,deletingPreset:Ke,drawerMode:X,drawerOpen:Le,editingEndpoint:qe,editingProvider:V,endpointDrawerOpen:Ne,filteredProviders:rt,handleAddRoute:wt,handleAddSuggestion:kt,handleApplyPreset:gt,handleCompatibilityEnabledChange:Pt,handleConfirmDialog:Mt,handleDeleteProvider:xe,handleOpenCreate:yt,handleOpenCreateEndpoint:ut,handleOpenEditEndpoint:dt,handleOpenEdit:vt,handlePresetNameChange:pt,handleProviderSubmit:Et,handleRemoveRoute:xt,handleResetRoutes:Ot,handleRouteChange:Dt,handleSavePreset:ft,handleSaveRoutes:Ft,handleValidationModeChange:Ct,initiateTestConnection:Rt,isDirtyByEndpoint:mt,presetDiffDialog:Xe,presetErrorByEndpoint:Qe,presetNameByEndpoint:pe,presetsByEndpoint:me,presetsExpanded:Je,providerCount:at,providerModelOptions:lt,providerSearch:ae,providerTypeFilter:A,providers:x,pushToast:i,routeError:Ue,routesByEndpoint:I,savingClaudeValidation:Ge,savingCompatibilityPolicy:_e,savingPresetFor:ze,savingRouteFor:Ve,setActiveTab:j,setConfirmAction:we,setDrawerMode:Y,setDrawerOpen:W,setEditingEndpoint:ee,setEditingProvider:Z,setEndpointDrawerOpen:te,setPresetDiffDialog:Ye,setPresetsExpanded:We,setProviderSearch:et,setProviderTypeFilter:tt,setTestDialogUsePreset:oe,systemTabs:nt,tabs:g,testDialogOpen:He,testDialogPreservedExtras:be,testDialogProvider:se,testDialogUsePreset:z,testingProviderId:Be,closeTestDialog:De,confirmTestDialog:St}}export{Zt as C,en as O,sn as a,nn as g,tn as i,on as u};
|