pikiloom 0.4.15 → 0.4.17

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 (41) hide show
  1. package/README.md +2 -1
  2. package/dashboard/dist/assets/{AgentTab-CKoy_-w4.js → AgentTab-CDVhy5K1.js} +1 -1
  3. package/dashboard/dist/assets/{DirBrowser-DpbuN0OL.js → DirBrowser-BElI1-4D.js} +1 -1
  4. package/dashboard/dist/assets/{ExtensionsTab-ymr7K8dU.js → ExtensionsTab-BB8ipJ77.js} +1 -1
  5. package/dashboard/dist/assets/{IMAccessTab-CaTtCn3l.js → IMAccessTab-IZt_yXoG.js} +1 -1
  6. package/dashboard/dist/assets/{Modal-DA-9kJxp.js → Modal-C1EAGSL1.js} +1 -1
  7. package/dashboard/dist/assets/{Modals-BkLIRnNK.js → Modals-DYUV5yR9.js} +1 -1
  8. package/dashboard/dist/assets/{Select-B0pZtuzF.js → Select-BnsbE6Qv.js} +1 -1
  9. package/dashboard/dist/assets/SessionPanel-Ca_TVTT1.js +1 -0
  10. package/dashboard/dist/assets/{SystemTab-B9TcGMzc.js → SystemTab-Dk6k2OTt.js} +1 -1
  11. package/dashboard/dist/assets/index-CK-3CNRp.js +3 -0
  12. package/dashboard/dist/assets/index-CnJsD381.js +23 -0
  13. package/dashboard/dist/assets/index-dzfjF9Js.css +1 -0
  14. package/dashboard/dist/assets/{shared-i_XUH0xm.js → shared-CZVD0MJD.js} +1 -1
  15. package/dashboard/dist/index.html +2 -2
  16. package/dist/agent/artifacts.js +160 -0
  17. package/dist/agent/images.js +51 -24
  18. package/dist/agent/index.js +4 -2
  19. package/dist/agent/mcp/bridge.js +201 -7
  20. package/dist/agent/mcp/extensions.js +20 -9
  21. package/dist/agent/mcp/tools/workspace.js +4 -3
  22. package/dist/agent/stream.js +3 -2
  23. package/dist/bot/bot.js +83 -4
  24. package/dist/bot/commands.js +48 -2
  25. package/dist/bot/menu.js +1 -0
  26. package/dist/bot/session-hub.js +1 -1
  27. package/dist/channels/dingtalk/bot.js +9 -1
  28. package/dist/channels/discord/bot.js +9 -1
  29. package/dist/channels/feishu/bot.js +8 -1
  30. package/dist/channels/slack/bot.js +9 -1
  31. package/dist/channels/telegram/bot.js +8 -1
  32. package/dist/channels/wecom/bot.js +9 -1
  33. package/dist/channels/weixin/bot.js +9 -1
  34. package/dist/cli/main.js +1 -0
  35. package/dist/dashboard/routes/config.js +134 -12
  36. package/dist/dashboard/routes/sessions.js +108 -27
  37. package/package.json +1 -1
  38. package/dashboard/dist/assets/SessionPanel-CYQtZZNX.js +0 -1
  39. package/dashboard/dist/assets/index-BCYshErN.js +0 -3
  40. package/dashboard/dist/assets/index-C5irxzzD.js +0 -23
  41. package/dashboard/dist/assets/index-FD86DEDF.css +0 -1
@@ -1,23 +0,0 @@
1
- const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/SessionPanel-CYQtZZNX.js","assets/react-vendor-C7Sl8SE7.js","assets/index-BCYshErN.js","assets/router-DHISdpPk.js","assets/index-FD86DEDF.css","assets/Modal-DA-9kJxp.js","assets/Select-B0pZtuzF.js","assets/DirBrowser-DpbuN0OL.js","assets/markdown-DxQYQFeH.js","assets/ExtensionsTab-ymr7K8dU.js"])))=>i.map(i=>d[i]);
2
- import{c as E,a as J,u as je,i as mn,f as Lt,A as as,s as rn,S as pe,B as Je,g as Zt,w as ls,b as cs,E as Gt,C as on,d as ds,e as us,n as hs,h as Sn,j as Rt,k as Te,D as $t,l as ps,m as Cn,_ as Tn,T as xs,o as fs}from"./index-BCYshErN.js";import{j as e,r,a as an}from"./react-vendor-C7Sl8SE7.js";import{I as gs}from"./Select-B0pZtuzF.js";import{M as Wt,a as Bt}from"./Modal-DA-9kJxp.js";import{D as ms}from"./DirBrowser-DpbuN0OL.js";import{n as bs,r as vs,M as ln}from"./markdown-DxQYQFeH.js";import{WorkspaceExtensionsBody as js}from"./ExtensionsTab-ymr7K8dU.js";function ws({open:t,className:n}){return e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",className:E("shrink-0 text-fg-5/40 transition-transform duration-200",t&&"rotate-180",n),children:e.jsx("polyline",{points:"6 9 12 15 18 9"})})}function Ye({open:t,onToggle:n,dot:s,label:a,preview:l,badge:d,collapsedContent:p,children:c,className:b}){return e.jsxs("div",{className:E("rounded-md border border-edge bg-panel overflow-hidden","shadow-[0_2px_8px_rgba(0,0,0,0.06)]",b),children:[e.jsxs("button",{onClick:n,className:"w-full flex items-center gap-2.5 px-3.5 py-2.5 text-left hover:bg-panel-h/40 transition-colors",children:[s&&e.jsx("span",{className:E("h-[7px] w-[7px] shrink-0 rounded-full",s.color,s.pulse&&"animate-pulse")}),e.jsx("span",{className:"text-[10.5px] font-semibold uppercase tracking-[0.14em] text-fg-5",children:a}),e.jsx("span",{className:"flex-1 min-w-0 overflow-hidden",children:l}),d,e.jsx(ws,{open:t})]}),!t&&p,t&&c&&e.jsx("div",{className:"border-t border-edge",children:c})]})}const ks=5e3,ys=15e3,_t=8,Pt=30,Ns=1,Qe=new Map,ve=new Map,qt=new Set,En=[];let Mt=0;function Qt(t){return typeof t=="number"&&Number.isFinite(t)}function Oe(t,n,s,a){for(t.delete(n),t.set(n,s);t.size>a;){const l=t.keys().next().value;if(!l)break;t.delete(l)}}function Ln(t,n){const s=t.get(n);return!s?.value||s.expiresAt<=Date.now()?null:(Oe(t,n,s,t===ve?Pt:_t),s.value)}function Mn(t){return{workdir:t.workdir,agent:t.agent,sessionId:t.sessionId,rich:t.rich??!0,lastNTurns:Qt(t.lastNTurns)?t.lastNTurns:void 0,turnOffset:Qt(t.turnOffset)?t.turnOffset:void 0,turnLimit:Qt(t.turnLimit)?t.turnLimit:void 0}}function cn(t){const n=Mn(t);return[n.workdir,n.agent,n.sessionId,n.rich?"rich":"plain",n.lastNTurns??"",n.turnOffset??"",n.turnLimit??""].join("::")}function In(){for(;Mt<Ns;){const t=En.shift();if(!t)return;Mt+=1,t().finally(()=>{Mt=Math.max(0,Mt-1),In()})}}async function Ss(t,n={}){const s=t;if(!n.force){const d=Ln(Qe,s);if(d)return d}const a=Qe.get(s);if(a?.promise)return a.promise;const l=J.getWorkspaceSessions(t,n.request).then(d=>(Oe(Qe,s,{value:d,expiresAt:d.ok?Date.now()+ks:0},_t),d)).finally(()=>{const d=Qe.get(s);d?.promise&&Oe(Qe,s,{value:d.value,expiresAt:d.expiresAt},_t)});return Oe(Qe,s,{value:a?.value,expiresAt:a?.expiresAt??0,promise:l},_t),l}function Cs(t,n={}){const s=cn(t),a=ve.get(s);return a?.value?.ok&&(n.allowStale||a.expiresAt>Date.now())?a.value:null}async function Ts(t,n={}){const s=Mn(t),a=cn(s);if(!n.force){const p=Ln(ve,a);if(p?.ok)return p}const l=ve.get(a);if(l?.promise)return l.promise;const d=J.getSessionMessages(s.workdir,s.agent,s.sessionId,{rich:s.rich,lastNTurns:s.lastNTurns,turnOffset:s.turnOffset,turnLimit:s.turnLimit},n.request).then(p=>(Oe(ve,a,{value:p,expiresAt:p.ok?Date.now()+ys:0},Pt),p)).finally(()=>{const p=ve.get(a);p?.promise&&Oe(ve,a,{value:p.value,expiresAt:p.expiresAt},Pt)});return Oe(ve,a,{value:l?.value,expiresAt:l?.expiresAt??0,promise:d},Pt),d}function Es(t){const n=cn(t);Cs(t)||qt.has(n)||ve.get(n)?.promise||(qt.add(n),En.push(async()=>{try{await Ts(t)}catch{}finally{qt.delete(n)}}),In())}const bt=new Map,en=new Set;let De=null,Ee=0,bn=!1,Xe=null,mt=500;const Ls=8e3;function Ms(t){const n=bt.get(t.type);if(n)for(const s of n)s(t)}function Is(){const t=window.location;return`${t.protocol==="https:"?"wss:":"ws:"}//${t.host}/ws`}function dn(){if(De)return;An();const t=new WebSocket(Is());t.onopen=()=>{const n=bn;if(bn=!0,mt=500,n)for(const s of en)s()},t.onmessage=n=>{try{const s=JSON.parse(n.data);if(s.type==="pong")return;Ms(s)}catch{}},t.onclose=()=>{De=null,Ee>0&&Rs()},t.onerror=()=>{},De=t}function As(){An(),De&&(De.close(),De=null)}function An(){Xe&&(clearTimeout(Xe),Xe=null)}function Rs(){Xe||(Xe=setTimeout(()=>{Xe=null,Ee>0&&dn()},mt),mt=Math.min(mt*2,Ls))}function _s(t,n){let s=bt.get(t);s||(s=new Set,bt.set(t,s)),s.add(n),Ee++,Ee===1&&dn()}function Ps(t,n){const s=bt.get(t);s&&(s.delete(n),s.size===0&&bt.delete(t)),Ee=Math.max(0,Ee-1),Ee===0&&As()}typeof document<"u"&&document.addEventListener("visibilitychange",()=>{document.visibilityState==="visible"&&Ee>0&&!De&&(mt=500,dn())});function vn(t,n){const s=r.useRef(n);s.current=n,r.useEffect(()=>{if(!t)return;const a=l=>s.current(l);return _s(t,a),()=>Ps(t,a)},[t])}function Ws(t){const n=r.useRef(t);n.current=t,r.useEffect(()=>{const s=()=>n.current();return en.add(s),()=>{en.delete(s)}},[])}function eo(t){const n=t.richMessages?.length?t.richMessages:t.messages?.map(p=>({role:p.role,text:p.text,blocks:[{type:"text",content:p.text}]}))||[],s=$s(n),a=Math.max(t.window?.totalTurns??t.totalTurns??s.length,s.length),l=t.window?.endTurn??a,d=t.window?.startTurn??Math.max(0,l-s.length);return{turns:s,startTurn:d,endTurn:l,totalTurns:a,hasOlder:t.window?.hasOlder??d>0}}function to(t,n){const s=Math.max(0,t.startTurn-n.startTurn);return{turns:[...n.turns.slice(0,s),...t.turns],startTurn:n.startTurn,endTurn:t.endTurn,totalTurns:Math.max(t.totalTurns,n.totalTurns),hasOlder:n.hasOlder}}function no(t,n){if(n.startTurn<=t.startTurn)return n;const s=Math.max(0,n.startTurn-t.startTurn);return{turns:[...t.turns.slice(0,s),...n.turns],startTurn:t.startTurn,endTurn:n.endTurn,totalTurns:n.totalTurns,hasOlder:t.startTurn>0}}function Bs(t,n){const s=[t.text,n.text].filter(Boolean);return{role:t.role,text:s.join(`
3
-
4
- `),blocks:[...t.blocks,...n.blocks],usage:n.usage??t.usage??null}}function $s(t){const n=[];let s={user:null,assistant:null};for(const a of t)if(a.role==="user"){if(s.assistant&&Rn(a.text))continue;(s.user||s.assistant)&&(n.push(s),s={user:null,assistant:null}),s.user=a}else s.assistant?s.assistant=Bs(s.assistant,a):s.assistant=a;return(s.user||s.assistant)&&n.push(s),n}const Os=new Set(["task-notification","system-reminder","persisted-output","local-command-stdout","local-command-caveat","local-command-stderr","ide_opened_file","ide_diagnostics","ide_selection","event","analysis","case_id","tool-use-id","output-file"]),Ds=["continued from a previous","summary below covers","earlier portion of the conversation","Summary:","Key Technical Concepts"];function Rn(t){const s=t.trim().match(/^<([a-z][a-z0-9_-]*)\b/i);return s&&Os.has(s[1].toLowerCase())?!0:Ds.some(a=>t.includes(a))}function _n(t,n){const s=t.split(`
5
- `).filter(a=>a.trim());return s.length<=n?s.join(`
6
- `):s.slice(-n).join(`
7
- `)}function Fs(t){const n=String(t||"").trim().toLowerCase();return n?n.startsWith("interrupted by user")?"interrupted":n.startsWith("timed out")||n.startsWith("stopped before completion")||n.includes("max tokens")?"incomplete":"error":"error"}function Jt(t){return{id:`${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,file:t,previewUrl:URL.createObjectURL(t)}}function Us(t){for(const n of t)URL.revokeObjectURL(n.previewUrl)}function Hs(t){if(!Number.isFinite(t)||t<=0)return"0 B";if(t<1024)return`${t} B`;const n=t/1024;if(n<1024)return`${n.toFixed(n>=100?0:1)} KB`;const s=n/1024;return`${s.toFixed(s>=100?0:1)} MB`}async function zs(t){if(typeof ClipboardItem>"u"||!navigator.clipboard?.write)return!1;try{return await navigator.clipboard.write([new ClipboardItem({[t.type||"image/png"]:t})]),!0}catch{return!1}}function Q(t,n=120){if(t==null)return"";const a=(typeof t=="string"?t:String(t)).replace(/\s+/g," ").trim();return a.length<=n?a:a.slice(0,Math.max(0,n-1))+"…"}function Ks(t){if(!t)return null;try{const n=JSON.parse(t);return n&&typeof n=="object"&&!Array.isArray(n)?n:null}catch{return null}}function Pn(t){const n=String(t.toolName||"").trim()||"Tool",s=Ks(t.content);if(!s)return n;const a=Q(s.description,120);switch(n){case"Read":{const l=Q(s.file_path||s.path,140);return l?`Read ${l}`:"Read"}case"Edit":{const l=Q(s.file_path||s.path,140);return l?`Edit ${l}`:"Edit"}case"Write":{const l=Q(s.file_path||s.path,140);return l?`Write ${l}`:"Write"}case"Glob":{const l=Q(s.pattern||s.glob,120);return l?`Glob ${l}`:"Glob"}case"Grep":{const l=Q(s.pattern||s.query,120);return l?`Grep ${l}`:"Grep"}case"WebFetch":{const l=Q(s.url,120);return l?`WebFetch ${l}`:"WebFetch"}case"WebSearch":{const l=Q(s.query,120);return l?`WebSearch ${l}`:"WebSearch"}case"TodoWrite":return"Update plan";case"AskUserQuestion":{const d=(Array.isArray(s.questions)?s.questions:[])[0],p=Q(d?.question||s.question,120);return p?`Ask user: ${p}`:"Ask user"}case"Task":{const l=Q(s.description||s.prompt,120);return l?`Task: ${l}`:"Task"}case"Bash":{if(a)return`Bash: ${a}`;const l=Q(s.command,120);return l?`Bash: ${l}`:"Bash"}default:{const l=n.match(/^mcp__[^_]+__(.+)$/),d=l?l[1]:n;if(d==="im_send_file"){const c=Q(s.path,120);return c?`Send file: ${c}`:"Send file"}if(d==="im_list_files")return"List workspace files";if(a)return`${n}: ${a}`;const p=Q(s.file_path||s.path||s.command||s.query||s.pattern||s.url,120);return p?`${n}: ${p}`:n}}}function Vs(t){const n=(t.content||"").trim();if(!n)return"result";const s=n.split(`
8
- `).map(a=>a.trim()).find(Boolean)||"";return s?Q(s,140):"result"}function Gs(t){const n=t.indexOf(":");if(n<=0)return null;const s=t.slice(0,n).trim(),a=t.slice(n+1).trim();return!s||!a?null:{agent:s,sessionId:a}}const gt=new Map;function qs(t,n){return`${t}:${n}`}function Qs(t){const n=(()=>{try{return new URL(t.baseURL).host.toLowerCase()}catch{return""}})();return n.includes("openrouter")?"openrouter":n.includes("anthropic")?"anthropic":n.includes("deepseek")?"deepseek":n.includes("googleapis")||n.includes("vertex")?"google":n.includes("openai.com")?"openai":n.includes("dashscope")||n.includes("qwen")||n.includes("aliyun")?"qwen":n.includes("volces")||n.includes("volcengine")||n.includes("doubao")?"doubao":n.includes("bigmodel")||n.includes("zhipu")||n.includes("z.ai")?"glm":n.includes("minimax")?"minimax":t.kind==="anthropic"?"anthropic":t.kind==="google"?"google":t.kind==="openai"?"openai":"custom"}const Js=r.memo(function({session:n,workdir:s,onStreamQueued:a,onSendStart:l,onSendTaskAssigned:d,onSessionChange:p,t:c,streamPhase:b,streamTaskId:v,queuedTaskIds:g,queuedTasks:j,pendingQueuedSends:T,onRecall:k,onSteer:I,onStopAll:L,editDraft:S,onEditDraftConsumed:R,onSelectionChange:D}){const[H,P]=r.useState(""),[A,F]=r.useState(!1),[z,ae]=r.useState(null),[ee,M]=r.useState(()=>new Set),[K,Le]=r.useState(()=>new Set),de=r.useRef({prompt:"",files:[]}),we=je(o=>o.agentStatus?.agents??null),[$,Fe]=r.useState(we||[]),[Me,et]=r.useState(""),[ke,vt]=r.useState(""),[ue,jt]=r.useState(""),[te,ne]=r.useState([]),[Ue,Ie]=r.useState(null),[He,tt]=r.useState(null),[se,le]=r.useState(null),[W,ye]=r.useState(null),[X,Ae]=r.useState(null),[Re,wt]=r.useState(void 0),[B,re]=r.useState("closed"),[xe,Ne]=r.useState(null),oe=r.useRef(null),_e=r.useRef(!1),nt=r.useRef(null),kt=r.useRef(null),ze=r.useRef(null),st=r.useRef([]),[rt,Se]=r.useState([]),[V,fe]=r.useState(!1),[Ce,ie]=r.useState(0),Pe=r.useRef(null),We=je(o=>o.refreshAgentStatus),[he,ot]=r.useState([]),[it,Ot]=r.useState([]),[yt,Dt]=r.useState({}),at=r.useCallback(async()=>{try{const[o,x,m]=await Promise.all([fetch("/api/models/providers").then(N=>N.json()),fetch("/api/models/profiles").then(N=>N.json()),fetch("/api/models/agents").then(N=>N.json())]);if(o?.ok&&Ot(o.providers||[]),x?.ok&&ot(x.profiles||[]),m?.ok){const N={};for(const _ of m.bindings||[])N[_.agent]=_.activeProfileId;Dt(N)}}catch{}},[]);r.useEffect(()=>{we?.length&&Fe(we)},[we]),r.useEffect(()=>{st.current=te},[te]);const Be=qs(n.agent||"",n.sessionId),Ke=r.useRef(Be);Ke.current=Be,r.useEffect(()=>{const o=gt.get(Be);return o&&(gt.delete(Be),o.text&&P(o.text),o.files.length&&ne(o.files.map(Jt))),()=>{const x=oe.current?.value||"",m=st.current.map(N=>N.file);for(const N of st.current)URL.revokeObjectURL(N.previewUrl);x||m.length?gt.set(Ke.current,{text:x,files:m}):gt.delete(Ke.current)}},[Be]);const lt=r.useRef({agent:n.agent||"",sessionId:n.sessionId});r.useEffect(()=>{const o=lt.current,x={agent:n.agent||"",sessionId:n.sessionId};lt.current=x,!(o.agent===x.agent&&mn(o.sessionId)&&!mn(x.sessionId))&&(et(""),vt(""),jt(""),le(null),ye(null),Ae(null),re("closed"))},[n.agent,n.sessionId]),r.useEffect(()=>{S!=null&&(P(S),R?.(),requestAnimationFrame(()=>{const o=oe.current;o&&(o.focus(),o.setSelectionRange(S.length,S.length))}))},[S,R]),r.useEffect(()=>{if(!s)return;let o=!1;return J.getSkills(s).then(x=>{!o&&x.ok&&Se(x.skills)}).catch(()=>{}),()=>{o=!0}},[s]);const ct=V?(()=>{const o=H.match(/^\/(\S*)$/);return o?o[1].toLowerCase():null})():null,ge=ct!==null?rt.filter(o=>o.name.toLowerCase().includes(ct)||o.label&&o.label.toLowerCase().includes(ct)):[];r.useEffect(()=>{ie(0)},[V,H]),r.useEffect(()=>{if(!V||!Pe.current)return;const o=Pe.current.querySelector(`[data-skill-idx="${Ce}"]`);o&&o.scrollIntoView({block:"nearest"})},[Ce,V]),r.useEffect(()=>{if(!V)return;const o=x=>{Pe.current?.contains(x.target)||oe.current?.contains(x.target)||fe(!1)};return document.addEventListener("mousedown",o),()=>document.removeEventListener("mousedown",o)},[V]),r.useEffect(()=>{if(B==="closed")return;const o=x=>{const m=x.target;ze.current?.contains(m)||document.getElementById("cascade-portal")?.contains(m)||(re("closed"),le(null),ye(null),Ae(null))};return document.addEventListener("mousedown",o),()=>document.removeEventListener("mousedown",o)},[B]),r.useLayoutEffect(()=>{if(B==="closed"||!ze.current){Ne(null);return}const o=ze.current.getBoundingClientRect();Ne({left:o.left,bottom:window.innerHeight-o.top+8})},[B]);const Nt=g&&g.length?g[0]:null;r.useEffect(()=>{z&&(Nt||b!==null&&b!=="queued")&&ae(null)},[b,z,Nt]),r.useEffect(()=>{const o=oe.current;o&&(o.style.height="auto",o.style.height=Math.min(o.scrollHeight,200)+"px")},[H]);const dt=r.useCallback(o=>{const x=Array.from(o||[]).filter(m=>m.type.startsWith("image/"));x.length&&ne(m=>[...m,...x.map(Jt)])},[]),St=r.useCallback(()=>{Ie(null),ne(o=>(Us(o),[]))},[]),i=r.useCallback(o=>{ne(x=>{const m=x.find(N=>N.id===o);return m&&URL.revokeObjectURL(m.previewUrl),x.filter(N=>N.id!==o)}),Ie(x=>x===o?null:x)},[]),u=r.useCallback(()=>{const o=H.trim(),x=te.map(q=>q.file);if(!o&&x.length===0||A)return;const m=Me||n.agent||$.find(q=>q.isDefault)?.agent||"";if(!m)return;const N=$.find(q=>q.agent===m)||null,_=!!n.agent&&m===n.agent,me=(ke||_&&n.model||""||N?.selectedModel||"").trim()||null,be=m==="gemini"?null:(ue||(_?Lt(m,n.thinkingEffort,n.workflowEnabled):"")||Lt(m,N?.selectedEffort,N?.workflowEnabled)||"").trim()||null,Z=m!==n.agent,Vt=Z?"":n.sessionId,rs=Z&&n.agent?n.agent:null,os=Z&&n.sessionId?n.sessionId:null;F(!0),de.current={prompt:o,files:x},P(""),gt.delete(Ke.current);const is=x.length?x.map(q=>URL.createObjectURL(q)):void 0;St(),l(o,is),a(),J.sendSessionMessage(s,m,Vt,o,{attachments:x,model:me,effort:be,previousAgent:rs,previousSessionId:os}).then(q=>{if(q.taskId&&(ae(q.taskId),d?.(q.taskId)),!q.ok)return;const ft=typeof q.sessionKey=="string"?Gs(q.sessionKey):null;ft&&(ft.agent!==n.agent||ft.sessionId!==n.sessionId)&&ft&&p?.({...ft,workdir:s})}).catch(()=>{}).finally(()=>F(!1))},[$,St,te,H,l,d,p,a,Me,ue,ke,A,n.agent,n.sessionId,s]),h=b==="streaming",f=(()=>{const o=[];return g&&g.length&&o.push(...g),b==="queued"&&v&&!o.includes(v)&&o.unshift(v),z&&!o.includes(z)&&(b==="queued"||!b)&&o.push(z),o})(),w=f[f.length-1]||null,y=f.length>0,C=y||h;r.useEffect(()=>{const o=x=>f.includes(x)||x===v;M(x=>{let m=!1;const N=new Set;for(const _ of x)o(_)?N.add(_):m=!0;return m?N:x}),Le(x=>{let m=!1;const N=new Set;for(const _ of x)o(_)?N.add(_):m=!0;return m?N:x})},[f,v]),r.useEffect(()=>{!y&&de.current.files.length&&(de.current={prompt:"",files:[]})},[y]);const G=r.useCallback(o=>{if(!ee.has(o)){if(M(x=>{const m=new Set(x);return m.add(o),m}),o===w){const x=de.current;x.prompt&&P(x.prompt),x.files.length&&ne(x.files.map(Jt)),de.current={prompt:"",files:[]}}k?.(o),o===z&&ae(null)}},[ee,w,z,k]),[O,Y]=r.useState(!1),ut=r.useCallback(async()=>{if(!(O||!L)){Y(!0);try{await L()}finally{Y(!1)}}},[O,L]),Vn=r.useCallback(o=>{K.has(o)||(Le(x=>{const m=new Set(x);return m.add(o),m}),I?.(o),o===z&&ae(null))},[K,z,I]),pn=r.useCallback(o=>{P(`/${o.name} `),fe(!1),requestAnimationFrame(()=>{const x=oe.current;x&&(x.focus(),x.setSelectionRange(x.value.length,x.value.length))})},[]),Gn=r.useCallback(o=>{P(o);const x=/^\/\S*$/.test(o)&&rt.length>0;fe(x)},[rt.length]),qn=o=>{if(V&&ge.length>0){if(o.key==="ArrowDown"){o.preventDefault(),ie(x=>(x+1)%ge.length);return}if(o.key==="ArrowUp"){o.preventDefault(),ie(x=>(x-1+ge.length)%ge.length);return}if(o.key==="Tab"||o.key==="Enter"&&!o.shiftKey&&!_e.current){o.preventDefault(),pn(ge[Ce]);return}if(o.key==="Escape"){o.preventDefault(),fe(!1);return}}o.key==="Enter"&&!o.shiftKey&&!_e.current&&(o.preventDefault(),u())},Qn=r.useCallback(o=>{const x=Array.from(o.clipboardData?.items||[]).filter(m=>m.kind==="file"&&m.type.startsWith("image/")).map(m=>m.getAsFile()).filter(m=>!!m);x.length&&(o.preventDefault(),dt(x))},[dt]),ce=Me||n.agent||$.find(o=>o.isDefault)?.agent||$.find(o=>o.installed)?.agent||$[0]?.agent||"",Ct=$.find(o=>o.agent===ce)||null,ht=se||ce,pt=$.find(o=>o.agent===ht)||Ct,Tt=r.useMemo(()=>{if(!pt)return[];const o=[];for(const m of pt.models||[])o.push({id:m.id,label:m.id,kind:"native",description:m.alias&&m.alias.toLowerCase()!==m.id.toLowerCase()?m.alias:void 0});const x=new Set(as[ht]||[]);for(const m of he){const N=it.find(me=>me.id===m.providerId);if(!N||!x.has(N.kind))continue;const _=m.name.trim().toLowerCase()!==m.modelId.trim().toLowerCase();o.push({id:m.modelId,label:m.name,kind:"profile",profileId:m.id,description:_?`${N.name} · ${m.modelId}`:N.name})}return o},[pt,ht,he,it]),Jn=r.useMemo(()=>Tt.findIndex(o=>o.kind==="profile"),[Tt]),Xn=yt[ht]||null,xn=!!n.agent&&ce===n.agent,xt=ke||xn&&n.model||""||Ct?.selectedModel||"",Et=ce==="gemini"?"":ue||(xn?Lt(ce,n.thinkingEffort,n.workflowEnabled):"")||Lt(ce,Ct?.selectedEffort,Ct?.workflowEnabled)||"";r.useEffect(()=>{D?.({model:xt||null,effort:Et||null})},[xt,Et,D]);const Yn=Gt[ht]||[],$e=Ue&&te.find(o=>o.id===Ue)||null,Zn=$e?{key:$e.id,url:$e.previewUrl,name:$e.file.name,size:$e.file.size,file:$e.file,onRemove:()=>i($e.id)}:He?{key:He,url:He}:null,fn=(!!H.trim()||te.length>0)&&!A&&!!ce,Ft=()=>{le(null),ye(null),Ae(null),wt(void 0)},Ut=r.useCallback(async(o,x,m)=>{const N=o==="gemini"?"":m||"";if(Re!==void 0)try{await fetch(`/api/models/agents/${o}/active`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({profileId:Re})}),at(),We()}catch{}et(o),vt(x),jt(N),Ft(),re("closed")},[Re,at,We]),es=()=>{B==="closed"?(Ft(),We(),at(),re("agent")):(Ft(),re("closed"))},Ht=se||ce,gn=Zt(Ht),zt=W??xt,Ve=X??Et,ts=zt?rn(zt):"",Ge=(()=>{const o=yt[Ht];return o?he.find(x=>x.id===o)??null:null})(),qe=Ge?it.find(o=>o.id===Ge.providerId)??null:null,ns=qe?Qs(qe):null,Kt=Ge&&Ge.name.trim().toLowerCase()!==Ge.modelId.trim().toLowerCase()?Ge.name:ts,ss=[gn.shortLabel,qe?qe.name:null,Kt||null,Ve?Ve.charAt(0).toUpperCase()+Ve.slice(1):null].filter(Boolean).join(" / ");return e.jsxs("div",{className:"shrink-0",ref:kt,children:[e.jsxs("div",{className:"max-w-[680px] mx-auto px-5 pb-4 pt-2",children:[C&&e.jsxs("div",{className:"mb-2 space-y-1.5",children:[h&&e.jsxs("div",{className:"flex items-center gap-2.5 rounded-lg border border-primary/20 bg-primary/[0.04] px-3.5 py-1.5 transition-colors",children:[e.jsx(pe,{className:"h-3 w-3 text-primary shrink-0"}),e.jsx("span",{className:"flex-1 min-w-0 text-[12px] font-medium text-fg-3 truncate",children:c("hub.running")}),e.jsxs("button",{onClick:ut,disabled:O,title:c("hub.stopHint"),className:"flex items-center gap-1 px-2 py-1 rounded-md text-[11px] font-medium text-fg-4 hover:text-err hover:bg-err/10 transition-colors disabled:opacity-30 disabled:pointer-events-none shrink-0",children:[O?e.jsx(pe,{className:"h-2.5 w-2.5"}):e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"currentColor",children:e.jsx("rect",{x:"4",y:"4",width:"16",height:"16",rx:"2"})}),c("hub.stop")]})]}),f.map((o,x)=>{const m=x===f.length-1,N=f.length>1?`${c("hub.queued")} #${x+1}`:c("hub.queued"),_=T?.find(Z=>Z.taskId===o)||(m?T?.find(Z=>!Z.taskId):void 0),me=j?.find(Z=>Z.taskId===o)?.prompt||_?.prompt||null,be=_?.imageUrls?.length?_.imageUrls:[];return e.jsxs("div",{className:"flex items-center gap-2.5 rounded-lg border border-warn/25 bg-warn/[0.04] px-3.5 py-1.5 transition-colors",children:[e.jsx("span",{className:"h-1.5 w-1.5 rounded-full bg-warn animate-pulse shrink-0"}),e.jsxs("div",{className:"flex-1 min-w-0 flex items-center gap-2",children:[e.jsx("span",{className:"text-[12px] font-medium text-warn shrink-0",children:N}),be.length>0&&e.jsxs("div",{className:"flex items-center gap-1 shrink-0",children:[be.slice(0,3).map((Z,Vt)=>e.jsx("button",{type:"button",onClick:()=>tt(Z),title:c("hub.previewImage"),className:"block h-5 w-5 shrink-0 overflow-hidden rounded border border-warn/30 transition-opacity hover:opacity-80",children:e.jsx("img",{src:Z,alt:"",className:"h-full w-full object-cover"})},`${Z}-${Vt}`)),be.length>3&&e.jsxs("span",{className:"text-[10px] text-fg-5/60",children:["+",be.length-3]})]}),me&&e.jsx("span",{className:"text-[11px] text-fg-5/60 truncate",children:me})]}),e.jsxs("div",{className:"flex items-center gap-1 shrink-0",children:[e.jsxs("button",{onClick:()=>Vn(o),disabled:K.has(o),title:c("hub.steerHint"),className:"flex items-center gap-1 px-2 py-1 rounded-md text-[11px] font-medium text-fg-4 hover:text-blue-400 hover:bg-blue-400/10 transition-colors disabled:opacity-30 disabled:pointer-events-none",children:[K.has(o)?e.jsx(pe,{className:"h-2.5 w-2.5"}):e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",children:e.jsx("polyline",{points:"9 6 15 12 9 18"})}),c("hub.steer")]}),e.jsxs("button",{onClick:()=>G(o),disabled:ee.has(o),title:c("hub.recallHint"),className:"flex items-center gap-1 px-2 py-1 rounded-md text-[11px] font-medium text-fg-4 hover:text-err hover:bg-err/10 transition-colors disabled:opacity-30 disabled:pointer-events-none",children:[ee.has(o)?e.jsx(pe,{className:"h-2.5 w-2.5"}):e.jsxs("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",children:[e.jsx("path",{d:"M18 6 6 18"}),e.jsx("path",{d:"M6 6l12 12"})]}),c("hub.recall")]})]})]},o)})]}),e.jsxs("div",{className:"relative rounded-xl border border-edge/40 bg-panel shadow-sm transition-[border-color,box-shadow] duration-200 focus-within:border-fg-5/40 focus-within:shadow-md",children:[e.jsx("input",{ref:nt,type:"file",accept:"image/*",multiple:!0,className:"hidden",onChange:o=>{dt(o.target.files),o.target.value=""}}),te.length>0&&e.jsx("div",{className:"px-3 pt-3",children:e.jsx("div",{className:"flex gap-2 overflow-x-auto pb-1",children:te.map(o=>e.jsxs("div",{className:"relative shrink-0",children:[e.jsxs("button",{type:"button",onClick:()=>Ie(o.id),title:c("hub.previewImage"),className:"group relative h-[72px] w-[72px] overflow-hidden rounded-lg border border-edge/30 bg-panel-alt/30",children:[e.jsx("img",{src:o.previewUrl,alt:o.file.name,className:"h-full w-full object-cover transition-transform duration-200 group-hover:scale-[1.03]"}),e.jsx("div",{className:"pointer-events-none absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/60 via-black/10 to-transparent px-1.5 pb-1 pt-3 text-left",children:e.jsx("div",{className:"truncate text-[8px] font-medium text-white/90 leading-tight",children:o.file.name})})]}),e.jsx("button",{type:"button",onClick:x=>{x.stopPropagation(),i(o.id)},title:c("hub.removeImage"),className:"absolute -right-1 -top-1 flex h-5 w-5 items-center justify-center rounded-full border border-white/10 bg-black/65 text-white/75 transition-colors hover:bg-black/80 hover:text-white",children:e.jsxs("svg",{width:"9",height:"9",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",children:[e.jsx("path",{d:"M18 6 6 18"}),e.jsx("path",{d:"M6 6l12 12"})]})})]},o.id))})}),V&&ge.length>0&&e.jsxs("div",{ref:Pe,className:"absolute bottom-full left-0 right-0 mb-1.5 z-50 max-h-[200px] overflow-y-auto rounded-xl border border-edge/40 bg-[var(--th-dropdown)] backdrop-blur-xl shadow-lg animate-in",children:[e.jsx("div",{className:"px-3 pt-2 pb-1 border-b border-edge/20",children:e.jsx("span",{className:"text-[10px] font-semibold text-fg-5 uppercase tracking-wider",children:c("hub.skills")})}),e.jsx("div",{className:"py-1",children:ge.map((o,x)=>e.jsxs("button",{"data-skill-idx":x,onMouseDown:m=>{m.preventDefault(),pn(o)},onMouseEnter:()=>ie(x),className:E("flex flex-col w-full px-3 py-1.5 text-left transition-colors",x===Ce?"bg-panel-h text-fg":"text-fg-3 hover:bg-panel-alt/50"),children:[e.jsxs("span",{className:"text-[12.5px] font-medium",children:["/",o.name]}),(o.label||o.description)&&e.jsx("span",{className:"text-[11px] text-fg-5 truncate",children:o.label||o.description})]},o.name))})]}),e.jsx("textarea",{ref:oe,value:H,onChange:o=>Gn(o.target.value),onPaste:Qn,onKeyDown:qn,onCompositionStart:()=>{_e.current=!0},onCompositionEnd:()=>{_e.current=!1},placeholder:c("hub.inputPlaceholder"),rows:1,className:"w-full resize-none bg-transparent px-4 pt-3 pb-1 text-[13.5px] text-fg outline-none placeholder:text-fg-5/25 leading-[1.6]",style:{maxHeight:200,overflow:H.split(`
9
- `).length>6?"auto":"hidden"}}),e.jsxs("div",{className:"flex items-center gap-1.5 px-2.5 pb-2 pt-1",children:[e.jsx("button",{type:"button",onClick:()=>nt.current?.click(),title:c("hub.addImages"),className:"flex h-7 w-7 items-center justify-center rounded-lg text-fg-5/50 transition-colors hover:bg-panel-h/60 hover:text-fg-3",children:e.jsxs("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.1",strokeLinecap:"round",children:[e.jsx("path",{d:"M12 5v14"}),e.jsx("path",{d:"M5 12h14"})]})}),e.jsxs("button",{ref:ze,onClick:es,disabled:!$.length,title:$.length?ss:void 0,className:E("flex items-center gap-1.5 h-[28px] px-2.5 rounded-lg text-[11px] font-medium transition-all duration-200 select-none",B!=="closed"?"bg-panel-h border border-edge-h text-fg-3":"text-fg-5/60 hover:text-fg-4 hover:bg-panel-h/50 border border-transparent"),children:[$.length?e.jsx(Je,{brand:Ht,size:12}):e.jsx(pe,{className:"h-3 w-3"}),$.length?e.jsxs("span",{className:"flex items-center gap-1 max-w-[460px] min-w-0 truncate",children:[e.jsx("span",{className:"shrink-0",children:gn.shortLabel}),qe&&e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"text-fg-5/40 shrink-0",children:"/"}),e.jsx(Je,{brand:ns||"custom",size:12}),e.jsx("span",{className:"shrink-0 truncate max-w-[140px]",children:qe.name})]}),Kt&&e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"text-fg-5/40 shrink-0",children:"/"}),e.jsx("span",{className:"truncate",title:zt||void 0,children:Kt})]}),Ve&&e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"text-fg-5/40 shrink-0",children:"/"}),e.jsx("span",{className:"shrink-0",children:Ve.charAt(0).toUpperCase()+Ve.slice(1)})]})]}):e.jsx("span",{className:"max-w-[420px] truncate",children:c("hub.selectAgent")}),e.jsx("svg",{width:"9",height:"9",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",className:E("text-fg-5/30 transition-transform duration-200",B!=="closed"&&"rotate-180"),children:e.jsx("polyline",{points:"6 9 12 15 18 9"})})]}),B!=="closed"&&xe&&an.createPortal(e.jsxs("div",{id:"cascade-portal",className:"fixed z-[200] w-[300px] rounded-xl border border-edge/40 bg-[var(--th-dropdown)] backdrop-blur-xl shadow-lg overflow-hidden animate-in",style:{left:xe.left,bottom:xe.bottom},children:[e.jsxs("div",{className:"flex items-center gap-2 px-3 pt-2.5 pb-1.5 border-b border-edge/20",children:[B!=="agent"&&e.jsx("button",{onClick:()=>{if(B==="effort"){const o=pt?.capabilities?.modelSwitch!==!1;re(o?"model":"agent")}else re("agent")},className:"p-0.5 rounded text-fg-5/50 hover:text-fg-3 transition-colors",children:e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",children:e.jsx("polyline",{points:"15 18 9 12 15 6"})})}),e.jsx("span",{className:"text-[10px] font-semibold text-fg-5 uppercase tracking-wider",children:c(B==="agent"?"hub.selectAgent":B==="model"?"hub.selectModel":"hub.selectEffort")}),e.jsx("div",{className:"ml-auto flex items-center gap-0.5",children:(()=>{const x=pt?.capabilities?.modelSwitch!==!1?["agent","model","effort"]:["agent","effort"],m=x.indexOf(B);return x.map((N,_)=>e.jsx("span",{className:E("w-1.5 h-1.5 rounded-full transition-colors",B===N?"bg-primary":_<m?"bg-primary/40":"bg-fg-5/15")},N))})()})]}),e.jsxs("div",{className:"max-h-[200px] overflow-y-auto py-1",children:[B==="agent"&&$.filter(o=>o.installed).map(o=>{const x=Zt(o.agent),m=ls(o.usage),N=m?cs(m):"ok";return e.jsxs(Xt,{selected:o.agent===(se||ce),onClick:()=>{if(le(o.agent),ye(o.selectedModel||""),Ae(o.selectedEffort||""),!(o.capabilities?.modelSwitch!==!1)){(Gt[o.agent]||[]).length?re("effort"):Ut(o.agent,o.selectedModel||"",null);return}re("model")},children:[e.jsx(Je,{brand:o.agent,size:14}),e.jsx("span",{style:{color:x.color},children:x.label}),m&&e.jsxs("span",{className:E("ml-auto font-mono text-[10px]",N==="err"?"text-err":N==="warn"?"text-warn":"text-fg-5"),children:[m.label," ",Math.round(m.usedPercent??0),"%"]})]},o.agent)}),B==="model"&&e.jsxs(e.Fragment,{children:[Tt.map((o,x)=>{const m=x===0&&o.kind==="native",N=x===Jn&&o.kind==="profile",_=Re!==void 0?Re:Xn,me=o.kind==="profile"?!!o.profileId&&o.profileId===_:!_&&o.id===(W??xt);return e.jsxs("div",{children:[m&&e.jsx("div",{className:"px-3 pb-1 pt-1.5 text-[10px] font-medium uppercase tracking-wide text-fg-5",children:c("hub.modelGroupNative")}),N&&e.jsx("div",{className:"px-3 pb-1 pt-2 text-[10px] font-medium uppercase tracking-wide text-fg-5",children:c("hub.modelGroupProfiles")}),e.jsx(Xt,{selected:me,onClick:()=>{const be=se||ce;if(ye(o.id),wt(o.profileId??null),Gt[be]?.length){re("effort");return}Ut(be,o.id,null)},children:e.jsxs("div",{className:"min-w-0 flex-1",children:[e.jsx("div",{className:E("truncate text-[11.5px]",o.kind==="native"&&"font-mono text-[11px]"),title:o.id,children:o.label}),o.description&&e.jsx("div",{className:"truncate text-[10px] text-fg-5/80",children:o.description})]})})]},`${o.kind}:${o.profileId||o.id}`)}),Tt.length===0&&e.jsx("div",{className:"px-3 py-3 text-[11px] text-fg-5 text-center",children:c("config.noModel")})]}),B==="effort"&&Yn.map(o=>e.jsx(Xt,{selected:o===(X||Et),onClick:()=>{Ae(o),Ut(se||ce,W??xt,o)},children:o.charAt(0).toUpperCase()+o.slice(1)},o))]})]}),document.body),e.jsx("div",{className:"flex-1"}),e.jsx("button",{onClick:u,disabled:!fn,className:E("flex items-center justify-center w-[30px] h-[30px] rounded-lg transition-all duration-200",fn?"bg-primary text-primary-fg hover:brightness-110 shadow-sm":"bg-fg/6 text-fg-5/20"),children:A?e.jsx(pe,{className:"h-3.5 w-3.5"}):e.jsxs("svg",{width:"15",height:"15",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("line",{x1:"12",y1:"19",x2:"12",y2:"5"}),e.jsx("polyline",{points:"5 12 12 5 19 12"})]})})]})]})]}),e.jsx(Xs,{source:Zn,onClose:()=>{Ie(null),tt(null)},t:c})]})});function Xs({source:t,onClose:n,t:s}){const[a,l]=r.useState(!1);if(r.useEffect(()=>{l(!1)},[t?.key]),r.useEffect(()=>{if(!t)return;const c=b=>{b.key==="Escape"&&n()};return document.addEventListener("keydown",c),()=>document.removeEventListener("keydown",c)},[t,n]),!t)return null;const d=t.file,p=t.onRemove;return an.createPortal(e.jsx("div",{className:"fixed inset-0 z-[220] flex items-center justify-center bg-black/72 px-4 py-6 backdrop-blur-sm",onClick:n,children:e.jsxs("div",{className:"w-full max-w-[1024px]",onClick:c=>c.stopPropagation(),children:[e.jsxs("div",{className:"mb-3 flex items-center gap-2 text-[11px] text-white/72",children:[t.name&&e.jsx("span",{className:"truncate font-medium text-white/90",children:t.name}),typeof t.size=="number"&&e.jsx("span",{children:Hs(t.size)}),e.jsxs("div",{className:"ml-auto flex items-center gap-2",children:[d&&e.jsx("button",{type:"button",onClick:async()=>{await zs(d)&&(l(!0),window.setTimeout(()=>l(!1),1600))},className:"rounded-lg border border-white/12 bg-white/10 px-3 py-1.5 text-[11px] font-medium text-white/88 transition-colors hover:bg-white/14",children:s(a?"hub.copied":"hub.copyImage")}),p&&e.jsx("button",{type:"button",onClick:p,className:"rounded-lg border border-white/12 bg-white/10 px-3 py-1.5 text-[11px] font-medium text-white/88 transition-colors hover:bg-white/14",children:s("hub.removeImage")}),e.jsx("button",{type:"button",onClick:n,className:"flex h-9 w-9 items-center justify-center rounded-full border border-white/12 bg-white/10 text-white/88 transition-colors hover:bg-white/14",children:e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.2",strokeLinecap:"round",children:[e.jsx("path",{d:"M18 6 6 18"}),e.jsx("path",{d:"M6 6l12 12"})]})})]})]}),e.jsx("div",{className:"overflow-hidden rounded-xl border border-white/10 bg-black/35 shadow-[0_20px_70px_rgba(0,0,0,0.45)]",children:e.jsx("img",{src:t.url,alt:t.name||"",className:"max-h-[80vh] w-full object-contain"})})]})}),document.body)}function Xt({selected:t,onClick:n,children:s}){return e.jsxs("button",{onClick:n,className:E("flex items-center gap-2 w-full px-3 py-2 text-[12px] text-left transition-colors",t?"text-fg bg-panel-h font-medium":"text-fg-3 hover:bg-panel-alt/50 hover:text-fg-2"),children:[s,t&&e.jsx("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",className:"ml-auto text-ok",children:e.jsx("polyline",{points:"20 6 9 17 4 12"})}),!t&&e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",className:"ml-auto text-fg-5/20",children:e.jsx("polyline",{points:"9 6 15 12 9 18"})})]})}function Ys(){return function(t){bs(t)}}const un=[vs,Ys],Zs=t=>/^https?:\/\//.test(t),jn=t=>/^(\/|~\/|\.\.?\/)/.test(t);function er({text:t}){const[n,s]=r.useState(!1),a=()=>{navigator.clipboard.writeText(t).then(()=>{s(!0),setTimeout(()=>s(!1),2e3)}).catch(()=>{})};return e.jsx("button",{onClick:a,className:"flex items-center text-fg-5/50 hover:text-fg-3 transition-colors",children:n?e.jsx("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"#34d399",strokeWidth:"2",children:e.jsx("polyline",{points:"20 6 9 17 4 12"})}):e.jsxs("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:[e.jsx("rect",{x:"9",y:"9",width:"13",height:"13",rx:"2"}),e.jsx("path",{d:"M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"})]})})}function wn(t){const n=/^[.~/].*\.\w+$/.test(t)||/^[a-z][\w-]*\//.test(t),s=/^(npm |npx |git |python|pip |yarn |pnpm |cargo |go |make )/.test(t);return n?"bg-blue-500/8 border-blue-400/12 text-blue-300/90":s?"bg-amber-500/8 border-amber-400/10 text-amber-300/80":"bg-[rgba(255,255,255,0.06)] border-edge/20 text-fg-3"}const hn={h1:({children:t})=>e.jsx("h2",{className:"text-[16px] font-bold text-fg mt-4 mb-2",children:t}),h2:({children:t})=>e.jsx("h3",{className:"text-[14.5px] font-semibold text-fg mt-4 mb-1.5",children:t}),h3:({children:t})=>e.jsx("h4",{className:"text-[13.5px] font-semibold text-fg mt-3 mb-1",children:t}),p:({children:t})=>e.jsx("p",{className:"my-1.5 whitespace-pre-wrap break-words",children:t}),strong:({children:t})=>e.jsx("strong",{className:"font-semibold text-fg",children:t}),em:({children:t})=>e.jsx("em",{className:"italic text-fg-3",children:t}),a:({href:t,children:n})=>t&&Zs(t)?e.jsx("a",{href:t,target:"_blank",rel:"noopener noreferrer",className:"text-blue-400 underline underline-offset-2 decoration-blue-400/30 cursor-pointer hover:text-blue-300 transition-colors",children:n}):t&&jn(t)?e.jsx("span",{className:"text-blue-400 underline underline-offset-2 decoration-blue-400/30 cursor-pointer hover:text-blue-300 transition-colors",onClick:()=>J.openInEditor(t),children:n}):e.jsx("span",{className:"text-blue-400 underline underline-offset-2 decoration-blue-400/30",children:n}),ul:({children:t})=>e.jsx("ul",{className:"space-y-1 my-2 ml-1",children:t}),ol:({children:t})=>e.jsx("ol",{className:"space-y-1 my-2 ml-1 list-decimal list-inside",children:t}),li:({children:t})=>e.jsxs("li",{className:"flex gap-2 items-start",children:[e.jsx("span",{className:"shrink-0 mt-[10px] w-[5px] h-[5px] rounded-full bg-fg-5/40"}),e.jsx("span",{className:"flex-1",children:t})]}),blockquote:({children:t})=>e.jsx("blockquote",{className:"border-l-2 border-fg-5/30 pl-3 my-2 text-fg-4 italic",children:t}),hr:()=>e.jsx("hr",{className:"border-edge/30 my-4"}),code:({className:t,children:n,...s})=>{const a=String(n).replace(/\n$/,""),l=/language-(\w+)/.exec(t||"");if(!l&&!t&&!a.includes(`
10
- `))return jn(a)?e.jsx("code",{className:E("px-1.5 py-[1px] rounded text-[12px] font-mono border cursor-pointer hover:brightness-125 transition-all",wn(a)),onClick:()=>J.openInEditor(a),children:a}):e.jsx("code",{className:E("px-1.5 py-[1px] rounded text-[12px] font-mono border",wn(a)),children:a});const d=l?.[1]||"";return e.jsxs("div",{className:"rounded-lg overflow-hidden border border-edge/30 bg-[rgba(0,0,0,0.25)] my-3 not-prose",children:[e.jsxs("div",{className:"flex items-center justify-between px-3.5 py-1.5 border-b border-edge/15 bg-[rgba(0,0,0,0.12)]",children:[e.jsx("span",{className:"text-[10px] font-mono text-fg-5/50",children:d||"text"}),e.jsx(er,{text:a})]}),e.jsx("pre",{className:"px-3.5 py-3 text-[12px] leading-[1.65] text-fg-3 font-mono whitespace-pre-wrap break-words overflow-x-auto",children:e.jsx("code",{children:a})})]})},pre:({children:t})=>e.jsx(e.Fragment,{children:t}),table:({children:t})=>e.jsx("div",{className:"my-3 overflow-x-auto rounded-lg border border-edge/30",children:e.jsx("table",{className:"w-full text-[12.5px]",children:t})}),thead:({children:t})=>e.jsx("thead",{className:"bg-[rgba(0,0,0,0.1)]",children:t}),th:({children:t})=>e.jsx("th",{className:"px-3 py-1.5 text-left font-semibold text-fg-3 border-b border-edge/30",children:t}),td:({children:t})=>e.jsx("td",{className:"px-3 py-1.5 text-fg-4 border-t border-edge/12",children:t}),tr:({children:t})=>e.jsx("tr",{className:"even:bg-[rgba(255,255,255,0.015)]",children:t})};function Ze(t){return!!t?.steps?.length}function tr(t,n){let s=t;for(const[a,l]of Object.entries(n))s=s.replace(new RegExp(`\\{${a}\\}`,"g"),l);return s}function nr({status:t}){return t==="completed"?e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",className:"text-ok",children:e.jsx("polyline",{points:"20 6 9 17 4 12"})}):t==="inProgress"?e.jsx("span",{className:"h-1.5 w-1.5 rounded-full bg-cyan-400 animate-pulse"}):e.jsx("span",{className:"h-1.5 w-1.5 rounded-full bg-fg-5/25"})}function Wn({plan:t,t:n,className:s}){const[a,l]=r.useState(!1);if(!Ze(t))return null;const d=t.steps.length,p=t.steps.filter(v=>v.status==="completed").length,c=d>0&&p===d,b=tr(n("hub.planProgress"),{done:String(p),total:String(d)});return e.jsx(Ye,{open:a,onToggle:()=>l(v=>!v),dot:{color:c?"bg-emerald-400/60":"bg-cyan-400/60",pulse:!c},label:b,preview:t.explanation?e.jsx("span",{className:"text-[11.5px] text-fg-4 truncate",children:t.explanation}):void 0,badge:e.jsx("span",{className:E("rounded-md border px-1.5 py-0.5 text-[10px] font-mono",c?"border-ok/20 text-ok":"border-edge text-fg-5"),children:n(c?"hub.planDone":"hub.planInProgress")}),className:s,children:e.jsx("div",{className:"px-3.5 py-2.5 space-y-1",children:t.steps.map((v,g)=>{const j=v.status==="completed"?"text-fg-5 line-through decoration-fg-5/40":v.status==="inProgress"?"text-fg-3":"text-fg-4";return e.jsxs("div",{className:"flex items-center gap-2 py-[2px]",children:[e.jsx("span",{className:"shrink-0 flex items-center justify-center w-[10px]",children:e.jsx(nr,{status:v.status})}),e.jsx("span",{className:E("text-[12px] leading-[1.5]",j),children:v.step})]},`${g}:${v.step}`)})})})}function Bn(t){return!!t.text||!!t.thinking||!!(t.activity&&t.activity.split(`
11
- `).filter(Boolean).length)||!!t.previewMeta?.toolCalls?.length||Ze(t.plan)||!!(t.subAgents&&t.subAgents.length)}function so(t){return Bn(t)||t.phase==="streaming"?!0:t.phase==="done"&&!!t.error}function sr(t){return t.phase!=="done"||!t.error?null:Bn(t)?"hub.streamErrored":"hub.streamFailed"}function rr({detail:t,t:n,className:s}){const a=Fs(t);if(a==="interrupted")return e.jsxs("div",{className:E("flex items-center gap-1.5 text-[11px] text-fg-5/55",s),children:[e.jsx("span",{className:"inline-block h-2 w-2 rounded-[2px] bg-fg-5/45 shrink-0"}),e.jsx("span",{children:n("hub.turnStopped")})]});const l=a==="error"?{dot:"bg-rose-400/55",text:"text-rose-300/65"}:{dot:"bg-fg-5/40",text:"text-fg-5/55"};return e.jsxs("div",{className:E("flex items-start gap-1.5 text-[11px] leading-[1.6]",l.text,s),children:[e.jsx("span",{className:E("mt-[5px] h-1 w-1 rounded-full shrink-0",l.dot)}),e.jsx("span",{className:"min-w-0 break-words",children:t})]})}const or=64;function ir(t,n){const[s,a]=r.useState(t),l=r.useRef(0),d=r.useRef(null);return r.useEffect(()=>{if(n<=0)return;const p=Date.now()-l.current,c=()=>{l.current=Date.now(),a(t)};return p>=n?c():(d.current&&clearTimeout(d.current),d.current=window.setTimeout(c,n-p)),()=>{d.current&&clearTimeout(d.current)}},[t,n]),n<=0?t:s}function ro({stream:t,t:n}){const s=Ze(t.plan),[a,l]=r.useState(!1),[d,p]=r.useState(!1),c=r.useRef(null),b=r.useRef(null),v=sr(t),g=r.useMemo(()=>(t.activity||"").split(`
12
- `).filter(Boolean),[t.activity]),j=t.previewMeta?.toolCalls??[],T=g[g.length-1]||j[j.length-1]?.summary||"";r.useLayoutEffect(()=>{const S=c.current;S&&a&&(S.scrollTop=S.scrollHeight)},[a,t.activity,j.length]),r.useLayoutEffect(()=>{const S=b.current;S&&d&&(S.scrollTop=S.scrollHeight)},[d,t.thinking]);const k=t.subAgents??null,I=ir(t.text,t.phase==="streaming"?or:0),L=r.useMemo(()=>e.jsx(ln,{remarkPlugins:un,components:hn,children:I}),[I]);return e.jsxs("div",{className:"space-y-3 animate-in",children:[s&&e.jsx(Wn,{plan:t.plan,t:n,className:"mb-1 max-w-[760px]"}),k&&k.length>0&&k.map(S=>e.jsx($n,{sub:S,t:n},S.id)),(j.length>0||g.length>0)&&e.jsx(Ye,{open:a,onToggle:()=>l(S=>!S),dot:{color:"bg-cyan-400/60",pulse:!0},label:n("hub.activity"),preview:e.jsx("span",{className:"text-[12px] text-fg-4 truncate",children:T}),badge:(j.length||g.length)>1?e.jsx(on,{children:j.length||g.length}):void 0,children:e.jsx("div",{ref:c,className:"px-3.5 py-2.5 space-y-0.5 max-h-[280px] overflow-y-auto",children:j.length>0?j.map(S=>e.jsx(ar,{call:S},S.id)):g.map((S,R)=>e.jsxs("div",{className:"flex items-center gap-1.5 py-[2px]",children:[e.jsx("span",{className:"w-1 h-1 rounded-full shrink-0 bg-fg-5/30"}),e.jsx("span",{className:"text-[11px] font-mono text-fg-5/60 truncate",children:S})]},R))})}),t.thinking&&e.jsx(Ye,{open:d,onToggle:()=>p(S=>!S),dot:{color:"bg-violet-400/50",pulse:!0},label:n("hub.thinking"),collapsedContent:e.jsx("div",{className:"px-3.5 pb-2.5 -mt-0.5 text-[12px] text-fg-4 leading-[1.65] whitespace-pre-wrap break-words line-clamp-3",children:_n(t.thinking,3)}),children:e.jsx("div",{ref:b,className:"px-3.5 py-3 text-[12px] text-fg-4 leading-[1.7] whitespace-pre-wrap break-words max-h-[280px] overflow-y-auto",children:t.thinking})}),t.text&&e.jsxs("div",{className:"session-md text-[13.5px] leading-[1.75] text-fg-2",children:[L,t.phase==="streaming"&&e.jsx(tn,{className:"ml-1 inline-flex align-text-bottom text-fg-4"})]}),!t.text&&t.phase==="streaming"&&e.jsx("div",{className:"py-1",children:e.jsx(tn,{className:"text-fg-5"})}),t.phase==="streaming"&&(t.generatingImages??0)>0&&e.jsxs("div",{className:"flex items-center gap-2 text-[12px] text-fg-4",children:[e.jsxs("span",{className:"relative inline-flex items-center justify-center w-3 h-3",children:[e.jsx("span",{className:"absolute inline-flex w-3 h-3 rounded-full bg-cyan-400/40 animate-ping"}),e.jsx("span",{className:"relative inline-block w-1.5 h-1.5 rounded-full bg-cyan-400/80"})]}),e.jsx("span",{children:t.generatingImages===1?"Generating image…":`Generating ${t.generatingImages} images…`})]}),v&&t.error&&e.jsx(rr,{detail:t.error,t:n,className:"pt-0.5"})]})}function ar({call:t}){const[n,s]=r.useState(!1),a=!!(t.input||t.result),l=t.status==="failed"?"bg-rose-400/70":t.status==="running"?"bg-cyan-400/70":"bg-fg-5/30";return e.jsxs("div",{children:[e.jsxs("button",{type:"button",onClick:()=>a&&s(d=>!d),className:`flex w-full items-center gap-1.5 py-[2px] text-left min-w-0 ${a?"cursor-pointer hover:bg-white/[0.03] rounded":"cursor-default"}`,title:a?void 0:t.summary,children:[e.jsx("span",{className:`w-1 h-1 rounded-full shrink-0 ${l} ${t.status==="running"?"animate-pulse":""}`}),e.jsx("span",{className:"text-[11px] font-mono text-fg-5/60 truncate flex-1",children:t.summary}),a&&e.jsx("span",{className:`shrink-0 text-[9px] text-fg-5/40 transition-transform ${n?"rotate-90":""}`,children:"▸"})]}),n&&e.jsxs("div",{className:"ml-2.5 mt-0.5 mb-1 space-y-1 border-l border-white/[0.06] pl-2.5",children:[t.input&&e.jsx("pre",{className:"whitespace-pre-wrap break-words text-[10.5px] font-mono leading-[1.55] text-fg-4/80 max-h-[140px] overflow-y-auto",children:t.input}),t.result&&e.jsx("pre",{className:"whitespace-pre-wrap break-words text-[10.5px] font-mono leading-[1.55] text-fg-5/70 max-h-[140px] overflow-y-auto border-t border-white/[0.04] pt-1",children:t.result})]})]})}function tn({className:t}){return e.jsxs("span",{className:`thinking-dots inline-flex items-center gap-[3px] ${t||""}`,children:[e.jsx("span",{}),e.jsx("span",{}),e.jsx("span",{})]})}function $n({sub:t,t:n}){const[s,a]=r.useState(!1),l=t.status,d=l==="failed"?"bg-rose-400/60":l==="done"?"bg-emerald-400/55":"bg-amber-400/60",p=l==="running",c=t.tools,b=r.useMemo(()=>{const j=new Set,T=[];for(const k of c)j.has(k.name)||(j.add(k.name),T.push(k.name));return T},[c]),v=t.kind?`${n("hub.subAgent")||"Sub-agent"} · ${t.kind}`:n("hub.subAgent")||"Sub-agent",g=t.model?rn(t.model):null;return e.jsx(Ye,{open:s,onToggle:()=>a(j=>!j),dot:{color:d,pulse:p},label:v,preview:e.jsxs("span",{className:"flex items-center gap-1.5 min-w-0 text-[12px] text-fg-4",children:[t.description&&e.jsx("span",{className:"truncate",children:t.description}),g&&e.jsx("span",{className:"text-[10px] font-mono text-fg-5/55 shrink-0",children:g}),!t.description&&b.length>0&&e.jsx("span",{className:"font-mono text-fg-5/60 truncate",children:b.join(" · ")})]}),badge:c.length>0?e.jsx(on,{children:c.length}):void 0,children:e.jsxs("div",{className:"px-3.5 py-2.5 space-y-1 max-h-[260px] overflow-y-auto",children:[t.description&&e.jsx("div",{className:"mb-1.5 text-[12px] text-fg-3 leading-[1.55]",children:t.description}),c.length===0?e.jsxs("div",{className:"text-[11px] font-mono text-fg-5/50",children:["— ",n("hub.subAgentWaiting")||"waiting for first tool…"]}):c.map(j=>e.jsxs("div",{className:"flex items-center gap-1.5 py-[2px]",children:[e.jsx("span",{className:"w-1 h-1 rounded-full shrink-0 bg-fg-5/30"}),e.jsx("span",{className:"text-[11px] font-mono text-fg-5/65 truncate",children:j.summary})]},j.id))]})})}function lr({message:t,t:n}){const{activityBlocks:s,thinkingBlocks:a,planBlocks:l,subAgentBlocks:d,outputBlocks:p,noticeBlocks:c}=On(t.blocks),b=[...l].reverse().find(g=>Ze(g.plan));return s.length>0||d.length>0||!!b?.plan||a.length>0||p.length>0||c.length>0?e.jsxs("div",{className:"space-y-3",children:[s.length>0&&e.jsx(ur,{blocks:s,t:n}),d.map(g=>g.subAgent?e.jsx($n,{sub:g.subAgent,t:n},g.toolId||g.subAgent.id):null),b?.plan&&e.jsx(Wn,{plan:b.plan,t:n,className:"max-w-[760px]"}),a.length>0&&e.jsx(pr,{blocks:a,t:n}),p.length>0&&e.jsx(gr,{blocks:p,t:n}),c.length>0&&e.jsx(dr,{blocks:c,t:n})]}):null}function cr(t){const{activityBlocks:n,thinkingBlocks:s,planBlocks:a,subAgentBlocks:l,outputBlocks:d,noticeBlocks:p}=On(t.blocks);return d.length>0||n.length>0||l.length>0||s.length>0||a.some(c=>Ze(c.plan))||p.length>0}function On(t){const n=t.filter(s=>s.type==="plan"||s.type==="tool_use"||s.type==="tool_result"||s.type==="image"||s.type==="sub_agent"||!!s.content.trim());return{activityBlocks:n.filter(s=>s.type==="tool_use"||s.type==="tool_result"),thinkingBlocks:n.filter(s=>s.type==="thinking"),planBlocks:n.filter(s=>s.type==="plan"&&Ze(s.plan)),subAgentBlocks:n.filter(s=>s.type==="sub_agent"),outputBlocks:n.filter(s=>s.type==="text"||s.type==="image"),noticeBlocks:n.filter(s=>s.type==="system_notice")}}function dr({blocks:t,t:n}){const s=t.map(a=>a.content).filter(Boolean).join(`
13
-
14
- `).trim();return s?e.jsxs("div",{className:"flex items-start gap-2 rounded-md border border-amber-500/30 bg-amber-500/[0.06] px-3 py-2 text-[12.5px] leading-[1.7] text-fg-3",children:[e.jsx("span",{className:"mt-[6px] h-1.5 w-1.5 rounded-full bg-amber-400/70 shrink-0"}),e.jsxs("div",{className:"min-w-0",children:[e.jsx("div",{className:"text-[11px] font-mono uppercase tracking-wide text-amber-300/80",children:n("hub.systemNotice")||"Agent notice"}),e.jsx("div",{className:"mt-0.5 break-words whitespace-pre-wrap",children:s})]})]}):null}function ur({blocks:t,t:n}){const[s,a]=r.useState(!1),l=t.filter(b=>b.type==="tool_use"),d=l.length,p=l[l.length-1],c=p?Pn(p):"";return e.jsx(Ye,{open:s,onToggle:()=>a(b=>!b),dot:{color:"bg-cyan-400/60"},label:n("hub.activity"),preview:e.jsx("span",{className:"text-[11.5px] font-mono text-fg-4 truncate",children:c}),badge:d>0?e.jsx(on,{children:d}):void 0,children:e.jsx("div",{className:"px-3.5 py-2.5 space-y-0.5",children:t.map((b,v)=>e.jsx(hr,{block:b},v))})})}function hr({block:t}){const[n,s]=r.useState(!1),a=t.type==="tool_use",l=a?Pn(t):Vs(t);return e.jsxs("div",{children:[e.jsxs("button",{onClick:()=>t.content&&s(d=>!d),className:E("flex items-center gap-2 py-[3px] w-full text-left group rounded-sm transition-colors",t.content&&"hover:bg-panel-h/30"),children:[e.jsx("span",{className:E("h-1.5 w-1.5 rounded-full shrink-0",a?"bg-fg-5/40":"bg-ok/40")}),e.jsx("span",{className:"text-[11px] font-mono text-fg-5/60 group-hover:text-fg-3 transition-colors truncate",children:l})]}),n&&t.content&&e.jsx("pre",{className:"ml-3 mt-1 mb-2 p-3 rounded-md bg-inset border border-edge text-[11px] leading-[1.6] text-fg-4 font-mono whitespace-pre-wrap break-words max-h-[240px] overflow-y-auto",children:t.content.length>3e3?t.content.slice(0,3e3)+`
15
- …`:t.content})]})}function pr({blocks:t,t:n}){const[s,a]=r.useState(!1),l=r.useRef(null),d=t.map(c=>c.content).filter(Boolean).join(`
16
-
17
- `).trim();if(!d)return null;const p=_n(d,3);return e.jsx(Ye,{open:s,onToggle:()=>a(c=>!c),dot:{color:"bg-violet-400/50"},label:n("hub.thinking"),collapsedContent:p?e.jsx("div",{className:"px-3.5 pb-2.5 -mt-0.5 text-[12px] text-fg-4 leading-[1.65] whitespace-pre-wrap break-words line-clamp-3",children:p}):void 0,children:e.jsx(xr,{scrollRef:l,text:d})})}function xr({scrollRef:t,text:n}){return r.useLayoutEffect(()=>{const s=t.current;s&&(s.scrollTop=s.scrollHeight)},[t]),e.jsx("div",{ref:t,className:"px-3.5 py-3 text-[12px] text-fg-4 leading-[1.7] whitespace-pre-wrap break-words max-h-[320px] overflow-y-auto",children:n})}function fr({block:t,onLightbox:n,t:s}){const a=t.imageCaption?.trim()||"",[l,d]=r.useState(!1);return e.jsxs("figure",{className:"flex flex-col gap-1.5 max-w-[400px]",children:[e.jsx("img",{src:t.content,alt:a||"",className:"max-w-[400px] max-h-[300px] rounded-md border border-fg-6/50 object-contain cursor-zoom-in hover:opacity-90 transition-opacity",onClick:()=>n(t.content)}),a&&e.jsxs(e.Fragment,{children:[e.jsxs("button",{type:"button",onClick:()=>d(p=>!p),"aria-expanded":l,className:E("self-start inline-flex items-center gap-1 px-2 py-[3px] rounded-md","text-[11px] font-medium tracking-wide","border border-fg-6/40 bg-fg-6/[0.06] text-fg-3","hover:bg-fg-6/[0.12] hover:text-fg-2 hover:border-fg-6/60","transition-colors"),title:s(l?"hub.imagePromptHide":"hub.imagePromptShow"),children:[e.jsx("span",{"aria-hidden":!0,className:"text-[9px] leading-none",children:l?"▾":"▸"}),e.jsx("span",{children:s("hub.imagePrompt")})]}),l&&e.jsx("div",{className:"rounded-md border border-fg-6/30 bg-fg-6/[0.05] px-3 py-2 max-w-[400px] max-h-[260px] overflow-y-auto",children:e.jsx("div",{className:"text-[11.5px] leading-[1.65] text-fg-3 whitespace-pre-wrap break-words",children:a})})]})]})}function gr({blocks:t,t:n}){const s=t.filter(c=>c.type==="text"),a=t.filter(c=>c.type==="image"),l=s.map(c=>c.content).filter(Boolean).join(`
18
-
19
- `),[d,p]=r.useState(null);return!l.trim()&&a.length===0?null:e.jsxs(e.Fragment,{children:[l.trim()&&e.jsx("div",{className:"session-md text-[13.5px] leading-[1.75] text-fg-2",children:e.jsx(ln,{remarkPlugins:un,components:hn,children:l})}),a.length>0&&e.jsx("div",{className:"flex flex-wrap gap-3 mt-2",children:a.map((c,b)=>e.jsx(fr,{block:c,onLightbox:p,t:n},b))}),d&&e.jsx(Dn,{src:d,onClose:()=>p(null)})]})}const oo=r.memo(function({turn:n,turnIndex:s,agent:a,meta:l,model:d,effort:p,providerName:c,t:b,onResend:v,onEdit:g,onFork:j}){const T=n.user&&Rn(n.user.text),k=j&&typeof s=="number"?()=>j(s):void 0,I=!!n.assistant&&cr(n.assistant);return e.jsxs("div",{className:"session-turn",children:[n.user&&!T&&e.jsx(Fn,{text:n.user.text,blocks:n.user.blocks,t:b,onResend:v,onEdit:g,onFork:k}),T&&n.user&&!n.assistant&&e.jsx("div",{className:"mb-4 px-4 py-3 rounded-lg bg-[rgba(255,255,255,0.02)] border border-edge/20 text-[12.5px] leading-[1.7] text-fg-4",children:e.jsx(ln,{remarkPlugins:un,components:hn,children:n.user.text})}),I&&e.jsxs(e.Fragment,{children:[e.jsx(jr,{agent:a,meta:l,model:d,effort:p,providerName:c,previewMeta:n.assistant.usage??null}),e.jsx("div",{className:"mb-6",children:e.jsx(lr,{message:n.assistant,t:b})})]})]})});function Dn({src:t,onClose:n}){return r.useEffect(()=>{const s=a=>{a.key==="Escape"&&n()};return window.addEventListener("keydown",s),()=>window.removeEventListener("keydown",s)},[n]),an.createPortal(e.jsx("div",{className:"fixed inset-0 z-[9999] flex items-center justify-center bg-black/80 backdrop-blur-sm cursor-zoom-out",onClick:n,children:e.jsx("img",{src:t,className:"max-w-[90vw] max-h-[90vh] object-contain rounded-lg shadow-2xl",onClick:s=>s.stopPropagation()})}),document.body)}const mr=1500,br=16,kn=8;function vr(t){const n=t.split(`
20
- `);return n.length<=kn?t:n.slice(0,kn).join(`
21
- `)}function Fn({text:t,blocks:n,t:s,onResend:a,onEdit:l,onFork:d}){const[p,c]=r.useState(!1),[b,v]=r.useState(!1),[g,j]=r.useState(null),T=t?t.split(`
22
- `).length:0,k=!!t&&(t.length>mr||T>br),[I,L]=r.useState(!1),S=t?k&&!I?vr(t):t:"",R=!!(a||l||d),D=n?.filter(A=>A.type==="image")||[],H=()=>{navigator.clipboard.writeText(t).then(()=>{v(!0),setTimeout(()=>v(!1),1500)}).catch(()=>{})},P=s("hub.expand").replace("{chars}",t?t.length.toLocaleString():"0").replace("{lines}",String(T));return e.jsxs("div",{className:"flex flex-col items-end mb-5 group/bubble",onMouseEnter:()=>c(!0),onMouseLeave:()=>c(!1),children:[e.jsxs("div",{className:"max-w-[72%] rounded-md border border-fg-6 bg-panel px-4 py-3 text-[13.5px] leading-[1.72] text-fg shadow-sm",children:[t&&e.jsxs("div",{className:"whitespace-pre-wrap break-words",children:[S,k&&!I&&e.jsx("span",{className:"text-fg-5/60",children:"…"})]}),k&&e.jsx("button",{type:"button",onClick:()=>L(A=>!A),className:"mt-2 text-[11.5px] text-fg-4 hover:text-fg-2 underline decoration-fg-5/40 underline-offset-2 transition-colors",children:I?s("hub.collapse"):P}),D.length>0&&e.jsx("div",{className:E("flex flex-wrap gap-2",t&&"mt-2"),children:D.map((A,F)=>e.jsx("img",{src:A.content,className:"max-w-[280px] max-h-[200px] rounded border border-fg-6/50 object-cover cursor-zoom-in hover:opacity-90 transition-opacity",onClick:()=>j(A.content)},F))})]}),g&&e.jsx(Dn,{src:g,onClose:()=>j(null)}),R&&e.jsxs("div",{className:E("flex items-center gap-1 mt-1.5 mr-1 transition-all duration-200",p?"opacity-100 translate-y-0":"opacity-0 -translate-y-1 pointer-events-none"),children:[e.jsx(It,{label:s(b?"hub.copied":"hub.copy"),onClick:H,children:b?e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"#34d399",strokeWidth:"2",children:e.jsx("polyline",{points:"20 6 9 17 4 12"})}):e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:[e.jsx("rect",{x:"9",y:"9",width:"13",height:"13",rx:"2"}),e.jsx("path",{d:"M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"})]})}),a&&e.jsx(It,{label:s("hub.rerun"),onClick:()=>a(t),children:e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:[e.jsx("polyline",{points:"23 4 23 10 17 10"}),e.jsx("path",{d:"M20.49 15a9 9 0 1 1-2.12-9.36L23 10"})]})}),l&&e.jsx(It,{label:s("hub.edit"),onClick:()=>l(t),children:e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:[e.jsx("path",{d:"M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7"}),e.jsx("path",{d:"M18.5 2.5a2.121 2.121 0 0 1 3 3L12 15l-4 1 1-4 9.5-9.5z"})]})}),d&&e.jsx(It,{label:s("hub.fork"),onClick:d,children:e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:[e.jsx("circle",{cx:"6",cy:"6",r:"2"}),e.jsx("circle",{cx:"18",cy:"6",r:"2"}),e.jsx("circle",{cx:"12",cy:"20",r:"2"}),e.jsx("path",{d:"M6 8v3a3 3 0 0 0 3 3h6a3 3 0 0 0 3-3V8"}),e.jsx("path",{d:"M12 14v4"})]})})]})]})}function It({label:t,onClick:n,children:s}){return e.jsx("button",{onClick:n,title:t,className:"flex items-center justify-center w-7 h-7 rounded border border-fg-6 bg-panel text-fg-4 shadow-sm hover:text-fg-2 hover:border-edge-h hover:bg-panel-h transition-colors",children:s})}function jr({agent:t,meta:n,model:s,effort:a,providerName:l,previewMeta:d,liveStartedAt:p}){const c=d?.contextPercent??null,b=d?.contextUsedTokens??0,v=d?.turnOutputTokens??0,g=c!=null||b>0||v>0,j=p!=null&&p>0,T=d?.providerName??l??null;return e.jsxs("div",{className:"flex items-center gap-1.5 mt-1 mb-3",children:[e.jsx(Je,{brand:t,size:13}),e.jsx("span",{style:{color:n.color},className:"text-[12px] font-semibold opacity-70",children:n.label}),(s||a)&&e.jsxs("span",{className:"text-[10px] font-mono text-fg-5/50",children:[s||"",s&&a?" · ":"",a||""]}),T&&e.jsxs("span",{className:"text-[10px] font-mono text-fg-5/70 px-1.5 py-px rounded bg-fg-5/8",title:`This turn is routed through ${T} (BYOK), not the agent CLI's native auth.`,children:["via ",T]}),(g||j)&&e.jsxs("span",{className:"ml-auto inline-flex items-center gap-1 text-[10px] font-mono text-fg-5/55",title:Nr(d),children:[c!=null&&e.jsx(Sr,{pct:c}),e.jsx("span",{children:c!=null?`${c.toFixed(1)}%`:""}),b>0&&e.jsxs("span",{className:"text-fg-5/40",children:["· ",yr(b)]}),v>0&&e.jsxs("span",{className:"text-fg-5/40",children:["· ↑",Un(v)]}),j&&e.jsx(wr,{startedAt:p,leadingDot:g})]})]})}function wr({startedAt:t,leadingDot:n}){const[,s]=r.useState(0);r.useEffect(()=>{const l=setInterval(()=>s(d=>d+1),1e3);return()=>clearInterval(l)},[]);const a=Math.max(0,Date.now()-t);return e.jsxs("span",{className:"text-fg-5/55 tabular-nums",title:"Elapsed time of the running turn",children:[n?"· ":"",kr(a)]})}function kr(t){const n=Math.floor(t/1e3);if(n<60)return`${n}s`;const s=Math.floor(n/60),a=n%60;return s<60?`${s}m${a.toString().padStart(2,"0")}s`:`${Math.floor(s/60)}h${(s%60).toString().padStart(2,"0")}m`}function yr(t){return`${Un(t)} tok`}function Un(t){return t>=1e6?`${(t/1e6).toFixed(1)}M`:t>=1e3?`${(t/1e3).toFixed(1)}k`:`${t}`}function Nr(t){if(!t)return"";const n=[];return t.contextPercent!=null&&n.push(`Context: ${t.contextPercent.toFixed(1)}%`),t.inputTokens!=null&&n.push(`Input: ${t.inputTokens.toLocaleString()}`),t.turnOutputTokens!=null?n.push(`Output (turn): ${t.turnOutputTokens.toLocaleString()}`):t.outputTokens!=null&&n.push(`Output: ${t.outputTokens.toLocaleString()}`),t.cachedInputTokens!=null&&n.push(`Cached: ${t.cachedInputTokens.toLocaleString()}`),n.join(" · ")}function Sr({pct:t}){const n=t>=85?"bg-rose-400/70":t>=60?"bg-amber-400/70":"bg-emerald-400/70";return e.jsx("span",{className:`h-1.5 w-1.5 rounded-full ${n}`})}function yn(t,n,s){return t==="zh-CN"?n:s}function Cr({open:t,onClose:n,workdir:s}){const a=je(d=>d.locale),l=s.split("/").pop()||s;return e.jsxs(Wt,{open:t,onClose:n,wide:!0,children:[e.jsx(Bt,{title:yn(a,`${l} — 项目扩展`,`${l} — Project Extensions`),description:yn(a,"仅对当前工作区生效。直接操作项目目录中的 .mcp.json 与 .pikiloom/skills/。","Project-scoped only. Operates directly on .mcp.json and .pikiloom/skills/ in the workspace directory."),onClose:n}),t?e.jsx(js,{workdir:s}):null]})}let Nn=Tn(()=>import("./SessionPanel-CYQtZZNX.js"),__vite__mapDeps([0,1,2,3,4,5,6,7,8,9]));function nn(){return Nn??=Tn(()=>import("./SessionPanel-CYQtZZNX.js"),__vite__mapDeps([0,1,2,3,4,5,6,7,8,9])),Nn}const Tr=r.lazy(async()=>({default:(await nn()).SessionPanel})),Yt=5,Er=240,Lr=120,Mr=12,Ir=900*1e3,U=(t,n)=>`${t}:${n}`;function Ar(t){const n=new Map;for(const c of t)n.set(U(c.agent||"",c.sessionId),c);const s=new Map,a=new Set;for(const c of t){const b=c.migratedFrom;if(!b||b.kind!=="fork"||!b.sessionId)continue;const v=U(b.agent||c.agent||"",b.sessionId);n.has(v)&&(a.add(U(c.agent||"",c.sessionId)),s.has(v)||s.set(v,[]),s.get(v).push(c))}const l=[],d=new Set,p=(c,b)=>{const v=U(c.agent||"",c.sessionId);if(d.has(v))return;d.add(v),l.push(Object.assign({},c,{__forkDepth:b}));const g=s.get(v);if(g)for(const j of g)p(j,b+1)};for(const c of t){const b=U(c.agent||"",c.sessionId);a.has(b)||p(c,0)}for(const c of t)p(c,0);return l}let Rr=0;function At(){return`mk-${Date.now().toString(36)}-${(++Rr).toString(36)}`}function _r(t){return t==="vscode"||t==="cursor"||t==="windsurf"||t==="finder"||t==="default"}function Pr(t,n){const s=String(t||"").toLowerCase();return s.includes("cursor")?"cursor":s.includes("windsurf")?"windsurf":s.includes("code")||n==="darwin"?"vscode":"default"}function Hn(t){switch(t){case"cursor":return"hub.openTargetCursor";case"windsurf":return"hub.openTargetWindsurf";case"finder":return"hub.openTargetFinder";case"default":return"hub.openTargetDefault";default:return"hub.openTargetVsCode"}}const Wr=r.memo(function({active:n=!0}){const s=je(i=>i.locale),a=je(i=>i.state?.runtimeWorkdir??null),l=r.useMemo(()=>ds(s),[s]),[d,p]=r.useState([]),[c,b]=r.useState({}),[v,g]=r.useState({}),[j,T]=r.useState(!0),[k,I]=r.useState(()=>{try{const u=sessionStorage.getItem("pikiloom-layout-mode");if(u==="1"||u==="2"||u==="3"||u==="6")return Number(u)}catch{}const i=window.innerWidth;return i>=1920?3:i>=1280?2:1}),[L,S]=r.useState(()=>{try{const i=sessionStorage.getItem("pikiloom-open-sessions");if(i){const u=JSON.parse(i);if(Array.isArray(u))return u.map(h=>({...h,mountKey:h.mountKey||At()}))}}catch{}return[]}),[R,D]=r.useState(()=>{try{const i=sessionStorage.getItem("pikiloom-active-slot");if(i!=null){const u=Number(i);if(Number.isFinite(u)&&u>=0)return u}}catch{}return 0}),H=r.useCallback(i=>{I(i);try{sessionStorage.setItem("pikiloom-layout-mode",String(i))}catch{}},[]),P=r.useCallback(i=>{S(u=>{const h=typeof i=="function"?i(u):i;try{const f=h.map(({pendingPrompt:w,pendingImageUrls:y,...C})=>C);sessionStorage.setItem("pikiloom-open-sessions",JSON.stringify(f))}catch{}return h})},[]),A=r.useCallback(i=>{D(u=>{const h=typeof i=="function"?i(u):i;try{sessionStorage.setItem("pikiloom-active-slot",String(h))}catch{}return h})},[]);r.useEffect(()=>{P(i=>i.length>k?i.slice(0,k):i),A(i=>i>=k?k-1:i)},[k]);const[F,z]=r.useState(!1),ae=r.useRef(k);ae.current=k;const ee=r.useRef(R);ee.current=R;const M=r.useRef(-1),K=L[R]??null,Le=r.useCallback(i=>{if(!i){P([]),A(0);return}const u=i.mountKey?i:{...i,mountKey:At()};P(h=>{const f=h.findIndex(y=>y.agent===u.agent&&y.sessionId===u.sessionId);if(f>=0)return A(f),h;if(h.length<ae.current){const y=[...h,u];return A(y.length-1),y}const w=[...h];return w[ee.current]=u,w})},[]),[de,we]=r.useState(!1),[$,Fe]=r.useState(null),[Me,et]=r.useState(""),[ke,vt]=r.useState("all"),[ue,jt]=r.useState({}),te=r.useDeferredValue(Me),ne=r.useRef(!1),Ue=r.useRef({}),Ie=r.useRef(c);Ie.current=c;const He=r.useRef(ue);He.current=ue;const tt=r.useRef(new Set),se=r.useRef({});r.useEffect(()=>()=>{for(const i of Object.values(se.current))clearTimeout(i)},[]);const le=r.useCallback(async()=>{try{const i=await J.getWorkspaces(),u=i.ok?i.workspaces:[];u.length&&p(h=>h.length===u.length&&h.every((f,w)=>f.path===u[w].path&&f.name===u[w].name)?h:u),ne.current=!0}catch{ne.current=!0}finally{T(!1)}},[]);r.useEffect(()=>{le()},[le]);const W=r.useCallback(async(i,u={})=>{if(!Ue.current[i]){Ue.current[i]=!0,u.background||g(h=>({...h,[i]:!0}));try{const h=await Ss(i,{force:u.force});r.startTransition(()=>{b(f=>{const w=h.sessions||[],y=f[i]||[],C=new Set(w.map(O=>U(O.agent||"",O.sessionId))),G=y.filter(O=>{if(O.runState!=="running")return!1;const Y=U(O.agent||"",O.sessionId);if(C.has(Y))return!1;const ut=He.current[Y];return!(ut?.resolvedKey&&ut.resolvedKey!==Y)});return{...f,[i]:G.length?[...G,...w]:w}})})}catch{u.background||r.startTransition(()=>{b(h=>({...h,[i]:[]}))})}finally{Ue.current[i]=!1,u.background||g(h=>({...h,[i]:!1}))}}},[]),ye=r.useRef(a);r.useEffect(()=>{a!==ye.current&&(ye.current=a,!(!a||!ne.current)&&le().then(()=>{W(a,{force:!0})}))},[a,le,W]);const X=r.useCallback((i,u)=>{const h=i.agent||"";!h||!i.sessionId||(nn(),Es({workdir:u,agent:h,sessionId:i.sessionId,rich:!0,turnOffset:0,turnLimit:Mr}))},[]),Ae=r.useCallback((i,u,h=Lr)=>{const f=`${u}:${U(i.agent||"",i.sessionId)}`,w=se.current[f];w&&clearTimeout(w),se.current[f]=setTimeout(()=>{delete se.current[f],X(i,u)},h)},[X]),Re=r.useCallback((i,u)=>{const h=`${u}:${U(i.agent||"",i.sessionId)}`,f=se.current[h];f&&(clearTimeout(f),delete se.current[h])},[]);r.useEffect(()=>{n&&nn()},[n]),r.useEffect(()=>{if(!n)return;const i=[];return d.forEach((u,h)=>{if(c[u.path]||v[u.path])return;const f=setTimeout(()=>{W(u.path)},h*90);i.push(f)}),()=>{for(const u of i)clearTimeout(u)}},[n,W,v,c,d]);const wt=r.useRef(new Map);vn(n&&ne.current&&d.length>0?"sessions-changed":null,r.useCallback(i=>{if(typeof document<"u"&&document.visibilityState==="hidden")return;const u=i.key,h=u?d.filter(y=>(Ie.current[y.path]||[]).some(C=>U(C.agent||"",C.sessionId)===u)):d,f=h.length?h:d,w=wt.current;for(const y of f)w.has(y.path)&&clearTimeout(w.get(y.path)),w.set(y.path,setTimeout(()=>{w.delete(y.path),W(y.path,{background:!0,force:!0})},300))},[d,W]));const B=r.useCallback(i=>{const u=i.agent||"";return!u||!i.sessionId?i:us(i,ue[U(u,i.sessionId)]||null)},[ue]);vn("stream-update",r.useCallback(i=>{const u=i.key;u&&jt(h=>{const f={},w=Date.now()-Ir;for(const[C,G]of Object.entries(h))G.updatedAt>=w&&(f[C]=G);const y=hs(u,i.snapshot??null);if(!y){const C=f[u];return C&&C.phase!=="done"&&(f[u]={...C,phase:"done",updatedAt:Date.now()}),f}return f[u]=y,y.resolvedKey!==u&&(f[y.resolvedKey]={...y,key:y.resolvedKey}),f})},[])),Ws(r.useCallback(()=>{if(!(!n||!ne.current||d.length===0))for(const i of d)W(i.path,{background:!0,force:!0})},[n,d,W])),r.useEffect(()=>{if(!n||!ne.current||d.length===0)return;const i=()=>{if(!(typeof document<"u"&&document.visibilityState==="hidden"))for(const h of d)W(h.path,{background:!0,force:!0})};if(i(),typeof document>"u"||typeof window>"u")return;const u=()=>{document.visibilityState==="visible"&&i()};return document.addEventListener("visibilitychange",u),window.addEventListener("focus",u),()=>{document.removeEventListener("visibilitychange",u),window.removeEventListener("focus",u)}},[n,W,d]),r.useEffect(()=>{if(!n)return;const i=[];return d.forEach((u,h)=>{const f=(c[u.path]||[])[0];if(!f)return;const w=`${u.path}:${U(f.agent||"",f.sessionId)}`;if(tt.current.has(w))return;const y=setTimeout(()=>{tt.current.add(w),X(f,u.path)},Er+h*120);i.push(y)}),()=>{for(const u of i)clearTimeout(u)}},[n,c,X,d]);const re=r.useCallback(async i=>{try{(await J.addWorkspace(i)).ok&&(we(!1),await le(),W(i))}catch{}},[le,W]),[xe,Ne]=r.useState(null),[oe,_e]=r.useState(!1),[nt,kt]=r.useState(null),ze=r.useCallback(i=>{Ne(i)},[]),st=r.useCallback(async()=>{const i=xe;if(i){_e(!0);try{await J.removeWorkspace(i),p(u=>u.filter(h=>h.path!==i)),b(u=>{const h={...u};return delete h[i],h}),P(u=>u.filter(h=>h.workdir!==i)),A(0),Ne(null)}catch{}finally{_e(!1)}}},[xe]),rt=r.useCallback(i=>{W(i,{force:!0})},[W]),[Se,V]=r.useState(null),[fe,Ce]=r.useState(!1),[ie,Pe]=r.useState(!1),We=je(i=>i.toast),[he,ot]=r.useState(null),it=r.useCallback((i,u,h)=>{ot({anchor:{right:i.right,bottom:i.bottom},target:{workdir:h,agent:u.agent||"",sessionId:u.sessionId,title:Sn(u).slice(0,120)||u.sessionId.slice(0,16)}})},[]);r.useEffect(()=>{if(!he)return;const i=()=>ot(null),u=h=>{h.key==="Escape"&&i()};return window.addEventListener("mousedown",i),window.addEventListener("scroll",i,!0),window.addEventListener("resize",i),window.addEventListener("keydown",u),()=>{window.removeEventListener("mousedown",i),window.removeEventListener("scroll",i,!0),window.removeEventListener("resize",i),window.removeEventListener("keydown",u)}},[he]);const Ot=r.useCallback(i=>{Ce(!1),V(i),ot(null)},[]),yt=r.useCallback(async()=>{const i=Se;if(i){Pe(!0);try{const u=await J.deleteSession(i.workdir,i.agent,i.sessionId,fe);if(!u.ok){const h=u.error?.includes("still running")?l("session.deleteRunningError"):u.error||l("session.deleteFailed");We(h,!1);return}b(h=>{const f=h[i.workdir];if(!f)return h;const w=f.filter(y=>!(y.agent===i.agent&&y.sessionId===i.sessionId));return w.length===f.length?h:{...h,[i.workdir]:w}}),P(h=>h.filter(f=>!(f.workdir===i.workdir&&f.agent===i.agent&&f.sessionId===i.sessionId))),V(null)}catch(u){We(u?.message||l("session.deleteFailed"),!1)}finally{Pe(!1)}}},[Se,fe,l,We]),Dt=r.useCallback(i=>{P(u=>{let h=!1;const f=u.map(w=>w.mountKey===i&&(w.pendingPrompt!=null||w.pendingImageUrls)?(h=!0,{...w,pendingPrompt:null,pendingImageUrls:void 0}):w);return h?f:u})},[P]),at=r.useCallback((i,u,h)=>{X({agent:i.agent,sessionId:i.sessionId,runState:"running"},i.workdir),b(y=>{const C=y[i.workdir]||[];if(C.some(Y=>Y.sessionId===i.sessionId&&Y.agent===i.agent))return y;const O={sessionId:i.sessionId,agent:i.agent,runState:"running",lastQuestion:u,createdAt:new Date().toISOString(),runUpdatedAt:new Date().toISOString()};return{...y,[i.workdir]:[O,...C]}});const f=M.current,w={...i,mountKey:At(),pendingPrompt:u||null,pendingImageUrls:h&&h.length?h:void 0};r.startTransition(()=>{Fe(null),P(y=>{if(f>=y.length)return[...y,w];const C=[...y];return C[f]=w,C}),A(f>=0?f:0)}),W(i.workdir,{background:!0,force:!0})},[W,X,P,A]),Be=r.useCallback((i,u)=>{X(i,u),Fe(null),r.startTransition(()=>{Le({agent:i.agent||"",sessionId:i.sessionId,workdir:u})})},[X]),Ke=r.useCallback((i,u)=>{X({agent:i.agent,sessionId:i.sessionId,runState:"running"},i.workdir),r.startTransition(()=>{u!=null?(P(h=>{if(u>=h.length)return h;const f=[...h];return f[u]={...h[u],agent:i.agent,sessionId:i.sessionId,workdir:i.workdir},f}),A(u)):Le({...i,mountKey:At()})}),W(i.workdir,{background:!0,force:!0})},[W,X]),lt=r.useCallback(i=>{let u=i;if(ke==="running"?u=u.filter(h=>Rt(h)==="running"):ke==="review"&&(u=u.filter(h=>Rt(h)==="incomplete")),te.trim()){const h=te.toLowerCase();u=u.filter(f=>(f.lastMessageText||"").toLowerCase().includes(h)||(f.lastQuestion||"").toLowerCase().includes(h)||(f.lastAnswer||"").toLowerCase().includes(h)||(f.title||"").toLowerCase().includes(h)||(f.agent||"").toLowerCase().includes(h))}return u},[te,ke]),ct=r.useMemo(()=>{const i={};for(const u of d){const h=(c[u.path]||[]).map(B),f=new Map;for(const y of h){const C=U(y.agent||"",y.sessionId),G=ue[C],O=G?.resolvedKey&&G.resolvedKey!==C?G.resolvedKey:C,Y=f.get(O);if(!Y){f.set(O,y);continue}U(Y.agent||"",Y.sessionId)!==O&&C===O&&f.set(O,y)}const w=lt([...f.values()]);i[u.path]=Ar(w)}return i},[d,c,ue,lt,B]),ge=r.useCallback(i=>{const u=(c[i.workdir]||[]).find(h=>h.sessionId===i.sessionId&&h.agent===i.agent)??{sessionId:i.sessionId,agent:i.agent,runState:"running"};return B(u)},[B,c]),Nt=r.useMemo(()=>new Set(L.map(i=>U(i.agent,i.sessionId))),[L]),dt=K?U(K.agent,K.sessionId):null,St=r.useCallback(i=>{P(u=>{const h=u.filter((f,w)=>w!==i);return h.length===0?A(0):ee.current>=h.length&&A(h.length-1),h})},[]);return e.jsxs("div",{className:"h-full overflow-hidden p-4 flex gap-3 mx-auto",children:[e.jsxs("div",{className:"panel-isolated w-[252px] shrink-0 flex flex-col overflow-hidden rounded-xl border border-edge bg-panel backdrop-blur-sm",style:{boxShadow:"var(--th-card-shadow)"},children:[e.jsxs("div",{className:"px-3 pt-3 pb-2 space-y-2",children:[e.jsxs("div",{className:"relative group",children:[e.jsxs("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",className:"absolute left-2.5 top-1/2 -translate-y-1/2 text-fg-5/40 group-focus-within:text-fg-4 transition-colors",children:[e.jsx("circle",{cx:"11",cy:"11",r:"8"}),e.jsx("line",{x1:"21",y1:"21",x2:"16.65",y2:"16.65"})]}),e.jsx("input",{value:Me,onChange:i=>et(i.target.value),placeholder:l("hub.search"),className:"w-full rounded-lg border border-edge/40 bg-inset/50 pl-8 pr-7 py-1.5 text-[12px] text-fg outline-none placeholder:text-fg-5/30 focus:border-primary/30 focus:bg-inset focus:shadow-[0_0_0_3px_rgba(99,102,241,0.06)] transition-all duration-200"}),Me&&e.jsx("button",{onClick:()=>et(""),className:"absolute right-2 top-1/2 -translate-y-1/2 p-0.5 rounded text-fg-5/30 hover:text-fg-4 transition-colors",children:e.jsxs("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",children:[e.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),e.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]}),e.jsx("div",{className:"flex items-center rounded-lg bg-inset/30 border border-edge/20 p-0.5",children:["all","running","review"].map(i=>e.jsx("button",{onClick:()=>vt(i),className:E("flex-1 px-2 py-[5px] rounded-md text-[11px] font-medium transition-all duration-200",ke===i?"bg-panel-h text-fg-2 shadow-[0_1px_2px_rgba(0,0,0,0.1),inset_0_1px_0_rgba(255,255,255,0.04)]":"text-fg-5/60 hover:text-fg-4"),children:l(`hub.filter${i[0].toUpperCase()+i.slice(1)}`)},i))})]}),e.jsx("div",{className:"flex-1 overflow-y-auto",children:j?e.jsx("div",{className:"flex items-center justify-center py-12",children:e.jsx(pe,{className:"h-4 w-4 text-fg-5"})}):d.length===0&&!de?e.jsx("div",{className:"py-12 text-center text-[13px] text-fg-5",children:l("hub.noWorkspaces")}):d.map(i=>e.jsx(Dr,{workspace:i,sessions:ct[i.path]||[],loading:!!v[i.path]||!(i.path in c),isActive:i.path===a,selectedKey:dt,openSessionKeys:Nt,onSelectSession:Be,onNewSession:Fe,onRefresh:rt,onRemove:ze,onExtensions:kt,onWarmSession:Ae,onCancelWarmSession:Re,onSessionMenuOpen:it,t:l},i.path))}),e.jsxs("div",{className:"shrink-0 border-t border-edge/20 px-3 py-2 space-y-1.5",children:[e.jsx("div",{className:"flex items-center rounded-md bg-inset/30 border border-edge/20 p-0.5",children:[1,2,3,6].map(i=>e.jsx("button",{onClick:()=>H(i),className:E("flex-1 flex items-center justify-center p-1.5 rounded transition-all",k===i?"bg-panel-h text-fg-2 shadow-[0_1px_2px_rgba(0,0,0,0.1)]":"text-fg-5/40 hover:text-fg-4"),title:l(`hub.layout${i}`),children:i===1?e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:e.jsx("rect",{x:"2",y:"2",width:"12",height:"12",rx:"1.5"})}):i===2?e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:[e.jsx("rect",{x:"1",y:"2",width:"6",height:"12",rx:"1.5"}),e.jsx("rect",{x:"9",y:"2",width:"6",height:"12",rx:"1.5"})]}):i===3?e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:[e.jsx("rect",{x:"0.5",y:"2",width:"4",height:"12",rx:"1"}),e.jsx("rect",{x:"6",y:"2",width:"4",height:"12",rx:"1"}),e.jsx("rect",{x:"11.5",y:"2",width:"4",height:"12",rx:"1"})]}):e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"none",stroke:"currentColor",strokeWidth:"1.2",children:[e.jsx("rect",{x:"0.5",y:"1",width:"4",height:"5.5",rx:"0.8"}),e.jsx("rect",{x:"6",y:"1",width:"4",height:"5.5",rx:"0.8"}),e.jsx("rect",{x:"11.5",y:"1",width:"4",height:"5.5",rx:"0.8"}),e.jsx("rect",{x:"0.5",y:"9.5",width:"4",height:"5.5",rx:"0.8"}),e.jsx("rect",{x:"6",y:"9.5",width:"4",height:"5.5",rx:"0.8"}),e.jsx("rect",{x:"11.5",y:"9.5",width:"4",height:"5.5",rx:"0.8"})]})},i))}),e.jsxs(Te,{variant:"ghost",size:"sm",onClick:()=>we(i=>!i),className:"w-full",children:[e.jsxs("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",children:[e.jsx("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),e.jsx("line",{x1:"5",y1:"12",x2:"19",y2:"12"})]}),l("hub.addWorkspace")]})]})]}),e.jsx("div",{className:"flex-1 min-w-0 flex flex-col overflow-hidden gap-0",children:e.jsx("div",{className:"flex-1 min-h-0 grid gap-3",style:{gridTemplateColumns:`repeat(${k===6?3:k}, 1fr)`,gridTemplateRows:k===6?"repeat(2, 1fr)":"1fr"},children:(()=>{const i=$?L.length<k?L.length:R:-1;return M.current=i,Array.from({length:k},(u,h)=>{if($&&h===i)return e.jsx("div",{className:"min-w-0 overflow-hidden rounded-xl border border-edge bg-panel flex flex-col",style:{boxShadow:"var(--th-card-shadow)"},children:e.jsx($r,{workdir:$,workspaceName:d.find(C=>C.path===$)?.name||$.split("/").pop()||"",onSessionCreated:at,onClose:()=>Fe(null),t:l},$)},`new-${$}`);const f=L[h]??null;if(!f)return e.jsx("div",{className:"min-w-0 overflow-hidden rounded-xl border border-dashed border-edge/40 bg-panel/30 flex items-center justify-center",children:e.jsxs("div",{className:"text-center px-4",children:[e.jsxs("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",className:"mx-auto text-fg-5/20 mb-2",children:[e.jsx("rect",{x:"3",y:"3",width:"18",height:"18",rx:"2"}),e.jsx("line",{x1:"12",y1:"8",x2:"12",y2:"16"}),e.jsx("line",{x1:"8",y1:"12",x2:"16",y2:"12"})]}),e.jsx("div",{className:"text-[12px] text-fg-5/40",children:l("hub.emptySlot")})]})},`empty-${h}`);const w=ge(f),y=h===R;return e.jsxs("div",{className:E("min-w-0 overflow-hidden rounded-xl border bg-panel flex flex-col transition-[border-color,box-shadow] duration-200",y?"border-primary/40 ring-[3px] ring-primary/[0.06]":"border-edge hover:border-edge-h"),style:{boxShadow:y?"var(--th-card-shadow), 0 0 0 1px rgba(14,165,233,0.08)":"var(--th-card-shadow)"},onClick:()=>A(h),children:[e.jsxs("div",{className:E("shrink-0 flex items-center gap-2 px-2.5 h-8 border-b border-edge/30",y?"bg-primary/[0.03]":"bg-panel/60"),children:[(()=>{const C=Rt(w);return e.jsx($t,{variant:C==="running"?"ok":C==="waiting"?"info":C==="incomplete"?"warn":"idle",pulse:C==="running"||C==="waiting"})})(),e.jsxs("div",{className:"flex-1 min-w-0 flex items-center gap-0",children:[e.jsx("span",{className:"shrink-0 text-[10px] font-medium text-fg-5",children:f.workdir.split("/").pop()||f.workdir}),e.jsx("span",{className:"shrink-0 text-fg-6 text-[10px] mx-1",children:"/"}),e.jsx("span",{className:"min-w-0 truncate text-[11px] font-medium text-fg-3",children:w.title||w.lastQuestion?.slice(0,60)||f.sessionId.slice(0,12)})]}),e.jsxs("div",{className:"shrink-0 flex items-center gap-2.5 pl-4 text-[9px] text-fg-5/50 tabular-nums",children:[e.jsx("span",{title:l("hub.created"),children:ps(w.createdAt)}),w.runUpdatedAt&&e.jsx("span",{title:l("hub.updated"),children:Cn(w.runUpdatedAt)}),!!w.numTurns&&e.jsxs("span",{className:"flex items-center gap-0.5",children:[e.jsx("svg",{width:"9",height:"9",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",className:"opacity-60",children:e.jsx("path",{d:"M21 15a2 2 0 01-2 2H7l-4 4V5a2 2 0 012-2h14a2 2 0 012 2z"})}),w.numTurns]}),e.jsx("button",{"data-filetree-toggle":!0,onClick:C=>{C.stopPropagation(),z(G=>!G)},className:E("p-0.5 rounded transition-colors",F?"text-fg-3 bg-panel-h":"text-fg-5/40 hover:text-fg-3 hover:bg-panel-h"),title:l("hub.files"),children:e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",children:e.jsx("path",{d:"M2 6a2 2 0 012-2h5l2 2h9a2 2 0 012 2v10a2 2 0 01-2 2H4a2 2 0 01-2-2V6z"})})}),e.jsx("button",{onClick:C=>{C.stopPropagation(),St(h)},className:"p-0.5 rounded text-fg-5/40 hover:text-fg-2 hover:bg-panel-h transition-colors",title:l("hub.closePanel"),children:e.jsxs("svg",{width:"9",height:"9",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",children:[e.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),e.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]})]}),e.jsx("div",{className:"flex-1 min-h-0",children:e.jsx(r.Suspense,{fallback:e.jsx("div",{className:"h-full"}),children:e.jsx(Tr,{session:w,workdir:f.workdir,active:n&&y,onSessionChange:C=>Ke(C,h),initialPendingPrompt:f.pendingPrompt??null,initialPendingImageUrls:f.pendingImageUrls,onPendingPromptConsumed:()=>Dt(f.mountKey)},f.mountKey)})})]},f.mountKey||U(f.agent,f.sessionId))})})()})}),F&&K&&e.jsx(Ur,{workdir:K.workdir,onClose:()=>z(!1),t:l}),e.jsx(Br,{open:de,initialPath:a||void 0,onAdd:re,onClose:()=>we(!1),t:l}),e.jsxs(Wt,{open:!!xe,onClose:()=>!oe&&Ne(null),children:[e.jsx(Bt,{title:l("hub.removeWorkspace"),onClose:()=>!oe&&Ne(null)}),e.jsx("div",{className:"text-[13px] text-fg-3 leading-relaxed",children:l("modal.confirmRemoveWorkspace")}),e.jsx("div",{className:"mt-1 text-[12px] text-fg-5",children:l("modal.confirmRemoveWorkspaceHint")}),xe&&e.jsx("div",{className:"mt-3 rounded-md bg-inset/50 border border-edge/30 px-3 py-2 font-mono text-[11px] text-fg-4 break-all",children:xe}),e.jsxs("div",{className:"flex justify-end gap-2 mt-4",children:[e.jsx(Te,{variant:"ghost",onClick:()=>Ne(null),disabled:oe,children:l("modal.cancel")}),e.jsx(Te,{variant:"primary",onClick:st,disabled:oe,className:"!bg-red-500/90 !border-red-500/50 hover:!bg-red-500 !text-white",children:l(oe?"modal.removing":"modal.remove")})]})]}),he&&(()=>{const u=Math.max(8,Math.min(he.anchor.right-160,window.innerWidth-160-8)),h=Math.min(he.anchor.bottom+4,window.innerHeight-60);return e.jsx("div",{className:"fixed z-[60] min-w-[160px] rounded-md border border-edge bg-panel/95 backdrop-blur-md py-1",style:{left:u,top:h,boxShadow:"0 8px 24px rgba(0,0,0,0.20), 0 2px 6px rgba(0,0,0,0.10)"},onMouseDown:f=>f.stopPropagation(),role:"menu",children:e.jsxs("button",{type:"button",role:"menuitem",onClick:()=>Ot(he.target),className:"w-full flex items-center gap-2 px-3 py-1.5 text-left text-[12px] text-fg-2 hover:bg-panel-h/60 hover:text-red-400 transition-colors",children:[e.jsxs("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("polyline",{points:"3 6 5 6 21 6"}),e.jsx("path",{d:"M19 6l-1 14a2 2 0 01-2 2H8a2 2 0 01-2-2L5 6"}),e.jsx("path",{d:"M10 11v6"}),e.jsx("path",{d:"M14 11v6"}),e.jsx("path",{d:"M9 6V4a2 2 0 012-2h2a2 2 0 012 2v2"})]}),l("session.delete")]})})})(),e.jsxs(Wt,{open:!!Se,onClose:()=>!ie&&V(null),children:[e.jsx(Bt,{title:l("session.deleteTitle"),onClose:()=>!ie&&V(null)}),e.jsx("div",{className:"text-[13px] text-fg-3 leading-relaxed",children:l("session.deleteHint")}),Se&&e.jsxs("div",{className:"mt-3 rounded-md bg-inset/50 border border-edge/30 px-3 py-2 text-[11px] text-fg-4 break-all",children:[e.jsx("span",{className:"font-mono text-fg-5",children:Se.agent}),e.jsx("span",{className:"mx-1.5 text-fg-5/50",children:"·"}),e.jsx("span",{children:Se.title})]}),e.jsxs("div",{className:"mt-4 space-y-2",children:[e.jsxs("label",{className:"flex items-start gap-2 cursor-pointer",children:[e.jsx("input",{type:"radio",name:"delete-session-scope",checked:!fe,onChange:()=>Ce(!1),disabled:ie,className:"mt-0.5"}),e.jsxs("div",{className:"flex-1",children:[e.jsx("div",{className:"text-[12px] text-fg-2",children:l("session.deletePikiloomOnly")}),e.jsx("div",{className:"text-[11px] text-fg-5 leading-snug mt-0.5",children:l("session.deletePikiloomOnlyHint")})]})]}),e.jsxs("label",{className:"flex items-start gap-2 cursor-pointer",children:[e.jsx("input",{type:"radio",name:"delete-session-scope",checked:fe,onChange:()=>Ce(!0),disabled:ie,className:"mt-0.5"}),e.jsxs("div",{className:"flex-1",children:[e.jsx("div",{className:"text-[12px] text-fg-2",children:l("session.deletePurgeNative")}),e.jsx("div",{className:"text-[11px] text-fg-5 leading-snug mt-0.5",children:l("session.deletePurgeNativeHint")})]})]})]}),e.jsxs("div",{className:"flex justify-end gap-2 mt-4",children:[e.jsx(Te,{variant:"ghost",onClick:()=>V(null),disabled:ie,children:l("modal.cancel")}),e.jsx(Te,{variant:"primary",onClick:yt,disabled:ie,className:"!bg-red-500/90 !border-red-500/50 hover:!bg-red-500 !text-white",children:l(ie?"session.deleting":"modal.remove")})]})]}),e.jsx(Cr,{open:!!nt,onClose:()=>kt(null),workdir:nt||""})]})});function Br({open:t,initialPath:n,onAdd:s,onClose:a,t:l}){const[d,p]=r.useState(""),c=r.useCallback(b=>p(b),[]);return r.useEffect(()=>{t&&p("")},[t]),e.jsxs(Wt,{open:t,onClose:a,children:[e.jsx(Bt,{title:l("hub.addWorkspace"),onClose:a}),e.jsx(ms,{initialPath:n,maxHeight:360,minHeight:200,onSelect:c,t:l}),e.jsxs("div",{className:"flex gap-2 mt-4",children:[e.jsx(Te,{disabled:!d,onClick:()=>d&&s(d),className:"flex-1",children:l("hub.add")}),e.jsx(Te,{variant:"secondary",onClick:a,className:"flex-1",children:l("hub.cancel")})]})]})}function $r({workdir:t,workspaceName:n,onSessionCreated:s,onClose:a,t:l}){const[d,p]=r.useState(null),[c,b]=r.useState([]),v=r.useRef(null),g=r.useRef([]),j=r.useMemo(()=>({sessionId:"",agent:"",runState:"completed"}),[]),T=r.useCallback(()=>{},[]),k=r.useCallback((S,R)=>{p(S||null),v.current=S||null;const D=R||[];b(D),g.current=D},[]),I=r.useCallback(S=>{const R=g.current;g.current=[],s(S,v.current||void 0,R.length?R:void 0)},[s]),L=!!d||c.length>0;return e.jsxs("div",{className:"flex flex-col h-full overflow-hidden",children:[e.jsxs("div",{className:"shrink-0 flex items-center gap-2 px-4 h-10 border-b border-edge/50 bg-panel/40 backdrop-blur-md z-10",children:[e.jsx("span",{className:"flex-1 min-w-0 text-[13px] font-medium text-fg truncate",children:l("hub.newSession")}),e.jsxs("span",{className:"flex items-center gap-1 text-[10px] text-fg-5/60 shrink-0",children:[e.jsx("svg",{width:"9",height:"9",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",className:"opacity-60",children:e.jsx("path",{d:"M22 19a2 2 0 01-2 2H4a2 2 0 01-2-2V5a2 2 0 012-2h5l2 3h9a2 2 0 012 2z"})}),e.jsx("span",{className:"max-w-[80px] truncate",children:n})]}),e.jsx($t,{variant:L?"ok":"idle",pulse:L}),!L&&e.jsx("button",{onClick:a,className:"p-1 rounded text-fg-5 hover:text-fg-2 transition-colors",children:e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[e.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),e.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]}),e.jsx("div",{className:"flex-1 overflow-y-auto",children:L?e.jsxs("div",{className:"max-w-[900px] mx-auto px-6 py-6 space-y-0",children:[e.jsx(Fn,{text:d||"",blocks:c.map(S=>({type:"image",content:S})),t:l}),e.jsx("div",{className:"mt-3 mb-4 animate-in",children:e.jsx(tn,{className:"text-fg-5"})})]}):e.jsx("div",{className:"flex items-center justify-center h-full",children:e.jsx("div",{className:"text-center space-y-1.5",children:e.jsx("div",{className:"text-[13px] text-fg-5",children:l("hub.newSessionHint")})})})}),e.jsx(Js,{session:j,workdir:t,onStreamQueued:T,onSendStart:k,onSessionChange:I,t:l,streamPhase:null})]})}function Or({git:t}){if(!t)return null;const n=[t.detached?`detached HEAD${t.shortSha?` @ ${t.shortSha}`:""}`:`branch ${t.branch??"?"}`,t.upstream?`upstream ${t.upstream}`:t.detached?"":"no upstream",t.ahead||t.behind?`↑${t.ahead} ahead · ↓${t.behind} behind`:"",t.changed>0?`${t.changed} changed (${t.staged} staged · ${t.unstaged} unstaged · ${t.untracked} untracked)`:"clean"].filter(Boolean).join(`
23
- `);return e.jsx(xs,{content:n,className:E("shrink-0 items-center",t.changed>0?"text-amber-400/80":t.ahead||t.behind?"text-sky-400/70":"text-fg-5/50"),onClick:s=>s.stopPropagation(),children:e.jsxs("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("circle",{cx:"6",cy:"6",r:"2.5"}),e.jsx("circle",{cx:"6",cy:"18",r:"2.5"}),e.jsx("circle",{cx:"18",cy:"8",r:"2.5"}),e.jsx("path",{d:"M6 8.5v7"}),e.jsx("path",{d:"M18 10.5c0 4.5-6 3-6 7.5"})]})})}const Dr=r.memo(function({workspace:n,sessions:s,loading:a,isActive:l,selectedKey:d,openSessionKeys:p,onSelectSession:c,onNewSession:b,onRefresh:v,onRemove:g,onExtensions:j,onWarmSession:T,onCancelWarmSession:k,onSessionMenuOpen:I,t:L}){const[S,R]=r.useState(!0),[D,H]=r.useState(Yt);r.useEffect(()=>{H(Yt)},[s.length]);const P=s.slice(0,D),A=s.length-D,F=n.path,[z,ae]=r.useState(null),ee=r.useCallback(()=>{J.getWorkspaceGit(F).then(M=>ae(M.git)).catch(()=>ae(null))},[F]);return r.useEffect(()=>{ee()},[ee]),e.jsxs("div",{className:"border-b border-edge/30",children:[e.jsxs("div",{className:"flex items-center gap-2 px-3 py-2 cursor-pointer hover:bg-panel-h/50 transition-colors",onClick:()=>R(M=>!M),children:[e.jsx("svg",{width:"9",height:"9",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",className:E("shrink-0 text-fg-5 transition-transform duration-150",S&&"rotate-90"),children:e.jsx("polyline",{points:"9 6 15 12 9 18"})}),e.jsxs("div",{className:"flex-1 min-w-0 flex items-center gap-1.5",children:[e.jsx("span",{className:E("min-w-0 truncate text-[12px] font-semibold",l?"text-primary":"text-fg-3"),children:n.name}),e.jsx(Or,{git:z})]}),l&&e.jsx($t,{variant:"ok"}),e.jsxs("div",{className:"flex items-center gap-1 shrink-0",children:[e.jsx("button",{onClick:M=>{M.stopPropagation(),b(F)},className:"p-1 rounded text-fg-5 hover:text-primary hover:bg-panel-h/60 transition-colors",title:L("hub.newSession"),children:e.jsxs("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",children:[e.jsx("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),e.jsx("line",{x1:"5",y1:"12",x2:"19",y2:"12"})]})}),e.jsx("button",{onClick:M=>{M.stopPropagation(),j(F)},className:"p-1 rounded text-fg-5 hover:text-primary hover:bg-panel-h/60 transition-colors",title:L("hub.extensions"),children:e.jsxs("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("path",{d:"M12 22v-5"}),e.jsx("path",{d:"M9 8V2"}),e.jsx("path",{d:"M15 8V2"}),e.jsx("path",{d:"M18 8v5a6 6 0 0 1-12 0V8z"})]})}),e.jsx("button",{onClick:M=>{M.stopPropagation(),v(F),ee()},className:"p-1 rounded text-fg-5 hover:text-fg-2 hover:bg-panel-h/60 transition-colors",children:e.jsxs("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",children:[e.jsx("polyline",{points:"23 4 23 10 17 10"}),e.jsx("path",{d:"M20.49 15a9 9 0 1 1-2.12-9.36L23 10"})]})}),!l&&e.jsx("button",{onClick:M=>{M.stopPropagation(),g(F)},className:"p-1 rounded text-fg-5 hover:text-red-400 hover:bg-panel-h/60 transition-colors",children:e.jsxs("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[e.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),e.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]})]}),S&&e.jsx("div",{className:"pb-1",children:a?e.jsx("div",{className:"flex items-center justify-center py-4",children:e.jsx(pe,{className:"h-3 w-3 text-fg-5"})}):s.length===0?e.jsx("div",{className:"py-3 text-center text-[11px] text-fg-5",children:L("sessions.noSessions")}):e.jsxs(e.Fragment,{children:[P.map(M=>{const K=U(M.agent||"",M.sessionId),Le=M.__forkDepth||0;return e.jsx(Fr,{session:M,isSelected:d===K,isOpen:p?.has(K)??!1,forkDepth:Le,onClick:()=>c(M,F),onWarm:()=>T(M,F),onCancelWarm:()=>k(M,F),onShowMenu:de=>I(de,M,F),menuLabel:L("session.openActions")},K)}),A>0&&e.jsxs("button",{onClick:()=>H(M=>M+Yt),className:"flex items-center gap-1.5 w-full px-3 py-1.5 text-[11px] text-fg-5 hover:text-fg-3 hover:bg-panel-h/50 transition-colors",children:[e.jsxs("span",{children:["+ ",L("hub.nMore").replace("{n}",String(A))]}),e.jsx("svg",{width:"8",height:"8",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:e.jsx("polyline",{points:"6 9 12 15 18 9"})})]})]})})]})}),Fr=r.memo(function({session:n,isSelected:s,isOpen:a,forkDepth:l=0,onClick:d,onWarm:p,onCancelWarm:c,onShowMenu:b,menuLabel:v}){const g=Zt(n.agent||""),j=Rt(n),T=Sn(n).slice(0,500)||n.sessionId.slice(0,16),k=fs(n,T).slice(0,500),I=n.model?rn(n.model):null,L=l>0?Math.min(l,3)*14:0,S=a?10:12,R=r.useRef(null);return e.jsxs("div",{className:"relative group",children:[e.jsxs("button",{onClick:d,onMouseEnter:p,onFocus:p,onMouseLeave:c,onBlur:c,className:E("w-full pr-3 py-2 text-left transition-all duration-100",s?"bg-selected hover:bg-selected-h":a?"bg-panel-h/30 hover:bg-panel-h/50":"hover:bg-panel-h/50"),style:{paddingLeft:S+L,...a?{borderLeft:`2px solid ${s?g.color:`${g.color}30`}`}:{}},children:[e.jsxs("div",{className:"flex items-center gap-1.5 text-[10px] text-fg-5",children:[l>0&&e.jsxs("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",className:"text-fg-5/60 shrink-0","aria-label":"Fork",children:[e.jsx("circle",{cx:"6",cy:"6",r:"2"}),e.jsx("circle",{cx:"18",cy:"6",r:"2"}),e.jsx("circle",{cx:"12",cy:"20",r:"2"}),e.jsx("path",{d:"M6 8v3a3 3 0 0 0 3 3h6a3 3 0 0 0 3-3V8"}),e.jsx("path",{d:"M12 14v4"})]}),e.jsx(Je,{brand:n.agent||"",size:10}),e.jsx("span",{className:"font-medium shrink-0",style:{color:g.color},children:g.shortLabel}),I&&e.jsx("span",{className:"truncate max-w-[72px] font-mono text-fg-5/40 text-[9px]",children:I}),e.jsxs("div",{className:"ml-auto flex items-center gap-1.5 shrink-0 transition-opacity group-hover:opacity-0 group-focus-within:opacity-0",children:[!!n.numTurns&&e.jsxs("span",{className:"flex items-center gap-0.5 text-fg-5/50 tabular-nums",children:[e.jsx("svg",{width:"9",height:"9",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",className:"opacity-50",children:e.jsx("path",{d:"M21 15a2 2 0 01-2 2H7l-4 4V5a2 2 0 012-2h14a2 2 0 012 2z"})}),n.numTurns]}),e.jsx("span",{className:"tabular-nums",children:Cn(n.runUpdatedAt||n.createdAt)})]})]}),e.jsxs("div",{className:"mt-1 flex items-center gap-1.5",children:[e.jsx($t,{variant:j==="running"?"ok":j==="waiting"?"info":j==="incomplete"?"warn":"idle",pulse:j==="running"||j==="waiting"}),e.jsx("span",{className:"truncate text-[12px] leading-snug text-fg-2",children:T})]}),k&&e.jsx("div",{className:"mt-0.5 pl-[11px]",children:e.jsx("span",{className:"block truncate text-[10px] leading-snug text-fg-5",children:k})})]}),e.jsx("button",{ref:R,type:"button","aria-label":v,"aria-haspopup":"menu",onMouseDown:D=>{D.stopPropagation()},onClick:D=>{D.stopPropagation(),D.preventDefault(),R.current&&b(R.current.getBoundingClientRect())},className:"absolute top-1.5 right-1.5 p-1 rounded text-fg-5 opacity-0 group-hover:opacity-100 focus-visible:opacity-100 hover:bg-panel-h hover:text-fg-2 transition-opacity",children:e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true",children:[e.jsx("circle",{cx:"12",cy:"5",r:"1.5"}),e.jsx("circle",{cx:"12",cy:"12",r:"1.5"}),e.jsx("circle",{cx:"12",cy:"19",r:"1.5"})]})})]})}),Ur=r.memo(function({workdir:n,onClose:s,t:a}){const l=je(g=>g.state?.hostApp??null),d=je(g=>g.state?.platform??null),p=je(g=>g.toast),[c,b]=r.useState(()=>Pr(l,d)),v=r.useCallback(async g=>{try{const j=await J.openInEditor(g,c);if(!j.ok)throw new Error(j.error||`Failed to open ${g}`)}catch(j){p(j?.message||String(j),!1)}},[c,p]);return e.jsxs("div",{className:"fixed z-50 w-[280px] max-h-[calc(100vh-100px)] flex flex-col rounded-xl border border-edge bg-panel/95 backdrop-blur-md overflow-hidden",style:{boxShadow:"0 8px 32px rgba(0,0,0,0.18), 0 2px 8px rgba(0,0,0,0.12)",right:16,top:80},children:[e.jsxs("div",{className:"shrink-0 flex items-center gap-1.5 px-2.5 py-1.5 border-b border-edge/30",children:[e.jsx("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",className:"shrink-0 text-fg-5",children:e.jsx("path",{d:"M2 6a2 2 0 012-2h5l2 2h9a2 2 0 012 2v10a2 2 0 01-2 2H4a2 2 0 01-2-2V6z"})}),e.jsx("span",{className:"flex-1 text-[10px] font-semibold text-fg-4 uppercase tracking-wider",children:a("hub.files")}),e.jsx("button",{onClick:s,className:"p-0.5 rounded text-fg-5/40 hover:text-fg-2 transition-colors",title:a("hub.closePanel"),children:e.jsxs("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",children:[e.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),e.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]}),e.jsxs("div",{className:"shrink-0 px-2.5 py-1.5 border-b border-edge/20 flex items-center gap-2",children:[e.jsx(gs,{value:c,options:(d==="darwin"?["vscode","finder"]:["vscode"]).map(g=>({value:g,label:a(Hn(g))})),onChange:g=>{_r(g)&&b(g)},renderIcon:g=>e.jsx(zn,{target:g,size:14})}),e.jsx(Te,{size:"sm",variant:"ghost",onClick:()=>v(n),className:"flex-1 min-w-0 text-[11px]",children:a("hub.openProject")})]}),e.jsx("div",{className:"flex-1 overflow-y-auto px-1 py-1.5",children:e.jsx(Hr,{basePath:n,openTarget:c,onOpenPath:v,t:a})})]})});function zn({target:t,size:n=16}){return t==="default"?e.jsxs("svg",{width:n,height:n,viewBox:"0 0 16 16",className:"shrink-0 text-fg-4",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("path",{d:"M6 3H4a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1v-2"}),e.jsx("path",{d:"M9 2h5v5"}),e.jsx("path",{d:"M14 2L7 9"})]}):e.jsx(Je,{brand:t,size:n})}function Hr({basePath:t,includeHidden:n=!1,openTarget:s,onOpenPath:a,t:l}){const[d,p]=r.useState([]),[c,b]=r.useState(!0);r.useEffect(()=>{let g=!1;return b(!0),J.lsDir(t,!0,n).then(j=>{!g&&j.ok&&p(j.dirs.slice(0,50).map(T=>({entry:T,expanded:!1,children:null,loading:!1})))}).catch(()=>{}).finally(()=>{g||b(!1)}),()=>{g=!0}},[t,n]);const v=r.useCallback(g=>{const j=T=>T.map(k=>k.entry.path===g?k.expanded?{...k,expanded:!1}:k.children===null?(J.lsDir(g,!0,n).then(I=>{I.ok&&p(L=>sn(L,g,{children:I.dirs.slice(0,50).map(S=>({entry:S,expanded:!1,children:null,loading:!1})),loading:!1}))}).catch(()=>{p(I=>sn(I,g,{children:[],loading:!1}))}),{...k,loading:!0,expanded:!0}):{...k,expanded:!0}:k.children?{...k,children:j(k.children)}:k);p(T=>j(T))},[n]);return c?e.jsx("div",{className:"flex justify-center py-3",children:e.jsx(pe,{className:"h-3 w-3 text-fg-5"})}):d.length===0?e.jsx("div",{className:"py-3 text-center text-[11px] text-fg-5",children:"—"}):e.jsx("div",{className:"space-y-px",children:e.jsx(Kn,{nodes:d,depth:0,onToggle:v,openTarget:s,onOpenPath:a,t:l})})}function Kn({nodes:t,depth:n,onToggle:s,openTarget:a,onOpenPath:l,t:d}){return e.jsx(e.Fragment,{children:t.map(p=>e.jsx(zr,{node:p,depth:n,onToggle:s,openTarget:a,onOpenPath:l,t:d},p.entry.path))})}function zr({node:t,depth:n,onToggle:s,openTarget:a,onOpenPath:l,t:d}){const{entry:p,expanded:c,children:b,loading:v}=t,g=n*14,[j,T]=r.useState(!1),k=d(Hn(a)),I=d("hub.openWithTarget").replace("{target}",k);return e.jsxs(e.Fragment,{children:[e.jsxs("div",{onClick:p.isDir?()=>s(p.path):void 0,onMouseEnter:()=>T(!0),onMouseLeave:()=>T(!1),className:E("flex items-center gap-1.5 py-1 rounded text-[11px] text-fg-3 transition-colors",p.isDir?"hover:bg-panel-h/50 cursor-pointer":"hover:bg-panel-h/50 cursor-default"),style:{paddingLeft:8+g,paddingRight:8},children:[p.isDir?v?e.jsx(pe,{className:"h-2 w-2 text-fg-5 shrink-0"}):e.jsx("svg",{width:"8",height:"8",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",className:E("shrink-0 text-fg-5/40 transition-transform duration-150",c&&"rotate-90"),children:e.jsx("polyline",{points:"9 6 15 12 9 18"})}):e.jsx("span",{className:"w-2 shrink-0"}),p.isDir?e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",className:"shrink-0 text-blue-400/70",children:e.jsx("path",{d:"M2 6a2 2 0 012-2h5l2 2h9a2 2 0 012 2v10a2 2 0 01-2 2H4a2 2 0 01-2-2V6z",fill:"currentColor",opacity:"0.25",stroke:"currentColor",strokeWidth:"1.5"})}):e.jsxs("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",className:"shrink-0 text-fg-5",children:[e.jsx("path",{d:"M14 2H6a2 2 0 00-2 2v16a2 2 0 002 2h12a2 2 0 002-2V8z"}),e.jsx("polyline",{points:"14 2 14 8 20 8"})]}),e.jsx("span",{className:"truncate flex-1",children:p.name}),j&&e.jsxs("div",{className:"flex items-center gap-0.5 shrink-0",children:[e.jsx("button",{onClick:L=>{L.stopPropagation(),l(p.path)},className:"inline-flex items-center gap-1 rounded px-1 py-0.5 text-fg-5 hover:text-blue-400 transition-colors",title:I,children:e.jsx(zn,{target:a,subtle:!0})}),!p.isDir&&e.jsx(Kr,{filePath:p.path,t:d})]})]}),p.isDir&&c&&b&&b.length>0&&e.jsx(Kn,{nodes:b,depth:n+1,onToggle:s,openTarget:a,onOpenPath:l,t:d})]})}function Kr({filePath:t,t:n}){const[s,a]=r.useState(!1);return e.jsx("button",{onClick:l=>{l.stopPropagation(),navigator.clipboard.writeText(t).then(()=>{a(!0),setTimeout(()=>a(!1),1500)}).catch(()=>{})},className:E("p-0.5 rounded transition-colors",s?"text-ok":"text-fg-5 hover:text-fg-3"),title:n("hub.copied"),children:s?e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",children:e.jsx("polyline",{points:"20 6 9 17 4 12"})}):e.jsxs("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:[e.jsx("rect",{x:"9",y:"9",width:"13",height:"13",rx:"2"}),e.jsx("path",{d:"M5 15H4a2 2 0 01-2-2V4a2 2 0 012-2h9a2 2 0 012 2v1"})]})})}function sn(t,n,s){return t.map(a=>a.entry.path===n?{...a,...s}:a.children?{...a,children:sn(a.children,n,s)}:a)}const io=Object.freeze(Object.defineProperty({__proto__:null,SessionWorkspace:Wr},Symbol.toStringTag,{value:"Module"}));export{Js as I,ro as L,rr as R,oo as T,Fn as U,to as a,Bn as b,Ws as c,tn as d,so as e,jr as f,io as i,Ts as l,no as m,eo as n,Cs as p,vn as u};
@@ -1 +0,0 @@
1
- @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial;--ambient-angle:0deg}}}@layer theme{:root,:host{--font-sans:"Geist", ui-sans-serif, system-ui, sans-serif;--font-mono:"Geist Mono", ui-monospace, monospace;--color-red-200:oklch(88.5% .062 18.334);--color-red-300:oklch(80.8% .114 19.571);--color-red-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-amber-100:oklch(96.2% .059 95.617);--color-amber-200:oklch(92.4% .12 95.746);--color-amber-300:oklch(87.9% .169 91.605);--color-amber-400:oklch(82.8% .189 84.429);--color-amber-500:oklch(76.9% .188 70.08);--color-amber-600:oklch(66.6% .179 58.318);--color-amber-700:oklch(55.5% .163 48.998);--color-emerald-200:oklch(90.5% .093 164.15);--color-emerald-300:oklch(84.5% .143 164.978);--color-emerald-400:oklch(76.5% .177 163.223);--color-emerald-500:oklch(69.6% .17 162.48);--color-emerald-700:oklch(50.8% .118 165.612);--color-cyan-400:oklch(78.9% .154 211.53);--color-sky-400:oklch(74.6% .16 232.661);--color-blue-300:oklch(80.9% .105 251.813);--color-blue-400:oklch(70.7% .165 254.624);--color-blue-500:oklch(62.3% .214 259.815);--color-indigo-500:oklch(58.5% .233 277.117);--color-violet-400:oklch(70.2% .183 293.541);--color-rose-200:oklch(89.2% .058 10.001);--color-rose-300:oklch(81% .117 11.638);--color-rose-400:oklch(71.2% .194 13.428);--color-rose-500:oklch(64.5% .246 16.439);--color-rose-700:oklch(51.4% .222 16.935);--color-rose-900:oklch(41% .159 10.272);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--container-3xl:48rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wide:.025em;--tracking-wider:.05em;--leading-tight:1.25;--leading-snug:1.375;--leading-relaxed:1.625;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-ping:ping 1s cubic-bezier(0, 0, .2, 1) infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--blur-sm:8px;--blur-md:12px;--blur-xl:24px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-surface:var(--th-surface);--color-foreground:var(--th-fg);--color-fg:var(--th-fg);--color-fg-2:var(--th-fg-2);--color-fg-3:var(--th-fg-3);--color-fg-4:var(--th-fg-4);--color-fg-5:var(--th-fg-5);--color-fg-6:var(--th-fg-6);--color-panel:var(--th-panel);--color-panel-h:var(--th-panel-h);--color-panel-alt:var(--th-panel-alt);--color-inset:var(--th-inset);--color-edge:var(--th-edge);--color-edge-h:var(--th-edge-h);--color-control:var(--th-control-bg);--color-control-h:var(--th-control-bg-h);--color-control-border:var(--th-control-border);--color-control-border-h:var(--th-control-border-h);--color-primary:var(--th-primary);--color-primary-fg:var(--th-primary-fg);--color-selected:var(--th-selected-bg);--color-selected-h:var(--th-selected-bg-h);--color-ok:var(--th-ok);--color-warn:var(--th-warn);--color-err:var(--th-err);--color-edge-strong:var(--edge-strong)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.\!visible{visibility:visible!important}.collapse{visibility:collapse}.invisible{visibility:hidden}.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-x-0{inset-inline:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.-top-1{top:calc(var(--spacing) * -1)}.-top-36{top:calc(var(--spacing) * -36)}.top-0{top:calc(var(--spacing) * 0)}.top-1\.5{top:calc(var(--spacing) * 1.5)}.top-1\/2{top:50%}.-right-1{right:calc(var(--spacing) * -1)}.right-0{right:calc(var(--spacing) * 0)}.right-1\.5{right:calc(var(--spacing) * 1.5)}.right-2{right:calc(var(--spacing) * 2)}.right-3{right:calc(var(--spacing) * 3)}.right-6{right:calc(var(--spacing) * 6)}.-bottom-40{bottom:calc(var(--spacing) * -40)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-6{bottom:calc(var(--spacing) * 6)}.bottom-full{bottom:100%}.-left-20{left:calc(var(--spacing) * -20)}.left-0{left:calc(var(--spacing) * 0)}.left-2\.5{left:calc(var(--spacing) * 2.5)}.left-3\.5{left:calc(var(--spacing) * 3.5)}.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.z-100{z-index:100}.z-200{z-index:200}.z-\[60\]{z-index:60}.z-\[200\]{z-index:200}.z-\[220\]{z-index:220}.z-\[240\]{z-index:240}.z-\[9999\]{z-index:9999}.order-3{order:3}.col-span-full{grid-column:1/-1}.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-1{margin-inline:calc(var(--spacing) * 1)}.mx-1\.5{margin-inline:calc(var(--spacing) * 1.5)}.mx-2{margin-inline:calc(var(--spacing) * 2)}.mx-auto{margin-inline:auto}.my-1\.5{margin-block:calc(var(--spacing) * 1.5)}.my-2{margin-block:calc(var(--spacing) * 2)}.my-3{margin-block:calc(var(--spacing) * 3)}.my-4{margin-block:calc(var(--spacing) * 4)}.-mt-0\.5{margin-top:calc(var(--spacing) * -.5)}.-mt-1{margin-top:calc(var(--spacing) * -1)}.mt-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-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-\[2px\]{margin-top:2px}.mt-\[5px\]{margin-top:5px}.mt-\[6px\]{margin-top:6px}.mt-\[10px\]{margin-top:10px}.mt-auto{margin-top:auto}.-mr-1{margin-right:calc(var(--spacing) * -1)}.mr-1{margin-right:calc(var(--spacing) * 1)}.mr-1\.5{margin-right:calc(var(--spacing) * 1.5)}.mr-2{margin-right:calc(var(--spacing) * 2)}.\!mb-1{margin-bottom:calc(var(--spacing) * 1)!important}.mb-0{margin-bottom:calc(var(--spacing) * 0)}.mb-0\.5{margin-bottom:calc(var(--spacing) * .5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.ml-0\.5{margin-left:calc(var(--spacing) * .5)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-2\.5{margin-left:calc(var(--spacing) * 2.5)}.ml-3{margin-left:calc(var(--spacing) * 3)}.ml-auto{margin-left:auto}.line-clamp-1{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.line-clamp-3{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.\!h-7{height:calc(var(--spacing) * 7)!important}.h-1{height:calc(var(--spacing) * 1)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-3{height:calc(var(--spacing) * 3)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-56{height:calc(var(--spacing) * 56)}.h-\[3px\]{height:3px}.h-\[5px\]{height:5px}.h-\[6px\]{height:6px}.h-\[7px\]{height:7px}.h-\[18px\]{height:18px}.h-\[22px\]{height:22px}.h-\[28px\]{height:28px}.h-\[30px\]{height:30px}.h-\[68px\]{height:68px}.h-\[72px\]{height:72px}.h-\[104px\]{height:104px}.h-\[120px\]{height:120px}.h-\[360px\]{height:360px}.h-\[420px\]{height:420px}.h-full{height:100%}.h-screen{height:100vh}.max-h-\[40vh\]{max-height:40vh}.max-h-\[60vh\]{max-height:60vh}.max-h-\[80vh\]{max-height:80vh}.max-h-\[90vh\]{max-height:90vh}.max-h-\[140px\]{max-height:140px}.max-h-\[200px\]{max-height:200px}.max-h-\[240px\]{max-height:240px}.max-h-\[260px\]{max-height:260px}.max-h-\[280px\]{max-height:280px}.max-h-\[300px\]{max-height:300px}.max-h-\[320px\]{max-height:320px}.max-h-\[calc\(100vh-100px\)\]{max-height:calc(100vh - 100px)}.max-h-\[inherit\]{max-height:inherit}.max-h-\[min\(88vh\,860px\)\]{max-height:min(88vh,860px)}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-13{min-height:calc(var(--spacing) * 13)}.min-h-\[64px\]{min-height:64px}.min-h-\[112px\]{min-height:112px}.min-h-\[120px\]{min-height:120px}.\!w-\[34px\]{width:34px!important}.w-1{width:calc(var(--spacing) * 1)}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2{width:calc(var(--spacing) * 2)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-2\/3{width:66.6667%}.w-2\/5{width:40%}.w-3{width:calc(var(--spacing) * 3)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-10{width:calc(var(--spacing) * 10)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-16{width:calc(var(--spacing) * 16)}.w-24{width:calc(var(--spacing) * 24)}.w-28{width:calc(var(--spacing) * 28)}.w-52{width:calc(var(--spacing) * 52)}.w-56{width:calc(var(--spacing) * 56)}.w-\[5px\]{width:5px}.w-\[6px\]{width:6px}.w-\[7px\]{width:7px}.w-\[10px\]{width:10px}.w-\[30px\]{width:30px}.w-\[72px\]{width:72px}.w-\[252px\]{width:252px}.w-\[280px\]{width:280px}.w-\[300px\]{width:300px}.w-\[360px\]{width:360px}.w-\[420px\]{width:420px}.w-auto{width:auto}.w-fit{width:fit-content}.w-full{width:100%}.max-w-3xl{max-width:var(--container-3xl)}.max-w-\[72\%\]{max-width:72%}.max-w-\[72px\]{max-width:72px}.max-w-\[80px\]{max-width:80px}.max-w-\[90vw\]{max-width:90vw}.max-w-\[140px\]{max-width:140px}.max-w-\[280px\]{max-width:280px}.max-w-\[340px\]{max-width:340px}.max-w-\[400px\]{max-width:400px}.max-w-\[420px\]{max-width:420px}.max-w-\[460px\]{max-width:460px}.max-w-\[480px\]{max-width:480px}.max-w-\[640px\]{max-width:640px}.max-w-\[680px\]{max-width:680px}.max-w-\[760px\]{max-width:760px}.max-w-\[840px\]{max-width:840px}.max-w-\[900px\]{max-width:900px}.max-w-\[1024px\]{max-width:1024px}.max-w-\[1120px\]{max-width:1120px}.max-w-\[1180px\]{max-width:1180px}.max-w-full{max-width:100%}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-4{min-width:calc(var(--spacing) * 4)}.min-w-\[160px\]{min-width:160px}.min-w-\[200px\]{min-width:200px}.flex-1{flex:1}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.-translate-y-1{--tw-translate-y:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-0{--tw-translate-y:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-90{rotate:90deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-ping{animation:var(--animate-ping)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.cursor-zoom-in{cursor:zoom-in}.cursor-zoom-out{cursor:zoom-out}.resize{resize:both}.resize-none{resize:none}.resize-y{resize:vertical}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-\[80px_auto_1fr\]{grid-template-columns:80px auto 1fr}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-0{gap:calc(var(--spacing) * 0)}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-\[3px\]{gap:3px}:where(.space-y-0>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 0) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 0) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-0\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * .5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * .5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-7>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 7) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 7) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-px>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(1px * var(--tw-space-y-reverse));margin-block-end:calc(1px * calc(1 - var(--tw-space-y-reverse)))}.gap-x-2{column-gap:calc(var(--spacing) * 2)}.gap-x-3{column-gap:calc(var(--spacing) * 3)}.gap-x-4{column-gap:calc(var(--spacing) * 4)}.gap-x-5{column-gap:calc(var(--spacing) * 5)}.gap-y-0\.5{row-gap:calc(var(--spacing) * .5)}.gap-y-1\.5{row-gap:calc(var(--spacing) * 1.5)}.gap-y-2{row-gap:calc(var(--spacing) * 2)}.self-start{align-self:flex-start}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overscroll-contain{overscroll-behavior:contain}.scroll-smooth{scroll-behavior:smooth}.rounded{border-radius:.25rem}.rounded-\[2px\]{border-radius:2px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-t-lg{border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg)}.rounded-b-lg{border-bottom-right-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.\!border-red-500\/50{border-color:#fb2c3680!important}@supports (color:color-mix(in lab,red,red)){.\!border-red-500\/50{border-color:color-mix(in oklab,var(--color-red-500) 50%,transparent)!important}}.border-\[var\(--edge-default\)\]{border-color:var(--edge-default)}.border-\[var\(--edge-strong\)\]{border-color:var(--edge-strong)}.border-\[var\(--edge-subtle\)\]{border-color:var(--edge-subtle)}.border-\[var\(--th-badge-err-border\)\]{border-color:var(--th-badge-err-border)}.border-\[var\(--th-badge-info-border\)\]{border-color:var(--th-badge-info-border)}.border-\[var\(--th-badge-ok-border\)\]{border-color:var(--th-badge-ok-border)}.border-\[var\(--th-badge-running-border\)\]{border-color:var(--th-badge-running-border)}.border-\[var\(--th-badge-warn-border\)\]{border-color:var(--th-badge-warn-border)}.border-amber-400\/10{border-color:#fcbb001a}@supports (color:color-mix(in lab,red,red)){.border-amber-400\/10{border-color:color-mix(in oklab,var(--color-amber-400) 10%,transparent)}}.border-amber-500\/20{border-color:#f99c0033}@supports (color:color-mix(in lab,red,red)){.border-amber-500\/20{border-color:color-mix(in oklab,var(--color-amber-500) 20%,transparent)}}.border-amber-500\/30{border-color:#f99c004d}@supports (color:color-mix(in lab,red,red)){.border-amber-500\/30{border-color:color-mix(in oklab,var(--color-amber-500) 30%,transparent)}}.border-blue-400\/12{border-color:#54a2ff1f}@supports (color:color-mix(in lab,red,red)){.border-blue-400\/12{border-color:color-mix(in oklab,var(--color-blue-400) 12%,transparent)}}.border-control-border{border-color:var(--color-control-border)}.border-control-border-h{border-color:var(--color-control-border-h)}.border-edge{border-color:var(--color-edge)}.border-edge-h{border-color:var(--color-edge-h)}.border-edge\/12{border-color:var(--color-edge)}@supports (color:color-mix(in lab,red,red)){.border-edge\/12{border-color:color-mix(in oklab,var(--color-edge) 12%,transparent)}}.border-edge\/15{border-color:var(--color-edge)}@supports (color:color-mix(in lab,red,red)){.border-edge\/15{border-color:color-mix(in oklab,var(--color-edge) 15%,transparent)}}.border-edge\/20{border-color:var(--color-edge)}@supports (color:color-mix(in lab,red,red)){.border-edge\/20{border-color:color-mix(in oklab,var(--color-edge) 20%,transparent)}}.border-edge\/30{border-color:var(--color-edge)}@supports (color:color-mix(in lab,red,red)){.border-edge\/30{border-color:color-mix(in oklab,var(--color-edge) 30%,transparent)}}.border-edge\/40{border-color:var(--color-edge)}@supports (color:color-mix(in lab,red,red)){.border-edge\/40{border-color:color-mix(in oklab,var(--color-edge) 40%,transparent)}}.border-edge\/50{border-color:var(--color-edge)}@supports (color:color-mix(in lab,red,red)){.border-edge\/50{border-color:color-mix(in oklab,var(--color-edge) 50%,transparent)}}.border-edge\/60{border-color:var(--color-edge)}@supports (color:color-mix(in lab,red,red)){.border-edge\/60{border-color:color-mix(in oklab,var(--color-edge) 60%,transparent)}}.border-edge\/70{border-color:var(--color-edge)}@supports (color:color-mix(in lab,red,red)){.border-edge\/70{border-color:color-mix(in oklab,var(--color-edge) 70%,transparent)}}.border-emerald-500\/20{border-color:#00bb7f33}@supports (color:color-mix(in lab,red,red)){.border-emerald-500\/20{border-color:color-mix(in oklab,var(--color-emerald-500) 20%,transparent)}}.border-emerald-700\/20{border-color:#00795633}@supports (color:color-mix(in lab,red,red)){.border-emerald-700\/20{border-color:color-mix(in oklab,var(--color-emerald-700) 20%,transparent)}}.border-fg-5\/30{border-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.border-fg-5\/30{border-color:color-mix(in oklab,var(--color-fg-5) 30%,transparent)}}.border-fg-6,.border-fg-6\/30{border-color:var(--color-fg-6)}@supports (color:color-mix(in lab,red,red)){.border-fg-6\/30{border-color:color-mix(in oklab,var(--color-fg-6) 30%,transparent)}}.border-fg-6\/40{border-color:var(--color-fg-6)}@supports (color:color-mix(in lab,red,red)){.border-fg-6\/40{border-color:color-mix(in oklab,var(--color-fg-6) 40%,transparent)}}.border-fg-6\/50{border-color:var(--color-fg-6)}@supports (color:color-mix(in lab,red,red)){.border-fg-6\/50{border-color:color-mix(in oklab,var(--color-fg-6) 50%,transparent)}}.border-indigo-500\/10{border-color:#625fff1a}@supports (color:color-mix(in lab,red,red)){.border-indigo-500\/10{border-color:color-mix(in oklab,var(--color-indigo-500) 10%,transparent)}}.border-ok\/20{border-color:var(--color-ok)}@supports (color:color-mix(in lab,red,red)){.border-ok\/20{border-color:color-mix(in oklab,var(--color-ok) 20%,transparent)}}.border-primary\/20{border-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.border-primary\/20{border-color:color-mix(in oklab,var(--color-primary) 20%,transparent)}}.border-primary\/40{border-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.border-primary\/40{border-color:color-mix(in oklab,var(--color-primary) 40%,transparent)}}.border-red-300\/40{border-color:#ffa3a366}@supports (color:color-mix(in lab,red,red)){.border-red-300\/40{border-color:color-mix(in oklab,var(--color-red-300) 40%,transparent)}}.border-red-500\/20{border-color:#fb2c3633}@supports (color:color-mix(in lab,red,red)){.border-red-500\/20{border-color:color-mix(in oklab,var(--color-red-500) 20%,transparent)}}.border-rose-700\/40{border-color:#c2003966}@supports (color:color-mix(in lab,red,red)){.border-rose-700\/40{border-color:color-mix(in oklab,var(--color-rose-700) 40%,transparent)}}.border-transparent{border-color:#0000}.border-warn\/25{border-color:var(--color-warn)}@supports (color:color-mix(in lab,red,red)){.border-warn\/25{border-color:color-mix(in oklab,var(--color-warn) 25%,transparent)}}.border-warn\/30{border-color:var(--color-warn)}@supports (color:color-mix(in lab,red,red)){.border-warn\/30{border-color:color-mix(in oklab,var(--color-warn) 30%,transparent)}}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.border-white\/10{border-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.border-white\/12{border-color:#ffffff1f}@supports (color:color-mix(in lab,red,red)){.border-white\/12{border-color:color-mix(in oklab,var(--color-white) 12%,transparent)}}.border-white\/\[0\.04\]{border-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.04\]{border-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.border-white\/\[0\.06\]{border-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.06\]{border-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.\!bg-red-500\/90{background-color:#fb2c36e6!important}@supports (color:color-mix(in lab,red,red)){.\!bg-red-500\/90{background-color:color-mix(in oklab,var(--color-red-500) 90%,transparent)!important}}.bg-\[\#0b0f16\]{background-color:#0b0f16}.bg-\[rgba\(0\,0\,0\,0\.1\)\]{background-color:#0000001a}.bg-\[rgba\(0\,0\,0\,0\.12\)\]{background-color:#0000001f}.bg-\[rgba\(0\,0\,0\,0\.25\)\]{background-color:#00000040}.bg-\[rgba\(255\,255\,255\,0\.02\)\]{background-color:#ffffff05}.bg-\[rgba\(255\,255\,255\,0\.06\)\]{background-color:#ffffff0f}.bg-\[var\(--brand-accent\)\]{background-color:var(--brand-accent)}.bg-\[var\(--surface-1\)\]{background-color:var(--surface-1)}.bg-\[var\(--surface-2\)\],.bg-\[var\(--surface-2\)\]\/60{background-color:var(--surface-2)}@supports (color:color-mix(in lab,red,red)){.bg-\[var\(--surface-2\)\]\/60{background-color:color-mix(in oklab,var(--surface-2) 60%,transparent)}}.bg-\[var\(--surface-elev\)\]{background-color:var(--surface-elev)}.bg-\[var\(--th-accent\,\#7c3aed\)\]{background-color:var(--th-accent,#7c3aed)}.bg-\[var\(--th-badge-accent-bg\)\]{background-color:var(--th-badge-accent-bg)}.bg-\[var\(--th-badge-err-bg\)\]{background-color:var(--th-badge-err-bg)}.bg-\[var\(--th-badge-info-bg\)\]{background-color:var(--th-badge-info-bg)}.bg-\[var\(--th-badge-ok-bg\)\]{background-color:var(--th-badge-ok-bg)}.bg-\[var\(--th-badge-running-bg\)\]{background-color:var(--th-badge-running-bg)}.bg-\[var\(--th-badge-warn-bg\)\]{background-color:var(--th-badge-warn-bg)}.bg-\[var\(--th-bg\)\]\/80{background-color:var(--th-bg)}@supports (color:color-mix(in lab,red,red)){.bg-\[var\(--th-bg\)\]\/80{background-color:color-mix(in oklab,var(--th-bg) 80%,transparent)}}.bg-\[var\(--th-dropdown\)\]{background-color:var(--th-dropdown)}.bg-\[var\(--th-err\)\]{background-color:var(--th-err)}.bg-\[var\(--th-info\)\]{background-color:var(--th-info)}.bg-\[var\(--th-ok\)\]{background-color:var(--th-ok)}.bg-\[var\(--th-running\)\]{background-color:var(--th-running)}.bg-\[var\(--th-sidebar\)\]{background-color:var(--th-sidebar)}.bg-\[var\(--th-warn\)\]{background-color:var(--th-warn)}.bg-amber-400\/60{background-color:#fcbb0099}@supports (color:color-mix(in lab,red,red)){.bg-amber-400\/60{background-color:color-mix(in oklab,var(--color-amber-400) 60%,transparent)}}.bg-amber-400\/70{background-color:#fcbb00b3}@supports (color:color-mix(in lab,red,red)){.bg-amber-400\/70{background-color:color-mix(in oklab,var(--color-amber-400) 70%,transparent)}}.bg-amber-500{background-color:var(--color-amber-500)}.bg-amber-500\/5{background-color:#f99c000d}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/5{background-color:color-mix(in oklab,var(--color-amber-500) 5%,transparent)}}.bg-amber-500\/8{background-color:#f99c0014}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/8{background-color:color-mix(in oklab,var(--color-amber-500) 8%,transparent)}}.bg-amber-500\/10{background-color:#f99c001a}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/10{background-color:color-mix(in oklab,var(--color-amber-500) 10%,transparent)}}.bg-amber-500\/\[0\.06\]{background-color:#f99c000f}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/\[0\.06\]{background-color:color-mix(in oklab,var(--color-amber-500) 6%,transparent)}}.bg-black\/35{background-color:#00000059}@supports (color:color-mix(in lab,red,red)){.bg-black\/35{background-color:color-mix(in oklab,var(--color-black) 35%,transparent)}}.bg-black\/65{background-color:#000000a6}@supports (color:color-mix(in lab,red,red)){.bg-black\/65{background-color:color-mix(in oklab,var(--color-black) 65%,transparent)}}.bg-black\/72{background-color:#000000b8}@supports (color:color-mix(in lab,red,red)){.bg-black\/72{background-color:color-mix(in oklab,var(--color-black) 72%,transparent)}}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:color-mix(in oklab,var(--color-black) 80%,transparent)}}.bg-blue-500\/8{background-color:#3080ff14}@supports (color:color-mix(in lab,red,red)){.bg-blue-500\/8{background-color:color-mix(in oklab,var(--color-blue-500) 8%,transparent)}}.bg-control{background-color:var(--color-control)}.bg-control-h{background-color:var(--color-control-h)}.bg-cyan-400{background-color:var(--color-cyan-400)}.bg-cyan-400\/40{background-color:#00d2ef66}@supports (color:color-mix(in lab,red,red)){.bg-cyan-400\/40{background-color:color-mix(in oklab,var(--color-cyan-400) 40%,transparent)}}.bg-cyan-400\/60{background-color:#00d2ef99}@supports (color:color-mix(in lab,red,red)){.bg-cyan-400\/60{background-color:color-mix(in oklab,var(--color-cyan-400) 60%,transparent)}}.bg-cyan-400\/70{background-color:#00d2efb3}@supports (color:color-mix(in lab,red,red)){.bg-cyan-400\/70{background-color:color-mix(in oklab,var(--color-cyan-400) 70%,transparent)}}.bg-cyan-400\/80{background-color:#00d2efcc}@supports (color:color-mix(in lab,red,red)){.bg-cyan-400\/80{background-color:color-mix(in oklab,var(--color-cyan-400) 80%,transparent)}}.bg-emerald-400\/55{background-color:#00d2948c}@supports (color:color-mix(in lab,red,red)){.bg-emerald-400\/55{background-color:color-mix(in oklab,var(--color-emerald-400) 55%,transparent)}}.bg-emerald-400\/60{background-color:#00d29499}@supports (color:color-mix(in lab,red,red)){.bg-emerald-400\/60{background-color:color-mix(in oklab,var(--color-emerald-400) 60%,transparent)}}.bg-emerald-400\/70{background-color:#00d294b3}@supports (color:color-mix(in lab,red,red)){.bg-emerald-400\/70{background-color:color-mix(in oklab,var(--color-emerald-400) 70%,transparent)}}.bg-emerald-500{background-color:var(--color-emerald-500)}.bg-emerald-500\/10{background-color:#00bb7f1a}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/10{background-color:color-mix(in oklab,var(--color-emerald-500) 10%,transparent)}}.bg-emerald-700\/5{background-color:#0079560d}@supports (color:color-mix(in lab,red,red)){.bg-emerald-700\/5{background-color:color-mix(in oklab,var(--color-emerald-700) 5%,transparent)}}.bg-fg-5,.bg-fg-5\/8{background-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.bg-fg-5\/8{background-color:color-mix(in oklab,var(--color-fg-5) 8%,transparent)}}.bg-fg-5\/15{background-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.bg-fg-5\/15{background-color:color-mix(in oklab,var(--color-fg-5) 15%,transparent)}}.bg-fg-5\/25{background-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.bg-fg-5\/25{background-color:color-mix(in oklab,var(--color-fg-5) 25%,transparent)}}.bg-fg-5\/30{background-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.bg-fg-5\/30{background-color:color-mix(in oklab,var(--color-fg-5) 30%,transparent)}}.bg-fg-5\/35{background-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.bg-fg-5\/35{background-color:color-mix(in oklab,var(--color-fg-5) 35%,transparent)}}.bg-fg-5\/40{background-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.bg-fg-5\/40{background-color:color-mix(in oklab,var(--color-fg-5) 40%,transparent)}}.bg-fg-5\/45{background-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.bg-fg-5\/45{background-color:color-mix(in oklab,var(--color-fg-5) 45%,transparent)}}.bg-fg-5\/50{background-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.bg-fg-5\/50{background-color:color-mix(in oklab,var(--color-fg-5) 50%,transparent)}}.bg-fg-6,.bg-fg-6\/\[0\.05\]{background-color:var(--color-fg-6)}@supports (color:color-mix(in lab,red,red)){.bg-fg-6\/\[0\.05\]{background-color:color-mix(in oklab,var(--color-fg-6) 5%,transparent)}}.bg-fg-6\/\[0\.06\]{background-color:var(--color-fg-6)}@supports (color:color-mix(in lab,red,red)){.bg-fg-6\/\[0\.06\]{background-color:color-mix(in oklab,var(--color-fg-6) 6%,transparent)}}.bg-fg\/6{background-color:var(--color-fg)}@supports (color:color-mix(in lab,red,red)){.bg-fg\/6{background-color:color-mix(in oklab,var(--color-fg) 6%,transparent)}}.bg-fg\/10{background-color:var(--color-fg)}@supports (color:color-mix(in lab,red,red)){.bg-fg\/10{background-color:color-mix(in oklab,var(--color-fg) 10%,transparent)}}.bg-indigo-500\/\[0\.06\]{background-color:#625fff0f}@supports (color:color-mix(in lab,red,red)){.bg-indigo-500\/\[0\.06\]{background-color:color-mix(in oklab,var(--color-indigo-500) 6%,transparent)}}.bg-inset,.bg-inset\/30{background-color:var(--color-inset)}@supports (color:color-mix(in lab,red,red)){.bg-inset\/30{background-color:color-mix(in oklab,var(--color-inset) 30%,transparent)}}.bg-inset\/40{background-color:var(--color-inset)}@supports (color:color-mix(in lab,red,red)){.bg-inset\/40{background-color:color-mix(in oklab,var(--color-inset) 40%,transparent)}}.bg-inset\/50{background-color:var(--color-inset)}@supports (color:color-mix(in lab,red,red)){.bg-inset\/50{background-color:color-mix(in oklab,var(--color-inset) 50%,transparent)}}.bg-inset\/60{background-color:var(--color-inset)}@supports (color:color-mix(in lab,red,red)){.bg-inset\/60{background-color:color-mix(in oklab,var(--color-inset) 60%,transparent)}}.bg-inset\/70{background-color:var(--color-inset)}@supports (color:color-mix(in lab,red,red)){.bg-inset\/70{background-color:color-mix(in oklab,var(--color-inset) 70%,transparent)}}.bg-ok\/40{background-color:var(--color-ok)}@supports (color:color-mix(in lab,red,red)){.bg-ok\/40{background-color:color-mix(in oklab,var(--color-ok) 40%,transparent)}}.bg-panel{background-color:var(--color-panel)}.bg-panel-alt,.bg-panel-alt\/30{background-color:var(--color-panel-alt)}@supports (color:color-mix(in lab,red,red)){.bg-panel-alt\/30{background-color:color-mix(in oklab,var(--color-panel-alt) 30%,transparent)}}.bg-panel-alt\/40{background-color:var(--color-panel-alt)}@supports (color:color-mix(in lab,red,red)){.bg-panel-alt\/40{background-color:color-mix(in oklab,var(--color-panel-alt) 40%,transparent)}}.bg-panel-h,.bg-panel-h\/30{background-color:var(--color-panel-h)}@supports (color:color-mix(in lab,red,red)){.bg-panel-h\/30{background-color:color-mix(in oklab,var(--color-panel-h) 30%,transparent)}}.bg-panel\/30{background-color:var(--color-panel)}@supports (color:color-mix(in lab,red,red)){.bg-panel\/30{background-color:color-mix(in oklab,var(--color-panel) 30%,transparent)}}.bg-panel\/40{background-color:var(--color-panel)}@supports (color:color-mix(in lab,red,red)){.bg-panel\/40{background-color:color-mix(in oklab,var(--color-panel) 40%,transparent)}}.bg-panel\/60{background-color:var(--color-panel)}@supports (color:color-mix(in lab,red,red)){.bg-panel\/60{background-color:color-mix(in oklab,var(--color-panel) 60%,transparent)}}.bg-panel\/80{background-color:var(--color-panel)}@supports (color:color-mix(in lab,red,red)){.bg-panel\/80{background-color:color-mix(in oklab,var(--color-panel) 80%,transparent)}}.bg-panel\/95{background-color:var(--color-panel)}@supports (color:color-mix(in lab,red,red)){.bg-panel\/95{background-color:color-mix(in oklab,var(--color-panel) 95%,transparent)}}.bg-primary,.bg-primary\/10{background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/10{background-color:color-mix(in oklab,var(--color-primary) 10%,transparent)}}.bg-primary\/12{background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/12{background-color:color-mix(in oklab,var(--color-primary) 12%,transparent)}}.bg-primary\/40{background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/40{background-color:color-mix(in oklab,var(--color-primary) 40%,transparent)}}.bg-primary\/\[0\.03\]{background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/\[0\.03\]{background-color:color-mix(in oklab,var(--color-primary) 3%,transparent)}}.bg-primary\/\[0\.04\]{background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/\[0\.04\]{background-color:color-mix(in oklab,var(--color-primary) 4%,transparent)}}.bg-red-500{background-color:var(--color-red-500)}.bg-red-500\/10{background-color:#fb2c361a}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/10{background-color:color-mix(in oklab,var(--color-red-500) 10%,transparent)}}.bg-rose-400\/55{background-color:#ff667f8c}@supports (color:color-mix(in lab,red,red)){.bg-rose-400\/55{background-color:color-mix(in oklab,var(--color-rose-400) 55%,transparent)}}.bg-rose-400\/60{background-color:#ff667f99}@supports (color:color-mix(in lab,red,red)){.bg-rose-400\/60{background-color:color-mix(in oklab,var(--color-rose-400) 60%,transparent)}}.bg-rose-400\/70{background-color:#ff667fb3}@supports (color:color-mix(in lab,red,red)){.bg-rose-400\/70{background-color:color-mix(in oklab,var(--color-rose-400) 70%,transparent)}}.bg-rose-500{background-color:var(--color-rose-500)}.bg-rose-900\/20{background-color:#8b083633}@supports (color:color-mix(in lab,red,red)){.bg-rose-900\/20{background-color:color-mix(in oklab,var(--color-rose-900) 20%,transparent)}}.bg-selected{background-color:var(--color-selected)}.bg-transparent{background-color:#0000}.bg-violet-400\/50{background-color:#a685ff80}@supports (color:color-mix(in lab,red,red)){.bg-violet-400\/50{background-color:color-mix(in oklab,var(--color-violet-400) 50%,transparent)}}.bg-warn,.bg-warn\/\[0\.04\]{background-color:var(--color-warn)}@supports (color:color-mix(in lab,red,red)){.bg-warn\/\[0\.04\]{background-color:color-mix(in oklab,var(--color-warn) 4%,transparent)}}.bg-white{background-color:var(--color-white)}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.bg-gradient-to-t{--tw-gradient-position:to top in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-black\/60{--tw-gradient-from:#0009}@supports (color:color-mix(in lab,red,red)){.from-black\/60{--tw-gradient-from:color-mix(in oklab, var(--color-black) 60%, transparent)}}.from-black\/60{--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-black\/10{--tw-gradient-via:#0000001a}@supports (color:color-mix(in lab,red,red)){.via-black\/10{--tw-gradient-via:color-mix(in oklab, var(--color-black) 10%, transparent)}}.via-black\/10{--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-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))}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.\!p-0{padding:calc(var(--spacing) * 0)!important}.\!p-3\.5{padding:calc(var(--spacing) * 3.5)!important}.\!p-4{padding:calc(var(--spacing) * 4)!important}.p-0{padding:calc(var(--spacing) * 0)}.p-0\.5{padding:calc(var(--spacing) * .5)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-2\.5{padding:calc(var(--spacing) * 2.5)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.\!px-1\.5{padding-inline:calc(var(--spacing) * 1.5)!important}.px-0\.5{padding-inline:calc(var(--spacing) * .5)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-3\.5{padding-inline:calc(var(--spacing) * 3.5)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.\!py-0{padding-block:calc(var(--spacing) * 0)!important}.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-3\.5{padding-block:calc(var(--spacing) * 3.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-10{padding-block:calc(var(--spacing) * 10)}.py-12{padding-block:calc(var(--spacing) * 12)}.py-20{padding-block:calc(var(--spacing) * 20)}.py-\[1px\]{padding-block:1px}.py-\[2px\]{padding-block:2px}.py-\[3px\]{padding-block:3px}.py-\[5px\]{padding-block:5px}.py-\[7px\]{padding-block:7px}.py-px{padding-block:1px}.pt-0\.5{padding-top:calc(var(--spacing) * .5)}.pt-1{padding-top:calc(var(--spacing) * 1)}.pt-1\.5{padding-top:calc(var(--spacing) * 1.5)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-2\.5{padding-top:calc(var(--spacing) * 2.5)}.pt-3{padding-top:calc(var(--spacing) * 3)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pr-1{padding-right:calc(var(--spacing) * 1)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pr-2\.5{padding-right:calc(var(--spacing) * 2.5)}.pr-3{padding-right:calc(var(--spacing) * 3)}.pr-7{padding-right:calc(var(--spacing) * 7)}.pr-8{padding-right:calc(var(--spacing) * 8)}.pb-1{padding-bottom:calc(var(--spacing) * 1)}.pb-1\.5{padding-bottom:calc(var(--spacing) * 1.5)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-2\.5{padding-bottom:calc(var(--spacing) * 2.5)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.pl-2{padding-left:calc(var(--spacing) * 2)}.pl-2\.5{padding-left:calc(var(--spacing) * 2.5)}.pl-3{padding-left:calc(var(--spacing) * 3)}.pl-4{padding-left:calc(var(--spacing) * 4)}.pl-7{padding-left:calc(var(--spacing) * 7)}.pl-8{padding-left:calc(var(--spacing) * 8)}.pl-12{padding-left:calc(var(--spacing) * 12)}.pl-\[11px\]{padding-left:11px}.text-center{text-align:center}.text-left{text-align:left}.align-text-bottom{vertical-align:text-bottom}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-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-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.\!text-\[9px\]{font-size:9px!important}.\!text-\[10px\]{font-size:10px!important}.\!text-\[12px\]{font-size:12px!important}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.text-\[10\.5px\]{font-size:10.5px}.text-\[10px\]{font-size:10px}.text-\[11\.5px\]{font-size:11.5px}.text-\[11px\]{font-size:11px}.text-\[12\.5px\]{font-size:12.5px}.text-\[12px\]{font-size:12px}.text-\[13\.5px\]{font-size:13.5px}.text-\[13px\]{font-size:13px}.text-\[14\.5px\]{font-size:14.5px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[16px\]{font-size:16px}.text-\[18px\]{font-size:18px}.text-\[22px\]{font-size:22px}.text-\[26px\]{font-size:26px}.leading-\[1\.5\]{--tw-leading:1.5;line-height:1.5}.leading-\[1\.6\]{--tw-leading:1.6;line-height:1.6}.leading-\[1\.7\]{--tw-leading:1.7;line-height:1.7}.leading-\[1\.55\]{--tw-leading:1.55;line-height:1.55}.leading-\[1\.65\]{--tw-leading:1.65;line-height:1.65}.leading-\[1\.72\]{--tw-leading:1.72;line-height:1.72}.leading-\[1\.75\]{--tw-leading:1.75;line-height:1.75}.leading-\[16px\]{--tw-leading:16px;line-height:16px}.leading-\[18px\]{--tw-leading:18px;line-height:18px}.leading-\[20px\]{--tw-leading:20px;line-height:20px}.leading-\[22px\]{--tw-leading:22px;line-height:22px}.leading-\[26px\]{--tw-leading:26px;line-height:26px}.leading-\[34px\]{--tw-leading:34px;line-height:34px}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-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-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[0\.01em\]{--tw-tracking:.01em;letter-spacing:.01em}.tracking-\[0\.06em\]{--tw-tracking:.06em;letter-spacing:.06em}.tracking-\[0\.12em\]{--tw-tracking:.12em;letter-spacing:.12em}.tracking-\[0\.14em\]{--tw-tracking:.14em;letter-spacing:.14em}.tracking-\[0\.16em\]{--tw-tracking:.16em;letter-spacing:.16em}.tracking-\[0\.18em\]{--tw-tracking:.18em;letter-spacing:.18em}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.\!text-err{color:var(--color-err)!important}.\!text-white{color:var(--color-white)!important}.text-\[\#6c7086\]{color:#6c7086}.text-\[\#cdd6f4\]{color:#cdd6f4}.text-\[var\(--brand-accent-fg\)\]{color:var(--brand-accent-fg)}.text-\[var\(--th-badge-accent-text\)\]{color:var(--th-badge-accent-text)}.text-\[var\(--th-badge-err-text\)\]{color:var(--th-badge-err-text)}.text-\[var\(--th-badge-info-text\)\]{color:var(--th-badge-info-text)}.text-\[var\(--th-badge-ok-text\)\]{color:var(--th-badge-ok-text)}.text-\[var\(--th-badge-running-text\)\]{color:var(--th-badge-running-text)}.text-\[var\(--th-badge-warn-text\)\]{color:var(--th-badge-warn-text)}.text-\[var\(--th-err\)\]{color:var(--th-err)}.text-\[var\(--th-ok\)\]{color:var(--th-ok)}.text-\[var\(--th-warn\)\]{color:var(--th-warn)}.text-amber-200{color:var(--color-amber-200)}.text-amber-200\/80{color:#fee685cc}@supports (color:color-mix(in lab,red,red)){.text-amber-200\/80{color:color-mix(in oklab,var(--color-amber-200) 80%,transparent)}}.text-amber-300\/80{color:#ffd236cc}@supports (color:color-mix(in lab,red,red)){.text-amber-300\/80{color:color-mix(in oklab,var(--color-amber-300) 80%,transparent)}}.text-amber-400{color:var(--color-amber-400)}.text-amber-400\/80{color:#fcbb00cc}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/80{color:color-mix(in oklab,var(--color-amber-400) 80%,transparent)}}.text-amber-600{color:var(--color-amber-600)}.text-amber-700{color:var(--color-amber-700)}.text-blue-300\/90{color:#90c5ffe6}@supports (color:color-mix(in lab,red,red)){.text-blue-300\/90{color:color-mix(in oklab,var(--color-blue-300) 90%,transparent)}}.text-blue-400{color:var(--color-blue-400)}.text-blue-400\/70{color:#54a2ffb3}@supports (color:color-mix(in lab,red,red)){.text-blue-400\/70{color:color-mix(in oklab,var(--color-blue-400) 70%,transparent)}}.text-emerald-200{color:var(--color-emerald-200)}.text-emerald-700{color:var(--color-emerald-700)}.text-err{color:var(--color-err)}.text-fg{color:var(--color-fg)}.text-fg-2{color:var(--color-fg-2)}.text-fg-3{color:var(--color-fg-3)}.text-fg-4,.text-fg-4\/80{color:var(--color-fg-4)}@supports (color:color-mix(in lab,red,red)){.text-fg-4\/80{color:color-mix(in oklab,var(--color-fg-4) 80%,transparent)}}.text-fg-5,.text-fg-5\/20{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.text-fg-5\/20{color:color-mix(in oklab,var(--color-fg-5) 20%,transparent)}}.text-fg-5\/30{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.text-fg-5\/30{color:color-mix(in oklab,var(--color-fg-5) 30%,transparent)}}.text-fg-5\/40{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.text-fg-5\/40{color:color-mix(in oklab,var(--color-fg-5) 40%,transparent)}}.text-fg-5\/50{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.text-fg-5\/50{color:color-mix(in oklab,var(--color-fg-5) 50%,transparent)}}.text-fg-5\/55{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.text-fg-5\/55{color:color-mix(in oklab,var(--color-fg-5) 55%,transparent)}}.text-fg-5\/60{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.text-fg-5\/60{color:color-mix(in oklab,var(--color-fg-5) 60%,transparent)}}.text-fg-5\/65{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.text-fg-5\/65{color:color-mix(in oklab,var(--color-fg-5) 65%,transparent)}}.text-fg-5\/70{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.text-fg-5\/70{color:color-mix(in oklab,var(--color-fg-5) 70%,transparent)}}.text-fg-5\/80{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.text-fg-5\/80{color:color-mix(in oklab,var(--color-fg-5) 80%,transparent)}}.text-fg-6{color:var(--color-fg-6)}.text-ok{color:var(--color-ok)}.text-primary{color:var(--color-primary)}.text-primary-fg{color:var(--color-primary-fg)}.text-red-200{color:var(--color-red-200)}.text-red-500\/70{color:#fb2c36b3}@supports (color:color-mix(in lab,red,red)){.text-red-500\/70{color:color-mix(in oklab,var(--color-red-500) 70%,transparent)}}.text-red-600{color:var(--color-red-600)}.text-rose-200{color:var(--color-rose-200)}.text-rose-300\/65{color:#ffa2aea6}@supports (color:color-mix(in lab,red,red)){.text-rose-300\/65{color:color-mix(in oklab,var(--color-rose-300) 65%,transparent)}}.text-sky-400\/70{color:#00bcfeb3}@supports (color:color-mix(in lab,red,red)){.text-sky-400\/70{color:color-mix(in oklab,var(--color-sky-400) 70%,transparent)}}.text-warn{color:var(--color-warn)}.text-white{color:var(--color-white)}.text-white\/72{color:#ffffffb8}@supports (color:color-mix(in lab,red,red)){.text-white\/72{color:color-mix(in oklab,var(--color-white) 72%,transparent)}}.text-white\/75{color:#ffffffbf}@supports (color:color-mix(in lab,red,red)){.text-white\/75{color:color-mix(in oklab,var(--color-white) 75%,transparent)}}.text-white\/88{color:#ffffffe0}@supports (color:color-mix(in lab,red,red)){.text-white\/88{color:color-mix(in oklab,var(--color-white) 88%,transparent)}}.text-white\/90{color:#ffffffe6}@supports (color:color-mix(in lab,red,red)){.text-white\/90{color:color-mix(in oklab,var(--color-white) 90%,transparent)}}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.line-through{text-decoration-line:line-through}.underline{text-decoration-line:underline}.decoration-blue-400\/30{text-decoration-color:#54a2ff4d}@supports (color:color-mix(in lab,red,red)){.decoration-blue-400\/30{-webkit-text-decoration-color:color-mix(in oklab,var(--color-blue-400) 30%,transparent);text-decoration-color:color-mix(in oklab,var(--color-blue-400) 30%,transparent)}}.decoration-fg-5\/40{-webkit-text-decoration-color:var(--color-fg-5);text-decoration-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.decoration-fg-5\/40{-webkit-text-decoration-color:color-mix(in oklab,var(--color-fg-5) 40%,transparent);text-decoration-color:color-mix(in oklab,var(--color-fg-5) 40%,transparent)}}.underline-offset-2{text-underline-offset:2px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-100{opacity:1}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_0_4px_var\(--th-glow-a\)\]{--tw-shadow:0 0 0 4px var(--tw-shadow-color,var(--th-glow-a));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_8px_var\(--th-err-glow\)\]{--tw-shadow:0 0 8px var(--tw-shadow-color,var(--th-err-glow));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_8px_var\(--th-glow-a\)\]{--tw-shadow:0 0 8px var(--tw-shadow-color,var(--th-glow-a));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_8px_var\(--th-warn-glow\)\]{--tw-shadow:0 0 8px var(--tw-shadow-color,var(--th-warn-glow));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_10px_var\(--th-err-glow\)\]{--tw-shadow:0 0 10px var(--tw-shadow-color,var(--th-err-glow));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_10px_var\(--th-info-glow\)\]{--tw-shadow:0 0 10px var(--tw-shadow-color,var(--th-info-glow));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_10px_var\(--th-ok-glow\)\]{--tw-shadow:0 0 10px var(--tw-shadow-color,var(--th-ok-glow));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_10px_var\(--th-running-glow\)\]{--tw-shadow:0 0 10px var(--tw-shadow-color,var(--th-running-glow));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_10px_var\(--th-warn-glow\)\]{--tw-shadow:0 0 10px var(--tw-shadow-color,var(--th-warn-glow));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_1px_0_rgba\(255\,255\,255\,0\.02\)\,0_4px_12px_rgba\(2\,6\,23\,0\.06\)\]{--tw-shadow:0 1px 0 var(--tw-shadow-color,#ffffff05), 0 4px 12px var(--tw-shadow-color,#0206170f);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_1px_0_rgba\(255\,255\,255\,0\.02\)\,0_4px_12px_rgba\(15\,23\,42\,0\.05\)\]{--tw-shadow:0 1px 0 var(--tw-shadow-color,#ffffff05), 0 4px 12px var(--tw-shadow-color,#0f172a0d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_1px_0_rgba\(255\,255\,255\,0\.03\)\]{--tw-shadow:0 1px 0 var(--tw-shadow-color,#ffffff08);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_1px_2px_rgba\(0\,0\,0\,0\.1\)\,inset_0_1px_0_rgba\(255\,255\,255\,0\.04\)\]{--tw-shadow:0 1px 2px var(--tw-shadow-color,#0000001a), inset 0 1px 0 var(--tw-shadow-color,#ffffff0a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_1px_2px_rgba\(0\,0\,0\,0\.1\)\]{--tw-shadow:0 1px 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-\[0_2px_8px_rgba\(0\,0\,0\,0\.06\)\]{--tw-shadow:0 2px 8px var(--tw-shadow-color,#0000000f);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_20px_48px_rgba\(2\,6\,23\,0\.28\)\]{--tw-shadow:0 20px 48px var(--tw-shadow-color,#02061747);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_20px_70px_rgba\(0\,0\,0\,0\.45\)\]{--tw-shadow:0 20px 70px var(--tw-shadow-color,#00000073);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_24px_64px_rgba\(2\,6\,23\,0\.22\)\]{--tw-shadow:0 24px 64px var(--tw-shadow-color,#02061738);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_24px_64px_rgba\(2\,6\,23\,0\.24\)\]{--tw-shadow:0 24px 64px var(--tw-shadow-color,#0206173d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_24px_64px_rgba\(2\,6\,23\,0\.32\)\]{--tw-shadow:0 24px 64px var(--tw-shadow-color,#02061752);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.02\)\]{--tw-shadow:inset 0 1px 0 var(--tw-shadow-color,#ffffff05);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[inset_0_1px_0_rgba\(255\,255\,255\,0\.03\)\]{--tw-shadow:inset 0 1px 0 var(--tw-shadow-color,#ffffff08);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-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)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-\[3px\]{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-primary\/\[0\.06\]{--tw-ring-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.ring-primary\/\[0\.06\]{--tw-ring-color:color-mix(in oklab, var(--color-primary) 6%, transparent)}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur,.backdrop-blur-\[8px\]{--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-\[20px\]{--tw-backdrop-blur:blur(20px);-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-md{--tw-backdrop-blur:blur(var(--blur-md));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-xl{--tw-backdrop-blur:blur(var(--blur-xl));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-saturate-125{--tw-backdrop-saturate:saturate(125%);-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-filter\:blur\(20px\)_saturate\(1\.2\)\]{-webkit-backdrop-filter:blur(20px)saturate(1.2);backdrop-filter:blur(20px)saturate(1.2)}.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-\[background\,border-color\]{transition-property:background,border-color;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[background\,color\,border-color\,box-shadow\,transform\]{transition-property:background,color,border-color,box-shadow,transform;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[background\]{transition-property:background;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[border-color\,background\,transform\,box-shadow\]{transition-property:border-color,background,transform,box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[border-color\,box-shadow\,background\]{transition-property:border-color,box-shadow,background;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[border-color\,box-shadow\]{transition-property:border-color,box-shadow;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-500{--tw-duration:.5s;transition-duration:.5s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.group-focus-within\:text-fg-4:is(:where(.group):focus-within *){color:var(--color-fg-4)}.group-focus-within\:opacity-0:is(:where(.group):focus-within *){opacity:0}@media(hover:hover){.group-hover\:scale-\[1\.03\]:is(:where(.group):hover *){scale:1.03}.group-hover\:border-\[var\(--edge-default\)\]:is(:where(.group):hover *){border-color:var(--edge-default)}.group-hover\:border-edge-h:is(:where(.group):hover *){border-color:var(--color-edge-h)}.group-hover\:text-fg:is(:where(.group):hover *){color:var(--color-fg)}.group-hover\:text-fg-3:is(:where(.group):hover *){color:var(--color-fg-3)}.group-hover\:text-fg-4:is(:where(.group):hover *){color:var(--color-fg-4)}.group-hover\:text-primary:is(:where(.group):hover *){color:var(--color-primary)}.group-hover\:opacity-0:is(:where(.group):hover *){opacity:0}.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.placeholder\:text-fg-5::placeholder,.placeholder\:text-fg-5\/25::placeholder{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.placeholder\:text-fg-5\/25::placeholder{color:color-mix(in oklab,var(--color-fg-5) 25%,transparent)}}.placeholder\:text-fg-5\/30::placeholder{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.placeholder\:text-fg-5\/30::placeholder{color:color-mix(in oklab,var(--color-fg-5) 30%,transparent)}}.placeholder\:text-fg-5\/50::placeholder{color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.placeholder\:text-fg-5\/50::placeholder{color:color-mix(in oklab,var(--color-fg-5) 50%,transparent)}}.even\:bg-\[rgba\(255\,255\,255\,0\.015\)\]:nth-child(2n){background-color:#ffffff04}.focus-within\:border-fg-5\/40:focus-within{border-color:var(--color-fg-5)}@supports (color:color-mix(in lab,red,red)){.focus-within\:border-fg-5\/40:focus-within{border-color:color-mix(in oklab,var(--color-fg-5) 40%,transparent)}}.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\:-translate-y-0\.5:hover{--tw-translate-y:calc(var(--spacing) * -.5);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:border-\[color-mix\(in_oklab\,var\(--th-err\)_45\%\,transparent\)\]:hover{border-color:var(--th-err)}@supports (color:color-mix(in lab,red,red)){.hover\:border-\[color-mix\(in_oklab\,var\(--th-err\)_45\%\,transparent\)\]:hover{border-color:color-mix(in oklab,var(--th-err) 45%,transparent)}}.hover\:border-\[var\(--edge-default\)\]:hover{border-color:var(--edge-default)}.hover\:border-\[var\(--edge-strong\)\]:hover{border-color:var(--edge-strong)}.hover\:border-control-border-h:hover{border-color:var(--color-control-border-h)}.hover\:border-edge-h:hover{border-color:var(--color-edge-h)}.hover\:border-edge-strong:hover{border-color:var(--color-edge-strong)}.hover\:border-fg-6\/60:hover{border-color:var(--color-fg-6)}@supports (color:color-mix(in lab,red,red)){.hover\:border-fg-6\/60:hover{border-color:color-mix(in oklab,var(--color-fg-6) 60%,transparent)}}.hover\:\!bg-red-500:hover{background-color:var(--color-red-500)!important}.hover\:bg-\[color-mix\(in_oklab\,var\(--th-err\)_8\%\,transparent\)\]:hover{background-color:var(--th-err)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-\[color-mix\(in_oklab\,var\(--th-err\)_8\%\,transparent\)\]:hover{background-color:color-mix(in oklab,var(--th-err) 8%,transparent)}}.hover\:bg-\[var\(--surface-2\)\]:hover{background-color:var(--surface-2)}.hover\:bg-\[var\(--surface-3\)\]:hover{background-color:var(--surface-3)}.hover\:bg-amber-500\/10:hover{background-color:#f99c001a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-amber-500\/10:hover{background-color:color-mix(in oklab,var(--color-amber-500) 10%,transparent)}}.hover\:bg-black\/80:hover{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.hover\:bg-black\/80:hover{background-color:color-mix(in oklab,var(--color-black) 80%,transparent)}}.hover\:bg-blue-400\/10:hover{background-color:#54a2ff1a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-blue-400\/10:hover{background-color:color-mix(in oklab,var(--color-blue-400) 10%,transparent)}}.hover\:bg-control-h:hover{background-color:var(--color-control-h)}.hover\:bg-err\/10:hover{background-color:var(--color-err)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-err\/10:hover{background-color:color-mix(in oklab,var(--color-err) 10%,transparent)}}.hover\:bg-fg-6\/\[0\.12\]:hover{background-color:var(--color-fg-6)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-fg-6\/\[0\.12\]:hover{background-color:color-mix(in oklab,var(--color-fg-6) 12%,transparent)}}.hover\:bg-inset:hover{background-color:var(--color-inset)}.hover\:bg-panel:hover{background-color:var(--color-panel)}.hover\:bg-panel-alt:hover,.hover\:bg-panel-alt\/50:hover{background-color:var(--color-panel-alt)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-panel-alt\/50:hover{background-color:color-mix(in oklab,var(--color-panel-alt) 50%,transparent)}}.hover\:bg-panel-h:hover,.hover\:bg-panel-h\/30:hover{background-color:var(--color-panel-h)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-panel-h\/30:hover{background-color:color-mix(in oklab,var(--color-panel-h) 30%,transparent)}}.hover\:bg-panel-h\/40:hover{background-color:var(--color-panel-h)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-panel-h\/40:hover{background-color:color-mix(in oklab,var(--color-panel-h) 40%,transparent)}}.hover\:bg-panel-h\/50:hover{background-color:var(--color-panel-h)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-panel-h\/50:hover{background-color:color-mix(in oklab,var(--color-panel-h) 50%,transparent)}}.hover\:bg-panel-h\/60:hover{background-color:var(--color-panel-h)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-panel-h\/60:hover{background-color:color-mix(in oklab,var(--color-panel-h) 60%,transparent)}}.hover\:bg-selected-h:hover{background-color:var(--color-selected-h)}.hover\:bg-white\/14:hover{background-color:#ffffff24}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/14:hover{background-color:color-mix(in oklab,var(--color-white) 14%,transparent)}}.hover\:bg-white\/\[0\.03\]:hover{background-color:#ffffff08}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.03\]:hover{background-color:color-mix(in oklab,var(--color-white) 3%,transparent)}}.hover\:\!text-err:hover{color:var(--color-err)!important}.hover\:text-\[var\(--th-err\)\]:hover{color:var(--th-err)}.hover\:text-amber-100:hover{color:var(--color-amber-100)}.hover\:text-blue-300:hover{color:var(--color-blue-300)}.hover\:text-blue-400:hover{color:var(--color-blue-400)}.hover\:text-err:hover{color:var(--color-err)}.hover\:text-fg:hover{color:var(--color-fg)}.hover\:text-fg-2:hover{color:var(--color-fg-2)}.hover\:text-fg-3:hover{color:var(--color-fg-3)}.hover\:text-fg-4:hover{color:var(--color-fg-4)}.hover\:text-primary:hover,.hover\:text-primary\/80:hover{color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.hover\:text-primary\/80:hover{color:color-mix(in oklab,var(--color-primary) 80%,transparent)}}.hover\:text-red-400:hover{color:var(--color-red-400)}.hover\:text-white:hover{color:var(--color-white)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-80:hover{opacity:.8}.hover\:opacity-90:hover{opacity:.9}.hover\:shadow-\[0_4px_16px_rgba\(15\,23\,42\,0\.06\)\]:hover{--tw-shadow:0 4px 16px var(--tw-shadow-color,#0f172a0f);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-sm:hover{--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)}.hover\:brightness-110:hover{--tw-brightness:brightness(110%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.hover\:brightness-125:hover{--tw-brightness:brightness(125%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}.focus\:border-\[var\(--edge-strong\)\]:focus{border-color:var(--edge-strong)}.focus\:border-control-border-h:focus{border-color:var(--color-control-border-h)}.focus\:border-edge-h:focus{border-color:var(--color-edge-h)}.focus\:border-primary\/30:focus{border-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.focus\:border-primary\/30:focus{border-color:color-mix(in oklab,var(--color-primary) 30%,transparent)}}.focus\:bg-\[var\(--surface-2\)\]:focus{background-color:var(--surface-2)}.focus\:bg-\[var\(--surface-3\)\]:focus{background-color:var(--surface-3)}.focus\:bg-control-h:focus{background-color:var(--color-control-h)}.focus\:bg-inset:focus{background-color:var(--color-inset)}.focus\:shadow-\[0_0_0_3px_rgba\(99\,102\,241\,0\.06\)\]:focus{--tw-shadow:0 0 0 3px var(--tw-shadow-color,#6366f10f);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:shadow-\[0_0_0_3px_var\(--brand-glow-a\)\]:focus{--tw-shadow:0 0 0 3px var(--tw-shadow-color,var(--brand-glow-a));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:shadow-\[0_0_0_4px_var\(--th-glow-a\)\]:focus{--tw-shadow:0 0 0 4px var(--tw-shadow-color,var(--th-glow-a));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-\[var\(--th-glow-a\)\]:focus{--tw-ring-color:var(--th-glow-a)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:border-control-border-h:focus-visible{border-color:var(--color-control-border-h)}.focus-visible\:border-edge-h:focus-visible{border-color:var(--color-edge-h)}.focus-visible\:opacity-100:focus-visible{opacity:1}.focus-visible\:shadow-\[0_0_0_3px_var\(--brand-glow-a\)\]:focus-visible{--tw-shadow:0 0 0 3px var(--tw-shadow-color,var(--brand-glow-a));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\:shadow-\[0_0_0_4px_var\(--th-glow-a\)\]:focus-visible{--tw-shadow:0 0 0 4px var(--tw-shadow-color,var(--th-glow-a));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\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:border-\[var\(--edge-subtle\)\]:disabled{border-color:var(--edge-subtle)}.disabled\:border-edge:disabled{border-color:var(--color-edge)}.disabled\:bg-\[var\(--surface-2\)\]:disabled{background-color:var(--surface-2)}.disabled\:bg-panel-alt:disabled{background-color:var(--color-panel-alt)}.disabled\:text-fg-5:disabled{color:var(--color-fg-5)}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:shadow-none:disabled{--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)}.disabled\:placeholder\:text-fg-6:disabled::placeholder{color:var(--color-fg-6)}@media(hover:hover){.disabled\:hover\:border-\[var\(--edge-subtle\)\]:disabled:hover{border-color:var(--edge-subtle)}.disabled\:hover\:border-edge:disabled:hover{border-color:var(--color-edge)}.disabled\:hover\:bg-panel-alt:disabled:hover{background-color:var(--color-panel-alt)}}@media(min-width:40rem){.sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:grid-cols-\[minmax\(0\,2fr\)_minmax\(0\,1fr\)\]{grid-template-columns:minmax(0,2fr) minmax(0,1fr)}.sm\:flex-row{flex-direction:row}.sm\:flex-wrap{flex-wrap:wrap}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}}@media(min-width:48rem){.md\:order-none{order:0}.md\:flex{display:flex}.md\:inline{display:inline}.md\:w-auto{width:auto}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:64rem){.lg\:col-span-full{grid-column:1/-1}.lg\:grid{display:grid}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-\[var\(--row-grid\,260px_120px_minmax\(0\,1fr\)_auto\)\]{grid-template-columns:var(--row-grid,260px 120px minmax(0,1fr) auto)}.lg\:items-center{align-items:center}.lg\:justify-end{justify-content:flex-end}}@media(min-width:80rem){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl\:flex-row{flex-direction:row}.xl\:items-end{align-items:flex-end}.xl\:justify-between{justify-content:space-between}.xl\:gap-6{gap:calc(var(--spacing) * 6)}}@media(prefers-color-scheme:dark){.dark\:text-amber-400{color:var(--color-amber-400)}.dark\:text-emerald-300{color:var(--color-emerald-300)}}.\[\&\>\*\+\*\]\:border-t>*+*{border-top-style:var(--tw-border-style);border-top-width:1px}.\[\&\>\*\+\*\]\:border-\[var\(--edge-subtle\)\]>*+*{border-color:var(--edge-subtle)}}:root{--th-surface:#080a0d;--surface-0:#06080b;--surface-1:#0a0d12;--surface-2:#ffffff06;--surface-3:#ffffff0e;--surface-elev:#0f172af0;--th-fg:#f8fafcf0;--th-fg-2:#f8fafccc;--th-fg-3:#e2e8f0a8;--th-fg-4:#cbd5e185;--th-fg-5:#94a3b880;--th-fg-6:#94a3b838;--th-panel:#0f172a85;--th-panel-h:#0f172ab3;--th-panel-alt:#0f172a57;--th-inset:#ffffff0d;--th-control-bg:#ffffff0f;--th-control-bg-h:#ffffff1a;--th-control-border:#94a3b847;--th-control-border-h:#94a3b873;--th-edge:#94a3b82e;--th-edge-h:#94a3b852;--edge-subtle:#94a3b81a;--edge-default:#94a3b82e;--edge-strong:#94a3b852;--th-inset-hl:#ffffff0d;--th-selected-bg:#ffffff12;--th-selected-bg-h:#ffffff1a;--th-primary:#f8fafc;--th-primary-fg:#09090b;--th-primary-h:#fff;--brand-accent:#f8fafc;--brand-accent-fg:#09090b;--brand-glow-a:#7dd3fc52;--brand-glow-b:#a78bfa3d;--brand-glow-idle:#7dd3fc00;--th-sidebar:#080a0dc7;--th-header:#080a0dbd;--th-modal-bg:#0a0e14f5;--th-overlay:#02061799;--th-dropdown:#0c1018fa;--th-grid-dot:#94a3b814;--th-grad-start:#f8fafc;--th-grad-mid:#cbd5e1;--th-grad-end:#94a3b8;--th-glow-a:#94a3b829;--th-glow-b:#60a5fa14;--th-shimmer-a:#ffffff04;--th-shimmer-b:#94a3b814;--th-orb1:#94a3b81f;--th-orb2:#60a5fa17;--th-orb3:#3b82f60d;--th-noise:.02;--th-card-shadow:0 8px 30px #02061724;--th-ok:#34d399;--th-ok-glow:#34d39980;--th-warn:#fbbf24;--th-warn-glow:#fbbf2480;--th-err:#f87171;--th-err-glow:#f8717180;--th-info:#7dd3fc;--th-info-glow:#7dd3fc73;--th-running:#60a5fa;--th-running-glow:#60a5fa73;--th-idle:#94a3b873;--th-badge-ok-text:#d1fae5;--th-badge-ok-bg:#10b98129;--th-badge-ok-border:#34d39947;--th-badge-warn-text:#fde68a;--th-badge-warn-bg:#f59e0b29;--th-badge-warn-border:#fbbf2447;--th-badge-err-text:#fecaca;--th-badge-err-bg:#ef444429;--th-badge-err-border:#f8717147;--th-badge-accent-text:#bae6fd;--th-badge-accent-bg:#0ea5e92e;--th-badge-accent-border:#7dd3fc47;--th-badge-info-text:#bae6fd;--th-badge-info-bg:#7dd3fc24;--th-badge-info-border:#7dd3fc4d;--th-badge-running-text:#dbeafe;--th-badge-running-bg:#60a5fa29;--th-badge-running-border:#60a5fa52;--th-badge-muted-text:#e2e8f0bd;--th-badge-muted-bg:#0f172a57;--th-badge-muted-border:#94a3b833}[data-theme=light]{--th-surface:#eef2f6;--surface-0:#eef2f6;--surface-1:#e5e9ee;--surface-2:#ffffffe0;--surface-3:#fffffffa;--surface-elev:#fffffffa;--th-fg:#0f172afa;--th-fg-2:#0f172ae0;--th-fg-3:#1e293bc7;--th-fg-4:#334155ad;--th-fg-5:#47556994;--th-fg-6:#47556938;--th-panel:#fffffff0;--th-panel-h:#fffffff5;--th-panel-alt:#ffffffe0;--th-inset:#0f172a0d;--th-edge:#0f172a1a;--th-edge-h:#0f172a29;--edge-subtle:#0f172a0f;--edge-default:#0f172a1a;--edge-strong:#0f172a2e;--brand-accent:#0f172a;--brand-accent-fg:#f8fafc;--brand-glow-a:#38bdf83d;--brand-glow-b:#8b5cf62e;--brand-glow-idle:#38bdf800;--th-control-bg:#fff;--th-control-bg-h:#fffffffa;--th-control-border:#0f172a2e;--th-control-border-h:#0f172a52;--th-primary:#0f172a;--th-primary-fg:#f8fafc;--th-primary-h:#020617;--th-sidebar:#eef2f6e6;--th-header:#eef2f6e0;--th-modal-bg:#fffffff5;--th-overlay:#0f172a2e;--th-dropdown:#fffffffc;--th-grid-dot:#64748b1a;--th-grad-start:#0f172a;--th-grad-mid:#334155;--th-grad-end:#64748b;--th-glow-a:#64748b2e;--th-glow-b:#38bdf81a;--th-shimmer-a:#0f172a0b;--th-shimmer-b:#64748b1f;--th-orb1:#94a3b81f;--th-orb2:#38bdf814;--th-orb3:#0ea5e90d;--th-noise:.012;--th-card-shadow:0 16px 40px #0f172a1a;--th-ok:#22c55e;--th-ok-glow:#22c55e59;--th-warn:#f59e0b;--th-warn-glow:#f59e0b59;--th-err:#ef4444;--th-err-glow:#ef444459;--th-info:#0ea5e9;--th-info-glow:#0ea5e959;--th-running:#3b82f6;--th-running-glow:#3b82f659;--th-idle:#47556973;--th-badge-ok-text:#166534;--th-badge-ok-bg:#22c55e1f;--th-badge-ok-border:#22c55e38;--th-badge-warn-text:#92400e;--th-badge-warn-bg:#f59e0b24;--th-badge-warn-border:#f59e0b3d;--th-badge-err-text:#991b1b;--th-badge-err-bg:#ef44441f;--th-badge-err-border:#ef444438;--th-badge-accent-text:#0c4a6e;--th-badge-accent-bg:#0ea5e91f;--th-badge-accent-border:#0ea5e938;--th-badge-info-text:#0c4a6e;--th-badge-info-bg:#0ea5e91f;--th-badge-info-border:#0ea5e938;--th-badge-running-text:#1e3a8a;--th-badge-running-bg:#3b82f61f;--th-badge-running-border:#3b82f63d;--th-badge-muted-text:#334155d1;--th-badge-muted-bg:#ffffffc2;--th-badge-muted-border:#0f172a1f;--th-inset-hl:#ffffffb8;--th-selected-bg:#0f172a0f;--th-selected-bg-h:#0f172a17}body{background:var(--color-surface);color:var(--color-foreground);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(circle at 100% 0,#94a3b814,#0000 28%),radial-gradient(circle at 0 100%,#60a5fa0f,#0000 24%)}#root{min-height:100vh}button:not(:disabled){cursor:pointer}button:disabled{cursor:not-allowed}::selection{background:#818cf840}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--th-fg-6);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--th-edge-h)}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.3}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes drift{0%{transform:translate(0)scale(1)}33%{transform:translate(30px,-20px)scale(1.05)}66%{transform:translate(-20px,15px)scale(.97)}to{transform:translate(0)scale(1)}}@keyframes thinking-dot{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-soft{0%{opacity:0}to{opacity:1}}.animate-in{animation:.5s cubic-bezier(.21,.47,.32,.98) both fade-in}.animate-in-up{animation:.45s cubic-bezier(.21,.47,.32,.98) both fade-in-up}.animate-in-fade{animation:.28s ease-out both fade-in-soft}.animate-scale{animation:.25s ease-out both scale-in}.animate-pulse-soft{animation:2s ease-in-out infinite pulse-soft}.thinking-dots span{background:currentColor;border-radius:50%;width:5px;height:5px;animation:1.4s ease-in-out infinite thinking-dot;display:inline-block}.thinking-dots span:nth-child(2){animation-delay:.16s}.thinking-dots span:nth-child(3){animation-delay:.32s}.animate-shimmer{background:linear-gradient(90deg,var(--th-shimmer-a) 25%,var(--th-shimmer-b) 50%,var(--th-shimmer-a) 75%);background-size:200% 100%;animation:1.5s infinite shimmer}.glass{background:var(--th-panel);-webkit-backdrop-filter:blur(6px)saturate(1.02);backdrop-filter:blur(6px)saturate(1.02);border:1px solid var(--th-edge);box-shadow:0 6px 18px #0f172a0f}.glass-strong{background:var(--th-modal-bg);-webkit-backdrop-filter:blur(24px)saturate(1.08);backdrop-filter:blur(24px)saturate(1.08);border:1px solid var(--th-edge-h)}.text-gradient{background:linear-gradient(135deg,var(--th-grad-start) 0%,var(--th-grad-mid) 50%,var(--th-grad-end) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.grid-bg{background-image:radial-gradient(var(--th-grid-dot) 1px,transparent 1px);background-size:24px 24px}.card-glow{position:relative}.card-glow:before{content:"";border-radius:inherit;background:linear-gradient(135deg,var(--th-glow-a),var(--th-glow-b),transparent 60%);z-index:-1;opacity:0;transition:opacity .3s;position:absolute;inset:-1px}.card-glow:hover:before{opacity:1}@keyframes ambient-breath{0%,to{opacity:.55}50%{opacity:1}}@keyframes ambient-rotate{to{--ambient-angle:360deg}}@property --ambient-angle{syntax:"<angle>";inherits:false;initial-value:0deg}.ambient-glow{isolation:isolate;position:relative}.ambient-glow:before{content:"";border-radius:inherit;background:conic-gradient(from var(--ambient-angle),var(--brand-glow-idle) 0deg,var(--brand-glow-a) 80deg,var(--brand-glow-b) 160deg,var(--brand-glow-idle) 240deg,var(--brand-glow-idle) 360deg);pointer-events:none;z-index:0;opacity:0;padding:1px;transition:opacity .6s ease-out;position:absolute;inset:-1px;-webkit-mask-image:linear-gradient(#000 0 0),linear-gradient(#000 0 0);mask-image:linear-gradient(#000 0 0),linear-gradient(#000 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.ambient-glow[data-streaming=true]:before{opacity:1;animation:6s linear infinite ambient-rotate,2.4s ease-in-out infinite ambient-breath}@keyframes status-pulse-running{0%,to{box-shadow:0 0 0 0 var(--th-running-glow)}50%{box-shadow:0 0 0 4px #0000}}.status-pulse-running{animation:1.6s ease-out infinite status-pulse-running}.noise-overlay:after{content:"";opacity:var(--th-noise);pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px 256px;position:fixed;inset:0}.panel-isolated{contain:layout style paint;will-change:transform}.panel-scroll-safe{contain:layout style}@supports (content-visibility:auto){.session-turn{content-visibility:auto;contain-intrinsic-size:1px 320px}}.session-turn+.session-turn{margin-top:2rem}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}@keyframes pulse{50%{opacity:.5}}