drizzle-cube 0.4.5 → 0.4.8
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/dist/adapters/express/index.cjs +8 -4
- package/dist/adapters/express/index.d.ts +7 -0
- package/dist/adapters/express/index.js +189 -139
- package/dist/adapters/fastify/index.cjs +8 -4
- package/dist/adapters/fastify/index.d.ts +7 -0
- package/dist/adapters/fastify/index.js +209 -150
- package/dist/adapters/handler-BLcxTuwi.cjs +23 -0
- package/dist/adapters/handler-odjn7MIB.js +1880 -0
- package/dist/adapters/hono/index.cjs +8 -4
- package/dist/adapters/hono/index.d.ts +7 -0
- package/dist/adapters/hono/index.js +202 -144
- package/dist/adapters/{mcp-transport-YHDZWKOi.js → mcp-transport-CU5g9bxj.js} +7 -3
- package/dist/adapters/{mcp-transport-BqLo4hKi.cjs → mcp-transport-KX92EgkF.cjs} +21 -21
- package/dist/adapters/nextjs/index.cjs +7 -3
- package/dist/adapters/nextjs/index.d.ts +14 -0
- package/dist/adapters/nextjs/index.js +220 -144
- package/dist/client/charts/chartConfigs.d.ts +2 -9
- package/dist/client/charts.js +72 -70
- package/dist/client/charts.js.map +1 -1
- package/dist/client/chunks/{RetentionCombinedChart.config-C-ILIaEb.js → RetentionCombinedChart.config-Bbp2ghim.js} +2 -1
- package/dist/client/chunks/RetentionCombinedChart.config-Bbp2ghim.js.map +1 -0
- package/dist/client/chunks/{RetentionHeatmap.config-CIvhc-GT.js → RetentionHeatmap.config-BWf_-vdj.js} +2 -1
- package/dist/client/chunks/RetentionHeatmap.config-BWf_-vdj.js.map +1 -0
- package/dist/client/chunks/{analysis-builder-CG5VIMYB.js → analysis-builder-Bov_gLsf.js} +1408 -1393
- package/dist/client/chunks/analysis-builder-Bov_gLsf.js.map +1 -0
- package/dist/client/chunks/{analysis-builder-shared-CjlKJgyA.js → analysis-builder-shared-NBk6y0md.js} +3 -3
- package/dist/client/chunks/{analysis-builder-shared-CjlKJgyA.js.map → analysis-builder-shared-NBk6y0md.js.map} +1 -1
- package/dist/client/chunks/{chart-activity-grid-DStNr34n.js → chart-activity-grid-CE7xGFQo.js} +2 -2
- package/dist/client/chunks/{chart-activity-grid-DStNr34n.js.map → chart-activity-grid-CE7xGFQo.js.map} +1 -1
- package/dist/client/chunks/chart-box-plot-Dja4LS3O.js +313 -0
- package/dist/client/chunks/chart-box-plot-Dja4LS3O.js.map +1 -0
- package/dist/client/chunks/{chart-config-activity-grid-CAlo1cHA.js → chart-config-activity-grid-CmOqDuOT.js} +4 -5
- package/dist/client/chunks/chart-config-activity-grid-CmOqDuOT.js.map +1 -0
- package/dist/client/chunks/{chart-config-area-CyyJOO2T.js → chart-config-area-CK_GVApT.js} +4 -5
- package/dist/client/chunks/chart-config-area-CK_GVApT.js.map +1 -0
- package/dist/client/chunks/{chart-config-bar-soxw6m2o.js → chart-config-bar-C8uzktxl.js} +4 -5
- package/dist/client/chunks/chart-config-bar-C8uzktxl.js.map +1 -0
- package/dist/client/chunks/chart-config-box-plot-D3DA7_pr.js +85 -0
- package/dist/client/chunks/chart-config-box-plot-D3DA7_pr.js.map +1 -0
- package/dist/client/chunks/{chart-config-bubble-CuSsCHZ4.js → chart-config-bubble-q3DoQX5F.js} +4 -5
- package/dist/client/chunks/chart-config-bubble-q3DoQX5F.js.map +1 -0
- package/dist/client/chunks/{chart-config-data-table-BhgqwoqT.js → chart-config-data-table-B20Y5JCm.js} +4 -5
- package/dist/client/chunks/chart-config-data-table-B20Y5JCm.js.map +1 -0
- package/dist/client/chunks/{chart-config-funnel-BlSQYng0.js → chart-config-funnel-3eYnGg8M.js} +4 -5
- package/dist/client/chunks/chart-config-funnel-3eYnGg8M.js.map +1 -0
- package/dist/client/chunks/{chart-config-heat-map-DHQGFZhX.js → chart-config-heat-map-_wEnTnRA.js} +4 -5
- package/dist/client/chunks/chart-config-heat-map-_wEnTnRA.js.map +1 -0
- package/dist/client/chunks/{chart-config-kpi-delta-yTA5ug_l.js → chart-config-kpi-delta-DLGZ2A3X.js} +4 -5
- package/dist/client/chunks/chart-config-kpi-delta-DLGZ2A3X.js.map +1 -0
- package/dist/client/chunks/{chart-config-kpi-number-nVAwDXzq.js → chart-config-kpi-number-K-wzviXF.js} +4 -5
- package/dist/client/chunks/chart-config-kpi-number-K-wzviXF.js.map +1 -0
- package/dist/client/chunks/{chart-config-kpi-text-DZjqsx-b.js → chart-config-kpi-text-BjYqwqaJ.js} +4 -5
- package/dist/client/chunks/chart-config-kpi-text-BjYqwqaJ.js.map +1 -0
- package/dist/client/chunks/{chart-config-line-D5ME6w0v.js → chart-config-line-JNagi9tf.js} +4 -5
- package/dist/client/chunks/chart-config-line-JNagi9tf.js.map +1 -0
- package/dist/client/chunks/{chart-config-markdown-BXKL5TbQ.js → chart-config-markdown-BWQSjJpy.js} +4 -5
- package/dist/client/chunks/chart-config-markdown-BWQSjJpy.js.map +1 -0
- package/dist/client/chunks/{chart-config-pie-DlHa2jTy.js → chart-config-pie-CNLXb-fr.js} +4 -5
- package/dist/client/chunks/chart-config-pie-CNLXb-fr.js.map +1 -0
- package/dist/client/chunks/{chart-config-radar-BBAVIF0S.js → chart-config-radar-oxHfRAa3.js} +4 -5
- package/dist/client/chunks/chart-config-radar-oxHfRAa3.js.map +1 -0
- package/dist/client/chunks/{chart-config-radial-bar-CTwjDRnB.js → chart-config-radial-bar-_Aw3jAEm.js} +4 -5
- package/dist/client/chunks/chart-config-radial-bar-_Aw3jAEm.js.map +1 -0
- package/dist/client/chunks/{chart-config-sankey-CNAgsMQ4.js → chart-config-sankey-C8FX9hGF.js} +4 -5
- package/dist/client/chunks/chart-config-sankey-C8FX9hGF.js.map +1 -0
- package/dist/client/chunks/{chart-config-scatter-CWvN2E-X.js → chart-config-scatter-DFKM80eO.js} +4 -5
- package/dist/client/chunks/chart-config-scatter-DFKM80eO.js.map +1 -0
- package/dist/client/chunks/{chart-config-sunburst-W_SKwaj0.js → chart-config-sunburst-BmC0NLTU.js} +4 -5
- package/dist/client/chunks/chart-config-sunburst-BmC0NLTU.js.map +1 -0
- package/dist/client/chunks/{chart-config-tree-map-IRAYf9YM.js → chart-config-tree-map-DGMbNTaa.js} +4 -5
- package/dist/client/chunks/chart-config-tree-map-DGMbNTaa.js.map +1 -0
- package/dist/client/chunks/{chart-data-table-Ch_1c1Zo.js → chart-data-table-Ba_6tuJw.js} +2 -2
- package/dist/client/chunks/{chart-data-table-Ch_1c1Zo.js.map → chart-data-table-Ba_6tuJw.js.map} +1 -1
- package/dist/client/chunks/{chart-kpi-delta-CWCmi8vL.js → chart-kpi-delta-D9XJoKuA.js} +3 -3
- package/dist/client/chunks/{chart-kpi-delta-CWCmi8vL.js.map → chart-kpi-delta-D9XJoKuA.js.map} +1 -1
- package/dist/client/chunks/{chart-kpi-number-C-5m3qt5.js → chart-kpi-number-C29Vj2g8.js} +2 -2
- package/dist/client/chunks/{chart-kpi-number-C-5m3qt5.js.map → chart-kpi-number-C29Vj2g8.js.map} +1 -1
- package/dist/client/chunks/{chart-kpi-text--t4ibPmx.js → chart-kpi-text-CgjjrurK.js} +2 -2
- package/dist/client/chunks/{chart-kpi-text--t4ibPmx.js.map → chart-kpi-text-CgjjrurK.js.map} +1 -1
- package/dist/client/chunks/chart-markdown-Du4Z2iqK.js +2695 -0
- package/dist/client/chunks/chart-markdown-Du4Z2iqK.js.map +1 -0
- package/dist/client/chunks/{charts-loader-m5Ussksz.js → charts-loader-HYQFVOo4.js} +14 -13
- package/dist/client/chunks/charts-loader-HYQFVOo4.js.map +1 -0
- package/dist/client/chunks/{components-D-5p1LVQ.js → components-O0hh7ooo.js} +6 -6
- package/dist/client/chunks/components-O0hh7ooo.js.map +1 -0
- package/dist/client/chunks/{icons-DRreo6m8.js → icons-DAeqv1iX.js} +7 -7
- package/dist/client/chunks/{icons-DRreo6m8.js.map → icons-DAeqv1iX.js.map} +1 -1
- package/dist/client/components/AgenticNotebook/AgentChatPanel.d.ts +8 -0
- package/dist/client/components/AgenticNotebook/ChatInput.d.ts +14 -0
- package/dist/client/components/AgenticNotebook/ChatMessage.d.ts +7 -0
- package/dist/client/components/AgenticNotebook/NotebookCanvas.d.ts +3 -0
- package/dist/client/components/AgenticNotebook/NotebookMarkdownBlock.d.ts +12 -0
- package/dist/client/components/AgenticNotebook/NotebookPortletBlock.d.ts +12 -0
- package/dist/client/components/AgenticNotebook/index.d.ts +34 -0
- package/dist/client/components/charts/BoxPlotChart.config.d.ts +11 -0
- package/dist/client/components/charts/BoxPlotChart.d.ts +4 -0
- package/dist/client/components/charts/index.d.ts +1 -0
- package/dist/client/components.js +1 -1
- package/dist/client/hooks/useAgentChat.d.ts +36 -0
- package/dist/client/icons.js +1 -1
- package/dist/client/index.d.ts +6 -0
- package/dist/client/index.js +923 -187
- package/dist/client/index.js.map +1 -1
- package/dist/client/stores/notebookStore.d.ts +152 -0
- package/dist/client/styles.css +1 -1
- package/dist/client/types.d.ts +1 -1
- package/dist/client/utils.js +3 -3
- package/dist/client-bundle-stats.html +4 -4
- package/dist/server/index.cjs +116 -90
- package/dist/server/index.d.ts +155 -0
- package/dist/server/index.js +7088 -4852
- package/package.json +12 -6
- package/dist/client/chunks/RetentionCombinedChart.config-C-ILIaEb.js.map +0 -1
- package/dist/client/chunks/RetentionHeatmap.config-CIvhc-GT.js.map +0 -1
- package/dist/client/chunks/analysis-builder-CG5VIMYB.js.map +0 -1
- package/dist/client/chunks/chart-config-activity-grid-CAlo1cHA.js.map +0 -1
- package/dist/client/chunks/chart-config-area-CyyJOO2T.js.map +0 -1
- package/dist/client/chunks/chart-config-bar-soxw6m2o.js.map +0 -1
- package/dist/client/chunks/chart-config-bubble-CuSsCHZ4.js.map +0 -1
- package/dist/client/chunks/chart-config-data-table-BhgqwoqT.js.map +0 -1
- package/dist/client/chunks/chart-config-funnel-BlSQYng0.js.map +0 -1
- package/dist/client/chunks/chart-config-heat-map-DHQGFZhX.js.map +0 -1
- package/dist/client/chunks/chart-config-kpi-delta-yTA5ug_l.js.map +0 -1
- package/dist/client/chunks/chart-config-kpi-number-nVAwDXzq.js.map +0 -1
- package/dist/client/chunks/chart-config-kpi-text-DZjqsx-b.js.map +0 -1
- package/dist/client/chunks/chart-config-line-D5ME6w0v.js.map +0 -1
- package/dist/client/chunks/chart-config-markdown-BXKL5TbQ.js.map +0 -1
- package/dist/client/chunks/chart-config-pie-DlHa2jTy.js.map +0 -1
- package/dist/client/chunks/chart-config-radar-BBAVIF0S.js.map +0 -1
- package/dist/client/chunks/chart-config-radial-bar-CTwjDRnB.js.map +0 -1
- package/dist/client/chunks/chart-config-sankey-CNAgsMQ4.js.map +0 -1
- package/dist/client/chunks/chart-config-scatter-CWvN2E-X.js.map +0 -1
- package/dist/client/chunks/chart-config-sunburst-W_SKwaj0.js.map +0 -1
- package/dist/client/chunks/chart-config-tree-map-IRAYf9YM.js.map +0 -1
- package/dist/client/chunks/chart-markdown-Rq6ORisB.js +0 -276
- package/dist/client/chunks/chart-markdown-Rq6ORisB.js.map +0 -1
- package/dist/client/chunks/chartConfigRegistry-C5dZm-ZK.js +0 -44
- package/dist/client/chunks/chartConfigRegistry-C5dZm-ZK.js.map +0 -1
- package/dist/client/chunks/charts-loader-m5Ussksz.js.map +0 -1
- package/dist/client/chunks/components-D-5p1LVQ.js.map +0 -1
package/dist/client/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/client/components/AnalyticsPage.tsx","../../src/client/components/DashboardThumbnailPlaceholder.tsx"],"sourcesContent":["// Placeholder component - will be implemented in Phase 4\nexport function AnalyticsPage() {\n return <div>Analytics Page - Coming in Phase 4</div>\n}","/**\n * DashboardThumbnailPlaceholder\n *\n * A placeholder component shown when a dashboard thumbnail doesn't exist\n * but the thumbnail feature is enabled. Displays a simple grid icon\n * with \"No preview\" text.\n */\n\nimport { getIcon } from '../icons'\n\nconst GridIcon = getIcon('segment')\n\nexport interface DashboardThumbnailPlaceholderProps {\n /** Additional CSS classes */\n className?: string\n}\n\nexport function DashboardThumbnailPlaceholder({\n className = ''\n}: DashboardThumbnailPlaceholderProps) {\n return (\n <div\n className={`dc:flex dc:items-center dc:justify-center bg-dc-bg-secondary ${className}`}\n >\n <div className=\"dc:text-center\">\n <GridIcon\n className=\"dc:w-8 dc:h-8 dc:mx-auto dc:mb-2 text-dc-text-muted dc:opacity-50\"\n />\n <span className=\"dc:text-xs text-dc-text-muted\">No preview</span>\n </div>\n </div>\n )\n}\n\nexport default DashboardThumbnailPlaceholder\n"],"names":["AnalyticsPage","jsx","GridIcon","getIcon","DashboardThumbnailPlaceholder","className","jsxs"],"mappings":";;;;;;;;;;;;;;;;AACO,SAASA,IAAgB;AAC9B,SAAO,gBAAAC,EAAC,SAAI,UAAA,qCAAA,CAAkC;AAChD;ACOA,MAAMC,IAAWC,EAAQ,SAAS;AAO3B,SAASC,EAA8B;AAAA,EAC5C,WAAAC,IAAY;AACd,GAAuC;AACrC,SACE,gBAAAJ;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,gEAAgEI,CAAS;AAAA,MAEpF,UAAA,gBAAAC,EAAC,OAAA,EAAI,WAAU,kBACb,UAAA;AAAA,QAAA,gBAAAL;AAAA,UAACC;AAAA,UAAA;AAAA,YACC,WAAU;AAAA,UAAA;AAAA,QAAA;AAAA,QAEZ,gBAAAD,EAAC,QAAA,EAAK,WAAU,iCAAgC,UAAA,aAAA,CAAU;AAAA,MAAA,EAAA,CAC5D;AAAA,IAAA;AAAA,EAAA;AAGN;"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/client/stores/notebookStore.tsx","../../src/client/components/AgenticNotebook/NotebookPortletBlock.tsx","../../src/client/components/AgenticNotebook/NotebookMarkdownBlock.tsx","../../src/client/components/AgenticNotebook/NotebookCanvas.tsx","../../src/client/hooks/useAgentChat.ts","../../src/client/components/AgenticNotebook/ChatMessage.tsx","../../src/client/components/AgenticNotebook/ChatInput.tsx","../../src/client/components/AgenticNotebook/AgentChatPanel.tsx","../../src/client/components/AgenticNotebook/index.tsx","../../src/client/components/AnalyticsPage.tsx","../../src/client/components/DashboardThumbnailPlaceholder.tsx"],"sourcesContent":["/**\n * Notebook Zustand Store (Instance-based)\n *\n * State management for the AgenticNotebook component, consolidating:\n * - Notebook blocks (portlets + markdown)\n * - Chat messages\n * - Session state\n * - UI state\n *\n * KEY ARCHITECTURE: Instance-based stores\n * - Each AgenticNotebook gets its own store instance via Context\n * - No server state (data fetching is handled by portlets via TanStack Query)\n * - State is per-notebook session\n *\n * Uses Zustand's createStore (factory) instead of create (singleton).\n * Store is provided via React Context.\n */\n\nimport { createContext, useContext, useRef, type ReactNode } from 'react'\nimport { createStore, useStore, type StoreApi } from 'zustand'\nimport { devtools, subscribeWithSelector } from 'zustand/middleware'\nimport type {\n ChartType,\n ChartAxisConfig,\n ChartDisplayConfig,\n} from '../types'\n\n// ============================================================================\n// Types\n// ============================================================================\n\n/**\n * A portlet block in the notebook\n */\nexport interface PortletBlock {\n id: string\n type: 'portlet'\n title: string\n query: string\n chartType: ChartType\n chartConfig?: ChartAxisConfig\n displayConfig?: ChartDisplayConfig\n}\n\n/**\n * A markdown text block in the notebook\n */\nexport interface MarkdownBlock {\n id: string\n type: 'markdown'\n title?: string\n content: string\n}\n\n/**\n * A block in the notebook canvas\n */\nexport type NotebookBlock = PortletBlock | MarkdownBlock\n\n/**\n * A tool call record for display in chat messages\n */\nexport interface ToolCallRecord {\n id: string\n name: string\n input?: unknown\n result?: unknown\n status: 'running' | 'complete' | 'error'\n}\n\n/**\n * A chat message\n */\nexport interface ChatMessage {\n id: string\n role: 'user' | 'assistant'\n content: string\n toolCalls?: ToolCallRecord[]\n timestamp: number\n}\n\n/**\n * Serializable notebook config for save/load\n */\nexport interface NotebookConfig {\n blocks: NotebookBlock[]\n messages: ChatMessage[]\n}\n\n// ============================================================================\n// Store State\n// ============================================================================\n\nexport interface NotebookStoreState {\n /** Ordered array of notebook blocks */\n blocks: NotebookBlock[]\n\n /** Chat message history */\n messages: ChatMessage[]\n\n /** Whether the agent is currently streaming a response */\n isStreaming: boolean\n\n /** Agent SDK session ID for multi-turn conversations */\n sessionId: string | null\n\n /** Chat input value */\n inputValue: string\n}\n\n// ============================================================================\n// Store Actions\n// ============================================================================\n\nexport interface NotebookStoreActions {\n // Block actions\n addBlock: (block: NotebookBlock) => void\n removeBlock: (id: string) => void\n moveBlock: (id: string, direction: 'up' | 'down') => void\n\n // Chat actions\n addMessage: (message: ChatMessage) => void\n appendToLastAssistantMessage: (text: string) => void\n addToolCallToLastAssistant: (toolCall: ToolCallRecord) => void\n updateLastToolCall: (update: Partial<ToolCallRecord>) => void\n\n // Session/UI actions\n setIsStreaming: (streaming: boolean) => void\n setSessionId: (id: string | null) => void\n setInputValue: (value: string) => void\n\n // Persistence\n save: () => NotebookConfig\n load: (config: NotebookConfig) => void\n\n // Reset\n reset: () => void\n}\n\n/**\n * Combined store type\n */\nexport type NotebookStore = NotebookStoreState & NotebookStoreActions\n\n// ============================================================================\n// Initial State\n// ============================================================================\n\nconst createDefaultState = (): NotebookStoreState => ({\n blocks: [],\n messages: [],\n isStreaming: false,\n sessionId: null,\n inputValue: '',\n})\n\n// ============================================================================\n// Store Factory\n// ============================================================================\n\nfunction createStoreActions(\n set: (\n partial:\n | Partial<NotebookStore>\n | ((state: NotebookStore) => Partial<NotebookStore>)\n ) => void,\n get: () => NotebookStore\n): NotebookStoreActions {\n return {\n // Block actions\n addBlock: (block) =>\n set((state) => ({\n blocks: [...state.blocks, block],\n })),\n\n removeBlock: (id) =>\n set((state) => ({\n blocks: state.blocks.filter((b) => b.id !== id),\n })),\n\n moveBlock: (id, direction) =>\n set((state) => {\n const idx = state.blocks.findIndex((b) => b.id === id)\n if (idx === -1) return {}\n if (direction === 'up' && idx === 0) return {}\n if (direction === 'down' && idx === state.blocks.length - 1) return {}\n\n const newBlocks = [...state.blocks]\n const swapIdx = direction === 'up' ? idx - 1 : idx + 1\n ;[newBlocks[idx], newBlocks[swapIdx]] = [newBlocks[swapIdx], newBlocks[idx]]\n return { blocks: newBlocks }\n }),\n\n // Chat actions\n addMessage: (message) =>\n set((state) => ({\n messages: [...state.messages, message],\n })),\n\n appendToLastAssistantMessage: (text) =>\n set((state) => {\n const messages = [...state.messages]\n const lastMsg = messages[messages.length - 1]\n if (lastMsg && lastMsg.role === 'assistant') {\n messages[messages.length - 1] = {\n ...lastMsg,\n content: lastMsg.content + text,\n }\n }\n return { messages }\n }),\n\n addToolCallToLastAssistant: (toolCall) =>\n set((state) => {\n const messages = [...state.messages]\n const lastMsg = messages[messages.length - 1]\n if (lastMsg && lastMsg.role === 'assistant') {\n messages[messages.length - 1] = {\n ...lastMsg,\n toolCalls: [...(lastMsg.toolCalls || []), toolCall],\n }\n }\n return { messages }\n }),\n\n updateLastToolCall: (update) =>\n set((state) => {\n const messages = [...state.messages]\n const lastMsg = messages[messages.length - 1]\n if (lastMsg?.role === 'assistant' && lastMsg.toolCalls?.length) {\n const toolCalls = [...lastMsg.toolCalls]\n // Find by ID if provided, otherwise fall back to last\n const idx = update.id\n ? toolCalls.findIndex((tc) => tc.id === update.id)\n : toolCalls.length - 1\n if (idx !== -1) {\n toolCalls[idx] = { ...toolCalls[idx], ...update }\n messages[messages.length - 1] = { ...lastMsg, toolCalls }\n }\n }\n return { messages }\n }),\n\n // Session/UI actions\n setIsStreaming: (streaming) => set({ isStreaming: streaming }),\n setSessionId: (id) => set({ sessionId: id }),\n setInputValue: (value) => set({ inputValue: value }),\n\n // Persistence\n save: () => {\n const state = get()\n return {\n blocks: state.blocks,\n messages: state.messages,\n }\n },\n\n load: (config) =>\n set({\n blocks: config.blocks || [],\n messages: config.messages || [],\n }),\n\n // Reset\n reset: () => set(createDefaultState()),\n }\n}\n\n/**\n * Create a new notebook store instance\n */\nexport function createNotebookStore() {\n const initialState = createDefaultState()\n\n return createStore<NotebookStore>()(\n devtools(\n subscribeWithSelector((set, get) => ({\n ...initialState,\n ...createStoreActions(set, get),\n })),\n { name: 'NotebookStore' }\n )\n )\n}\n\n// ============================================================================\n// React Context & Provider\n// ============================================================================\n\nconst NotebookStoreContext = createContext<StoreApi<NotebookStore> | null>(null)\n\nexport interface NotebookStoreProviderProps {\n children: ReactNode\n /** Initial config to load */\n initialConfig?: NotebookConfig\n}\n\n/**\n * Provider component that creates a store instance per AgenticNotebook\n */\nexport function NotebookStoreProvider({\n children,\n initialConfig,\n}: NotebookStoreProviderProps) {\n const storeRef = useRef<StoreApi<NotebookStore> | null>(null)\n\n if (!storeRef.current) {\n const store = createNotebookStore()\n if (initialConfig) {\n store.getState().load(initialConfig)\n }\n storeRef.current = store\n }\n\n return (\n <NotebookStoreContext.Provider value={storeRef.current}>\n {children}\n </NotebookStoreContext.Provider>\n )\n}\n\n/**\n * Hook to access the notebook store from context\n * @throws Error if used outside of provider\n */\nexport function useNotebookStore<T>(selector: (state: NotebookStore) => T): T {\n const store = useContext(NotebookStoreContext)\n if (!store) {\n throw new Error('useNotebookStore must be used within NotebookStoreProvider')\n }\n return useStore(store, selector)\n}\n\n// ============================================================================\n// Selectors\n// ============================================================================\n\nexport const selectBlocks = (state: NotebookStore) => state.blocks\nexport const selectMessages = (state: NotebookStore) => state.messages\nexport const selectIsStreaming = (state: NotebookStore) => state.isStreaming\nexport const selectSessionId = (state: NotebookStore) => state.sessionId\nexport const selectInputValue = (state: NotebookStore) => state.inputValue\n\nexport const selectChatState = (state: NotebookStore) => ({\n messages: state.messages,\n isStreaming: state.isStreaming,\n inputValue: state.inputValue,\n})\n\nexport const selectChatActions = (state: NotebookStore) => ({\n addMessage: state.addMessage,\n appendToLastAssistantMessage: state.appendToLastAssistantMessage,\n addToolCallToLastAssistant: state.addToolCallToLastAssistant,\n updateLastToolCall: state.updateLastToolCall,\n setIsStreaming: state.setIsStreaming,\n setInputValue: state.setInputValue,\n setSessionId: state.setSessionId,\n})\n\nexport const selectBlockActions = (state: NotebookStore) => ({\n addBlock: state.addBlock,\n removeBlock: state.removeBlock,\n moveBlock: state.moveBlock,\n})\n","/**\n * NotebookPortletBlock - Wraps AnalyticsPortlet for notebook display\n */\n\nimport React from 'react'\nimport type { PortletBlock } from '../../stores/notebookStore'\nimport AnalyticsPortlet from '../AnalyticsPortlet'\n\ninterface NotebookPortletBlockProps {\n block: PortletBlock\n onRemove: (id: string) => void\n onMoveUp: (id: string) => void\n onMoveDown: (id: string) => void\n isFirst: boolean\n isLast: boolean\n}\n\nconst NotebookPortletBlock = React.memo(function NotebookPortletBlock({\n block,\n onRemove,\n onMoveUp,\n onMoveDown,\n isFirst,\n isLast,\n}: NotebookPortletBlockProps) {\n return (\n <div className=\"dc:group dc:relative dc:mb-4\">\n {/* Hover toolbar */}\n <div className=\"dc:absolute dc:right-2 dc:top-2 dc:z-10 dc:flex dc:gap-1 dc:opacity-0 dc:group-hover:opacity-100 dc:transition-opacity\">\n {!isFirst && (\n <button\n onClick={() => onMoveUp(block.id)}\n className=\"dc:p-1 dc:rounded dc:text-xs bg-dc-surface text-dc-text-secondary dc:hover:opacity-80 border-dc-border dc:border\"\n title=\"Move up\"\n >\n ▲\n </button>\n )}\n {!isLast && (\n <button\n onClick={() => onMoveDown(block.id)}\n className=\"dc:p-1 dc:rounded dc:text-xs bg-dc-surface text-dc-text-secondary dc:hover:opacity-80 border-dc-border dc:border\"\n title=\"Move down\"\n >\n ▼\n </button>\n )}\n <button\n onClick={() => onRemove(block.id)}\n className=\"dc:p-1 dc:rounded dc:text-xs text-dc-error dc:hover:opacity-80 bg-dc-surface border-dc-border dc:border\"\n title=\"Remove\"\n >\n ✕\n </button>\n </div>\n\n {/* Title */}\n {block.title && (\n <h4 className=\"dc:text-sm dc:font-semibold text-dc-text dc:mb-2 dc:px-1\">\n {block.title}\n </h4>\n )}\n\n {/* Portlet */}\n <div className=\"dc:rounded-lg dc:overflow-hidden border-dc-border dc:border bg-dc-surface\">\n <AnalyticsPortlet\n query={block.query}\n chartType={block.chartType}\n chartConfig={block.chartConfig}\n displayConfig={block.displayConfig}\n height={400}\n eagerLoad={true}\n />\n </div>\n </div>\n )\n})\n\nexport default NotebookPortletBlock\n","/**\n * NotebookMarkdownBlock - Renders a markdown text block in the notebook\n * Uses markdown-to-jsx for full GFM support including tables\n */\n\nimport React from 'react'\nimport Markdown from 'markdown-to-jsx'\nimport type { MarkdownBlock } from '../../stores/notebookStore'\n\ninterface NotebookMarkdownBlockProps {\n block: MarkdownBlock\n onRemove: (id: string) => void\n onMoveUp: (id: string) => void\n onMoveDown: (id: string) => void\n isFirst: boolean\n isLast: boolean\n}\n\n/** markdown-to-jsx options with dc: themed overrides */\nconst markdownOptions = {\n overrides: {\n h1: { props: { className: 'dc:text-lg dc:font-bold text-dc-text dc:mb-2 dc:mt-3' } },\n h2: { props: { className: 'dc:text-base dc:font-semibold text-dc-text dc:mb-2 dc:mt-3' } },\n h3: { props: { className: 'dc:text-sm dc:font-semibold text-dc-text dc:mb-2 dc:mt-3' } },\n p: { props: { className: 'dc:text-sm dc:leading-relaxed text-dc-text dc:mb-2' } },\n strong: { props: { className: 'dc:font-semibold' } },\n a: { props: { className: 'text-dc-accent dc:hover:underline', target: '_blank', rel: 'noopener noreferrer' } },\n code: { props: { className: 'dc:px-1 dc:py-0.5 dc:rounded dc:text-xs bg-dc-surface-secondary text-dc-accent dc:font-mono' } },\n pre: { props: { className: 'dc:rounded-lg dc:p-3 dc:my-2 dc:overflow-x-auto dc:text-xs bg-dc-surface-secondary text-dc-text dc:font-mono' } },\n ul: { props: { className: 'dc:list-disc dc:ml-5 dc:mb-2 dc:text-sm text-dc-text dc:space-y-1' } },\n ol: { props: { className: 'dc:list-decimal dc:ml-5 dc:mb-2 dc:text-sm text-dc-text dc:space-y-1' } },\n li: { props: { className: 'dc:text-sm text-dc-text' } },\n hr: { props: { className: 'dc:my-3 border-dc-border' } },\n blockquote: { props: { className: 'dc:border-l-4 border-dc-accent dc:pl-3 dc:my-2 dc:italic text-dc-text-secondary dc:text-sm' } },\n table: { props: { className: 'dc:w-full dc:border-collapse dc:my-2 dc:text-sm' } },\n thead: { props: { className: 'bg-dc-surface-secondary' } },\n th: { props: { className: 'dc:px-3 dc:py-2 dc:text-left dc:font-semibold dc:text-xs text-dc-text-secondary dc:uppercase dc:tracking-wider border-dc-border dc:border-b' } },\n td: { props: { className: 'dc:px-3 dc:py-2 dc:text-sm text-dc-text border-dc-border dc:border-b' } },\n tr: { props: { className: 'dc:hover:opacity-80' } },\n },\n}\n\nconst NotebookMarkdownBlock = React.memo(function NotebookMarkdownBlock({\n block,\n onRemove,\n onMoveUp,\n onMoveDown,\n isFirst,\n isLast,\n}: NotebookMarkdownBlockProps) {\n return (\n <div className=\"dc:group dc:relative dc:mb-4\">\n {/* Hover toolbar */}\n <div className=\"dc:absolute dc:right-2 dc:top-2 dc:z-10 dc:flex dc:gap-1 dc:opacity-0 dc:group-hover:opacity-100 dc:transition-opacity\">\n {!isFirst && (\n <button\n onClick={() => onMoveUp(block.id)}\n className=\"dc:p-1 dc:rounded dc:text-xs bg-dc-surface text-dc-text-secondary dc:hover:opacity-80 border-dc-border dc:border\"\n title=\"Move up\"\n >\n ▲\n </button>\n )}\n {!isLast && (\n <button\n onClick={() => onMoveDown(block.id)}\n className=\"dc:p-1 dc:rounded dc:text-xs bg-dc-surface text-dc-text-secondary dc:hover:opacity-80 border-dc-border dc:border\"\n title=\"Move down\"\n >\n ▼\n </button>\n )}\n <button\n onClick={() => onRemove(block.id)}\n className=\"dc:p-1 dc:rounded dc:text-xs text-dc-error dc:hover:opacity-80 bg-dc-surface border-dc-border dc:border\"\n title=\"Remove\"\n >\n ✕\n </button>\n </div>\n\n {/* Title */}\n {block.title && (\n <h4 className=\"dc:text-sm dc:font-semibold text-dc-text dc:mb-2 dc:px-1\">\n {block.title}\n </h4>\n )}\n\n {/* Markdown content */}\n <div className=\"dc:rounded-lg dc:p-4 bg-dc-surface border-dc-border dc:border\">\n <Markdown options={markdownOptions}>\n {block.content}\n </Markdown>\n </div>\n </div>\n )\n})\n\nexport default NotebookMarkdownBlock\n","/**\n * NotebookCanvas - Left panel displaying notebook blocks\n */\n\nimport React, { useCallback, useRef, useEffect } from 'react'\nimport { useShallow } from 'zustand/react/shallow'\nimport { useNotebookStore, selectBlocks, selectBlockActions } from '../../stores/notebookStore'\nimport NotebookPortletBlock from './NotebookPortletBlock'\nimport NotebookMarkdownBlock from './NotebookMarkdownBlock'\n\nconst NotebookCanvas = React.memo(function NotebookCanvas() {\n const blocks = useNotebookStore(selectBlocks)\n const { removeBlock, moveBlock } = useNotebookStore(useShallow(selectBlockActions))\n const endRef = useRef<HTMLDivElement>(null)\n\n // Auto-scroll only when NEW blocks are added (not on initial load)\n const prevCountRef = useRef(blocks.length)\n useEffect(() => {\n if (blocks.length > prevCountRef.current) {\n endRef.current?.scrollIntoView({ behavior: 'smooth' })\n }\n prevCountRef.current = blocks.length\n }, [blocks.length])\n\n const handleRemove = useCallback((id: string) => removeBlock(id), [removeBlock])\n const handleMoveUp = useCallback((id: string) => moveBlock(id, 'up'), [moveBlock])\n const handleMoveDown = useCallback((id: string) => moveBlock(id, 'down'), [moveBlock])\n\n if (blocks.length === 0) {\n return (\n <div className=\"dc:flex dc:items-center dc:justify-center dc:h-full\">\n <div className=\"dc:text-center dc:max-w-sm dc:px-6\">\n <div className=\"dc:text-4xl dc:mb-4 dc:opacity-30\">📊</div>\n <h3 className=\"dc:text-base dc:font-semibold text-dc-text dc:mb-2\">\n Your notebook is empty\n </h3>\n <p className=\"dc:text-sm text-dc-text-secondary\">\n Ask the AI assistant a question about your data.\n Charts and insights will appear here as the assistant analyzes your data.\n </p>\n </div>\n </div>\n )\n }\n\n return (\n <div className=\"dc:h-full dc:overflow-y-auto dc:p-4\">\n {blocks.map((block, index) => {\n const isFirst = index === 0\n const isLast = index === blocks.length - 1\n\n if (block.type === 'portlet') {\n return (\n <NotebookPortletBlock\n key={block.id}\n block={block}\n onRemove={handleRemove}\n onMoveUp={handleMoveUp}\n onMoveDown={handleMoveDown}\n isFirst={isFirst}\n isLast={isLast}\n />\n )\n }\n\n if (block.type === 'markdown') {\n return (\n <NotebookMarkdownBlock\n key={block.id}\n block={block}\n onRemove={handleRemove}\n onMoveUp={handleMoveUp}\n onMoveDown={handleMoveDown}\n isFirst={isFirst}\n isLast={isLast}\n />\n )\n }\n\n return null\n })}\n <div ref={endRef} />\n </div>\n )\n})\n\nexport default NotebookCanvas\n","/**\n * useAgentChat Hook\n * SSE streaming hook for the agentic notebook chat interface\n */\n\nimport { useRef, useCallback, useState } from 'react'\nimport { useCubeApi } from '../providers/CubeProvider'\nimport type { PortletBlock, MarkdownBlock } from '../stores/notebookStore'\n\ninterface AgentSSEEvent {\n type: 'text_delta' | 'tool_use_start' | 'tool_use_result' | 'add_portlet' | 'add_markdown' | 'turn_complete' | 'done' | 'error'\n data: any\n}\n\nexport interface UseAgentChatOptions {\n /** Override default agent endpoint (default: apiUrl + '/agent/chat') */\n agentEndpoint?: string\n /** Client-side API key for demo/try-site use */\n agentApiKey?: string\n /** Called when agent adds a portlet to the notebook */\n onAddPortlet: (data: PortletBlock) => void\n /** Called when agent adds a markdown block to the notebook */\n onAddMarkdown: (data: MarkdownBlock) => void\n /** Called when streaming text arrives */\n onTextDelta: (text: string) => void\n /** Called when a tool call starts */\n onToolStart: (id: string, name: string, input?: unknown) => void\n /** Called when a tool call completes */\n onToolResult: (id: string, name: string, result?: unknown) => void\n /** Called when the agent completes with session ID */\n onDone: (sessionId: string) => void\n /** Called when a turn completes (between agentic turns) */\n onTurnComplete?: () => void\n /** Called on error */\n onError: (message: string) => void\n}\n\nexport interface UseAgentChatResult {\n /** Send a message to the agent */\n sendMessage: (content: string, sessionId?: string | null) => Promise<void>\n /** Whether the agent is currently streaming */\n isStreaming: boolean\n /** Abort the current stream */\n abort: () => void\n}\n\n/**\n * Hook for streaming chat with the agentic notebook backend.\n * Uses fetch() with ReadableStream to consume SSE events.\n */\nexport function useAgentChat(options: UseAgentChatOptions): UseAgentChatResult {\n const {\n agentEndpoint,\n agentApiKey,\n onAddPortlet,\n onAddMarkdown,\n onTextDelta,\n onToolStart,\n onToolResult,\n onTurnComplete,\n onDone,\n onError,\n } = options\n\n const { cubeApi } = useCubeApi()\n const abortControllerRef = useRef<AbortController | null>(null)\n const [isStreaming, setIsStreaming] = useState(false)\n\n const sendMessage = useCallback(async (content: string, sessionId?: string | null) => {\n function handleEvent(event: AgentSSEEvent) {\n switch (event.type) {\n case 'text_delta':\n onTextDelta(event.data)\n break\n case 'tool_use_start':\n onToolStart(event.data.id, event.data.name, event.data.input)\n break\n case 'tool_use_result':\n onToolResult(event.data.id, event.data.name, event.data.result)\n break\n case 'add_portlet':\n onAddPortlet({\n ...event.data,\n type: 'portlet',\n })\n break\n case 'add_markdown':\n onAddMarkdown({\n ...event.data,\n type: 'markdown',\n })\n break\n case 'turn_complete':\n onTurnComplete?.()\n break\n case 'done':\n onDone(event.data.sessionId)\n break\n case 'error':\n onError(event.data.message)\n break\n }\n }\n\n // Abort any existing stream\n if (abortControllerRef.current) {\n abortControllerRef.current.abort()\n }\n\n const controller = new AbortController()\n abortControllerRef.current = controller\n setIsStreaming(true)\n\n try {\n // Build endpoint URL from CubeClient's API URL\n const apiUrl = (cubeApi as any).apiUrl || '/cubejs-api/v1'\n const endpoint = agentEndpoint || `${apiUrl}/agent/chat`\n\n // Build headers matching CubeClient's auth pattern\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n ...(cubeApi as any).headers,\n }\n\n // Add agent API key if provided\n if (agentApiKey) {\n headers['X-Agent-Api-Key'] = agentApiKey\n }\n\n const response = await fetch(endpoint, {\n method: 'POST',\n headers,\n credentials: (cubeApi as any).credentials ?? 'include',\n body: JSON.stringify({\n message: content,\n ...(sessionId ? { sessionId } : {}),\n }),\n signal: controller.signal,\n })\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}))\n throw new Error(errorData.error || `Agent request failed: ${response.status}`)\n }\n\n if (!response.body) {\n throw new Error('No response body received')\n }\n\n // Read SSE stream\n const reader = response.body.getReader()\n const decoder = new TextDecoder()\n let buffer = ''\n\n while (true) {\n const { done, value } = await reader.read()\n if (done) break\n\n buffer += decoder.decode(value, { stream: true })\n\n // Process complete SSE events (delimited by double newline)\n const events = buffer.split('\\n\\n')\n buffer = events.pop() || '' // Keep incomplete last chunk\n\n for (const eventStr of events) {\n const lines = eventStr.trim().split('\\n')\n for (const line of lines) {\n if (line.startsWith('data: ')) {\n try {\n const event: AgentSSEEvent = JSON.parse(line.slice(6))\n handleEvent(event)\n } catch {\n // Skip malformed events\n }\n }\n }\n }\n }\n\n // Process any remaining buffer\n if (buffer.trim()) {\n const lines = buffer.trim().split('\\n')\n for (const line of lines) {\n if (line.startsWith('data: ')) {\n try {\n const event: AgentSSEEvent = JSON.parse(line.slice(6))\n handleEvent(event)\n } catch {\n // Skip malformed events\n }\n }\n }\n }\n } catch (error) {\n if ((error as Error).name !== 'AbortError') {\n onError(error instanceof Error ? error.message : 'Stream failed')\n }\n } finally {\n setIsStreaming(false)\n abortControllerRef.current = null\n }\n }, [cubeApi, agentEndpoint, agentApiKey, onAddPortlet, onAddMarkdown, onTextDelta, onToolStart, onToolResult, onTurnComplete, onDone, onError])\n\n const abort = useCallback(() => {\n if (abortControllerRef.current) {\n abortControllerRef.current.abort()\n abortControllerRef.current = null\n setIsStreaming(false)\n }\n }, [])\n\n return {\n sendMessage,\n isStreaming,\n abort,\n }\n}\n","/**\n * ChatMessage - Renders individual user and assistant messages\n */\n\nimport React, { useState } from 'react'\nimport type { ChatMessage as ChatMessageType, ToolCallRecord } from '../../stores/notebookStore'\n\n/** Simple inline markdown parser for bold, italic, and code in chat text */\nfunction renderInlineMarkdown(text: string): React.ReactNode[] {\n const nodes: React.ReactNode[] = []\n let remaining = text\n let key = 0\n\n while (remaining) {\n // Code inline `text`\n const codeMatch = remaining.match(/^(.*?)`([^`]+)`(.*)$/)\n if (codeMatch) {\n const [, before, code, after] = codeMatch\n if (before) nodes.push(<span key={key++}>{before}</span>)\n nodes.push(\n <code key={key++} className=\"dc:px-1 dc:py-0.5 dc:rounded dc:text-xs bg-dc-surface dc:font-mono\">\n {code}\n </code>\n )\n remaining = after\n continue\n }\n\n // Bold **text**\n const boldMatch = remaining.match(/^(.*?)\\*\\*([^*]+)\\*\\*(.*)$/)\n if (boldMatch) {\n const [, before, bold, after] = boldMatch\n if (before) nodes.push(<span key={key++}>{before}</span>)\n nodes.push(<strong key={key++} className=\"dc:font-semibold\">{bold}</strong>)\n remaining = after\n continue\n }\n\n // Plain text\n nodes.push(<span key={key}>{remaining}</span>)\n break\n }\n\n return nodes\n}\n\ninterface ChatMessageProps {\n message: ChatMessageType\n}\n\n/** Tool call label mapping for user-friendly display */\nconst TOOL_LABELS: Record<string, string> = {\n discover_cubes: 'Discovering cubes',\n get_cube_metadata: 'Reading metadata',\n execute_query: 'Executing query',\n add_portlet: 'Adding visualization',\n add_markdown: 'Adding explanation',\n}\n\nfunction ToolCallIndicator({ toolCall }: { toolCall: ToolCallRecord }) {\n const [expanded, setExpanded] = useState(false)\n const label = TOOL_LABELS[toolCall.name] || toolCall.name\n const isRunning = toolCall.status === 'running'\n\n return (\n <div className=\"dc:my-1 dc:text-xs\">\n <button\n onClick={() => setExpanded(!expanded)}\n className=\"dc:flex dc:items-center dc:gap-1.5 text-dc-text-secondary dc:hover:opacity-80 dc:transition-opacity\"\n >\n {isRunning ? (\n <span className=\"dc:inline-block dc:w-3 dc:h-3 dc:border-2 border-dc-accent dc:border-t-transparent dc:rounded-full dc:animate-spin\" />\n ) : (\n <span className=\"dc:text-xs\">\n {toolCall.status === 'error' ? '\\u2717' : '\\u2713'}\n </span>\n )}\n <span>{label}{isRunning ? '...' : ''}</span>\n {!isRunning && (\n <span className=\"dc:text-[10px] dc:opacity-60\">\n {expanded ? '\\u25B2' : '\\u25BC'}\n </span>\n )}\n </button>\n {expanded && toolCall.result != null && (\n <pre className=\"dc:mt-1 dc:p-2 dc:rounded dc:text-[11px] dc:overflow-x-auto dc:max-h-32 dc:overflow-y-auto bg-dc-surface-secondary text-dc-text-secondary\">\n {typeof toolCall.result === 'string'\n ? toolCall.result\n : JSON.stringify(toolCall.result, null, 2)}\n </pre>\n )}\n </div>\n )\n}\n\nconst ChatMessage = React.memo(function ChatMessage({ message }: ChatMessageProps) {\n const isUser = message.role === 'user'\n const hasContent = !!message.content?.trim()\n const hasToolCalls = message.toolCalls && message.toolCalls.length > 0\n\n // Don't render empty assistant messages\n if (!isUser && !hasContent && !hasToolCalls) return null\n\n return (\n <div className={`dc:flex dc:mb-3 ${isUser ? 'dc:justify-end' : 'dc:justify-start'}`}>\n <div\n className={`dc:max-w-[85%] dc:rounded-lg dc:px-3 dc:py-2 dc:text-sm ${\n isUser\n ? 'bg-dc-accent text-dc-accent-text dc:rounded-br-sm'\n : 'bg-dc-surface-secondary text-dc-text dc:rounded-bl-sm'\n }`}\n >\n {/* Message text */}\n {hasContent && (\n <div className=\"dc:whitespace-pre-wrap dc:break-words\">\n {isUser ? message.content : renderInlineMarkdown(message.content)}\n </div>\n )}\n\n {/* Tool call indicators */}\n {hasToolCalls && (\n <div className={hasContent ? 'dc:mt-1 dc:border-t dc:border-current dc:border-opacity-10 dc:pt-1' : ''}>\n {message.toolCalls!.map((tc, i) => (\n <ToolCallIndicator key={tc.id || i} toolCall={tc} />\n ))}\n </div>\n )}\n </div>\n </div>\n )\n})\n\nexport default ChatMessage\n","/**\n * ChatInput - Text input for sending messages to the agent\n */\n\nimport React, { useCallback, useRef, useEffect } from 'react'\n\ninterface ChatInputProps {\n value: string\n onChange: (value: string) => void\n onSend: () => void\n onStop?: () => void\n onContinue?: () => void\n isStreaming?: boolean\n showContinue?: boolean\n disabled?: boolean\n placeholder?: string\n}\n\nconst ChatInput = React.memo(function ChatInput({\n value,\n onChange,\n onSend,\n onStop,\n onContinue,\n isStreaming = false,\n showContinue = false,\n disabled = false,\n placeholder = 'Ask about your data...',\n}: ChatInputProps) {\n const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n // Auto-resize textarea\n useEffect(() => {\n const textarea = textareaRef.current\n if (textarea) {\n textarea.style.height = 'auto'\n textarea.style.height = `${Math.min(textarea.scrollHeight, 150)}px`\n }\n }, [value])\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n if (e.key === 'Enter' && !e.shiftKey) {\n e.preventDefault()\n if (!disabled && value.trim()) {\n onSend()\n }\n }\n },\n [disabled, value, onSend]\n )\n\n return (\n <div className=\"dc:flex dc:gap-2 dc:items-end dc:p-3 border-dc-border dc:border-t\">\n <textarea\n ref={textareaRef}\n value={value}\n onChange={(e) => onChange(e.target.value)}\n onKeyDown={handleKeyDown}\n placeholder={placeholder}\n disabled={disabled}\n rows={1}\n className=\"dc:flex-1 dc:resize-none dc:rounded-lg dc:px-3 dc:py-2 dc:text-sm bg-dc-surface-secondary text-dc-text border-dc-border dc:border dc:outline-none dc:focus:ring-1 focus:ring-dc-accent dc:disabled:opacity-50\"\n />\n {isStreaming ? (\n <button\n onClick={onStop}\n className=\"dc:px-4 dc:py-2 dc:rounded-lg dc:text-sm dc:font-medium dc:transition-colors text-dc-error border-dc-border dc:border dc:hover:opacity-80 dc:shrink-0\"\n >\n Stop\n </button>\n ) : (\n <>\n {showContinue && !value.trim() && (\n <button\n onClick={() => {\n onContinue?.()\n textareaRef.current?.focus()\n }}\n className=\"dc:px-4 dc:py-2 dc:rounded-lg dc:text-sm dc:font-medium dc:transition-colors border-dc-border dc:border text-dc-text-secondary dc:hover:opacity-80 dc:shrink-0\"\n >\n Continue\n </button>\n )}\n <button\n onClick={onSend}\n disabled={disabled || !value.trim()}\n className=\"dc:px-4 dc:py-2 dc:rounded-lg dc:text-sm dc:font-medium dc:transition-colors bg-dc-accent text-dc-accent-text dc:hover:opacity-90 dc:disabled:opacity-40 dc:disabled:cursor-not-allowed dc:shrink-0\"\n >\n Send\n </button>\n </>\n )}\n </div>\n )\n})\n\nexport default ChatInput\n","/**\n * AgentChatPanel - Right panel containing chat messages and input\n */\n\nimport React, { useRef, useEffect, useCallback } from 'react'\nimport { useShallow } from 'zustand/react/shallow'\nimport { useNotebookStore, selectChatState, selectChatActions } from '../../stores/notebookStore'\nimport { useAgentChat } from '../../hooks/useAgentChat'\nimport type { PortletBlock, MarkdownBlock } from '../../stores/notebookStore'\nimport ChatMessage from './ChatMessage'\nimport ChatInput from './ChatInput'\n\ninterface AgentChatPanelProps {\n agentEndpoint?: string\n agentApiKey?: string\n onClear?: () => void\n}\n\nconst AgentChatPanel = React.memo(function AgentChatPanel({\n agentEndpoint,\n agentApiKey,\n onClear,\n}: AgentChatPanelProps) {\n const messagesEndRef = useRef<HTMLDivElement>(null)\n\n // Track whether the next content should start a new assistant message\n // (set after turn_complete, cleared when first content of new turn arrives)\n const needsNewMessageRef = useRef(false)\n\n // Store state\n const { messages, isStreaming, inputValue } = useNotebookStore(useShallow(selectChatState))\n const {\n addMessage,\n appendToLastAssistantMessage,\n addToolCallToLastAssistant,\n updateLastToolCall,\n setIsStreaming,\n setInputValue,\n setSessionId,\n } = useNotebookStore(useShallow(selectChatActions))\n\n const sessionId = useNotebookStore((s) => s.sessionId)\n const addBlock = useNotebookStore((s) => s.addBlock)\n const reset = useNotebookStore((s) => s.reset)\n\n // Lazily create a new assistant message when needed (between turns)\n const ensureNewMessage = useCallback(() => {\n if (needsNewMessageRef.current) {\n needsNewMessageRef.current = false\n addMessage({\n id: `msg-${Date.now()}`,\n role: 'assistant',\n content: '',\n toolCalls: [],\n timestamp: Date.now(),\n })\n }\n }, [addMessage])\n\n // Auto-scroll only when NEW messages arrive (not on initial load)\n const prevMsgCountRef = useRef(messages.length)\n useEffect(() => {\n if (messages.length > prevMsgCountRef.current) {\n messagesEndRef.current?.scrollIntoView({ behavior: 'smooth' })\n }\n prevMsgCountRef.current = messages.length\n }, [messages])\n\n // Agent chat hook\n const { sendMessage, abort } = useAgentChat({\n agentEndpoint,\n agentApiKey,\n onTextDelta: useCallback((text: string) => {\n ensureNewMessage()\n appendToLastAssistantMessage(text)\n }, [ensureNewMessage, appendToLastAssistantMessage]),\n onToolStart: useCallback((id: string, name: string, input?: unknown) => {\n ensureNewMessage()\n addToolCallToLastAssistant({ id, name, input, status: 'running' })\n }, [ensureNewMessage, addToolCallToLastAssistant]),\n onToolResult: useCallback((id: string, _name: string, result?: unknown) => {\n updateLastToolCall({ id, status: 'complete', result })\n }, [updateLastToolCall]),\n onAddPortlet: useCallback((data: PortletBlock) => {\n addBlock(data)\n }, [addBlock]),\n onAddMarkdown: useCallback((data: MarkdownBlock) => {\n addBlock(data)\n }, [addBlock]),\n onTurnComplete: useCallback(() => {\n // Don't create a new message yet — just flag that the next turn\n // should start a new bubble (created lazily by ensureNewMessage)\n needsNewMessageRef.current = true\n }, []),\n onDone: useCallback((sid: string) => {\n needsNewMessageRef.current = false\n setSessionId(sid)\n setIsStreaming(false)\n }, [setSessionId, setIsStreaming]),\n onError: useCallback((message: string) => {\n ensureNewMessage()\n appendToLastAssistantMessage(`\\n\\nError: ${message}`)\n setIsStreaming(false)\n }, [ensureNewMessage, appendToLastAssistantMessage, setIsStreaming]),\n })\n\n // Send a message (used by both Send and Continue)\n const doSend = useCallback((content: string) => {\n if (!content || isStreaming) return\n\n needsNewMessageRef.current = false\n\n // Add user message\n addMessage({\n id: `msg-${Date.now()}`,\n role: 'user',\n content,\n timestamp: Date.now(),\n })\n\n // Create empty assistant message for first turn's streaming\n addMessage({\n id: `msg-${Date.now() + 1}`,\n role: 'assistant',\n content: '',\n toolCalls: [],\n timestamp: Date.now(),\n })\n\n setInputValue('')\n setIsStreaming(true)\n\n // Send to agent\n sendMessage(content, sessionId)\n }, [isStreaming, addMessage, setInputValue, setIsStreaming, sendMessage, sessionId])\n\n const handleSend = useCallback(() => {\n doSend(inputValue.trim())\n }, [inputValue, doSend])\n\n const handleStop = useCallback(() => {\n abort()\n setIsStreaming(false)\n }, [abort, setIsStreaming])\n\n const handleContinue = useCallback(() => {\n // Just set placeholder text — user types their own follow-up and sends\n setInputValue('')\n }, [setInputValue])\n\n const handleClear = useCallback(() => {\n abort()\n setIsStreaming(false)\n reset()\n onClear?.()\n }, [abort, setIsStreaming, reset, onClear])\n\n return (\n <div className=\"dc:flex dc:flex-col dc:h-full bg-dc-surface\">\n {/* Header */}\n <div className=\"dc:flex dc:items-center dc:justify-between dc:px-4 dc:py-3 border-dc-border dc:border-b\">\n <h3 className=\"dc:text-sm dc:font-semibold text-dc-text\">AI Assistant</h3>\n {(messages.length > 0) && (\n <button\n onClick={handleClear}\n disabled={isStreaming}\n className=\"dc:text-xs dc:px-2 dc:py-1 dc:rounded text-dc-text-secondary dc:hover:opacity-80 dc:disabled:opacity-40\"\n title=\"Clear notebook and chat\"\n >\n Clear\n </button>\n )}\n </div>\n\n {/* Messages */}\n <div className=\"dc:flex-1 dc:overflow-y-auto dc:px-4 dc:py-3\">\n {messages.length === 0 ? (\n <EmptyState />\n ) : (\n messages.map((msg) => <ChatMessage key={msg.id} message={msg} />)\n )}\n <div ref={messagesEndRef} />\n </div>\n\n {/* Input */}\n <ChatInput\n value={inputValue}\n onChange={setInputValue}\n onSend={handleSend}\n onStop={handleStop}\n onContinue={handleContinue}\n isStreaming={isStreaming}\n showContinue={!isStreaming && messages.length > 0}\n />\n </div>\n )\n})\n\nfunction EmptyState() {\n return (\n <div className=\"dc:flex dc:items-center dc:justify-center dc:h-full\">\n <div className=\"dc:text-center dc:max-w-xs\">\n <div className=\"dc:text-lg dc:font-semibold text-dc-text dc:mb-2\">\n Data Analysis Assistant\n </div>\n <p className=\"dc:text-sm text-dc-text-secondary dc:mb-4\">\n Ask me about your data and I'll create visualizations and insights.\n </p>\n <div className=\"dc:space-y-2 dc:text-xs text-dc-text-muted\">\n <p>\"Show me employee productivity trends\"</p>\n <p>\"What are the top departments by headcount?\"</p>\n <p>\"Compare revenue across product categories\"</p>\n </div>\n </div>\n </div>\n )\n}\n\nexport default AgentChatPanel\n","/**\n * AgenticNotebook - AI-powered data analysis notebook\n *\n * Top-level component combining a notebook canvas (left) with a chat panel (right).\n * The AI agent discovers available data, executes queries, creates visualizations,\n * and explains findings within a single conversational flow.\n *\n * Requires:\n * - CubeProvider wrapping this component\n * - Server configured with `agent` option in HonoAdapterOptions\n * - @anthropic-ai/claude-agent-sdk installed on the server\n */\n\nimport React, { useCallback, useEffect, useRef, useState } from 'react'\nimport {\n NotebookStoreProvider,\n useNotebookStore,\n type NotebookConfig,\n} from '../../stores/notebookStore'\nimport NotebookCanvas from './NotebookCanvas'\nimport AgentChatPanel from './AgentChatPanel'\nimport type { ColorPalette } from '../../types'\n\nexport interface AgenticNotebookProps {\n /** Initial config to restore (saved notebooks) */\n config?: NotebookConfig\n /** Override default agent endpoint (default: apiUrl + '/agent/chat') */\n agentEndpoint?: string\n /** Client-side API key (for demo/try-site use) */\n agentApiKey?: string\n /** Callback when notebook state changes (for persistence) */\n onSave?: (config: NotebookConfig) => void | Promise<void>\n /** Callback when dirty state changes */\n onDirtyStateChange?: (isDirty: boolean) => void\n /** Color palette for charts */\n colorPalette?: ColorPalette\n /** Additional CSS class name */\n className?: string\n}\n\n/**\n * Inner component that uses the notebook store (must be inside provider)\n */\nfunction AgenticNotebookInner({\n agentEndpoint,\n agentApiKey,\n onSave,\n onDirtyStateChange,\n className,\n}: Omit<AgenticNotebookProps, 'config' | 'colorPalette'>) {\n const [dividerPosition, setDividerPosition] = useState(60) // 60% left, 40% right\n const containerRef = useRef<HTMLDivElement>(null)\n const isDraggingRef = useRef(false)\n\n const blockCount = useNotebookStore((s) => s.blocks.length)\n const messageCount = useNotebookStore((s) => s.messages.length)\n const save = useNotebookStore((s) => s.save)\n\n // Track dirty state\n const initialRef = useRef({ blockCount, msgCount: messageCount })\n useEffect(() => {\n const isDirty =\n blockCount !== initialRef.current.blockCount ||\n messageCount !== initialRef.current.msgCount\n onDirtyStateChange?.(isDirty)\n }, [blockCount, messageCount, onDirtyStateChange])\n\n // Debounced save - fires 1s after blocks/messages count stabilizes\n const saveTimeoutRef = useRef<ReturnType<typeof setTimeout>>()\n const onSaveRef = useRef(onSave)\n onSaveRef.current = onSave\n // Track whether we've ever had content (so we save empty state on Clear but not on initial mount)\n const hasHadContentRef = useRef(blockCount > 0 || messageCount > 0)\n useEffect(() => {\n if (blockCount > 0 || messageCount > 0) {\n hasHadContentRef.current = true\n }\n if (!onSaveRef.current || !hasHadContentRef.current) return\n\n if (saveTimeoutRef.current) clearTimeout(saveTimeoutRef.current)\n saveTimeoutRef.current = setTimeout(() => {\n const config = save()\n onSaveRef.current?.(config)\n }, 1000)\n\n return () => {\n if (saveTimeoutRef.current) clearTimeout(saveTimeoutRef.current)\n }\n }, [blockCount, messageCount, save])\n\n // Explicit clear handler — save immediately with empty state\n const handleClear = useCallback(() => {\n if (onSaveRef.current) {\n // Cancel any pending debounced save\n if (saveTimeoutRef.current) clearTimeout(saveTimeoutRef.current)\n onSaveRef.current({ blocks: [], messages: [] })\n }\n }, [])\n\n // Divider drag handlers\n const handleDividerMouseDown = useCallback((e: React.MouseEvent) => {\n e.preventDefault()\n isDraggingRef.current = true\n\n const handleMouseMove = (moveEvent: MouseEvent) => {\n if (!isDraggingRef.current || !containerRef.current) return\n const rect = containerRef.current.getBoundingClientRect()\n const newPos = ((moveEvent.clientX - rect.left) / rect.width) * 100\n setDividerPosition(Math.min(Math.max(newPos, 30), 80))\n }\n\n const handleMouseUp = () => {\n isDraggingRef.current = false\n document.removeEventListener('mousemove', handleMouseMove)\n document.removeEventListener('mouseup', handleMouseUp)\n }\n\n document.addEventListener('mousemove', handleMouseMove)\n document.addEventListener('mouseup', handleMouseUp)\n }, [])\n\n return (\n <div\n ref={containerRef}\n className={`dc:flex dc:h-full dc:w-full dc:overflow-hidden bg-dc-surface-secondary ${className || ''}`}\n >\n {/* Left: Notebook Canvas */}\n <div\n className=\"dc:h-full dc:overflow-hidden\"\n style={{ width: `${dividerPosition}%` }}\n >\n <NotebookCanvas />\n </div>\n\n {/* Resizable Divider */}\n <div\n className=\"dc:w-1 dc:h-full dc:cursor-col-resize dc:flex-shrink-0 dc:transition-colors bg-dc-border dc:hover:bg-dc-accent\"\n onMouseDown={handleDividerMouseDown}\n />\n\n {/* Right: Chat Panel */}\n <div\n className=\"dc:h-full dc:overflow-hidden\"\n style={{ width: `${100 - dividerPosition}%` }}\n >\n <AgentChatPanel\n agentEndpoint={agentEndpoint}\n agentApiKey={agentApiKey}\n onClear={handleClear}\n />\n </div>\n </div>\n )\n}\n\n/**\n * AgenticNotebook - AI-powered data analysis notebook\n *\n * @example\n * ```tsx\n * <CubeProvider apiOptions={{ apiUrl: '/api/cubejs-api/v1' }} token={token}>\n * <AgenticNotebook\n * agentApiKey=\"sk-...\"\n * onSave={(config) => saveToDatabase(config)}\n * />\n * </CubeProvider>\n * ```\n */\nconst AgenticNotebook = React.memo(function AgenticNotebook({\n config,\n ...props\n}: AgenticNotebookProps) {\n return (\n <NotebookStoreProvider initialConfig={config}>\n <AgenticNotebookInner {...props} />\n </NotebookStoreProvider>\n )\n})\n\nexport default AgenticNotebook\n","// Placeholder component - will be implemented in Phase 4\nexport function AnalyticsPage() {\n return <div>Analytics Page - Coming in Phase 4</div>\n}","/**\n * DashboardThumbnailPlaceholder\n *\n * A placeholder component shown when a dashboard thumbnail doesn't exist\n * but the thumbnail feature is enabled. Displays a simple grid icon\n * with \"No preview\" text.\n */\n\nimport { getIcon } from '../icons'\n\nconst GridIcon = getIcon('segment')\n\nexport interface DashboardThumbnailPlaceholderProps {\n /** Additional CSS classes */\n className?: string\n}\n\nexport function DashboardThumbnailPlaceholder({\n className = ''\n}: DashboardThumbnailPlaceholderProps) {\n return (\n <div\n className={`dc:flex dc:items-center dc:justify-center bg-dc-bg-secondary ${className}`}\n >\n <div className=\"dc:text-center\">\n <GridIcon\n className=\"dc:w-8 dc:h-8 dc:mx-auto dc:mb-2 text-dc-text-muted dc:opacity-50\"\n />\n <span className=\"dc:text-xs text-dc-text-muted\">No preview</span>\n </div>\n </div>\n )\n}\n\nexport default DashboardThumbnailPlaceholder\n"],"names":["createDefaultState","createStoreActions","set","get","block","state","id","b","direction","idx","newBlocks","swapIdx","message","text","messages","lastMsg","toolCall","update","toolCalls","tc","streaming","value","config","createNotebookStore","initialState","createStore","devtools","subscribeWithSelector","NotebookStoreContext","createContext","NotebookStoreProvider","children","initialConfig","storeRef","useRef","store","useNotebookStore","selector","useContext","useStore","selectBlocks","selectMessages","selectIsStreaming","selectSessionId","selectInputValue","selectChatState","selectChatActions","selectBlockActions","NotebookPortletBlock","React","onRemove","onMoveUp","onMoveDown","isFirst","isLast","jsxs","jsx","AnalyticsPortlet","markdownOptions","NotebookMarkdownBlock","Markdown","NotebookCanvas","blocks","removeBlock","moveBlock","useShallow","endRef","prevCountRef","useEffect","handleRemove","useCallback","handleMoveUp","handleMoveDown","index","useAgentChat","options","agentEndpoint","agentApiKey","onAddPortlet","onAddMarkdown","onTextDelta","onToolStart","onToolResult","onTurnComplete","onDone","onError","cubeApi","useCubeApi","abortControllerRef","isStreaming","setIsStreaming","useState","sendMessage","content","sessionId","handleEvent","event","controller","apiUrl","endpoint","headers","response","errorData","reader","decoder","buffer","done","events","eventStr","lines","line","error","abort","renderInlineMarkdown","nodes","remaining","key","codeMatch","before","code","after","boldMatch","bold","TOOL_LABELS","ToolCallIndicator","expanded","setExpanded","label","isRunning","ChatMessage","isUser","hasContent","hasToolCalls","i","ChatInput","onChange","onSend","onStop","onContinue","showContinue","disabled","placeholder","textareaRef","textarea","handleKeyDown","e","Fragment","AgentChatPanel","onClear","messagesEndRef","needsNewMessageRef","inputValue","addMessage","appendToLastAssistantMessage","addToolCallToLastAssistant","updateLastToolCall","setInputValue","setSessionId","s","addBlock","reset","ensureNewMessage","prevMsgCountRef","name","input","_name","result","data","sid","doSend","handleSend","handleStop","handleContinue","handleClear","EmptyState","msg","AgenticNotebookInner","onSave","onDirtyStateChange","className","dividerPosition","setDividerPosition","containerRef","isDraggingRef","blockCount","messageCount","save","initialRef","isDirty","saveTimeoutRef","onSaveRef","hasHadContentRef","handleDividerMouseDown","handleMouseMove","moveEvent","rect","newPos","handleMouseUp","AgenticNotebook","props","AnalyticsPage","GridIcon","getIcon","DashboardThumbnailPlaceholder"],"mappings":"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"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { StoreApi } from 'zustand';
|
|
3
|
+
import { ChartType, ChartAxisConfig, ChartDisplayConfig } from '../types';
|
|
4
|
+
/**
|
|
5
|
+
* A portlet block in the notebook
|
|
6
|
+
*/
|
|
7
|
+
export interface PortletBlock {
|
|
8
|
+
id: string;
|
|
9
|
+
type: 'portlet';
|
|
10
|
+
title: string;
|
|
11
|
+
query: string;
|
|
12
|
+
chartType: ChartType;
|
|
13
|
+
chartConfig?: ChartAxisConfig;
|
|
14
|
+
displayConfig?: ChartDisplayConfig;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* A markdown text block in the notebook
|
|
18
|
+
*/
|
|
19
|
+
export interface MarkdownBlock {
|
|
20
|
+
id: string;
|
|
21
|
+
type: 'markdown';
|
|
22
|
+
title?: string;
|
|
23
|
+
content: string;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* A block in the notebook canvas
|
|
27
|
+
*/
|
|
28
|
+
export type NotebookBlock = PortletBlock | MarkdownBlock;
|
|
29
|
+
/**
|
|
30
|
+
* A tool call record for display in chat messages
|
|
31
|
+
*/
|
|
32
|
+
export interface ToolCallRecord {
|
|
33
|
+
id: string;
|
|
34
|
+
name: string;
|
|
35
|
+
input?: unknown;
|
|
36
|
+
result?: unknown;
|
|
37
|
+
status: 'running' | 'complete' | 'error';
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* A chat message
|
|
41
|
+
*/
|
|
42
|
+
export interface ChatMessage {
|
|
43
|
+
id: string;
|
|
44
|
+
role: 'user' | 'assistant';
|
|
45
|
+
content: string;
|
|
46
|
+
toolCalls?: ToolCallRecord[];
|
|
47
|
+
timestamp: number;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Serializable notebook config for save/load
|
|
51
|
+
*/
|
|
52
|
+
export interface NotebookConfig {
|
|
53
|
+
blocks: NotebookBlock[];
|
|
54
|
+
messages: ChatMessage[];
|
|
55
|
+
}
|
|
56
|
+
export interface NotebookStoreState {
|
|
57
|
+
/** Ordered array of notebook blocks */
|
|
58
|
+
blocks: NotebookBlock[];
|
|
59
|
+
/** Chat message history */
|
|
60
|
+
messages: ChatMessage[];
|
|
61
|
+
/** Whether the agent is currently streaming a response */
|
|
62
|
+
isStreaming: boolean;
|
|
63
|
+
/** Agent SDK session ID for multi-turn conversations */
|
|
64
|
+
sessionId: string | null;
|
|
65
|
+
/** Chat input value */
|
|
66
|
+
inputValue: string;
|
|
67
|
+
}
|
|
68
|
+
export interface NotebookStoreActions {
|
|
69
|
+
addBlock: (block: NotebookBlock) => void;
|
|
70
|
+
removeBlock: (id: string) => void;
|
|
71
|
+
moveBlock: (id: string, direction: 'up' | 'down') => void;
|
|
72
|
+
addMessage: (message: ChatMessage) => void;
|
|
73
|
+
appendToLastAssistantMessage: (text: string) => void;
|
|
74
|
+
addToolCallToLastAssistant: (toolCall: ToolCallRecord) => void;
|
|
75
|
+
updateLastToolCall: (update: Partial<ToolCallRecord>) => void;
|
|
76
|
+
setIsStreaming: (streaming: boolean) => void;
|
|
77
|
+
setSessionId: (id: string | null) => void;
|
|
78
|
+
setInputValue: (value: string) => void;
|
|
79
|
+
save: () => NotebookConfig;
|
|
80
|
+
load: (config: NotebookConfig) => void;
|
|
81
|
+
reset: () => void;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Combined store type
|
|
85
|
+
*/
|
|
86
|
+
export type NotebookStore = NotebookStoreState & NotebookStoreActions;
|
|
87
|
+
/**
|
|
88
|
+
* Create a new notebook store instance
|
|
89
|
+
*/
|
|
90
|
+
export declare function createNotebookStore(): Omit<Omit<StoreApi<NotebookStore>, "setState" | "devtools"> & {
|
|
91
|
+
setState(partial: NotebookStore | Partial<NotebookStore> | ((state: NotebookStore) => NotebookStore | Partial<NotebookStore>), replace?: false | undefined, action?: (string | {
|
|
92
|
+
[x: string]: unknown;
|
|
93
|
+
[x: number]: unknown;
|
|
94
|
+
[x: symbol]: unknown;
|
|
95
|
+
type: string;
|
|
96
|
+
}) | undefined): void;
|
|
97
|
+
setState(state: NotebookStore | ((state: NotebookStore) => NotebookStore), replace: true, action?: (string | {
|
|
98
|
+
[x: string]: unknown;
|
|
99
|
+
[x: number]: unknown;
|
|
100
|
+
[x: symbol]: unknown;
|
|
101
|
+
type: string;
|
|
102
|
+
}) | undefined): void;
|
|
103
|
+
devtools: {
|
|
104
|
+
cleanup: () => void;
|
|
105
|
+
};
|
|
106
|
+
}, "subscribe"> & {
|
|
107
|
+
subscribe: {
|
|
108
|
+
(listener: (selectedState: NotebookStore, previousSelectedState: NotebookStore) => void): () => void;
|
|
109
|
+
<U>(selector: (state: NotebookStore) => U, listener: (selectedState: U, previousSelectedState: U) => void, options?: {
|
|
110
|
+
equalityFn?: ((a: U, b: U) => boolean) | undefined;
|
|
111
|
+
fireImmediately?: boolean;
|
|
112
|
+
} | undefined): () => void;
|
|
113
|
+
};
|
|
114
|
+
};
|
|
115
|
+
export interface NotebookStoreProviderProps {
|
|
116
|
+
children: ReactNode;
|
|
117
|
+
/** Initial config to load */
|
|
118
|
+
initialConfig?: NotebookConfig;
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Provider component that creates a store instance per AgenticNotebook
|
|
122
|
+
*/
|
|
123
|
+
export declare function NotebookStoreProvider({ children, initialConfig, }: NotebookStoreProviderProps): import("react/jsx-runtime").JSX.Element;
|
|
124
|
+
/**
|
|
125
|
+
* Hook to access the notebook store from context
|
|
126
|
+
* @throws Error if used outside of provider
|
|
127
|
+
*/
|
|
128
|
+
export declare function useNotebookStore<T>(selector: (state: NotebookStore) => T): T;
|
|
129
|
+
export declare const selectBlocks: (state: NotebookStore) => NotebookBlock[];
|
|
130
|
+
export declare const selectMessages: (state: NotebookStore) => ChatMessage[];
|
|
131
|
+
export declare const selectIsStreaming: (state: NotebookStore) => boolean;
|
|
132
|
+
export declare const selectSessionId: (state: NotebookStore) => string | null;
|
|
133
|
+
export declare const selectInputValue: (state: NotebookStore) => string;
|
|
134
|
+
export declare const selectChatState: (state: NotebookStore) => {
|
|
135
|
+
messages: ChatMessage[];
|
|
136
|
+
isStreaming: boolean;
|
|
137
|
+
inputValue: string;
|
|
138
|
+
};
|
|
139
|
+
export declare const selectChatActions: (state: NotebookStore) => {
|
|
140
|
+
addMessage: (message: ChatMessage) => void;
|
|
141
|
+
appendToLastAssistantMessage: (text: string) => void;
|
|
142
|
+
addToolCallToLastAssistant: (toolCall: ToolCallRecord) => void;
|
|
143
|
+
updateLastToolCall: (update: Partial<ToolCallRecord>) => void;
|
|
144
|
+
setIsStreaming: (streaming: boolean) => void;
|
|
145
|
+
setInputValue: (value: string) => void;
|
|
146
|
+
setSessionId: (id: string | null) => void;
|
|
147
|
+
};
|
|
148
|
+
export declare const selectBlockActions: (state: NotebookStore) => {
|
|
149
|
+
addBlock: (block: NotebookBlock) => void;
|
|
150
|
+
removeBlock: (id: string) => void;
|
|
151
|
+
moveBlock: (id: string, direction: "up" | "down") => void;
|
|
152
|
+
};
|
package/dist/client/styles.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
.hljs{display:block;overflow-x:auto;color:var(--dc-text);background:transparent}.hljs-keyword,.hljs-selector-tag,.hljs-operator{color:var(--dc-primary);font-weight:600}.hljs-number,.hljs-literal,.hljs-boolean{color:var(--dc-warning)}.hljs-title,.hljs-function{color:var(--dc-accent);font-weight:600}.hljs-built_in,.hljs-type{color:var(--dc-info)}.hljs-variable,.hljs-property{color:var(--dc-text)}.hljs-meta{color:var(--dc-text-muted)}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.language-json .hljs-attr{color:var(--dc-primary)}.language-json .hljs-string{color:var(--dc-success)}.language-json .hljs-number{color:var(--dc-warning)}.language-json .hljs-literal{color:var(--dc-accent);font-weight:600}.language-sql .hljs-keyword{color:var(--dc-primary);font-weight:700;text-transform:uppercase}.language-sql .hljs-string{color:var(--dc-success)}.language-sql .hljs-number{color:var(--dc-warning)}.language-sql .hljs-comment{color:var(--dc-text-muted);font-style:italic}.language-sql .hljs-function{color:var(--dc-accent);font-weight:600}@media(prefers-color-scheme:dark){.hljs-string{color:#7ee787}.hljs-number,.hljs-literal{color:#f0883e}}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-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-space-x-reverse:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-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{:root,:host{--dc-font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--dc-color-black:#000;--dc-color-white:#fff;--dc-spacing:.25rem;--dc-container-sm:24rem;--dc-container-md:28rem;--dc-container-lg:32rem;--dc-container-2xl:42rem;--dc-container-4xl:56rem;--dc-container-5xl:64rem;--dc-container-6xl:72rem;--dc-container-7xl:80rem;--dc-text-xs:.75rem;--dc-text-xs--line-height:calc(1 / .75);--dc-text-sm:.875rem;--dc-text-sm--line-height:calc(1.25 / .875);--dc-text-base:1rem;--dc-text-base--line-height: 1.5 ;--dc-text-lg:1.125rem;--dc-text-lg--line-height:calc(1.75 / 1.125);--dc-text-xl:1.25rem;--dc-text-xl--line-height:calc(1.75 / 1.25);--dc-text-2xl:1.5rem;--dc-text-2xl--line-height:calc(2 / 1.5);--dc-text-3xl:1.875rem;--dc-text-3xl--line-height: 1.2 ;--dc-text-4xl:2.25rem;--dc-text-4xl--line-height:calc(2.5 / 2.25);--dc-text-5xl:3rem;--dc-text-5xl--line-height:1;--dc-font-weight-normal:400;--dc-font-weight-medium:500;--dc-font-weight-semibold:600;--dc-font-weight-bold:700;--dc-tracking-normal:0em;--dc-tracking-wide:.025em;--dc-tracking-wider:.05em;--dc-leading-tight:1.25;--dc-leading-relaxed:1.625;--dc-radius-sm:.25rem;--dc-radius-md:.375rem;--dc-radius-lg:.5rem;--dc-shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--dc-shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--dc-shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--dc-shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--dc-shadow-2xl:0 25px 50px -12px #00000040;--dc-drop-shadow-sm:0 1px 2px #00000026;--dc-ease-out:cubic-bezier(0, 0, .2, 1);--dc-ease-in-out:cubic-bezier(.4, 0, .2, 1);--dc-animate-spin:spin 1s linear infinite;--dc-animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--dc-blur-md:12px;--dc-default-transition-duration:.15s;--dc-default-transition-timing-function:cubic-bezier(.4, 0, .2, 1)}}@layer base,components;@layer utilities{.dc\:pointer-events-none{pointer-events:none}.dc\:sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.dc\:absolute{position:absolute}.dc\:fixed{position:fixed}.dc\:relative{position:relative}.dc\:sticky{position:sticky}.dc\:inset-0{inset:calc(var(--dc-spacing) * 0)}.dc\:-top-0\.5{top:calc(var(--dc-spacing) * -.5)}.dc\:-top-1{top:calc(var(--dc-spacing) * -1)}.dc\:-top-5{top:calc(var(--dc-spacing) * -5)}.dc\:top-0{top:calc(var(--dc-spacing) * 0)}.dc\:top-0\.5{top:calc(var(--dc-spacing) * .5)}.dc\:top-1{top:calc(var(--dc-spacing) * 1)}.dc\:top-1\/2{top:50%}.dc\:top-full{top:100%}.dc\:-right-0\.5{right:calc(var(--dc-spacing) * -.5)}.dc\:right-0{right:calc(var(--dc-spacing) * 0)}.dc\:right-0\.5{right:calc(var(--dc-spacing) * .5)}.dc\:right-1{right:calc(var(--dc-spacing) * 1)}.dc\:right-4{right:calc(var(--dc-spacing) * 4)}.dc\:right-full{right:100%}.dc\:bottom-0{bottom:calc(var(--dc-spacing) * 0)}.dc\:left-0{left:calc(var(--dc-spacing) * 0)}.dc\:left-2{left:calc(var(--dc-spacing) * 2)}.dc\:left-4{left:calc(var(--dc-spacing) * 4)}.dc\:left-full{left:100%}.dc\:z-10{z-index:10}.dc\:z-20{z-index:20}.dc\:z-30{z-index:30}.dc\:z-40{z-index:40}.dc\:z-50{z-index:50}.dc\:z-\[60\]{z-index:60}.dc\:float-right{float:right}.dc\:m-0{margin:calc(var(--dc-spacing) * 0)}.dc\:-mx-2{margin-inline:calc(var(--dc-spacing) * -2)}.dc\:mx-1{margin-inline:calc(var(--dc-spacing) * 1)}.dc\:mx-4{margin-inline:calc(var(--dc-spacing) * 4)}.dc\:mx-auto{margin-inline:auto}.dc\:my-0\.5{margin-block:calc(var(--dc-spacing) * .5)}.dc\:my-4{margin-block:calc(var(--dc-spacing) * 4)}.dc\:mt-0\.5{margin-top:calc(var(--dc-spacing) * .5)}.dc\:mt-1{margin-top:calc(var(--dc-spacing) * 1)}.dc\:mt-2{margin-top:calc(var(--dc-spacing) * 2)}.dc\:mt-3{margin-top:calc(var(--dc-spacing) * 3)}.dc\:mt-4{margin-top:calc(var(--dc-spacing) * 4)}.dc\:mt-6{margin-top:calc(var(--dc-spacing) * 6)}.dc\:-mr-2{margin-right:calc(var(--dc-spacing) * -2)}.dc\:mr-0\.5{margin-right:calc(var(--dc-spacing) * .5)}.dc\:mr-1{margin-right:calc(var(--dc-spacing) * 1)}.dc\:mr-1\.5{margin-right:calc(var(--dc-spacing) * 1.5)}.dc\:mr-2{margin-right:calc(var(--dc-spacing) * 2)}.dc\:mr-3{margin-right:calc(var(--dc-spacing) * 3)}.dc\:mb-0{margin-bottom:calc(var(--dc-spacing) * 0)}.dc\:mb-1{margin-bottom:calc(var(--dc-spacing) * 1)}.dc\:mb-1\.5{margin-bottom:calc(var(--dc-spacing) * 1.5)}.dc\:mb-2{margin-bottom:calc(var(--dc-spacing) * 2)}.dc\:mb-3{margin-bottom:calc(var(--dc-spacing) * 3)}.dc\:mb-4{margin-bottom:calc(var(--dc-spacing) * 4)}.dc\:mb-16{margin-bottom:calc(var(--dc-spacing) * 16)}.dc\:-ml-2{margin-left:calc(var(--dc-spacing) * -2)}.dc\:ml-0\.5{margin-left:calc(var(--dc-spacing) * .5)}.dc\:ml-1{margin-left:calc(var(--dc-spacing) * 1)}.dc\:ml-1\.5{margin-left:calc(var(--dc-spacing) * 1.5)}.dc\:ml-2{margin-left:calc(var(--dc-spacing) * 2)}.dc\:ml-4{margin-left:calc(var(--dc-spacing) * 4)}.dc\:ml-auto{margin-left:auto}.dc\:block{display:block}.dc\:flex{display:flex}.dc\:grid{display:grid}.dc\:hidden{display:none}.dc\:inline-block{display:inline-block}.dc\:inline-flex{display:inline-flex}.dc\:h-0\.5{height:calc(var(--dc-spacing) * .5)}.dc\:h-1\.5{height:calc(var(--dc-spacing) * 1.5)}.dc\:h-2{height:calc(var(--dc-spacing) * 2)}.dc\:h-2\.5{height:calc(var(--dc-spacing) * 2.5)}.dc\:h-3{height:calc(var(--dc-spacing) * 3)}.dc\:h-3\.5{height:calc(var(--dc-spacing) * 3.5)}.dc\:h-4{height:calc(var(--dc-spacing) * 4)}.dc\:h-5{height:calc(var(--dc-spacing) * 5)}.dc\:h-6{height:calc(var(--dc-spacing) * 6)}.dc\:h-8{height:calc(var(--dc-spacing) * 8)}.dc\:h-10{height:calc(var(--dc-spacing) * 10)}.dc\:h-12{height:calc(var(--dc-spacing) * 12)}.dc\:h-64{height:calc(var(--dc-spacing) * 64)}.dc\:h-\[60vh\]{height:60vh}.dc\:h-\[90vh\]{height:90vh}.dc\:h-full{height:100%}.dc\:h-px{height:1px}.dc\:max-h-20{max-height:calc(var(--dc-spacing) * 20)}.dc\:max-h-32{max-height:calc(var(--dc-spacing) * 32)}.dc\:max-h-40{max-height:calc(var(--dc-spacing) * 40)}.dc\:max-h-48{max-height:calc(var(--dc-spacing) * 48)}.dc\:max-h-56{max-height:calc(var(--dc-spacing) * 56)}.dc\:max-h-60{max-height:calc(var(--dc-spacing) * 60)}.dc\:max-h-64{max-height:calc(var(--dc-spacing) * 64)}.dc\:max-h-72{max-height:calc(var(--dc-spacing) * 72)}.dc\:max-h-80{max-height:calc(var(--dc-spacing) * 80)}.dc\:max-h-\[40\%\]{max-height:40%}.dc\:max-h-\[80vh\]{max-height:80vh}.dc\:max-h-\[85vh\]{max-height:85vh}.dc\:max-h-\[90vh\]{max-height:90vh}.dc\:min-h-0{min-height:calc(var(--dc-spacing) * 0)}.dc\:min-h-10{min-height:calc(var(--dc-spacing) * 10)}.dc\:min-h-12{min-height:calc(var(--dc-spacing) * 12)}.dc\:min-h-16{min-height:calc(var(--dc-spacing) * 16)}.dc\:min-h-\[30px\]{min-height:30px}.dc\:min-h-\[48px\]{min-height:48px}.dc\:min-h-\[50vh\]{min-height:50vh}.dc\:min-h-\[100px\]{min-height:100px}.dc\:min-h-\[200px\]{min-height:200px}.dc\:min-h-\[400px\]{min-height:400px}.dc\:w-1\.5{width:calc(var(--dc-spacing) * 1.5)}.dc\:w-2{width:calc(var(--dc-spacing) * 2)}.dc\:w-2\.5{width:calc(var(--dc-spacing) * 2.5)}.dc\:w-3{width:calc(var(--dc-spacing) * 3)}.dc\:w-3\.5{width:calc(var(--dc-spacing) * 3.5)}.dc\:w-4{width:calc(var(--dc-spacing) * 4)}.dc\:w-5{width:calc(var(--dc-spacing) * 5)}.dc\:w-6{width:calc(var(--dc-spacing) * 6)}.dc\:w-8{width:calc(var(--dc-spacing) * 8)}.dc\:w-10{width:calc(var(--dc-spacing) * 10)}.dc\:w-12{width:calc(var(--dc-spacing) * 12)}.dc\:w-16{width:calc(var(--dc-spacing) * 16)}.dc\:w-20{width:calc(var(--dc-spacing) * 20)}.dc\:w-24{width:calc(var(--dc-spacing) * 24)}.dc\:w-28{width:calc(var(--dc-spacing) * 28)}.dc\:w-36{width:calc(var(--dc-spacing) * 36)}.dc\:w-48{width:calc(var(--dc-spacing) * 48)}.dc\:w-52{width:calc(var(--dc-spacing) * 52)}.dc\:w-72{width:calc(var(--dc-spacing) * 72)}.dc\:w-\[90vw\]{width:90vw}.dc\:w-\[180px\]{width:180px}.dc\:w-\[280px\]{width:280px}.dc\:w-full{width:100%}.dc\:w-px{width:1px}.dc\:max-w-2xl{max-width:var(--dc-container-2xl)}.dc\:max-w-4xl{max-width:var(--dc-container-4xl)}.dc\:max-w-5xl{max-width:var(--dc-container-5xl)}.dc\:max-w-6xl{max-width:var(--dc-container-6xl)}.dc\:max-w-7xl{max-width:var(--dc-container-7xl)}.dc\:max-w-32{max-width:calc(var(--dc-spacing) * 32)}.dc\:max-w-\[100px\]{max-width:100px}.dc\:max-w-\[150px\]{max-width:150px}.dc\:max-w-\[200px\]{max-width:200px}.dc\:max-w-\[280px\]{max-width:280px}.dc\:max-w-\[1400px\]{max-width:1400px}.dc\:max-w-full{max-width:100%}.dc\:max-w-lg{max-width:var(--dc-container-lg)}.dc\:max-w-md{max-width:var(--dc-container-md)}.dc\:max-w-none{max-width:none}.dc\:max-w-sm{max-width:var(--dc-container-sm)}.dc\:min-w-0{min-width:calc(var(--dc-spacing) * 0)}.dc\:min-w-\[60px\]{min-width:60px}.dc\:min-w-\[70px\]{min-width:70px}.dc\:min-w-\[80px\]{min-width:80px}.dc\:min-w-\[100px\]{min-width:100px}.dc\:min-w-\[120px\]{min-width:120px}.dc\:min-w-\[180px\]{min-width:180px}.dc\:min-w-\[200px\]{min-width:200px}.dc\:min-w-\[220px\]{min-width:220px}.dc\:min-w-\[280px\]{min-width:280px}.dc\:min-w-full{min-width:100%}.dc\:min-w-max{min-width:max-content}.dc\:flex-1{flex:1}.dc\:flex-shrink-0,.dc\:shrink-0{flex-shrink:0}.dc\:border-collapse{border-collapse:collapse}.dc\:-translate-x-16{--tw-translate-x:calc(var(--dc-spacing) * -16);translate:var(--tw-translate-x) var(--tw-translate-y)}.dc\:translate-x-0{--tw-translate-x:calc(var(--dc-spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.dc\:translate-x-16{--tw-translate-x:calc(var(--dc-spacing) * 16);translate:var(--tw-translate-x) var(--tw-translate-y)}.dc\:-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.dc\:scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}.dc\:rotate-180{rotate:180deg}.dc\:transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.dc\:animate-pulse{animation:var(--dc-animate-pulse)}.dc\:animate-spin{animation:var(--dc-animate-spin)}.dc\:cursor-default{cursor:default}.dc\:cursor-grab{cursor:grab}.dc\:cursor-grabbing{cursor:grabbing}.dc\:cursor-help{cursor:help}.dc\:cursor-move{cursor:move}.dc\:cursor-not-allowed{cursor:not-allowed}.dc\:cursor-pointer{cursor:pointer}.dc\:cursor-wait{cursor:wait}.dc\:resize-none{resize:none}.dc\:resize-y{resize:vertical}.dc\:list-inside{list-style-position:inside}.dc\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.dc\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dc\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.dc\:flex-col{flex-direction:column}.dc\:flex-wrap{flex-wrap:wrap}.dc\:items-center{align-items:center}.dc\:items-end{align-items:flex-end}.dc\:items-start{align-items:flex-start}.dc\:justify-between{justify-content:space-between}.dc\:justify-center{justify-content:center}.dc\:justify-end{justify-content:flex-end}.dc\:justify-start{justify-content:flex-start}.dc\:gap-0\.5{gap:calc(var(--dc-spacing) * .5)}.dc\:gap-1{gap:calc(var(--dc-spacing) * 1)}.dc\:gap-1\.5{gap:calc(var(--dc-spacing) * 1.5)}.dc\:gap-2{gap:calc(var(--dc-spacing) * 2)}.dc\:gap-3{gap:calc(var(--dc-spacing) * 3)}.dc\:gap-4{gap:calc(var(--dc-spacing) * 4)}.dc\:gap-6{gap:calc(var(--dc-spacing) * 6)}:where(.dc\:space-y-0\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * .5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * .5) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-x-0\.5>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * .5) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * .5) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-1>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 1) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 1) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-1\.5>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 1.5) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 1.5) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 2) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-3>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 3) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 3) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-4>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 4) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 4) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}.dc\:truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dc\:overflow-auto{overflow:auto}.dc\:overflow-hidden{overflow:hidden}.dc\:overflow-visible{overflow:visible}.dc\:overflow-x-auto{overflow-x:auto}.dc\:overflow-y-auto{overflow-y:auto}.dc\:rounded{border-radius:.25rem}.dc\:rounded-full{border-radius:3.40282e38px}.dc\:rounded-lg{border-radius:var(--dc-radius-lg)}.dc\:rounded-md{border-radius:var(--dc-radius-md)}.dc\:rounded-none{border-radius:0}.dc\:rounded-sm{border-radius:var(--dc-radius-sm)}.dc\:rounded-t-lg{border-top-left-radius:var(--dc-radius-lg);border-top-right-radius:var(--dc-radius-lg)}.dc\:rounded-t-sm{border-top-left-radius:var(--dc-radius-sm);border-top-right-radius:var(--dc-radius-sm)}.dc\:rounded-b-lg{border-bottom-right-radius:var(--dc-radius-lg);border-bottom-left-radius:var(--dc-radius-lg)}.dc\:border{border-style:var(--tw-border-style);border-width:1px}.dc\:border-2{border-style:var(--tw-border-style);border-width:2px}.dc\:border-x{border-inline-style:var(--tw-border-style);border-inline-width:1px}.dc\:border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.dc\:border-t-2{border-top-style:var(--tw-border-style);border-top-width:2px}.dc\:border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.dc\:border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.dc\:border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.dc\:border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.dc\:border-dashed{--tw-border-style:dashed;border-style:dashed}.dc\:border-none{--tw-border-style:none;border-style:none}.dc\:border-solid{--tw-border-style:solid;border-style:solid}.dc\:bg-black\/50{background-color:var(--dc-color-black)}@supports (color:color-mix(in lab,red,red)){.dc\:bg-black\/50{background-color:color-mix(in oklab,var(--dc-color-black) 50%,transparent)}}.dc\:p-0\.5{padding:calc(var(--dc-spacing) * .5)}.dc\:p-1{padding:calc(var(--dc-spacing) * 1)}.dc\:p-1\.5{padding:calc(var(--dc-spacing) * 1.5)}.dc\:p-2{padding:calc(var(--dc-spacing) * 2)}.dc\:p-3{padding:calc(var(--dc-spacing) * 3)}.dc\:p-4{padding:calc(var(--dc-spacing) * 4)}.dc\:p-6{padding:calc(var(--dc-spacing) * 6)}.dc\:px-1{padding-inline:calc(var(--dc-spacing) * 1)}.dc\:px-1\.5{padding-inline:calc(var(--dc-spacing) * 1.5)}.dc\:px-2{padding-inline:calc(var(--dc-spacing) * 2)}.dc\:px-2\.5{padding-inline:calc(var(--dc-spacing) * 2.5)}.dc\:px-3{padding-inline:calc(var(--dc-spacing) * 3)}.dc\:px-4{padding-inline:calc(var(--dc-spacing) * 4)}.dc\:px-6{padding-inline:calc(var(--dc-spacing) * 6)}.dc\:py-0\.5{padding-block:calc(var(--dc-spacing) * .5)}.dc\:py-1{padding-block:calc(var(--dc-spacing) * 1)}.dc\:py-1\.5{padding-block:calc(var(--dc-spacing) * 1.5)}.dc\:py-2{padding-block:calc(var(--dc-spacing) * 2)}.dc\:py-2\.5{padding-block:calc(var(--dc-spacing) * 2.5)}.dc\:py-3{padding-block:calc(var(--dc-spacing) * 3)}.dc\:py-4{padding-block:calc(var(--dc-spacing) * 4)}.dc\:py-6{padding-block:calc(var(--dc-spacing) * 6)}.dc\:py-8{padding-block:calc(var(--dc-spacing) * 8)}.dc\:py-12{padding-block:calc(var(--dc-spacing) * 12)}.dc\:pt-1{padding-top:calc(var(--dc-spacing) * 1)}.dc\:pt-2{padding-top:calc(var(--dc-spacing) * 2)}.dc\:pt-3{padding-top:calc(var(--dc-spacing) * 3)}.dc\:pt-4{padding-top:calc(var(--dc-spacing) * 4)}.dc\:pt-6{padding-top:calc(var(--dc-spacing) * 6)}.dc\:pr-1{padding-right:calc(var(--dc-spacing) * 1)}.dc\:pr-3{padding-right:calc(var(--dc-spacing) * 3)}.dc\:pb-1{padding-bottom:calc(var(--dc-spacing) * 1)}.dc\:pb-2{padding-bottom:calc(var(--dc-spacing) * 2)}.dc\:pb-3{padding-bottom:calc(var(--dc-spacing) * 3)}.dc\:pb-4{padding-bottom:calc(var(--dc-spacing) * 4)}.dc\:pb-24{padding-bottom:calc(var(--dc-spacing) * 24)}.dc\:pl-2{padding-left:calc(var(--dc-spacing) * 2)}.dc\:pl-8{padding-left:calc(var(--dc-spacing) * 8)}.dc\:text-center{text-align:center}.dc\:text-left{text-align:left}.dc\:text-right{text-align:right}.dc\:align-top{vertical-align:top}.dc\:font-mono{font-family:var(--dc-font-mono)}.dc\:text-2xl{font-size:var(--dc-text-2xl);line-height:var(--tw-leading,var(--dc-text-2xl--line-height))}.dc\:text-3xl{font-size:var(--dc-text-3xl);line-height:var(--tw-leading,var(--dc-text-3xl--line-height))}.dc\:text-4xl{font-size:var(--dc-text-4xl);line-height:var(--tw-leading,var(--dc-text-4xl--line-height))}.dc\:text-5xl{font-size:var(--dc-text-5xl);line-height:var(--tw-leading,var(--dc-text-5xl--line-height))}.dc\:text-base{font-size:var(--dc-text-base);line-height:var(--tw-leading,var(--dc-text-base--line-height))}.dc\:text-lg{font-size:var(--dc-text-lg);line-height:var(--tw-leading,var(--dc-text-lg--line-height))}.dc\:text-sm{font-size:var(--dc-text-sm);line-height:var(--tw-leading,var(--dc-text-sm--line-height))}.dc\:text-xl{font-size:var(--dc-text-xl);line-height:var(--tw-leading,var(--dc-text-xl--line-height))}.dc\:text-xs{font-size:var(--dc-text-xs);line-height:var(--tw-leading,var(--dc-text-xs--line-height))}.dc\:text-\[10px\]{font-size:10px}.dc\:leading-none{--tw-leading:1;line-height:1}.dc\:leading-relaxed{--tw-leading:var(--dc-leading-relaxed);line-height:var(--dc-leading-relaxed)}.dc\:leading-tight{--tw-leading:var(--dc-leading-tight);line-height:var(--dc-leading-tight)}.dc\:font-bold{--tw-font-weight:var(--dc-font-weight-bold);font-weight:var(--dc-font-weight-bold)}.dc\:font-medium{--tw-font-weight:var(--dc-font-weight-medium);font-weight:var(--dc-font-weight-medium)}.dc\:font-normal{--tw-font-weight:var(--dc-font-weight-normal);font-weight:var(--dc-font-weight-normal)}.dc\:font-semibold{--tw-font-weight:var(--dc-font-weight-semibold);font-weight:var(--dc-font-weight-semibold)}.dc\:tracking-normal{--tw-tracking:var(--dc-tracking-normal);letter-spacing:var(--dc-tracking-normal)}.dc\:tracking-wide{--tw-tracking:var(--dc-tracking-wide);letter-spacing:var(--dc-tracking-wide)}.dc\:tracking-wider{--tw-tracking:var(--dc-tracking-wider);letter-spacing:var(--dc-tracking-wider)}.dc\:break-words{overflow-wrap:break-word}.dc\:whitespace-nowrap{white-space:nowrap}.dc\:whitespace-pre-wrap{white-space:pre-wrap}.dc\:text-white{color:var(--dc-color-white)}.dc\:capitalize{text-transform:capitalize}.dc\:normal-case{text-transform:none}.dc\:uppercase{text-transform:uppercase}.dc\:italic{font-style:italic}.dc\:underline{text-decoration-line:underline}.dc\:opacity-0{opacity:0}.dc\:opacity-25{opacity:.25}.dc\:opacity-30{opacity:.3}.dc\:opacity-40{opacity:.4}.dc\:opacity-50{opacity:.5}.dc\:opacity-70{opacity:.7}.dc\:opacity-75{opacity:.75}.dc\:opacity-80{opacity:.8}.dc\:opacity-90{opacity:.9}.dc\:opacity-100{opacity:1}.dc\:shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\:shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\:shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\:ring-1{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\: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)}.dc\:ring-offset-1{--tw-ring-offset-width:1px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.dc\:drop-shadow-sm{--tw-drop-shadow-size:drop-shadow(0 1px 2px var(--tw-drop-shadow-color,#00000026));--tw-drop-shadow:drop-shadow(var(--dc-drop-shadow-sm));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,)}.dc\:backdrop-blur-md{--tw-backdrop-blur:blur(var(--dc-blur-md));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.dc\:transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--dc-default-transition-timing-function));transition-duration:var(--tw-duration,var(--dc-default-transition-duration))}.dc\:transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--dc-default-transition-timing-function));transition-duration:var(--tw-duration,var(--dc-default-transition-duration))}.dc\:transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--dc-default-transition-timing-function));transition-duration:var(--tw-duration,var(--dc-default-transition-duration))}.dc\:transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--dc-default-transition-timing-function));transition-duration:var(--tw-duration,var(--dc-default-transition-duration))}.dc\:duration-150{--tw-duration:.15s;transition-duration:.15s}.dc\:duration-200{--tw-duration:.2s;transition-duration:.2s}.dc\:duration-300{--tw-duration:.3s;transition-duration:.3s}.dc\:ease-in-out{--tw-ease:var(--dc-ease-in-out);transition-timing-function:var(--dc-ease-in-out)}.dc\:ease-out{--tw-ease:var(--dc-ease-out);transition-timing-function:var(--dc-ease-out)}.dc\:outline-none{--tw-outline-style:none;outline-style:none}@media(hover:hover){.dc\:group-hover\:opacity-100:is(:where(.dc\:group):hover *){opacity:1}}.dc\:first\:rounded-l-sm:first-child{border-top-left-radius:var(--dc-radius-sm);border-bottom-left-radius:var(--dc-radius-sm)}.dc\:last\:mb-0:last-child{margin-bottom:calc(var(--dc-spacing) * 0)}.dc\:last\:rounded-r-sm:last-child{border-top-right-radius:var(--dc-radius-sm);border-bottom-right-radius:var(--dc-radius-sm)}.dc\:last\:border-r-0:last-child{border-right-style:var(--tw-border-style);border-right-width:0}@media(hover:hover){.dc\: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)}.dc\:hover\:underline:hover{text-decoration-line:underline}.dc\:hover\:opacity-80:hover{opacity:.8}.dc\:hover\:opacity-90:hover{opacity:.9}.dc\:hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.dc\:focus\:ring-1:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\: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)}.dc\:focus\:ring-current:focus{--tw-ring-color:currentcolor}.dc\:focus\:ring-offset-1:focus{--tw-ring-offset-width:1px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.dc\: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)}.dc\:focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.dc\:active\:cursor-grabbing:active{cursor:grabbing}.dc\:disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.dc\:disabled\:opacity-40:disabled{opacity:.4}.dc\:disabled\:opacity-50:disabled{opacity:.5}@media(min-width:40rem){.dc\:sm\:inline{display:inline}.dc\:sm\:w-32{width:calc(var(--dc-spacing) * 32)}.dc\:sm\:w-40{width:calc(var(--dc-spacing) * 40)}.dc\:sm\:flex-initial{flex:0 auto}.dc\:sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.dc\:sm\:flex-row{flex-direction:row}.dc\:sm\:items-center{align-items:center}.dc\:sm\:justify-start{justify-content:flex-start}.dc\:sm\:opacity-0{opacity:0}@media(hover:hover){.dc\:sm\:group-hover\:opacity-100:is(:where(.dc\:group):hover *){opacity:1}}}@media(min-width:48rem){.dc\:md\:block{display:block}.dc\:md\:flex{display:flex}.dc\:md\:hidden{display:none}.dc\:md\:h-\[80vh\]{height:80vh}.dc\:md\:h-\[90vh\]{height:90vh}.dc\:md\:max-h-\[700px\]{max-height:700px}.dc\:md\:w-80{width:calc(var(--dc-spacing) * 80)}.dc\:md\:w-\[900px\]{width:900px}.dc\:md\:w-\[min\(90vw\,1400px\)\]{width:min(90vw,1400px)}.dc\:md\:max-w-\[900px\]{max-width:900px}.dc\:md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dc\:md\:items-center{align-items:center}.dc\:md\:justify-center{justify-content:center}.dc\:md\:gap-3{gap:calc(var(--dc-spacing) * 3)}.dc\:md\:rounded-lg{border-radius:var(--dc-radius-lg)}.dc\:md\:px-4{padding-inline:calc(var(--dc-spacing) * 4)}.dc\:md\:px-6{padding-inline:calc(var(--dc-spacing) * 6)}.dc\:md\:py-3{padding-block:calc(var(--dc-spacing) * 3)}.dc\:md\:py-4{padding-block:calc(var(--dc-spacing) * 4)}.dc\:md\:pt-6{padding-top:calc(var(--dc-spacing) * 6)}.dc\:md\:pb-4{padding-bottom:calc(var(--dc-spacing) * 4)}}@media(min-width:64rem){.dc\:lg\:col-span-2{grid-column:span 2/span 2}.dc\:lg\:flex{display:flex}.dc\:lg\:inline{display:inline}.dc\:lg\:h-\[var\(--dc-max-h\)\]{height:var(--dc-max-h)}.dc\:lg\:h-auto{height:auto}.dc\:lg\:h-full{height:100%}.dc\:lg\:max-h-\[var\(--dc-max-h\)\]{max-height:var(--dc-max-h)}.dc\:lg\:w-96{width:calc(var(--dc-spacing) * 96)}.dc\:lg\:flex-1{flex:1}.dc\:lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dc\:lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.dc\:lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.dc\:lg\:flex-row{flex-direction:row}.dc\:lg\:overflow-hidden{overflow:hidden}.dc\:lg\:border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.dc\:lg\:border-b-0{border-bottom-style:var(--tw-border-style);border-bottom-width:0}}.bg-dc-surface{background-color:var(--dc-surface)}.bg-dc-surface-secondary{background-color:var(--dc-surface-secondary)}.bg-dc-surface-tertiary{background-color:var(--dc-surface-tertiary)}.bg-dc-surface-hover{background-color:var(--dc-surface-hover)}.text-dc-text{color:var(--dc-text)}.text-dc-text-secondary{color:var(--dc-text-secondary)}.text-dc-text-muted{color:var(--dc-text-muted)}.text-dc-text-disabled{color:var(--dc-text-disabled)}.border-dc-border{border-color:var(--dc-border)}.border-dc-border-secondary{border-color:var(--dc-border-secondary)}.border-dc-border-hover{border-color:var(--dc-border-hover)}.bg-dc-primary{background-color:var(--dc-primary)}.bg-dc-primary-hover{background-color:var(--dc-primary-hover)}.text-dc-primary{color:var(--dc-primary)}.text-dc-primary-content{color:var(--dc-primary-content)}.border-dc-primary{border-color:var(--dc-primary)}.ring-dc-primary{--tw-ring-color:var(--dc-primary)}.bg-dc-success{background-color:var(--dc-success)}.bg-dc-success-bg{background-color:var(--dc-success-bg)}.text-dc-success{color:var(--dc-success)}.border-dc-success{border-color:var(--dc-success)}.border-dc-success-border{border-color:var(--dc-success-border)}.bg-dc-warning{background-color:var(--dc-warning)}.bg-dc-warning-bg{background-color:var(--dc-warning-bg)}.text-dc-warning{color:var(--dc-warning)}.border-dc-warning{border-color:var(--dc-warning)}.border-dc-warning-border{border-color:var(--dc-warning-border)}.bg-dc-error{background-color:var(--dc-error)}.bg-dc-error-bg{background-color:var(--dc-error-bg)}.text-dc-error{color:var(--dc-error)}.border-dc-error{border-color:var(--dc-error)}.border-dc-error-border{border-color:var(--dc-error-border)}.bg-dc-info{background-color:var(--dc-info)}.bg-dc-info-bg{background-color:var(--dc-info-bg)}.text-dc-info{color:var(--dc-info)}.border-dc-info{border-color:var(--dc-info)}.border-dc-info-border{border-color:var(--dc-info-border)}.bg-dc-danger{background-color:var(--dc-danger)}.bg-dc-danger-bg{background-color:var(--dc-danger-bg)}.bg-dc-danger-hover{background-color:var(--dc-danger-hover)}.text-dc-danger{color:var(--dc-danger)}.border-dc-danger{border-color:var(--dc-danger)}.bg-dc-accent{background-color:var(--dc-accent)}.bg-dc-accent-bg{background-color:var(--dc-accent-bg)}.bg-dc-accent-hover{background-color:var(--dc-accent-hover)}.text-dc-accent{color:var(--dc-accent)}.border-dc-accent{border-color:var(--dc-accent)}.border-dc-accent-border{border-color:var(--dc-accent-border)}.ring-dc-accent{--tw-ring-color:var(--dc-accent)}.bg-dc-card-bg{background-color:var(--dc-card-bg)}.bg-dc-card-bg-hover{background-color:var(--dc-card-bg-hover)}.border-dc-card-border{border-color:var(--dc-card-border)}.border-dc-card-border-hover{border-color:var(--dc-card-border-hover)}.bg-dc-muted{background-color:var(--dc-muted)}.bg-dc-muted-bg{background-color:var(--dc-muted-bg)}.text-dc-muted{color:var(--dc-muted)}.border-dc-muted{border-color:var(--dc-muted)}.border-dc-muted-border{border-color:var(--dc-muted-border)}.bg-dc-dimension{background-color:var(--dc-dimension-bg)}.text-dc-dimension,.text-dc-dimension-text{color:var(--dc-dimension-text)}.border-dc-dimension{border-color:var(--dc-dimension-border)}.bg-dc-time-dimension{background-color:var(--dc-time-dimension-bg)}.text-dc-time-dimension,.text-dc-time-dimension-text{color:var(--dc-time-dimension-text)}.border-dc-time-dimension{border-color:var(--dc-time-dimension-border)}.bg-dc-measure{background-color:var(--dc-measure-bg)}.text-dc-measure,.text-dc-measure-text{color:var(--dc-measure-text)}.border-dc-measure{border-color:var(--dc-measure-border)}.bg-dc-filter{background-color:var(--dc-filter-bg)}.text-dc-filter,.text-dc-filter-text{color:var(--dc-filter-text)}.border-dc-filter{border-color:var(--dc-filter-border)}.hover\:bg-dc-surface-hover:hover{background-color:var(--dc-surface-hover)}.hover\:border-dc-border-hover:hover{border-color:var(--dc-border-hover)}.hover\:bg-dc-primary-hover:hover{background-color:var(--dc-primary-hover)}.hover\:bg-dc-danger-hover:hover{background-color:var(--dc-danger-hover)}.hover\:bg-dc-accent-hover:hover{background-color:var(--dc-accent-hover)}.hover\:border-dc-accent:hover{border-color:var(--dc-accent)}.hover\:bg-dc-card-bg-hover:hover{background-color:var(--dc-card-bg-hover)}.hover\:border-dc-card-border-hover:hover{border-color:var(--dc-card-border-hover)}.hover\:text-dc-primary:hover{color:var(--dc-primary)}.hover\:text-dc-accent:hover{color:var(--dc-accent)}.hover\:text-dc-danger:hover{color:var(--dc-danger)}.focus\:ring-dc-primary:focus{--tw-ring-color:var(--dc-primary)}.focus\:ring-dc-accent:focus{--tw-ring-color:var(--dc-accent)}.focus\:border-dc-primary:focus{border-color:var(--dc-primary)}.focus\:border-dc-accent:focus{border-color:var(--dc-accent)}.placeholder-dc-text-muted::placeholder{color:var(--dc-text-muted)}.placeholder-dc-text-disabled::placeholder{color:var(--dc-text-disabled)}}:root{--dc-surface:#fff;--dc-surface-secondary:#f9fafb;--dc-surface-tertiary:#f3f4f6;--dc-surface-hover:#f3f4f6;--dc-text:#111827;--dc-text-secondary:#374151;--dc-text-muted:#6b7280;--dc-text-disabled:#9ca3af;--dc-border:#e5e7eb;--dc-border-secondary:#d1d5db;--dc-border-hover:#d1d5db;--dc-primary:#3b82f6;--dc-primary-hover:#2563eb;--dc-primary-content:#fff;--dc-success:#10b981;--dc-success-bg:#d1fae5;--dc-success-border:#6ee7b7;--dc-warning:#f59e0b;--dc-warning-bg:#fef3c7;--dc-warning-border:#fcd34d;--dc-error:#ef4444;--dc-error-bg:#fee2e2;--dc-error-border:#fca5a5;--dc-info:#3b82f6;--dc-info-bg:#dbeafe;--dc-info-border:#93c5fd;--dc-danger:#dc2626;--dc-danger-hover:#b91c1c;--dc-danger-bg:#fee2e2;--dc-dimension-bg:#bbf7d0;--dc-dimension-text:#15803d;--dc-dimension-border:#86efac;--dc-time-dimension-bg:#bfdbfe;--dc-time-dimension-text:#1d4ed8;--dc-time-dimension-border:#60a5fa;--dc-measure-bg:#fde68a;--dc-measure-text:#b45309;--dc-measure-border:#fbbf24;--dc-filter-bg:#e9d5ff;--dc-filter-text:#7c3aed;--dc-filter-border:#c084fc;--dc-overlay:#000000bf;--dc-overlay-light:#00000080;--dc-shadow-sm:0 1px 2px 0 #0000000d;--dc-shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--dc-shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--dc-shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--dc-shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--dc-shadow-2xl:0 25px 50px -12px #00000040;--dc-card-bg:#fff;--dc-card-bg-hover:#f9fafb;--dc-card-border:#e5e7eb;--dc-card-border-hover:#d1d5db;--dc-accent:#3b82f6;--dc-accent-hover:#2563eb;--dc-accent-bg:#eff6ff;--dc-accent-border:#93c5fd;--dc-muted:#6b7280;--dc-muted-bg:#f3f4f6;--dc-muted-border:#e5e7eb;--dc-ai-gradient-start:#faf5ff;--dc-ai-gradient-end:#eef2ff}[data-theme=dark],.dark,html.dark{--dc-surface:#1e293b;--dc-surface-secondary:#334155;--dc-surface-tertiary:#475569;--dc-surface-hover:#475569;--dc-text:#f1f5f9;--dc-text-secondary:#e2e8f0;--dc-text-muted:#cbd5e1;--dc-text-disabled:#94a3b8;--dc-border:#475569;--dc-border-secondary:#64748b;--dc-border-hover:#64748b;--dc-primary:#60a5fa;--dc-primary-hover:#3b82f6;--dc-primary-content:#0c4a6e;--dc-success:#34d399;--dc-success-bg:#064e3b;--dc-success-border:#059669;--dc-warning:#fbbf24;--dc-warning-bg:#78350f;--dc-warning-border:#d97706;--dc-error:#f87171;--dc-error-bg:#7f1d1d;--dc-error-border:#dc2626;--dc-info:#60a5fa;--dc-info-bg:#1e3a8a;--dc-info-border:#2563eb;--dc-danger:#ef4444;--dc-danger-hover:#dc2626;--dc-danger-bg:#7f1d1d;--dc-dimension-bg:#22c55e66;--dc-dimension-text:#4ade80;--dc-dimension-border:#22c55e;--dc-time-dimension-bg:#3b82f666;--dc-time-dimension-text:#60a5fa;--dc-time-dimension-border:#3b82f6;--dc-measure-bg:#f59e0b66;--dc-measure-text:#fbbf24;--dc-measure-border:#f59e0b;--dc-filter-bg:#8b5cf666;--dc-filter-text:#c084fc;--dc-filter-border:#a855f7;--dc-overlay:#000000d9;--dc-overlay-light:#0009;--dc-shadow-sm:0 1px 2px 0 #0000004d;--dc-shadow:0 1px 3px 0 #0006, 0 1px 2px -1px #0006;--dc-shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0006;--dc-shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -4px #0006;--dc-shadow-xl:0 20px 25px -5px #0006, 0 8px 10px -6px #0006;--dc-shadow-2xl:0 25px 50px -12px #00000080;--dc-card-bg:#1e293b;--dc-card-bg-hover:#334155;--dc-card-border:#475569;--dc-card-border-hover:#64748b;--dc-accent:#60a5fa;--dc-accent-hover:#3b82f6;--dc-accent-bg:#1e3a8a;--dc-accent-border:#2563eb;--dc-muted:#94a3b8;--dc-muted-bg:#334155;--dc-muted-border:#475569;--dc-ai-gradient-start:#8b5cf626;--dc-ai-gradient-end:#6366f126}[data-theme=neon],html.neon{--dc-surface:#0a0118;--dc-surface-secondary:#1a0f2e;--dc-surface-tertiary:#2a1f3e;--dc-surface-hover:#3a2f4e;--dc-text:#fff;--dc-text-secondary:#e0e0ff;--dc-text-muted:#b0b0d0;--dc-text-disabled:#808090;--dc-border:#f0f;--dc-border-secondary:#0ff;--dc-border-hover:#0f0;--dc-primary:#0ff;--dc-primary-hover:#0cc;--dc-primary-content:#000;--dc-success:#0f0;--dc-success-bg:#00ff0026;--dc-success-border:#0f0;--dc-warning:#ff0;--dc-warning-bg:#ffff0026;--dc-warning-border:#ff0;--dc-error:#f06;--dc-error-bg:#ff006626;--dc-error-border:#f06;--dc-info:#0ff;--dc-info-bg:#00ffff26;--dc-info-border:#0ff;--dc-danger:#ff1493;--dc-danger-hover:#cc1077;--dc-danger-bg:#ff149326;--dc-dimension-bg:#00ff0059;--dc-dimension-text:#0f0;--dc-dimension-border:#0f0;--dc-time-dimension-bg:#00ffff59;--dc-time-dimension-text:#0ff;--dc-time-dimension-border:#0ff;--dc-measure-bg:#ff00ff59;--dc-measure-text:#f0f;--dc-measure-border:#f0f;--dc-filter-bg:#a855f759;--dc-filter-text:#a855f7;--dc-filter-border:#a855f7;--dc-overlay:#0a0118f2;--dc-overlay-light:#0a0118bf;--dc-shadow-sm:0 0 4px #ff00ff4d;--dc-shadow:0 0 8px #f0f6, 0 0 12px #0ff3;--dc-shadow-md:0 0 12px #ff00ff80, 0 0 20px #00ffff4d;--dc-shadow-lg:0 0 20px #f0f9, 0 0 30px #0ff6;--dc-shadow-xl:0 0 30px #ff00ffb3, 0 0 50px #00ffff80;--dc-shadow-2xl:0 0 50px #f0fc, 0 0 80px #0ff9;--dc-card-bg:#1a0f2e;--dc-card-bg-hover:#2a1f3e;--dc-card-border:#f0f;--dc-card-border-hover:#0ff;--dc-accent:#0ff;--dc-accent-hover:#0cc;--dc-accent-bg:#00ffff26;--dc-accent-border:#0ff;--dc-muted:#b0b0d0;--dc-muted-bg:#2a1f3e;--dc-muted-border:#f0f;--dc-ai-gradient-start:#00ffff1a;--dc-ai-gradient-end:#ff00ff1a}.recharts-surface:focus,.recharts-wrapper:focus,.recharts-area:focus,.recharts-area-area:focus,.recharts-area-curve:focus,.recharts-line:focus,.recharts-line-curve:focus,.recharts-bar:focus,.recharts-pie:focus,.recharts-sector:focus,.recharts-layer:focus,.recharts-wrapper svg:focus,.recharts-wrapper g:focus,.recharts-wrapper path:focus,.recharts-wrapper rect:focus,.recharts-wrapper circle:focus{outline:none}.hljs{background-color:var(--dc-surface-secondary)!important;color:var(--dc-text)!important;padding:.5em!important}.hljs-keyword,.hljs-selector-tag,.hljs-literal,.hljs-section,.hljs-link{color:var(--dc-primary)}.hljs-string,.hljs-attr{color:var(--dc-success)}.hljs-number{color:var(--dc-warning)}.hljs-comment,.hljs-quote{color:var(--dc-text-muted);font-style:italic}.hljs-title,.hljs-class .hljs-title,.hljs-function .hljs-title{color:var(--dc-accent)}.hljs-variable,.hljs-attribute,.hljs-property{color:var(--dc-text-secondary)}.hljs-built_in,.hljs-name{color:var(--dc-info)}.hljs-meta,.hljs-meta-keyword{color:var(--dc-muted)}pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}.react-grid-layout{transition:height .2s;position:relative}.react-grid-item{transition:left .2s,top .2s,width .2s,height .2s}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{z-index:1;will-change:width,height;transition:none}.react-grid-item.react-draggable-dragging{z-index:3;will-change:transform;transition:none}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{opacity:.2;z-index:2;-webkit-user-select:none;user-select:none;background:red;transition-duration:.1s}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{opacity:0;width:20px;height:20px;position:absolute}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";border-bottom:2px solid #0006;border-right:2px solid #0006;width:5px;height:5px;position:absolute;bottom:3px;right:3px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:100% 100%;background-repeat:no-repeat;background-origin:content-box;width:20px;height:20px;padding:0 3px 3px 0;position:absolute}.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-grid-layout{margin:0!important}.react-grid-item{overflow:hidden}.scaled-grid-inner .react-grid-item{transition:none!important}.scaled-grid-inner .react-grid-item.react-grid-placeholder{display:none!important}.dashboard-grid-container{width:100%;position:relative}.mobile-stacked-layout{width:100%}.dc-row-layout{padding-top:var(--dc-top-drop-space,0px);padding-bottom:var(--dc-bottom-drop-space,0px);flex-direction:column;gap:0;display:flex;position:relative}.dc-row-layout-row-wrapper{padding-bottom:var(--dc-row-gap,24px);position:relative}.dc-row-layout-row{align-items:stretch;gap:var(--dc-column-gap,16px);width:100%;display:flex;overflow:hidden}.dc-row-layout-column-wrapper{flex-direction:column;height:100%;display:flex;position:relative}.dc-row-layout-column{z-index:2;height:100%;position:relative}.dc-split-handle{opacity:0;pointer-events:none;z-index:1}.dc-row-layout-editable .dc-split-handle,.dc-row-layout-dragging .dc-split-handle{pointer-events:auto}.dc-row-layout-editable .dc-split-handle:hover,.dc-row-layout-editable .dc-split-handle.dc-drop-zone-active{opacity:1}.dc-column-resize-handle{top:0;bottom:0;left:calc(100% + (var(--dc-column-gap,16px) / 2));width:calc(var(--dc-column-gap,16px) * 3);cursor:col-resize;background:0 0;transition:background .2s,opacity .2s;position:absolute;transform:translate(-50%)}.dc-column-resize-handle:after{content:"";background:var(--dc-border);opacity:0;width:2px;transition:opacity .2s,background .2s,width .2s;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.dc-column-resize-handle:hover,.dc-column-resize-handle.dc-drop-zone-active{background:rgba(var(--dc-primary-rgb),.1)}.dc-column-resize-handle:hover:after,.dc-column-resize-handle.dc-drop-zone-active:after{background:var(--dc-primary);opacity:1;width:8px}.dc-row-resize-handle{left:0;right:0;top:calc(100% - (var(--dc-row-gap,24px) / 2));height:calc(var(--dc-row-gap,24px) * 3);cursor:row-resize;background:0 0;transition:background .2s,opacity .2s;position:absolute;transform:translateY(-50%)}.dc-row-boundary-drop{height:var(--dc-row-gap,24px);cursor:default;opacity:0;position:absolute;left:0;right:0}.dc-row-layout-editable .dc-row-boundary-drop{opacity:0;pointer-events:none}.dc-row-layout-dragging .dc-row-boundary-drop{pointer-events:auto}.dc-row-boundary-drop.dc-drop-zone-active{opacity:1}.dc-row-boundary-drop-top{transform:translateY(calc(-1 * var(--dc-row-gap,24px) / 2));top:0}.dc-row-boundary-drop-bottom{transform:translateY(calc(var(--dc-row-gap,24px) / 2));bottom:0}.dc-row-boundary-drop:after{content:"";background:var(--dc-border);opacity:0;height:2px;transition:opacity .2s,background .2s,height .2s;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.dc-row-boundary-drop.dc-drop-zone-active{background:rgba(var(--dc-primary-rgb),.1)}.dc-row-boundary-drop.dc-drop-zone-active:after{background:var(--dc-primary);opacity:1;height:8px}.dc-row-resize-handle:after{content:"";background:var(--dc-border);opacity:0;height:2px;transition:opacity .2s,background .2s,height .2s;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.dc-row-resize-handle:hover,.dc-row-resize-handle.dc-drop-zone-active{background:rgba(var(--dc-primary-rgb),.1)}.dc-row-resize-handle:hover:after,.dc-row-resize-handle.dc-drop-zone-active:after{background:var(--dc-primary);opacity:1;height:8px}.dc-row-resize-handle-drop-only{cursor:default}.dc-row-resize-handle-drop-only:hover:not(.dc-drop-zone-active){background:0 0}.dc-row-resize-handle-drop-only:hover:not(.dc-drop-zone-active):after{background:var(--dc-border);opacity:0;height:2px}.dc-row-edge-drop{width:calc(var(--dc-column-gap,16px) * 3);z-index:1;background:0 0;transition:background .2s;position:absolute;top:0;bottom:0}.dc-row-layout-editable .dc-row-edge-drop{opacity:0;pointer-events:none}.dc-row-layout-dragging .dc-row-edge-drop{opacity:0;pointer-events:auto;z-index:5}.dc-row-edge-drop.dc-drop-zone-active{opacity:1}.dc-row-edge-drop-left{transform:translate(calc(-1 * var(--dc-column-gap,16px)));left:0}.dc-row-edge-drop-right{transform:translate(var(--dc-column-gap,16px));right:0}.dc-row-edge-drop:after{content:"";background:var(--dc-border);opacity:0;width:2px;transition:opacity .2s,background .2s,width .2s;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.dc-row-edge-drop.dc-drop-zone-active{background:rgba(var(--dc-primary-rgb),.1)}.dc-row-edge-drop.dc-drop-zone-active:after{background:var(--dc-primary);opacity:1;width:8px}.dc-row-resize-handle-drop{position:relative}@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-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}
|
|
1
|
+
.hljs{display:block;overflow-x:auto;color:var(--dc-text);background:transparent}.hljs-keyword,.hljs-selector-tag,.hljs-operator{color:var(--dc-primary);font-weight:600}.hljs-number,.hljs-literal,.hljs-boolean{color:var(--dc-warning)}.hljs-title,.hljs-function{color:var(--dc-accent);font-weight:600}.hljs-built_in,.hljs-type{color:var(--dc-info)}.hljs-variable,.hljs-property{color:var(--dc-text)}.hljs-meta{color:var(--dc-text-muted)}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.language-json .hljs-attr{color:var(--dc-primary)}.language-json .hljs-string{color:var(--dc-success)}.language-json .hljs-number{color:var(--dc-warning)}.language-json .hljs-literal{color:var(--dc-accent);font-weight:600}.language-sql .hljs-keyword{color:var(--dc-primary);font-weight:700;text-transform:uppercase}.language-sql .hljs-string{color:var(--dc-success)}.language-sql .hljs-number{color:var(--dc-warning)}.language-sql .hljs-comment{color:var(--dc-text-muted);font-style:italic}.language-sql .hljs-function{color:var(--dc-accent);font-weight:600}@media(prefers-color-scheme:dark){.hljs-string{color:#7ee787}.hljs-number,.hljs-literal{color:#f0883e}}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-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-space-x-reverse:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-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{:root,:host{--dc-font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--dc-color-black:#000;--dc-color-white:#fff;--dc-spacing:.25rem;--dc-container-xs:20rem;--dc-container-sm:24rem;--dc-container-md:28rem;--dc-container-lg:32rem;--dc-container-2xl:42rem;--dc-container-4xl:56rem;--dc-container-5xl:64rem;--dc-container-6xl:72rem;--dc-container-7xl:80rem;--dc-text-xs:.75rem;--dc-text-xs--line-height:calc(1 / .75);--dc-text-sm:.875rem;--dc-text-sm--line-height:calc(1.25 / .875);--dc-text-base:1rem;--dc-text-base--line-height: 1.5 ;--dc-text-lg:1.125rem;--dc-text-lg--line-height:calc(1.75 / 1.125);--dc-text-xl:1.25rem;--dc-text-xl--line-height:calc(1.75 / 1.25);--dc-text-2xl:1.5rem;--dc-text-2xl--line-height:calc(2 / 1.5);--dc-text-3xl:1.875rem;--dc-text-3xl--line-height: 1.2 ;--dc-text-4xl:2.25rem;--dc-text-4xl--line-height:calc(2.5 / 2.25);--dc-text-5xl:3rem;--dc-text-5xl--line-height:1;--dc-font-weight-normal:400;--dc-font-weight-medium:500;--dc-font-weight-semibold:600;--dc-font-weight-bold:700;--dc-tracking-normal:0em;--dc-tracking-wide:.025em;--dc-tracking-wider:.05em;--dc-leading-tight:1.25;--dc-leading-relaxed:1.625;--dc-radius-sm:.25rem;--dc-radius-md:.375rem;--dc-radius-lg:.5rem;--dc-shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--dc-shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--dc-shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--dc-shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--dc-shadow-2xl:0 25px 50px -12px #00000040;--dc-drop-shadow-sm:0 1px 2px #00000026;--dc-ease-out:cubic-bezier(0, 0, .2, 1);--dc-ease-in-out:cubic-bezier(.4, 0, .2, 1);--dc-animate-spin:spin 1s linear infinite;--dc-animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--dc-blur-md:12px;--dc-default-transition-duration:.15s;--dc-default-transition-timing-function:cubic-bezier(.4, 0, .2, 1)}}@layer base,components;@layer utilities{.dc\:pointer-events-none{pointer-events:none}.dc\:sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.dc\:absolute{position:absolute}.dc\:fixed{position:fixed}.dc\:relative{position:relative}.dc\:sticky{position:sticky}.dc\:inset-0{inset:calc(var(--dc-spacing) * 0)}.dc\:-top-0\.5{top:calc(var(--dc-spacing) * -.5)}.dc\:-top-1{top:calc(var(--dc-spacing) * -1)}.dc\:-top-5{top:calc(var(--dc-spacing) * -5)}.dc\:top-0{top:calc(var(--dc-spacing) * 0)}.dc\:top-0\.5{top:calc(var(--dc-spacing) * .5)}.dc\:top-1{top:calc(var(--dc-spacing) * 1)}.dc\:top-1\/2{top:50%}.dc\:top-2{top:calc(var(--dc-spacing) * 2)}.dc\:top-full{top:100%}.dc\:-right-0\.5{right:calc(var(--dc-spacing) * -.5)}.dc\:right-0{right:calc(var(--dc-spacing) * 0)}.dc\:right-0\.5{right:calc(var(--dc-spacing) * .5)}.dc\:right-1{right:calc(var(--dc-spacing) * 1)}.dc\:right-2{right:calc(var(--dc-spacing) * 2)}.dc\:right-4{right:calc(var(--dc-spacing) * 4)}.dc\:right-full{right:100%}.dc\:bottom-0{bottom:calc(var(--dc-spacing) * 0)}.dc\:left-0{left:calc(var(--dc-spacing) * 0)}.dc\:left-2{left:calc(var(--dc-spacing) * 2)}.dc\:left-4{left:calc(var(--dc-spacing) * 4)}.dc\:left-full{left:100%}.dc\:z-10{z-index:10}.dc\:z-20{z-index:20}.dc\:z-30{z-index:30}.dc\:z-40{z-index:40}.dc\:z-50{z-index:50}.dc\:z-\[60\]{z-index:60}.dc\:float-right{float:right}.dc\:m-0{margin:calc(var(--dc-spacing) * 0)}.dc\:-mx-2{margin-inline:calc(var(--dc-spacing) * -2)}.dc\:mx-1{margin-inline:calc(var(--dc-spacing) * 1)}.dc\:mx-4{margin-inline:calc(var(--dc-spacing) * 4)}.dc\:mx-auto{margin-inline:auto}.dc\:my-0\.5{margin-block:calc(var(--dc-spacing) * .5)}.dc\:my-1{margin-block:calc(var(--dc-spacing) * 1)}.dc\:my-2{margin-block:calc(var(--dc-spacing) * 2)}.dc\:my-3{margin-block:calc(var(--dc-spacing) * 3)}.dc\:my-4{margin-block:calc(var(--dc-spacing) * 4)}.dc\:mt-0\.5{margin-top:calc(var(--dc-spacing) * .5)}.dc\:mt-1{margin-top:calc(var(--dc-spacing) * 1)}.dc\:mt-2{margin-top:calc(var(--dc-spacing) * 2)}.dc\:mt-3{margin-top:calc(var(--dc-spacing) * 3)}.dc\:mt-4{margin-top:calc(var(--dc-spacing) * 4)}.dc\:mt-6{margin-top:calc(var(--dc-spacing) * 6)}.dc\:-mr-2{margin-right:calc(var(--dc-spacing) * -2)}.dc\:mr-0\.5{margin-right:calc(var(--dc-spacing) * .5)}.dc\:mr-1{margin-right:calc(var(--dc-spacing) * 1)}.dc\:mr-1\.5{margin-right:calc(var(--dc-spacing) * 1.5)}.dc\:mr-2{margin-right:calc(var(--dc-spacing) * 2)}.dc\:mr-3{margin-right:calc(var(--dc-spacing) * 3)}.dc\:mb-0{margin-bottom:calc(var(--dc-spacing) * 0)}.dc\:mb-1{margin-bottom:calc(var(--dc-spacing) * 1)}.dc\:mb-1\.5{margin-bottom:calc(var(--dc-spacing) * 1.5)}.dc\:mb-2{margin-bottom:calc(var(--dc-spacing) * 2)}.dc\:mb-3{margin-bottom:calc(var(--dc-spacing) * 3)}.dc\:mb-4{margin-bottom:calc(var(--dc-spacing) * 4)}.dc\:mb-16{margin-bottom:calc(var(--dc-spacing) * 16)}.dc\:-ml-2{margin-left:calc(var(--dc-spacing) * -2)}.dc\:ml-0\.5{margin-left:calc(var(--dc-spacing) * .5)}.dc\:ml-1{margin-left:calc(var(--dc-spacing) * 1)}.dc\:ml-1\.5{margin-left:calc(var(--dc-spacing) * 1.5)}.dc\:ml-2{margin-left:calc(var(--dc-spacing) * 2)}.dc\:ml-4{margin-left:calc(var(--dc-spacing) * 4)}.dc\:ml-5{margin-left:calc(var(--dc-spacing) * 5)}.dc\:ml-6{margin-left:calc(var(--dc-spacing) * 6)}.dc\:ml-auto{margin-left:auto}.dc\:block{display:block}.dc\:flex{display:flex}.dc\:grid{display:grid}.dc\:hidden{display:none}.dc\:inline-block{display:inline-block}.dc\:inline-flex{display:inline-flex}.dc\:h-0\.5{height:calc(var(--dc-spacing) * .5)}.dc\:h-1\.5{height:calc(var(--dc-spacing) * 1.5)}.dc\:h-2{height:calc(var(--dc-spacing) * 2)}.dc\:h-2\.5{height:calc(var(--dc-spacing) * 2.5)}.dc\:h-3{height:calc(var(--dc-spacing) * 3)}.dc\:h-3\.5{height:calc(var(--dc-spacing) * 3.5)}.dc\:h-4{height:calc(var(--dc-spacing) * 4)}.dc\:h-5{height:calc(var(--dc-spacing) * 5)}.dc\:h-6{height:calc(var(--dc-spacing) * 6)}.dc\:h-8{height:calc(var(--dc-spacing) * 8)}.dc\:h-10{height:calc(var(--dc-spacing) * 10)}.dc\:h-12{height:calc(var(--dc-spacing) * 12)}.dc\:h-64{height:calc(var(--dc-spacing) * 64)}.dc\:h-\[60vh\]{height:60vh}.dc\:h-\[90vh\]{height:90vh}.dc\:h-full{height:100%}.dc\:h-px{height:1px}.dc\:max-h-20{max-height:calc(var(--dc-spacing) * 20)}.dc\:max-h-32{max-height:calc(var(--dc-spacing) * 32)}.dc\:max-h-40{max-height:calc(var(--dc-spacing) * 40)}.dc\:max-h-48{max-height:calc(var(--dc-spacing) * 48)}.dc\:max-h-56{max-height:calc(var(--dc-spacing) * 56)}.dc\:max-h-60{max-height:calc(var(--dc-spacing) * 60)}.dc\:max-h-64{max-height:calc(var(--dc-spacing) * 64)}.dc\:max-h-72{max-height:calc(var(--dc-spacing) * 72)}.dc\:max-h-80{max-height:calc(var(--dc-spacing) * 80)}.dc\:max-h-\[40\%\]{max-height:40%}.dc\:max-h-\[80vh\]{max-height:80vh}.dc\:max-h-\[85vh\]{max-height:85vh}.dc\:max-h-\[90vh\]{max-height:90vh}.dc\:min-h-0{min-height:calc(var(--dc-spacing) * 0)}.dc\:min-h-10{min-height:calc(var(--dc-spacing) * 10)}.dc\:min-h-12{min-height:calc(var(--dc-spacing) * 12)}.dc\:min-h-16{min-height:calc(var(--dc-spacing) * 16)}.dc\:min-h-\[30px\]{min-height:30px}.dc\:min-h-\[48px\]{min-height:48px}.dc\:min-h-\[50vh\]{min-height:50vh}.dc\:min-h-\[100px\]{min-height:100px}.dc\:min-h-\[200px\]{min-height:200px}.dc\:min-h-\[400px\]{min-height:400px}.dc\:w-1{width:calc(var(--dc-spacing) * 1)}.dc\:w-1\.5{width:calc(var(--dc-spacing) * 1.5)}.dc\:w-2{width:calc(var(--dc-spacing) * 2)}.dc\:w-2\.5{width:calc(var(--dc-spacing) * 2.5)}.dc\:w-3{width:calc(var(--dc-spacing) * 3)}.dc\:w-3\.5{width:calc(var(--dc-spacing) * 3.5)}.dc\:w-4{width:calc(var(--dc-spacing) * 4)}.dc\:w-5{width:calc(var(--dc-spacing) * 5)}.dc\:w-6{width:calc(var(--dc-spacing) * 6)}.dc\:w-8{width:calc(var(--dc-spacing) * 8)}.dc\:w-10{width:calc(var(--dc-spacing) * 10)}.dc\:w-12{width:calc(var(--dc-spacing) * 12)}.dc\:w-16{width:calc(var(--dc-spacing) * 16)}.dc\:w-20{width:calc(var(--dc-spacing) * 20)}.dc\:w-24{width:calc(var(--dc-spacing) * 24)}.dc\:w-28{width:calc(var(--dc-spacing) * 28)}.dc\:w-36{width:calc(var(--dc-spacing) * 36)}.dc\:w-48{width:calc(var(--dc-spacing) * 48)}.dc\:w-52{width:calc(var(--dc-spacing) * 52)}.dc\:w-72{width:calc(var(--dc-spacing) * 72)}.dc\:w-\[90vw\]{width:90vw}.dc\:w-\[180px\]{width:180px}.dc\:w-\[280px\]{width:280px}.dc\:w-full{width:100%}.dc\:w-px{width:1px}.dc\:max-w-2xl{max-width:var(--dc-container-2xl)}.dc\:max-w-4xl{max-width:var(--dc-container-4xl)}.dc\:max-w-5xl{max-width:var(--dc-container-5xl)}.dc\:max-w-6xl{max-width:var(--dc-container-6xl)}.dc\:max-w-7xl{max-width:var(--dc-container-7xl)}.dc\:max-w-32{max-width:calc(var(--dc-spacing) * 32)}.dc\:max-w-\[85\%\]{max-width:85%}.dc\:max-w-\[100px\]{max-width:100px}.dc\:max-w-\[150px\]{max-width:150px}.dc\:max-w-\[200px\]{max-width:200px}.dc\:max-w-\[280px\]{max-width:280px}.dc\:max-w-\[1400px\]{max-width:1400px}.dc\:max-w-full{max-width:100%}.dc\:max-w-lg{max-width:var(--dc-container-lg)}.dc\:max-w-md{max-width:var(--dc-container-md)}.dc\:max-w-none{max-width:none}.dc\:max-w-sm{max-width:var(--dc-container-sm)}.dc\:max-w-xs{max-width:var(--dc-container-xs)}.dc\:min-w-0{min-width:calc(var(--dc-spacing) * 0)}.dc\:min-w-\[60px\]{min-width:60px}.dc\:min-w-\[70px\]{min-width:70px}.dc\:min-w-\[80px\]{min-width:80px}.dc\:min-w-\[100px\]{min-width:100px}.dc\:min-w-\[120px\]{min-width:120px}.dc\:min-w-\[180px\]{min-width:180px}.dc\:min-w-\[200px\]{min-width:200px}.dc\:min-w-\[220px\]{min-width:220px}.dc\:min-w-\[280px\]{min-width:280px}.dc\:min-w-full{min-width:100%}.dc\:min-w-max{min-width:max-content}.dc\:flex-1{flex:1}.dc\:flex-shrink-0,.dc\:shrink-0{flex-shrink:0}.dc\:border-collapse{border-collapse:collapse}.dc\:-translate-x-16{--tw-translate-x:calc(var(--dc-spacing) * -16);translate:var(--tw-translate-x) var(--tw-translate-y)}.dc\:translate-x-0{--tw-translate-x:calc(var(--dc-spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.dc\:translate-x-16{--tw-translate-x:calc(var(--dc-spacing) * 16);translate:var(--tw-translate-x) var(--tw-translate-y)}.dc\:-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.dc\:scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}.dc\:rotate-180{rotate:180deg}.dc\:transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.dc\:animate-pulse{animation:var(--dc-animate-pulse)}.dc\:animate-spin{animation:var(--dc-animate-spin)}.dc\:cursor-col-resize{cursor:col-resize}.dc\:cursor-default{cursor:default}.dc\:cursor-grab{cursor:grab}.dc\:cursor-grabbing{cursor:grabbing}.dc\:cursor-help{cursor:help}.dc\:cursor-move{cursor:move}.dc\:cursor-not-allowed{cursor:not-allowed}.dc\:cursor-pointer{cursor:pointer}.dc\:cursor-wait{cursor:wait}.dc\:resize-none{resize:none}.dc\:resize-y{resize:vertical}.dc\:list-inside{list-style-position:inside}.dc\:list-decimal{list-style-type:decimal}.dc\:list-disc{list-style-type:disc}.dc\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.dc\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dc\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.dc\:flex-col{flex-direction:column}.dc\:flex-wrap{flex-wrap:wrap}.dc\:items-center{align-items:center}.dc\:items-end{align-items:flex-end}.dc\:items-start{align-items:flex-start}.dc\:justify-between{justify-content:space-between}.dc\:justify-center{justify-content:center}.dc\:justify-end{justify-content:flex-end}.dc\:justify-start{justify-content:flex-start}.dc\:gap-0\.5{gap:calc(var(--dc-spacing) * .5)}.dc\:gap-1{gap:calc(var(--dc-spacing) * 1)}.dc\:gap-1\.5{gap:calc(var(--dc-spacing) * 1.5)}.dc\:gap-2{gap:calc(var(--dc-spacing) * 2)}.dc\:gap-3{gap:calc(var(--dc-spacing) * 3)}.dc\:gap-4{gap:calc(var(--dc-spacing) * 4)}.dc\:gap-6{gap:calc(var(--dc-spacing) * 6)}:where(.dc\:space-y-0\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * .5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * .5) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--dc-spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--dc-spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.dc\:space-x-0\.5>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * .5) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * .5) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-1>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 1) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 1) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-1\.5>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 1.5) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 1.5) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 2) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-3>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 3) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 3) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:space-x-4>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--dc-spacing) * 4) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--dc-spacing) * 4) * calc(1 - var(--tw-space-x-reverse)))}:where(.dc\:divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}.dc\:truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dc\:overflow-auto{overflow:auto}.dc\:overflow-hidden{overflow:hidden}.dc\:overflow-visible{overflow:visible}.dc\:overflow-x-auto{overflow-x:auto}.dc\:overflow-y-auto{overflow-y:auto}.dc\:rounded{border-radius:.25rem}.dc\:rounded-full{border-radius:3.40282e38px}.dc\:rounded-lg{border-radius:var(--dc-radius-lg)}.dc\:rounded-md{border-radius:var(--dc-radius-md)}.dc\:rounded-none{border-radius:0}.dc\:rounded-sm{border-radius:var(--dc-radius-sm)}.dc\:rounded-t-lg{border-top-left-radius:var(--dc-radius-lg);border-top-right-radius:var(--dc-radius-lg)}.dc\:rounded-t-sm{border-top-left-radius:var(--dc-radius-sm);border-top-right-radius:var(--dc-radius-sm)}.dc\:rounded-b-lg{border-bottom-right-radius:var(--dc-radius-lg);border-bottom-left-radius:var(--dc-radius-lg)}.dc\:rounded-br-sm{border-bottom-right-radius:var(--dc-radius-sm)}.dc\:rounded-bl-sm{border-bottom-left-radius:var(--dc-radius-sm)}.dc\:border{border-style:var(--tw-border-style);border-width:1px}.dc\:border-2{border-style:var(--tw-border-style);border-width:2px}.dc\:border-x{border-inline-style:var(--tw-border-style);border-inline-width:1px}.dc\:border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.dc\:border-t-2{border-top-style:var(--tw-border-style);border-top-width:2px}.dc\:border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.dc\:border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.dc\:border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.dc\:border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.dc\:border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.dc\:border-dashed{--tw-border-style:dashed;border-style:dashed}.dc\:border-none{--tw-border-style:none;border-style:none}.dc\:border-solid{--tw-border-style:solid;border-style:solid}.dc\:border-current{border-color:currentColor}.dc\:border-t-transparent{border-top-color:#0000}.dc\:bg-black\/50{background-color:var(--dc-color-black)}@supports (color:color-mix(in lab,red,red)){.dc\:bg-black\/50{background-color:color-mix(in oklab,var(--dc-color-black) 50%,transparent)}}.dc\:p-0\.5{padding:calc(var(--dc-spacing) * .5)}.dc\:p-1{padding:calc(var(--dc-spacing) * 1)}.dc\:p-1\.5{padding:calc(var(--dc-spacing) * 1.5)}.dc\:p-2{padding:calc(var(--dc-spacing) * 2)}.dc\:p-3{padding:calc(var(--dc-spacing) * 3)}.dc\:p-4{padding:calc(var(--dc-spacing) * 4)}.dc\:p-6{padding:calc(var(--dc-spacing) * 6)}.dc\:px-1{padding-inline:calc(var(--dc-spacing) * 1)}.dc\:px-1\.5{padding-inline:calc(var(--dc-spacing) * 1.5)}.dc\:px-2{padding-inline:calc(var(--dc-spacing) * 2)}.dc\:px-2\.5{padding-inline:calc(var(--dc-spacing) * 2.5)}.dc\:px-3{padding-inline:calc(var(--dc-spacing) * 3)}.dc\:px-4{padding-inline:calc(var(--dc-spacing) * 4)}.dc\:px-6{padding-inline:calc(var(--dc-spacing) * 6)}.dc\:py-0\.5{padding-block:calc(var(--dc-spacing) * .5)}.dc\:py-1{padding-block:calc(var(--dc-spacing) * 1)}.dc\:py-1\.5{padding-block:calc(var(--dc-spacing) * 1.5)}.dc\:py-2{padding-block:calc(var(--dc-spacing) * 2)}.dc\:py-2\.5{padding-block:calc(var(--dc-spacing) * 2.5)}.dc\:py-3{padding-block:calc(var(--dc-spacing) * 3)}.dc\:py-4{padding-block:calc(var(--dc-spacing) * 4)}.dc\:py-6{padding-block:calc(var(--dc-spacing) * 6)}.dc\:py-8{padding-block:calc(var(--dc-spacing) * 8)}.dc\:py-12{padding-block:calc(var(--dc-spacing) * 12)}.dc\:pt-1{padding-top:calc(var(--dc-spacing) * 1)}.dc\:pt-2{padding-top:calc(var(--dc-spacing) * 2)}.dc\:pt-3{padding-top:calc(var(--dc-spacing) * 3)}.dc\:pt-4{padding-top:calc(var(--dc-spacing) * 4)}.dc\:pt-6{padding-top:calc(var(--dc-spacing) * 6)}.dc\:pr-1{padding-right:calc(var(--dc-spacing) * 1)}.dc\:pr-3{padding-right:calc(var(--dc-spacing) * 3)}.dc\:pb-1{padding-bottom:calc(var(--dc-spacing) * 1)}.dc\:pb-2{padding-bottom:calc(var(--dc-spacing) * 2)}.dc\:pb-3{padding-bottom:calc(var(--dc-spacing) * 3)}.dc\:pb-4{padding-bottom:calc(var(--dc-spacing) * 4)}.dc\:pb-24{padding-bottom:calc(var(--dc-spacing) * 24)}.dc\:pl-2{padding-left:calc(var(--dc-spacing) * 2)}.dc\:pl-3{padding-left:calc(var(--dc-spacing) * 3)}.dc\:pl-8{padding-left:calc(var(--dc-spacing) * 8)}.dc\:text-center{text-align:center}.dc\:text-left{text-align:left}.dc\:text-right{text-align:right}.dc\:align-top{vertical-align:top}.dc\:font-mono{font-family:var(--dc-font-mono)}.dc\:text-2xl{font-size:var(--dc-text-2xl);line-height:var(--tw-leading,var(--dc-text-2xl--line-height))}.dc\:text-3xl{font-size:var(--dc-text-3xl);line-height:var(--tw-leading,var(--dc-text-3xl--line-height))}.dc\:text-4xl{font-size:var(--dc-text-4xl);line-height:var(--tw-leading,var(--dc-text-4xl--line-height))}.dc\:text-5xl{font-size:var(--dc-text-5xl);line-height:var(--tw-leading,var(--dc-text-5xl--line-height))}.dc\:text-base{font-size:var(--dc-text-base);line-height:var(--tw-leading,var(--dc-text-base--line-height))}.dc\:text-lg{font-size:var(--dc-text-lg);line-height:var(--tw-leading,var(--dc-text-lg--line-height))}.dc\:text-sm{font-size:var(--dc-text-sm);line-height:var(--tw-leading,var(--dc-text-sm--line-height))}.dc\:text-xl{font-size:var(--dc-text-xl);line-height:var(--tw-leading,var(--dc-text-xl--line-height))}.dc\:text-xs{font-size:var(--dc-text-xs);line-height:var(--tw-leading,var(--dc-text-xs--line-height))}.dc\:text-\[10px\]{font-size:10px}.dc\:text-\[11px\]{font-size:11px}.dc\:leading-none{--tw-leading:1;line-height:1}.dc\:leading-relaxed{--tw-leading:var(--dc-leading-relaxed);line-height:var(--dc-leading-relaxed)}.dc\:leading-tight{--tw-leading:var(--dc-leading-tight);line-height:var(--dc-leading-tight)}.dc\:font-bold{--tw-font-weight:var(--dc-font-weight-bold);font-weight:var(--dc-font-weight-bold)}.dc\:font-medium{--tw-font-weight:var(--dc-font-weight-medium);font-weight:var(--dc-font-weight-medium)}.dc\:font-normal{--tw-font-weight:var(--dc-font-weight-normal);font-weight:var(--dc-font-weight-normal)}.dc\:font-semibold{--tw-font-weight:var(--dc-font-weight-semibold);font-weight:var(--dc-font-weight-semibold)}.dc\:tracking-normal{--tw-tracking:var(--dc-tracking-normal);letter-spacing:var(--dc-tracking-normal)}.dc\:tracking-wide{--tw-tracking:var(--dc-tracking-wide);letter-spacing:var(--dc-tracking-wide)}.dc\:tracking-wider{--tw-tracking:var(--dc-tracking-wider);letter-spacing:var(--dc-tracking-wider)}.dc\:break-words{overflow-wrap:break-word}.dc\:whitespace-nowrap{white-space:nowrap}.dc\:whitespace-pre-wrap{white-space:pre-wrap}.dc\:text-white{color:var(--dc-color-white)}.dc\:capitalize{text-transform:capitalize}.dc\:normal-case{text-transform:none}.dc\:uppercase{text-transform:uppercase}.dc\:italic{font-style:italic}.dc\:underline{text-decoration-line:underline}.dc\:opacity-0{opacity:0}.dc\:opacity-25{opacity:.25}.dc\:opacity-30{opacity:.3}.dc\:opacity-40{opacity:.4}.dc\:opacity-50{opacity:.5}.dc\:opacity-60{opacity:.6}.dc\:opacity-70{opacity:.7}.dc\:opacity-75{opacity:.75}.dc\:opacity-80{opacity:.8}.dc\:opacity-90{opacity:.9}.dc\:opacity-100{opacity:1}.dc\:shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\:shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\:shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\:ring-1{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\: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)}.dc\:ring-offset-1{--tw-ring-offset-width:1px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.dc\:drop-shadow-sm{--tw-drop-shadow-size:drop-shadow(0 1px 2px var(--tw-drop-shadow-color,#00000026));--tw-drop-shadow:drop-shadow(var(--dc-drop-shadow-sm));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,)}.dc\:backdrop-blur-md{--tw-backdrop-blur:blur(var(--dc-blur-md));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.dc\:transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--dc-default-transition-timing-function));transition-duration:var(--tw-duration,var(--dc-default-transition-duration))}.dc\:transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--dc-default-transition-timing-function));transition-duration:var(--tw-duration,var(--dc-default-transition-duration))}.dc\:transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--dc-default-transition-timing-function));transition-duration:var(--tw-duration,var(--dc-default-transition-duration))}.dc\:transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--dc-default-transition-timing-function));transition-duration:var(--tw-duration,var(--dc-default-transition-duration))}.dc\:duration-150{--tw-duration:.15s;transition-duration:.15s}.dc\:duration-200{--tw-duration:.2s;transition-duration:.2s}.dc\:duration-300{--tw-duration:.3s;transition-duration:.3s}.dc\:ease-in-out{--tw-ease:var(--dc-ease-in-out);transition-timing-function:var(--dc-ease-in-out)}.dc\:ease-out{--tw-ease:var(--dc-ease-out);transition-timing-function:var(--dc-ease-out)}.dc\:outline-none{--tw-outline-style:none;outline-style:none}@media(hover:hover){.dc\:group-hover\:opacity-100:is(:where(.dc\:group):hover *){opacity:1}}.dc\:first\:rounded-l-sm:first-child{border-top-left-radius:var(--dc-radius-sm);border-bottom-left-radius:var(--dc-radius-sm)}.dc\:last\:mb-0:last-child{margin-bottom:calc(var(--dc-spacing) * 0)}.dc\:last\:rounded-r-sm:last-child{border-top-right-radius:var(--dc-radius-sm);border-bottom-right-radius:var(--dc-radius-sm)}.dc\:last\:border-r-0:last-child{border-right-style:var(--tw-border-style);border-right-width:0}@media(hover:hover){.dc\: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)}.dc\:hover\:underline:hover{text-decoration-line:underline}.dc\:hover\:opacity-80:hover{opacity:.8}.dc\:hover\:opacity-90:hover{opacity:.9}.dc\:hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.dc\:focus\:ring-1:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.dc\: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)}.dc\:focus\:ring-current:focus{--tw-ring-color:currentcolor}.dc\:focus\:ring-offset-1:focus{--tw-ring-offset-width:1px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.dc\: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)}.dc\:focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.dc\:active\:cursor-grabbing:active{cursor:grabbing}.dc\:disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.dc\:disabled\:opacity-40:disabled{opacity:.4}.dc\:disabled\:opacity-50:disabled{opacity:.5}@media(min-width:40rem){.dc\:sm\:inline{display:inline}.dc\:sm\:w-32{width:calc(var(--dc-spacing) * 32)}.dc\:sm\:w-40{width:calc(var(--dc-spacing) * 40)}.dc\:sm\:flex-initial{flex:0 auto}.dc\:sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.dc\:sm\:flex-row{flex-direction:row}.dc\:sm\:items-center{align-items:center}.dc\:sm\:justify-start{justify-content:flex-start}.dc\:sm\:opacity-0{opacity:0}@media(hover:hover){.dc\:sm\:group-hover\:opacity-100:is(:where(.dc\:group):hover *){opacity:1}}}@media(min-width:48rem){.dc\:md\:block{display:block}.dc\:md\:flex{display:flex}.dc\:md\:hidden{display:none}.dc\:md\:h-\[80vh\]{height:80vh}.dc\:md\:h-\[90vh\]{height:90vh}.dc\:md\:max-h-\[700px\]{max-height:700px}.dc\:md\:w-80{width:calc(var(--dc-spacing) * 80)}.dc\:md\:w-\[900px\]{width:900px}.dc\:md\:w-\[min\(90vw\,1400px\)\]{width:min(90vw,1400px)}.dc\:md\:max-w-\[900px\]{max-width:900px}.dc\:md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dc\:md\:items-center{align-items:center}.dc\:md\:justify-center{justify-content:center}.dc\:md\:gap-3{gap:calc(var(--dc-spacing) * 3)}.dc\:md\:rounded-lg{border-radius:var(--dc-radius-lg)}.dc\:md\:px-4{padding-inline:calc(var(--dc-spacing) * 4)}.dc\:md\:px-6{padding-inline:calc(var(--dc-spacing) * 6)}.dc\:md\:py-3{padding-block:calc(var(--dc-spacing) * 3)}.dc\:md\:py-4{padding-block:calc(var(--dc-spacing) * 4)}.dc\:md\:pt-6{padding-top:calc(var(--dc-spacing) * 6)}.dc\:md\:pb-4{padding-bottom:calc(var(--dc-spacing) * 4)}}@media(min-width:64rem){.dc\:lg\:col-span-2{grid-column:span 2/span 2}.dc\:lg\:flex{display:flex}.dc\:lg\:inline{display:inline}.dc\:lg\:h-\[var\(--dc-max-h\)\]{height:var(--dc-max-h)}.dc\:lg\:h-auto{height:auto}.dc\:lg\:h-full{height:100%}.dc\:lg\:max-h-\[var\(--dc-max-h\)\]{max-height:var(--dc-max-h)}.dc\:lg\:w-96{width:calc(var(--dc-spacing) * 96)}.dc\:lg\:flex-1{flex:1}.dc\:lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dc\:lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.dc\:lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.dc\:lg\:flex-row{flex-direction:row}.dc\:lg\:overflow-hidden{overflow:hidden}.dc\:lg\:border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.dc\:lg\:border-b-0{border-bottom-style:var(--tw-border-style);border-bottom-width:0}}.bg-dc-surface{background-color:var(--dc-surface)}.bg-dc-surface-secondary{background-color:var(--dc-surface-secondary)}.bg-dc-surface-tertiary{background-color:var(--dc-surface-tertiary)}.bg-dc-surface-hover{background-color:var(--dc-surface-hover)}.text-dc-text{color:var(--dc-text)}.text-dc-text-secondary{color:var(--dc-text-secondary)}.text-dc-text-muted{color:var(--dc-text-muted)}.text-dc-text-disabled{color:var(--dc-text-disabled)}.border-dc-border{border-color:var(--dc-border)}.border-dc-border-secondary{border-color:var(--dc-border-secondary)}.border-dc-border-hover{border-color:var(--dc-border-hover)}.bg-dc-primary{background-color:var(--dc-primary)}.bg-dc-primary-hover{background-color:var(--dc-primary-hover)}.text-dc-primary{color:var(--dc-primary)}.text-dc-primary-content{color:var(--dc-primary-content)}.border-dc-primary{border-color:var(--dc-primary)}.ring-dc-primary{--tw-ring-color:var(--dc-primary)}.bg-dc-success{background-color:var(--dc-success)}.bg-dc-success-bg{background-color:var(--dc-success-bg)}.text-dc-success{color:var(--dc-success)}.border-dc-success{border-color:var(--dc-success)}.border-dc-success-border{border-color:var(--dc-success-border)}.bg-dc-warning{background-color:var(--dc-warning)}.bg-dc-warning-bg{background-color:var(--dc-warning-bg)}.text-dc-warning{color:var(--dc-warning)}.border-dc-warning{border-color:var(--dc-warning)}.border-dc-warning-border{border-color:var(--dc-warning-border)}.bg-dc-error{background-color:var(--dc-error)}.bg-dc-error-bg{background-color:var(--dc-error-bg)}.text-dc-error{color:var(--dc-error)}.border-dc-error{border-color:var(--dc-error)}.border-dc-error-border{border-color:var(--dc-error-border)}.bg-dc-info{background-color:var(--dc-info)}.bg-dc-info-bg{background-color:var(--dc-info-bg)}.text-dc-info{color:var(--dc-info)}.border-dc-info{border-color:var(--dc-info)}.border-dc-info-border{border-color:var(--dc-info-border)}.bg-dc-danger{background-color:var(--dc-danger)}.bg-dc-danger-bg{background-color:var(--dc-danger-bg)}.bg-dc-danger-hover{background-color:var(--dc-danger-hover)}.text-dc-danger{color:var(--dc-danger)}.border-dc-danger{border-color:var(--dc-danger)}.bg-dc-accent{background-color:var(--dc-accent)}.bg-dc-accent-bg{background-color:var(--dc-accent-bg)}.bg-dc-accent-hover{background-color:var(--dc-accent-hover)}.text-dc-accent{color:var(--dc-accent)}.text-dc-accent-text{color:var(--dc-accent-text)}.border-dc-accent{border-color:var(--dc-accent)}.border-dc-accent-border{border-color:var(--dc-accent-border)}.ring-dc-accent{--tw-ring-color:var(--dc-accent)}.bg-dc-card-bg{background-color:var(--dc-card-bg)}.bg-dc-card-bg-hover{background-color:var(--dc-card-bg-hover)}.border-dc-card-border{border-color:var(--dc-card-border)}.border-dc-card-border-hover{border-color:var(--dc-card-border-hover)}.bg-dc-muted{background-color:var(--dc-muted)}.bg-dc-muted-bg{background-color:var(--dc-muted-bg)}.text-dc-muted{color:var(--dc-muted)}.border-dc-muted{border-color:var(--dc-muted)}.border-dc-muted-border{border-color:var(--dc-muted-border)}.bg-dc-dimension{background-color:var(--dc-dimension-bg)}.text-dc-dimension,.text-dc-dimension-text{color:var(--dc-dimension-text)}.border-dc-dimension{border-color:var(--dc-dimension-border)}.bg-dc-time-dimension{background-color:var(--dc-time-dimension-bg)}.text-dc-time-dimension,.text-dc-time-dimension-text{color:var(--dc-time-dimension-text)}.border-dc-time-dimension{border-color:var(--dc-time-dimension-border)}.bg-dc-measure{background-color:var(--dc-measure-bg)}.text-dc-measure,.text-dc-measure-text{color:var(--dc-measure-text)}.border-dc-measure{border-color:var(--dc-measure-border)}.bg-dc-filter{background-color:var(--dc-filter-bg)}.text-dc-filter,.text-dc-filter-text{color:var(--dc-filter-text)}.border-dc-filter{border-color:var(--dc-filter-border)}.hover\:bg-dc-surface-hover:hover{background-color:var(--dc-surface-hover)}.hover\:border-dc-border-hover:hover{border-color:var(--dc-border-hover)}.hover\:bg-dc-primary-hover:hover{background-color:var(--dc-primary-hover)}.hover\:bg-dc-danger-hover:hover{background-color:var(--dc-danger-hover)}.hover\:bg-dc-accent-hover:hover{background-color:var(--dc-accent-hover)}.hover\:border-dc-accent:hover{border-color:var(--dc-accent)}.hover\:bg-dc-card-bg-hover:hover{background-color:var(--dc-card-bg-hover)}.hover\:border-dc-card-border-hover:hover{border-color:var(--dc-card-border-hover)}.hover\:text-dc-primary:hover{color:var(--dc-primary)}.hover\:text-dc-accent:hover{color:var(--dc-accent)}.hover\:text-dc-danger:hover{color:var(--dc-danger)}.focus\:ring-dc-primary:focus{--tw-ring-color:var(--dc-primary)}.focus\:ring-dc-accent:focus{--tw-ring-color:var(--dc-accent)}.focus\:border-dc-primary:focus{border-color:var(--dc-primary)}.focus\:border-dc-accent:focus{border-color:var(--dc-accent)}.placeholder-dc-text-muted::placeholder{color:var(--dc-text-muted)}.placeholder-dc-text-disabled::placeholder{color:var(--dc-text-disabled)}}:root{--dc-surface:#fff;--dc-surface-secondary:#f9fafb;--dc-surface-tertiary:#f3f4f6;--dc-surface-hover:#f3f4f6;--dc-text:#111827;--dc-text-secondary:#374151;--dc-text-muted:#6b7280;--dc-text-disabled:#9ca3af;--dc-border:#e5e7eb;--dc-border-secondary:#d1d5db;--dc-border-hover:#d1d5db;--dc-primary:#3b82f6;--dc-primary-hover:#2563eb;--dc-primary-content:#fff;--dc-success:#10b981;--dc-success-bg:#d1fae5;--dc-success-border:#6ee7b7;--dc-warning:#f59e0b;--dc-warning-bg:#fef3c7;--dc-warning-border:#fcd34d;--dc-error:#ef4444;--dc-error-bg:#fee2e2;--dc-error-border:#fca5a5;--dc-info:#3b82f6;--dc-info-bg:#dbeafe;--dc-info-border:#93c5fd;--dc-danger:#dc2626;--dc-danger-hover:#b91c1c;--dc-danger-bg:#fee2e2;--dc-dimension-bg:#bbf7d0;--dc-dimension-text:#15803d;--dc-dimension-border:#86efac;--dc-time-dimension-bg:#bfdbfe;--dc-time-dimension-text:#1d4ed8;--dc-time-dimension-border:#60a5fa;--dc-measure-bg:#fde68a;--dc-measure-text:#b45309;--dc-measure-border:#fbbf24;--dc-filter-bg:#e9d5ff;--dc-filter-text:#7c3aed;--dc-filter-border:#c084fc;--dc-overlay:#000000bf;--dc-overlay-light:#00000080;--dc-shadow-sm:0 1px 2px 0 #0000000d;--dc-shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--dc-shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--dc-shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--dc-shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--dc-shadow-2xl:0 25px 50px -12px #00000040;--dc-card-bg:#fff;--dc-card-bg-hover:#f9fafb;--dc-card-border:#e5e7eb;--dc-card-border-hover:#d1d5db;--dc-accent:#3b82f6;--dc-accent-hover:#2563eb;--dc-accent-bg:#eff6ff;--dc-accent-border:#93c5fd;--dc-accent-text:#fff;--dc-muted:#6b7280;--dc-muted-bg:#f3f4f6;--dc-muted-border:#e5e7eb;--dc-ai-gradient-start:#faf5ff;--dc-ai-gradient-end:#eef2ff}[data-theme=dark],.dark,html.dark{--dc-surface:#1e293b;--dc-surface-secondary:#334155;--dc-surface-tertiary:#475569;--dc-surface-hover:#475569;--dc-text:#f1f5f9;--dc-text-secondary:#e2e8f0;--dc-text-muted:#cbd5e1;--dc-text-disabled:#94a3b8;--dc-border:#475569;--dc-border-secondary:#64748b;--dc-border-hover:#64748b;--dc-primary:#60a5fa;--dc-primary-hover:#3b82f6;--dc-primary-content:#0c4a6e;--dc-success:#34d399;--dc-success-bg:#064e3b;--dc-success-border:#059669;--dc-warning:#fbbf24;--dc-warning-bg:#78350f;--dc-warning-border:#d97706;--dc-error:#f87171;--dc-error-bg:#7f1d1d;--dc-error-border:#dc2626;--dc-info:#60a5fa;--dc-info-bg:#1e3a8a;--dc-info-border:#2563eb;--dc-danger:#ef4444;--dc-danger-hover:#dc2626;--dc-danger-bg:#7f1d1d;--dc-dimension-bg:#22c55e66;--dc-dimension-text:#4ade80;--dc-dimension-border:#22c55e;--dc-time-dimension-bg:#3b82f666;--dc-time-dimension-text:#60a5fa;--dc-time-dimension-border:#3b82f6;--dc-measure-bg:#f59e0b66;--dc-measure-text:#fbbf24;--dc-measure-border:#f59e0b;--dc-filter-bg:#8b5cf666;--dc-filter-text:#c084fc;--dc-filter-border:#a855f7;--dc-overlay:#000000d9;--dc-overlay-light:#0009;--dc-shadow-sm:0 1px 2px 0 #0000004d;--dc-shadow:0 1px 3px 0 #0006, 0 1px 2px -1px #0006;--dc-shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0006;--dc-shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -4px #0006;--dc-shadow-xl:0 20px 25px -5px #0006, 0 8px 10px -6px #0006;--dc-shadow-2xl:0 25px 50px -12px #00000080;--dc-card-bg:#1e293b;--dc-card-bg-hover:#334155;--dc-card-border:#475569;--dc-card-border-hover:#64748b;--dc-accent:#60a5fa;--dc-accent-hover:#3b82f6;--dc-accent-bg:#1e3a8a;--dc-accent-border:#2563eb;--dc-accent-text:#fff;--dc-muted:#94a3b8;--dc-muted-bg:#334155;--dc-muted-border:#475569;--dc-ai-gradient-start:#8b5cf626;--dc-ai-gradient-end:#6366f126}[data-theme=neon],html.neon{--dc-surface:#0a0118;--dc-surface-secondary:#1a0f2e;--dc-surface-tertiary:#2a1f3e;--dc-surface-hover:#3a2f4e;--dc-text:#fff;--dc-text-secondary:#e0e0ff;--dc-text-muted:#b0b0d0;--dc-text-disabled:#808090;--dc-border:#f0f;--dc-border-secondary:#0ff;--dc-border-hover:#0f0;--dc-primary:#0ff;--dc-primary-hover:#0cc;--dc-primary-content:#000;--dc-success:#0f0;--dc-success-bg:#00ff0026;--dc-success-border:#0f0;--dc-warning:#ff0;--dc-warning-bg:#ffff0026;--dc-warning-border:#ff0;--dc-error:#f06;--dc-error-bg:#ff006626;--dc-error-border:#f06;--dc-info:#0ff;--dc-info-bg:#00ffff26;--dc-info-border:#0ff;--dc-danger:#ff1493;--dc-danger-hover:#cc1077;--dc-danger-bg:#ff149326;--dc-dimension-bg:#00ff0059;--dc-dimension-text:#0f0;--dc-dimension-border:#0f0;--dc-time-dimension-bg:#00ffff59;--dc-time-dimension-text:#0ff;--dc-time-dimension-border:#0ff;--dc-measure-bg:#ff00ff59;--dc-measure-text:#f0f;--dc-measure-border:#f0f;--dc-filter-bg:#a855f759;--dc-filter-text:#a855f7;--dc-filter-border:#a855f7;--dc-overlay:#0a0118f2;--dc-overlay-light:#0a0118bf;--dc-shadow-sm:0 0 4px #ff00ff4d;--dc-shadow:0 0 8px #f0f6, 0 0 12px #0ff3;--dc-shadow-md:0 0 12px #ff00ff80, 0 0 20px #00ffff4d;--dc-shadow-lg:0 0 20px #f0f9, 0 0 30px #0ff6;--dc-shadow-xl:0 0 30px #ff00ffb3, 0 0 50px #00ffff80;--dc-shadow-2xl:0 0 50px #f0fc, 0 0 80px #0ff9;--dc-card-bg:#1a0f2e;--dc-card-bg-hover:#2a1f3e;--dc-card-border:#f0f;--dc-card-border-hover:#0ff;--dc-accent:#0ff;--dc-accent-hover:#0cc;--dc-accent-bg:#00ffff26;--dc-accent-border:#0ff;--dc-accent-text:#0a0118;--dc-muted:#b0b0d0;--dc-muted-bg:#2a1f3e;--dc-muted-border:#f0f;--dc-ai-gradient-start:#00ffff1a;--dc-ai-gradient-end:#ff00ff1a}.recharts-surface:focus,.recharts-wrapper:focus,.recharts-area:focus,.recharts-area-area:focus,.recharts-area-curve:focus,.recharts-line:focus,.recharts-line-curve:focus,.recharts-bar:focus,.recharts-pie:focus,.recharts-sector:focus,.recharts-layer:focus,.recharts-wrapper svg:focus,.recharts-wrapper g:focus,.recharts-wrapper path:focus,.recharts-wrapper rect:focus,.recharts-wrapper circle:focus{outline:none}.hljs{background-color:var(--dc-surface-secondary)!important;color:var(--dc-text)!important;padding:.5em!important}.hljs-keyword,.hljs-selector-tag,.hljs-literal,.hljs-section,.hljs-link{color:var(--dc-primary)}.hljs-string,.hljs-attr{color:var(--dc-success)}.hljs-number{color:var(--dc-warning)}.hljs-comment,.hljs-quote{color:var(--dc-text-muted);font-style:italic}.hljs-title,.hljs-class .hljs-title,.hljs-function .hljs-title{color:var(--dc-accent)}.hljs-variable,.hljs-attribute,.hljs-property{color:var(--dc-text-secondary)}.hljs-built_in,.hljs-name{color:var(--dc-info)}.hljs-meta,.hljs-meta-keyword{color:var(--dc-muted)}pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}.react-grid-layout{transition:height .2s;position:relative}.react-grid-item{transition:left .2s,top .2s,width .2s,height .2s}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{z-index:1;will-change:width,height;transition:none}.react-grid-item.react-draggable-dragging{z-index:3;will-change:transform;transition:none}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{opacity:.2;z-index:2;-webkit-user-select:none;user-select:none;background:red;transition-duration:.1s}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{opacity:0;width:20px;height:20px;position:absolute}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";border-bottom:2px solid #0006;border-right:2px solid #0006;width:5px;height:5px;position:absolute;bottom:3px;right:3px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:100% 100%;background-repeat:no-repeat;background-origin:content-box;width:20px;height:20px;padding:0 3px 3px 0;position:absolute}.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-grid-layout{margin:0!important}.react-grid-item{overflow:hidden}.scaled-grid-inner .react-grid-item{transition:none!important}.scaled-grid-inner .react-grid-item.react-grid-placeholder{display:none!important}.dashboard-grid-container{width:100%;position:relative}.mobile-stacked-layout{width:100%}.dc-row-layout{padding-top:var(--dc-top-drop-space,0px);padding-bottom:var(--dc-bottom-drop-space,0px);flex-direction:column;gap:0;display:flex;position:relative}.dc-row-layout-row-wrapper{padding-bottom:var(--dc-row-gap,24px);position:relative}.dc-row-layout-row{align-items:stretch;gap:var(--dc-column-gap,16px);width:100%;display:flex;overflow:hidden}.dc-row-layout-column-wrapper{flex-direction:column;height:100%;display:flex;position:relative}.dc-row-layout-column{z-index:2;height:100%;position:relative}.dc-split-handle{opacity:0;pointer-events:none;z-index:1}.dc-row-layout-editable .dc-split-handle,.dc-row-layout-dragging .dc-split-handle{pointer-events:auto}.dc-row-layout-editable .dc-split-handle:hover,.dc-row-layout-editable .dc-split-handle.dc-drop-zone-active{opacity:1}.dc-column-resize-handle{top:0;bottom:0;left:calc(100% + (var(--dc-column-gap,16px) / 2));width:calc(var(--dc-column-gap,16px) * 3);cursor:col-resize;background:0 0;transition:background .2s,opacity .2s;position:absolute;transform:translate(-50%)}.dc-column-resize-handle:after{content:"";background:var(--dc-border);opacity:0;width:2px;transition:opacity .2s,background .2s,width .2s;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.dc-column-resize-handle:hover,.dc-column-resize-handle.dc-drop-zone-active{background:rgba(var(--dc-primary-rgb),.1)}.dc-column-resize-handle:hover:after,.dc-column-resize-handle.dc-drop-zone-active:after{background:var(--dc-primary);opacity:1;width:8px}.dc-row-resize-handle{left:0;right:0;top:calc(100% - (var(--dc-row-gap,24px) / 2));height:calc(var(--dc-row-gap,24px) * 3);cursor:row-resize;background:0 0;transition:background .2s,opacity .2s;position:absolute;transform:translateY(-50%)}.dc-row-boundary-drop{height:var(--dc-row-gap,24px);cursor:default;opacity:0;position:absolute;left:0;right:0}.dc-row-layout-editable .dc-row-boundary-drop{opacity:0;pointer-events:none}.dc-row-layout-dragging .dc-row-boundary-drop{pointer-events:auto}.dc-row-boundary-drop.dc-drop-zone-active{opacity:1}.dc-row-boundary-drop-top{transform:translateY(calc(-1 * var(--dc-row-gap,24px) / 2));top:0}.dc-row-boundary-drop-bottom{transform:translateY(calc(var(--dc-row-gap,24px) / 2));bottom:0}.dc-row-boundary-drop:after{content:"";background:var(--dc-border);opacity:0;height:2px;transition:opacity .2s,background .2s,height .2s;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.dc-row-boundary-drop.dc-drop-zone-active{background:rgba(var(--dc-primary-rgb),.1)}.dc-row-boundary-drop.dc-drop-zone-active:after{background:var(--dc-primary);opacity:1;height:8px}.dc-row-resize-handle:after{content:"";background:var(--dc-border);opacity:0;height:2px;transition:opacity .2s,background .2s,height .2s;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.dc-row-resize-handle:hover,.dc-row-resize-handle.dc-drop-zone-active{background:rgba(var(--dc-primary-rgb),.1)}.dc-row-resize-handle:hover:after,.dc-row-resize-handle.dc-drop-zone-active:after{background:var(--dc-primary);opacity:1;height:8px}.dc-row-resize-handle-drop-only{cursor:default}.dc-row-resize-handle-drop-only:hover:not(.dc-drop-zone-active){background:0 0}.dc-row-resize-handle-drop-only:hover:not(.dc-drop-zone-active):after{background:var(--dc-border);opacity:0;height:2px}.dc-row-edge-drop{width:calc(var(--dc-column-gap,16px) * 3);z-index:1;background:0 0;transition:background .2s;position:absolute;top:0;bottom:0}.dc-row-layout-editable .dc-row-edge-drop{opacity:0;pointer-events:none}.dc-row-layout-dragging .dc-row-edge-drop{opacity:0;pointer-events:auto;z-index:5}.dc-row-edge-drop.dc-drop-zone-active{opacity:1}.dc-row-edge-drop-left{transform:translate(calc(-1 * var(--dc-column-gap,16px)));left:0}.dc-row-edge-drop-right{transform:translate(var(--dc-column-gap,16px));right:0}.dc-row-edge-drop:after{content:"";background:var(--dc-border);opacity:0;width:2px;transition:opacity .2s,background .2s,width .2s;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.dc-row-edge-drop.dc-drop-zone-active{background:rgba(var(--dc-primary-rgb),.1)}.dc-row-edge-drop.dc-drop-zone-active:after{background:var(--dc-primary);opacity:1;width:8px}.dc-row-resize-handle-drop{position:relative}@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-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}
|