fluxy-bot 0.2.11 → 0.2.13

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.
@@ -50,4 +50,4 @@ In order to be iterable, non-array objects must have a [Symbol.iterator]() metho
50
50
  ${O}px !important;
51
51
  ${C}px !important;
52
52
  }
53
- `),()=>{B.contains(F)&&B.removeChild(F)}},[t]),Y.jsx(Gz,{isPresent:t,childRef:d,sizeRef:g,pop:u,children:u===!1?e:X.cloneElement(e,{ref:b})})}const Hz=({children:e,initial:t,isPresent:r,onExitComplete:i,custom:s,presenceAffectsLayout:u,mode:c,anchorX:d,anchorY:g,root:p})=>{const h=Cy(Vz),b=X.useId();let y=!0,E=X.useMemo(()=>(y=!1,{id:b,initial:t,isPresent:r,custom:s,onExitComplete:T=>{h.set(T,!0);for(const x of h.values())if(!x)return;i&&i()},register:T=>(h.set(T,!1),()=>h.delete(T))}),[r,h,i]);return u&&y&&(E={...E}),X.useMemo(()=>{h.forEach((T,x)=>h.set(x,!1))},[r]),X.useEffect(()=>{!r&&!h.size&&i&&i()},[r]),e=Y.jsx(jz,{pop:c==="popLayout",isPresent:r,anchorX:d,anchorY:g,root:p,children:e}),Y.jsx(bu.Provider,{value:E,children:e})};function Vz(){return new Map}function wx(e=!0){const t=X.useContext(bu);if(t===null)return[!0,null];const{isPresent:r,onExitComplete:i,register:s}=t,u=X.useId();X.useEffect(()=>{if(e)return s(u)},[e]);const c=X.useCallback(()=>e&&i&&i(u),[u,i,e]);return!r&&i?[!1,c]:[!0]}const Cl=e=>e.key||"";function mk(e){const t=[];return X.Children.forEach(e,r=>{X.isValidElement(r)&&t.push(r)}),t}const lf=({children:e,custom:t,initial:r=!0,onExitComplete:i,presenceAffectsLayout:s=!0,mode:u="sync",propagate:c=!1,anchorX:d="left",anchorY:g="top",root:p})=>{const[h,b]=wx(c),y=X.useMemo(()=>mk(e),[e]),E=c&&!h?[]:y.map(Cl),T=X.useRef(!0),x=X.useRef(y),k=Cy(()=>new Map),A=X.useRef(new Set),[O,C]=X.useState(y),[F,B]=X.useState(y);Q_(()=>{T.current=!1,x.current=y;for(let q=0;q<F.length;q++){const te=Cl(F[q]);E.includes(te)?(k.delete(te),A.current.delete(te)):k.get(te)!==!0&&k.set(te,!1)}},[F,E.length,E.join("-")]);const D=[];if(y!==O){let q=[...y];for(let te=0;te<F.length;te++){const M=F[te],ee=Cl(M);E.includes(ee)||(q.splice(te,0,M),D.push(M))}return u==="wait"&&D.length&&(q=D),B(mk(q)),C(y),null}const{forceRender:$}=X.useContext(Ny);return Y.jsx(Y.Fragment,{children:F.map(q=>{const te=Cl(q),M=c&&!h?!1:y===F||E.includes(te),ee=()=>{if(A.current.has(te))return;if(A.current.add(te),k.has(te))k.set(te,!0);else return;let ne=!0;k.forEach(ie=>{ie||(ne=!1)}),ne&&($?.(),B(x.current),c&&b?.(),i&&i())};return Y.jsx(Hz,{isPresent:M,initial:!T.current||r?void 0:!1,custom:t,presenceAffectsLayout:s,mode:u,root:p,onExitComplete:M?void 0:ee,anchorX:d,anchorY:g,children:q},te)})})},kx=X.createContext({strict:!1}),hk={animation:["animate","variants","whileHover","whileTap","exit","whileInView","whileFocus","whileDrag"],exit:["exit"],drag:["drag","dragControls"],focus:["whileFocus"],hover:["whileHover","onHoverStart","onHoverEnd"],tap:["whileTap","onTap","onTapStart","onTapCancel"],pan:["onPan","onPanStart","onPanSessionStart","onPanEnd"],inView:["whileInView","onViewportEnter","onViewportLeave"],layout:["layout","layoutId"]};let bk=!1;function $z(){if(bk)return;const e={};for(const t in hk)e[t]={isEnabled:r=>hk[t].some(i=>!!r[i])};ex(e),bk=!0}function _x(){return $z(),OB()}function qz(e){const t=_x();for(const r in e)t[r]={...t[r],...e[r]};ex(t)}const Yz=new Set(["animate","exit","variants","initial","style","values","variants","transition","transformTemplate","custom","inherit","onBeforeLayoutMeasure","onAnimationStart","onAnimationComplete","onUpdate","onDragStart","onDrag","onDragEnd","onMeasureDragConstraints","onDirectionLock","onDragTransitionEnd","_dragX","_dragY","onHoverStart","onHoverEnd","onViewportEnter","onViewportLeave","globalTapTarget","propagate","ignoreStrict","viewport"]);function eu(e){return e.startsWith("while")||e.startsWith("drag")&&e!=="draggable"||e.startsWith("layout")||e.startsWith("onTap")||e.startsWith("onPan")||e.startsWith("onLayout")||Yz.has(e)}let Rx=e=>!eu(e);function Wz(e){typeof e=="function"&&(Rx=t=>t.startsWith("on")?!eu(t):e(t))}try{Wz(require("@emotion/is-prop-valid").default)}catch{}function Xz(e,t,r){const i={};for(const s in e)s==="values"&&typeof e.values=="object"||(Rx(s)||r===!0&&eu(s)||!t&&!eu(s)||e.draggable&&s.startsWith("onDrag"))&&(i[s]=e[s]);return i}const Su=X.createContext({});function Kz(e,t){if(Eu(e)){const{initial:r,animate:i}=e;return{initial:r===!1||Ho(r)?r:void 0,animate:Ho(i)?i:void 0}}return e.inherit!==!1?t:{}}function Zz(e){const{initial:t,animate:r}=Kz(e,X.useContext(Su));return X.useMemo(()=>({initial:t,animate:r}),[yk(t),yk(r)])}function yk(e){return Array.isArray(e)?e.join(" "):e}const rE=()=>({style:{},transform:{},transformOrigin:{},vars:{}});function xx(e,t,r){for(const i in t)!_t(t[i])&&!sx(i,r)&&(e[i]=t[i])}function Qz({transformTemplate:e},t){return X.useMemo(()=>{const r=rE();return tE(r,t,e),Object.assign({},r.vars,r.style)},[t])}function Jz(e,t){const r=e.style||{},i={};return xx(i,r,e),Object.assign(i,Qz(e,t)),i}function eP(e,t){const r={},i=Jz(e,t);return e.drag&&e.dragListener!==!1&&(r.draggable=!1,i.userSelect=i.WebkitUserSelect=i.WebkitTouchCallout="none",i.touchAction=e.drag===!0?"none":`pan-${e.drag==="x"?"y":"x"}`),e.tabIndex===void 0&&(e.onTap||e.onTapStart||e.whileTap)&&(r.tabIndex=0),r.style=i,r}const Nx=()=>({...rE(),attrs:{}});function tP(e,t,r,i){const s=X.useMemo(()=>{const u=Nx();return lx(u,t,cx(i),e.transformTemplate,e.style),{...u.attrs,style:{...u.style}}},[t]);if(e.style){const u={};xx(u,e.style,e),s.style={...u,...s.style}}return s}const nP=["animate","circle","defs","desc","ellipse","g","image","line","filter","marker","mask","metadata","path","pattern","polygon","polyline","rect","stop","switch","symbol","svg","text","tspan","use","view"];function iE(e){return typeof e!="string"||e.includes("-")?!1:!!(nP.indexOf(e)>-1||/[A-Z]/u.test(e))}function aP(e,t,r,{latestValues:i},s,u=!1,c){const g=(c??iE(e)?tP:eP)(t,i,s,e),p=Xz(t,typeof e=="string",u),h=e!==X.Fragment?{...p,...g,ref:r}:{},{children:b}=t,y=X.useMemo(()=>_t(b)?b.get():b,[b]);return X.createElement(e,{...h,children:y})}function rP({scrapeMotionValuesFromProps:e,createRenderState:t},r,i,s){return{latestValues:iP(r,i,s,e),renderState:t()}}function iP(e,t,r,i){const s={},u=i(e,{});for(const y in u)s[y]=Pl(u[y]);let{initial:c,animate:d}=e;const g=Eu(e),p=QR(e);t&&p&&!g&&e.inherit!==!1&&(c===void 0&&(c=t.initial),d===void 0&&(d=t.animate));let h=r?r.initial===!1:!1;h=h||c===!1;const b=h?d:c;if(b&&typeof b!="boolean"&&!yu(b)){const y=Array.isArray(b)?b:[b];for(let E=0;E<y.length;E++){const T=Yy(e,y[E]);if(T){const{transitionEnd:x,transition:k,...A}=T;for(const O in A){let C=A[O];if(Array.isArray(C)){const F=h?C.length-1:0;C=C[F]}C!==null&&(s[O]=C)}for(const O in x)s[O]=x[O]}}}return s}const Cx=e=>(t,r)=>{const i=X.useContext(Su),s=X.useContext(bu),u=()=>rP(e,t,i,s);return r?u():Cy(u)},oP=Cx({scrapeMotionValuesFromProps:nE,createRenderState:rE}),sP=Cx({scrapeMotionValuesFromProps:dx,createRenderState:Nx}),lP=Symbol.for("motionComponentSymbol");function uP(e,t,r){const i=X.useRef(r);X.useInsertionEffect(()=>{i.current=r});const s=X.useRef(null);return X.useCallback(u=>{u&&e.onMount?.(u),t&&(u?t.mount(u):t.unmount());const c=i.current;if(typeof c=="function")if(u){const d=c(u);typeof d=="function"&&(s.current=d)}else s.current?(s.current(),s.current=null):c(u);else c&&(c.current=u)},[t])}const Ox=X.createContext({});function ai(e){return e&&typeof e=="object"&&Object.prototype.hasOwnProperty.call(e,"current")}function cP(e,t,r,i,s,u){const{visualElement:c}=X.useContext(Su),d=X.useContext(kx),g=X.useContext(bu),p=X.useContext(aE),h=p.reducedMotion,b=p.skipAnimations,y=X.useRef(null),E=X.useRef(!1);i=i||d.renderer,!y.current&&i&&(y.current=i(e,{visualState:t,parent:c,props:r,presenceContext:g,blockInitialAnimation:g?g.initial===!1:!1,reducedMotionConfig:h,skipAnimations:b,isSVG:u}),E.current&&y.current&&(y.current.manuallyAnimateOnMount=!0));const T=y.current,x=X.useContext(Ox);T&&!T.projection&&s&&(T.type==="html"||T.type==="svg")&&dP(y.current,r,s,x);const k=X.useRef(!1);X.useInsertionEffect(()=>{T&&k.current&&T.update(r,g)});const A=r[zR],O=X.useRef(!!A&&!window.MotionHandoffIsComplete?.(A)&&window.MotionHasOptimisedAnimation?.(A));return Q_(()=>{E.current=!0,T&&(k.current=!0,window.MotionIsMounted=!0,T.updateFeatures(),T.scheduleRenderMicrotask(),O.current&&T.animationState&&T.animationState.animateChanges())}),X.useEffect(()=>{T&&(!O.current&&T.animationState&&T.animationState.animateChanges(),O.current&&(queueMicrotask(()=>{window.MotionHandoffMarkAsComplete?.(A)}),O.current=!1),T.enteringChildren=void 0)}),T}function dP(e,t,r,i){const{layoutId:s,layout:u,drag:c,dragConstraints:d,layoutScroll:g,layoutRoot:p,layoutCrossfade:h}=t;e.projection=new r(e.latestValues,t["data-framer-portal-id"]?void 0:Ix(e.parent)),e.projection.setOptions({layoutId:s,layout:u,alwaysMeasureLayout:!!c||d&&ai(d),visualElement:e,animationType:typeof u=="string"?u:"both",initialPromotionConfig:i,crossfade:h,layoutScroll:g,layoutRoot:p})}function Ix(e){if(e)return e.options.allowProjection!==!1?e.projection:Ix(e.parent)}function bp(e,{forwardMotionProps:t=!1,type:r}={},i,s){i&&qz(i);const u=r?r==="svg":iE(e),c=u?sP:oP;function d(p,h){let b;const y={...X.useContext(aE),...p,layoutId:pP(p)},{isStatic:E}=y,T=Zz(p),x=c(p,E);if(!E&&Z_){fP();const k=gP(y);b=k.MeasureLayout,T.visualElement=cP(e,x,y,s,k.ProjectionNode,u)}return Y.jsxs(Su.Provider,{value:T,children:[b&&T.visualElement?Y.jsx(b,{visualElement:T.visualElement,...y}):null,aP(e,p,uP(x,T.visualElement,h),x,E,t,u)]})}d.displayName=`motion.${typeof e=="string"?e:`create(${e.displayName??e.name??""})`}`;const g=X.forwardRef(d);return g[lP]=e,g}function pP({layoutId:e}){const t=X.useContext(Ny).id;return t&&e!==void 0?t+"-"+e:e}function fP(e,t){X.useContext(kx).strict}function gP(e){const t=_x(),{drag:r,layout:i}=t;if(!r&&!i)return{};const s={...r,...i};return{MeasureLayout:r?.isEnabled(e)||i?.isEnabled(e)?s.MeasureLayout:void 0,ProjectionNode:s.ProjectionNode}}function mP(e,t){if(typeof Proxy>"u")return bp;const r=new Map,i=(u,c)=>bp(u,c,e,t),s=(u,c)=>i(u,c);return new Proxy(s,{get:(u,c)=>c==="create"?i:(r.has(c)||r.set(c,bp(c,void 0,e,t)),r.get(c))})}const hP=(e,t)=>t.isSVG??iE(e)?new WB(t):new jB(t,{allowProjection:e!==X.Fragment});class bP extends Ba{constructor(t){super(t),t.animationState||(t.animationState=JB(t))}updateAnimationControlsSubscription(){const{animate:t}=this.node.getProps();yu(t)&&(this.unmountControls=t.subscribe(this.node))}mount(){this.updateAnimationControlsSubscription()}update(){const{animate:t}=this.node.getProps(),{animate:r}=this.node.prevProps||{};t!==r&&this.updateAnimationControlsSubscription()}unmount(){this.node.animationState.reset(),this.unmountControls?.()}}let yP=0;class EP extends Ba{constructor(){super(...arguments),this.id=yP++}update(){if(!this.node.presenceContext)return;const{isPresent:t,onExitComplete:r}=this.node.presenceContext,{isPresent:i}=this.node.prevPresenceContext||{};if(!this.node.animationState||t===i)return;const s=this.node.animationState.setActive("exit",!t);r&&!t&&s.then(()=>{r(this.id)})}mount(){const{register:t,onExitComplete:r}=this.node.presenceContext||{};r&&r(this.id),t&&(this.unmount=t(this.id))}unmount(){}}const SP={animation:{Feature:bP},exit:{Feature:EP}};function as(e){return{point:{x:e.pageX,y:e.pageY}}}const TP=e=>t=>Zy(t)&&e(t,as(t));function Lo(e,t,r,i){return Vo(e,t,TP(r),i)}const Dx=({current:e})=>e?e.ownerDocument.defaultView:null,Ek=(e,t)=>Math.abs(e-t);function vP(e,t){const r=Ek(e.x,t.x),i=Ek(e.y,t.y);return Math.sqrt(r**2+i**2)}const Sk=new Set(["auto","scroll"]);class Lx{constructor(t,r,{transformPagePoint:i,contextWindow:s=window,dragSnapToOrigin:u=!1,distanceThreshold:c=3,element:d}={}){if(this.startEvent=null,this.lastMoveEvent=null,this.lastMoveEventInfo=null,this.handlers={},this.contextWindow=window,this.scrollPositions=new Map,this.removeScrollListeners=null,this.onElementScroll=E=>{this.handleScroll(E.target)},this.onWindowScroll=()=>{this.handleScroll(window)},this.updatePoint=()=>{if(!(this.lastMoveEvent&&this.lastMoveEventInfo))return;const E=Ep(this.lastMoveEventInfo,this.history),T=this.startEvent!==null,x=vP(E.offset,{x:0,y:0})>=this.distanceThreshold;if(!T&&!x)return;const{point:k}=E,{timestamp:A}=vt;this.history.push({...k,timestamp:A});const{onStart:O,onMove:C}=this.handlers;T||(O&&O(this.lastMoveEvent,E),this.startEvent=this.lastMoveEvent),C&&C(this.lastMoveEvent,E)},this.handlePointerMove=(E,T)=>{this.lastMoveEvent=E,this.lastMoveEventInfo=yp(T,this.transformPagePoint),Xe.update(this.updatePoint,!0)},this.handlePointerUp=(E,T)=>{this.end();const{onEnd:x,onSessionEnd:k,resumeAnimation:A}=this.handlers;if((this.dragSnapToOrigin||!this.startEvent)&&A&&A(),!(this.lastMoveEvent&&this.lastMoveEventInfo))return;const O=Ep(E.type==="pointercancel"?this.lastMoveEventInfo:yp(T,this.transformPagePoint),this.history);this.startEvent&&x&&x(E,O),k&&k(E,O)},!Zy(t))return;this.dragSnapToOrigin=u,this.handlers=r,this.transformPagePoint=i,this.distanceThreshold=c,this.contextWindow=s||window;const g=as(t),p=yp(g,this.transformPagePoint),{point:h}=p,{timestamp:b}=vt;this.history=[{...h,timestamp:b}];const{onSessionStart:y}=r;y&&y(t,Ep(p,this.history)),this.removeListeners=es(Lo(this.contextWindow,"pointermove",this.handlePointerMove),Lo(this.contextWindow,"pointerup",this.handlePointerUp),Lo(this.contextWindow,"pointercancel",this.handlePointerUp)),d&&this.startScrollTracking(d)}startScrollTracking(t){let r=t.parentElement;for(;r;){const i=getComputedStyle(r);(Sk.has(i.overflowX)||Sk.has(i.overflowY))&&this.scrollPositions.set(r,{x:r.scrollLeft,y:r.scrollTop}),r=r.parentElement}this.scrollPositions.set(window,{x:window.scrollX,y:window.scrollY}),window.addEventListener("scroll",this.onElementScroll,{capture:!0}),window.addEventListener("scroll",this.onWindowScroll),this.removeScrollListeners=()=>{window.removeEventListener("scroll",this.onElementScroll,{capture:!0}),window.removeEventListener("scroll",this.onWindowScroll)}}handleScroll(t){const r=this.scrollPositions.get(t);if(!r)return;const i=t===window,s=i?{x:window.scrollX,y:window.scrollY}:{x:t.scrollLeft,y:t.scrollTop},u={x:s.x-r.x,y:s.y-r.y};u.x===0&&u.y===0||(i?this.lastMoveEventInfo&&(this.lastMoveEventInfo.point.x+=u.x,this.lastMoveEventInfo.point.y+=u.y):this.history.length>0&&(this.history[0].x-=u.x,this.history[0].y-=u.y),this.scrollPositions.set(t,s),Xe.update(this.updatePoint,!0))}updateHandlers(t){this.handlers=t}end(){this.removeListeners&&this.removeListeners(),this.removeScrollListeners&&this.removeScrollListeners(),this.scrollPositions.clear(),Ua(this.updatePoint)}}function yp(e,t){return t?{point:t(e.point)}:e}function Tk(e,t){return{x:e.x-t.x,y:e.y-t.y}}function Ep({point:e},t){return{point:e,delta:Tk(e,Mx(t)),offset:Tk(e,AP(t)),velocity:wP(t,.1)}}function AP(e){return e[0]}function Mx(e){return e[e.length-1]}function wP(e,t){if(e.length<2)return{x:0,y:0};let r=e.length-1,i=null;const s=Mx(e);for(;r>=0&&(i=e[r],!(s.timestamp-i.timestamp>kn(t)));)r--;if(!i)return{x:0,y:0};i===e[0]&&e.length>2&&s.timestamp-i.timestamp>kn(t)*2&&(i=e[1]);const u=mn(s.timestamp-i.timestamp);if(u===0)return{x:0,y:0};const c={x:(s.x-i.x)/u,y:(s.y-i.y)/u};return c.x===1/0&&(c.x=0),c.y===1/0&&(c.y=0),c}function kP(e,{min:t,max:r},i){return t!==void 0&&e<t?e=i?Je(t,e,i.min):Math.max(e,t):r!==void 0&&e>r&&(e=i?Je(r,e,i.max):Math.min(e,r)),e}function vk(e,t,r){return{min:t!==void 0?e.min+t:void 0,max:r!==void 0?e.max+r-(e.max-e.min):void 0}}function _P(e,{top:t,left:r,bottom:i,right:s}){return{x:vk(e.x,r,s),y:vk(e.y,t,i)}}function Ak(e,t){let r=t.min-e.min,i=t.max-e.max;return t.max-t.min<e.max-e.min&&([r,i]=[i,r]),{min:r,max:i}}function RP(e,t){return{x:Ak(e.x,t.x),y:Ak(e.y,t.y)}}function xP(e,t){let r=.5;const i=Mt(e),s=Mt(t);return s>i?r=Po(t.min,t.max-i,e.min):i>s&&(r=Po(e.min,e.max-s,t.min)),Mn(0,1,r)}function NP(e,t){const r={};return t.min!==void 0&&(r.min=t.min-e.min),t.max!==void 0&&(r.max=t.max-e.min),r}const uf=.35;function CP(e=uf){return e===!1?e=0:e===!0&&(e=uf),{x:wk(e,"left","right"),y:wk(e,"top","bottom")}}function wk(e,t,r){return{min:kk(e,t),max:kk(e,r)}}function kk(e,t){return typeof e=="number"?e:e[t]||0}const OP=new WeakMap;class IP{constructor(t){this.openDragLock=null,this.isDragging=!1,this.currentDirection=null,this.originPoint={x:0,y:0},this.constraints=!1,this.hasMutatedConstraints=!1,this.elastic=ft(),this.latestPointerEvent=null,this.latestPanInfo=null,this.visualElement=t}start(t,{snapToCursor:r=!1,distanceThreshold:i}={}){const{presenceContext:s}=this.visualElement;if(s&&s.isPresent===!1)return;const u=b=>{r&&this.snapToCursor(as(b).point),this.stopAnimation()},c=(b,y)=>{const{drag:E,dragPropagation:T,onDragStart:x}=this.getProps();if(E&&!T&&(this.openDragLock&&this.openDragLock(),this.openDragLock=sB(E),!this.openDragLock))return;this.latestPointerEvent=b,this.latestPanInfo=y,this.isDragging=!0,this.currentDirection=null,this.resolveConstraints(),this.visualElement.projection&&(this.visualElement.projection.isAnimationBlocked=!0,this.visualElement.projection.target=void 0),Dn(A=>{let O=this.getAxisMotionValue(A).get()||0;if(Ln.test(O)){const{projection:C}=this.visualElement;if(C&&C.layout){const F=C.layout.layoutBox[A];F&&(O=Mt(F)*(parseFloat(O)/100))}}this.originPoint[A]=O}),x&&Xe.update(()=>x(b,y),!1,!0),Qp(this.visualElement,"transform");const{animationState:k}=this.visualElement;k&&k.setActive("whileDrag",!0)},d=(b,y)=>{this.latestPointerEvent=b,this.latestPanInfo=y;const{dragPropagation:E,dragDirectionLock:T,onDirectionLock:x,onDrag:k}=this.getProps();if(!E&&!this.openDragLock)return;const{offset:A}=y;if(T&&this.currentDirection===null){this.currentDirection=LP(A),this.currentDirection!==null&&x&&x(this.currentDirection);return}this.updateAxis("x",y.point,A),this.updateAxis("y",y.point,A),this.visualElement.render(),k&&Xe.update(()=>k(b,y),!1,!0)},g=(b,y)=>{this.latestPointerEvent=b,this.latestPanInfo=y,this.stop(b,y),this.latestPointerEvent=null,this.latestPanInfo=null},p=()=>{const{dragSnapToOrigin:b}=this.getProps();(b||this.constraints)&&this.startAnimation({x:0,y:0})},{dragSnapToOrigin:h}=this.getProps();this.panSession=new Lx(t,{onSessionStart:u,onStart:c,onMove:d,onSessionEnd:g,resumeAnimation:p},{transformPagePoint:this.visualElement.getTransformPagePoint(),dragSnapToOrigin:h,distanceThreshold:i,contextWindow:Dx(this.visualElement),element:this.visualElement.current})}stop(t,r){const i=t||this.latestPointerEvent,s=r||this.latestPanInfo,u=this.isDragging;if(this.cancel(),!u||!s||!i)return;const{velocity:c}=s;this.startAnimation(c);const{onDragEnd:d}=this.getProps();d&&Xe.postRender(()=>d(i,s))}cancel(){this.isDragging=!1;const{projection:t,animationState:r}=this.visualElement;t&&(t.isAnimationBlocked=!1),this.endPanSession();const{dragPropagation:i}=this.getProps();!i&&this.openDragLock&&(this.openDragLock(),this.openDragLock=null),r&&r.setActive("whileDrag",!1)}endPanSession(){this.panSession&&this.panSession.end(),this.panSession=void 0}updateAxis(t,r,i){const{drag:s}=this.getProps();if(!i||!Ol(t,s,this.currentDirection))return;const u=this.getAxisMotionValue(t);let c=this.originPoint[t]+i[t];this.constraints&&this.constraints[t]&&(c=kP(c,this.constraints[t],this.elastic[t])),u.set(c)}resolveConstraints(){const{dragConstraints:t,dragElastic:r}=this.getProps(),i=this.visualElement.projection&&!this.visualElement.projection.layout?this.visualElement.projection.measure(!1):this.visualElement.projection?.layout,s=this.constraints;t&&ai(t)?this.constraints||(this.constraints=this.resolveRefConstraints()):t&&i?this.constraints=_P(i.layoutBox,t):this.constraints=!1,this.elastic=CP(r),s!==this.constraints&&!ai(t)&&i&&this.constraints&&!this.hasMutatedConstraints&&Dn(u=>{this.constraints!==!1&&this.getAxisMotionValue(u)&&(this.constraints[u]=NP(i.layoutBox[u],this.constraints[u]))})}resolveRefConstraints(){const{dragConstraints:t,onMeasureDragConstraints:r}=this.getProps();if(!t||!ai(t))return!1;const i=t.current,{projection:s}=this.visualElement;if(!s||!s.layout)return!1;const u=UB(i,s.root,this.visualElement.getTransformPagePoint());let c=RP(s.layout.layoutBox,u);if(r){const d=r(DB(c));this.hasMutatedConstraints=!!d,d&&(c=nx(d))}return c}startAnimation(t){const{drag:r,dragMomentum:i,dragElastic:s,dragTransition:u,dragSnapToOrigin:c,onDragTransitionEnd:d}=this.getProps(),g=this.constraints||{},p=Dn(h=>{if(!Ol(h,r,this.currentDirection))return;let b=g&&g[h]||{};c&&(b={min:0,max:0});const y=s?200:1e6,E=s?40:1e7,T={type:"inertia",velocity:i?t[h]:0,bounceStiffness:y,bounceDamping:E,timeConstant:750,restDelta:1,restSpeed:10,...u,...b};return this.startAxisValueAnimation(h,T)});return Promise.all(p).then(d)}startAxisValueAnimation(t,r){const i=this.getAxisMotionValue(t);return Qp(this.visualElement,t),i.start(qy(t,i,0,r,this.visualElement,!1))}stopAnimation(){Dn(t=>this.getAxisMotionValue(t).stop())}getAxisMotionValue(t){const r=`_drag${t.toUpperCase()}`,i=this.visualElement.getProps(),s=i[r];return s||this.visualElement.getValue(t,(i.initial?i.initial[t]:void 0)||0)}snapToCursor(t){Dn(r=>{const{drag:i}=this.getProps();if(!Ol(r,i,this.currentDirection))return;const{projection:s}=this.visualElement,u=this.getAxisMotionValue(r);if(s&&s.layout){const{min:c,max:d}=s.layout.layoutBox[r],g=u.get()||0;u.set(t[r]-Je(c,d,.5)+g)}})}scalePositionWithinConstraints(){if(!this.visualElement.current)return;const{drag:t,dragConstraints:r}=this.getProps(),{projection:i}=this.visualElement;if(!ai(r)||!i||!this.constraints)return;this.stopAnimation();const s={x:0,y:0};Dn(c=>{const d=this.getAxisMotionValue(c);if(d&&this.constraints!==!1){const g=d.get();s[c]=xP({min:g,max:g},this.constraints[c])}});const{transformTemplate:u}=this.visualElement.getProps();this.visualElement.current.style.transform=u?u({},""):"none",i.root&&i.root.updateScroll(),i.updateLayout(),this.constraints=!1,this.resolveConstraints(),Dn(c=>{if(!Ol(c,t,null))return;const d=this.getAxisMotionValue(c),{min:g,max:p}=this.constraints[c];d.set(Je(g,p,s[c]))}),this.visualElement.render()}addListeners(){if(!this.visualElement.current)return;OP.set(this.visualElement,this);const t=this.visualElement.current,r=Lo(t,"pointerdown",p=>{const{drag:h,dragListener:b=!0}=this.getProps(),y=p.target,E=y!==t&&fB(y);h&&b&&!E&&this.start(p)});let i;const s=()=>{const{dragConstraints:p}=this.getProps();ai(p)&&p.current&&(this.constraints=this.resolveRefConstraints(),i||(i=DP(t,p.current,()=>this.scalePositionWithinConstraints())))},{projection:u}=this.visualElement,c=u.addEventListener("measure",s);u&&!u.layout&&(u.root&&u.root.updateScroll(),u.updateLayout()),Xe.read(s);const d=Vo(window,"resize",()=>this.scalePositionWithinConstraints()),g=u.addEventListener("didUpdate",(({delta:p,hasLayoutChanged:h})=>{this.isDragging&&h&&(Dn(b=>{const y=this.getAxisMotionValue(b);y&&(this.originPoint[b]+=p[b].translate,y.set(y.get()+p[b].translate))}),this.visualElement.render())}));return()=>{d(),r(),c(),g&&g(),i&&i()}}getProps(){const t=this.visualElement.getProps(),{drag:r=!1,dragDirectionLock:i=!1,dragPropagation:s=!1,dragConstraints:u=!1,dragElastic:c=uf,dragMomentum:d=!0}=t;return{...t,drag:r,dragDirectionLock:i,dragPropagation:s,dragConstraints:u,dragElastic:c,dragMomentum:d}}}function _k(e){let t=!0;return()=>{if(t){t=!1;return}e()}}function DP(e,t,r){const i=Dw(e,_k(r)),s=Dw(t,_k(r));return()=>{i(),s()}}function Ol(e,t,r){return(t===!0||t===e)&&(r===null||r===e)}function LP(e,t=10){let r=null;return Math.abs(e.y)>t?r="y":Math.abs(e.x)>t&&(r="x"),r}class MP extends Ba{constructor(t){super(t),this.removeGroupControls=hn,this.removeListeners=hn,this.controls=new IP(t)}mount(){const{dragControls:t}=this.node.getProps();t&&(this.removeGroupControls=t.subscribe(this.controls)),this.removeListeners=this.controls.addListeners()||hn}update(){const{dragControls:t}=this.node.getProps(),{dragControls:r}=this.node.prevProps||{};t!==r&&(this.removeGroupControls(),t&&(this.removeGroupControls=t.subscribe(this.controls)))}unmount(){this.removeGroupControls(),this.removeListeners(),this.controls.isDragging||this.controls.endPanSession()}}const Sp=e=>(t,r)=>{e&&Xe.update(()=>e(t,r),!1,!0)};class UP extends Ba{constructor(){super(...arguments),this.removePointerDownListener=hn}onPointerDown(t){this.session=new Lx(t,this.createPanHandlers(),{transformPagePoint:this.node.getTransformPagePoint(),contextWindow:Dx(this.node)})}createPanHandlers(){const{onPanSessionStart:t,onPanStart:r,onPan:i,onPanEnd:s}=this.node.getProps();return{onSessionStart:Sp(t),onStart:Sp(r),onMove:Sp(i),onEnd:(u,c)=>{delete this.session,s&&Xe.postRender(()=>s(u,c))}}}mount(){this.removePointerDownListener=Lo(this.node.current,"pointerdown",t=>this.onPointerDown(t))}update(){this.session&&this.session.updateHandlers(this.createPanHandlers())}unmount(){this.removePointerDownListener(),this.session&&this.session.end()}}let Tp=!1;class FP extends X.Component{componentDidMount(){const{visualElement:t,layoutGroup:r,switchLayoutGroup:i,layoutId:s}=this.props,{projection:u}=t;u&&(r.group&&r.group.add(u),i&&i.register&&s&&i.register(u),Tp&&u.root.didUpdate(),u.addEventListener("animationComplete",()=>{this.safeToRemove()}),u.setOptions({...u.options,layoutDependency:this.props.layoutDependency,onExitComplete:()=>this.safeToRemove()})),Gl.hasEverUpdated=!0}getSnapshotBeforeUpdate(t){const{layoutDependency:r,visualElement:i,drag:s,isPresent:u}=this.props,{projection:c}=i;return c&&(c.isPresent=u,t.layoutDependency!==r&&c.setOptions({...c.options,layoutDependency:r}),Tp=!0,s||t.layoutDependency!==r||r===void 0||t.isPresent!==u?c.willUpdate():this.safeToRemove(),t.isPresent!==u&&(u?c.promote():c.relegate()||Xe.postRender(()=>{const d=c.getStack();(!d||!d.members.length)&&this.safeToRemove()}))),null}componentDidUpdate(){const{projection:t}=this.props.visualElement;t&&(t.root.didUpdate(),Ky.postRender(()=>{!t.currentAnimation&&t.isLead()&&this.safeToRemove()}))}componentWillUnmount(){const{visualElement:t,layoutGroup:r,switchLayoutGroup:i}=this.props,{projection:s}=t;Tp=!0,s&&(s.scheduleCheckAfterUnmount(),r&&r.group&&r.group.remove(s),i&&i.deregister&&i.deregister(s))}safeToRemove(){const{safeToRemove:t}=this.props;t&&t()}render(){return null}}function Ux(e){const[t,r]=wx(),i=X.useContext(Ny);return Y.jsx(FP,{...e,layoutGroup:i,switchLayoutGroup:X.useContext(Ox),isPresent:t,safeToRemove:r})}const BP={pan:{Feature:UP},drag:{Feature:MP,ProjectionNode:Ax,MeasureLayout:Ux}};function Rk(e,t,r){const{props:i}=e;e.animationState&&i.whileHover&&e.animationState.setActive("whileHover",r==="Start");const s="onHover"+r,u=i[s];u&&Xe.postRender(()=>u(t,as(t)))}class zP extends Ba{mount(){const{current:t}=this.node;t&&(this.unmount=uB(t,(r,i)=>(Rk(this.node,i,"Start"),s=>Rk(this.node,s,"End"))))}unmount(){}}class PP extends Ba{constructor(){super(...arguments),this.isActive=!1}onFocus(){let t=!1;try{t=this.node.current.matches(":focus-visible")}catch{t=!0}!t||!this.node.animationState||(this.node.animationState.setActive("whileFocus",!0),this.isActive=!0)}onBlur(){!this.isActive||!this.node.animationState||(this.node.animationState.setActive("whileFocus",!1),this.isActive=!1)}mount(){this.unmount=es(Vo(this.node.current,"focus",()=>this.onFocus()),Vo(this.node.current,"blur",()=>this.onBlur()))}unmount(){}}function xk(e,t,r){const{props:i}=e;if(e.current instanceof HTMLButtonElement&&e.current.disabled)return;e.animationState&&i.whileTap&&e.animationState.setActive("whileTap",r==="Start");const s="onTap"+(r==="End"?"":r),u=i[s];u&&Xe.postRender(()=>u(t,as(t)))}class GP extends Ba{mount(){const{current:t}=this.node;if(!t)return;const{globalTapTarget:r,propagate:i}=this.node.props;this.unmount=mB(t,(s,u)=>(xk(this.node,u,"Start"),(c,{success:d})=>xk(this.node,c,d?"End":"Cancel")),{useGlobalTarget:r,stopPropagation:i?.tap===!1})}unmount(){}}const cf=new WeakMap,vp=new WeakMap,jP=e=>{const t=cf.get(e.target);t&&t(e)},HP=e=>{e.forEach(jP)};function VP({root:e,...t}){const r=e||document;vp.has(r)||vp.set(r,{});const i=vp.get(r),s=JSON.stringify(t);return i[s]||(i[s]=new IntersectionObserver(HP,{root:e,...t})),i[s]}function $P(e,t,r){const i=VP(t);return cf.set(e,r),i.observe(e),()=>{cf.delete(e),i.unobserve(e)}}const qP={some:0,all:1};class YP extends Ba{constructor(){super(...arguments),this.hasEnteredView=!1,this.isInView=!1}startObserver(){this.unmount();const{viewport:t={}}=this.node.getProps(),{root:r,margin:i,amount:s="some",once:u}=t,c={root:r?r.current:void 0,rootMargin:i,threshold:typeof s=="number"?s:qP[s]},d=g=>{const{isIntersecting:p}=g;if(this.isInView===p||(this.isInView=p,u&&!p&&this.hasEnteredView))return;p&&(this.hasEnteredView=!0),this.node.animationState&&this.node.animationState.setActive("whileInView",p);const{onViewportEnter:h,onViewportLeave:b}=this.node.getProps(),y=p?h:b;y&&y(g)};return $P(this.node.current,c,d)}mount(){this.startObserver()}update(){if(typeof IntersectionObserver>"u")return;const{props:t,prevProps:r}=this.node;["amount","margin","root"].some(WP(t,r))&&this.startObserver()}unmount(){}}function WP({viewport:e={}},{viewport:t={}}={}){return r=>e[r]!==t[r]}const XP={inView:{Feature:YP},tap:{Feature:GP},focus:{Feature:PP},hover:{Feature:zP}},KP={layout:{ProjectionNode:Ax,MeasureLayout:Ux}},ZP={...SP,...XP,...BP,...KP},jl=mP(ZP,hP);function QP({images:e,index:t,onClose:r,onNavigate:i}){const s=X.useCallback(()=>{t>0&&i(t-1)},[t,i]),u=X.useCallback(()=>{t<e.length-1&&i(t+1)},[t,e.length,i]);return X.useEffect(()=>{const c=d=>{d.key==="Escape"&&r(),d.key==="ArrowLeft"&&s(),d.key==="ArrowRight"&&u()};return window.addEventListener("keydown",c),()=>window.removeEventListener("keydown",c)},[r,s,u]),Y.jsx(lf,{children:Y.jsxs(jl.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.15},className:"fixed inset-0 z-50 flex items-center justify-center bg-black/90",onClick:r,children:[Y.jsx("button",{onClick:r,className:"absolute top-4 right-4 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:Y.jsx(Ok,{className:"h-5 w-5"})}),e.length>1&&Y.jsxs("div",{className:"absolute top-4 left-1/2 -translate-x-1/2 text-white/70 text-sm tabular-nums",children:[t+1," / ",e.length]}),t>0&&Y.jsx("button",{onClick:c=>{c.stopPropagation(),s()},className:"absolute left-3 top-1/2 -translate-y-1/2 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:Y.jsx(hO,{className:"h-6 w-6"})}),t<e.length-1&&Y.jsx("button",{onClick:c=>{c.stopPropagation(),u()},className:"absolute right-3 top-1/2 -translate-y-1/2 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:Y.jsx(yO,{className:"h-6 w-6"})}),Y.jsx("img",{src:e[t],alt:"",className:"max-h-[85vh] max-w-[90vw] object-contain rounded-lg",onClick:c=>c.stopPropagation()})]})})}function JP({messages:e,streaming:t,streamBuffer:r,tools:i}){const s=X.useRef(null),[u,c]=X.useState(null),d=X.useCallback((h,b)=>{c({images:h,index:b})},[]);X.useEffect(()=>{s.current?.scrollIntoView({behavior:"smooth"})},[e,r,i,t]);const g=i.length>0?i[i.length-1]:null,p=g?.status==="running"?g.name:void 0;return Y.jsxs("div",{className:"flex-1 overflow-y-auto overflow-x-hidden p-4 flex flex-col min-h-0",children:[Y.jsx("div",{className:"flex-1"}),e.length===0&&!t&&Y.jsx("div",{className:"flex items-center justify-center py-8 text-muted-foreground text-sm",children:"Start a conversation"}),Y.jsxs("div",{className:"space-y-3",children:[e.map(h=>Y.jsx(nU,{role:h.role,content:h.content,timestamp:h.timestamp,hasAttachments:h.hasAttachments,audioData:h.audioData,attachments:h.attachments,onImageClick:d},h.id)),t&&Y.jsx(rU,{text:r,toolName:p})]}),Y.jsx("div",{ref:s}),u&&Y.jsx(QP,{images:u.images,index:u.index,onClose:()=>c(null),onNavigate:h=>c(b=>b?{...b,index:h}:null)})]})}function eG(e){const t=Math.floor(e/60),r=e%60;return`${t}:${r.toString().padStart(2,"0")}`}function tG(e,t=4*1024*1024){return new Promise(r=>{const i=new Image;i.onload=()=>{let{width:u,height:c}=i;if(u>1600||c>1600){const p=Math.min(1600/u,1600/c);u=Math.round(u*p),c=Math.round(c*p)}const d=document.createElement("canvas");d.width=u,d.height=c,d.getContext("2d").drawImage(i,0,0,u,c);for(const p of[.8,.6,.4,.3]){const h=d.toDataURL("image/jpeg",p);if(Math.round((h.length-23)*.75)<=t){r(h);return}}r(d.toDataURL("image/jpeg",.2))},i.onerror=()=>r(e),i.src=e})}function nG({onSend:e,onStop:t,streaming:r,whisperEnabled:i}){const[s,u]=X.useState(""),[c,d]=X.useState([]),[g,p]=X.useState(!1),[h,b]=X.useState(0),E=s.trim().length>0||c.length>0,T=X.useRef(null),x=X.useRef(null),k=X.useRef(null),A=X.useRef(null),O=X.useRef(null),C=X.useRef(0),F=X.useRef(0),B=X.useRef(null),D=X.useRef(!1),$=X.useRef(null),q=X.useRef(null),te=X.useRef([]),M=X.useRef(null);X.useEffect(()=>{const _=T.current;_&&(_.style.height="0px",_.style.height=`${Math.min(_.scrollHeight,88)}px`)},[s]),X.useEffect(()=>{if(g)return $.current=setInterval(()=>b(_=>_+1),1e3),()=>{$.current&&clearInterval($.current)}},[g]);const ee=X.useCallback(_=>{$.current&&clearInterval($.current),B.current&&(clearTimeout(B.current),B.current=null),D.current=!1;const N=q.current,j=M.current;_||!N||N.state==="inactive"?(j?.getTracks().forEach(R=>R.stop()),q.current=null,M.current=null,te.current=[]):(N.onstop=async()=>{j?.getTracks().forEach(fe=>fe.stop());const R=new Blob(te.current,{type:"audio/webm"});if(te.current=[],q.current=null,M.current=null,R.size<1e3)return;const le=new FileReader;le.onloadend=async()=>{const fe=le.result,pe=fe.split(",")[1];if(pe)try{const Ue=await(await fetch("/api/whisper/transcribe",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({audio:pe})})).json();Ue.transcript?.trim()&&e(Ue.transcript.trim(),void 0,fe)}catch{}},le.readAsDataURL(R)},N.stop()),O.current&&(O.current.style.transform=""),p(!1),b(0),F.current=0},[e]),ne=X.useCallback(_=>{const N=_.type.startsWith("image/"),j=_.type==="application/pdf";if(!N&&!j)return;const R=new FileReader;R.onload=async le=>{let fe=le.target?.result;N&&(fe=await tG(fe)),d(pe=>[...pe,{id:Math.random().toString(36).slice(2),type:N?"image":"file",name:_.name,preview:fe}])},R.readAsDataURL(_)},[]),ie=X.useCallback(_=>{const N=_.target.files;if(N){for(let j=0;j<N.length;j++)ne(N[j]);_.target.value=""}},[ne]),oe=X.useCallback(_=>{d(N=>N.filter(j=>j.id!==_))},[]);X.useEffect(()=>{const _=N=>{if(N.clipboardData?.items){for(const j of N.clipboardData.items)if(j.type.startsWith("image/")){N.preventDefault();const R=j.getAsFile();R&&ne(R)}}};return document.addEventListener("paste",_),()=>document.removeEventListener("paste",_)},[ne]);const ae=()=>{E&&(e(s,c.length>0?c:void 0),u(""),d([]),requestAnimationFrame(()=>T.current?.focus()))},z=X.useCallback(_=>{_.preventDefault(),C.current=_.clientX,F.current=0,_.currentTarget.setPointerCapture(_.pointerId),B.current=setTimeout(async()=>{if(i)try{const N=await navigator.mediaDevices.getUserMedia({audio:!0});M.current=N;const j=MediaRecorder.isTypeSupported("audio/webm;codecs=opus")?"audio/webm;codecs=opus":"audio/webm",R=new MediaRecorder(N,{mimeType:j});te.current=[],R.ondataavailable=le=>{le.data.size>0&&te.current.push(le.data)},q.current=R,R.start(),D.current=!0,p(!0),b(0)}catch{}},200)},[]),W=X.useCallback(_=>{if(!D.current)return;const N=Math.min(0,_.clientX-C.current);if(F.current=N,O.current&&(O.current.style.transform=`translateX(${N}px)`),A.current){const j=A.current.getBoundingClientRect(),R=j.left+j.width/2;Math.abs(_.clientX-R)<36&&ee(!0)}},[ee]),se=X.useCallback(()=>{B.current&&(clearTimeout(B.current),B.current=null),D.current&&ee(!1)},[ee]),ge=X.useCallback(()=>{B.current&&(clearTimeout(B.current),B.current=null),D.current&&ee(!0)},[ee]);return Y.jsxs("div",{className:"shrink-0 p-3 relative",children:[Y.jsxs("div",{className:`flex flex-col transition-opacity duration-100 ${g?"opacity-0 pointer-events-none":"opacity-100"}`,children:[Y.jsx(lf,{children:c.length>0&&Y.jsx(jl.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},transition:{duration:.15},className:"overflow-hidden",children:Y.jsx("div",{className:"flex gap-2 px-3 pt-2.5 pb-2 flex-wrap bg-white/[0.04] border border-white/[0.08] rounded-2xl mb-2",children:c.map(_=>Y.jsxs("div",{className:"relative group flex-shrink-0",children:[_.type==="image"?Y.jsx("img",{src:_.preview,alt:_.name,className:"w-14 h-14 rounded-lg object-cover border border-white/10"}):Y.jsxs("div",{className:"w-14 h-14 rounded-lg bg-white/5 border border-white/10 flex flex-col items-center justify-center gap-0.5 px-1",children:[Y.jsx("svg",{className:"w-5 h-5 text-muted-foreground",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:1.5,children:Y.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M19.5 14.25v-2.625a3.375 3.375 0 00-3.375-3.375h-1.5A1.125 1.125 0 0113.5 7.125v-1.5a3.375 3.375 0 00-3.375-3.375H8.25m2.25 0H5.625c-.621 0-1.125.504-1.125 1.125v17.25c0 .621.504 1.125 1.125 1.125h12.75c.621 0 1.125-.504 1.125-1.125V11.25a9 9 0 00-9-9z"})}),Y.jsx("span",{className:"text-[8px] text-muted-foreground truncate w-full text-center",children:_.name.split(".").pop()})]}),Y.jsx("button",{onClick:()=>oe(_.id),className:"absolute -top-1.5 -right-1.5 w-4 h-4 bg-black/80 border border-white/20 rounded-full flex items-center justify-center opacity-0 group-hover:opacity-100 transition-opacity",children:Y.jsx(Ok,{className:"w-2.5 h-2.5 text-white"})})]},_.id))})})}),Y.jsxs("div",{className:"flex items-end gap-2",children:[Y.jsxs("div",{className:"flex-1 flex items-end bg-white rounded-2xl px-4",children:[Y.jsx("textarea",{ref:T,value:s,onChange:_=>u(_.target.value),placeholder:"Type a message...",rows:1,className:"flex-1 resize-none bg-transparent text-gray-900 py-3 text-sm outline-none placeholder:text-gray-400 overflow-y-auto",style:{maxHeight:88}}),Y.jsx("input",{ref:x,type:"file",className:"hidden",accept:"image/*,.pdf",multiple:!0,onChange:ie}),Y.jsx("input",{ref:k,type:"file",className:"hidden",accept:"image/*",capture:"environment",onChange:ie}),Y.jsx("button",{type:"button",onClick:()=>x.current?.click(),className:"shrink-0 p-1.5 mb-2 text-gray-400 hover:text-gray-600 transition-colors",children:Y.jsx(Ap,{className:"h-4 w-4"})}),Y.jsx("button",{type:"button",onClick:()=>k.current?.click(),className:"shrink-0 p-1.5 mb-2 text-gray-400 hover:text-gray-600 transition-colors",children:Y.jsx(gO,{className:"h-4 w-4"})})]}),r?Y.jsx("button",{onClick:t,className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-destructive text-destructive-foreground transition-colors",children:Y.jsx(xO,{className:"h-4 w-4"})}):E?Y.jsx("button",{onClick:ae,className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-white text-gray-900 transition-colors hover:bg-gray-100",children:Y.jsx(_O,{className:"h-4 w-4"})}):Y.jsx("div",{className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-white text-gray-900 transition-colors hover:bg-gray-100 cursor-pointer touch-none select-none",onPointerDown:z,onPointerMove:W,onPointerUp:se,onPointerCancel:ge,children:Y.jsx(fA,{className:"h-4 w-4"})})]})]}),Y.jsx(lf,{children:g&&Y.jsx(jl.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.1},className:"absolute inset-0 p-3 flex items-center touch-none",children:Y.jsxs("div",{className:"flex items-center w-full gap-2",children:[Y.jsxs("div",{className:"flex items-center gap-2 shrink-0",children:[Y.jsxs("span",{className:"relative flex h-2 w-2 shrink-0",children:[Y.jsx("span",{className:"animate-ping absolute inline-flex h-full w-full rounded-full bg-destructive opacity-75"}),Y.jsx("span",{className:"relative inline-flex rounded-full h-2 w-2 bg-destructive"})]}),Y.jsx("span",{className:"text-sm font-medium tabular-nums",children:eG(h)})]}),Y.jsxs("div",{className:"flex-1 flex items-center bg-muted rounded-full h-12 pl-1 pr-0.5",children:[Y.jsx("div",{ref:A,className:"flex items-center justify-center h-9 w-9 shrink-0 rounded-full bg-destructive/10 text-destructive",children:Y.jsx(Ck,{className:"h-4 w-4"})}),Y.jsx("div",{className:"flex-1 flex justify-center min-w-0",children:Y.jsx(jl.span,{className:"text-[13px] whitespace-nowrap select-none font-medium",style:{backgroundImage:"linear-gradient(90deg, #999 0%, #999 35%, #fff 50%, #999 65%, #999 100%)",backgroundSize:"200% 100%",WebkitBackgroundClip:"text",WebkitTextFillColor:"transparent",backgroundClip:"text"},animate:{backgroundPosition:["200% center","-200% center"]},transition:{duration:2.5,repeat:1/0,ease:"linear"},children:"◄◄ slide to cancel"})}),Y.jsx("div",{ref:O,className:"shrink-0 touch-none select-none will-change-transform",style:{transition:"none"},onPointerDown:z,onPointerMove:W,onPointerUp:se,onPointerCancel:ge,children:Y.jsx("div",{className:"flex items-center justify-center h-11 w-11 rounded-full bg-destructive text-destructive-foreground",children:Y.jsx(fA,{className:"h-5 w-5"})})})]})]})})})]})}function aG(){const e=X.useRef(null),[t,r]=X.useState(!1),[i,s]=X.useState("Fluxy"),[u,c]=X.useState(!1);X.useEffect(()=>{const T=location.protocol==="https:"?"wss:":"ws:",x=location.host,k=new pf(`${T}//${x}/fluxy/ws`);e.current=k;const A=k.onStatus(r),O=k.on("app:rebuilding",()=>{window.parent?.postMessage({type:"fluxy:rebuilding"},"*")}),C=k.on("app:rebuilt",()=>{window.parent?.postMessage({type:"fluxy:rebuilt"},"*")}),F=k.on("app:build-error",B=>{window.parent?.postMessage({type:"fluxy:build-error",error:B.error},"*")});return k.connect(),()=>{A(),O(),C(),F(),k.disconnect()}},[]),X.useEffect(()=>{fetch("/api/settings").then(T=>T.json()).then(T=>{T.agent_name&&s(T.agent_name),T.whisper_enabled==="true"&&c(!0)}).catch(()=>{})},[]);const{messages:d,streaming:g,streamBuffer:p,tools:h,sendMessage:b,stopStreaming:y,clearContext:E}=DO(e.current);return Y.jsxs("div",{className:"flex flex-col h-dvh overflow-hidden",children:[Y.jsxs("div",{className:"flex items-center gap-3 px-4 py-3 border-b border-border shrink-0",children:[Y.jsx("img",{src:"/fluxy.png",alt:i,className:"h-5 w-auto"}),Y.jsx("span",{className:"text-sm font-semibold",children:i}),Y.jsx("div",{className:`h-2 w-2 rounded-full ${t?"bg-green-500":"bg-red-500"}`}),Y.jsx("div",{className:"flex-1"}),Y.jsx("button",{onClick:E,className:"flex items-center justify-center h-7 w-7 rounded-full text-muted-foreground hover:text-foreground hover:bg-white/[0.06] transition-colors",title:"Clear context",children:Y.jsx(Ck,{className:"h-4 w-4"})})]}),Y.jsxs("div",{className:"flex-1 min-h-0 flex flex-col overflow-hidden",children:[Y.jsx(JP,{messages:d,streaming:g,streamBuffer:p,tools:h}),Y.jsx(nG,{onSend:b,onStop:y,streaming:g,whisperEnabled:u})]})]})}sO.createRoot(document.getElementById("root")).render(Y.jsx(ra.StrictMode,{children:Y.jsx(aG,{})}));
53
+ `),()=>{B.contains(F)&&B.removeChild(F)}},[t]),Y.jsx(Gz,{isPresent:t,childRef:d,sizeRef:g,pop:u,children:u===!1?e:X.cloneElement(e,{ref:b})})}const Hz=({children:e,initial:t,isPresent:r,onExitComplete:i,custom:s,presenceAffectsLayout:u,mode:c,anchorX:d,anchorY:g,root:p})=>{const h=Cy(Vz),b=X.useId();let y=!0,E=X.useMemo(()=>(y=!1,{id:b,initial:t,isPresent:r,custom:s,onExitComplete:T=>{h.set(T,!0);for(const x of h.values())if(!x)return;i&&i()},register:T=>(h.set(T,!1),()=>h.delete(T))}),[r,h,i]);return u&&y&&(E={...E}),X.useMemo(()=>{h.forEach((T,x)=>h.set(x,!1))},[r]),X.useEffect(()=>{!r&&!h.size&&i&&i()},[r]),e=Y.jsx(jz,{pop:c==="popLayout",isPresent:r,anchorX:d,anchorY:g,root:p,children:e}),Y.jsx(bu.Provider,{value:E,children:e})};function Vz(){return new Map}function wx(e=!0){const t=X.useContext(bu);if(t===null)return[!0,null];const{isPresent:r,onExitComplete:i,register:s}=t,u=X.useId();X.useEffect(()=>{if(e)return s(u)},[e]);const c=X.useCallback(()=>e&&i&&i(u),[u,i,e]);return!r&&i?[!1,c]:[!0]}const Cl=e=>e.key||"";function mk(e){const t=[];return X.Children.forEach(e,r=>{X.isValidElement(r)&&t.push(r)}),t}const lf=({children:e,custom:t,initial:r=!0,onExitComplete:i,presenceAffectsLayout:s=!0,mode:u="sync",propagate:c=!1,anchorX:d="left",anchorY:g="top",root:p})=>{const[h,b]=wx(c),y=X.useMemo(()=>mk(e),[e]),E=c&&!h?[]:y.map(Cl),T=X.useRef(!0),x=X.useRef(y),k=Cy(()=>new Map),A=X.useRef(new Set),[O,C]=X.useState(y),[F,B]=X.useState(y);Q_(()=>{T.current=!1,x.current=y;for(let q=0;q<F.length;q++){const te=Cl(F[q]);E.includes(te)?(k.delete(te),A.current.delete(te)):k.get(te)!==!0&&k.set(te,!1)}},[F,E.length,E.join("-")]);const D=[];if(y!==O){let q=[...y];for(let te=0;te<F.length;te++){const M=F[te],ee=Cl(M);E.includes(ee)||(q.splice(te,0,M),D.push(M))}return u==="wait"&&D.length&&(q=D),B(mk(q)),C(y),null}const{forceRender:$}=X.useContext(Ny);return Y.jsx(Y.Fragment,{children:F.map(q=>{const te=Cl(q),M=c&&!h?!1:y===F||E.includes(te),ee=()=>{if(A.current.has(te))return;if(A.current.add(te),k.has(te))k.set(te,!0);else return;let ne=!0;k.forEach(ie=>{ie||(ne=!1)}),ne&&($?.(),B(x.current),c&&b?.(),i&&i())};return Y.jsx(Hz,{isPresent:M,initial:!T.current||r?void 0:!1,custom:t,presenceAffectsLayout:s,mode:u,root:p,onExitComplete:M?void 0:ee,anchorX:d,anchorY:g,children:q},te)})})},kx=X.createContext({strict:!1}),hk={animation:["animate","variants","whileHover","whileTap","exit","whileInView","whileFocus","whileDrag"],exit:["exit"],drag:["drag","dragControls"],focus:["whileFocus"],hover:["whileHover","onHoverStart","onHoverEnd"],tap:["whileTap","onTap","onTapStart","onTapCancel"],pan:["onPan","onPanStart","onPanSessionStart","onPanEnd"],inView:["whileInView","onViewportEnter","onViewportLeave"],layout:["layout","layoutId"]};let bk=!1;function $z(){if(bk)return;const e={};for(const t in hk)e[t]={isEnabled:r=>hk[t].some(i=>!!r[i])};ex(e),bk=!0}function _x(){return $z(),OB()}function qz(e){const t=_x();for(const r in e)t[r]={...t[r],...e[r]};ex(t)}const Yz=new Set(["animate","exit","variants","initial","style","values","variants","transition","transformTemplate","custom","inherit","onBeforeLayoutMeasure","onAnimationStart","onAnimationComplete","onUpdate","onDragStart","onDrag","onDragEnd","onMeasureDragConstraints","onDirectionLock","onDragTransitionEnd","_dragX","_dragY","onHoverStart","onHoverEnd","onViewportEnter","onViewportLeave","globalTapTarget","propagate","ignoreStrict","viewport"]);function eu(e){return e.startsWith("while")||e.startsWith("drag")&&e!=="draggable"||e.startsWith("layout")||e.startsWith("onTap")||e.startsWith("onPan")||e.startsWith("onLayout")||Yz.has(e)}let Rx=e=>!eu(e);function Wz(e){typeof e=="function"&&(Rx=t=>t.startsWith("on")?!eu(t):e(t))}try{Wz(require("@emotion/is-prop-valid").default)}catch{}function Xz(e,t,r){const i={};for(const s in e)s==="values"&&typeof e.values=="object"||(Rx(s)||r===!0&&eu(s)||!t&&!eu(s)||e.draggable&&s.startsWith("onDrag"))&&(i[s]=e[s]);return i}const Su=X.createContext({});function Kz(e,t){if(Eu(e)){const{initial:r,animate:i}=e;return{initial:r===!1||Ho(r)?r:void 0,animate:Ho(i)?i:void 0}}return e.inherit!==!1?t:{}}function Zz(e){const{initial:t,animate:r}=Kz(e,X.useContext(Su));return X.useMemo(()=>({initial:t,animate:r}),[yk(t),yk(r)])}function yk(e){return Array.isArray(e)?e.join(" "):e}const rE=()=>({style:{},transform:{},transformOrigin:{},vars:{}});function xx(e,t,r){for(const i in t)!_t(t[i])&&!sx(i,r)&&(e[i]=t[i])}function Qz({transformTemplate:e},t){return X.useMemo(()=>{const r=rE();return tE(r,t,e),Object.assign({},r.vars,r.style)},[t])}function Jz(e,t){const r=e.style||{},i={};return xx(i,r,e),Object.assign(i,Qz(e,t)),i}function eP(e,t){const r={},i=Jz(e,t);return e.drag&&e.dragListener!==!1&&(r.draggable=!1,i.userSelect=i.WebkitUserSelect=i.WebkitTouchCallout="none",i.touchAction=e.drag===!0?"none":`pan-${e.drag==="x"?"y":"x"}`),e.tabIndex===void 0&&(e.onTap||e.onTapStart||e.whileTap)&&(r.tabIndex=0),r.style=i,r}const Nx=()=>({...rE(),attrs:{}});function tP(e,t,r,i){const s=X.useMemo(()=>{const u=Nx();return lx(u,t,cx(i),e.transformTemplate,e.style),{...u.attrs,style:{...u.style}}},[t]);if(e.style){const u={};xx(u,e.style,e),s.style={...u,...s.style}}return s}const nP=["animate","circle","defs","desc","ellipse","g","image","line","filter","marker","mask","metadata","path","pattern","polygon","polyline","rect","stop","switch","symbol","svg","text","tspan","use","view"];function iE(e){return typeof e!="string"||e.includes("-")?!1:!!(nP.indexOf(e)>-1||/[A-Z]/u.test(e))}function aP(e,t,r,{latestValues:i},s,u=!1,c){const g=(c??iE(e)?tP:eP)(t,i,s,e),p=Xz(t,typeof e=="string",u),h=e!==X.Fragment?{...p,...g,ref:r}:{},{children:b}=t,y=X.useMemo(()=>_t(b)?b.get():b,[b]);return X.createElement(e,{...h,children:y})}function rP({scrapeMotionValuesFromProps:e,createRenderState:t},r,i,s){return{latestValues:iP(r,i,s,e),renderState:t()}}function iP(e,t,r,i){const s={},u=i(e,{});for(const y in u)s[y]=Pl(u[y]);let{initial:c,animate:d}=e;const g=Eu(e),p=QR(e);t&&p&&!g&&e.inherit!==!1&&(c===void 0&&(c=t.initial),d===void 0&&(d=t.animate));let h=r?r.initial===!1:!1;h=h||c===!1;const b=h?d:c;if(b&&typeof b!="boolean"&&!yu(b)){const y=Array.isArray(b)?b:[b];for(let E=0;E<y.length;E++){const T=Yy(e,y[E]);if(T){const{transitionEnd:x,transition:k,...A}=T;for(const O in A){let C=A[O];if(Array.isArray(C)){const F=h?C.length-1:0;C=C[F]}C!==null&&(s[O]=C)}for(const O in x)s[O]=x[O]}}}return s}const Cx=e=>(t,r)=>{const i=X.useContext(Su),s=X.useContext(bu),u=()=>rP(e,t,i,s);return r?u():Cy(u)},oP=Cx({scrapeMotionValuesFromProps:nE,createRenderState:rE}),sP=Cx({scrapeMotionValuesFromProps:dx,createRenderState:Nx}),lP=Symbol.for("motionComponentSymbol");function uP(e,t,r){const i=X.useRef(r);X.useInsertionEffect(()=>{i.current=r});const s=X.useRef(null);return X.useCallback(u=>{u&&e.onMount?.(u),t&&(u?t.mount(u):t.unmount());const c=i.current;if(typeof c=="function")if(u){const d=c(u);typeof d=="function"&&(s.current=d)}else s.current?(s.current(),s.current=null):c(u);else c&&(c.current=u)},[t])}const Ox=X.createContext({});function ai(e){return e&&typeof e=="object"&&Object.prototype.hasOwnProperty.call(e,"current")}function cP(e,t,r,i,s,u){const{visualElement:c}=X.useContext(Su),d=X.useContext(kx),g=X.useContext(bu),p=X.useContext(aE),h=p.reducedMotion,b=p.skipAnimations,y=X.useRef(null),E=X.useRef(!1);i=i||d.renderer,!y.current&&i&&(y.current=i(e,{visualState:t,parent:c,props:r,presenceContext:g,blockInitialAnimation:g?g.initial===!1:!1,reducedMotionConfig:h,skipAnimations:b,isSVG:u}),E.current&&y.current&&(y.current.manuallyAnimateOnMount=!0));const T=y.current,x=X.useContext(Ox);T&&!T.projection&&s&&(T.type==="html"||T.type==="svg")&&dP(y.current,r,s,x);const k=X.useRef(!1);X.useInsertionEffect(()=>{T&&k.current&&T.update(r,g)});const A=r[zR],O=X.useRef(!!A&&!window.MotionHandoffIsComplete?.(A)&&window.MotionHasOptimisedAnimation?.(A));return Q_(()=>{E.current=!0,T&&(k.current=!0,window.MotionIsMounted=!0,T.updateFeatures(),T.scheduleRenderMicrotask(),O.current&&T.animationState&&T.animationState.animateChanges())}),X.useEffect(()=>{T&&(!O.current&&T.animationState&&T.animationState.animateChanges(),O.current&&(queueMicrotask(()=>{window.MotionHandoffMarkAsComplete?.(A)}),O.current=!1),T.enteringChildren=void 0)}),T}function dP(e,t,r,i){const{layoutId:s,layout:u,drag:c,dragConstraints:d,layoutScroll:g,layoutRoot:p,layoutCrossfade:h}=t;e.projection=new r(e.latestValues,t["data-framer-portal-id"]?void 0:Ix(e.parent)),e.projection.setOptions({layoutId:s,layout:u,alwaysMeasureLayout:!!c||d&&ai(d),visualElement:e,animationType:typeof u=="string"?u:"both",initialPromotionConfig:i,crossfade:h,layoutScroll:g,layoutRoot:p})}function Ix(e){if(e)return e.options.allowProjection!==!1?e.projection:Ix(e.parent)}function bp(e,{forwardMotionProps:t=!1,type:r}={},i,s){i&&qz(i);const u=r?r==="svg":iE(e),c=u?sP:oP;function d(p,h){let b;const y={...X.useContext(aE),...p,layoutId:pP(p)},{isStatic:E}=y,T=Zz(p),x=c(p,E);if(!E&&Z_){fP();const k=gP(y);b=k.MeasureLayout,T.visualElement=cP(e,x,y,s,k.ProjectionNode,u)}return Y.jsxs(Su.Provider,{value:T,children:[b&&T.visualElement?Y.jsx(b,{visualElement:T.visualElement,...y}):null,aP(e,p,uP(x,T.visualElement,h),x,E,t,u)]})}d.displayName=`motion.${typeof e=="string"?e:`create(${e.displayName??e.name??""})`}`;const g=X.forwardRef(d);return g[lP]=e,g}function pP({layoutId:e}){const t=X.useContext(Ny).id;return t&&e!==void 0?t+"-"+e:e}function fP(e,t){X.useContext(kx).strict}function gP(e){const t=_x(),{drag:r,layout:i}=t;if(!r&&!i)return{};const s={...r,...i};return{MeasureLayout:r?.isEnabled(e)||i?.isEnabled(e)?s.MeasureLayout:void 0,ProjectionNode:s.ProjectionNode}}function mP(e,t){if(typeof Proxy>"u")return bp;const r=new Map,i=(u,c)=>bp(u,c,e,t),s=(u,c)=>i(u,c);return new Proxy(s,{get:(u,c)=>c==="create"?i:(r.has(c)||r.set(c,bp(c,void 0,e,t)),r.get(c))})}const hP=(e,t)=>t.isSVG??iE(e)?new WB(t):new jB(t,{allowProjection:e!==X.Fragment});class bP extends Ba{constructor(t){super(t),t.animationState||(t.animationState=JB(t))}updateAnimationControlsSubscription(){const{animate:t}=this.node.getProps();yu(t)&&(this.unmountControls=t.subscribe(this.node))}mount(){this.updateAnimationControlsSubscription()}update(){const{animate:t}=this.node.getProps(),{animate:r}=this.node.prevProps||{};t!==r&&this.updateAnimationControlsSubscription()}unmount(){this.node.animationState.reset(),this.unmountControls?.()}}let yP=0;class EP extends Ba{constructor(){super(...arguments),this.id=yP++}update(){if(!this.node.presenceContext)return;const{isPresent:t,onExitComplete:r}=this.node.presenceContext,{isPresent:i}=this.node.prevPresenceContext||{};if(!this.node.animationState||t===i)return;const s=this.node.animationState.setActive("exit",!t);r&&!t&&s.then(()=>{r(this.id)})}mount(){const{register:t,onExitComplete:r}=this.node.presenceContext||{};r&&r(this.id),t&&(this.unmount=t(this.id))}unmount(){}}const SP={animation:{Feature:bP},exit:{Feature:EP}};function as(e){return{point:{x:e.pageX,y:e.pageY}}}const TP=e=>t=>Zy(t)&&e(t,as(t));function Lo(e,t,r,i){return Vo(e,t,TP(r),i)}const Dx=({current:e})=>e?e.ownerDocument.defaultView:null,Ek=(e,t)=>Math.abs(e-t);function vP(e,t){const r=Ek(e.x,t.x),i=Ek(e.y,t.y);return Math.sqrt(r**2+i**2)}const Sk=new Set(["auto","scroll"]);class Lx{constructor(t,r,{transformPagePoint:i,contextWindow:s=window,dragSnapToOrigin:u=!1,distanceThreshold:c=3,element:d}={}){if(this.startEvent=null,this.lastMoveEvent=null,this.lastMoveEventInfo=null,this.handlers={},this.contextWindow=window,this.scrollPositions=new Map,this.removeScrollListeners=null,this.onElementScroll=E=>{this.handleScroll(E.target)},this.onWindowScroll=()=>{this.handleScroll(window)},this.updatePoint=()=>{if(!(this.lastMoveEvent&&this.lastMoveEventInfo))return;const E=Ep(this.lastMoveEventInfo,this.history),T=this.startEvent!==null,x=vP(E.offset,{x:0,y:0})>=this.distanceThreshold;if(!T&&!x)return;const{point:k}=E,{timestamp:A}=vt;this.history.push({...k,timestamp:A});const{onStart:O,onMove:C}=this.handlers;T||(O&&O(this.lastMoveEvent,E),this.startEvent=this.lastMoveEvent),C&&C(this.lastMoveEvent,E)},this.handlePointerMove=(E,T)=>{this.lastMoveEvent=E,this.lastMoveEventInfo=yp(T,this.transformPagePoint),Xe.update(this.updatePoint,!0)},this.handlePointerUp=(E,T)=>{this.end();const{onEnd:x,onSessionEnd:k,resumeAnimation:A}=this.handlers;if((this.dragSnapToOrigin||!this.startEvent)&&A&&A(),!(this.lastMoveEvent&&this.lastMoveEventInfo))return;const O=Ep(E.type==="pointercancel"?this.lastMoveEventInfo:yp(T,this.transformPagePoint),this.history);this.startEvent&&x&&x(E,O),k&&k(E,O)},!Zy(t))return;this.dragSnapToOrigin=u,this.handlers=r,this.transformPagePoint=i,this.distanceThreshold=c,this.contextWindow=s||window;const g=as(t),p=yp(g,this.transformPagePoint),{point:h}=p,{timestamp:b}=vt;this.history=[{...h,timestamp:b}];const{onSessionStart:y}=r;y&&y(t,Ep(p,this.history)),this.removeListeners=es(Lo(this.contextWindow,"pointermove",this.handlePointerMove),Lo(this.contextWindow,"pointerup",this.handlePointerUp),Lo(this.contextWindow,"pointercancel",this.handlePointerUp)),d&&this.startScrollTracking(d)}startScrollTracking(t){let r=t.parentElement;for(;r;){const i=getComputedStyle(r);(Sk.has(i.overflowX)||Sk.has(i.overflowY))&&this.scrollPositions.set(r,{x:r.scrollLeft,y:r.scrollTop}),r=r.parentElement}this.scrollPositions.set(window,{x:window.scrollX,y:window.scrollY}),window.addEventListener("scroll",this.onElementScroll,{capture:!0}),window.addEventListener("scroll",this.onWindowScroll),this.removeScrollListeners=()=>{window.removeEventListener("scroll",this.onElementScroll,{capture:!0}),window.removeEventListener("scroll",this.onWindowScroll)}}handleScroll(t){const r=this.scrollPositions.get(t);if(!r)return;const i=t===window,s=i?{x:window.scrollX,y:window.scrollY}:{x:t.scrollLeft,y:t.scrollTop},u={x:s.x-r.x,y:s.y-r.y};u.x===0&&u.y===0||(i?this.lastMoveEventInfo&&(this.lastMoveEventInfo.point.x+=u.x,this.lastMoveEventInfo.point.y+=u.y):this.history.length>0&&(this.history[0].x-=u.x,this.history[0].y-=u.y),this.scrollPositions.set(t,s),Xe.update(this.updatePoint,!0))}updateHandlers(t){this.handlers=t}end(){this.removeListeners&&this.removeListeners(),this.removeScrollListeners&&this.removeScrollListeners(),this.scrollPositions.clear(),Ua(this.updatePoint)}}function yp(e,t){return t?{point:t(e.point)}:e}function Tk(e,t){return{x:e.x-t.x,y:e.y-t.y}}function Ep({point:e},t){return{point:e,delta:Tk(e,Mx(t)),offset:Tk(e,AP(t)),velocity:wP(t,.1)}}function AP(e){return e[0]}function Mx(e){return e[e.length-1]}function wP(e,t){if(e.length<2)return{x:0,y:0};let r=e.length-1,i=null;const s=Mx(e);for(;r>=0&&(i=e[r],!(s.timestamp-i.timestamp>kn(t)));)r--;if(!i)return{x:0,y:0};i===e[0]&&e.length>2&&s.timestamp-i.timestamp>kn(t)*2&&(i=e[1]);const u=mn(s.timestamp-i.timestamp);if(u===0)return{x:0,y:0};const c={x:(s.x-i.x)/u,y:(s.y-i.y)/u};return c.x===1/0&&(c.x=0),c.y===1/0&&(c.y=0),c}function kP(e,{min:t,max:r},i){return t!==void 0&&e<t?e=i?Je(t,e,i.min):Math.max(e,t):r!==void 0&&e>r&&(e=i?Je(r,e,i.max):Math.min(e,r)),e}function vk(e,t,r){return{min:t!==void 0?e.min+t:void 0,max:r!==void 0?e.max+r-(e.max-e.min):void 0}}function _P(e,{top:t,left:r,bottom:i,right:s}){return{x:vk(e.x,r,s),y:vk(e.y,t,i)}}function Ak(e,t){let r=t.min-e.min,i=t.max-e.max;return t.max-t.min<e.max-e.min&&([r,i]=[i,r]),{min:r,max:i}}function RP(e,t){return{x:Ak(e.x,t.x),y:Ak(e.y,t.y)}}function xP(e,t){let r=.5;const i=Mt(e),s=Mt(t);return s>i?r=Po(t.min,t.max-i,e.min):i>s&&(r=Po(e.min,e.max-s,t.min)),Mn(0,1,r)}function NP(e,t){const r={};return t.min!==void 0&&(r.min=t.min-e.min),t.max!==void 0&&(r.max=t.max-e.min),r}const uf=.35;function CP(e=uf){return e===!1?e=0:e===!0&&(e=uf),{x:wk(e,"left","right"),y:wk(e,"top","bottom")}}function wk(e,t,r){return{min:kk(e,t),max:kk(e,r)}}function kk(e,t){return typeof e=="number"?e:e[t]||0}const OP=new WeakMap;class IP{constructor(t){this.openDragLock=null,this.isDragging=!1,this.currentDirection=null,this.originPoint={x:0,y:0},this.constraints=!1,this.hasMutatedConstraints=!1,this.elastic=ft(),this.latestPointerEvent=null,this.latestPanInfo=null,this.visualElement=t}start(t,{snapToCursor:r=!1,distanceThreshold:i}={}){const{presenceContext:s}=this.visualElement;if(s&&s.isPresent===!1)return;const u=b=>{r&&this.snapToCursor(as(b).point),this.stopAnimation()},c=(b,y)=>{const{drag:E,dragPropagation:T,onDragStart:x}=this.getProps();if(E&&!T&&(this.openDragLock&&this.openDragLock(),this.openDragLock=sB(E),!this.openDragLock))return;this.latestPointerEvent=b,this.latestPanInfo=y,this.isDragging=!0,this.currentDirection=null,this.resolveConstraints(),this.visualElement.projection&&(this.visualElement.projection.isAnimationBlocked=!0,this.visualElement.projection.target=void 0),Dn(A=>{let O=this.getAxisMotionValue(A).get()||0;if(Ln.test(O)){const{projection:C}=this.visualElement;if(C&&C.layout){const F=C.layout.layoutBox[A];F&&(O=Mt(F)*(parseFloat(O)/100))}}this.originPoint[A]=O}),x&&Xe.update(()=>x(b,y),!1,!0),Qp(this.visualElement,"transform");const{animationState:k}=this.visualElement;k&&k.setActive("whileDrag",!0)},d=(b,y)=>{this.latestPointerEvent=b,this.latestPanInfo=y;const{dragPropagation:E,dragDirectionLock:T,onDirectionLock:x,onDrag:k}=this.getProps();if(!E&&!this.openDragLock)return;const{offset:A}=y;if(T&&this.currentDirection===null){this.currentDirection=LP(A),this.currentDirection!==null&&x&&x(this.currentDirection);return}this.updateAxis("x",y.point,A),this.updateAxis("y",y.point,A),this.visualElement.render(),k&&Xe.update(()=>k(b,y),!1,!0)},g=(b,y)=>{this.latestPointerEvent=b,this.latestPanInfo=y,this.stop(b,y),this.latestPointerEvent=null,this.latestPanInfo=null},p=()=>{const{dragSnapToOrigin:b}=this.getProps();(b||this.constraints)&&this.startAnimation({x:0,y:0})},{dragSnapToOrigin:h}=this.getProps();this.panSession=new Lx(t,{onSessionStart:u,onStart:c,onMove:d,onSessionEnd:g,resumeAnimation:p},{transformPagePoint:this.visualElement.getTransformPagePoint(),dragSnapToOrigin:h,distanceThreshold:i,contextWindow:Dx(this.visualElement),element:this.visualElement.current})}stop(t,r){const i=t||this.latestPointerEvent,s=r||this.latestPanInfo,u=this.isDragging;if(this.cancel(),!u||!s||!i)return;const{velocity:c}=s;this.startAnimation(c);const{onDragEnd:d}=this.getProps();d&&Xe.postRender(()=>d(i,s))}cancel(){this.isDragging=!1;const{projection:t,animationState:r}=this.visualElement;t&&(t.isAnimationBlocked=!1),this.endPanSession();const{dragPropagation:i}=this.getProps();!i&&this.openDragLock&&(this.openDragLock(),this.openDragLock=null),r&&r.setActive("whileDrag",!1)}endPanSession(){this.panSession&&this.panSession.end(),this.panSession=void 0}updateAxis(t,r,i){const{drag:s}=this.getProps();if(!i||!Ol(t,s,this.currentDirection))return;const u=this.getAxisMotionValue(t);let c=this.originPoint[t]+i[t];this.constraints&&this.constraints[t]&&(c=kP(c,this.constraints[t],this.elastic[t])),u.set(c)}resolveConstraints(){const{dragConstraints:t,dragElastic:r}=this.getProps(),i=this.visualElement.projection&&!this.visualElement.projection.layout?this.visualElement.projection.measure(!1):this.visualElement.projection?.layout,s=this.constraints;t&&ai(t)?this.constraints||(this.constraints=this.resolveRefConstraints()):t&&i?this.constraints=_P(i.layoutBox,t):this.constraints=!1,this.elastic=CP(r),s!==this.constraints&&!ai(t)&&i&&this.constraints&&!this.hasMutatedConstraints&&Dn(u=>{this.constraints!==!1&&this.getAxisMotionValue(u)&&(this.constraints[u]=NP(i.layoutBox[u],this.constraints[u]))})}resolveRefConstraints(){const{dragConstraints:t,onMeasureDragConstraints:r}=this.getProps();if(!t||!ai(t))return!1;const i=t.current,{projection:s}=this.visualElement;if(!s||!s.layout)return!1;const u=UB(i,s.root,this.visualElement.getTransformPagePoint());let c=RP(s.layout.layoutBox,u);if(r){const d=r(DB(c));this.hasMutatedConstraints=!!d,d&&(c=nx(d))}return c}startAnimation(t){const{drag:r,dragMomentum:i,dragElastic:s,dragTransition:u,dragSnapToOrigin:c,onDragTransitionEnd:d}=this.getProps(),g=this.constraints||{},p=Dn(h=>{if(!Ol(h,r,this.currentDirection))return;let b=g&&g[h]||{};c&&(b={min:0,max:0});const y=s?200:1e6,E=s?40:1e7,T={type:"inertia",velocity:i?t[h]:0,bounceStiffness:y,bounceDamping:E,timeConstant:750,restDelta:1,restSpeed:10,...u,...b};return this.startAxisValueAnimation(h,T)});return Promise.all(p).then(d)}startAxisValueAnimation(t,r){const i=this.getAxisMotionValue(t);return Qp(this.visualElement,t),i.start(qy(t,i,0,r,this.visualElement,!1))}stopAnimation(){Dn(t=>this.getAxisMotionValue(t).stop())}getAxisMotionValue(t){const r=`_drag${t.toUpperCase()}`,i=this.visualElement.getProps(),s=i[r];return s||this.visualElement.getValue(t,(i.initial?i.initial[t]:void 0)||0)}snapToCursor(t){Dn(r=>{const{drag:i}=this.getProps();if(!Ol(r,i,this.currentDirection))return;const{projection:s}=this.visualElement,u=this.getAxisMotionValue(r);if(s&&s.layout){const{min:c,max:d}=s.layout.layoutBox[r],g=u.get()||0;u.set(t[r]-Je(c,d,.5)+g)}})}scalePositionWithinConstraints(){if(!this.visualElement.current)return;const{drag:t,dragConstraints:r}=this.getProps(),{projection:i}=this.visualElement;if(!ai(r)||!i||!this.constraints)return;this.stopAnimation();const s={x:0,y:0};Dn(c=>{const d=this.getAxisMotionValue(c);if(d&&this.constraints!==!1){const g=d.get();s[c]=xP({min:g,max:g},this.constraints[c])}});const{transformTemplate:u}=this.visualElement.getProps();this.visualElement.current.style.transform=u?u({},""):"none",i.root&&i.root.updateScroll(),i.updateLayout(),this.constraints=!1,this.resolveConstraints(),Dn(c=>{if(!Ol(c,t,null))return;const d=this.getAxisMotionValue(c),{min:g,max:p}=this.constraints[c];d.set(Je(g,p,s[c]))}),this.visualElement.render()}addListeners(){if(!this.visualElement.current)return;OP.set(this.visualElement,this);const t=this.visualElement.current,r=Lo(t,"pointerdown",p=>{const{drag:h,dragListener:b=!0}=this.getProps(),y=p.target,E=y!==t&&fB(y);h&&b&&!E&&this.start(p)});let i;const s=()=>{const{dragConstraints:p}=this.getProps();ai(p)&&p.current&&(this.constraints=this.resolveRefConstraints(),i||(i=DP(t,p.current,()=>this.scalePositionWithinConstraints())))},{projection:u}=this.visualElement,c=u.addEventListener("measure",s);u&&!u.layout&&(u.root&&u.root.updateScroll(),u.updateLayout()),Xe.read(s);const d=Vo(window,"resize",()=>this.scalePositionWithinConstraints()),g=u.addEventListener("didUpdate",(({delta:p,hasLayoutChanged:h})=>{this.isDragging&&h&&(Dn(b=>{const y=this.getAxisMotionValue(b);y&&(this.originPoint[b]+=p[b].translate,y.set(y.get()+p[b].translate))}),this.visualElement.render())}));return()=>{d(),r(),c(),g&&g(),i&&i()}}getProps(){const t=this.visualElement.getProps(),{drag:r=!1,dragDirectionLock:i=!1,dragPropagation:s=!1,dragConstraints:u=!1,dragElastic:c=uf,dragMomentum:d=!0}=t;return{...t,drag:r,dragDirectionLock:i,dragPropagation:s,dragConstraints:u,dragElastic:c,dragMomentum:d}}}function _k(e){let t=!0;return()=>{if(t){t=!1;return}e()}}function DP(e,t,r){const i=Dw(e,_k(r)),s=Dw(t,_k(r));return()=>{i(),s()}}function Ol(e,t,r){return(t===!0||t===e)&&(r===null||r===e)}function LP(e,t=10){let r=null;return Math.abs(e.y)>t?r="y":Math.abs(e.x)>t&&(r="x"),r}class MP extends Ba{constructor(t){super(t),this.removeGroupControls=hn,this.removeListeners=hn,this.controls=new IP(t)}mount(){const{dragControls:t}=this.node.getProps();t&&(this.removeGroupControls=t.subscribe(this.controls)),this.removeListeners=this.controls.addListeners()||hn}update(){const{dragControls:t}=this.node.getProps(),{dragControls:r}=this.node.prevProps||{};t!==r&&(this.removeGroupControls(),t&&(this.removeGroupControls=t.subscribe(this.controls)))}unmount(){this.removeGroupControls(),this.removeListeners(),this.controls.isDragging||this.controls.endPanSession()}}const Sp=e=>(t,r)=>{e&&Xe.update(()=>e(t,r),!1,!0)};class UP extends Ba{constructor(){super(...arguments),this.removePointerDownListener=hn}onPointerDown(t){this.session=new Lx(t,this.createPanHandlers(),{transformPagePoint:this.node.getTransformPagePoint(),contextWindow:Dx(this.node)})}createPanHandlers(){const{onPanSessionStart:t,onPanStart:r,onPan:i,onPanEnd:s}=this.node.getProps();return{onSessionStart:Sp(t),onStart:Sp(r),onMove:Sp(i),onEnd:(u,c)=>{delete this.session,s&&Xe.postRender(()=>s(u,c))}}}mount(){this.removePointerDownListener=Lo(this.node.current,"pointerdown",t=>this.onPointerDown(t))}update(){this.session&&this.session.updateHandlers(this.createPanHandlers())}unmount(){this.removePointerDownListener(),this.session&&this.session.end()}}let Tp=!1;class FP extends X.Component{componentDidMount(){const{visualElement:t,layoutGroup:r,switchLayoutGroup:i,layoutId:s}=this.props,{projection:u}=t;u&&(r.group&&r.group.add(u),i&&i.register&&s&&i.register(u),Tp&&u.root.didUpdate(),u.addEventListener("animationComplete",()=>{this.safeToRemove()}),u.setOptions({...u.options,layoutDependency:this.props.layoutDependency,onExitComplete:()=>this.safeToRemove()})),Gl.hasEverUpdated=!0}getSnapshotBeforeUpdate(t){const{layoutDependency:r,visualElement:i,drag:s,isPresent:u}=this.props,{projection:c}=i;return c&&(c.isPresent=u,t.layoutDependency!==r&&c.setOptions({...c.options,layoutDependency:r}),Tp=!0,s||t.layoutDependency!==r||r===void 0||t.isPresent!==u?c.willUpdate():this.safeToRemove(),t.isPresent!==u&&(u?c.promote():c.relegate()||Xe.postRender(()=>{const d=c.getStack();(!d||!d.members.length)&&this.safeToRemove()}))),null}componentDidUpdate(){const{projection:t}=this.props.visualElement;t&&(t.root.didUpdate(),Ky.postRender(()=>{!t.currentAnimation&&t.isLead()&&this.safeToRemove()}))}componentWillUnmount(){const{visualElement:t,layoutGroup:r,switchLayoutGroup:i}=this.props,{projection:s}=t;Tp=!0,s&&(s.scheduleCheckAfterUnmount(),r&&r.group&&r.group.remove(s),i&&i.deregister&&i.deregister(s))}safeToRemove(){const{safeToRemove:t}=this.props;t&&t()}render(){return null}}function Ux(e){const[t,r]=wx(),i=X.useContext(Ny);return Y.jsx(FP,{...e,layoutGroup:i,switchLayoutGroup:X.useContext(Ox),isPresent:t,safeToRemove:r})}const BP={pan:{Feature:UP},drag:{Feature:MP,ProjectionNode:Ax,MeasureLayout:Ux}};function Rk(e,t,r){const{props:i}=e;e.animationState&&i.whileHover&&e.animationState.setActive("whileHover",r==="Start");const s="onHover"+r,u=i[s];u&&Xe.postRender(()=>u(t,as(t)))}class zP extends Ba{mount(){const{current:t}=this.node;t&&(this.unmount=uB(t,(r,i)=>(Rk(this.node,i,"Start"),s=>Rk(this.node,s,"End"))))}unmount(){}}class PP extends Ba{constructor(){super(...arguments),this.isActive=!1}onFocus(){let t=!1;try{t=this.node.current.matches(":focus-visible")}catch{t=!0}!t||!this.node.animationState||(this.node.animationState.setActive("whileFocus",!0),this.isActive=!0)}onBlur(){!this.isActive||!this.node.animationState||(this.node.animationState.setActive("whileFocus",!1),this.isActive=!1)}mount(){this.unmount=es(Vo(this.node.current,"focus",()=>this.onFocus()),Vo(this.node.current,"blur",()=>this.onBlur()))}unmount(){}}function xk(e,t,r){const{props:i}=e;if(e.current instanceof HTMLButtonElement&&e.current.disabled)return;e.animationState&&i.whileTap&&e.animationState.setActive("whileTap",r==="Start");const s="onTap"+(r==="End"?"":r),u=i[s];u&&Xe.postRender(()=>u(t,as(t)))}class GP extends Ba{mount(){const{current:t}=this.node;if(!t)return;const{globalTapTarget:r,propagate:i}=this.node.props;this.unmount=mB(t,(s,u)=>(xk(this.node,u,"Start"),(c,{success:d})=>xk(this.node,c,d?"End":"Cancel")),{useGlobalTarget:r,stopPropagation:i?.tap===!1})}unmount(){}}const cf=new WeakMap,vp=new WeakMap,jP=e=>{const t=cf.get(e.target);t&&t(e)},HP=e=>{e.forEach(jP)};function VP({root:e,...t}){const r=e||document;vp.has(r)||vp.set(r,{});const i=vp.get(r),s=JSON.stringify(t);return i[s]||(i[s]=new IntersectionObserver(HP,{root:e,...t})),i[s]}function $P(e,t,r){const i=VP(t);return cf.set(e,r),i.observe(e),()=>{cf.delete(e),i.unobserve(e)}}const qP={some:0,all:1};class YP extends Ba{constructor(){super(...arguments),this.hasEnteredView=!1,this.isInView=!1}startObserver(){this.unmount();const{viewport:t={}}=this.node.getProps(),{root:r,margin:i,amount:s="some",once:u}=t,c={root:r?r.current:void 0,rootMargin:i,threshold:typeof s=="number"?s:qP[s]},d=g=>{const{isIntersecting:p}=g;if(this.isInView===p||(this.isInView=p,u&&!p&&this.hasEnteredView))return;p&&(this.hasEnteredView=!0),this.node.animationState&&this.node.animationState.setActive("whileInView",p);const{onViewportEnter:h,onViewportLeave:b}=this.node.getProps(),y=p?h:b;y&&y(g)};return $P(this.node.current,c,d)}mount(){this.startObserver()}update(){if(typeof IntersectionObserver>"u")return;const{props:t,prevProps:r}=this.node;["amount","margin","root"].some(WP(t,r))&&this.startObserver()}unmount(){}}function WP({viewport:e={}},{viewport:t={}}={}){return r=>e[r]!==t[r]}const XP={inView:{Feature:YP},tap:{Feature:GP},focus:{Feature:PP},hover:{Feature:zP}},KP={layout:{ProjectionNode:Ax,MeasureLayout:Ux}},ZP={...SP,...XP,...BP,...KP},jl=mP(ZP,hP);function QP({images:e,index:t,onClose:r,onNavigate:i}){const s=X.useCallback(()=>{t>0&&i(t-1)},[t,i]),u=X.useCallback(()=>{t<e.length-1&&i(t+1)},[t,e.length,i]);return X.useEffect(()=>{const c=d=>{d.key==="Escape"&&r(),d.key==="ArrowLeft"&&s(),d.key==="ArrowRight"&&u()};return window.addEventListener("keydown",c),()=>window.removeEventListener("keydown",c)},[r,s,u]),Y.jsx(lf,{children:Y.jsxs(jl.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.15},className:"fixed inset-0 z-50 flex items-center justify-center bg-black/90",onClick:r,children:[Y.jsx("button",{onClick:r,className:"absolute top-4 right-4 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:Y.jsx(Ok,{className:"h-5 w-5"})}),e.length>1&&Y.jsxs("div",{className:"absolute top-4 left-1/2 -translate-x-1/2 text-white/70 text-sm tabular-nums",children:[t+1," / ",e.length]}),t>0&&Y.jsx("button",{onClick:c=>{c.stopPropagation(),s()},className:"absolute left-3 top-1/2 -translate-y-1/2 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:Y.jsx(hO,{className:"h-6 w-6"})}),t<e.length-1&&Y.jsx("button",{onClick:c=>{c.stopPropagation(),u()},className:"absolute right-3 top-1/2 -translate-y-1/2 z-10 p-2 rounded-full bg-white/10 hover:bg-white/20 transition-colors text-white",children:Y.jsx(yO,{className:"h-6 w-6"})}),Y.jsx("img",{src:e[t],alt:"",className:"max-h-[85vh] max-w-[90vw] object-contain rounded-lg",onClick:c=>c.stopPropagation()})]})})}function JP({messages:e,streaming:t,streamBuffer:r,tools:i}){const s=X.useRef(null),[u,c]=X.useState(null),d=X.useCallback((h,b)=>{c({images:h,index:b})},[]);X.useEffect(()=>{s.current?.scrollIntoView({behavior:"smooth"})},[e,r,i,t]);const g=i.length>0?i[i.length-1]:null,p=g?.status==="running"?g.name:void 0;return Y.jsxs("div",{className:"flex-1 overflow-y-auto overflow-x-hidden p-4 flex flex-col min-h-0",children:[Y.jsx("div",{className:"flex-1"}),e.length===0&&!t&&Y.jsx("div",{className:"flex items-center justify-center py-8 text-muted-foreground text-sm",children:"Start a conversation"}),Y.jsxs("div",{className:"space-y-3",children:[e.map(h=>Y.jsx(nU,{role:h.role,content:h.content,timestamp:h.timestamp,hasAttachments:h.hasAttachments,audioData:h.audioData,attachments:h.attachments,onImageClick:d},h.id)),t&&Y.jsx(rU,{text:r,toolName:p})]}),Y.jsx("div",{ref:s}),u&&Y.jsx(QP,{images:u.images,index:u.index,onClose:()=>c(null),onNavigate:h=>c(b=>b?{...b,index:h}:null)})]})}function eG(e){const t=Math.floor(e/60),r=e%60;return`${t}:${r.toString().padStart(2,"0")}`}function tG(e,t=4*1024*1024){return new Promise(r=>{const i=new Image;i.onload=()=>{let{width:u,height:c}=i;if(u>1600||c>1600){const p=Math.min(1600/u,1600/c);u=Math.round(u*p),c=Math.round(c*p)}const d=document.createElement("canvas");d.width=u,d.height=c,d.getContext("2d").drawImage(i,0,0,u,c);for(const p of[.8,.6,.4,.3]){const h=d.toDataURL("image/jpeg",p);if(Math.round((h.length-23)*.75)<=t){r(h);return}}r(d.toDataURL("image/jpeg",.2))},i.onerror=()=>r(e),i.src=e})}function nG({onSend:e,onStop:t,streaming:r,whisperEnabled:i}){const[s,u]=X.useState(""),[c,d]=X.useState([]),[g,p]=X.useState(!1),[h,b]=X.useState(0),E=s.trim().length>0||c.length>0,T=X.useRef(null),x=X.useRef(null),k=X.useRef(null),A=X.useRef(null),O=X.useRef(null),C=X.useRef(0),F=X.useRef(0),B=X.useRef(null),D=X.useRef(!1),$=X.useRef(null),q=X.useRef(null),te=X.useRef([]),M=X.useRef(null);X.useEffect(()=>{const _=T.current;_&&(_.style.height="0px",_.style.height=`${Math.min(_.scrollHeight,88)}px`)},[s]),X.useEffect(()=>{if(g)return $.current=setInterval(()=>b(_=>_+1),1e3),()=>{$.current&&clearInterval($.current)}},[g]);const ee=X.useCallback(_=>{$.current&&clearInterval($.current),B.current&&(clearTimeout(B.current),B.current=null),D.current=!1;const N=q.current,j=M.current;_||!N||N.state==="inactive"?(j?.getTracks().forEach(R=>R.stop()),q.current=null,M.current=null,te.current=[]):(N.onstop=async()=>{j?.getTracks().forEach(fe=>fe.stop());const R=new Blob(te.current,{type:"audio/webm"});if(te.current=[],q.current=null,M.current=null,R.size<1e3)return;const le=new FileReader;le.onloadend=async()=>{const fe=le.result,pe=fe.split(",")[1];if(pe)try{const Ue=await(await fetch("/api/whisper/transcribe",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({audio:pe})})).json();Ue.transcript?.trim()&&e(Ue.transcript.trim(),void 0,fe)}catch{}},le.readAsDataURL(R)},N.stop()),O.current&&(O.current.style.transform=""),p(!1),b(0),F.current=0},[e]),ne=X.useCallback(_=>{const N=_.type.startsWith("image/"),j=_.type==="application/pdf";if(!N&&!j)return;const R=new FileReader;R.onload=async le=>{let fe=le.target?.result;N&&(fe=await tG(fe)),d(pe=>[...pe,{id:Math.random().toString(36).slice(2),type:N?"image":"file",name:_.name,preview:fe}])},R.readAsDataURL(_)},[]),ie=X.useCallback(_=>{const N=_.target.files;if(N){for(let j=0;j<N.length;j++)ne(N[j]);_.target.value=""}},[ne]),oe=X.useCallback(_=>{d(N=>N.filter(j=>j.id!==_))},[]);X.useEffect(()=>{const _=N=>{if(N.clipboardData?.items){for(const j of N.clipboardData.items)if(j.type.startsWith("image/")){N.preventDefault();const R=j.getAsFile();R&&ne(R)}}};return document.addEventListener("paste",_),()=>document.removeEventListener("paste",_)},[ne]);const ae=()=>{E&&(e(s,c.length>0?c:void 0),u(""),d([]),requestAnimationFrame(()=>T.current?.focus()))},z=X.useCallback(_=>{_.preventDefault(),C.current=_.clientX,F.current=0,_.currentTarget.setPointerCapture(_.pointerId),B.current=setTimeout(async()=>{if(i)try{const N=await navigator.mediaDevices.getUserMedia({audio:!0});M.current=N;const j=MediaRecorder.isTypeSupported("audio/webm;codecs=opus")?"audio/webm;codecs=opus":"audio/webm",R=new MediaRecorder(N,{mimeType:j});te.current=[],R.ondataavailable=le=>{le.data.size>0&&te.current.push(le.data)},q.current=R,R.start(),D.current=!0,p(!0),b(0)}catch{}},200)},[]),W=X.useCallback(_=>{if(!D.current)return;const N=Math.min(0,_.clientX-C.current);if(F.current=N,O.current&&(O.current.style.transform=`translateX(${N}px)`),A.current){const j=A.current.getBoundingClientRect(),R=j.left+j.width/2;Math.abs(_.clientX-R)<36&&ee(!0)}},[ee]),se=X.useCallback(()=>{B.current&&(clearTimeout(B.current),B.current=null),D.current&&ee(!1)},[ee]),ge=X.useCallback(()=>{B.current&&(clearTimeout(B.current),B.current=null),D.current&&ee(!0)},[ee]);return Y.jsxs("div",{className:"shrink-0 p-3 relative",children:[Y.jsxs("div",{className:`flex flex-col transition-opacity duration-100 ${g?"opacity-0 pointer-events-none":"opacity-100"}`,children:[Y.jsx(lf,{children:c.length>0&&Y.jsx(jl.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},transition:{duration:.15},className:"overflow-hidden",children:Y.jsx("div",{className:"flex gap-2 px-3 pt-2.5 pb-2 flex-wrap bg-white/[0.04] border border-white/[0.08] rounded-2xl mb-2",children:c.map(_=>Y.jsxs("div",{className:"relative group flex-shrink-0",children:[_.type==="image"?Y.jsx("img",{src:_.preview,alt:_.name,className:"w-14 h-14 rounded-lg object-cover border border-white/10"}):Y.jsxs("div",{className:"w-14 h-14 rounded-lg bg-white/5 border border-white/10 flex flex-col items-center justify-center gap-0.5 px-1",children:[Y.jsx("svg",{className:"w-5 h-5 text-muted-foreground",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:1.5,children:Y.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M19.5 14.25v-2.625a3.375 3.375 0 00-3.375-3.375h-1.5A1.125 1.125 0 0113.5 7.125v-1.5a3.375 3.375 0 00-3.375-3.375H8.25m2.25 0H5.625c-.621 0-1.125.504-1.125 1.125v17.25c0 .621.504 1.125 1.125 1.125h12.75c.621 0 1.125-.504 1.125-1.125V11.25a9 9 0 00-9-9z"})}),Y.jsx("span",{className:"text-[8px] text-muted-foreground truncate w-full text-center",children:_.name.split(".").pop()})]}),Y.jsx("button",{onClick:()=>oe(_.id),className:"absolute -top-1.5 -right-1.5 w-4 h-4 bg-black/80 border border-white/20 rounded-full flex items-center justify-center opacity-0 group-hover:opacity-100 transition-opacity",children:Y.jsx(Ok,{className:"w-2.5 h-2.5 text-white"})})]},_.id))})})}),Y.jsxs("div",{className:"flex items-end gap-2",children:[Y.jsxs("div",{className:"flex-1 flex items-end bg-white rounded-2xl px-4",children:[Y.jsx("textarea",{ref:T,value:s,onChange:_=>u(_.target.value),placeholder:"Type a message...",rows:1,className:"flex-1 resize-none bg-transparent text-gray-900 py-3 text-sm outline-none placeholder:text-gray-400 overflow-y-auto",style:{maxHeight:88}}),Y.jsx("input",{ref:x,type:"file",className:"hidden",accept:"image/*,.pdf",multiple:!0,onChange:ie}),Y.jsx("input",{ref:k,type:"file",className:"hidden",accept:"image/*",capture:"environment",onChange:ie}),Y.jsx("button",{type:"button",onClick:()=>x.current?.click(),className:"shrink-0 p-1.5 mb-2 text-gray-400 hover:text-gray-600 transition-colors",children:Y.jsx(Ap,{className:"h-4 w-4"})}),Y.jsx("button",{type:"button",onClick:()=>k.current?.click(),className:"shrink-0 p-1.5 mb-2 text-gray-400 hover:text-gray-600 transition-colors",children:Y.jsx(gO,{className:"h-4 w-4"})})]}),r?Y.jsx("button",{onClick:t,className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-destructive text-destructive-foreground transition-colors",children:Y.jsx(xO,{className:"h-4 w-4"})}):E?Y.jsx("button",{onClick:ae,className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-white text-gray-900 transition-colors hover:bg-gray-100",children:Y.jsx(_O,{className:"h-4 w-4"})}):Y.jsx("div",{className:"flex items-center justify-center h-12 w-12 shrink-0 rounded-full bg-white text-gray-900 transition-colors hover:bg-gray-100 cursor-pointer touch-none select-none",onPointerDown:z,onPointerMove:W,onPointerUp:se,onPointerCancel:ge,children:Y.jsx(fA,{className:"h-4 w-4"})})]})]}),Y.jsx(lf,{children:g&&Y.jsx(jl.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.1},className:"absolute inset-0 p-3 flex items-center touch-none",children:Y.jsxs("div",{className:"flex items-center w-full gap-2",children:[Y.jsxs("div",{className:"flex items-center gap-2 shrink-0",children:[Y.jsxs("span",{className:"relative flex h-2 w-2 shrink-0",children:[Y.jsx("span",{className:"animate-ping absolute inline-flex h-full w-full rounded-full bg-destructive opacity-75"}),Y.jsx("span",{className:"relative inline-flex rounded-full h-2 w-2 bg-destructive"})]}),Y.jsx("span",{className:"text-sm font-medium tabular-nums",children:eG(h)})]}),Y.jsxs("div",{className:"flex-1 flex items-center bg-muted rounded-full h-12 pl-1 pr-0.5",children:[Y.jsx("div",{ref:A,className:"flex items-center justify-center h-9 w-9 shrink-0 rounded-full bg-destructive/10 text-destructive",children:Y.jsx(Ck,{className:"h-4 w-4"})}),Y.jsx("div",{className:"flex-1 flex justify-center min-w-0",children:Y.jsx(jl.span,{className:"text-[13px] whitespace-nowrap select-none font-medium",style:{backgroundImage:"linear-gradient(90deg, #999 0%, #999 35%, #fff 50%, #999 65%, #999 100%)",backgroundSize:"200% 100%",WebkitBackgroundClip:"text",WebkitTextFillColor:"transparent",backgroundClip:"text"},animate:{backgroundPosition:["200% center","-200% center"]},transition:{duration:2.5,repeat:1/0,ease:"linear"},children:"◄◄ slide to cancel"})}),Y.jsx("div",{ref:O,className:"shrink-0 touch-none select-none will-change-transform",style:{transition:"none"},onPointerDown:z,onPointerMove:W,onPointerUp:se,onPointerCancel:ge,children:Y.jsx("div",{className:"flex items-center justify-center h-11 w-11 rounded-full bg-destructive text-destructive-foreground",children:Y.jsx(fA,{className:"h-5 w-5"})})})]})]})})})]})}function aG(){const e=X.useRef(null),[t,r]=X.useState(!1),[i,s]=X.useState("Fluxy"),[u,c]=X.useState(!1);X.useEffect(()=>{const T=location.protocol==="https:"?"wss:":"ws:",x=location.host,k=new pf(`${T}//${x}/fluxy/ws`);e.current=k;const A=k.onStatus(r),O=k.on("app:rebuilding",()=>{console.log("[fluxy] app:rebuilding received"),window.parent?.postMessage({type:"fluxy:rebuilding"},"*")}),C=k.on("app:rebuilt",()=>{console.log("[fluxy] app:rebuilt received"),window.parent?.postMessage({type:"fluxy:rebuilt"},"*")}),F=k.on("app:build-error",D=>{console.log("[fluxy] app:build-error received:",D.error),window.parent?.postMessage({type:"fluxy:build-error",error:D.error},"*")}),B=k.on("app:hmr-update",()=>{console.log("[fluxy] Vite HMR update — changes applied automatically"),window.parent?.postMessage({type:"fluxy:hmr-update"},"*")});return k.connect(),()=>{A(),O(),C(),F(),B(),k.disconnect()}},[]),X.useEffect(()=>{fetch("/api/settings").then(T=>T.json()).then(T=>{T.agent_name&&s(T.agent_name),T.whisper_enabled==="true"&&c(!0)}).catch(()=>{})},[]);const{messages:d,streaming:g,streamBuffer:p,tools:h,sendMessage:b,stopStreaming:y,clearContext:E}=DO(e.current);return Y.jsxs("div",{className:"flex flex-col h-dvh overflow-hidden",children:[Y.jsxs("div",{className:"flex items-center gap-3 px-4 py-3 border-b border-border shrink-0",children:[Y.jsx("img",{src:"/fluxy.png",alt:i,className:"h-5 w-auto"}),Y.jsx("span",{className:"text-sm font-semibold",children:i}),Y.jsx("div",{className:`h-2 w-2 rounded-full ${t?"bg-green-500":"bg-red-500"}`}),Y.jsx("div",{className:"flex-1"}),Y.jsx("button",{onClick:E,className:"flex items-center justify-center h-7 w-7 rounded-full text-muted-foreground hover:text-foreground hover:bg-white/[0.06] transition-colors",title:"Clear context",children:Y.jsx(Ck,{className:"h-4 w-4"})})]}),Y.jsxs("div",{className:"flex-1 min-h-0 flex flex-col overflow-hidden",children:[Y.jsx(JP,{messages:d,streaming:g,streamBuffer:p,tools:h}),Y.jsx(nG,{onSend:b,onStop:y,streaming:g,whisperEnabled:u})]})]})}sO.createRoot(document.getElementById("root")).render(Y.jsx(ra.StrictMode,{children:Y.jsx(aG,{})}));
@@ -0,0 +1 @@
1
+ @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial;--tw-content:"";--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}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--color-amber-400:oklch(82.8% .189 84.429);--color-amber-500:oklch(76.9% .188 70.08);--color-green-500:oklch(72.3% .219 149.579);--color-emerald-400:oklch(76.5% .177 163.223);--color-emerald-500:oklch(69.6% .17 162.48);--color-slate-500:oklch(55.4% .046 257.417);--color-slate-800:oklch(27.9% .041 260.031);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-900:oklch(21% .034 264.665);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-lg:32rem;--container-6xl:72rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-widest:.1em;--leading-tight:1.25;--leading-relaxed:1.625;--radius-xs:.125rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-ping:ping 1s cubic-bezier(0, 0, .2, 1) infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--animate-bounce:bounce 1s infinite;--blur-md:12px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-background:#212121;--color-foreground:#f5f5f5}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.\@container\/card-header{container:card-header/inline-size}.pointer-events-none{pointer-events:none}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.inset-x-0{inset-inline:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.-top-0\.5{top:calc(var(--spacing) * -.5)}.-top-1\.5{top:calc(var(--spacing) * -1.5)}.top-0{top:calc(var(--spacing) * 0)}.top-1\/2{top:50%}.top-2{top:calc(var(--spacing) * 2)}.top-4{top:calc(var(--spacing) * 4)}.top-\[50\%\]{top:50%}.top-full{top:100%}.-right-0\.5{right:calc(var(--spacing) * -.5)}.-right-1\.5{right:calc(var(--spacing) * -1.5)}.right-0{right:calc(var(--spacing) * 0)}.right-2{right:calc(var(--spacing) * 2)}.right-3{right:calc(var(--spacing) * 3)}.right-4{right:calc(var(--spacing) * 4)}.bottom-0{bottom:calc(var(--spacing) * 0)}.left-0{left:calc(var(--spacing) * 0)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing) * 2)}.left-3{left:calc(var(--spacing) * 3)}.left-\[50\%\]{left:50%}.z-10{z-index:10}.z-50{z-index:50}.z-\[49\]{z-index:49}.z-\[200\]{z-index:200}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.mx-1\.5{margin-inline:calc(var(--spacing) * 1.5)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.my-1\.5{margin-block:calc(var(--spacing) * 1.5)}.my-2{margin-block:calc(var(--spacing) * 2)}.-mt-3{margin-top:calc(var(--spacing) * -3)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-2\.5{margin-top:calc(var(--spacing) * 2.5)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-auto{margin-top:auto}.mt-px{margin-top:1px}.mr-1\.5{margin-right:calc(var(--spacing) * 1.5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.ml-0\.5{margin-left:calc(var(--spacing) * .5)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.field-sizing-content{field-sizing:content}.aspect-square{aspect-ratio:1}.size-2{width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.size-2\.5{width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.size-3\.5{width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.size-4{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.size-full{width:100%;height:100%}.h-1{height:calc(var(--spacing) * 1)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-3{height:calc(var(--spacing) * 3)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-24{height:calc(var(--spacing) * 24)}.h-28{height:calc(var(--spacing) * 28)}.h-\[18px\]{height:18px}.h-\[22px\]{height:22px}.h-\[180px\]{height:180px}.h-\[calc\(100\%-1px\)\]{height:calc(100% - 1px)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-dvh{height:100dvh}.h-full{height:100%}.h-px{height:1px}.max-h-\(--radix-dropdown-menu-content-available-height\){max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-\(--radix-select-content-available-height\){max-height:var(--radix-select-content-available-height)}.max-h-48{max-height:calc(var(--spacing) * 48)}.max-h-\[85vh\]{max-height:85vh}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-16{min-height:calc(var(--spacing) * 16)}.min-h-\[200px\]{min-height:200px}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2{width:calc(var(--spacing) * 2)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-3{width:calc(var(--spacing) * 3)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-3\/4{width:75%}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-10{width:calc(var(--spacing) * 10)}.w-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-24{width:calc(var(--spacing) * 24)}.w-28{width:calc(var(--spacing) * 28)}.w-52{width:calc(var(--spacing) * 52)}.w-72{width:calc(var(--spacing) * 72)}.w-\[18px\]{width:18px}.w-auto{width:auto}.w-fit{width:fit-content}.w-full{width:100%}.max-w-6xl{max-width:var(--container-6xl)}.max-w-10{max-width:calc(var(--spacing) * 10)}.max-w-\[75\%\]{max-width:75%}.max-w-\[90vw\]{max-width:90vw}.max-w-\[320px\]{max-width:320px}.max-w-\[480px\]{max-width:480px}.max-w-\[calc\(100\%-2rem\)\]{max-width:calc(100% - 2rem)}.max-w-none{max-width:none}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[180px\]{min-width:180px}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.origin-\(--radix-dropdown-menu-content-transform-origin\){transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\(--radix-select-content-transform-origin\){transform-origin:var(--radix-select-content-transform-origin)}.origin-\(--radix-tooltip-content-transform-origin\){transform-origin:var(--radix-tooltip-content-transform-origin)}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-0{--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-\[18px\]{--tw-translate-x:18px;translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[calc\(-50\%_-_2px\)\]{--tw-translate-y: calc(-50% - 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-45{rotate:45deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-bounce{animation:var(--animate-bounce)}.animate-ping{animation:var(--animate-ping)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.resize-none{resize:none}.scroll-my-1{scroll-margin-block:calc(var(--spacing) * 1)}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.auto-rows-min{grid-auto-rows:min-content}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-3\.5{gap:calc(var(--spacing) * 3.5)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}:where(.-space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * -2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * -2) * calc(1 - var(--tw-space-x-reverse)))}.self-start{align-self:flex-start}.justify-self-end{justify-self:flex-end}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.75rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[2px\]{border-radius:2px}.rounded-\[24px\]{border-radius:24px}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-xs{border-radius:var(--radius-xs)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-\[1\.5px\]{border-style:var(--tw-border-style);border-width:1.5px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-\[\#AF27E3\]\/20{border-color:#af27e333}.border-\[\#AF27E3\]\/30{border-color:#af27e34d}.border-\[\#AF27E3\]\/40{border-color:#af27e366}.border-amber-500\/20{border-color:#f99c0033}@supports (color:color-mix(in lab,red,red)){.border-amber-500\/20{border-color:color-mix(in oklab,var(--color-amber-500) 20%,transparent)}}.border-border{border-color:#3a3a3a}.border-emerald-500\/15{border-color:#00bb7f26}@supports (color:color-mix(in lab,red,red)){.border-emerald-500\/15{border-color:color-mix(in oklab,var(--color-emerald-500) 15%,transparent)}}.border-emerald-500\/20{border-color:#00bb7f33}@supports (color:color-mix(in lab,red,red)){.border-emerald-500\/20{border-color:color-mix(in oklab,var(--color-emerald-500) 20%,transparent)}}.border-input{border-color:#3a3a3a}.border-muted-foreground\/30{border-color:#9999994d}.border-red-500\/15{border-color:#fb2c3626}@supports (color:color-mix(in lab,red,red)){.border-red-500\/15{border-color:color-mix(in oklab,var(--color-red-500) 15%,transparent)}}.border-red-500\/20{border-color:#fb2c3633}@supports (color:color-mix(in lab,red,red)){.border-red-500\/20{border-color:color-mix(in oklab,var(--color-red-500) 20%,transparent)}}.border-slate-800{border-color:var(--color-slate-800)}.border-transparent{border-color:#0000}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.border-white\/10{border-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.border-white\/20{border-color:#fff3}@supports (color:color-mix(in lab,red,red)){.border-white\/20{border-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.border-white\/\[0\.04\]{border-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.04\]{border-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.border-white\/\[0\.06\]{border-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.06\]{border-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.border-white\/\[0\.08\]{border-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.08\]{border-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.border-t-\[\#04D1FE\]{border-top-color:#04d1fe}.border-t-primary{border-top-color:#3c8fff}.border-t-transparent{border-top-color:#0000}.border-l-transparent{border-left-color:#0000}.bg-\[\#222\]{background-color:#222}.bg-\[\#181818\]{background-color:#181818}.bg-\[\#AF27E3\]\/10{background-color:#af27e31a}.bg-\[\#AF27E3\]\/15{background-color:#af27e326}.bg-\[\#AF27E3\]\/\[0\.06\]{background-color:#af27e30f}.bg-accent{background-color:#333}.bg-amber-500\/8{background-color:#f99c0014}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/8{background-color:color-mix(in oklab,var(--color-amber-500) 8%,transparent)}}.bg-amber-500\/15{background-color:#f99c0026}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/15{background-color:color-mix(in oklab,var(--color-amber-500) 15%,transparent)}}.bg-background{background-color:#212121}.bg-background\/90{background-color:#212121e6}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab,red,red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black) 40%,transparent)}}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:color-mix(in oklab,var(--color-black) 80%,transparent)}}.bg-black\/85{background-color:#000000d9}@supports (color:color-mix(in lab,red,red)){.bg-black\/85{background-color:color-mix(in oklab,var(--color-black) 85%,transparent)}}.bg-black\/90{background-color:#000000e6}@supports (color:color-mix(in lab,red,red)){.bg-black\/90{background-color:color-mix(in oklab,var(--color-black) 90%,transparent)}}.bg-border{background-color:#3a3a3a}.bg-card{background-color:#2a2a2a}.bg-destructive{background-color:#fd486b}.bg-destructive\/10{background-color:#fd486b1a}.bg-destructive\/15{background-color:#fd486b26}.bg-emerald-500\/8{background-color:#00bb7f14}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/8{background-color:color-mix(in oklab,var(--color-emerald-500) 8%,transparent)}}.bg-emerald-500\/10{background-color:#00bb7f1a}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/10{background-color:color-mix(in oklab,var(--color-emerald-500) 10%,transparent)}}.bg-emerald-500\/15{background-color:#00bb7f26}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/15{background-color:color-mix(in oklab,var(--color-emerald-500) 15%,transparent)}}.bg-foreground{background-color:#f5f5f5}.bg-green-500{background-color:var(--color-green-500)}.bg-muted{background-color:#333}.bg-muted-foreground{background-color:#999}.bg-muted-foreground\/60{background-color:#9999}.bg-popover{background-color:#2a2a2a}.bg-primary{background-color:#3c8fff}.bg-red-500{background-color:var(--color-red-500)}.bg-red-500\/8{background-color:#fb2c3614}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/8{background-color:color-mix(in oklab,var(--color-red-500) 8%,transparent)}}.bg-red-500\/10{background-color:#fb2c361a}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/10{background-color:color-mix(in oklab,var(--color-red-500) 10%,transparent)}}.bg-secondary{background-color:#333}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/5{background-color:#ffffff0d}@supports (color:color-mix(in lab,red,red)){.bg-white\/5{background-color:color-mix(in oklab,var(--color-white) 5%,transparent)}}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.bg-white\/20{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.bg-white\/20{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.bg-white\/70{background-color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.bg-white\/70{background-color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.bg-white\/\[0\.02\]{background-color:#ffffff05}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.02\]{background-color:color-mix(in oklab,var(--color-white) 2%,transparent)}}.bg-white\/\[0\.03\]{background-color:#ffffff08}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.03\]{background-color:color-mix(in oklab,var(--color-white) 3%,transparent)}}.bg-white\/\[0\.04\]{background-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.04\]{background-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.bg-white\/\[0\.05\]{background-color:#ffffff0d}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.05\]{background-color:color-mix(in oklab,var(--color-white) 5%,transparent)}}.bg-white\/\[0\.06\]{background-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.06\]{background-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.bg-white\/\[0\.08\]{background-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.08\]{background-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.fill-current{fill:currentColor}.fill-foreground{fill:#f5f5f5}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.p-0{padding:calc(var(--spacing) * 0)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-\[3px\]{padding:3px}.p-px{padding:1px}.px-0\.5{padding-inline:calc(var(--spacing) * .5)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-3\.5{padding-inline:calc(var(--spacing) * 3.5)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-7{padding-inline:calc(var(--spacing) * 7)}.px-8{padding-inline:calc(var(--spacing) * 8)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.pt-2\.5{padding-top:calc(var(--spacing) * 2.5)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pt-8{padding-top:calc(var(--spacing) * 8)}.pr-0\.5{padding-right:calc(var(--spacing) * .5)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pr-8{padding-right:calc(var(--spacing) * 8)}.pr-10{padding-right:calc(var(--spacing) * 10)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.pb-8{padding-bottom:calc(var(--spacing) * 8)}.pl-1{padding-left:calc(var(--spacing) * 1)}.pl-2{padding-left:calc(var(--spacing) * 2)}.pl-4{padding-left:calc(var(--spacing) * 4)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.8rem\]{font-size:.8rem}.text-\[8px\]{font-size:8px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.leading-\[1\.1\]{--tw-leading:1.1;line-height:1.1}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-balance{text-wrap:balance}.break-words{overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.text-\[\#AF27E3\]{color:#af27e3}.text-\[\#AF27E3\]\/60{color:#af27e399}.text-amber-400{color:var(--color-amber-400)}.text-amber-400\/60{color:#fcbb0099}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/60{color:color-mix(in oklab,var(--color-amber-400) 60%,transparent)}}.text-amber-400\/70{color:#fcbb00b3}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/70{color:color-mix(in oklab,var(--color-amber-400) 70%,transparent)}}.text-amber-400\/90{color:#fcbb00e6}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/90{color:color-mix(in oklab,var(--color-amber-400) 90%,transparent)}}.text-background{color:#212121}.text-card-foreground{color:#f5f5f5}.text-destructive{color:#fd486b}.text-destructive-foreground{color:#fff}.text-emerald-400{color:var(--color-emerald-400)}.text-emerald-400\/60{color:#00d29499}@supports (color:color-mix(in lab,red,red)){.text-emerald-400\/60{color:color-mix(in oklab,var(--color-emerald-400) 60%,transparent)}}.text-emerald-400\/90{color:#00d294e6}@supports (color:color-mix(in lab,red,red)){.text-emerald-400\/90{color:color-mix(in oklab,var(--color-emerald-400) 90%,transparent)}}.text-foreground{color:#f5f5f5}.text-foreground\/60{color:#f5f5f599}.text-foreground\/80{color:#f5f5f5cc}.text-gray-400{color:var(--color-gray-400)}.text-gray-900{color:var(--color-gray-900)}.text-muted-foreground{color:#999}.text-muted-foreground\/50{color:#99999980}.text-popover-foreground{color:#f5f5f5}.text-primary{color:#3c8fff}.text-primary-foreground{color:#fff}.text-primary-foreground\/60{color:#fff9}.text-red-400{color:var(--color-red-400)}.text-red-400\/70{color:#ff6568b3}@supports (color:color-mix(in lab,red,red)){.text-red-400\/70{color:color-mix(in oklab,var(--color-red-400) 70%,transparent)}}.text-red-400\/90{color:#ff6568e6}@supports (color:color-mix(in lab,red,red)){.text-red-400\/90{color:color-mix(in oklab,var(--color-red-400) 90%,transparent)}}.text-secondary-foreground{color:#f5f5f5}.text-slate-500{color:var(--color-slate-500)}.text-white{color:var(--color-white)}.text-white\/20{color:#fff3}@supports (color:color-mix(in lab,red,red)){.text-white\/20{color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.text-white\/25{color:#ffffff40}@supports (color:color-mix(in lab,red,red)){.text-white\/25{color:color-mix(in oklab,var(--color-white) 25%,transparent)}}.text-white\/30{color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.text-white\/30{color:color-mix(in oklab,var(--color-white) 30%,transparent)}}.text-white\/35{color:#ffffff59}@supports (color:color-mix(in lab,red,red)){.text-white\/35{color:color-mix(in oklab,var(--color-white) 35%,transparent)}}.text-white\/40{color:#fff6}@supports (color:color-mix(in lab,red,red)){.text-white\/40{color:color-mix(in oklab,var(--color-white) 40%,transparent)}}.text-white\/50{color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.text-white\/50{color:color-mix(in oklab,var(--color-white) 50%,transparent)}}.text-white\/60{color:#fff9}@supports (color:color-mix(in lab,red,red)){.text-white\/60{color:color-mix(in oklab,var(--color-white) 60%,transparent)}}.text-white\/70{color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.text-white\/70{color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-100{opacity:1}.opacity-\[0\.06\]{opacity:.06}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xs{--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-0{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-background{--tw-ring-color:#212121}.ring-offset-background{--tw-ring-offset-color:#212121}.outline-hidden{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.outline-hidden{outline-offset:2px;outline:2px solid #0000}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.backdrop-blur-md{--tw-backdrop-blur:blur(var(--blur-md));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[width\]{transition-property:width;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.will-change-transform{will-change:transform}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media(hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.group-has-data-\[size\=lg\]\/avatar-group\:size-10:is(:where(.group\/avatar-group):has([data-size=lg]) *){width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.group-has-data-\[size\=sm\]\/avatar-group\:size-6:is(:where(.group\/avatar-group):has([data-size=sm]) *){width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.group-data-\[orientation\=horizontal\]\/tabs\:h-9:is(:where(.group\/tabs)[data-orientation=horizontal] *){height:calc(var(--spacing) * 9)}.group-data-\[orientation\=vertical\]\/tabs\:h-fit:is(:where(.group\/tabs)[data-orientation=vertical] *){height:fit-content}.group-data-\[orientation\=vertical\]\/tabs\:w-full:is(:where(.group\/tabs)[data-orientation=vertical] *){width:100%}.group-data-\[orientation\=vertical\]\/tabs\:flex-col:is(:where(.group\/tabs)[data-orientation=vertical] *){flex-direction:column}.group-data-\[orientation\=vertical\]\/tabs\:justify-start:is(:where(.group\/tabs)[data-orientation=vertical] *){justify-content:flex-start}.group-data-\[size\=default\]\/avatar\:size-2\.5:is(:where(.group\/avatar)[data-size=default] *){width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.group-data-\[size\=default\]\/switch\:size-4:is(:where(.group\/switch)[data-size=default] *){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.group-data-\[size\=lg\]\/avatar\:size-3:is(:where(.group\/avatar)[data-size=lg] *){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.group-data-\[size\=sm\]\/avatar\:size-2:is(:where(.group\/avatar)[data-size=sm] *){width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.group-data-\[size\=sm\]\/avatar\:text-xs:is(:where(.group\/avatar)[data-size=sm] *){font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.group-data-\[size\=sm\]\/switch\:size-3:is(:where(.group\/switch)[data-size=sm] *){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.group-data-\[variant\=line\]\/tabs-list\:bg-transparent:is(:where(.group\/tabs-list)[data-variant=line] *){background-color:#0000}.selection\:bg-primary ::selection{background-color:#3c8fff}.selection\:bg-primary::selection{background-color:#3c8fff}.selection\:text-primary-foreground ::selection{color:#fff}.selection\:text-primary-foreground::selection{color:#fff}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:calc(var(--spacing) * 7)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:#f5f5f5}.placeholder\:text-gray-400::placeholder{color:var(--color-gray-400)}.placeholder\:text-muted-foreground::placeholder{color:#999}.placeholder\:text-white\/20::placeholder{color:#fff3}@supports (color:color-mix(in lab,red,red)){.placeholder\:text-white\/20::placeholder{color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:bg-foreground:after{content:var(--tw-content);background-color:#f5f5f5}.after\:opacity-0:after{content:var(--tw-content);opacity:0}.after\:transition-opacity:after{content:var(--tw-content);transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.group-data-\[orientation\=horizontal\]\/tabs\:after\:inset-x-0:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);inset-inline:calc(var(--spacing) * 0)}.group-data-\[orientation\=horizontal\]\/tabs\:after\:bottom-\[-5px\]:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);bottom:-5px}.group-data-\[orientation\=horizontal\]\/tabs\:after\:h-0\.5:is(:where(.group\/tabs)[data-orientation=horizontal] *):after{content:var(--tw-content);height:calc(var(--spacing) * .5)}.group-data-\[orientation\=vertical\]\/tabs\:after\:inset-y-0:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);inset-block:calc(var(--spacing) * 0)}.group-data-\[orientation\=vertical\]\/tabs\:after\:-right-1:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);right:calc(var(--spacing) * -1)}.group-data-\[orientation\=vertical\]\/tabs\:after\:w-0\.5:is(:where(.group\/tabs)[data-orientation=vertical] *):after{content:var(--tw-content);width:calc(var(--spacing) * .5)}@media(hover:hover){.hover\:border-white\/10:hover{border-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:border-white\/10:hover{border-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.hover\:border-white\/15:hover{border-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.hover\:border-white\/15:hover{border-color:color-mix(in oklab,var(--color-white) 15%,transparent)}}.hover\:bg-accent:hover{background-color:#333}.hover\:bg-destructive\/90:hover{background-color:#fd486be6}.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:bg-primary\/90:hover{background-color:#3c8fffe6}.hover\:bg-secondary\/80:hover{background-color:#333c}.hover\:bg-white\/20:hover{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/20:hover{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.hover\:bg-white\/30:hover{background-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/30:hover{background-color:color-mix(in oklab,var(--color-white) 30%,transparent)}}.hover\:bg-white\/\[0\.1\]:hover{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.1\]:hover{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.hover\:bg-white\/\[0\.02\]:hover{background-color:#ffffff05}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.02\]:hover{background-color:color-mix(in oklab,var(--color-white) 2%,transparent)}}.hover\:bg-white\/\[0\.04\]:hover{background-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.04\]:hover{background-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.hover\:bg-white\/\[0\.06\]:hover{background-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.06\]:hover{background-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.hover\:bg-white\/\[0\.08\]:hover{background-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.08\]:hover{background-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.hover\:bg-white\/\[0\.09\]:hover{background-color:#ffffff17}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.09\]:hover{background-color:color-mix(in oklab,var(--color-white) 9%,transparent)}}.hover\:text-accent-foreground:hover,.hover\:text-foreground:hover{color:#f5f5f5}.hover\:text-gray-600:hover{color:var(--color-gray-600)}.hover\:text-white:hover{color:var(--color-white)}.hover\:text-white\/40:hover{color:#fff6}@supports (color:color-mix(in lab,red,red)){.hover\:text-white\/40:hover{color:color-mix(in oklab,var(--color-white) 40%,transparent)}}.hover\:text-white\/50:hover{color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.hover\:text-white\/50:hover{color:color-mix(in oklab,var(--color-white) 50%,transparent)}}.hover\:text-white\/60:hover{color:#fff9}@supports (color:color-mix(in lab,red,red)){.hover\:text-white\/60:hover{color:color-mix(in oklab,var(--color-white) 60%,transparent)}}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-80:hover{opacity:.8}.hover\:opacity-90:hover{opacity:.9}.hover\:opacity-100:hover{opacity:1}.hover\:brightness-110:hover{--tw-brightness:brightness(110%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}.focus\:border-\[\#AF27E3\]\/30:focus{border-color:#af27e34d}.focus\:bg-accent:focus{background-color:#333}.focus\:text-accent-foreground:focus{color:#f5f5f5}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:#3c8fff}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-hidden:focus{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.focus\:outline-hidden:focus{outline-offset:2px;outline:2px solid #0000}}.focus-visible\:border-ring:focus-visible{border-color:#3c8fff}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:oklab(67.0267% .20922 .0534847/.2)}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:oklab(65.65% -.0412982 -.180011/.5)}.focus-visible\:outline-1:focus-visible{outline-style:var(--tw-outline-style);outline-width:1px}.focus-visible\:outline-ring:focus-visible{outline-color:#3c8fff}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}.has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\]:has([data-slot=card-action]){grid-template-columns:1fr auto}.has-\[\>svg\]\:px-1\.5:has(>svg){padding-inline:calc(var(--spacing) * 1.5)}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing) * 2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing) * 3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing) * 4)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:#fd486b}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:oklab(67.0267% .20922 .0534847/.2)}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[inset\]\:pl-8[data-inset]{padding-left:calc(var(--spacing) * 8)}.data-\[orientation\=horizontal\]\:h-px[data-orientation=horizontal]{height:1px}.data-\[orientation\=horizontal\]\:w-full[data-orientation=horizontal]{width:100%}.data-\[orientation\=horizontal\]\:flex-col[data-orientation=horizontal]{flex-direction:column}.data-\[orientation\=vertical\]\:h-full[data-orientation=vertical]{height:100%}.data-\[orientation\=vertical\]\:w-px[data-orientation=vertical]{width:1px}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:#999}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[size\=default\]\:h-9[data-size=default]{height:calc(var(--spacing) * 9)}.data-\[size\=default\]\:h-\[1\.15rem\][data-size=default]{height:1.15rem}.data-\[size\=default\]\:w-8[data-size=default]{width:calc(var(--spacing) * 8)}.data-\[size\=lg\]\:size-10[data-size=lg]{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.data-\[size\=sm\]\:size-6[data-size=sm]{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.data-\[size\=sm\]\:h-3\.5[data-size=sm]{height:calc(var(--spacing) * 3.5)}.data-\[size\=sm\]\:h-8[data-size=sm]{height:calc(var(--spacing) * 8)}.data-\[size\=sm\]\:w-6[data-size=sm]{width:calc(var(--spacing) * 6)}:is(.\*\:data-\[slot\=avatar\]\:ring-2>*)[data-slot=avatar]{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}:is(.\*\:data-\[slot\=avatar\]\:ring-background>*)[data-slot=avatar]{--tw-ring-color:#212121}:is(.\*\:data-\[slot\=select-value\]\:line-clamp-1>*)[data-slot=select-value]{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}:is(.\*\:data-\[slot\=select-value\]\:flex>*)[data-slot=select-value]{display:flex}:is(.\*\:data-\[slot\=select-value\]\:items-center>*)[data-slot=select-value]{align-items:center}:is(.\*\:data-\[slot\=select-value\]\:gap-2>*)[data-slot=select-value]{gap:calc(var(--spacing) * 2)}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:#212121}.data-\[state\=active\]\:bg-primary[data-state=active]{background-color:#3c8fff}.data-\[state\=active\]\:text-foreground[data-state=active]{color:#f5f5f5}.data-\[state\=active\]\:text-primary-foreground[data-state=active]{color:#fff}.data-\[state\=active\]\:shadow-none[data-state=active]{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=default\]\/tabs-list\:data-\[state\=active\]\:shadow-sm:is(:where(.group\/tabs-list)[data-variant=default] *)[data-state=active]{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:bg-transparent:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{background-color:#0000}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:shadow-none:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:after\:opacity-100:is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]:after{content:var(--tw-content);opacity:1}.data-\[state\=checked\]\:translate-x-\[calc\(100\%-2px\)\][data-state=checked]{--tw-translate-x: calc(100% - 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:#3c8fff}.data-\[state\=closed\]\:duration-300[data-state=closed]{--tw-duration:.3s;transition-duration:.3s}.data-\[state\=open\]\:bg-accent[data-state=open],.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:#333}.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:#f5f5f5}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:#999}.data-\[state\=open\]\:duration-500[data-state=open]{--tw-duration:.5s;transition-duration:.5s}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:#3a3a3a}.data-\[variant\=destructive\]\:text-destructive[data-variant=destructive]{color:#fd486b}.data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant=destructive]:focus{background-color:#fd486b1a}.data-\[variant\=destructive\]\:focus\:text-destructive[data-variant=destructive]:focus{color:#fd486b}.data-\[variant\=line\]\:rounded-none[data-variant=line]{border-radius:0}@media(min-width:40rem){.sm\:mt-4{margin-top:calc(var(--spacing) * 4)}.sm\:mb-6{margin-bottom:calc(var(--spacing) * 6)}.sm\:block{display:block}.sm\:h-2\.5{height:calc(var(--spacing) * 2.5)}.sm\:w-2\.5{width:calc(var(--spacing) * 2.5)}.sm\:w-16{width:calc(var(--spacing) * 16)}.sm\:max-w-lg{max-width:var(--container-lg)}.sm\:max-w-sm{max-width:var(--container-sm)}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:items-start{align-items:flex-start}.sm\:justify-between{justify-content:space-between}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2{gap:calc(var(--spacing) * 2)}.sm\:gap-3{gap:calc(var(--spacing) * 3)}.sm\:gap-4{gap:calc(var(--spacing) * 4)}:where(.sm\:space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.sm\:space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}.sm\:p-6{padding:calc(var(--spacing) * 6)}.sm\:px-4{padding-inline:calc(var(--spacing) * 4)}.sm\:py-2{padding-block:calc(var(--spacing) * 2)}.sm\:text-left{text-align:left}.sm\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.sm\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.sm\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.sm\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.sm\:text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}}@media(min-width:48rem){.md\:block{display:block}.md\:flex{display:flex}.md\:hidden{display:none}.md\:p-6{padding:calc(var(--spacing) * 6)}.md\:px-6{padding-inline:calc(var(--spacing) * 6)}.md\:py-4{padding-block:calc(var(--spacing) * 4)}.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}@media(min-width:64rem){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.dark\:border-input:is(.dark *){border-color:#3a3a3a}.dark\:bg-destructive\/60:is(.dark *){background-color:#fd486b99}.dark\:bg-input\/30:is(.dark *){background-color:#3a3a3a4d}.dark\:text-muted-foreground:is(.dark *){color:#999}@media(hover:hover){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:#33333380}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:#3a3a3a80}.dark\:hover\:text-foreground:is(.dark *):hover{color:#f5f5f5}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible,.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:oklab(67.0267% .20922 .0534847/.4)}.dark\:data-\[state\=active\]\:border-input:is(.dark *)[data-state=active]{border-color:#3a3a3a}.dark\:data-\[state\=active\]\:bg-input\/30:is(.dark *)[data-state=active]{background-color:#3a3a3a4d}.dark\:data-\[state\=active\]\:text-foreground:is(.dark *)[data-state=active]{color:#f5f5f5}.dark\:group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:border-transparent:is(.dark *):is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{border-color:#0000}.dark\:group-data-\[variant\=line\]\/tabs-list\:data-\[state\=active\]\:bg-transparent:is(.dark *):is(:where(.group\/tabs-list)[data-variant=line] *)[data-state=active]{background-color:#0000}.dark\:data-\[state\=checked\]\:bg-primary-foreground:is(.dark *)[data-state=checked]{background-color:#fff}.dark\:data-\[state\=unchecked\]\:bg-foreground:is(.dark *)[data-state=unchecked]{background-color:#f5f5f5}.dark\:data-\[state\=unchecked\]\:bg-input\/80:is(.dark *)[data-state=unchecked]{background-color:#3a3a3acc}.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:is(.dark *)[data-variant=destructive]:focus{background-color:#fd486b33}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground svg:not([class*=text-]){color:#999}.\[\.border-b\]\:pb-6.border-b{padding-bottom:calc(var(--spacing) * 6)}.\[\.border-t\]\:pt-6.border-t{padding-top:calc(var(--spacing) * 6)}:is(.\*\:\[span\]\:last\:flex>*):is(span):last-child{display:flex}:is(.\*\:\[span\]\:last\:items-center>*):is(span):last-child{align-items:center}:is(.\*\:\[span\]\:last\:gap-2>*):is(span):last-child{gap:calc(var(--spacing) * 2)}:is(.data-\[variant\=destructive\]\:\*\:\[svg\]\:\!text-destructive[data-variant=destructive]>*):is(svg){color:#fd486b!important}.\[\&\>\*\:first-child\]\:mt-0>:first-child{margin-top:calc(var(--spacing) * 0)}.\[\&\>\*\:last-child\]\:mb-0>:last-child{margin-bottom:calc(var(--spacing) * 0)}.\[\&\>svg\]\:pointer-events-none>svg{pointer-events:none}.\[\&\>svg\]\:size-3>svg{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&\>svg\]\:size-4>svg{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.group-has-data-\[size\=lg\]\/avatar-group\:\[\&\>svg\]\:size-5:is(:where(.group\/avatar-group):has([data-size=lg]) *)>svg{width:calc(var(--spacing) * 5);height:calc(var(--spacing) * 5)}.group-has-data-\[size\=sm\]\/avatar-group\:\[\&\>svg\]\:size-3:is(:where(.group\/avatar-group):has([data-size=sm]) *)>svg{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.group-data-\[size\=default\]\/avatar\:\[\&\>svg\]\:size-2:is(:where(.group\/avatar)[data-size=default] *)>svg,.group-data-\[size\=lg\]\/avatar\:\[\&\>svg\]\:size-2:is(:where(.group\/avatar)[data-size=lg] *)>svg{width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.group-data-\[size\=sm\]\/avatar\:\[\&\>svg\]\:hidden:is(:where(.group\/avatar)[data-size=sm] *)>svg{display:none}@media(hover:hover){a.\[a\&\]\:hover\:bg-accent:hover{background-color:#333}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:#fd486be6}a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:#3c8fffe6}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:#333333e6}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:#f5f5f5}a.\[a\&\]\:hover\:underline:hover{text-decoration-line:underline}}}body{background-color:var(--color-background);color:var(--color-foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background-color:#af27e340}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4a4a4a}.text-gradient{color:#0000;-webkit-text-fill-color:transparent;background-image:linear-gradient(135deg,#04d1fe,#af27e3,#fb4072);-webkit-background-clip:text;background-clip:text}.bg-gradient-brand{background-image:linear-gradient(135deg,#04d1fe,#af27e3,#fb4072)}.glow-border{box-shadow:0 0 0 1px #af27e31a,0 0 20px -5px #af27e326}.animated-border{position:relative;overflow:hidden}.animated-border:before{content:"";background:conic-gradient(#04d1fe,#af27e3,#fb4072,#04d1fe);animation:3s linear infinite border-spin;position:absolute;inset:-150%}.animated-border>*{z-index:1;position:relative}.animated-border-slow:before{animation-duration:5s}.input-glow:focus{border-color:#af27e366;box-shadow:0 0 0 1px #af27e326,0 0 20px -5px #af27e340,0 0 4px -1px #04d1fe1a}@keyframes border-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@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}@keyframes spin{to{transform:rotate(360deg)}}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}@keyframes pulse{50%{opacity:.5}}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}
@@ -4,8 +4,8 @@
4
4
  <meta charset="UTF-8" />
5
5
  <meta name="viewport" content="width=device-width, initial-scale=1.0, interactive-widget=resizes-content" />
6
6
  <title>Fluxy Chat</title>
7
- <script type="module" crossorigin src="/fluxy/assets/fluxy-Bja2ie0F.js"></script>
8
- <link rel="stylesheet" crossorigin href="/fluxy/assets/fluxy-CTBZksup.css">
7
+ <script type="module" crossorigin src="/fluxy/assets/fluxy-CtIx2O_C.js"></script>
8
+ <link rel="stylesheet" crossorigin href="/fluxy/assets/fluxy-Dtd8GixO.css">
9
9
  </head>
10
10
  <body class="bg-background text-foreground">
11
11
  <div id="root"></div>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "fluxy-bot",
3
- "version": "0.2.11",
3
+ "version": "0.2.13",
4
4
  "description": "Self-hosted AI bot — run your own AI assistant from anywhere",
5
5
  "type": "module",
6
6
  "license": "MIT",
@@ -44,32 +44,20 @@
44
44
  },
45
45
  "dependencies": {
46
46
  "@anthropic-ai/claude-agent-sdk": "^0.2.50",
47
- "better-sqlite3": "^12.6.2",
48
- "express": "^5.2.1",
49
- "radix-ui": "^1.4.3",
50
- "tsx": "^4.21.0",
51
- "ws": "^8.19.0"
52
- },
53
- "devDependencies": {
54
47
  "@react-three/drei": "^10.7.7",
55
48
  "@react-three/fiber": "^9.5.0",
56
49
  "@tailwindcss/postcss": "^4.2.0",
57
50
  "@tailwindcss/vite": "^4.2.0",
58
- "@types/better-sqlite3": "^7.6.13",
59
- "@types/express": "^5.0.6",
60
- "@types/node": "^25.3.0",
61
- "@types/react": "^19.2.14",
62
- "@types/react-dom": "^19.2.3",
63
- "@types/react-syntax-highlighter": "^15.5.13",
64
- "@types/ws": "^8.18.1",
65
51
  "@vitejs/plugin-react": "^5.1.4",
52
+ "better-sqlite3": "^12.6.2",
66
53
  "class-variance-authority": "^0.7.1",
67
54
  "clsx": "^2.1.1",
68
- "concurrently": "^9.2.1",
69
55
  "date-fns": "^4.1.0",
56
+ "express": "^5.2.1",
70
57
  "framer-motion": "^12.34.3",
71
58
  "lucide-react": "^0.575.0",
72
59
  "postcss": "^8.5.6",
60
+ "radix-ui": "^1.4.3",
73
61
  "react": "^19.2.4",
74
62
  "react-dom": "^19.2.4",
75
63
  "react-markdown": "^10.1.0",
@@ -80,9 +68,21 @@
80
68
  "tailwind-merge": "^3.5.0",
81
69
  "tailwindcss": "^4.2.0",
82
70
  "three": "^0.183.1",
83
- "typescript": "^5.9.3",
71
+ "tsx": "^4.21.0",
84
72
  "vite": "^7.3.1",
85
73
  "vite-plugin-pwa": "^1.2.0",
74
+ "ws": "^8.19.0",
86
75
  "zustand": "^5.0.11"
76
+ },
77
+ "devDependencies": {
78
+ "@types/better-sqlite3": "^7.6.13",
79
+ "@types/express": "^5.0.6",
80
+ "@types/node": "^25.3.0",
81
+ "@types/react": "^19.2.14",
82
+ "@types/react-dom": "^19.2.3",
83
+ "@types/react-syntax-highlighter": "^15.5.13",
84
+ "@types/ws": "^8.18.1",
85
+ "concurrently": "^9.2.1",
86
+ "typescript": "^5.9.3"
87
87
  }
88
88
  }
package/postcss.config.js CHANGED
@@ -1,5 +1,5 @@
1
1
  export default {
2
2
  plugins: {
3
- '@tailwindcss/postcss': {},
3
+ // Tailwind is handled by @tailwindcss/vite plugin — no PostCSS plugin needed
4
4
  },
5
5
  };