sparkrun-ui 1.2.2 → 1.2.4

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.
Files changed (71) hide show
  1. package/dist/.next/BUILD_ID +1 -1
  2. package/dist/.next/build-manifest.json +3 -3
  3. package/dist/.next/prerender-manifest.json +3 -3
  4. package/dist/.next/server/app/_global-error.html +1 -1
  5. package/dist/.next/server/app/_global-error.rsc +1 -1
  6. package/dist/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  7. package/dist/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  8. package/dist/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  9. package/dist/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  10. package/dist/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  11. package/dist/.next/server/app/_not-found/page.js.nft.json +1 -1
  12. package/dist/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  13. package/dist/.next/server/app/_not-found.html +1 -1
  14. package/dist/.next/server/app/_not-found.rsc +16 -16
  15. package/dist/.next/server/app/_not-found.segments/_full.segment.rsc +16 -16
  16. package/dist/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
  17. package/dist/.next/server/app/_not-found.segments/_index.segment.rsc +10 -10
  18. package/dist/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  19. package/dist/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  20. package/dist/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  21. package/dist/.next/server/app/benchmarks/[id]/page.js.nft.json +1 -1
  22. package/dist/.next/server/app/benchmarks/[id]/page_client-reference-manifest.js +1 -1
  23. package/dist/.next/server/app/benchmarks/new/page.js.nft.json +1 -1
  24. package/dist/.next/server/app/benchmarks/new/page_client-reference-manifest.js +1 -1
  25. package/dist/.next/server/app/benchmarks/page.js.nft.json +1 -1
  26. package/dist/.next/server/app/benchmarks/page_client-reference-manifest.js +1 -1
  27. package/dist/.next/server/app/chat/page.js.nft.json +1 -1
  28. package/dist/.next/server/app/chat/page_client-reference-manifest.js +1 -1
  29. package/dist/.next/server/app/dashboard/page.js.nft.json +1 -1
  30. package/dist/.next/server/app/dashboard/page_client-reference-manifest.js +1 -1
  31. package/dist/.next/server/app/index.html +1 -1
  32. package/dist/.next/server/app/index.rsc +16 -16
  33. package/dist/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  34. package/dist/.next/server/app/index.segments/_full.segment.rsc +16 -16
  35. package/dist/.next/server/app/index.segments/_head.segment.rsc +4 -4
  36. package/dist/.next/server/app/index.segments/_index.segment.rsc +10 -10
  37. package/dist/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  38. package/dist/.next/server/app/launch/page.js.nft.json +1 -1
  39. package/dist/.next/server/app/launch/page_client-reference-manifest.js +1 -1
  40. package/dist/.next/server/app/logs/[clusterId]/page.js.nft.json +1 -1
  41. package/dist/.next/server/app/logs/[clusterId]/page_client-reference-manifest.js +1 -1
  42. package/dist/.next/server/app/monitor/page.js.nft.json +1 -1
  43. package/dist/.next/server/app/monitor/page_client-reference-manifest.js +1 -1
  44. package/dist/.next/server/app/page.js.nft.json +1 -1
  45. package/dist/.next/server/app/page_client-reference-manifest.js +1 -1
  46. package/dist/.next/server/app/recipes/page.js.nft.json +1 -1
  47. package/dist/.next/server/app/recipes/page_client-reference-manifest.js +1 -1
  48. package/dist/.next/server/chunks/node_modules__pnpm_0jzojku._.js +6 -6
  49. package/dist/.next/server/chunks/ssr/{[root-of-the-server]__0y7ehiy._.js → [root-of-the-server]__13kp732._.js} +2 -2
  50. package/dist/.next/server/chunks/ssr/_0-wjfxk._.js +3 -3
  51. package/dist/.next/server/chunks/ssr/_0efad.3._.js +1 -1
  52. package/dist/.next/server/chunks/ssr/_0gbw~w_._.js +1 -1
  53. package/dist/.next/server/chunks/ssr/{_0m5y5l7._.js → _0mx8o88._.js} +2 -2
  54. package/dist/.next/server/chunks/ssr/app_components_dashboard_DashboardLive_tsx_10_yvzp._.js +1 -1
  55. package/dist/.next/server/middleware-build-manifest.js +3 -3
  56. package/dist/.next/server/pages/404.html +1 -1
  57. package/dist/.next/server/pages/500.html +1 -1
  58. package/dist/.next/server/server-reference-manifest.js +1 -1
  59. package/dist/.next/server/server-reference-manifest.json +1 -1
  60. package/dist/.next/static/chunks/{0-s876x.4qfai.js → 07x551vl4mw9a.js} +1 -1
  61. package/dist/.next/static/chunks/{16.c4q2lj5zlu.js → 0at5msm1mdg1q.js} +1 -1
  62. package/dist/.next/static/chunks/0phvjve3rvmp7.js +1 -0
  63. package/dist/.next/static/chunks/10t1d-iawzz1x.js +1 -0
  64. package/dist/.next/static/chunks/{0l02frokvgs9t.css → 15p6v9muehnl5.css} +1 -1
  65. package/dist/package.json +1 -1
  66. package/package.json +1 -1
  67. package/dist/.next/static/chunks/0j95jkol3vrh-.js +0 -1
  68. package/dist/.next/static/chunks/0x~v2lf_7ekbw.js +0 -1
  69. /package/dist/.next/static/{0BbaFq9ofGMo-l5uHDeyi → cddknQWvPQ4Xwbv6WBFh1}/_buildManifest.js +0 -0
  70. /package/dist/.next/static/{0BbaFq9ofGMo-l5uHDeyi → cddknQWvPQ4Xwbv6WBFh1}/_clientMiddlewareManifest.js +0 -0
  71. /package/dist/.next/static/{0BbaFq9ofGMo-l5uHDeyi → cddknQWvPQ4Xwbv6WBFh1}/_ssgManifest.js +0 -0
@@ -0,0 +1 @@
1
+ (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,2265,e=>{"use strict";var t=e.i(76350),s=e.i(33209);e.s(["Card",0,function({className:e,...r}){return(0,t.jsx)("div",{className:(0,s.cn)("rounded-lg border border-zinc-200 bg-white shadow-sm dark:border-zinc-800 dark:bg-zinc-900",e),...r})},"CardBody",0,function({className:e,...r}){return(0,t.jsx)("div",{className:(0,s.cn)("px-5 py-4",e),...r})},"CardDescription",0,function({className:e,...r}){return(0,t.jsx)("p",{className:(0,s.cn)("text-sm text-zinc-500 dark:text-zinc-400",e),...r})},"CardFooter",0,function({className:e,...r}){return(0,t.jsx)("div",{className:(0,s.cn)("flex items-center justify-end gap-2 border-t border-zinc-200 px-5 py-3 dark:border-zinc-800",e),...r})},"CardHeader",0,function({className:e,...r}){return(0,t.jsx)("div",{className:(0,s.cn)("flex flex-col gap-1 border-b border-zinc-200 px-5 py-4 dark:border-zinc-800",e),...r})},"CardTitle",0,function({className:e,...r}){return(0,t.jsx)("h3",{className:(0,s.cn)("text-base font-semibold text-zinc-900 dark:text-zinc-100",e),...r})}])},69393,e=>{"use strict";var t=e.i(76350),s=e.i(33209);let r={neutral:"bg-zinc-100 text-zinc-700 dark:bg-zinc-800 dark:text-zinc-300",sky:"bg-sky-100 text-sky-700 dark:bg-sky-950 dark:text-sky-300",green:"bg-emerald-100 text-emerald-700 dark:bg-emerald-950 dark:text-emerald-300",amber:"bg-amber-100 text-amber-700 dark:bg-amber-950 dark:text-amber-300",red:"bg-red-100 text-red-700 dark:bg-red-950 dark:text-red-300",purple:"bg-purple-100 text-purple-700 dark:bg-purple-950 dark:text-purple-300"};e.s(["Badge",0,function({tone:e="neutral",className:a,...i}){return(0,t.jsx)("span",{className:(0,s.cn)("inline-flex items-center gap-1 rounded px-1.5 py-0.5 text-xs font-medium",r[e],a),...i})}])},81807,e=>{"use strict";let t=(0,e.i(6927).default)("scroll-text",[["path",{d:"M15 12h-5",key:"r7krc0"}],["path",{d:"M15 8h-5",key:"1khuty"}],["path",{d:"M19 17V5a2 2 0 0 0-2-2H4",key:"zz82l3"}],["path",{d:"M8 21h12a2 2 0 0 0 2-2v-1a1 1 0 0 0-1-1H11a1 1 0 0 0-1 1v1a2 2 0 1 1-4 0V5a2 2 0 1 0-4 0v2a1 1 0 0 0 1 1h3",key:"1ph1d7"}]]);e.s(["ScrollText",0,t],81807)},84339,e=>{"use strict";let t=(0,e.i(6927).default)("loader-circle",[["path",{d:"M21 12a9 9 0 1 1-6.219-8.56",key:"13zald"}]]);e.s(["Loader2",0,t],84339)},83079,e=>{"use strict";var t=e.i(76350),s=e.i(73576),r=e.i(33209);let a={primary:"bg-sky-600 text-white hover:bg-sky-500 active:bg-sky-700 dark:bg-sky-500 dark:hover:bg-sky-400",secondary:"bg-zinc-100 text-zinc-900 hover:bg-zinc-200 active:bg-zinc-300 dark:bg-zinc-800 dark:text-zinc-100 dark:hover:bg-zinc-700 dark:active:bg-zinc-600 border border-zinc-200 dark:border-zinc-700",ghost:"text-zinc-700 hover:bg-zinc-100 active:bg-zinc-200 dark:text-zinc-300 dark:hover:bg-zinc-800 dark:active:bg-zinc-700",danger:"bg-red-600 text-white hover:bg-red-500 active:bg-red-700 dark:bg-red-500 dark:hover:bg-red-400",success:"bg-emerald-600 text-white hover:bg-emerald-500 active:bg-emerald-700 dark:bg-emerald-500 dark:hover:bg-emerald-400"},i={sm:"h-8 px-3 text-sm",md:"h-9 px-4 text-sm",lg:"h-10 px-5 text-base"},n=s.forwardRef(function({variant:e="secondary",size:s="md",className:n,...l},c){return(0,t.jsx)("button",{ref:c,className:(0,r.cn)("inline-flex items-center justify-center gap-2 rounded-md font-medium transition-colors cursor-pointer focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 focus-visible:ring-offset-zinc-50 dark:focus-visible:ring-offset-zinc-950 focus-visible:ring-sky-500 disabled:opacity-50 disabled:cursor-not-allowed",a[e],i[s],n),...l})});e.s(["Button",0,n])},63825,e=>{"use strict";let t=(0,e.i(6927).default)("triangle-alert",[["path",{d:"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3",key:"wmoenq"}],["path",{d:"M12 9v4",key:"juzpu7"}],["path",{d:"M12 17h.01",key:"p32p05"}]]);e.s(["AlertTriangle",0,t],63825)},44501,30650,e=>{"use strict";let t=(0,e.i(6927).default)("square",[["rect",{width:"18",height:"18",x:"3",y:"3",rx:"2",key:"afitv7"}]]);e.s(["Square",0,t],44501);var s=e.i(73576),r=e.i(21432);e.s(["useWorkloadHealth",0,function(e){let[t,a]=(0,s.useState)(null),[i,n]=(0,s.useState)(e);return e!==i&&(n(e),a(null)),(0,s.useEffect)(()=>{if(!e)return;let t=!1,s=new AbortController,i=async()=>{try{let i=await r.rpc.workloads.health({clusterId:e},{signal:s.signal});t||a(i)}catch{}};i();let n=setInterval(i,5e3);return()=>{t=!0,s.abort(),clearInterval(n)}},[e]),t??{ready:!1,state:"loading"}}],30650)},14779,73424,38540,e=>{"use strict";var t=e.i(6927);let s=(0,t.default)("cpu",[["path",{d:"M12 20v2",key:"1lh1kg"}],["path",{d:"M12 2v2",key:"tus03m"}],["path",{d:"M17 20v2",key:"1rnc9c"}],["path",{d:"M17 2v2",key:"11trls"}],["path",{d:"M2 12h2",key:"1t8f8n"}],["path",{d:"M2 17h2",key:"7oei6x"}],["path",{d:"M2 7h2",key:"asdhe0"}],["path",{d:"M20 12h2",key:"1q8mjw"}],["path",{d:"M20 17h2",key:"1fpfkl"}],["path",{d:"M20 7h2",key:"1o8tra"}],["path",{d:"M7 20v2",key:"4gnj0m"}],["path",{d:"M7 2v2",key:"1i4yhu"}],["rect",{x:"4",y:"4",width:"16",height:"16",rx:"2",key:"1vbyd7"}],["rect",{x:"8",y:"8",width:"8",height:"8",rx:"1",key:"z9xiuo"}]]);e.s(["Cpu",0,s],14779);let r=(0,t.default)("memory-stick",[["path",{d:"M12 12v-2",key:"fwoke6"}],["path",{d:"M12 18v-2",key:"qj6yno"}],["path",{d:"M16 12v-2",key:"heuere"}],["path",{d:"M16 18v-2",key:"s1ct0w"}],["path",{d:"M2 11h1.5",key:"15p63e"}],["path",{d:"M20 18v-2",key:"12ehxp"}],["path",{d:"M20.5 11H22",key:"khsy7a"}],["path",{d:"M4 18v-2",key:"1c3oqr"}],["path",{d:"M8 12v-2",key:"1mwtfd"}],["path",{d:"M8 18v-2",key:"qcmpov"}],["rect",{x:"2",y:"6",width:"20",height:"10",rx:"2",key:"1qcswk"}]]);e.s(["MemoryStick",0,r],73424);let a=(0,t.default)("server",[["rect",{width:"20",height:"8",x:"2",y:"2",rx:"2",ry:"2",key:"ngkwjq"}],["rect",{width:"20",height:"8",x:"2",y:"14",rx:"2",ry:"2",key:"iecqi9"}],["line",{x1:"6",x2:"6.01",y1:"6",y2:"6",key:"16zg32"}],["line",{x1:"6",x2:"6.01",y1:"18",y2:"18",key:"nzw8ys"}]]);e.s(["Server",0,a],38540)},66399,e=>{"use strict";var t=e.i(76350),s=e.i(73576),r=e.i(55367),a=e.i(84339),i=e.i(64477),n=e.i(82088),l=e.i(83079),c=e.i(69393),d=e.i(31307),o=e.i(21432);let x=new Map;e.s(["RecipeShowDialog",0,function({name:e,title:m,open:u,onOpenChange:h,running:p=!1,showLaunch:g=!0}){let[b,k]=(0,s.useState)(()=>x.get(e)??null),[f,j]=(0,s.useState)(null),[y,v]=(0,s.useState)(!1);return(0,s.useEffect)(()=>{if(!u)return;let t=x.get(e);if(t)return void k(t);let s=!1;return v(!0),j(null),o.rpc.recipes.show({name:e}).then(t=>{s||(x.set(e,t.text),k(t.text))}).catch(e=>{s||j(e instanceof Error?e.message:String(e))}).finally(()=>{s||v(!1)}),()=>{s=!0}},[u,e]),(0,t.jsx)(n.Dialog,{open:u,onOpenChange:h,children:(0,t.jsxs)(n.Dialog.Content,{title:m??e,size:"xl",description:"sparkrun recipe show",children:[(0,t.jsx)(n.Dialog.Body,{children:y&&!b?(0,t.jsxs)("div",{className:"flex items-center gap-2 text-sm text-zinc-500",children:[(0,t.jsx)(a.Loader2,{size:14,className:"animate-spin"})," loading…"]}):f?(0,t.jsx)("p",{className:"text-sm text-red-600 dark:text-red-400",children:f}):b?(0,t.jsx)(d.YamlEditor,{value:b,readOnly:!0,className:"max-h-[60vh]"}):null}),(0,t.jsxs)(n.Dialog.Footer,{children:[(0,t.jsx)(n.Dialog.Close,{render:(0,t.jsx)(l.Button,{variant:"ghost",type:"button",children:"Close"})}),p?(0,t.jsx)(c.Badge,{tone:"green",children:"already running"}):g?(0,t.jsx)(r.default,{href:`/launch?recipe=${encodeURIComponent(e)}`,children:(0,t.jsxs)(l.Button,{variant:"primary",children:[(0,t.jsx)(i.Rocket,{size:14}),"Launch"]})}):null]})]})})}])},60632,e=>{"use strict";var t=e.i(76350),s=e.i(73576),r=e.i(55367),a=e.i(63825),i=e.i(64477),n=e.i(21432),l=e.i(2265),c=e.i(69393),d=e.i(83079),o=e.i(75261),x=e.i(4403),m=e.i(44501),u=e.i(81807),h=e.i(84339),p=e.i(82088),g=e.i(84538),b=e.i(66399),k=e.i(30650);function f({workload:e,recipe:a}){var i,c,h;let y,v,[z,N]=(0,s.useState)(!1),[w,C]=(0,s.useState)(!1),[M,_]=(0,s.useTransition)(),S=(0,k.useWorkloadHealth)(e.cluster_id),T=e.meta.model||e.meta.recipe||e.cluster_id,G=function(e){if(!e)return null;let t=e.match(/^Up\s+(.+?)(?:\s*\([^)]*\))?\s*$/);return t?.[1]??null}(e.status),B=a?.registeredName??e.meta.recipe;return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsxs)(l.Card,{children:[(0,t.jsx)(l.CardHeader,{children:(0,t.jsx)(l.CardTitle,{className:"text-sm font-semibold",children:T})}),(0,t.jsxs)(l.CardBody,{className:"flex flex-col gap-3 text-sm",children:[(0,t.jsxs)("dl",{className:"grid grid-cols-[auto_1fr] gap-x-3 gap-y-1 text-xs",children:[a&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Recipe"}),(0,t.jsx)("dd",{children:B?(0,t.jsx)("button",{type:"button",onClick:()=>C(!0),className:"cursor-pointer font-medium text-sky-600 hover:underline dark:text-sky-400",children:a.label}):(0,t.jsx)("span",{className:"font-medium text-zinc-700 dark:text-zinc-300",children:a.label})})]}),e.meta.port&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Port"}),(0,t.jsx)("dd",{className:"font-mono text-zinc-700 dark:text-zinc-300",children:e.meta.port})]}),e.host&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Host"}),(0,t.jsx)("dd",{className:"font-mono text-zinc-700 dark:text-zinc-300",children:e.host})]}),G&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Uptime"}),(0,t.jsx)("dd",{className:"text-zinc-700 dark:text-zinc-300",children:G})]}),(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Status"}),(0,t.jsx)("dd",{children:(0,t.jsx)(j,{health:S,containerStatus:e.status})})]}),(0,t.jsxs)("div",{className:"flex justify-end gap-2 pt-2",children:[e.host&&e.meta.port&&(0,t.jsx)(r.default,{href:`/chat?clusterId=${encodeURIComponent(e.cluster_id)}`,children:(0,t.jsxs)(d.Button,{variant:"ghost",size:"sm",children:[(0,t.jsx)(x.MessageSquare,{size:14}),"Chat"]})}),(0,t.jsx)(r.default,{href:`/logs/${e.cluster_id}`,children:(0,t.jsxs)(d.Button,{variant:"ghost",size:"sm",children:[(0,t.jsx)(u.ScrollText,{size:14}),"Logs"]})}),(0,t.jsx)(r.default,{href:(i=a,c=e.meta.model,h=function(e){let t=e?.overrides,s=t?.served_model_name;if("string"==typeof s&&s)return s;let r=e?.recipe_state,a=r?._applied_overrides,i=a?.served_model_name;if("string"==typeof i&&i)return i;let n=r?._raw,l=n?.defaults,c=l?.served_model_name;if("string"==typeof c&&c)return c}(e.meta),y=i?.registeredName??i?.label,v=new URLSearchParams,y&&v.set("recipe",y),c&&v.set("model",c),h&&v.set("servedModelName",h),v.set("skipRun","1"),`/benchmarks/new?${v.toString()}`),children:(0,t.jsxs)(d.Button,{variant:"ghost",size:"sm",children:[(0,t.jsx)(o.Gauge,{size:14}),"Benchmark"]})}),(0,t.jsxs)(d.Button,{variant:"danger",size:"sm",onClick:()=>N(!0),disabled:M,children:[(0,t.jsx)(m.Square,{size:14}),M?"Stopping…":"Stop"]})]})]})]}),(0,t.jsx)(p.AlertDialog,{open:z,onOpenChange:N,title:"Stop this workload?",description:(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("span",{className:"block font-mono",children:T}),(0,t.jsxs)("span",{className:"mt-2 block",children:["The container will be terminated on ",e.host??"the target host","."]})]}),confirmLabel:"Stop",destructive:!0,onConfirm:()=>{_(async()=>{try{await n.rpc.workloads.stop({clusterId:e.cluster_id}),g.toast.success("Stop requested",`${T} is shutting down`)}catch(t){let e=t instanceof Error?t.message:"Unknown error";g.toast.error("Stop failed",e)}})}}),a&&B&&(0,t.jsx)(b.RecipeShowDialog,{name:B,title:a.label,open:w,onOpenChange:e=>!e&&C(!1),showLaunch:!1})]})}function j({health:e,containerStatus:s}){return e.ready?(0,t.jsxs)("span",{className:"inline-flex items-center gap-1.5",children:[(0,t.jsx)("span",{className:"h-1.5 w-1.5 rounded-full bg-emerald-500"}),(0,t.jsx)("span",{className:"text-zinc-700 dark:text-zinc-300",children:"Ready"})]}):"loading"===e.state?(0,t.jsxs)("span",{className:"inline-flex items-center gap-1.5",children:[(0,t.jsx)(h.Loader2,{size:10,className:"animate-spin text-zinc-400"}),(0,t.jsx)("span",{className:"text-zinc-500 capitalize dark:text-zinc-400",children:s??"Checking…"})]}):"starting"===e.state?(0,t.jsxs)("span",{className:"inline-flex items-center gap-1.5",children:[(0,t.jsx)(h.Loader2,{size:10,className:"animate-spin text-amber-500"}),(0,t.jsx)("span",{className:"text-amber-700 dark:text-amber-300",children:"Starting…"})]}):(0,t.jsxs)("span",{className:"inline-flex items-center gap-1.5",children:[(0,t.jsx)("span",{className:"h-1.5 w-1.5 rounded-full bg-red-500"}),(0,t.jsx)("span",{className:"text-red-700 dark:text-red-300",title:e.reason??void 0,children:"Unreachable"})]})}var y=e.i(14779),v=e.i(73424),z=e.i(38540),N=e.i(74799),w=e.i(98638);function C(e){if(!e)return 0;let t=parseFloat(e);return Number.isFinite(t)?t:0}function M(e){if(!e)return{hostCount:0,cpuAvg:0,gpuAvg:0,memUsedGb:0,memTotalGb:0,gpuMemUsedGb:0,gpuMemTotalGb:0,powerW:0,cpuTempC:0,gpuTempC:0,jobsTotal:0};let t=Object.values(e.hosts),s=0,r=0,a=0,i=0,n=0,l=0,c=0,d=0,o=0,x=0;for(let e of t)s+=C(e.cpu_usage_pct),r+=C(e.gpu_util_pct),a+=C(e.mem_used_mb),i+=C(e.mem_total_mb),n+=C(e.gpu_mem_used_mb),l+=C(e.gpu_mem_total_mb),c+=C(e.gpu_power_w),d+=C(e.cpu_temp_c),o+=C(e.gpu_temp_c),x+=C(e.sparkrun_jobs);let m=t.length||1;return{hostCount:t.length,cpuAvg:s/m,gpuAvg:r/m,memUsedGb:a/1024,memTotalGb:i/1024,gpuMemUsedGb:n/1024,gpuMemTotalGb:l/1024,powerW:c,cpuTempC:d/m,gpuTempC:o/m,jobsTotal:x}}function _(){let[e,r]=(0,s.useState)(null),[a,i]=(0,s.useState)({cpu:[],gpu:[]}),[c,d]=(0,s.useState)(!1);(0,s.useEffect)(()=>{let e=new AbortController,t=!1;return(async()=>{try{let s=await n.rpc.monitor.stream({intervalSec:2},{signal:e.signal});for await(let e of(d(!0),s)){if(t)break;r(e);let s=M(e);i(e=>({cpu:S(e.cpu,s.cpuAvg),gpu:S(e.gpu,s.gpuAvg)}))}}catch(e){t||e instanceof DOMException&&"AbortError"===e.name||console.error("[monitor.stream]",e)}finally{t||d(!1)}})(),()=>{t=!0,e.abort()}},[]);let o=M(e),x=o.memTotalGb?o.memUsedGb/o.memTotalGb*100:0,m=o.gpuMemTotalGb?o.gpuMemUsedGb/o.gpuMemTotalGb*100:0;return(0,t.jsx)(l.Card,{children:(0,t.jsxs)(l.CardBody,{className:"p-5",children:[(0,t.jsxs)("div",{className:"mb-4 flex items-baseline justify-between",children:[(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)(z.Server,{size:14,className:"text-zinc-500"}),(0,t.jsx)("span",{className:"text-sm font-medium text-zinc-700 dark:text-zinc-300",children:"Cluster overview"}),(0,t.jsxs)("span",{className:"text-xs text-zinc-500",children:["· ",o.hostCount||"—"," host",1===o.hostCount?"":"s"," · ",o.jobsTotal," job",1===o.jobsTotal?"":"s"]})]}),(0,t.jsx)("span",{className:"inline-flex h-2 w-2 rounded-full "+(c?"animate-pulse bg-emerald-500":"bg-zinc-300"),title:c?"live":"reconnecting"})]}),(0,t.jsxs)("div",{className:"grid grid-cols-2 gap-4 sm:grid-cols-3 lg:grid-cols-5",children:[(0,t.jsx)($,{icon:(0,t.jsx)(y.Cpu,{size:14}),tone:"sky",label:"CPU",value:`${o.cpuAvg.toFixed(1)}%`,sub:`avg across ${o.hostCount||0}`,pct:o.cpuAvg,spark:a.cpu}),(0,t.jsx)($,{icon:(0,t.jsx)(w.Zap,{size:14}),tone:"purple",label:"GPU",value:`${o.gpuAvg.toFixed(0)}%`,sub:`avg across ${o.hostCount||0}`,pct:o.gpuAvg,spark:a.gpu}),(0,t.jsx)($,{icon:(0,t.jsx)(v.MemoryStick,{size:14}),tone:"green",label:"Memory",value:`${o.memUsedGb.toFixed(0)} / ${o.memTotalGb.toFixed(0)} GB`,sub:`${x.toFixed(0)}% used`,pct:x}),(0,t.jsx)($,{icon:(0,t.jsx)(w.Zap,{size:14}),tone:"amber",label:"Power",value:`${o.powerW.toFixed(1)} W`,sub:o.gpuMemTotalGb?`GPU mem ${o.gpuMemUsedGb.toFixed(0)}/${o.gpuMemTotalGb.toFixed(0)} GB`:"total GPU draw",pct:m}),(0,t.jsx)($,{icon:(0,t.jsx)(N.Thermometer,{size:14}),tone:"red",label:"Temps",value:o.cpuTempC||o.gpuTempC?`${o.gpuTempC.toFixed(0)}\xb0C / ${o.cpuTempC.toFixed(0)}\xb0C`:"—",sub:"GPU / CPU avg",pct:o.gpuTempC>0?Math.min(100,o.gpuTempC/100*100):0})]})]})})}function S(e,t){let s=e.concat(t);return s.length>40?s.slice(-40):s}let T={sky:"bg-sky-500 dark:bg-sky-400",purple:"bg-purple-500 dark:bg-purple-400",green:"bg-emerald-500 dark:bg-emerald-400",amber:"bg-amber-500 dark:bg-amber-400",red:"bg-red-500 dark:bg-red-400"},G={sky:"stroke-sky-500 dark:stroke-sky-400",purple:"stroke-purple-500 dark:stroke-purple-400",green:"stroke-emerald-500 dark:stroke-emerald-400",amber:"stroke-amber-500 dark:stroke-amber-400"},B={sky:"text-sky-600 dark:text-sky-400",purple:"text-purple-600 dark:text-purple-400",green:"text-emerald-600 dark:text-emerald-400",amber:"text-amber-600 dark:text-amber-400",red:"text-red-600 dark:text-red-400"};function $({icon:e,label:s,value:r,sub:a,pct:i,tone:n,spark:l}){let c=Math.max(0,Math.min(100,i));return(0,t.jsxs)("div",{className:"flex flex-col gap-1.5",children:[(0,t.jsxs)("div",{className:"flex items-center justify-between",children:[(0,t.jsxs)("div",{className:`flex items-center gap-1.5 text-xs font-medium ${B[n]}`,children:[e,s]}),l&&l.length>2&&(0,t.jsx)(U,{values:l,className:G[n]})]}),(0,t.jsx)("div",{className:"font-mono text-xl font-semibold text-zinc-900 dark:text-zinc-100",children:r}),(0,t.jsx)("div",{className:"h-1.5 overflow-hidden rounded bg-zinc-100 dark:bg-zinc-800",children:(0,t.jsx)("div",{className:`${T[n]} h-full transition-all duration-300`,style:{width:`${c}%`}})}),(0,t.jsx)("div",{className:"text-[11px] text-zinc-500 dark:text-zinc-400",children:a})]})}function U({values:e,className:s}){let r=Math.max(100,...e),a=56/Math.max(1,e.length-1),i=e.map((e,t)=>`${0===t?"M":"L"} ${t*a} ${16-e/r*16}`).join(" ");return(0,t.jsx)("svg",{width:56,height:16,viewBox:"0 0 56 16",className:"flex-shrink-0",children:(0,t.jsx)("path",{d:i,fill:"none",strokeWidth:1.25,className:s})})}e.s(["DashboardLive",0,function({initial:e,recipeByCluster:o}){let[x,m]=(0,s.useState)(e),[u,h]=(0,s.useState)(!0);return(0,s.useEffect)(()=>{let e=new AbortController,t=!1;return(async()=>{try{for await(let s of(await n.rpc.status.stream({intervalMs:3e3},{signal:e.signal}))){if(t)break;m(s),h(!0)}}catch(e){t||h(!1),e instanceof DOMException&&"AbortError"===e.name||console.error("[status.stream]",e)}})(),()=>{t=!0,e.abort()}},[]),(0,t.jsxs)("div",{className:"flex flex-col gap-6",children:[(0,t.jsxs)("div",{className:"flex items-baseline justify-between",children:[(0,t.jsx)("h1",{className:"text-2xl font-semibold tracking-tight",children:"Dashboard"}),(0,t.jsxs)("div",{className:"flex items-center gap-2 text-sm",children:[(0,t.jsxs)(c.Badge,{tone:"sky",children:[x.host_count," host",1===x.host_count?"":"s"]}),(0,t.jsxs)(c.Badge,{tone:"green",children:[x.total_containers," running"]}),(0,t.jsx)(c.Badge,{tone:u?"neutral":"amber",children:u?"live":"reconnecting…"})]})]}),(0,t.jsx)(_,{}),Object.keys(x.errors).length>0&&(0,t.jsx)(l.Card,{className:"border-amber-300 bg-amber-50 dark:border-amber-900 dark:bg-amber-950/40",children:(0,t.jsxs)(l.CardBody,{className:"flex gap-3",children:[(0,t.jsx)(a.AlertTriangle,{className:"mt-0.5 shrink-0 text-amber-600 dark:text-amber-400",size:18}),(0,t.jsxs)("div",{className:"flex flex-col gap-1 text-sm",children:[(0,t.jsx)("h3",{className:"font-medium text-amber-900 dark:text-amber-200",children:"Cluster status reported errors"}),(0,t.jsx)("ul",{className:"flex flex-col gap-1 text-amber-800 dark:text-amber-300",children:Object.entries(x.errors).map(([e,s])=>(0,t.jsxs)("li",{className:"font-mono text-xs",children:[(0,t.jsxs)("span",{className:"font-semibold",children:[e,":"]})," ","string"==typeof s?s:s&&"object"==typeof s&&"message"in s?String(s.message):JSON.stringify(s)]},e))})]})]})}),(0,t.jsxs)("div",{className:"flex flex-col gap-3",children:[(0,t.jsx)("h2",{className:"text-sm font-medium text-zinc-700 dark:text-zinc-300",children:"Workloads"}),0===x.solo_entries.length?(0,t.jsx)(l.Card,{children:(0,t.jsxs)(l.CardBody,{className:"flex flex-col items-center gap-4 py-12 text-center",children:[(0,t.jsx)("div",{className:"flex h-12 w-12 items-center justify-center rounded-full bg-sky-50 text-sky-600 dark:bg-sky-950 dark:text-sky-400",children:(0,t.jsx)(i.Rocket,{size:22})}),(0,t.jsxs)("div",{className:"flex flex-col gap-1",children:[(0,t.jsx)("h3",{className:"text-base font-semibold text-zinc-900 dark:text-zinc-100",children:"No workloads running"}),(0,t.jsx)("p",{className:"text-sm text-zinc-500 dark:text-zinc-400",children:"Launch a recipe to start an inference workload on your cluster."})]}),(0,t.jsx)(r.default,{href:"/launch",children:(0,t.jsxs)(d.Button,{variant:"primary",children:[(0,t.jsx)(i.Rocket,{size:14}),"Launch a recipe"]})})]})}):(0,t.jsx)("div",{className:"grid grid-cols-1 gap-4 lg:grid-cols-2",children:x.solo_entries.map(e=>(0,t.jsx)(f,{workload:e,recipe:o.get(e.cluster_id)},e.cluster_id))})]})]})}],60632)}]);
@@ -0,0 +1 @@
1
+ (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,2265,e=>{"use strict";var t=e.i(76350),r=e.i(33209);e.s(["Card",0,function({className:e,...s}){return(0,t.jsx)("div",{className:(0,r.cn)("rounded-lg border border-zinc-200 bg-white shadow-sm dark:border-zinc-800 dark:bg-zinc-900",e),...s})},"CardBody",0,function({className:e,...s}){return(0,t.jsx)("div",{className:(0,r.cn)("px-5 py-4",e),...s})},"CardDescription",0,function({className:e,...s}){return(0,t.jsx)("p",{className:(0,r.cn)("text-sm text-zinc-500 dark:text-zinc-400",e),...s})},"CardFooter",0,function({className:e,...s}){return(0,t.jsx)("div",{className:(0,r.cn)("flex items-center justify-end gap-2 border-t border-zinc-200 px-5 py-3 dark:border-zinc-800",e),...s})},"CardHeader",0,function({className:e,...s}){return(0,t.jsx)("div",{className:(0,r.cn)("flex flex-col gap-1 border-b border-zinc-200 px-5 py-4 dark:border-zinc-800",e),...s})},"CardTitle",0,function({className:e,...s}){return(0,t.jsx)("h3",{className:(0,r.cn)("text-base font-semibold text-zinc-900 dark:text-zinc-100",e),...s})}])},69393,e=>{"use strict";var t=e.i(76350),r=e.i(33209);let s={neutral:"bg-zinc-100 text-zinc-700 dark:bg-zinc-800 dark:text-zinc-300",sky:"bg-sky-100 text-sky-700 dark:bg-sky-950 dark:text-sky-300",green:"bg-emerald-100 text-emerald-700 dark:bg-emerald-950 dark:text-emerald-300",amber:"bg-amber-100 text-amber-700 dark:bg-amber-950 dark:text-amber-300",red:"bg-red-100 text-red-700 dark:bg-red-950 dark:text-red-300",purple:"bg-purple-100 text-purple-700 dark:bg-purple-950 dark:text-purple-300"};e.s(["Badge",0,function({tone:e="neutral",className:a,...n}){return(0,t.jsx)("span",{className:(0,r.cn)("inline-flex items-center gap-1 rounded px-1.5 py-0.5 text-xs font-medium",s[e],a),...n})}])},14779,73424,38540,e=>{"use strict";var t=e.i(6927);let r=(0,t.default)("cpu",[["path",{d:"M12 20v2",key:"1lh1kg"}],["path",{d:"M12 2v2",key:"tus03m"}],["path",{d:"M17 20v2",key:"1rnc9c"}],["path",{d:"M17 2v2",key:"11trls"}],["path",{d:"M2 12h2",key:"1t8f8n"}],["path",{d:"M2 17h2",key:"7oei6x"}],["path",{d:"M2 7h2",key:"asdhe0"}],["path",{d:"M20 12h2",key:"1q8mjw"}],["path",{d:"M20 17h2",key:"1fpfkl"}],["path",{d:"M20 7h2",key:"1o8tra"}],["path",{d:"M7 20v2",key:"4gnj0m"}],["path",{d:"M7 2v2",key:"1i4yhu"}],["rect",{x:"4",y:"4",width:"16",height:"16",rx:"2",key:"1vbyd7"}],["rect",{x:"8",y:"8",width:"8",height:"8",rx:"1",key:"z9xiuo"}]]);e.s(["Cpu",0,r],14779);let s=(0,t.default)("memory-stick",[["path",{d:"M12 12v-2",key:"fwoke6"}],["path",{d:"M12 18v-2",key:"qj6yno"}],["path",{d:"M16 12v-2",key:"heuere"}],["path",{d:"M16 18v-2",key:"s1ct0w"}],["path",{d:"M2 11h1.5",key:"15p63e"}],["path",{d:"M20 18v-2",key:"12ehxp"}],["path",{d:"M20.5 11H22",key:"khsy7a"}],["path",{d:"M4 18v-2",key:"1c3oqr"}],["path",{d:"M8 12v-2",key:"1mwtfd"}],["path",{d:"M8 18v-2",key:"qcmpov"}],["rect",{x:"2",y:"6",width:"20",height:"10",rx:"2",key:"1qcswk"}]]);e.s(["MemoryStick",0,s],73424);let a=(0,t.default)("server",[["rect",{width:"20",height:"8",x:"2",y:"2",rx:"2",ry:"2",key:"ngkwjq"}],["rect",{width:"20",height:"8",x:"2",y:"14",rx:"2",ry:"2",key:"iecqi9"}],["line",{x1:"6",x2:"6.01",y1:"6",y2:"6",key:"16zg32"}],["line",{x1:"6",x2:"6.01",y1:"18",y2:"18",key:"nzw8ys"}]]);e.s(["Server",0,a],38540)},40277,e=>{"use strict";var t=e.i(76350),r=e.i(73576),s=e.i(2265),a=e.i(69393),n=e.i(21432),i=e.i(14779),l=e.i(73424),c=e.i(38540),d=e.i(98638);function o(e){if(null==e||""===e)return null;let t=parseFloat(e);return Number.isFinite(t)?t:null}function x({host:e,metrics:r,history:n}){let p=o(r.cpu_usage_pct)??0,m=o(r.gpu_util_pct)??0,h=o(r.mem_used_mb)??0,g=o(r.mem_total_mb)??1,k=o(r.gpu_mem_used_mb),y=o(r.gpu_mem_total_mb),b=null!=k&&y?k/y*100:null,f=o(r.cpu_temp_c),j=o(r.gpu_temp_c),v=o(r.gpu_power_w);return(0,t.jsxs)(s.Card,{children:[(0,t.jsxs)(s.CardHeader,{children:[(0,t.jsxs)(s.CardTitle,{className:"flex items-center gap-2",children:[(0,t.jsx)(c.Server,{size:16,className:"text-zinc-500"}),e]}),(0,t.jsxs)(s.CardDescription,{children:[r.hostname," · ",r.gpu_name??"—"]})]}),(0,t.jsxs)(s.CardBody,{className:"flex flex-col gap-3",children:[(0,t.jsx)(u,{label:"CPU",pct:p,history:n.cpu,icon:(0,t.jsx)(i.Cpu,{size:14}),tone:"sky",right:null!=f&&`${f.toFixed(1)}\xb0C`}),(0,t.jsx)(u,{label:"GPU",pct:m,history:n.gpu,icon:(0,t.jsx)(d.Zap,{size:14}),tone:"purple",right:null!=j&&`${j.toFixed(0)}\xb0C`}),(0,t.jsx)(u,{label:"Memory",pct:h/g*100,history:n.mem,icon:(0,t.jsx)(l.MemoryStick,{size:14}),tone:"green",right:`${(h/1024).toFixed(1)}/${(g/1024).toFixed(0)} GB`}),null!=b&&(0,t.jsx)(u,{label:"GPU memory",pct:b,history:[],icon:(0,t.jsx)(d.Zap,{size:14}),tone:"amber",right:null!=k&&y?`${(k/1024).toFixed(1)}/${(y/1024).toFixed(0)} GB`:null}),(0,t.jsxs)("div",{className:"flex flex-wrap items-center gap-2 pt-1 text-xs text-zinc-500 dark:text-zinc-400",children:[null!=v&&(0,t.jsxs)(a.Badge,{tone:"neutral",children:[v.toFixed(1)," W"]}),r.sparkrun_jobs&&"0"!==r.sparkrun_jobs&&(0,t.jsxs)(a.Badge,{tone:"sky",children:[r.sparkrun_jobs," job","1"===r.sparkrun_jobs?"":"s"]})]})]})]})}let p={sky:"text-sky-500 dark:text-sky-400",purple:"text-purple-500 dark:text-purple-400",green:"text-emerald-500 dark:text-emerald-400",amber:"text-amber-500 dark:text-amber-400"};function u({label:e,pct:r,history:s,icon:a,tone:n,right:i}){let l=Math.max(0,Math.min(100,r));return(0,t.jsxs)("div",{className:"flex flex-col gap-1",children:[(0,t.jsxs)("div",{className:"flex items-center justify-between text-xs",children:[(0,t.jsxs)("span",{className:"flex items-center gap-1.5 text-zinc-700 dark:text-zinc-300",children:[a,e]}),(0,t.jsxs)("span",{className:"flex items-center gap-2 text-zinc-500 dark:text-zinc-400",children:[i,(0,t.jsxs)("span",{className:"font-mono text-zinc-700 dark:text-zinc-200",children:[l.toFixed(0),"%"]})]})]}),(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)("div",{className:"h-2 flex-1 overflow-hidden rounded bg-zinc-200 dark:bg-zinc-800",children:(0,t.jsx)("div",{className:"h-full transition-all duration-300 "+("sky"===n?"bg-sky-500 dark:bg-sky-400":"purple"===n?"bg-purple-500 dark:bg-purple-400":"green"===n?"bg-emerald-500 dark:bg-emerald-400":"bg-amber-500 dark:bg-amber-400"),style:{width:`${l}%`}})}),s.length>2&&(0,t.jsx)(m,{values:s,className:p[n]})]})]})}function m({values:e,className:r}){if(e.length<2)return null;let s=Math.max(100,...e),a=80/Math.max(1,e.length-1),n=e.map((e,t)=>`${t*a},${16-e/s*16}`),i=(e.length-1)*a,l=`M 0,16 L ${n.join(" L ")} L ${i},16 Z`,c=`M ${n.join(" L ")}`;return(0,t.jsxs)("svg",{width:80,height:16,viewBox:"0 0 80 16",className:`flex-shrink-0 ${r}`,children:[(0,t.jsx)("path",{d:l,fill:"currentColor",stroke:"none",opacity:.35}),(0,t.jsx)("path",{d:c,fill:"none",stroke:"currentColor",strokeWidth:1})]})}function h(e){if(null==e||""===e)return 0;let t=parseFloat(e);return Number.isFinite(t)?t:0}function g(e,t){let r=e.concat(t);return r.length>30?r.slice(-30):r}e.s(["MonitorLive",0,function(){let[e,i]=(0,r.useState)(null),[l,c]=(0,r.useState)({}),[d,o]=(0,r.useState)(!1);(0,r.useEffect)(()=>{let e=new AbortController,t=!1;return(async()=>{try{let r=await n.rpc.monitor.stream({intervalSec:2},{signal:e.signal});for await(let e of(o(!0),r)){if(t)break;i(e),c(t=>{let r={...t};for(let[t,s]of Object.entries(e.hosts)){let e=r[t]??{cpu:[],gpu:[],mem:[],power:[]};r[t]={cpu:g(e.cpu,h(s.cpu_usage_pct)),gpu:g(e.gpu,h(s.gpu_util_pct)),mem:g(e.mem,h(s.mem_used_pct)),power:g(e.power,h(s.gpu_power_w))}}return r})}}catch(e){t||e instanceof DOMException&&"AbortError"===e.name||console.error("[monitor.stream]",e)}finally{t||o(!1)}})(),()=>{t=!0,e.abort()}},[]);let p=e?Object.entries(e.hosts):[];return(0,t.jsxs)("div",{className:"flex flex-col gap-6",children:[(0,t.jsxs)("div",{className:"flex items-baseline justify-between",children:[(0,t.jsx)("h1",{className:"text-2xl font-semibold tracking-tight",children:"Cluster monitor"}),(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)(a.Badge,{tone:d?"green":"amber",children:d?"live":"reconnecting…"}),e&&(0,t.jsxs)(a.Badge,{tone:"neutral",children:[p.length," host",1===p.length?"":"s"]})]})]}),e?(0,t.jsx)("div",{className:"grid grid-cols-1 gap-4 lg:grid-cols-2 xl:grid-cols-3",children:p.map(([e,r])=>(0,t.jsx)(x,{host:e,metrics:r,history:l[e]??{cpu:[],gpu:[],mem:[],power:[]}},e))}):(0,t.jsx)(s.Card,{children:(0,t.jsx)(s.CardBody,{className:"text-sm text-zinc-500 dark:text-zinc-400",children:"Waiting for first monitor sample…"})})]})}],40277)}]);
@@ -1,3 +1,3 @@
1
1
  @font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fef07dbb0973bf53-s.12tyk43_3sh9u.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.0jzbimsg8vl84.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/53b9e256198e5412-s.0-wfv7uh4i7h9.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.0nx0ww8fni_q3.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.09~u27dqhyhd6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist", "Geist Fallback"}
2
2
  @font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5ce348bf30bf5439-s.0ee55_hj9qcer.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.0.qu-9752pffj.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/6306c77e7c8268e4-s.0mao5jbfbduzp.woff2)format("woff2");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7d817b4c03b0c5f1-s.0uzt.a6d44yda.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.0mvwgmnhv29no.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.09zddjkbdep5a.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
3
- @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-content:""}}}@layer theme{:root,:host{--color-red-50:#fef2f2;--color-red-100:#ffe2e2;--color-red-200:#ffcaca;--color-red-300:#ffa3a3;--color-red-400:#ff6568;--color-red-500:#fb2c36;--color-red-600:#e40014;--color-red-700:#bf000f;--color-red-800:#9f0712;--color-red-900:#82181a;--color-red-950:#460809;--color-amber-50:#fffbeb;--color-amber-100:#fef3c6;--color-amber-200:#fee685;--color-amber-300:#ffd236;--color-amber-400:#fcbb00;--color-amber-500:#f99c00;--color-amber-600:#dd7400;--color-amber-700:#b75000;--color-amber-800:#953d00;--color-amber-900:#7b3306;--color-amber-950:#461901;--color-yellow-200:#fff085;--color-yellow-300:#ffe02a;--color-green-100:#dcfce7;--color-green-300:#7bf1a8;--color-green-400:#05df72;--color-green-600:#00a544;--color-green-700:#008138;--color-green-900:#0d542b;--color-emerald-50:#ecfdf5;--color-emerald-100:#d0fae5;--color-emerald-200:#a4f4cf;--color-emerald-300:#5ee9b5;--color-emerald-400:#00d294;--color-emerald-500:#00bb7f;--color-emerald-600:#009767;--color-emerald-700:#007956;--color-emerald-800:#005f46;--color-emerald-900:#004e3b;--color-emerald-950:#002c22;--color-cyan-200:#a2f4fd;--color-cyan-300:#53eafd;--color-sky-50:#f0f9ff;--color-sky-100:#dff2fe;--color-sky-300:#77d4ff;--color-sky-400:#00bcfe;--color-sky-500:#00a5ef;--color-sky-600:#0084cc;--color-sky-700:#0069a4;--color-sky-950:#052f4a;--color-blue-300:#90c5ff;--color-blue-400:#54a2ff;--color-indigo-500:#625fff;--color-purple-100:#f3e8ff;--color-purple-300:#d9b3ff;--color-purple-400:#c07eff;--color-purple-500:#ac4bff;--color-purple-600:#9810fa;--color-purple-700:#8200da;--color-purple-950:#3c0366;--color-fuchsia-300:#f2a9ff;--color-fuchsia-400:#ec6cff;--color-zinc-50:#fafafa;--color-zinc-100:#f4f4f5;--color-zinc-200:#e4e4e7;--color-zinc-300:#d4d4d8;--color-zinc-400:#9f9fa9;--color-zinc-500:#71717b;--color-zinc-600:#52525c;--color-zinc-700:#3f3f46;--color-zinc-800:#27272a;--color-zinc-900:#18181b;--color-zinc-950:#09090b;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-lg:32rem;--container-2xl:42rem;--container-3xl:48rem;--container-4xl:56rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wider:.05em;--leading-relaxed:1.625;--radius-md:.375rem;--radius-lg:.5rem;--radius-2xl:1rem;--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--animate-bounce:bounce 1s infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-red-50:lab(96.5005% 4.18508 1.52328);--color-red-100:lab(92.243% 10.2865 3.83865);--color-red-200:lab(86.017% 19.8815 7.75869);--color-red-300:lab(76.5514% 36.422 15.5335);--color-red-400:lab(63.7053% 60.745 31.3109);--color-red-500:lab(55.4814% 75.0732 48.8528);--color-red-600:lab(48.4493% 77.4328 61.5452);--color-red-700:lab(40.4273% 67.2623 53.7441);--color-red-800:lab(33.7174% 55.8993 41.0293);--color-red-900:lab(28.5139% 44.5539 29.0463);--color-red-950:lab(13.003% 29.04 16.7519);--color-amber-50:lab(98.6252% -.635922 8.42309);--color-amber-100:lab(95.916% -1.21653 23.111);--color-amber-200:lab(91.7203% -.505269 49.9084);--color-amber-300:lab(86.4156% 6.13147 78.3961);--color-amber-400:lab(80.1641% 16.6016 99.2089);--color-amber-500:lab(72.7183% 31.8672 97.9407);--color-amber-600:lab(60.3514% 40.5624 87.1228);--color-amber-700:lab(47.2709% 42.9082 69.2966);--color-amber-800:lab(37.8822% 37.1699 52.2718);--color-amber-900:lab(31.2288% 30.2627 40.0378);--color-amber-950:lab(15.8111% 20.9107 23.3752);--color-yellow-200:lab(94.3433% -5.00429 52.9663);--color-yellow-300:lab(89.7033% -.480294 84.4917);--color-green-100:lab(96.1861% -13.8464 6.52365);--color-green-300:lab(86.9953% -47.2691 25.0054);--color-green-400:lab(78.503% -64.9265 39.7492);--color-green-600:lab(59.0978% -58.6621 41.2579);--color-green-700:lab(47.0329% -47.0239 31.4788);--color-green-900:lab(30.797% -29.6927 17.382);--color-emerald-50:lab(97.8462% -6.94966 1.85487);--color-emerald-100:lab(94.9004% -17.0769 5.63836);--color-emerald-200:lab(90.2247% -31.039 9.47084);--color-emerald-300:lab(83.9203% -48.7124 13.8849);--color-emerald-400:lab(75.0771% -60.7313 19.4147);--color-emerald-500:lab(66.9756% -58.27 19.5419);--color-emerald-600:lab(55.0481% -49.9246 15.93);--color-emerald-700:lab(44.4871% -41.0396 11.0361);--color-emerald-800:lab(35.3675% -33.1188 8.04002);--color-emerald-900:lab(28.8637% -26.9249 5.45986);--color-emerald-950:lab(15.0582% -17.9507 2.38369);--color-cyan-200:lab(91.0821% -24.0435 -12.8306);--color-cyan-300:lab(85.3886% -36.7636 -21.5716);--color-sky-50:lab(97.3623% -2.33802 -4.13098);--color-sky-100:lab(94.3709% -4.56053 -8.23453);--color-sky-300:lab(80.3307% -20.2945 -31.385);--color-sky-400:lab(70.687% -23.6078 -45.9483);--color-sky-500:lab(63.3038% -18.433 -51.0407);--color-sky-600:lab(51.7754% -11.4712 -49.8349);--color-sky-700:lab(41.6013% -9.10804 -42.5647);--color-sky-950:lab(17.8299% -5.31271 -21.1584);--color-blue-300:lab(77.5052% -6.4629 -36.42);--color-blue-400:lab(65.0361% -1.42065 -56.9802);--color-indigo-500:lab(48.295% 38.3129 -81.9673);--color-purple-100:lab(93.3333% 6.97437 -9.83434);--color-purple-300:lab(78.3298% 26.2195 -34.9499);--color-purple-400:lab(63.6946% 47.6127 -59.2066);--color-purple-500:lab(52.0183% 66.11 -78.2316);--color-purple-600:lab(43.0295% 75.21 -86.5669);--color-purple-700:lab(36.1758% 69.8525 -80.0381);--color-purple-950:lab(14.8253% 38.9005 -44.5861);--color-fuchsia-300:lab(78.5378% 39.3533 -32.9615);--color-fuchsia-400:lab(66.1178% 66.0652 -52.4733);--color-zinc-50:lab(98.26% 0 0);--color-zinc-100:lab(96.1634% .0993311 -.364041);--color-zinc-200:lab(90.6853% .399232 -1.45452);--color-zinc-300:lab(84.9837% .601262 -2.17986);--color-zinc-400:lab(65.6464% 1.53497 -5.42429);--color-zinc-500:lab(47.8878% 1.65477 -5.77283);--color-zinc-600:lab(35.1166% 1.78212 -6.1173);--color-zinc-700:lab(26.8019% 1.35387 -4.68303);--color-zinc-800:lab(15.7305% .613764 -2.16959);--color-zinc-900:lab(8.30603% .618205 -2.16572);--color-zinc-950:lab(2.51107% .242703 -.886115)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.top-0{top:calc(var(--spacing) * 0)}.top-1\/2{top:50%}.right-0{right:calc(var(--spacing) * 0)}.right-4{right:calc(var(--spacing) * 4)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-4{bottom:calc(var(--spacing) * 4)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing) * 2)}.left-2\.5{left:calc(var(--spacing) * 2.5)}.-z-10{z-index:calc(10 * -1)}.z-10{z-index:10}.z-50{z-index:50}.z-\[60\]{z-index:60}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.-mx-2{margin-inline:calc(var(--spacing) * -2)}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-12{margin-top:calc(var(--spacing) * 12)}.mr-1{margin-right:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-72{height:calc(var(--spacing) * 72)}.h-80{height:calc(var(--spacing) * 80)}.h-\[70vh\]{height:70vh}.h-\[420px\]{height:420px}.h-full{height:100%}.max-h-80{max-height:calc(var(--spacing) * 80)}.max-h-96{max-height:calc(var(--spacing) * 96)}.max-h-\[60vh\]{max-height:60vh}.max-h-\[200px\]{max-height:200px}.min-h-\[calc\(100vh-12rem\)\]{min-height:calc(100vh - 12rem)}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2{width:calc(var(--spacing) * 2)}.w-4{width:calc(var(--spacing) * 4)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-12{width:calc(var(--spacing) * 12)}.w-44{width:calc(var(--spacing) * 44)}.w-48{width:calc(var(--spacing) * 48)}.w-64{width:calc(var(--spacing) * 64)}.w-\[92vw\]{width:92vw}.w-\[340px\]{width:340px}.w-\[360px\]{width:360px}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-3xl{max-width:var(--container-3xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-\[18rem\]{max-width:18rem}.max-w-\[20rem\]{max-width:20rem}.max-w-\[80\%\]{max-width:80%}.max-w-\[90vw\]{max-width:90vw}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[12rem\]{min-width:12rem}.min-w-\[var\(--anchor-width\)\]{min-width:var(--anchor-width)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.animate-bounce{animation:var(--animate-bounce)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-help{cursor:help}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize{resize:both}.resize-none{resize:none}.scroll-mb-40{scroll-margin-bottom:calc(var(--spacing) * 40)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-\[auto_1fr\]{grid-template-columns:auto 1fr}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-8{gap:calc(var(--spacing) * 8)}.gap-x-3{column-gap:calc(var(--spacing) * 3)}.gap-y-1{row-gap:calc(var(--spacing) * 1)}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-zinc-200>:not(:last-child)){border-color:var(--color-zinc-200)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-none{border-radius:0}.rounded-t-2xl{border-top-left-radius:var(--radius-2xl);border-top-right-radius:var(--radius-2xl)}.rounded-l-md{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md)}.rounded-r-md{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.rounded-br-md{border-bottom-right-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-x-0{border-inline-style:var(--tw-border-style);border-inline-width:0}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r-0{border-right-style:var(--tw-border-style);border-right-width:0}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-l-0{border-left-style:var(--tw-border-style);border-left-width:0}.border-amber-200{border-color:var(--color-amber-200)}.border-amber-300{border-color:var(--color-amber-300)}.border-emerald-200{border-color:var(--color-emerald-200)}.border-emerald-300{border-color:var(--color-emerald-300)}.border-red-200{border-color:var(--color-red-200)}.border-red-300{border-color:var(--color-red-300)}.border-transparent{border-color:#0000}.border-zinc-200{border-color:var(--color-zinc-200)}.border-zinc-300{border-color:var(--color-zinc-300)}.bg-amber-50{background-color:var(--color-amber-50)}.bg-amber-100{background-color:var(--color-amber-100)}.bg-amber-500{background-color:var(--color-amber-500)}.bg-black{background-color:var(--color-black)}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab, red, red)){.bg-black\/40{background-color:color-mix(in oklab, var(--color-black) 40%, transparent)}}.bg-emerald-50{background-color:var(--color-emerald-50)}.bg-emerald-100{background-color:var(--color-emerald-100)}.bg-emerald-500{background-color:var(--color-emerald-500)}.bg-emerald-600{background-color:var(--color-emerald-600)}.bg-green-100{background-color:var(--color-green-100)}.bg-purple-100{background-color:var(--color-purple-100)}.bg-purple-500{background-color:var(--color-purple-500)}.bg-red-50{background-color:var(--color-red-50)}.bg-red-100{background-color:var(--color-red-100)}.bg-red-500{background-color:var(--color-red-500)}.bg-red-600{background-color:var(--color-red-600)}.bg-sky-50{background-color:var(--color-sky-50)}.bg-sky-100{background-color:var(--color-sky-100)}.bg-sky-500{background-color:var(--color-sky-500)}.bg-sky-600{background-color:var(--color-sky-600)}.bg-sky-600\/20{background-color:#0084cc33}@supports (color:color-mix(in lab, red, red)){.bg-sky-600\/20{background-color:color-mix(in oklab, var(--color-sky-600) 20%, transparent)}}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/80{background-color:#fffc}@supports (color:color-mix(in lab, red, red)){.bg-white\/80{background-color:color-mix(in oklab, var(--color-white) 80%, transparent)}}.bg-zinc-50{background-color:var(--color-zinc-50)}.bg-zinc-100{background-color:var(--color-zinc-100)}.bg-zinc-200{background-color:var(--color-zinc-200)}.bg-zinc-300{background-color:var(--color-zinc-300)}.bg-zinc-400{background-color:var(--color-zinc-400)}.bg-zinc-900{background-color:var(--color-zinc-900)}.bg-zinc-950{background-color:var(--color-zinc-950)}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-t{--tw-gradient-position:to top in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-sky-500{--tw-gradient-from:var(--color-sky-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-zinc-50{--tw-gradient-from:var(--color-zinc-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.via-zinc-50\/95{--tw-gradient-via:#fafafaf2}@supports (color:color-mix(in lab, red, red)){.via-zinc-50\/95{--tw-gradient-via:color-mix(in oklab, var(--color-zinc-50) 95%, transparent)}}.via-zinc-50\/95{--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-indigo-500{--tw-gradient-to:var(--color-indigo-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.fill-current{fill:currentColor}.fill-zinc-500{fill:var(--color-zinc-500)}.stroke-amber-500{stroke:var(--color-amber-500)}.stroke-emerald-500{stroke:var(--color-emerald-500)}.stroke-purple-500{stroke:var(--color-purple-500)}.stroke-sky-500{stroke:var(--color-sky-500)}.stroke-zinc-200{stroke:var(--color-zinc-200)}.p-0{padding:calc(var(--spacing) * 0)}.p-0\.5{padding:calc(var(--spacing) * .5)}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-12{padding-block:calc(var(--spacing) * 12)}.pt-0\.5{padding-top:calc(var(--spacing) * .5)}.pt-1{padding-top:calc(var(--spacing) * 1)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-3{padding-top:calc(var(--spacing) * 3)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pb-1{padding-bottom:calc(var(--spacing) * 1)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pl-7{padding-left:calc(var(--spacing) * 7)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-geist-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.break-words{overflow-wrap:break-word}.whitespace-pre-wrap{white-space:pre-wrap}.text-amber-500{color:var(--color-amber-500)}.text-amber-600{color:var(--color-amber-600)}.text-amber-700{color:var(--color-amber-700)}.text-amber-800{color:var(--color-amber-800)}.text-amber-900{color:var(--color-amber-900)}.text-blue-300{color:var(--color-blue-300)}.text-blue-400{color:var(--color-blue-400)}.text-cyan-200{color:var(--color-cyan-200)}.text-cyan-300{color:var(--color-cyan-300)}.text-emerald-300{color:var(--color-emerald-300)}.text-emerald-400{color:var(--color-emerald-400)}.text-emerald-500{color:var(--color-emerald-500)}.text-emerald-600{color:var(--color-emerald-600)}.text-emerald-700{color:var(--color-emerald-700)}.text-emerald-900{color:var(--color-emerald-900)}.text-fuchsia-300{color:var(--color-fuchsia-300)}.text-fuchsia-400{color:var(--color-fuchsia-400)}.text-green-400{color:var(--color-green-400)}.text-green-600{color:var(--color-green-600)}.text-green-700{color:var(--color-green-700)}.text-purple-500{color:var(--color-purple-500)}.text-purple-600{color:var(--color-purple-600)}.text-purple-700{color:var(--color-purple-700)}.text-red-300{color:var(--color-red-300)}.text-red-400{color:var(--color-red-400)}.text-red-500{color:var(--color-red-500)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-red-800{color:var(--color-red-800)}.text-red-900{color:var(--color-red-900)}.text-sky-400{color:var(--color-sky-400)}.text-sky-500{color:var(--color-sky-500)}.text-sky-600{color:var(--color-sky-600)}.text-sky-700{color:var(--color-sky-700)}.text-white{color:var(--color-white)}.text-yellow-200{color:var(--color-yellow-200)}.text-yellow-300{color:var(--color-yellow-300)}.text-zinc-100{color:var(--color-zinc-100)}.text-zinc-300{color:var(--color-zinc-300)}.text-zinc-400{color:var(--color-zinc-400)}.text-zinc-500{color:var(--color-zinc-500)}.text-zinc-600{color:var(--color-zinc-600)}.text-zinc-700{color:var(--color-zinc-700)}.text-zinc-800{color:var(--color-zinc-800)}.text-zinc-900{color:var(--color-zinc-900)}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.decoration-zinc-400{-webkit-text-decoration-color:var(--color-zinc-400);-webkit-text-decoration-color:var(--color-zinc-400);-webkit-text-decoration-color:var(--color-zinc-400);text-decoration-color:var(--color-zinc-400)}.decoration-dotted{text-decoration-style:dotted}.underline-offset-2{text-underline-offset:2px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-1{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-sky-600{--tw-ring-color:var(--color-sky-600)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur{--tw-backdrop-blur:blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-\[2px\]{--tw-backdrop-blur:blur(2px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.\[animation-delay\:-0\.3s\]{animation-delay:-.3s}.\[animation-delay\:-0\.15s\]{animation-delay:-.15s}.placeholder\:text-zinc-400::placeholder{color:var(--color-zinc-400)}.focus-within\:border-zinc-300:focus-within{border-color:var(--color-zinc-300)}.focus-within\:shadow-md:focus-within{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}@media (hover:hover){.hover\:bg-emerald-500:hover{background-color:var(--color-emerald-500)}.hover\:bg-red-500:hover{background-color:var(--color-red-500)}.hover\:bg-sky-500:hover{background-color:var(--color-sky-500)}.hover\:bg-zinc-50:hover{background-color:var(--color-zinc-50)}.hover\:bg-zinc-100:hover{background-color:var(--color-zinc-100)}.hover\:bg-zinc-200:hover{background-color:var(--color-zinc-200)}.hover\:bg-zinc-700:hover{background-color:var(--color-zinc-700)}.hover\:text-red-600:hover{color:var(--color-red-600)}.hover\:text-sky-600:hover{color:var(--color-sky-600)}.hover\:text-zinc-900:hover{color:var(--color-zinc-900)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}}.focus\:border-sky-500:focus{border-color:var(--color-sky-500)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-sky-500\/30:focus{--tw-ring-color:#00a5ef4d}@supports (color:color-mix(in lab, red, red)){.focus\:ring-sky-500\/30:focus{--tw-ring-color:color-mix(in oklab, var(--color-sky-500) 30%, transparent)}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus-visible\:ring-sky-500:focus-visible{--tw-ring-color:var(--color-sky-500)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:ring-offset-zinc-50:focus-visible{--tw-ring-offset-color:var(--color-zinc-50)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.active\:bg-emerald-700:active{background-color:var(--color-emerald-700)}.active\:bg-red-700:active{background-color:var(--color-red-700)}.active\:bg-sky-700:active{background-color:var(--color-sky-700)}.active\:bg-zinc-200:active{background-color:var(--color-zinc-200)}.active\:bg-zinc-300:active{background-color:var(--color-zinc-300)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-zinc-300:disabled{background-color:var(--color-zinc-300)}.disabled\:opacity-50:disabled{opacity:.5}.data-\[checked\]\:translate-x-4[data-checked]{--tw-translate-x:calc(var(--spacing) * 4);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[checked\]\:bg-sky-600[data-checked]{background-color:var(--color-sky-600)}.data-\[ending-style\]\:translate-x-2[data-ending-style]{--tw-translate-x:calc(var(--spacing) * 2);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[ending-style\]\:translate-x-full[data-ending-style]{--tw-translate-x:100%;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[ending-style\]\:scale-\[0\.97\][data-ending-style]{scale:.97}.data-\[ending-style\]\:opacity-0[data-ending-style]{opacity:0}.data-\[highlighted\]\:bg-sky-50[data-highlighted]{background-color:var(--color-sky-50)}.data-\[selected\]\:text-zinc-900[data-selected]{color:var(--color-zinc-900)}.data-\[selected\]\:after\:absolute[data-selected]:after{content:var(--tw-content);position:absolute}.data-\[selected\]\:after\:inset-x-0[data-selected]:after{content:var(--tw-content);inset-inline:calc(var(--spacing) * 0)}.data-\[selected\]\:after\:-bottom-px[data-selected]:after{content:var(--tw-content);bottom:-1px}.data-\[selected\]\:after\:h-0\.5[data-selected]:after{content:var(--tw-content);height:calc(var(--spacing) * .5)}.data-\[selected\]\:after\:bg-sky-600[data-selected]:after{content:var(--tw-content);background-color:var(--color-sky-600)}.data-\[starting-style\]\:translate-x-2[data-starting-style]{--tw-translate-x:calc(var(--spacing) * 2);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[starting-style\]\:translate-x-full[data-starting-style]{--tw-translate-x:100%;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[starting-style\]\:scale-\[0\.97\][data-starting-style]{scale:.97}.data-\[starting-style\]\:opacity-0[data-starting-style]{opacity:0}@media (min-width:40rem){.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\:flex-row{flex-direction:row}}@media (min-width:48rem){.md\:flex{display:flex}.md\:hidden{display:none}}@media (min-width:64rem){.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-5{grid-template-columns:repeat(5,minmax(0,1fr))}.lg\:grid-cols-\[1fr_360px\]{grid-template-columns:1fr 360px}}@media (min-width:80rem){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (prefers-color-scheme:dark){:where(.dark\:divide-zinc-800>:not(:last-child)){border-color:var(--color-zinc-800)}.dark\:border-amber-900{border-color:var(--color-amber-900)}.dark\:border-emerald-800{border-color:var(--color-emerald-800)}.dark\:border-emerald-900{border-color:var(--color-emerald-900)}.dark\:border-red-800{border-color:var(--color-red-800)}.dark\:border-red-900{border-color:var(--color-red-900)}.dark\:border-transparent{border-color:#0000}.dark\:border-zinc-700{border-color:var(--color-zinc-700)}.dark\:border-zinc-800{border-color:var(--color-zinc-800)}.dark\:bg-amber-400{background-color:var(--color-amber-400)}.dark\:bg-amber-950{background-color:var(--color-amber-950)}.dark\:bg-amber-950\/40{background-color:#46190166}@supports (color:color-mix(in lab, red, red)){.dark\:bg-amber-950\/40{background-color:color-mix(in oklab, var(--color-amber-950) 40%, transparent)}}.dark\:bg-emerald-400{background-color:var(--color-emerald-400)}.dark\:bg-emerald-500{background-color:var(--color-emerald-500)}.dark\:bg-emerald-950{background-color:var(--color-emerald-950)}.dark\:bg-green-900{background-color:var(--color-green-900)}.dark\:bg-purple-400{background-color:var(--color-purple-400)}.dark\:bg-purple-950{background-color:var(--color-purple-950)}.dark\:bg-red-400{background-color:var(--color-red-400)}.dark\:bg-red-500{background-color:var(--color-red-500)}.dark\:bg-red-950{background-color:var(--color-red-950)}.dark\:bg-sky-400{background-color:var(--color-sky-400)}.dark\:bg-sky-500{background-color:var(--color-sky-500)}.dark\:bg-sky-950{background-color:var(--color-sky-950)}.dark\:bg-transparent{background-color:#0000}.dark\:bg-zinc-100{background-color:var(--color-zinc-100)}.dark\:bg-zinc-500{background-color:var(--color-zinc-500)}.dark\:bg-zinc-700{background-color:var(--color-zinc-700)}.dark\:bg-zinc-800{background-color:var(--color-zinc-800)}.dark\:bg-zinc-900{background-color:var(--color-zinc-900)}.dark\:bg-zinc-900\/40{background-color:#18181b66}@supports (color:color-mix(in lab, red, red)){.dark\:bg-zinc-900\/40{background-color:color-mix(in oklab, var(--color-zinc-900) 40%, transparent)}}.dark\:bg-zinc-950{background-color:var(--color-zinc-950)}.dark\:bg-zinc-950\/80{background-color:#09090bcc}@supports (color:color-mix(in lab, red, red)){.dark\:bg-zinc-950\/80{background-color:color-mix(in oklab, var(--color-zinc-950) 80%, transparent)}}.dark\:from-zinc-950{--tw-gradient-from:var(--color-zinc-950);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.dark\:via-zinc-950\/95{--tw-gradient-via:#09090bf2}@supports (color:color-mix(in lab, red, red)){.dark\:via-zinc-950\/95{--tw-gradient-via:color-mix(in oklab, var(--color-zinc-950) 95%, transparent)}}.dark\:via-zinc-950\/95{--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.dark\:fill-zinc-400{fill:var(--color-zinc-400)}.dark\:stroke-amber-400{stroke:var(--color-amber-400)}.dark\:stroke-emerald-400{stroke:var(--color-emerald-400)}.dark\:stroke-purple-400{stroke:var(--color-purple-400)}.dark\:stroke-sky-400{stroke:var(--color-sky-400)}.dark\:stroke-zinc-800{stroke:var(--color-zinc-800)}.dark\:text-amber-200{color:var(--color-amber-200)}.dark\:text-amber-300{color:var(--color-amber-300)}.dark\:text-amber-400{color:var(--color-amber-400)}.dark\:text-emerald-100{color:var(--color-emerald-100)}.dark\:text-emerald-300{color:var(--color-emerald-300)}.dark\:text-emerald-400{color:var(--color-emerald-400)}.dark\:text-green-300{color:var(--color-green-300)}.dark\:text-purple-300{color:var(--color-purple-300)}.dark\:text-purple-400{color:var(--color-purple-400)}.dark\:text-red-100{color:var(--color-red-100)}.dark\:text-red-200{color:var(--color-red-200)}.dark\:text-red-300{color:var(--color-red-300)}.dark\:text-red-400{color:var(--color-red-400)}.dark\:text-sky-300{color:var(--color-sky-300)}.dark\:text-sky-400{color:var(--color-sky-400)}.dark\:text-zinc-100{color:var(--color-zinc-100)}.dark\:text-zinc-200{color:var(--color-zinc-200)}.dark\:text-zinc-300{color:var(--color-zinc-300)}.dark\:text-zinc-400{color:var(--color-zinc-400)}.dark\:text-zinc-500{color:var(--color-zinc-500)}.dark\:text-zinc-600{color:var(--color-zinc-600)}.dark\:text-zinc-700{color:var(--color-zinc-700)}.dark\:text-zinc-900{color:var(--color-zinc-900)}.dark\:placeholder\:text-zinc-500::placeholder{color:var(--color-zinc-500)}.dark\:focus-within\:border-zinc-700:focus-within{border-color:var(--color-zinc-700)}@media (hover:hover){.dark\:hover\:bg-emerald-400:hover{background-color:var(--color-emerald-400)}.dark\:hover\:bg-red-400:hover{background-color:var(--color-red-400)}.dark\:hover\:bg-sky-400:hover{background-color:var(--color-sky-400)}.dark\:hover\:bg-zinc-300:hover{background-color:var(--color-zinc-300)}.dark\:hover\:bg-zinc-700:hover{background-color:var(--color-zinc-700)}.dark\:hover\:bg-zinc-800:hover{background-color:var(--color-zinc-800)}.dark\:hover\:bg-zinc-950:hover{background-color:var(--color-zinc-950)}.dark\:hover\:text-red-400:hover{color:var(--color-red-400)}.dark\:hover\:text-sky-400:hover{color:var(--color-sky-400)}.dark\:hover\:text-zinc-100:hover{color:var(--color-zinc-100)}}.dark\:focus-visible\:ring-offset-zinc-950:focus-visible{--tw-ring-offset-color:var(--color-zinc-950)}.dark\:active\:bg-zinc-600:active{background-color:var(--color-zinc-600)}.dark\:active\:bg-zinc-700:active,.dark\:disabled\:bg-zinc-700:disabled{background-color:var(--color-zinc-700)}.dark\:disabled\:text-zinc-500:disabled{color:var(--color-zinc-500)}.dark\:data-\[checked\]\:bg-sky-500[data-checked]{background-color:var(--color-sky-500)}.dark\:data-\[highlighted\]\:bg-sky-950[data-highlighted]{background-color:var(--color-sky-950)}.dark\:data-\[selected\]\:text-zinc-100[data-selected]{color:var(--color-zinc-100)}.dark\:data-\[selected\]\:after\:bg-sky-400[data-selected]:after{content:var(--tw-content);background-color:var(--color-sky-400)}}}:root{--background:#fafafa;--foreground:#18181b;--cm-property:#0369a1;--cm-string:#15803d;--cm-atom:#9333ea;--cm-comment:#71717a;--cm-keyword:#b45309;--cm-meta:#71717a;--cm-punct:#52525b}@media (prefers-color-scheme:dark){:root{--background:#09090b;--foreground:#fafafa;--cm-property:#7dd3fc;--cm-string:#86efac;--cm-atom:#d8b4fe;--cm-comment:#a1a1aa;--cm-keyword:#fcd34d;--cm-meta:#a1a1aa;--cm-punct:#d4d4d8}}html,body{background:var(--background);color:var(--foreground)}body{font-family:var(--font-geist-sans), ui-sans-serif, system-ui, sans-serif;position:relative}#root-isolation{isolation:isolate}button:not(:disabled),[role=button]:not([aria-disabled=true]),[role=tab],[role=option],[role=menuitem]{cursor:pointer}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}
3
+ @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-content:""}}}@layer theme{:root,:host{--color-red-50:#fef2f2;--color-red-100:#ffe2e2;--color-red-200:#ffcaca;--color-red-300:#ffa3a3;--color-red-400:#ff6568;--color-red-500:#fb2c36;--color-red-600:#e40014;--color-red-700:#bf000f;--color-red-800:#9f0712;--color-red-900:#82181a;--color-red-950:#460809;--color-amber-50:#fffbeb;--color-amber-100:#fef3c6;--color-amber-200:#fee685;--color-amber-300:#ffd236;--color-amber-400:#fcbb00;--color-amber-500:#f99c00;--color-amber-600:#dd7400;--color-amber-700:#b75000;--color-amber-800:#953d00;--color-amber-900:#7b3306;--color-amber-950:#461901;--color-yellow-200:#fff085;--color-yellow-300:#ffe02a;--color-green-100:#dcfce7;--color-green-300:#7bf1a8;--color-green-400:#05df72;--color-green-600:#00a544;--color-green-700:#008138;--color-green-900:#0d542b;--color-emerald-50:#ecfdf5;--color-emerald-100:#d0fae5;--color-emerald-200:#a4f4cf;--color-emerald-300:#5ee9b5;--color-emerald-400:#00d294;--color-emerald-500:#00bb7f;--color-emerald-600:#009767;--color-emerald-700:#007956;--color-emerald-800:#005f46;--color-emerald-900:#004e3b;--color-emerald-950:#002c22;--color-cyan-200:#a2f4fd;--color-cyan-300:#53eafd;--color-sky-50:#f0f9ff;--color-sky-100:#dff2fe;--color-sky-300:#77d4ff;--color-sky-400:#00bcfe;--color-sky-500:#00a5ef;--color-sky-600:#0084cc;--color-sky-700:#0069a4;--color-sky-950:#052f4a;--color-blue-300:#90c5ff;--color-blue-400:#54a2ff;--color-indigo-500:#625fff;--color-purple-100:#f3e8ff;--color-purple-300:#d9b3ff;--color-purple-400:#c07eff;--color-purple-500:#ac4bff;--color-purple-600:#9810fa;--color-purple-700:#8200da;--color-purple-950:#3c0366;--color-fuchsia-300:#f2a9ff;--color-fuchsia-400:#ec6cff;--color-zinc-50:#fafafa;--color-zinc-100:#f4f4f5;--color-zinc-200:#e4e4e7;--color-zinc-300:#d4d4d8;--color-zinc-400:#9f9fa9;--color-zinc-500:#71717b;--color-zinc-600:#52525c;--color-zinc-700:#3f3f46;--color-zinc-800:#27272a;--color-zinc-900:#18181b;--color-zinc-950:#09090b;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-lg:32rem;--container-2xl:42rem;--container-3xl:48rem;--container-4xl:56rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wider:.05em;--leading-relaxed:1.625;--radius-md:.375rem;--radius-lg:.5rem;--radius-2xl:1rem;--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--animate-bounce:bounce 1s infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-red-50:lab(96.5005% 4.18508 1.52328);--color-red-100:lab(92.243% 10.2865 3.83865);--color-red-200:lab(86.017% 19.8815 7.75869);--color-red-300:lab(76.5514% 36.422 15.5335);--color-red-400:lab(63.7053% 60.745 31.3109);--color-red-500:lab(55.4814% 75.0732 48.8528);--color-red-600:lab(48.4493% 77.4328 61.5452);--color-red-700:lab(40.4273% 67.2623 53.7441);--color-red-800:lab(33.7174% 55.8993 41.0293);--color-red-900:lab(28.5139% 44.5539 29.0463);--color-red-950:lab(13.003% 29.04 16.7519);--color-amber-50:lab(98.6252% -.635922 8.42309);--color-amber-100:lab(95.916% -1.21653 23.111);--color-amber-200:lab(91.7203% -.505269 49.9084);--color-amber-300:lab(86.4156% 6.13147 78.3961);--color-amber-400:lab(80.1641% 16.6016 99.2089);--color-amber-500:lab(72.7183% 31.8672 97.9407);--color-amber-600:lab(60.3514% 40.5624 87.1228);--color-amber-700:lab(47.2709% 42.9082 69.2966);--color-amber-800:lab(37.8822% 37.1699 52.2718);--color-amber-900:lab(31.2288% 30.2627 40.0378);--color-amber-950:lab(15.8111% 20.9107 23.3752);--color-yellow-200:lab(94.3433% -5.00429 52.9663);--color-yellow-300:lab(89.7033% -.480294 84.4917);--color-green-100:lab(96.1861% -13.8464 6.52365);--color-green-300:lab(86.9953% -47.2691 25.0054);--color-green-400:lab(78.503% -64.9265 39.7492);--color-green-600:lab(59.0978% -58.6621 41.2579);--color-green-700:lab(47.0329% -47.0239 31.4788);--color-green-900:lab(30.797% -29.6927 17.382);--color-emerald-50:lab(97.8462% -6.94966 1.85487);--color-emerald-100:lab(94.9004% -17.0769 5.63836);--color-emerald-200:lab(90.2247% -31.039 9.47084);--color-emerald-300:lab(83.9203% -48.7124 13.8849);--color-emerald-400:lab(75.0771% -60.7313 19.4147);--color-emerald-500:lab(66.9756% -58.27 19.5419);--color-emerald-600:lab(55.0481% -49.9246 15.93);--color-emerald-700:lab(44.4871% -41.0396 11.0361);--color-emerald-800:lab(35.3675% -33.1188 8.04002);--color-emerald-900:lab(28.8637% -26.9249 5.45986);--color-emerald-950:lab(15.0582% -17.9507 2.38369);--color-cyan-200:lab(91.0821% -24.0435 -12.8306);--color-cyan-300:lab(85.3886% -36.7636 -21.5716);--color-sky-50:lab(97.3623% -2.33802 -4.13098);--color-sky-100:lab(94.3709% -4.56053 -8.23453);--color-sky-300:lab(80.3307% -20.2945 -31.385);--color-sky-400:lab(70.687% -23.6078 -45.9483);--color-sky-500:lab(63.3038% -18.433 -51.0407);--color-sky-600:lab(51.7754% -11.4712 -49.8349);--color-sky-700:lab(41.6013% -9.10804 -42.5647);--color-sky-950:lab(17.8299% -5.31271 -21.1584);--color-blue-300:lab(77.5052% -6.4629 -36.42);--color-blue-400:lab(65.0361% -1.42065 -56.9802);--color-indigo-500:lab(48.295% 38.3129 -81.9673);--color-purple-100:lab(93.3333% 6.97437 -9.83434);--color-purple-300:lab(78.3298% 26.2195 -34.9499);--color-purple-400:lab(63.6946% 47.6127 -59.2066);--color-purple-500:lab(52.0183% 66.11 -78.2316);--color-purple-600:lab(43.0295% 75.21 -86.5669);--color-purple-700:lab(36.1758% 69.8525 -80.0381);--color-purple-950:lab(14.8253% 38.9005 -44.5861);--color-fuchsia-300:lab(78.5378% 39.3533 -32.9615);--color-fuchsia-400:lab(66.1178% 66.0652 -52.4733);--color-zinc-50:lab(98.26% 0 0);--color-zinc-100:lab(96.1634% .0993311 -.364041);--color-zinc-200:lab(90.6853% .399232 -1.45452);--color-zinc-300:lab(84.9837% .601262 -2.17986);--color-zinc-400:lab(65.6464% 1.53497 -5.42429);--color-zinc-500:lab(47.8878% 1.65477 -5.77283);--color-zinc-600:lab(35.1166% 1.78212 -6.1173);--color-zinc-700:lab(26.8019% 1.35387 -4.68303);--color-zinc-800:lab(15.7305% .613764 -2.16959);--color-zinc-900:lab(8.30603% .618205 -2.16572);--color-zinc-950:lab(2.51107% .242703 -.886115)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.top-0{top:calc(var(--spacing) * 0)}.top-1\/2{top:50%}.right-0{right:calc(var(--spacing) * 0)}.right-4{right:calc(var(--spacing) * 4)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-4{bottom:calc(var(--spacing) * 4)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing) * 2)}.left-2\.5{left:calc(var(--spacing) * 2.5)}.-z-10{z-index:calc(10 * -1)}.z-10{z-index:10}.z-50{z-index:50}.z-\[60\]{z-index:60}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.-mx-2{margin-inline:calc(var(--spacing) * -2)}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-12{margin-top:calc(var(--spacing) * 12)}.mr-1{margin-right:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-56{height:calc(var(--spacing) * 56)}.h-80{height:calc(var(--spacing) * 80)}.h-\[70vh\]{height:70vh}.h-\[420px\]{height:420px}.h-full{height:100%}.max-h-80{max-height:calc(var(--spacing) * 80)}.max-h-96{max-height:calc(var(--spacing) * 96)}.max-h-\[60vh\]{max-height:60vh}.max-h-\[200px\]{max-height:200px}.min-h-\[calc\(100vh-12rem\)\]{min-height:calc(100vh - 12rem)}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2{width:calc(var(--spacing) * 2)}.w-4{width:calc(var(--spacing) * 4)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-12{width:calc(var(--spacing) * 12)}.w-44{width:calc(var(--spacing) * 44)}.w-48{width:calc(var(--spacing) * 48)}.w-64{width:calc(var(--spacing) * 64)}.w-\[92vw\]{width:92vw}.w-\[340px\]{width:340px}.w-\[360px\]{width:360px}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-3xl{max-width:var(--container-3xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-\[18rem\]{max-width:18rem}.max-w-\[20rem\]{max-width:20rem}.max-w-\[80\%\]{max-width:80%}.max-w-\[90vw\]{max-width:90vw}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[12rem\]{min-width:12rem}.min-w-\[var\(--anchor-width\)\]{min-width:var(--anchor-width)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.animate-bounce{animation:var(--animate-bounce)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-help{cursor:help}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize{resize:both}.resize-none{resize:none}.scroll-mb-40{scroll-margin-bottom:calc(var(--spacing) * 40)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-\[auto_1fr\]{grid-template-columns:auto 1fr}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-8{gap:calc(var(--spacing) * 8)}.gap-x-3{column-gap:calc(var(--spacing) * 3)}.gap-y-1{row-gap:calc(var(--spacing) * 1)}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-zinc-200>:not(:last-child)){border-color:var(--color-zinc-200)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-none{border-radius:0}.rounded-t-2xl{border-top-left-radius:var(--radius-2xl);border-top-right-radius:var(--radius-2xl)}.rounded-l-md{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md)}.rounded-r-md{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.rounded-br-md{border-bottom-right-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-x-0{border-inline-style:var(--tw-border-style);border-inline-width:0}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r-0{border-right-style:var(--tw-border-style);border-right-width:0}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-l-0{border-left-style:var(--tw-border-style);border-left-width:0}.border-amber-200{border-color:var(--color-amber-200)}.border-amber-300{border-color:var(--color-amber-300)}.border-emerald-200{border-color:var(--color-emerald-200)}.border-emerald-300{border-color:var(--color-emerald-300)}.border-red-200{border-color:var(--color-red-200)}.border-red-300{border-color:var(--color-red-300)}.border-transparent{border-color:#0000}.border-zinc-200{border-color:var(--color-zinc-200)}.border-zinc-300{border-color:var(--color-zinc-300)}.bg-amber-50{background-color:var(--color-amber-50)}.bg-amber-100{background-color:var(--color-amber-100)}.bg-amber-500{background-color:var(--color-amber-500)}.bg-black{background-color:var(--color-black)}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab, red, red)){.bg-black\/40{background-color:color-mix(in oklab, var(--color-black) 40%, transparent)}}.bg-emerald-50{background-color:var(--color-emerald-50)}.bg-emerald-100{background-color:var(--color-emerald-100)}.bg-emerald-500{background-color:var(--color-emerald-500)}.bg-emerald-600{background-color:var(--color-emerald-600)}.bg-green-100{background-color:var(--color-green-100)}.bg-purple-100{background-color:var(--color-purple-100)}.bg-purple-500{background-color:var(--color-purple-500)}.bg-red-50{background-color:var(--color-red-50)}.bg-red-100{background-color:var(--color-red-100)}.bg-red-500{background-color:var(--color-red-500)}.bg-red-600{background-color:var(--color-red-600)}.bg-sky-50{background-color:var(--color-sky-50)}.bg-sky-100{background-color:var(--color-sky-100)}.bg-sky-500{background-color:var(--color-sky-500)}.bg-sky-600{background-color:var(--color-sky-600)}.bg-sky-600\/20{background-color:#0084cc33}@supports (color:color-mix(in lab, red, red)){.bg-sky-600\/20{background-color:color-mix(in oklab, var(--color-sky-600) 20%, transparent)}}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/80{background-color:#fffc}@supports (color:color-mix(in lab, red, red)){.bg-white\/80{background-color:color-mix(in oklab, var(--color-white) 80%, transparent)}}.bg-zinc-50{background-color:var(--color-zinc-50)}.bg-zinc-100{background-color:var(--color-zinc-100)}.bg-zinc-200{background-color:var(--color-zinc-200)}.bg-zinc-300{background-color:var(--color-zinc-300)}.bg-zinc-400{background-color:var(--color-zinc-400)}.bg-zinc-900{background-color:var(--color-zinc-900)}.bg-zinc-950{background-color:var(--color-zinc-950)}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-t{--tw-gradient-position:to top in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-sky-500{--tw-gradient-from:var(--color-sky-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-zinc-50{--tw-gradient-from:var(--color-zinc-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.via-zinc-50\/95{--tw-gradient-via:#fafafaf2}@supports (color:color-mix(in lab, red, red)){.via-zinc-50\/95{--tw-gradient-via:color-mix(in oklab, var(--color-zinc-50) 95%, transparent)}}.via-zinc-50\/95{--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-indigo-500{--tw-gradient-to:var(--color-indigo-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.fill-current{fill:currentColor}.fill-zinc-500{fill:var(--color-zinc-500)}.stroke-amber-500{stroke:var(--color-amber-500)}.stroke-emerald-500{stroke:var(--color-emerald-500)}.stroke-purple-500{stroke:var(--color-purple-500)}.stroke-sky-500{stroke:var(--color-sky-500)}.stroke-zinc-200{stroke:var(--color-zinc-200)}.p-0{padding:calc(var(--spacing) * 0)}.p-0\.5{padding:calc(var(--spacing) * .5)}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-12{padding-block:calc(var(--spacing) * 12)}.pt-0\.5{padding-top:calc(var(--spacing) * .5)}.pt-1{padding-top:calc(var(--spacing) * 1)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-3{padding-top:calc(var(--spacing) * 3)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pb-1{padding-bottom:calc(var(--spacing) * 1)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pl-7{padding-left:calc(var(--spacing) * 7)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-geist-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.break-words{overflow-wrap:break-word}.whitespace-pre-wrap{white-space:pre-wrap}.text-amber-500{color:var(--color-amber-500)}.text-amber-600{color:var(--color-amber-600)}.text-amber-700{color:var(--color-amber-700)}.text-amber-800{color:var(--color-amber-800)}.text-amber-900{color:var(--color-amber-900)}.text-blue-300{color:var(--color-blue-300)}.text-blue-400{color:var(--color-blue-400)}.text-cyan-200{color:var(--color-cyan-200)}.text-cyan-300{color:var(--color-cyan-300)}.text-emerald-300{color:var(--color-emerald-300)}.text-emerald-400{color:var(--color-emerald-400)}.text-emerald-500{color:var(--color-emerald-500)}.text-emerald-600{color:var(--color-emerald-600)}.text-emerald-700{color:var(--color-emerald-700)}.text-emerald-900{color:var(--color-emerald-900)}.text-fuchsia-300{color:var(--color-fuchsia-300)}.text-fuchsia-400{color:var(--color-fuchsia-400)}.text-green-400{color:var(--color-green-400)}.text-green-600{color:var(--color-green-600)}.text-green-700{color:var(--color-green-700)}.text-purple-500{color:var(--color-purple-500)}.text-purple-600{color:var(--color-purple-600)}.text-purple-700{color:var(--color-purple-700)}.text-red-300{color:var(--color-red-300)}.text-red-400{color:var(--color-red-400)}.text-red-500{color:var(--color-red-500)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-red-800{color:var(--color-red-800)}.text-red-900{color:var(--color-red-900)}.text-sky-400{color:var(--color-sky-400)}.text-sky-500{color:var(--color-sky-500)}.text-sky-600{color:var(--color-sky-600)}.text-sky-700{color:var(--color-sky-700)}.text-white{color:var(--color-white)}.text-yellow-200{color:var(--color-yellow-200)}.text-yellow-300{color:var(--color-yellow-300)}.text-zinc-100{color:var(--color-zinc-100)}.text-zinc-300{color:var(--color-zinc-300)}.text-zinc-400{color:var(--color-zinc-400)}.text-zinc-500{color:var(--color-zinc-500)}.text-zinc-600{color:var(--color-zinc-600)}.text-zinc-700{color:var(--color-zinc-700)}.text-zinc-800{color:var(--color-zinc-800)}.text-zinc-900{color:var(--color-zinc-900)}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.decoration-zinc-400{-webkit-text-decoration-color:var(--color-zinc-400);-webkit-text-decoration-color:var(--color-zinc-400);-webkit-text-decoration-color:var(--color-zinc-400);text-decoration-color:var(--color-zinc-400)}.decoration-dotted{text-decoration-style:dotted}.underline-offset-2{text-underline-offset:2px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-1{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-sky-600{--tw-ring-color:var(--color-sky-600)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur{--tw-backdrop-blur:blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-\[2px\]{--tw-backdrop-blur:blur(2px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.\[animation-delay\:-0\.3s\]{animation-delay:-.3s}.\[animation-delay\:-0\.15s\]{animation-delay:-.15s}.placeholder\:text-zinc-400::placeholder{color:var(--color-zinc-400)}.focus-within\:border-zinc-300:focus-within{border-color:var(--color-zinc-300)}.focus-within\:shadow-md:focus-within{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}@media (hover:hover){.hover\:bg-emerald-500:hover{background-color:var(--color-emerald-500)}.hover\:bg-red-500:hover{background-color:var(--color-red-500)}.hover\:bg-sky-500:hover{background-color:var(--color-sky-500)}.hover\:bg-zinc-50:hover{background-color:var(--color-zinc-50)}.hover\:bg-zinc-100:hover{background-color:var(--color-zinc-100)}.hover\:bg-zinc-200:hover{background-color:var(--color-zinc-200)}.hover\:bg-zinc-700:hover{background-color:var(--color-zinc-700)}.hover\:text-red-600:hover{color:var(--color-red-600)}.hover\:text-sky-600:hover{color:var(--color-sky-600)}.hover\:text-zinc-900:hover{color:var(--color-zinc-900)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}}.focus\:border-sky-500:focus{border-color:var(--color-sky-500)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-sky-500\/30:focus{--tw-ring-color:#00a5ef4d}@supports (color:color-mix(in lab, red, red)){.focus\:ring-sky-500\/30:focus{--tw-ring-color:color-mix(in oklab, var(--color-sky-500) 30%, transparent)}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus-visible\:ring-sky-500:focus-visible{--tw-ring-color:var(--color-sky-500)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:ring-offset-zinc-50:focus-visible{--tw-ring-offset-color:var(--color-zinc-50)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.active\:bg-emerald-700:active{background-color:var(--color-emerald-700)}.active\:bg-red-700:active{background-color:var(--color-red-700)}.active\:bg-sky-700:active{background-color:var(--color-sky-700)}.active\:bg-zinc-200:active{background-color:var(--color-zinc-200)}.active\:bg-zinc-300:active{background-color:var(--color-zinc-300)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-zinc-300:disabled{background-color:var(--color-zinc-300)}.disabled\:opacity-50:disabled{opacity:.5}.data-\[checked\]\:translate-x-4[data-checked]{--tw-translate-x:calc(var(--spacing) * 4);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[checked\]\:bg-sky-600[data-checked]{background-color:var(--color-sky-600)}.data-\[ending-style\]\:translate-x-2[data-ending-style]{--tw-translate-x:calc(var(--spacing) * 2);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[ending-style\]\:translate-x-full[data-ending-style]{--tw-translate-x:100%;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[ending-style\]\:scale-\[0\.97\][data-ending-style]{scale:.97}.data-\[ending-style\]\:opacity-0[data-ending-style]{opacity:0}.data-\[highlighted\]\:bg-sky-50[data-highlighted]{background-color:var(--color-sky-50)}.data-\[selected\]\:text-zinc-900[data-selected]{color:var(--color-zinc-900)}.data-\[selected\]\:after\:absolute[data-selected]:after{content:var(--tw-content);position:absolute}.data-\[selected\]\:after\:inset-x-0[data-selected]:after{content:var(--tw-content);inset-inline:calc(var(--spacing) * 0)}.data-\[selected\]\:after\:-bottom-px[data-selected]:after{content:var(--tw-content);bottom:-1px}.data-\[selected\]\:after\:h-0\.5[data-selected]:after{content:var(--tw-content);height:calc(var(--spacing) * .5)}.data-\[selected\]\:after\:bg-sky-600[data-selected]:after{content:var(--tw-content);background-color:var(--color-sky-600)}.data-\[starting-style\]\:translate-x-2[data-starting-style]{--tw-translate-x:calc(var(--spacing) * 2);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[starting-style\]\:translate-x-full[data-starting-style]{--tw-translate-x:100%;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[starting-style\]\:scale-\[0\.97\][data-starting-style]{scale:.97}.data-\[starting-style\]\:opacity-0[data-starting-style]{opacity:0}@media (min-width:40rem){.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\:flex-row{flex-direction:row}}@media (min-width:48rem){.md\:flex{display:flex}.md\:hidden{display:none}}@media (min-width:64rem){.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-5{grid-template-columns:repeat(5,minmax(0,1fr))}.lg\:grid-cols-\[1fr_360px\]{grid-template-columns:1fr 360px}}@media (min-width:80rem){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (prefers-color-scheme:dark){:where(.dark\:divide-zinc-800>:not(:last-child)){border-color:var(--color-zinc-800)}.dark\:border-amber-900{border-color:var(--color-amber-900)}.dark\:border-emerald-800{border-color:var(--color-emerald-800)}.dark\:border-emerald-900{border-color:var(--color-emerald-900)}.dark\:border-red-800{border-color:var(--color-red-800)}.dark\:border-red-900{border-color:var(--color-red-900)}.dark\:border-transparent{border-color:#0000}.dark\:border-zinc-700{border-color:var(--color-zinc-700)}.dark\:border-zinc-800{border-color:var(--color-zinc-800)}.dark\:bg-amber-400{background-color:var(--color-amber-400)}.dark\:bg-amber-950{background-color:var(--color-amber-950)}.dark\:bg-amber-950\/40{background-color:#46190166}@supports (color:color-mix(in lab, red, red)){.dark\:bg-amber-950\/40{background-color:color-mix(in oklab, var(--color-amber-950) 40%, transparent)}}.dark\:bg-emerald-400{background-color:var(--color-emerald-400)}.dark\:bg-emerald-500{background-color:var(--color-emerald-500)}.dark\:bg-emerald-950{background-color:var(--color-emerald-950)}.dark\:bg-green-900{background-color:var(--color-green-900)}.dark\:bg-purple-400{background-color:var(--color-purple-400)}.dark\:bg-purple-950{background-color:var(--color-purple-950)}.dark\:bg-red-400{background-color:var(--color-red-400)}.dark\:bg-red-500{background-color:var(--color-red-500)}.dark\:bg-red-950{background-color:var(--color-red-950)}.dark\:bg-sky-400{background-color:var(--color-sky-400)}.dark\:bg-sky-500{background-color:var(--color-sky-500)}.dark\:bg-sky-950{background-color:var(--color-sky-950)}.dark\:bg-transparent{background-color:#0000}.dark\:bg-zinc-100{background-color:var(--color-zinc-100)}.dark\:bg-zinc-500{background-color:var(--color-zinc-500)}.dark\:bg-zinc-700{background-color:var(--color-zinc-700)}.dark\:bg-zinc-800{background-color:var(--color-zinc-800)}.dark\:bg-zinc-900{background-color:var(--color-zinc-900)}.dark\:bg-zinc-900\/40{background-color:#18181b66}@supports (color:color-mix(in lab, red, red)){.dark\:bg-zinc-900\/40{background-color:color-mix(in oklab, var(--color-zinc-900) 40%, transparent)}}.dark\:bg-zinc-950{background-color:var(--color-zinc-950)}.dark\:bg-zinc-950\/80{background-color:#09090bcc}@supports (color:color-mix(in lab, red, red)){.dark\:bg-zinc-950\/80{background-color:color-mix(in oklab, var(--color-zinc-950) 80%, transparent)}}.dark\:from-zinc-950{--tw-gradient-from:var(--color-zinc-950);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.dark\:via-zinc-950\/95{--tw-gradient-via:#09090bf2}@supports (color:color-mix(in lab, red, red)){.dark\:via-zinc-950\/95{--tw-gradient-via:color-mix(in oklab, var(--color-zinc-950) 95%, transparent)}}.dark\:via-zinc-950\/95{--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.dark\:fill-zinc-400{fill:var(--color-zinc-400)}.dark\:stroke-amber-400{stroke:var(--color-amber-400)}.dark\:stroke-emerald-400{stroke:var(--color-emerald-400)}.dark\:stroke-purple-400{stroke:var(--color-purple-400)}.dark\:stroke-sky-400{stroke:var(--color-sky-400)}.dark\:stroke-zinc-800{stroke:var(--color-zinc-800)}.dark\:text-amber-200{color:var(--color-amber-200)}.dark\:text-amber-300{color:var(--color-amber-300)}.dark\:text-amber-400{color:var(--color-amber-400)}.dark\:text-emerald-100{color:var(--color-emerald-100)}.dark\:text-emerald-300{color:var(--color-emerald-300)}.dark\:text-emerald-400{color:var(--color-emerald-400)}.dark\:text-green-300{color:var(--color-green-300)}.dark\:text-purple-300{color:var(--color-purple-300)}.dark\:text-purple-400{color:var(--color-purple-400)}.dark\:text-red-100{color:var(--color-red-100)}.dark\:text-red-200{color:var(--color-red-200)}.dark\:text-red-300{color:var(--color-red-300)}.dark\:text-red-400{color:var(--color-red-400)}.dark\:text-sky-300{color:var(--color-sky-300)}.dark\:text-sky-400{color:var(--color-sky-400)}.dark\:text-zinc-100{color:var(--color-zinc-100)}.dark\:text-zinc-200{color:var(--color-zinc-200)}.dark\:text-zinc-300{color:var(--color-zinc-300)}.dark\:text-zinc-400{color:var(--color-zinc-400)}.dark\:text-zinc-500{color:var(--color-zinc-500)}.dark\:text-zinc-600{color:var(--color-zinc-600)}.dark\:text-zinc-700{color:var(--color-zinc-700)}.dark\:text-zinc-900{color:var(--color-zinc-900)}.dark\:placeholder\:text-zinc-500::placeholder{color:var(--color-zinc-500)}.dark\:focus-within\:border-zinc-700:focus-within{border-color:var(--color-zinc-700)}@media (hover:hover){.dark\:hover\:bg-emerald-400:hover{background-color:var(--color-emerald-400)}.dark\:hover\:bg-red-400:hover{background-color:var(--color-red-400)}.dark\:hover\:bg-sky-400:hover{background-color:var(--color-sky-400)}.dark\:hover\:bg-zinc-300:hover{background-color:var(--color-zinc-300)}.dark\:hover\:bg-zinc-700:hover{background-color:var(--color-zinc-700)}.dark\:hover\:bg-zinc-800:hover{background-color:var(--color-zinc-800)}.dark\:hover\:bg-zinc-950:hover{background-color:var(--color-zinc-950)}.dark\:hover\:text-red-400:hover{color:var(--color-red-400)}.dark\:hover\:text-sky-400:hover{color:var(--color-sky-400)}.dark\:hover\:text-zinc-100:hover{color:var(--color-zinc-100)}}.dark\:focus-visible\:ring-offset-zinc-950:focus-visible{--tw-ring-offset-color:var(--color-zinc-950)}.dark\:active\:bg-zinc-600:active{background-color:var(--color-zinc-600)}.dark\:active\:bg-zinc-700:active,.dark\:disabled\:bg-zinc-700:disabled{background-color:var(--color-zinc-700)}.dark\:disabled\:text-zinc-500:disabled{color:var(--color-zinc-500)}.dark\:data-\[checked\]\:bg-sky-500[data-checked]{background-color:var(--color-sky-500)}.dark\:data-\[highlighted\]\:bg-sky-950[data-highlighted]{background-color:var(--color-sky-950)}.dark\:data-\[selected\]\:text-zinc-100[data-selected]{color:var(--color-zinc-100)}.dark\:data-\[selected\]\:after\:bg-sky-400[data-selected]:after{content:var(--tw-content);background-color:var(--color-sky-400)}}}:root{--background:#fafafa;--foreground:#18181b;--cm-property:#0369a1;--cm-string:#15803d;--cm-atom:#9333ea;--cm-comment:#71717a;--cm-keyword:#b45309;--cm-meta:#71717a;--cm-punct:#52525b}@media (prefers-color-scheme:dark){:root{--background:#09090b;--foreground:#fafafa;--cm-property:#7dd3fc;--cm-string:#86efac;--cm-atom:#d8b4fe;--cm-comment:#a1a1aa;--cm-keyword:#fcd34d;--cm-meta:#a1a1aa;--cm-punct:#d4d4d8}}html,body{background:var(--background);color:var(--foreground)}body{font-family:var(--font-geist-sans), ui-sans-serif, system-ui, sans-serif;position:relative}#root-isolation{isolation:isolate}button:not(:disabled),[role=button]:not([aria-disabled=true]),[role=tab],[role=option],[role=menuitem]{cursor:pointer}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}
package/dist/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "sparkrun-ui",
3
- "version": "1.2.2",
3
+ "version": "1.2.4",
4
4
  "description": "Web UI for sparkrun — launch and monitor inference workloads on NVIDIA DGX Spark clusters.",
5
5
  "license": "Apache-2.0",
6
6
  "homepage": "https://github.com/mcampa/sparkrun-ui",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "sparkrun-ui",
3
- "version": "1.2.2",
3
+ "version": "1.2.4",
4
4
  "description": "Web UI for sparkrun — launch and monitor inference workloads on NVIDIA DGX Spark clusters.",
5
5
  "license": "Apache-2.0",
6
6
  "homepage": "https://github.com/mcampa/sparkrun-ui",
@@ -1 +0,0 @@
1
- (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,2265,e=>{"use strict";var t=e.i(76350),s=e.i(33209);e.s(["Card",0,function({className:e,...r}){return(0,t.jsx)("div",{className:(0,s.cn)("rounded-lg border border-zinc-200 bg-white shadow-sm dark:border-zinc-800 dark:bg-zinc-900",e),...r})},"CardBody",0,function({className:e,...r}){return(0,t.jsx)("div",{className:(0,s.cn)("px-5 py-4",e),...r})},"CardDescription",0,function({className:e,...r}){return(0,t.jsx)("p",{className:(0,s.cn)("text-sm text-zinc-500 dark:text-zinc-400",e),...r})},"CardFooter",0,function({className:e,...r}){return(0,t.jsx)("div",{className:(0,s.cn)("flex items-center justify-end gap-2 border-t border-zinc-200 px-5 py-3 dark:border-zinc-800",e),...r})},"CardHeader",0,function({className:e,...r}){return(0,t.jsx)("div",{className:(0,s.cn)("flex flex-col gap-1 border-b border-zinc-200 px-5 py-4 dark:border-zinc-800",e),...r})},"CardTitle",0,function({className:e,...r}){return(0,t.jsx)("h3",{className:(0,s.cn)("text-base font-semibold text-zinc-900 dark:text-zinc-100",e),...r})}])},69393,e=>{"use strict";var t=e.i(76350),s=e.i(33209);let r={neutral:"bg-zinc-100 text-zinc-700 dark:bg-zinc-800 dark:text-zinc-300",sky:"bg-sky-100 text-sky-700 dark:bg-sky-950 dark:text-sky-300",green:"bg-emerald-100 text-emerald-700 dark:bg-emerald-950 dark:text-emerald-300",amber:"bg-amber-100 text-amber-700 dark:bg-amber-950 dark:text-amber-300",red:"bg-red-100 text-red-700 dark:bg-red-950 dark:text-red-300",purple:"bg-purple-100 text-purple-700 dark:bg-purple-950 dark:text-purple-300"};e.s(["Badge",0,function({tone:e="neutral",className:a,...i}){return(0,t.jsx)("span",{className:(0,s.cn)("inline-flex items-center gap-1 rounded px-1.5 py-0.5 text-xs font-medium",r[e],a),...i})}])},81807,e=>{"use strict";let t=(0,e.i(6927).default)("scroll-text",[["path",{d:"M15 12h-5",key:"r7krc0"}],["path",{d:"M15 8h-5",key:"1khuty"}],["path",{d:"M19 17V5a2 2 0 0 0-2-2H4",key:"zz82l3"}],["path",{d:"M8 21h12a2 2 0 0 0 2-2v-1a1 1 0 0 0-1-1H11a1 1 0 0 0-1 1v1a2 2 0 1 1-4 0V5a2 2 0 1 0-4 0v2a1 1 0 0 0 1 1h3",key:"1ph1d7"}]]);e.s(["ScrollText",0,t],81807)},84339,e=>{"use strict";let t=(0,e.i(6927).default)("loader-circle",[["path",{d:"M21 12a9 9 0 1 1-6.219-8.56",key:"13zald"}]]);e.s(["Loader2",0,t],84339)},83079,e=>{"use strict";var t=e.i(76350),s=e.i(73576),r=e.i(33209);let a={primary:"bg-sky-600 text-white hover:bg-sky-500 active:bg-sky-700 dark:bg-sky-500 dark:hover:bg-sky-400",secondary:"bg-zinc-100 text-zinc-900 hover:bg-zinc-200 active:bg-zinc-300 dark:bg-zinc-800 dark:text-zinc-100 dark:hover:bg-zinc-700 dark:active:bg-zinc-600 border border-zinc-200 dark:border-zinc-700",ghost:"text-zinc-700 hover:bg-zinc-100 active:bg-zinc-200 dark:text-zinc-300 dark:hover:bg-zinc-800 dark:active:bg-zinc-700",danger:"bg-red-600 text-white hover:bg-red-500 active:bg-red-700 dark:bg-red-500 dark:hover:bg-red-400",success:"bg-emerald-600 text-white hover:bg-emerald-500 active:bg-emerald-700 dark:bg-emerald-500 dark:hover:bg-emerald-400"},i={sm:"h-8 px-3 text-sm",md:"h-9 px-4 text-sm",lg:"h-10 px-5 text-base"},n=s.forwardRef(function({variant:e="secondary",size:s="md",className:n,...l},c){return(0,t.jsx)("button",{ref:c,className:(0,r.cn)("inline-flex items-center justify-center gap-2 rounded-md font-medium transition-colors cursor-pointer focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 focus-visible:ring-offset-zinc-50 dark:focus-visible:ring-offset-zinc-950 focus-visible:ring-sky-500 disabled:opacity-50 disabled:cursor-not-allowed",a[e],i[s],n),...l})});e.s(["Button",0,n])},63825,e=>{"use strict";let t=(0,e.i(6927).default)("triangle-alert",[["path",{d:"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3",key:"wmoenq"}],["path",{d:"M12 9v4",key:"juzpu7"}],["path",{d:"M12 17h.01",key:"p32p05"}]]);e.s(["AlertTriangle",0,t],63825)},44501,30650,e=>{"use strict";let t=(0,e.i(6927).default)("square",[["rect",{width:"18",height:"18",x:"3",y:"3",rx:"2",key:"afitv7"}]]);e.s(["Square",0,t],44501);var s=e.i(73576),r=e.i(21432);e.s(["useWorkloadHealth",0,function(e){let[t,a]=(0,s.useState)(null),[i,n]=(0,s.useState)(e);return e!==i&&(n(e),a(null)),(0,s.useEffect)(()=>{if(!e)return;let t=!1,s=new AbortController,i=async()=>{try{let i=await r.rpc.workloads.health({clusterId:e},{signal:s.signal});t||a(i)}catch{}};i();let n=setInterval(i,5e3);return()=>{t=!0,s.abort(),clearInterval(n)}},[e]),t??{ready:!1,state:"loading"}}],30650)},14779,38540,e=>{"use strict";var t=e.i(6927);let s=(0,t.default)("cpu",[["path",{d:"M12 20v2",key:"1lh1kg"}],["path",{d:"M12 2v2",key:"tus03m"}],["path",{d:"M17 20v2",key:"1rnc9c"}],["path",{d:"M17 2v2",key:"11trls"}],["path",{d:"M2 12h2",key:"1t8f8n"}],["path",{d:"M2 17h2",key:"7oei6x"}],["path",{d:"M2 7h2",key:"asdhe0"}],["path",{d:"M20 12h2",key:"1q8mjw"}],["path",{d:"M20 17h2",key:"1fpfkl"}],["path",{d:"M20 7h2",key:"1o8tra"}],["path",{d:"M7 20v2",key:"4gnj0m"}],["path",{d:"M7 2v2",key:"1i4yhu"}],["rect",{x:"4",y:"4",width:"16",height:"16",rx:"2",key:"1vbyd7"}],["rect",{x:"8",y:"8",width:"8",height:"8",rx:"1",key:"z9xiuo"}]]);e.s(["Cpu",0,s],14779);let r=(0,t.default)("server",[["rect",{width:"20",height:"8",x:"2",y:"2",rx:"2",ry:"2",key:"ngkwjq"}],["rect",{width:"20",height:"8",x:"2",y:"14",rx:"2",ry:"2",key:"iecqi9"}],["line",{x1:"6",x2:"6.01",y1:"6",y2:"6",key:"16zg32"}],["line",{x1:"6",x2:"6.01",y1:"18",y2:"18",key:"nzw8ys"}]]);e.s(["Server",0,r],38540)},66399,e=>{"use strict";var t=e.i(76350),s=e.i(73576),r=e.i(55367),a=e.i(84339),i=e.i(64477),n=e.i(82088),l=e.i(83079),c=e.i(69393),d=e.i(31307),o=e.i(21432);let x=new Map;e.s(["RecipeShowDialog",0,function({name:e,title:m,open:u,onOpenChange:h,running:p=!1,showLaunch:g=!0}){let[b,k]=(0,s.useState)(()=>x.get(e)??null),[f,j]=(0,s.useState)(null),[y,v]=(0,s.useState)(!1);return(0,s.useEffect)(()=>{if(!u)return;let t=x.get(e);if(t)return void k(t);let s=!1;return v(!0),j(null),o.rpc.recipes.show({name:e}).then(t=>{s||(x.set(e,t.text),k(t.text))}).catch(e=>{s||j(e instanceof Error?e.message:String(e))}).finally(()=>{s||v(!1)}),()=>{s=!0}},[u,e]),(0,t.jsx)(n.Dialog,{open:u,onOpenChange:h,children:(0,t.jsxs)(n.Dialog.Content,{title:m??e,size:"xl",description:"sparkrun recipe show",children:[(0,t.jsx)(n.Dialog.Body,{children:y&&!b?(0,t.jsxs)("div",{className:"flex items-center gap-2 text-sm text-zinc-500",children:[(0,t.jsx)(a.Loader2,{size:14,className:"animate-spin"})," loading…"]}):f?(0,t.jsx)("p",{className:"text-sm text-red-600 dark:text-red-400",children:f}):b?(0,t.jsx)(d.YamlEditor,{value:b,readOnly:!0,className:"max-h-[60vh]"}):null}),(0,t.jsxs)(n.Dialog.Footer,{children:[(0,t.jsx)(n.Dialog.Close,{render:(0,t.jsx)(l.Button,{variant:"ghost",type:"button",children:"Close"})}),p?(0,t.jsx)(c.Badge,{tone:"green",children:"already running"}):g?(0,t.jsx)(r.default,{href:`/launch?recipe=${encodeURIComponent(e)}`,children:(0,t.jsxs)(l.Button,{variant:"primary",children:[(0,t.jsx)(i.Rocket,{size:14}),"Launch"]})}):null]})]})})}])},60632,e=>{"use strict";var t=e.i(76350),s=e.i(73576),r=e.i(55367),a=e.i(63825),i=e.i(64477),n=e.i(21432),l=e.i(2265),c=e.i(69393),d=e.i(83079),o=e.i(75261),x=e.i(4403),m=e.i(44501),u=e.i(81807),h=e.i(84339),p=e.i(82088),g=e.i(84538),b=e.i(66399),k=e.i(30650);function f({workload:e,recipe:a}){var i,c,h;let y,v,[z,N]=(0,s.useState)(!1),[w,C]=(0,s.useState)(!1),[M,_]=(0,s.useTransition)(),T=(0,k.useWorkloadHealth)(e.cluster_id),S=e.meta.model||e.meta.recipe||e.cluster_id,G=function(e){if(!e)return null;let t=e.match(/^Up\s+(.+?)(?:\s*\([^)]*\))?\s*$/);return t?.[1]??null}(e.status),B=a?.registeredName??e.meta.recipe;return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsxs)(l.Card,{children:[(0,t.jsx)(l.CardHeader,{children:(0,t.jsx)(l.CardTitle,{className:"text-sm font-semibold",children:S})}),(0,t.jsxs)(l.CardBody,{className:"flex flex-col gap-3 text-sm",children:[(0,t.jsxs)("dl",{className:"grid grid-cols-[auto_1fr] gap-x-3 gap-y-1 text-xs",children:[a&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Recipe"}),(0,t.jsx)("dd",{children:B?(0,t.jsx)("button",{type:"button",onClick:()=>C(!0),className:"cursor-pointer font-medium text-sky-600 hover:underline dark:text-sky-400",children:a.label}):(0,t.jsx)("span",{className:"font-medium text-zinc-700 dark:text-zinc-300",children:a.label})})]}),e.meta.port&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Port"}),(0,t.jsx)("dd",{className:"font-mono text-zinc-700 dark:text-zinc-300",children:e.meta.port})]}),e.host&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Host"}),(0,t.jsx)("dd",{className:"font-mono text-zinc-700 dark:text-zinc-300",children:e.host})]}),G&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Uptime"}),(0,t.jsx)("dd",{className:"text-zinc-700 dark:text-zinc-300",children:G})]}),(0,t.jsx)("dt",{className:"text-zinc-500 dark:text-zinc-400",children:"Status"}),(0,t.jsx)("dd",{children:(0,t.jsx)(j,{health:T,containerStatus:e.status})})]}),(0,t.jsxs)("div",{className:"flex justify-end gap-2 pt-2",children:[e.host&&e.meta.port&&(0,t.jsx)(r.default,{href:`/chat?clusterId=${encodeURIComponent(e.cluster_id)}`,children:(0,t.jsxs)(d.Button,{variant:"ghost",size:"sm",children:[(0,t.jsx)(x.MessageSquare,{size:14}),"Chat"]})}),(0,t.jsx)(r.default,{href:`/logs/${e.cluster_id}`,children:(0,t.jsxs)(d.Button,{variant:"ghost",size:"sm",children:[(0,t.jsx)(u.ScrollText,{size:14}),"Logs"]})}),(0,t.jsx)(r.default,{href:(i=a,c=e.meta.model,h=function(e){let t=e?.overrides,s=t?.served_model_name;if("string"==typeof s&&s)return s;let r=e?.recipe_state,a=r?._applied_overrides,i=a?.served_model_name;if("string"==typeof i&&i)return i;let n=r?._raw,l=n?.defaults,c=l?.served_model_name;if("string"==typeof c&&c)return c}(e.meta),y=i?.registeredName??i?.label,v=new URLSearchParams,y&&v.set("recipe",y),c&&v.set("model",c),h&&v.set("servedModelName",h),v.set("skipRun","1"),`/benchmarks/new?${v.toString()}`),children:(0,t.jsxs)(d.Button,{variant:"ghost",size:"sm",children:[(0,t.jsx)(o.Gauge,{size:14}),"Benchmark"]})}),(0,t.jsxs)(d.Button,{variant:"danger",size:"sm",onClick:()=>N(!0),disabled:M,children:[(0,t.jsx)(m.Square,{size:14}),M?"Stopping…":"Stop"]})]})]})]}),(0,t.jsx)(p.AlertDialog,{open:z,onOpenChange:N,title:"Stop this workload?",description:(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("span",{className:"block font-mono",children:S}),(0,t.jsxs)("span",{className:"mt-2 block",children:["The container will be terminated on ",e.host??"the target host","."]})]}),confirmLabel:"Stop",destructive:!0,onConfirm:()=>{_(async()=>{try{await n.rpc.workloads.stop({clusterId:e.cluster_id}),g.toast.success("Stop requested",`${S} is shutting down`)}catch(t){let e=t instanceof Error?t.message:"Unknown error";g.toast.error("Stop failed",e)}})}}),a&&B&&(0,t.jsx)(b.RecipeShowDialog,{name:B,title:a.label,open:w,onOpenChange:e=>!e&&C(!1),showLaunch:!1})]})}function j({health:e,containerStatus:s}){return e.ready?(0,t.jsxs)("span",{className:"inline-flex items-center gap-1.5",children:[(0,t.jsx)("span",{className:"h-1.5 w-1.5 rounded-full bg-emerald-500"}),(0,t.jsx)("span",{className:"text-zinc-700 dark:text-zinc-300",children:"Ready"})]}):"loading"===e.state?(0,t.jsxs)("span",{className:"inline-flex items-center gap-1.5",children:[(0,t.jsx)(h.Loader2,{size:10,className:"animate-spin text-zinc-400"}),(0,t.jsx)("span",{className:"text-zinc-500 capitalize dark:text-zinc-400",children:s??"Checking…"})]}):"starting"===e.state?(0,t.jsxs)("span",{className:"inline-flex items-center gap-1.5",children:[(0,t.jsx)(h.Loader2,{size:10,className:"animate-spin text-amber-500"}),(0,t.jsx)("span",{className:"text-amber-700 dark:text-amber-300",children:"Starting…"})]}):(0,t.jsxs)("span",{className:"inline-flex items-center gap-1.5",children:[(0,t.jsx)("span",{className:"h-1.5 w-1.5 rounded-full bg-red-500"}),(0,t.jsx)("span",{className:"text-red-700 dark:text-red-300",title:e.reason??void 0,children:"Unreachable"})]})}var y=e.i(14779);let v=(0,e.i(6927).default)("memory-stick",[["path",{d:"M12 12v-2",key:"fwoke6"}],["path",{d:"M12 18v-2",key:"qj6yno"}],["path",{d:"M16 12v-2",key:"heuere"}],["path",{d:"M16 18v-2",key:"s1ct0w"}],["path",{d:"M2 11h1.5",key:"15p63e"}],["path",{d:"M20 18v-2",key:"12ehxp"}],["path",{d:"M20.5 11H22",key:"khsy7a"}],["path",{d:"M4 18v-2",key:"1c3oqr"}],["path",{d:"M8 12v-2",key:"1mwtfd"}],["path",{d:"M8 18v-2",key:"qcmpov"}],["rect",{x:"2",y:"6",width:"20",height:"10",rx:"2",key:"1qcswk"}]]);var z=e.i(38540),N=e.i(74799),w=e.i(98638);function C(e){if(!e)return 0;let t=parseFloat(e);return Number.isFinite(t)?t:0}function M(e){if(!e)return{hostCount:0,cpuAvg:0,gpuAvg:0,memUsedGb:0,memTotalGb:0,gpuMemUsedGb:0,gpuMemTotalGb:0,powerW:0,cpuTempC:0,gpuTempC:0,jobsTotal:0};let t=Object.values(e.hosts),s=0,r=0,a=0,i=0,n=0,l=0,c=0,d=0,o=0,x=0;for(let e of t)s+=C(e.cpu_usage_pct),r+=C(e.gpu_util_pct),a+=C(e.mem_used_mb),i+=C(e.mem_total_mb),n+=C(e.gpu_mem_used_mb),l+=C(e.gpu_mem_total_mb),c+=C(e.gpu_power_w),d+=C(e.cpu_temp_c),o+=C(e.gpu_temp_c),x+=C(e.sparkrun_jobs);let m=t.length||1;return{hostCount:t.length,cpuAvg:s/m,gpuAvg:r/m,memUsedGb:a/1024,memTotalGb:i/1024,gpuMemUsedGb:n/1024,gpuMemTotalGb:l/1024,powerW:c,cpuTempC:d/m,gpuTempC:o/m,jobsTotal:x}}function _(){let[e,r]=(0,s.useState)(null),[a,i]=(0,s.useState)({cpu:[],gpu:[]}),[c,d]=(0,s.useState)(!1);(0,s.useEffect)(()=>{let e=new AbortController,t=!1;return(async()=>{try{let s=await n.rpc.monitor.stream({intervalSec:2},{signal:e.signal});for await(let e of(d(!0),s)){if(t)break;r(e);let s=M(e);i(e=>({cpu:T(e.cpu,s.cpuAvg),gpu:T(e.gpu,s.gpuAvg)}))}}catch(e){t||e instanceof DOMException&&"AbortError"===e.name||console.error("[monitor.stream]",e)}finally{t||d(!1)}})(),()=>{t=!0,e.abort()}},[]);let o=M(e),x=o.memTotalGb?o.memUsedGb/o.memTotalGb*100:0,m=o.gpuMemTotalGb?o.gpuMemUsedGb/o.gpuMemTotalGb*100:0;return(0,t.jsx)(l.Card,{children:(0,t.jsxs)(l.CardBody,{className:"p-5",children:[(0,t.jsxs)("div",{className:"mb-4 flex items-baseline justify-between",children:[(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)(z.Server,{size:14,className:"text-zinc-500"}),(0,t.jsx)("span",{className:"text-sm font-medium text-zinc-700 dark:text-zinc-300",children:"Cluster overview"}),(0,t.jsxs)("span",{className:"text-xs text-zinc-500",children:["· ",o.hostCount||"—"," host",1===o.hostCount?"":"s"," · ",o.jobsTotal," job",1===o.jobsTotal?"":"s"]})]}),(0,t.jsx)("span",{className:"inline-flex h-2 w-2 rounded-full "+(c?"animate-pulse bg-emerald-500":"bg-zinc-300"),title:c?"live":"reconnecting"})]}),(0,t.jsxs)("div",{className:"grid grid-cols-2 gap-4 sm:grid-cols-3 lg:grid-cols-5",children:[(0,t.jsx)($,{icon:(0,t.jsx)(y.Cpu,{size:14}),tone:"sky",label:"CPU",value:`${o.cpuAvg.toFixed(1)}%`,sub:`avg across ${o.hostCount||0}`,pct:o.cpuAvg,spark:a.cpu}),(0,t.jsx)($,{icon:(0,t.jsx)(w.Zap,{size:14}),tone:"purple",label:"GPU",value:`${o.gpuAvg.toFixed(0)}%`,sub:`avg across ${o.hostCount||0}`,pct:o.gpuAvg,spark:a.gpu}),(0,t.jsx)($,{icon:(0,t.jsx)(v,{size:14}),tone:"green",label:"Memory",value:`${o.memUsedGb.toFixed(0)} / ${o.memTotalGb.toFixed(0)} GB`,sub:`${x.toFixed(0)}% used`,pct:x}),(0,t.jsx)($,{icon:(0,t.jsx)(w.Zap,{size:14}),tone:"amber",label:"Power",value:`${o.powerW.toFixed(1)} W`,sub:o.gpuMemTotalGb?`GPU mem ${o.gpuMemUsedGb.toFixed(0)}/${o.gpuMemTotalGb.toFixed(0)} GB`:"total GPU draw",pct:m}),(0,t.jsx)($,{icon:(0,t.jsx)(N.Thermometer,{size:14}),tone:"red",label:"Temps",value:o.cpuTempC||o.gpuTempC?`${o.gpuTempC.toFixed(0)}\xb0C / ${o.cpuTempC.toFixed(0)}\xb0C`:"—",sub:"GPU / CPU avg",pct:o.gpuTempC>0?Math.min(100,o.gpuTempC/100*100):0})]})]})})}function T(e,t){let s=e.concat(t);return s.length>40?s.slice(-40):s}let S={sky:"bg-sky-500 dark:bg-sky-400",purple:"bg-purple-500 dark:bg-purple-400",green:"bg-emerald-500 dark:bg-emerald-400",amber:"bg-amber-500 dark:bg-amber-400",red:"bg-red-500 dark:bg-red-400"},G={sky:"stroke-sky-500 dark:stroke-sky-400",purple:"stroke-purple-500 dark:stroke-purple-400",green:"stroke-emerald-500 dark:stroke-emerald-400",amber:"stroke-amber-500 dark:stroke-amber-400"},B={sky:"text-sky-600 dark:text-sky-400",purple:"text-purple-600 dark:text-purple-400",green:"text-emerald-600 dark:text-emerald-400",amber:"text-amber-600 dark:text-amber-400",red:"text-red-600 dark:text-red-400"};function $({icon:e,label:s,value:r,sub:a,pct:i,tone:n,spark:l}){let c=Math.max(0,Math.min(100,i));return(0,t.jsxs)("div",{className:"flex flex-col gap-1.5",children:[(0,t.jsxs)("div",{className:"flex items-center justify-between",children:[(0,t.jsxs)("div",{className:`flex items-center gap-1.5 text-xs font-medium ${B[n]}`,children:[e,s]}),l&&l.length>2&&(0,t.jsx)(U,{values:l,className:G[n]})]}),(0,t.jsx)("div",{className:"font-mono text-xl font-semibold text-zinc-900 dark:text-zinc-100",children:r}),(0,t.jsx)("div",{className:"h-1.5 overflow-hidden rounded bg-zinc-100 dark:bg-zinc-800",children:(0,t.jsx)("div",{className:`${S[n]} h-full transition-all duration-300`,style:{width:`${c}%`}})}),(0,t.jsx)("div",{className:"text-[11px] text-zinc-500 dark:text-zinc-400",children:a})]})}function U({values:e,className:s}){let r=Math.max(100,...e),a=56/Math.max(1,e.length-1),i=e.map((e,t)=>`${0===t?"M":"L"} ${t*a} ${16-e/r*16}`).join(" ");return(0,t.jsx)("svg",{width:56,height:16,viewBox:"0 0 56 16",className:"flex-shrink-0",children:(0,t.jsx)("path",{d:i,fill:"none",strokeWidth:1.25,className:s})})}e.s(["DashboardLive",0,function({initial:e,recipeByCluster:o}){let[x,m]=(0,s.useState)(e),[u,h]=(0,s.useState)(!0);return(0,s.useEffect)(()=>{let e=new AbortController,t=!1;return(async()=>{try{for await(let s of(await n.rpc.status.stream({intervalMs:3e3},{signal:e.signal}))){if(t)break;m(s),h(!0)}}catch(e){t||h(!1),e instanceof DOMException&&"AbortError"===e.name||console.error("[status.stream]",e)}})(),()=>{t=!0,e.abort()}},[]),(0,t.jsxs)("div",{className:"flex flex-col gap-6",children:[(0,t.jsxs)("div",{className:"flex items-baseline justify-between",children:[(0,t.jsx)("h1",{className:"text-2xl font-semibold tracking-tight",children:"Dashboard"}),(0,t.jsxs)("div",{className:"flex items-center gap-2 text-sm",children:[(0,t.jsxs)(c.Badge,{tone:"sky",children:[x.host_count," host",1===x.host_count?"":"s"]}),(0,t.jsxs)(c.Badge,{tone:"green",children:[x.total_containers," running"]}),(0,t.jsx)(c.Badge,{tone:u?"neutral":"amber",children:u?"live":"reconnecting…"})]})]}),(0,t.jsx)(_,{}),Object.keys(x.errors).length>0&&(0,t.jsx)(l.Card,{className:"border-amber-300 bg-amber-50 dark:border-amber-900 dark:bg-amber-950/40",children:(0,t.jsxs)(l.CardBody,{className:"flex gap-3",children:[(0,t.jsx)(a.AlertTriangle,{className:"mt-0.5 shrink-0 text-amber-600 dark:text-amber-400",size:18}),(0,t.jsxs)("div",{className:"flex flex-col gap-1 text-sm",children:[(0,t.jsx)("h3",{className:"font-medium text-amber-900 dark:text-amber-200",children:"Cluster status reported errors"}),(0,t.jsx)("ul",{className:"flex flex-col gap-1 text-amber-800 dark:text-amber-300",children:Object.entries(x.errors).map(([e,s])=>(0,t.jsxs)("li",{className:"font-mono text-xs",children:[(0,t.jsxs)("span",{className:"font-semibold",children:[e,":"]})," ","string"==typeof s?s:s&&"object"==typeof s&&"message"in s?String(s.message):JSON.stringify(s)]},e))})]})]})}),(0,t.jsxs)("div",{className:"flex flex-col gap-3",children:[(0,t.jsx)("h2",{className:"text-sm font-medium text-zinc-700 dark:text-zinc-300",children:"Workloads"}),0===x.solo_entries.length?(0,t.jsx)(l.Card,{children:(0,t.jsxs)(l.CardBody,{className:"flex flex-col items-center gap-4 py-12 text-center",children:[(0,t.jsx)("div",{className:"flex h-12 w-12 items-center justify-center rounded-full bg-sky-50 text-sky-600 dark:bg-sky-950 dark:text-sky-400",children:(0,t.jsx)(i.Rocket,{size:22})}),(0,t.jsxs)("div",{className:"flex flex-col gap-1",children:[(0,t.jsx)("h3",{className:"text-base font-semibold text-zinc-900 dark:text-zinc-100",children:"No workloads running"}),(0,t.jsx)("p",{className:"text-sm text-zinc-500 dark:text-zinc-400",children:"Launch a recipe to start an inference workload on your cluster."})]}),(0,t.jsx)(r.default,{href:"/launch",children:(0,t.jsxs)(d.Button,{variant:"primary",children:[(0,t.jsx)(i.Rocket,{size:14}),"Launch a recipe"]})})]})}):(0,t.jsx)("div",{className:"grid grid-cols-1 gap-4 lg:grid-cols-2",children:x.solo_entries.map(e=>(0,t.jsx)(f,{workload:e,recipe:o.get(e.cluster_id)},e.cluster_id))})]})]})}],60632)}]);
@@ -1 +0,0 @@
1
- (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,2265,e=>{"use strict";var t=e.i(76350),r=e.i(33209);e.s(["Card",0,function({className:e,...s}){return(0,t.jsx)("div",{className:(0,r.cn)("rounded-lg border border-zinc-200 bg-white shadow-sm dark:border-zinc-800 dark:bg-zinc-900",e),...s})},"CardBody",0,function({className:e,...s}){return(0,t.jsx)("div",{className:(0,r.cn)("px-5 py-4",e),...s})},"CardDescription",0,function({className:e,...s}){return(0,t.jsx)("p",{className:(0,r.cn)("text-sm text-zinc-500 dark:text-zinc-400",e),...s})},"CardFooter",0,function({className:e,...s}){return(0,t.jsx)("div",{className:(0,r.cn)("flex items-center justify-end gap-2 border-t border-zinc-200 px-5 py-3 dark:border-zinc-800",e),...s})},"CardHeader",0,function({className:e,...s}){return(0,t.jsx)("div",{className:(0,r.cn)("flex flex-col gap-1 border-b border-zinc-200 px-5 py-4 dark:border-zinc-800",e),...s})},"CardTitle",0,function({className:e,...s}){return(0,t.jsx)("h3",{className:(0,r.cn)("text-base font-semibold text-zinc-900 dark:text-zinc-100",e),...s})}])},69393,e=>{"use strict";var t=e.i(76350),r=e.i(33209);let s={neutral:"bg-zinc-100 text-zinc-700 dark:bg-zinc-800 dark:text-zinc-300",sky:"bg-sky-100 text-sky-700 dark:bg-sky-950 dark:text-sky-300",green:"bg-emerald-100 text-emerald-700 dark:bg-emerald-950 dark:text-emerald-300",amber:"bg-amber-100 text-amber-700 dark:bg-amber-950 dark:text-amber-300",red:"bg-red-100 text-red-700 dark:bg-red-950 dark:text-red-300",purple:"bg-purple-100 text-purple-700 dark:bg-purple-950 dark:text-purple-300"};e.s(["Badge",0,function({tone:e="neutral",className:n,...a}){return(0,t.jsx)("span",{className:(0,r.cn)("inline-flex items-center gap-1 rounded px-1.5 py-0.5 text-xs font-medium",s[e],n),...a})}])},14779,38540,e=>{"use strict";var t=e.i(6927);let r=(0,t.default)("cpu",[["path",{d:"M12 20v2",key:"1lh1kg"}],["path",{d:"M12 2v2",key:"tus03m"}],["path",{d:"M17 20v2",key:"1rnc9c"}],["path",{d:"M17 2v2",key:"11trls"}],["path",{d:"M2 12h2",key:"1t8f8n"}],["path",{d:"M2 17h2",key:"7oei6x"}],["path",{d:"M2 7h2",key:"asdhe0"}],["path",{d:"M20 12h2",key:"1q8mjw"}],["path",{d:"M20 17h2",key:"1fpfkl"}],["path",{d:"M20 7h2",key:"1o8tra"}],["path",{d:"M7 20v2",key:"4gnj0m"}],["path",{d:"M7 2v2",key:"1i4yhu"}],["rect",{x:"4",y:"4",width:"16",height:"16",rx:"2",key:"1vbyd7"}],["rect",{x:"8",y:"8",width:"8",height:"8",rx:"1",key:"z9xiuo"}]]);e.s(["Cpu",0,r],14779);let s=(0,t.default)("server",[["rect",{width:"20",height:"8",x:"2",y:"2",rx:"2",ry:"2",key:"ngkwjq"}],["rect",{width:"20",height:"8",x:"2",y:"14",rx:"2",ry:"2",key:"iecqi9"}],["line",{x1:"6",x2:"6.01",y1:"6",y2:"6",key:"16zg32"}],["line",{x1:"6",x2:"6.01",y1:"18",y2:"18",key:"nzw8ys"}]]);e.s(["Server",0,s],38540)},40277,e=>{"use strict";var t=e.i(76350),r=e.i(73576),s=e.i(2265),n=e.i(69393),a=e.i(21432),i=e.i(14779),l=e.i(38540),c=e.i(74799),d=e.i(98638);function o(e){if(null==e||""===e)return null;let t=parseFloat(e);return Number.isFinite(t)?t:null}function x({host:e,metrics:r,history:a}){let u=o(r.cpu_usage_pct)??0,m=o(r.gpu_util_pct)??0,h=o(r.mem_used_mb)??0,g=o(r.mem_total_mb)??1,b=o(r.gpu_mem_used_mb),k=o(r.gpu_mem_total_mb),y=null!=b&&k?b/k*100:null,f=o(r.cpu_temp_c),j=o(r.gpu_temp_c),v=o(r.gpu_power_w);return(0,t.jsxs)(s.Card,{children:[(0,t.jsxs)(s.CardHeader,{children:[(0,t.jsxs)(s.CardTitle,{className:"flex items-center gap-2",children:[(0,t.jsx)(l.Server,{size:16,className:"text-zinc-500"}),e]}),(0,t.jsxs)(s.CardDescription,{children:[r.hostname," · ",r.gpu_name??"—"]})]}),(0,t.jsxs)(s.CardBody,{className:"flex flex-col gap-3",children:[(0,t.jsx)(p,{label:"CPU",pct:u,history:a.cpu,icon:(0,t.jsx)(i.Cpu,{size:14}),tone:"sky",right:null!=f&&`${f.toFixed(1)}\xb0C`}),(0,t.jsx)(p,{label:"GPU",pct:m,history:a.gpu,icon:(0,t.jsx)(d.Zap,{size:14}),tone:"purple",right:null!=j&&`${j.toFixed(0)}\xb0C`}),(0,t.jsx)(p,{label:"Memory",pct:h/g*100,history:a.mem,icon:(0,t.jsx)(c.Thermometer,{size:14}),tone:"green",right:`${(h/1024).toFixed(1)}/${(g/1024).toFixed(0)} GB`}),null!=y&&(0,t.jsx)(p,{label:"GPU memory",pct:y,history:[],icon:(0,t.jsx)(d.Zap,{size:14}),tone:"amber",right:null!=b&&k?`${(b/1024).toFixed(1)}/${(k/1024).toFixed(0)} GB`:null}),(0,t.jsxs)("div",{className:"flex flex-wrap items-center gap-2 pt-1 text-xs text-zinc-500 dark:text-zinc-400",children:[null!=v&&(0,t.jsxs)(n.Badge,{tone:"neutral",children:[v.toFixed(1)," W"]}),r.sparkrun_jobs&&"0"!==r.sparkrun_jobs&&(0,t.jsxs)(n.Badge,{tone:"sky",children:[r.sparkrun_jobs," job","1"===r.sparkrun_jobs?"":"s"]})]})]})]})}let u={sky:"text-sky-500 dark:text-sky-400",purple:"text-purple-500 dark:text-purple-400",green:"text-emerald-500 dark:text-emerald-400",amber:"text-amber-500 dark:text-amber-400"};function p({label:e,pct:r,history:s,icon:n,tone:a,right:i}){let l=Math.max(0,Math.min(100,r));return(0,t.jsxs)("div",{className:"flex flex-col gap-1",children:[(0,t.jsxs)("div",{className:"flex items-center justify-between text-xs",children:[(0,t.jsxs)("span",{className:"flex items-center gap-1.5 text-zinc-700 dark:text-zinc-300",children:[n,e]}),(0,t.jsxs)("span",{className:"flex items-center gap-2 text-zinc-500 dark:text-zinc-400",children:[i,(0,t.jsxs)("span",{className:"font-mono text-zinc-700 dark:text-zinc-200",children:[l.toFixed(0),"%"]})]})]}),(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)("div",{className:"h-2 flex-1 overflow-hidden rounded bg-zinc-200 dark:bg-zinc-800",children:(0,t.jsx)("div",{className:"h-full transition-all duration-300 "+("sky"===a?"bg-sky-500 dark:bg-sky-400":"purple"===a?"bg-purple-500 dark:bg-purple-400":"green"===a?"bg-emerald-500 dark:bg-emerald-400":"bg-amber-500 dark:bg-amber-400"),style:{width:`${l}%`}})}),s.length>2&&(0,t.jsx)(m,{values:s,className:u[a]})]})]})}function m({values:e,className:r}){if(e.length<2)return null;let s=Math.max(100,...e),n=80/Math.max(1,e.length-1),a=e.map((e,t)=>`${t*n},${16-e/s*16}`),i=(e.length-1)*n,l=`M 0,16 L ${a.join(" L ")} L ${i},16 Z`,c=`M ${a.join(" L ")}`;return(0,t.jsxs)("svg",{width:80,height:16,viewBox:"0 0 80 16",className:`flex-shrink-0 ${r}`,children:[(0,t.jsx)("path",{d:l,fill:"currentColor",stroke:"none",opacity:.35}),(0,t.jsx)("path",{d:c,fill:"none",stroke:"currentColor",strokeWidth:1})]})}function h(e){if(null==e||""===e)return 0;let t=parseFloat(e);return Number.isFinite(t)?t:0}function g(e,t){let r=e.concat(t);return r.length>30?r.slice(-30):r}e.s(["MonitorLive",0,function(){let[e,i]=(0,r.useState)(null),[l,c]=(0,r.useState)({}),[d,o]=(0,r.useState)(!1);(0,r.useEffect)(()=>{let e=new AbortController,t=!1;return(async()=>{try{let r=await a.rpc.monitor.stream({intervalSec:2},{signal:e.signal});for await(let e of(o(!0),r)){if(t)break;i(e),c(t=>{let r={...t};for(let[t,s]of Object.entries(e.hosts)){let e=r[t]??{cpu:[],gpu:[],mem:[],power:[]};r[t]={cpu:g(e.cpu,h(s.cpu_usage_pct)),gpu:g(e.gpu,h(s.gpu_util_pct)),mem:g(e.mem,h(s.mem_used_pct)),power:g(e.power,h(s.gpu_power_w))}}return r})}}catch(e){t||e instanceof DOMException&&"AbortError"===e.name||console.error("[monitor.stream]",e)}finally{t||o(!1)}})(),()=>{t=!0,e.abort()}},[]);let u=e?Object.entries(e.hosts):[];return(0,t.jsxs)("div",{className:"flex flex-col gap-6",children:[(0,t.jsxs)("div",{className:"flex items-baseline justify-between",children:[(0,t.jsx)("h1",{className:"text-2xl font-semibold tracking-tight",children:"Cluster monitor"}),(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)(n.Badge,{tone:d?"green":"amber",children:d?"live":"reconnecting…"}),e&&(0,t.jsxs)(n.Badge,{tone:"neutral",children:[u.length," host",1===u.length?"":"s"]})]})]}),e?(0,t.jsx)("div",{className:"grid grid-cols-1 gap-4 lg:grid-cols-2 xl:grid-cols-3",children:u.map(([e,r])=>(0,t.jsx)(x,{host:e,metrics:r,history:l[e]??{cpu:[],gpu:[],mem:[],power:[]}},e))}):(0,t.jsx)(s.Card,{children:(0,t.jsx)(s.CardBody,{className:"text-sm text-zinc-500 dark:text-zinc-400",children:"Waiting for first monitor sample…"})})]})}],40277)}]);