@botuyo/chat-widget-standalone 1.0.65 → 1.0.66
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -21
- package/dist/Avatar3D-LfNJe183.js.map +1 -1
- package/dist/botuyo-chat.es.js +1 -1
- package/dist/botuyo-chat.es.js.map +1 -1
- package/dist/botuyo-chat.umd.js +1 -1
- package/dist/botuyo-chat.umd.js.map +1 -1
- package/dist/chunk-audio-f-7lTw8u.js.map +1 -1
- package/dist/chunk-chat-ui-C3MpSoay.js.map +1 -1
- package/dist/chunk-gallery-UGD27UqU.js.map +1 -1
- package/dist/src/chat-widget/components/Gallery.stories.d.ts.map +1 -1
- package/dist/stats-umd.html +1 -1
- package/dist/stats.html +1 -1
- package/package.json +155 -155
package/LICENSE
CHANGED
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
MIT License
|
|
2
|
-
|
|
3
|
-
Copyright (c) 2026 Paseo Libre
|
|
4
|
-
|
|
5
|
-
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
in the Software without restriction, including without limitation the rights
|
|
8
|
-
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
furnished to do so, subject to the following conditions:
|
|
11
|
-
|
|
12
|
-
The above copyright notice and this permission notice shall be included in all
|
|
13
|
-
copies or substantial portions of the Software.
|
|
14
|
-
|
|
15
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
-
SOFTWARE.
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2026 Paseo Libre
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Avatar3D-LfNJe183.js","sources":["../src/chat-widget/components/Avatar3D.tsx"],"sourcesContent":["/**\r\n * @package @botuyo/chat-widget\r\n * Avatar3D Component — Lazy-loaded 3D avatar for voice calls\r\n *\r\n * Uses React Three Fiber + @pixiv/three-vrm to render VRM models\r\n * with emotion-driven blendshapes and idle animations.\r\n *\r\n * This component is loaded via React.lazy() — it adds 0KB to the\r\n * main bundle. Three.js + VRM are only downloaded when a tenant\r\n * has avatar3dUrl configured.\r\n */\r\n\r\n// React Three Fiber types are resolved via tsconfig\r\n'use client'\r\n\r\nimport { useRef, useEffect, useMemo } from 'react'\r\nimport { Canvas, useFrame, useThree } from '@react-three/fiber'\r\nimport { VRMLoaderPlugin, VRMExpressionPresetName, VRM } from '@pixiv/three-vrm'\r\nimport * as THREE from 'three'\r\nimport { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader.js'\r\n\r\n// ═══════════════════════════════════════\r\n// TYPES\r\n// ═══════════════════════════════════════\r\n\r\ntype CallState = 'idle' | 'connecting' | 'listening' | 'speaking' | 'thinking'\r\n\r\ninterface Avatar3DProps {\r\n modelUrl: string\r\n emotion: string | null\r\n callState: CallState\r\n audioLevel: number\r\n primaryColor: string\r\n size: number\r\n}\r\n\r\n// ═══════════════════════════════════════\r\n// EMOTION → VRM BLENDSHAPE MAPPING\r\n// ═══════════════════════════════════════\r\n\r\ninterface EmotionConfig {\r\n expressions: Record<string, number> // VRM expression name → weight 0-1\r\n headRotation?: [number, number, number] // euler XYZ in radians\r\n}\r\n\r\nconst EMOTION_MAP: Record<string, EmotionConfig> = {\r\n default: {\r\n expressions: { [VRMExpressionPresetName.Neutral]: 1 },\r\n },\r\n happy: {\r\n expressions: { [VRMExpressionPresetName.Happy]: 0.8 },\r\n },\r\n angry: {\r\n expressions: { [VRMExpressionPresetName.Angry]: 0.7 },\r\n headRotation: [0.05, 0, 0],\r\n },\r\n sorry: {\r\n expressions: { [VRMExpressionPresetName.Sad]: 0.6 },\r\n headRotation: [-0.08, 0, 0],\r\n },\r\n confused: {\r\n expressions: { [VRMExpressionPresetName.Sad]: 0.3 },\r\n headRotation: [0, 0, 0.08],\r\n },\r\n love: {\r\n expressions: { [VRMExpressionPresetName.Happy]: 0.9, [VRMExpressionPresetName.Relaxed]: 0.4 },\r\n },\r\n thinking: {\r\n expressions: { [VRMExpressionPresetName.Neutral]: 0.6 },\r\n headRotation: [0.06, -0.1, 0],\r\n },\r\n writing: {\r\n expressions: { [VRMExpressionPresetName.Neutral]: 0.8 },\r\n headRotation: [-0.05, 0, 0],\r\n },\r\n wink: {\r\n expressions: { [VRMExpressionPresetName.Happy]: 0.5, [VRMExpressionPresetName.Blink]: 0.9 },\r\n },\r\n}\r\n\r\n// ═══════════════════════════════════════\r\n// VRM MODEL COMPONENT (inside Canvas)\r\n// ═══════════════════════════════════════\r\n\r\ninterface VRMModelProps {\r\n url: string\r\n emotion: string | null\r\n callState: CallState\r\n audioLevel: number\r\n}\r\n\r\nfunction VRMModel({ url, emotion, callState, audioLevel }: VRMModelProps) {\r\n const vrmRef = useRef<VRM | null>(null)\r\n const glbSceneRef = useRef<THREE.Group | null>(null)\r\n const mixerRef = useRef<THREE.AnimationMixer | null>(null)\r\n const baseRotationY = useRef(0)\r\n const baseScale = useRef(1)\r\n const blinkTimer = useRef(0)\r\n const nextBlinkAt = useRef(3.5) // Initial value, randomized in useFrame\r\n const breathPhase = useRef(0)\r\n const currentExpressions = useRef<Record<string, number>>({})\r\n const targetExpressions = useRef<Record<string, number>>({})\r\n const headTarget = useRef(new THREE.Euler(0, 0, 0))\r\n const baseY = useRef(0)\r\n const { scene, camera } = useThree()\r\n\r\n // Load model using Three.js GLTFLoader (with VRM plugin for VRM models)\r\n useEffect(() => {\r\n const loader = new GLTFLoader()\r\n loader.register((parser) => new VRMLoaderPlugin(parser) as any)\r\n\r\n loader.load(\r\n url,\r\n (gltf) => {\r\n const vrm = (gltf as any).userData?.vrm as VRM | undefined\r\n if (vrm) {\r\n // ── VRM MODEL PATH ──\r\n vrmRef.current = vrm\r\n vrm.scene.rotation.y = Math.PI\r\n const box = new THREE.Box3().setFromObject(vrm.scene)\r\n const center = box.getCenter(new THREE.Vector3())\r\n const height = box.getSize(new THREE.Vector3()).y\r\n vrm.scene.position.y = -center.y - height * 0.05\r\n baseY.current = vrm.scene.position.y\r\n scene.add(vrm.scene)\r\n } else {\r\n // ── PLAIN GLB FALLBACK ──\r\n console.info('[Avatar3D] Plain GLB model detected, using fallback animations')\r\n const model = gltf.scene\r\n\r\n // Force world matrix update so bbox is accurate\r\n model.updateMatrixWorld(true)\r\n const box = new THREE.Box3().setFromObject(model)\r\n const center = box.getCenter(new THREE.Vector3())\r\n const size = box.getSize(new THREE.Vector3())\r\n\r\n // Create pivot wrapper for proper rotation around geometric center\r\n const pivot = new THREE.Group()\r\n\r\n // Center model geometry at pivot origin\r\n model.position.sub(center)\r\n pivot.add(model)\r\n\r\n // Don't rotate the model — move the CAMERA to the front instead\r\n baseRotationY.current = 0\r\n\r\n glbSceneRef.current = pivot\r\n baseY.current = 0\r\n baseScale.current = 1\r\n scene.add(pivot)\r\n\r\n // Frame the HEAD: camera at -Z (model faces -Z based on tests)\r\n const fov = (camera as THREE.PerspectiveCamera).fov * (Math.PI / 180)\r\n const headY = size.y * 0.35\r\n const cameraZ = (size.y * 0.5) / Math.tan(fov / 2)\r\n // Camera on the -Z side to see the model's FRONT\r\n camera.position.set(0, headY, -cameraZ)\r\n camera.lookAt(0, headY, 0)\r\n\r\n // Play embedded animations if available\r\n if (gltf.animations.length > 0) {\r\n const mixer = new THREE.AnimationMixer(model)\r\n mixerRef.current = mixer\r\n gltf.animations.forEach((clip) => {\r\n mixer.clipAction(clip).play()\r\n })\r\n }\r\n }\r\n },\r\n undefined,\r\n (error) => {\r\n console.error('[Avatar3D] Failed to load model:', error)\r\n },\r\n )\r\n\r\n return () => {\r\n if (vrmRef.current) {\r\n scene.remove(vrmRef.current.scene)\r\n vrmRef.current = null\r\n }\r\n if (glbSceneRef.current) {\r\n scene.remove(glbSceneRef.current)\r\n glbSceneRef.current = null\r\n }\r\n if (mixerRef.current) {\r\n mixerRef.current.stopAllAction()\r\n mixerRef.current = null\r\n }\r\n }\r\n }, [url, scene])\r\n\r\n // Update target expressions when emotion changes (VRM only)\r\n useEffect(() => {\r\n const config = EMOTION_MAP[emotion || 'default'] || EMOTION_MAP.default\r\n targetExpressions.current = config.expressions\r\n if (config.headRotation) {\r\n headTarget.current.set(...config.headRotation)\r\n } else {\r\n headTarget.current.set(0, 0, 0)\r\n }\r\n }, [emotion])\r\n\r\n // Animation loop\r\n useFrame((_, delta) => {\r\n const dt = Math.min(delta, 0.1) // Cap delta to avoid jumps\r\n breathPhase.current += dt * 1.2\r\n\r\n // ── GLB FALLBACK ANIMATION ──\r\n const glb = glbSceneRef.current\r\n if (glb) {\r\n // Update animation mixer if present\r\n if (mixerRef.current) {\r\n mixerRef.current.update(dt)\r\n }\r\n\r\n // Gentle breathing bob\r\n const breathOffset = Math.sin(breathPhase.current) * 0.003\r\n glb.position.y = baseY.current + breathOffset\r\n\r\n // Subtle idle rotation (relative to base facing direction)\r\n const idleSway = Math.sin(breathPhase.current * 0.3) * 0.02\r\n glb.rotation.y = baseRotationY.current + idleSway\r\n\r\n // Audio-reactive scale pulse when speaking\r\n if (callState === 'speaking' && audioLevel > 0.01) {\r\n const pulse = 1 + audioLevel * 0.03\r\n const targetScale = baseScale.current * pulse\r\n const currentScale = glb.scale.x\r\n glb.scale.setScalar(THREE.MathUtils.lerp(currentScale, targetScale, 0.1))\r\n } else {\r\n // Return to base scale smoothly\r\n const currentScale = glb.scale.x\r\n if (Math.abs(currentScale - baseScale.current) > 0.001) {\r\n glb.scale.setScalar(THREE.MathUtils.lerp(currentScale, baseScale.current, 0.05))\r\n }\r\n }\r\n\r\n return // Skip VRM-specific code\r\n }\r\n\r\n // ── VRM ANIMATION (original code) ──\r\n const vrm = vrmRef.current\r\n if (!vrm) return\r\n\r\n // ── BREATHING ──\r\n const breathOffset = Math.sin(breathPhase.current) * 0.003\r\n vrm.scene.position.y = baseY.current + breathOffset\r\n\r\n // ── BLINKING ──\r\n blinkTimer.current += dt\r\n if (blinkTimer.current >= nextBlinkAt.current) {\r\n const blinkProgress = (blinkTimer.current - nextBlinkAt.current) / 0.15\r\n if (blinkProgress < 1) {\r\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Blink, blinkProgress)\r\n } else if (blinkProgress < 2) {\r\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Blink, 2 - blinkProgress)\r\n } else {\r\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Blink, 0)\r\n blinkTimer.current = 0\r\n nextBlinkAt.current = Math.random() * 4 + 2\r\n }\r\n }\r\n\r\n // ── EMOTION BLENDING ──\r\n const lerpSpeed = 4 * dt\r\n const allKeys = new Set([\r\n ...Object.keys(currentExpressions.current),\r\n ...Object.keys(targetExpressions.current),\r\n ])\r\n\r\n for (const key of allKeys) {\r\n const current = currentExpressions.current[key] || 0\r\n const target = targetExpressions.current[key] || 0\r\n const next = THREE.MathUtils.lerp(current, target, lerpSpeed)\r\n currentExpressions.current[key] = next\r\n\r\n // Don't override blink during active blink animation\r\n if (key === VRMExpressionPresetName.Blink && blinkTimer.current >= nextBlinkAt.current) continue\r\n\r\n vrm.expressionManager?.setValue(key, next)\r\n }\r\n\r\n // ── SPEAKING MOUTH ──\r\n if (callState === 'speaking' && audioLevel > 0.01) {\r\n const mouthTarget = Math.min(audioLevel * 1.5, 0.8)\r\n const currentMouth = vrm.expressionManager?.getValue(VRMExpressionPresetName.Aa) || 0\r\n const smoothMouth = THREE.MathUtils.lerp(currentMouth, mouthTarget, 8 * dt)\r\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Aa, smoothMouth)\r\n } else {\r\n const currentMouth = vrm.expressionManager?.getValue(VRMExpressionPresetName.Aa) || 0\r\n if (currentMouth > 0.01) {\r\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Aa, currentMouth * 0.9)\r\n }\r\n }\r\n\r\n // ── HEAD MOVEMENT ──\r\n if (vrm.humanoid) {\r\n const head = vrm.humanoid.getNormalizedBoneNode('head')\r\n if (head) {\r\n const idleSwayX = Math.sin(breathPhase.current * 0.3) * 0.01\r\n const idleSwayZ = Math.cos(breathPhase.current * 0.2) * 0.005\r\n\r\n const targetX = headTarget.current.x + idleSwayX\r\n const targetY = headTarget.current.y\r\n const targetZ = headTarget.current.z + idleSwayZ\r\n\r\n head.rotation.x = THREE.MathUtils.lerp(head.rotation.x, targetX, 3 * dt)\r\n head.rotation.y = THREE.MathUtils.lerp(head.rotation.y, targetY, 3 * dt)\r\n head.rotation.z = THREE.MathUtils.lerp(head.rotation.z, targetZ, 3 * dt)\r\n }\r\n }\r\n\r\n // ── CALL STATE REACTIONS ──\r\n if (callState === 'listening' && vrm.humanoid) {\r\n const head = vrm.humanoid.getNormalizedBoneNode('head')\r\n if (head) {\r\n head.rotation.z = THREE.MathUtils.lerp(head.rotation.z, 0.03, 2 * dt)\r\n }\r\n }\r\n\r\n // Update VRM (required for expression changes to take effect)\r\n vrm.update(dt)\r\n })\r\n\r\n return null\r\n}\r\n\r\n// ═══════════════════════════════════════\r\n// AUTO CAMERA FRAMING\r\n// ═══════════════════════════════════════\r\n\r\nfunction CameraSetup() {\r\n const { camera } = useThree()\r\n useEffect(() => {\r\n // Default camera position — will be overridden by model loader for GLB\r\n // For VRM: fixed head-level framing\r\n camera.position.set(0, 0.1, 0.6)\r\n camera.lookAt(0, 0.1, 0)\r\n }, [camera])\r\n return null\r\n}\r\n\r\n// ═══════════════════════════════════════\r\n// MAIN AVATAR 3D COMPONENT (exported)\r\n// ═══════════════════════════════════════\r\n\r\nexport default function Avatar3D({\r\n modelUrl,\r\n emotion,\r\n callState,\r\n audioLevel,\r\n primaryColor,\r\n size,\r\n}: Avatar3DProps) {\r\n const glowIntensity = useMemo(() => {\r\n switch (callState) {\r\n case 'speaking': return 0.6\r\n case 'listening': return 0.4\r\n case 'thinking': return 0.3\r\n default: return 0.15\r\n }\r\n }, [callState])\r\n\r\n const isActive = callState === 'listening' || callState === 'speaking'\r\n\r\n return (\r\n <div className=\"relative flex flex-col items-center gap-4\">\r\n {/* Glow ring behind canvas */}\r\n <div\r\n className=\"relative rounded-full overflow-hidden\"\r\n style={{\r\n width: `${size}px`,\r\n height: `${size}px`,\r\n boxShadow: isActive\r\n ? `0 0 0 3px ${primaryColor}50, 0 0 30px ${primaryColor}${Math.floor(glowIntensity * 255).toString(16).padStart(2, '0')}, 0 0 60px ${primaryColor}20`\r\n : `0 0 0 2px ${primaryColor}25`,\r\n transition: 'box-shadow 0.5s ease',\r\n }}\r\n >\r\n <Canvas\r\n style={{ width: '100%', height: '100%', background: 'transparent' }}\r\n gl={{ alpha: true, antialias: true, preserveDrawingBuffer: false }}\r\n camera={{ fov: 30, near: 0.01, far: 10 }}\r\n dpr={[1, 2]}\r\n >\r\n <CameraSetup />\r\n\r\n {/* Lighting — soft studio setup */}\r\n {/* @ts-ignore R3F IntrinsicElements conflict */}\r\n <ambientLight intensity={0.6} />\r\n {/* @ts-ignore */}\r\n <directionalLight position={[1, 2, 3]} intensity={0.8} color=\"#ffffff\" />\r\n {/* @ts-ignore */}\r\n <directionalLight position={[-1, 1, -1]} intensity={0.3} color=\"#b4c6e7\" />\r\n\r\n {/* Rim light for depth — matches primary color */}\r\n {/* @ts-ignore */}\r\n <pointLight\r\n position={[0, 0.5, -0.5]}\r\n intensity={glowIntensity * 2}\r\n color={primaryColor}\r\n distance={3}\r\n />\r\n\r\n <VRMModel\r\n url={modelUrl}\r\n emotion={emotion}\r\n callState={callState}\r\n audioLevel={audioLevel}\r\n />\r\n </Canvas>\r\n </div>\r\n </div>\r\n )\r\n}\r\n"],"names":["EMOTION_MAP","default","expressions","VRMExpressionPresetName","Neutral","happy","Happy","angry","Angry","headRotation","sorry","Sad","confused","love","Relaxed","thinking","writing","wink","Blink","VRMModel","url","emotion","callState","audioLevel","vrmRef","useRef","glbSceneRef","mixerRef","baseRotationY","baseScale","blinkTimer","nextBlinkAt","breathPhase","currentExpressions","targetExpressions","headTarget","THREE","Euler","baseY","scene","camera","useThree","useEffect","loader","GLTFLoader","register","parser","VRMLoaderPlugin","load","gltf","vrm","userData","current","rotation","y","Math","PI","box","Box3","setFromObject","center","getCenter","Vector3","height","getSize","position","add","console","info","model","updateMatrixWorld","size","pivot","Group","sub","fov","headY","cameraZ","tan","set","lookAt","animations","length","mixer","AnimationMixer","forEach","clip","clipAction","play","error","remove","stopAllAction","config","useFrame","_","delta","dt","min","glb","update","breathOffset","sin","idleSway","pulse","targetScale","currentScale","scale","x","setScalar","MathUtils","lerp","abs","blinkProgress","expressionManager","setValue","random","lerpSpeed","allKeys","Set","Object","keys","key","target","next","mouthTarget","currentMouth","getValue","Aa","smoothMouth","humanoid","head","getNormalizedBoneNode","idleSwayX","idleSwayZ","cos","targetX","targetY","targetZ","z","CameraSetup","Avatar3D","modelUrl","primaryColor","glowIntensity","useMemo","jsx","className","children","style","width","boxShadow","floor","toString","padStart","transition","jsxs","Canvas","background","gl","alpha","antialias","preserveDrawingBuffer","near","far","dpr","intensity","color","distance"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Avatar3D-LfNJe183.js","sources":["../src/chat-widget/components/Avatar3D.tsx"],"sourcesContent":["/**\n * @package @botuyo/chat-widget\n * Avatar3D Component — Lazy-loaded 3D avatar for voice calls\n *\n * Uses React Three Fiber + @pixiv/three-vrm to render VRM models\n * with emotion-driven blendshapes and idle animations.\n *\n * This component is loaded via React.lazy() — it adds 0KB to the\n * main bundle. Three.js + VRM are only downloaded when a tenant\n * has avatar3dUrl configured.\n */\n\n// React Three Fiber types are resolved via tsconfig\n'use client'\n\nimport { useRef, useEffect, useMemo } from 'react'\nimport { Canvas, useFrame, useThree } from '@react-three/fiber'\nimport { VRMLoaderPlugin, VRMExpressionPresetName, VRM } from '@pixiv/three-vrm'\nimport * as THREE from 'three'\nimport { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader.js'\n\n// ═══════════════════════════════════════\n// TYPES\n// ═══════════════════════════════════════\n\ntype CallState = 'idle' | 'connecting' | 'listening' | 'speaking' | 'thinking'\n\ninterface Avatar3DProps {\n modelUrl: string\n emotion: string | null\n callState: CallState\n audioLevel: number\n primaryColor: string\n size: number\n}\n\n// ═══════════════════════════════════════\n// EMOTION → VRM BLENDSHAPE MAPPING\n// ═══════════════════════════════════════\n\ninterface EmotionConfig {\n expressions: Record<string, number> // VRM expression name → weight 0-1\n headRotation?: [number, number, number] // euler XYZ in radians\n}\n\nconst EMOTION_MAP: Record<string, EmotionConfig> = {\n default: {\n expressions: { [VRMExpressionPresetName.Neutral]: 1 },\n },\n happy: {\n expressions: { [VRMExpressionPresetName.Happy]: 0.8 },\n },\n angry: {\n expressions: { [VRMExpressionPresetName.Angry]: 0.7 },\n headRotation: [0.05, 0, 0],\n },\n sorry: {\n expressions: { [VRMExpressionPresetName.Sad]: 0.6 },\n headRotation: [-0.08, 0, 0],\n },\n confused: {\n expressions: { [VRMExpressionPresetName.Sad]: 0.3 },\n headRotation: [0, 0, 0.08],\n },\n love: {\n expressions: { [VRMExpressionPresetName.Happy]: 0.9, [VRMExpressionPresetName.Relaxed]: 0.4 },\n },\n thinking: {\n expressions: { [VRMExpressionPresetName.Neutral]: 0.6 },\n headRotation: [0.06, -0.1, 0],\n },\n writing: {\n expressions: { [VRMExpressionPresetName.Neutral]: 0.8 },\n headRotation: [-0.05, 0, 0],\n },\n wink: {\n expressions: { [VRMExpressionPresetName.Happy]: 0.5, [VRMExpressionPresetName.Blink]: 0.9 },\n },\n}\n\n// ═══════════════════════════════════════\n// VRM MODEL COMPONENT (inside Canvas)\n// ═══════════════════════════════════════\n\ninterface VRMModelProps {\n url: string\n emotion: string | null\n callState: CallState\n audioLevel: number\n}\n\nfunction VRMModel({ url, emotion, callState, audioLevel }: VRMModelProps) {\n const vrmRef = useRef<VRM | null>(null)\n const glbSceneRef = useRef<THREE.Group | null>(null)\n const mixerRef = useRef<THREE.AnimationMixer | null>(null)\n const baseRotationY = useRef(0)\n const baseScale = useRef(1)\n const blinkTimer = useRef(0)\n const nextBlinkAt = useRef(3.5) // Initial value, randomized in useFrame\n const breathPhase = useRef(0)\n const currentExpressions = useRef<Record<string, number>>({})\n const targetExpressions = useRef<Record<string, number>>({})\n const headTarget = useRef(new THREE.Euler(0, 0, 0))\n const baseY = useRef(0)\n const { scene, camera } = useThree()\n\n // Load model using Three.js GLTFLoader (with VRM plugin for VRM models)\n useEffect(() => {\n const loader = new GLTFLoader()\n loader.register((parser) => new VRMLoaderPlugin(parser) as any)\n\n loader.load(\n url,\n (gltf) => {\n const vrm = (gltf as any).userData?.vrm as VRM | undefined\n if (vrm) {\n // ── VRM MODEL PATH ──\n vrmRef.current = vrm\n vrm.scene.rotation.y = Math.PI\n const box = new THREE.Box3().setFromObject(vrm.scene)\n const center = box.getCenter(new THREE.Vector3())\n const height = box.getSize(new THREE.Vector3()).y\n vrm.scene.position.y = -center.y - height * 0.05\n baseY.current = vrm.scene.position.y\n scene.add(vrm.scene)\n } else {\n // ── PLAIN GLB FALLBACK ──\n console.info('[Avatar3D] Plain GLB model detected, using fallback animations')\n const model = gltf.scene\n\n // Force world matrix update so bbox is accurate\n model.updateMatrixWorld(true)\n const box = new THREE.Box3().setFromObject(model)\n const center = box.getCenter(new THREE.Vector3())\n const size = box.getSize(new THREE.Vector3())\n\n // Create pivot wrapper for proper rotation around geometric center\n const pivot = new THREE.Group()\n\n // Center model geometry at pivot origin\n model.position.sub(center)\n pivot.add(model)\n\n // Don't rotate the model — move the CAMERA to the front instead\n baseRotationY.current = 0\n\n glbSceneRef.current = pivot\n baseY.current = 0\n baseScale.current = 1\n scene.add(pivot)\n\n // Frame the HEAD: camera at -Z (model faces -Z based on tests)\n const fov = (camera as THREE.PerspectiveCamera).fov * (Math.PI / 180)\n const headY = size.y * 0.35\n const cameraZ = (size.y * 0.5) / Math.tan(fov / 2)\n // Camera on the -Z side to see the model's FRONT\n camera.position.set(0, headY, -cameraZ)\n camera.lookAt(0, headY, 0)\n\n // Play embedded animations if available\n if (gltf.animations.length > 0) {\n const mixer = new THREE.AnimationMixer(model)\n mixerRef.current = mixer\n gltf.animations.forEach((clip) => {\n mixer.clipAction(clip).play()\n })\n }\n }\n },\n undefined,\n (error) => {\n console.error('[Avatar3D] Failed to load model:', error)\n },\n )\n\n return () => {\n if (vrmRef.current) {\n scene.remove(vrmRef.current.scene)\n vrmRef.current = null\n }\n if (glbSceneRef.current) {\n scene.remove(glbSceneRef.current)\n glbSceneRef.current = null\n }\n if (mixerRef.current) {\n mixerRef.current.stopAllAction()\n mixerRef.current = null\n }\n }\n }, [url, scene])\n\n // Update target expressions when emotion changes (VRM only)\n useEffect(() => {\n const config = EMOTION_MAP[emotion || 'default'] || EMOTION_MAP.default\n targetExpressions.current = config.expressions\n if (config.headRotation) {\n headTarget.current.set(...config.headRotation)\n } else {\n headTarget.current.set(0, 0, 0)\n }\n }, [emotion])\n\n // Animation loop\n useFrame((_, delta) => {\n const dt = Math.min(delta, 0.1) // Cap delta to avoid jumps\n breathPhase.current += dt * 1.2\n\n // ── GLB FALLBACK ANIMATION ──\n const glb = glbSceneRef.current\n if (glb) {\n // Update animation mixer if present\n if (mixerRef.current) {\n mixerRef.current.update(dt)\n }\n\n // Gentle breathing bob\n const breathOffset = Math.sin(breathPhase.current) * 0.003\n glb.position.y = baseY.current + breathOffset\n\n // Subtle idle rotation (relative to base facing direction)\n const idleSway = Math.sin(breathPhase.current * 0.3) * 0.02\n glb.rotation.y = baseRotationY.current + idleSway\n\n // Audio-reactive scale pulse when speaking\n if (callState === 'speaking' && audioLevel > 0.01) {\n const pulse = 1 + audioLevel * 0.03\n const targetScale = baseScale.current * pulse\n const currentScale = glb.scale.x\n glb.scale.setScalar(THREE.MathUtils.lerp(currentScale, targetScale, 0.1))\n } else {\n // Return to base scale smoothly\n const currentScale = glb.scale.x\n if (Math.abs(currentScale - baseScale.current) > 0.001) {\n glb.scale.setScalar(THREE.MathUtils.lerp(currentScale, baseScale.current, 0.05))\n }\n }\n\n return // Skip VRM-specific code\n }\n\n // ── VRM ANIMATION (original code) ──\n const vrm = vrmRef.current\n if (!vrm) return\n\n // ── BREATHING ──\n const breathOffset = Math.sin(breathPhase.current) * 0.003\n vrm.scene.position.y = baseY.current + breathOffset\n\n // ── BLINKING ──\n blinkTimer.current += dt\n if (blinkTimer.current >= nextBlinkAt.current) {\n const blinkProgress = (blinkTimer.current - nextBlinkAt.current) / 0.15\n if (blinkProgress < 1) {\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Blink, blinkProgress)\n } else if (blinkProgress < 2) {\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Blink, 2 - blinkProgress)\n } else {\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Blink, 0)\n blinkTimer.current = 0\n nextBlinkAt.current = Math.random() * 4 + 2\n }\n }\n\n // ── EMOTION BLENDING ──\n const lerpSpeed = 4 * dt\n const allKeys = new Set([\n ...Object.keys(currentExpressions.current),\n ...Object.keys(targetExpressions.current),\n ])\n\n for (const key of allKeys) {\n const current = currentExpressions.current[key] || 0\n const target = targetExpressions.current[key] || 0\n const next = THREE.MathUtils.lerp(current, target, lerpSpeed)\n currentExpressions.current[key] = next\n\n // Don't override blink during active blink animation\n if (key === VRMExpressionPresetName.Blink && blinkTimer.current >= nextBlinkAt.current) continue\n\n vrm.expressionManager?.setValue(key, next)\n }\n\n // ── SPEAKING MOUTH ──\n if (callState === 'speaking' && audioLevel > 0.01) {\n const mouthTarget = Math.min(audioLevel * 1.5, 0.8)\n const currentMouth = vrm.expressionManager?.getValue(VRMExpressionPresetName.Aa) || 0\n const smoothMouth = THREE.MathUtils.lerp(currentMouth, mouthTarget, 8 * dt)\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Aa, smoothMouth)\n } else {\n const currentMouth = vrm.expressionManager?.getValue(VRMExpressionPresetName.Aa) || 0\n if (currentMouth > 0.01) {\n vrm.expressionManager?.setValue(VRMExpressionPresetName.Aa, currentMouth * 0.9)\n }\n }\n\n // ── HEAD MOVEMENT ──\n if (vrm.humanoid) {\n const head = vrm.humanoid.getNormalizedBoneNode('head')\n if (head) {\n const idleSwayX = Math.sin(breathPhase.current * 0.3) * 0.01\n const idleSwayZ = Math.cos(breathPhase.current * 0.2) * 0.005\n\n const targetX = headTarget.current.x + idleSwayX\n const targetY = headTarget.current.y\n const targetZ = headTarget.current.z + idleSwayZ\n\n head.rotation.x = THREE.MathUtils.lerp(head.rotation.x, targetX, 3 * dt)\n head.rotation.y = THREE.MathUtils.lerp(head.rotation.y, targetY, 3 * dt)\n head.rotation.z = THREE.MathUtils.lerp(head.rotation.z, targetZ, 3 * dt)\n }\n }\n\n // ── CALL STATE REACTIONS ──\n if (callState === 'listening' && vrm.humanoid) {\n const head = vrm.humanoid.getNormalizedBoneNode('head')\n if (head) {\n head.rotation.z = THREE.MathUtils.lerp(head.rotation.z, 0.03, 2 * dt)\n }\n }\n\n // Update VRM (required for expression changes to take effect)\n vrm.update(dt)\n })\n\n return null\n}\n\n// ═══════════════════════════════════════\n// AUTO CAMERA FRAMING\n// ═══════════════════════════════════════\n\nfunction CameraSetup() {\n const { camera } = useThree()\n useEffect(() => {\n // Default camera position — will be overridden by model loader for GLB\n // For VRM: fixed head-level framing\n camera.position.set(0, 0.1, 0.6)\n camera.lookAt(0, 0.1, 0)\n }, [camera])\n return null\n}\n\n// ═══════════════════════════════════════\n// MAIN AVATAR 3D COMPONENT (exported)\n// ═══════════════════════════════════════\n\nexport default function Avatar3D({\n modelUrl,\n emotion,\n callState,\n audioLevel,\n primaryColor,\n size,\n}: Avatar3DProps) {\n const glowIntensity = useMemo(() => {\n switch (callState) {\n case 'speaking': return 0.6\n case 'listening': return 0.4\n case 'thinking': return 0.3\n default: return 0.15\n }\n }, [callState])\n\n const isActive = callState === 'listening' || callState === 'speaking'\n\n return (\n <div className=\"relative flex flex-col items-center gap-4\">\n {/* Glow ring behind canvas */}\n <div\n className=\"relative rounded-full overflow-hidden\"\n style={{\n width: `${size}px`,\n height: `${size}px`,\n boxShadow: isActive\n ? `0 0 0 3px ${primaryColor}50, 0 0 30px ${primaryColor}${Math.floor(glowIntensity * 255).toString(16).padStart(2, '0')}, 0 0 60px ${primaryColor}20`\n : `0 0 0 2px ${primaryColor}25`,\n transition: 'box-shadow 0.5s ease',\n }}\n >\n <Canvas\n style={{ width: '100%', height: '100%', background: 'transparent' }}\n gl={{ alpha: true, antialias: true, preserveDrawingBuffer: false }}\n camera={{ fov: 30, near: 0.01, far: 10 }}\n dpr={[1, 2]}\n >\n <CameraSetup />\n\n {/* Lighting — soft studio setup */}\n {/* @ts-ignore R3F IntrinsicElements conflict */}\n <ambientLight intensity={0.6} />\n {/* @ts-ignore */}\n <directionalLight position={[1, 2, 3]} intensity={0.8} color=\"#ffffff\" />\n {/* @ts-ignore */}\n <directionalLight position={[-1, 1, -1]} intensity={0.3} color=\"#b4c6e7\" />\n\n {/* Rim light for depth — matches primary color */}\n {/* @ts-ignore */}\n <pointLight\n position={[0, 0.5, -0.5]}\n intensity={glowIntensity * 2}\n color={primaryColor}\n distance={3}\n />\n\n <VRMModel\n url={modelUrl}\n emotion={emotion}\n callState={callState}\n audioLevel={audioLevel}\n />\n </Canvas>\n </div>\n </div>\n )\n}\n"],"names":["EMOTION_MAP","default","expressions","VRMExpressionPresetName","Neutral","happy","Happy","angry","Angry","headRotation","sorry","Sad","confused","love","Relaxed","thinking","writing","wink","Blink","VRMModel","url","emotion","callState","audioLevel","vrmRef","useRef","glbSceneRef","mixerRef","baseRotationY","baseScale","blinkTimer","nextBlinkAt","breathPhase","currentExpressions","targetExpressions","headTarget","THREE","Euler","baseY","scene","camera","useThree","useEffect","loader","GLTFLoader","register","parser","VRMLoaderPlugin","load","gltf","vrm","userData","current","rotation","y","Math","PI","box","Box3","setFromObject","center","getCenter","Vector3","height","getSize","position","add","console","info","model","updateMatrixWorld","size","pivot","Group","sub","fov","headY","cameraZ","tan","set","lookAt","animations","length","mixer","AnimationMixer","forEach","clip","clipAction","play","error","remove","stopAllAction","config","useFrame","_","delta","dt","min","glb","update","breathOffset","sin","idleSway","pulse","targetScale","currentScale","scale","x","setScalar","MathUtils","lerp","abs","blinkProgress","expressionManager","setValue","random","lerpSpeed","allKeys","Set","Object","keys","key","target","next","mouthTarget","currentMouth","getValue","Aa","smoothMouth","humanoid","head","getNormalizedBoneNode","idleSwayX","idleSwayZ","cos","targetX","targetY","targetZ","z","CameraSetup","Avatar3D","modelUrl","primaryColor","glowIntensity","useMemo","jsx","className","children","style","width","boxShadow","floor","toString","padStart","transition","jsxs","Canvas","background","gl","alpha","antialias","preserveDrawingBuffer","near","far","dpr","intensity","color","distance"],"mappings":"mWA6CA,MAAMA,EAA6C,CACjDC,QAAS,CACPC,YAAa,CAAE,CAACC,EAAwBC,SAAU,IAEpDC,MAAO,CACLH,YAAa,CAAE,CAACC,EAAwBG,OAAQ,KAElDC,MAAO,CACLL,YAAa,CAAE,CAACC,EAAwBK,OAAQ,IAChDC,aAAc,CAAC,IAAM,EAAG,IAE1BC,MAAO,CACLR,YAAa,CAAE,CAACC,EAAwBQ,KAAM,IAC9CF,aAAc,EAAC,IAAO,EAAG,IAE3BG,SAAU,CACRV,YAAa,CAAE,CAACC,EAAwBQ,KAAM,IAC9CF,aAAc,CAAC,EAAG,EAAG,MAEvBI,KAAM,CACJX,YAAa,CAAE,CAACC,EAAwBG,OAAQ,GAAK,CAACH,EAAwBW,SAAU,KAE1FC,SAAU,CACRb,YAAa,CAAE,CAACC,EAAwBC,SAAU,IAClDK,aAAc,CAAC,KAAM,GAAM,IAE7BO,QAAS,CACPd,YAAa,CAAE,CAACC,EAAwBC,SAAU,IAClDK,aAAc,EAAC,IAAO,EAAG,IAE3BQ,KAAM,CACJf,YAAa,CAAE,CAACC,EAAwBG,OAAQ,GAAK,CAACH,EAAwBe,OAAQ,MAe1F,SAASC,GAASC,IAAEA,EAAAC,QAAKA,EAAAC,UAASA,EAAAC,WAAWA,IAC3C,MAAMC,EAASC,EAAmB,MAC5BC,EAAcD,EAA2B,MACzCE,EAAWF,EAAoC,MAC/CG,EAAgBH,EAAO,GACvBI,EAAYJ,EAAO,GACnBK,EAAaL,EAAO,GACpBM,EAAcN,EAAO,KACrBO,EAAcP,EAAO,GACrBQ,EAAqBR,EAA+B,IACpDS,EAAoBT,EAA+B,IACnDU,EAAaV,EAAO,IAAIW,EAAMC,MAAM,EAAG,EAAG,IAC1CC,EAAQb,EAAO,IACfc,MAAEA,EAAAC,OAAOA,GAAWC,IA4N1B,OAzNAC,EAAU,KACR,MAAMC,EAAS,IAAIC,EAmEnB,OAlEAD,EAAOE,SAAUC,GAAW,IAAIC,EAAgBD,IAEhDH,EAAOK,KACL5B,EACC6B,IACC,MAAMC,EAAOD,EAAaE,UAAUD,IACpC,GAAIA,EAAK,CAEP1B,EAAO4B,QAAUF,EACjBA,EAAIX,MAAMc,SAASC,EAAIC,KAAKC,GAC5B,MAAMC,GAAM,IAAIrB,EAAMsB,MAAOC,cAAcT,EAAIX,OACzCqB,EAASH,EAAII,UAAU,IAAIzB,EAAM0B,SACjCC,EAASN,EAAIO,QAAQ,IAAI5B,EAAM0B,SAAWR,EAChDJ,EAAIX,MAAM0B,SAASX,GAAKM,EAAON,EAAa,IAATS,EACnCzB,EAAMc,QAAUF,EAAIX,MAAM0B,SAASX,EACnCf,EAAM2B,IAAIhB,EAAIX,MAChB,KAAO,CAEL4B,QAAQC,KAAK,kEACb,MAAMC,EAAQpB,EAAKV,MAGnB8B,EAAMC,mBAAkB,GACxB,MAAMb,GAAM,IAAIrB,EAAMsB,MAAOC,cAAcU,GACrCT,EAASH,EAAII,UAAU,IAAIzB,EAAM0B,SACjCS,EAAOd,EAAIO,QAAQ,IAAI5B,EAAM0B,SAG7BU,EAAQ,IAAIpC,EAAMqC,MAGxBJ,EAAMJ,SAASS,IAAId,GACnBY,EAAMN,IAAIG,GAGVzC,EAAcwB,QAAU,EAExB1B,EAAY0B,QAAUoB,EACtBlC,EAAMc,QAAU,EAChBvB,EAAUuB,QAAU,EACpBb,EAAM2B,IAAIM,GAGV,MAAMG,EAAOnC,EAAmCmC,KAAOpB,KAAKC,GAAK,KAC3DoB,EAAiB,IAATL,EAAKjB,EACbuB,EAAoB,GAATN,EAAKjB,EAAWC,KAAKuB,IAAIH,EAAM,GAMhD,GAJAnC,EAAOyB,SAASc,IAAI,EAAGH,GAAQC,GAC/BrC,EAAOwC,OAAO,EAAGJ,EAAO,GAGpB3B,EAAKgC,WAAWC,OAAS,EAAG,CAC9B,MAAMC,EAAQ,IAAI/C,EAAMgD,eAAef,GACvC1C,EAASyB,QAAU+B,EACnBlC,EAAKgC,WAAWI,QAASC,IACvBH,EAAMI,WAAWD,GAAME,QAE3B,CACF,QAEF,EACCC,IACCtB,QAAQsB,MAAM,mCAAoCA,KAI/C,KACDjE,EAAO4B,UACTb,EAAMmD,OAAOlE,EAAO4B,QAAQb,OAC5Bf,EAAO4B,QAAU,MAEf1B,EAAY0B,UACdb,EAAMmD,OAAOhE,EAAY0B,SACzB1B,EAAY0B,QAAU,MAEpBzB,EAASyB,UACXzB,EAASyB,QAAQuC,gBACjBhE,EAASyB,QAAU,QAGtB,CAAChC,EAAKmB,IAGTG,EAAU,KACR,MAAMkD,EAAS5F,EAAYqB,GAAW,YAAcrB,EAAYC,QAChEiC,EAAkBkB,QAAUwC,EAAO1F,YAC/B0F,EAAOnF,aACT0B,EAAWiB,QAAQ2B,OAAOa,EAAOnF,cAEjC0B,EAAWiB,QAAQ2B,IAAI,EAAG,EAAG,IAE9B,CAAC1D,IAGJwE,EAAS,CAACC,EAAGC,KACX,MAAMC,EAAKzC,KAAK0C,IAAIF,EAAO,IAC3B/D,EAAYoB,SAAgB,IAAL4C,EAGvB,MAAME,EAAMxE,EAAY0B,QACxB,GAAI8C,EAAK,CAEHvE,EAASyB,SACXzB,EAASyB,QAAQ+C,OAAOH,GAI1B,MAAMI,EAA+C,KAAhC7C,KAAK8C,IAAIrE,EAAYoB,SAC1C8C,EAAIjC,SAASX,EAAIhB,EAAMc,QAAUgD,EAGjC,MAAME,EAAiD,IAAtC/C,KAAK8C,IAA0B,GAAtBrE,EAAYoB,SAItC,GAHA8C,EAAI7C,SAASC,EAAI1B,EAAcwB,QAAUkD,EAGvB,aAAdhF,GAA4BC,EAAa,IAAM,CACjD,MAAMgF,EAAQ,EAAiB,IAAbhF,EACZiF,EAAc3E,EAAUuB,QAAUmD,EAClCE,EAAeP,EAAIQ,MAAMC,EAC/BT,EAAIQ,MAAME,UAAUxE,EAAMyE,UAAUC,KAAKL,EAAcD,EAAa,IACtE,KAAO,CAEL,MAAMC,EAAeP,EAAIQ,MAAMC,EAC3BpD,KAAKwD,IAAIN,EAAe5E,EAAUuB,SAAW,MAC/C8C,EAAIQ,MAAME,UAAUxE,EAAMyE,UAAUC,KAAKL,EAAc5E,EAAUuB,QAAS,KAE9E,CAEA,MACF,CAGA,MAAMF,EAAM1B,EAAO4B,QACnB,IAAKF,EAAK,OAGV,MAAMkD,EAA+C,KAAhC7C,KAAK8C,IAAIrE,EAAYoB,SAK1C,GAJAF,EAAIX,MAAM0B,SAASX,EAAIhB,EAAMc,QAAUgD,EAGvCtE,EAAWsB,SAAW4C,EAClBlE,EAAWsB,SAAWrB,EAAYqB,QAAS,CAC7C,MAAM4D,GAAiBlF,EAAWsB,QAAUrB,EAAYqB,SAAW,IAC/D4D,EAAgB,EAClB9D,EAAI+D,mBAAmBC,SAAS/G,EAAwBe,MAAO8F,GACtDA,EAAgB,EACzB9D,EAAI+D,mBAAmBC,SAAS/G,EAAwBe,MAAO,EAAI8F,IAEnE9D,EAAI+D,mBAAmBC,SAAS/G,EAAwBe,MAAO,GAC/DY,EAAWsB,QAAU,EACrBrB,EAAYqB,QAA0B,EAAhBG,KAAK4D,SAAe,EAE9C,CAGA,MAAMC,EAAY,EAAIpB,EAChBqB,qBAAcC,IAAI,IACnBC,OAAOC,KAAKvF,EAAmBmB,YAC/BmE,OAAOC,KAAKtF,EAAkBkB,WAGnC,IAAA,MAAWqE,KAAOJ,EAAS,CACzB,MAAMjE,EAAUnB,EAAmBmB,QAAQqE,IAAQ,EAC7CC,EAASxF,EAAkBkB,QAAQqE,IAAQ,EAC3CE,EAAOvF,EAAMyE,UAAUC,KAAK1D,EAASsE,EAAQN,GACnDnF,EAAmBmB,QAAQqE,GAAOE,EAG9BF,IAAQtH,EAAwBe,OAASY,EAAWsB,SAAWrB,EAAYqB,SAE/EF,EAAI+D,mBAAmBC,SAASO,EAAKE,EACvC,CAGA,GAAkB,aAAdrG,GAA4BC,EAAa,IAAM,CACjD,MAAMqG,EAAcrE,KAAK0C,IAAiB,IAAb1E,EAAkB,IACzCsG,EAAe3E,EAAI+D,mBAAmBa,SAAS3H,EAAwB4H,KAAO,EAC9EC,EAAc5F,EAAMyE,UAAUC,KAAKe,EAAcD,EAAa,EAAI5B,GACxE9C,EAAI+D,mBAAmBC,SAAS/G,EAAwB4H,GAAIC,EAC9D,KAAO,CACL,MAAMH,EAAe3E,EAAI+D,mBAAmBa,SAAS3H,EAAwB4H,KAAO,EAChFF,EAAe,KACjB3E,EAAI+D,mBAAmBC,SAAS/G,EAAwB4H,GAAmB,GAAfF,EAEhE,CAGA,GAAI3E,EAAI+E,SAAU,CAChB,MAAMC,EAAOhF,EAAI+E,SAASE,sBAAsB,QAChD,GAAID,EAAM,CACR,MAAME,EAAkD,IAAtC7E,KAAK8C,IAA0B,GAAtBrE,EAAYoB,SACjCiF,EAAkD,KAAtC9E,KAAK+E,IAA0B,GAAtBtG,EAAYoB,SAEjCmF,EAAUpG,EAAWiB,QAAQuD,EAAIyB,EACjCI,EAAUrG,EAAWiB,QAAQE,EAC7BmF,EAAUtG,EAAWiB,QAAQsF,EAAIL,EAEvCH,EAAK7E,SAASsD,EAAIvE,EAAMyE,UAAUC,KAAKoB,EAAK7E,SAASsD,EAAG4B,EAAS,EAAIvC,GACrEkC,EAAK7E,SAASC,EAAIlB,EAAMyE,UAAUC,KAAKoB,EAAK7E,SAASC,EAAGkF,EAAS,EAAIxC,GACrEkC,EAAK7E,SAASqF,EAAItG,EAAMyE,UAAUC,KAAKoB,EAAK7E,SAASqF,EAAGD,EAAS,EAAIzC,EACvE,CACF,CAGA,GAAkB,cAAd1E,GAA6B4B,EAAI+E,SAAU,CAC7C,MAAMC,EAAOhF,EAAI+E,SAASE,sBAAsB,QAC5CD,IACFA,EAAK7E,SAASqF,EAAItG,EAAMyE,UAAUC,KAAKoB,EAAK7E,SAASqF,EAAG,IAAM,EAAI1C,GAEtE,CAGA9C,EAAIiD,OAAOH,KAGN,IACT,CAMA,SAAS2C,IACP,MAAMnG,OAAEA,GAAWC,IAOnB,OANAC,EAAU,KAGRF,EAAOyB,SAASc,IAAI,EAAG,GAAK,IAC5BvC,EAAOwC,OAAO,EAAG,GAAK,IACrB,CAACxC,IACG,IACT,CAMA,SAAwBoG,GAASC,SAC/BA,EAAAxH,QACAA,EAAAC,UACAA,EAAAC,WACAA,EAAAuH,aACAA,EAAAvE,KACAA,IAEA,MAAMwE,EAAgBC,EAAQ,KAC5B,OAAQ1H,GACN,IAAK,WAAY,MAAO,GACxB,IAAK,YAAa,MAAO,GACzB,IAAK,WAAY,MAAO,GACxB,QAAS,MAAO,MAEjB,CAACA;AAIJ,OACE2H,EAAC,MAAA,CAAIC,UAAU,4CAEbC,wBAAAF,EAAC,MAAA,CACCC,UAAU,wCACVE,MAAO,CACLC,MAAO,GAAG9E,MACVR,OAAQ,GAAGQ,MACX+E,UAVuB,cAAdhI,GAA2C,aAAdA,EAWlC,aAAawH,iBAA4BA,IAAevF,KAAKgG,MAAsB,IAAhBR,GAAqBS,SAAS,IAAIC,SAAS,EAAG,kBAAkBX,MACnI,aAAaA,MACjBY,WAAY,wBAGdP,wBAAAQ,EAACC,EAAA,CACCR,MAAO,CAAEC,MAAO,OAAQtF,OAAQ,OAAQ8F,WAAY,eACpDC,GAAI,CAAEC,OAAO,EAAMC,WAAW,EAAMC,uBAAuB,GAC3DzH,OAAQ,CAAEmC,IAAK,GAAIuF,KAAM,IAAMC,IAAK,IACpCC,IAAK,CAAC,EAAG,GAETjB,SAAA;eAAAF,EAACN,EAAA;eAIDM,EAAC,eAAA,CAAaoB,UAAW;eAEzBpB,EAAC,mBAAA,CAAiBhF,SAAU,CAAC,EAAG,EAAG,GAAIoG,UAAW,GAAKC,MAAM;eAE7DrB,EAAC,mBAAA,CAAiBhF,SAAU,EAAC,EAAI,GAAG,GAAKoG,UAAW,GAAKC,MAAM;eAI/DrB,EAAC,aAAA,CACChF,SAAU,CAAC,EAAG,IAAK,IACnBoG,UAA2B,EAAhBtB,EACXuB,MAAOxB,EACPyB,SAAU;eAGZtB,EAAC9H,EAAA,CACCC,IAAKyH,EACLxH,UACAC,YACAC,qBAMZ"}
|
package/dist/botuyo-chat.es.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{createRoot as t}from"react-dom/client";import e,{useState as r,useMemo as o,useEffect as n,useCallback as a,Component as i,useReducer as s,useRef as c,createContext as d,useContext as l,lazy as u,Suspense as p}from"react";import{u as h,g,e as m,f,D as w,c as b,X as y,M as v,l as x,m as k,t as _,h as z,i as E,j as S,k as O,n as I,o as $}from"./chunk-chat-ui-C3MpSoay.js";import{p as C}from"./chunk-chat-ui-C3MpSoay.js";import{jsxs as N,jsx as T}from"react/jsx-runtime";import{l as M}from"./vendor-socket-DMqyM-90.js";const A='@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:host,:root{--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-50:oklch(97.1% .013 17.38);--color-red-100:oklch(93.6% .032 17.717);--color-red-200:oklch(88.5% .062 18.334);--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-red-900:oklch(39.6% .141 25.723);--color-amber-500:oklch(76.9% .188 70.08);--color-yellow-50:oklch(98.7% .026 102.212);--color-yellow-300:oklch(90.5% .182 98.111);--color-yellow-700:oklch(55.4% .135 66.442);--color-yellow-900:oklch(42.1% .095 57.708);--color-green-50:oklch(98.2% .018 155.826);--color-green-200:oklch(92.5% .084 155.995);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-green-900:oklch(39.3% .095 152.535);--color-emerald-500:oklch(69.6% .17 162.48);--color-emerald-600:oklch(59.6% .145 163.225);--color-blue-50:oklch(97% .014 254.604);--color-blue-200:oklch(88.2% .059 254.128);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-700:oklch(48.8% .243 264.376);--color-blue-900:oklch(37.9% .146 265.522);--color-purple-500:oklch(62.7% .265 303.9);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-800:oklch(27.8% .033 256.848);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--text-xs:.75rem;--text-xs--line-height:1.33333;--text-sm:.875rem;--text-sm--line-height:1.42857;--text-base:1rem;--text-base--line-height:1.5;--text-lg:1.125rem;--text-lg--line-height:1.55556;--text-xl:1.25rem;--text-xl--line-height:1.4;--text-2xl:1.5rem;--text-2xl--line-height:1.33333;--text-3xl:1.875rem;--text-3xl--line-height:1.2;--text-4xl:2.25rem;--text-4xl--line-height:1.11111;--text-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-medium:500;--font-weight-bold:700;--font-weight-black:900;--tracking-tighter:-.05em;--tracking-tight:-.025em;--tracking-wider:.05em;--tracking-widest:.1em;--leading-tight:1.25;--leading-relaxed:1.625;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--ease-out:cubic-bezier(0,0,.2,1);--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-sm:8px;--blur-md:12px;--blur-2xl:40px;--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)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{border:0 solid;box-sizing:border-box;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;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);line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}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,pre,samp{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-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}::file-selector-button{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}: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}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::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,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.sr-only{border-width:0;clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;white-space:nowrap;width:1px}.absolute,.sr-only{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing)*0)}.-top-1{top:calc(var(--spacing)*-1)}.-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-3{top:calc(var(--spacing)*3)}.top-4{top:calc(var(--spacing)*4)}.top-full{top:100%}.-right-0\\.5{right:calc(var(--spacing)*-.5)}.-right-1{right:calc(var(--spacing)*-1)}.-right-1\\.5{right:calc(var(--spacing)*-1.5)}.right-0{right:calc(var(--spacing)*0)}.right-2{right:calc(var(--spacing)*2)}.right-3{right:calc(var(--spacing)*3)}.right-4{right:calc(var(--spacing)*4)}.right-6{right:calc(var(--spacing)*6)}.-bottom-0\\.5{bottom:calc(var(--spacing)*-.5)}.-bottom-1{bottom:calc(var(--spacing)*-1)}.bottom-3{bottom:calc(var(--spacing)*3)}.bottom-4{bottom:calc(var(--spacing)*4)}.bottom-full{bottom:100%}.left-0{left:calc(var(--spacing)*0)}.left-1\\/2{left:50%}.left-4{left:calc(var(--spacing)*4)}.left-6{left:calc(var(--spacing)*6)}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.z-\\[60\\]{z-index:60}.z-\\[9999\\]{z-index:9999}.z-\\[100000\\]{z-index:100000}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mx-1{margin-inline:calc(var(--spacing)*1)}.my-2{margin-block:calc(var(--spacing)*2)}.my-3{margin-block:calc(var(--spacing)*3)}.my-4{margin-block:calc(var(--spacing)*4)}.my-8{margin-block:calc(var(--spacing)*8)}.mt-0\\.5{margin-top:calc(var(--spacing)*.5)}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-1\\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mr-1{margin-right:calc(var(--spacing)*1)}.mr-3{margin-right:calc(var(--spacing)*3)}.mr-auto{margin-right:auto}.mb-0{margin-bottom:calc(var(--spacing)*0)}.mb-0\\.5{margin-bottom:calc(var(--spacing)*.5)}.mb-1{margin-bottom:calc(var(--spacing)*1)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.ml-0\\.5{margin-left:calc(var(--spacing)*.5)}.ml-2{margin-left:calc(var(--spacing)*2)}.ml-3{margin-left:calc(var(--spacing)*3)}.ml-auto{margin-left:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-0{height:calc(var(--spacing)*0)}.h-1{height:calc(var(--spacing)*1)}.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-12{height:calc(var(--spacing)*12)}.h-14{height:calc(var(--spacing)*14)}.h-16{height:calc(var(--spacing)*16)}.h-20{height:calc(var(--spacing)*20)}.h-24{height:calc(var(--spacing)*24)}.h-32{height:calc(var(--spacing)*32)}.h-48{height:calc(var(--spacing)*48)}.h-56{height:calc(var(--spacing)*56)}.h-\\[44px\\]{height:44px}.h-auto{height:auto}.h-full{height:100%}.max-h-\\[85\\%\\]{max-height:85%}.max-h-\\[120px\\]{max-height:120px}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-\\[40px\\]{min-height:40px}.min-h-full{min-height:100%}.w-0{width:calc(var(--spacing)*0)}.w-1{width:calc(var(--spacing)*1)}.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-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-12{width:calc(var(--spacing)*12)}.w-14{width:calc(var(--spacing)*14)}.w-16{width:calc(var(--spacing)*16)}.w-20{width:calc(var(--spacing)*20)}.w-24{width:calc(var(--spacing)*24)}.w-\\[3px\\]{width:3px}.w-\\[calc\\(100\\%-0\\.5rem\\)\\]{width:calc(100% - .5rem)}.w-auto{width:auto}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.max-w-0{max-width:calc(var(--spacing)*0)}.max-w-\\[60px\\]{max-width:60px}.max-w-\\[85\\%\\]{max-width:85%}.max-w-\\[90\\%\\]{max-width:90%}.max-w-\\[320px\\]{max-width:320px}.max-w-full{max-width:100%}.max-w-md{max-width:var(--container-md)}.max-w-none{max-width:none}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-\\[200px\\]{min-width:200px}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.origin-bottom{transform-origin:bottom}.origin-bottom-left{transform-origin:0 100%}.origin-bottom-right{transform-origin:100% 100%}.-translate-x-1\\/2{--tw-translate-x:-50%}.-translate-x-1\\/2,.-translate-x-6{translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-x-6{--tw-translate-x:calc(var(--spacing)*-6)}.translate-x-0{--tw-translate-x:calc(var(--spacing)*0)}.translate-x-0,.translate-x-6{translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-6{--tw-translate-x:calc(var(--spacing)*6)}.-translate-y-1\\/2{--tw-translate-y:-50%}.-translate-y-1\\/2,.translate-y-0{translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-y-0{--tw-translate-y:calc(var(--spacing)*0)}.translate-y-2{--tw-translate-y:calc(var(--spacing)*2)}.translate-y-2,.translate-y-8{translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-y-8{--tw-translate-y:calc(var(--spacing)*8)}.scale-50{--tw-scale-x:50%;--tw-scale-y:50%;--tw-scale-z:50%}.scale-50,.scale-90{scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-90{--tw-scale-x:90%;--tw-scale-y:90%;--tw-scale-z:90%}.scale-100{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%}.scale-100,.scale-105{scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-105{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%}.scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%}.scale-110,.scale-125{scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%}.scale-\\[0\\.85\\]{scale:.85}.-rotate-90{rotate:-90deg}.rotate-0{rotate:none}.rotate-45{rotate:45deg}.rotate-90{rotate:90deg}.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-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.cursor-wait{cursor:wait}.resize{resize:both}.resize-none{resize:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.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-1{gap:calc(var(--spacing)*1)}.gap-1\\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}.gap-8{gap:calc(var(--spacing)*8)}.gap-\\[2px\\]{gap:2px}.gap-\\[3px\\]{gap:3px}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-end:calc(var(--spacing)*1*(1 - var(--tw-space-y-reverse)));margin-block-start:calc(var(--spacing)*1*var(--tw-space-y-reverse))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-end:calc(var(--spacing)*2*(1 - var(--tw-space-y-reverse)));margin-block-start:calc(var(--spacing)*2*var(--tw-space-y-reverse))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-end:calc(var(--spacing)*4*(1 - var(--tw-space-y-reverse)));margin-block-start:calc(var(--spacing)*4*var(--tw-space-y-reverse))}.truncate{text-overflow:ellipsis;white-space:nowrap}.overflow-hidden,.truncate{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.scroll-smooth{scroll-behavior:smooth}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\\[18px\\]{border-radius:18px}.rounded-\\[24px\\]{border-radius:24px}.rounded-\\[28px\\]{border-radius:28px}.rounded-full{border-radius:3.40282e+38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-none{border-radius:0}.rounded-xl{border-radius:var(--radius-xl)}.rounded-l-\\[4px\\]{border-bottom-left-radius:4px}.rounded-l-\\[4px\\],.rounded-tl-\\[4px\\]{border-top-left-radius:4px}.rounded-r-\\[4px\\]{border-bottom-right-radius:4px}.rounded-r-\\[4px\\],.rounded-tr-\\[4px\\]{border-top-right-radius:4px}.rounded-br-\\[4px\\]{border-bottom-right-radius:4px}.rounded-bl-\\[4px\\]{border-bottom-left-radius:4px}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-\\[hsl\\(210\\,90\\%\\,50\\%\\)\\]{border-color:#0d80f2}.border-blue-200{border-color:var(--color-blue-200)}.border-gray-200{border-color:var(--color-gray-200)}.border-green-200{border-color:var(--color-green-200)}.border-red-200{border-color:var(--color-red-200)}.border-yellow-300{border-color:var(--color-yellow-300)}.bg-amber-500{background-color:var(--color-amber-500)}.bg-amber-500\\/20{background-color:#f99c0033}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\\/20{background-color:color-mix(in oklab,var(--color-amber-500)20%,transparent)}}.bg-black\\/5{background-color:#0000000d}@supports (color:color-mix(in lab,red,red)){.bg-black\\/5{background-color:color-mix(in oklab,var(--color-black)5%,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\\/70{background-color:#000000b3}@supports (color:color-mix(in lab,red,red)){.bg-black\\/70{background-color:color-mix(in oklab,var(--color-black)70%,transparent)}}.bg-black\\/95{background-color:#000000f2}@supports (color:color-mix(in lab,red,red)){.bg-black\\/95{background-color:color-mix(in oklab,var(--color-black)95%,transparent)}}.bg-blue-50{background-color:var(--color-blue-50)}.bg-blue-500\\/20{background-color:#3080ff33}@supports (color:color-mix(in lab,red,red)){.bg-blue-500\\/20{background-color:color-mix(in oklab,var(--color-blue-500)20%,transparent)}}.bg-current,.bg-current\\/20{background-color:currentColor}@supports (color:color-mix(in lab,red,red)){.bg-current\\/20{background-color:color-mix(in oklab,currentcolor 20%,transparent)}}.bg-emerald-500{background-color:var(--color-emerald-500)}.bg-emerald-500\\/10{background-color:#00bb7f1a}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\\/10{background-color:color-mix(in oklab,var(--color-emerald-500)10%,transparent)}}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-500\\/20{background-color:#6a728233}@supports (color:color-mix(in lab,red,red)){.bg-gray-500\\/20{background-color:color-mix(in oklab,var(--color-gray-500)20%,transparent)}}.bg-green-50{background-color:var(--color-green-50)}.bg-green-500\\/10{background-color:#00c7581a}@supports (color:color-mix(in lab,red,red)){.bg-green-500\\/10{background-color:color-mix(in oklab,var(--color-green-500)10%,transparent)}}.bg-green-500\\/20{background-color:#00c75833}@supports (color:color-mix(in lab,red,red)){.bg-green-500\\/20{background-color:color-mix(in oklab,var(--color-green-500)20%,transparent)}}.bg-red-50{background-color:var(--color-red-50)}.bg-red-100{background-color:var(--color-red-100)}.bg-red-500{background-color:var(--color-red-500)}.bg-red-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-red-500\\/20{background-color:#fb2c3633}@supports (color:color-mix(in lab,red,red)){.bg-red-500\\/20{background-color:color-mix(in oklab,var(--color-red-500)20%,transparent)}}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\\/10{background-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.bg-white\\/40{background-color:#fff6}@supports (color:color-mix(in lab,red,red)){.bg-white\\/40{background-color:color-mix(in oklab,var(--color-white)40%,transparent)}}.bg-white\\/80{background-color:#fffc}@supports (color:color-mix(in lab,red,red)){.bg-white\\/80{background-color:color-mix(in oklab,var(--color-white)80%,transparent)}}.bg-yellow-50{background-color:var(--color-yellow-50)}.bg-gradient-to-b{--tw-gradient-position:to bottom in oklab}.bg-gradient-to-b,.bg-gradient-to-br{background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab}.bg-gradient-to-t{--tw-gradient-position:to top in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-black\\/40{--tw-gradient-from:#0006}@supports (color:color-mix(in lab,red,red)){.from-black\\/40{--tw-gradient-from:color-mix(in oklab,var(--color-black)40%,transparent)}}.from-black\\/40{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-black\\/60{--tw-gradient-from:#0009}@supports (color:color-mix(in lab,red,red)){.from-black\\/60{--tw-gradient-from:color-mix(in oklab,var(--color-black)60%,transparent)}}.from-black\\/60{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.via-transparent{--tw-gradient-via:transparent;--tw-gradient-via-stops:var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-via)var(--tw-gradient-via-position),var(--tw-gradient-to)var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-black\\/20{--tw-gradient-to:#0003}@supports (color:color-mix(in lab,red,red)){.to-black\\/20{--tw-gradient-to:color-mix(in oklab,var(--color-black)20%,transparent)}}.to-black\\/20{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.fill-current{fill:currentColor}.stroke-\\[2\\.5\\]{stroke-width:2.5px}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.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-8{padding:calc(var(--spacing)*8)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.px-10{padding-inline:calc(var(--spacing)*10)}.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-16{padding-block:calc(var(--spacing)*16)}.pr-8{padding-right:calc(var(--spacing)*8)}.pb-1{padding-bottom:calc(var(--spacing)*1)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-4{padding-bottom:calc(var(--spacing)*4)}.text-center{text-align:center}.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-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--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-\\[7px\\]{font-size:7px}.text-\\[8px\\]{font-size:8px}.text-\\[9px\\]{font-size:9px}.text-\\[10px\\]{font-size:10px}.text-\\[11px\\]{font-size:11px}.text-\\[12px\\]{font-size:12px}.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-black{--tw-font-weight:var(--font-weight-black);font-weight:var(--font-weight-black)}.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)}.tracking-\\[0\\.1em\\]{--tw-tracking:.1em;letter-spacing:.1em}.tracking-\\[0\\.2em\\]{--tw-tracking:.2em;letter-spacing:.2em}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-tighter{--tw-tracking:var(--tracking-tighter);letter-spacing:var(--tracking-tighter)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.break-words{overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.text-amber-500{color:var(--color-amber-500)}.text-blue-500{color:var(--color-blue-500)}.text-blue-700{color:var(--color-blue-700)}.text-blue-900{color:var(--color-blue-900)}.text-emerald-500{color:var(--color-emerald-500)}.text-emerald-600{color:var(--color-emerald-600)}.text-gray-600{color:var(--color-gray-600)}.text-gray-800{color:var(--color-gray-800)}.text-green-500{color:var(--color-green-500)}.text-green-600{color:var(--color-green-600)}.text-green-700{color:var(--color-green-700)}.text-green-900{color:var(--color-green-900)}.text-purple-500{color:var(--color-purple-500)}.text-red-500{color:var(--color-red-500)}.text-red-600{color:var(--color-red-600)}.text-red-900{color:var(--color-red-900)}.text-white{color:var(--color-white)}.text-yellow-700{color:var(--color-yellow-700)}.text-yellow-900{color:var(--color-yellow-900)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.no-underline{text-decoration-line:none}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-20{opacity:.2}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.opacity-100{opacity:1}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a)}.shadow,.shadow-inner{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 var(--tw-shadow-color,#0000000d)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a)}.shadow-lg,.shadow-md{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)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a)}.ring,.shadow-sm{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor)}.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-\\[hsl\\(210\\,90\\%\\,50\\%\\)\\]\\/30{--tw-ring-color:oklab(60.6854% -.0507387 -.187037/.3)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px)}.blur,.blur-2xl{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,)}.blur-2xl{--tw-blur:blur(var(--blur-2xl))}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur-md{--tw-backdrop-blur:blur(var(--blur-md))}.backdrop-blur-md,.backdrop-blur-sm{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm))}.transition{transition-duration:var(--tw-duration,var(--default-transition-duration));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,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.transition-all{transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.transition-colors{transition-duration:var(--tw-duration,var(--default-transition-duration));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-opacity{transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.transition-transform{transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-400{--tw-duration:.4s;transition-duration:.4s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.duration-700{--tw-duration:.7s;transition-duration:.7s}.duration-1000{--tw-duration:1s;transition-duration:1s}.ease-\\[cubic-bezier\\(0\\.16\\,1\\,0\\.3\\,1\\)\\]{--tw-ease:cubic-bezier(.16,1,.3,1);transition-timing-function:cubic-bezier(.16,1,.3,1)}.ease-\\[cubic-bezier\\(0\\.34\\,1\\.56\\,0\\.64\\,1\\)\\]{--tw-ease:cubic-bezier(.34,1.56,.64,1);transition-timing-function:cubic-bezier(.34,1.56,.64,1)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.\\[animation-delay\\:-0\\.3s\\]{animation-delay:-.3s}.\\[animation-delay\\:-0\\.15s\\]{animation-delay:-.15s}@media(hover:hover){.group-hover\\:opacity-100:is(:where(.group):hover *){opacity:1}}.last\\:mb-0:last-child{margin-bottom:calc(var(--spacing)*0)}@media(hover:hover){.hover\\:-translate-y-1:hover{--tw-translate-y:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.hover\\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\\:scale-110:hover{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\\:scale-\\[1\\.02\\]:hover{scale:1.02}.hover\\:rotate-6:hover{rotate:6deg}.hover\\:border-\\[hsl\\(210\\,90\\%\\,70\\%\\)\\]:hover{border-color:#6eb3f7}.hover\\:bg-emerald-500\\/20:hover{background-color:#00bb7f33}@supports (color:color-mix(in lab,red,red)){.hover\\:bg-emerald-500\\/20:hover{background-color:color-mix(in oklab,var(--color-emerald-500)20%,transparent)}}.hover\\:bg-red-500\\/30:hover{background-color:#fb2c364d}@supports (color:color-mix(in lab,red,red)){.hover\\:bg-red-500\\/30:hover{background-color:color-mix(in oklab,var(--color-red-500)30%,transparent)}}.hover\\:bg-red-600:hover{background-color:var(--color-red-600)}.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\\/60:hover{background-color:#fff9}@supports (color:color-mix(in lab,red,red)){.hover\\:bg-white\\/60:hover{background-color:color-mix(in oklab,var(--color-white)60%,transparent)}}.hover\\:underline:hover{text-decoration-line:underline}.hover\\:opacity-90:hover{opacity:.9}.hover\\:opacity-100:hover{opacity:1}.hover\\:shadow-lg:hover{--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)}}.focus\\:underline:focus{text-decoration-line:underline}.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-emerald-500:focus{--tw-ring-color:var(--color-emerald-500)}.focus\\:ring-red-500:focus{--tw-ring-color:var(--color-red-500)}.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-none:focus{--tw-outline-style:none;outline-style:none}.active\\:scale-90:active{--tw-scale-x:90%;--tw-scale-y:90%;--tw-scale-z:90%;scale:var(--tw-scale-x)var(--tw-scale-y)}.active\\:scale-95:active{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x)var(--tw-scale-y)}.disabled\\:opacity-30:disabled{opacity:.3}.disabled\\:opacity-50:disabled{opacity:.5}.disabled\\:grayscale:disabled{--tw-grayscale:grayscale(100%);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,)}@media(min-width:40rem){.sm\\:h-8{height:calc(var(--spacing)*8)}.sm\\:h-16{height:calc(var(--spacing)*16)}.sm\\:w-8{width:calc(var(--spacing)*8)}.sm\\:w-16{width:calc(var(--spacing)*16)}.sm\\:w-auto{width:auto}}@media(prefers-color-scheme:dark){.dark\\:bg-black\\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.dark\\:bg-black\\/80{background-color:color-mix(in oklab,var(--color-black)80%,transparent)}}.dark\\:bg-white\\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.dark\\:bg-white\\/10{background-color:color-mix(in oklab,var(--color-white)10%,transparent)}}}}#botuyo-chat-widget-root .sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}@media(prefers-contrast:high){#botuyo-chat-widget-root{--border-width:2px;--focus-ring-width:3px;--focus-ring-color:hsl(var(--primary))}#botuyo-chat-widget-root [role=button],#botuyo-chat-widget-root [role=dialog],#botuyo-chat-widget-root button,#botuyo-chat-widget-root input,#botuyo-chat-widget-root textarea{border-width:var(--border-width)!important}#botuyo-chat-widget-root :focus-visible{outline:var(--focus-ring-width)solid var(--focus-ring-color)!important;outline-offset:2px!important}#botuyo-chat-widget-root{--foreground:0 0% 0%;--background:0 0% 100%;--muted-foreground:0 0% 20%}#botuyo-chat-widget-root.dark{--foreground:0 0% 100%;--background:0 0% 0%;--muted-foreground:0 0% 80%}#botuyo-chat-widget-root [class*=opacity-],#botuyo-chat-widget-root [style*=opacity]{opacity:1!important}}@media(prefers-reduced-motion:reduce){#botuyo-chat-widget-root *,#botuyo-chat-widget-root :after,#botuyo-chat-widget-root :before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}#botuyo-chat-widget-root .animate-pulse,#botuyo-chat-widget-root [data-state=closed],#botuyo-chat-widget-root [data-state=open]{animation:none!important}#botuyo-chat-widget-root .scroll-smooth{scroll-behavior:auto!important}}#botuyo-chat-widget-root :focus-visible{border-radius:var(--radius,.5rem);outline:2px solid hsl(var(--primary));outline-offset:2px}#botuyo-chat-widget-root [role=button]:focus-visible,#botuyo-chat-widget-root button:focus-visible{box-shadow:0 0 0 4px hsl(var(--primary)/.1);outline:2px solid hsl(var(--primary));outline-offset:2px}#botuyo-chat-widget-root input:focus-visible,#botuyo-chat-widget-root textarea:focus-visible{border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary)/.1);outline:2px solid hsl(var(--primary));outline-offset:0}#botuyo-chat-widget-root .skip-link{background:hsl(var(--primary));border-radius:0 0 4px;color:hsl(var(--primary-foreground));left:0;padding:8px;position:absolute;text-decoration:none;top:-40px;z-index:100000}#botuyo-chat-widget-root .skip-link:focus{top:0}@media(prefers-color-scheme:dark)and (prefers-contrast:high){#botuyo-chat-widget-root{--primary:48 96% 89%;--destructive:0 84% 60%;--success:142 76% 36%}}#botuyo-chat-widget-root [data-state]:after{content:attr(data-state);clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}@media(min-resolution:192dpi){#botuyo-chat-widget-root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}}#botuyo-chat-widget-root [data-tooltip]:focus:after,#botuyo-chat-widget-root [data-tooltip]:hover:after{background:hsl(var(--popover));border-radius:4px;bottom:100%;color:hsl(var(--popover-foreground));content:attr(data-tooltip);font-size:12px;left:50%;padding:4px 8px;pointer-events:none;position:absolute;transform:translate(-50%);white-space:nowrap;z-index:1000}#botuyo-chat-widget-root [aria-live=assertive],#botuyo-chat-widget-root [aria-live=polite]{position:relative}@keyframes live-region-update{0%{opacity:.8}to{opacity:1}}#botuyo-chat-widget-root [aria-live]:not([aria-atomic=false]):has(:new){animation:live-region-update .2s ease-in-out}#botuyo-chat-widget-root .scrollbar-none{scrollbar-width:none;-ms-overflow-style:none}#botuyo-chat-widget-root .scrollbar-none::-webkit-scrollbar{display:none;height:0;width:0}#botuyo-chat-widget-root .scrollbar-thin{scrollbar-width:thin}#botuyo-chat-widget-root .scrollbar-thin::-webkit-scrollbar{height:4px;width:4px}#botuyo-chat-widget-root .scrollbar-thin::-webkit-scrollbar-track{background:0 0}#botuyo-chat-widget-root .scrollbar-thin::-webkit-scrollbar-thumb{background:hsl(var(--border));border-radius:2px}#botuyo-chat-widget-root .scrollbar-thin::-webkit-scrollbar-thumb:hover{background:hsl(var(--muted-foreground)/.5)}#botuyo-chat-widget-root .hidden{display:none!important}#botuyo-chat-widget-root .block{display:block!important}#botuyo-chat-widget-root .flex{display:flex!important}#botuyo-chat-widget-root .inline-flex{display:inline-flex!important}#botuyo-chat-widget-root .grid{display:grid!important}#botuyo-chat-widget-root .flex-row{flex-direction:row!important}#botuyo-chat-widget-root .flex-col{flex-direction:column!important}#botuyo-chat-widget-root .flex-1{flex:1!important}#botuyo-chat-widget-root .flex-none{flex:none!important}#botuyo-chat-widget-root .shrink-0{flex-shrink:0!important}#botuyo-chat-widget-root .grow{flex-grow:1!important}#botuyo-chat-widget-root .items-center{align-items:center!important}#botuyo-chat-widget-root .items-start{align-items:flex-start!important}#botuyo-chat-widget-root .items-end{align-items:flex-end!important}#botuyo-chat-widget-root .justify-center{justify-content:center!important}#botuyo-chat-widget-root .justify-between{justify-content:space-between!important}#botuyo-chat-widget-root .justify-end{justify-content:flex-end!important}#botuyo-chat-widget-root .relative{position:relative!important}#botuyo-chat-widget-root .absolute{position:absolute!important}#botuyo-chat-widget-root .fixed{position:fixed!important}#botuyo-chat-widget-root .inset-0{inset:0!important}#botuyo-chat-widget-root .w-full{width:100%!important}#botuyo-chat-widget-root .h-full{height:100%!important}#botuyo-chat-widget-root .w-fit{width:-moz-fit-content!important;width:fit-content!important}#botuyo-chat-widget-root .w-auto{width:auto!important}#botuyo-chat-widget-root .h-auto{height:auto!important}#botuyo-chat-widget-root .h-0{height:0!important}#botuyo-chat-widget-root .w-0{width:0!important}#botuyo-chat-widget-root .h-6{height:1.5rem!important}#botuyo-chat-widget-root .w-6{width:1.5rem!important}#botuyo-chat-widget-root .h-7{height:1.75rem!important}#botuyo-chat-widget-root .w-7{width:1.75rem!important}#botuyo-chat-widget-root .h-8{height:2rem!important}#botuyo-chat-widget-root .w-8{width:2rem!important}#botuyo-chat-widget-root .h-14{height:3.5rem!important}#botuyo-chat-widget-root .w-14{width:3.5rem!important}#botuyo-chat-widget-root .min-h-0{min-height:0!important}#botuyo-chat-widget-root .min-w-0{min-width:0!important}#botuyo-chat-widget-root .overflow-hidden{overflow:hidden!important}#botuyo-chat-widget-root .overflow-auto{overflow:auto!important}#botuyo-chat-widget-root .overflow-y-auto{overflow-y:auto!important}#botuyo-chat-widget-root .gap-1{gap:.25rem!important}#botuyo-chat-widget-root .gap-2{gap:.5rem!important}#botuyo-chat-widget-root .gap-3{gap:.75rem!important}#botuyo-chat-widget-root .gap-4{gap:1rem!important}#botuyo-chat-widget-root .p-1{padding:.25rem!important}#botuyo-chat-widget-root .p-2{padding:.5rem!important}#botuyo-chat-widget-root .p-3{padding:.75rem!important}#botuyo-chat-widget-root .p-4{padding:1rem!important}#botuyo-chat-widget-root .px-4{padding-left:1rem!important;padding-right:1rem!important}#botuyo-chat-widget-root .py-2{padding-bottom:.5rem!important;padding-top:.5rem!important}#botuyo-chat-widget-root .m-0{margin:0!important}#botuyo-chat-widget-root .mt-2{margin-top:.5rem!important}#botuyo-chat-widget-root .mt-4{margin-top:1rem!important}#botuyo-chat-widget-root .mb-2{margin-bottom:.5rem!important}#botuyo-chat-widget-root .ml-auto{margin-left:auto!important}#botuyo-chat-widget-root .rounded{border-radius:.25rem!important}#botuyo-chat-widget-root .rounded-lg{border-radius:.5rem!important}#botuyo-chat-widget-root .rounded-xl{border-radius:.75rem!important}#botuyo-chat-widget-root .rounded-2xl{border-radius:1rem!important}#botuyo-chat-widget-root .rounded-full{border-radius:9999px!important}#botuyo-chat-widget-root .text-xs{font-size:.75rem!important;line-height:1rem!important}#botuyo-chat-widget-root .text-sm{font-size:.875rem!important;line-height:1.25rem!important}#botuyo-chat-widget-root .text-base{font-size:1rem!important;line-height:1.5rem!important}#botuyo-chat-widget-root .text-lg{font-size:1.125rem!important;line-height:1.75rem!important}#botuyo-chat-widget-root .font-medium{font-weight:500!important}#botuyo-chat-widget-root .font-semibold{font-weight:600!important}#botuyo-chat-widget-root .font-bold{font-weight:700!important}#botuyo-chat-widget-root .font-black{font-weight:900!important}#botuyo-chat-widget-root .uppercase{text-transform:uppercase!important}#botuyo-chat-widget-root .truncate{overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}#botuyo-chat-widget-root .text-foreground{color:hsl(var(--foreground))!important}#botuyo-chat-widget-root .text-muted-foreground{color:hsl(var(--muted-foreground))!important}#botuyo-chat-widget-root .text-primary{color:hsl(var(--primary))!important}#botuyo-chat-widget-root .text-primary-foreground{color:hsl(var(--primary-foreground))!important}#botuyo-chat-widget-root .text-destructive{color:hsl(var(--destructive))!important}#botuyo-chat-widget-root .text-white{color:#fff!important}#botuyo-chat-widget-root .bg-background{background-color:hsl(var(--background))!important}#botuyo-chat-widget-root .bg-muted{background-color:hsl(var(--muted))!important}#botuyo-chat-widget-root .bg-primary{background-color:hsl(var(--primary))!important}#botuyo-chat-widget-root .bg-card{background-color:hsl(var(--card))!important}#botuyo-chat-widget-root .bg-transparent{background-color:#0000!important}#botuyo-chat-widget-root .border{border-width:1px!important}#botuyo-chat-widget-root .border-2{border-width:2px!important}#botuyo-chat-widget-root .border-b{border-bottom-width:1px!important}#botuyo-chat-widget-root .border-t{border-top-width:1px!important}#botuyo-chat-widget-root .border-border{border-color:hsl(var(--border))!important}#botuyo-chat-widget-root .shadow{box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a!important}#botuyo-chat-widget-root .shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a!important}#botuyo-chat-widget-root .shadow-xl{box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a!important}#botuyo-chat-widget-root .transition{transition-duration:.15s!important;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important}#botuyo-chat-widget-root .transition-all{transition-duration:.15s!important;transition-property:all!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important}#botuyo-chat-widget-root .duration-300{transition-duration:.3s!important}#botuyo-chat-widget-root .duration-500{transition-duration:.5s!important}#botuyo-chat-widget-root .opacity-0{opacity:0!important}#botuyo-chat-widget-root .opacity-100{opacity:1!important}#botuyo-chat-widget-root .scale-95{transform:scale(.95)!important}#botuyo-chat-widget-root .scale-100{transform:scale(1)!important}#botuyo-chat-widget-root .translate-y-full{transform:translateY(100%)!important}#botuyo-chat-widget-root .z-10{z-index:10!important}#botuyo-chat-widget-root .z-20{z-index:20!important}#botuyo-chat-widget-root .z-50{z-index:50!important}#botuyo-chat-widget-root .pointer-events-none{pointer-events:none!important}#botuyo-chat-widget-root .pointer-events-auto{pointer-events:auto!important}#botuyo-chat-widget-root .cursor-pointer{cursor:pointer!important}#botuyo-chat-widget-root .select-none{-webkit-user-select:none!important;-moz-user-select:none!important;user-select:none!important}@keyframes spin{to{transform:rotate(1turn)}}#botuyo-chat-widget,#botuyo-chat-widget-root,:root{--background:0 0% 100%;--foreground:240 10% 3.9%;--card:0 0% 100%;--card-foreground:240 10% 3.9%;--popover:0 0% 100%;--popover-foreground:240 10% 3.9%;--primary:160 84% 39%;--primary-foreground:0 0% 100%;--muted:240 4.8% 95.9%;--muted-foreground:240 3.8% 46.1%;--accent:240 4.8% 95.9%;--accent-foreground:240 5.9% 10%;--destructive:0 84.2% 60.2%;--destructive-foreground:0 0% 98%;--border:240 5.9% 90%;--input:240 5.9% 90%;--ring:160 84% 39%;--radius:.5rem;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:.75rem;--spacing-6:1.5rem;--spacing-7:1.75rem;--spacing-8:2rem;--window-border-radius:24px;--launcher-border-radius:50%;--window-height:700px;--window-bottom:24px}#botuyo-chat-widget-root.dark,#botuyo-chat-widget.dark,.dark{--background:240 10% 3.9%;--foreground:0 0% 98%;--card:240 10% 3.9%;--card-foreground:0 0% 98%;--popover:240 10% 3.9%;--popover-foreground:0 0% 98%;--primary:160 84% 39%;--primary-foreground:0 0% 100%;--muted:240 3.7% 15.9%;--muted-foreground:240 5% 64.9%;--accent:240 3.7% 15.9%;--accent-foreground:0 0% 98%;--destructive:0 62.8% 30.6%;--destructive-foreground:0 0% 98%;--border:240 3.7% 15.9%;--input:240 3.7% 15.9%;--ring:160 84% 39%}#botuyo-chat-widget-root,#botuyo-chat-widget-root *{box-sizing:border-box;margin:0;padding:0}#botuyo-chat-widget-root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:hsl(var(--foreground));font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@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}}#botuyo-chat-widget-root .chat-launcher{align-items:center;background-color:hsl(var(--primary));border-radius:50%;bottom:1.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;color:#fff;cursor:pointer;display:flex;height:60px;justify-content:center;position:fixed;right:1.5rem;transition:all .2s;width:60px;z-index:999999}#botuyo-chat-widget-root .chat-launcher:hover{box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;transform:scale(1.05)}#botuyo-chat-widget-root .chat-launcher.position-bottom-left{left:1.5rem;right:auto}#botuyo-chat-widget-root .chat-launcher.position-top-right{bottom:auto;top:1.5rem}#botuyo-chat-widget-root .chat-launcher.position-top-left{inset:1.5rem auto auto 1.5rem}#botuyo-chat-widget-root .chat-window{animation:slideInRight .3s ease-out;background-color:hsl(var(--background));border-radius:1rem;bottom:6rem;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;height:600px;max-height:calc(100vh - 8rem);overflow:hidden;position:fixed;right:1.5rem;width:400px;z-index:999999}#botuyo-chat-widget-root .chat-window.closing{animation:slideOutRight .2s ease-in}@media(max-width:640px){#botuyo-chat-widget-root .chat-window{animation:slideInUp .3s ease-out;border-radius:0;height:100%;inset:0;max-height:100vh;width:100%}}#botuyo-chat-widget-root .message-bubble{word-wrap:break-word;border-radius:1rem;max-width:80%;padding:.75rem 1rem}#botuyo-chat-widget-root .message-bubble.user{background-color:hsl(var(--primary));color:hsl(var(--primary-foreground));margin-left:auto}#botuyo-chat-widget-root .message-bubble.bot{background-color:hsl(var(--muted));color:hsl(var(--foreground))}#botuyo-chat-widget-root .chat-messages::-webkit-scrollbar{width:6px}#botuyo-chat-widget-root .chat-messages::-webkit-scrollbar-track{background:0 0}#botuyo-chat-widget-root .chat-messages::-webkit-scrollbar-thumb{background:hsl(var(--muted));border-radius:3px}#botuyo-chat-widget-root .chat-messages::-webkit-scrollbar-thumb:hover{background:hsl(var(--muted-foreground))}#botuyo-chat-widget-root .chat-input{background-color:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:.5rem;color:hsl(var(--foreground));outline:none;padding:.75rem;transition:border-color .2s;width:100%}#botuyo-chat-widget-root .chat-input:focus{border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary)/.1)}@media(max-width:640px){#botuyo-chat-widget-root .chat-launcher{bottom:1rem;height:56px;right:1rem;width:56px}}@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-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}';function j({isOpen:t,onClick:e,unreadCount:i=0,primaryColor:s,logoUrl:c,starterPrompt:d,position:l="bottom-right",emotion:u="default",avatars:p={},styles:k,promptPersistence:_="session",avatarScale:z=1,showPromptAvatar:E=!1}){const{t:S}=h("extracted"),O=g({primaryColor:s}),I=k?.launcher?.bg,$=m(),{triggerHaptic:C,getGlowClass:M}=f(),A=$.launcherPulse&&!1!==k?.launcher?.pulse,[j,P]=r(!1),[D,Z]=r(!1),[F,U]=r(!1),[L,R]=r(!1),B="bottom-right"===l,W="chat_launcher_prompt_state",J=o(()=>p[u]||p.default||c||w,[u,p,c]);n(()=>{R(!1)},[J]),n(()=>{const t=Object.values(p).filter(t=>!!t);c&&t.push(c),t.forEach(t=>{(new Image).src=t})},[p,c]),n(()=>{"forever"===_&&"dismissed"===localStorage.getItem(W)&&U(!0)},[_]);const V=a(()=>{Z(!0),setTimeout(()=>P(!1),500),"always"!==_&&(U(!0),"forever"===_&&localStorage.setItem(W,"dismissed"))},[_]);n(()=>{if("always"!==_&&F||!d||t)return void P(!1);const e=setTimeout(()=>{P(!0),Z(!1)},2e3),r=setTimeout(()=>V(),12e3);return()=>{clearTimeout(e),clearTimeout(r)}},[d,t,F,_,V]);const q=()=>{x.debug("Launcher handleMainAction called, isOpen:",t),C(),U(!0),"forever"===_&&localStorage.setItem(W,"dismissed"),e()};/* @__PURE__ */
|
|
1
|
+
import{createRoot as t}from"react-dom/client";import e,{useState as r,useMemo as o,useEffect as n,useCallback as a,Component as i,useReducer as s,useRef as c,createContext as d,useContext as l,lazy as u,Suspense as p}from"react";import{u as h,g,e as m,f,D as w,c as b,X as y,M as v,l as x,m as k,t as _,h as z,i as E,j as S,k as O,n as I,o as $}from"./chunk-chat-ui-C3MpSoay.js";import{p as C}from"./chunk-chat-ui-C3MpSoay.js";import{jsxs as N,jsx as T}from"react/jsx-runtime";import{l as M}from"./vendor-socket-DMqyM-90.js";const A='@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:host,:root{--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-50:oklch(97.1% .013 17.38);--color-red-100:oklch(93.6% .032 17.717);--color-red-200:oklch(88.5% .062 18.334);--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-red-900:oklch(39.6% .141 25.723);--color-amber-500:oklch(76.9% .188 70.08);--color-yellow-50:oklch(98.7% .026 102.212);--color-yellow-300:oklch(90.5% .182 98.111);--color-yellow-700:oklch(55.4% .135 66.442);--color-yellow-900:oklch(42.1% .095 57.708);--color-green-50:oklch(98.2% .018 155.826);--color-green-200:oklch(92.5% .084 155.995);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-green-900:oklch(39.3% .095 152.535);--color-emerald-500:oklch(69.6% .17 162.48);--color-emerald-600:oklch(59.6% .145 163.225);--color-blue-50:oklch(97% .014 254.604);--color-blue-200:oklch(88.2% .059 254.128);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-700:oklch(48.8% .243 264.376);--color-blue-900:oklch(37.9% .146 265.522);--color-purple-500:oklch(62.7% .265 303.9);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-800:oklch(27.8% .033 256.848);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--text-xs:.75rem;--text-xs--line-height:1.33333;--text-sm:.875rem;--text-sm--line-height:1.42857;--text-base:1rem;--text-base--line-height:1.5;--text-lg:1.125rem;--text-lg--line-height:1.55556;--text-xl:1.25rem;--text-xl--line-height:1.4;--text-2xl:1.5rem;--text-2xl--line-height:1.33333;--text-3xl:1.875rem;--text-3xl--line-height:1.2;--text-4xl:2.25rem;--text-4xl--line-height:1.11111;--text-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-medium:500;--font-weight-bold:700;--font-weight-black:900;--tracking-tighter:-.05em;--tracking-tight:-.025em;--tracking-wider:.05em;--tracking-widest:.1em;--leading-tight:1.25;--leading-relaxed:1.625;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--ease-out:cubic-bezier(0,0,.2,1);--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-sm:8px;--blur-md:12px;--blur-2xl:40px;--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)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{border:0 solid;box-sizing:border-box;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;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);line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}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,pre,samp{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-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}::file-selector-button{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}: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}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::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,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.sr-only{border-width:0;clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;white-space:nowrap;width:1px}.absolute,.sr-only{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing)*0)}.-top-1{top:calc(var(--spacing)*-1)}.-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-3{top:calc(var(--spacing)*3)}.top-4{top:calc(var(--spacing)*4)}.top-full{top:100%}.-right-0\\.5{right:calc(var(--spacing)*-.5)}.-right-1{right:calc(var(--spacing)*-1)}.-right-1\\.5{right:calc(var(--spacing)*-1.5)}.right-0{right:calc(var(--spacing)*0)}.right-2{right:calc(var(--spacing)*2)}.right-3{right:calc(var(--spacing)*3)}.right-4{right:calc(var(--spacing)*4)}.right-6{right:calc(var(--spacing)*6)}.-bottom-0\\.5{bottom:calc(var(--spacing)*-.5)}.-bottom-1{bottom:calc(var(--spacing)*-1)}.bottom-3{bottom:calc(var(--spacing)*3)}.bottom-4{bottom:calc(var(--spacing)*4)}.bottom-full{bottom:100%}.left-0{left:calc(var(--spacing)*0)}.left-1\\/2{left:50%}.left-4{left:calc(var(--spacing)*4)}.left-6{left:calc(var(--spacing)*6)}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.z-\\[60\\]{z-index:60}.z-\\[9999\\]{z-index:9999}.z-\\[100000\\]{z-index:100000}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mx-1{margin-inline:calc(var(--spacing)*1)}.my-2{margin-block:calc(var(--spacing)*2)}.my-3{margin-block:calc(var(--spacing)*3)}.my-4{margin-block:calc(var(--spacing)*4)}.my-8{margin-block:calc(var(--spacing)*8)}.mt-0\\.5{margin-top:calc(var(--spacing)*.5)}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-1\\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mr-1{margin-right:calc(var(--spacing)*1)}.mr-3{margin-right:calc(var(--spacing)*3)}.mr-auto{margin-right:auto}.mb-0{margin-bottom:calc(var(--spacing)*0)}.mb-0\\.5{margin-bottom:calc(var(--spacing)*.5)}.mb-1{margin-bottom:calc(var(--spacing)*1)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.ml-0\\.5{margin-left:calc(var(--spacing)*.5)}.ml-2{margin-left:calc(var(--spacing)*2)}.ml-3{margin-left:calc(var(--spacing)*3)}.ml-auto{margin-left:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-0{height:calc(var(--spacing)*0)}.h-1{height:calc(var(--spacing)*1)}.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-12{height:calc(var(--spacing)*12)}.h-14{height:calc(var(--spacing)*14)}.h-16{height:calc(var(--spacing)*16)}.h-20{height:calc(var(--spacing)*20)}.h-24{height:calc(var(--spacing)*24)}.h-32{height:calc(var(--spacing)*32)}.h-48{height:calc(var(--spacing)*48)}.h-56{height:calc(var(--spacing)*56)}.h-\\[44px\\]{height:44px}.h-auto{height:auto}.h-full{height:100%}.max-h-\\[85\\%\\]{max-height:85%}.max-h-\\[120px\\]{max-height:120px}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-\\[40px\\]{min-height:40px}.min-h-full{min-height:100%}.w-0{width:calc(var(--spacing)*0)}.w-1{width:calc(var(--spacing)*1)}.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-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-12{width:calc(var(--spacing)*12)}.w-14{width:calc(var(--spacing)*14)}.w-16{width:calc(var(--spacing)*16)}.w-20{width:calc(var(--spacing)*20)}.w-24{width:calc(var(--spacing)*24)}.w-\\[3px\\]{width:3px}.w-\\[calc\\(100\\%-0\\.5rem\\)\\]{width:calc(100% - .5rem)}.w-auto{width:auto}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.max-w-0{max-width:calc(var(--spacing)*0)}.max-w-\\[60px\\]{max-width:60px}.max-w-\\[85\\%\\]{max-width:85%}.max-w-\\[90\\%\\]{max-width:90%}.max-w-\\[320px\\]{max-width:320px}.max-w-full{max-width:100%}.max-w-md{max-width:var(--container-md)}.max-w-none{max-width:none}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-\\[200px\\]{min-width:200px}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.origin-bottom{transform-origin:bottom}.origin-bottom-left{transform-origin:0 100%}.origin-bottom-right{transform-origin:100% 100%}.-translate-x-1\\/2{--tw-translate-x:-50%}.-translate-x-1\\/2,.-translate-x-6{translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-x-6{--tw-translate-x:calc(var(--spacing)*-6)}.translate-x-0{--tw-translate-x:calc(var(--spacing)*0)}.translate-x-0,.translate-x-6{translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-6{--tw-translate-x:calc(var(--spacing)*6)}.-translate-y-1\\/2{--tw-translate-y:-50%}.-translate-y-1\\/2,.translate-y-0{translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-y-0{--tw-translate-y:calc(var(--spacing)*0)}.translate-y-2{--tw-translate-y:calc(var(--spacing)*2)}.translate-y-2,.translate-y-8{translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-y-8{--tw-translate-y:calc(var(--spacing)*8)}.scale-50{--tw-scale-x:50%;--tw-scale-y:50%;--tw-scale-z:50%}.scale-50,.scale-90{scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-90{--tw-scale-x:90%;--tw-scale-y:90%;--tw-scale-z:90%}.scale-100{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%}.scale-100,.scale-105{scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-105{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%}.scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%}.scale-110,.scale-125{scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%}.scale-\\[0\\.85\\]{scale:.85}.-rotate-90{rotate:-90deg}.rotate-0{rotate:none}.rotate-45{rotate:45deg}.rotate-90{rotate:90deg}.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-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.cursor-wait{cursor:wait}.resize{resize:both}.resize-none{resize:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.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-1{gap:calc(var(--spacing)*1)}.gap-1\\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}.gap-8{gap:calc(var(--spacing)*8)}.gap-\\[2px\\]{gap:2px}.gap-\\[3px\\]{gap:3px}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-end:calc(var(--spacing)*1*(1 - var(--tw-space-y-reverse)));margin-block-start:calc(var(--spacing)*1*var(--tw-space-y-reverse))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-end:calc(var(--spacing)*2*(1 - var(--tw-space-y-reverse)));margin-block-start:calc(var(--spacing)*2*var(--tw-space-y-reverse))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-end:calc(var(--spacing)*4*(1 - var(--tw-space-y-reverse)));margin-block-start:calc(var(--spacing)*4*var(--tw-space-y-reverse))}.truncate{text-overflow:ellipsis;white-space:nowrap}.overflow-hidden,.truncate{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.scroll-smooth{scroll-behavior:smooth}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\\[18px\\]{border-radius:18px}.rounded-\\[24px\\]{border-radius:24px}.rounded-\\[28px\\]{border-radius:28px}.rounded-full{border-radius:3.40282e+38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-none{border-radius:0}.rounded-xl{border-radius:var(--radius-xl)}.rounded-l-\\[4px\\]{border-bottom-left-radius:4px}.rounded-l-\\[4px\\],.rounded-tl-\\[4px\\]{border-top-left-radius:4px}.rounded-r-\\[4px\\]{border-bottom-right-radius:4px}.rounded-r-\\[4px\\],.rounded-tr-\\[4px\\]{border-top-right-radius:4px}.rounded-br-\\[4px\\]{border-bottom-right-radius:4px}.rounded-bl-\\[4px\\]{border-bottom-left-radius:4px}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-\\[hsl\\(210\\,90\\%\\,50\\%\\)\\]{border-color:#0d80f2}.border-blue-200{border-color:var(--color-blue-200)}.border-gray-200{border-color:var(--color-gray-200)}.border-green-200{border-color:var(--color-green-200)}.border-red-200{border-color:var(--color-red-200)}.border-yellow-300{border-color:var(--color-yellow-300)}.bg-amber-500{background-color:var(--color-amber-500)}.bg-amber-500\\/20{background-color:#f99c0033}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\\/20{background-color:color-mix(in oklab,var(--color-amber-500)20%,transparent)}}.bg-black\\/5{background-color:#0000000d}@supports (color:color-mix(in lab,red,red)){.bg-black\\/5{background-color:color-mix(in oklab,var(--color-black)5%,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\\/70{background-color:#000000b3}@supports (color:color-mix(in lab,red,red)){.bg-black\\/70{background-color:color-mix(in oklab,var(--color-black)70%,transparent)}}.bg-black\\/95{background-color:#000000f2}@supports (color:color-mix(in lab,red,red)){.bg-black\\/95{background-color:color-mix(in oklab,var(--color-black)95%,transparent)}}.bg-blue-50{background-color:var(--color-blue-50)}.bg-blue-500\\/20{background-color:#3080ff33}@supports (color:color-mix(in lab,red,red)){.bg-blue-500\\/20{background-color:color-mix(in oklab,var(--color-blue-500)20%,transparent)}}.bg-current,.bg-current\\/20{background-color:currentColor}@supports (color:color-mix(in lab,red,red)){.bg-current\\/20{background-color:color-mix(in oklab,currentcolor 20%,transparent)}}.bg-emerald-500{background-color:var(--color-emerald-500)}.bg-emerald-500\\/10{background-color:#00bb7f1a}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\\/10{background-color:color-mix(in oklab,var(--color-emerald-500)10%,transparent)}}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-500\\/20{background-color:#6a728233}@supports (color:color-mix(in lab,red,red)){.bg-gray-500\\/20{background-color:color-mix(in oklab,var(--color-gray-500)20%,transparent)}}.bg-green-50{background-color:var(--color-green-50)}.bg-green-500\\/10{background-color:#00c7581a}@supports (color:color-mix(in lab,red,red)){.bg-green-500\\/10{background-color:color-mix(in oklab,var(--color-green-500)10%,transparent)}}.bg-green-500\\/20{background-color:#00c75833}@supports (color:color-mix(in lab,red,red)){.bg-green-500\\/20{background-color:color-mix(in oklab,var(--color-green-500)20%,transparent)}}.bg-red-50{background-color:var(--color-red-50)}.bg-red-100{background-color:var(--color-red-100)}.bg-red-500{background-color:var(--color-red-500)}.bg-red-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-red-500\\/20{background-color:#fb2c3633}@supports (color:color-mix(in lab,red,red)){.bg-red-500\\/20{background-color:color-mix(in oklab,var(--color-red-500)20%,transparent)}}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\\/10{background-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.bg-white\\/40{background-color:#fff6}@supports (color:color-mix(in lab,red,red)){.bg-white\\/40{background-color:color-mix(in oklab,var(--color-white)40%,transparent)}}.bg-white\\/80{background-color:#fffc}@supports (color:color-mix(in lab,red,red)){.bg-white\\/80{background-color:color-mix(in oklab,var(--color-white)80%,transparent)}}.bg-yellow-50{background-color:var(--color-yellow-50)}.bg-gradient-to-b{--tw-gradient-position:to bottom in oklab}.bg-gradient-to-b,.bg-gradient-to-br{background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab}.bg-gradient-to-t{--tw-gradient-position:to top in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-black\\/40{--tw-gradient-from:#0006}@supports (color:color-mix(in lab,red,red)){.from-black\\/40{--tw-gradient-from:color-mix(in oklab,var(--color-black)40%,transparent)}}.from-black\\/40{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-black\\/60{--tw-gradient-from:#0009}@supports (color:color-mix(in lab,red,red)){.from-black\\/60{--tw-gradient-from:color-mix(in oklab,var(--color-black)60%,transparent)}}.from-black\\/60{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.via-transparent{--tw-gradient-via:transparent;--tw-gradient-via-stops:var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-via)var(--tw-gradient-via-position),var(--tw-gradient-to)var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-black\\/20{--tw-gradient-to:#0003}@supports (color:color-mix(in lab,red,red)){.to-black\\/20{--tw-gradient-to:color-mix(in oklab,var(--color-black)20%,transparent)}}.to-black\\/20{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.fill-current{fill:currentColor}.stroke-\\[2\\.5\\]{stroke-width:2.5px}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.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-8{padding:calc(var(--spacing)*8)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.px-10{padding-inline:calc(var(--spacing)*10)}.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-16{padding-block:calc(var(--spacing)*16)}.pr-8{padding-right:calc(var(--spacing)*8)}.pb-1{padding-bottom:calc(var(--spacing)*1)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-4{padding-bottom:calc(var(--spacing)*4)}.text-center{text-align:center}.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-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--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-\\[7px\\]{font-size:7px}.text-\\[8px\\]{font-size:8px}.text-\\[9px\\]{font-size:9px}.text-\\[10px\\]{font-size:10px}.text-\\[11px\\]{font-size:11px}.text-\\[12px\\]{font-size:12px}.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-black{--tw-font-weight:var(--font-weight-black);font-weight:var(--font-weight-black)}.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)}.tracking-\\[0\\.1em\\]{--tw-tracking:.1em;letter-spacing:.1em}.tracking-\\[0\\.2em\\]{--tw-tracking:.2em;letter-spacing:.2em}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-tighter{--tw-tracking:var(--tracking-tighter);letter-spacing:var(--tracking-tighter)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.break-words{overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.text-amber-500{color:var(--color-amber-500)}.text-blue-500{color:var(--color-blue-500)}.text-blue-700{color:var(--color-blue-700)}.text-blue-900{color:var(--color-blue-900)}.text-emerald-500{color:var(--color-emerald-500)}.text-emerald-600{color:var(--color-emerald-600)}.text-gray-600{color:var(--color-gray-600)}.text-gray-800{color:var(--color-gray-800)}.text-green-500{color:var(--color-green-500)}.text-green-600{color:var(--color-green-600)}.text-green-700{color:var(--color-green-700)}.text-green-900{color:var(--color-green-900)}.text-purple-500{color:var(--color-purple-500)}.text-red-500{color:var(--color-red-500)}.text-red-600{color:var(--color-red-600)}.text-red-900{color:var(--color-red-900)}.text-white{color:var(--color-white)}.text-yellow-700{color:var(--color-yellow-700)}.text-yellow-900{color:var(--color-yellow-900)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.no-underline{text-decoration-line:none}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-20{opacity:.2}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.opacity-100{opacity:1}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a)}.shadow,.shadow-inner{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 var(--tw-shadow-color,#0000000d)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a)}.shadow-lg,.shadow-md{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)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a)}.ring,.shadow-sm{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor)}.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-\\[hsl\\(210\\,90\\%\\,50\\%\\)\\]\\/30{--tw-ring-color:oklab(60.6854% -.0507388 -.187037/.3)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px)}.blur,.blur-2xl{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,)}.blur-2xl{--tw-blur:blur(var(--blur-2xl))}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur-md{--tw-backdrop-blur:blur(var(--blur-md))}.backdrop-blur-md,.backdrop-blur-sm{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm))}.transition{transition-duration:var(--tw-duration,var(--default-transition-duration));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,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.transition-all{transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.transition-colors{transition-duration:var(--tw-duration,var(--default-transition-duration));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-opacity{transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.transition-transform{transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-400{--tw-duration:.4s;transition-duration:.4s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.duration-700{--tw-duration:.7s;transition-duration:.7s}.duration-1000{--tw-duration:1s;transition-duration:1s}.ease-\\[cubic-bezier\\(0\\.16\\,1\\,0\\.3\\,1\\)\\]{--tw-ease:cubic-bezier(.16,1,.3,1);transition-timing-function:cubic-bezier(.16,1,.3,1)}.ease-\\[cubic-bezier\\(0\\.34\\,1\\.56\\,0\\.64\\,1\\)\\]{--tw-ease:cubic-bezier(.34,1.56,.64,1);transition-timing-function:cubic-bezier(.34,1.56,.64,1)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.\\[animation-delay\\:-0\\.3s\\]{animation-delay:-.3s}.\\[animation-delay\\:-0\\.15s\\]{animation-delay:-.15s}@media(hover:hover){.group-hover\\:opacity-100:is(:where(.group):hover *){opacity:1}}.last\\:mb-0:last-child{margin-bottom:calc(var(--spacing)*0)}@media(hover:hover){.hover\\:-translate-y-1:hover{--tw-translate-y:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.hover\\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\\:scale-110:hover{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\\:scale-\\[1\\.02\\]:hover{scale:1.02}.hover\\:rotate-6:hover{rotate:6deg}.hover\\:border-\\[hsl\\(210\\,90\\%\\,70\\%\\)\\]:hover{border-color:#6eb3f7}.hover\\:bg-emerald-500\\/20:hover{background-color:#00bb7f33}@supports (color:color-mix(in lab,red,red)){.hover\\:bg-emerald-500\\/20:hover{background-color:color-mix(in oklab,var(--color-emerald-500)20%,transparent)}}.hover\\:bg-red-500\\/30:hover{background-color:#fb2c364d}@supports (color:color-mix(in lab,red,red)){.hover\\:bg-red-500\\/30:hover{background-color:color-mix(in oklab,var(--color-red-500)30%,transparent)}}.hover\\:bg-red-600:hover{background-color:var(--color-red-600)}.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\\/60:hover{background-color:#fff9}@supports (color:color-mix(in lab,red,red)){.hover\\:bg-white\\/60:hover{background-color:color-mix(in oklab,var(--color-white)60%,transparent)}}.hover\\:underline:hover{text-decoration-line:underline}.hover\\:opacity-90:hover{opacity:.9}.hover\\:opacity-100:hover{opacity:1}.hover\\:shadow-lg:hover{--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)}}.focus\\:underline:focus{text-decoration-line:underline}.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-emerald-500:focus{--tw-ring-color:var(--color-emerald-500)}.focus\\:ring-red-500:focus{--tw-ring-color:var(--color-red-500)}.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-none:focus{--tw-outline-style:none;outline-style:none}.active\\:scale-90:active{--tw-scale-x:90%;--tw-scale-y:90%;--tw-scale-z:90%;scale:var(--tw-scale-x)var(--tw-scale-y)}.active\\:scale-95:active{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x)var(--tw-scale-y)}.disabled\\:opacity-30:disabled{opacity:.3}.disabled\\:opacity-50:disabled{opacity:.5}.disabled\\:grayscale:disabled{--tw-grayscale:grayscale(100%);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,)}@media(min-width:40rem){.sm\\:h-8{height:calc(var(--spacing)*8)}.sm\\:h-16{height:calc(var(--spacing)*16)}.sm\\:w-8{width:calc(var(--spacing)*8)}.sm\\:w-16{width:calc(var(--spacing)*16)}.sm\\:w-auto{width:auto}}@media(prefers-color-scheme:dark){.dark\\:bg-black\\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.dark\\:bg-black\\/80{background-color:color-mix(in oklab,var(--color-black)80%,transparent)}}.dark\\:bg-white\\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.dark\\:bg-white\\/10{background-color:color-mix(in oklab,var(--color-white)10%,transparent)}}}}#botuyo-chat-widget-root .sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}@media(prefers-contrast:high){#botuyo-chat-widget-root{--border-width:2px;--focus-ring-width:3px;--focus-ring-color:hsl(var(--primary))}#botuyo-chat-widget-root [role=button],#botuyo-chat-widget-root [role=dialog],#botuyo-chat-widget-root button,#botuyo-chat-widget-root input,#botuyo-chat-widget-root textarea{border-width:var(--border-width)!important}#botuyo-chat-widget-root :focus-visible{outline:var(--focus-ring-width)solid var(--focus-ring-color)!important;outline-offset:2px!important}#botuyo-chat-widget-root{--foreground:0 0% 0%;--background:0 0% 100%;--muted-foreground:0 0% 20%}#botuyo-chat-widget-root.dark{--foreground:0 0% 100%;--background:0 0% 0%;--muted-foreground:0 0% 80%}#botuyo-chat-widget-root [class*=opacity-],#botuyo-chat-widget-root [style*=opacity]{opacity:1!important}}@media(prefers-reduced-motion:reduce){#botuyo-chat-widget-root *,#botuyo-chat-widget-root :after,#botuyo-chat-widget-root :before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}#botuyo-chat-widget-root .animate-pulse,#botuyo-chat-widget-root [data-state=closed],#botuyo-chat-widget-root [data-state=open]{animation:none!important}#botuyo-chat-widget-root .scroll-smooth{scroll-behavior:auto!important}}#botuyo-chat-widget-root :focus-visible{border-radius:var(--radius,.5rem);outline:2px solid hsl(var(--primary));outline-offset:2px}#botuyo-chat-widget-root [role=button]:focus-visible,#botuyo-chat-widget-root button:focus-visible{box-shadow:0 0 0 4px hsl(var(--primary)/.1);outline:2px solid hsl(var(--primary));outline-offset:2px}#botuyo-chat-widget-root input:focus-visible,#botuyo-chat-widget-root textarea:focus-visible{border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary)/.1);outline:2px solid hsl(var(--primary));outline-offset:0}#botuyo-chat-widget-root .skip-link{background:hsl(var(--primary));border-radius:0 0 4px;color:hsl(var(--primary-foreground));left:0;padding:8px;position:absolute;text-decoration:none;top:-40px;z-index:100000}#botuyo-chat-widget-root .skip-link:focus{top:0}@media(prefers-color-scheme:dark)and (prefers-contrast:high){#botuyo-chat-widget-root{--primary:48 96% 89%;--destructive:0 84% 60%;--success:142 76% 36%}}#botuyo-chat-widget-root [data-state]:after{content:attr(data-state);clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}@media(min-resolution:192dpi){#botuyo-chat-widget-root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}}#botuyo-chat-widget-root [data-tooltip]:focus:after,#botuyo-chat-widget-root [data-tooltip]:hover:after{background:hsl(var(--popover));border-radius:4px;bottom:100%;color:hsl(var(--popover-foreground));content:attr(data-tooltip);font-size:12px;left:50%;padding:4px 8px;pointer-events:none;position:absolute;transform:translate(-50%);white-space:nowrap;z-index:1000}#botuyo-chat-widget-root [aria-live=assertive],#botuyo-chat-widget-root [aria-live=polite]{position:relative}@keyframes live-region-update{0%{opacity:.8}to{opacity:1}}#botuyo-chat-widget-root [aria-live]:not([aria-atomic=false]):has(:new){animation:live-region-update .2s ease-in-out}#botuyo-chat-widget-root .scrollbar-none{scrollbar-width:none;-ms-overflow-style:none}#botuyo-chat-widget-root .scrollbar-none::-webkit-scrollbar{display:none;height:0;width:0}#botuyo-chat-widget-root .scrollbar-thin{scrollbar-width:thin}#botuyo-chat-widget-root .scrollbar-thin::-webkit-scrollbar{height:4px;width:4px}#botuyo-chat-widget-root .scrollbar-thin::-webkit-scrollbar-track{background:0 0}#botuyo-chat-widget-root .scrollbar-thin::-webkit-scrollbar-thumb{background:hsl(var(--border));border-radius:2px}#botuyo-chat-widget-root .scrollbar-thin::-webkit-scrollbar-thumb:hover{background:hsl(var(--muted-foreground)/.5)}#botuyo-chat-widget-root .hidden{display:none!important}#botuyo-chat-widget-root .block{display:block!important}#botuyo-chat-widget-root .flex{display:flex!important}#botuyo-chat-widget-root .inline-flex{display:inline-flex!important}#botuyo-chat-widget-root .grid{display:grid!important}#botuyo-chat-widget-root .flex-row{flex-direction:row!important}#botuyo-chat-widget-root .flex-col{flex-direction:column!important}#botuyo-chat-widget-root .flex-1{flex:1!important}#botuyo-chat-widget-root .flex-none{flex:none!important}#botuyo-chat-widget-root .shrink-0{flex-shrink:0!important}#botuyo-chat-widget-root .grow{flex-grow:1!important}#botuyo-chat-widget-root .items-center{align-items:center!important}#botuyo-chat-widget-root .items-start{align-items:flex-start!important}#botuyo-chat-widget-root .items-end{align-items:flex-end!important}#botuyo-chat-widget-root .justify-center{justify-content:center!important}#botuyo-chat-widget-root .justify-between{justify-content:space-between!important}#botuyo-chat-widget-root .justify-end{justify-content:flex-end!important}#botuyo-chat-widget-root .relative{position:relative!important}#botuyo-chat-widget-root .absolute{position:absolute!important}#botuyo-chat-widget-root .fixed{position:fixed!important}#botuyo-chat-widget-root .inset-0{inset:0!important}#botuyo-chat-widget-root .w-full{width:100%!important}#botuyo-chat-widget-root .h-full{height:100%!important}#botuyo-chat-widget-root .w-fit{width:-moz-fit-content!important;width:fit-content!important}#botuyo-chat-widget-root .w-auto{width:auto!important}#botuyo-chat-widget-root .h-auto{height:auto!important}#botuyo-chat-widget-root .h-0{height:0!important}#botuyo-chat-widget-root .w-0{width:0!important}#botuyo-chat-widget-root .h-6{height:1.5rem!important}#botuyo-chat-widget-root .w-6{width:1.5rem!important}#botuyo-chat-widget-root .h-7{height:1.75rem!important}#botuyo-chat-widget-root .w-7{width:1.75rem!important}#botuyo-chat-widget-root .h-8{height:2rem!important}#botuyo-chat-widget-root .w-8{width:2rem!important}#botuyo-chat-widget-root .h-14{height:3.5rem!important}#botuyo-chat-widget-root .w-14{width:3.5rem!important}#botuyo-chat-widget-root .min-h-0{min-height:0!important}#botuyo-chat-widget-root .min-w-0{min-width:0!important}#botuyo-chat-widget-root .overflow-hidden{overflow:hidden!important}#botuyo-chat-widget-root .overflow-auto{overflow:auto!important}#botuyo-chat-widget-root .overflow-y-auto{overflow-y:auto!important}#botuyo-chat-widget-root .gap-1{gap:.25rem!important}#botuyo-chat-widget-root .gap-2{gap:.5rem!important}#botuyo-chat-widget-root .gap-3{gap:.75rem!important}#botuyo-chat-widget-root .gap-4{gap:1rem!important}#botuyo-chat-widget-root .p-1{padding:.25rem!important}#botuyo-chat-widget-root .p-2{padding:.5rem!important}#botuyo-chat-widget-root .p-3{padding:.75rem!important}#botuyo-chat-widget-root .p-4{padding:1rem!important}#botuyo-chat-widget-root .px-4{padding-left:1rem!important;padding-right:1rem!important}#botuyo-chat-widget-root .py-2{padding-bottom:.5rem!important;padding-top:.5rem!important}#botuyo-chat-widget-root .m-0{margin:0!important}#botuyo-chat-widget-root .mt-2{margin-top:.5rem!important}#botuyo-chat-widget-root .mt-4{margin-top:1rem!important}#botuyo-chat-widget-root .mb-2{margin-bottom:.5rem!important}#botuyo-chat-widget-root .ml-auto{margin-left:auto!important}#botuyo-chat-widget-root .rounded{border-radius:.25rem!important}#botuyo-chat-widget-root .rounded-lg{border-radius:.5rem!important}#botuyo-chat-widget-root .rounded-xl{border-radius:.75rem!important}#botuyo-chat-widget-root .rounded-2xl{border-radius:1rem!important}#botuyo-chat-widget-root .rounded-full{border-radius:9999px!important}#botuyo-chat-widget-root .text-xs{font-size:.75rem!important;line-height:1rem!important}#botuyo-chat-widget-root .text-sm{font-size:.875rem!important;line-height:1.25rem!important}#botuyo-chat-widget-root .text-base{font-size:1rem!important;line-height:1.5rem!important}#botuyo-chat-widget-root .text-lg{font-size:1.125rem!important;line-height:1.75rem!important}#botuyo-chat-widget-root .font-medium{font-weight:500!important}#botuyo-chat-widget-root .font-semibold{font-weight:600!important}#botuyo-chat-widget-root .font-bold{font-weight:700!important}#botuyo-chat-widget-root .font-black{font-weight:900!important}#botuyo-chat-widget-root .uppercase{text-transform:uppercase!important}#botuyo-chat-widget-root .truncate{overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}#botuyo-chat-widget-root .text-foreground{color:hsl(var(--foreground))!important}#botuyo-chat-widget-root .text-muted-foreground{color:hsl(var(--muted-foreground))!important}#botuyo-chat-widget-root .text-primary{color:hsl(var(--primary))!important}#botuyo-chat-widget-root .text-primary-foreground{color:hsl(var(--primary-foreground))!important}#botuyo-chat-widget-root .text-destructive{color:hsl(var(--destructive))!important}#botuyo-chat-widget-root .text-white{color:#fff!important}#botuyo-chat-widget-root .bg-background{background-color:hsl(var(--background))!important}#botuyo-chat-widget-root .bg-muted{background-color:hsl(var(--muted))!important}#botuyo-chat-widget-root .bg-primary{background-color:hsl(var(--primary))!important}#botuyo-chat-widget-root .bg-card{background-color:hsl(var(--card))!important}#botuyo-chat-widget-root .bg-transparent{background-color:#0000!important}#botuyo-chat-widget-root .border{border-width:1px!important}#botuyo-chat-widget-root .border-2{border-width:2px!important}#botuyo-chat-widget-root .border-b{border-bottom-width:1px!important}#botuyo-chat-widget-root .border-t{border-top-width:1px!important}#botuyo-chat-widget-root .border-border{border-color:hsl(var(--border))!important}#botuyo-chat-widget-root .shadow{box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a!important}#botuyo-chat-widget-root .shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a!important}#botuyo-chat-widget-root .shadow-xl{box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a!important}#botuyo-chat-widget-root .transition{transition-duration:.15s!important;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important}#botuyo-chat-widget-root .transition-all{transition-duration:.15s!important;transition-property:all!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important}#botuyo-chat-widget-root .duration-300{transition-duration:.3s!important}#botuyo-chat-widget-root .duration-500{transition-duration:.5s!important}#botuyo-chat-widget-root .opacity-0{opacity:0!important}#botuyo-chat-widget-root .opacity-100{opacity:1!important}#botuyo-chat-widget-root .scale-95{transform:scale(.95)!important}#botuyo-chat-widget-root .scale-100{transform:scale(1)!important}#botuyo-chat-widget-root .translate-y-full{transform:translateY(100%)!important}#botuyo-chat-widget-root .z-10{z-index:10!important}#botuyo-chat-widget-root .z-20{z-index:20!important}#botuyo-chat-widget-root .z-50{z-index:50!important}#botuyo-chat-widget-root .pointer-events-none{pointer-events:none!important}#botuyo-chat-widget-root .pointer-events-auto{pointer-events:auto!important}#botuyo-chat-widget-root .cursor-pointer{cursor:pointer!important}#botuyo-chat-widget-root .select-none{-webkit-user-select:none!important;-moz-user-select:none!important;user-select:none!important}@keyframes spin{to{transform:rotate(1turn)}}#botuyo-chat-widget,#botuyo-chat-widget-root,:root{--background:0 0% 100%;--foreground:240 10% 3.9%;--card:0 0% 100%;--card-foreground:240 10% 3.9%;--popover:0 0% 100%;--popover-foreground:240 10% 3.9%;--primary:160 84% 39%;--primary-foreground:0 0% 100%;--muted:240 4.8% 95.9%;--muted-foreground:240 3.8% 46.1%;--accent:240 4.8% 95.9%;--accent-foreground:240 5.9% 10%;--destructive:0 84.2% 60.2%;--destructive-foreground:0 0% 98%;--border:240 5.9% 90%;--input:240 5.9% 90%;--ring:160 84% 39%;--radius:.5rem;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:.75rem;--spacing-6:1.5rem;--spacing-7:1.75rem;--spacing-8:2rem;--window-border-radius:24px;--launcher-border-radius:50%;--window-height:700px;--window-bottom:24px}#botuyo-chat-widget-root.dark,#botuyo-chat-widget.dark,.dark{--background:240 10% 3.9%;--foreground:0 0% 98%;--card:240 10% 3.9%;--card-foreground:0 0% 98%;--popover:240 10% 3.9%;--popover-foreground:0 0% 98%;--primary:160 84% 39%;--primary-foreground:0 0% 100%;--muted:240 3.7% 15.9%;--muted-foreground:240 5% 64.9%;--accent:240 3.7% 15.9%;--accent-foreground:0 0% 98%;--destructive:0 62.8% 30.6%;--destructive-foreground:0 0% 98%;--border:240 3.7% 15.9%;--input:240 3.7% 15.9%;--ring:160 84% 39%}#botuyo-chat-widget-root,#botuyo-chat-widget-root *{box-sizing:border-box;margin:0;padding:0}#botuyo-chat-widget-root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:hsl(var(--foreground));font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@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}}#botuyo-chat-widget-root .chat-launcher{align-items:center;background-color:hsl(var(--primary));border-radius:50%;bottom:1.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;color:#fff;cursor:pointer;display:flex;height:60px;justify-content:center;position:fixed;right:1.5rem;transition:all .2s;width:60px;z-index:999999}#botuyo-chat-widget-root .chat-launcher:hover{box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;transform:scale(1.05)}#botuyo-chat-widget-root .chat-launcher.position-bottom-left{left:1.5rem;right:auto}#botuyo-chat-widget-root .chat-launcher.position-top-right{bottom:auto;top:1.5rem}#botuyo-chat-widget-root .chat-launcher.position-top-left{inset:1.5rem auto auto 1.5rem}#botuyo-chat-widget-root .chat-window{animation:slideInRight .3s ease-out;background-color:hsl(var(--background));border-radius:1rem;bottom:6rem;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;height:600px;max-height:calc(100vh - 8rem);overflow:hidden;position:fixed;right:1.5rem;width:400px;z-index:999999}#botuyo-chat-widget-root .chat-window.closing{animation:slideOutRight .2s ease-in}@media(max-width:640px){#botuyo-chat-widget-root .chat-window{animation:slideInUp .3s ease-out;border-radius:0;height:100%;inset:0;max-height:100vh;width:100%}}#botuyo-chat-widget-root .message-bubble{word-wrap:break-word;border-radius:1rem;max-width:80%;padding:.75rem 1rem}#botuyo-chat-widget-root .message-bubble.user{background-color:hsl(var(--primary));color:hsl(var(--primary-foreground));margin-left:auto}#botuyo-chat-widget-root .message-bubble.bot{background-color:hsl(var(--muted));color:hsl(var(--foreground))}#botuyo-chat-widget-root .chat-messages::-webkit-scrollbar{width:6px}#botuyo-chat-widget-root .chat-messages::-webkit-scrollbar-track{background:0 0}#botuyo-chat-widget-root .chat-messages::-webkit-scrollbar-thumb{background:hsl(var(--muted));border-radius:3px}#botuyo-chat-widget-root .chat-messages::-webkit-scrollbar-thumb:hover{background:hsl(var(--muted-foreground))}#botuyo-chat-widget-root .chat-input{background-color:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:.5rem;color:hsl(var(--foreground));outline:none;padding:.75rem;transition:border-color .2s;width:100%}#botuyo-chat-widget-root .chat-input:focus{border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary)/.1)}@media(max-width:640px){#botuyo-chat-widget-root .chat-launcher{bottom:1rem;height:56px;right:1rem;width:56px}}@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-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}';function j({isOpen:t,onClick:e,unreadCount:i=0,primaryColor:s,logoUrl:c,starterPrompt:d,position:l="bottom-right",emotion:u="default",avatars:p={},styles:k,promptPersistence:_="session",avatarScale:z=1,showPromptAvatar:E=!1}){const{t:S}=h("extracted"),O=g({primaryColor:s}),I=k?.launcher?.bg,$=m(),{triggerHaptic:C,getGlowClass:M}=f(),A=$.launcherPulse&&!1!==k?.launcher?.pulse,[j,P]=r(!1),[D,Z]=r(!1),[F,U]=r(!1),[L,R]=r(!1),B="bottom-right"===l,W="chat_launcher_prompt_state",J=o(()=>p[u]||p.default||c||w,[u,p,c]);n(()=>{R(!1)},[J]),n(()=>{const t=Object.values(p).filter(t=>!!t);c&&t.push(c),t.forEach(t=>{(new Image).src=t})},[p,c]),n(()=>{"forever"===_&&"dismissed"===localStorage.getItem(W)&&U(!0)},[_]);const V=a(()=>{Z(!0),setTimeout(()=>P(!1),500),"always"!==_&&(U(!0),"forever"===_&&localStorage.setItem(W,"dismissed"))},[_]);n(()=>{if("always"!==_&&F||!d||t)return void P(!1);const e=setTimeout(()=>{P(!0),Z(!1)},2e3),r=setTimeout(()=>V(),12e3);return()=>{clearTimeout(e),clearTimeout(r)}},[d,t,F,_,V]);const q=()=>{x.debug("Launcher handleMainAction called, isOpen:",t),C(),U(!0),"forever"===_&&localStorage.setItem(W,"dismissed"),e()};/* @__PURE__ */
|
|
2
2
|
return N("div",{className:b("flex items-center w-fit transition-all duration-500",B?"flex-row ml-auto":"flex-row-reverse mr-auto"),children:[
|
|
3
3
|
/* @__PURE__ */T("div",{className:b("transition-all duration-700 ease-[cubic-bezier(0.34,1.56,0.64,1)] flex items-end",j?b("opacity-100 translate-x-0 translate-y-0 w-auto max-w-[320px]",B?"mr-3":"ml-3"):b("opacity-0 w-0 max-w-0 overflow-hidden pointer-events-none",B?"translate-x-6 translate-y-2":"-translate-x-6 translate-y-2")),children:/* @__PURE__ */N("div",{className:b("relative cursor-pointer group",D&&"opacity-0 scale-90 transition-all duration-400",!j&&"hidden"),onClick:q,children:[
|
|
4
4
|
/* @__PURE__ */N("div",{style:{position:"relative",maxWidth:"290px",padding:"14px 40px 14px 18px",borderRadius:B?"20px 20px 8px 20px":"20px 20px 20px 8px",backgroundColor:"hsl(var(--background) / 0.95)",backdropFilter:"blur(16px)",WebkitBackdropFilter:"blur(16px)",color:"hsl(var(--foreground))",boxShadow:"0 8px 32px -8px rgba(0,0,0,0.15), 0 4px 12px -4px rgba(0,0,0,0.08), 0 0 0 1px hsl(var(--border) / 0.4), inset 0 1px 0 hsl(var(--background) / 0.8)",borderLeft:B?`3px solid ${O||"hsl(160,84%,39%)"}`:"none",borderRight:B?"none":`3px solid ${O||"hsl(160,84%,39%)"}`},children:[
|