@nationaldesignstudio/react 0.0.8 → 0.0.10
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/components/atoms/button/button.d.ts +1 -1
- package/dist/components/atoms/button/icon-button.d.ts +20 -0
- package/dist/components/organisms/navbar/navbar.d.ts +1 -0
- package/dist/index.js +4659 -1876
- package/dist/index.js.map +1 -1
- package/dist/tailwind.css +1 -15
- package/dist/tokens.css +73 -1389
- package/package.json +5 -6
- package/src/components/atoms/accordion/accordion.stories.tsx +1 -1
- package/src/components/atoms/button/button.stories.tsx +0 -9
- package/src/components/atoms/button/button.tsx +1 -1
- package/src/components/atoms/button/icon-button.stories.tsx +0 -9
- package/src/components/atoms/button/icon-button.tsx +35 -0
- package/src/components/atoms/pager-control/pager-control.stories.tsx +0 -3
- package/src/components/organisms/navbar/navbar.tsx +31 -79
- package/src/components/sections/banner/banner.tsx +3 -5
- package/src/components/sections/faq-section/faq-section.tsx +2 -1
- package/src/components/sections/hero/hero.tsx +1 -0
- package/src/components/sections/tout/tout.tsx +1 -0
- package/src/components/sections/two-column-section/two-column-section.tsx +8 -11
- package/src/stories/TokenShowcase.stories.tsx +3 -3
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useControlled.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useRefWithInit.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useStableCallback.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useIsoLayoutEffect.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/warn.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/list/CompositeListContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/list/CompositeList.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/direction-provider/DirectionContext.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/formatErrorMessage.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/root/AccordionRootContext.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useMergedRefs.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/reactVersion.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/getReactElementRef.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/mergeObjects.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/getStateAttributesProps.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/resolveClassName.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/resolveStyle.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/merge-props/mergeProps.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/empty.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useRenderElement.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/reason-parts.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/createBaseUIEventDetails.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/root/AccordionRoot.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/safeReact.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useId.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useBaseUiId.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useOnMount.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useAnimationFrame.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/resolveRef.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useAnimationsFinished.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useTransitionStatus.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/root/useCollapsibleRoot.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/root/CollapsibleRootContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/list/useCompositeListItem.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/item/AccordionItemContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/stateAttributesMapping.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/panel/CollapsiblePanelDataAttributes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/trigger/CollapsibleTriggerDataAttributes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/collapsibleOpenStateMapping.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/item/AccordionItemDataAttributes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/item/stateAttributesMapping.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/item/AccordionItem.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/header/AccordionHeader.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/isElementDisabled.js","../../../node_modules/.bun/@floating-ui+utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/error.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/root/CompositeRootContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useFocusableWhenDisabled.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/use-button/useButton.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/event.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/composite.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/trigger/AccordionTrigger.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/root/AccordionRootDataAttributes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/panel/useCollapsiblePanel.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/panel/AccordionPanelCssVars.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useValueAsRef.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useOpenChangeComplete.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/panel/AccordionPanel.js","../../../node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.mjs","../../../node_modules/.bun/tailwind-merge@3.4.0/node_modules/tailwind-merge/dist/bundle-mjs.mjs","../src/lib/utils.ts","../src/components/atoms/accordion/accordion.tsx","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/button/Button.js","../../../node_modules/.bun/class-variance-authority@0.7.1/node_modules/class-variance-authority/dist/index.mjs","../src/components/atoms/button/button.tsx","../../../node_modules/.bun/@radix-ui+react-compose-refs@1.1.2+e2cc400bcbee7045/node_modules/@radix-ui/react-compose-refs/dist/index.mjs","../../../node_modules/.bun/@radix-ui+react-slot@1.2.4+e2cc400bcbee7045/node_modules/@radix-ui/react-slot/dist/index.mjs","../src/components/atoms/button/icon-button.tsx","../src/components/atoms/pager-control/pager-control.tsx","../src/components/organisms/card/card.tsx","../src/components/organisms/navbar/navbar.tsx","../src/components/organisms/us-gov-banner/us-gov-banner.tsx","../src/components/sections/banner/banner.tsx","../src/components/sections/card-grid/card-grid.tsx","../src/components/sections/two-column-section/two-column-section.tsx","../src/components/sections/faq-section/faq-section.tsx","../src/components/sections/hero/hero.tsx","../src/components/sections/prose/prose.tsx","../src/components/sections/river/river.tsx","../src/components/sections/tout/tout.tsx"],"sourcesContent":["'use client';\n\n// TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler -- process.env never changes, dependency arrays are intentionally ignored\n/* eslint-disable react-hooks/rules-of-hooks, react-hooks/exhaustive-deps */\nimport * as React from 'react';\nexport function useControlled({\n controlled,\n default: defaultProp,\n name,\n state = 'value'\n}) {\n // isControlled is ignored in the hook dependency lists as it should never change.\n const {\n current: isControlled\n } = React.useRef(controlled !== undefined);\n const [valueState, setValue] = React.useState(defaultProp);\n const value = isControlled ? controlled : valueState;\n if (process.env.NODE_ENV !== 'production') {\n React.useEffect(() => {\n if (isControlled !== (controlled !== undefined)) {\n console.error([`Base UI: A component is changing the ${isControlled ? '' : 'un'}controlled ${state} state of ${name} to be ${isControlled ? 'un' : ''}controlled.`, 'Elements should not switch from uncontrolled to controlled (or vice versa).', `Decide between using a controlled or uncontrolled ${name} ` + 'element for the lifetime of the component.', \"The nature of the state is determined during the first render. It's considered controlled if the value is not `undefined`.\", 'More info: https://fb.me/react-controlled-components'].join('\\n'));\n }\n }, [state, name, controlled]);\n const {\n current: defaultValue\n } = React.useRef(defaultProp);\n React.useEffect(() => {\n // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is for more details.\n if (!isControlled && JSON.stringify(defaultValue) !== JSON.stringify(defaultProp)) {\n console.error([`Base UI: A component is changing the default ${state} state of an uncontrolled ${name} after being initialized. ` + `To suppress this warning opt to use a controlled ${name}.`].join('\\n'));\n }\n }, [JSON.stringify(defaultProp)]);\n }\n const setValueIfUncontrolled = React.useCallback(newValue => {\n if (!isControlled) {\n setValue(newValue);\n }\n }, []);\n return [value, setValueIfUncontrolled];\n}","'use client';\n\nimport * as React from 'react';\nconst UNINITIALIZED = {};\n\n/**\n * A React.useRef() that is initialized with a function. Note that it accepts an optional\n * initialization argument, so the initialization function doesn't need to be an inline closure.\n *\n * @usage\n * const ref = useRefWithInit(sortColumns, columns)\n */\n\nexport function useRefWithInit(init, initArg) {\n const ref = React.useRef(UNINITIALIZED);\n if (ref.current === UNINITIALIZED) {\n ref.current = init(initArg);\n }\n return ref;\n}","'use client';\n\nimport * as React from 'react';\nimport { useRefWithInit } from \"./useRefWithInit.js\";\n\n// https://github.com/mui/material-ui/issues/41190#issuecomment-2040873379\nconst useInsertionEffect = React[`useInsertionEffect${Math.random().toFixed(1)}`.slice(0, -3)];\nconst useSafeInsertionEffect =\n// React 17 doesn't have useInsertionEffect.\nuseInsertionEffect &&\n// Preact replaces useInsertionEffect with useLayoutEffect and fires too late.\nuseInsertionEffect !== React.useLayoutEffect ? useInsertionEffect : fn => fn();\n/**\n * Stabilizes the function passed so it's always the same between renders.\n *\n * The function becomes non-reactive to any values it captures.\n * It can safely be passed as a dependency of `React.useMemo` and `React.useEffect` without re-triggering them if its captured values change.\n *\n * The function must only be called inside effects and event handlers, never during render (which throws an error).\n *\n * This hook is a more permissive version of React 19.2's `React.useEffectEvent` in that it can be passed through contexts and called in event handler props, not just effects.\n */\nexport function useStableCallback(callback) {\n const stable = useRefWithInit(createStableCallback).current;\n stable.next = callback;\n useSafeInsertionEffect(stable.effect);\n return stable.trampoline;\n}\nfunction createStableCallback() {\n const stable = {\n next: undefined,\n callback: assertNotCalled,\n trampoline: (...args) => stable.callback?.(...args),\n effect: () => {\n stable.callback = stable.next;\n }\n };\n return stable;\n}\nfunction assertNotCalled() {\n if (process.env.NODE_ENV !== 'production') {\n throw new Error('Base UI: Cannot call an event handler while rendering.');\n }\n}","'use client';\n\nimport * as React from 'react';\nconst noop = () => {};\nexport const useIsoLayoutEffect = typeof document !== 'undefined' ? React.useLayoutEffect : noop;","let set;\nif (process.env.NODE_ENV !== 'production') {\n set = new Set();\n}\nexport function warn(...messages) {\n if (process.env.NODE_ENV !== 'production') {\n const messageKey = messages.join(' ');\n if (!set.has(messageKey)) {\n set.add(messageKey);\n console.warn(`Base UI: ${messageKey}`);\n }\n }\n}","'use client';\n\nimport * as React from 'react';\nexport const CompositeListContext = /*#__PURE__*/React.createContext({\n register: () => {},\n unregister: () => {},\n subscribeMapChange: () => {\n return () => {};\n },\n elementsRef: {\n current: []\n },\n nextIndexRef: {\n current: 0\n }\n});\nif (process.env.NODE_ENV !== \"production\") CompositeListContext.displayName = \"CompositeListContext\";\nexport function useCompositeListContext() {\n return React.useContext(CompositeListContext);\n}","/* eslint-disable no-bitwise */\n'use client';\n\nimport * as React from 'react';\nimport { useRefWithInit } from '@base-ui-components/utils/useRefWithInit';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { CompositeListContext } from \"./CompositeListContext.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\n/**\n * Provides context for a list of items in a composite component.\n * @internal\n */\nexport function CompositeList(props) {\n const {\n children,\n elementsRef,\n labelsRef,\n onMapChange: onMapChangeProp\n } = props;\n const onMapChange = useStableCallback(onMapChangeProp);\n const nextIndexRef = React.useRef(0);\n const listeners = useRefWithInit(createListeners).current;\n\n // We use a stable `map` to avoid O(n^2) re-allocation costs for large lists.\n // `mapTick` is our re-render trigger mechanism. We also need to update the\n // elements and label refs, but there's a lot of async work going on and sometimes\n // the effect that handles `onMapChange` gets called after those refs have been\n // filled, and we don't want to lose those values by setting their lengths to `0`.\n // We also need to have them at the proper length because floating-ui uses that\n // information for list navigation.\n\n const map = useRefWithInit(createMap).current;\n // `mapTick` uses a counter rather than objects for low precision-loss risk and better memory efficiency\n const [mapTick, setMapTick] = React.useState(0);\n const lastTickRef = React.useRef(mapTick);\n const register = useStableCallback((node, metadata) => {\n map.set(node, metadata ?? null);\n lastTickRef.current += 1;\n setMapTick(lastTickRef.current);\n });\n const unregister = useStableCallback(node => {\n map.delete(node);\n lastTickRef.current += 1;\n setMapTick(lastTickRef.current);\n });\n const sortedMap = React.useMemo(() => {\n // `mapTick` is the `useMemo` trigger as `map` is stable.\n disableEslintWarning(mapTick);\n const newMap = new Map();\n // Filter out disconnected elements before sorting to avoid inconsistent\n // compareDocumentPosition results when elements are detached from the DOM.\n const sortedNodes = Array.from(map.keys()).filter(node => node.isConnected).sort(sortByDocumentPosition);\n sortedNodes.forEach((node, index) => {\n const metadata = map.get(node) ?? {};\n newMap.set(node, {\n ...metadata,\n index\n });\n });\n return newMap;\n }, [map, mapTick]);\n useIsoLayoutEffect(() => {\n if (typeof MutationObserver !== 'function' || sortedMap.size === 0) {\n return undefined;\n }\n const mutationObserver = new MutationObserver(entries => {\n const diff = new Set();\n const updateDiff = node => diff.has(node) ? diff.delete(node) : diff.add(node);\n entries.forEach(entry => {\n entry.removedNodes.forEach(updateDiff);\n entry.addedNodes.forEach(updateDiff);\n });\n if (diff.size === 0) {\n lastTickRef.current += 1;\n setMapTick(lastTickRef.current);\n }\n });\n sortedMap.forEach((_, node) => {\n if (node.parentElement) {\n mutationObserver.observe(node.parentElement, {\n childList: true\n });\n }\n });\n return () => {\n mutationObserver.disconnect();\n };\n }, [sortedMap]);\n useIsoLayoutEffect(() => {\n const shouldUpdateLengths = lastTickRef.current === mapTick;\n if (shouldUpdateLengths) {\n if (elementsRef.current.length !== sortedMap.size) {\n elementsRef.current.length = sortedMap.size;\n }\n if (labelsRef && labelsRef.current.length !== sortedMap.size) {\n labelsRef.current.length = sortedMap.size;\n }\n nextIndexRef.current = sortedMap.size;\n }\n onMapChange(sortedMap);\n }, [onMapChange, sortedMap, elementsRef, labelsRef, mapTick]);\n useIsoLayoutEffect(() => {\n return () => {\n elementsRef.current = [];\n };\n }, [elementsRef]);\n useIsoLayoutEffect(() => {\n return () => {\n if (labelsRef) {\n labelsRef.current = [];\n }\n };\n }, [labelsRef]);\n const subscribeMapChange = useStableCallback(fn => {\n listeners.add(fn);\n return () => {\n listeners.delete(fn);\n };\n });\n useIsoLayoutEffect(() => {\n listeners.forEach(l => l(sortedMap));\n }, [listeners, sortedMap]);\n const contextValue = React.useMemo(() => ({\n register,\n unregister,\n subscribeMapChange,\n elementsRef,\n labelsRef,\n nextIndexRef\n }), [register, unregister, subscribeMapChange, elementsRef, labelsRef, nextIndexRef]);\n return /*#__PURE__*/_jsx(CompositeListContext.Provider, {\n value: contextValue,\n children: children\n });\n}\nfunction createMap() {\n return new Map();\n}\nfunction createListeners() {\n return new Set();\n}\nfunction sortByDocumentPosition(a, b) {\n const position = a.compareDocumentPosition(b);\n if (position & Node.DOCUMENT_POSITION_FOLLOWING || position & Node.DOCUMENT_POSITION_CONTAINED_BY) {\n return -1;\n }\n if (position & Node.DOCUMENT_POSITION_PRECEDING || position & Node.DOCUMENT_POSITION_CONTAINS) {\n return 1;\n }\n return 0;\n}\nfunction disableEslintWarning(_) {}","'use client';\n\nimport * as React from 'react';\n/**\n * @internal\n */\nexport const DirectionContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") DirectionContext.displayName = \"DirectionContext\";\nexport function useDirection() {\n const context = React.useContext(DirectionContext);\n return context?.direction ?? 'ltr';\n}","/**\n * WARNING: Don't import this directly. It's imported by the code generated by\n * `@mui/interal-babel-plugin-minify-errors`. Make sure to always use string literals in `Error`\n * constructors to ensure the plugin works as expected. Supported patterns include:\n * throw new Error('My message');\n * throw new Error(`My message: ${foo}`);\n * throw new Error(`My message: ${foo}` + 'another string');\n * ...\n */\nexport default function formatErrorMessage(code, ...args) {\n const url = new URL(`https://base-ui.com/production-error/${code}`);\n args.forEach(arg => url.searchParams.append('args[]', arg));\n return `Base UI error #${code}; visit ${url} for the full message.`;\n}","'use client';\n\nimport _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const AccordionRootContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") AccordionRootContext.displayName = \"AccordionRootContext\";\nexport function useAccordionRootContext() {\n const context = React.useContext(AccordionRootContext);\n if (context === undefined) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: AccordionRootContext is missing. Accordion parts must be placed within <Accordion.Root>.' : _formatErrorMessage(10));\n }\n return context;\n}","import { useRefWithInit } from \"./useRefWithInit.js\";\n\n/**\n * Merges refs into a single memoized callback ref or `null`.\n * This makes sure multiple refs are updated together and have the same value.\n *\n * This function accepts up to four refs. If you need to merge more, or have an unspecified number of refs to merge,\n * use `useMergedRefsN` instead.\n */\n\nexport function useMergedRefs(a, b, c, d) {\n const forkRef = useRefWithInit(createForkRef).current;\n if (didChange(forkRef, a, b, c, d)) {\n update(forkRef, [a, b, c, d]);\n }\n return forkRef.callback;\n}\n\n/**\n * Merges an array of refs into a single memoized callback ref or `null`.\n *\n * If you need to merge a fixed number (up to four) of refs, use `useMergedRefs` instead for better performance.\n */\nexport function useMergedRefsN(refs) {\n const forkRef = useRefWithInit(createForkRef).current;\n if (didChangeN(forkRef, refs)) {\n update(forkRef, refs);\n }\n return forkRef.callback;\n}\nfunction createForkRef() {\n return {\n callback: null,\n cleanup: null,\n refs: []\n };\n}\nfunction didChange(forkRef, a, b, c, d) {\n // prettier-ignore\n return forkRef.refs[0] !== a || forkRef.refs[1] !== b || forkRef.refs[2] !== c || forkRef.refs[3] !== d;\n}\nfunction didChangeN(forkRef, newRefs) {\n return forkRef.refs.length !== newRefs.length || forkRef.refs.some((ref, index) => ref !== newRefs[index]);\n}\nfunction update(forkRef, refs) {\n forkRef.refs = refs;\n if (refs.every(ref => ref == null)) {\n forkRef.callback = null;\n return;\n }\n forkRef.callback = instance => {\n if (forkRef.cleanup) {\n forkRef.cleanup();\n forkRef.cleanup = null;\n }\n if (instance != null) {\n const cleanupCallbacks = Array(refs.length).fill(null);\n for (let i = 0; i < refs.length; i += 1) {\n const ref = refs[i];\n if (ref == null) {\n continue;\n }\n switch (typeof ref) {\n case 'function':\n {\n const refCleanup = ref(instance);\n if (typeof refCleanup === 'function') {\n cleanupCallbacks[i] = refCleanup;\n }\n break;\n }\n case 'object':\n {\n ref.current = instance;\n break;\n }\n default:\n }\n }\n forkRef.cleanup = () => {\n for (let i = 0; i < refs.length; i += 1) {\n const ref = refs[i];\n if (ref == null) {\n continue;\n }\n switch (typeof ref) {\n case 'function':\n {\n const cleanupCallback = cleanupCallbacks[i];\n if (typeof cleanupCallback === 'function') {\n cleanupCallback();\n } else {\n ref(null);\n }\n break;\n }\n case 'object':\n {\n ref.current = null;\n break;\n }\n default:\n }\n }\n };\n }\n };\n}","import * as React from 'react';\nconst majorVersion = parseInt(React.version, 10);\nexport function isReactVersionAtLeast(reactVersionToCheck) {\n return majorVersion >= reactVersionToCheck;\n}","import * as React from 'react';\nimport { isReactVersionAtLeast } from \"./reactVersion.js\";\n\n/**\n * Extracts the `ref` from a React element, handling different React versions.\n */\nexport function getReactElementRef(element) {\n if (! /*#__PURE__*/React.isValidElement(element)) {\n return null;\n }\n const reactElement = element;\n const propsWithRef = reactElement.props;\n return (isReactVersionAtLeast(19) ? propsWithRef?.ref : reactElement.ref) ?? null;\n}","export function mergeObjects(a, b) {\n if (a && !b) {\n return a;\n }\n if (!a && b) {\n return b;\n }\n if (a || b) {\n return {\n ...a,\n ...b\n };\n }\n return undefined;\n}","export function getStateAttributesProps(state, customMapping) {\n const props = {};\n\n /* eslint-disable-next-line guard-for-in */\n for (const key in state) {\n const value = state[key];\n if (customMapping?.hasOwnProperty(key)) {\n const customProps = customMapping[key](value);\n if (customProps != null) {\n Object.assign(props, customProps);\n }\n continue;\n }\n if (value === true) {\n props[`data-${key.toLowerCase()}`] = '';\n } else if (value) {\n props[`data-${key.toLowerCase()}`] = value.toString();\n }\n }\n return props;\n}","/**\n * If the provided className is a string, it will be returned as is.\n * Otherwise, the function will call the className function with the state as the first argument.\n *\n * @param className\n * @param state\n */\nexport function resolveClassName(className, state) {\n return typeof className === 'function' ? className(state) : className;\n}","/**\n * If the provided style is an object, it will be returned as is.\n * Otherwise, the function will call the style function with the state as the first argument.\n *\n * @param style\n * @param state\n */\nexport function resolveStyle(style, state) {\n return typeof style === 'function' ? style(state) : style;\n}","import { mergeObjects } from '@base-ui-components/utils/mergeObjects';\nconst EMPTY_PROPS = {};\n\n/**\n * Merges multiple sets of React props. It follows the Object.assign pattern where the rightmost object's fields overwrite\n * the conflicting ones from others. This doesn't apply to event handlers, `className` and `style` props.\n * Event handlers are merged such that they are called in sequence (the rightmost one being called first),\n * and allows the user to prevent the subsequent event handlers from being\n * executed by attaching a `preventBaseUIHandler` method.\n * It also merges the `className` and `style` props, whereby the classes are concatenated\n * and the rightmost styles overwrite the subsequent ones.\n *\n * Props can either be provided as objects or as functions that take the previous props as an argument.\n * The function will receive the merged props up to that point (going from left to right):\n * so in the case of `(obj1, obj2, fn, obj3)`, `fn` will receive the merged props of `obj1` and `obj2`.\n * The function is responsible for chaining event handlers if needed (i.e. we don't run the merge logic).\n *\n * Event handlers returned by the functions are not automatically prevented when `preventBaseUIHandler` is called.\n * They must check `event.baseUIHandlerPrevented` themselves and bail out if it's true.\n *\n * @important **`ref` is not merged.**\n * @param props props to merge.\n * @returns the merged props.\n */\n/* eslint-disable id-denylist */\n\nexport function mergeProps(a, b, c, d, e) {\n // We need to mutably own `merged`\n let merged = {\n ...resolvePropsGetter(a, EMPTY_PROPS)\n };\n if (b) {\n merged = mergeOne(merged, b);\n }\n if (c) {\n merged = mergeOne(merged, c);\n }\n if (d) {\n merged = mergeOne(merged, d);\n }\n if (e) {\n merged = mergeOne(merged, e);\n }\n return merged;\n}\n/* eslint-enable id-denylist */\n\nexport function mergePropsN(props) {\n if (props.length === 0) {\n return EMPTY_PROPS;\n }\n if (props.length === 1) {\n return resolvePropsGetter(props[0], EMPTY_PROPS);\n }\n\n // We need to mutably own `merged`\n let merged = {\n ...resolvePropsGetter(props[0], EMPTY_PROPS)\n };\n for (let i = 1; i < props.length; i += 1) {\n merged = mergeOne(merged, props[i]);\n }\n return merged;\n}\nfunction mergeOne(merged, inputProps) {\n if (isPropsGetter(inputProps)) {\n return inputProps(merged);\n }\n return mutablyMergeInto(merged, inputProps);\n}\n\n/**\n * Merges two sets of props. In case of conflicts, the external props take precedence.\n */\nfunction mutablyMergeInto(mergedProps, externalProps) {\n if (!externalProps) {\n return mergedProps;\n }\n\n // eslint-disable-next-line guard-for-in\n for (const propName in externalProps) {\n const externalPropValue = externalProps[propName];\n switch (propName) {\n case 'style':\n {\n mergedProps[propName] = mergeObjects(mergedProps.style, externalPropValue);\n break;\n }\n case 'className':\n {\n mergedProps[propName] = mergeClassNames(mergedProps.className, externalPropValue);\n break;\n }\n default:\n {\n if (isEventHandler(propName, externalPropValue)) {\n mergedProps[propName] = mergeEventHandlers(mergedProps[propName], externalPropValue);\n } else {\n mergedProps[propName] = externalPropValue;\n }\n }\n }\n }\n return mergedProps;\n}\nfunction isEventHandler(key, value) {\n // This approach is more efficient than using a regex.\n const code0 = key.charCodeAt(0);\n const code1 = key.charCodeAt(1);\n const code2 = key.charCodeAt(2);\n return code0 === 111 /* o */ && code1 === 110 /* n */ && code2 >= 65 /* A */ && code2 <= 90 /* Z */ && (typeof value === 'function' || typeof value === 'undefined');\n}\nfunction isPropsGetter(inputProps) {\n return typeof inputProps === 'function';\n}\nfunction resolvePropsGetter(inputProps, previousProps) {\n if (isPropsGetter(inputProps)) {\n return inputProps(previousProps);\n }\n return inputProps ?? EMPTY_PROPS;\n}\nfunction mergeEventHandlers(ourHandler, theirHandler) {\n if (!theirHandler) {\n return ourHandler;\n }\n if (!ourHandler) {\n return theirHandler;\n }\n return event => {\n if (isSyntheticEvent(event)) {\n const baseUIEvent = event;\n makeEventPreventable(baseUIEvent);\n const result = theirHandler(baseUIEvent);\n if (!baseUIEvent.baseUIHandlerPrevented) {\n ourHandler?.(baseUIEvent);\n }\n return result;\n }\n const result = theirHandler(event);\n ourHandler?.(event);\n return result;\n };\n}\nexport function makeEventPreventable(event) {\n event.preventBaseUIHandler = () => {\n event.baseUIHandlerPrevented = true;\n };\n return event;\n}\nexport function mergeClassNames(ourClassName, theirClassName) {\n if (theirClassName) {\n if (ourClassName) {\n // eslint-disable-next-line prefer-template\n return theirClassName + ' ' + ourClassName;\n }\n return theirClassName;\n }\n return ourClassName;\n}\nfunction isSyntheticEvent(event) {\n return event != null && typeof event === 'object' && 'nativeEvent' in event;\n}","export function NOOP() {}\nexport const EMPTY_ARRAY = Object.freeze([]);\nexport const EMPTY_OBJECT = Object.freeze({});","import _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nimport { useMergedRefs, useMergedRefsN } from '@base-ui-components/utils/useMergedRefs';\nimport { getReactElementRef } from '@base-ui-components/utils/getReactElementRef';\nimport { mergeObjects } from '@base-ui-components/utils/mergeObjects';\nimport { getStateAttributesProps } from \"./getStateAttributesProps.js\";\nimport { resolveClassName } from \"./resolveClassName.js\";\nimport { resolveStyle } from \"./resolveStyle.js\";\nimport { mergeProps, mergePropsN, mergeClassNames } from \"../merge-props/index.js\";\nimport { EMPTY_OBJECT } from \"./constants.js\";\nimport { createElement as _createElement } from \"react\";\n/**\n * Renders a Base UI element.\n *\n * @param element The default HTML element to render. Can be overridden by the `render` prop.\n * @param componentProps An object containing the `render` and `className` props to be used for element customization. Other props are ignored.\n * @param params Additional parameters for rendering the element.\n */\nexport function useRenderElement(element, componentProps, params = {}) {\n const renderProp = componentProps.render;\n const outProps = useRenderElementProps(componentProps, params);\n if (params.enabled === false) {\n return null;\n }\n const state = params.state ?? EMPTY_OBJECT;\n return evaluateRenderProp(element, renderProp, outProps, state);\n}\n\n/**\n * Computes render element final props.\n */\nfunction useRenderElementProps(componentProps, params = {}) {\n const {\n className: classNameProp,\n style: styleProp,\n render: renderProp\n } = componentProps;\n const {\n state = EMPTY_OBJECT,\n ref,\n props,\n stateAttributesMapping,\n enabled = true\n } = params;\n const className = enabled ? resolveClassName(classNameProp, state) : undefined;\n const style = enabled ? resolveStyle(styleProp, state) : undefined;\n const stateProps = enabled ? getStateAttributesProps(state, stateAttributesMapping) : EMPTY_OBJECT;\n const outProps = enabled ? mergeObjects(stateProps, Array.isArray(props) ? mergePropsN(props) : props) ?? EMPTY_OBJECT : EMPTY_OBJECT;\n\n // SAFETY: The `useMergedRefs` functions use a single hook to store the same value,\n // switching between them at runtime is safe. If this assertion fails, React will\n // throw at runtime anyway.\n // This also skips the `useMergedRefs` call on the server, which is fine because\n // refs are not used on the server side.\n /* eslint-disable react-hooks/rules-of-hooks */\n if (typeof document !== 'undefined') {\n if (!enabled) {\n useMergedRefs(null, null);\n } else if (Array.isArray(ref)) {\n outProps.ref = useMergedRefsN([outProps.ref, getReactElementRef(renderProp), ...ref]);\n } else {\n outProps.ref = useMergedRefs(outProps.ref, getReactElementRef(renderProp), ref);\n }\n }\n if (!enabled) {\n return EMPTY_OBJECT;\n }\n if (className !== undefined) {\n outProps.className = mergeClassNames(outProps.className, className);\n }\n if (style !== undefined) {\n outProps.style = mergeObjects(outProps.style, style);\n }\n return outProps;\n}\nfunction evaluateRenderProp(element, render, props, state) {\n if (render) {\n if (typeof render === 'function') {\n return render(props, state);\n }\n const mergedProps = mergeProps(props, render.props);\n mergedProps.ref = props.ref;\n return /*#__PURE__*/React.cloneElement(render, mergedProps);\n }\n if (element) {\n if (typeof element === 'string') {\n return renderTag(element, props);\n }\n }\n // Unreachable, but the typings on `useRenderElement` need to be reworked\n // to annotate it correctly.\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: Render element or function are not defined.' : _formatErrorMessage(8));\n}\nfunction renderTag(Tag, props) {\n if (Tag === 'button') {\n return /*#__PURE__*/_createElement(\"button\", {\n type: \"button\",\n ...props,\n key: props.key\n });\n }\n if (Tag === 'img') {\n return /*#__PURE__*/_createElement(\"img\", {\n alt: \"\",\n ...props,\n key: props.key\n });\n }\n return /*#__PURE__*/React.createElement(Tag, props);\n}","export const none = 'none';\nexport const triggerPress = 'trigger-press';\nexport const triggerHover = 'trigger-hover';\nexport const triggerFocus = 'trigger-focus';\nexport const outsidePress = 'outside-press';\nexport const itemPress = 'item-press';\nexport const closePress = 'close-press';\nexport const linkPress = 'link-press';\nexport const clearPress = 'clear-press';\nexport const chipRemovePress = 'chip-remove-press';\nexport const trackPress = 'track-press';\nexport const incrementPress = 'increment-press';\nexport const decrementPress = 'decrement-press';\nexport const inputChange = 'input-change';\nexport const inputClear = 'input-clear';\nexport const inputBlur = 'input-blur';\nexport const inputPaste = 'input-paste';\nexport const focusOut = 'focus-out';\nexport const escapeKey = 'escape-key';\nexport const listNavigation = 'list-navigation';\nexport const keyboard = 'keyboard';\nexport const pointer = 'pointer';\nexport const drag = 'drag';\nexport const wheel = 'wheel';\nexport const scrub = 'scrub';\nexport const cancelOpen = 'cancel-open';\nexport const siblingOpen = 'sibling-open';\nexport const disabled = 'disabled';\nexport const imperativeAction = 'imperative-action';\nexport const windowResize = 'window-resize';","import { EMPTY_OBJECT } from \"./constants.js\";\nimport { REASONS } from \"./reasons.js\";\n\n/**\n * Maps a change `reason` string to the corresponding native event type.\n */\n\n/**\n * Details of custom change events emitted by Base UI components.\n */\n\n/**\n * Details of custom generic events emitted by Base UI components.\n */\n\n/**\n * Creates a Base UI event details object with the given reason and utilities\n * for preventing Base UI's internal event handling.\n */\nexport function createChangeEventDetails(reason, event, trigger, customProperties) {\n let canceled = false;\n let allowPropagation = false;\n const custom = customProperties ?? EMPTY_OBJECT;\n const details = {\n reason,\n event: event ?? new Event('base-ui'),\n cancel() {\n canceled = true;\n },\n allowPropagation() {\n allowPropagation = true;\n },\n get isCanceled() {\n return canceled;\n },\n get isPropagationAllowed() {\n return allowPropagation;\n },\n trigger,\n ...custom\n };\n return details;\n}\nexport function createGenericEventDetails(reason, event, customProperties) {\n const custom = customProperties ?? EMPTY_OBJECT;\n const details = {\n reason,\n event: event ?? new Event('base-ui'),\n ...custom\n };\n return details;\n}","'use client';\n\nimport * as React from 'react';\nimport { useControlled } from '@base-ui-components/utils/useControlled';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { warn } from '@base-ui-components/utils/warn';\nimport { CompositeList } from \"../../composite/list/CompositeList.js\";\nimport { useDirection } from \"../../direction-provider/DirectionContext.js\";\nimport { AccordionRootContext } from \"./AccordionRootContext.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst rootStateAttributesMapping = {\n value: () => null\n};\n\n/**\n * Groups all parts of the accordion.\n * Renders a `<div>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\nexport const AccordionRoot = /*#__PURE__*/React.forwardRef(function AccordionRoot(componentProps, forwardedRef) {\n const {\n render,\n className,\n disabled = false,\n hiddenUntilFound: hiddenUntilFoundProp,\n keepMounted: keepMountedProp,\n loopFocus = true,\n onValueChange: onValueChangeProp,\n multiple = false,\n orientation = 'vertical',\n value: valueProp,\n defaultValue: defaultValueProp,\n ...elementProps\n } = componentProps;\n const direction = useDirection();\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useIsoLayoutEffect(() => {\n if (hiddenUntilFoundProp && keepMountedProp === false) {\n warn('The `keepMounted={false}` prop on a Accordion.Root will be ignored when using `hiddenUntilFound` since it requires Panels to remain mounted when closed.');\n }\n }, [hiddenUntilFoundProp, keepMountedProp]);\n }\n\n // memoized to allow omitting both defaultValue and value\n // which would otherwise trigger a warning in useControlled\n const defaultValue = React.useMemo(() => {\n if (valueProp === undefined) {\n return defaultValueProp ?? [];\n }\n return undefined;\n }, [valueProp, defaultValueProp]);\n const onValueChange = useStableCallback(onValueChangeProp);\n const accordionItemRefs = React.useRef([]);\n const [value, setValue] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: 'Accordion',\n state: 'value'\n });\n const handleValueChange = useStableCallback((newValue, nextOpen) => {\n const details = createChangeEventDetails(REASONS.none);\n if (!multiple) {\n const nextValue = value[0] === newValue ? [] : [newValue];\n onValueChange(nextValue, details);\n if (details.isCanceled) {\n return;\n }\n setValue(nextValue);\n } else if (nextOpen) {\n const nextOpenValues = value.slice();\n nextOpenValues.push(newValue);\n onValueChange(nextOpenValues, details);\n if (details.isCanceled) {\n return;\n }\n setValue(nextOpenValues);\n } else {\n const nextOpenValues = value.filter(v => v !== newValue);\n onValueChange(nextOpenValues, details);\n if (details.isCanceled) {\n return;\n }\n setValue(nextOpenValues);\n }\n });\n const state = React.useMemo(() => ({\n value,\n disabled,\n orientation\n }), [value, disabled, orientation]);\n const contextValue = React.useMemo(() => ({\n accordionItemRefs,\n direction,\n disabled,\n handleValueChange,\n hiddenUntilFound: hiddenUntilFoundProp ?? false,\n keepMounted: keepMountedProp ?? false,\n loopFocus,\n orientation,\n state,\n value\n }), [direction, disabled, handleValueChange, hiddenUntilFoundProp, keepMountedProp, loopFocus, orientation, state, value]);\n const element = useRenderElement('div', componentProps, {\n state,\n ref: forwardedRef,\n props: [{\n dir: direction,\n role: 'region'\n }, elementProps],\n stateAttributesMapping: rootStateAttributesMapping\n });\n return /*#__PURE__*/_jsx(AccordionRootContext.Provider, {\n value: contextValue,\n children: /*#__PURE__*/_jsx(CompositeList, {\n elementsRef: accordionItemRefs,\n children: element\n })\n });\n});\nif (process.env.NODE_ENV !== \"production\") AccordionRoot.displayName = \"AccordionRoot\";","import * as React from 'react';\n\n// https://github.com/mui/material-ui/issues/41190#issuecomment-2040873379\nexport const SafeReact = {\n ...React\n};","'use client';\n\nimport * as React from 'react';\nimport { SafeReact } from \"./safeReact.js\";\nlet globalId = 0;\n\n// TODO React 17: Remove `useGlobalId` once React 17 support is removed\nfunction useGlobalId(idOverride, prefix = 'mui') {\n const [defaultId, setDefaultId] = React.useState(idOverride);\n const id = idOverride || defaultId;\n React.useEffect(() => {\n if (defaultId == null) {\n // Fallback to this default id when possible.\n // Use the incrementing value for client-side rendering only.\n // We can't use it server-side.\n // If you want to use random values please consider the Birthday Problem: https://en.wikipedia.org/wiki/Birthday_problem\n globalId += 1;\n setDefaultId(`${prefix}-${globalId}`);\n }\n }, [defaultId, prefix]);\n return id;\n}\nconst maybeReactUseId = SafeReact.useId;\n\n/**\n *\n * @example <div id={useId()} />\n * @param idOverride\n * @returns {string}\n */\nexport function useId(idOverride, prefix) {\n // React.useId() is only available from React 17.0.0.\n if (maybeReactUseId !== undefined) {\n const reactId = maybeReactUseId();\n return idOverride ?? (prefix ? `${prefix}-${reactId}` : reactId);\n }\n\n // TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler\n // eslint-disable-next-line react-hooks/rules-of-hooks -- `React.useId` is invariant at runtime.\n return useGlobalId(idOverride, prefix);\n}","'use client';\n\nimport { useId } from '@base-ui-components/utils/useId';\n\n/**\n * Wraps `useId` and prefixes generated `id`s with `base-ui-`\n * @param {string | undefined} idOverride overrides the generated id when provided\n * @returns {string | undefined}\n */\nexport function useBaseUiId(idOverride) {\n return useId(idOverride, 'base-ui');\n}","'use client';\n\nimport * as React from 'react';\nconst EMPTY = [];\n\n/**\n * A React.useEffect equivalent that runs once, when the component is mounted.\n */\nexport function useOnMount(fn) {\n // TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler -- no need to put `fn` in the dependency array\n /* eslint-disable react-hooks/exhaustive-deps */\n React.useEffect(fn, EMPTY);\n /* eslint-enable react-hooks/exhaustive-deps */\n}","'use client';\n\nimport { useRefWithInit } from \"./useRefWithInit.js\";\nimport { useOnMount } from \"./useOnMount.js\";\n/** Unlike `setTimeout`, rAF doesn't guarantee a positive integer return value, so we can't have\n * a monomorphic `uint` type with `0` meaning empty.\n * See warning note at:\n * https://developer.mozilla.org/en-US/docs/Web/API/Window/requestAnimationFrame#return_value */\nconst EMPTY = null;\nlet LAST_RAF = globalThis.requestAnimationFrame;\nclass Scheduler {\n /* This implementation uses an array as a backing data-structure for frame callbacks.\n * It allows `O(1)` callback cancelling by inserting a `null` in the array, though it\n * never calls the native `cancelAnimationFrame` if there are no frames left. This can\n * be much more efficient if there is a call pattern that alterns as\n * \"request-cancel-request-cancel-…\".\n * But in the case of \"request-request-…-cancel-cancel-…\", it leaves the final animation\n * frame to run anyway. We turn that frame into a `O(1)` no-op via `callbacksCount`. */\n\n callbacks = [];\n callbacksCount = 0;\n nextId = 1;\n startId = 1;\n isScheduled = false;\n tick = timestamp => {\n this.isScheduled = false;\n const currentCallbacks = this.callbacks;\n const currentCallbacksCount = this.callbacksCount;\n\n // Update these before iterating, callbacks could call `requestAnimationFrame` again.\n this.callbacks = [];\n this.callbacksCount = 0;\n this.startId = this.nextId;\n if (currentCallbacksCount > 0) {\n for (let i = 0; i < currentCallbacks.length; i += 1) {\n currentCallbacks[i]?.(timestamp);\n }\n }\n };\n request(fn) {\n const id = this.nextId;\n this.nextId += 1;\n this.callbacks.push(fn);\n this.callbacksCount += 1;\n\n /* In a test environment with fake timers, a fake `requestAnimationFrame` can be called\n * but there's no guarantee that the animation frame will actually run before the fake\n * timers are teared, which leaves `isScheduled` set, but won't run our `tick()`. */\n const didRAFChange = process.env.NODE_ENV === 'test' && LAST_RAF !== requestAnimationFrame && (LAST_RAF = requestAnimationFrame, true);\n if (!this.isScheduled || didRAFChange) {\n requestAnimationFrame(this.tick);\n this.isScheduled = true;\n }\n return id;\n }\n cancel(id) {\n const index = id - this.startId;\n if (index < 0 || index >= this.callbacks.length) {\n return;\n }\n this.callbacks[index] = null;\n this.callbacksCount -= 1;\n }\n}\nconst scheduler = new Scheduler();\nexport class AnimationFrame {\n static create() {\n return new AnimationFrame();\n }\n static request(fn) {\n return scheduler.request(fn);\n }\n static cancel(id) {\n return scheduler.cancel(id);\n }\n currentId = EMPTY;\n\n /**\n * Executes `fn` after `delay`, clearing any previously scheduled call.\n */\n request(fn) {\n this.cancel();\n this.currentId = scheduler.request(() => {\n this.currentId = EMPTY;\n fn();\n });\n }\n cancel = () => {\n if (this.currentId !== EMPTY) {\n scheduler.cancel(this.currentId);\n this.currentId = EMPTY;\n }\n };\n disposeEffect = () => {\n return this.cancel;\n };\n}\n\n/**\n * A `requestAnimationFrame` with automatic cleanup and guard.\n */\nexport function useAnimationFrame() {\n const timeout = useRefWithInit(AnimationFrame.create).current;\n useOnMount(timeout.disposeEffect);\n return timeout;\n}","/**\n * If the provided argument is a ref object, returns its `current` value.\n * Otherwise, returns the argument itself.\n */\nexport function resolveRef(maybeRef) {\n if (maybeRef == null) {\n return maybeRef;\n }\n return 'current' in maybeRef ? maybeRef.current : maybeRef;\n}","'use client';\n\nimport * as ReactDOM from 'react-dom';\nimport { useAnimationFrame } from '@base-ui-components/utils/useAnimationFrame';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { resolveRef } from \"./resolveRef.js\";\n\n/**\n * Executes a function once all animations have finished on the provided element.\n * @param elementOrRef - The element to watch for animations.\n * @param waitForNextTick - Whether to wait for the next tick before checking for animations.\n * @param treatAbortedAsFinished - Whether to treat aborted animations as finished. If `false`, and there are aborted animations,\n * the function will check again if any new animations have started and wait for them to finish.\n * @returns A function that takes a callback to execute once all animations have finished, and an optional AbortSignal to abort the callback\n */\nexport function useAnimationsFinished(elementOrRef, waitForNextTick = false, treatAbortedAsFinished = true) {\n const frame = useAnimationFrame();\n return useStableCallback((fnToExecute,\n /**\n * An optional [AbortSignal](https://developer.mozilla.org/en-US/docs/Web/API/AbortSignal) that\n * can be used to abort `fnToExecute` before all the animations have finished.\n * @default null\n */\n signal = null) => {\n frame.cancel();\n const element = resolveRef(elementOrRef);\n if (element == null) {\n return;\n }\n if (typeof element.getAnimations !== 'function' || globalThis.BASE_UI_ANIMATIONS_DISABLED) {\n fnToExecute();\n } else {\n frame.request(() => {\n function exec() {\n if (!element) {\n return;\n }\n Promise.all(element.getAnimations().map(anim => anim.finished)).then(() => {\n if (signal != null && signal.aborted) {\n return;\n }\n\n // Synchronously flush the unmounting of the component so that the browser doesn't\n // paint: https://github.com/mui/base-ui/issues/979\n ReactDOM.flushSync(fnToExecute);\n }).catch(() => {\n if (treatAbortedAsFinished) {\n if (signal != null && signal.aborted) {\n return;\n }\n ReactDOM.flushSync(fnToExecute);\n } else if (element.getAnimations().length > 0 && element.getAnimations().some(anim => anim.pending || anim.playState !== 'finished')) {\n // Sometimes animations can be aborted because a property they depend on changes while the animation plays.\n // In such cases, we need to re-check if any new animations have started.\n exec();\n }\n });\n }\n\n // `open: true` animations need to wait for the next tick to be detected\n if (waitForNextTick) {\n frame.request(exec);\n } else {\n exec();\n }\n });\n }\n });\n}","'use client';\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { AnimationFrame } from '@base-ui-components/utils/useAnimationFrame';\n/**\n * Provides a status string for CSS animations.\n * @param open - a boolean that determines if the element is open.\n * @param enableIdleState - a boolean that enables the `'idle'` state between `'starting'` and `'ending'`\n */\nexport function useTransitionStatus(open, enableIdleState = false, deferEndingState = false) {\n const [transitionStatus, setTransitionStatus] = React.useState(open && enableIdleState ? 'idle' : undefined);\n const [mounted, setMounted] = React.useState(open);\n if (open && !mounted) {\n setMounted(true);\n setTransitionStatus('starting');\n }\n if (!open && mounted && transitionStatus !== 'ending' && !deferEndingState) {\n setTransitionStatus('ending');\n }\n if (!open && !mounted && transitionStatus === 'ending') {\n setTransitionStatus(undefined);\n }\n useIsoLayoutEffect(() => {\n if (!open && mounted && transitionStatus !== 'ending' && deferEndingState) {\n const frame = AnimationFrame.request(() => {\n setTransitionStatus('ending');\n });\n return () => {\n AnimationFrame.cancel(frame);\n };\n }\n return undefined;\n }, [open, mounted, transitionStatus, deferEndingState]);\n useIsoLayoutEffect(() => {\n if (!open || enableIdleState) {\n return undefined;\n }\n const frame = AnimationFrame.request(() => {\n ReactDOM.flushSync(() => {\n setTransitionStatus(undefined);\n });\n });\n return () => {\n AnimationFrame.cancel(frame);\n };\n }, [enableIdleState, open]);\n useIsoLayoutEffect(() => {\n if (!open || !enableIdleState) {\n return undefined;\n }\n if (open && mounted && transitionStatus !== 'idle') {\n setTransitionStatus('starting');\n }\n const frame = AnimationFrame.request(() => {\n setTransitionStatus('idle');\n });\n return () => {\n AnimationFrame.cancel(frame);\n };\n }, [enableIdleState, open, mounted, setTransitionStatus, transitionStatus]);\n return React.useMemo(() => ({\n mounted,\n setMounted,\n transitionStatus\n }), [mounted, transitionStatus]);\n}","'use client';\n\nimport * as React from 'react';\nimport { useControlled } from '@base-ui-components/utils/useControlled';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useBaseUiId } from \"../../utils/useBaseUiId.js\";\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { useAnimationsFinished } from \"../../utils/useAnimationsFinished.js\";\nimport { useTransitionStatus } from \"../../utils/useTransitionStatus.js\";\nexport function useCollapsibleRoot(parameters) {\n const {\n open: openParam,\n defaultOpen,\n onOpenChange,\n disabled\n } = parameters;\n const isControlled = openParam !== undefined;\n const [open, setOpen] = useControlled({\n controlled: openParam,\n default: defaultOpen,\n name: 'Collapsible',\n state: 'open'\n });\n const {\n mounted,\n setMounted,\n transitionStatus\n } = useTransitionStatus(open, true, true);\n const [visible, setVisible] = React.useState(open);\n const [{\n height,\n width\n }, setDimensions] = React.useState({\n height: undefined,\n width: undefined\n });\n const defaultPanelId = useBaseUiId();\n const [panelIdState, setPanelIdState] = React.useState();\n const panelId = panelIdState ?? defaultPanelId;\n const [hiddenUntilFound, setHiddenUntilFound] = React.useState(false);\n const [keepMounted, setKeepMounted] = React.useState(false);\n const abortControllerRef = React.useRef(null);\n const animationTypeRef = React.useRef(null);\n const transitionDimensionRef = React.useRef(null);\n const panelRef = React.useRef(null);\n const runOnceAnimationsFinish = useAnimationsFinished(panelRef, false);\n const handleTrigger = useStableCallback(event => {\n const nextOpen = !open;\n const eventDetails = createChangeEventDetails(REASONS.triggerPress, event.nativeEvent);\n onOpenChange(nextOpen, eventDetails);\n if (eventDetails.isCanceled) {\n return;\n }\n const panel = panelRef.current;\n if (animationTypeRef.current === 'css-animation' && panel != null) {\n panel.style.removeProperty('animation-name');\n }\n if (!hiddenUntilFound && !keepMounted) {\n if (animationTypeRef.current != null && animationTypeRef.current !== 'css-animation') {\n if (!mounted && nextOpen) {\n setMounted(true);\n }\n }\n if (animationTypeRef.current === 'css-animation') {\n if (!visible && nextOpen) {\n setVisible(true);\n }\n if (!mounted && nextOpen) {\n setMounted(true);\n }\n }\n }\n setOpen(nextOpen);\n if (animationTypeRef.current === 'none' && mounted && !nextOpen) {\n setMounted(false);\n }\n });\n useIsoLayoutEffect(() => {\n /**\n * Unmount immediately when closing in controlled mode and keepMounted={false}\n * and no CSS animations or transitions are applied\n */\n if (isControlled && animationTypeRef.current === 'none' && !keepMounted && !open) {\n setMounted(false);\n }\n }, [isControlled, keepMounted, open, openParam, setMounted]);\n return React.useMemo(() => ({\n abortControllerRef,\n animationTypeRef,\n disabled,\n handleTrigger,\n height,\n mounted,\n open,\n panelId,\n panelRef,\n runOnceAnimationsFinish,\n setDimensions,\n setHiddenUntilFound,\n setKeepMounted,\n setMounted,\n setOpen,\n setPanelIdState,\n setVisible,\n transitionDimensionRef,\n transitionStatus,\n visible,\n width\n }), [abortControllerRef, animationTypeRef, disabled, handleTrigger, height, mounted, open, panelId, panelRef, runOnceAnimationsFinish, setDimensions, setHiddenUntilFound, setKeepMounted, setMounted, setOpen, setVisible, transitionDimensionRef, transitionStatus, visible, width]);\n}","'use client';\n\nimport _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const CollapsibleRootContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") CollapsibleRootContext.displayName = \"CollapsibleRootContext\";\nexport function useCollapsibleRootContext() {\n const context = React.useContext(CollapsibleRootContext);\n if (context === undefined) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: CollapsibleRootContext is missing. Collapsible parts must be placed within <Collapsible.Root>.' : _formatErrorMessage(15));\n }\n return context;\n}","'use client';\n\nimport * as React from 'react';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { useCompositeListContext } from \"./CompositeListContext.js\";\nexport let IndexGuessBehavior = /*#__PURE__*/function (IndexGuessBehavior) {\n IndexGuessBehavior[IndexGuessBehavior[\"None\"] = 0] = \"None\";\n IndexGuessBehavior[IndexGuessBehavior[\"GuessFromOrder\"] = 1] = \"GuessFromOrder\";\n return IndexGuessBehavior;\n}({});\n\n/**\n * Used to register a list item and its index (DOM position) in the `CompositeList`.\n */\nexport function useCompositeListItem(params = {}) {\n const {\n label,\n metadata,\n textRef,\n indexGuessBehavior,\n index: externalIndex\n } = params;\n const {\n register,\n unregister,\n subscribeMapChange,\n elementsRef,\n labelsRef,\n nextIndexRef\n } = useCompositeListContext();\n const indexRef = React.useRef(-1);\n const [index, setIndex] = React.useState(externalIndex ?? (indexGuessBehavior === IndexGuessBehavior.GuessFromOrder ? () => {\n if (indexRef.current === -1) {\n const newIndex = nextIndexRef.current;\n nextIndexRef.current += 1;\n indexRef.current = newIndex;\n }\n return indexRef.current;\n } : -1));\n const componentRef = React.useRef(null);\n const ref = React.useCallback(node => {\n componentRef.current = node;\n if (index !== -1 && node !== null) {\n elementsRef.current[index] = node;\n if (labelsRef) {\n const isLabelDefined = label !== undefined;\n labelsRef.current[index] = isLabelDefined ? label : textRef?.current?.textContent ?? node.textContent;\n }\n }\n }, [index, elementsRef, labelsRef, label, textRef]);\n useIsoLayoutEffect(() => {\n if (externalIndex != null) {\n return undefined;\n }\n const node = componentRef.current;\n if (node) {\n register(node, metadata);\n return () => {\n unregister(node);\n };\n }\n return undefined;\n }, [externalIndex, register, unregister, metadata]);\n useIsoLayoutEffect(() => {\n if (externalIndex != null) {\n return undefined;\n }\n return subscribeMapChange(map => {\n const i = componentRef.current ? map.get(componentRef.current)?.index : null;\n if (i != null) {\n setIndex(i);\n }\n });\n }, [externalIndex, subscribeMapChange, setIndex]);\n return React.useMemo(() => ({\n ref,\n index\n }), [index, ref]);\n}","'use client';\n\nimport _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const AccordionItemContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") AccordionItemContext.displayName = \"AccordionItemContext\";\nexport function useAccordionItemContext() {\n const context = React.useContext(AccordionItemContext);\n if (context === undefined) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: AccordionItemContext is missing. Accordion parts must be placed within <Accordion.Item>.' : _formatErrorMessage(9));\n }\n return context;\n}","export let TransitionStatusDataAttributes = /*#__PURE__*/function (TransitionStatusDataAttributes) {\n /**\n * Present when the component is animating in.\n */\n TransitionStatusDataAttributes[\"startingStyle\"] = \"data-starting-style\";\n /**\n * Present when the component is animating out.\n */\n TransitionStatusDataAttributes[\"endingStyle\"] = \"data-ending-style\";\n return TransitionStatusDataAttributes;\n}({});\nconst STARTING_HOOK = {\n [TransitionStatusDataAttributes.startingStyle]: ''\n};\nconst ENDING_HOOK = {\n [TransitionStatusDataAttributes.endingStyle]: ''\n};\nexport const transitionStatusMapping = {\n transitionStatus(value) {\n if (value === 'starting') {\n return STARTING_HOOK;\n }\n if (value === 'ending') {\n return ENDING_HOOK;\n }\n return null;\n }\n};","import { TransitionStatusDataAttributes } from \"../../utils/stateAttributesMapping.js\";\nexport let CollapsiblePanelDataAttributes = function (CollapsiblePanelDataAttributes) {\n /**\n * Present when the collapsible panel is open.\n */\n CollapsiblePanelDataAttributes[\"open\"] = \"data-open\";\n /**\n * Present when the collapsible panel is closed.\n */\n CollapsiblePanelDataAttributes[\"closed\"] = \"data-closed\";\n /**\n * Present when the panel is animating in.\n */\n CollapsiblePanelDataAttributes[CollapsiblePanelDataAttributes[\"startingStyle\"] = TransitionStatusDataAttributes.startingStyle] = \"startingStyle\";\n /**\n * Present when the panel is animating out.\n */\n CollapsiblePanelDataAttributes[CollapsiblePanelDataAttributes[\"endingStyle\"] = TransitionStatusDataAttributes.endingStyle] = \"endingStyle\";\n return CollapsiblePanelDataAttributes;\n}({});","export let CollapsibleTriggerDataAttributes = /*#__PURE__*/function (CollapsibleTriggerDataAttributes) {\n /**\n * Present when the collapsible panel is open.\n */\n CollapsibleTriggerDataAttributes[\"panelOpen\"] = \"data-panel-open\";\n return CollapsibleTriggerDataAttributes;\n}({});","import { CollapsiblePanelDataAttributes } from \"../collapsible/panel/CollapsiblePanelDataAttributes.js\";\nimport { CollapsibleTriggerDataAttributes } from \"../collapsible/trigger/CollapsibleTriggerDataAttributes.js\";\nconst PANEL_OPEN_HOOK = {\n [CollapsiblePanelDataAttributes.open]: ''\n};\nconst PANEL_CLOSED_HOOK = {\n [CollapsiblePanelDataAttributes.closed]: ''\n};\nexport const triggerOpenStateMapping = {\n open(value) {\n if (value) {\n return {\n [CollapsibleTriggerDataAttributes.panelOpen]: ''\n };\n }\n return null;\n }\n};\nexport const collapsibleOpenStateMapping = {\n open(value) {\n if (value) {\n return PANEL_OPEN_HOOK;\n }\n return PANEL_CLOSED_HOOK;\n }\n};","export let AccordionItemDataAttributes = /*#__PURE__*/function (AccordionItemDataAttributes) {\n /**\n * Indicates the index of the accordion item.\n * @type {number}\n */\n AccordionItemDataAttributes[\"index\"] = \"data-index\";\n /**\n * Present when the accordion item is disabled.\n */\n AccordionItemDataAttributes[\"disabled\"] = \"data-disabled\";\n /**\n * Present when the accordion item is open.\n */\n AccordionItemDataAttributes[\"open\"] = \"data-open\";\n return AccordionItemDataAttributes;\n}({});","import { collapsibleOpenStateMapping as baseMapping } from \"../../utils/collapsibleOpenStateMapping.js\";\nimport { transitionStatusMapping } from \"../../utils/stateAttributesMapping.js\";\nimport { AccordionItemDataAttributes } from \"./AccordionItemDataAttributes.js\";\nexport const accordionStateAttributesMapping = {\n ...baseMapping,\n index: value => {\n return Number.isInteger(value) ? {\n [AccordionItemDataAttributes.index]: String(value)\n } : null;\n },\n ...transitionStatusMapping,\n value: () => null\n};","'use client';\n\nimport * as React from 'react';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useMergedRefs } from '@base-ui-components/utils/useMergedRefs';\nimport { useBaseUiId } from \"../../utils/useBaseUiId.js\";\nimport { useCollapsibleRoot } from \"../../collapsible/root/useCollapsibleRoot.js\";\nimport { CollapsibleRootContext } from \"../../collapsible/root/CollapsibleRootContext.js\";\nimport { useCompositeListItem } from \"../../composite/list/useCompositeListItem.js\";\nimport { useAccordionRootContext } from \"../root/AccordionRootContext.js\";\nimport { AccordionItemContext } from \"./AccordionItemContext.js\";\nimport { accordionStateAttributesMapping } from \"./stateAttributesMapping.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\n/**\n * Groups an accordion header with the corresponding panel.\n * Renders a `<div>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\nexport const AccordionItem = /*#__PURE__*/React.forwardRef(function AccordionItem(componentProps, forwardedRef) {\n const {\n className,\n disabled: disabledProp = false,\n onOpenChange: onOpenChangeProp,\n render,\n value: valueProp,\n ...elementProps\n } = componentProps;\n const {\n ref: listItemRef,\n index\n } = useCompositeListItem();\n const mergedRef = useMergedRefs(forwardedRef, listItemRef);\n const {\n disabled: contextDisabled,\n handleValueChange,\n state: rootState,\n value: openValues\n } = useAccordionRootContext();\n const fallbackValue = useBaseUiId();\n const value = valueProp ?? fallbackValue;\n const disabled = disabledProp || contextDisabled;\n const isOpen = React.useMemo(() => {\n if (!openValues) {\n return false;\n }\n for (let i = 0; i < openValues.length; i += 1) {\n if (openValues[i] === value) {\n return true;\n }\n }\n return false;\n }, [openValues, value]);\n const onOpenChange = useStableCallback((nextOpen, eventDetails) => {\n onOpenChangeProp?.(nextOpen, eventDetails);\n if (eventDetails.isCanceled) {\n return;\n }\n handleValueChange(value, nextOpen);\n });\n const collapsible = useCollapsibleRoot({\n open: isOpen,\n onOpenChange,\n disabled\n });\n const collapsibleState = React.useMemo(() => ({\n open: collapsible.open,\n disabled: collapsible.disabled,\n hidden: !collapsible.mounted,\n transitionStatus: collapsible.transitionStatus\n }), [collapsible.open, collapsible.disabled, collapsible.mounted, collapsible.transitionStatus]);\n const collapsibleContext = React.useMemo(() => ({\n ...collapsible,\n onOpenChange,\n state: collapsibleState\n }), [collapsible, collapsibleState, onOpenChange]);\n const state = React.useMemo(() => ({\n ...rootState,\n index,\n disabled,\n open: isOpen\n }), [disabled, index, isOpen, rootState]);\n const [triggerId, setTriggerId] = React.useState(useBaseUiId());\n const accordionItemContext = React.useMemo(() => ({\n open: isOpen,\n state,\n setTriggerId,\n triggerId\n }), [isOpen, state, setTriggerId, triggerId]);\n const element = useRenderElement('div', componentProps, {\n state,\n ref: mergedRef,\n props: elementProps,\n stateAttributesMapping: accordionStateAttributesMapping\n });\n return /*#__PURE__*/_jsx(CollapsibleRootContext.Provider, {\n value: collapsibleContext,\n children: /*#__PURE__*/_jsx(AccordionItemContext.Provider, {\n value: accordionItemContext,\n children: element\n })\n });\n});\nif (process.env.NODE_ENV !== \"production\") AccordionItem.displayName = \"AccordionItem\";","'use client';\n\nimport * as React from 'react';\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nimport { useAccordionItemContext } from \"../item/AccordionItemContext.js\";\nimport { accordionStateAttributesMapping } from \"../item/stateAttributesMapping.js\";\n\n/**\n * A heading that labels the corresponding panel.\n * Renders an `<h3>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\nexport const AccordionHeader = /*#__PURE__*/React.forwardRef(function AccordionHeader(componentProps, forwardedRef) {\n const {\n render,\n className,\n ...elementProps\n } = componentProps;\n const {\n state\n } = useAccordionItemContext();\n const element = useRenderElement('h3', componentProps, {\n state,\n ref: forwardedRef,\n props: elementProps,\n stateAttributesMapping: accordionStateAttributesMapping\n });\n return element;\n});\nif (process.env.NODE_ENV !== \"production\") AccordionHeader.displayName = \"AccordionHeader\";","export function isElementDisabled(element) {\n return element == null || element.hasAttribute('disabled') || element.getAttribute('aria-disabled') === 'true';\n}","function hasWindow() {\n return typeof window !== 'undefined';\n}\nfunction getNodeName(node) {\n if (isNode(node)) {\n return (node.nodeName || '').toLowerCase();\n }\n // Mocked nodes in testing environments may not be instances of Node. By\n // returning `#document` an infinite loop won't occur.\n // https://github.com/floating-ui/floating-ui/issues/2317\n return '#document';\n}\nfunction getWindow(node) {\n var _node$ownerDocument;\n return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n var _ref;\n return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n if (!hasWindow() || typeof ShadowRoot === 'undefined') {\n return false;\n }\n return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nconst invalidOverflowDisplayValues = /*#__PURE__*/new Set(['inline', 'contents']);\nfunction isOverflowElement(element) {\n const {\n overflow,\n overflowX,\n overflowY,\n display\n } = getComputedStyle(element);\n return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !invalidOverflowDisplayValues.has(display);\n}\nconst tableElements = /*#__PURE__*/new Set(['table', 'td', 'th']);\nfunction isTableElement(element) {\n return tableElements.has(getNodeName(element));\n}\nconst topLayerSelectors = [':popover-open', ':modal'];\nfunction isTopLayer(element) {\n return topLayerSelectors.some(selector => {\n try {\n return element.matches(selector);\n } catch (_e) {\n return false;\n }\n });\n}\nconst transformProperties = ['transform', 'translate', 'scale', 'rotate', 'perspective'];\nconst willChangeValues = ['transform', 'translate', 'scale', 'rotate', 'perspective', 'filter'];\nconst containValues = ['paint', 'layout', 'strict', 'content'];\nfunction isContainingBlock(elementOrCss) {\n const webkit = isWebKit();\n const css = isElement(elementOrCss) ? getComputedStyle(elementOrCss) : elementOrCss;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n // https://drafts.csswg.org/css-transforms-2/#individual-transforms\n return transformProperties.some(value => css[value] ? css[value] !== 'none' : false) || (css.containerType ? css.containerType !== 'normal' : false) || !webkit && (css.backdropFilter ? css.backdropFilter !== 'none' : false) || !webkit && (css.filter ? css.filter !== 'none' : false) || willChangeValues.some(value => (css.willChange || '').includes(value)) || containValues.some(value => (css.contain || '').includes(value));\n}\nfunction getContainingBlock(element) {\n let currentNode = getParentNode(element);\n while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n if (isContainingBlock(currentNode)) {\n return currentNode;\n } else if (isTopLayer(currentNode)) {\n return null;\n }\n currentNode = getParentNode(currentNode);\n }\n return null;\n}\nfunction isWebKit() {\n if (typeof CSS === 'undefined' || !CSS.supports) return false;\n return CSS.supports('-webkit-backdrop-filter', 'none');\n}\nconst lastTraversableNodeNames = /*#__PURE__*/new Set(['html', 'body', '#document']);\nfunction isLastTraversableNode(node) {\n return lastTraversableNodeNames.has(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n if (isElement(element)) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n }\n return {\n scrollLeft: element.scrollX,\n scrollTop: element.scrollY\n };\n}\nfunction getParentNode(node) {\n if (getNodeName(node) === 'html') {\n return node;\n }\n const result =\n // Step into the shadow DOM of the parent of a slotted node.\n node.assignedSlot ||\n // DOM Element detected.\n node.parentNode ||\n // ShadowRoot detected.\n isShadowRoot(node) && node.host ||\n // Fallback.\n getDocumentElement(node);\n return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n const parentNode = getParentNode(node);\n if (isLastTraversableNode(parentNode)) {\n return node.ownerDocument ? node.ownerDocument.body : node.body;\n }\n if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n return parentNode;\n }\n return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list, traverseIframes) {\n var _node$ownerDocument2;\n if (list === void 0) {\n list = [];\n }\n if (traverseIframes === void 0) {\n traverseIframes = true;\n }\n const scrollableAncestor = getNearestOverflowAncestor(node);\n const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n const win = getWindow(scrollableAncestor);\n if (isBody) {\n const frameElement = getFrameElement(win);\n return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);\n }\n return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));\n}\nfunction getFrameElement(win) {\n return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getFrameElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isTopLayer, isWebKit };\n","let set;\nif (process.env.NODE_ENV !== 'production') {\n set = new Set();\n}\nexport function error(...messages) {\n if (process.env.NODE_ENV !== 'production') {\n const messageKey = messages.join(' ');\n if (!set.has(messageKey)) {\n set.add(messageKey);\n console.error(`Base UI: ${messageKey}`);\n }\n }\n}","'use client';\n\nimport _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const CompositeRootContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") CompositeRootContext.displayName = \"CompositeRootContext\";\nexport function useCompositeRootContext(optional = false) {\n const context = React.useContext(CompositeRootContext);\n if (context === undefined && !optional) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: CompositeRootContext is missing. Composite parts must be placed within <Composite.Root>.' : _formatErrorMessage(16));\n }\n return context;\n}","'use client';\n\nimport * as React from 'react';\nexport function useFocusableWhenDisabled(parameters) {\n const {\n focusableWhenDisabled,\n disabled,\n composite = false,\n tabIndex: tabIndexProp = 0,\n isNativeButton\n } = parameters;\n const isFocusableComposite = composite && focusableWhenDisabled !== false;\n const isNonFocusableComposite = composite && focusableWhenDisabled === false;\n\n // we can't explicitly assign `undefined` to any of these props because it\n // would otherwise prevent subsequently merged props from setting them\n const props = React.useMemo(() => {\n const additionalProps = {\n // allow Tabbing away from focusableWhenDisabled elements\n onKeyDown(event) {\n if (disabled && focusableWhenDisabled && event.key !== 'Tab') {\n event.preventDefault();\n }\n }\n };\n if (!composite) {\n additionalProps.tabIndex = tabIndexProp;\n if (!isNativeButton && disabled) {\n additionalProps.tabIndex = focusableWhenDisabled ? tabIndexProp : -1;\n }\n }\n if (isNativeButton && (focusableWhenDisabled || isFocusableComposite) || !isNativeButton && disabled) {\n additionalProps['aria-disabled'] = disabled;\n }\n if (isNativeButton && (!focusableWhenDisabled || isNonFocusableComposite)) {\n additionalProps.disabled = disabled;\n }\n return additionalProps;\n }, [composite, disabled, focusableWhenDisabled, isFocusableComposite, isNonFocusableComposite, isNativeButton, tabIndexProp]);\n return {\n props\n };\n}","'use client';\n\nimport * as React from 'react';\nimport { isHTMLElement } from '@floating-ui/utils/dom';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { error } from '@base-ui-components/utils/error';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { makeEventPreventable, mergeProps } from \"../merge-props/index.js\";\nimport { useCompositeRootContext } from \"../composite/root/CompositeRootContext.js\";\nimport { useFocusableWhenDisabled } from \"../utils/useFocusableWhenDisabled.js\";\nexport function useButton(parameters = {}) {\n const {\n disabled = false,\n focusableWhenDisabled,\n tabIndex = 0,\n native: isNativeButton = true\n } = parameters;\n const elementRef = React.useRef(null);\n const isCompositeItem = useCompositeRootContext(true) !== undefined;\n const isValidLink = useStableCallback(() => {\n const element = elementRef.current;\n return Boolean(element?.tagName === 'A' && element?.href);\n });\n const {\n props: focusableWhenDisabledProps\n } = useFocusableWhenDisabled({\n focusableWhenDisabled,\n disabled,\n composite: isCompositeItem,\n tabIndex,\n isNativeButton\n });\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(() => {\n if (!elementRef.current) {\n return;\n }\n const isButtonTag = elementRef.current.tagName === 'BUTTON';\n if (isNativeButton) {\n if (!isButtonTag) {\n error('A component that acts as a button was not rendered as a native <button>, which does not match the default. Ensure that the element passed to the `render` prop of the component is a real <button>, or set the `nativeButton` prop on the component to `false`.');\n }\n } else if (isButtonTag) {\n error('A component that acts as a button was rendered as a native <button>, which does not match the default. Ensure that the element passed to the `render` prop of the component is not a real <button>, or set the `nativeButton` prop on the component to `true`.');\n }\n }, [isNativeButton]);\n }\n\n // handles a disabled composite button rendering another button, e.g.\n // <Toolbar.Button disabled render={<Menu.Trigger />} />\n // the `disabled` prop needs to pass through 2 `useButton`s then finally\n // delete the `disabled` attribute from DOM\n const updateDisabled = React.useCallback(() => {\n const element = elementRef.current;\n if (!isButtonElement(element)) {\n return;\n }\n if (isCompositeItem && disabled && focusableWhenDisabledProps.disabled === undefined && element.disabled) {\n element.disabled = false;\n }\n }, [disabled, focusableWhenDisabledProps.disabled, isCompositeItem]);\n useIsoLayoutEffect(updateDisabled, [updateDisabled]);\n const getButtonProps = React.useCallback((externalProps = {}) => {\n const {\n onClick: externalOnClick,\n onMouseDown: externalOnMouseDown,\n onKeyUp: externalOnKeyUp,\n onKeyDown: externalOnKeyDown,\n onPointerDown: externalOnPointerDown,\n ...otherExternalProps\n } = externalProps;\n const type = isNativeButton ? 'button' : undefined;\n return mergeProps({\n type,\n onClick(event) {\n if (disabled) {\n event.preventDefault();\n return;\n }\n externalOnClick?.(event);\n },\n onMouseDown(event) {\n if (!disabled) {\n externalOnMouseDown?.(event);\n }\n },\n onKeyDown(event) {\n if (!disabled) {\n makeEventPreventable(event);\n externalOnKeyDown?.(event);\n }\n if (event.baseUIHandlerPrevented) {\n return;\n }\n const shouldClick = event.target === event.currentTarget && !isNativeButton && !isValidLink() && !disabled;\n const isEnterKey = event.key === 'Enter';\n const isSpaceKey = event.key === ' ';\n\n // Keyboard accessibility for non interactive elements\n if (shouldClick) {\n if (isSpaceKey || isEnterKey) {\n event.preventDefault();\n }\n if (isEnterKey) {\n externalOnClick?.(event);\n }\n }\n },\n onKeyUp(event) {\n // calling preventDefault in keyUp on a <button> will not dispatch a click event if Space is pressed\n // https://codesandbox.io/p/sandbox/button-keyup-preventdefault-dn7f0\n // Keyboard accessibility for non interactive elements\n if (!disabled) {\n makeEventPreventable(event);\n externalOnKeyUp?.(event);\n }\n if (event.baseUIHandlerPrevented) {\n return;\n }\n if (event.target === event.currentTarget && !isNativeButton && !disabled && event.key === ' ') {\n externalOnClick?.(event);\n }\n },\n onPointerDown(event) {\n if (disabled) {\n event.preventDefault();\n return;\n }\n externalOnPointerDown?.(event);\n }\n }, !isNativeButton ? {\n role: 'button'\n } : undefined, focusableWhenDisabledProps, otherExternalProps);\n }, [disabled, focusableWhenDisabledProps, isNativeButton, isValidLink]);\n const buttonRef = useStableCallback(element => {\n elementRef.current = element;\n updateDisabled();\n });\n return {\n getButtonProps,\n buttonRef\n };\n}\nfunction isButtonElement(elem) {\n return isHTMLElement(elem) && elem.tagName === 'BUTTON';\n}","import { isAndroid, isJSDOM } from '@base-ui-components/utils/detectBrowser';\nexport function stopEvent(event) {\n event.preventDefault();\n event.stopPropagation();\n}\nexport function isReactEvent(event) {\n return 'nativeEvent' in event;\n}\n\n// License: https://github.com/adobe/react-spectrum/blob/b35d5c02fe900badccd0cf1a8f23bb593419f238/packages/@react-aria/utils/src/isVirtualEvent.ts\nexport function isVirtualClick(event) {\n // FIXME: Firefox is now emitting a deprecation warning for `mozInputSource`.\n // Try to find a workaround for this. `react-aria` source still has the check.\n if (event.mozInputSource === 0 && event.isTrusted) {\n return true;\n }\n if (isAndroid && event.pointerType) {\n return event.type === 'click' && event.buttons === 1;\n }\n return event.detail === 0 && !event.pointerType;\n}\nexport function isVirtualPointerEvent(event) {\n if (isJSDOM) {\n return false;\n }\n return !isAndroid && event.width === 0 && event.height === 0 || isAndroid && event.width === 1 && event.height === 1 && event.pressure === 0 && event.detail === 0 && event.pointerType === 'mouse' ||\n // iOS VoiceOver returns 0.333• for width/height.\n event.width < 1 && event.height < 1 && event.pressure === 0 && event.detail === 0 && event.pointerType === 'touch';\n}\nexport function isMouseLikePointerType(pointerType, strict) {\n // On some Linux machines with Chromium, mouse inputs return a `pointerType`\n // of \"pen\": https://github.com/floating-ui/floating-ui/issues/2015\n const values = ['mouse', 'pen'];\n if (!strict) {\n values.push('', undefined);\n }\n return values.includes(pointerType);\n}\nexport function isClickLikeEvent(event) {\n const type = event.type;\n return type === 'click' || type === 'mousedown' || type === 'keydown' || type === 'keyup';\n}","import { isHTMLElement } from '@floating-ui/utils/dom';\nexport { stopEvent, isIndexOutOfListBounds, isListIndexDisabled, createGridCellMap, findNonDisabledListIndex, getGridCellIndexOfCorner, getGridCellIndices, getGridNavigatedIndex, getMaxListIndex, getMinListIndex } from \"../floating-ui-react/utils.js\";\nexport const ARROW_UP = 'ArrowUp';\nexport const ARROW_DOWN = 'ArrowDown';\nexport const ARROW_LEFT = 'ArrowLeft';\nexport const ARROW_RIGHT = 'ArrowRight';\nexport const HOME = 'Home';\nexport const END = 'End';\nexport const HORIZONTAL_KEYS = new Set([ARROW_LEFT, ARROW_RIGHT]);\nexport const HORIZONTAL_KEYS_WITH_EXTRA_KEYS = new Set([ARROW_LEFT, ARROW_RIGHT, HOME, END]);\nexport const VERTICAL_KEYS = new Set([ARROW_UP, ARROW_DOWN]);\nexport const VERTICAL_KEYS_WITH_EXTRA_KEYS = new Set([ARROW_UP, ARROW_DOWN, HOME, END]);\nexport const ARROW_KEYS = new Set([...HORIZONTAL_KEYS, ...VERTICAL_KEYS]);\nexport const ALL_KEYS = new Set([...ARROW_KEYS, HOME, END]);\nexport const COMPOSITE_KEYS = new Set([ARROW_UP, ARROW_DOWN, ARROW_LEFT, ARROW_RIGHT, HOME, END]);\nexport const SHIFT = 'Shift';\nexport const CONTROL = 'Control';\nexport const ALT = 'Alt';\nexport const META = 'Meta';\nexport const MODIFIER_KEYS = new Set([SHIFT, CONTROL, ALT, META]);\nfunction isInputElement(element) {\n return isHTMLElement(element) && element.tagName === 'INPUT';\n}\nexport function isNativeInput(element) {\n if (isInputElement(element) && element.selectionStart != null) {\n return true;\n }\n if (isHTMLElement(element) && element.tagName === 'TEXTAREA') {\n return true;\n }\n return false;\n}\nexport function scrollIntoViewIfNeeded(scrollContainer, element, direction, orientation) {\n if (!scrollContainer || !element || !element.scrollTo) {\n return;\n }\n let targetX = scrollContainer.scrollLeft;\n let targetY = scrollContainer.scrollTop;\n const isOverflowingX = scrollContainer.clientWidth < scrollContainer.scrollWidth;\n const isOverflowingY = scrollContainer.clientHeight < scrollContainer.scrollHeight;\n if (isOverflowingX && orientation !== 'vertical') {\n const elementOffsetLeft = getOffset(scrollContainer, element, 'left');\n const containerStyles = getStyles(scrollContainer);\n const elementStyles = getStyles(element);\n if (direction === 'ltr') {\n if (elementOffsetLeft + element.offsetWidth + elementStyles.scrollMarginRight > scrollContainer.scrollLeft + scrollContainer.clientWidth - containerStyles.scrollPaddingRight) {\n // overflow to the right, scroll to align right edges\n targetX = elementOffsetLeft + element.offsetWidth + elementStyles.scrollMarginRight - scrollContainer.clientWidth + containerStyles.scrollPaddingRight;\n } else if (elementOffsetLeft - elementStyles.scrollMarginLeft < scrollContainer.scrollLeft + containerStyles.scrollPaddingLeft) {\n // overflow to the left, scroll to align left edges\n targetX = elementOffsetLeft - elementStyles.scrollMarginLeft - containerStyles.scrollPaddingLeft;\n }\n }\n if (direction === 'rtl') {\n if (elementOffsetLeft - elementStyles.scrollMarginRight < scrollContainer.scrollLeft + containerStyles.scrollPaddingLeft) {\n // overflow to the left, scroll to align left edges\n targetX = elementOffsetLeft - elementStyles.scrollMarginLeft - containerStyles.scrollPaddingLeft;\n } else if (elementOffsetLeft + element.offsetWidth + elementStyles.scrollMarginRight > scrollContainer.scrollLeft + scrollContainer.clientWidth - containerStyles.scrollPaddingRight) {\n // overflow to the right, scroll to align right edges\n targetX = elementOffsetLeft + element.offsetWidth + elementStyles.scrollMarginRight - scrollContainer.clientWidth + containerStyles.scrollPaddingRight;\n }\n }\n }\n if (isOverflowingY && orientation !== 'horizontal') {\n const elementOffsetTop = getOffset(scrollContainer, element, 'top');\n const containerStyles = getStyles(scrollContainer);\n const elementStyles = getStyles(element);\n if (elementOffsetTop - elementStyles.scrollMarginTop < scrollContainer.scrollTop + containerStyles.scrollPaddingTop) {\n // overflow upwards, align top edges\n targetY = elementOffsetTop - elementStyles.scrollMarginTop - containerStyles.scrollPaddingTop;\n } else if (elementOffsetTop + element.offsetHeight + elementStyles.scrollMarginBottom > scrollContainer.scrollTop + scrollContainer.clientHeight - containerStyles.scrollPaddingBottom) {\n // overflow downwards, align bottom edges\n targetY = elementOffsetTop + element.offsetHeight + elementStyles.scrollMarginBottom - scrollContainer.clientHeight + containerStyles.scrollPaddingBottom;\n }\n }\n scrollContainer.scrollTo({\n left: targetX,\n top: targetY,\n behavior: 'auto'\n });\n}\nfunction getOffset(ancestor, element, side) {\n const propName = side === 'left' ? 'offsetLeft' : 'offsetTop';\n let result = 0;\n while (element.offsetParent) {\n result += element[propName];\n if (element.offsetParent === ancestor) {\n break;\n }\n element = element.offsetParent;\n }\n return result;\n}\nfunction getStyles(element) {\n const styles = getComputedStyle(element);\n return {\n scrollMarginTop: parseFloat(styles.scrollMarginTop) || 0,\n scrollMarginRight: parseFloat(styles.scrollMarginRight) || 0,\n scrollMarginBottom: parseFloat(styles.scrollMarginBottom) || 0,\n scrollMarginLeft: parseFloat(styles.scrollMarginLeft) || 0,\n scrollPaddingTop: parseFloat(styles.scrollPaddingTop) || 0,\n scrollPaddingRight: parseFloat(styles.scrollPaddingRight) || 0,\n scrollPaddingBottom: parseFloat(styles.scrollPaddingBottom) || 0,\n scrollPaddingLeft: parseFloat(styles.scrollPaddingLeft) || 0\n };\n}","'use client';\n\nimport * as React from 'react';\nimport { isElementDisabled } from '@base-ui-components/utils/isElementDisabled';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { triggerOpenStateMapping } from \"../../utils/collapsibleOpenStateMapping.js\";\nimport { useButton } from \"../../use-button/index.js\";\nimport { useCollapsibleRootContext } from \"../../collapsible/root/CollapsibleRootContext.js\";\nimport { ARROW_DOWN, ARROW_UP, ARROW_RIGHT, ARROW_LEFT, HOME, END, stopEvent } from \"../../composite/composite.js\";\nimport { useAccordionRootContext } from \"../root/AccordionRootContext.js\";\nimport { useAccordionItemContext } from \"../item/AccordionItemContext.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nconst SUPPORTED_KEYS = new Set([ARROW_DOWN, ARROW_UP, ARROW_RIGHT, ARROW_LEFT, HOME, END]);\nfunction getActiveTriggers(accordionItemRefs) {\n const {\n current: accordionItemElements\n } = accordionItemRefs;\n const output = [];\n for (let i = 0; i < accordionItemElements.length; i += 1) {\n const section = accordionItemElements[i];\n if (!isElementDisabled(section)) {\n const trigger = section?.querySelector('[type=\"button\"]');\n if (!isElementDisabled(trigger)) {\n output.push(trigger);\n }\n }\n }\n return output;\n}\n\n/**\n * A button that opens and closes the corresponding panel.\n * Renders a `<button>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\n\nexport const AccordionTrigger = /*#__PURE__*/React.forwardRef(function AccordionTrigger(componentProps, forwardedRef) {\n const {\n disabled: disabledProp,\n className,\n id: idProp,\n render,\n nativeButton = true,\n ...elementProps\n } = componentProps;\n const {\n panelId,\n open,\n handleTrigger,\n disabled: contextDisabled\n } = useCollapsibleRootContext();\n const disabled = disabledProp ?? contextDisabled;\n const {\n getButtonProps,\n buttonRef\n } = useButton({\n disabled,\n focusableWhenDisabled: true,\n native: nativeButton\n });\n const {\n accordionItemRefs,\n direction,\n loopFocus,\n orientation\n } = useAccordionRootContext();\n const isRtl = direction === 'rtl';\n const isHorizontal = orientation === 'horizontal';\n const {\n state,\n setTriggerId,\n triggerId: id\n } = useAccordionItemContext();\n useIsoLayoutEffect(() => {\n if (idProp) {\n setTriggerId(idProp);\n }\n return () => {\n setTriggerId(undefined);\n };\n }, [idProp, setTriggerId]);\n const props = React.useMemo(() => ({\n 'aria-controls': open ? panelId : undefined,\n 'aria-expanded': open,\n disabled,\n id,\n onClick: handleTrigger,\n onKeyDown(event) {\n if (!SUPPORTED_KEYS.has(event.key)) {\n return;\n }\n stopEvent(event);\n const triggers = getActiveTriggers(accordionItemRefs);\n const numOfEnabledTriggers = triggers.length;\n const lastIndex = numOfEnabledTriggers - 1;\n let nextIndex = -1;\n const thisIndex = triggers.indexOf(event.target);\n function toNext() {\n if (loopFocus) {\n nextIndex = thisIndex + 1 > lastIndex ? 0 : thisIndex + 1;\n } else {\n nextIndex = Math.min(thisIndex + 1, lastIndex);\n }\n }\n function toPrev() {\n if (loopFocus) {\n nextIndex = thisIndex === 0 ? lastIndex : thisIndex - 1;\n } else {\n nextIndex = thisIndex - 1;\n }\n }\n switch (event.key) {\n case ARROW_DOWN:\n if (!isHorizontal) {\n toNext();\n }\n break;\n case ARROW_UP:\n if (!isHorizontal) {\n toPrev();\n }\n break;\n case ARROW_RIGHT:\n if (isHorizontal) {\n if (isRtl) {\n toPrev();\n } else {\n toNext();\n }\n }\n break;\n case ARROW_LEFT:\n if (isHorizontal) {\n if (isRtl) {\n toNext();\n } else {\n toPrev();\n }\n }\n break;\n case 'Home':\n nextIndex = 0;\n break;\n case 'End':\n nextIndex = lastIndex;\n break;\n default:\n break;\n }\n if (nextIndex > -1) {\n triggers[nextIndex].focus();\n }\n }\n }), [accordionItemRefs, disabled, handleTrigger, id, isHorizontal, isRtl, loopFocus, open, panelId]);\n const element = useRenderElement('button', componentProps, {\n state,\n ref: [forwardedRef, buttonRef],\n props: [props, elementProps, getButtonProps],\n stateAttributesMapping: triggerOpenStateMapping\n });\n return element;\n});\nif (process.env.NODE_ENV !== \"production\") AccordionTrigger.displayName = \"AccordionTrigger\";","export let AccordionRootDataAttributes = /*#__PURE__*/function (AccordionRootDataAttributes) {\n /**\n * Present when the accordion is disabled.\n */\n AccordionRootDataAttributes[\"disabled\"] = \"data-disabled\";\n /**\n * Indicates the orientation of the accordion.\n */\n AccordionRootDataAttributes[\"orientation\"] = \"data-orientation\";\n return AccordionRootDataAttributes;\n}({});","'use client';\n\nimport * as React from 'react';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useMergedRefs } from '@base-ui-components/utils/useMergedRefs';\nimport { useOnMount } from '@base-ui-components/utils/useOnMount';\nimport { AnimationFrame, useAnimationFrame } from '@base-ui-components/utils/useAnimationFrame';\nimport { warn } from '@base-ui-components/utils/warn';\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { CollapsiblePanelDataAttributes } from \"./CollapsiblePanelDataAttributes.js\";\nimport { AccordionRootDataAttributes } from \"../../accordion/root/AccordionRootDataAttributes.js\";\nexport function useCollapsiblePanel(parameters) {\n const {\n abortControllerRef,\n animationTypeRef,\n externalRef,\n height,\n hiddenUntilFound,\n keepMounted,\n id: idParam,\n mounted,\n onOpenChange,\n open,\n panelRef,\n runOnceAnimationsFinish,\n setDimensions,\n setMounted,\n setOpen,\n setVisible,\n transitionDimensionRef,\n visible,\n width\n } = parameters;\n const isBeforeMatchRef = React.useRef(false);\n const latestAnimationNameRef = React.useRef(null);\n const shouldCancelInitialOpenAnimationRef = React.useRef(open);\n const shouldCancelInitialOpenTransitionRef = React.useRef(open);\n const endingStyleFrame = useAnimationFrame();\n\n /**\n * When opening, the `hidden` attribute is removed immediately.\n * When closing, the `hidden` attribute is set after any exit animations runs.\n */\n const hidden = React.useMemo(() => {\n if (animationTypeRef.current === 'css-animation') {\n return !visible;\n }\n return !open && !mounted;\n }, [open, mounted, visible, animationTypeRef]);\n\n /**\n * When `keepMounted` is `true` this runs once as soon as it exists in the DOM\n * regardless of initial open state.\n *\n * When `keepMounted` is `false` this runs on every mount, typically every\n * time it opens. If the panel is in the middle of a close transition that is\n * interrupted and re-opens, this won't run as the panel was not unmounted.\n */\n const handlePanelRef = useStableCallback(element => {\n if (!element) {\n return undefined;\n }\n if (animationTypeRef.current == null || transitionDimensionRef.current == null) {\n const panelStyles = getComputedStyle(element);\n const hasAnimation = panelStyles.animationName !== 'none' && panelStyles.animationName !== '';\n const hasTransition = panelStyles.transitionDuration !== '0s' && panelStyles.transitionDuration !== '';\n\n /**\n * animationTypeRef is safe to read in render because it's only ever set\n * once here during the first render and never again.\n * https://react.dev/learn/referencing-values-with-refs#best-practices-for-refs\n */\n if (hasAnimation && hasTransition) {\n if (process.env.NODE_ENV !== 'production') {\n warn('CSS transitions and CSS animations both detected on Collapsible or Accordion panel.', 'Only one of either animation type should be used.');\n }\n } else if (panelStyles.animationName === 'none' && panelStyles.transitionDuration !== '0s') {\n animationTypeRef.current = 'css-transition';\n } else if (panelStyles.animationName !== 'none' && panelStyles.transitionDuration === '0s') {\n animationTypeRef.current = 'css-animation';\n } else {\n animationTypeRef.current = 'none';\n }\n\n /**\n * We need to know in advance which side is being collapsed when using CSS\n * transitions in order to set the value of width/height to `0px` momentarily.\n * Setting both to `0px` will break layout.\n */\n if (element.getAttribute(AccordionRootDataAttributes.orientation) === 'horizontal' || panelStyles.transitionProperty.indexOf('width') > -1) {\n transitionDimensionRef.current = 'width';\n } else {\n transitionDimensionRef.current = 'height';\n }\n }\n if (animationTypeRef.current !== 'css-transition') {\n return undefined;\n }\n if (height === undefined || width === undefined) {\n setDimensions({\n height: element.scrollHeight,\n width: element.scrollWidth\n });\n if (shouldCancelInitialOpenTransitionRef.current) {\n element.style.setProperty('transition-duration', '0s');\n }\n }\n let frame = -1;\n let nextFrame = -1;\n frame = AnimationFrame.request(() => {\n shouldCancelInitialOpenTransitionRef.current = false;\n nextFrame = AnimationFrame.request(() => {\n /**\n * This is slightly faster than another RAF and is the earliest\n * opportunity to remove the temporary `transition-duration: 0s` that\n * was applied to cancel opening transitions of initially open panels.\n * https://nolanlawson.com/2018/09/25/accurately-measuring-layout-on-the-web/\n */\n setTimeout(() => {\n element.style.removeProperty('transition-duration');\n });\n });\n });\n return () => {\n AnimationFrame.cancel(frame);\n AnimationFrame.cancel(nextFrame);\n };\n });\n const mergedPanelRef = useMergedRefs(externalRef, panelRef, handlePanelRef);\n useIsoLayoutEffect(() => {\n if (animationTypeRef.current !== 'css-transition') {\n return undefined;\n }\n const panel = panelRef.current;\n if (!panel) {\n return undefined;\n }\n let resizeFrame = -1;\n if (abortControllerRef.current != null) {\n abortControllerRef.current.abort();\n abortControllerRef.current = null;\n }\n if (open) {\n const originalLayoutStyles = {\n 'justify-content': panel.style.justifyContent,\n 'align-items': panel.style.alignItems,\n 'align-content': panel.style.alignContent,\n 'justify-items': panel.style.justifyItems\n };\n\n /* opening */\n Object.keys(originalLayoutStyles).forEach(key => {\n panel.style.setProperty(key, 'initial', 'important');\n });\n\n /**\n * When `keepMounted={false}` and the panel is initially closed, the very\n * first time it opens (not any subsequent opens) `data-starting-style` is\n * off or missing by a frame so we need to set it manually. Otherwise any\n * CSS properties expected to transition using [data-starting-style] may\n * be mis-timed and appear to be complete skipped.\n */\n if (!shouldCancelInitialOpenTransitionRef.current && !keepMounted) {\n panel.setAttribute(CollapsiblePanelDataAttributes.startingStyle, '');\n }\n setDimensions({\n height: panel.scrollHeight,\n width: panel.scrollWidth\n });\n resizeFrame = AnimationFrame.request(() => {\n Object.entries(originalLayoutStyles).forEach(([key, value]) => {\n if (value === '') {\n panel.style.removeProperty(key);\n } else {\n panel.style.setProperty(key, value);\n }\n });\n });\n } else {\n if (panel.scrollHeight === 0 && panel.scrollWidth === 0) {\n return undefined;\n }\n\n /* closing */\n setDimensions({\n height: panel.scrollHeight,\n width: panel.scrollWidth\n });\n const abortController = new AbortController();\n abortControllerRef.current = abortController;\n const signal = abortController.signal;\n let attributeObserver = null;\n const endingStyleAttribute = CollapsiblePanelDataAttributes.endingStyle;\n\n // Wait for `[data-ending-style]` to be applied.\n attributeObserver = new MutationObserver(mutationList => {\n const hasEndingStyle = mutationList.some(mutation => mutation.type === 'attributes' && mutation.attributeName === endingStyleAttribute);\n if (hasEndingStyle) {\n attributeObserver?.disconnect();\n attributeObserver = null;\n runOnceAnimationsFinish(() => {\n setDimensions({\n height: 0,\n width: 0\n });\n panel.style.removeProperty('content-visibility');\n setMounted(false);\n if (abortControllerRef.current === abortController) {\n abortControllerRef.current = null;\n }\n }, signal);\n }\n });\n attributeObserver.observe(panel, {\n attributes: true,\n attributeFilter: [endingStyleAttribute]\n });\n return () => {\n attributeObserver?.disconnect();\n endingStyleFrame.cancel();\n if (abortControllerRef.current === abortController) {\n abortController.abort();\n abortControllerRef.current = null;\n }\n };\n }\n return () => {\n AnimationFrame.cancel(resizeFrame);\n };\n }, [abortControllerRef, animationTypeRef, endingStyleFrame, hiddenUntilFound, keepMounted, mounted, open, panelRef, runOnceAnimationsFinish, setDimensions, setMounted]);\n useIsoLayoutEffect(() => {\n if (animationTypeRef.current !== 'css-animation') {\n return;\n }\n const panel = panelRef.current;\n if (!panel) {\n return;\n }\n latestAnimationNameRef.current = panel.style.animationName || latestAnimationNameRef.current;\n panel.style.setProperty('animation-name', 'none');\n setDimensions({\n height: panel.scrollHeight,\n width: panel.scrollWidth\n });\n if (!shouldCancelInitialOpenAnimationRef.current && !isBeforeMatchRef.current) {\n panel.style.removeProperty('animation-name');\n }\n if (open) {\n if (abortControllerRef.current != null) {\n abortControllerRef.current.abort();\n abortControllerRef.current = null;\n }\n setMounted(true);\n setVisible(true);\n } else {\n abortControllerRef.current = new AbortController();\n runOnceAnimationsFinish(() => {\n setMounted(false);\n setVisible(false);\n abortControllerRef.current = null;\n }, abortControllerRef.current.signal);\n }\n }, [abortControllerRef, animationTypeRef, open, panelRef, runOnceAnimationsFinish, setDimensions, setMounted, setVisible, visible]);\n useOnMount(() => {\n const frame = AnimationFrame.request(() => {\n shouldCancelInitialOpenAnimationRef.current = false;\n });\n return () => AnimationFrame.cancel(frame);\n });\n useIsoLayoutEffect(() => {\n if (!hiddenUntilFound) {\n return undefined;\n }\n const panel = panelRef.current;\n if (!panel) {\n return undefined;\n }\n let frame = -1;\n let nextFrame = -1;\n if (open && isBeforeMatchRef.current) {\n panel.style.transitionDuration = '0s';\n setDimensions({\n height: panel.scrollHeight,\n width: panel.scrollWidth\n });\n frame = AnimationFrame.request(() => {\n isBeforeMatchRef.current = false;\n nextFrame = AnimationFrame.request(() => {\n setTimeout(() => {\n panel.style.removeProperty('transition-duration');\n });\n });\n });\n }\n return () => {\n AnimationFrame.cancel(frame);\n AnimationFrame.cancel(nextFrame);\n };\n }, [hiddenUntilFound, open, panelRef, setDimensions]);\n useIsoLayoutEffect(() => {\n const panel = panelRef.current;\n if (panel && hiddenUntilFound && hidden) {\n /**\n * React only supports a boolean for the `hidden` attribute and forces\n * legit string values to booleans so we have to force it back in the DOM\n * when necessary: https://github.com/facebook/react/issues/24740\n */\n panel.setAttribute('hidden', 'until-found');\n /**\n * Set data-starting-style here to persist the closed styles, this is to\n * prevent transitions from starting when the `hidden` attribute changes\n * to `'until-found'` as they could have different `display` properties:\n * https://github.com/tailwindlabs/tailwindcss/pull/14625\n */\n if (animationTypeRef.current === 'css-transition') {\n panel.setAttribute(CollapsiblePanelDataAttributes.startingStyle, '');\n }\n }\n }, [hiddenUntilFound, hidden, animationTypeRef, panelRef]);\n React.useEffect(function registerBeforeMatchListener() {\n const panel = panelRef.current;\n if (!panel) {\n return undefined;\n }\n function handleBeforeMatch(event) {\n isBeforeMatchRef.current = true;\n setOpen(true);\n onOpenChange(true, createChangeEventDetails(REASONS.none, event));\n }\n panel.addEventListener('beforematch', handleBeforeMatch);\n return () => {\n panel.removeEventListener('beforematch', handleBeforeMatch);\n };\n }, [onOpenChange, panelRef, setOpen]);\n return React.useMemo(() => ({\n props: {\n hidden,\n id: idParam,\n ref: mergedPanelRef\n }\n }), [hidden, idParam, mergedPanelRef]);\n}","export let AccordionPanelCssVars = /*#__PURE__*/function (AccordionPanelCssVars) {\n /**\n * The accordion panel's height.\n * @type {number}\n */\n AccordionPanelCssVars[\"accordionPanelHeight\"] = \"--accordion-panel-height\";\n /**\n * The accordion panel's width.\n * @type {number}\n */\n AccordionPanelCssVars[\"accordionPanelWidth\"] = \"--accordion-panel-width\";\n return AccordionPanelCssVars;\n}({});","'use client';\n\nimport { useIsoLayoutEffect } from \"./useIsoLayoutEffect.js\";\nimport { useRefWithInit } from \"./useRefWithInit.js\";\n\n/**\n * Untracks the provided value by turning it into a ref to remove its reactivity.\n *\n * Used to access the passed value inside `React.useEffect` without causing the effect to re-run when the value changes.\n */\nexport function useValueAsRef(value) {\n const latest = useRefWithInit(createLatestRef, value).current;\n latest.next = value;\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useIsoLayoutEffect(latest.effect);\n return latest;\n}\nfunction createLatestRef(value) {\n const latest = {\n current: value,\n next: value,\n effect: () => {\n latest.current = latest.next;\n }\n };\n return latest;\n}","'use client';\n\nimport * as React from 'react';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useValueAsRef } from '@base-ui-components/utils/useValueAsRef';\nimport { useAnimationsFinished } from \"./useAnimationsFinished.js\";\n\n/**\n * Calls the provided function when the CSS open/close animation or transition completes.\n */\nexport function useOpenChangeComplete(parameters) {\n const {\n enabled = true,\n open,\n ref,\n onComplete: onCompleteParam\n } = parameters;\n const openRef = useValueAsRef(open);\n const onComplete = useStableCallback(onCompleteParam);\n const runOnceAnimationsFinish = useAnimationsFinished(ref, open);\n React.useEffect(() => {\n if (!enabled) {\n return;\n }\n runOnceAnimationsFinish(() => {\n if (open === openRef.current) {\n onComplete();\n }\n });\n }, [enabled, open, onComplete, runOnceAnimationsFinish, openRef]);\n}","'use client';\n\nimport * as React from 'react';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { warn } from '@base-ui-components/utils/warn';\nimport { useCollapsibleRootContext } from \"../../collapsible/root/CollapsibleRootContext.js\";\nimport { useCollapsiblePanel } from \"../../collapsible/panel/useCollapsiblePanel.js\";\nimport { useAccordionRootContext } from \"../root/AccordionRootContext.js\";\nimport { useAccordionItemContext } from \"../item/AccordionItemContext.js\";\nimport { accordionStateAttributesMapping } from \"../item/stateAttributesMapping.js\";\nimport { AccordionPanelCssVars } from \"./AccordionPanelCssVars.js\";\nimport { useOpenChangeComplete } from \"../../utils/useOpenChangeComplete.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\n/**\n * A collapsible panel with the accordion item contents.\n * Renders a `<div>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\nexport const AccordionPanel = /*#__PURE__*/React.forwardRef(function AccordionPanel(componentProps, forwardedRef) {\n const {\n className,\n hiddenUntilFound: hiddenUntilFoundProp,\n keepMounted: keepMountedProp,\n id: idProp,\n render,\n ...elementProps\n } = componentProps;\n const {\n hiddenUntilFound: contextHiddenUntilFound,\n keepMounted: contextKeepMounted\n } = useAccordionRootContext();\n const {\n abortControllerRef,\n animationTypeRef,\n height,\n mounted,\n onOpenChange,\n open,\n panelId,\n panelRef,\n runOnceAnimationsFinish,\n setDimensions,\n setHiddenUntilFound,\n setKeepMounted,\n setMounted,\n setOpen,\n setVisible,\n transitionDimensionRef,\n visible,\n width,\n setPanelIdState,\n transitionStatus\n } = useCollapsibleRootContext();\n const hiddenUntilFound = hiddenUntilFoundProp ?? contextHiddenUntilFound;\n const keepMounted = keepMountedProp ?? contextKeepMounted;\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useIsoLayoutEffect(() => {\n if (keepMountedProp === false && hiddenUntilFound) {\n warn('The `keepMounted={false}` prop on a Accordion.Panel will be ignored when using `contextHiddenUntilFound` on the Panel or the Root since it requires the panel to remain mounted when closed.');\n }\n }, [hiddenUntilFound, keepMountedProp]);\n }\n useIsoLayoutEffect(() => {\n if (idProp) {\n setPanelIdState(idProp);\n return () => {\n setPanelIdState(undefined);\n };\n }\n return undefined;\n }, [idProp, setPanelIdState]);\n useIsoLayoutEffect(() => {\n setHiddenUntilFound(hiddenUntilFound);\n }, [setHiddenUntilFound, hiddenUntilFound]);\n useIsoLayoutEffect(() => {\n setKeepMounted(keepMounted);\n }, [setKeepMounted, keepMounted]);\n useOpenChangeComplete({\n open: open && transitionStatus === 'idle',\n ref: panelRef,\n onComplete() {\n if (!open) {\n return;\n }\n setDimensions({\n width: undefined,\n height: undefined\n });\n }\n });\n const {\n props\n } = useCollapsiblePanel({\n abortControllerRef,\n animationTypeRef,\n externalRef: forwardedRef,\n height,\n hiddenUntilFound,\n id: idProp ?? panelId,\n keepMounted,\n mounted,\n onOpenChange,\n open,\n panelRef,\n runOnceAnimationsFinish,\n setDimensions,\n setMounted,\n setOpen,\n setVisible,\n transitionDimensionRef,\n visible,\n width\n });\n const {\n state,\n triggerId\n } = useAccordionItemContext();\n const panelState = React.useMemo(() => ({\n ...state,\n transitionStatus\n }), [state, transitionStatus]);\n const element = useRenderElement('div', componentProps, {\n state: panelState,\n ref: [forwardedRef, panelRef],\n props: [props, {\n 'aria-labelledby': triggerId,\n role: 'region',\n style: {\n [AccordionPanelCssVars.accordionPanelHeight]: height === undefined ? 'auto' : `${height}px`,\n [AccordionPanelCssVars.accordionPanelWidth]: width === undefined ? 'auto' : `${width}px`\n }\n }, elementProps],\n stateAttributesMapping: accordionStateAttributesMapping\n });\n const shouldRender = keepMounted || hiddenUntilFound || !keepMounted && mounted;\n if (!shouldRender) {\n return null;\n }\n return element;\n});\nif (process.env.NODE_ENV !== \"production\") AccordionPanel.displayName = \"AccordionPanel\";","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","/**\n * Concatenates two arrays faster than the array spread operator.\n */\nconst concatArrays = (array1, array2) => {\n // Pre-allocate for better V8 optimization\n const combinedArray = new Array(array1.length + array2.length);\n for (let i = 0; i < array1.length; i++) {\n combinedArray[i] = array1[i];\n }\n for (let i = 0; i < array2.length; i++) {\n combinedArray[array1.length + i] = array2[i];\n }\n return combinedArray;\n};\n\n// Factory function ensures consistent object shapes\nconst createClassValidatorObject = (classGroupId, validator) => ({\n classGroupId,\n validator\n});\n// Factory ensures consistent ClassPartObject shape\nconst createClassPartObject = (nextPart = new Map(), validators = null, classGroupId) => ({\n nextPart,\n validators,\n classGroupId\n});\nconst CLASS_PART_SEPARATOR = '-';\nconst EMPTY_CONFLICTS = [];\n// I use two dots here because one dot is used as prefix for class groups in plugins\nconst ARBITRARY_PROPERTY_PREFIX = 'arbitrary..';\nconst createClassGroupUtils = config => {\n const classMap = createClassMap(config);\n const {\n conflictingClassGroups,\n conflictingClassGroupModifiers\n } = config;\n const getClassGroupId = className => {\n if (className.startsWith('[') && className.endsWith(']')) {\n return getGroupIdForArbitraryProperty(className);\n }\n const classParts = className.split(CLASS_PART_SEPARATOR);\n // Classes like `-inset-1` produce an empty string as first classPart. We assume that classes for negative values are used correctly and skip it.\n const startIndex = classParts[0] === '' && classParts.length > 1 ? 1 : 0;\n return getGroupRecursive(classParts, startIndex, classMap);\n };\n const getConflictingClassGroupIds = (classGroupId, hasPostfixModifier) => {\n if (hasPostfixModifier) {\n const modifierConflicts = conflictingClassGroupModifiers[classGroupId];\n const baseConflicts = conflictingClassGroups[classGroupId];\n if (modifierConflicts) {\n if (baseConflicts) {\n // Merge base conflicts with modifier conflicts\n return concatArrays(baseConflicts, modifierConflicts);\n }\n // Only modifier conflicts\n return modifierConflicts;\n }\n // Fall back to without postfix if no modifier conflicts\n return baseConflicts || EMPTY_CONFLICTS;\n }\n return conflictingClassGroups[classGroupId] || EMPTY_CONFLICTS;\n };\n return {\n getClassGroupId,\n getConflictingClassGroupIds\n };\n};\nconst getGroupRecursive = (classParts, startIndex, classPartObject) => {\n const classPathsLength = classParts.length - startIndex;\n if (classPathsLength === 0) {\n return classPartObject.classGroupId;\n }\n const currentClassPart = classParts[startIndex];\n const nextClassPartObject = classPartObject.nextPart.get(currentClassPart);\n if (nextClassPartObject) {\n const result = getGroupRecursive(classParts, startIndex + 1, nextClassPartObject);\n if (result) return result;\n }\n const validators = classPartObject.validators;\n if (validators === null) {\n return undefined;\n }\n // Build classRest string efficiently by joining from startIndex onwards\n const classRest = startIndex === 0 ? classParts.join(CLASS_PART_SEPARATOR) : classParts.slice(startIndex).join(CLASS_PART_SEPARATOR);\n const validatorsLength = validators.length;\n for (let i = 0; i < validatorsLength; i++) {\n const validatorObj = validators[i];\n if (validatorObj.validator(classRest)) {\n return validatorObj.classGroupId;\n }\n }\n return undefined;\n};\n/**\n * Get the class group ID for an arbitrary property.\n *\n * @param className - The class name to get the group ID for. Is expected to be string starting with `[` and ending with `]`.\n */\nconst getGroupIdForArbitraryProperty = className => className.slice(1, -1).indexOf(':') === -1 ? undefined : (() => {\n const content = className.slice(1, -1);\n const colonIndex = content.indexOf(':');\n const property = content.slice(0, colonIndex);\n return property ? ARBITRARY_PROPERTY_PREFIX + property : undefined;\n})();\n/**\n * Exported for testing only\n */\nconst createClassMap = config => {\n const {\n theme,\n classGroups\n } = config;\n return processClassGroups(classGroups, theme);\n};\n// Split into separate functions to maintain monomorphic call sites\nconst processClassGroups = (classGroups, theme) => {\n const classMap = createClassPartObject();\n for (const classGroupId in classGroups) {\n const group = classGroups[classGroupId];\n processClassesRecursively(group, classMap, classGroupId, theme);\n }\n return classMap;\n};\nconst processClassesRecursively = (classGroup, classPartObject, classGroupId, theme) => {\n const len = classGroup.length;\n for (let i = 0; i < len; i++) {\n const classDefinition = classGroup[i];\n processClassDefinition(classDefinition, classPartObject, classGroupId, theme);\n }\n};\n// Split into separate functions for each type to maintain monomorphic call sites\nconst processClassDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n if (typeof classDefinition === 'string') {\n processStringDefinition(classDefinition, classPartObject, classGroupId);\n return;\n }\n if (typeof classDefinition === 'function') {\n processFunctionDefinition(classDefinition, classPartObject, classGroupId, theme);\n return;\n }\n processObjectDefinition(classDefinition, classPartObject, classGroupId, theme);\n};\nconst processStringDefinition = (classDefinition, classPartObject, classGroupId) => {\n const classPartObjectToEdit = classDefinition === '' ? classPartObject : getPart(classPartObject, classDefinition);\n classPartObjectToEdit.classGroupId = classGroupId;\n};\nconst processFunctionDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n if (isThemeGetter(classDefinition)) {\n processClassesRecursively(classDefinition(theme), classPartObject, classGroupId, theme);\n return;\n }\n if (classPartObject.validators === null) {\n classPartObject.validators = [];\n }\n classPartObject.validators.push(createClassValidatorObject(classGroupId, classDefinition));\n};\nconst processObjectDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n const entries = Object.entries(classDefinition);\n const len = entries.length;\n for (let i = 0; i < len; i++) {\n const [key, value] = entries[i];\n processClassesRecursively(value, getPart(classPartObject, key), classGroupId, theme);\n }\n};\nconst getPart = (classPartObject, path) => {\n let current = classPartObject;\n const parts = path.split(CLASS_PART_SEPARATOR);\n const len = parts.length;\n for (let i = 0; i < len; i++) {\n const part = parts[i];\n let next = current.nextPart.get(part);\n if (!next) {\n next = createClassPartObject();\n current.nextPart.set(part, next);\n }\n current = next;\n }\n return current;\n};\n// Type guard maintains monomorphic check\nconst isThemeGetter = func => 'isThemeGetter' in func && func.isThemeGetter === true;\n\n// LRU cache implementation using plain objects for simplicity\nconst createLruCache = maxCacheSize => {\n if (maxCacheSize < 1) {\n return {\n get: () => undefined,\n set: () => {}\n };\n }\n let cacheSize = 0;\n let cache = Object.create(null);\n let previousCache = Object.create(null);\n const update = (key, value) => {\n cache[key] = value;\n cacheSize++;\n if (cacheSize > maxCacheSize) {\n cacheSize = 0;\n previousCache = cache;\n cache = Object.create(null);\n }\n };\n return {\n get(key) {\n let value = cache[key];\n if (value !== undefined) {\n return value;\n }\n if ((value = previousCache[key]) !== undefined) {\n update(key, value);\n return value;\n }\n },\n set(key, value) {\n if (key in cache) {\n cache[key] = value;\n } else {\n update(key, value);\n }\n }\n };\n};\nconst IMPORTANT_MODIFIER = '!';\nconst MODIFIER_SEPARATOR = ':';\nconst EMPTY_MODIFIERS = [];\n// Pre-allocated result object shape for consistency\nconst createResultObject = (modifiers, hasImportantModifier, baseClassName, maybePostfixModifierPosition, isExternal) => ({\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition,\n isExternal\n});\nconst createParseClassName = config => {\n const {\n prefix,\n experimentalParseClassName\n } = config;\n /**\n * Parse class name into parts.\n *\n * Inspired by `splitAtTopLevelOnly` used in Tailwind CSS\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v3.2.2/src/util/splitAtTopLevelOnly.js\n */\n let parseClassName = className => {\n // Use simple array with push for better performance\n const modifiers = [];\n let bracketDepth = 0;\n let parenDepth = 0;\n let modifierStart = 0;\n let postfixModifierPosition;\n const len = className.length;\n for (let index = 0; index < len; index++) {\n const currentCharacter = className[index];\n if (bracketDepth === 0 && parenDepth === 0) {\n if (currentCharacter === MODIFIER_SEPARATOR) {\n modifiers.push(className.slice(modifierStart, index));\n modifierStart = index + 1;\n continue;\n }\n if (currentCharacter === '/') {\n postfixModifierPosition = index;\n continue;\n }\n }\n if (currentCharacter === '[') bracketDepth++;else if (currentCharacter === ']') bracketDepth--;else if (currentCharacter === '(') parenDepth++;else if (currentCharacter === ')') parenDepth--;\n }\n const baseClassNameWithImportantModifier = modifiers.length === 0 ? className : className.slice(modifierStart);\n // Inline important modifier check\n let baseClassName = baseClassNameWithImportantModifier;\n let hasImportantModifier = false;\n if (baseClassNameWithImportantModifier.endsWith(IMPORTANT_MODIFIER)) {\n baseClassName = baseClassNameWithImportantModifier.slice(0, -1);\n hasImportantModifier = true;\n } else if (\n /**\n * In Tailwind CSS v3 the important modifier was at the start of the base class name. This is still supported for legacy reasons.\n * @see https://github.com/dcastil/tailwind-merge/issues/513#issuecomment-2614029864\n */\n baseClassNameWithImportantModifier.startsWith(IMPORTANT_MODIFIER)) {\n baseClassName = baseClassNameWithImportantModifier.slice(1);\n hasImportantModifier = true;\n }\n const maybePostfixModifierPosition = postfixModifierPosition && postfixModifierPosition > modifierStart ? postfixModifierPosition - modifierStart : undefined;\n return createResultObject(modifiers, hasImportantModifier, baseClassName, maybePostfixModifierPosition);\n };\n if (prefix) {\n const fullPrefix = prefix + MODIFIER_SEPARATOR;\n const parseClassNameOriginal = parseClassName;\n parseClassName = className => className.startsWith(fullPrefix) ? parseClassNameOriginal(className.slice(fullPrefix.length)) : createResultObject(EMPTY_MODIFIERS, false, className, undefined, true);\n }\n if (experimentalParseClassName) {\n const parseClassNameOriginal = parseClassName;\n parseClassName = className => experimentalParseClassName({\n className,\n parseClassName: parseClassNameOriginal\n });\n }\n return parseClassName;\n};\n\n/**\n * Sorts modifiers according to following schema:\n * - Predefined modifiers are sorted alphabetically\n * - When an arbitrary variant appears, it must be preserved which modifiers are before and after it\n */\nconst createSortModifiers = config => {\n // Pre-compute weights for all known modifiers for O(1) comparison\n const modifierWeights = new Map();\n // Assign weights to sensitive modifiers (highest priority, but preserve order)\n config.orderSensitiveModifiers.forEach((mod, index) => {\n modifierWeights.set(mod, 1000000 + index); // High weights for sensitive mods\n });\n return modifiers => {\n const result = [];\n let currentSegment = [];\n // Process modifiers in one pass\n for (let i = 0; i < modifiers.length; i++) {\n const modifier = modifiers[i];\n // Check if modifier is sensitive (starts with '[' or in orderSensitiveModifiers)\n const isArbitrary = modifier[0] === '[';\n const isOrderSensitive = modifierWeights.has(modifier);\n if (isArbitrary || isOrderSensitive) {\n // Sort and flush current segment alphabetically\n if (currentSegment.length > 0) {\n currentSegment.sort();\n result.push(...currentSegment);\n currentSegment = [];\n }\n result.push(modifier);\n } else {\n // Regular modifier - add to current segment for batch sorting\n currentSegment.push(modifier);\n }\n }\n // Sort and add any remaining segment items\n if (currentSegment.length > 0) {\n currentSegment.sort();\n result.push(...currentSegment);\n }\n return result;\n };\n};\nconst createConfigUtils = config => ({\n cache: createLruCache(config.cacheSize),\n parseClassName: createParseClassName(config),\n sortModifiers: createSortModifiers(config),\n ...createClassGroupUtils(config)\n});\nconst SPLIT_CLASSES_REGEX = /\\s+/;\nconst mergeClassList = (classList, configUtils) => {\n const {\n parseClassName,\n getClassGroupId,\n getConflictingClassGroupIds,\n sortModifiers\n } = configUtils;\n /**\n * Set of classGroupIds in following format:\n * `{importantModifier}{variantModifiers}{classGroupId}`\n * @example 'float'\n * @example 'hover:focus:bg-color'\n * @example 'md:!pr'\n */\n const classGroupsInConflict = [];\n const classNames = classList.trim().split(SPLIT_CLASSES_REGEX);\n let result = '';\n for (let index = classNames.length - 1; index >= 0; index -= 1) {\n const originalClassName = classNames[index];\n const {\n isExternal,\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition\n } = parseClassName(originalClassName);\n if (isExternal) {\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n let hasPostfixModifier = !!maybePostfixModifierPosition;\n let classGroupId = getClassGroupId(hasPostfixModifier ? baseClassName.substring(0, maybePostfixModifierPosition) : baseClassName);\n if (!classGroupId) {\n if (!hasPostfixModifier) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n classGroupId = getClassGroupId(baseClassName);\n if (!classGroupId) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n hasPostfixModifier = false;\n }\n // Fast path: skip sorting for empty or single modifier\n const variantModifier = modifiers.length === 0 ? '' : modifiers.length === 1 ? modifiers[0] : sortModifiers(modifiers).join(':');\n const modifierId = hasImportantModifier ? variantModifier + IMPORTANT_MODIFIER : variantModifier;\n const classId = modifierId + classGroupId;\n if (classGroupsInConflict.indexOf(classId) > -1) {\n // Tailwind class omitted due to conflict\n continue;\n }\n classGroupsInConflict.push(classId);\n const conflictGroups = getConflictingClassGroupIds(classGroupId, hasPostfixModifier);\n for (let i = 0; i < conflictGroups.length; ++i) {\n const group = conflictGroups[i];\n classGroupsInConflict.push(modifierId + group);\n }\n // Tailwind class not in conflict\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n }\n return result;\n};\n\n/**\n * The code in this file is copied from https://github.com/lukeed/clsx and modified to suit the needs of tailwind-merge better.\n *\n * Specifically:\n * - Runtime code from https://github.com/lukeed/clsx/blob/v1.2.1/src/index.js\n * - TypeScript types from https://github.com/lukeed/clsx/blob/v1.2.1/clsx.d.ts\n *\n * Original code has MIT license: Copyright (c) Luke Edwards <luke.edwards05@gmail.com> (lukeed.com)\n */\nconst twJoin = (...classLists) => {\n let index = 0;\n let argument;\n let resolvedValue;\n let string = '';\n while (index < classLists.length) {\n if (argument = classLists[index++]) {\n if (resolvedValue = toValue(argument)) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n};\nconst toValue = mix => {\n // Fast path for strings\n if (typeof mix === 'string') {\n return mix;\n }\n let resolvedValue;\n let string = '';\n for (let k = 0; k < mix.length; k++) {\n if (mix[k]) {\n if (resolvedValue = toValue(mix[k])) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n};\nconst createTailwindMerge = (createConfigFirst, ...createConfigRest) => {\n let configUtils;\n let cacheGet;\n let cacheSet;\n let functionToCall;\n const initTailwindMerge = classList => {\n const config = createConfigRest.reduce((previousConfig, createConfigCurrent) => createConfigCurrent(previousConfig), createConfigFirst());\n configUtils = createConfigUtils(config);\n cacheGet = configUtils.cache.get;\n cacheSet = configUtils.cache.set;\n functionToCall = tailwindMerge;\n return tailwindMerge(classList);\n };\n const tailwindMerge = classList => {\n const cachedResult = cacheGet(classList);\n if (cachedResult) {\n return cachedResult;\n }\n const result = mergeClassList(classList, configUtils);\n cacheSet(classList, result);\n return result;\n };\n functionToCall = initTailwindMerge;\n return (...args) => functionToCall(twJoin(...args));\n};\nconst fallbackThemeArr = [];\nconst fromTheme = key => {\n const themeGetter = theme => theme[key] || fallbackThemeArr;\n themeGetter.isThemeGetter = true;\n return themeGetter;\n};\nconst arbitraryValueRegex = /^\\[(?:(\\w[\\w-]*):)?(.+)\\]$/i;\nconst arbitraryVariableRegex = /^\\((?:(\\w[\\w-]*):)?(.+)\\)$/i;\nconst fractionRegex = /^\\d+\\/\\d+$/;\nconst tshirtUnitRegex = /^(\\d+(\\.\\d+)?)?(xs|sm|md|lg|xl)$/;\nconst lengthUnitRegex = /\\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\\b(calc|min|max|clamp)\\(.+\\)|^0$/;\nconst colorFunctionRegex = /^(rgba?|hsla?|hwb|(ok)?(lab|lch)|color-mix)\\(.+\\)$/;\n// Shadow always begins with x and y offset separated by underscore optionally prepended by inset\nconst shadowRegex = /^(inset_)?-?((\\d+)?\\.?(\\d+)[a-z]+|0)_-?((\\d+)?\\.?(\\d+)[a-z]+|0)/;\nconst imageRegex = /^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\\(.+\\)$/;\nconst isFraction = value => fractionRegex.test(value);\nconst isNumber = value => !!value && !Number.isNaN(Number(value));\nconst isInteger = value => !!value && Number.isInteger(Number(value));\nconst isPercent = value => value.endsWith('%') && isNumber(value.slice(0, -1));\nconst isTshirtSize = value => tshirtUnitRegex.test(value);\nconst isAny = () => true;\nconst isLengthOnly = value =>\n// `colorFunctionRegex` check is necessary because color functions can have percentages in them which which would be incorrectly classified as lengths.\n// For example, `hsl(0 0% 0%)` would be classified as a length without this check.\n// I could also use lookbehind assertion in `lengthUnitRegex` but that isn't supported widely enough.\nlengthUnitRegex.test(value) && !colorFunctionRegex.test(value);\nconst isNever = () => false;\nconst isShadow = value => shadowRegex.test(value);\nconst isImage = value => imageRegex.test(value);\nconst isAnyNonArbitrary = value => !isArbitraryValue(value) && !isArbitraryVariable(value);\nconst isArbitrarySize = value => getIsArbitraryValue(value, isLabelSize, isNever);\nconst isArbitraryValue = value => arbitraryValueRegex.test(value);\nconst isArbitraryLength = value => getIsArbitraryValue(value, isLabelLength, isLengthOnly);\nconst isArbitraryNumber = value => getIsArbitraryValue(value, isLabelNumber, isNumber);\nconst isArbitraryPosition = value => getIsArbitraryValue(value, isLabelPosition, isNever);\nconst isArbitraryImage = value => getIsArbitraryValue(value, isLabelImage, isImage);\nconst isArbitraryShadow = value => getIsArbitraryValue(value, isLabelShadow, isShadow);\nconst isArbitraryVariable = value => arbitraryVariableRegex.test(value);\nconst isArbitraryVariableLength = value => getIsArbitraryVariable(value, isLabelLength);\nconst isArbitraryVariableFamilyName = value => getIsArbitraryVariable(value, isLabelFamilyName);\nconst isArbitraryVariablePosition = value => getIsArbitraryVariable(value, isLabelPosition);\nconst isArbitraryVariableSize = value => getIsArbitraryVariable(value, isLabelSize);\nconst isArbitraryVariableImage = value => getIsArbitraryVariable(value, isLabelImage);\nconst isArbitraryVariableShadow = value => getIsArbitraryVariable(value, isLabelShadow, true);\n// Helpers\nconst getIsArbitraryValue = (value, testLabel, testValue) => {\n const result = arbitraryValueRegex.exec(value);\n if (result) {\n if (result[1]) {\n return testLabel(result[1]);\n }\n return testValue(result[2]);\n }\n return false;\n};\nconst getIsArbitraryVariable = (value, testLabel, shouldMatchNoLabel = false) => {\n const result = arbitraryVariableRegex.exec(value);\n if (result) {\n if (result[1]) {\n return testLabel(result[1]);\n }\n return shouldMatchNoLabel;\n }\n return false;\n};\n// Labels\nconst isLabelPosition = label => label === 'position' || label === 'percentage';\nconst isLabelImage = label => label === 'image' || label === 'url';\nconst isLabelSize = label => label === 'length' || label === 'size' || label === 'bg-size';\nconst isLabelLength = label => label === 'length';\nconst isLabelNumber = label => label === 'number';\nconst isLabelFamilyName = label => label === 'family-name';\nconst isLabelShadow = label => label === 'shadow';\nconst validators = /*#__PURE__*/Object.defineProperty({\n __proto__: null,\n isAny,\n isAnyNonArbitrary,\n isArbitraryImage,\n isArbitraryLength,\n isArbitraryNumber,\n isArbitraryPosition,\n isArbitraryShadow,\n isArbitrarySize,\n isArbitraryValue,\n isArbitraryVariable,\n isArbitraryVariableFamilyName,\n isArbitraryVariableImage,\n isArbitraryVariableLength,\n isArbitraryVariablePosition,\n isArbitraryVariableShadow,\n isArbitraryVariableSize,\n isFraction,\n isInteger,\n isNumber,\n isPercent,\n isTshirtSize\n}, Symbol.toStringTag, {\n value: 'Module'\n});\nconst getDefaultConfig = () => {\n /**\n * Theme getters for theme variable namespaces\n * @see https://tailwindcss.com/docs/theme#theme-variable-namespaces\n */\n /***/\n const themeColor = fromTheme('color');\n const themeFont = fromTheme('font');\n const themeText = fromTheme('text');\n const themeFontWeight = fromTheme('font-weight');\n const themeTracking = fromTheme('tracking');\n const themeLeading = fromTheme('leading');\n const themeBreakpoint = fromTheme('breakpoint');\n const themeContainer = fromTheme('container');\n const themeSpacing = fromTheme('spacing');\n const themeRadius = fromTheme('radius');\n const themeShadow = fromTheme('shadow');\n const themeInsetShadow = fromTheme('inset-shadow');\n const themeTextShadow = fromTheme('text-shadow');\n const themeDropShadow = fromTheme('drop-shadow');\n const themeBlur = fromTheme('blur');\n const themePerspective = fromTheme('perspective');\n const themeAspect = fromTheme('aspect');\n const themeEase = fromTheme('ease');\n const themeAnimate = fromTheme('animate');\n /**\n * Helpers to avoid repeating the same scales\n *\n * We use functions that create a new array every time they're called instead of static arrays.\n * This ensures that users who modify any scale by mutating the array (e.g. with `array.push(element)`) don't accidentally mutate arrays in other parts of the config.\n */\n /***/\n const scaleBreak = () => ['auto', 'avoid', 'all', 'avoid-page', 'page', 'left', 'right', 'column'];\n const scalePosition = () => ['center', 'top', 'bottom', 'left', 'right', 'top-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-top', 'top-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-top', 'bottom-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-bottom', 'bottom-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-bottom'];\n const scalePositionWithArbitrary = () => [...scalePosition(), isArbitraryVariable, isArbitraryValue];\n const scaleOverflow = () => ['auto', 'hidden', 'clip', 'visible', 'scroll'];\n const scaleOverscroll = () => ['auto', 'contain', 'none'];\n const scaleUnambiguousSpacing = () => [isArbitraryVariable, isArbitraryValue, themeSpacing];\n const scaleInset = () => [isFraction, 'full', 'auto', ...scaleUnambiguousSpacing()];\n const scaleGridTemplateColsRows = () => [isInteger, 'none', 'subgrid', isArbitraryVariable, isArbitraryValue];\n const scaleGridColRowStartAndEnd = () => ['auto', {\n span: ['full', isInteger, isArbitraryVariable, isArbitraryValue]\n }, isInteger, isArbitraryVariable, isArbitraryValue];\n const scaleGridColRowStartOrEnd = () => [isInteger, 'auto', isArbitraryVariable, isArbitraryValue];\n const scaleGridAutoColsRows = () => ['auto', 'min', 'max', 'fr', isArbitraryVariable, isArbitraryValue];\n const scaleAlignPrimaryAxis = () => ['start', 'end', 'center', 'between', 'around', 'evenly', 'stretch', 'baseline', 'center-safe', 'end-safe'];\n const scaleAlignSecondaryAxis = () => ['start', 'end', 'center', 'stretch', 'center-safe', 'end-safe'];\n const scaleMargin = () => ['auto', ...scaleUnambiguousSpacing()];\n const scaleSizing = () => [isFraction, 'auto', 'full', 'dvw', 'dvh', 'lvw', 'lvh', 'svw', 'svh', 'min', 'max', 'fit', ...scaleUnambiguousSpacing()];\n const scaleColor = () => [themeColor, isArbitraryVariable, isArbitraryValue];\n const scaleBgPosition = () => [...scalePosition(), isArbitraryVariablePosition, isArbitraryPosition, {\n position: [isArbitraryVariable, isArbitraryValue]\n }];\n const scaleBgRepeat = () => ['no-repeat', {\n repeat: ['', 'x', 'y', 'space', 'round']\n }];\n const scaleBgSize = () => ['auto', 'cover', 'contain', isArbitraryVariableSize, isArbitrarySize, {\n size: [isArbitraryVariable, isArbitraryValue]\n }];\n const scaleGradientStopPosition = () => [isPercent, isArbitraryVariableLength, isArbitraryLength];\n const scaleRadius = () => [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', 'full', themeRadius, isArbitraryVariable, isArbitraryValue];\n const scaleBorderWidth = () => ['', isNumber, isArbitraryVariableLength, isArbitraryLength];\n const scaleLineStyle = () => ['solid', 'dashed', 'dotted', 'double'];\n const scaleBlendMode = () => ['normal', 'multiply', 'screen', 'overlay', 'darken', 'lighten', 'color-dodge', 'color-burn', 'hard-light', 'soft-light', 'difference', 'exclusion', 'hue', 'saturation', 'color', 'luminosity'];\n const scaleMaskImagePosition = () => [isNumber, isPercent, isArbitraryVariablePosition, isArbitraryPosition];\n const scaleBlur = () => [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeBlur, isArbitraryVariable, isArbitraryValue];\n const scaleRotate = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleScale = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleSkew = () => [isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleTranslate = () => [isFraction, 'full', ...scaleUnambiguousSpacing()];\n return {\n cacheSize: 500,\n theme: {\n animate: ['spin', 'ping', 'pulse', 'bounce'],\n aspect: ['video'],\n blur: [isTshirtSize],\n breakpoint: [isTshirtSize],\n color: [isAny],\n container: [isTshirtSize],\n 'drop-shadow': [isTshirtSize],\n ease: ['in', 'out', 'in-out'],\n font: [isAnyNonArbitrary],\n 'font-weight': ['thin', 'extralight', 'light', 'normal', 'medium', 'semibold', 'bold', 'extrabold', 'black'],\n 'inset-shadow': [isTshirtSize],\n leading: ['none', 'tight', 'snug', 'normal', 'relaxed', 'loose'],\n perspective: ['dramatic', 'near', 'normal', 'midrange', 'distant', 'none'],\n radius: [isTshirtSize],\n shadow: [isTshirtSize],\n spacing: ['px', isNumber],\n text: [isTshirtSize],\n 'text-shadow': [isTshirtSize],\n tracking: ['tighter', 'tight', 'normal', 'wide', 'wider', 'widest']\n },\n classGroups: {\n // --------------\n // --- Layout ---\n // --------------\n /**\n * Aspect Ratio\n * @see https://tailwindcss.com/docs/aspect-ratio\n */\n aspect: [{\n aspect: ['auto', 'square', isFraction, isArbitraryValue, isArbitraryVariable, themeAspect]\n }],\n /**\n * Container\n * @see https://tailwindcss.com/docs/container\n * @deprecated since Tailwind CSS v4.0.0\n */\n container: ['container'],\n /**\n * Columns\n * @see https://tailwindcss.com/docs/columns\n */\n columns: [{\n columns: [isNumber, isArbitraryValue, isArbitraryVariable, themeContainer]\n }],\n /**\n * Break After\n * @see https://tailwindcss.com/docs/break-after\n */\n 'break-after': [{\n 'break-after': scaleBreak()\n }],\n /**\n * Break Before\n * @see https://tailwindcss.com/docs/break-before\n */\n 'break-before': [{\n 'break-before': scaleBreak()\n }],\n /**\n * Break Inside\n * @see https://tailwindcss.com/docs/break-inside\n */\n 'break-inside': [{\n 'break-inside': ['auto', 'avoid', 'avoid-page', 'avoid-column']\n }],\n /**\n * Box Decoration Break\n * @see https://tailwindcss.com/docs/box-decoration-break\n */\n 'box-decoration': [{\n 'box-decoration': ['slice', 'clone']\n }],\n /**\n * Box Sizing\n * @see https://tailwindcss.com/docs/box-sizing\n */\n box: [{\n box: ['border', 'content']\n }],\n /**\n * Display\n * @see https://tailwindcss.com/docs/display\n */\n display: ['block', 'inline-block', 'inline', 'flex', 'inline-flex', 'table', 'inline-table', 'table-caption', 'table-cell', 'table-column', 'table-column-group', 'table-footer-group', 'table-header-group', 'table-row-group', 'table-row', 'flow-root', 'grid', 'inline-grid', 'contents', 'list-item', 'hidden'],\n /**\n * Screen Reader Only\n * @see https://tailwindcss.com/docs/display#screen-reader-only\n */\n sr: ['sr-only', 'not-sr-only'],\n /**\n * Floats\n * @see https://tailwindcss.com/docs/float\n */\n float: [{\n float: ['right', 'left', 'none', 'start', 'end']\n }],\n /**\n * Clear\n * @see https://tailwindcss.com/docs/clear\n */\n clear: [{\n clear: ['left', 'right', 'both', 'none', 'start', 'end']\n }],\n /**\n * Isolation\n * @see https://tailwindcss.com/docs/isolation\n */\n isolation: ['isolate', 'isolation-auto'],\n /**\n * Object Fit\n * @see https://tailwindcss.com/docs/object-fit\n */\n 'object-fit': [{\n object: ['contain', 'cover', 'fill', 'none', 'scale-down']\n }],\n /**\n * Object Position\n * @see https://tailwindcss.com/docs/object-position\n */\n 'object-position': [{\n object: scalePositionWithArbitrary()\n }],\n /**\n * Overflow\n * @see https://tailwindcss.com/docs/overflow\n */\n overflow: [{\n overflow: scaleOverflow()\n }],\n /**\n * Overflow X\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-x': [{\n 'overflow-x': scaleOverflow()\n }],\n /**\n * Overflow Y\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-y': [{\n 'overflow-y': scaleOverflow()\n }],\n /**\n * Overscroll Behavior\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n overscroll: [{\n overscroll: scaleOverscroll()\n }],\n /**\n * Overscroll Behavior X\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-x': [{\n 'overscroll-x': scaleOverscroll()\n }],\n /**\n * Overscroll Behavior Y\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-y': [{\n 'overscroll-y': scaleOverscroll()\n }],\n /**\n * Position\n * @see https://tailwindcss.com/docs/position\n */\n position: ['static', 'fixed', 'absolute', 'relative', 'sticky'],\n /**\n * Top / Right / Bottom / Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n inset: [{\n inset: scaleInset()\n }],\n /**\n * Right / Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-x': [{\n 'inset-x': scaleInset()\n }],\n /**\n * Top / Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-y': [{\n 'inset-y': scaleInset()\n }],\n /**\n * Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n start: [{\n start: scaleInset()\n }],\n /**\n * End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n end: [{\n end: scaleInset()\n }],\n /**\n * Top\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n top: [{\n top: scaleInset()\n }],\n /**\n * Right\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n right: [{\n right: scaleInset()\n }],\n /**\n * Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n bottom: [{\n bottom: scaleInset()\n }],\n /**\n * Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n left: [{\n left: scaleInset()\n }],\n /**\n * Visibility\n * @see https://tailwindcss.com/docs/visibility\n */\n visibility: ['visible', 'invisible', 'collapse'],\n /**\n * Z-Index\n * @see https://tailwindcss.com/docs/z-index\n */\n z: [{\n z: [isInteger, 'auto', isArbitraryVariable, isArbitraryValue]\n }],\n // ------------------------\n // --- Flexbox and Grid ---\n // ------------------------\n /**\n * Flex Basis\n * @see https://tailwindcss.com/docs/flex-basis\n */\n basis: [{\n basis: [isFraction, 'full', 'auto', themeContainer, ...scaleUnambiguousSpacing()]\n }],\n /**\n * Flex Direction\n * @see https://tailwindcss.com/docs/flex-direction\n */\n 'flex-direction': [{\n flex: ['row', 'row-reverse', 'col', 'col-reverse']\n }],\n /**\n * Flex Wrap\n * @see https://tailwindcss.com/docs/flex-wrap\n */\n 'flex-wrap': [{\n flex: ['nowrap', 'wrap', 'wrap-reverse']\n }],\n /**\n * Flex\n * @see https://tailwindcss.com/docs/flex\n */\n flex: [{\n flex: [isNumber, isFraction, 'auto', 'initial', 'none', isArbitraryValue]\n }],\n /**\n * Flex Grow\n * @see https://tailwindcss.com/docs/flex-grow\n */\n grow: [{\n grow: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Flex Shrink\n * @see https://tailwindcss.com/docs/flex-shrink\n */\n shrink: [{\n shrink: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Order\n * @see https://tailwindcss.com/docs/order\n */\n order: [{\n order: [isInteger, 'first', 'last', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Grid Template Columns\n * @see https://tailwindcss.com/docs/grid-template-columns\n */\n 'grid-cols': [{\n 'grid-cols': scaleGridTemplateColsRows()\n }],\n /**\n * Grid Column Start / End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start-end': [{\n col: scaleGridColRowStartAndEnd()\n }],\n /**\n * Grid Column Start\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start': [{\n 'col-start': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Column End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-end': [{\n 'col-end': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Template Rows\n * @see https://tailwindcss.com/docs/grid-template-rows\n */\n 'grid-rows': [{\n 'grid-rows': scaleGridTemplateColsRows()\n }],\n /**\n * Grid Row Start / End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start-end': [{\n row: scaleGridColRowStartAndEnd()\n }],\n /**\n * Grid Row Start\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start': [{\n 'row-start': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Row End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-end': [{\n 'row-end': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Auto Flow\n * @see https://tailwindcss.com/docs/grid-auto-flow\n */\n 'grid-flow': [{\n 'grid-flow': ['row', 'col', 'dense', 'row-dense', 'col-dense']\n }],\n /**\n * Grid Auto Columns\n * @see https://tailwindcss.com/docs/grid-auto-columns\n */\n 'auto-cols': [{\n 'auto-cols': scaleGridAutoColsRows()\n }],\n /**\n * Grid Auto Rows\n * @see https://tailwindcss.com/docs/grid-auto-rows\n */\n 'auto-rows': [{\n 'auto-rows': scaleGridAutoColsRows()\n }],\n /**\n * Gap\n * @see https://tailwindcss.com/docs/gap\n */\n gap: [{\n gap: scaleUnambiguousSpacing()\n }],\n /**\n * Gap X\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-x': [{\n 'gap-x': scaleUnambiguousSpacing()\n }],\n /**\n * Gap Y\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-y': [{\n 'gap-y': scaleUnambiguousSpacing()\n }],\n /**\n * Justify Content\n * @see https://tailwindcss.com/docs/justify-content\n */\n 'justify-content': [{\n justify: [...scaleAlignPrimaryAxis(), 'normal']\n }],\n /**\n * Justify Items\n * @see https://tailwindcss.com/docs/justify-items\n */\n 'justify-items': [{\n 'justify-items': [...scaleAlignSecondaryAxis(), 'normal']\n }],\n /**\n * Justify Self\n * @see https://tailwindcss.com/docs/justify-self\n */\n 'justify-self': [{\n 'justify-self': ['auto', ...scaleAlignSecondaryAxis()]\n }],\n /**\n * Align Content\n * @see https://tailwindcss.com/docs/align-content\n */\n 'align-content': [{\n content: ['normal', ...scaleAlignPrimaryAxis()]\n }],\n /**\n * Align Items\n * @see https://tailwindcss.com/docs/align-items\n */\n 'align-items': [{\n items: [...scaleAlignSecondaryAxis(), {\n baseline: ['', 'last']\n }]\n }],\n /**\n * Align Self\n * @see https://tailwindcss.com/docs/align-self\n */\n 'align-self': [{\n self: ['auto', ...scaleAlignSecondaryAxis(), {\n baseline: ['', 'last']\n }]\n }],\n /**\n * Place Content\n * @see https://tailwindcss.com/docs/place-content\n */\n 'place-content': [{\n 'place-content': scaleAlignPrimaryAxis()\n }],\n /**\n * Place Items\n * @see https://tailwindcss.com/docs/place-items\n */\n 'place-items': [{\n 'place-items': [...scaleAlignSecondaryAxis(), 'baseline']\n }],\n /**\n * Place Self\n * @see https://tailwindcss.com/docs/place-self\n */\n 'place-self': [{\n 'place-self': ['auto', ...scaleAlignSecondaryAxis()]\n }],\n // Spacing\n /**\n * Padding\n * @see https://tailwindcss.com/docs/padding\n */\n p: [{\n p: scaleUnambiguousSpacing()\n }],\n /**\n * Padding X\n * @see https://tailwindcss.com/docs/padding\n */\n px: [{\n px: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Y\n * @see https://tailwindcss.com/docs/padding\n */\n py: [{\n py: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Start\n * @see https://tailwindcss.com/docs/padding\n */\n ps: [{\n ps: scaleUnambiguousSpacing()\n }],\n /**\n * Padding End\n * @see https://tailwindcss.com/docs/padding\n */\n pe: [{\n pe: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Top\n * @see https://tailwindcss.com/docs/padding\n */\n pt: [{\n pt: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Right\n * @see https://tailwindcss.com/docs/padding\n */\n pr: [{\n pr: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Bottom\n * @see https://tailwindcss.com/docs/padding\n */\n pb: [{\n pb: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Left\n * @see https://tailwindcss.com/docs/padding\n */\n pl: [{\n pl: scaleUnambiguousSpacing()\n }],\n /**\n * Margin\n * @see https://tailwindcss.com/docs/margin\n */\n m: [{\n m: scaleMargin()\n }],\n /**\n * Margin X\n * @see https://tailwindcss.com/docs/margin\n */\n mx: [{\n mx: scaleMargin()\n }],\n /**\n * Margin Y\n * @see https://tailwindcss.com/docs/margin\n */\n my: [{\n my: scaleMargin()\n }],\n /**\n * Margin Start\n * @see https://tailwindcss.com/docs/margin\n */\n ms: [{\n ms: scaleMargin()\n }],\n /**\n * Margin End\n * @see https://tailwindcss.com/docs/margin\n */\n me: [{\n me: scaleMargin()\n }],\n /**\n * Margin Top\n * @see https://tailwindcss.com/docs/margin\n */\n mt: [{\n mt: scaleMargin()\n }],\n /**\n * Margin Right\n * @see https://tailwindcss.com/docs/margin\n */\n mr: [{\n mr: scaleMargin()\n }],\n /**\n * Margin Bottom\n * @see https://tailwindcss.com/docs/margin\n */\n mb: [{\n mb: scaleMargin()\n }],\n /**\n * Margin Left\n * @see https://tailwindcss.com/docs/margin\n */\n ml: [{\n ml: scaleMargin()\n }],\n /**\n * Space Between X\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x': [{\n 'space-x': scaleUnambiguousSpacing()\n }],\n /**\n * Space Between X Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x-reverse': ['space-x-reverse'],\n /**\n * Space Between Y\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y': [{\n 'space-y': scaleUnambiguousSpacing()\n }],\n /**\n * Space Between Y Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y-reverse': ['space-y-reverse'],\n // --------------\n // --- Sizing ---\n // --------------\n /**\n * Size\n * @see https://tailwindcss.com/docs/width#setting-both-width-and-height\n */\n size: [{\n size: scaleSizing()\n }],\n /**\n * Width\n * @see https://tailwindcss.com/docs/width\n */\n w: [{\n w: [themeContainer, 'screen', ...scaleSizing()]\n }],\n /**\n * Min-Width\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-w': [{\n 'min-w': [themeContainer, 'screen', /** Deprecated. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'none', ...scaleSizing()]\n }],\n /**\n * Max-Width\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-w': [{\n 'max-w': [themeContainer, 'screen', 'none', /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'prose', /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n {\n screen: [themeBreakpoint]\n }, ...scaleSizing()]\n }],\n /**\n * Height\n * @see https://tailwindcss.com/docs/height\n */\n h: [{\n h: ['screen', 'lh', ...scaleSizing()]\n }],\n /**\n * Min-Height\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-h': [{\n 'min-h': ['screen', 'lh', 'none', ...scaleSizing()]\n }],\n /**\n * Max-Height\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-h': [{\n 'max-h': ['screen', 'lh', ...scaleSizing()]\n }],\n // ------------------\n // --- Typography ---\n // ------------------\n /**\n * Font Size\n * @see https://tailwindcss.com/docs/font-size\n */\n 'font-size': [{\n text: ['base', themeText, isArbitraryVariableLength, isArbitraryLength]\n }],\n /**\n * Font Smoothing\n * @see https://tailwindcss.com/docs/font-smoothing\n */\n 'font-smoothing': ['antialiased', 'subpixel-antialiased'],\n /**\n * Font Style\n * @see https://tailwindcss.com/docs/font-style\n */\n 'font-style': ['italic', 'not-italic'],\n /**\n * Font Weight\n * @see https://tailwindcss.com/docs/font-weight\n */\n 'font-weight': [{\n font: [themeFontWeight, isArbitraryVariable, isArbitraryNumber]\n }],\n /**\n * Font Stretch\n * @see https://tailwindcss.com/docs/font-stretch\n */\n 'font-stretch': [{\n 'font-stretch': ['ultra-condensed', 'extra-condensed', 'condensed', 'semi-condensed', 'normal', 'semi-expanded', 'expanded', 'extra-expanded', 'ultra-expanded', isPercent, isArbitraryValue]\n }],\n /**\n * Font Family\n * @see https://tailwindcss.com/docs/font-family\n */\n 'font-family': [{\n font: [isArbitraryVariableFamilyName, isArbitraryValue, themeFont]\n }],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-normal': ['normal-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-ordinal': ['ordinal'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-slashed-zero': ['slashed-zero'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-figure': ['lining-nums', 'oldstyle-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-spacing': ['proportional-nums', 'tabular-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-fraction': ['diagonal-fractions', 'stacked-fractions'],\n /**\n * Letter Spacing\n * @see https://tailwindcss.com/docs/letter-spacing\n */\n tracking: [{\n tracking: [themeTracking, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Line Clamp\n * @see https://tailwindcss.com/docs/line-clamp\n */\n 'line-clamp': [{\n 'line-clamp': [isNumber, 'none', isArbitraryVariable, isArbitraryNumber]\n }],\n /**\n * Line Height\n * @see https://tailwindcss.com/docs/line-height\n */\n leading: [{\n leading: [/** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n themeLeading, ...scaleUnambiguousSpacing()]\n }],\n /**\n * List Style Image\n * @see https://tailwindcss.com/docs/list-style-image\n */\n 'list-image': [{\n 'list-image': ['none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * List Style Position\n * @see https://tailwindcss.com/docs/list-style-position\n */\n 'list-style-position': [{\n list: ['inside', 'outside']\n }],\n /**\n * List Style Type\n * @see https://tailwindcss.com/docs/list-style-type\n */\n 'list-style-type': [{\n list: ['disc', 'decimal', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Text Alignment\n * @see https://tailwindcss.com/docs/text-align\n */\n 'text-alignment': [{\n text: ['left', 'center', 'right', 'justify', 'start', 'end']\n }],\n /**\n * Placeholder Color\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://v3.tailwindcss.com/docs/placeholder-color\n */\n 'placeholder-color': [{\n placeholder: scaleColor()\n }],\n /**\n * Text Color\n * @see https://tailwindcss.com/docs/text-color\n */\n 'text-color': [{\n text: scaleColor()\n }],\n /**\n * Text Decoration\n * @see https://tailwindcss.com/docs/text-decoration\n */\n 'text-decoration': ['underline', 'overline', 'line-through', 'no-underline'],\n /**\n * Text Decoration Style\n * @see https://tailwindcss.com/docs/text-decoration-style\n */\n 'text-decoration-style': [{\n decoration: [...scaleLineStyle(), 'wavy']\n }],\n /**\n * Text Decoration Thickness\n * @see https://tailwindcss.com/docs/text-decoration-thickness\n */\n 'text-decoration-thickness': [{\n decoration: [isNumber, 'from-font', 'auto', isArbitraryVariable, isArbitraryLength]\n }],\n /**\n * Text Decoration Color\n * @see https://tailwindcss.com/docs/text-decoration-color\n */\n 'text-decoration-color': [{\n decoration: scaleColor()\n }],\n /**\n * Text Underline Offset\n * @see https://tailwindcss.com/docs/text-underline-offset\n */\n 'underline-offset': [{\n 'underline-offset': [isNumber, 'auto', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Text Transform\n * @see https://tailwindcss.com/docs/text-transform\n */\n 'text-transform': ['uppercase', 'lowercase', 'capitalize', 'normal-case'],\n /**\n * Text Overflow\n * @see https://tailwindcss.com/docs/text-overflow\n */\n 'text-overflow': ['truncate', 'text-ellipsis', 'text-clip'],\n /**\n * Text Wrap\n * @see https://tailwindcss.com/docs/text-wrap\n */\n 'text-wrap': [{\n text: ['wrap', 'nowrap', 'balance', 'pretty']\n }],\n /**\n * Text Indent\n * @see https://tailwindcss.com/docs/text-indent\n */\n indent: [{\n indent: scaleUnambiguousSpacing()\n }],\n /**\n * Vertical Alignment\n * @see https://tailwindcss.com/docs/vertical-align\n */\n 'vertical-align': [{\n align: ['baseline', 'top', 'middle', 'bottom', 'text-top', 'text-bottom', 'sub', 'super', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Whitespace\n * @see https://tailwindcss.com/docs/whitespace\n */\n whitespace: [{\n whitespace: ['normal', 'nowrap', 'pre', 'pre-line', 'pre-wrap', 'break-spaces']\n }],\n /**\n * Word Break\n * @see https://tailwindcss.com/docs/word-break\n */\n break: [{\n break: ['normal', 'words', 'all', 'keep']\n }],\n /**\n * Overflow Wrap\n * @see https://tailwindcss.com/docs/overflow-wrap\n */\n wrap: [{\n wrap: ['break-word', 'anywhere', 'normal']\n }],\n /**\n * Hyphens\n * @see https://tailwindcss.com/docs/hyphens\n */\n hyphens: [{\n hyphens: ['none', 'manual', 'auto']\n }],\n /**\n * Content\n * @see https://tailwindcss.com/docs/content\n */\n content: [{\n content: ['none', isArbitraryVariable, isArbitraryValue]\n }],\n // -------------------\n // --- Backgrounds ---\n // -------------------\n /**\n * Background Attachment\n * @see https://tailwindcss.com/docs/background-attachment\n */\n 'bg-attachment': [{\n bg: ['fixed', 'local', 'scroll']\n }],\n /**\n * Background Clip\n * @see https://tailwindcss.com/docs/background-clip\n */\n 'bg-clip': [{\n 'bg-clip': ['border', 'padding', 'content', 'text']\n }],\n /**\n * Background Origin\n * @see https://tailwindcss.com/docs/background-origin\n */\n 'bg-origin': [{\n 'bg-origin': ['border', 'padding', 'content']\n }],\n /**\n * Background Position\n * @see https://tailwindcss.com/docs/background-position\n */\n 'bg-position': [{\n bg: scaleBgPosition()\n }],\n /**\n * Background Repeat\n * @see https://tailwindcss.com/docs/background-repeat\n */\n 'bg-repeat': [{\n bg: scaleBgRepeat()\n }],\n /**\n * Background Size\n * @see https://tailwindcss.com/docs/background-size\n */\n 'bg-size': [{\n bg: scaleBgSize()\n }],\n /**\n * Background Image\n * @see https://tailwindcss.com/docs/background-image\n */\n 'bg-image': [{\n bg: ['none', {\n linear: [{\n to: ['t', 'tr', 'r', 'br', 'b', 'bl', 'l', 'tl']\n }, isInteger, isArbitraryVariable, isArbitraryValue],\n radial: ['', isArbitraryVariable, isArbitraryValue],\n conic: [isInteger, isArbitraryVariable, isArbitraryValue]\n }, isArbitraryVariableImage, isArbitraryImage]\n }],\n /**\n * Background Color\n * @see https://tailwindcss.com/docs/background-color\n */\n 'bg-color': [{\n bg: scaleColor()\n }],\n /**\n * Gradient Color Stops From Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from-pos': [{\n from: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops Via Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via-pos': [{\n via: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops To Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to-pos': [{\n to: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops From\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from': [{\n from: scaleColor()\n }],\n /**\n * Gradient Color Stops Via\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via': [{\n via: scaleColor()\n }],\n /**\n * Gradient Color Stops To\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to': [{\n to: scaleColor()\n }],\n // ---------------\n // --- Borders ---\n // ---------------\n /**\n * Border Radius\n * @see https://tailwindcss.com/docs/border-radius\n */\n rounded: [{\n rounded: scaleRadius()\n }],\n /**\n * Border Radius Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-s': [{\n 'rounded-s': scaleRadius()\n }],\n /**\n * Border Radius End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-e': [{\n 'rounded-e': scaleRadius()\n }],\n /**\n * Border Radius Top\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-t': [{\n 'rounded-t': scaleRadius()\n }],\n /**\n * Border Radius Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-r': [{\n 'rounded-r': scaleRadius()\n }],\n /**\n * Border Radius Bottom\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-b': [{\n 'rounded-b': scaleRadius()\n }],\n /**\n * Border Radius Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-l': [{\n 'rounded-l': scaleRadius()\n }],\n /**\n * Border Radius Start Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ss': [{\n 'rounded-ss': scaleRadius()\n }],\n /**\n * Border Radius Start End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-se': [{\n 'rounded-se': scaleRadius()\n }],\n /**\n * Border Radius End End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ee': [{\n 'rounded-ee': scaleRadius()\n }],\n /**\n * Border Radius End Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-es': [{\n 'rounded-es': scaleRadius()\n }],\n /**\n * Border Radius Top Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tl': [{\n 'rounded-tl': scaleRadius()\n }],\n /**\n * Border Radius Top Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tr': [{\n 'rounded-tr': scaleRadius()\n }],\n /**\n * Border Radius Bottom Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-br': [{\n 'rounded-br': scaleRadius()\n }],\n /**\n * Border Radius Bottom Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-bl': [{\n 'rounded-bl': scaleRadius()\n }],\n /**\n * Border Width\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w': [{\n border: scaleBorderWidth()\n }],\n /**\n * Border Width X\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-x': [{\n 'border-x': scaleBorderWidth()\n }],\n /**\n * Border Width Y\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-y': [{\n 'border-y': scaleBorderWidth()\n }],\n /**\n * Border Width Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-s': [{\n 'border-s': scaleBorderWidth()\n }],\n /**\n * Border Width End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-e': [{\n 'border-e': scaleBorderWidth()\n }],\n /**\n * Border Width Top\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-t': [{\n 'border-t': scaleBorderWidth()\n }],\n /**\n * Border Width Right\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-r': [{\n 'border-r': scaleBorderWidth()\n }],\n /**\n * Border Width Bottom\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-b': [{\n 'border-b': scaleBorderWidth()\n }],\n /**\n * Border Width Left\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-l': [{\n 'border-l': scaleBorderWidth()\n }],\n /**\n * Divide Width X\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x': [{\n 'divide-x': scaleBorderWidth()\n }],\n /**\n * Divide Width X Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x-reverse': ['divide-x-reverse'],\n /**\n * Divide Width Y\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y': [{\n 'divide-y': scaleBorderWidth()\n }],\n /**\n * Divide Width Y Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y-reverse': ['divide-y-reverse'],\n /**\n * Border Style\n * @see https://tailwindcss.com/docs/border-style\n */\n 'border-style': [{\n border: [...scaleLineStyle(), 'hidden', 'none']\n }],\n /**\n * Divide Style\n * @see https://tailwindcss.com/docs/border-style#setting-the-divider-style\n */\n 'divide-style': [{\n divide: [...scaleLineStyle(), 'hidden', 'none']\n }],\n /**\n * Border Color\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color': [{\n border: scaleColor()\n }],\n /**\n * Border Color X\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-x': [{\n 'border-x': scaleColor()\n }],\n /**\n * Border Color Y\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-y': [{\n 'border-y': scaleColor()\n }],\n /**\n * Border Color S\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-s': [{\n 'border-s': scaleColor()\n }],\n /**\n * Border Color E\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-e': [{\n 'border-e': scaleColor()\n }],\n /**\n * Border Color Top\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-t': [{\n 'border-t': scaleColor()\n }],\n /**\n * Border Color Right\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-r': [{\n 'border-r': scaleColor()\n }],\n /**\n * Border Color Bottom\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-b': [{\n 'border-b': scaleColor()\n }],\n /**\n * Border Color Left\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-l': [{\n 'border-l': scaleColor()\n }],\n /**\n * Divide Color\n * @see https://tailwindcss.com/docs/divide-color\n */\n 'divide-color': [{\n divide: scaleColor()\n }],\n /**\n * Outline Style\n * @see https://tailwindcss.com/docs/outline-style\n */\n 'outline-style': [{\n outline: [...scaleLineStyle(), 'none', 'hidden']\n }],\n /**\n * Outline Offset\n * @see https://tailwindcss.com/docs/outline-offset\n */\n 'outline-offset': [{\n 'outline-offset': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Outline Width\n * @see https://tailwindcss.com/docs/outline-width\n */\n 'outline-w': [{\n outline: ['', isNumber, isArbitraryVariableLength, isArbitraryLength]\n }],\n /**\n * Outline Color\n * @see https://tailwindcss.com/docs/outline-color\n */\n 'outline-color': [{\n outline: scaleColor()\n }],\n // ---------------\n // --- Effects ---\n // ---------------\n /**\n * Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow\n */\n shadow: [{\n shadow: [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-shadow-color\n */\n 'shadow-color': [{\n shadow: scaleColor()\n }],\n /**\n * Inset Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-shadow\n */\n 'inset-shadow': [{\n 'inset-shadow': ['none', themeInsetShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Inset Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-shadow-color\n */\n 'inset-shadow-color': [{\n 'inset-shadow': scaleColor()\n }],\n /**\n * Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-a-ring\n */\n 'ring-w': [{\n ring: scaleBorderWidth()\n }],\n /**\n * Ring Width Inset\n * @see https://v3.tailwindcss.com/docs/ring-width#inset-rings\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-w-inset': ['ring-inset'],\n /**\n * Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-ring-color\n */\n 'ring-color': [{\n ring: scaleColor()\n }],\n /**\n * Ring Offset Width\n * @see https://v3.tailwindcss.com/docs/ring-offset-width\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-w': [{\n 'ring-offset': [isNumber, isArbitraryLength]\n }],\n /**\n * Ring Offset Color\n * @see https://v3.tailwindcss.com/docs/ring-offset-color\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-color': [{\n 'ring-offset': scaleColor()\n }],\n /**\n * Inset Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-ring\n */\n 'inset-ring-w': [{\n 'inset-ring': scaleBorderWidth()\n }],\n /**\n * Inset Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-ring-color\n */\n 'inset-ring-color': [{\n 'inset-ring': scaleColor()\n }],\n /**\n * Text Shadow\n * @see https://tailwindcss.com/docs/text-shadow\n */\n 'text-shadow': [{\n 'text-shadow': ['none', themeTextShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Text Shadow Color\n * @see https://tailwindcss.com/docs/text-shadow#setting-the-shadow-color\n */\n 'text-shadow-color': [{\n 'text-shadow': scaleColor()\n }],\n /**\n * Opacity\n * @see https://tailwindcss.com/docs/opacity\n */\n opacity: [{\n opacity: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Mix Blend Mode\n * @see https://tailwindcss.com/docs/mix-blend-mode\n */\n 'mix-blend': [{\n 'mix-blend': [...scaleBlendMode(), 'plus-darker', 'plus-lighter']\n }],\n /**\n * Background Blend Mode\n * @see https://tailwindcss.com/docs/background-blend-mode\n */\n 'bg-blend': [{\n 'bg-blend': scaleBlendMode()\n }],\n /**\n * Mask Clip\n * @see https://tailwindcss.com/docs/mask-clip\n */\n 'mask-clip': [{\n 'mask-clip': ['border', 'padding', 'content', 'fill', 'stroke', 'view']\n }, 'mask-no-clip'],\n /**\n * Mask Composite\n * @see https://tailwindcss.com/docs/mask-composite\n */\n 'mask-composite': [{\n mask: ['add', 'subtract', 'intersect', 'exclude']\n }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image-linear-pos': [{\n 'mask-linear': [isNumber]\n }],\n 'mask-image-linear-from-pos': [{\n 'mask-linear-from': scaleMaskImagePosition()\n }],\n 'mask-image-linear-to-pos': [{\n 'mask-linear-to': scaleMaskImagePosition()\n }],\n 'mask-image-linear-from-color': [{\n 'mask-linear-from': scaleColor()\n }],\n 'mask-image-linear-to-color': [{\n 'mask-linear-to': scaleColor()\n }],\n 'mask-image-t-from-pos': [{\n 'mask-t-from': scaleMaskImagePosition()\n }],\n 'mask-image-t-to-pos': [{\n 'mask-t-to': scaleMaskImagePosition()\n }],\n 'mask-image-t-from-color': [{\n 'mask-t-from': scaleColor()\n }],\n 'mask-image-t-to-color': [{\n 'mask-t-to': scaleColor()\n }],\n 'mask-image-r-from-pos': [{\n 'mask-r-from': scaleMaskImagePosition()\n }],\n 'mask-image-r-to-pos': [{\n 'mask-r-to': scaleMaskImagePosition()\n }],\n 'mask-image-r-from-color': [{\n 'mask-r-from': scaleColor()\n }],\n 'mask-image-r-to-color': [{\n 'mask-r-to': scaleColor()\n }],\n 'mask-image-b-from-pos': [{\n 'mask-b-from': scaleMaskImagePosition()\n }],\n 'mask-image-b-to-pos': [{\n 'mask-b-to': scaleMaskImagePosition()\n }],\n 'mask-image-b-from-color': [{\n 'mask-b-from': scaleColor()\n }],\n 'mask-image-b-to-color': [{\n 'mask-b-to': scaleColor()\n }],\n 'mask-image-l-from-pos': [{\n 'mask-l-from': scaleMaskImagePosition()\n }],\n 'mask-image-l-to-pos': [{\n 'mask-l-to': scaleMaskImagePosition()\n }],\n 'mask-image-l-from-color': [{\n 'mask-l-from': scaleColor()\n }],\n 'mask-image-l-to-color': [{\n 'mask-l-to': scaleColor()\n }],\n 'mask-image-x-from-pos': [{\n 'mask-x-from': scaleMaskImagePosition()\n }],\n 'mask-image-x-to-pos': [{\n 'mask-x-to': scaleMaskImagePosition()\n }],\n 'mask-image-x-from-color': [{\n 'mask-x-from': scaleColor()\n }],\n 'mask-image-x-to-color': [{\n 'mask-x-to': scaleColor()\n }],\n 'mask-image-y-from-pos': [{\n 'mask-y-from': scaleMaskImagePosition()\n }],\n 'mask-image-y-to-pos': [{\n 'mask-y-to': scaleMaskImagePosition()\n }],\n 'mask-image-y-from-color': [{\n 'mask-y-from': scaleColor()\n }],\n 'mask-image-y-to-color': [{\n 'mask-y-to': scaleColor()\n }],\n 'mask-image-radial': [{\n 'mask-radial': [isArbitraryVariable, isArbitraryValue]\n }],\n 'mask-image-radial-from-pos': [{\n 'mask-radial-from': scaleMaskImagePosition()\n }],\n 'mask-image-radial-to-pos': [{\n 'mask-radial-to': scaleMaskImagePosition()\n }],\n 'mask-image-radial-from-color': [{\n 'mask-radial-from': scaleColor()\n }],\n 'mask-image-radial-to-color': [{\n 'mask-radial-to': scaleColor()\n }],\n 'mask-image-radial-shape': [{\n 'mask-radial': ['circle', 'ellipse']\n }],\n 'mask-image-radial-size': [{\n 'mask-radial': [{\n closest: ['side', 'corner'],\n farthest: ['side', 'corner']\n }]\n }],\n 'mask-image-radial-pos': [{\n 'mask-radial-at': scalePosition()\n }],\n 'mask-image-conic-pos': [{\n 'mask-conic': [isNumber]\n }],\n 'mask-image-conic-from-pos': [{\n 'mask-conic-from': scaleMaskImagePosition()\n }],\n 'mask-image-conic-to-pos': [{\n 'mask-conic-to': scaleMaskImagePosition()\n }],\n 'mask-image-conic-from-color': [{\n 'mask-conic-from': scaleColor()\n }],\n 'mask-image-conic-to-color': [{\n 'mask-conic-to': scaleColor()\n }],\n /**\n * Mask Mode\n * @see https://tailwindcss.com/docs/mask-mode\n */\n 'mask-mode': [{\n mask: ['alpha', 'luminance', 'match']\n }],\n /**\n * Mask Origin\n * @see https://tailwindcss.com/docs/mask-origin\n */\n 'mask-origin': [{\n 'mask-origin': ['border', 'padding', 'content', 'fill', 'stroke', 'view']\n }],\n /**\n * Mask Position\n * @see https://tailwindcss.com/docs/mask-position\n */\n 'mask-position': [{\n mask: scaleBgPosition()\n }],\n /**\n * Mask Repeat\n * @see https://tailwindcss.com/docs/mask-repeat\n */\n 'mask-repeat': [{\n mask: scaleBgRepeat()\n }],\n /**\n * Mask Size\n * @see https://tailwindcss.com/docs/mask-size\n */\n 'mask-size': [{\n mask: scaleBgSize()\n }],\n /**\n * Mask Type\n * @see https://tailwindcss.com/docs/mask-type\n */\n 'mask-type': [{\n 'mask-type': ['alpha', 'luminance']\n }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image': [{\n mask: ['none', isArbitraryVariable, isArbitraryValue]\n }],\n // ---------------\n // --- Filters ---\n // ---------------\n /**\n * Filter\n * @see https://tailwindcss.com/docs/filter\n */\n filter: [{\n filter: [\n // Deprecated since Tailwind CSS v3.0.0\n '', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Blur\n * @see https://tailwindcss.com/docs/blur\n */\n blur: [{\n blur: scaleBlur()\n }],\n /**\n * Brightness\n * @see https://tailwindcss.com/docs/brightness\n */\n brightness: [{\n brightness: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Contrast\n * @see https://tailwindcss.com/docs/contrast\n */\n contrast: [{\n contrast: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Drop Shadow\n * @see https://tailwindcss.com/docs/drop-shadow\n */\n 'drop-shadow': [{\n 'drop-shadow': [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeDropShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Drop Shadow Color\n * @see https://tailwindcss.com/docs/filter-drop-shadow#setting-the-shadow-color\n */\n 'drop-shadow-color': [{\n 'drop-shadow': scaleColor()\n }],\n /**\n * Grayscale\n * @see https://tailwindcss.com/docs/grayscale\n */\n grayscale: [{\n grayscale: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Hue Rotate\n * @see https://tailwindcss.com/docs/hue-rotate\n */\n 'hue-rotate': [{\n 'hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Invert\n * @see https://tailwindcss.com/docs/invert\n */\n invert: [{\n invert: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Saturate\n * @see https://tailwindcss.com/docs/saturate\n */\n saturate: [{\n saturate: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Sepia\n * @see https://tailwindcss.com/docs/sepia\n */\n sepia: [{\n sepia: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Filter\n * @see https://tailwindcss.com/docs/backdrop-filter\n */\n 'backdrop-filter': [{\n 'backdrop-filter': [\n // Deprecated since Tailwind CSS v3.0.0\n '', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Blur\n * @see https://tailwindcss.com/docs/backdrop-blur\n */\n 'backdrop-blur': [{\n 'backdrop-blur': scaleBlur()\n }],\n /**\n * Backdrop Brightness\n * @see https://tailwindcss.com/docs/backdrop-brightness\n */\n 'backdrop-brightness': [{\n 'backdrop-brightness': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Contrast\n * @see https://tailwindcss.com/docs/backdrop-contrast\n */\n 'backdrop-contrast': [{\n 'backdrop-contrast': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Grayscale\n * @see https://tailwindcss.com/docs/backdrop-grayscale\n */\n 'backdrop-grayscale': [{\n 'backdrop-grayscale': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Hue Rotate\n * @see https://tailwindcss.com/docs/backdrop-hue-rotate\n */\n 'backdrop-hue-rotate': [{\n 'backdrop-hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Invert\n * @see https://tailwindcss.com/docs/backdrop-invert\n */\n 'backdrop-invert': [{\n 'backdrop-invert': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Opacity\n * @see https://tailwindcss.com/docs/backdrop-opacity\n */\n 'backdrop-opacity': [{\n 'backdrop-opacity': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Saturate\n * @see https://tailwindcss.com/docs/backdrop-saturate\n */\n 'backdrop-saturate': [{\n 'backdrop-saturate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Sepia\n * @see https://tailwindcss.com/docs/backdrop-sepia\n */\n 'backdrop-sepia': [{\n 'backdrop-sepia': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n // --------------\n // --- Tables ---\n // --------------\n /**\n * Border Collapse\n * @see https://tailwindcss.com/docs/border-collapse\n */\n 'border-collapse': [{\n border: ['collapse', 'separate']\n }],\n /**\n * Border Spacing\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing': [{\n 'border-spacing': scaleUnambiguousSpacing()\n }],\n /**\n * Border Spacing X\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-x': [{\n 'border-spacing-x': scaleUnambiguousSpacing()\n }],\n /**\n * Border Spacing Y\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-y': [{\n 'border-spacing-y': scaleUnambiguousSpacing()\n }],\n /**\n * Table Layout\n * @see https://tailwindcss.com/docs/table-layout\n */\n 'table-layout': [{\n table: ['auto', 'fixed']\n }],\n /**\n * Caption Side\n * @see https://tailwindcss.com/docs/caption-side\n */\n caption: [{\n caption: ['top', 'bottom']\n }],\n // ---------------------------------\n // --- Transitions and Animation ---\n // ---------------------------------\n /**\n * Transition Property\n * @see https://tailwindcss.com/docs/transition-property\n */\n transition: [{\n transition: ['', 'all', 'colors', 'opacity', 'shadow', 'transform', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Behavior\n * @see https://tailwindcss.com/docs/transition-behavior\n */\n 'transition-behavior': [{\n transition: ['normal', 'discrete']\n }],\n /**\n * Transition Duration\n * @see https://tailwindcss.com/docs/transition-duration\n */\n duration: [{\n duration: [isNumber, 'initial', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Timing Function\n * @see https://tailwindcss.com/docs/transition-timing-function\n */\n ease: [{\n ease: ['linear', 'initial', themeEase, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Delay\n * @see https://tailwindcss.com/docs/transition-delay\n */\n delay: [{\n delay: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Animation\n * @see https://tailwindcss.com/docs/animation\n */\n animate: [{\n animate: ['none', themeAnimate, isArbitraryVariable, isArbitraryValue]\n }],\n // ------------------\n // --- Transforms ---\n // ------------------\n /**\n * Backface Visibility\n * @see https://tailwindcss.com/docs/backface-visibility\n */\n backface: [{\n backface: ['hidden', 'visible']\n }],\n /**\n * Perspective\n * @see https://tailwindcss.com/docs/perspective\n */\n perspective: [{\n perspective: [themePerspective, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Perspective Origin\n * @see https://tailwindcss.com/docs/perspective-origin\n */\n 'perspective-origin': [{\n 'perspective-origin': scalePositionWithArbitrary()\n }],\n /**\n * Rotate\n * @see https://tailwindcss.com/docs/rotate\n */\n rotate: [{\n rotate: scaleRotate()\n }],\n /**\n * Rotate X\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-x': [{\n 'rotate-x': scaleRotate()\n }],\n /**\n * Rotate Y\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-y': [{\n 'rotate-y': scaleRotate()\n }],\n /**\n * Rotate Z\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-z': [{\n 'rotate-z': scaleRotate()\n }],\n /**\n * Scale\n * @see https://tailwindcss.com/docs/scale\n */\n scale: [{\n scale: scaleScale()\n }],\n /**\n * Scale X\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-x': [{\n 'scale-x': scaleScale()\n }],\n /**\n * Scale Y\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-y': [{\n 'scale-y': scaleScale()\n }],\n /**\n * Scale Z\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-z': [{\n 'scale-z': scaleScale()\n }],\n /**\n * Scale 3D\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-3d': ['scale-3d'],\n /**\n * Skew\n * @see https://tailwindcss.com/docs/skew\n */\n skew: [{\n skew: scaleSkew()\n }],\n /**\n * Skew X\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-x': [{\n 'skew-x': scaleSkew()\n }],\n /**\n * Skew Y\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-y': [{\n 'skew-y': scaleSkew()\n }],\n /**\n * Transform\n * @see https://tailwindcss.com/docs/transform\n */\n transform: [{\n transform: [isArbitraryVariable, isArbitraryValue, '', 'none', 'gpu', 'cpu']\n }],\n /**\n * Transform Origin\n * @see https://tailwindcss.com/docs/transform-origin\n */\n 'transform-origin': [{\n origin: scalePositionWithArbitrary()\n }],\n /**\n * Transform Style\n * @see https://tailwindcss.com/docs/transform-style\n */\n 'transform-style': [{\n transform: ['3d', 'flat']\n }],\n /**\n * Translate\n * @see https://tailwindcss.com/docs/translate\n */\n translate: [{\n translate: scaleTranslate()\n }],\n /**\n * Translate X\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-x': [{\n 'translate-x': scaleTranslate()\n }],\n /**\n * Translate Y\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-y': [{\n 'translate-y': scaleTranslate()\n }],\n /**\n * Translate Z\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-z': [{\n 'translate-z': scaleTranslate()\n }],\n /**\n * Translate None\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-none': ['translate-none'],\n // ---------------------\n // --- Interactivity ---\n // ---------------------\n /**\n * Accent Color\n * @see https://tailwindcss.com/docs/accent-color\n */\n accent: [{\n accent: scaleColor()\n }],\n /**\n * Appearance\n * @see https://tailwindcss.com/docs/appearance\n */\n appearance: [{\n appearance: ['none', 'auto']\n }],\n /**\n * Caret Color\n * @see https://tailwindcss.com/docs/just-in-time-mode#caret-color-utilities\n */\n 'caret-color': [{\n caret: scaleColor()\n }],\n /**\n * Color Scheme\n * @see https://tailwindcss.com/docs/color-scheme\n */\n 'color-scheme': [{\n scheme: ['normal', 'dark', 'light', 'light-dark', 'only-dark', 'only-light']\n }],\n /**\n * Cursor\n * @see https://tailwindcss.com/docs/cursor\n */\n cursor: [{\n cursor: ['auto', 'default', 'pointer', 'wait', 'text', 'move', 'help', 'not-allowed', 'none', 'context-menu', 'progress', 'cell', 'crosshair', 'vertical-text', 'alias', 'copy', 'no-drop', 'grab', 'grabbing', 'all-scroll', 'col-resize', 'row-resize', 'n-resize', 'e-resize', 's-resize', 'w-resize', 'ne-resize', 'nw-resize', 'se-resize', 'sw-resize', 'ew-resize', 'ns-resize', 'nesw-resize', 'nwse-resize', 'zoom-in', 'zoom-out', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Field Sizing\n * @see https://tailwindcss.com/docs/field-sizing\n */\n 'field-sizing': [{\n 'field-sizing': ['fixed', 'content']\n }],\n /**\n * Pointer Events\n * @see https://tailwindcss.com/docs/pointer-events\n */\n 'pointer-events': [{\n 'pointer-events': ['auto', 'none']\n }],\n /**\n * Resize\n * @see https://tailwindcss.com/docs/resize\n */\n resize: [{\n resize: ['none', '', 'y', 'x']\n }],\n /**\n * Scroll Behavior\n * @see https://tailwindcss.com/docs/scroll-behavior\n */\n 'scroll-behavior': [{\n scroll: ['auto', 'smooth']\n }],\n /**\n * Scroll Margin\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-m': [{\n 'scroll-m': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin X\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mx': [{\n 'scroll-mx': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Y\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-my': [{\n 'scroll-my': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ms': [{\n 'scroll-ms': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-me': [{\n 'scroll-me': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Top\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mt': [{\n 'scroll-mt': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Right\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mr': [{\n 'scroll-mr': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Bottom\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mb': [{\n 'scroll-mb': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Left\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ml': [{\n 'scroll-ml': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-p': [{\n 'scroll-p': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding X\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-px': [{\n 'scroll-px': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Y\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-py': [{\n 'scroll-py': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-ps': [{\n 'scroll-ps': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pe': [{\n 'scroll-pe': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Top\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pt': [{\n 'scroll-pt': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Right\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pr': [{\n 'scroll-pr': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Bottom\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pb': [{\n 'scroll-pb': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Left\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pl': [{\n 'scroll-pl': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Snap Align\n * @see https://tailwindcss.com/docs/scroll-snap-align\n */\n 'snap-align': [{\n snap: ['start', 'end', 'center', 'align-none']\n }],\n /**\n * Scroll Snap Stop\n * @see https://tailwindcss.com/docs/scroll-snap-stop\n */\n 'snap-stop': [{\n snap: ['normal', 'always']\n }],\n /**\n * Scroll Snap Type\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-type': [{\n snap: ['none', 'x', 'y', 'both']\n }],\n /**\n * Scroll Snap Type Strictness\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-strictness': [{\n snap: ['mandatory', 'proximity']\n }],\n /**\n * Touch Action\n * @see https://tailwindcss.com/docs/touch-action\n */\n touch: [{\n touch: ['auto', 'none', 'manipulation']\n }],\n /**\n * Touch Action X\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-x': [{\n 'touch-pan': ['x', 'left', 'right']\n }],\n /**\n * Touch Action Y\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-y': [{\n 'touch-pan': ['y', 'up', 'down']\n }],\n /**\n * Touch Action Pinch Zoom\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-pz': ['touch-pinch-zoom'],\n /**\n * User Select\n * @see https://tailwindcss.com/docs/user-select\n */\n select: [{\n select: ['none', 'text', 'all', 'auto']\n }],\n /**\n * Will Change\n * @see https://tailwindcss.com/docs/will-change\n */\n 'will-change': [{\n 'will-change': ['auto', 'scroll', 'contents', 'transform', isArbitraryVariable, isArbitraryValue]\n }],\n // -----------\n // --- SVG ---\n // -----------\n /**\n * Fill\n * @see https://tailwindcss.com/docs/fill\n */\n fill: [{\n fill: ['none', ...scaleColor()]\n }],\n /**\n * Stroke Width\n * @see https://tailwindcss.com/docs/stroke-width\n */\n 'stroke-w': [{\n stroke: [isNumber, isArbitraryVariableLength, isArbitraryLength, isArbitraryNumber]\n }],\n /**\n * Stroke\n * @see https://tailwindcss.com/docs/stroke\n */\n stroke: [{\n stroke: ['none', ...scaleColor()]\n }],\n // ---------------------\n // --- Accessibility ---\n // ---------------------\n /**\n * Forced Color Adjust\n * @see https://tailwindcss.com/docs/forced-color-adjust\n */\n 'forced-color-adjust': [{\n 'forced-color-adjust': ['auto', 'none']\n }]\n },\n conflictingClassGroups: {\n overflow: ['overflow-x', 'overflow-y'],\n overscroll: ['overscroll-x', 'overscroll-y'],\n inset: ['inset-x', 'inset-y', 'start', 'end', 'top', 'right', 'bottom', 'left'],\n 'inset-x': ['right', 'left'],\n 'inset-y': ['top', 'bottom'],\n flex: ['basis', 'grow', 'shrink'],\n gap: ['gap-x', 'gap-y'],\n p: ['px', 'py', 'ps', 'pe', 'pt', 'pr', 'pb', 'pl'],\n px: ['pr', 'pl'],\n py: ['pt', 'pb'],\n m: ['mx', 'my', 'ms', 'me', 'mt', 'mr', 'mb', 'ml'],\n mx: ['mr', 'ml'],\n my: ['mt', 'mb'],\n size: ['w', 'h'],\n 'font-size': ['leading'],\n 'fvn-normal': ['fvn-ordinal', 'fvn-slashed-zero', 'fvn-figure', 'fvn-spacing', 'fvn-fraction'],\n 'fvn-ordinal': ['fvn-normal'],\n 'fvn-slashed-zero': ['fvn-normal'],\n 'fvn-figure': ['fvn-normal'],\n 'fvn-spacing': ['fvn-normal'],\n 'fvn-fraction': ['fvn-normal'],\n 'line-clamp': ['display', 'overflow'],\n rounded: ['rounded-s', 'rounded-e', 'rounded-t', 'rounded-r', 'rounded-b', 'rounded-l', 'rounded-ss', 'rounded-se', 'rounded-ee', 'rounded-es', 'rounded-tl', 'rounded-tr', 'rounded-br', 'rounded-bl'],\n 'rounded-s': ['rounded-ss', 'rounded-es'],\n 'rounded-e': ['rounded-se', 'rounded-ee'],\n 'rounded-t': ['rounded-tl', 'rounded-tr'],\n 'rounded-r': ['rounded-tr', 'rounded-br'],\n 'rounded-b': ['rounded-br', 'rounded-bl'],\n 'rounded-l': ['rounded-tl', 'rounded-bl'],\n 'border-spacing': ['border-spacing-x', 'border-spacing-y'],\n 'border-w': ['border-w-x', 'border-w-y', 'border-w-s', 'border-w-e', 'border-w-t', 'border-w-r', 'border-w-b', 'border-w-l'],\n 'border-w-x': ['border-w-r', 'border-w-l'],\n 'border-w-y': ['border-w-t', 'border-w-b'],\n 'border-color': ['border-color-x', 'border-color-y', 'border-color-s', 'border-color-e', 'border-color-t', 'border-color-r', 'border-color-b', 'border-color-l'],\n 'border-color-x': ['border-color-r', 'border-color-l'],\n 'border-color-y': ['border-color-t', 'border-color-b'],\n translate: ['translate-x', 'translate-y', 'translate-none'],\n 'translate-none': ['translate', 'translate-x', 'translate-y', 'translate-z'],\n 'scroll-m': ['scroll-mx', 'scroll-my', 'scroll-ms', 'scroll-me', 'scroll-mt', 'scroll-mr', 'scroll-mb', 'scroll-ml'],\n 'scroll-mx': ['scroll-mr', 'scroll-ml'],\n 'scroll-my': ['scroll-mt', 'scroll-mb'],\n 'scroll-p': ['scroll-px', 'scroll-py', 'scroll-ps', 'scroll-pe', 'scroll-pt', 'scroll-pr', 'scroll-pb', 'scroll-pl'],\n 'scroll-px': ['scroll-pr', 'scroll-pl'],\n 'scroll-py': ['scroll-pt', 'scroll-pb'],\n touch: ['touch-x', 'touch-y', 'touch-pz'],\n 'touch-x': ['touch'],\n 'touch-y': ['touch'],\n 'touch-pz': ['touch']\n },\n conflictingClassGroupModifiers: {\n 'font-size': ['leading']\n },\n orderSensitiveModifiers: ['*', '**', 'after', 'backdrop', 'before', 'details-content', 'file', 'first-letter', 'first-line', 'marker', 'placeholder', 'selection']\n };\n};\n\n/**\n * @param baseConfig Config where other config will be merged into. This object will be mutated.\n * @param configExtension Partial config to merge into the `baseConfig`.\n */\nconst mergeConfigs = (baseConfig, {\n cacheSize,\n prefix,\n experimentalParseClassName,\n extend = {},\n override = {}\n}) => {\n overrideProperty(baseConfig, 'cacheSize', cacheSize);\n overrideProperty(baseConfig, 'prefix', prefix);\n overrideProperty(baseConfig, 'experimentalParseClassName', experimentalParseClassName);\n overrideConfigProperties(baseConfig.theme, override.theme);\n overrideConfigProperties(baseConfig.classGroups, override.classGroups);\n overrideConfigProperties(baseConfig.conflictingClassGroups, override.conflictingClassGroups);\n overrideConfigProperties(baseConfig.conflictingClassGroupModifiers, override.conflictingClassGroupModifiers);\n overrideProperty(baseConfig, 'orderSensitiveModifiers', override.orderSensitiveModifiers);\n mergeConfigProperties(baseConfig.theme, extend.theme);\n mergeConfigProperties(baseConfig.classGroups, extend.classGroups);\n mergeConfigProperties(baseConfig.conflictingClassGroups, extend.conflictingClassGroups);\n mergeConfigProperties(baseConfig.conflictingClassGroupModifiers, extend.conflictingClassGroupModifiers);\n mergeArrayProperties(baseConfig, extend, 'orderSensitiveModifiers');\n return baseConfig;\n};\nconst overrideProperty = (baseObject, overrideKey, overrideValue) => {\n if (overrideValue !== undefined) {\n baseObject[overrideKey] = overrideValue;\n }\n};\nconst overrideConfigProperties = (baseObject, overrideObject) => {\n if (overrideObject) {\n for (const key in overrideObject) {\n overrideProperty(baseObject, key, overrideObject[key]);\n }\n }\n};\nconst mergeConfigProperties = (baseObject, mergeObject) => {\n if (mergeObject) {\n for (const key in mergeObject) {\n mergeArrayProperties(baseObject, mergeObject, key);\n }\n }\n};\nconst mergeArrayProperties = (baseObject, mergeObject, key) => {\n const mergeValue = mergeObject[key];\n if (mergeValue !== undefined) {\n baseObject[key] = baseObject[key] ? baseObject[key].concat(mergeValue) : mergeValue;\n }\n};\nconst extendTailwindMerge = (configExtension, ...createConfig) => typeof configExtension === 'function' ? createTailwindMerge(getDefaultConfig, configExtension, ...createConfig) : createTailwindMerge(() => mergeConfigs(getDefaultConfig(), configExtension), ...createConfig);\nconst twMerge = /*#__PURE__*/createTailwindMerge(getDefaultConfig);\nexport { createTailwindMerge, extendTailwindMerge, fromTheme, getDefaultConfig, mergeConfigs, twJoin, twMerge, validators };\n//# sourceMappingURL=bundle-mjs.mjs.map\n","import { type ClassValue, clsx } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n\treturn twMerge(clsx(inputs));\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { Accordion as BaseAccordion } from \"@base-ui-components/react/accordion\";\nimport { cn } from \"@/lib/utils\";\n\n// =============================================================================\n// Accordion\n// =============================================================================\n\nexport interface AccordionProps extends React.HTMLAttributes<HTMLDivElement> {\n\t/**\n\t * Allow multiple items to be expanded at once\n\t * @default false\n\t */\n\tallowMultiple?: boolean;\n\t/**\n\t * The ID(s) of items that should be expanded by default\n\t */\n\tdefaultExpanded?: string | string[];\n\tchildren: React.ReactNode;\n}\n\n/**\n * Accordion component for expandable/collapsible content sections.\n * Built on Base UI's Accordion primitive.\n *\n * @example\n * ```tsx\n * <Accordion defaultExpanded=\"item-1\">\n * <AccordionItem id=\"item-1\" title=\"Question 1\">\n * Answer to question 1\n * </AccordionItem>\n * <AccordionItem id=\"item-2\" title=\"Question 2\">\n * Answer to question 2\n * </AccordionItem>\n * </Accordion>\n * ```\n */\nconst Accordion = React.forwardRef<HTMLDivElement, AccordionProps>(\n\t({ className, allowMultiple = false, defaultExpanded, children }, ref) => {\n\t\t// Normalize defaultExpanded to array format for Base UI\n\t\tconst defaultValue = React.useMemo((): string[] | undefined => {\n\t\t\tif (!defaultExpanded) return undefined;\n\t\t\tif (Array.isArray(defaultExpanded)) return defaultExpanded;\n\t\t\treturn [defaultExpanded];\n\t\t}, [defaultExpanded]);\n\n\t\treturn (\n\t\t\t<BaseAccordion.Root\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"flex flex-col\", className)}\n\t\t\t\tdefaultValue={defaultValue}\n\t\t\t\tmultiple={allowMultiple}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</BaseAccordion.Root>\n\t\t);\n\t},\n);\nAccordion.displayName = \"Accordion\";\n\n// =============================================================================\n// AccordionItem\n// =============================================================================\n\nexport interface AccordionItemProps\n\textends Omit<React.HTMLAttributes<HTMLDivElement>, \"title\"> {\n\t/**\n\t * Unique identifier for this item\n\t */\n\tid: string;\n\t/**\n\t * The question/title displayed in the header\n\t */\n\ttitle: string;\n\t/**\n\t * The answer/content revealed when expanded\n\t */\n\tchildren: React.ReactNode;\n}\n\n/**\n * Individual accordion item with collapsible content.\n * Must be used within an Accordion component.\n */\nconst AccordionItem = React.forwardRef<HTMLDivElement, AccordionItemProps>(\n\t({ className, id, title, children }, ref) => {\n\t\treturn (\n\t\t\t<BaseAccordion.Item\n\t\t\t\tref={ref}\n\t\t\t\tvalue={id}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"border-b overflow-hidden\",\n\t\t\t\t\t\"border-gray-700 data-[open]:border-orange-400\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t{/* Header - always visible */}\n\t\t\t\t<BaseAccordion.Header>\n\t\t\t\t\t<BaseAccordion.Trigger\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\"flex w-full items-center justify-between py-spacing-28 text-left\",\n\t\t\t\t\t\t\t\"typography-body-large transition-colors cursor-pointer\",\n\t\t\t\t\t\t\t\"text-gray-500 hover:text-gray-300 data-[open]:text-gray-100\",\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t<span>{title}</span>\n\t\t\t\t\t\t<span\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"text-base transition-transform duration-200\",\n\t\t\t\t\t\t\t\t\"[[data-open]_&]:rotate-45\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t+\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</BaseAccordion.Trigger>\n\t\t\t\t</BaseAccordion.Header>\n\n\t\t\t\t{/* Content - collapsible */}\n\t\t\t\t<BaseAccordion.Panel\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"h-[var(--accordion-panel-height)] overflow-hidden\",\n\t\t\t\t\t\t\"transition-[height] duration-200 ease-in-out\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t<div className=\"typography-body-large text-gray-500 pb-spacing-28\">\n\t\t\t\t\t\t{children}\n\t\t\t\t\t</div>\n\t\t\t\t</BaseAccordion.Panel>\n\t\t\t</BaseAccordion.Item>\n\t\t);\n\t},\n);\nAccordionItem.displayName = \"AccordionItem\";\n\nexport { Accordion, AccordionItem };\n","'use client';\n\nimport * as React from 'react';\nimport { useButton } from \"../use-button/useButton.js\";\nimport { useRenderElement } from \"../utils/useRenderElement.js\";\n/**\n * A button component that can be used to trigger actions.\n * Renders a `<button>` element.\n *\n * Documentation: [Base UI Button](https://base-ui.com/react/components/button)\n */\nexport const Button = /*#__PURE__*/React.forwardRef(function Button(componentProps, forwardedRef) {\n const {\n render,\n className,\n disabled: disabledProp = false,\n focusableWhenDisabled = false,\n nativeButton = true,\n ...elementProps\n } = componentProps;\n const disabled = Boolean(disabledProp);\n const {\n getButtonProps,\n buttonRef\n } = useButton({\n disabled,\n focusableWhenDisabled,\n native: nativeButton\n });\n const state = React.useMemo(() => ({\n disabled\n }), [disabled]);\n return useRenderElement('button', componentProps, {\n state,\n ref: [forwardedRef, buttonRef],\n props: [elementProps, getButtonProps]\n });\n});\nif (process.env.NODE_ENV !== \"production\") Button.displayName = \"Button\";","/**\n * Copyright 2022 Joe Bell. All rights reserved.\n *\n * This file is licensed to you under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with the\n * License. You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR REPRESENTATIONS OF ANY KIND, either express or implied. See the\n * License for the specific language governing permissions and limitations under\n * the License.\n */ import { clsx } from \"clsx\";\nconst falsyToString = (value)=>typeof value === \"boolean\" ? `${value}` : value === 0 ? \"0\" : value;\nexport const cx = clsx;\nexport const cva = (base, config)=>(props)=>{\n var _config_compoundVariants;\n if ((config === null || config === void 0 ? void 0 : config.variants) == null) return cx(base, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n const { variants, defaultVariants } = config;\n const getVariantClassNames = Object.keys(variants).map((variant)=>{\n const variantProp = props === null || props === void 0 ? void 0 : props[variant];\n const defaultVariantProp = defaultVariants === null || defaultVariants === void 0 ? void 0 : defaultVariants[variant];\n if (variantProp === null) return null;\n const variantKey = falsyToString(variantProp) || falsyToString(defaultVariantProp);\n return variants[variant][variantKey];\n });\n const propsWithoutUndefined = props && Object.entries(props).reduce((acc, param)=>{\n let [key, value] = param;\n if (value === undefined) {\n return acc;\n }\n acc[key] = value;\n return acc;\n }, {});\n const getCompoundVariantClassNames = config === null || config === void 0 ? void 0 : (_config_compoundVariants = config.compoundVariants) === null || _config_compoundVariants === void 0 ? void 0 : _config_compoundVariants.reduce((acc, param)=>{\n let { class: cvClass, className: cvClassName, ...compoundVariantOptions } = param;\n return Object.entries(compoundVariantOptions).every((param)=>{\n let [key, value] = param;\n return Array.isArray(value) ? value.includes({\n ...defaultVariants,\n ...propsWithoutUndefined\n }[key]) : ({\n ...defaultVariants,\n ...propsWithoutUndefined\n })[key] === value;\n }) ? [\n ...acc,\n cvClass,\n cvClassName\n ] : acc;\n }, []);\n return cx(base, getVariantClassNames, getCompoundVariantClassNames, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n };\n\n","import {\n\tButton as BaseButton,\n\ttype ButtonProps as BaseButtonProps,\n} from \"@base-ui-components/react/button\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * Button component based on Figma BaseKit / Interface / Buttons\n *\n * Variants:\n * - charcoal: Dark filled button (for light backgrounds)\n * - charcoalOutline: Dark outlined button (for light backgrounds)\n * - charcoalOutlineQuiet: Subtle dark outlined button (for light backgrounds)\n * - ivory: Light filled button (for dark backgrounds)\n * - ivoryOutline: Light outlined button (for dark backgrounds)\n * - ivoryOutlineQuiet: Subtle light outlined button (for dark backgrounds)\n * - secondary: Gray filled button (for dark backgrounds)\n *\n * Sizes:\n * - lg: Large buttons (46px height)\n * - default: Medium buttons (38px height)\n * - sm: Small buttons (33px height)\n *\n * For icon-only buttons, use the IconButton component instead.\n */\nconst buttonVariants = cva(\n\t\"inline-flex items-center justify-center gap-spacing-6 whitespace-nowrap transition-colors duration-150 cursor-pointer focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\t// Charcoal (dark filled) - primary dark\n\t\t\t\tcharcoal:\n\t\t\t\t\t\"bg-gray-1200 text-gray-100 hover:bg-gray-1100 active:bg-gray-1000 focus-visible:ring-gray-1000\",\n\t\t\t\t// Charcoal Outline - outlined dark (for light backgrounds)\n\t\t\t\tcharcoalOutline:\n\t\t\t\t\t\"border border-alpha-black-30 text-gray-1000 hover:bg-alpha-black-5 active:bg-alpha-black-10 focus-visible:ring-gray-1000\",\n\t\t\t\t// Charcoal Outline Quiet - subtle outlined dark (for light backgrounds)\n\t\t\t\tcharcoalOutlineQuiet:\n\t\t\t\t\t\"border border-alpha-black-20 text-alpha-black-60 hover:border-alpha-black-30 hover:text-alpha-black-80 active:bg-alpha-black-5 focus-visible:ring-gray-1000\",\n\t\t\t\t// Ivory (light filled) - primary light (for dark backgrounds)\n\t\t\t\tivory:\n\t\t\t\t\t\"bg-gray-50 text-gray-1000 hover:bg-gray-100 active:bg-gray-200 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory Outline - outlined light (for dark backgrounds)\n\t\t\t\tivoryOutline:\n\t\t\t\t\t\"border border-gray-50 text-gray-50 hover:bg-alpha-white-10 active:bg-alpha-white-20 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory Outline Quiet - subtle light outline (for dark backgrounds)\n\t\t\t\tivoryOutlineQuiet:\n\t\t\t\t\t\"border border-alpha-white-20 text-alpha-white-60 hover:border-alpha-white-30 hover:text-alpha-white-80 active:bg-alpha-white-5 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Secondary - gray filled button (for dark backgrounds)\n\t\t\t\tsecondary:\n\t\t\t\t\t\"bg-gray-800 text-gray-100 hover:bg-gray-700 active:bg-gray-600 focus-visible:ring-gray-700 focus-visible:ring-offset-gray-1000\",\n\t\t\t},\n\t\t\tsize: {\n\t\t\t\t// Large - uses brand-large component tokens\n\t\t\t\tlg: \"px-spacing-brand-large-component-button-padding-x-large py-spacing-brand-large-component-button-padding-y-large rounded-[var(--spacing-brand-large-component-button-radius-large)] typography-brand-large-button-large h-spacing-brand-large-component-button-height-large\",\n\t\t\t\t// Medium (default) - uses brand-medium component tokens\n\t\t\t\tdefault:\n\t\t\t\t\t\"px-spacing-brand-medium-component-button-padding-x-medium py-spacing-brand-medium-component-button-padding-y-medium rounded-[var(--spacing-brand-medium-component-button-radius-medium)] typography-brand-medium-button-small h-spacing-brand-medium-component-button-height-medium\",\n\t\t\t\t// Small - uses brand-small component tokens\n\t\t\t\tsm: \"px-spacing-brand-small-component-button-padding-x-small py-spacing-brand-small-component-button-padding-y-small rounded-[var(--spacing-brand-small-component-button-radius-small)] typography-brand-small-button-small h-spacing-brand-small-component-button-height-small\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"charcoal\",\n\t\t\tsize: \"default\",\n\t\t},\n\t},\n);\n\nexport type HTMLButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement>;\nexport type ButtonProps = BaseButtonProps &\n\tVariantProps<typeof buttonVariants> &\n\tHTMLButtonProps;\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n\t({ className, variant, size, render, nativeButton, ...props }, ref) => {\n\t\t// When render prop is provided, default nativeButton to false to suppress warnings\n\t\tconst isNativeButton = nativeButton ?? render === undefined;\n\n\t\treturn (\n\t\t\t<BaseButton\n\t\t\t\tclassName={cn(buttonVariants({ variant, size, className }))}\n\t\t\t\tref={ref}\n\t\t\t\trender={render}\n\t\t\t\tnativeButton={isNativeButton}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n","// packages/react/compose-refs/src/compose-refs.tsx\nimport * as React from \"react\";\nfunction setRef(ref, value) {\n if (typeof ref === \"function\") {\n return ref(value);\n } else if (ref !== null && ref !== void 0) {\n ref.current = value;\n }\n}\nfunction composeRefs(...refs) {\n return (node) => {\n let hasCleanup = false;\n const cleanups = refs.map((ref) => {\n const cleanup = setRef(ref, node);\n if (!hasCleanup && typeof cleanup == \"function\") {\n hasCleanup = true;\n }\n return cleanup;\n });\n if (hasCleanup) {\n return () => {\n for (let i = 0; i < cleanups.length; i++) {\n const cleanup = cleanups[i];\n if (typeof cleanup == \"function\") {\n cleanup();\n } else {\n setRef(refs[i], null);\n }\n }\n };\n }\n };\n}\nfunction useComposedRefs(...refs) {\n return React.useCallback(composeRefs(...refs), refs);\n}\nexport {\n composeRefs,\n useComposedRefs\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\nvar REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nvar use = React[\" use \".trim().toString()];\nfunction isPromiseLike(value) {\n return typeof value === \"object\" && value !== null && \"then\" in value;\n}\nfunction isLazyComponent(element) {\n return element != null && typeof element === \"object\" && \"$$typeof\" in element && element.$$typeof === REACT_LAZY_TYPE && \"_payload\" in element && isPromiseLike(element._payload);\n}\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","import { Slot } from \"@radix-ui/react-slot\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * IconButton component based on Figma BaseKit / Interface / Icon Button\n *\n * Variants:\n * - charcoal: Dark filled button (for light backgrounds)\n * - charcoalOutline: Dark outlined button (for light backgrounds)\n * - charcoalOutlineQuiet: Subtle dark outlined button (for light backgrounds)\n * - ghost: No background/border, just icon (for light backgrounds)\n * - ghostDark: No background/border, just icon (for dark backgrounds)\n * - ivory: Light filled button (for dark backgrounds)\n * - ivoryOutline: Light outlined button (for dark backgrounds)\n * - ivoryOutlineQuiet: Subtle light outlined button (for dark backgrounds)\n *\n * Sizes:\n * - lg: Large (46x46)\n * - default: Medium (36x36)\n * - sm: Small (29x29)\n */\nconst iconButtonVariants = cva(\n\t\"inline-flex items-center justify-center whitespace-nowrap transition-colors duration-150 cursor-pointer focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\t// Charcoal (dark filled) - primary dark\n\t\t\t\tcharcoal:\n\t\t\t\t\t\"bg-gray-1200 text-gray-100 hover:bg-gray-1100 active:bg-gray-1000 focus-visible:ring-gray-1000\",\n\t\t\t\t// Charcoal Outline - outlined dark (for light backgrounds)\n\t\t\t\tcharcoalOutline:\n\t\t\t\t\t\"border border-alpha-black-30 text-gray-1000 hover:bg-alpha-black-5 active:bg-alpha-black-10 focus-visible:ring-gray-1000\",\n\t\t\t\t// Charcoal Outline Quiet - subtle outlined dark (for light backgrounds)\n\t\t\t\tcharcoalOutlineQuiet:\n\t\t\t\t\t\"border border-alpha-black-20 text-alpha-black-60 hover:border-alpha-black-30 hover:text-alpha-black-80 active:bg-alpha-black-5 focus-visible:ring-gray-1000\",\n\t\t\t\t// Ghost - no background/border (for light backgrounds)\n\t\t\t\tghost:\n\t\t\t\t\t\"text-gray-700 hover:text-gray-900 hover:bg-alpha-black-5 active:bg-alpha-black-10 focus-visible:ring-gray-1000\",\n\t\t\t\t// Ghost Dark - no background/border (for dark backgrounds)\n\t\t\t\tghostDark:\n\t\t\t\t\t\"text-gray-300 hover:text-gray-100 hover:bg-alpha-white-10 active:bg-alpha-white-20 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory (light filled) - primary light (for dark backgrounds)\n\t\t\t\tivory:\n\t\t\t\t\t\"bg-gray-50 text-gray-1000 hover:bg-gray-100 active:bg-gray-200 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory Outline - outlined light (for dark backgrounds)\n\t\t\t\tivoryOutline:\n\t\t\t\t\t\"border border-gray-50 text-gray-50 hover:bg-alpha-white-10 active:bg-alpha-white-20 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory Outline Quiet - subtle light outline (for dark backgrounds)\n\t\t\t\tivoryOutlineQuiet:\n\t\t\t\t\t\"border border-alpha-white-20 text-alpha-white-60 hover:border-alpha-white-30 hover:text-alpha-white-80 active:bg-alpha-white-5 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t},\n\t\t\tsize: {\n\t\t\t\t// Large (46x46)\n\t\t\t\tlg: \"rounded-[12px] size-[46px]\",\n\t\t\t\t// Medium (36x36) - default\n\t\t\t\tdefault: \"rounded-[12px] size-[36px]\",\n\t\t\t\t// Small (29x29)\n\t\t\t\tsm: \"rounded-[10px] size-[29px]\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"charcoal\",\n\t\t\tsize: \"default\",\n\t\t},\n\t},\n);\n\nexport interface IconButtonProps\n\textends React.ButtonHTMLAttributes<HTMLButtonElement>,\n\t\tVariantProps<typeof iconButtonVariants> {\n\tasChild?: boolean;\n}\n\nconst IconButton = React.forwardRef<HTMLButtonElement, IconButtonProps>(\n\t({ className, variant, size, asChild = false, ...props }, ref) => {\n\t\tconst Comp = asChild ? Slot : \"button\";\n\t\treturn (\n\t\t\t<Comp\n\t\t\t\tclassName={cn(iconButtonVariants({ variant, size, className }))}\n\t\t\t\tref={ref}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nIconButton.displayName = \"IconButton\";\n\nexport { IconButton, iconButtonVariants };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\nconst pagerControlVariants = cva(\"flex items-center\", {\n\tvariants: {\n\t\tsize: {\n\t\t\tsm: \"gap-[1px]\",\n\t\t\tdefault: \"gap-[2px]\",\n\t\t\tlg: \"gap-[3px]\",\n\t\t},\n\t},\n\tdefaultVariants: {\n\t\tsize: \"default\",\n\t},\n});\n\nconst dotBaseVariants = cva(\n\t\"cursor-pointer rounded-full transition-all duration-500 ease-[cubic-bezier(0.23,1,0.32,1)]\",\n\t{\n\t\tvariants: {\n\t\t\tsize: {\n\t\t\t\tsm: \"h-[6px]\",\n\t\t\t\tdefault: \"h-[10px]\",\n\t\t\t\tlg: \"h-[14px]\",\n\t\t\t},\n\t\t\tvariant: {\n\t\t\t\tcharcoal: \"\",\n\t\t\t\tivory: \"\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tsize: \"default\",\n\t\t\tvariant: \"charcoal\",\n\t\t},\n\t},\n);\n\nexport interface PagerControlProps\n\textends Omit<React.HTMLAttributes<HTMLDivElement>, \"onChange\">,\n\t\tVariantProps<typeof pagerControlVariants>,\n\t\tVariantProps<typeof dotBaseVariants> {\n\t/**\n\t * Total number of pages/items\n\t */\n\tcount: number;\n\t/**\n\t * Current active page index (0-based)\n\t */\n\tactiveIndex?: number;\n\t/**\n\t * Duration in milliseconds for each page before auto-advancing\n\t * Set to 0 to disable auto-advance\n\t * @default 5000\n\t */\n\tduration?: number;\n\t/**\n\t * Whether the pager should auto-advance\n\t * @default true\n\t */\n\tautoPlay?: boolean;\n\t/**\n\t * Callback when the active page changes\n\t */\n\tonChange?: (index: number) => void;\n\t/**\n\t * Whether to pause auto-advance on hover\n\t * @default true\n\t */\n\tpauseOnHover?: boolean;\n\t/**\n\t * Whether to loop back to the first page after the last\n\t * @default true\n\t */\n\tloop?: boolean;\n}\n\n/**\n * PagerControl component for indicating progress through a series of pages/slides.\n *\n * Features smooth width transitions when switching between dots and an animated\n * progress fill on the active dot that shows time remaining before auto-advancing\n * (similar to Apple's carousel indicators).\n *\n * Variants:\n * - charcoal: Dark dots (for light backgrounds)\n * - ivory: Light dots (for dark backgrounds)\n *\n * Sizes:\n * - sm: Small dots (6px height)\n * - default: Medium dots (10px height)\n * - lg: Large dots (14px height)\n */\nconst PagerControl = React.forwardRef<HTMLDivElement, PagerControlProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\tsize,\n\t\t\tvariant,\n\t\t\tcount,\n\t\t\tactiveIndex: controlledIndex,\n\t\t\tduration = 5000,\n\t\t\tautoPlay = true,\n\t\t\tonChange,\n\t\t\tpauseOnHover = true,\n\t\t\tloop = true,\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\tconst [internalIndex, setInternalIndex] = React.useState(0);\n\t\tconst [isPaused, setIsPaused] = React.useState(false);\n\t\tconst [progress, setProgress] = React.useState(0);\n\n\t\t// Use controlled index if provided, otherwise use internal state\n\t\tconst activeIndex =\n\t\t\tcontrolledIndex !== undefined ? controlledIndex : internalIndex;\n\t\tconst isControlled = controlledIndex !== undefined;\n\n\t\tconst animationFrameRef = React.useRef<number | null>(null);\n\t\tconst startTimeRef = React.useRef<number | null>(null);\n\t\tconst pausedProgressRef = React.useRef<number>(0);\n\n\t\tconst goToNext = React.useCallback(() => {\n\t\t\tconst nextIndex = activeIndex + 1;\n\t\t\tif (nextIndex >= count) {\n\t\t\t\tif (loop) {\n\t\t\t\t\tif (!isControlled) setInternalIndex(0);\n\t\t\t\t\tonChange?.(0);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (!isControlled) setInternalIndex(nextIndex);\n\t\t\t\tonChange?.(nextIndex);\n\t\t\t}\n\t\t}, [activeIndex, count, loop, isControlled, onChange]);\n\n\t\tconst goToIndex = React.useCallback(\n\t\t\t(index: number) => {\n\t\t\t\tif (!isControlled) setInternalIndex(index);\n\t\t\t\tonChange?.(index);\n\t\t\t\t// Reset progress when manually changing\n\t\t\t\tsetProgress(0);\n\t\t\t\tpausedProgressRef.current = 0;\n\t\t\t\tstartTimeRef.current = null;\n\t\t\t},\n\t\t\t[isControlled, onChange],\n\t\t);\n\n\t\t// Animation loop for smooth progress fill\n\t\tReact.useEffect(() => {\n\t\t\tif (!autoPlay || duration <= 0 || isPaused) {\n\t\t\t\tif (animationFrameRef.current) {\n\t\t\t\t\tcancelAnimationFrame(animationFrameRef.current);\n\t\t\t\t\tanimationFrameRef.current = null;\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst animate = (timestamp: number) => {\n\t\t\t\tif (startTimeRef.current === null) {\n\t\t\t\t\tstartTimeRef.current =\n\t\t\t\t\t\ttimestamp - (pausedProgressRef.current / 100) * duration;\n\t\t\t\t}\n\n\t\t\t\tconst elapsed = timestamp - startTimeRef.current;\n\t\t\t\tconst newProgress = Math.min((elapsed / duration) * 100, 100);\n\t\t\t\tsetProgress(newProgress);\n\n\t\t\t\tif (newProgress >= 100) {\n\t\t\t\t\tgoToNext();\n\t\t\t\t\t// Reset for next cycle\n\t\t\t\t\tsetProgress(0);\n\t\t\t\t\tpausedProgressRef.current = 0;\n\t\t\t\t\tstartTimeRef.current = null;\n\t\t\t\t} else {\n\t\t\t\t\tanimationFrameRef.current = requestAnimationFrame(animate);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tanimationFrameRef.current = requestAnimationFrame(animate);\n\n\t\t\treturn () => {\n\t\t\t\tif (animationFrameRef.current) {\n\t\t\t\t\tcancelAnimationFrame(animationFrameRef.current);\n\t\t\t\t}\n\t\t\t};\n\t\t}, [autoPlay, duration, isPaused, goToNext]);\n\n\t\t// Handle pause/resume\n\t\tconst handleMouseEnter = React.useCallback(() => {\n\t\t\tif (pauseOnHover) {\n\t\t\t\tpausedProgressRef.current = progress;\n\t\t\t\tstartTimeRef.current = null;\n\t\t\t\tsetIsPaused(true);\n\t\t\t}\n\t\t}, [pauseOnHover, progress]);\n\n\t\tconst handleMouseLeave = React.useCallback(() => {\n\t\t\tif (pauseOnHover) {\n\t\t\t\tsetIsPaused(false);\n\t\t\t}\n\t\t}, [pauseOnHover]);\n\n\t\t// Reset progress when activeIndex changes externally (controlled mode)\n\t\tReact.useEffect(() => {\n\t\t\tif (isControlled) {\n\t\t\t\tsetProgress(0);\n\t\t\t\tpausedProgressRef.current = 0;\n\t\t\t\tstartTimeRef.current = null;\n\t\t\t}\n\t\t}, [isControlled]);\n\n\t\t// Get dot dimensions based on size\n\t\tconst getDotWidth = (isActive: boolean) => {\n\t\t\tif (isActive) {\n\t\t\t\tswitch (size) {\n\t\t\t\t\tcase \"sm\":\n\t\t\t\t\t\treturn \"w-[16px]\";\n\t\t\t\t\tcase \"lg\":\n\t\t\t\t\t\treturn \"w-[36px]\";\n\t\t\t\t\tdefault:\n\t\t\t\t\t\treturn \"w-[26px]\";\n\t\t\t\t}\n\t\t\t}\n\t\t\tswitch (size) {\n\t\t\t\tcase \"sm\":\n\t\t\t\t\treturn \"w-[6px]\";\n\t\t\t\tcase \"lg\":\n\t\t\t\t\treturn \"w-[14px]\";\n\t\t\t\tdefault:\n\t\t\t\t\treturn \"w-[10px]\";\n\t\t\t}\n\t\t};\n\n\t\t// Get background classes for inactive dots\n\t\tconst getInactiveClasses = () => {\n\t\t\tif (variant === \"ivory\") {\n\t\t\t\treturn \"bg-alpha-white-30 hover:bg-alpha-white-60\";\n\t\t\t}\n\t\t\treturn \"bg-alpha-black-30 hover:bg-alpha-black-60\";\n\t\t};\n\n\t\t// Get background class for active dot (the track/background)\n\t\tconst getActiveTrackClass = () => {\n\t\t\tif (variant === \"ivory\") {\n\t\t\t\treturn \"bg-alpha-white-30\";\n\t\t\t}\n\t\t\treturn \"bg-alpha-black-30\";\n\t\t};\n\n\t\t// Get fill color for the progress indicator\n\t\tconst getProgressFillClass = () => {\n\t\t\tif (variant === \"ivory\") {\n\t\t\t\treturn \"bg-gray-50\";\n\t\t\t}\n\t\t\treturn \"bg-gray-1200\";\n\t\t};\n\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\trole=\"tablist\"\n\t\t\t\taria-label=\"Page indicators\"\n\t\t\t\tclassName={cn(pagerControlVariants({ size, className }))}\n\t\t\t\tonMouseEnter={handleMouseEnter}\n\t\t\t\tonMouseLeave={handleMouseLeave}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{Array.from({ length: count }, (_, index) => {\n\t\t\t\t\tconst isActive = index === activeIndex;\n\n\t\t\t\t\tif (isActive) {\n\t\t\t\t\t\t// Active dot with progress fill\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t<button\n\t\t\t\t\t\t\t\t// biome-ignore lint/suspicious/noArrayIndexKey: Pagination dots have fixed order based on count\n\t\t\t\t\t\t\t\tkey={index}\n\t\t\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t\t\trole=\"tab\"\n\t\t\t\t\t\t\t\taria-selected={true}\n\t\t\t\t\t\t\t\taria-label={`Page ${index + 1} of ${count}, current`}\n\t\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\t\"relative cursor-pointer overflow-hidden rounded-full transition-all duration-500 ease-[cubic-bezier(0.23,1,0.32,1)]\",\n\t\t\t\t\t\t\t\t\tdotBaseVariants({ size, variant }),\n\t\t\t\t\t\t\t\t\tgetDotWidth(true),\n\t\t\t\t\t\t\t\t\tgetActiveTrackClass(),\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\tonClick={() => goToIndex(index)}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{/* Progress fill */}\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\t\t\"absolute top-0 bottom-0 left-0 h-full rounded-full\",\n\t\t\t\t\t\t\t\t\t\tgetProgressFillClass(),\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\t\twidth: autoPlay && duration > 0 ? `${progress}%` : \"100%\",\n\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</button>\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Inactive dot\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<button\n\t\t\t\t\t\t\t// biome-ignore lint/suspicious/noArrayIndexKey: Pagination dots have fixed order based on count\n\t\t\t\t\t\t\tkey={index}\n\t\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t\trole=\"tab\"\n\t\t\t\t\t\t\taria-selected={false}\n\t\t\t\t\t\t\taria-label={`Go to page ${index + 1} of ${count}`}\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\tdotBaseVariants({ size, variant }),\n\t\t\t\t\t\t\t\tgetDotWidth(false),\n\t\t\t\t\t\t\t\tgetInactiveClasses(),\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\tonClick={() => goToIndex(index)}\n\t\t\t\t\t\t/>\n\t\t\t\t\t);\n\t\t\t\t})}\n\t\t\t</div>\n\t\t);\n\t},\n);\nPagerControl.displayName = \"PagerControl\";\n\nexport { PagerControl, pagerControlVariants };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\nconst cardVariants = cva(\"flex overflow-hidden rounded-[24px] bg-white\", {\n\tvariants: {\n\t\tlayout: {\n\t\t\tvertical: \"w-full flex-col\",\n\t\t\thorizontal: \"w-full flex-row\",\n\t\t},\n\t},\n\tdefaultVariants: {\n\t\tlayout: \"vertical\",\n\t},\n});\n\nexport interface CardProps\n\textends React.HTMLAttributes<HTMLDivElement>,\n\t\tVariantProps<typeof cardVariants> {}\n\n/**\n * Card component for displaying content in a contained, scannable format.\n *\n * Layouts:\n * - vertical: Image on top, content below (default)\n * - horizontal: Image on left, content on right\n *\n * Use with CardImage, CardContent, CardEyebrow, CardTitle, CardDescription, and CardActions.\n */\nconst Card = React.forwardRef<HTMLDivElement, CardProps>(\n\t({ className, layout, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(cardVariants({ layout, className }))}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCard.displayName = \"Card\";\n\nexport interface CardImageProps extends React.HTMLAttributes<HTMLDivElement> {\n\t/**\n\t * The image source URL\n\t */\n\tsrc?: string;\n\t/**\n\t * Alt text for the image\n\t */\n\talt?: string;\n}\n\n/**\n * Card image area. For vertical layout, displays with 16:9 aspect ratio.\n * For horizontal layout, takes up ~40% width and stretches to content height.\n */\nconst CardImage = React.forwardRef<HTMLDivElement, CardImageProps>(\n\t({ className, src, alt = \"\", ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"relative shrink-0 bg-gray-500\",\n\t\t\t\t\t// Vertical: full width with aspect ratio\n\t\t\t\t\t\"aspect-video w-full\",\n\t\t\t\t\t// When in horizontal card (parent has flex-row), override\n\t\t\t\t\t\"[.flex-row>&]:aspect-auto [.flex-row>&]:w-2/5 [.flex-row>&]:self-stretch\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{src && (\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\talt={alt}\n\t\t\t\t\t\tclassName=\"absolute inset-0 size-full object-cover\"\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t);\n\t},\n);\nCardImage.displayName = \"CardImage\";\n\nexport interface CardContentProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Card content container with proper padding and spacing.\n */\nconst CardContent = React.forwardRef<HTMLDivElement, CardContentProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex w-full flex-1 flex-col gap-spacing-24 p-spacing-24\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardContent.displayName = \"CardContent\";\n\nexport interface CardEyebrowProps\n\textends React.HTMLAttributes<HTMLParagraphElement> {}\n\n/**\n * Optional eyebrow text above the card title.\n */\nconst CardEyebrow = React.forwardRef<HTMLParagraphElement, CardEyebrowProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<p\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"typography-brand-large-caption-large text-gray-500\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardEyebrow.displayName = \"CardEyebrow\";\n\nexport interface CardTitleProps\n\textends React.HTMLAttributes<HTMLHeadingElement> {\n\t/**\n\t * The heading level to render (h1-h6). Defaults to h3.\n\t */\n\tas?: \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\";\n}\n\n/**\n * Card title/heading. Use the `as` prop to change the heading level.\n */\nconst CardTitle = React.forwardRef<HTMLHeadingElement, CardTitleProps>(\n\t({ className, as: Component = \"h3\", ...props }, ref) => {\n\t\treturn (\n\t\t\t<Component\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"typography-brand-large-subheading-small text-gray-1100\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardTitle.displayName = \"CardTitle\";\n\nexport interface CardDescriptionProps\n\textends React.HTMLAttributes<HTMLParagraphElement> {}\n\n/**\n * Card body/description text.\n */\nconst CardDescription = React.forwardRef<\n\tHTMLParagraphElement,\n\tCardDescriptionProps\n>(({ className, ...props }, ref) => {\n\treturn (\n\t\t<p\n\t\t\tref={ref}\n\t\t\tclassName={cn(\n\t\t\t\t\"typography-brand-large-body-small text-gray-800\",\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\t{...props}\n\t\t/>\n\t);\n});\nCardDescription.displayName = \"CardDescription\";\n\nexport interface CardBodyProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Container for card text content (eyebrow, title, description).\n */\nconst CardBody = React.forwardRef<HTMLDivElement, CardBodyProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"flex w-full flex-col gap-spacing-14\", className)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardBody.displayName = \"CardBody\";\n\nexport interface CardActionsProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Container for card action buttons.\n */\nconst CardActions = React.forwardRef<HTMLDivElement, CardActionsProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"flex gap-spacing-11\", className)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardActions.displayName = \"CardActions\";\n\nexport {\n\tCard,\n\tcardVariants,\n\tCardImage,\n\tCardContent,\n\tCardEyebrow,\n\tCardTitle,\n\tCardDescription,\n\tCardBody,\n\tCardActions,\n};\n","import { Slot } from \"@radix-ui/react-slot\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n// Context for mobile menu state\nconst NavbarContext = React.createContext<{\n\tisMobileMenuOpen: boolean;\n\tsetIsMobileMenuOpen: (open: boolean) => void;\n}>({\n\tisMobileMenuOpen: false,\n\tsetIsMobileMenuOpen: () => {},\n});\n\nexport interface NavbarProps extends React.HTMLAttributes<HTMLElement> {}\n\n/**\n * Main navigation bar container.\n * Provides responsive layout for brand, links, and actions.\n */\nconst Navbar = React.forwardRef<HTMLElement, NavbarProps>(\n\t({ className, children, ...props }, ref) => {\n\t\tconst [isMobileMenuOpen, setIsMobileMenuOpen] = React.useState(false);\n\t\tconst navRef = React.useRef<HTMLElement>(null);\n\n\t\t// Set navbar height CSS variable for mobile menu positioning\n\t\tReact.useEffect(() => {\n\t\t\tconst updateHeight = () => {\n\t\t\t\tif (navRef.current) {\n\t\t\t\t\tconst height = navRef.current.offsetHeight;\n\t\t\t\t\tdocument.documentElement.style.setProperty(\n\t\t\t\t\t\t\"--navbar-height\",\n\t\t\t\t\t\t`${height}px`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tupdateHeight();\n\t\t\twindow.addEventListener(\"resize\", updateHeight);\n\t\t\treturn () => window.removeEventListener(\"resize\", updateHeight);\n\t\t}, []);\n\n\t\t// Merge refs\n\t\tconst mergedRef = React.useCallback(\n\t\t\t(node: HTMLElement | null) => {\n\t\t\t\t(navRef as React.MutableRefObject<HTMLElement | null>).current = node;\n\t\t\t\tif (typeof ref === \"function\") {\n\t\t\t\t\tref(node);\n\t\t\t\t} else if (ref) {\n\t\t\t\t\tref.current = node;\n\t\t\t\t}\n\t\t\t},\n\t\t\t[ref],\n\t\t);\n\n\t\treturn (\n\t\t\t<NavbarContext.Provider value={{ isMobileMenuOpen, setIsMobileMenuOpen }}>\n\t\t\t\t<nav\n\t\t\t\t\tref={mergedRef}\n\t\t\t\t\tclassName={cn(\"relative z-50 w-full bg-gray-50\", className)}\n\t\t\t\t\t{...props}\n\t\t\t\t>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\"flex w-full items-center justify-between\",\n\t\t\t\t\t\t\t// Mobile\n\t\t\t\t\t\t\t\"px-spacing-20 py-spacing-8\",\n\t\t\t\t\t\t\t// Tablet\n\t\t\t\t\t\t\t\"md:px-spacing-32 md:py-spacing-16\",\n\t\t\t\t\t\t\t// Desktop\n\t\t\t\t\t\t\t\"xl:px-spacing-32 xl:py-spacing-24\",\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t{children}\n\t\t\t\t\t</div>\n\t\t\t\t</nav>\n\t\t\t</NavbarContext.Provider>\n\t\t);\n\t},\n);\nNavbar.displayName = \"Navbar\";\n\nexport interface NavbarBrandProps extends React.HTMLAttributes<HTMLDivElement> {\n\tasChild?: boolean;\n}\n\n/**\n * Brand/logo area of the navbar.\n * Use asChild to render as a link.\n */\nconst NavbarBrand = React.forwardRef<HTMLDivElement, NavbarBrandProps>(\n\t({ className, asChild = false, ...props }, ref) => {\n\t\tconst Comp = asChild ? Slot : \"div\";\n\t\treturn <Comp ref={ref} className={cn(\"shrink-0\", className)} {...props} />;\n\t},\n);\nNavbarBrand.displayName = \"NavbarBrand\";\n\nexport interface NavbarLinksProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Container for navigation links.\n * Centers links on desktop, hidden on mobile (use NavbarMobileMenu instead).\n */\nconst NavbarLinks = React.forwardRef<HTMLDivElement, NavbarLinksProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"hidden items-center gap-spacing-40 md:flex\", className)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nNavbarLinks.displayName = \"NavbarLinks\";\n\nexport interface NavbarLinkProps\n\textends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n\tasChild?: boolean;\n\tactive?: boolean;\n}\n\n/**\n * Individual navigation link.\n * Use asChild to render with a router Link component.\n */\nconst NavbarLink = React.forwardRef<HTMLAnchorElement, NavbarLinkProps>(\n\t({ className, asChild = false, active, ...props }, ref) => {\n\t\tconst Comp = asChild ? Slot : \"a\";\n\t\treturn (\n\t\t\t<Comp\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"typography-brand-medium-link-small text-gray-900 transition-colors hover:text-gray-700\",\n\t\t\t\t\tactive && \"text-gray-1100\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nNavbarLink.displayName = \"NavbarLink\";\n\nexport interface NavbarActionsProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Container for navbar action items (search, menu button, etc).\n */\nconst NavbarActions = React.forwardRef<HTMLDivElement, NavbarActionsProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"flex items-center gap-spacing-8\", className)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nNavbarActions.displayName = \"NavbarActions\";\n\nexport interface NavbarMobileMenuProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Mobile menu container that displays navigation links on mobile devices.\n * Hidden on desktop (md and above). Should be used with NavbarMobileMenuButton.\n */\nconst NavbarMobileMenu = React.forwardRef<\n\tHTMLDivElement,\n\tNavbarMobileMenuProps\n>(({ className, children, ...props }, ref) => {\n\tconst { isMobileMenuOpen, setIsMobileMenuOpen } =\n\t\tReact.useContext(NavbarContext);\n\tconst menuRef = React.useRef<HTMLDivElement>(null);\n\n\t// Close menu when clicking outside\n\tReact.useEffect(() => {\n\t\tif (!isMobileMenuOpen) return;\n\n\t\tconst handleClickOutside = (event: MouseEvent) => {\n\t\t\tconst target = event.target as Node;\n\t\t\tif (menuRef.current && !menuRef.current.contains(target)) {\n\t\t\t\tsetIsMobileMenuOpen(false);\n\t\t\t}\n\t\t};\n\n\t\t// Use setTimeout to avoid immediate close on button click\n\t\tconst timeoutId = setTimeout(() => {\n\t\t\tdocument.addEventListener(\"mousedown\", handleClickOutside);\n\t\t}, 0);\n\n\t\treturn () => {\n\t\t\tclearTimeout(timeoutId);\n\t\t\tdocument.removeEventListener(\"mousedown\", handleClickOutside);\n\t\t};\n\t}, [isMobileMenuOpen, setIsMobileMenuOpen]);\n\n\t// Prevent body scroll when menu is open\n\tReact.useEffect(() => {\n\t\tif (isMobileMenuOpen) {\n\t\t\tdocument.body.style.overflow = \"hidden\";\n\t\t} else {\n\t\t\tdocument.body.style.overflow = \"\";\n\t\t}\n\t\treturn () => {\n\t\t\tdocument.body.style.overflow = \"\";\n\t\t};\n\t}, [isMobileMenuOpen]);\n\n\t// Close menu on escape key\n\tReact.useEffect(() => {\n\t\tif (!isMobileMenuOpen) return;\n\n\t\tconst handleEscape = (event: KeyboardEvent) => {\n\t\t\tif (event.key === \"Escape\") {\n\t\t\t\tsetIsMobileMenuOpen(false);\n\t\t\t}\n\t\t};\n\n\t\tdocument.addEventListener(\"keydown\", handleEscape);\n\t\treturn () => document.removeEventListener(\"keydown\", handleEscape);\n\t}, [isMobileMenuOpen, setIsMobileMenuOpen]);\n\n\tif (!isMobileMenuOpen) return null;\n\n\treturn (\n\t\t<div\n\t\t\tref={menuRef}\n\t\t\tclassName={cn(\n\t\t\t\t\"fixed inset-0 z-50 bg-gray-50 md:hidden\",\n\t\t\t\t// Position below navbar\n\t\t\t\t\"pt-[calc(var(--navbar-height,60px)+1px)]\",\n\t\t\t\t// Smooth transition\n\t\t\t\t\"transition-opacity duration-200\",\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\trole=\"dialog\"\n\t\t\taria-modal=\"true\"\n\t\t\taria-label=\"Mobile navigation menu\"\n\t\t\t{...props}\n\t\t>\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex flex-col\",\n\t\t\t\t\t// Padding matching navbar\n\t\t\t\t\t\"px-spacing-20 py-spacing-16\",\n\t\t\t\t\t// Gap between links\n\t\t\t\t\t\"gap-spacing-8\",\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</div>\n\t\t</div>\n\t);\n});\nNavbarMobileMenu.displayName = \"NavbarMobileMenu\";\n\nexport interface NavbarMobileMenuButtonProps\n\textends React.ButtonHTMLAttributes<HTMLButtonElement> {\n\tasChild?: boolean;\n}\n\n/**\n * Button to toggle the mobile menu.\n * Should be placed in NavbarActions on mobile.\n * Use asChild to render as a custom button component (e.g., IconButton).\n */\nconst NavbarMobileMenuButton = React.forwardRef<\n\tHTMLButtonElement,\n\tNavbarMobileMenuButtonProps\n>(({ className, asChild = false, children, ...props }, ref) => {\n\tconst { isMobileMenuOpen, setIsMobileMenuOpen } =\n\t\tReact.useContext(NavbarContext);\n\n\tconst handleClick = () => {\n\t\tsetIsMobileMenuOpen(!isMobileMenuOpen);\n\t};\n\n\tif (asChild) {\n\t\treturn (\n\t\t\t<Slot\n\t\t\t\tref={ref}\n\t\t\t\taria-label=\"Toggle navigation menu\"\n\t\t\t\taria-expanded={isMobileMenuOpen}\n\t\t\t\taria-controls=\"navbar-mobile-menu\"\n\t\t\t\tonClick={handleClick}\n\t\t\t\tclassName={className}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</Slot>\n\t\t);\n\t}\n\n\treturn (\n\t\t<button\n\t\t\tref={ref}\n\t\t\ttype=\"button\"\n\t\t\taria-label=\"Toggle navigation menu\"\n\t\t\taria-expanded={isMobileMenuOpen}\n\t\t\taria-controls=\"navbar-mobile-menu\"\n\t\t\tonClick={handleClick}\n\t\t\tclassName={cn(\"transition-colors\", className)}\n\t\t\t{...props}\n\t\t>\n\t\t\t{children}\n\t\t</button>\n\t);\n});\nNavbarMobileMenuButton.displayName = \"NavbarMobileMenuButton\";\n\nexport interface NavbarMobileMenuLinkProps\n\textends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n\tasChild?: boolean;\n\tactive?: boolean;\n}\n\n/**\n * Navigation link for the mobile menu.\n * Automatically closes the mobile menu when clicked.\n * Use asChild to render with a router Link component.\n */\nconst NavbarMobileMenuLink = React.forwardRef<\n\tHTMLAnchorElement,\n\tNavbarMobileMenuLinkProps\n>(({ className, asChild = false, active, onClick, ...props }, ref) => {\n\tconst { setIsMobileMenuOpen } = React.useContext(NavbarContext);\n\tconst Comp = asChild ? Slot : \"a\";\n\n\tconst handleClick = (event: React.MouseEvent<HTMLAnchorElement>) => {\n\t\tsetIsMobileMenuOpen(false);\n\t\tonClick?.(event);\n\t};\n\n\treturn (\n\t\t<Comp\n\t\t\tref={ref}\n\t\t\tclassName={cn(\n\t\t\t\t\"typography-brand-medium-link-medium text-gray-900 transition-colors hover:text-gray-700\",\n\t\t\t\t\"py-spacing-8\",\n\t\t\t\tactive && \"text-gray-1100\",\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\tonClick={handleClick}\n\t\t\t{...props}\n\t\t/>\n\t);\n});\nNavbarMobileMenuLink.displayName = \"NavbarMobileMenuLink\";\n\nexport {\n\tNavbar,\n\tNavbarBrand,\n\tNavbarLinks,\n\tNavbarLink,\n\tNavbarActions,\n\tNavbarMobileMenu,\n\tNavbarMobileMenuButton,\n\tNavbarMobileMenuLink,\n};\n","import * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\nexport interface USGovBannerProps extends React.HTMLAttributes<HTMLDivElement> {\n\t/**\n\t * Custom flag icon element. Defaults to a US flag SVG.\n\t */\n\tflagIcon?: React.ReactNode;\n\t/**\n\t * Banner text content\n\t * @default \"An official website of the United States government\"\n\t */\n\ttext?: string;\n}\n\n/**\n * US Government official website banner.\n * Displays the official government website notice with flag icon.\n * Commonly placed at the very top of government websites.\n */\nconst USGovBanner = React.forwardRef<HTMLDivElement, USGovBannerProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\tflagIcon,\n\t\t\ttext = \"An official website of the United States government\",\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex w-full items-center justify-center bg-gray-50 py-spacing-12\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t<div className=\"flex items-center gap-spacing-8 opacity-70\">\n\t\t\t\t\t{flagIcon ?? <DefaultUSFlag />}\n\t\t\t\t\t<p className=\"text-[11px] leading-[13px] tracking-[0.17px] text-gray-900\">\n\t\t\t\t\t\t{text}\n\t\t\t\t\t</p>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t},\n);\nUSGovBanner.displayName = \"USGovBanner\";\n\nfunction DefaultUSFlag() {\n\treturn (\n\t\t<svg\n\t\t\twidth=\"16\"\n\t\t\theight=\"12\"\n\t\t\tviewBox=\"0 0 16 12\"\n\t\t\tfill=\"none\"\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\n\t\t\taria-hidden=\"true\"\n\t\t>\n\t\t\t<path d=\"M0 0H16V12H0V0Z\" fill=\"#212121\" fillOpacity=\"0.1\" />\n\t\t\t<path\n\t\t\t\td=\"M0 0H16V0.923077H0V0ZM0 1.84615H16V2.76923H0V1.84615ZM0 3.69231H16V4.61538H0V3.69231ZM0 5.53846H16V6.46154H0V5.53846ZM0 7.38462H16V8.30769H0V7.38462ZM0 9.23077H16V10.1538H0V9.23077ZM0 11.0769H16V12H0V11.0769Z\"\n\t\t\t\tfill=\"#BF0A30\"\n\t\t\t\tfillOpacity=\"0.8\"\n\t\t\t/>\n\t\t\t<path d=\"M0 0H8V6.46154H0V0Z\" fill=\"#002868\" fillOpacity=\"0.8\" />\n\t\t</svg>\n\t);\n}\n\nexport { USGovBanner };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * Banner component based on Figma BaseKit / Banners\n *\n * Used to surface short, important updates or a single key action\n * without disrupting the main page content.\n *\n * Responsive behavior using 24-column grid:\n * - Mobile (sm): Stacked layout, 20px horizontal / 32px vertical padding\n * - Tablet (md): Horizontal layout, 56px padding\n * - Desktop (lg): Horizontal layout, 72px padding\n *\n * Must be placed inside a `grid-container`. Uses `col-full` to span all columns.\n */\nconst bannerVariants = cva(\n\t[\n\t\t// Grid alignment - full width\n\t\t\"col-full\",\n\t\t// Responsive padding: mobile -> tablet -> desktop\n\t\t\"px-spacing-20 py-spacing-32\",\n\t\t\"md:p-spacing-56\",\n\t\t\"lg:px-spacing-72 lg:pb-spacing-72 lg:pt-0\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\ttheme: {\n\t\t\t\tlight: \"bg-gray-50\",\n\t\t\t\tdark: \"bg-gray-1200\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\ttheme: \"light\",\n\t\t},\n\t},\n);\n\nexport interface BannerProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof bannerVariants> {\n\t/**\n\t * The heading text displayed in the banner\n\t */\n\theading: string;\n\t/**\n\t * The description text displayed below the heading\n\t */\n\tdescription: string;\n\t/**\n\t * Optional action element (typically a Button component)\n\t */\n\taction?: React.ReactNode;\n}\n\n/**\n * Banner component for surfacing important updates or CTAs.\n *\n * Uses the 24-column grid system - must be placed inside a `grid-container`.\n * Spans full width with `col-full`.\n *\n * Responsive across breakpoints:\n * - Mobile: Stacked layout with smaller padding\n * - Tablet: Horizontal layout with medium padding\n * - Desktop: Horizontal layout with larger padding\n *\n * @example\n * ```tsx\n * <div className=\"grid-container\">\n * <Banner\n * heading=\"Important Update\"\n * description=\"Check out our new features.\"\n * action={<Button>Learn More</Button>}\n * />\n * </div>\n *\n * // Dark theme\n * <Banner\n * theme=\"dark\"\n * heading=\"Still Have Questions?\"\n * description=\"Contact us at support@example.com\"\n * action={<Button variant=\"secondary\">Email Us</Button>}\n * />\n * ```\n */\nconst Banner = React.forwardRef<HTMLElement, BannerProps>(\n\t({ className, theme, heading, description, action, ...props }, ref) => {\n\t\tconst isDark = theme === \"dark\";\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(bannerVariants({ theme }), className)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Inner container with border-top for dark theme */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"flex flex-col md:flex-row gap-spacing-20 items-start md:items-center md:justify-between\",\n\t\t\t\t\t\tisDark && \"border-t border-gray-700 py-spacing-36\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{/* Copy section */}\n\t\t\t\t\t<div className=\"flex flex-col gap-spacing-6 items-start\">\n\t\t\t\t\t\t<h2\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"typography-subheading-small\",\n\t\t\t\t\t\t\t\tisDark ? \"text-gray-100\" : \"text-gray-900\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{heading}\n\t\t\t\t\t\t</h2>\n\t\t\t\t\t\t<p\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"typography-body-small\",\n\t\t\t\t\t\t\t\tisDark ? \"text-gray-500\" : \"text-gray-800\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{description}\n\t\t\t\t\t\t</p>\n\t\t\t\t\t</div>\n\t\t\t\t\t{/* Action slot */}\n\t\t\t\t\t{action}\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nBanner.displayName = \"Banner\";\n\nexport { Banner, bannerVariants };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * CardGrid component for displaying cards in a responsive grid layout\n *\n * Variants:\n * - A: 3 columns on desktop, 2 on tablet, 1 on mobile\n * - B: 2 columns on desktop/tablet, 1 on mobile\n *\n * Uses the 24-column grid system with grid-container as root.\n */\nconst cardGridVariants = cva(\n\t// Base styles - grid-container for proper grid context\n\t[\n\t\t\"grid-container\",\n\t\t// Small (mobile): 72px y padding\n\t\t\"py-spacing-72\",\n\t\t// Large (desktop): 128px y padding\n\t\t\"lg:py-spacing-128\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\tA: \"\",\n\t\t\t\tB: \"\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"A\",\n\t\t},\n\t},\n);\n\nexport interface CardGridProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof cardGridVariants> {\n\t/**\n\t * The title text displayed above the cards\n\t */\n\ttitle: string;\n\t/**\n\t * The card elements to display in the grid\n\t */\n\tcards: React.ReactNode[];\n}\n\n/**\n * CardGrid component for displaying cards in a responsive grid layout.\n *\n * Uses the 24-column grid system with grid-container as root.\n *\n * Layout (Variant A):\n * - Mobile (sm): Single column, py-72\n * - Tablet (md): 2 columns, gap-56 between title and cards, gap-y-20 between cards\n * - Desktop (lg+): 3 columns, py-128, gap-64 between title and cards, gap-y-20 between cards\n *\n * Layout (Variant B):\n * - Mobile (sm): Single column, py-72\n * - Tablet (md): 2 columns, gap-56 between title and cards, gap-y-20 between cards\n * - Desktop (lg+): 2 columns, py-128, gap-64 between title and cards, gap-y-20 between cards\n *\n * @example\n * ```tsx\n * <CardGrid\n * variant=\"A\"\n * title=\"Featured Cards\"\n * cards={[\n * <Card key=\"1\">...</Card>,\n * <Card key=\"2\">...</Card>,\n * ]}\n * />\n * ```\n */\nconst CardGrid = React.forwardRef<HTMLElement, CardGridProps>(\n\t({ className, variant, title, cards, ...props }, ref) => {\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(cardGridVariants({ variant }), className)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Title - col-full within grid */}\n\t\t\t\t<h2\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"col-full\",\n\t\t\t\t\t\t\"typography-headline-small text-gray-900\",\n\t\t\t\t\t\t// Gap after title: mobile default, md: 56px, lg: 64px\n\t\t\t\t\t\t\"mb-spacing-36 md:mb-spacing-56 lg:mb-spacing-64\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{title}\n\t\t\t\t</h2>\n\n\t\t\t\t{/* Inner grid for cards */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"col-full\",\n\t\t\t\t\t\t// Mobile: single column\n\t\t\t\t\t\t\"grid grid-cols-1 gap-spacing-20\",\n\t\t\t\t\t\t// Tablet: 2 columns\n\t\t\t\t\t\t\"md:grid-cols-2\",\n\t\t\t\t\t\t// Desktop: 3 columns for variant A, 2 columns for variant B\n\t\t\t\t\t\tvariant === \"A\" && \"lg:grid-cols-3\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{React.Children.toArray(cards).map((card) => (\n\t\t\t\t\t\t<div key={(card as React.ReactElement).key}>{card}</div>\n\t\t\t\t\t))}\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nCardGrid.displayName = \"CardGrid\";\n\nexport { CardGrid, cardGridVariants };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * TwoColumnSection component for text-heavy content sections\n *\n * Layout:\n * - Desktop (lg+): Title left, content right with border-top divider\n * - Mobile/Tablet: Stacked vertically\n *\n * Uses the 24-column grid system.\n */\nconst twoColumnSectionVariants = cva(\n\t// Base styles - responsive padding\n\t[\n\t\t\"w-full\",\n\t\t// Small (mobile): 20px x, 56px top, 20px bottom\n\t\t\"px-spacing-20 pt-spacing-56 pb-spacing-20\",\n\t\t// Medium (tablet): 56px x, 56px y\n\t\t\"md:px-spacing-56 md:py-spacing-56\",\n\t\t// Large (desktop): 72px x, 72px top, 112px bottom\n\t\t\"lg:px-spacing-72 lg:pt-spacing-72 lg:pb-spacing-112\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\ttheme: {\n\t\t\t\tdark: \"bg-gray-1200\",\n\t\t\t\tlight: \"bg-white\",\n\t\t\t},\n\t\t\tlayout: {\n\t\t\t\t/** Default 24-column grid with asymmetric split (title: 9, content: 15) */\n\t\t\t\tasymmetric: \"\",\n\t\t\t\t/** Equal 2-column layout at md+ breakpoints */\n\t\t\t\tequal: \"\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\ttheme: \"dark\",\n\t\t\tlayout: \"asymmetric\",\n\t\t},\n\t},\n);\n\nexport interface TwoColumnSectionProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof twoColumnSectionVariants> {\n\t/**\n\t * The title text displayed in the left column\n\t */\n\ttitle: string;\n\t/**\n\t * Lead content - prominently styled (brighter text)\n\t * Can be a string or ReactNode for rich content\n\t */\n\tlead?: React.ReactNode;\n\t/**\n\t * Body content - secondary styled (muted text)\n\t * Can be a string or ReactNode for rich content\n\t */\n\tchildren: React.ReactNode;\n\t/**\n\t * Layout style for the columns\n\t * - \"asymmetric\" (default): Uses 24-column grid with ~40/60 split (title: 9, content: 15)\n\t * - \"equal\": Simple 2-column equal-width layout at md+ breakpoints\n\t */\n\tlayout?: \"asymmetric\" | \"equal\";\n}\n\n/**\n * TwoColumnSection component for text-heavy content with title/content split.\n *\n * Layout:\n * - Mobile/Tablet: Stacked (title above content)\n * - Desktop (lg+): Title left (~40%), Content right (~60%)\n *\n * @example\n * ```tsx\n * <TwoColumnSection\n * title=\"US Tech Force\"\n * lead=\"The US Tech Force is recruiting an elite corps of engineers...\"\n * theme=\"dark\"\n * >\n * <p>Through a two-year program, participants will work...</p>\n * <p>Upon completing the program, engineers can seek...</p>\n * </TwoColumnSection>\n * ```\n */\nconst TwoColumnSection = React.forwardRef<HTMLElement, TwoColumnSectionProps>(\n\t({ className, theme, layout, title, lead, children, ...props }, ref) => {\n\t\tconst isDark = theme === \"dark\" || theme === undefined;\n\t\tconst isEqual = layout === \"equal\";\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(twoColumnSectionVariants({ theme, layout }), className)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Inner container with border-top */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"border-t pt-spacing-36\",\n\t\t\t\t\t\tisDark ? \"border-gray-700\" : \"border-gray-300\",\n\t\t\t\t\t\t// Grid layout\n\t\t\t\t\t\t\"grid grid-cols-1 gap-spacing-56\",\n\t\t\t\t\t\tisEqual\n\t\t\t\t\t\t\t? \"md:grid-cols-2\"\n\t\t\t\t\t\t\t: \"lg:grid-cols-24 lg:gap-spacing-56\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{/* Title column */}\n\t\t\t\t\t<h2\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\"typography-subheading-medium\",\n\t\t\t\t\t\t\tisDark ? \"text-gray-100\" : \"text-gray-900\",\n\t\t\t\t\t\t\t// Column span based on layout\n\t\t\t\t\t\t\t!isEqual && \"lg:col-span-9\",\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t{title}\n\t\t\t\t\t</h2>\n\n\t\t\t\t\t{/* Content column */}\n\t\t\t\t\t<div className={cn(\"flex flex-col gap-spacing-56\", !isEqual && \"lg:col-span-15\")}>\n\t\t\t\t\t\t{/* Lead content - brighter/prominent */}\n\t\t\t\t\t\t{lead && (\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\t\"typography-body-large\",\n\t\t\t\t\t\t\t\t\tisDark ? \"text-gray-100\" : \"text-gray-900\",\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{typeof lead === \"string\" ? <p>{lead}</p> : lead}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t)}\n\n\t\t\t\t\t\t{/* Body content - muted */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"typography-body-medium flex flex-col gap-[1em]\",\n\t\t\t\t\t\t\t\tisDark ? \"text-gray-400\" : \"text-gray-600\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{children}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nTwoColumnSection.displayName = \"TwoColumnSection\";\n\nexport { TwoColumnSection, twoColumnSectionVariants };\n","import * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\nimport { TwoColumnSection } from \"../two-column-section\";\nimport type { VariantProps } from \"class-variance-authority\";\nimport { twoColumnSectionVariants } from \"../two-column-section/two-column-section\";\n\nexport interface FaqSectionProps\n\textends Omit<React.HTMLAttributes<HTMLElement>, \"title\">,\n\t\tVariantProps<typeof twoColumnSectionVariants> {\n\t/**\n\t * The title text displayed in the left column\n\t * @default \"Frequently Asked Questions\"\n\t */\n\ttitle?: string;\n\t/**\n\t * The FAQ content - typically an Accordion with AccordionItems\n\t */\n\tchildren: React.ReactNode;\n}\n\n/**\n * FaqSection component for displaying FAQ content in a two-column layout.\n *\n * Wraps TwoColumnSection with FAQ-specific defaults and typography.\n *\n * Layout:\n * - Mobile/Tablet: Stacked (title above content)\n * - Desktop (lg+): Title left (~40%), FAQ content right (~60%)\n *\n * @example\n * ```tsx\n * <FaqSection>\n * <Accordion defaultExpanded=\"faq-1\">\n * <AccordionItem id=\"faq-1\" title=\"What is the US Tech Force?\">\n * Tech Force will be an elite group of technology specialists...\n * </AccordionItem>\n * <AccordionItem id=\"faq-2\" title=\"What skills are required?\">\n * We're looking for expertise in software engineering...\n * </AccordionItem>\n * </Accordion>\n * </FaqSection>\n *\n * // With custom title\n * <FaqSection title=\"Common Questions\" theme=\"light\">\n * ...\n * </FaqSection>\n * ```\n */\nconst FaqSection = React.forwardRef<HTMLElement, FaqSectionProps>(\n\t(\n\t\t{ className, theme = \"dark\", title = \"Frequently Asked Questions\", children, ...props },\n\t\tref,\n\t) => {\n\t\treturn (\n\t\t\t<TwoColumnSection\n\t\t\t\tref={ref}\n\t\t\t\ttheme={theme}\n\t\t\t\ttitle={title}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t// Override title typography to be larger\n\t\t\t\t\t\"[&_h2]:typography-subheading-large\",\n\t\t\t\t\t// Accordion typography overrides\n\t\t\t\t\t\"[&_button]:typography-body-large [&_button]:md:typography-subheading-small\",\n\t\t\t\t\t\"[&_[data-accordion-panel]]:typography-body-medium [&_[data-accordion-panel]]:md:typography-body-large\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</TwoColumnSection>\n\t\t);\n\t},\n);\nFaqSection.displayName = \"FaqSection\";\n\nexport { FaqSection };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * Hero variants based on Figma BaseKit / Heros\n *\n * Variants:\n * - A1: Content aligned at bottom (default)\n * - A2: Content aligned at top\n * - A3: Content aligned at center\n *\n * Each variant is responsive across breakpoints:\n * - sm (Mobile): 500px height, 20px padding\n * - md (Tablet): 650px height, 56px padding\n * - lg (Desktop): 700-850px height, 64-72px padding\n */\nconst heroVariants = cva(\n\t[\n\t\t\"flex w-full bg-gray-1000\",\n\t\t// Mobile (sm)\n\t\t\"h-[500px] p-spacing-20\",\n\t\t// Tablet (md)\n\t\t\"md:h-[650px] md:p-spacing-56\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\t// A1: Content at bottom\n\t\t\t\tA1: [\n\t\t\t\t\t\"items-end\",\n\t\t\t\t\t// Desktop (lg) - 800px height, 72px padding\n\t\t\t\t\t\"xl:h-[800px] xl:p-spacing-72\",\n\t\t\t\t],\n\t\t\t\t// A2: Content at top\n\t\t\t\tA2: [\n\t\t\t\t\t\"items-start\",\n\t\t\t\t\t// Desktop (lg) - 700px height, 64px padding\n\t\t\t\t\t\"xl:h-[700px] xl:p-spacing-64\",\n\t\t\t\t],\n\t\t\t\t// A3: Content centered\n\t\t\t\tA3: [\n\t\t\t\t\t\"items-center\",\n\t\t\t\t\t// Desktop (lg) - 800px height, 64px padding\n\t\t\t\t\t\"xl:h-[800px] xl:p-spacing-64\",\n\t\t\t\t],\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"A1\",\n\t\t},\n\t},\n);\n\nexport interface HeroProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof heroVariants> {\n\t/**\n\t * The title text displayed in the hero\n\t */\n\ttitle: string;\n\t/**\n\t * URL for the background image\n\t */\n\tbackgroundImage?: string;\n\t/**\n\t * URL for a background video (takes precedence over backgroundImage)\n\t */\n\tbackgroundVideo?: string;\n\t/**\n\t * Opacity of the dark overlay (0-1, default: 0)\n\t */\n\toverlayOpacity?: number;\n\t/**\n\t * Color of the overlay (default: \"black\")\n\t */\n\toverlayColor?: string;\n\t/**\n\t * CSS background-position value (default: \"center\")\n\t */\n\tbackgroundPosition?: string;\n}\n\n/**\n * Hero component for page headers with large display typography.\n *\n * Features responsive sizing across three variants:\n * - A1: Content at bottom (default)\n * - A2: Content at top\n * - A3: Content centered\n *\n * Each variant responds to breakpoints:\n * - Mobile: 500px height, 20px padding, 64px typography\n * - Tablet (768px+): 650px height, 56px padding, 128-148px typography\n * - Desktop (1440px+): 700-800px height, 64-72px padding, 148-192px typography\n *\n * @example\n * ```tsx\n * // Simple hero\n * <Hero title=\"Welcome\" variant=\"A1\" />\n *\n * // With background image and overlay\n * <Hero\n * title=\"Welcome\"\n * variant=\"A1\"\n * backgroundImage=\"/hero.jpg\"\n * overlayOpacity={0.4}\n * />\n * ```\n */\nconst Hero = React.forwardRef<HTMLElement, HeroProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\ttitle,\n\t\t\tvariant,\n\t\t\tbackgroundImage,\n\t\t\tbackgroundVideo,\n\t\t\toverlayOpacity = 0,\n\t\t\toverlayColor = \"black\",\n\t\t\tbackgroundPosition = \"center\",\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\tconst hasBackground = backgroundImage || backgroundVideo;\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\theroVariants({ variant }),\n\t\t\t\t\thasBackground && \"relative overflow-hidden\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Background image */}\n\t\t\t\t{backgroundImage && !backgroundVideo && (\n\t\t\t\t\t<div\n\t\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\t\tclassName=\"absolute inset-0 bg-cover\"\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tbackgroundImage: `url(${backgroundImage})`,\n\t\t\t\t\t\t\tbackgroundPosition,\n\t\t\t\t\t\t}}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\n\t\t\t\t{/* Background video */}\n\t\t\t\t{backgroundVideo && (\n\t\t\t\t\t<video\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tloop\n\t\t\t\t\t\tmuted\n\t\t\t\t\t\tplaysInline\n\t\t\t\t\t\tclassName=\"absolute inset-0 h-full w-full object-cover\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={backgroundVideo} />\n\t\t\t\t\t</video>\n\t\t\t\t)}\n\n\t\t\t\t{/* Overlay */}\n\t\t\t\t{hasBackground && overlayOpacity > 0 && (\n\t\t\t\t\t<div\n\t\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\t\tclassName=\"absolute inset-0\"\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tbackgroundColor: overlayColor,\n\t\t\t\t\t\t\topacity: overlayOpacity,\n\t\t\t\t\t\t}}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\n\t\t\t\t{/* Content */}\n\t\t\t\t<h1\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"typography-display-large text-gray-50\",\n\t\t\t\t\t\thasBackground && \"relative z-10\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{title}\n\t\t\t\t</h1>\n\t\t\t</section>\n\t\t);\n\t},\n);\nHero.displayName = \"Hero\";\n\nexport { Hero, heroVariants };\n","import * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\nexport interface ProseProps extends React.HTMLAttributes<HTMLDivElement> {\n\tchildren: React.ReactNode;\n}\n\n/**\n * Prose container for long-form content with proper typography and spacing.\n *\n * Provides responsive spacing between content blocks:\n * - Desktop (1440px+): 96px gap\n * - Tablet (768px+): 72px gap\n * - Mobile: 56px gap\n *\n * Use with ProseSection components for proper content structure.\n */\nconst Prose = React.forwardRef<HTMLDivElement, ProseProps>(\n\t({ className, children, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex w-full max-w-[700px] flex-col overflow-hidden\",\n\t\t\t\t\t// Responsive gap between sections\n\t\t\t\t\t\"gap-spacing-56 md:gap-spacing-72 xl:gap-spacing-96\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</div>\n\t\t);\n\t},\n);\nProse.displayName = \"Prose\";\n\nexport interface ProseSectionProps extends React.HTMLAttributes<HTMLElement> {\n\t/**\n\t * The heading text for this section\n\t */\n\theading: string;\n\t/**\n\t * The heading level to render (h2 or h3)\n\t * @default \"h2\"\n\t */\n\tas?: \"h2\" | \"h3\";\n\tchildren: React.ReactNode;\n}\n\n/**\n * A section within Prose content, containing a heading and body text.\n *\n * Responsive typography:\n * - h2: Uses typography-headline-medium (42px mobile → 56px tablet → 72px desktop)\n * - h3: Uses typography-headline-small (32px mobile → 42px tablet → 56px desktop)\n * - Body: Uses typography-body-medium (16px mobile/tablet → 18px desktop)\n */\nconst ProseSection = React.forwardRef<HTMLElement, ProseSectionProps>(\n\t({ className, heading, as = \"h2\", children, ...props }, ref) => {\n\t\tconst Heading = as;\n\t\tconst headingClass =\n\t\t\tas === \"h2\" ? \"typography-headline-medium\" : \"typography-headline-small\";\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex w-full flex-col\",\n\t\t\t\t\t// Responsive gap between heading and body\n\t\t\t\t\t\"gap-spacing-24 md:gap-spacing-40\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t<Heading className={cn(headingClass, \"text-gray-900\")}>\n\t\t\t\t\t{heading}\n\t\t\t\t</Heading>\n\t\t\t\t<div className=\"typography-body-medium flex flex-col gap-[1em] text-gray-800 break-words\">\n\t\t\t\t\t{children}\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nProseSection.displayName = \"ProseSection\";\n\nexport { Prose, ProseSection };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * River component for content sections with text and media\n *\n * Variants:\n * - A: Text on left (9 cols), media on right (15 cols) on desktop\n * - B: Media on left (15 cols), text on right (9 cols) on desktop\n *\n * Uses the 24-column grid system. Must be placed inside a `grid-container`.\n */\nconst riverVariants = cva(\n\t// Base styles - col-full within parent grid, responsive padding\n\t[\n\t\t\"col-full\",\n\t\t// Small (mobile): 20px x, 72px top, 20px bottom\n\t\t\"px-spacing-20 pt-spacing-72 pb-spacing-20\",\n\t\t// Medium (tablet): 56px x, 96px y\n\t\t\"md:px-spacing-56 md:py-spacing-96\",\n\t\t// Large (desktop): 72px x, 128px y\n\t\t\"lg:px-spacing-72 lg:py-spacing-128\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\tA: \"\",\n\t\t\t\tB: \"\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"A\",\n\t\t},\n\t},\n);\n\nexport interface RiverProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof riverVariants> {\n\t/**\n\t * The headline text\n\t */\n\theadline: string;\n\t/**\n\t * The body text\n\t */\n\tbody: string;\n\t/**\n\t * Primary action button (required)\n\t */\n\tprimaryAction: React.ReactNode;\n\t/**\n\t * Secondary action button (optional)\n\t */\n\tsecondaryAction?: React.ReactNode;\n\t/**\n\t * Media content (image, video, etc.)\n\t */\n\tmedia: React.ReactNode;\n}\n\n/**\n * River component for content sections with text and media.\n *\n * Uses the 24-column grid system - must be placed inside a `grid-container`.\n *\n * Layout:\n * - Mobile/Tablet: Stacked (text above media)\n * - Desktop (lg+):\n * - Variant A: Text (9 cols) | Media (15 cols)\n * - Variant B: Media (15 cols) | Text (9 cols)\n *\n * @example\n * ```tsx\n * <div className=\"grid-container\">\n * <River\n * variant=\"A\"\n * headline=\"Feature Headline\"\n * body=\"Description of the feature...\"\n * primaryAction={<Button>Primary</Button>}\n * secondaryAction={<Button variant=\"charcoalOutline\">Secondary</Button>}\n * media={<img src=\"...\" alt=\"Feature\" />}\n * />\n * </div>\n * ```\n */\nconst River = React.forwardRef<HTMLElement, RiverProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\tvariant,\n\t\t\theadline,\n\t\t\tbody,\n\t\t\tprimaryAction,\n\t\t\tsecondaryAction,\n\t\t\tmedia,\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\tconst contentColumn = (\n\t\t\t<div\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex flex-col\",\n\t\t\t\t\t// Full width on mobile/tablet, 9 cols on desktop\n\t\t\t\t\t\"lg:col-span-9\",\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t{/* Text content with 16px gap */}\n\t\t\t\t<div className=\"flex flex-col gap-spacing-16\">\n\t\t\t\t\t<h2 className=\"typography-headline-small text-gray-900\">\n\t\t\t\t\t\t{headline}\n\t\t\t\t\t</h2>\n\t\t\t\t\t<p className=\"typography-body-small text-gray-800\">{body}</p>\n\t\t\t\t</div>\n\n\t\t\t\t{/* Buttons with 36px gap from text, responsive sizes */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"flex flex-row gap-spacing-16 mt-spacing-36\",\n\t\t\t\t\t\t\"[&>*]:flex-shrink-0\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{primaryAction}\n\t\t\t\t\t{secondaryAction}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\n\t\tconst mediaColumn = (\n\t\t\t<div\n\t\t\t\tclassName={cn(\n\t\t\t\t\t// Full width on mobile/tablet, 15 cols on desktop\n\t\t\t\t\t\"lg:col-span-15\",\n\t\t\t\t\t// Ensure media fills the container\n\t\t\t\t\t\"[&>*]:w-full [&>*]:h-auto\",\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t{media}\n\t\t\t</div>\n\t\t);\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(riverVariants({ variant }), className)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Inner grid container for 24-col layout */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"grid grid-cols-1 gap-spacing-36\",\n\t\t\t\t\t\t\"lg:grid-cols-24 lg:gap-spacing-36\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{variant === \"B\" ? (\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t{mediaColumn}\n\t\t\t\t\t\t\t{contentColumn}\n\t\t\t\t\t\t</>\n\t\t\t\t\t) : (\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t{contentColumn}\n\t\t\t\t\t\t\t{mediaColumn}\n\t\t\t\t\t\t</>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nRiver.displayName = \"River\";\n\nexport { River, riverVariants };\n","import * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * Tout component based on Figma BaseKit / Touts\n *\n * A full-bleed section with a background image and overlaid content.\n * Content can be positioned on the left side or centered.\n *\n * Responsive behavior:\n * - Mobile (sm): 600px height, 4 columns with gap-20, content spans all 4 cols\n * - Tablet (md): 750px height, 12 columns with gap-20, content spans 9 cols (left) or centered\n * - Desktop (lg): 900px height, 24 columns with gap-20, content spans 9 cols (left) or centered\n *\n * This component is self-contained - do NOT wrap in a grid-container.\n */\nexport interface ToutProps extends React.HTMLAttributes<HTMLElement> {\n\t/**\n\t * The headline displayed in the tout\n\t */\n\theadline: React.ReactNode;\n\t/**\n\t * The body text displayed below the headline (optional)\n\t */\n\tbody?: string;\n\t/**\n\t * Primary action button (required)\n\t */\n\tprimaryAction: React.ReactNode;\n\t/**\n\t * Secondary action button (optional)\n\t */\n\tsecondaryAction?: React.ReactNode;\n\t/**\n\t * Background media (image or video element)\n\t * Should be a full-bleed element that covers the entire section\n\t */\n\tbackgroundMedia: React.ReactNode;\n\t/**\n\t * Content alignment: left (default) or center\n\t */\n\talign?: \"left\" | \"center\";\n\t/**\n\t * Show National Design Studio footer link at the bottom of the section\n\t */\n\tndstudioFooter?: boolean;\n}\n\n/**\n * Tout component for hero-like sections with background media and overlaid content.\n *\n * This component is self-contained with its own grid.\n * Grid setup:\n * - Desktop (lg): 24 columns, gap-spacing-20, content spans 9 cols\n * - Tablet (md): 12 columns, gap-spacing-20, content spans 9 cols\n * - Mobile: 4 columns, gap-spacing-20, content spans all 4 cols\n *\n * @example\n * ```tsx\n * <Tout\n * headline=\"Feature Headline\"\n * body=\"Description of the feature...\"\n * primaryAction={<Button>Primary</Button>}\n * secondaryAction={<Button variant=\"charcoalOutline\">Secondary</Button>}\n * backgroundMedia={\n * <img\n * src=\"/background.jpg\"\n * alt=\"\"\n * className=\"absolute inset-0 w-full h-full object-cover\"\n * />\n * }\n * />\n * ```\n */\nconst Tout = React.forwardRef<HTMLElement, ToutProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\theadline,\n\t\t\tbody,\n\t\t\tprimaryAction,\n\t\t\tsecondaryAction,\n\t\t\tbackgroundMedia,\n\t\t\talign = \"left\",\n\t\t\tndstudioFooter,\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\tconst isCentered = align === \"center\";\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t// Full width\n\t\t\t\t\t\"w-full\",\n\t\t\t\t\t// Positioning context for background\n\t\t\t\t\t\"relative overflow-hidden\",\n\t\t\t\t\t// Responsive height: 600px mobile, 750px tablet, 900px desktop\n\t\t\t\t\t\"h-[600px] md:h-[750px] lg:h-[900px]\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Background layer - full bleed */}\n\t\t\t\t<div\n\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\tclassName=\"absolute inset-0 pointer-events-none\"\n\t\t\t\t>\n\t\t\t\t\t{/* Fallback background color */}\n\t\t\t\t\t<div className=\"absolute inset-0 bg-gray-500\" />\n\t\t\t\t\t{/* Background media */}\n\t\t\t\t\t{backgroundMedia}\n\t\t\t\t</div>\n\n\t\t\t\t{/* Inner grid for content alignment */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t// Position above background\n\t\t\t\t\t\t\"relative z-10\",\n\t\t\t\t\t\t// Grid setup with responsive columns\n\t\t\t\t\t\t\"grid w-full h-full\",\n\t\t\t\t\t\t// Mobile: 4 columns with gap-20\n\t\t\t\t\t\t\"grid-cols-4 gap-spacing-20\",\n\t\t\t\t\t\t// Tablet (md): 12 columns\n\t\t\t\t\t\t\"md:grid-cols-12\",\n\t\t\t\t\t\t// Desktop (lg): 24 columns\n\t\t\t\t\t\t\"lg:grid-cols-24\",\n\t\t\t\t\t\t// Max width and centering like grid-container\n\t\t\t\t\t\t\"max-w-[var(--breakpoint-lg)] mx-auto\",\n\t\t\t\t\t\t// Responsive margins matching grid-container\n\t\t\t\t\t\t\"px-spacing-20 md:px-spacing-56 lg:px-spacing-72\",\n\t\t\t\t\t\t// Vertical padding to position content at bottom\n\t\t\t\t\t\t\"py-spacing-36 md:py-spacing-56 lg:py-spacing-72\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{/* Content column - aligned to grid */}\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t// Flex container for content\n\t\t\t\t\t\t\t\"flex flex-col\",\n\t\t\t\t\t\t\tisCentered ? \"justify-start items-center\" : \"justify-end\",\n\t\t\t\t\t\t\t// Responsive gap between text and buttons\n\t\t\t\t\t\t\t\"gap-spacing-28 md:gap-spacing-36\",\n\t\t\t\t\t\t\t// Mobile: all 4 cols\n\t\t\t\t\t\t\t\"col-span-4\",\n\t\t\t\t\t\t\t// Tablet & Desktop: 9 cols left-aligned, full width centered\n\t\t\t\t\t\t\tisCentered ? \"md:col-span-12 lg:col-span-24\" : \"md:col-span-9\",\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Text content stack */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"flex flex-col gap-spacing-16\",\n\t\t\t\t\t\t\t\tisCentered && \"items-center text-center\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<h2 className=\"typography-headline-small text-gray-900\">\n\t\t\t\t\t\t\t\t{headline}\n\t\t\t\t\t\t\t</h2>\n\t\t\t\t\t\t\t{body && (\n\t\t\t\t\t\t\t\t<p className=\"typography-body-small text-gray-800\">{body}</p>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* CTA buttons */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"flex flex-row\",\n\t\t\t\t\t\t\t\tisCentered ? \"justify-center\" : \"items-start\",\n\t\t\t\t\t\t\t\t// Responsive gap between buttons\n\t\t\t\t\t\t\t\t\"gap-spacing-8 md:gap-spacing-12\",\n\t\t\t\t\t\t\t\t\"[&>*]:flex-shrink-0\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{primaryAction}\n\t\t\t\t\t\t\t{secondaryAction}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\n\t\t\t\t{/* National Design Studio footer */}\n\t\t\t\t{ndstudioFooter && (\n\t\t\t\t\t<div className=\"absolute bottom-6 md:bottom-8 left-0 right-0 z-10 text-center\">\n\t\t\t\t\t\t<p className=\"typography-label-large uppercase text-ivory-alpha-75\">\n\t\t\t\t\t\t\tDesigned and Engineered in DC by{\" \"}\n\t\t\t\t\t\t\t<a\n\t\t\t\t\t\t\t\thref=\"https://ndstudio.gov\"\n\t\t\t\t\t\t\t\ttarget=\"_blank\"\n\t\t\t\t\t\t\t\trel=\"noopener noreferrer\"\n\t\t\t\t\t\t\t\tclassName=\"hover:underline\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tNational Design Studio\n\t\t\t\t\t\t\t</a>\n\t\t\t\t\t\t</p>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</section>\n\t\t);\n\t},\n);\nTout.displayName = \"Tout\";\n\nexport { Tout };\n"],"names":["useControlled","controlled","defaultProp","name","state","isControlled","React","valueState","setValue","value","defaultValue","setValueIfUncontrolled","newValue","UNINITIALIZED","useRefWithInit","init","initArg","ref","useInsertionEffect","useSafeInsertionEffect","fn","useStableCallback","callback","stable","createStableCallback","assertNotCalled","args","noop","useIsoLayoutEffect","set","warn","messages","messageKey","CompositeListContext","useCompositeListContext","CompositeList","props","children","elementsRef","labelsRef","onMapChangeProp","onMapChange","nextIndexRef","listeners","createListeners","map","createMap","mapTick","setMapTick","lastTickRef","register","node","metadata","unregister","sortedMap","newMap","sortByDocumentPosition","index","mutationObserver","entries","diff","updateDiff","entry","_","subscribeMapChange","l","contextValue","_jsx","a","b","position","DirectionContext","useDirection","formatErrorMessage","code","url","arg","AccordionRootContext","useAccordionRootContext","context","_formatErrorMessage","useMergedRefs","c","d","forkRef","createForkRef","didChange","update","useMergedRefsN","refs","didChangeN","newRefs","instance","cleanupCallbacks","i","refCleanup","cleanupCallback","majorVersion","isReactVersionAtLeast","reactVersionToCheck","getReactElementRef","element","reactElement","propsWithRef","mergeObjects","getStateAttributesProps","customMapping","key","customProps","resolveClassName","className","resolveStyle","style","EMPTY_PROPS","mergeProps","e","merged","resolvePropsGetter","mergeOne","mergePropsN","inputProps","isPropsGetter","mutablyMergeInto","mergedProps","externalProps","propName","externalPropValue","mergeClassNames","isEventHandler","mergeEventHandlers","code0","code1","code2","previousProps","ourHandler","theirHandler","event","isSyntheticEvent","baseUIEvent","makeEventPreventable","result","ourClassName","theirClassName","EMPTY_OBJECT","useRenderElement","componentProps","params","renderProp","outProps","useRenderElementProps","evaluateRenderProp","classNameProp","styleProp","stateAttributesMapping","enabled","stateProps","render","renderTag","Tag","_createElement","none","triggerPress","createChangeEventDetails","reason","trigger","customProperties","canceled","allowPropagation","custom","rootStateAttributesMapping","AccordionRoot","forwardedRef","disabled","hiddenUntilFoundProp","keepMountedProp","loopFocus","onValueChangeProp","multiple","orientation","valueProp","defaultValueProp","elementProps","direction","onValueChange","accordionItemRefs","handleValueChange","nextOpen","details","REASONS.none","nextOpenValues","v","nextValue","SafeReact","globalId","useGlobalId","idOverride","prefix","defaultId","setDefaultId","id","maybeReactUseId","useId","reactId","useBaseUiId","EMPTY","useOnMount","LAST_RAF","Scheduler","timestamp","currentCallbacks","currentCallbacksCount","didRAFChange","scheduler","AnimationFrame","useAnimationFrame","timeout","resolveRef","maybeRef","useAnimationsFinished","elementOrRef","waitForNextTick","treatAbortedAsFinished","frame","fnToExecute","signal","exec","anim","ReactDOM","useTransitionStatus","open","enableIdleState","deferEndingState","transitionStatus","setTransitionStatus","mounted","setMounted","useCollapsibleRoot","parameters","openParam","defaultOpen","onOpenChange","setOpen","visible","setVisible","height","width","setDimensions","defaultPanelId","panelIdState","setPanelIdState","panelId","hiddenUntilFound","setHiddenUntilFound","keepMounted","setKeepMounted","abortControllerRef","animationTypeRef","transitionDimensionRef","panelRef","runOnceAnimationsFinish","handleTrigger","eventDetails","REASONS.triggerPress","panel","CollapsibleRootContext","useCollapsibleRootContext","IndexGuessBehavior","useCompositeListItem","label","textRef","indexGuessBehavior","externalIndex","indexRef","setIndex","newIndex","componentRef","isLabelDefined","AccordionItemContext","useAccordionItemContext","TransitionStatusDataAttributes","STARTING_HOOK","ENDING_HOOK","transitionStatusMapping","CollapsiblePanelDataAttributes","CollapsibleTriggerDataAttributes","PANEL_OPEN_HOOK","PANEL_CLOSED_HOOK","triggerOpenStateMapping","collapsibleOpenStateMapping","AccordionItemDataAttributes","accordionStateAttributesMapping","baseMapping","AccordionItem","disabledProp","onOpenChangeProp","listItemRef","mergedRef","contextDisabled","rootState","openValues","fallbackValue","isOpen","collapsible","collapsibleState","collapsibleContext","triggerId","setTriggerId","accordionItemContext","AccordionHeader","isElementDisabled","hasWindow","getWindow","_node$ownerDocument","isHTMLElement","error","CompositeRootContext","useCompositeRootContext","optional","useFocusableWhenDisabled","focusableWhenDisabled","composite","tabIndexProp","isNativeButton","isFocusableComposite","isNonFocusableComposite","additionalProps","useButton","tabIndex","elementRef","isCompositeItem","isValidLink","focusableWhenDisabledProps","isButtonTag","updateDisabled","isButtonElement","getButtonProps","externalOnClick","externalOnMouseDown","externalOnKeyUp","externalOnKeyDown","externalOnPointerDown","otherExternalProps","shouldClick","isEnterKey","isSpaceKey","buttonRef","elem","stopEvent","ARROW_UP","ARROW_DOWN","ARROW_LEFT","ARROW_RIGHT","HOME","END","HORIZONTAL_KEYS","VERTICAL_KEYS","ARROW_KEYS","SUPPORTED_KEYS","getActiveTriggers","accordionItemElements","output","section","AccordionTrigger","idProp","nativeButton","isRtl","isHorizontal","triggers","lastIndex","nextIndex","thisIndex","toNext","toPrev","AccordionRootDataAttributes","useCollapsiblePanel","externalRef","idParam","isBeforeMatchRef","latestAnimationNameRef","shouldCancelInitialOpenAnimationRef","shouldCancelInitialOpenTransitionRef","endingStyleFrame","hidden","handlePanelRef","panelStyles","hasAnimation","hasTransition","nextFrame","mergedPanelRef","resizeFrame","originalLayoutStyles","abortController","attributeObserver","endingStyleAttribute","mutationList","mutation","handleBeforeMatch","AccordionPanelCssVars","useValueAsRef","latest","createLatestRef","useOpenChangeComplete","onCompleteParam","openRef","onComplete","AccordionPanel","contextHiddenUntilFound","contextKeepMounted","panelState","r","f","n","clsx","concatArrays","array1","array2","combinedArray","createClassValidatorObject","classGroupId","validator","createClassPartObject","nextPart","validators","CLASS_PART_SEPARATOR","EMPTY_CONFLICTS","ARBITRARY_PROPERTY_PREFIX","createClassGroupUtils","config","classMap","createClassMap","conflictingClassGroups","conflictingClassGroupModifiers","getGroupIdForArbitraryProperty","classParts","startIndex","getGroupRecursive","hasPostfixModifier","modifierConflicts","baseConflicts","classPartObject","currentClassPart","nextClassPartObject","classRest","validatorsLength","validatorObj","content","colonIndex","property","theme","classGroups","processClassGroups","group","processClassesRecursively","classGroup","len","classDefinition","processClassDefinition","processStringDefinition","processFunctionDefinition","processObjectDefinition","classPartObjectToEdit","getPart","isThemeGetter","path","current","parts","part","next","func","createLruCache","maxCacheSize","cacheSize","cache","previousCache","IMPORTANT_MODIFIER","MODIFIER_SEPARATOR","EMPTY_MODIFIERS","createResultObject","modifiers","hasImportantModifier","baseClassName","maybePostfixModifierPosition","isExternal","createParseClassName","experimentalParseClassName","parseClassName","bracketDepth","parenDepth","modifierStart","postfixModifierPosition","currentCharacter","baseClassNameWithImportantModifier","fullPrefix","parseClassNameOriginal","createSortModifiers","modifierWeights","mod","currentSegment","modifier","isArbitrary","isOrderSensitive","createConfigUtils","SPLIT_CLASSES_REGEX","mergeClassList","classList","configUtils","getClassGroupId","getConflictingClassGroupIds","sortModifiers","classGroupsInConflict","classNames","originalClassName","variantModifier","modifierId","classId","conflictGroups","twJoin","classLists","argument","resolvedValue","string","toValue","mix","k","createTailwindMerge","createConfigFirst","createConfigRest","cacheGet","cacheSet","functionToCall","initTailwindMerge","previousConfig","createConfigCurrent","tailwindMerge","cachedResult","fallbackThemeArr","fromTheme","themeGetter","arbitraryValueRegex","arbitraryVariableRegex","fractionRegex","tshirtUnitRegex","lengthUnitRegex","colorFunctionRegex","shadowRegex","imageRegex","isFraction","isNumber","isInteger","isPercent","isTshirtSize","isAny","isLengthOnly","isNever","isShadow","isImage","isAnyNonArbitrary","isArbitraryValue","isArbitraryVariable","isArbitrarySize","getIsArbitraryValue","isLabelSize","isArbitraryLength","isLabelLength","isArbitraryNumber","isLabelNumber","isArbitraryPosition","isLabelPosition","isArbitraryImage","isLabelImage","isArbitraryShadow","isLabelShadow","isArbitraryVariableLength","getIsArbitraryVariable","isArbitraryVariableFamilyName","isLabelFamilyName","isArbitraryVariablePosition","isArbitraryVariableSize","isArbitraryVariableImage","isArbitraryVariableShadow","testLabel","testValue","shouldMatchNoLabel","getDefaultConfig","themeColor","themeFont","themeText","themeFontWeight","themeTracking","themeLeading","themeBreakpoint","themeContainer","themeSpacing","themeRadius","themeShadow","themeInsetShadow","themeTextShadow","themeDropShadow","themeBlur","themePerspective","themeAspect","themeEase","themeAnimate","scaleBreak","scalePosition","scalePositionWithArbitrary","scaleOverflow","scaleOverscroll","scaleUnambiguousSpacing","scaleInset","scaleGridTemplateColsRows","scaleGridColRowStartAndEnd","scaleGridColRowStartOrEnd","scaleGridAutoColsRows","scaleAlignPrimaryAxis","scaleAlignSecondaryAxis","scaleMargin","scaleSizing","scaleColor","scaleBgPosition","scaleBgRepeat","scaleBgSize","scaleGradientStopPosition","scaleRadius","scaleBorderWidth","scaleLineStyle","scaleBlendMode","scaleMaskImagePosition","scaleBlur","scaleRotate","scaleScale","scaleSkew","scaleTranslate","twMerge","cn","inputs","Accordion","allowMultiple","defaultExpanded","jsx","BaseAccordion.Root","title","jsxs","BaseAccordion.Item","BaseAccordion.Header","BaseAccordion.Trigger","BaseAccordion.Panel","Button","falsyToString","cx","cva","base","_config_compoundVariants","variants","defaultVariants","getVariantClassNames","variant","variantProp","defaultVariantProp","variantKey","propsWithoutUndefined","acc","param","getCompoundVariantClassNames","cvClass","cvClassName","compoundVariantOptions","buttonVariants","size","BaseButton","setRef","composeRefs","hasCleanup","cleanups","cleanup","REACT_LAZY_TYPE","use","isPromiseLike","isLazyComponent","createSlot","ownerName","SlotClone","createSlotClone","Slot2","slotProps","childrenArray","slottable","isSlottable","newElement","newChildren","child","Slot","childrenRef","getElementRef","props2","SLOTTABLE_IDENTIFIER","childProps","overrideProps","slotPropValue","childPropValue","getter","mayWarn","iconButtonVariants","IconButton","asChild","pagerControlVariants","dotBaseVariants","PagerControl","count","controlledIndex","duration","autoPlay","onChange","pauseOnHover","loop","internalIndex","setInternalIndex","isPaused","setIsPaused","progress","setProgress","activeIndex","animationFrameRef","startTimeRef","pausedProgressRef","goToNext","goToIndex","animate","elapsed","newProgress","handleMouseEnter","handleMouseLeave","getDotWidth","isActive","getInactiveClasses","getActiveTrackClass","getProgressFillClass","cardVariants","Card","layout","CardImage","src","alt","CardContent","CardEyebrow","CardTitle","Component","CardDescription","CardBody","CardActions","NavbarContext","Navbar","isMobileMenuOpen","setIsMobileMenuOpen","navRef","updateHeight","NavbarBrand","NavbarLinks","NavbarLink","active","NavbarActions","NavbarMobileMenu","menuRef","handleClickOutside","target","timeoutId","handleEscape","NavbarMobileMenuButton","handleClick","NavbarMobileMenuLink","onClick","Comp","USGovBanner","flagIcon","text","DefaultUSFlag","bannerVariants","Banner","heading","description","action","isDark","cardGridVariants","CardGrid","cards","card","twoColumnSectionVariants","TwoColumnSection","lead","isEqual","FaqSection","heroVariants","Hero","backgroundImage","backgroundVideo","overlayOpacity","overlayColor","backgroundPosition","hasBackground","Prose","ProseSection","as","Heading","headingClass","riverVariants","River","headline","body","primaryAction","secondaryAction","media","contentColumn","mediaColumn","Fragment","Tout","backgroundMedia","align","ndstudioFooter","isCentered"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,62,63,65,66]}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useControlled.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useRefWithInit.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useStableCallback.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useIsoLayoutEffect.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/warn.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/list/CompositeListContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/list/CompositeList.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/direction-provider/DirectionContext.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/formatErrorMessage.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/root/AccordionRootContext.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useMergedRefs.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/reactVersion.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/getReactElementRef.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/mergeObjects.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/getStateAttributesProps.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/resolveClassName.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/resolveStyle.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/merge-props/mergeProps.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/empty.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/constants.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useRenderElement.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/reason-parts.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/createBaseUIEventDetails.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/root/AccordionRoot.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/safeReact.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useId.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useBaseUiId.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useOnMount.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useAnimationFrame.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/resolveRef.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useAnimationsFinished.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useTransitionStatus.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/root/useCollapsibleRoot.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/root/CollapsibleRootContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/list/useCompositeListItem.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/item/AccordionItemContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/stateAttributesMapping.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/panel/CollapsiblePanelDataAttributes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/trigger/CollapsibleTriggerDataAttributes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/collapsibleOpenStateMapping.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/item/AccordionItemDataAttributes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/item/stateAttributesMapping.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/item/AccordionItem.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/header/AccordionHeader.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/isElementDisabled.js","../../../node_modules/.bun/@floating-ui+utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/error.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/root/CompositeRootContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useFocusableWhenDisabled.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/use-button/useButton.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/detectBrowser.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/constants.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/element.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/nodes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/event.js","../../../node_modules/.bun/tabbable@6.3.0/node_modules/tabbable/dist/index.esm.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/tabbable.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/composite/composite.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/trigger/AccordionTrigger.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/root/AccordionRootDataAttributes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/collapsible/panel/useCollapsiblePanel.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/panel/AccordionPanelCssVars.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useValueAsRef.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useOpenChangeComplete.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/accordion/panel/AccordionPanel.js","../../../node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.mjs","../../../node_modules/.bun/tailwind-merge@3.4.0/node_modules/tailwind-merge/dist/bundle-mjs.mjs","../src/lib/utils.ts","../src/components/atoms/accordion/accordion.tsx","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/button/Button.js","../../../node_modules/.bun/class-variance-authority@0.7.1/node_modules/class-variance-authority/dist/index.mjs","../src/components/atoms/button/button.tsx","../../../node_modules/.bun/@radix-ui+react-compose-refs@1.1.2+e2cc400bcbee7045/node_modules/@radix-ui/react-compose-refs/dist/index.mjs","../../../node_modules/.bun/@radix-ui+react-slot@1.2.4+e2cc400bcbee7045/node_modules/@radix-ui/react-slot/dist/index.mjs","../src/components/atoms/button/icon-button.tsx","../src/components/atoms/pager-control/pager-control.tsx","../src/components/organisms/card/card.tsx","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/root/DialogRootContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/popupStateMapping.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useTimeout.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/createEventEmitter.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/components/FloatingTree.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/createAttribute.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/visuallyHidden.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/owner.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/FocusGuard.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/enqueueFocus.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/markOthers.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/components/FloatingPortal.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/components/FloatingFocusManager.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/hooks/useDismiss.js","../../../node_modules/.bun/reselect@5.1.1/node_modules/reselect/dist/reselect.mjs","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/store/createSelector.js","../../../node_modules/.bun/use-sync-external-store@1.6.0+6ccf2a00d98a8a5e/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.js","../../../node_modules/.bun/use-sync-external-store@1.6.0+6ccf2a00d98a8a5e/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js","../../../node_modules/.bun/use-sync-external-store@1.6.0+6ccf2a00d98a8a5e/node_modules/use-sync-external-store/shim/index.js","../../../node_modules/.bun/use-sync-external-store@1.6.0+6ccf2a00d98a8a5e/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.js","../../../node_modules/.bun/use-sync-external-store@1.6.0+6ccf2a00d98a8a5e/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.development.js","../../../node_modules/.bun/use-sync-external-store@1.6.0+6ccf2a00d98a8a5e/node_modules/use-sync-external-store/shim/with-selector.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/store/useStore.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/store/Store.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/store/ReactStore.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/components/FloatingRootStore.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/popups/popupStoreUtils.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/popups/popupTriggerMap.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/utils/getEmptyRootContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/popups/store.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/hooks/useSyncedFloatingRootContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/hooks/useInteractions.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/floating-ui-react/hooks/useRole.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/popup/DialogPopupCssVars.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/popup/DialogPopupDataAttributes.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/portal/DialogPortalContext.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/popup/DialogPopup.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/inertValue.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/InternalBackdrop.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/portal/DialogPortal.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useScrollLock.js","../../../node_modules/.bun/@base-ui-components+utils@0.2.2+14ce1350b375dddf/node_modules/@base-ui-components/utils/esm/useEnhancedClickHandler.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/utils/useOpenInteractionType.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/root/useDialogRoot.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/store/DialogStore.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/root/DialogRoot.js","../../../node_modules/.bun/@base-ui-components+react@1.0.0-rc.0+14ce1350b375dddf/node_modules/@base-ui-components/react/esm/dialog/title/DialogTitle.js","../src/components/organisms/navbar/navbar.tsx","../src/components/organisms/us-gov-banner/us-gov-banner.tsx","../src/components/sections/banner/banner.tsx","../src/components/sections/card-grid/card-grid.tsx","../src/components/sections/two-column-section/two-column-section.tsx","../src/components/sections/faq-section/faq-section.tsx","../src/components/sections/hero/hero.tsx","../src/components/sections/prose/prose.tsx","../src/components/sections/river/river.tsx","../src/components/sections/tout/tout.tsx"],"sourcesContent":["'use client';\n\n// TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler -- process.env never changes, dependency arrays are intentionally ignored\n/* eslint-disable react-hooks/rules-of-hooks, react-hooks/exhaustive-deps */\nimport * as React from 'react';\nexport function useControlled({\n controlled,\n default: defaultProp,\n name,\n state = 'value'\n}) {\n // isControlled is ignored in the hook dependency lists as it should never change.\n const {\n current: isControlled\n } = React.useRef(controlled !== undefined);\n const [valueState, setValue] = React.useState(defaultProp);\n const value = isControlled ? controlled : valueState;\n if (process.env.NODE_ENV !== 'production') {\n React.useEffect(() => {\n if (isControlled !== (controlled !== undefined)) {\n console.error([`Base UI: A component is changing the ${isControlled ? '' : 'un'}controlled ${state} state of ${name} to be ${isControlled ? 'un' : ''}controlled.`, 'Elements should not switch from uncontrolled to controlled (or vice versa).', `Decide between using a controlled or uncontrolled ${name} ` + 'element for the lifetime of the component.', \"The nature of the state is determined during the first render. It's considered controlled if the value is not `undefined`.\", 'More info: https://fb.me/react-controlled-components'].join('\\n'));\n }\n }, [state, name, controlled]);\n const {\n current: defaultValue\n } = React.useRef(defaultProp);\n React.useEffect(() => {\n // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is for more details.\n if (!isControlled && JSON.stringify(defaultValue) !== JSON.stringify(defaultProp)) {\n console.error([`Base UI: A component is changing the default ${state} state of an uncontrolled ${name} after being initialized. ` + `To suppress this warning opt to use a controlled ${name}.`].join('\\n'));\n }\n }, [JSON.stringify(defaultProp)]);\n }\n const setValueIfUncontrolled = React.useCallback(newValue => {\n if (!isControlled) {\n setValue(newValue);\n }\n }, []);\n return [value, setValueIfUncontrolled];\n}","'use client';\n\nimport * as React from 'react';\nconst UNINITIALIZED = {};\n\n/**\n * A React.useRef() that is initialized with a function. Note that it accepts an optional\n * initialization argument, so the initialization function doesn't need to be an inline closure.\n *\n * @usage\n * const ref = useRefWithInit(sortColumns, columns)\n */\n\nexport function useRefWithInit(init, initArg) {\n const ref = React.useRef(UNINITIALIZED);\n if (ref.current === UNINITIALIZED) {\n ref.current = init(initArg);\n }\n return ref;\n}","'use client';\n\nimport * as React from 'react';\nimport { useRefWithInit } from \"./useRefWithInit.js\";\n\n// https://github.com/mui/material-ui/issues/41190#issuecomment-2040873379\nconst useInsertionEffect = React[`useInsertionEffect${Math.random().toFixed(1)}`.slice(0, -3)];\nconst useSafeInsertionEffect =\n// React 17 doesn't have useInsertionEffect.\nuseInsertionEffect &&\n// Preact replaces useInsertionEffect with useLayoutEffect and fires too late.\nuseInsertionEffect !== React.useLayoutEffect ? useInsertionEffect : fn => fn();\n/**\n * Stabilizes the function passed so it's always the same between renders.\n *\n * The function becomes non-reactive to any values it captures.\n * It can safely be passed as a dependency of `React.useMemo` and `React.useEffect` without re-triggering them if its captured values change.\n *\n * The function must only be called inside effects and event handlers, never during render (which throws an error).\n *\n * This hook is a more permissive version of React 19.2's `React.useEffectEvent` in that it can be passed through contexts and called in event handler props, not just effects.\n */\nexport function useStableCallback(callback) {\n const stable = useRefWithInit(createStableCallback).current;\n stable.next = callback;\n useSafeInsertionEffect(stable.effect);\n return stable.trampoline;\n}\nfunction createStableCallback() {\n const stable = {\n next: undefined,\n callback: assertNotCalled,\n trampoline: (...args) => stable.callback?.(...args),\n effect: () => {\n stable.callback = stable.next;\n }\n };\n return stable;\n}\nfunction assertNotCalled() {\n if (process.env.NODE_ENV !== 'production') {\n throw new Error('Base UI: Cannot call an event handler while rendering.');\n }\n}","'use client';\n\nimport * as React from 'react';\nconst noop = () => {};\nexport const useIsoLayoutEffect = typeof document !== 'undefined' ? React.useLayoutEffect : noop;","let set;\nif (process.env.NODE_ENV !== 'production') {\n set = new Set();\n}\nexport function warn(...messages) {\n if (process.env.NODE_ENV !== 'production') {\n const messageKey = messages.join(' ');\n if (!set.has(messageKey)) {\n set.add(messageKey);\n console.warn(`Base UI: ${messageKey}`);\n }\n }\n}","'use client';\n\nimport * as React from 'react';\nexport const CompositeListContext = /*#__PURE__*/React.createContext({\n register: () => {},\n unregister: () => {},\n subscribeMapChange: () => {\n return () => {};\n },\n elementsRef: {\n current: []\n },\n nextIndexRef: {\n current: 0\n }\n});\nif (process.env.NODE_ENV !== \"production\") CompositeListContext.displayName = \"CompositeListContext\";\nexport function useCompositeListContext() {\n return React.useContext(CompositeListContext);\n}","/* eslint-disable no-bitwise */\n'use client';\n\nimport * as React from 'react';\nimport { useRefWithInit } from '@base-ui-components/utils/useRefWithInit';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { CompositeListContext } from \"./CompositeListContext.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\n/**\n * Provides context for a list of items in a composite component.\n * @internal\n */\nexport function CompositeList(props) {\n const {\n children,\n elementsRef,\n labelsRef,\n onMapChange: onMapChangeProp\n } = props;\n const onMapChange = useStableCallback(onMapChangeProp);\n const nextIndexRef = React.useRef(0);\n const listeners = useRefWithInit(createListeners).current;\n\n // We use a stable `map` to avoid O(n^2) re-allocation costs for large lists.\n // `mapTick` is our re-render trigger mechanism. We also need to update the\n // elements and label refs, but there's a lot of async work going on and sometimes\n // the effect that handles `onMapChange` gets called after those refs have been\n // filled, and we don't want to lose those values by setting their lengths to `0`.\n // We also need to have them at the proper length because floating-ui uses that\n // information for list navigation.\n\n const map = useRefWithInit(createMap).current;\n // `mapTick` uses a counter rather than objects for low precision-loss risk and better memory efficiency\n const [mapTick, setMapTick] = React.useState(0);\n const lastTickRef = React.useRef(mapTick);\n const register = useStableCallback((node, metadata) => {\n map.set(node, metadata ?? null);\n lastTickRef.current += 1;\n setMapTick(lastTickRef.current);\n });\n const unregister = useStableCallback(node => {\n map.delete(node);\n lastTickRef.current += 1;\n setMapTick(lastTickRef.current);\n });\n const sortedMap = React.useMemo(() => {\n // `mapTick` is the `useMemo` trigger as `map` is stable.\n disableEslintWarning(mapTick);\n const newMap = new Map();\n // Filter out disconnected elements before sorting to avoid inconsistent\n // compareDocumentPosition results when elements are detached from the DOM.\n const sortedNodes = Array.from(map.keys()).filter(node => node.isConnected).sort(sortByDocumentPosition);\n sortedNodes.forEach((node, index) => {\n const metadata = map.get(node) ?? {};\n newMap.set(node, {\n ...metadata,\n index\n });\n });\n return newMap;\n }, [map, mapTick]);\n useIsoLayoutEffect(() => {\n if (typeof MutationObserver !== 'function' || sortedMap.size === 0) {\n return undefined;\n }\n const mutationObserver = new MutationObserver(entries => {\n const diff = new Set();\n const updateDiff = node => diff.has(node) ? diff.delete(node) : diff.add(node);\n entries.forEach(entry => {\n entry.removedNodes.forEach(updateDiff);\n entry.addedNodes.forEach(updateDiff);\n });\n if (diff.size === 0) {\n lastTickRef.current += 1;\n setMapTick(lastTickRef.current);\n }\n });\n sortedMap.forEach((_, node) => {\n if (node.parentElement) {\n mutationObserver.observe(node.parentElement, {\n childList: true\n });\n }\n });\n return () => {\n mutationObserver.disconnect();\n };\n }, [sortedMap]);\n useIsoLayoutEffect(() => {\n const shouldUpdateLengths = lastTickRef.current === mapTick;\n if (shouldUpdateLengths) {\n if (elementsRef.current.length !== sortedMap.size) {\n elementsRef.current.length = sortedMap.size;\n }\n if (labelsRef && labelsRef.current.length !== sortedMap.size) {\n labelsRef.current.length = sortedMap.size;\n }\n nextIndexRef.current = sortedMap.size;\n }\n onMapChange(sortedMap);\n }, [onMapChange, sortedMap, elementsRef, labelsRef, mapTick]);\n useIsoLayoutEffect(() => {\n return () => {\n elementsRef.current = [];\n };\n }, [elementsRef]);\n useIsoLayoutEffect(() => {\n return () => {\n if (labelsRef) {\n labelsRef.current = [];\n }\n };\n }, [labelsRef]);\n const subscribeMapChange = useStableCallback(fn => {\n listeners.add(fn);\n return () => {\n listeners.delete(fn);\n };\n });\n useIsoLayoutEffect(() => {\n listeners.forEach(l => l(sortedMap));\n }, [listeners, sortedMap]);\n const contextValue = React.useMemo(() => ({\n register,\n unregister,\n subscribeMapChange,\n elementsRef,\n labelsRef,\n nextIndexRef\n }), [register, unregister, subscribeMapChange, elementsRef, labelsRef, nextIndexRef]);\n return /*#__PURE__*/_jsx(CompositeListContext.Provider, {\n value: contextValue,\n children: children\n });\n}\nfunction createMap() {\n return new Map();\n}\nfunction createListeners() {\n return new Set();\n}\nfunction sortByDocumentPosition(a, b) {\n const position = a.compareDocumentPosition(b);\n if (position & Node.DOCUMENT_POSITION_FOLLOWING || position & Node.DOCUMENT_POSITION_CONTAINED_BY) {\n return -1;\n }\n if (position & Node.DOCUMENT_POSITION_PRECEDING || position & Node.DOCUMENT_POSITION_CONTAINS) {\n return 1;\n }\n return 0;\n}\nfunction disableEslintWarning(_) {}","'use client';\n\nimport * as React from 'react';\n/**\n * @internal\n */\nexport const DirectionContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") DirectionContext.displayName = \"DirectionContext\";\nexport function useDirection() {\n const context = React.useContext(DirectionContext);\n return context?.direction ?? 'ltr';\n}","/**\n * WARNING: Don't import this directly. It's imported by the code generated by\n * `@mui/interal-babel-plugin-minify-errors`. Make sure to always use string literals in `Error`\n * constructors to ensure the plugin works as expected. Supported patterns include:\n * throw new Error('My message');\n * throw new Error(`My message: ${foo}`);\n * throw new Error(`My message: ${foo}` + 'another string');\n * ...\n */\nexport default function formatErrorMessage(code, ...args) {\n const url = new URL(`https://base-ui.com/production-error/${code}`);\n args.forEach(arg => url.searchParams.append('args[]', arg));\n return `Base UI error #${code}; visit ${url} for the full message.`;\n}","'use client';\n\nimport _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const AccordionRootContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") AccordionRootContext.displayName = \"AccordionRootContext\";\nexport function useAccordionRootContext() {\n const context = React.useContext(AccordionRootContext);\n if (context === undefined) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: AccordionRootContext is missing. Accordion parts must be placed within <Accordion.Root>.' : _formatErrorMessage(10));\n }\n return context;\n}","import { useRefWithInit } from \"./useRefWithInit.js\";\n\n/**\n * Merges refs into a single memoized callback ref or `null`.\n * This makes sure multiple refs are updated together and have the same value.\n *\n * This function accepts up to four refs. If you need to merge more, or have an unspecified number of refs to merge,\n * use `useMergedRefsN` instead.\n */\n\nexport function useMergedRefs(a, b, c, d) {\n const forkRef = useRefWithInit(createForkRef).current;\n if (didChange(forkRef, a, b, c, d)) {\n update(forkRef, [a, b, c, d]);\n }\n return forkRef.callback;\n}\n\n/**\n * Merges an array of refs into a single memoized callback ref or `null`.\n *\n * If you need to merge a fixed number (up to four) of refs, use `useMergedRefs` instead for better performance.\n */\nexport function useMergedRefsN(refs) {\n const forkRef = useRefWithInit(createForkRef).current;\n if (didChangeN(forkRef, refs)) {\n update(forkRef, refs);\n }\n return forkRef.callback;\n}\nfunction createForkRef() {\n return {\n callback: null,\n cleanup: null,\n refs: []\n };\n}\nfunction didChange(forkRef, a, b, c, d) {\n // prettier-ignore\n return forkRef.refs[0] !== a || forkRef.refs[1] !== b || forkRef.refs[2] !== c || forkRef.refs[3] !== d;\n}\nfunction didChangeN(forkRef, newRefs) {\n return forkRef.refs.length !== newRefs.length || forkRef.refs.some((ref, index) => ref !== newRefs[index]);\n}\nfunction update(forkRef, refs) {\n forkRef.refs = refs;\n if (refs.every(ref => ref == null)) {\n forkRef.callback = null;\n return;\n }\n forkRef.callback = instance => {\n if (forkRef.cleanup) {\n forkRef.cleanup();\n forkRef.cleanup = null;\n }\n if (instance != null) {\n const cleanupCallbacks = Array(refs.length).fill(null);\n for (let i = 0; i < refs.length; i += 1) {\n const ref = refs[i];\n if (ref == null) {\n continue;\n }\n switch (typeof ref) {\n case 'function':\n {\n const refCleanup = ref(instance);\n if (typeof refCleanup === 'function') {\n cleanupCallbacks[i] = refCleanup;\n }\n break;\n }\n case 'object':\n {\n ref.current = instance;\n break;\n }\n default:\n }\n }\n forkRef.cleanup = () => {\n for (let i = 0; i < refs.length; i += 1) {\n const ref = refs[i];\n if (ref == null) {\n continue;\n }\n switch (typeof ref) {\n case 'function':\n {\n const cleanupCallback = cleanupCallbacks[i];\n if (typeof cleanupCallback === 'function') {\n cleanupCallback();\n } else {\n ref(null);\n }\n break;\n }\n case 'object':\n {\n ref.current = null;\n break;\n }\n default:\n }\n }\n };\n }\n };\n}","import * as React from 'react';\nconst majorVersion = parseInt(React.version, 10);\nexport function isReactVersionAtLeast(reactVersionToCheck) {\n return majorVersion >= reactVersionToCheck;\n}","import * as React from 'react';\nimport { isReactVersionAtLeast } from \"./reactVersion.js\";\n\n/**\n * Extracts the `ref` from a React element, handling different React versions.\n */\nexport function getReactElementRef(element) {\n if (! /*#__PURE__*/React.isValidElement(element)) {\n return null;\n }\n const reactElement = element;\n const propsWithRef = reactElement.props;\n return (isReactVersionAtLeast(19) ? propsWithRef?.ref : reactElement.ref) ?? null;\n}","export function mergeObjects(a, b) {\n if (a && !b) {\n return a;\n }\n if (!a && b) {\n return b;\n }\n if (a || b) {\n return {\n ...a,\n ...b\n };\n }\n return undefined;\n}","export function getStateAttributesProps(state, customMapping) {\n const props = {};\n\n /* eslint-disable-next-line guard-for-in */\n for (const key in state) {\n const value = state[key];\n if (customMapping?.hasOwnProperty(key)) {\n const customProps = customMapping[key](value);\n if (customProps != null) {\n Object.assign(props, customProps);\n }\n continue;\n }\n if (value === true) {\n props[`data-${key.toLowerCase()}`] = '';\n } else if (value) {\n props[`data-${key.toLowerCase()}`] = value.toString();\n }\n }\n return props;\n}","/**\n * If the provided className is a string, it will be returned as is.\n * Otherwise, the function will call the className function with the state as the first argument.\n *\n * @param className\n * @param state\n */\nexport function resolveClassName(className, state) {\n return typeof className === 'function' ? className(state) : className;\n}","/**\n * If the provided style is an object, it will be returned as is.\n * Otherwise, the function will call the style function with the state as the first argument.\n *\n * @param style\n * @param state\n */\nexport function resolveStyle(style, state) {\n return typeof style === 'function' ? style(state) : style;\n}","import { mergeObjects } from '@base-ui-components/utils/mergeObjects';\nconst EMPTY_PROPS = {};\n\n/**\n * Merges multiple sets of React props. It follows the Object.assign pattern where the rightmost object's fields overwrite\n * the conflicting ones from others. This doesn't apply to event handlers, `className` and `style` props.\n * Event handlers are merged such that they are called in sequence (the rightmost one being called first),\n * and allows the user to prevent the subsequent event handlers from being\n * executed by attaching a `preventBaseUIHandler` method.\n * It also merges the `className` and `style` props, whereby the classes are concatenated\n * and the rightmost styles overwrite the subsequent ones.\n *\n * Props can either be provided as objects or as functions that take the previous props as an argument.\n * The function will receive the merged props up to that point (going from left to right):\n * so in the case of `(obj1, obj2, fn, obj3)`, `fn` will receive the merged props of `obj1` and `obj2`.\n * The function is responsible for chaining event handlers if needed (i.e. we don't run the merge logic).\n *\n * Event handlers returned by the functions are not automatically prevented when `preventBaseUIHandler` is called.\n * They must check `event.baseUIHandlerPrevented` themselves and bail out if it's true.\n *\n * @important **`ref` is not merged.**\n * @param props props to merge.\n * @returns the merged props.\n */\n/* eslint-disable id-denylist */\n\nexport function mergeProps(a, b, c, d, e) {\n // We need to mutably own `merged`\n let merged = {\n ...resolvePropsGetter(a, EMPTY_PROPS)\n };\n if (b) {\n merged = mergeOne(merged, b);\n }\n if (c) {\n merged = mergeOne(merged, c);\n }\n if (d) {\n merged = mergeOne(merged, d);\n }\n if (e) {\n merged = mergeOne(merged, e);\n }\n return merged;\n}\n/* eslint-enable id-denylist */\n\nexport function mergePropsN(props) {\n if (props.length === 0) {\n return EMPTY_PROPS;\n }\n if (props.length === 1) {\n return resolvePropsGetter(props[0], EMPTY_PROPS);\n }\n\n // We need to mutably own `merged`\n let merged = {\n ...resolvePropsGetter(props[0], EMPTY_PROPS)\n };\n for (let i = 1; i < props.length; i += 1) {\n merged = mergeOne(merged, props[i]);\n }\n return merged;\n}\nfunction mergeOne(merged, inputProps) {\n if (isPropsGetter(inputProps)) {\n return inputProps(merged);\n }\n return mutablyMergeInto(merged, inputProps);\n}\n\n/**\n * Merges two sets of props. In case of conflicts, the external props take precedence.\n */\nfunction mutablyMergeInto(mergedProps, externalProps) {\n if (!externalProps) {\n return mergedProps;\n }\n\n // eslint-disable-next-line guard-for-in\n for (const propName in externalProps) {\n const externalPropValue = externalProps[propName];\n switch (propName) {\n case 'style':\n {\n mergedProps[propName] = mergeObjects(mergedProps.style, externalPropValue);\n break;\n }\n case 'className':\n {\n mergedProps[propName] = mergeClassNames(mergedProps.className, externalPropValue);\n break;\n }\n default:\n {\n if (isEventHandler(propName, externalPropValue)) {\n mergedProps[propName] = mergeEventHandlers(mergedProps[propName], externalPropValue);\n } else {\n mergedProps[propName] = externalPropValue;\n }\n }\n }\n }\n return mergedProps;\n}\nfunction isEventHandler(key, value) {\n // This approach is more efficient than using a regex.\n const code0 = key.charCodeAt(0);\n const code1 = key.charCodeAt(1);\n const code2 = key.charCodeAt(2);\n return code0 === 111 /* o */ && code1 === 110 /* n */ && code2 >= 65 /* A */ && code2 <= 90 /* Z */ && (typeof value === 'function' || typeof value === 'undefined');\n}\nfunction isPropsGetter(inputProps) {\n return typeof inputProps === 'function';\n}\nfunction resolvePropsGetter(inputProps, previousProps) {\n if (isPropsGetter(inputProps)) {\n return inputProps(previousProps);\n }\n return inputProps ?? EMPTY_PROPS;\n}\nfunction mergeEventHandlers(ourHandler, theirHandler) {\n if (!theirHandler) {\n return ourHandler;\n }\n if (!ourHandler) {\n return theirHandler;\n }\n return event => {\n if (isSyntheticEvent(event)) {\n const baseUIEvent = event;\n makeEventPreventable(baseUIEvent);\n const result = theirHandler(baseUIEvent);\n if (!baseUIEvent.baseUIHandlerPrevented) {\n ourHandler?.(baseUIEvent);\n }\n return result;\n }\n const result = theirHandler(event);\n ourHandler?.(event);\n return result;\n };\n}\nexport function makeEventPreventable(event) {\n event.preventBaseUIHandler = () => {\n event.baseUIHandlerPrevented = true;\n };\n return event;\n}\nexport function mergeClassNames(ourClassName, theirClassName) {\n if (theirClassName) {\n if (ourClassName) {\n // eslint-disable-next-line prefer-template\n return theirClassName + ' ' + ourClassName;\n }\n return theirClassName;\n }\n return ourClassName;\n}\nfunction isSyntheticEvent(event) {\n return event != null && typeof event === 'object' && 'nativeEvent' in event;\n}","export function NOOP() {}\nexport const EMPTY_ARRAY = Object.freeze([]);\nexport const EMPTY_OBJECT = Object.freeze({});","export const TYPEAHEAD_RESET_MS = 500;\nexport const PATIENT_CLICK_THRESHOLD = 500;\nexport const DISABLED_TRANSITIONS_STYLE = {\n style: {\n transition: 'none'\n }\n};\nexport { EMPTY_OBJECT, EMPTY_ARRAY } from '@base-ui-components/utils/empty';\nexport const CLICK_TRIGGER_IDENTIFIER = 'data-base-ui-click-trigger';\n\n/**\n * Used for dropdowns that usually strictly prefer top/bottom placements and\n * use `var(--available-height)` to limit their height.\n */\nexport const DROPDOWN_COLLISION_AVOIDANCE = {\n fallbackAxisSide: 'none'\n};\n\n/**\n * Used by regular popups that usually aren't scrollable and are allowed to\n * freely flip to any axis of placement.\n */\nexport const POPUP_COLLISION_AVOIDANCE = {\n fallbackAxisSide: 'end'\n};\n\n/**\n * Special visually hidden styles for the aria-owns owner element to ensure owned element\n * accessibility in iOS/Safari/VoiceControl.\n * The owner element is an empty span, so most of the common visually hidden styles are not needed.\n * @see https://github.com/floating-ui/floating-ui/issues/3403\n */\nexport const ownerVisuallyHidden = {\n clipPath: 'inset(50%)',\n position: 'fixed',\n top: 0,\n left: 0\n};","import _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nimport { useMergedRefs, useMergedRefsN } from '@base-ui-components/utils/useMergedRefs';\nimport { getReactElementRef } from '@base-ui-components/utils/getReactElementRef';\nimport { mergeObjects } from '@base-ui-components/utils/mergeObjects';\nimport { getStateAttributesProps } from \"./getStateAttributesProps.js\";\nimport { resolveClassName } from \"./resolveClassName.js\";\nimport { resolveStyle } from \"./resolveStyle.js\";\nimport { mergeProps, mergePropsN, mergeClassNames } from \"../merge-props/index.js\";\nimport { EMPTY_OBJECT } from \"./constants.js\";\nimport { createElement as _createElement } from \"react\";\n/**\n * Renders a Base UI element.\n *\n * @param element The default HTML element to render. Can be overridden by the `render` prop.\n * @param componentProps An object containing the `render` and `className` props to be used for element customization. Other props are ignored.\n * @param params Additional parameters for rendering the element.\n */\nexport function useRenderElement(element, componentProps, params = {}) {\n const renderProp = componentProps.render;\n const outProps = useRenderElementProps(componentProps, params);\n if (params.enabled === false) {\n return null;\n }\n const state = params.state ?? EMPTY_OBJECT;\n return evaluateRenderProp(element, renderProp, outProps, state);\n}\n\n/**\n * Computes render element final props.\n */\nfunction useRenderElementProps(componentProps, params = {}) {\n const {\n className: classNameProp,\n style: styleProp,\n render: renderProp\n } = componentProps;\n const {\n state = EMPTY_OBJECT,\n ref,\n props,\n stateAttributesMapping,\n enabled = true\n } = params;\n const className = enabled ? resolveClassName(classNameProp, state) : undefined;\n const style = enabled ? resolveStyle(styleProp, state) : undefined;\n const stateProps = enabled ? getStateAttributesProps(state, stateAttributesMapping) : EMPTY_OBJECT;\n const outProps = enabled ? mergeObjects(stateProps, Array.isArray(props) ? mergePropsN(props) : props) ?? EMPTY_OBJECT : EMPTY_OBJECT;\n\n // SAFETY: The `useMergedRefs` functions use a single hook to store the same value,\n // switching between them at runtime is safe. If this assertion fails, React will\n // throw at runtime anyway.\n // This also skips the `useMergedRefs` call on the server, which is fine because\n // refs are not used on the server side.\n /* eslint-disable react-hooks/rules-of-hooks */\n if (typeof document !== 'undefined') {\n if (!enabled) {\n useMergedRefs(null, null);\n } else if (Array.isArray(ref)) {\n outProps.ref = useMergedRefsN([outProps.ref, getReactElementRef(renderProp), ...ref]);\n } else {\n outProps.ref = useMergedRefs(outProps.ref, getReactElementRef(renderProp), ref);\n }\n }\n if (!enabled) {\n return EMPTY_OBJECT;\n }\n if (className !== undefined) {\n outProps.className = mergeClassNames(outProps.className, className);\n }\n if (style !== undefined) {\n outProps.style = mergeObjects(outProps.style, style);\n }\n return outProps;\n}\nfunction evaluateRenderProp(element, render, props, state) {\n if (render) {\n if (typeof render === 'function') {\n return render(props, state);\n }\n const mergedProps = mergeProps(props, render.props);\n mergedProps.ref = props.ref;\n return /*#__PURE__*/React.cloneElement(render, mergedProps);\n }\n if (element) {\n if (typeof element === 'string') {\n return renderTag(element, props);\n }\n }\n // Unreachable, but the typings on `useRenderElement` need to be reworked\n // to annotate it correctly.\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: Render element or function are not defined.' : _formatErrorMessage(8));\n}\nfunction renderTag(Tag, props) {\n if (Tag === 'button') {\n return /*#__PURE__*/_createElement(\"button\", {\n type: \"button\",\n ...props,\n key: props.key\n });\n }\n if (Tag === 'img') {\n return /*#__PURE__*/_createElement(\"img\", {\n alt: \"\",\n ...props,\n key: props.key\n });\n }\n return /*#__PURE__*/React.createElement(Tag, props);\n}","export const none = 'none';\nexport const triggerPress = 'trigger-press';\nexport const triggerHover = 'trigger-hover';\nexport const triggerFocus = 'trigger-focus';\nexport const outsidePress = 'outside-press';\nexport const itemPress = 'item-press';\nexport const closePress = 'close-press';\nexport const linkPress = 'link-press';\nexport const clearPress = 'clear-press';\nexport const chipRemovePress = 'chip-remove-press';\nexport const trackPress = 'track-press';\nexport const incrementPress = 'increment-press';\nexport const decrementPress = 'decrement-press';\nexport const inputChange = 'input-change';\nexport const inputClear = 'input-clear';\nexport const inputBlur = 'input-blur';\nexport const inputPaste = 'input-paste';\nexport const focusOut = 'focus-out';\nexport const escapeKey = 'escape-key';\nexport const listNavigation = 'list-navigation';\nexport const keyboard = 'keyboard';\nexport const pointer = 'pointer';\nexport const drag = 'drag';\nexport const wheel = 'wheel';\nexport const scrub = 'scrub';\nexport const cancelOpen = 'cancel-open';\nexport const siblingOpen = 'sibling-open';\nexport const disabled = 'disabled';\nexport const imperativeAction = 'imperative-action';\nexport const windowResize = 'window-resize';","import { EMPTY_OBJECT } from \"./constants.js\";\nimport { REASONS } from \"./reasons.js\";\n\n/**\n * Maps a change `reason` string to the corresponding native event type.\n */\n\n/**\n * Details of custom change events emitted by Base UI components.\n */\n\n/**\n * Details of custom generic events emitted by Base UI components.\n */\n\n/**\n * Creates a Base UI event details object with the given reason and utilities\n * for preventing Base UI's internal event handling.\n */\nexport function createChangeEventDetails(reason, event, trigger, customProperties) {\n let canceled = false;\n let allowPropagation = false;\n const custom = customProperties ?? EMPTY_OBJECT;\n const details = {\n reason,\n event: event ?? new Event('base-ui'),\n cancel() {\n canceled = true;\n },\n allowPropagation() {\n allowPropagation = true;\n },\n get isCanceled() {\n return canceled;\n },\n get isPropagationAllowed() {\n return allowPropagation;\n },\n trigger,\n ...custom\n };\n return details;\n}\nexport function createGenericEventDetails(reason, event, customProperties) {\n const custom = customProperties ?? EMPTY_OBJECT;\n const details = {\n reason,\n event: event ?? new Event('base-ui'),\n ...custom\n };\n return details;\n}","'use client';\n\nimport * as React from 'react';\nimport { useControlled } from '@base-ui-components/utils/useControlled';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { warn } from '@base-ui-components/utils/warn';\nimport { CompositeList } from \"../../composite/list/CompositeList.js\";\nimport { useDirection } from \"../../direction-provider/DirectionContext.js\";\nimport { AccordionRootContext } from \"./AccordionRootContext.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst rootStateAttributesMapping = {\n value: () => null\n};\n\n/**\n * Groups all parts of the accordion.\n * Renders a `<div>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\nexport const AccordionRoot = /*#__PURE__*/React.forwardRef(function AccordionRoot(componentProps, forwardedRef) {\n const {\n render,\n className,\n disabled = false,\n hiddenUntilFound: hiddenUntilFoundProp,\n keepMounted: keepMountedProp,\n loopFocus = true,\n onValueChange: onValueChangeProp,\n multiple = false,\n orientation = 'vertical',\n value: valueProp,\n defaultValue: defaultValueProp,\n ...elementProps\n } = componentProps;\n const direction = useDirection();\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useIsoLayoutEffect(() => {\n if (hiddenUntilFoundProp && keepMountedProp === false) {\n warn('The `keepMounted={false}` prop on a Accordion.Root will be ignored when using `hiddenUntilFound` since it requires Panels to remain mounted when closed.');\n }\n }, [hiddenUntilFoundProp, keepMountedProp]);\n }\n\n // memoized to allow omitting both defaultValue and value\n // which would otherwise trigger a warning in useControlled\n const defaultValue = React.useMemo(() => {\n if (valueProp === undefined) {\n return defaultValueProp ?? [];\n }\n return undefined;\n }, [valueProp, defaultValueProp]);\n const onValueChange = useStableCallback(onValueChangeProp);\n const accordionItemRefs = React.useRef([]);\n const [value, setValue] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: 'Accordion',\n state: 'value'\n });\n const handleValueChange = useStableCallback((newValue, nextOpen) => {\n const details = createChangeEventDetails(REASONS.none);\n if (!multiple) {\n const nextValue = value[0] === newValue ? [] : [newValue];\n onValueChange(nextValue, details);\n if (details.isCanceled) {\n return;\n }\n setValue(nextValue);\n } else if (nextOpen) {\n const nextOpenValues = value.slice();\n nextOpenValues.push(newValue);\n onValueChange(nextOpenValues, details);\n if (details.isCanceled) {\n return;\n }\n setValue(nextOpenValues);\n } else {\n const nextOpenValues = value.filter(v => v !== newValue);\n onValueChange(nextOpenValues, details);\n if (details.isCanceled) {\n return;\n }\n setValue(nextOpenValues);\n }\n });\n const state = React.useMemo(() => ({\n value,\n disabled,\n orientation\n }), [value, disabled, orientation]);\n const contextValue = React.useMemo(() => ({\n accordionItemRefs,\n direction,\n disabled,\n handleValueChange,\n hiddenUntilFound: hiddenUntilFoundProp ?? false,\n keepMounted: keepMountedProp ?? false,\n loopFocus,\n orientation,\n state,\n value\n }), [direction, disabled, handleValueChange, hiddenUntilFoundProp, keepMountedProp, loopFocus, orientation, state, value]);\n const element = useRenderElement('div', componentProps, {\n state,\n ref: forwardedRef,\n props: [{\n dir: direction,\n role: 'region'\n }, elementProps],\n stateAttributesMapping: rootStateAttributesMapping\n });\n return /*#__PURE__*/_jsx(AccordionRootContext.Provider, {\n value: contextValue,\n children: /*#__PURE__*/_jsx(CompositeList, {\n elementsRef: accordionItemRefs,\n children: element\n })\n });\n});\nif (process.env.NODE_ENV !== \"production\") AccordionRoot.displayName = \"AccordionRoot\";","import * as React from 'react';\n\n// https://github.com/mui/material-ui/issues/41190#issuecomment-2040873379\nexport const SafeReact = {\n ...React\n};","'use client';\n\nimport * as React from 'react';\nimport { SafeReact } from \"./safeReact.js\";\nlet globalId = 0;\n\n// TODO React 17: Remove `useGlobalId` once React 17 support is removed\nfunction useGlobalId(idOverride, prefix = 'mui') {\n const [defaultId, setDefaultId] = React.useState(idOverride);\n const id = idOverride || defaultId;\n React.useEffect(() => {\n if (defaultId == null) {\n // Fallback to this default id when possible.\n // Use the incrementing value for client-side rendering only.\n // We can't use it server-side.\n // If you want to use random values please consider the Birthday Problem: https://en.wikipedia.org/wiki/Birthday_problem\n globalId += 1;\n setDefaultId(`${prefix}-${globalId}`);\n }\n }, [defaultId, prefix]);\n return id;\n}\nconst maybeReactUseId = SafeReact.useId;\n\n/**\n *\n * @example <div id={useId()} />\n * @param idOverride\n * @returns {string}\n */\nexport function useId(idOverride, prefix) {\n // React.useId() is only available from React 17.0.0.\n if (maybeReactUseId !== undefined) {\n const reactId = maybeReactUseId();\n return idOverride ?? (prefix ? `${prefix}-${reactId}` : reactId);\n }\n\n // TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler\n // eslint-disable-next-line react-hooks/rules-of-hooks -- `React.useId` is invariant at runtime.\n return useGlobalId(idOverride, prefix);\n}","'use client';\n\nimport { useId } from '@base-ui-components/utils/useId';\n\n/**\n * Wraps `useId` and prefixes generated `id`s with `base-ui-`\n * @param {string | undefined} idOverride overrides the generated id when provided\n * @returns {string | undefined}\n */\nexport function useBaseUiId(idOverride) {\n return useId(idOverride, 'base-ui');\n}","'use client';\n\nimport * as React from 'react';\nconst EMPTY = [];\n\n/**\n * A React.useEffect equivalent that runs once, when the component is mounted.\n */\nexport function useOnMount(fn) {\n // TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler -- no need to put `fn` in the dependency array\n /* eslint-disable react-hooks/exhaustive-deps */\n React.useEffect(fn, EMPTY);\n /* eslint-enable react-hooks/exhaustive-deps */\n}","'use client';\n\nimport { useRefWithInit } from \"./useRefWithInit.js\";\nimport { useOnMount } from \"./useOnMount.js\";\n/** Unlike `setTimeout`, rAF doesn't guarantee a positive integer return value, so we can't have\n * a monomorphic `uint` type with `0` meaning empty.\n * See warning note at:\n * https://developer.mozilla.org/en-US/docs/Web/API/Window/requestAnimationFrame#return_value */\nconst EMPTY = null;\nlet LAST_RAF = globalThis.requestAnimationFrame;\nclass Scheduler {\n /* This implementation uses an array as a backing data-structure for frame callbacks.\n * It allows `O(1)` callback cancelling by inserting a `null` in the array, though it\n * never calls the native `cancelAnimationFrame` if there are no frames left. This can\n * be much more efficient if there is a call pattern that alterns as\n * \"request-cancel-request-cancel-…\".\n * But in the case of \"request-request-…-cancel-cancel-…\", it leaves the final animation\n * frame to run anyway. We turn that frame into a `O(1)` no-op via `callbacksCount`. */\n\n callbacks = [];\n callbacksCount = 0;\n nextId = 1;\n startId = 1;\n isScheduled = false;\n tick = timestamp => {\n this.isScheduled = false;\n const currentCallbacks = this.callbacks;\n const currentCallbacksCount = this.callbacksCount;\n\n // Update these before iterating, callbacks could call `requestAnimationFrame` again.\n this.callbacks = [];\n this.callbacksCount = 0;\n this.startId = this.nextId;\n if (currentCallbacksCount > 0) {\n for (let i = 0; i < currentCallbacks.length; i += 1) {\n currentCallbacks[i]?.(timestamp);\n }\n }\n };\n request(fn) {\n const id = this.nextId;\n this.nextId += 1;\n this.callbacks.push(fn);\n this.callbacksCount += 1;\n\n /* In a test environment with fake timers, a fake `requestAnimationFrame` can be called\n * but there's no guarantee that the animation frame will actually run before the fake\n * timers are teared, which leaves `isScheduled` set, but won't run our `tick()`. */\n const didRAFChange = process.env.NODE_ENV === 'test' && LAST_RAF !== requestAnimationFrame && (LAST_RAF = requestAnimationFrame, true);\n if (!this.isScheduled || didRAFChange) {\n requestAnimationFrame(this.tick);\n this.isScheduled = true;\n }\n return id;\n }\n cancel(id) {\n const index = id - this.startId;\n if (index < 0 || index >= this.callbacks.length) {\n return;\n }\n this.callbacks[index] = null;\n this.callbacksCount -= 1;\n }\n}\nconst scheduler = new Scheduler();\nexport class AnimationFrame {\n static create() {\n return new AnimationFrame();\n }\n static request(fn) {\n return scheduler.request(fn);\n }\n static cancel(id) {\n return scheduler.cancel(id);\n }\n currentId = EMPTY;\n\n /**\n * Executes `fn` after `delay`, clearing any previously scheduled call.\n */\n request(fn) {\n this.cancel();\n this.currentId = scheduler.request(() => {\n this.currentId = EMPTY;\n fn();\n });\n }\n cancel = () => {\n if (this.currentId !== EMPTY) {\n scheduler.cancel(this.currentId);\n this.currentId = EMPTY;\n }\n };\n disposeEffect = () => {\n return this.cancel;\n };\n}\n\n/**\n * A `requestAnimationFrame` with automatic cleanup and guard.\n */\nexport function useAnimationFrame() {\n const timeout = useRefWithInit(AnimationFrame.create).current;\n useOnMount(timeout.disposeEffect);\n return timeout;\n}","/**\n * If the provided argument is a ref object, returns its `current` value.\n * Otherwise, returns the argument itself.\n */\nexport function resolveRef(maybeRef) {\n if (maybeRef == null) {\n return maybeRef;\n }\n return 'current' in maybeRef ? maybeRef.current : maybeRef;\n}","'use client';\n\nimport * as ReactDOM from 'react-dom';\nimport { useAnimationFrame } from '@base-ui-components/utils/useAnimationFrame';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { resolveRef } from \"./resolveRef.js\";\n\n/**\n * Executes a function once all animations have finished on the provided element.\n * @param elementOrRef - The element to watch for animations.\n * @param waitForNextTick - Whether to wait for the next tick before checking for animations.\n * @param treatAbortedAsFinished - Whether to treat aborted animations as finished. If `false`, and there are aborted animations,\n * the function will check again if any new animations have started and wait for them to finish.\n * @returns A function that takes a callback to execute once all animations have finished, and an optional AbortSignal to abort the callback\n */\nexport function useAnimationsFinished(elementOrRef, waitForNextTick = false, treatAbortedAsFinished = true) {\n const frame = useAnimationFrame();\n return useStableCallback((fnToExecute,\n /**\n * An optional [AbortSignal](https://developer.mozilla.org/en-US/docs/Web/API/AbortSignal) that\n * can be used to abort `fnToExecute` before all the animations have finished.\n * @default null\n */\n signal = null) => {\n frame.cancel();\n const element = resolveRef(elementOrRef);\n if (element == null) {\n return;\n }\n if (typeof element.getAnimations !== 'function' || globalThis.BASE_UI_ANIMATIONS_DISABLED) {\n fnToExecute();\n } else {\n frame.request(() => {\n function exec() {\n if (!element) {\n return;\n }\n Promise.all(element.getAnimations().map(anim => anim.finished)).then(() => {\n if (signal != null && signal.aborted) {\n return;\n }\n\n // Synchronously flush the unmounting of the component so that the browser doesn't\n // paint: https://github.com/mui/base-ui/issues/979\n ReactDOM.flushSync(fnToExecute);\n }).catch(() => {\n if (treatAbortedAsFinished) {\n if (signal != null && signal.aborted) {\n return;\n }\n ReactDOM.flushSync(fnToExecute);\n } else if (element.getAnimations().length > 0 && element.getAnimations().some(anim => anim.pending || anim.playState !== 'finished')) {\n // Sometimes animations can be aborted because a property they depend on changes while the animation plays.\n // In such cases, we need to re-check if any new animations have started.\n exec();\n }\n });\n }\n\n // `open: true` animations need to wait for the next tick to be detected\n if (waitForNextTick) {\n frame.request(exec);\n } else {\n exec();\n }\n });\n }\n });\n}","'use client';\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { AnimationFrame } from '@base-ui-components/utils/useAnimationFrame';\n/**\n * Provides a status string for CSS animations.\n * @param open - a boolean that determines if the element is open.\n * @param enableIdleState - a boolean that enables the `'idle'` state between `'starting'` and `'ending'`\n */\nexport function useTransitionStatus(open, enableIdleState = false, deferEndingState = false) {\n const [transitionStatus, setTransitionStatus] = React.useState(open && enableIdleState ? 'idle' : undefined);\n const [mounted, setMounted] = React.useState(open);\n if (open && !mounted) {\n setMounted(true);\n setTransitionStatus('starting');\n }\n if (!open && mounted && transitionStatus !== 'ending' && !deferEndingState) {\n setTransitionStatus('ending');\n }\n if (!open && !mounted && transitionStatus === 'ending') {\n setTransitionStatus(undefined);\n }\n useIsoLayoutEffect(() => {\n if (!open && mounted && transitionStatus !== 'ending' && deferEndingState) {\n const frame = AnimationFrame.request(() => {\n setTransitionStatus('ending');\n });\n return () => {\n AnimationFrame.cancel(frame);\n };\n }\n return undefined;\n }, [open, mounted, transitionStatus, deferEndingState]);\n useIsoLayoutEffect(() => {\n if (!open || enableIdleState) {\n return undefined;\n }\n const frame = AnimationFrame.request(() => {\n ReactDOM.flushSync(() => {\n setTransitionStatus(undefined);\n });\n });\n return () => {\n AnimationFrame.cancel(frame);\n };\n }, [enableIdleState, open]);\n useIsoLayoutEffect(() => {\n if (!open || !enableIdleState) {\n return undefined;\n }\n if (open && mounted && transitionStatus !== 'idle') {\n setTransitionStatus('starting');\n }\n const frame = AnimationFrame.request(() => {\n setTransitionStatus('idle');\n });\n return () => {\n AnimationFrame.cancel(frame);\n };\n }, [enableIdleState, open, mounted, setTransitionStatus, transitionStatus]);\n return React.useMemo(() => ({\n mounted,\n setMounted,\n transitionStatus\n }), [mounted, transitionStatus]);\n}","'use client';\n\nimport * as React from 'react';\nimport { useControlled } from '@base-ui-components/utils/useControlled';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useBaseUiId } from \"../../utils/useBaseUiId.js\";\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { useAnimationsFinished } from \"../../utils/useAnimationsFinished.js\";\nimport { useTransitionStatus } from \"../../utils/useTransitionStatus.js\";\nexport function useCollapsibleRoot(parameters) {\n const {\n open: openParam,\n defaultOpen,\n onOpenChange,\n disabled\n } = parameters;\n const isControlled = openParam !== undefined;\n const [open, setOpen] = useControlled({\n controlled: openParam,\n default: defaultOpen,\n name: 'Collapsible',\n state: 'open'\n });\n const {\n mounted,\n setMounted,\n transitionStatus\n } = useTransitionStatus(open, true, true);\n const [visible, setVisible] = React.useState(open);\n const [{\n height,\n width\n }, setDimensions] = React.useState({\n height: undefined,\n width: undefined\n });\n const defaultPanelId = useBaseUiId();\n const [panelIdState, setPanelIdState] = React.useState();\n const panelId = panelIdState ?? defaultPanelId;\n const [hiddenUntilFound, setHiddenUntilFound] = React.useState(false);\n const [keepMounted, setKeepMounted] = React.useState(false);\n const abortControllerRef = React.useRef(null);\n const animationTypeRef = React.useRef(null);\n const transitionDimensionRef = React.useRef(null);\n const panelRef = React.useRef(null);\n const runOnceAnimationsFinish = useAnimationsFinished(panelRef, false);\n const handleTrigger = useStableCallback(event => {\n const nextOpen = !open;\n const eventDetails = createChangeEventDetails(REASONS.triggerPress, event.nativeEvent);\n onOpenChange(nextOpen, eventDetails);\n if (eventDetails.isCanceled) {\n return;\n }\n const panel = panelRef.current;\n if (animationTypeRef.current === 'css-animation' && panel != null) {\n panel.style.removeProperty('animation-name');\n }\n if (!hiddenUntilFound && !keepMounted) {\n if (animationTypeRef.current != null && animationTypeRef.current !== 'css-animation') {\n if (!mounted && nextOpen) {\n setMounted(true);\n }\n }\n if (animationTypeRef.current === 'css-animation') {\n if (!visible && nextOpen) {\n setVisible(true);\n }\n if (!mounted && nextOpen) {\n setMounted(true);\n }\n }\n }\n setOpen(nextOpen);\n if (animationTypeRef.current === 'none' && mounted && !nextOpen) {\n setMounted(false);\n }\n });\n useIsoLayoutEffect(() => {\n /**\n * Unmount immediately when closing in controlled mode and keepMounted={false}\n * and no CSS animations or transitions are applied\n */\n if (isControlled && animationTypeRef.current === 'none' && !keepMounted && !open) {\n setMounted(false);\n }\n }, [isControlled, keepMounted, open, openParam, setMounted]);\n return React.useMemo(() => ({\n abortControllerRef,\n animationTypeRef,\n disabled,\n handleTrigger,\n height,\n mounted,\n open,\n panelId,\n panelRef,\n runOnceAnimationsFinish,\n setDimensions,\n setHiddenUntilFound,\n setKeepMounted,\n setMounted,\n setOpen,\n setPanelIdState,\n setVisible,\n transitionDimensionRef,\n transitionStatus,\n visible,\n width\n }), [abortControllerRef, animationTypeRef, disabled, handleTrigger, height, mounted, open, panelId, panelRef, runOnceAnimationsFinish, setDimensions, setHiddenUntilFound, setKeepMounted, setMounted, setOpen, setVisible, transitionDimensionRef, transitionStatus, visible, width]);\n}","'use client';\n\nimport _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const CollapsibleRootContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") CollapsibleRootContext.displayName = \"CollapsibleRootContext\";\nexport function useCollapsibleRootContext() {\n const context = React.useContext(CollapsibleRootContext);\n if (context === undefined) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: CollapsibleRootContext is missing. Collapsible parts must be placed within <Collapsible.Root>.' : _formatErrorMessage(15));\n }\n return context;\n}","'use client';\n\nimport * as React from 'react';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { useCompositeListContext } from \"./CompositeListContext.js\";\nexport let IndexGuessBehavior = /*#__PURE__*/function (IndexGuessBehavior) {\n IndexGuessBehavior[IndexGuessBehavior[\"None\"] = 0] = \"None\";\n IndexGuessBehavior[IndexGuessBehavior[\"GuessFromOrder\"] = 1] = \"GuessFromOrder\";\n return IndexGuessBehavior;\n}({});\n\n/**\n * Used to register a list item and its index (DOM position) in the `CompositeList`.\n */\nexport function useCompositeListItem(params = {}) {\n const {\n label,\n metadata,\n textRef,\n indexGuessBehavior,\n index: externalIndex\n } = params;\n const {\n register,\n unregister,\n subscribeMapChange,\n elementsRef,\n labelsRef,\n nextIndexRef\n } = useCompositeListContext();\n const indexRef = React.useRef(-1);\n const [index, setIndex] = React.useState(externalIndex ?? (indexGuessBehavior === IndexGuessBehavior.GuessFromOrder ? () => {\n if (indexRef.current === -1) {\n const newIndex = nextIndexRef.current;\n nextIndexRef.current += 1;\n indexRef.current = newIndex;\n }\n return indexRef.current;\n } : -1));\n const componentRef = React.useRef(null);\n const ref = React.useCallback(node => {\n componentRef.current = node;\n if (index !== -1 && node !== null) {\n elementsRef.current[index] = node;\n if (labelsRef) {\n const isLabelDefined = label !== undefined;\n labelsRef.current[index] = isLabelDefined ? label : textRef?.current?.textContent ?? node.textContent;\n }\n }\n }, [index, elementsRef, labelsRef, label, textRef]);\n useIsoLayoutEffect(() => {\n if (externalIndex != null) {\n return undefined;\n }\n const node = componentRef.current;\n if (node) {\n register(node, metadata);\n return () => {\n unregister(node);\n };\n }\n return undefined;\n }, [externalIndex, register, unregister, metadata]);\n useIsoLayoutEffect(() => {\n if (externalIndex != null) {\n return undefined;\n }\n return subscribeMapChange(map => {\n const i = componentRef.current ? map.get(componentRef.current)?.index : null;\n if (i != null) {\n setIndex(i);\n }\n });\n }, [externalIndex, subscribeMapChange, setIndex]);\n return React.useMemo(() => ({\n ref,\n index\n }), [index, ref]);\n}","'use client';\n\nimport _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const AccordionItemContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") AccordionItemContext.displayName = \"AccordionItemContext\";\nexport function useAccordionItemContext() {\n const context = React.useContext(AccordionItemContext);\n if (context === undefined) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: AccordionItemContext is missing. Accordion parts must be placed within <Accordion.Item>.' : _formatErrorMessage(9));\n }\n return context;\n}","export let TransitionStatusDataAttributes = /*#__PURE__*/function (TransitionStatusDataAttributes) {\n /**\n * Present when the component is animating in.\n */\n TransitionStatusDataAttributes[\"startingStyle\"] = \"data-starting-style\";\n /**\n * Present when the component is animating out.\n */\n TransitionStatusDataAttributes[\"endingStyle\"] = \"data-ending-style\";\n return TransitionStatusDataAttributes;\n}({});\nconst STARTING_HOOK = {\n [TransitionStatusDataAttributes.startingStyle]: ''\n};\nconst ENDING_HOOK = {\n [TransitionStatusDataAttributes.endingStyle]: ''\n};\nexport const transitionStatusMapping = {\n transitionStatus(value) {\n if (value === 'starting') {\n return STARTING_HOOK;\n }\n if (value === 'ending') {\n return ENDING_HOOK;\n }\n return null;\n }\n};","import { TransitionStatusDataAttributes } from \"../../utils/stateAttributesMapping.js\";\nexport let CollapsiblePanelDataAttributes = function (CollapsiblePanelDataAttributes) {\n /**\n * Present when the collapsible panel is open.\n */\n CollapsiblePanelDataAttributes[\"open\"] = \"data-open\";\n /**\n * Present when the collapsible panel is closed.\n */\n CollapsiblePanelDataAttributes[\"closed\"] = \"data-closed\";\n /**\n * Present when the panel is animating in.\n */\n CollapsiblePanelDataAttributes[CollapsiblePanelDataAttributes[\"startingStyle\"] = TransitionStatusDataAttributes.startingStyle] = \"startingStyle\";\n /**\n * Present when the panel is animating out.\n */\n CollapsiblePanelDataAttributes[CollapsiblePanelDataAttributes[\"endingStyle\"] = TransitionStatusDataAttributes.endingStyle] = \"endingStyle\";\n return CollapsiblePanelDataAttributes;\n}({});","export let CollapsibleTriggerDataAttributes = /*#__PURE__*/function (CollapsibleTriggerDataAttributes) {\n /**\n * Present when the collapsible panel is open.\n */\n CollapsibleTriggerDataAttributes[\"panelOpen\"] = \"data-panel-open\";\n return CollapsibleTriggerDataAttributes;\n}({});","import { CollapsiblePanelDataAttributes } from \"../collapsible/panel/CollapsiblePanelDataAttributes.js\";\nimport { CollapsibleTriggerDataAttributes } from \"../collapsible/trigger/CollapsibleTriggerDataAttributes.js\";\nconst PANEL_OPEN_HOOK = {\n [CollapsiblePanelDataAttributes.open]: ''\n};\nconst PANEL_CLOSED_HOOK = {\n [CollapsiblePanelDataAttributes.closed]: ''\n};\nexport const triggerOpenStateMapping = {\n open(value) {\n if (value) {\n return {\n [CollapsibleTriggerDataAttributes.panelOpen]: ''\n };\n }\n return null;\n }\n};\nexport const collapsibleOpenStateMapping = {\n open(value) {\n if (value) {\n return PANEL_OPEN_HOOK;\n }\n return PANEL_CLOSED_HOOK;\n }\n};","export let AccordionItemDataAttributes = /*#__PURE__*/function (AccordionItemDataAttributes) {\n /**\n * Indicates the index of the accordion item.\n * @type {number}\n */\n AccordionItemDataAttributes[\"index\"] = \"data-index\";\n /**\n * Present when the accordion item is disabled.\n */\n AccordionItemDataAttributes[\"disabled\"] = \"data-disabled\";\n /**\n * Present when the accordion item is open.\n */\n AccordionItemDataAttributes[\"open\"] = \"data-open\";\n return AccordionItemDataAttributes;\n}({});","import { collapsibleOpenStateMapping as baseMapping } from \"../../utils/collapsibleOpenStateMapping.js\";\nimport { transitionStatusMapping } from \"../../utils/stateAttributesMapping.js\";\nimport { AccordionItemDataAttributes } from \"./AccordionItemDataAttributes.js\";\nexport const accordionStateAttributesMapping = {\n ...baseMapping,\n index: value => {\n return Number.isInteger(value) ? {\n [AccordionItemDataAttributes.index]: String(value)\n } : null;\n },\n ...transitionStatusMapping,\n value: () => null\n};","'use client';\n\nimport * as React from 'react';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useMergedRefs } from '@base-ui-components/utils/useMergedRefs';\nimport { useBaseUiId } from \"../../utils/useBaseUiId.js\";\nimport { useCollapsibleRoot } from \"../../collapsible/root/useCollapsibleRoot.js\";\nimport { CollapsibleRootContext } from \"../../collapsible/root/CollapsibleRootContext.js\";\nimport { useCompositeListItem } from \"../../composite/list/useCompositeListItem.js\";\nimport { useAccordionRootContext } from \"../root/AccordionRootContext.js\";\nimport { AccordionItemContext } from \"./AccordionItemContext.js\";\nimport { accordionStateAttributesMapping } from \"./stateAttributesMapping.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\n/**\n * Groups an accordion header with the corresponding panel.\n * Renders a `<div>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\nexport const AccordionItem = /*#__PURE__*/React.forwardRef(function AccordionItem(componentProps, forwardedRef) {\n const {\n className,\n disabled: disabledProp = false,\n onOpenChange: onOpenChangeProp,\n render,\n value: valueProp,\n ...elementProps\n } = componentProps;\n const {\n ref: listItemRef,\n index\n } = useCompositeListItem();\n const mergedRef = useMergedRefs(forwardedRef, listItemRef);\n const {\n disabled: contextDisabled,\n handleValueChange,\n state: rootState,\n value: openValues\n } = useAccordionRootContext();\n const fallbackValue = useBaseUiId();\n const value = valueProp ?? fallbackValue;\n const disabled = disabledProp || contextDisabled;\n const isOpen = React.useMemo(() => {\n if (!openValues) {\n return false;\n }\n for (let i = 0; i < openValues.length; i += 1) {\n if (openValues[i] === value) {\n return true;\n }\n }\n return false;\n }, [openValues, value]);\n const onOpenChange = useStableCallback((nextOpen, eventDetails) => {\n onOpenChangeProp?.(nextOpen, eventDetails);\n if (eventDetails.isCanceled) {\n return;\n }\n handleValueChange(value, nextOpen);\n });\n const collapsible = useCollapsibleRoot({\n open: isOpen,\n onOpenChange,\n disabled\n });\n const collapsibleState = React.useMemo(() => ({\n open: collapsible.open,\n disabled: collapsible.disabled,\n hidden: !collapsible.mounted,\n transitionStatus: collapsible.transitionStatus\n }), [collapsible.open, collapsible.disabled, collapsible.mounted, collapsible.transitionStatus]);\n const collapsibleContext = React.useMemo(() => ({\n ...collapsible,\n onOpenChange,\n state: collapsibleState\n }), [collapsible, collapsibleState, onOpenChange]);\n const state = React.useMemo(() => ({\n ...rootState,\n index,\n disabled,\n open: isOpen\n }), [disabled, index, isOpen, rootState]);\n const [triggerId, setTriggerId] = React.useState(useBaseUiId());\n const accordionItemContext = React.useMemo(() => ({\n open: isOpen,\n state,\n setTriggerId,\n triggerId\n }), [isOpen, state, setTriggerId, triggerId]);\n const element = useRenderElement('div', componentProps, {\n state,\n ref: mergedRef,\n props: elementProps,\n stateAttributesMapping: accordionStateAttributesMapping\n });\n return /*#__PURE__*/_jsx(CollapsibleRootContext.Provider, {\n value: collapsibleContext,\n children: /*#__PURE__*/_jsx(AccordionItemContext.Provider, {\n value: accordionItemContext,\n children: element\n })\n });\n});\nif (process.env.NODE_ENV !== \"production\") AccordionItem.displayName = \"AccordionItem\";","'use client';\n\nimport * as React from 'react';\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nimport { useAccordionItemContext } from \"../item/AccordionItemContext.js\";\nimport { accordionStateAttributesMapping } from \"../item/stateAttributesMapping.js\";\n\n/**\n * A heading that labels the corresponding panel.\n * Renders an `<h3>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\nexport const AccordionHeader = /*#__PURE__*/React.forwardRef(function AccordionHeader(componentProps, forwardedRef) {\n const {\n render,\n className,\n ...elementProps\n } = componentProps;\n const {\n state\n } = useAccordionItemContext();\n const element = useRenderElement('h3', componentProps, {\n state,\n ref: forwardedRef,\n props: elementProps,\n stateAttributesMapping: accordionStateAttributesMapping\n });\n return element;\n});\nif (process.env.NODE_ENV !== \"production\") AccordionHeader.displayName = \"AccordionHeader\";","export function isElementDisabled(element) {\n return element == null || element.hasAttribute('disabled') || element.getAttribute('aria-disabled') === 'true';\n}","function hasWindow() {\n return typeof window !== 'undefined';\n}\nfunction getNodeName(node) {\n if (isNode(node)) {\n return (node.nodeName || '').toLowerCase();\n }\n // Mocked nodes in testing environments may not be instances of Node. By\n // returning `#document` an infinite loop won't occur.\n // https://github.com/floating-ui/floating-ui/issues/2317\n return '#document';\n}\nfunction getWindow(node) {\n var _node$ownerDocument;\n return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n var _ref;\n return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n if (!hasWindow() || typeof ShadowRoot === 'undefined') {\n return false;\n }\n return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nconst invalidOverflowDisplayValues = /*#__PURE__*/new Set(['inline', 'contents']);\nfunction isOverflowElement(element) {\n const {\n overflow,\n overflowX,\n overflowY,\n display\n } = getComputedStyle(element);\n return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !invalidOverflowDisplayValues.has(display);\n}\nconst tableElements = /*#__PURE__*/new Set(['table', 'td', 'th']);\nfunction isTableElement(element) {\n return tableElements.has(getNodeName(element));\n}\nconst topLayerSelectors = [':popover-open', ':modal'];\nfunction isTopLayer(element) {\n return topLayerSelectors.some(selector => {\n try {\n return element.matches(selector);\n } catch (_e) {\n return false;\n }\n });\n}\nconst transformProperties = ['transform', 'translate', 'scale', 'rotate', 'perspective'];\nconst willChangeValues = ['transform', 'translate', 'scale', 'rotate', 'perspective', 'filter'];\nconst containValues = ['paint', 'layout', 'strict', 'content'];\nfunction isContainingBlock(elementOrCss) {\n const webkit = isWebKit();\n const css = isElement(elementOrCss) ? getComputedStyle(elementOrCss) : elementOrCss;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n // https://drafts.csswg.org/css-transforms-2/#individual-transforms\n return transformProperties.some(value => css[value] ? css[value] !== 'none' : false) || (css.containerType ? css.containerType !== 'normal' : false) || !webkit && (css.backdropFilter ? css.backdropFilter !== 'none' : false) || !webkit && (css.filter ? css.filter !== 'none' : false) || willChangeValues.some(value => (css.willChange || '').includes(value)) || containValues.some(value => (css.contain || '').includes(value));\n}\nfunction getContainingBlock(element) {\n let currentNode = getParentNode(element);\n while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n if (isContainingBlock(currentNode)) {\n return currentNode;\n } else if (isTopLayer(currentNode)) {\n return null;\n }\n currentNode = getParentNode(currentNode);\n }\n return null;\n}\nfunction isWebKit() {\n if (typeof CSS === 'undefined' || !CSS.supports) return false;\n return CSS.supports('-webkit-backdrop-filter', 'none');\n}\nconst lastTraversableNodeNames = /*#__PURE__*/new Set(['html', 'body', '#document']);\nfunction isLastTraversableNode(node) {\n return lastTraversableNodeNames.has(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n if (isElement(element)) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n }\n return {\n scrollLeft: element.scrollX,\n scrollTop: element.scrollY\n };\n}\nfunction getParentNode(node) {\n if (getNodeName(node) === 'html') {\n return node;\n }\n const result =\n // Step into the shadow DOM of the parent of a slotted node.\n node.assignedSlot ||\n // DOM Element detected.\n node.parentNode ||\n // ShadowRoot detected.\n isShadowRoot(node) && node.host ||\n // Fallback.\n getDocumentElement(node);\n return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n const parentNode = getParentNode(node);\n if (isLastTraversableNode(parentNode)) {\n return node.ownerDocument ? node.ownerDocument.body : node.body;\n }\n if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n return parentNode;\n }\n return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list, traverseIframes) {\n var _node$ownerDocument2;\n if (list === void 0) {\n list = [];\n }\n if (traverseIframes === void 0) {\n traverseIframes = true;\n }\n const scrollableAncestor = getNearestOverflowAncestor(node);\n const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n const win = getWindow(scrollableAncestor);\n if (isBody) {\n const frameElement = getFrameElement(win);\n return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);\n }\n return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));\n}\nfunction getFrameElement(win) {\n return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getFrameElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isTopLayer, isWebKit };\n","let set;\nif (process.env.NODE_ENV !== 'production') {\n set = new Set();\n}\nexport function error(...messages) {\n if (process.env.NODE_ENV !== 'production') {\n const messageKey = messages.join(' ');\n if (!set.has(messageKey)) {\n set.add(messageKey);\n console.error(`Base UI: ${messageKey}`);\n }\n }\n}","'use client';\n\nimport _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const CompositeRootContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") CompositeRootContext.displayName = \"CompositeRootContext\";\nexport function useCompositeRootContext(optional = false) {\n const context = React.useContext(CompositeRootContext);\n if (context === undefined && !optional) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: CompositeRootContext is missing. Composite parts must be placed within <Composite.Root>.' : _formatErrorMessage(16));\n }\n return context;\n}","'use client';\n\nimport * as React from 'react';\nexport function useFocusableWhenDisabled(parameters) {\n const {\n focusableWhenDisabled,\n disabled,\n composite = false,\n tabIndex: tabIndexProp = 0,\n isNativeButton\n } = parameters;\n const isFocusableComposite = composite && focusableWhenDisabled !== false;\n const isNonFocusableComposite = composite && focusableWhenDisabled === false;\n\n // we can't explicitly assign `undefined` to any of these props because it\n // would otherwise prevent subsequently merged props from setting them\n const props = React.useMemo(() => {\n const additionalProps = {\n // allow Tabbing away from focusableWhenDisabled elements\n onKeyDown(event) {\n if (disabled && focusableWhenDisabled && event.key !== 'Tab') {\n event.preventDefault();\n }\n }\n };\n if (!composite) {\n additionalProps.tabIndex = tabIndexProp;\n if (!isNativeButton && disabled) {\n additionalProps.tabIndex = focusableWhenDisabled ? tabIndexProp : -1;\n }\n }\n if (isNativeButton && (focusableWhenDisabled || isFocusableComposite) || !isNativeButton && disabled) {\n additionalProps['aria-disabled'] = disabled;\n }\n if (isNativeButton && (!focusableWhenDisabled || isNonFocusableComposite)) {\n additionalProps.disabled = disabled;\n }\n return additionalProps;\n }, [composite, disabled, focusableWhenDisabled, isFocusableComposite, isNonFocusableComposite, isNativeButton, tabIndexProp]);\n return {\n props\n };\n}","'use client';\n\nimport * as React from 'react';\nimport { isHTMLElement } from '@floating-ui/utils/dom';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { error } from '@base-ui-components/utils/error';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { makeEventPreventable, mergeProps } from \"../merge-props/index.js\";\nimport { useCompositeRootContext } from \"../composite/root/CompositeRootContext.js\";\nimport { useFocusableWhenDisabled } from \"../utils/useFocusableWhenDisabled.js\";\nexport function useButton(parameters = {}) {\n const {\n disabled = false,\n focusableWhenDisabled,\n tabIndex = 0,\n native: isNativeButton = true\n } = parameters;\n const elementRef = React.useRef(null);\n const isCompositeItem = useCompositeRootContext(true) !== undefined;\n const isValidLink = useStableCallback(() => {\n const element = elementRef.current;\n return Boolean(element?.tagName === 'A' && element?.href);\n });\n const {\n props: focusableWhenDisabledProps\n } = useFocusableWhenDisabled({\n focusableWhenDisabled,\n disabled,\n composite: isCompositeItem,\n tabIndex,\n isNativeButton\n });\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(() => {\n if (!elementRef.current) {\n return;\n }\n const isButtonTag = elementRef.current.tagName === 'BUTTON';\n if (isNativeButton) {\n if (!isButtonTag) {\n error('A component that acts as a button was not rendered as a native <button>, which does not match the default. Ensure that the element passed to the `render` prop of the component is a real <button>, or set the `nativeButton` prop on the component to `false`.');\n }\n } else if (isButtonTag) {\n error('A component that acts as a button was rendered as a native <button>, which does not match the default. Ensure that the element passed to the `render` prop of the component is not a real <button>, or set the `nativeButton` prop on the component to `true`.');\n }\n }, [isNativeButton]);\n }\n\n // handles a disabled composite button rendering another button, e.g.\n // <Toolbar.Button disabled render={<Menu.Trigger />} />\n // the `disabled` prop needs to pass through 2 `useButton`s then finally\n // delete the `disabled` attribute from DOM\n const updateDisabled = React.useCallback(() => {\n const element = elementRef.current;\n if (!isButtonElement(element)) {\n return;\n }\n if (isCompositeItem && disabled && focusableWhenDisabledProps.disabled === undefined && element.disabled) {\n element.disabled = false;\n }\n }, [disabled, focusableWhenDisabledProps.disabled, isCompositeItem]);\n useIsoLayoutEffect(updateDisabled, [updateDisabled]);\n const getButtonProps = React.useCallback((externalProps = {}) => {\n const {\n onClick: externalOnClick,\n onMouseDown: externalOnMouseDown,\n onKeyUp: externalOnKeyUp,\n onKeyDown: externalOnKeyDown,\n onPointerDown: externalOnPointerDown,\n ...otherExternalProps\n } = externalProps;\n const type = isNativeButton ? 'button' : undefined;\n return mergeProps({\n type,\n onClick(event) {\n if (disabled) {\n event.preventDefault();\n return;\n }\n externalOnClick?.(event);\n },\n onMouseDown(event) {\n if (!disabled) {\n externalOnMouseDown?.(event);\n }\n },\n onKeyDown(event) {\n if (!disabled) {\n makeEventPreventable(event);\n externalOnKeyDown?.(event);\n }\n if (event.baseUIHandlerPrevented) {\n return;\n }\n const shouldClick = event.target === event.currentTarget && !isNativeButton && !isValidLink() && !disabled;\n const isEnterKey = event.key === 'Enter';\n const isSpaceKey = event.key === ' ';\n\n // Keyboard accessibility for non interactive elements\n if (shouldClick) {\n if (isSpaceKey || isEnterKey) {\n event.preventDefault();\n }\n if (isEnterKey) {\n externalOnClick?.(event);\n }\n }\n },\n onKeyUp(event) {\n // calling preventDefault in keyUp on a <button> will not dispatch a click event if Space is pressed\n // https://codesandbox.io/p/sandbox/button-keyup-preventdefault-dn7f0\n // Keyboard accessibility for non interactive elements\n if (!disabled) {\n makeEventPreventable(event);\n externalOnKeyUp?.(event);\n }\n if (event.baseUIHandlerPrevented) {\n return;\n }\n if (event.target === event.currentTarget && !isNativeButton && !disabled && event.key === ' ') {\n externalOnClick?.(event);\n }\n },\n onPointerDown(event) {\n if (disabled) {\n event.preventDefault();\n return;\n }\n externalOnPointerDown?.(event);\n }\n }, !isNativeButton ? {\n role: 'button'\n } : undefined, focusableWhenDisabledProps, otherExternalProps);\n }, [disabled, focusableWhenDisabledProps, isNativeButton, isValidLink]);\n const buttonRef = useStableCallback(element => {\n elementRef.current = element;\n updateDisabled();\n });\n return {\n getButtonProps,\n buttonRef\n };\n}\nfunction isButtonElement(elem) {\n return isHTMLElement(elem) && elem.tagName === 'BUTTON';\n}","const hasNavigator = typeof navigator !== 'undefined';\nconst nav = getNavigatorData();\nconst platform = getPlatform();\nconst userAgent = getUserAgent();\nexport const isWebKit = typeof CSS === 'undefined' || !CSS.supports ? false : CSS.supports('-webkit-backdrop-filter:none');\nexport const isIOS =\n// iPads can claim to be MacIntel\nnav.platform === 'MacIntel' && nav.maxTouchPoints > 1 ? true : /iP(hone|ad|od)|iOS/.test(nav.platform);\nexport const isFirefox = hasNavigator && /firefox/i.test(userAgent);\nexport const isSafari = hasNavigator && /apple/i.test(navigator.vendor);\nexport const isEdge = hasNavigator && /Edg/i.test(userAgent);\nexport const isAndroid = hasNavigator && /android/i.test(platform) || /android/i.test(userAgent);\nexport const isMac = hasNavigator && platform.toLowerCase().startsWith('mac') && !navigator.maxTouchPoints;\nexport const isJSDOM = userAgent.includes('jsdom/');\n\n// Avoid Chrome DevTools blue warning.\nfunction getNavigatorData() {\n if (!hasNavigator) {\n return {\n platform: '',\n maxTouchPoints: -1\n };\n }\n const uaData = navigator.userAgentData;\n if (uaData?.platform) {\n return {\n platform: uaData.platform,\n maxTouchPoints: navigator.maxTouchPoints\n };\n }\n return {\n platform: navigator.platform ?? '',\n maxTouchPoints: navigator.maxTouchPoints ?? -1\n };\n}\nfunction getUserAgent() {\n if (!hasNavigator) {\n return '';\n }\n const uaData = navigator.userAgentData;\n if (uaData && Array.isArray(uaData.brands)) {\n return uaData.brands.map(({\n brand,\n version\n }) => `${brand}/${version}`).join(' ');\n }\n return navigator.userAgent;\n}\nfunction getPlatform() {\n if (!hasNavigator) {\n return '';\n }\n const uaData = navigator.userAgentData;\n if (uaData?.platform) {\n return uaData.platform;\n }\n return navigator.platform ?? '';\n}","export const FOCUSABLE_ATTRIBUTE = 'data-base-ui-focusable';\nexport const ACTIVE_KEY = 'active';\nexport const SELECTED_KEY = 'selected';\nexport const TYPEABLE_SELECTOR = \"input:not([type='hidden']):not([disabled]),\" + \"[contenteditable]:not([contenteditable='false']),textarea:not([disabled])\";\nexport const ARROW_LEFT = 'ArrowLeft';\nexport const ARROW_RIGHT = 'ArrowRight';\nexport const ARROW_UP = 'ArrowUp';\nexport const ARROW_DOWN = 'ArrowDown';","import { isHTMLElement, isShadowRoot } from '@floating-ui/utils/dom';\nimport { isJSDOM } from '@base-ui-components/utils/detectBrowser';\nimport { FOCUSABLE_ATTRIBUTE, TYPEABLE_SELECTOR } from \"./constants.js\";\nexport function activeElement(doc) {\n let element = doc.activeElement;\n while (element?.shadowRoot?.activeElement != null) {\n element = element.shadowRoot.activeElement;\n }\n return element;\n}\nexport function contains(parent, child) {\n if (!parent || !child) {\n return false;\n }\n const rootNode = child.getRootNode?.();\n\n // First, attempt with faster native method\n if (parent.contains(child)) {\n return true;\n }\n\n // then fallback to custom implementation with Shadow DOM support\n if (rootNode && isShadowRoot(rootNode)) {\n let next = child;\n while (next) {\n if (parent === next) {\n return true;\n }\n next = next.parentNode || next.host;\n }\n }\n\n // Give up, the result is false\n return false;\n}\nexport function getTarget(event) {\n if ('composedPath' in event) {\n return event.composedPath()[0];\n }\n\n // TS thinks `event` is of type never as it assumes all browsers support\n // `composedPath()`, but browsers without shadow DOM don't.\n return event.target;\n}\nexport function isEventTargetWithin(event, node) {\n if (node == null) {\n return false;\n }\n if ('composedPath' in event) {\n return event.composedPath().includes(node);\n }\n\n // TS thinks `event` is of type never as it assumes all browsers support composedPath, but browsers without shadow dom don't\n const eventAgain = event;\n return eventAgain.target != null && node.contains(eventAgain.target);\n}\nexport function isRootElement(element) {\n return element.matches('html,body');\n}\nexport function getDocument(node) {\n return node?.ownerDocument || document;\n}\nexport function isTypeableElement(element) {\n return isHTMLElement(element) && element.matches(TYPEABLE_SELECTOR);\n}\nexport function isTypeableCombobox(element) {\n if (!element) {\n return false;\n }\n return element.getAttribute('role') === 'combobox' && isTypeableElement(element);\n}\nexport function matchesFocusVisible(element) {\n // We don't want to block focus from working with `visibleOnly`\n // (JSDOM doesn't match `:focus-visible` when the element has `:focus`)\n if (!element || isJSDOM) {\n return true;\n }\n try {\n return element.matches(':focus-visible');\n } catch (_e) {\n return true;\n }\n}\nexport function getFloatingFocusElement(floatingElement) {\n if (!floatingElement) {\n return null;\n }\n // Try to find the element that has `{...getFloatingProps()}` spread on it.\n // This indicates the floating element is acting as a positioning wrapper, and\n // so focus should be managed on the child element with the event handlers and\n // aria props.\n return floatingElement.hasAttribute(FOCUSABLE_ATTRIBUTE) ? floatingElement : floatingElement.querySelector(`[${FOCUSABLE_ATTRIBUTE}]`) || floatingElement;\n}","/* eslint-disable @typescript-eslint/no-loop-func */\n\nexport function getNodeChildren(nodes, id, onlyOpenChildren = true) {\n const directChildren = nodes.filter(node => node.parentId === id && (!onlyOpenChildren || node.context?.open));\n return directChildren.flatMap(child => [child, ...getNodeChildren(nodes, child.id, onlyOpenChildren)]);\n}\nexport function getDeepestNode(nodes, id) {\n let deepestNodeId;\n let maxDepth = -1;\n function findDeepest(nodeId, depth) {\n if (depth > maxDepth) {\n deepestNodeId = nodeId;\n maxDepth = depth;\n }\n const children = getNodeChildren(nodes, nodeId);\n children.forEach(child => {\n findDeepest(child.id, depth + 1);\n });\n }\n findDeepest(id, 0);\n return nodes.find(node => node.id === deepestNodeId);\n}\nexport function getNodeAncestors(nodes, id) {\n let allAncestors = [];\n let currentParentId = nodes.find(node => node.id === id)?.parentId;\n while (currentParentId) {\n const currentNode = nodes.find(node => node.id === currentParentId);\n currentParentId = currentNode?.parentId;\n if (currentNode) {\n allAncestors = allAncestors.concat(currentNode);\n }\n }\n return allAncestors;\n}","import { isAndroid, isJSDOM } from '@base-ui-components/utils/detectBrowser';\nexport function stopEvent(event) {\n event.preventDefault();\n event.stopPropagation();\n}\nexport function isReactEvent(event) {\n return 'nativeEvent' in event;\n}\n\n// License: https://github.com/adobe/react-spectrum/blob/b35d5c02fe900badccd0cf1a8f23bb593419f238/packages/@react-aria/utils/src/isVirtualEvent.ts\nexport function isVirtualClick(event) {\n // FIXME: Firefox is now emitting a deprecation warning for `mozInputSource`.\n // Try to find a workaround for this. `react-aria` source still has the check.\n if (event.mozInputSource === 0 && event.isTrusted) {\n return true;\n }\n if (isAndroid && event.pointerType) {\n return event.type === 'click' && event.buttons === 1;\n }\n return event.detail === 0 && !event.pointerType;\n}\nexport function isVirtualPointerEvent(event) {\n if (isJSDOM) {\n return false;\n }\n return !isAndroid && event.width === 0 && event.height === 0 || isAndroid && event.width === 1 && event.height === 1 && event.pressure === 0 && event.detail === 0 && event.pointerType === 'mouse' ||\n // iOS VoiceOver returns 0.333• for width/height.\n event.width < 1 && event.height < 1 && event.pressure === 0 && event.detail === 0 && event.pointerType === 'touch';\n}\nexport function isMouseLikePointerType(pointerType, strict) {\n // On some Linux machines with Chromium, mouse inputs return a `pointerType`\n // of \"pen\": https://github.com/floating-ui/floating-ui/issues/2015\n const values = ['mouse', 'pen'];\n if (!strict) {\n values.push('', undefined);\n }\n return values.includes(pointerType);\n}\nexport function isClickLikeEvent(event) {\n const type = event.type;\n return type === 'click' || type === 'mousedown' || type === 'keydown' || type === 'keyup';\n}","/*!\n* tabbable 6.3.0\n* @license MIT, https://github.com/focus-trap/tabbable/blob/master/LICENSE\n*/\n// NOTE: separate `:not()` selectors has broader browser support than the newer\n// `:not([inert], [inert] *)` (Feb 2023)\n// CAREFUL: JSDom does not support `:not([inert] *)` as a selector; using it causes\n// the entire query to fail, resulting in no nodes found, which will break a lot\n// of things... so we have to rely on JS to identify nodes inside an inert container\nvar candidateSelectors = ['input:not([inert])', 'select:not([inert])', 'textarea:not([inert])', 'a[href]:not([inert])', 'button:not([inert])', '[tabindex]:not(slot):not([inert])', 'audio[controls]:not([inert])', 'video[controls]:not([inert])', '[contenteditable]:not([contenteditable=\"false\"]):not([inert])', 'details>summary:first-of-type:not([inert])', 'details:not([inert])'];\nvar candidateSelector = /* #__PURE__ */candidateSelectors.join(',');\nvar NoElement = typeof Element === 'undefined';\nvar matches = NoElement ? function () {} : Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;\nvar getRootNode = !NoElement && Element.prototype.getRootNode ? function (element) {\n var _element$getRootNode;\n return element === null || element === void 0 ? void 0 : (_element$getRootNode = element.getRootNode) === null || _element$getRootNode === void 0 ? void 0 : _element$getRootNode.call(element);\n} : function (element) {\n return element === null || element === void 0 ? void 0 : element.ownerDocument;\n};\n\n/**\n * Determines if a node is inert or in an inert ancestor.\n * @param {Element} [node]\n * @param {boolean} [lookUp] If true and `node` is not inert, looks up at ancestors to\n * see if any of them are inert. If false, only `node` itself is considered.\n * @returns {boolean} True if inert itself or by way of being in an inert ancestor.\n * False if `node` is falsy.\n */\nvar _isInert = function isInert(node, lookUp) {\n var _node$getAttribute;\n if (lookUp === void 0) {\n lookUp = true;\n }\n // CAREFUL: JSDom does not support inert at all, so we can't use the `HTMLElement.inert`\n // JS API property; we have to check the attribute, which can either be empty or 'true';\n // if it's `null` (not specified) or 'false', it's an active element\n var inertAtt = node === null || node === void 0 ? void 0 : (_node$getAttribute = node.getAttribute) === null || _node$getAttribute === void 0 ? void 0 : _node$getAttribute.call(node, 'inert');\n var inert = inertAtt === '' || inertAtt === 'true';\n\n // NOTE: this could also be handled with `node.matches('[inert], :is([inert] *)')`\n // if it weren't for `matches()` not being a function on shadow roots; the following\n // code works for any kind of node\n // CAREFUL: JSDom does not appear to support certain selectors like `:not([inert] *)`\n // so it likely would not support `:is([inert] *)` either...\n var result = inert || lookUp && node && _isInert(node.parentNode); // recursive\n\n return result;\n};\n\n/**\n * Determines if a node's content is editable.\n * @param {Element} [node]\n * @returns True if it's content-editable; false if it's not or `node` is falsy.\n */\nvar isContentEditable = function isContentEditable(node) {\n var _node$getAttribute2;\n // CAREFUL: JSDom does not support the `HTMLElement.isContentEditable` API so we have\n // to use the attribute directly to check for this, which can either be empty or 'true';\n // if it's `null` (not specified) or 'false', it's a non-editable element\n var attValue = node === null || node === void 0 ? void 0 : (_node$getAttribute2 = node.getAttribute) === null || _node$getAttribute2 === void 0 ? void 0 : _node$getAttribute2.call(node, 'contenteditable');\n return attValue === '' || attValue === 'true';\n};\n\n/**\n * @param {Element} el container to check in\n * @param {boolean} includeContainer add container to check\n * @param {(node: Element) => boolean} filter filter candidates\n * @returns {Element[]}\n */\nvar getCandidates = function getCandidates(el, includeContainer, filter) {\n // even if `includeContainer=false`, we still have to check it for inertness because\n // if it's inert, all its children are inert\n if (_isInert(el)) {\n return [];\n }\n var candidates = Array.prototype.slice.apply(el.querySelectorAll(candidateSelector));\n if (includeContainer && matches.call(el, candidateSelector)) {\n candidates.unshift(el);\n }\n candidates = candidates.filter(filter);\n return candidates;\n};\n\n/**\n * @callback GetShadowRoot\n * @param {Element} element to check for shadow root\n * @returns {ShadowRoot|boolean} ShadowRoot if available or boolean indicating if a shadowRoot is attached but not available.\n */\n\n/**\n * @callback ShadowRootFilter\n * @param {Element} shadowHostNode the element which contains shadow content\n * @returns {boolean} true if a shadow root could potentially contain valid candidates.\n */\n\n/**\n * @typedef {Object} CandidateScope\n * @property {Element} scopeParent contains inner candidates\n * @property {Element[]} candidates list of candidates found in the scope parent\n */\n\n/**\n * @typedef {Object} IterativeOptions\n * @property {GetShadowRoot|boolean} getShadowRoot true if shadow support is enabled; falsy if not;\n * if a function, implies shadow support is enabled and either returns the shadow root of an element\n * or a boolean stating if it has an undisclosed shadow root\n * @property {(node: Element) => boolean} filter filter candidates\n * @property {boolean} flatten if true then result will flatten any CandidateScope into the returned list\n * @property {ShadowRootFilter} shadowRootFilter filter shadow roots;\n */\n\n/**\n * @param {Element[]} elements list of element containers to match candidates from\n * @param {boolean} includeContainer add container list to check\n * @param {IterativeOptions} options\n * @returns {Array.<Element|CandidateScope>}\n */\nvar _getCandidatesIteratively = function getCandidatesIteratively(elements, includeContainer, options) {\n var candidates = [];\n var elementsToCheck = Array.from(elements);\n while (elementsToCheck.length) {\n var element = elementsToCheck.shift();\n if (_isInert(element, false)) {\n // no need to look up since we're drilling down\n // anything inside this container will also be inert\n continue;\n }\n if (element.tagName === 'SLOT') {\n // add shadow dom slot scope (slot itself cannot be focusable)\n var assigned = element.assignedElements();\n var content = assigned.length ? assigned : element.children;\n var nestedCandidates = _getCandidatesIteratively(content, true, options);\n if (options.flatten) {\n candidates.push.apply(candidates, nestedCandidates);\n } else {\n candidates.push({\n scopeParent: element,\n candidates: nestedCandidates\n });\n }\n } else {\n // check candidate element\n var validCandidate = matches.call(element, candidateSelector);\n if (validCandidate && options.filter(element) && (includeContainer || !elements.includes(element))) {\n candidates.push(element);\n }\n\n // iterate over shadow content if possible\n var shadowRoot = element.shadowRoot ||\n // check for an undisclosed shadow\n typeof options.getShadowRoot === 'function' && options.getShadowRoot(element);\n\n // no inert look up because we're already drilling down and checking for inertness\n // on the way down, so all containers to this root node should have already been\n // vetted as non-inert\n var validShadowRoot = !_isInert(shadowRoot, false) && (!options.shadowRootFilter || options.shadowRootFilter(element));\n if (shadowRoot && validShadowRoot) {\n // add shadow dom scope IIF a shadow root node was given; otherwise, an undisclosed\n // shadow exists, so look at light dom children as fallback BUT create a scope for any\n // child candidates found because they're likely slotted elements (elements that are\n // children of the web component element (which has the shadow), in the light dom, but\n // slotted somewhere _inside_ the undisclosed shadow) -- the scope is created below,\n // _after_ we return from this recursive call\n var _nestedCandidates = _getCandidatesIteratively(shadowRoot === true ? element.children : shadowRoot.children, true, options);\n if (options.flatten) {\n candidates.push.apply(candidates, _nestedCandidates);\n } else {\n candidates.push({\n scopeParent: element,\n candidates: _nestedCandidates\n });\n }\n } else {\n // there's not shadow so just dig into the element's (light dom) children\n // __without__ giving the element special scope treatment\n elementsToCheck.unshift.apply(elementsToCheck, element.children);\n }\n }\n }\n return candidates;\n};\n\n/**\n * @private\n * Determines if the node has an explicitly specified `tabindex` attribute.\n * @param {HTMLElement} node\n * @returns {boolean} True if so; false if not.\n */\nvar hasTabIndex = function hasTabIndex(node) {\n return !isNaN(parseInt(node.getAttribute('tabindex'), 10));\n};\n\n/**\n * Determine the tab index of a given node.\n * @param {HTMLElement} node\n * @returns {number} Tab order (negative, 0, or positive number).\n * @throws {Error} If `node` is falsy.\n */\nvar getTabIndex = function getTabIndex(node) {\n if (!node) {\n throw new Error('No node provided');\n }\n if (node.tabIndex < 0) {\n // in Chrome, <details/>, <audio controls/> and <video controls/> elements get a default\n // `tabIndex` of -1 when the 'tabindex' attribute isn't specified in the DOM,\n // yet they are still part of the regular tab order; in FF, they get a default\n // `tabIndex` of 0; since Chrome still puts those elements in the regular tab\n // order, consider their tab index to be 0.\n // Also browsers do not return `tabIndex` correctly for contentEditable nodes;\n // so if they don't have a tabindex attribute specifically set, assume it's 0.\n if ((/^(AUDIO|VIDEO|DETAILS)$/.test(node.tagName) || isContentEditable(node)) && !hasTabIndex(node)) {\n return 0;\n }\n }\n return node.tabIndex;\n};\n\n/**\n * Determine the tab index of a given node __for sort order purposes__.\n * @param {HTMLElement} node\n * @param {boolean} [isScope] True for a custom element with shadow root or slot that, by default,\n * has tabIndex -1, but needs to be sorted by document order in order for its content to be\n * inserted into the correct sort position.\n * @returns {number} Tab order (negative, 0, or positive number).\n */\nvar getSortOrderTabIndex = function getSortOrderTabIndex(node, isScope) {\n var tabIndex = getTabIndex(node);\n if (tabIndex < 0 && isScope && !hasTabIndex(node)) {\n return 0;\n }\n return tabIndex;\n};\nvar sortOrderedTabbables = function sortOrderedTabbables(a, b) {\n return a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex;\n};\nvar isInput = function isInput(node) {\n return node.tagName === 'INPUT';\n};\nvar isHiddenInput = function isHiddenInput(node) {\n return isInput(node) && node.type === 'hidden';\n};\nvar isDetailsWithSummary = function isDetailsWithSummary(node) {\n var r = node.tagName === 'DETAILS' && Array.prototype.slice.apply(node.children).some(function (child) {\n return child.tagName === 'SUMMARY';\n });\n return r;\n};\nvar getCheckedRadio = function getCheckedRadio(nodes, form) {\n for (var i = 0; i < nodes.length; i++) {\n if (nodes[i].checked && nodes[i].form === form) {\n return nodes[i];\n }\n }\n};\nvar isTabbableRadio = function isTabbableRadio(node) {\n if (!node.name) {\n return true;\n }\n var radioScope = node.form || getRootNode(node);\n var queryRadios = function queryRadios(name) {\n return radioScope.querySelectorAll('input[type=\"radio\"][name=\"' + name + '\"]');\n };\n var radioSet;\n if (typeof window !== 'undefined' && typeof window.CSS !== 'undefined' && typeof window.CSS.escape === 'function') {\n radioSet = queryRadios(window.CSS.escape(node.name));\n } else {\n try {\n radioSet = queryRadios(node.name);\n } catch (err) {\n // eslint-disable-next-line no-console\n console.error('Looks like you have a radio button with a name attribute containing invalid CSS selector characters and need the CSS.escape polyfill: %s', err.message);\n return false;\n }\n }\n var checked = getCheckedRadio(radioSet, node.form);\n return !checked || checked === node;\n};\nvar isRadio = function isRadio(node) {\n return isInput(node) && node.type === 'radio';\n};\nvar isNonTabbableRadio = function isNonTabbableRadio(node) {\n return isRadio(node) && !isTabbableRadio(node);\n};\n\n// determines if a node is ultimately attached to the window's document\nvar isNodeAttached = function isNodeAttached(node) {\n var _nodeRoot;\n // The root node is the shadow root if the node is in a shadow DOM; some document otherwise\n // (but NOT _the_ document; see second 'If' comment below for more).\n // If rootNode is shadow root, it'll have a host, which is the element to which the shadow\n // is attached, and the one we need to check if it's in the document or not (because the\n // shadow, and all nodes it contains, is never considered in the document since shadows\n // behave like self-contained DOMs; but if the shadow's HOST, which is part of the document,\n // is hidden, or is not in the document itself but is detached, it will affect the shadow's\n // visibility, including all the nodes it contains). The host could be any normal node,\n // or a custom element (i.e. web component). Either way, that's the one that is considered\n // part of the document, not the shadow root, nor any of its children (i.e. the node being\n // tested).\n // To further complicate things, we have to look all the way up until we find a shadow HOST\n // that is attached (or find none) because the node might be in nested shadows...\n // If rootNode is not a shadow root, it won't have a host, and so rootNode should be the\n // document (per the docs) and while it's a Document-type object, that document does not\n // appear to be the same as the node's `ownerDocument` for some reason, so it's safer\n // to ignore the rootNode at this point, and use `node.ownerDocument`. Otherwise,\n // using `rootNode.contains(node)` will _always_ be true we'll get false-positives when\n // node is actually detached.\n // NOTE: If `nodeRootHost` or `node` happens to be the `document` itself (which is possible\n // if a tabbable/focusable node was quickly added to the DOM, focused, and then removed\n // from the DOM as in https://github.com/focus-trap/focus-trap-react/issues/905), then\n // `ownerDocument` will be `null`, hence the optional chaining on it.\n var nodeRoot = node && getRootNode(node);\n var nodeRootHost = (_nodeRoot = nodeRoot) === null || _nodeRoot === void 0 ? void 0 : _nodeRoot.host;\n\n // in some cases, a detached node will return itself as the root instead of a document or\n // shadow root object, in which case, we shouldn't try to look further up the host chain\n var attached = false;\n if (nodeRoot && nodeRoot !== node) {\n var _nodeRootHost, _nodeRootHost$ownerDo, _node$ownerDocument;\n attached = !!((_nodeRootHost = nodeRootHost) !== null && _nodeRootHost !== void 0 && (_nodeRootHost$ownerDo = _nodeRootHost.ownerDocument) !== null && _nodeRootHost$ownerDo !== void 0 && _nodeRootHost$ownerDo.contains(nodeRootHost) || node !== null && node !== void 0 && (_node$ownerDocument = node.ownerDocument) !== null && _node$ownerDocument !== void 0 && _node$ownerDocument.contains(node));\n while (!attached && nodeRootHost) {\n var _nodeRoot2, _nodeRootHost2, _nodeRootHost2$ownerD;\n // since it's not attached and we have a root host, the node MUST be in a nested shadow DOM,\n // which means we need to get the host's host and check if that parent host is contained\n // in (i.e. attached to) the document\n nodeRoot = getRootNode(nodeRootHost);\n nodeRootHost = (_nodeRoot2 = nodeRoot) === null || _nodeRoot2 === void 0 ? void 0 : _nodeRoot2.host;\n attached = !!((_nodeRootHost2 = nodeRootHost) !== null && _nodeRootHost2 !== void 0 && (_nodeRootHost2$ownerD = _nodeRootHost2.ownerDocument) !== null && _nodeRootHost2$ownerD !== void 0 && _nodeRootHost2$ownerD.contains(nodeRootHost));\n }\n }\n return attached;\n};\nvar isZeroArea = function isZeroArea(node) {\n var _node$getBoundingClie = node.getBoundingClientRect(),\n width = _node$getBoundingClie.width,\n height = _node$getBoundingClie.height;\n return width === 0 && height === 0;\n};\nvar isHidden = function isHidden(node, _ref) {\n var displayCheck = _ref.displayCheck,\n getShadowRoot = _ref.getShadowRoot;\n if (displayCheck === 'full-native') {\n if ('checkVisibility' in node) {\n // Chrome >= 105, Edge >= 105, Firefox >= 106, Safari >= 17.4\n // @see https://developer.mozilla.org/en-US/docs/Web/API/Element/checkVisibility#browser_compatibility\n var visible = node.checkVisibility({\n // Checking opacity might be desirable for some use cases, but natively,\n // opacity zero elements _are_ focusable and tabbable.\n checkOpacity: false,\n opacityProperty: false,\n contentVisibilityAuto: true,\n visibilityProperty: true,\n // This is an alias for `visibilityProperty`. Contemporary browsers\n // support both. However, this alias has wider browser support (Chrome\n // >= 105 and Firefox >= 106, vs. Chrome >= 121 and Firefox >= 122), so\n // we include it anyway.\n checkVisibilityCSS: true\n });\n return !visible;\n }\n // Fall through to manual visibility checks\n }\n\n // NOTE: visibility will be `undefined` if node is detached from the document\n // (see notes about this further down), which means we will consider it visible\n // (this is legacy behavior from a very long way back)\n // NOTE: we check this regardless of `displayCheck=\"none\"` because this is a\n // _visibility_ check, not a _display_ check\n if (getComputedStyle(node).visibility === 'hidden') {\n return true;\n }\n var isDirectSummary = matches.call(node, 'details>summary:first-of-type');\n var nodeUnderDetails = isDirectSummary ? node.parentElement : node;\n if (matches.call(nodeUnderDetails, 'details:not([open]) *')) {\n return true;\n }\n if (!displayCheck || displayCheck === 'full' ||\n // full-native can run this branch when it falls through in case\n // Element#checkVisibility is unsupported\n displayCheck === 'full-native' || displayCheck === 'legacy-full') {\n if (typeof getShadowRoot === 'function') {\n // figure out if we should consider the node to be in an undisclosed shadow and use the\n // 'non-zero-area' fallback\n var originalNode = node;\n while (node) {\n var parentElement = node.parentElement;\n var rootNode = getRootNode(node);\n if (parentElement && !parentElement.shadowRoot && getShadowRoot(parentElement) === true // check if there's an undisclosed shadow\n ) {\n // node has an undisclosed shadow which means we can only treat it as a black box, so we\n // fall back to a non-zero-area test\n return isZeroArea(node);\n } else if (node.assignedSlot) {\n // iterate up slot\n node = node.assignedSlot;\n } else if (!parentElement && rootNode !== node.ownerDocument) {\n // cross shadow boundary\n node = rootNode.host;\n } else {\n // iterate up normal dom\n node = parentElement;\n }\n }\n node = originalNode;\n }\n // else, `getShadowRoot` might be true, but all that does is enable shadow DOM support\n // (i.e. it does not also presume that all nodes might have undisclosed shadows); or\n // it might be a falsy value, which means shadow DOM support is disabled\n\n // Since we didn't find it sitting in an undisclosed shadow (or shadows are disabled)\n // now we can just test to see if it would normally be visible or not, provided it's\n // attached to the main document.\n // NOTE: We must consider case where node is inside a shadow DOM and given directly to\n // `isTabbable()` or `isFocusable()` -- regardless of `getShadowRoot` option setting.\n\n if (isNodeAttached(node)) {\n // this works wherever the node is: if there's at least one client rect, it's\n // somehow displayed; it also covers the CSS 'display: contents' case where the\n // node itself is hidden in place of its contents; and there's no need to search\n // up the hierarchy either\n return !node.getClientRects().length;\n }\n\n // Else, the node isn't attached to the document, which means the `getClientRects()`\n // API will __always__ return zero rects (this can happen, for example, if React\n // is used to render nodes onto a detached tree, as confirmed in this thread:\n // https://github.com/facebook/react/issues/9117#issuecomment-284228870)\n //\n // It also means that even window.getComputedStyle(node).display will return `undefined`\n // because styles are only computed for nodes that are in the document.\n //\n // NOTE: THIS HAS BEEN THE CASE FOR YEARS. It is not new, nor is it caused by tabbable\n // somehow. Though it was never stated officially, anyone who has ever used tabbable\n // APIs on nodes in detached containers has actually implicitly used tabbable in what\n // was later (as of v5.2.0 on Apr 9, 2021) called `displayCheck=\"none\"` mode -- essentially\n // considering __everything__ to be visible because of the innability to determine styles.\n //\n // v6.0.0: As of this major release, the default 'full' option __no longer treats detached\n // nodes as visible with the 'none' fallback.__\n if (displayCheck !== 'legacy-full') {\n return true; // hidden\n }\n // else, fallback to 'none' mode and consider the node visible\n } else if (displayCheck === 'non-zero-area') {\n // NOTE: Even though this tests that the node's client rect is non-zero to determine\n // whether it's displayed, and that a detached node will __always__ have a zero-area\n // client rect, we don't special-case for whether the node is attached or not. In\n // this mode, we do want to consider nodes that have a zero area to be hidden at all\n // times, and that includes attached or not.\n return isZeroArea(node);\n }\n\n // visible, as far as we can tell, or per current `displayCheck=none` mode, we assume\n // it's visible\n return false;\n};\n\n// form fields (nested) inside a disabled fieldset are not focusable/tabbable\n// unless they are in the _first_ <legend> element of the top-most disabled\n// fieldset\nvar isDisabledFromFieldset = function isDisabledFromFieldset(node) {\n if (/^(INPUT|BUTTON|SELECT|TEXTAREA)$/.test(node.tagName)) {\n var parentNode = node.parentElement;\n // check if `node` is contained in a disabled <fieldset>\n while (parentNode) {\n if (parentNode.tagName === 'FIELDSET' && parentNode.disabled) {\n // look for the first <legend> among the children of the disabled <fieldset>\n for (var i = 0; i < parentNode.children.length; i++) {\n var child = parentNode.children.item(i);\n // when the first <legend> (in document order) is found\n if (child.tagName === 'LEGEND') {\n // if its parent <fieldset> is not nested in another disabled <fieldset>,\n // return whether `node` is a descendant of its first <legend>\n return matches.call(parentNode, 'fieldset[disabled] *') ? true : !child.contains(node);\n }\n }\n // the disabled <fieldset> containing `node` has no <legend>\n return true;\n }\n parentNode = parentNode.parentElement;\n }\n }\n\n // else, node's tabbable/focusable state should not be affected by a fieldset's\n // enabled/disabled state\n return false;\n};\nvar isNodeMatchingSelectorFocusable = function isNodeMatchingSelectorFocusable(options, node) {\n if (node.disabled ||\n // we must do an inert look up to filter out any elements inside an inert ancestor\n // because we're limited in the type of selectors we can use in JSDom (see related\n // note related to `candidateSelectors`)\n _isInert(node) || isHiddenInput(node) || isHidden(node, options) ||\n // For a details element with a summary, the summary element gets the focus\n isDetailsWithSummary(node) || isDisabledFromFieldset(node)) {\n return false;\n }\n return true;\n};\nvar isNodeMatchingSelectorTabbable = function isNodeMatchingSelectorTabbable(options, node) {\n if (isNonTabbableRadio(node) || getTabIndex(node) < 0 || !isNodeMatchingSelectorFocusable(options, node)) {\n return false;\n }\n return true;\n};\nvar isShadowRootTabbable = function isShadowRootTabbable(shadowHostNode) {\n var tabIndex = parseInt(shadowHostNode.getAttribute('tabindex'), 10);\n if (isNaN(tabIndex) || tabIndex >= 0) {\n return true;\n }\n // If a custom element has an explicit negative tabindex,\n // browsers will not allow tab targeting said element's children.\n return false;\n};\n\n/**\n * @param {Array.<Element|CandidateScope>} candidates\n * @returns Element[]\n */\nvar _sortByOrder = function sortByOrder(candidates) {\n var regularTabbables = [];\n var orderedTabbables = [];\n candidates.forEach(function (item, i) {\n var isScope = !!item.scopeParent;\n var element = isScope ? item.scopeParent : item;\n var candidateTabindex = getSortOrderTabIndex(element, isScope);\n var elements = isScope ? _sortByOrder(item.candidates) : element;\n if (candidateTabindex === 0) {\n isScope ? regularTabbables.push.apply(regularTabbables, elements) : regularTabbables.push(element);\n } else {\n orderedTabbables.push({\n documentOrder: i,\n tabIndex: candidateTabindex,\n item: item,\n isScope: isScope,\n content: elements\n });\n }\n });\n return orderedTabbables.sort(sortOrderedTabbables).reduce(function (acc, sortable) {\n sortable.isScope ? acc.push.apply(acc, sortable.content) : acc.push(sortable.content);\n return acc;\n }, []).concat(regularTabbables);\n};\nvar tabbable = function tabbable(container, options) {\n options = options || {};\n var candidates;\n if (options.getShadowRoot) {\n candidates = _getCandidatesIteratively([container], options.includeContainer, {\n filter: isNodeMatchingSelectorTabbable.bind(null, options),\n flatten: false,\n getShadowRoot: options.getShadowRoot,\n shadowRootFilter: isShadowRootTabbable\n });\n } else {\n candidates = getCandidates(container, options.includeContainer, isNodeMatchingSelectorTabbable.bind(null, options));\n }\n return _sortByOrder(candidates);\n};\nvar focusable = function focusable(container, options) {\n options = options || {};\n var candidates;\n if (options.getShadowRoot) {\n candidates = _getCandidatesIteratively([container], options.includeContainer, {\n filter: isNodeMatchingSelectorFocusable.bind(null, options),\n flatten: true,\n getShadowRoot: options.getShadowRoot\n });\n } else {\n candidates = getCandidates(container, options.includeContainer, isNodeMatchingSelectorFocusable.bind(null, options));\n }\n return candidates;\n};\nvar isTabbable = function isTabbable(node, options) {\n options = options || {};\n if (!node) {\n throw new Error('No node provided');\n }\n if (matches.call(node, candidateSelector) === false) {\n return false;\n }\n return isNodeMatchingSelectorTabbable(options, node);\n};\nvar focusableCandidateSelector = /* #__PURE__ */candidateSelectors.concat('iframe').join(',');\nvar isFocusable = function isFocusable(node, options) {\n options = options || {};\n if (!node) {\n throw new Error('No node provided');\n }\n if (matches.call(node, focusableCandidateSelector) === false) {\n return false;\n }\n return isNodeMatchingSelectorFocusable(options, node);\n};\n\nexport { focusable, getTabIndex, isFocusable, isTabbable, tabbable };\n//# sourceMappingURL=index.esm.js.map\n","import { tabbable } from 'tabbable';\nimport { activeElement, contains, getDocument } from \"./element.js\";\nexport const getTabbableOptions = () => ({\n getShadowRoot: true,\n displayCheck:\n // JSDOM does not support the `tabbable` library. To solve this we can\n // check if `ResizeObserver` is a real function (not polyfilled), which\n // determines if the current environment is JSDOM-like.\n typeof ResizeObserver === 'function' && ResizeObserver.toString().includes('[native code]') ? 'full' : 'none'\n});\nfunction getTabbableIn(container, dir) {\n const list = tabbable(container, getTabbableOptions());\n const len = list.length;\n if (len === 0) {\n return undefined;\n }\n const active = activeElement(getDocument(container));\n const index = list.indexOf(active);\n // eslint-disable-next-line no-nested-ternary\n const nextIndex = index === -1 ? dir === 1 ? 0 : len - 1 : index + dir;\n return list[nextIndex];\n}\nexport function getNextTabbable(referenceElement) {\n return getTabbableIn(getDocument(referenceElement).body, 1) || referenceElement;\n}\nexport function getPreviousTabbable(referenceElement) {\n return getTabbableIn(getDocument(referenceElement).body, -1) || referenceElement;\n}\nfunction getTabbableNearElement(referenceElement, dir) {\n if (!referenceElement) {\n return null;\n }\n const list = tabbable(getDocument(referenceElement).body, getTabbableOptions());\n const elementCount = list.length;\n if (elementCount === 0) {\n return null;\n }\n const index = list.indexOf(referenceElement);\n if (index === -1) {\n return null;\n }\n const nextIndex = (index + dir + elementCount) % elementCount;\n return list[nextIndex];\n}\nexport function getTabbableAfterElement(referenceElement) {\n return getTabbableNearElement(referenceElement, 1);\n}\nexport function getTabbableBeforeElement(referenceElement) {\n return getTabbableNearElement(referenceElement, -1);\n}\nexport function isOutsideEvent(event, container) {\n const containerElement = container || event.currentTarget;\n const relatedTarget = event.relatedTarget;\n return !relatedTarget || !contains(containerElement, relatedTarget);\n}\nexport function disableFocusInside(container) {\n const tabbableElements = tabbable(container, getTabbableOptions());\n tabbableElements.forEach(element => {\n element.dataset.tabindex = element.getAttribute('tabindex') || '';\n element.setAttribute('tabindex', '-1');\n });\n}\nexport function enableFocusInside(container) {\n const elements = container.querySelectorAll('[data-tabindex]');\n elements.forEach(element => {\n const tabindex = element.dataset.tabindex;\n delete element.dataset.tabindex;\n if (tabindex) {\n element.setAttribute('tabindex', tabindex);\n } else {\n element.removeAttribute('tabindex');\n }\n });\n}","import { isHTMLElement } from '@floating-ui/utils/dom';\nexport { stopEvent, isIndexOutOfListBounds, isListIndexDisabled, createGridCellMap, findNonDisabledListIndex, getGridCellIndexOfCorner, getGridCellIndices, getGridNavigatedIndex, getMaxListIndex, getMinListIndex } from \"../floating-ui-react/utils.js\";\nexport const ARROW_UP = 'ArrowUp';\nexport const ARROW_DOWN = 'ArrowDown';\nexport const ARROW_LEFT = 'ArrowLeft';\nexport const ARROW_RIGHT = 'ArrowRight';\nexport const HOME = 'Home';\nexport const END = 'End';\nexport const HORIZONTAL_KEYS = new Set([ARROW_LEFT, ARROW_RIGHT]);\nexport const HORIZONTAL_KEYS_WITH_EXTRA_KEYS = new Set([ARROW_LEFT, ARROW_RIGHT, HOME, END]);\nexport const VERTICAL_KEYS = new Set([ARROW_UP, ARROW_DOWN]);\nexport const VERTICAL_KEYS_WITH_EXTRA_KEYS = new Set([ARROW_UP, ARROW_DOWN, HOME, END]);\nexport const ARROW_KEYS = new Set([...HORIZONTAL_KEYS, ...VERTICAL_KEYS]);\nexport const ALL_KEYS = new Set([...ARROW_KEYS, HOME, END]);\nexport const COMPOSITE_KEYS = new Set([ARROW_UP, ARROW_DOWN, ARROW_LEFT, ARROW_RIGHT, HOME, END]);\nexport const SHIFT = 'Shift';\nexport const CONTROL = 'Control';\nexport const ALT = 'Alt';\nexport const META = 'Meta';\nexport const MODIFIER_KEYS = new Set([SHIFT, CONTROL, ALT, META]);\nfunction isInputElement(element) {\n return isHTMLElement(element) && element.tagName === 'INPUT';\n}\nexport function isNativeInput(element) {\n if (isInputElement(element) && element.selectionStart != null) {\n return true;\n }\n if (isHTMLElement(element) && element.tagName === 'TEXTAREA') {\n return true;\n }\n return false;\n}\nexport function scrollIntoViewIfNeeded(scrollContainer, element, direction, orientation) {\n if (!scrollContainer || !element || !element.scrollTo) {\n return;\n }\n let targetX = scrollContainer.scrollLeft;\n let targetY = scrollContainer.scrollTop;\n const isOverflowingX = scrollContainer.clientWidth < scrollContainer.scrollWidth;\n const isOverflowingY = scrollContainer.clientHeight < scrollContainer.scrollHeight;\n if (isOverflowingX && orientation !== 'vertical') {\n const elementOffsetLeft = getOffset(scrollContainer, element, 'left');\n const containerStyles = getStyles(scrollContainer);\n const elementStyles = getStyles(element);\n if (direction === 'ltr') {\n if (elementOffsetLeft + element.offsetWidth + elementStyles.scrollMarginRight > scrollContainer.scrollLeft + scrollContainer.clientWidth - containerStyles.scrollPaddingRight) {\n // overflow to the right, scroll to align right edges\n targetX = elementOffsetLeft + element.offsetWidth + elementStyles.scrollMarginRight - scrollContainer.clientWidth + containerStyles.scrollPaddingRight;\n } else if (elementOffsetLeft - elementStyles.scrollMarginLeft < scrollContainer.scrollLeft + containerStyles.scrollPaddingLeft) {\n // overflow to the left, scroll to align left edges\n targetX = elementOffsetLeft - elementStyles.scrollMarginLeft - containerStyles.scrollPaddingLeft;\n }\n }\n if (direction === 'rtl') {\n if (elementOffsetLeft - elementStyles.scrollMarginRight < scrollContainer.scrollLeft + containerStyles.scrollPaddingLeft) {\n // overflow to the left, scroll to align left edges\n targetX = elementOffsetLeft - elementStyles.scrollMarginLeft - containerStyles.scrollPaddingLeft;\n } else if (elementOffsetLeft + element.offsetWidth + elementStyles.scrollMarginRight > scrollContainer.scrollLeft + scrollContainer.clientWidth - containerStyles.scrollPaddingRight) {\n // overflow to the right, scroll to align right edges\n targetX = elementOffsetLeft + element.offsetWidth + elementStyles.scrollMarginRight - scrollContainer.clientWidth + containerStyles.scrollPaddingRight;\n }\n }\n }\n if (isOverflowingY && orientation !== 'horizontal') {\n const elementOffsetTop = getOffset(scrollContainer, element, 'top');\n const containerStyles = getStyles(scrollContainer);\n const elementStyles = getStyles(element);\n if (elementOffsetTop - elementStyles.scrollMarginTop < scrollContainer.scrollTop + containerStyles.scrollPaddingTop) {\n // overflow upwards, align top edges\n targetY = elementOffsetTop - elementStyles.scrollMarginTop - containerStyles.scrollPaddingTop;\n } else if (elementOffsetTop + element.offsetHeight + elementStyles.scrollMarginBottom > scrollContainer.scrollTop + scrollContainer.clientHeight - containerStyles.scrollPaddingBottom) {\n // overflow downwards, align bottom edges\n targetY = elementOffsetTop + element.offsetHeight + elementStyles.scrollMarginBottom - scrollContainer.clientHeight + containerStyles.scrollPaddingBottom;\n }\n }\n scrollContainer.scrollTo({\n left: targetX,\n top: targetY,\n behavior: 'auto'\n });\n}\nfunction getOffset(ancestor, element, side) {\n const propName = side === 'left' ? 'offsetLeft' : 'offsetTop';\n let result = 0;\n while (element.offsetParent) {\n result += element[propName];\n if (element.offsetParent === ancestor) {\n break;\n }\n element = element.offsetParent;\n }\n return result;\n}\nfunction getStyles(element) {\n const styles = getComputedStyle(element);\n return {\n scrollMarginTop: parseFloat(styles.scrollMarginTop) || 0,\n scrollMarginRight: parseFloat(styles.scrollMarginRight) || 0,\n scrollMarginBottom: parseFloat(styles.scrollMarginBottom) || 0,\n scrollMarginLeft: parseFloat(styles.scrollMarginLeft) || 0,\n scrollPaddingTop: parseFloat(styles.scrollPaddingTop) || 0,\n scrollPaddingRight: parseFloat(styles.scrollPaddingRight) || 0,\n scrollPaddingBottom: parseFloat(styles.scrollPaddingBottom) || 0,\n scrollPaddingLeft: parseFloat(styles.scrollPaddingLeft) || 0\n };\n}","'use client';\n\nimport * as React from 'react';\nimport { isElementDisabled } from '@base-ui-components/utils/isElementDisabled';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { triggerOpenStateMapping } from \"../../utils/collapsibleOpenStateMapping.js\";\nimport { useButton } from \"../../use-button/index.js\";\nimport { useCollapsibleRootContext } from \"../../collapsible/root/CollapsibleRootContext.js\";\nimport { ARROW_DOWN, ARROW_UP, ARROW_RIGHT, ARROW_LEFT, HOME, END, stopEvent } from \"../../composite/composite.js\";\nimport { useAccordionRootContext } from \"../root/AccordionRootContext.js\";\nimport { useAccordionItemContext } from \"../item/AccordionItemContext.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nconst SUPPORTED_KEYS = new Set([ARROW_DOWN, ARROW_UP, ARROW_RIGHT, ARROW_LEFT, HOME, END]);\nfunction getActiveTriggers(accordionItemRefs) {\n const {\n current: accordionItemElements\n } = accordionItemRefs;\n const output = [];\n for (let i = 0; i < accordionItemElements.length; i += 1) {\n const section = accordionItemElements[i];\n if (!isElementDisabled(section)) {\n const trigger = section?.querySelector('[type=\"button\"]');\n if (!isElementDisabled(trigger)) {\n output.push(trigger);\n }\n }\n }\n return output;\n}\n\n/**\n * A button that opens and closes the corresponding panel.\n * Renders a `<button>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\n\nexport const AccordionTrigger = /*#__PURE__*/React.forwardRef(function AccordionTrigger(componentProps, forwardedRef) {\n const {\n disabled: disabledProp,\n className,\n id: idProp,\n render,\n nativeButton = true,\n ...elementProps\n } = componentProps;\n const {\n panelId,\n open,\n handleTrigger,\n disabled: contextDisabled\n } = useCollapsibleRootContext();\n const disabled = disabledProp ?? contextDisabled;\n const {\n getButtonProps,\n buttonRef\n } = useButton({\n disabled,\n focusableWhenDisabled: true,\n native: nativeButton\n });\n const {\n accordionItemRefs,\n direction,\n loopFocus,\n orientation\n } = useAccordionRootContext();\n const isRtl = direction === 'rtl';\n const isHorizontal = orientation === 'horizontal';\n const {\n state,\n setTriggerId,\n triggerId: id\n } = useAccordionItemContext();\n useIsoLayoutEffect(() => {\n if (idProp) {\n setTriggerId(idProp);\n }\n return () => {\n setTriggerId(undefined);\n };\n }, [idProp, setTriggerId]);\n const props = React.useMemo(() => ({\n 'aria-controls': open ? panelId : undefined,\n 'aria-expanded': open,\n disabled,\n id,\n onClick: handleTrigger,\n onKeyDown(event) {\n if (!SUPPORTED_KEYS.has(event.key)) {\n return;\n }\n stopEvent(event);\n const triggers = getActiveTriggers(accordionItemRefs);\n const numOfEnabledTriggers = triggers.length;\n const lastIndex = numOfEnabledTriggers - 1;\n let nextIndex = -1;\n const thisIndex = triggers.indexOf(event.target);\n function toNext() {\n if (loopFocus) {\n nextIndex = thisIndex + 1 > lastIndex ? 0 : thisIndex + 1;\n } else {\n nextIndex = Math.min(thisIndex + 1, lastIndex);\n }\n }\n function toPrev() {\n if (loopFocus) {\n nextIndex = thisIndex === 0 ? lastIndex : thisIndex - 1;\n } else {\n nextIndex = thisIndex - 1;\n }\n }\n switch (event.key) {\n case ARROW_DOWN:\n if (!isHorizontal) {\n toNext();\n }\n break;\n case ARROW_UP:\n if (!isHorizontal) {\n toPrev();\n }\n break;\n case ARROW_RIGHT:\n if (isHorizontal) {\n if (isRtl) {\n toPrev();\n } else {\n toNext();\n }\n }\n break;\n case ARROW_LEFT:\n if (isHorizontal) {\n if (isRtl) {\n toNext();\n } else {\n toPrev();\n }\n }\n break;\n case 'Home':\n nextIndex = 0;\n break;\n case 'End':\n nextIndex = lastIndex;\n break;\n default:\n break;\n }\n if (nextIndex > -1) {\n triggers[nextIndex].focus();\n }\n }\n }), [accordionItemRefs, disabled, handleTrigger, id, isHorizontal, isRtl, loopFocus, open, panelId]);\n const element = useRenderElement('button', componentProps, {\n state,\n ref: [forwardedRef, buttonRef],\n props: [props, elementProps, getButtonProps],\n stateAttributesMapping: triggerOpenStateMapping\n });\n return element;\n});\nif (process.env.NODE_ENV !== \"production\") AccordionTrigger.displayName = \"AccordionTrigger\";","export let AccordionRootDataAttributes = /*#__PURE__*/function (AccordionRootDataAttributes) {\n /**\n * Present when the accordion is disabled.\n */\n AccordionRootDataAttributes[\"disabled\"] = \"data-disabled\";\n /**\n * Indicates the orientation of the accordion.\n */\n AccordionRootDataAttributes[\"orientation\"] = \"data-orientation\";\n return AccordionRootDataAttributes;\n}({});","'use client';\n\nimport * as React from 'react';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useMergedRefs } from '@base-ui-components/utils/useMergedRefs';\nimport { useOnMount } from '@base-ui-components/utils/useOnMount';\nimport { AnimationFrame, useAnimationFrame } from '@base-ui-components/utils/useAnimationFrame';\nimport { warn } from '@base-ui-components/utils/warn';\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { CollapsiblePanelDataAttributes } from \"./CollapsiblePanelDataAttributes.js\";\nimport { AccordionRootDataAttributes } from \"../../accordion/root/AccordionRootDataAttributes.js\";\nexport function useCollapsiblePanel(parameters) {\n const {\n abortControllerRef,\n animationTypeRef,\n externalRef,\n height,\n hiddenUntilFound,\n keepMounted,\n id: idParam,\n mounted,\n onOpenChange,\n open,\n panelRef,\n runOnceAnimationsFinish,\n setDimensions,\n setMounted,\n setOpen,\n setVisible,\n transitionDimensionRef,\n visible,\n width\n } = parameters;\n const isBeforeMatchRef = React.useRef(false);\n const latestAnimationNameRef = React.useRef(null);\n const shouldCancelInitialOpenAnimationRef = React.useRef(open);\n const shouldCancelInitialOpenTransitionRef = React.useRef(open);\n const endingStyleFrame = useAnimationFrame();\n\n /**\n * When opening, the `hidden` attribute is removed immediately.\n * When closing, the `hidden` attribute is set after any exit animations runs.\n */\n const hidden = React.useMemo(() => {\n if (animationTypeRef.current === 'css-animation') {\n return !visible;\n }\n return !open && !mounted;\n }, [open, mounted, visible, animationTypeRef]);\n\n /**\n * When `keepMounted` is `true` this runs once as soon as it exists in the DOM\n * regardless of initial open state.\n *\n * When `keepMounted` is `false` this runs on every mount, typically every\n * time it opens. If the panel is in the middle of a close transition that is\n * interrupted and re-opens, this won't run as the panel was not unmounted.\n */\n const handlePanelRef = useStableCallback(element => {\n if (!element) {\n return undefined;\n }\n if (animationTypeRef.current == null || transitionDimensionRef.current == null) {\n const panelStyles = getComputedStyle(element);\n const hasAnimation = panelStyles.animationName !== 'none' && panelStyles.animationName !== '';\n const hasTransition = panelStyles.transitionDuration !== '0s' && panelStyles.transitionDuration !== '';\n\n /**\n * animationTypeRef is safe to read in render because it's only ever set\n * once here during the first render and never again.\n * https://react.dev/learn/referencing-values-with-refs#best-practices-for-refs\n */\n if (hasAnimation && hasTransition) {\n if (process.env.NODE_ENV !== 'production') {\n warn('CSS transitions and CSS animations both detected on Collapsible or Accordion panel.', 'Only one of either animation type should be used.');\n }\n } else if (panelStyles.animationName === 'none' && panelStyles.transitionDuration !== '0s') {\n animationTypeRef.current = 'css-transition';\n } else if (panelStyles.animationName !== 'none' && panelStyles.transitionDuration === '0s') {\n animationTypeRef.current = 'css-animation';\n } else {\n animationTypeRef.current = 'none';\n }\n\n /**\n * We need to know in advance which side is being collapsed when using CSS\n * transitions in order to set the value of width/height to `0px` momentarily.\n * Setting both to `0px` will break layout.\n */\n if (element.getAttribute(AccordionRootDataAttributes.orientation) === 'horizontal' || panelStyles.transitionProperty.indexOf('width') > -1) {\n transitionDimensionRef.current = 'width';\n } else {\n transitionDimensionRef.current = 'height';\n }\n }\n if (animationTypeRef.current !== 'css-transition') {\n return undefined;\n }\n if (height === undefined || width === undefined) {\n setDimensions({\n height: element.scrollHeight,\n width: element.scrollWidth\n });\n if (shouldCancelInitialOpenTransitionRef.current) {\n element.style.setProperty('transition-duration', '0s');\n }\n }\n let frame = -1;\n let nextFrame = -1;\n frame = AnimationFrame.request(() => {\n shouldCancelInitialOpenTransitionRef.current = false;\n nextFrame = AnimationFrame.request(() => {\n /**\n * This is slightly faster than another RAF and is the earliest\n * opportunity to remove the temporary `transition-duration: 0s` that\n * was applied to cancel opening transitions of initially open panels.\n * https://nolanlawson.com/2018/09/25/accurately-measuring-layout-on-the-web/\n */\n setTimeout(() => {\n element.style.removeProperty('transition-duration');\n });\n });\n });\n return () => {\n AnimationFrame.cancel(frame);\n AnimationFrame.cancel(nextFrame);\n };\n });\n const mergedPanelRef = useMergedRefs(externalRef, panelRef, handlePanelRef);\n useIsoLayoutEffect(() => {\n if (animationTypeRef.current !== 'css-transition') {\n return undefined;\n }\n const panel = panelRef.current;\n if (!panel) {\n return undefined;\n }\n let resizeFrame = -1;\n if (abortControllerRef.current != null) {\n abortControllerRef.current.abort();\n abortControllerRef.current = null;\n }\n if (open) {\n const originalLayoutStyles = {\n 'justify-content': panel.style.justifyContent,\n 'align-items': panel.style.alignItems,\n 'align-content': panel.style.alignContent,\n 'justify-items': panel.style.justifyItems\n };\n\n /* opening */\n Object.keys(originalLayoutStyles).forEach(key => {\n panel.style.setProperty(key, 'initial', 'important');\n });\n\n /**\n * When `keepMounted={false}` and the panel is initially closed, the very\n * first time it opens (not any subsequent opens) `data-starting-style` is\n * off or missing by a frame so we need to set it manually. Otherwise any\n * CSS properties expected to transition using [data-starting-style] may\n * be mis-timed and appear to be complete skipped.\n */\n if (!shouldCancelInitialOpenTransitionRef.current && !keepMounted) {\n panel.setAttribute(CollapsiblePanelDataAttributes.startingStyle, '');\n }\n setDimensions({\n height: panel.scrollHeight,\n width: panel.scrollWidth\n });\n resizeFrame = AnimationFrame.request(() => {\n Object.entries(originalLayoutStyles).forEach(([key, value]) => {\n if (value === '') {\n panel.style.removeProperty(key);\n } else {\n panel.style.setProperty(key, value);\n }\n });\n });\n } else {\n if (panel.scrollHeight === 0 && panel.scrollWidth === 0) {\n return undefined;\n }\n\n /* closing */\n setDimensions({\n height: panel.scrollHeight,\n width: panel.scrollWidth\n });\n const abortController = new AbortController();\n abortControllerRef.current = abortController;\n const signal = abortController.signal;\n let attributeObserver = null;\n const endingStyleAttribute = CollapsiblePanelDataAttributes.endingStyle;\n\n // Wait for `[data-ending-style]` to be applied.\n attributeObserver = new MutationObserver(mutationList => {\n const hasEndingStyle = mutationList.some(mutation => mutation.type === 'attributes' && mutation.attributeName === endingStyleAttribute);\n if (hasEndingStyle) {\n attributeObserver?.disconnect();\n attributeObserver = null;\n runOnceAnimationsFinish(() => {\n setDimensions({\n height: 0,\n width: 0\n });\n panel.style.removeProperty('content-visibility');\n setMounted(false);\n if (abortControllerRef.current === abortController) {\n abortControllerRef.current = null;\n }\n }, signal);\n }\n });\n attributeObserver.observe(panel, {\n attributes: true,\n attributeFilter: [endingStyleAttribute]\n });\n return () => {\n attributeObserver?.disconnect();\n endingStyleFrame.cancel();\n if (abortControllerRef.current === abortController) {\n abortController.abort();\n abortControllerRef.current = null;\n }\n };\n }\n return () => {\n AnimationFrame.cancel(resizeFrame);\n };\n }, [abortControllerRef, animationTypeRef, endingStyleFrame, hiddenUntilFound, keepMounted, mounted, open, panelRef, runOnceAnimationsFinish, setDimensions, setMounted]);\n useIsoLayoutEffect(() => {\n if (animationTypeRef.current !== 'css-animation') {\n return;\n }\n const panel = panelRef.current;\n if (!panel) {\n return;\n }\n latestAnimationNameRef.current = panel.style.animationName || latestAnimationNameRef.current;\n panel.style.setProperty('animation-name', 'none');\n setDimensions({\n height: panel.scrollHeight,\n width: panel.scrollWidth\n });\n if (!shouldCancelInitialOpenAnimationRef.current && !isBeforeMatchRef.current) {\n panel.style.removeProperty('animation-name');\n }\n if (open) {\n if (abortControllerRef.current != null) {\n abortControllerRef.current.abort();\n abortControllerRef.current = null;\n }\n setMounted(true);\n setVisible(true);\n } else {\n abortControllerRef.current = new AbortController();\n runOnceAnimationsFinish(() => {\n setMounted(false);\n setVisible(false);\n abortControllerRef.current = null;\n }, abortControllerRef.current.signal);\n }\n }, [abortControllerRef, animationTypeRef, open, panelRef, runOnceAnimationsFinish, setDimensions, setMounted, setVisible, visible]);\n useOnMount(() => {\n const frame = AnimationFrame.request(() => {\n shouldCancelInitialOpenAnimationRef.current = false;\n });\n return () => AnimationFrame.cancel(frame);\n });\n useIsoLayoutEffect(() => {\n if (!hiddenUntilFound) {\n return undefined;\n }\n const panel = panelRef.current;\n if (!panel) {\n return undefined;\n }\n let frame = -1;\n let nextFrame = -1;\n if (open && isBeforeMatchRef.current) {\n panel.style.transitionDuration = '0s';\n setDimensions({\n height: panel.scrollHeight,\n width: panel.scrollWidth\n });\n frame = AnimationFrame.request(() => {\n isBeforeMatchRef.current = false;\n nextFrame = AnimationFrame.request(() => {\n setTimeout(() => {\n panel.style.removeProperty('transition-duration');\n });\n });\n });\n }\n return () => {\n AnimationFrame.cancel(frame);\n AnimationFrame.cancel(nextFrame);\n };\n }, [hiddenUntilFound, open, panelRef, setDimensions]);\n useIsoLayoutEffect(() => {\n const panel = panelRef.current;\n if (panel && hiddenUntilFound && hidden) {\n /**\n * React only supports a boolean for the `hidden` attribute and forces\n * legit string values to booleans so we have to force it back in the DOM\n * when necessary: https://github.com/facebook/react/issues/24740\n */\n panel.setAttribute('hidden', 'until-found');\n /**\n * Set data-starting-style here to persist the closed styles, this is to\n * prevent transitions from starting when the `hidden` attribute changes\n * to `'until-found'` as they could have different `display` properties:\n * https://github.com/tailwindlabs/tailwindcss/pull/14625\n */\n if (animationTypeRef.current === 'css-transition') {\n panel.setAttribute(CollapsiblePanelDataAttributes.startingStyle, '');\n }\n }\n }, [hiddenUntilFound, hidden, animationTypeRef, panelRef]);\n React.useEffect(function registerBeforeMatchListener() {\n const panel = panelRef.current;\n if (!panel) {\n return undefined;\n }\n function handleBeforeMatch(event) {\n isBeforeMatchRef.current = true;\n setOpen(true);\n onOpenChange(true, createChangeEventDetails(REASONS.none, event));\n }\n panel.addEventListener('beforematch', handleBeforeMatch);\n return () => {\n panel.removeEventListener('beforematch', handleBeforeMatch);\n };\n }, [onOpenChange, panelRef, setOpen]);\n return React.useMemo(() => ({\n props: {\n hidden,\n id: idParam,\n ref: mergedPanelRef\n }\n }), [hidden, idParam, mergedPanelRef]);\n}","export let AccordionPanelCssVars = /*#__PURE__*/function (AccordionPanelCssVars) {\n /**\n * The accordion panel's height.\n * @type {number}\n */\n AccordionPanelCssVars[\"accordionPanelHeight\"] = \"--accordion-panel-height\";\n /**\n * The accordion panel's width.\n * @type {number}\n */\n AccordionPanelCssVars[\"accordionPanelWidth\"] = \"--accordion-panel-width\";\n return AccordionPanelCssVars;\n}({});","'use client';\n\nimport { useIsoLayoutEffect } from \"./useIsoLayoutEffect.js\";\nimport { useRefWithInit } from \"./useRefWithInit.js\";\n\n/**\n * Untracks the provided value by turning it into a ref to remove its reactivity.\n *\n * Used to access the passed value inside `React.useEffect` without causing the effect to re-run when the value changes.\n */\nexport function useValueAsRef(value) {\n const latest = useRefWithInit(createLatestRef, value).current;\n latest.next = value;\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useIsoLayoutEffect(latest.effect);\n return latest;\n}\nfunction createLatestRef(value) {\n const latest = {\n current: value,\n next: value,\n effect: () => {\n latest.current = latest.next;\n }\n };\n return latest;\n}","'use client';\n\nimport * as React from 'react';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useValueAsRef } from '@base-ui-components/utils/useValueAsRef';\nimport { useAnimationsFinished } from \"./useAnimationsFinished.js\";\n\n/**\n * Calls the provided function when the CSS open/close animation or transition completes.\n */\nexport function useOpenChangeComplete(parameters) {\n const {\n enabled = true,\n open,\n ref,\n onComplete: onCompleteParam\n } = parameters;\n const openRef = useValueAsRef(open);\n const onComplete = useStableCallback(onCompleteParam);\n const runOnceAnimationsFinish = useAnimationsFinished(ref, open);\n React.useEffect(() => {\n if (!enabled) {\n return;\n }\n runOnceAnimationsFinish(() => {\n if (open === openRef.current) {\n onComplete();\n }\n });\n }, [enabled, open, onComplete, runOnceAnimationsFinish, openRef]);\n}","'use client';\n\nimport * as React from 'react';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { warn } from '@base-ui-components/utils/warn';\nimport { useCollapsibleRootContext } from \"../../collapsible/root/CollapsibleRootContext.js\";\nimport { useCollapsiblePanel } from \"../../collapsible/panel/useCollapsiblePanel.js\";\nimport { useAccordionRootContext } from \"../root/AccordionRootContext.js\";\nimport { useAccordionItemContext } from \"../item/AccordionItemContext.js\";\nimport { accordionStateAttributesMapping } from \"../item/stateAttributesMapping.js\";\nimport { AccordionPanelCssVars } from \"./AccordionPanelCssVars.js\";\nimport { useOpenChangeComplete } from \"../../utils/useOpenChangeComplete.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\n/**\n * A collapsible panel with the accordion item contents.\n * Renders a `<div>` element.\n *\n * Documentation: [Base UI Accordion](https://base-ui.com/react/components/accordion)\n */\nexport const AccordionPanel = /*#__PURE__*/React.forwardRef(function AccordionPanel(componentProps, forwardedRef) {\n const {\n className,\n hiddenUntilFound: hiddenUntilFoundProp,\n keepMounted: keepMountedProp,\n id: idProp,\n render,\n ...elementProps\n } = componentProps;\n const {\n hiddenUntilFound: contextHiddenUntilFound,\n keepMounted: contextKeepMounted\n } = useAccordionRootContext();\n const {\n abortControllerRef,\n animationTypeRef,\n height,\n mounted,\n onOpenChange,\n open,\n panelId,\n panelRef,\n runOnceAnimationsFinish,\n setDimensions,\n setHiddenUntilFound,\n setKeepMounted,\n setMounted,\n setOpen,\n setVisible,\n transitionDimensionRef,\n visible,\n width,\n setPanelIdState,\n transitionStatus\n } = useCollapsibleRootContext();\n const hiddenUntilFound = hiddenUntilFoundProp ?? contextHiddenUntilFound;\n const keepMounted = keepMountedProp ?? contextKeepMounted;\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useIsoLayoutEffect(() => {\n if (keepMountedProp === false && hiddenUntilFound) {\n warn('The `keepMounted={false}` prop on a Accordion.Panel will be ignored when using `contextHiddenUntilFound` on the Panel or the Root since it requires the panel to remain mounted when closed.');\n }\n }, [hiddenUntilFound, keepMountedProp]);\n }\n useIsoLayoutEffect(() => {\n if (idProp) {\n setPanelIdState(idProp);\n return () => {\n setPanelIdState(undefined);\n };\n }\n return undefined;\n }, [idProp, setPanelIdState]);\n useIsoLayoutEffect(() => {\n setHiddenUntilFound(hiddenUntilFound);\n }, [setHiddenUntilFound, hiddenUntilFound]);\n useIsoLayoutEffect(() => {\n setKeepMounted(keepMounted);\n }, [setKeepMounted, keepMounted]);\n useOpenChangeComplete({\n open: open && transitionStatus === 'idle',\n ref: panelRef,\n onComplete() {\n if (!open) {\n return;\n }\n setDimensions({\n width: undefined,\n height: undefined\n });\n }\n });\n const {\n props\n } = useCollapsiblePanel({\n abortControllerRef,\n animationTypeRef,\n externalRef: forwardedRef,\n height,\n hiddenUntilFound,\n id: idProp ?? panelId,\n keepMounted,\n mounted,\n onOpenChange,\n open,\n panelRef,\n runOnceAnimationsFinish,\n setDimensions,\n setMounted,\n setOpen,\n setVisible,\n transitionDimensionRef,\n visible,\n width\n });\n const {\n state,\n triggerId\n } = useAccordionItemContext();\n const panelState = React.useMemo(() => ({\n ...state,\n transitionStatus\n }), [state, transitionStatus]);\n const element = useRenderElement('div', componentProps, {\n state: panelState,\n ref: [forwardedRef, panelRef],\n props: [props, {\n 'aria-labelledby': triggerId,\n role: 'region',\n style: {\n [AccordionPanelCssVars.accordionPanelHeight]: height === undefined ? 'auto' : `${height}px`,\n [AccordionPanelCssVars.accordionPanelWidth]: width === undefined ? 'auto' : `${width}px`\n }\n }, elementProps],\n stateAttributesMapping: accordionStateAttributesMapping\n });\n const shouldRender = keepMounted || hiddenUntilFound || !keepMounted && mounted;\n if (!shouldRender) {\n return null;\n }\n return element;\n});\nif (process.env.NODE_ENV !== \"production\") AccordionPanel.displayName = \"AccordionPanel\";","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","/**\n * Concatenates two arrays faster than the array spread operator.\n */\nconst concatArrays = (array1, array2) => {\n // Pre-allocate for better V8 optimization\n const combinedArray = new Array(array1.length + array2.length);\n for (let i = 0; i < array1.length; i++) {\n combinedArray[i] = array1[i];\n }\n for (let i = 0; i < array2.length; i++) {\n combinedArray[array1.length + i] = array2[i];\n }\n return combinedArray;\n};\n\n// Factory function ensures consistent object shapes\nconst createClassValidatorObject = (classGroupId, validator) => ({\n classGroupId,\n validator\n});\n// Factory ensures consistent ClassPartObject shape\nconst createClassPartObject = (nextPart = new Map(), validators = null, classGroupId) => ({\n nextPart,\n validators,\n classGroupId\n});\nconst CLASS_PART_SEPARATOR = '-';\nconst EMPTY_CONFLICTS = [];\n// I use two dots here because one dot is used as prefix for class groups in plugins\nconst ARBITRARY_PROPERTY_PREFIX = 'arbitrary..';\nconst createClassGroupUtils = config => {\n const classMap = createClassMap(config);\n const {\n conflictingClassGroups,\n conflictingClassGroupModifiers\n } = config;\n const getClassGroupId = className => {\n if (className.startsWith('[') && className.endsWith(']')) {\n return getGroupIdForArbitraryProperty(className);\n }\n const classParts = className.split(CLASS_PART_SEPARATOR);\n // Classes like `-inset-1` produce an empty string as first classPart. We assume that classes for negative values are used correctly and skip it.\n const startIndex = classParts[0] === '' && classParts.length > 1 ? 1 : 0;\n return getGroupRecursive(classParts, startIndex, classMap);\n };\n const getConflictingClassGroupIds = (classGroupId, hasPostfixModifier) => {\n if (hasPostfixModifier) {\n const modifierConflicts = conflictingClassGroupModifiers[classGroupId];\n const baseConflicts = conflictingClassGroups[classGroupId];\n if (modifierConflicts) {\n if (baseConflicts) {\n // Merge base conflicts with modifier conflicts\n return concatArrays(baseConflicts, modifierConflicts);\n }\n // Only modifier conflicts\n return modifierConflicts;\n }\n // Fall back to without postfix if no modifier conflicts\n return baseConflicts || EMPTY_CONFLICTS;\n }\n return conflictingClassGroups[classGroupId] || EMPTY_CONFLICTS;\n };\n return {\n getClassGroupId,\n getConflictingClassGroupIds\n };\n};\nconst getGroupRecursive = (classParts, startIndex, classPartObject) => {\n const classPathsLength = classParts.length - startIndex;\n if (classPathsLength === 0) {\n return classPartObject.classGroupId;\n }\n const currentClassPart = classParts[startIndex];\n const nextClassPartObject = classPartObject.nextPart.get(currentClassPart);\n if (nextClassPartObject) {\n const result = getGroupRecursive(classParts, startIndex + 1, nextClassPartObject);\n if (result) return result;\n }\n const validators = classPartObject.validators;\n if (validators === null) {\n return undefined;\n }\n // Build classRest string efficiently by joining from startIndex onwards\n const classRest = startIndex === 0 ? classParts.join(CLASS_PART_SEPARATOR) : classParts.slice(startIndex).join(CLASS_PART_SEPARATOR);\n const validatorsLength = validators.length;\n for (let i = 0; i < validatorsLength; i++) {\n const validatorObj = validators[i];\n if (validatorObj.validator(classRest)) {\n return validatorObj.classGroupId;\n }\n }\n return undefined;\n};\n/**\n * Get the class group ID for an arbitrary property.\n *\n * @param className - The class name to get the group ID for. Is expected to be string starting with `[` and ending with `]`.\n */\nconst getGroupIdForArbitraryProperty = className => className.slice(1, -1).indexOf(':') === -1 ? undefined : (() => {\n const content = className.slice(1, -1);\n const colonIndex = content.indexOf(':');\n const property = content.slice(0, colonIndex);\n return property ? ARBITRARY_PROPERTY_PREFIX + property : undefined;\n})();\n/**\n * Exported for testing only\n */\nconst createClassMap = config => {\n const {\n theme,\n classGroups\n } = config;\n return processClassGroups(classGroups, theme);\n};\n// Split into separate functions to maintain monomorphic call sites\nconst processClassGroups = (classGroups, theme) => {\n const classMap = createClassPartObject();\n for (const classGroupId in classGroups) {\n const group = classGroups[classGroupId];\n processClassesRecursively(group, classMap, classGroupId, theme);\n }\n return classMap;\n};\nconst processClassesRecursively = (classGroup, classPartObject, classGroupId, theme) => {\n const len = classGroup.length;\n for (let i = 0; i < len; i++) {\n const classDefinition = classGroup[i];\n processClassDefinition(classDefinition, classPartObject, classGroupId, theme);\n }\n};\n// Split into separate functions for each type to maintain monomorphic call sites\nconst processClassDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n if (typeof classDefinition === 'string') {\n processStringDefinition(classDefinition, classPartObject, classGroupId);\n return;\n }\n if (typeof classDefinition === 'function') {\n processFunctionDefinition(classDefinition, classPartObject, classGroupId, theme);\n return;\n }\n processObjectDefinition(classDefinition, classPartObject, classGroupId, theme);\n};\nconst processStringDefinition = (classDefinition, classPartObject, classGroupId) => {\n const classPartObjectToEdit = classDefinition === '' ? classPartObject : getPart(classPartObject, classDefinition);\n classPartObjectToEdit.classGroupId = classGroupId;\n};\nconst processFunctionDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n if (isThemeGetter(classDefinition)) {\n processClassesRecursively(classDefinition(theme), classPartObject, classGroupId, theme);\n return;\n }\n if (classPartObject.validators === null) {\n classPartObject.validators = [];\n }\n classPartObject.validators.push(createClassValidatorObject(classGroupId, classDefinition));\n};\nconst processObjectDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n const entries = Object.entries(classDefinition);\n const len = entries.length;\n for (let i = 0; i < len; i++) {\n const [key, value] = entries[i];\n processClassesRecursively(value, getPart(classPartObject, key), classGroupId, theme);\n }\n};\nconst getPart = (classPartObject, path) => {\n let current = classPartObject;\n const parts = path.split(CLASS_PART_SEPARATOR);\n const len = parts.length;\n for (let i = 0; i < len; i++) {\n const part = parts[i];\n let next = current.nextPart.get(part);\n if (!next) {\n next = createClassPartObject();\n current.nextPart.set(part, next);\n }\n current = next;\n }\n return current;\n};\n// Type guard maintains monomorphic check\nconst isThemeGetter = func => 'isThemeGetter' in func && func.isThemeGetter === true;\n\n// LRU cache implementation using plain objects for simplicity\nconst createLruCache = maxCacheSize => {\n if (maxCacheSize < 1) {\n return {\n get: () => undefined,\n set: () => {}\n };\n }\n let cacheSize = 0;\n let cache = Object.create(null);\n let previousCache = Object.create(null);\n const update = (key, value) => {\n cache[key] = value;\n cacheSize++;\n if (cacheSize > maxCacheSize) {\n cacheSize = 0;\n previousCache = cache;\n cache = Object.create(null);\n }\n };\n return {\n get(key) {\n let value = cache[key];\n if (value !== undefined) {\n return value;\n }\n if ((value = previousCache[key]) !== undefined) {\n update(key, value);\n return value;\n }\n },\n set(key, value) {\n if (key in cache) {\n cache[key] = value;\n } else {\n update(key, value);\n }\n }\n };\n};\nconst IMPORTANT_MODIFIER = '!';\nconst MODIFIER_SEPARATOR = ':';\nconst EMPTY_MODIFIERS = [];\n// Pre-allocated result object shape for consistency\nconst createResultObject = (modifiers, hasImportantModifier, baseClassName, maybePostfixModifierPosition, isExternal) => ({\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition,\n isExternal\n});\nconst createParseClassName = config => {\n const {\n prefix,\n experimentalParseClassName\n } = config;\n /**\n * Parse class name into parts.\n *\n * Inspired by `splitAtTopLevelOnly` used in Tailwind CSS\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v3.2.2/src/util/splitAtTopLevelOnly.js\n */\n let parseClassName = className => {\n // Use simple array with push for better performance\n const modifiers = [];\n let bracketDepth = 0;\n let parenDepth = 0;\n let modifierStart = 0;\n let postfixModifierPosition;\n const len = className.length;\n for (let index = 0; index < len; index++) {\n const currentCharacter = className[index];\n if (bracketDepth === 0 && parenDepth === 0) {\n if (currentCharacter === MODIFIER_SEPARATOR) {\n modifiers.push(className.slice(modifierStart, index));\n modifierStart = index + 1;\n continue;\n }\n if (currentCharacter === '/') {\n postfixModifierPosition = index;\n continue;\n }\n }\n if (currentCharacter === '[') bracketDepth++;else if (currentCharacter === ']') bracketDepth--;else if (currentCharacter === '(') parenDepth++;else if (currentCharacter === ')') parenDepth--;\n }\n const baseClassNameWithImportantModifier = modifiers.length === 0 ? className : className.slice(modifierStart);\n // Inline important modifier check\n let baseClassName = baseClassNameWithImportantModifier;\n let hasImportantModifier = false;\n if (baseClassNameWithImportantModifier.endsWith(IMPORTANT_MODIFIER)) {\n baseClassName = baseClassNameWithImportantModifier.slice(0, -1);\n hasImportantModifier = true;\n } else if (\n /**\n * In Tailwind CSS v3 the important modifier was at the start of the base class name. This is still supported for legacy reasons.\n * @see https://github.com/dcastil/tailwind-merge/issues/513#issuecomment-2614029864\n */\n baseClassNameWithImportantModifier.startsWith(IMPORTANT_MODIFIER)) {\n baseClassName = baseClassNameWithImportantModifier.slice(1);\n hasImportantModifier = true;\n }\n const maybePostfixModifierPosition = postfixModifierPosition && postfixModifierPosition > modifierStart ? postfixModifierPosition - modifierStart : undefined;\n return createResultObject(modifiers, hasImportantModifier, baseClassName, maybePostfixModifierPosition);\n };\n if (prefix) {\n const fullPrefix = prefix + MODIFIER_SEPARATOR;\n const parseClassNameOriginal = parseClassName;\n parseClassName = className => className.startsWith(fullPrefix) ? parseClassNameOriginal(className.slice(fullPrefix.length)) : createResultObject(EMPTY_MODIFIERS, false, className, undefined, true);\n }\n if (experimentalParseClassName) {\n const parseClassNameOriginal = parseClassName;\n parseClassName = className => experimentalParseClassName({\n className,\n parseClassName: parseClassNameOriginal\n });\n }\n return parseClassName;\n};\n\n/**\n * Sorts modifiers according to following schema:\n * - Predefined modifiers are sorted alphabetically\n * - When an arbitrary variant appears, it must be preserved which modifiers are before and after it\n */\nconst createSortModifiers = config => {\n // Pre-compute weights for all known modifiers for O(1) comparison\n const modifierWeights = new Map();\n // Assign weights to sensitive modifiers (highest priority, but preserve order)\n config.orderSensitiveModifiers.forEach((mod, index) => {\n modifierWeights.set(mod, 1000000 + index); // High weights for sensitive mods\n });\n return modifiers => {\n const result = [];\n let currentSegment = [];\n // Process modifiers in one pass\n for (let i = 0; i < modifiers.length; i++) {\n const modifier = modifiers[i];\n // Check if modifier is sensitive (starts with '[' or in orderSensitiveModifiers)\n const isArbitrary = modifier[0] === '[';\n const isOrderSensitive = modifierWeights.has(modifier);\n if (isArbitrary || isOrderSensitive) {\n // Sort and flush current segment alphabetically\n if (currentSegment.length > 0) {\n currentSegment.sort();\n result.push(...currentSegment);\n currentSegment = [];\n }\n result.push(modifier);\n } else {\n // Regular modifier - add to current segment for batch sorting\n currentSegment.push(modifier);\n }\n }\n // Sort and add any remaining segment items\n if (currentSegment.length > 0) {\n currentSegment.sort();\n result.push(...currentSegment);\n }\n return result;\n };\n};\nconst createConfigUtils = config => ({\n cache: createLruCache(config.cacheSize),\n parseClassName: createParseClassName(config),\n sortModifiers: createSortModifiers(config),\n ...createClassGroupUtils(config)\n});\nconst SPLIT_CLASSES_REGEX = /\\s+/;\nconst mergeClassList = (classList, configUtils) => {\n const {\n parseClassName,\n getClassGroupId,\n getConflictingClassGroupIds,\n sortModifiers\n } = configUtils;\n /**\n * Set of classGroupIds in following format:\n * `{importantModifier}{variantModifiers}{classGroupId}`\n * @example 'float'\n * @example 'hover:focus:bg-color'\n * @example 'md:!pr'\n */\n const classGroupsInConflict = [];\n const classNames = classList.trim().split(SPLIT_CLASSES_REGEX);\n let result = '';\n for (let index = classNames.length - 1; index >= 0; index -= 1) {\n const originalClassName = classNames[index];\n const {\n isExternal,\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition\n } = parseClassName(originalClassName);\n if (isExternal) {\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n let hasPostfixModifier = !!maybePostfixModifierPosition;\n let classGroupId = getClassGroupId(hasPostfixModifier ? baseClassName.substring(0, maybePostfixModifierPosition) : baseClassName);\n if (!classGroupId) {\n if (!hasPostfixModifier) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n classGroupId = getClassGroupId(baseClassName);\n if (!classGroupId) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n hasPostfixModifier = false;\n }\n // Fast path: skip sorting for empty or single modifier\n const variantModifier = modifiers.length === 0 ? '' : modifiers.length === 1 ? modifiers[0] : sortModifiers(modifiers).join(':');\n const modifierId = hasImportantModifier ? variantModifier + IMPORTANT_MODIFIER : variantModifier;\n const classId = modifierId + classGroupId;\n if (classGroupsInConflict.indexOf(classId) > -1) {\n // Tailwind class omitted due to conflict\n continue;\n }\n classGroupsInConflict.push(classId);\n const conflictGroups = getConflictingClassGroupIds(classGroupId, hasPostfixModifier);\n for (let i = 0; i < conflictGroups.length; ++i) {\n const group = conflictGroups[i];\n classGroupsInConflict.push(modifierId + group);\n }\n // Tailwind class not in conflict\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n }\n return result;\n};\n\n/**\n * The code in this file is copied from https://github.com/lukeed/clsx and modified to suit the needs of tailwind-merge better.\n *\n * Specifically:\n * - Runtime code from https://github.com/lukeed/clsx/blob/v1.2.1/src/index.js\n * - TypeScript types from https://github.com/lukeed/clsx/blob/v1.2.1/clsx.d.ts\n *\n * Original code has MIT license: Copyright (c) Luke Edwards <luke.edwards05@gmail.com> (lukeed.com)\n */\nconst twJoin = (...classLists) => {\n let index = 0;\n let argument;\n let resolvedValue;\n let string = '';\n while (index < classLists.length) {\n if (argument = classLists[index++]) {\n if (resolvedValue = toValue(argument)) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n};\nconst toValue = mix => {\n // Fast path for strings\n if (typeof mix === 'string') {\n return mix;\n }\n let resolvedValue;\n let string = '';\n for (let k = 0; k < mix.length; k++) {\n if (mix[k]) {\n if (resolvedValue = toValue(mix[k])) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n};\nconst createTailwindMerge = (createConfigFirst, ...createConfigRest) => {\n let configUtils;\n let cacheGet;\n let cacheSet;\n let functionToCall;\n const initTailwindMerge = classList => {\n const config = createConfigRest.reduce((previousConfig, createConfigCurrent) => createConfigCurrent(previousConfig), createConfigFirst());\n configUtils = createConfigUtils(config);\n cacheGet = configUtils.cache.get;\n cacheSet = configUtils.cache.set;\n functionToCall = tailwindMerge;\n return tailwindMerge(classList);\n };\n const tailwindMerge = classList => {\n const cachedResult = cacheGet(classList);\n if (cachedResult) {\n return cachedResult;\n }\n const result = mergeClassList(classList, configUtils);\n cacheSet(classList, result);\n return result;\n };\n functionToCall = initTailwindMerge;\n return (...args) => functionToCall(twJoin(...args));\n};\nconst fallbackThemeArr = [];\nconst fromTheme = key => {\n const themeGetter = theme => theme[key] || fallbackThemeArr;\n themeGetter.isThemeGetter = true;\n return themeGetter;\n};\nconst arbitraryValueRegex = /^\\[(?:(\\w[\\w-]*):)?(.+)\\]$/i;\nconst arbitraryVariableRegex = /^\\((?:(\\w[\\w-]*):)?(.+)\\)$/i;\nconst fractionRegex = /^\\d+\\/\\d+$/;\nconst tshirtUnitRegex = /^(\\d+(\\.\\d+)?)?(xs|sm|md|lg|xl)$/;\nconst lengthUnitRegex = /\\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\\b(calc|min|max|clamp)\\(.+\\)|^0$/;\nconst colorFunctionRegex = /^(rgba?|hsla?|hwb|(ok)?(lab|lch)|color-mix)\\(.+\\)$/;\n// Shadow always begins with x and y offset separated by underscore optionally prepended by inset\nconst shadowRegex = /^(inset_)?-?((\\d+)?\\.?(\\d+)[a-z]+|0)_-?((\\d+)?\\.?(\\d+)[a-z]+|0)/;\nconst imageRegex = /^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\\(.+\\)$/;\nconst isFraction = value => fractionRegex.test(value);\nconst isNumber = value => !!value && !Number.isNaN(Number(value));\nconst isInteger = value => !!value && Number.isInteger(Number(value));\nconst isPercent = value => value.endsWith('%') && isNumber(value.slice(0, -1));\nconst isTshirtSize = value => tshirtUnitRegex.test(value);\nconst isAny = () => true;\nconst isLengthOnly = value =>\n// `colorFunctionRegex` check is necessary because color functions can have percentages in them which which would be incorrectly classified as lengths.\n// For example, `hsl(0 0% 0%)` would be classified as a length without this check.\n// I could also use lookbehind assertion in `lengthUnitRegex` but that isn't supported widely enough.\nlengthUnitRegex.test(value) && !colorFunctionRegex.test(value);\nconst isNever = () => false;\nconst isShadow = value => shadowRegex.test(value);\nconst isImage = value => imageRegex.test(value);\nconst isAnyNonArbitrary = value => !isArbitraryValue(value) && !isArbitraryVariable(value);\nconst isArbitrarySize = value => getIsArbitraryValue(value, isLabelSize, isNever);\nconst isArbitraryValue = value => arbitraryValueRegex.test(value);\nconst isArbitraryLength = value => getIsArbitraryValue(value, isLabelLength, isLengthOnly);\nconst isArbitraryNumber = value => getIsArbitraryValue(value, isLabelNumber, isNumber);\nconst isArbitraryPosition = value => getIsArbitraryValue(value, isLabelPosition, isNever);\nconst isArbitraryImage = value => getIsArbitraryValue(value, isLabelImage, isImage);\nconst isArbitraryShadow = value => getIsArbitraryValue(value, isLabelShadow, isShadow);\nconst isArbitraryVariable = value => arbitraryVariableRegex.test(value);\nconst isArbitraryVariableLength = value => getIsArbitraryVariable(value, isLabelLength);\nconst isArbitraryVariableFamilyName = value => getIsArbitraryVariable(value, isLabelFamilyName);\nconst isArbitraryVariablePosition = value => getIsArbitraryVariable(value, isLabelPosition);\nconst isArbitraryVariableSize = value => getIsArbitraryVariable(value, isLabelSize);\nconst isArbitraryVariableImage = value => getIsArbitraryVariable(value, isLabelImage);\nconst isArbitraryVariableShadow = value => getIsArbitraryVariable(value, isLabelShadow, true);\n// Helpers\nconst getIsArbitraryValue = (value, testLabel, testValue) => {\n const result = arbitraryValueRegex.exec(value);\n if (result) {\n if (result[1]) {\n return testLabel(result[1]);\n }\n return testValue(result[2]);\n }\n return false;\n};\nconst getIsArbitraryVariable = (value, testLabel, shouldMatchNoLabel = false) => {\n const result = arbitraryVariableRegex.exec(value);\n if (result) {\n if (result[1]) {\n return testLabel(result[1]);\n }\n return shouldMatchNoLabel;\n }\n return false;\n};\n// Labels\nconst isLabelPosition = label => label === 'position' || label === 'percentage';\nconst isLabelImage = label => label === 'image' || label === 'url';\nconst isLabelSize = label => label === 'length' || label === 'size' || label === 'bg-size';\nconst isLabelLength = label => label === 'length';\nconst isLabelNumber = label => label === 'number';\nconst isLabelFamilyName = label => label === 'family-name';\nconst isLabelShadow = label => label === 'shadow';\nconst validators = /*#__PURE__*/Object.defineProperty({\n __proto__: null,\n isAny,\n isAnyNonArbitrary,\n isArbitraryImage,\n isArbitraryLength,\n isArbitraryNumber,\n isArbitraryPosition,\n isArbitraryShadow,\n isArbitrarySize,\n isArbitraryValue,\n isArbitraryVariable,\n isArbitraryVariableFamilyName,\n isArbitraryVariableImage,\n isArbitraryVariableLength,\n isArbitraryVariablePosition,\n isArbitraryVariableShadow,\n isArbitraryVariableSize,\n isFraction,\n isInteger,\n isNumber,\n isPercent,\n isTshirtSize\n}, Symbol.toStringTag, {\n value: 'Module'\n});\nconst getDefaultConfig = () => {\n /**\n * Theme getters for theme variable namespaces\n * @see https://tailwindcss.com/docs/theme#theme-variable-namespaces\n */\n /***/\n const themeColor = fromTheme('color');\n const themeFont = fromTheme('font');\n const themeText = fromTheme('text');\n const themeFontWeight = fromTheme('font-weight');\n const themeTracking = fromTheme('tracking');\n const themeLeading = fromTheme('leading');\n const themeBreakpoint = fromTheme('breakpoint');\n const themeContainer = fromTheme('container');\n const themeSpacing = fromTheme('spacing');\n const themeRadius = fromTheme('radius');\n const themeShadow = fromTheme('shadow');\n const themeInsetShadow = fromTheme('inset-shadow');\n const themeTextShadow = fromTheme('text-shadow');\n const themeDropShadow = fromTheme('drop-shadow');\n const themeBlur = fromTheme('blur');\n const themePerspective = fromTheme('perspective');\n const themeAspect = fromTheme('aspect');\n const themeEase = fromTheme('ease');\n const themeAnimate = fromTheme('animate');\n /**\n * Helpers to avoid repeating the same scales\n *\n * We use functions that create a new array every time they're called instead of static arrays.\n * This ensures that users who modify any scale by mutating the array (e.g. with `array.push(element)`) don't accidentally mutate arrays in other parts of the config.\n */\n /***/\n const scaleBreak = () => ['auto', 'avoid', 'all', 'avoid-page', 'page', 'left', 'right', 'column'];\n const scalePosition = () => ['center', 'top', 'bottom', 'left', 'right', 'top-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-top', 'top-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-top', 'bottom-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-bottom', 'bottom-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-bottom'];\n const scalePositionWithArbitrary = () => [...scalePosition(), isArbitraryVariable, isArbitraryValue];\n const scaleOverflow = () => ['auto', 'hidden', 'clip', 'visible', 'scroll'];\n const scaleOverscroll = () => ['auto', 'contain', 'none'];\n const scaleUnambiguousSpacing = () => [isArbitraryVariable, isArbitraryValue, themeSpacing];\n const scaleInset = () => [isFraction, 'full', 'auto', ...scaleUnambiguousSpacing()];\n const scaleGridTemplateColsRows = () => [isInteger, 'none', 'subgrid', isArbitraryVariable, isArbitraryValue];\n const scaleGridColRowStartAndEnd = () => ['auto', {\n span: ['full', isInteger, isArbitraryVariable, isArbitraryValue]\n }, isInteger, isArbitraryVariable, isArbitraryValue];\n const scaleGridColRowStartOrEnd = () => [isInteger, 'auto', isArbitraryVariable, isArbitraryValue];\n const scaleGridAutoColsRows = () => ['auto', 'min', 'max', 'fr', isArbitraryVariable, isArbitraryValue];\n const scaleAlignPrimaryAxis = () => ['start', 'end', 'center', 'between', 'around', 'evenly', 'stretch', 'baseline', 'center-safe', 'end-safe'];\n const scaleAlignSecondaryAxis = () => ['start', 'end', 'center', 'stretch', 'center-safe', 'end-safe'];\n const scaleMargin = () => ['auto', ...scaleUnambiguousSpacing()];\n const scaleSizing = () => [isFraction, 'auto', 'full', 'dvw', 'dvh', 'lvw', 'lvh', 'svw', 'svh', 'min', 'max', 'fit', ...scaleUnambiguousSpacing()];\n const scaleColor = () => [themeColor, isArbitraryVariable, isArbitraryValue];\n const scaleBgPosition = () => [...scalePosition(), isArbitraryVariablePosition, isArbitraryPosition, {\n position: [isArbitraryVariable, isArbitraryValue]\n }];\n const scaleBgRepeat = () => ['no-repeat', {\n repeat: ['', 'x', 'y', 'space', 'round']\n }];\n const scaleBgSize = () => ['auto', 'cover', 'contain', isArbitraryVariableSize, isArbitrarySize, {\n size: [isArbitraryVariable, isArbitraryValue]\n }];\n const scaleGradientStopPosition = () => [isPercent, isArbitraryVariableLength, isArbitraryLength];\n const scaleRadius = () => [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', 'full', themeRadius, isArbitraryVariable, isArbitraryValue];\n const scaleBorderWidth = () => ['', isNumber, isArbitraryVariableLength, isArbitraryLength];\n const scaleLineStyle = () => ['solid', 'dashed', 'dotted', 'double'];\n const scaleBlendMode = () => ['normal', 'multiply', 'screen', 'overlay', 'darken', 'lighten', 'color-dodge', 'color-burn', 'hard-light', 'soft-light', 'difference', 'exclusion', 'hue', 'saturation', 'color', 'luminosity'];\n const scaleMaskImagePosition = () => [isNumber, isPercent, isArbitraryVariablePosition, isArbitraryPosition];\n const scaleBlur = () => [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeBlur, isArbitraryVariable, isArbitraryValue];\n const scaleRotate = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleScale = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleSkew = () => [isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleTranslate = () => [isFraction, 'full', ...scaleUnambiguousSpacing()];\n return {\n cacheSize: 500,\n theme: {\n animate: ['spin', 'ping', 'pulse', 'bounce'],\n aspect: ['video'],\n blur: [isTshirtSize],\n breakpoint: [isTshirtSize],\n color: [isAny],\n container: [isTshirtSize],\n 'drop-shadow': [isTshirtSize],\n ease: ['in', 'out', 'in-out'],\n font: [isAnyNonArbitrary],\n 'font-weight': ['thin', 'extralight', 'light', 'normal', 'medium', 'semibold', 'bold', 'extrabold', 'black'],\n 'inset-shadow': [isTshirtSize],\n leading: ['none', 'tight', 'snug', 'normal', 'relaxed', 'loose'],\n perspective: ['dramatic', 'near', 'normal', 'midrange', 'distant', 'none'],\n radius: [isTshirtSize],\n shadow: [isTshirtSize],\n spacing: ['px', isNumber],\n text: [isTshirtSize],\n 'text-shadow': [isTshirtSize],\n tracking: ['tighter', 'tight', 'normal', 'wide', 'wider', 'widest']\n },\n classGroups: {\n // --------------\n // --- Layout ---\n // --------------\n /**\n * Aspect Ratio\n * @see https://tailwindcss.com/docs/aspect-ratio\n */\n aspect: [{\n aspect: ['auto', 'square', isFraction, isArbitraryValue, isArbitraryVariable, themeAspect]\n }],\n /**\n * Container\n * @see https://tailwindcss.com/docs/container\n * @deprecated since Tailwind CSS v4.0.0\n */\n container: ['container'],\n /**\n * Columns\n * @see https://tailwindcss.com/docs/columns\n */\n columns: [{\n columns: [isNumber, isArbitraryValue, isArbitraryVariable, themeContainer]\n }],\n /**\n * Break After\n * @see https://tailwindcss.com/docs/break-after\n */\n 'break-after': [{\n 'break-after': scaleBreak()\n }],\n /**\n * Break Before\n * @see https://tailwindcss.com/docs/break-before\n */\n 'break-before': [{\n 'break-before': scaleBreak()\n }],\n /**\n * Break Inside\n * @see https://tailwindcss.com/docs/break-inside\n */\n 'break-inside': [{\n 'break-inside': ['auto', 'avoid', 'avoid-page', 'avoid-column']\n }],\n /**\n * Box Decoration Break\n * @see https://tailwindcss.com/docs/box-decoration-break\n */\n 'box-decoration': [{\n 'box-decoration': ['slice', 'clone']\n }],\n /**\n * Box Sizing\n * @see https://tailwindcss.com/docs/box-sizing\n */\n box: [{\n box: ['border', 'content']\n }],\n /**\n * Display\n * @see https://tailwindcss.com/docs/display\n */\n display: ['block', 'inline-block', 'inline', 'flex', 'inline-flex', 'table', 'inline-table', 'table-caption', 'table-cell', 'table-column', 'table-column-group', 'table-footer-group', 'table-header-group', 'table-row-group', 'table-row', 'flow-root', 'grid', 'inline-grid', 'contents', 'list-item', 'hidden'],\n /**\n * Screen Reader Only\n * @see https://tailwindcss.com/docs/display#screen-reader-only\n */\n sr: ['sr-only', 'not-sr-only'],\n /**\n * Floats\n * @see https://tailwindcss.com/docs/float\n */\n float: [{\n float: ['right', 'left', 'none', 'start', 'end']\n }],\n /**\n * Clear\n * @see https://tailwindcss.com/docs/clear\n */\n clear: [{\n clear: ['left', 'right', 'both', 'none', 'start', 'end']\n }],\n /**\n * Isolation\n * @see https://tailwindcss.com/docs/isolation\n */\n isolation: ['isolate', 'isolation-auto'],\n /**\n * Object Fit\n * @see https://tailwindcss.com/docs/object-fit\n */\n 'object-fit': [{\n object: ['contain', 'cover', 'fill', 'none', 'scale-down']\n }],\n /**\n * Object Position\n * @see https://tailwindcss.com/docs/object-position\n */\n 'object-position': [{\n object: scalePositionWithArbitrary()\n }],\n /**\n * Overflow\n * @see https://tailwindcss.com/docs/overflow\n */\n overflow: [{\n overflow: scaleOverflow()\n }],\n /**\n * Overflow X\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-x': [{\n 'overflow-x': scaleOverflow()\n }],\n /**\n * Overflow Y\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-y': [{\n 'overflow-y': scaleOverflow()\n }],\n /**\n * Overscroll Behavior\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n overscroll: [{\n overscroll: scaleOverscroll()\n }],\n /**\n * Overscroll Behavior X\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-x': [{\n 'overscroll-x': scaleOverscroll()\n }],\n /**\n * Overscroll Behavior Y\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-y': [{\n 'overscroll-y': scaleOverscroll()\n }],\n /**\n * Position\n * @see https://tailwindcss.com/docs/position\n */\n position: ['static', 'fixed', 'absolute', 'relative', 'sticky'],\n /**\n * Top / Right / Bottom / Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n inset: [{\n inset: scaleInset()\n }],\n /**\n * Right / Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-x': [{\n 'inset-x': scaleInset()\n }],\n /**\n * Top / Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-y': [{\n 'inset-y': scaleInset()\n }],\n /**\n * Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n start: [{\n start: scaleInset()\n }],\n /**\n * End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n end: [{\n end: scaleInset()\n }],\n /**\n * Top\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n top: [{\n top: scaleInset()\n }],\n /**\n * Right\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n right: [{\n right: scaleInset()\n }],\n /**\n * Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n bottom: [{\n bottom: scaleInset()\n }],\n /**\n * Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n left: [{\n left: scaleInset()\n }],\n /**\n * Visibility\n * @see https://tailwindcss.com/docs/visibility\n */\n visibility: ['visible', 'invisible', 'collapse'],\n /**\n * Z-Index\n * @see https://tailwindcss.com/docs/z-index\n */\n z: [{\n z: [isInteger, 'auto', isArbitraryVariable, isArbitraryValue]\n }],\n // ------------------------\n // --- Flexbox and Grid ---\n // ------------------------\n /**\n * Flex Basis\n * @see https://tailwindcss.com/docs/flex-basis\n */\n basis: [{\n basis: [isFraction, 'full', 'auto', themeContainer, ...scaleUnambiguousSpacing()]\n }],\n /**\n * Flex Direction\n * @see https://tailwindcss.com/docs/flex-direction\n */\n 'flex-direction': [{\n flex: ['row', 'row-reverse', 'col', 'col-reverse']\n }],\n /**\n * Flex Wrap\n * @see https://tailwindcss.com/docs/flex-wrap\n */\n 'flex-wrap': [{\n flex: ['nowrap', 'wrap', 'wrap-reverse']\n }],\n /**\n * Flex\n * @see https://tailwindcss.com/docs/flex\n */\n flex: [{\n flex: [isNumber, isFraction, 'auto', 'initial', 'none', isArbitraryValue]\n }],\n /**\n * Flex Grow\n * @see https://tailwindcss.com/docs/flex-grow\n */\n grow: [{\n grow: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Flex Shrink\n * @see https://tailwindcss.com/docs/flex-shrink\n */\n shrink: [{\n shrink: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Order\n * @see https://tailwindcss.com/docs/order\n */\n order: [{\n order: [isInteger, 'first', 'last', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Grid Template Columns\n * @see https://tailwindcss.com/docs/grid-template-columns\n */\n 'grid-cols': [{\n 'grid-cols': scaleGridTemplateColsRows()\n }],\n /**\n * Grid Column Start / End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start-end': [{\n col: scaleGridColRowStartAndEnd()\n }],\n /**\n * Grid Column Start\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start': [{\n 'col-start': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Column End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-end': [{\n 'col-end': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Template Rows\n * @see https://tailwindcss.com/docs/grid-template-rows\n */\n 'grid-rows': [{\n 'grid-rows': scaleGridTemplateColsRows()\n }],\n /**\n * Grid Row Start / End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start-end': [{\n row: scaleGridColRowStartAndEnd()\n }],\n /**\n * Grid Row Start\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start': [{\n 'row-start': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Row End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-end': [{\n 'row-end': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Auto Flow\n * @see https://tailwindcss.com/docs/grid-auto-flow\n */\n 'grid-flow': [{\n 'grid-flow': ['row', 'col', 'dense', 'row-dense', 'col-dense']\n }],\n /**\n * Grid Auto Columns\n * @see https://tailwindcss.com/docs/grid-auto-columns\n */\n 'auto-cols': [{\n 'auto-cols': scaleGridAutoColsRows()\n }],\n /**\n * Grid Auto Rows\n * @see https://tailwindcss.com/docs/grid-auto-rows\n */\n 'auto-rows': [{\n 'auto-rows': scaleGridAutoColsRows()\n }],\n /**\n * Gap\n * @see https://tailwindcss.com/docs/gap\n */\n gap: [{\n gap: scaleUnambiguousSpacing()\n }],\n /**\n * Gap X\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-x': [{\n 'gap-x': scaleUnambiguousSpacing()\n }],\n /**\n * Gap Y\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-y': [{\n 'gap-y': scaleUnambiguousSpacing()\n }],\n /**\n * Justify Content\n * @see https://tailwindcss.com/docs/justify-content\n */\n 'justify-content': [{\n justify: [...scaleAlignPrimaryAxis(), 'normal']\n }],\n /**\n * Justify Items\n * @see https://tailwindcss.com/docs/justify-items\n */\n 'justify-items': [{\n 'justify-items': [...scaleAlignSecondaryAxis(), 'normal']\n }],\n /**\n * Justify Self\n * @see https://tailwindcss.com/docs/justify-self\n */\n 'justify-self': [{\n 'justify-self': ['auto', ...scaleAlignSecondaryAxis()]\n }],\n /**\n * Align Content\n * @see https://tailwindcss.com/docs/align-content\n */\n 'align-content': [{\n content: ['normal', ...scaleAlignPrimaryAxis()]\n }],\n /**\n * Align Items\n * @see https://tailwindcss.com/docs/align-items\n */\n 'align-items': [{\n items: [...scaleAlignSecondaryAxis(), {\n baseline: ['', 'last']\n }]\n }],\n /**\n * Align Self\n * @see https://tailwindcss.com/docs/align-self\n */\n 'align-self': [{\n self: ['auto', ...scaleAlignSecondaryAxis(), {\n baseline: ['', 'last']\n }]\n }],\n /**\n * Place Content\n * @see https://tailwindcss.com/docs/place-content\n */\n 'place-content': [{\n 'place-content': scaleAlignPrimaryAxis()\n }],\n /**\n * Place Items\n * @see https://tailwindcss.com/docs/place-items\n */\n 'place-items': [{\n 'place-items': [...scaleAlignSecondaryAxis(), 'baseline']\n }],\n /**\n * Place Self\n * @see https://tailwindcss.com/docs/place-self\n */\n 'place-self': [{\n 'place-self': ['auto', ...scaleAlignSecondaryAxis()]\n }],\n // Spacing\n /**\n * Padding\n * @see https://tailwindcss.com/docs/padding\n */\n p: [{\n p: scaleUnambiguousSpacing()\n }],\n /**\n * Padding X\n * @see https://tailwindcss.com/docs/padding\n */\n px: [{\n px: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Y\n * @see https://tailwindcss.com/docs/padding\n */\n py: [{\n py: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Start\n * @see https://tailwindcss.com/docs/padding\n */\n ps: [{\n ps: scaleUnambiguousSpacing()\n }],\n /**\n * Padding End\n * @see https://tailwindcss.com/docs/padding\n */\n pe: [{\n pe: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Top\n * @see https://tailwindcss.com/docs/padding\n */\n pt: [{\n pt: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Right\n * @see https://tailwindcss.com/docs/padding\n */\n pr: [{\n pr: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Bottom\n * @see https://tailwindcss.com/docs/padding\n */\n pb: [{\n pb: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Left\n * @see https://tailwindcss.com/docs/padding\n */\n pl: [{\n pl: scaleUnambiguousSpacing()\n }],\n /**\n * Margin\n * @see https://tailwindcss.com/docs/margin\n */\n m: [{\n m: scaleMargin()\n }],\n /**\n * Margin X\n * @see https://tailwindcss.com/docs/margin\n */\n mx: [{\n mx: scaleMargin()\n }],\n /**\n * Margin Y\n * @see https://tailwindcss.com/docs/margin\n */\n my: [{\n my: scaleMargin()\n }],\n /**\n * Margin Start\n * @see https://tailwindcss.com/docs/margin\n */\n ms: [{\n ms: scaleMargin()\n }],\n /**\n * Margin End\n * @see https://tailwindcss.com/docs/margin\n */\n me: [{\n me: scaleMargin()\n }],\n /**\n * Margin Top\n * @see https://tailwindcss.com/docs/margin\n */\n mt: [{\n mt: scaleMargin()\n }],\n /**\n * Margin Right\n * @see https://tailwindcss.com/docs/margin\n */\n mr: [{\n mr: scaleMargin()\n }],\n /**\n * Margin Bottom\n * @see https://tailwindcss.com/docs/margin\n */\n mb: [{\n mb: scaleMargin()\n }],\n /**\n * Margin Left\n * @see https://tailwindcss.com/docs/margin\n */\n ml: [{\n ml: scaleMargin()\n }],\n /**\n * Space Between X\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x': [{\n 'space-x': scaleUnambiguousSpacing()\n }],\n /**\n * Space Between X Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x-reverse': ['space-x-reverse'],\n /**\n * Space Between Y\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y': [{\n 'space-y': scaleUnambiguousSpacing()\n }],\n /**\n * Space Between Y Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y-reverse': ['space-y-reverse'],\n // --------------\n // --- Sizing ---\n // --------------\n /**\n * Size\n * @see https://tailwindcss.com/docs/width#setting-both-width-and-height\n */\n size: [{\n size: scaleSizing()\n }],\n /**\n * Width\n * @see https://tailwindcss.com/docs/width\n */\n w: [{\n w: [themeContainer, 'screen', ...scaleSizing()]\n }],\n /**\n * Min-Width\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-w': [{\n 'min-w': [themeContainer, 'screen', /** Deprecated. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'none', ...scaleSizing()]\n }],\n /**\n * Max-Width\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-w': [{\n 'max-w': [themeContainer, 'screen', 'none', /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'prose', /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n {\n screen: [themeBreakpoint]\n }, ...scaleSizing()]\n }],\n /**\n * Height\n * @see https://tailwindcss.com/docs/height\n */\n h: [{\n h: ['screen', 'lh', ...scaleSizing()]\n }],\n /**\n * Min-Height\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-h': [{\n 'min-h': ['screen', 'lh', 'none', ...scaleSizing()]\n }],\n /**\n * Max-Height\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-h': [{\n 'max-h': ['screen', 'lh', ...scaleSizing()]\n }],\n // ------------------\n // --- Typography ---\n // ------------------\n /**\n * Font Size\n * @see https://tailwindcss.com/docs/font-size\n */\n 'font-size': [{\n text: ['base', themeText, isArbitraryVariableLength, isArbitraryLength]\n }],\n /**\n * Font Smoothing\n * @see https://tailwindcss.com/docs/font-smoothing\n */\n 'font-smoothing': ['antialiased', 'subpixel-antialiased'],\n /**\n * Font Style\n * @see https://tailwindcss.com/docs/font-style\n */\n 'font-style': ['italic', 'not-italic'],\n /**\n * Font Weight\n * @see https://tailwindcss.com/docs/font-weight\n */\n 'font-weight': [{\n font: [themeFontWeight, isArbitraryVariable, isArbitraryNumber]\n }],\n /**\n * Font Stretch\n * @see https://tailwindcss.com/docs/font-stretch\n */\n 'font-stretch': [{\n 'font-stretch': ['ultra-condensed', 'extra-condensed', 'condensed', 'semi-condensed', 'normal', 'semi-expanded', 'expanded', 'extra-expanded', 'ultra-expanded', isPercent, isArbitraryValue]\n }],\n /**\n * Font Family\n * @see https://tailwindcss.com/docs/font-family\n */\n 'font-family': [{\n font: [isArbitraryVariableFamilyName, isArbitraryValue, themeFont]\n }],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-normal': ['normal-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-ordinal': ['ordinal'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-slashed-zero': ['slashed-zero'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-figure': ['lining-nums', 'oldstyle-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-spacing': ['proportional-nums', 'tabular-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-fraction': ['diagonal-fractions', 'stacked-fractions'],\n /**\n * Letter Spacing\n * @see https://tailwindcss.com/docs/letter-spacing\n */\n tracking: [{\n tracking: [themeTracking, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Line Clamp\n * @see https://tailwindcss.com/docs/line-clamp\n */\n 'line-clamp': [{\n 'line-clamp': [isNumber, 'none', isArbitraryVariable, isArbitraryNumber]\n }],\n /**\n * Line Height\n * @see https://tailwindcss.com/docs/line-height\n */\n leading: [{\n leading: [/** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n themeLeading, ...scaleUnambiguousSpacing()]\n }],\n /**\n * List Style Image\n * @see https://tailwindcss.com/docs/list-style-image\n */\n 'list-image': [{\n 'list-image': ['none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * List Style Position\n * @see https://tailwindcss.com/docs/list-style-position\n */\n 'list-style-position': [{\n list: ['inside', 'outside']\n }],\n /**\n * List Style Type\n * @see https://tailwindcss.com/docs/list-style-type\n */\n 'list-style-type': [{\n list: ['disc', 'decimal', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Text Alignment\n * @see https://tailwindcss.com/docs/text-align\n */\n 'text-alignment': [{\n text: ['left', 'center', 'right', 'justify', 'start', 'end']\n }],\n /**\n * Placeholder Color\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://v3.tailwindcss.com/docs/placeholder-color\n */\n 'placeholder-color': [{\n placeholder: scaleColor()\n }],\n /**\n * Text Color\n * @see https://tailwindcss.com/docs/text-color\n */\n 'text-color': [{\n text: scaleColor()\n }],\n /**\n * Text Decoration\n * @see https://tailwindcss.com/docs/text-decoration\n */\n 'text-decoration': ['underline', 'overline', 'line-through', 'no-underline'],\n /**\n * Text Decoration Style\n * @see https://tailwindcss.com/docs/text-decoration-style\n */\n 'text-decoration-style': [{\n decoration: [...scaleLineStyle(), 'wavy']\n }],\n /**\n * Text Decoration Thickness\n * @see https://tailwindcss.com/docs/text-decoration-thickness\n */\n 'text-decoration-thickness': [{\n decoration: [isNumber, 'from-font', 'auto', isArbitraryVariable, isArbitraryLength]\n }],\n /**\n * Text Decoration Color\n * @see https://tailwindcss.com/docs/text-decoration-color\n */\n 'text-decoration-color': [{\n decoration: scaleColor()\n }],\n /**\n * Text Underline Offset\n * @see https://tailwindcss.com/docs/text-underline-offset\n */\n 'underline-offset': [{\n 'underline-offset': [isNumber, 'auto', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Text Transform\n * @see https://tailwindcss.com/docs/text-transform\n */\n 'text-transform': ['uppercase', 'lowercase', 'capitalize', 'normal-case'],\n /**\n * Text Overflow\n * @see https://tailwindcss.com/docs/text-overflow\n */\n 'text-overflow': ['truncate', 'text-ellipsis', 'text-clip'],\n /**\n * Text Wrap\n * @see https://tailwindcss.com/docs/text-wrap\n */\n 'text-wrap': [{\n text: ['wrap', 'nowrap', 'balance', 'pretty']\n }],\n /**\n * Text Indent\n * @see https://tailwindcss.com/docs/text-indent\n */\n indent: [{\n indent: scaleUnambiguousSpacing()\n }],\n /**\n * Vertical Alignment\n * @see https://tailwindcss.com/docs/vertical-align\n */\n 'vertical-align': [{\n align: ['baseline', 'top', 'middle', 'bottom', 'text-top', 'text-bottom', 'sub', 'super', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Whitespace\n * @see https://tailwindcss.com/docs/whitespace\n */\n whitespace: [{\n whitespace: ['normal', 'nowrap', 'pre', 'pre-line', 'pre-wrap', 'break-spaces']\n }],\n /**\n * Word Break\n * @see https://tailwindcss.com/docs/word-break\n */\n break: [{\n break: ['normal', 'words', 'all', 'keep']\n }],\n /**\n * Overflow Wrap\n * @see https://tailwindcss.com/docs/overflow-wrap\n */\n wrap: [{\n wrap: ['break-word', 'anywhere', 'normal']\n }],\n /**\n * Hyphens\n * @see https://tailwindcss.com/docs/hyphens\n */\n hyphens: [{\n hyphens: ['none', 'manual', 'auto']\n }],\n /**\n * Content\n * @see https://tailwindcss.com/docs/content\n */\n content: [{\n content: ['none', isArbitraryVariable, isArbitraryValue]\n }],\n // -------------------\n // --- Backgrounds ---\n // -------------------\n /**\n * Background Attachment\n * @see https://tailwindcss.com/docs/background-attachment\n */\n 'bg-attachment': [{\n bg: ['fixed', 'local', 'scroll']\n }],\n /**\n * Background Clip\n * @see https://tailwindcss.com/docs/background-clip\n */\n 'bg-clip': [{\n 'bg-clip': ['border', 'padding', 'content', 'text']\n }],\n /**\n * Background Origin\n * @see https://tailwindcss.com/docs/background-origin\n */\n 'bg-origin': [{\n 'bg-origin': ['border', 'padding', 'content']\n }],\n /**\n * Background Position\n * @see https://tailwindcss.com/docs/background-position\n */\n 'bg-position': [{\n bg: scaleBgPosition()\n }],\n /**\n * Background Repeat\n * @see https://tailwindcss.com/docs/background-repeat\n */\n 'bg-repeat': [{\n bg: scaleBgRepeat()\n }],\n /**\n * Background Size\n * @see https://tailwindcss.com/docs/background-size\n */\n 'bg-size': [{\n bg: scaleBgSize()\n }],\n /**\n * Background Image\n * @see https://tailwindcss.com/docs/background-image\n */\n 'bg-image': [{\n bg: ['none', {\n linear: [{\n to: ['t', 'tr', 'r', 'br', 'b', 'bl', 'l', 'tl']\n }, isInteger, isArbitraryVariable, isArbitraryValue],\n radial: ['', isArbitraryVariable, isArbitraryValue],\n conic: [isInteger, isArbitraryVariable, isArbitraryValue]\n }, isArbitraryVariableImage, isArbitraryImage]\n }],\n /**\n * Background Color\n * @see https://tailwindcss.com/docs/background-color\n */\n 'bg-color': [{\n bg: scaleColor()\n }],\n /**\n * Gradient Color Stops From Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from-pos': [{\n from: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops Via Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via-pos': [{\n via: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops To Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to-pos': [{\n to: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops From\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from': [{\n from: scaleColor()\n }],\n /**\n * Gradient Color Stops Via\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via': [{\n via: scaleColor()\n }],\n /**\n * Gradient Color Stops To\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to': [{\n to: scaleColor()\n }],\n // ---------------\n // --- Borders ---\n // ---------------\n /**\n * Border Radius\n * @see https://tailwindcss.com/docs/border-radius\n */\n rounded: [{\n rounded: scaleRadius()\n }],\n /**\n * Border Radius Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-s': [{\n 'rounded-s': scaleRadius()\n }],\n /**\n * Border Radius End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-e': [{\n 'rounded-e': scaleRadius()\n }],\n /**\n * Border Radius Top\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-t': [{\n 'rounded-t': scaleRadius()\n }],\n /**\n * Border Radius Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-r': [{\n 'rounded-r': scaleRadius()\n }],\n /**\n * Border Radius Bottom\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-b': [{\n 'rounded-b': scaleRadius()\n }],\n /**\n * Border Radius Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-l': [{\n 'rounded-l': scaleRadius()\n }],\n /**\n * Border Radius Start Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ss': [{\n 'rounded-ss': scaleRadius()\n }],\n /**\n * Border Radius Start End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-se': [{\n 'rounded-se': scaleRadius()\n }],\n /**\n * Border Radius End End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ee': [{\n 'rounded-ee': scaleRadius()\n }],\n /**\n * Border Radius End Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-es': [{\n 'rounded-es': scaleRadius()\n }],\n /**\n * Border Radius Top Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tl': [{\n 'rounded-tl': scaleRadius()\n }],\n /**\n * Border Radius Top Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tr': [{\n 'rounded-tr': scaleRadius()\n }],\n /**\n * Border Radius Bottom Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-br': [{\n 'rounded-br': scaleRadius()\n }],\n /**\n * Border Radius Bottom Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-bl': [{\n 'rounded-bl': scaleRadius()\n }],\n /**\n * Border Width\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w': [{\n border: scaleBorderWidth()\n }],\n /**\n * Border Width X\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-x': [{\n 'border-x': scaleBorderWidth()\n }],\n /**\n * Border Width Y\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-y': [{\n 'border-y': scaleBorderWidth()\n }],\n /**\n * Border Width Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-s': [{\n 'border-s': scaleBorderWidth()\n }],\n /**\n * Border Width End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-e': [{\n 'border-e': scaleBorderWidth()\n }],\n /**\n * Border Width Top\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-t': [{\n 'border-t': scaleBorderWidth()\n }],\n /**\n * Border Width Right\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-r': [{\n 'border-r': scaleBorderWidth()\n }],\n /**\n * Border Width Bottom\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-b': [{\n 'border-b': scaleBorderWidth()\n }],\n /**\n * Border Width Left\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-l': [{\n 'border-l': scaleBorderWidth()\n }],\n /**\n * Divide Width X\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x': [{\n 'divide-x': scaleBorderWidth()\n }],\n /**\n * Divide Width X Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x-reverse': ['divide-x-reverse'],\n /**\n * Divide Width Y\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y': [{\n 'divide-y': scaleBorderWidth()\n }],\n /**\n * Divide Width Y Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y-reverse': ['divide-y-reverse'],\n /**\n * Border Style\n * @see https://tailwindcss.com/docs/border-style\n */\n 'border-style': [{\n border: [...scaleLineStyle(), 'hidden', 'none']\n }],\n /**\n * Divide Style\n * @see https://tailwindcss.com/docs/border-style#setting-the-divider-style\n */\n 'divide-style': [{\n divide: [...scaleLineStyle(), 'hidden', 'none']\n }],\n /**\n * Border Color\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color': [{\n border: scaleColor()\n }],\n /**\n * Border Color X\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-x': [{\n 'border-x': scaleColor()\n }],\n /**\n * Border Color Y\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-y': [{\n 'border-y': scaleColor()\n }],\n /**\n * Border Color S\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-s': [{\n 'border-s': scaleColor()\n }],\n /**\n * Border Color E\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-e': [{\n 'border-e': scaleColor()\n }],\n /**\n * Border Color Top\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-t': [{\n 'border-t': scaleColor()\n }],\n /**\n * Border Color Right\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-r': [{\n 'border-r': scaleColor()\n }],\n /**\n * Border Color Bottom\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-b': [{\n 'border-b': scaleColor()\n }],\n /**\n * Border Color Left\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-l': [{\n 'border-l': scaleColor()\n }],\n /**\n * Divide Color\n * @see https://tailwindcss.com/docs/divide-color\n */\n 'divide-color': [{\n divide: scaleColor()\n }],\n /**\n * Outline Style\n * @see https://tailwindcss.com/docs/outline-style\n */\n 'outline-style': [{\n outline: [...scaleLineStyle(), 'none', 'hidden']\n }],\n /**\n * Outline Offset\n * @see https://tailwindcss.com/docs/outline-offset\n */\n 'outline-offset': [{\n 'outline-offset': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Outline Width\n * @see https://tailwindcss.com/docs/outline-width\n */\n 'outline-w': [{\n outline: ['', isNumber, isArbitraryVariableLength, isArbitraryLength]\n }],\n /**\n * Outline Color\n * @see https://tailwindcss.com/docs/outline-color\n */\n 'outline-color': [{\n outline: scaleColor()\n }],\n // ---------------\n // --- Effects ---\n // ---------------\n /**\n * Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow\n */\n shadow: [{\n shadow: [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-shadow-color\n */\n 'shadow-color': [{\n shadow: scaleColor()\n }],\n /**\n * Inset Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-shadow\n */\n 'inset-shadow': [{\n 'inset-shadow': ['none', themeInsetShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Inset Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-shadow-color\n */\n 'inset-shadow-color': [{\n 'inset-shadow': scaleColor()\n }],\n /**\n * Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-a-ring\n */\n 'ring-w': [{\n ring: scaleBorderWidth()\n }],\n /**\n * Ring Width Inset\n * @see https://v3.tailwindcss.com/docs/ring-width#inset-rings\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-w-inset': ['ring-inset'],\n /**\n * Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-ring-color\n */\n 'ring-color': [{\n ring: scaleColor()\n }],\n /**\n * Ring Offset Width\n * @see https://v3.tailwindcss.com/docs/ring-offset-width\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-w': [{\n 'ring-offset': [isNumber, isArbitraryLength]\n }],\n /**\n * Ring Offset Color\n * @see https://v3.tailwindcss.com/docs/ring-offset-color\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-color': [{\n 'ring-offset': scaleColor()\n }],\n /**\n * Inset Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-ring\n */\n 'inset-ring-w': [{\n 'inset-ring': scaleBorderWidth()\n }],\n /**\n * Inset Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-ring-color\n */\n 'inset-ring-color': [{\n 'inset-ring': scaleColor()\n }],\n /**\n * Text Shadow\n * @see https://tailwindcss.com/docs/text-shadow\n */\n 'text-shadow': [{\n 'text-shadow': ['none', themeTextShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Text Shadow Color\n * @see https://tailwindcss.com/docs/text-shadow#setting-the-shadow-color\n */\n 'text-shadow-color': [{\n 'text-shadow': scaleColor()\n }],\n /**\n * Opacity\n * @see https://tailwindcss.com/docs/opacity\n */\n opacity: [{\n opacity: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Mix Blend Mode\n * @see https://tailwindcss.com/docs/mix-blend-mode\n */\n 'mix-blend': [{\n 'mix-blend': [...scaleBlendMode(), 'plus-darker', 'plus-lighter']\n }],\n /**\n * Background Blend Mode\n * @see https://tailwindcss.com/docs/background-blend-mode\n */\n 'bg-blend': [{\n 'bg-blend': scaleBlendMode()\n }],\n /**\n * Mask Clip\n * @see https://tailwindcss.com/docs/mask-clip\n */\n 'mask-clip': [{\n 'mask-clip': ['border', 'padding', 'content', 'fill', 'stroke', 'view']\n }, 'mask-no-clip'],\n /**\n * Mask Composite\n * @see https://tailwindcss.com/docs/mask-composite\n */\n 'mask-composite': [{\n mask: ['add', 'subtract', 'intersect', 'exclude']\n }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image-linear-pos': [{\n 'mask-linear': [isNumber]\n }],\n 'mask-image-linear-from-pos': [{\n 'mask-linear-from': scaleMaskImagePosition()\n }],\n 'mask-image-linear-to-pos': [{\n 'mask-linear-to': scaleMaskImagePosition()\n }],\n 'mask-image-linear-from-color': [{\n 'mask-linear-from': scaleColor()\n }],\n 'mask-image-linear-to-color': [{\n 'mask-linear-to': scaleColor()\n }],\n 'mask-image-t-from-pos': [{\n 'mask-t-from': scaleMaskImagePosition()\n }],\n 'mask-image-t-to-pos': [{\n 'mask-t-to': scaleMaskImagePosition()\n }],\n 'mask-image-t-from-color': [{\n 'mask-t-from': scaleColor()\n }],\n 'mask-image-t-to-color': [{\n 'mask-t-to': scaleColor()\n }],\n 'mask-image-r-from-pos': [{\n 'mask-r-from': scaleMaskImagePosition()\n }],\n 'mask-image-r-to-pos': [{\n 'mask-r-to': scaleMaskImagePosition()\n }],\n 'mask-image-r-from-color': [{\n 'mask-r-from': scaleColor()\n }],\n 'mask-image-r-to-color': [{\n 'mask-r-to': scaleColor()\n }],\n 'mask-image-b-from-pos': [{\n 'mask-b-from': scaleMaskImagePosition()\n }],\n 'mask-image-b-to-pos': [{\n 'mask-b-to': scaleMaskImagePosition()\n }],\n 'mask-image-b-from-color': [{\n 'mask-b-from': scaleColor()\n }],\n 'mask-image-b-to-color': [{\n 'mask-b-to': scaleColor()\n }],\n 'mask-image-l-from-pos': [{\n 'mask-l-from': scaleMaskImagePosition()\n }],\n 'mask-image-l-to-pos': [{\n 'mask-l-to': scaleMaskImagePosition()\n }],\n 'mask-image-l-from-color': [{\n 'mask-l-from': scaleColor()\n }],\n 'mask-image-l-to-color': [{\n 'mask-l-to': scaleColor()\n }],\n 'mask-image-x-from-pos': [{\n 'mask-x-from': scaleMaskImagePosition()\n }],\n 'mask-image-x-to-pos': [{\n 'mask-x-to': scaleMaskImagePosition()\n }],\n 'mask-image-x-from-color': [{\n 'mask-x-from': scaleColor()\n }],\n 'mask-image-x-to-color': [{\n 'mask-x-to': scaleColor()\n }],\n 'mask-image-y-from-pos': [{\n 'mask-y-from': scaleMaskImagePosition()\n }],\n 'mask-image-y-to-pos': [{\n 'mask-y-to': scaleMaskImagePosition()\n }],\n 'mask-image-y-from-color': [{\n 'mask-y-from': scaleColor()\n }],\n 'mask-image-y-to-color': [{\n 'mask-y-to': scaleColor()\n }],\n 'mask-image-radial': [{\n 'mask-radial': [isArbitraryVariable, isArbitraryValue]\n }],\n 'mask-image-radial-from-pos': [{\n 'mask-radial-from': scaleMaskImagePosition()\n }],\n 'mask-image-radial-to-pos': [{\n 'mask-radial-to': scaleMaskImagePosition()\n }],\n 'mask-image-radial-from-color': [{\n 'mask-radial-from': scaleColor()\n }],\n 'mask-image-radial-to-color': [{\n 'mask-radial-to': scaleColor()\n }],\n 'mask-image-radial-shape': [{\n 'mask-radial': ['circle', 'ellipse']\n }],\n 'mask-image-radial-size': [{\n 'mask-radial': [{\n closest: ['side', 'corner'],\n farthest: ['side', 'corner']\n }]\n }],\n 'mask-image-radial-pos': [{\n 'mask-radial-at': scalePosition()\n }],\n 'mask-image-conic-pos': [{\n 'mask-conic': [isNumber]\n }],\n 'mask-image-conic-from-pos': [{\n 'mask-conic-from': scaleMaskImagePosition()\n }],\n 'mask-image-conic-to-pos': [{\n 'mask-conic-to': scaleMaskImagePosition()\n }],\n 'mask-image-conic-from-color': [{\n 'mask-conic-from': scaleColor()\n }],\n 'mask-image-conic-to-color': [{\n 'mask-conic-to': scaleColor()\n }],\n /**\n * Mask Mode\n * @see https://tailwindcss.com/docs/mask-mode\n */\n 'mask-mode': [{\n mask: ['alpha', 'luminance', 'match']\n }],\n /**\n * Mask Origin\n * @see https://tailwindcss.com/docs/mask-origin\n */\n 'mask-origin': [{\n 'mask-origin': ['border', 'padding', 'content', 'fill', 'stroke', 'view']\n }],\n /**\n * Mask Position\n * @see https://tailwindcss.com/docs/mask-position\n */\n 'mask-position': [{\n mask: scaleBgPosition()\n }],\n /**\n * Mask Repeat\n * @see https://tailwindcss.com/docs/mask-repeat\n */\n 'mask-repeat': [{\n mask: scaleBgRepeat()\n }],\n /**\n * Mask Size\n * @see https://tailwindcss.com/docs/mask-size\n */\n 'mask-size': [{\n mask: scaleBgSize()\n }],\n /**\n * Mask Type\n * @see https://tailwindcss.com/docs/mask-type\n */\n 'mask-type': [{\n 'mask-type': ['alpha', 'luminance']\n }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image': [{\n mask: ['none', isArbitraryVariable, isArbitraryValue]\n }],\n // ---------------\n // --- Filters ---\n // ---------------\n /**\n * Filter\n * @see https://tailwindcss.com/docs/filter\n */\n filter: [{\n filter: [\n // Deprecated since Tailwind CSS v3.0.0\n '', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Blur\n * @see https://tailwindcss.com/docs/blur\n */\n blur: [{\n blur: scaleBlur()\n }],\n /**\n * Brightness\n * @see https://tailwindcss.com/docs/brightness\n */\n brightness: [{\n brightness: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Contrast\n * @see https://tailwindcss.com/docs/contrast\n */\n contrast: [{\n contrast: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Drop Shadow\n * @see https://tailwindcss.com/docs/drop-shadow\n */\n 'drop-shadow': [{\n 'drop-shadow': [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeDropShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Drop Shadow Color\n * @see https://tailwindcss.com/docs/filter-drop-shadow#setting-the-shadow-color\n */\n 'drop-shadow-color': [{\n 'drop-shadow': scaleColor()\n }],\n /**\n * Grayscale\n * @see https://tailwindcss.com/docs/grayscale\n */\n grayscale: [{\n grayscale: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Hue Rotate\n * @see https://tailwindcss.com/docs/hue-rotate\n */\n 'hue-rotate': [{\n 'hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Invert\n * @see https://tailwindcss.com/docs/invert\n */\n invert: [{\n invert: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Saturate\n * @see https://tailwindcss.com/docs/saturate\n */\n saturate: [{\n saturate: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Sepia\n * @see https://tailwindcss.com/docs/sepia\n */\n sepia: [{\n sepia: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Filter\n * @see https://tailwindcss.com/docs/backdrop-filter\n */\n 'backdrop-filter': [{\n 'backdrop-filter': [\n // Deprecated since Tailwind CSS v3.0.0\n '', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Blur\n * @see https://tailwindcss.com/docs/backdrop-blur\n */\n 'backdrop-blur': [{\n 'backdrop-blur': scaleBlur()\n }],\n /**\n * Backdrop Brightness\n * @see https://tailwindcss.com/docs/backdrop-brightness\n */\n 'backdrop-brightness': [{\n 'backdrop-brightness': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Contrast\n * @see https://tailwindcss.com/docs/backdrop-contrast\n */\n 'backdrop-contrast': [{\n 'backdrop-contrast': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Grayscale\n * @see https://tailwindcss.com/docs/backdrop-grayscale\n */\n 'backdrop-grayscale': [{\n 'backdrop-grayscale': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Hue Rotate\n * @see https://tailwindcss.com/docs/backdrop-hue-rotate\n */\n 'backdrop-hue-rotate': [{\n 'backdrop-hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Invert\n * @see https://tailwindcss.com/docs/backdrop-invert\n */\n 'backdrop-invert': [{\n 'backdrop-invert': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Opacity\n * @see https://tailwindcss.com/docs/backdrop-opacity\n */\n 'backdrop-opacity': [{\n 'backdrop-opacity': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Saturate\n * @see https://tailwindcss.com/docs/backdrop-saturate\n */\n 'backdrop-saturate': [{\n 'backdrop-saturate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Sepia\n * @see https://tailwindcss.com/docs/backdrop-sepia\n */\n 'backdrop-sepia': [{\n 'backdrop-sepia': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n // --------------\n // --- Tables ---\n // --------------\n /**\n * Border Collapse\n * @see https://tailwindcss.com/docs/border-collapse\n */\n 'border-collapse': [{\n border: ['collapse', 'separate']\n }],\n /**\n * Border Spacing\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing': [{\n 'border-spacing': scaleUnambiguousSpacing()\n }],\n /**\n * Border Spacing X\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-x': [{\n 'border-spacing-x': scaleUnambiguousSpacing()\n }],\n /**\n * Border Spacing Y\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-y': [{\n 'border-spacing-y': scaleUnambiguousSpacing()\n }],\n /**\n * Table Layout\n * @see https://tailwindcss.com/docs/table-layout\n */\n 'table-layout': [{\n table: ['auto', 'fixed']\n }],\n /**\n * Caption Side\n * @see https://tailwindcss.com/docs/caption-side\n */\n caption: [{\n caption: ['top', 'bottom']\n }],\n // ---------------------------------\n // --- Transitions and Animation ---\n // ---------------------------------\n /**\n * Transition Property\n * @see https://tailwindcss.com/docs/transition-property\n */\n transition: [{\n transition: ['', 'all', 'colors', 'opacity', 'shadow', 'transform', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Behavior\n * @see https://tailwindcss.com/docs/transition-behavior\n */\n 'transition-behavior': [{\n transition: ['normal', 'discrete']\n }],\n /**\n * Transition Duration\n * @see https://tailwindcss.com/docs/transition-duration\n */\n duration: [{\n duration: [isNumber, 'initial', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Timing Function\n * @see https://tailwindcss.com/docs/transition-timing-function\n */\n ease: [{\n ease: ['linear', 'initial', themeEase, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Delay\n * @see https://tailwindcss.com/docs/transition-delay\n */\n delay: [{\n delay: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Animation\n * @see https://tailwindcss.com/docs/animation\n */\n animate: [{\n animate: ['none', themeAnimate, isArbitraryVariable, isArbitraryValue]\n }],\n // ------------------\n // --- Transforms ---\n // ------------------\n /**\n * Backface Visibility\n * @see https://tailwindcss.com/docs/backface-visibility\n */\n backface: [{\n backface: ['hidden', 'visible']\n }],\n /**\n * Perspective\n * @see https://tailwindcss.com/docs/perspective\n */\n perspective: [{\n perspective: [themePerspective, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Perspective Origin\n * @see https://tailwindcss.com/docs/perspective-origin\n */\n 'perspective-origin': [{\n 'perspective-origin': scalePositionWithArbitrary()\n }],\n /**\n * Rotate\n * @see https://tailwindcss.com/docs/rotate\n */\n rotate: [{\n rotate: scaleRotate()\n }],\n /**\n * Rotate X\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-x': [{\n 'rotate-x': scaleRotate()\n }],\n /**\n * Rotate Y\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-y': [{\n 'rotate-y': scaleRotate()\n }],\n /**\n * Rotate Z\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-z': [{\n 'rotate-z': scaleRotate()\n }],\n /**\n * Scale\n * @see https://tailwindcss.com/docs/scale\n */\n scale: [{\n scale: scaleScale()\n }],\n /**\n * Scale X\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-x': [{\n 'scale-x': scaleScale()\n }],\n /**\n * Scale Y\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-y': [{\n 'scale-y': scaleScale()\n }],\n /**\n * Scale Z\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-z': [{\n 'scale-z': scaleScale()\n }],\n /**\n * Scale 3D\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-3d': ['scale-3d'],\n /**\n * Skew\n * @see https://tailwindcss.com/docs/skew\n */\n skew: [{\n skew: scaleSkew()\n }],\n /**\n * Skew X\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-x': [{\n 'skew-x': scaleSkew()\n }],\n /**\n * Skew Y\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-y': [{\n 'skew-y': scaleSkew()\n }],\n /**\n * Transform\n * @see https://tailwindcss.com/docs/transform\n */\n transform: [{\n transform: [isArbitraryVariable, isArbitraryValue, '', 'none', 'gpu', 'cpu']\n }],\n /**\n * Transform Origin\n * @see https://tailwindcss.com/docs/transform-origin\n */\n 'transform-origin': [{\n origin: scalePositionWithArbitrary()\n }],\n /**\n * Transform Style\n * @see https://tailwindcss.com/docs/transform-style\n */\n 'transform-style': [{\n transform: ['3d', 'flat']\n }],\n /**\n * Translate\n * @see https://tailwindcss.com/docs/translate\n */\n translate: [{\n translate: scaleTranslate()\n }],\n /**\n * Translate X\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-x': [{\n 'translate-x': scaleTranslate()\n }],\n /**\n * Translate Y\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-y': [{\n 'translate-y': scaleTranslate()\n }],\n /**\n * Translate Z\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-z': [{\n 'translate-z': scaleTranslate()\n }],\n /**\n * Translate None\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-none': ['translate-none'],\n // ---------------------\n // --- Interactivity ---\n // ---------------------\n /**\n * Accent Color\n * @see https://tailwindcss.com/docs/accent-color\n */\n accent: [{\n accent: scaleColor()\n }],\n /**\n * Appearance\n * @see https://tailwindcss.com/docs/appearance\n */\n appearance: [{\n appearance: ['none', 'auto']\n }],\n /**\n * Caret Color\n * @see https://tailwindcss.com/docs/just-in-time-mode#caret-color-utilities\n */\n 'caret-color': [{\n caret: scaleColor()\n }],\n /**\n * Color Scheme\n * @see https://tailwindcss.com/docs/color-scheme\n */\n 'color-scheme': [{\n scheme: ['normal', 'dark', 'light', 'light-dark', 'only-dark', 'only-light']\n }],\n /**\n * Cursor\n * @see https://tailwindcss.com/docs/cursor\n */\n cursor: [{\n cursor: ['auto', 'default', 'pointer', 'wait', 'text', 'move', 'help', 'not-allowed', 'none', 'context-menu', 'progress', 'cell', 'crosshair', 'vertical-text', 'alias', 'copy', 'no-drop', 'grab', 'grabbing', 'all-scroll', 'col-resize', 'row-resize', 'n-resize', 'e-resize', 's-resize', 'w-resize', 'ne-resize', 'nw-resize', 'se-resize', 'sw-resize', 'ew-resize', 'ns-resize', 'nesw-resize', 'nwse-resize', 'zoom-in', 'zoom-out', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Field Sizing\n * @see https://tailwindcss.com/docs/field-sizing\n */\n 'field-sizing': [{\n 'field-sizing': ['fixed', 'content']\n }],\n /**\n * Pointer Events\n * @see https://tailwindcss.com/docs/pointer-events\n */\n 'pointer-events': [{\n 'pointer-events': ['auto', 'none']\n }],\n /**\n * Resize\n * @see https://tailwindcss.com/docs/resize\n */\n resize: [{\n resize: ['none', '', 'y', 'x']\n }],\n /**\n * Scroll Behavior\n * @see https://tailwindcss.com/docs/scroll-behavior\n */\n 'scroll-behavior': [{\n scroll: ['auto', 'smooth']\n }],\n /**\n * Scroll Margin\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-m': [{\n 'scroll-m': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin X\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mx': [{\n 'scroll-mx': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Y\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-my': [{\n 'scroll-my': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ms': [{\n 'scroll-ms': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-me': [{\n 'scroll-me': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Top\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mt': [{\n 'scroll-mt': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Right\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mr': [{\n 'scroll-mr': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Bottom\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mb': [{\n 'scroll-mb': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Left\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ml': [{\n 'scroll-ml': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-p': [{\n 'scroll-p': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding X\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-px': [{\n 'scroll-px': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Y\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-py': [{\n 'scroll-py': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-ps': [{\n 'scroll-ps': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pe': [{\n 'scroll-pe': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Top\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pt': [{\n 'scroll-pt': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Right\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pr': [{\n 'scroll-pr': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Bottom\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pb': [{\n 'scroll-pb': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Left\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pl': [{\n 'scroll-pl': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Snap Align\n * @see https://tailwindcss.com/docs/scroll-snap-align\n */\n 'snap-align': [{\n snap: ['start', 'end', 'center', 'align-none']\n }],\n /**\n * Scroll Snap Stop\n * @see https://tailwindcss.com/docs/scroll-snap-stop\n */\n 'snap-stop': [{\n snap: ['normal', 'always']\n }],\n /**\n * Scroll Snap Type\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-type': [{\n snap: ['none', 'x', 'y', 'both']\n }],\n /**\n * Scroll Snap Type Strictness\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-strictness': [{\n snap: ['mandatory', 'proximity']\n }],\n /**\n * Touch Action\n * @see https://tailwindcss.com/docs/touch-action\n */\n touch: [{\n touch: ['auto', 'none', 'manipulation']\n }],\n /**\n * Touch Action X\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-x': [{\n 'touch-pan': ['x', 'left', 'right']\n }],\n /**\n * Touch Action Y\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-y': [{\n 'touch-pan': ['y', 'up', 'down']\n }],\n /**\n * Touch Action Pinch Zoom\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-pz': ['touch-pinch-zoom'],\n /**\n * User Select\n * @see https://tailwindcss.com/docs/user-select\n */\n select: [{\n select: ['none', 'text', 'all', 'auto']\n }],\n /**\n * Will Change\n * @see https://tailwindcss.com/docs/will-change\n */\n 'will-change': [{\n 'will-change': ['auto', 'scroll', 'contents', 'transform', isArbitraryVariable, isArbitraryValue]\n }],\n // -----------\n // --- SVG ---\n // -----------\n /**\n * Fill\n * @see https://tailwindcss.com/docs/fill\n */\n fill: [{\n fill: ['none', ...scaleColor()]\n }],\n /**\n * Stroke Width\n * @see https://tailwindcss.com/docs/stroke-width\n */\n 'stroke-w': [{\n stroke: [isNumber, isArbitraryVariableLength, isArbitraryLength, isArbitraryNumber]\n }],\n /**\n * Stroke\n * @see https://tailwindcss.com/docs/stroke\n */\n stroke: [{\n stroke: ['none', ...scaleColor()]\n }],\n // ---------------------\n // --- Accessibility ---\n // ---------------------\n /**\n * Forced Color Adjust\n * @see https://tailwindcss.com/docs/forced-color-adjust\n */\n 'forced-color-adjust': [{\n 'forced-color-adjust': ['auto', 'none']\n }]\n },\n conflictingClassGroups: {\n overflow: ['overflow-x', 'overflow-y'],\n overscroll: ['overscroll-x', 'overscroll-y'],\n inset: ['inset-x', 'inset-y', 'start', 'end', 'top', 'right', 'bottom', 'left'],\n 'inset-x': ['right', 'left'],\n 'inset-y': ['top', 'bottom'],\n flex: ['basis', 'grow', 'shrink'],\n gap: ['gap-x', 'gap-y'],\n p: ['px', 'py', 'ps', 'pe', 'pt', 'pr', 'pb', 'pl'],\n px: ['pr', 'pl'],\n py: ['pt', 'pb'],\n m: ['mx', 'my', 'ms', 'me', 'mt', 'mr', 'mb', 'ml'],\n mx: ['mr', 'ml'],\n my: ['mt', 'mb'],\n size: ['w', 'h'],\n 'font-size': ['leading'],\n 'fvn-normal': ['fvn-ordinal', 'fvn-slashed-zero', 'fvn-figure', 'fvn-spacing', 'fvn-fraction'],\n 'fvn-ordinal': ['fvn-normal'],\n 'fvn-slashed-zero': ['fvn-normal'],\n 'fvn-figure': ['fvn-normal'],\n 'fvn-spacing': ['fvn-normal'],\n 'fvn-fraction': ['fvn-normal'],\n 'line-clamp': ['display', 'overflow'],\n rounded: ['rounded-s', 'rounded-e', 'rounded-t', 'rounded-r', 'rounded-b', 'rounded-l', 'rounded-ss', 'rounded-se', 'rounded-ee', 'rounded-es', 'rounded-tl', 'rounded-tr', 'rounded-br', 'rounded-bl'],\n 'rounded-s': ['rounded-ss', 'rounded-es'],\n 'rounded-e': ['rounded-se', 'rounded-ee'],\n 'rounded-t': ['rounded-tl', 'rounded-tr'],\n 'rounded-r': ['rounded-tr', 'rounded-br'],\n 'rounded-b': ['rounded-br', 'rounded-bl'],\n 'rounded-l': ['rounded-tl', 'rounded-bl'],\n 'border-spacing': ['border-spacing-x', 'border-spacing-y'],\n 'border-w': ['border-w-x', 'border-w-y', 'border-w-s', 'border-w-e', 'border-w-t', 'border-w-r', 'border-w-b', 'border-w-l'],\n 'border-w-x': ['border-w-r', 'border-w-l'],\n 'border-w-y': ['border-w-t', 'border-w-b'],\n 'border-color': ['border-color-x', 'border-color-y', 'border-color-s', 'border-color-e', 'border-color-t', 'border-color-r', 'border-color-b', 'border-color-l'],\n 'border-color-x': ['border-color-r', 'border-color-l'],\n 'border-color-y': ['border-color-t', 'border-color-b'],\n translate: ['translate-x', 'translate-y', 'translate-none'],\n 'translate-none': ['translate', 'translate-x', 'translate-y', 'translate-z'],\n 'scroll-m': ['scroll-mx', 'scroll-my', 'scroll-ms', 'scroll-me', 'scroll-mt', 'scroll-mr', 'scroll-mb', 'scroll-ml'],\n 'scroll-mx': ['scroll-mr', 'scroll-ml'],\n 'scroll-my': ['scroll-mt', 'scroll-mb'],\n 'scroll-p': ['scroll-px', 'scroll-py', 'scroll-ps', 'scroll-pe', 'scroll-pt', 'scroll-pr', 'scroll-pb', 'scroll-pl'],\n 'scroll-px': ['scroll-pr', 'scroll-pl'],\n 'scroll-py': ['scroll-pt', 'scroll-pb'],\n touch: ['touch-x', 'touch-y', 'touch-pz'],\n 'touch-x': ['touch'],\n 'touch-y': ['touch'],\n 'touch-pz': ['touch']\n },\n conflictingClassGroupModifiers: {\n 'font-size': ['leading']\n },\n orderSensitiveModifiers: ['*', '**', 'after', 'backdrop', 'before', 'details-content', 'file', 'first-letter', 'first-line', 'marker', 'placeholder', 'selection']\n };\n};\n\n/**\n * @param baseConfig Config where other config will be merged into. This object will be mutated.\n * @param configExtension Partial config to merge into the `baseConfig`.\n */\nconst mergeConfigs = (baseConfig, {\n cacheSize,\n prefix,\n experimentalParseClassName,\n extend = {},\n override = {}\n}) => {\n overrideProperty(baseConfig, 'cacheSize', cacheSize);\n overrideProperty(baseConfig, 'prefix', prefix);\n overrideProperty(baseConfig, 'experimentalParseClassName', experimentalParseClassName);\n overrideConfigProperties(baseConfig.theme, override.theme);\n overrideConfigProperties(baseConfig.classGroups, override.classGroups);\n overrideConfigProperties(baseConfig.conflictingClassGroups, override.conflictingClassGroups);\n overrideConfigProperties(baseConfig.conflictingClassGroupModifiers, override.conflictingClassGroupModifiers);\n overrideProperty(baseConfig, 'orderSensitiveModifiers', override.orderSensitiveModifiers);\n mergeConfigProperties(baseConfig.theme, extend.theme);\n mergeConfigProperties(baseConfig.classGroups, extend.classGroups);\n mergeConfigProperties(baseConfig.conflictingClassGroups, extend.conflictingClassGroups);\n mergeConfigProperties(baseConfig.conflictingClassGroupModifiers, extend.conflictingClassGroupModifiers);\n mergeArrayProperties(baseConfig, extend, 'orderSensitiveModifiers');\n return baseConfig;\n};\nconst overrideProperty = (baseObject, overrideKey, overrideValue) => {\n if (overrideValue !== undefined) {\n baseObject[overrideKey] = overrideValue;\n }\n};\nconst overrideConfigProperties = (baseObject, overrideObject) => {\n if (overrideObject) {\n for (const key in overrideObject) {\n overrideProperty(baseObject, key, overrideObject[key]);\n }\n }\n};\nconst mergeConfigProperties = (baseObject, mergeObject) => {\n if (mergeObject) {\n for (const key in mergeObject) {\n mergeArrayProperties(baseObject, mergeObject, key);\n }\n }\n};\nconst mergeArrayProperties = (baseObject, mergeObject, key) => {\n const mergeValue = mergeObject[key];\n if (mergeValue !== undefined) {\n baseObject[key] = baseObject[key] ? baseObject[key].concat(mergeValue) : mergeValue;\n }\n};\nconst extendTailwindMerge = (configExtension, ...createConfig) => typeof configExtension === 'function' ? createTailwindMerge(getDefaultConfig, configExtension, ...createConfig) : createTailwindMerge(() => mergeConfigs(getDefaultConfig(), configExtension), ...createConfig);\nconst twMerge = /*#__PURE__*/createTailwindMerge(getDefaultConfig);\nexport { createTailwindMerge, extendTailwindMerge, fromTheme, getDefaultConfig, mergeConfigs, twJoin, twMerge, validators };\n//# sourceMappingURL=bundle-mjs.mjs.map\n","import { type ClassValue, clsx } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n\treturn twMerge(clsx(inputs));\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { Accordion as BaseAccordion } from \"@base-ui-components/react/accordion\";\nimport { cn } from \"@/lib/utils\";\n\n// =============================================================================\n// Accordion\n// =============================================================================\n\nexport interface AccordionProps extends React.HTMLAttributes<HTMLDivElement> {\n\t/**\n\t * Allow multiple items to be expanded at once\n\t * @default false\n\t */\n\tallowMultiple?: boolean;\n\t/**\n\t * The ID(s) of items that should be expanded by default\n\t */\n\tdefaultExpanded?: string | string[];\n\tchildren: React.ReactNode;\n}\n\n/**\n * Accordion component for expandable/collapsible content sections.\n * Built on Base UI's Accordion primitive.\n *\n * @example\n * ```tsx\n * <Accordion defaultExpanded=\"item-1\">\n * <AccordionItem id=\"item-1\" title=\"Question 1\">\n * Answer to question 1\n * </AccordionItem>\n * <AccordionItem id=\"item-2\" title=\"Question 2\">\n * Answer to question 2\n * </AccordionItem>\n * </Accordion>\n * ```\n */\nconst Accordion = React.forwardRef<HTMLDivElement, AccordionProps>(\n\t({ className, allowMultiple = false, defaultExpanded, children }, ref) => {\n\t\t// Normalize defaultExpanded to array format for Base UI\n\t\tconst defaultValue = React.useMemo((): string[] | undefined => {\n\t\t\tif (!defaultExpanded) return undefined;\n\t\t\tif (Array.isArray(defaultExpanded)) return defaultExpanded;\n\t\t\treturn [defaultExpanded];\n\t\t}, [defaultExpanded]);\n\n\t\treturn (\n\t\t\t<BaseAccordion.Root\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"flex flex-col\", className)}\n\t\t\t\tdefaultValue={defaultValue}\n\t\t\t\tmultiple={allowMultiple}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</BaseAccordion.Root>\n\t\t);\n\t},\n);\nAccordion.displayName = \"Accordion\";\n\n// =============================================================================\n// AccordionItem\n// =============================================================================\n\nexport interface AccordionItemProps\n\textends Omit<React.HTMLAttributes<HTMLDivElement>, \"title\"> {\n\t/**\n\t * Unique identifier for this item\n\t */\n\tid: string;\n\t/**\n\t * The question/title displayed in the header\n\t */\n\ttitle: string;\n\t/**\n\t * The answer/content revealed when expanded\n\t */\n\tchildren: React.ReactNode;\n}\n\n/**\n * Individual accordion item with collapsible content.\n * Must be used within an Accordion component.\n */\nconst AccordionItem = React.forwardRef<HTMLDivElement, AccordionItemProps>(\n\t({ className, id, title, children }, ref) => {\n\t\treturn (\n\t\t\t<BaseAccordion.Item\n\t\t\t\tref={ref}\n\t\t\t\tvalue={id}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"border-b overflow-hidden\",\n\t\t\t\t\t\"border-gray-700 data-[open]:border-orange-400\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t{/* Header - always visible */}\n\t\t\t\t<BaseAccordion.Header>\n\t\t\t\t\t<BaseAccordion.Trigger\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\"flex w-full items-center justify-between py-spacing-28 text-left\",\n\t\t\t\t\t\t\t\"typography-body-large transition-colors cursor-pointer\",\n\t\t\t\t\t\t\t\"text-gray-500 hover:text-gray-300 data-[open]:text-gray-100\",\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t<span>{title}</span>\n\t\t\t\t\t\t<span\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"text-base transition-transform duration-200\",\n\t\t\t\t\t\t\t\t\"[[data-open]_&]:rotate-45\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t+\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</BaseAccordion.Trigger>\n\t\t\t\t</BaseAccordion.Header>\n\n\t\t\t\t{/* Content - collapsible */}\n\t\t\t\t<BaseAccordion.Panel\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"h-[var(--accordion-panel-height)] overflow-hidden\",\n\t\t\t\t\t\t\"transition-[height] duration-200 ease-in-out\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t<div className=\"typography-body-large text-gray-500 pb-spacing-28\">\n\t\t\t\t\t\t{children}\n\t\t\t\t\t</div>\n\t\t\t\t</BaseAccordion.Panel>\n\t\t\t</BaseAccordion.Item>\n\t\t);\n\t},\n);\nAccordionItem.displayName = \"AccordionItem\";\n\nexport { Accordion, AccordionItem };\n","'use client';\n\nimport * as React from 'react';\nimport { useButton } from \"../use-button/useButton.js\";\nimport { useRenderElement } from \"../utils/useRenderElement.js\";\n/**\n * A button component that can be used to trigger actions.\n * Renders a `<button>` element.\n *\n * Documentation: [Base UI Button](https://base-ui.com/react/components/button)\n */\nexport const Button = /*#__PURE__*/React.forwardRef(function Button(componentProps, forwardedRef) {\n const {\n render,\n className,\n disabled: disabledProp = false,\n focusableWhenDisabled = false,\n nativeButton = true,\n ...elementProps\n } = componentProps;\n const disabled = Boolean(disabledProp);\n const {\n getButtonProps,\n buttonRef\n } = useButton({\n disabled,\n focusableWhenDisabled,\n native: nativeButton\n });\n const state = React.useMemo(() => ({\n disabled\n }), [disabled]);\n return useRenderElement('button', componentProps, {\n state,\n ref: [forwardedRef, buttonRef],\n props: [elementProps, getButtonProps]\n });\n});\nif (process.env.NODE_ENV !== \"production\") Button.displayName = \"Button\";","/**\n * Copyright 2022 Joe Bell. All rights reserved.\n *\n * This file is licensed to you under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with the\n * License. You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR REPRESENTATIONS OF ANY KIND, either express or implied. See the\n * License for the specific language governing permissions and limitations under\n * the License.\n */ import { clsx } from \"clsx\";\nconst falsyToString = (value)=>typeof value === \"boolean\" ? `${value}` : value === 0 ? \"0\" : value;\nexport const cx = clsx;\nexport const cva = (base, config)=>(props)=>{\n var _config_compoundVariants;\n if ((config === null || config === void 0 ? void 0 : config.variants) == null) return cx(base, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n const { variants, defaultVariants } = config;\n const getVariantClassNames = Object.keys(variants).map((variant)=>{\n const variantProp = props === null || props === void 0 ? void 0 : props[variant];\n const defaultVariantProp = defaultVariants === null || defaultVariants === void 0 ? void 0 : defaultVariants[variant];\n if (variantProp === null) return null;\n const variantKey = falsyToString(variantProp) || falsyToString(defaultVariantProp);\n return variants[variant][variantKey];\n });\n const propsWithoutUndefined = props && Object.entries(props).reduce((acc, param)=>{\n let [key, value] = param;\n if (value === undefined) {\n return acc;\n }\n acc[key] = value;\n return acc;\n }, {});\n const getCompoundVariantClassNames = config === null || config === void 0 ? void 0 : (_config_compoundVariants = config.compoundVariants) === null || _config_compoundVariants === void 0 ? void 0 : _config_compoundVariants.reduce((acc, param)=>{\n let { class: cvClass, className: cvClassName, ...compoundVariantOptions } = param;\n return Object.entries(compoundVariantOptions).every((param)=>{\n let [key, value] = param;\n return Array.isArray(value) ? value.includes({\n ...defaultVariants,\n ...propsWithoutUndefined\n }[key]) : ({\n ...defaultVariants,\n ...propsWithoutUndefined\n })[key] === value;\n }) ? [\n ...acc,\n cvClass,\n cvClassName\n ] : acc;\n }, []);\n return cx(base, getVariantClassNames, getCompoundVariantClassNames, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n };\n\n","import {\n\tButton as BaseButton,\n\ttype ButtonProps as BaseButtonProps,\n} from \"@base-ui-components/react/button\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * Button component based on Figma BaseKit / Interface / Buttons\n *\n * Variants:\n * - charcoal: Dark filled button (for light backgrounds)\n * - charcoalOutline: Dark outlined button (for light backgrounds)\n * - charcoalOutlineQuiet: Subtle dark outlined button (for light backgrounds)\n * - ivory: Light filled button (for dark backgrounds)\n * - ivoryOutline: Light outlined button (for dark backgrounds)\n * - ivoryOutlineQuiet: Subtle light outlined button (for dark backgrounds)\n * - secondary: Gray filled button (for dark backgrounds)\n *\n * Sizes:\n * - lg: Large buttons (46px height)\n * - default: Medium buttons (38px height)\n * - sm: Small buttons (33px height)\n *\n * For icon-only buttons, use the IconButton component instead.\n */\nconst buttonVariants = cva(\n\t\"inline-flex items-center justify-center gap-spacing-6 whitespace-nowrap transition-colors duration-150 cursor-pointer focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\t// Charcoal (dark filled) - primary dark\n\t\t\t\tcharcoal:\n\t\t\t\t\t\"bg-gray-1200 text-gray-100 hover:bg-gray-1100 active:bg-gray-1000 focus-visible:ring-gray-1000\",\n\t\t\t\t// Charcoal Outline - outlined dark (for light backgrounds)\n\t\t\t\tcharcoalOutline:\n\t\t\t\t\t\"border border-alpha-black-30 text-gray-1000 hover:bg-alpha-black-5 active:bg-alpha-black-10 focus-visible:ring-gray-1000\",\n\t\t\t\t// Charcoal Outline Quiet - subtle outlined dark (for light backgrounds)\n\t\t\t\tcharcoalOutlineQuiet:\n\t\t\t\t\t\"border border-alpha-black-20 text-alpha-black-60 hover:border-alpha-black-30 hover:text-alpha-black-80 active:bg-alpha-black-5 focus-visible:ring-gray-1000\",\n\t\t\t\t// Ivory (light filled) - primary light (for dark backgrounds)\n\t\t\t\tivory:\n\t\t\t\t\t\"bg-gray-50 text-gray-1000 hover:bg-gray-100 active:bg-gray-200 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory Outline - outlined light (for dark backgrounds)\n\t\t\t\tivoryOutline:\n\t\t\t\t\t\"border border-gray-50 text-gray-50 hover:bg-alpha-white-10 active:bg-alpha-white-20 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory Outline Quiet - subtle light outline (for dark backgrounds)\n\t\t\t\tivoryOutlineQuiet:\n\t\t\t\t\t\"border border-alpha-white-20 text-alpha-white-60 hover:border-alpha-white-30 hover:text-alpha-white-80 active:bg-alpha-white-5 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Secondary - gray filled button (for dark backgrounds)\n\t\t\t\tgray:\n\t\t\t\t\t\"bg-gray-800 text-gray-100 hover:bg-gray-700 active:bg-gray-600 focus-visible:ring-gray-700 focus-visible:ring-offset-gray-1000\",\n\t\t\t},\n\t\t\tsize: {\n\t\t\t\t// Large - uses brand-large component tokens\n\t\t\t\tlg: \"px-spacing-brand-large-component-button-padding-x-large py-spacing-brand-large-component-button-padding-y-large rounded-[var(--spacing-brand-large-component-button-radius-large)] typography-brand-large-button-large h-spacing-brand-large-component-button-height-large\",\n\t\t\t\t// Medium (default) - uses brand-medium component tokens\n\t\t\t\tdefault:\n\t\t\t\t\t\"px-spacing-brand-medium-component-button-padding-x-medium py-spacing-brand-medium-component-button-padding-y-medium rounded-[var(--spacing-brand-medium-component-button-radius-medium)] typography-brand-medium-button-small h-spacing-brand-medium-component-button-height-medium\",\n\t\t\t\t// Small - uses brand-small component tokens\n\t\t\t\tsm: \"px-spacing-brand-small-component-button-padding-x-small py-spacing-brand-small-component-button-padding-y-small rounded-[var(--spacing-brand-small-component-button-radius-small)] typography-brand-small-button-small h-spacing-brand-small-component-button-height-small\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"charcoal\",\n\t\t\tsize: \"default\",\n\t\t},\n\t},\n);\n\nexport type HTMLButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement>;\nexport type ButtonProps = BaseButtonProps &\n\tVariantProps<typeof buttonVariants> &\n\tHTMLButtonProps;\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n\t({ className, variant, size, render, nativeButton, ...props }, ref) => {\n\t\t// When render prop is provided, default nativeButton to false to suppress warnings\n\t\tconst isNativeButton = nativeButton ?? render === undefined;\n\n\t\treturn (\n\t\t\t<BaseButton\n\t\t\t\tclassName={cn(buttonVariants({ variant, size, className }))}\n\t\t\t\tref={ref}\n\t\t\t\trender={render}\n\t\t\t\tnativeButton={isNativeButton}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n","// packages/react/compose-refs/src/compose-refs.tsx\nimport * as React from \"react\";\nfunction setRef(ref, value) {\n if (typeof ref === \"function\") {\n return ref(value);\n } else if (ref !== null && ref !== void 0) {\n ref.current = value;\n }\n}\nfunction composeRefs(...refs) {\n return (node) => {\n let hasCleanup = false;\n const cleanups = refs.map((ref) => {\n const cleanup = setRef(ref, node);\n if (!hasCleanup && typeof cleanup == \"function\") {\n hasCleanup = true;\n }\n return cleanup;\n });\n if (hasCleanup) {\n return () => {\n for (let i = 0; i < cleanups.length; i++) {\n const cleanup = cleanups[i];\n if (typeof cleanup == \"function\") {\n cleanup();\n } else {\n setRef(refs[i], null);\n }\n }\n };\n }\n };\n}\nfunction useComposedRefs(...refs) {\n return React.useCallback(composeRefs(...refs), refs);\n}\nexport {\n composeRefs,\n useComposedRefs\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\nvar REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nvar use = React[\" use \".trim().toString()];\nfunction isPromiseLike(value) {\n return typeof value === \"object\" && value !== null && \"then\" in value;\n}\nfunction isLazyComponent(element) {\n return element != null && typeof element === \"object\" && \"$$typeof\" in element && element.$$typeof === REACT_LAZY_TYPE && \"_payload\" in element && isPromiseLike(element._payload);\n}\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","import { Slot } from \"@radix-ui/react-slot\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * IconButton component based on Figma BaseKit / Interface / Icon Button\n *\n * **IMPORTANT: Accessibility Requirement**\n * Icon-only buttons MUST have an accessible label. Provide one of:\n * - `aria-label`: A text description of the button's action (recommended)\n * - `aria-labelledby`: Reference to an element containing the label\n * - `title`: Tooltip text (less preferred, but provides a label)\n *\n * @example\n * ```tsx\n * // Correct usage with aria-label\n * <IconButton aria-label=\"Close menu\">\n * <CloseIcon />\n * </IconButton>\n *\n * // Correct usage with aria-labelledby\n * <IconButton aria-labelledby=\"close-label\">\n * <CloseIcon />\n * </IconButton>\n * <span id=\"close-label\" className=\"sr-only\">Close menu</span>\n * ```\n *\n * Variants:\n * - charcoal: Dark filled button (for light backgrounds)\n * - charcoalOutline: Dark outlined button (for light backgrounds)\n * - charcoalOutlineQuiet: Subtle dark outlined button (for light backgrounds)\n * - ghost: No background/border, just icon (for light backgrounds)\n * - ghostDark: No background/border, just icon (for dark backgrounds)\n * - ivory: Light filled button (for dark backgrounds)\n * - ivoryOutline: Light outlined button (for dark backgrounds)\n * - ivoryOutlineQuiet: Subtle light outlined button (for dark backgrounds)\n *\n * Sizes:\n * - lg: Large (46x46)\n * - default: Medium (36x36)\n * - sm: Small (29x29)\n */\nconst iconButtonVariants = cva(\n\t\"inline-flex items-center justify-center whitespace-nowrap transition-colors duration-150 cursor-pointer focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\t// Charcoal (dark filled) - primary dark\n\t\t\t\tcharcoal:\n\t\t\t\t\t\"bg-gray-1200 text-gray-100 hover:bg-gray-1100 active:bg-gray-1000 focus-visible:ring-gray-1000\",\n\t\t\t\t// Charcoal Outline - outlined dark (for light backgrounds)\n\t\t\t\tcharcoalOutline:\n\t\t\t\t\t\"border border-alpha-black-30 text-gray-1000 hover:bg-alpha-black-5 active:bg-alpha-black-10 focus-visible:ring-gray-1000\",\n\t\t\t\t// Charcoal Outline Quiet - subtle outlined dark (for light backgrounds)\n\t\t\t\tcharcoalOutlineQuiet:\n\t\t\t\t\t\"border border-alpha-black-20 text-alpha-black-60 hover:border-alpha-black-30 hover:text-alpha-black-80 active:bg-alpha-black-5 focus-visible:ring-gray-1000\",\n\t\t\t\t// Ghost - no background/border (for light backgrounds)\n\t\t\t\tghost:\n\t\t\t\t\t\"text-gray-700 hover:text-gray-900 hover:bg-alpha-black-5 active:bg-alpha-black-10 focus-visible:ring-gray-1000\",\n\t\t\t\t// Ghost Dark - no background/border (for dark backgrounds)\n\t\t\t\tghostDark:\n\t\t\t\t\t\"text-gray-300 hover:text-gray-100 hover:bg-alpha-white-10 active:bg-alpha-white-20 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory (light filled) - primary light (for dark backgrounds)\n\t\t\t\tivory:\n\t\t\t\t\t\"bg-gray-50 text-gray-1000 hover:bg-gray-100 active:bg-gray-200 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory Outline - outlined light (for dark backgrounds)\n\t\t\t\tivoryOutline:\n\t\t\t\t\t\"border border-gray-50 text-gray-50 hover:bg-alpha-white-10 active:bg-alpha-white-20 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t\t// Ivory Outline Quiet - subtle light outline (for dark backgrounds)\n\t\t\t\tivoryOutlineQuiet:\n\t\t\t\t\t\"border border-alpha-white-20 text-alpha-white-60 hover:border-alpha-white-30 hover:text-alpha-white-80 active:bg-alpha-white-5 focus-visible:ring-gray-50 focus-visible:ring-offset-gray-1000\",\n\t\t\t},\n\t\t\tsize: {\n\t\t\t\t// Large (46x46)\n\t\t\t\tlg: \"rounded-[12px] size-[46px]\",\n\t\t\t\t// Medium (36x36) - default\n\t\t\t\tdefault: \"rounded-[12px] size-[36px]\",\n\t\t\t\t// Small (29x29)\n\t\t\t\tsm: \"rounded-[10px] size-[29px]\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"charcoal\",\n\t\t\tsize: \"default\",\n\t\t},\n\t},\n);\n\nexport interface IconButtonProps\n\textends React.ButtonHTMLAttributes<HTMLButtonElement>,\n\t\tVariantProps<typeof iconButtonVariants> {\n\tasChild?: boolean;\n}\n\nconst IconButton = React.forwardRef<HTMLButtonElement, IconButtonProps>(\n\t({ className, variant, size, asChild = false, ...props }, ref) => {\n\t\t// Development warning for missing accessible label\n\t\tReact.useEffect(() => {\n\t\t\tif (import.meta.env?.DEV) {\n\t\t\t\tconst hasAccessibleLabel =\n\t\t\t\t\tprops[\"aria-label\"] ||\n\t\t\t\t\tprops[\"aria-labelledby\"] ||\n\t\t\t\t\tprops.title;\n\t\t\t\tif (!hasAccessibleLabel) {\n\t\t\t\t\tconsole.warn(\n\t\t\t\t\t\t\"IconButton: Missing accessible label. Icon-only buttons must have an aria-label, aria-labelledby, or title attribute for screen reader users.\",\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t}, [props[\"aria-label\"], props[\"aria-labelledby\"], props.title]);\n\n\t\tconst Comp = asChild ? Slot : \"button\";\n\t\treturn (\n\t\t\t<Comp\n\t\t\t\tclassName={cn(iconButtonVariants({ variant, size, className }))}\n\t\t\t\tref={ref}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nIconButton.displayName = \"IconButton\";\n\nexport { IconButton, iconButtonVariants };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\nconst pagerControlVariants = cva(\"flex items-center\", {\n\tvariants: {\n\t\tsize: {\n\t\t\tsm: \"gap-[1px]\",\n\t\t\tdefault: \"gap-[2px]\",\n\t\t\tlg: \"gap-[3px]\",\n\t\t},\n\t},\n\tdefaultVariants: {\n\t\tsize: \"default\",\n\t},\n});\n\nconst dotBaseVariants = cva(\n\t\"cursor-pointer rounded-full transition-all duration-500 ease-[cubic-bezier(0.23,1,0.32,1)]\",\n\t{\n\t\tvariants: {\n\t\t\tsize: {\n\t\t\t\tsm: \"h-[6px]\",\n\t\t\t\tdefault: \"h-[10px]\",\n\t\t\t\tlg: \"h-[14px]\",\n\t\t\t},\n\t\t\tvariant: {\n\t\t\t\tcharcoal: \"\",\n\t\t\t\tivory: \"\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tsize: \"default\",\n\t\t\tvariant: \"charcoal\",\n\t\t},\n\t},\n);\n\nexport interface PagerControlProps\n\textends Omit<React.HTMLAttributes<HTMLDivElement>, \"onChange\">,\n\t\tVariantProps<typeof pagerControlVariants>,\n\t\tVariantProps<typeof dotBaseVariants> {\n\t/**\n\t * Total number of pages/items\n\t */\n\tcount: number;\n\t/**\n\t * Current active page index (0-based)\n\t */\n\tactiveIndex?: number;\n\t/**\n\t * Duration in milliseconds for each page before auto-advancing\n\t * Set to 0 to disable auto-advance\n\t * @default 5000\n\t */\n\tduration?: number;\n\t/**\n\t * Whether the pager should auto-advance\n\t * @default true\n\t */\n\tautoPlay?: boolean;\n\t/**\n\t * Callback when the active page changes\n\t */\n\tonChange?: (index: number) => void;\n\t/**\n\t * Whether to pause auto-advance on hover\n\t * @default true\n\t */\n\tpauseOnHover?: boolean;\n\t/**\n\t * Whether to loop back to the first page after the last\n\t * @default true\n\t */\n\tloop?: boolean;\n}\n\n/**\n * PagerControl component for indicating progress through a series of pages/slides.\n *\n * Features smooth width transitions when switching between dots and an animated\n * progress fill on the active dot that shows time remaining before auto-advancing\n * (similar to Apple's carousel indicators).\n *\n * Variants:\n * - charcoal: Dark dots (for light backgrounds)\n * - ivory: Light dots (for dark backgrounds)\n *\n * Sizes:\n * - sm: Small dots (6px height)\n * - default: Medium dots (10px height)\n * - lg: Large dots (14px height)\n */\nconst PagerControl = React.forwardRef<HTMLDivElement, PagerControlProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\tsize,\n\t\t\tvariant,\n\t\t\tcount,\n\t\t\tactiveIndex: controlledIndex,\n\t\t\tduration = 5000,\n\t\t\tautoPlay = true,\n\t\t\tonChange,\n\t\t\tpauseOnHover = true,\n\t\t\tloop = true,\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\tconst [internalIndex, setInternalIndex] = React.useState(0);\n\t\tconst [isPaused, setIsPaused] = React.useState(false);\n\t\tconst [progress, setProgress] = React.useState(0);\n\n\t\t// Use controlled index if provided, otherwise use internal state\n\t\tconst activeIndex =\n\t\t\tcontrolledIndex !== undefined ? controlledIndex : internalIndex;\n\t\tconst isControlled = controlledIndex !== undefined;\n\n\t\tconst animationFrameRef = React.useRef<number | null>(null);\n\t\tconst startTimeRef = React.useRef<number | null>(null);\n\t\tconst pausedProgressRef = React.useRef<number>(0);\n\n\t\tconst goToNext = React.useCallback(() => {\n\t\t\tconst nextIndex = activeIndex + 1;\n\t\t\tif (nextIndex >= count) {\n\t\t\t\tif (loop) {\n\t\t\t\t\tif (!isControlled) setInternalIndex(0);\n\t\t\t\t\tonChange?.(0);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (!isControlled) setInternalIndex(nextIndex);\n\t\t\t\tonChange?.(nextIndex);\n\t\t\t}\n\t\t}, [activeIndex, count, loop, isControlled, onChange]);\n\n\t\tconst goToIndex = React.useCallback(\n\t\t\t(index: number) => {\n\t\t\t\tif (!isControlled) setInternalIndex(index);\n\t\t\t\tonChange?.(index);\n\t\t\t\t// Reset progress when manually changing\n\t\t\t\tsetProgress(0);\n\t\t\t\tpausedProgressRef.current = 0;\n\t\t\t\tstartTimeRef.current = null;\n\t\t\t},\n\t\t\t[isControlled, onChange],\n\t\t);\n\n\t\t// Animation loop for smooth progress fill\n\t\tReact.useEffect(() => {\n\t\t\tif (!autoPlay || duration <= 0 || isPaused) {\n\t\t\t\tif (animationFrameRef.current) {\n\t\t\t\t\tcancelAnimationFrame(animationFrameRef.current);\n\t\t\t\t\tanimationFrameRef.current = null;\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst animate = (timestamp: number) => {\n\t\t\t\tif (startTimeRef.current === null) {\n\t\t\t\t\tstartTimeRef.current =\n\t\t\t\t\t\ttimestamp - (pausedProgressRef.current / 100) * duration;\n\t\t\t\t}\n\n\t\t\t\tconst elapsed = timestamp - startTimeRef.current;\n\t\t\t\tconst newProgress = Math.min((elapsed / duration) * 100, 100);\n\t\t\t\tsetProgress(newProgress);\n\n\t\t\t\tif (newProgress >= 100) {\n\t\t\t\t\tgoToNext();\n\t\t\t\t\t// Reset for next cycle\n\t\t\t\t\tsetProgress(0);\n\t\t\t\t\tpausedProgressRef.current = 0;\n\t\t\t\t\tstartTimeRef.current = null;\n\t\t\t\t} else {\n\t\t\t\t\tanimationFrameRef.current = requestAnimationFrame(animate);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tanimationFrameRef.current = requestAnimationFrame(animate);\n\n\t\t\treturn () => {\n\t\t\t\tif (animationFrameRef.current) {\n\t\t\t\t\tcancelAnimationFrame(animationFrameRef.current);\n\t\t\t\t}\n\t\t\t};\n\t\t}, [autoPlay, duration, isPaused, goToNext]);\n\n\t\t// Handle pause/resume\n\t\tconst handleMouseEnter = React.useCallback(() => {\n\t\t\tif (pauseOnHover) {\n\t\t\t\tpausedProgressRef.current = progress;\n\t\t\t\tstartTimeRef.current = null;\n\t\t\t\tsetIsPaused(true);\n\t\t\t}\n\t\t}, [pauseOnHover, progress]);\n\n\t\tconst handleMouseLeave = React.useCallback(() => {\n\t\t\tif (pauseOnHover) {\n\t\t\t\tsetIsPaused(false);\n\t\t\t}\n\t\t}, [pauseOnHover]);\n\n\t\t// Reset progress when activeIndex changes externally (controlled mode)\n\t\tReact.useEffect(() => {\n\t\t\tif (isControlled) {\n\t\t\t\tsetProgress(0);\n\t\t\t\tpausedProgressRef.current = 0;\n\t\t\t\tstartTimeRef.current = null;\n\t\t\t}\n\t\t}, [isControlled]);\n\n\t\t// Get dot dimensions based on size\n\t\tconst getDotWidth = (isActive: boolean) => {\n\t\t\tif (isActive) {\n\t\t\t\tswitch (size) {\n\t\t\t\t\tcase \"sm\":\n\t\t\t\t\t\treturn \"w-[16px]\";\n\t\t\t\t\tcase \"lg\":\n\t\t\t\t\t\treturn \"w-[36px]\";\n\t\t\t\t\tdefault:\n\t\t\t\t\t\treturn \"w-[26px]\";\n\t\t\t\t}\n\t\t\t}\n\t\t\tswitch (size) {\n\t\t\t\tcase \"sm\":\n\t\t\t\t\treturn \"w-[6px]\";\n\t\t\t\tcase \"lg\":\n\t\t\t\t\treturn \"w-[14px]\";\n\t\t\t\tdefault:\n\t\t\t\t\treturn \"w-[10px]\";\n\t\t\t}\n\t\t};\n\n\t\t// Get background classes for inactive dots\n\t\tconst getInactiveClasses = () => {\n\t\t\tif (variant === \"ivory\") {\n\t\t\t\treturn \"bg-alpha-white-30 hover:bg-alpha-white-60\";\n\t\t\t}\n\t\t\treturn \"bg-alpha-black-30 hover:bg-alpha-black-60\";\n\t\t};\n\n\t\t// Get background class for active dot (the track/background)\n\t\tconst getActiveTrackClass = () => {\n\t\t\tif (variant === \"ivory\") {\n\t\t\t\treturn \"bg-alpha-white-30\";\n\t\t\t}\n\t\t\treturn \"bg-alpha-black-30\";\n\t\t};\n\n\t\t// Get fill color for the progress indicator\n\t\tconst getProgressFillClass = () => {\n\t\t\tif (variant === \"ivory\") {\n\t\t\t\treturn \"bg-gray-50\";\n\t\t\t}\n\t\t\treturn \"bg-gray-1200\";\n\t\t};\n\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\trole=\"tablist\"\n\t\t\t\taria-label=\"Page indicators\"\n\t\t\t\tclassName={cn(pagerControlVariants({ size, className }))}\n\t\t\t\tonMouseEnter={handleMouseEnter}\n\t\t\t\tonMouseLeave={handleMouseLeave}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{Array.from({ length: count }, (_, index) => {\n\t\t\t\t\tconst isActive = index === activeIndex;\n\n\t\t\t\t\tif (isActive) {\n\t\t\t\t\t\t// Active dot with progress fill\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t<button\n\t\t\t\t\t\t\t\t// biome-ignore lint/suspicious/noArrayIndexKey: Pagination dots have fixed order based on count\n\t\t\t\t\t\t\t\tkey={index}\n\t\t\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t\t\trole=\"tab\"\n\t\t\t\t\t\t\t\taria-selected={true}\n\t\t\t\t\t\t\t\taria-label={`Page ${index + 1} of ${count}, current`}\n\t\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\t\"relative cursor-pointer overflow-hidden rounded-full transition-all duration-500 ease-[cubic-bezier(0.23,1,0.32,1)]\",\n\t\t\t\t\t\t\t\t\tdotBaseVariants({ size, variant }),\n\t\t\t\t\t\t\t\t\tgetDotWidth(true),\n\t\t\t\t\t\t\t\t\tgetActiveTrackClass(),\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\tonClick={() => goToIndex(index)}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{/* Progress fill */}\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\t\t\"absolute top-0 bottom-0 left-0 h-full rounded-full\",\n\t\t\t\t\t\t\t\t\t\tgetProgressFillClass(),\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\t\twidth: autoPlay && duration > 0 ? `${progress}%` : \"100%\",\n\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</button>\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Inactive dot\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<button\n\t\t\t\t\t\t\t// biome-ignore lint/suspicious/noArrayIndexKey: Pagination dots have fixed order based on count\n\t\t\t\t\t\t\tkey={index}\n\t\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t\trole=\"tab\"\n\t\t\t\t\t\t\taria-selected={false}\n\t\t\t\t\t\t\taria-label={`Go to page ${index + 1} of ${count}`}\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\tdotBaseVariants({ size, variant }),\n\t\t\t\t\t\t\t\tgetDotWidth(false),\n\t\t\t\t\t\t\t\tgetInactiveClasses(),\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\tonClick={() => goToIndex(index)}\n\t\t\t\t\t\t/>\n\t\t\t\t\t);\n\t\t\t\t})}\n\t\t\t</div>\n\t\t);\n\t},\n);\nPagerControl.displayName = \"PagerControl\";\n\nexport { PagerControl, pagerControlVariants };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\nconst cardVariants = cva(\"flex overflow-hidden rounded-[24px] bg-white\", {\n\tvariants: {\n\t\tlayout: {\n\t\t\tvertical: \"w-full flex-col\",\n\t\t\thorizontal: \"w-full flex-row\",\n\t\t},\n\t},\n\tdefaultVariants: {\n\t\tlayout: \"vertical\",\n\t},\n});\n\nexport interface CardProps\n\textends React.HTMLAttributes<HTMLDivElement>,\n\t\tVariantProps<typeof cardVariants> {}\n\n/**\n * Card component for displaying content in a contained, scannable format.\n *\n * Layouts:\n * - vertical: Image on top, content below (default)\n * - horizontal: Image on left, content on right\n *\n * Use with CardImage, CardContent, CardEyebrow, CardTitle, CardDescription, and CardActions.\n */\nconst Card = React.forwardRef<HTMLDivElement, CardProps>(\n\t({ className, layout, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(cardVariants({ layout, className }))}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCard.displayName = \"Card\";\n\nexport interface CardImageProps extends React.HTMLAttributes<HTMLDivElement> {\n\t/**\n\t * The image source URL\n\t */\n\tsrc?: string;\n\t/**\n\t * Alt text for the image\n\t */\n\talt?: string;\n}\n\n/**\n * Card image area. For vertical layout, displays with 16:9 aspect ratio.\n * For horizontal layout, takes up ~40% width and stretches to content height.\n */\nconst CardImage = React.forwardRef<HTMLDivElement, CardImageProps>(\n\t({ className, src, alt = \"\", ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"relative shrink-0 bg-gray-500\",\n\t\t\t\t\t// Vertical: full width with aspect ratio\n\t\t\t\t\t\"aspect-video w-full\",\n\t\t\t\t\t// When in horizontal card (parent has flex-row), override\n\t\t\t\t\t\"[.flex-row>&]:aspect-auto [.flex-row>&]:w-2/5 [.flex-row>&]:self-stretch\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{src && (\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\talt={alt}\n\t\t\t\t\t\tclassName=\"absolute inset-0 size-full object-cover\"\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t);\n\t},\n);\nCardImage.displayName = \"CardImage\";\n\nexport interface CardContentProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Card content container with proper padding and spacing.\n */\nconst CardContent = React.forwardRef<HTMLDivElement, CardContentProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex w-full flex-1 flex-col gap-spacing-24 p-spacing-24\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardContent.displayName = \"CardContent\";\n\nexport interface CardEyebrowProps\n\textends React.HTMLAttributes<HTMLParagraphElement> {}\n\n/**\n * Optional eyebrow text above the card title.\n */\nconst CardEyebrow = React.forwardRef<HTMLParagraphElement, CardEyebrowProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<p\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"typography-brand-large-caption-large text-gray-500\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardEyebrow.displayName = \"CardEyebrow\";\n\nexport interface CardTitleProps\n\textends React.HTMLAttributes<HTMLHeadingElement> {\n\t/**\n\t * The heading level to render (h1-h6). Defaults to h3.\n\t */\n\tas?: \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\";\n}\n\n/**\n * Card title/heading. Use the `as` prop to change the heading level.\n */\nconst CardTitle = React.forwardRef<HTMLHeadingElement, CardTitleProps>(\n\t({ className, as: Component = \"h3\", ...props }, ref) => {\n\t\treturn (\n\t\t\t<Component\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"typography-brand-large-subheading-small text-gray-1100\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardTitle.displayName = \"CardTitle\";\n\nexport interface CardDescriptionProps\n\textends React.HTMLAttributes<HTMLParagraphElement> {}\n\n/**\n * Card body/description text.\n */\nconst CardDescription = React.forwardRef<\n\tHTMLParagraphElement,\n\tCardDescriptionProps\n>(({ className, ...props }, ref) => {\n\treturn (\n\t\t<p\n\t\t\tref={ref}\n\t\t\tclassName={cn(\n\t\t\t\t\"typography-brand-large-body-small text-gray-800\",\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\t{...props}\n\t\t/>\n\t);\n});\nCardDescription.displayName = \"CardDescription\";\n\nexport interface CardBodyProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Container for card text content (eyebrow, title, description).\n */\nconst CardBody = React.forwardRef<HTMLDivElement, CardBodyProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"flex w-full flex-col gap-spacing-14\", className)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardBody.displayName = \"CardBody\";\n\nexport interface CardActionsProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Container for card action buttons.\n */\nconst CardActions = React.forwardRef<HTMLDivElement, CardActionsProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"flex gap-spacing-11\", className)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nCardActions.displayName = \"CardActions\";\n\nexport {\n\tCard,\n\tcardVariants,\n\tCardImage,\n\tCardContent,\n\tCardEyebrow,\n\tCardTitle,\n\tCardDescription,\n\tCardBody,\n\tCardActions,\n};\n","'use client';\n\nimport _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const DialogRootContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") DialogRootContext.displayName = \"DialogRootContext\";\nexport function useDialogRootContext(optional) {\n const dialogRootContext = React.useContext(DialogRootContext);\n if (optional === false && dialogRootContext === undefined) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: DialogRootContext is missing. Dialog parts must be placed within <Dialog.Root>.' : _formatErrorMessage(27));\n }\n return dialogRootContext;\n}","import { TransitionStatusDataAttributes } from \"./stateAttributesMapping.js\";\nexport let CommonPopupDataAttributes = function (CommonPopupDataAttributes) {\n /**\n * Present when the popup is open.\n */\n CommonPopupDataAttributes[\"open\"] = \"data-open\";\n /**\n * Present when the popup is closed.\n */\n CommonPopupDataAttributes[\"closed\"] = \"data-closed\";\n /**\n * Present when the popup is animating in.\n */\n CommonPopupDataAttributes[CommonPopupDataAttributes[\"startingStyle\"] = TransitionStatusDataAttributes.startingStyle] = \"startingStyle\";\n /**\n * Present when the popup is animating out.\n */\n CommonPopupDataAttributes[CommonPopupDataAttributes[\"endingStyle\"] = TransitionStatusDataAttributes.endingStyle] = \"endingStyle\";\n /**\n * Present when the anchor is hidden.\n */\n CommonPopupDataAttributes[\"anchorHidden\"] = \"data-anchor-hidden\";\n return CommonPopupDataAttributes;\n}({});\nexport let CommonTriggerDataAttributes = /*#__PURE__*/function (CommonTriggerDataAttributes) {\n /**\n * Present when the popup is open.\n */\n CommonTriggerDataAttributes[\"popupOpen\"] = \"data-popup-open\";\n /**\n * Present when a pressable trigger is pressed.\n */\n CommonTriggerDataAttributes[\"pressed\"] = \"data-pressed\";\n return CommonTriggerDataAttributes;\n}({});\nconst TRIGGER_HOOK = {\n [CommonTriggerDataAttributes.popupOpen]: ''\n};\nconst PRESSABLE_TRIGGER_HOOK = {\n [CommonTriggerDataAttributes.popupOpen]: '',\n [CommonTriggerDataAttributes.pressed]: ''\n};\nconst POPUP_OPEN_HOOK = {\n [CommonPopupDataAttributes.open]: ''\n};\nconst POPUP_CLOSED_HOOK = {\n [CommonPopupDataAttributes.closed]: ''\n};\nconst ANCHOR_HIDDEN_HOOK = {\n [CommonPopupDataAttributes.anchorHidden]: ''\n};\nexport const triggerOpenStateMapping = {\n open(value) {\n if (value) {\n return TRIGGER_HOOK;\n }\n return null;\n }\n};\nexport const pressableTriggerOpenStateMapping = {\n open(value) {\n if (value) {\n return PRESSABLE_TRIGGER_HOOK;\n }\n return null;\n }\n};\nexport const popupStateMapping = {\n open(value) {\n if (value) {\n return POPUP_OPEN_HOOK;\n }\n return POPUP_CLOSED_HOOK;\n },\n anchorHidden(value) {\n if (value) {\n return ANCHOR_HIDDEN_HOOK;\n }\n return null;\n }\n};","'use client';\n\nimport { useRefWithInit } from \"./useRefWithInit.js\";\nimport { useOnMount } from \"./useOnMount.js\";\nconst EMPTY = 0;\nexport class Timeout {\n static create() {\n return new Timeout();\n }\n currentId = EMPTY;\n\n /**\n * Executes `fn` after `delay`, clearing any previously scheduled call.\n */\n start(delay, fn) {\n this.clear();\n this.currentId = setTimeout(() => {\n this.currentId = EMPTY;\n fn();\n }, delay); /* Node.js types are enabled in development */\n }\n isStarted() {\n return this.currentId !== EMPTY;\n }\n clear = () => {\n if (this.currentId !== EMPTY) {\n clearTimeout(this.currentId);\n this.currentId = EMPTY;\n }\n };\n disposeEffect = () => {\n return this.clear;\n };\n}\n\n/**\n * A `setTimeout` with automatic cleanup and guard.\n */\nexport function useTimeout() {\n const timeout = useRefWithInit(Timeout.create).current;\n useOnMount(timeout.disposeEffect);\n return timeout;\n}","export function createEventEmitter() {\n const map = new Map();\n return {\n emit(event, data) {\n map.get(event)?.forEach(listener => listener(data));\n },\n on(event, listener) {\n if (!map.has(event)) {\n map.set(event, new Set());\n }\n map.get(event).add(listener);\n },\n off(event, listener) {\n map.get(event)?.delete(listener);\n }\n };\n}","'use client';\n\nimport * as React from 'react';\nimport { useId } from '@base-ui-components/utils/useId';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { useRefWithInit } from '@base-ui-components/utils/useRefWithInit';\nimport { FloatingTreeStore } from \"./FloatingTreeStore.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FloatingNodeContext = /*#__PURE__*/React.createContext(null);\nif (process.env.NODE_ENV !== \"production\") FloatingNodeContext.displayName = \"FloatingNodeContext\";\nconst FloatingTreeContext = /*#__PURE__*/React.createContext(null);\n\n/**\n * Returns the parent node id for nested floating elements, if available.\n * Returns `null` for top-level floating elements.\n */\nif (process.env.NODE_ENV !== \"production\") FloatingTreeContext.displayName = \"FloatingTreeContext\";\nexport const useFloatingParentNodeId = () => React.useContext(FloatingNodeContext)?.id || null;\n\n/**\n * Returns the nearest floating tree context, if available.\n */\nexport const useFloatingTree = externalTree => {\n const contextTree = React.useContext(FloatingTreeContext);\n return externalTree ?? contextTree;\n};\n\n/**\n * Registers a node into the `FloatingTree`, returning its id.\n * @see https://floating-ui.com/docs/FloatingTree\n */\nexport function useFloatingNodeId(externalTree) {\n const id = useId();\n const tree = useFloatingTree(externalTree);\n const parentId = useFloatingParentNodeId();\n useIsoLayoutEffect(() => {\n if (!id) {\n return undefined;\n }\n const node = {\n id,\n parentId\n };\n tree?.addNode(node);\n return () => {\n tree?.removeNode(node);\n };\n }, [tree, id, parentId]);\n return id;\n}\n/**\n * Provides parent node context for nested floating elements.\n * @see https://floating-ui.com/docs/FloatingTree\n * @internal\n */\nexport function FloatingNode(props) {\n const {\n children,\n id\n } = props;\n const parentId = useFloatingParentNodeId();\n return /*#__PURE__*/_jsx(FloatingNodeContext.Provider, {\n value: React.useMemo(() => ({\n id,\n parentId\n }), [id, parentId]),\n children: children\n });\n}\n/**\n * Provides context for nested floating elements when they are not children of\n * each other on the DOM.\n * This is not necessary in all cases, except when there must be explicit communication between parent and child floating elements. It is necessary for:\n * - The `bubbles` option in the `useDismiss()` Hook\n * - Nested virtual list navigation\n * - Nested floating elements that each open on hover\n * - Custom communication between parent and child floating elements\n * @see https://floating-ui.com/docs/FloatingTree\n * @internal\n */\nexport function FloatingTree(props) {\n const {\n children,\n externalTree\n } = props;\n const tree = useRefWithInit(() => externalTree ?? new FloatingTreeStore()).current;\n return /*#__PURE__*/_jsx(FloatingTreeContext.Provider, {\n value: tree,\n children: children\n });\n}","export function createAttribute(name) {\n return `data-base-ui-${name}`;\n}","export const visuallyHidden = {\n clip: 'rect(0 0 0 0)',\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n position: 'fixed',\n top: 0,\n left: 0,\n border: 0,\n padding: 0,\n width: 1,\n height: 1,\n margin: -1\n};","export { getWindow as ownerWindow } from '@floating-ui/utils/dom';\nexport function ownerDocument(node) {\n return node?.ownerDocument || document;\n}","'use client';\n\nimport * as React from 'react';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { isSafari } from '@base-ui-components/utils/detectBrowser';\nimport { visuallyHidden } from '@base-ui-components/utils/visuallyHidden';\n\n/**\n * @internal\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport const FocusGuard = /*#__PURE__*/React.forwardRef(function FocusGuard(props, ref) {\n const [role, setRole] = React.useState();\n useIsoLayoutEffect(() => {\n if (isSafari) {\n // Unlike other screen readers such as NVDA and JAWS, the virtual cursor\n // on VoiceOver does trigger the onFocus event, so we can use the focus\n // trap element. On Safari, only buttons trigger the onFocus event.\n setRole('button');\n }\n }, []);\n const restProps = {\n tabIndex: 0,\n // Role is only for VoiceOver\n role\n };\n return /*#__PURE__*/_jsx(\"span\", {\n ...props,\n ref: ref,\n style: visuallyHidden,\n \"aria-hidden\": role ? undefined : true,\n ...restProps,\n \"data-base-ui-focus-guard\": \"\"\n });\n});\nif (process.env.NODE_ENV !== \"production\") FocusGuard.displayName = \"FocusGuard\";","let rafId = 0;\nexport function enqueueFocus(el, options = {}) {\n const {\n preventScroll = false,\n cancelPrevious = true,\n sync = false\n } = options;\n if (cancelPrevious) {\n cancelAnimationFrame(rafId);\n }\n const exec = () => el?.focus({\n preventScroll\n });\n if (sync) {\n exec();\n } else {\n rafId = requestAnimationFrame(exec);\n }\n}","// Modified to add conditional `aria-hidden` support:\n// https://github.com/theKashey/aria-hidden/blob/9220c8f4a4fd35f63bee5510a9f41a37264382d4/src/index.ts\nimport { getNodeName } from '@floating-ui/utils/dom';\nimport { getDocument } from \"./element.js\";\nconst counters = {\n inert: new WeakMap(),\n 'aria-hidden': new WeakMap(),\n none: new WeakMap()\n};\nfunction getCounterMap(control) {\n if (control === 'inert') {\n return counters.inert;\n }\n if (control === 'aria-hidden') {\n return counters['aria-hidden'];\n }\n return counters.none;\n}\nlet uncontrolledElementsSet = new WeakSet();\nlet markerMap = {};\nlet lockCount = 0;\nexport const supportsInert = () => typeof HTMLElement !== 'undefined' && 'inert' in HTMLElement.prototype;\nconst unwrapHost = node => node && (node.host || unwrapHost(node.parentNode));\nconst correctElements = (parent, targets) => targets.map(target => {\n if (parent.contains(target)) {\n return target;\n }\n const correctedTarget = unwrapHost(target);\n if (parent.contains(correctedTarget)) {\n return correctedTarget;\n }\n return null;\n}).filter(x => x != null);\nfunction applyAttributeToOthers(uncorrectedAvoidElements, body, ariaHidden, inert) {\n const markerName = 'data-base-ui-inert';\n // eslint-disable-next-line no-nested-ternary\n const controlAttribute = inert ? 'inert' : ariaHidden ? 'aria-hidden' : null;\n const avoidElements = correctElements(body, uncorrectedAvoidElements);\n const elementsToKeep = new Set();\n const elementsToStop = new Set(avoidElements);\n const hiddenElements = [];\n if (!markerMap[markerName]) {\n markerMap[markerName] = new WeakMap();\n }\n const markerCounter = markerMap[markerName];\n avoidElements.forEach(keep);\n deep(body);\n elementsToKeep.clear();\n function keep(el) {\n if (!el || elementsToKeep.has(el)) {\n return;\n }\n elementsToKeep.add(el);\n if (el.parentNode) {\n keep(el.parentNode);\n }\n }\n function deep(parent) {\n if (!parent || elementsToStop.has(parent)) {\n return;\n }\n [].forEach.call(parent.children, node => {\n if (getNodeName(node) === 'script') {\n return;\n }\n if (elementsToKeep.has(node)) {\n deep(node);\n } else {\n const attr = controlAttribute ? node.getAttribute(controlAttribute) : null;\n const alreadyHidden = attr !== null && attr !== 'false';\n const counterMap = getCounterMap(controlAttribute);\n const counterValue = (counterMap.get(node) || 0) + 1;\n const markerValue = (markerCounter.get(node) || 0) + 1;\n counterMap.set(node, counterValue);\n markerCounter.set(node, markerValue);\n hiddenElements.push(node);\n if (counterValue === 1 && alreadyHidden) {\n uncontrolledElementsSet.add(node);\n }\n if (markerValue === 1) {\n node.setAttribute(markerName, '');\n }\n if (!alreadyHidden && controlAttribute) {\n node.setAttribute(controlAttribute, controlAttribute === 'inert' ? '' : 'true');\n }\n }\n });\n }\n lockCount += 1;\n return () => {\n hiddenElements.forEach(element => {\n const counterMap = getCounterMap(controlAttribute);\n const currentCounterValue = counterMap.get(element) || 0;\n const counterValue = currentCounterValue - 1;\n const markerValue = (markerCounter.get(element) || 0) - 1;\n counterMap.set(element, counterValue);\n markerCounter.set(element, markerValue);\n if (!counterValue) {\n if (!uncontrolledElementsSet.has(element) && controlAttribute) {\n element.removeAttribute(controlAttribute);\n }\n uncontrolledElementsSet.delete(element);\n }\n if (!markerValue) {\n element.removeAttribute(markerName);\n }\n });\n lockCount -= 1;\n if (!lockCount) {\n counters.inert = new WeakMap();\n counters['aria-hidden'] = new WeakMap();\n counters.none = new WeakMap();\n uncontrolledElementsSet = new WeakSet();\n markerMap = {};\n }\n };\n}\nexport function markOthers(avoidElements, ariaHidden = false, inert = false) {\n const body = getDocument(avoidElements[0]).body;\n return applyAttributeToOthers(avoidElements.concat(Array.from(body.querySelectorAll('[aria-live]'))), body, ariaHidden, inert);\n}","'use client';\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport { isNode } from '@floating-ui/utils/dom';\nimport { useId } from '@base-ui-components/utils/useId';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { FocusGuard } from \"../../utils/FocusGuard.js\";\nimport { enableFocusInside, disableFocusInside, getPreviousTabbable, getNextTabbable, isOutsideEvent } from \"../utils.js\";\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { createAttribute } from \"../utils/createAttribute.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nimport { EMPTY_OBJECT, ownerVisuallyHidden } from \"../../utils/constants.js\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nconst PortalContext = /*#__PURE__*/React.createContext(null);\nif (process.env.NODE_ENV !== \"production\") PortalContext.displayName = \"PortalContext\";\nexport const usePortalContext = () => React.useContext(PortalContext);\nconst attr = createAttribute('portal');\nexport function useFloatingPortalNode(props = {}) {\n const {\n ref,\n container: containerProp,\n componentProps = EMPTY_OBJECT,\n elementProps,\n elementState\n } = props;\n const uniqueId = useId();\n const portalContext = usePortalContext();\n const parentPortalNode = portalContext?.portalNode;\n const [containerElement, setContainerElement] = React.useState(null);\n const [portalNode, setPortalNode] = React.useState(null);\n const containerRef = React.useRef(null);\n useIsoLayoutEffect(() => {\n // Wait for the container to be resolved if explicitly `null`.\n if (containerProp === null) {\n if (containerRef.current) {\n containerRef.current = null;\n setPortalNode(null);\n setContainerElement(null);\n }\n return;\n }\n\n // React 17 does not use React.useId().\n if (uniqueId == null) {\n return;\n }\n const resolvedContainer = (containerProp && (isNode(containerProp) ? containerProp : containerProp.current)) ?? parentPortalNode ?? document.body;\n if (resolvedContainer == null) {\n if (containerRef.current) {\n containerRef.current = null;\n setPortalNode(null);\n setContainerElement(null);\n }\n return;\n }\n if (containerRef.current !== resolvedContainer) {\n containerRef.current = resolvedContainer;\n setPortalNode(null);\n setContainerElement(resolvedContainer);\n }\n }, [containerProp, parentPortalNode, uniqueId]);\n const portalElement = useRenderElement('div', componentProps, {\n ref: [ref, setPortalNode],\n state: elementState,\n props: [{\n id: uniqueId,\n [attr]: ''\n }, elementProps]\n });\n\n // This `createPortal` call injects `portalElement` into the `container`.\n // Another call inside `FloatingPortal`/`FloatingPortalLite` then injects the children into `portalElement`.\n const portalSubtree = containerElement && portalElement ? /*#__PURE__*/ReactDOM.createPortal(portalElement, containerElement) : null;\n return {\n portalNode,\n portalSubtree\n };\n}\n\n/**\n * Portals the floating element into a given container element — by default,\n * outside of the app root and into the body.\n * This is necessary to ensure the floating element can appear outside any\n * potential parent containers that cause clipping (such as `overflow: hidden`),\n * while retaining its location in the React tree.\n * @see https://floating-ui.com/docs/FloatingPortal\n * @internal\n */\nexport const FloatingPortal = /*#__PURE__*/React.forwardRef(function FloatingPortal(componentProps, forwardedRef) {\n const {\n children,\n container,\n className,\n render,\n renderGuards,\n ...elementProps\n } = componentProps;\n const {\n portalNode,\n portalSubtree\n } = useFloatingPortalNode({\n container,\n ref: forwardedRef,\n componentProps,\n elementProps\n });\n const beforeOutsideRef = React.useRef(null);\n const afterOutsideRef = React.useRef(null);\n const beforeInsideRef = React.useRef(null);\n const afterInsideRef = React.useRef(null);\n const [focusManagerState, setFocusManagerState] = React.useState(null);\n const modal = focusManagerState?.modal;\n const open = focusManagerState?.open;\n const shouldRenderGuards = typeof renderGuards === 'boolean' ? renderGuards : !!focusManagerState && !focusManagerState.modal && focusManagerState.open && !!portalNode;\n\n // https://codesandbox.io/s/tabbable-portal-f4tng?file=/src/TabbablePortal.tsx\n React.useEffect(() => {\n if (!portalNode || modal) {\n return undefined;\n }\n\n // Make sure elements inside the portal element are tabbable only when the\n // portal has already been focused, either by tabbing into a focus trap\n // element outside or using the mouse.\n function onFocus(event) {\n if (portalNode && isOutsideEvent(event)) {\n const focusing = event.type === 'focusin';\n const manageFocus = focusing ? enableFocusInside : disableFocusInside;\n manageFocus(portalNode);\n }\n }\n\n // Listen to the event on the capture phase so they run before the focus\n // trap elements onFocus prop is called.\n portalNode.addEventListener('focusin', onFocus, true);\n portalNode.addEventListener('focusout', onFocus, true);\n return () => {\n portalNode.removeEventListener('focusin', onFocus, true);\n portalNode.removeEventListener('focusout', onFocus, true);\n };\n }, [portalNode, modal]);\n React.useEffect(() => {\n if (!portalNode || open) {\n return;\n }\n enableFocusInside(portalNode);\n }, [open, portalNode]);\n const portalContextValue = React.useMemo(() => ({\n beforeOutsideRef,\n afterOutsideRef,\n beforeInsideRef,\n afterInsideRef,\n portalNode,\n setFocusManagerState\n }), [portalNode]);\n return /*#__PURE__*/_jsxs(React.Fragment, {\n children: [portalSubtree, /*#__PURE__*/_jsxs(PortalContext.Provider, {\n value: portalContextValue,\n children: [shouldRenderGuards && portalNode && /*#__PURE__*/_jsx(FocusGuard, {\n \"data-type\": \"outside\",\n ref: beforeOutsideRef,\n onFocus: event => {\n if (isOutsideEvent(event, portalNode)) {\n beforeInsideRef.current?.focus();\n } else {\n const domReference = focusManagerState ? focusManagerState.domReference : null;\n const prevTabbable = getPreviousTabbable(domReference);\n prevTabbable?.focus();\n }\n }\n }), shouldRenderGuards && portalNode && /*#__PURE__*/_jsx(\"span\", {\n \"aria-owns\": portalNode.id,\n style: ownerVisuallyHidden\n }), portalNode && /*#__PURE__*/ReactDOM.createPortal(children, portalNode), shouldRenderGuards && portalNode && /*#__PURE__*/_jsx(FocusGuard, {\n \"data-type\": \"outside\",\n ref: afterOutsideRef,\n onFocus: event => {\n if (isOutsideEvent(event, portalNode)) {\n afterInsideRef.current?.focus();\n } else {\n const domReference = focusManagerState ? focusManagerState.domReference : null;\n const nextTabbable = getNextTabbable(domReference);\n nextTabbable?.focus();\n if (focusManagerState?.closeOnFocusOut) {\n focusManagerState?.onOpenChange(false, createChangeEventDetails(REASONS.focusOut, event.nativeEvent));\n }\n }\n }\n })]\n })]\n });\n});\nif (process.env.NODE_ENV !== \"production\") FloatingPortal.displayName = \"FloatingPortal\";","'use client';\n\nimport * as React from 'react';\nimport { tabbable, isTabbable, focusable } from 'tabbable';\nimport { getComputedStyle, getNodeName, isHTMLElement } from '@floating-ui/utils/dom';\nimport { useMergedRefs } from '@base-ui-components/utils/useMergedRefs';\nimport { useValueAsRef } from '@base-ui-components/utils/useValueAsRef';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { visuallyHidden } from '@base-ui-components/utils/visuallyHidden';\nimport { useTimeout } from '@base-ui-components/utils/useTimeout';\nimport { useAnimationFrame } from '@base-ui-components/utils/useAnimationFrame';\nimport { ownerWindow } from '@base-ui-components/utils/owner';\nimport { FocusGuard } from \"../../utils/FocusGuard.js\";\nimport { activeElement, contains, getDocument, getTarget, isTypeableCombobox, isVirtualClick, isVirtualPointerEvent, stopEvent, getNodeAncestors, getNodeChildren, getFloatingFocusElement, getTabbableOptions, isOutsideEvent, getNextTabbable, getPreviousTabbable } from \"../utils.js\";\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { createAttribute } from \"../utils/createAttribute.js\";\nimport { enqueueFocus } from \"../utils/enqueueFocus.js\";\nimport { markOthers } from \"../utils/markOthers.js\";\nimport { usePortalContext } from \"./FloatingPortal.js\";\nimport { useFloatingTree } from \"./FloatingTree.js\";\nimport { CLICK_TRIGGER_IDENTIFIER } from \"../../utils/constants.js\";\nimport { resolveRef } from \"../../utils/resolveRef.js\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction getEventType(event, lastInteractionType) {\n const win = ownerWindow(event.target);\n if (event instanceof win.KeyboardEvent) {\n return 'keyboard';\n }\n if (event instanceof win.FocusEvent) {\n // Focus events can be caused by a preceding pointer interaction (e.g., focusout on outside press).\n // Prefer the last known pointer type if provided, else treat as keyboard.\n return lastInteractionType || 'keyboard';\n }\n if ('pointerType' in event) {\n return event.pointerType || 'keyboard';\n }\n if ('touches' in event) {\n return 'touch';\n }\n if (event instanceof win.MouseEvent) {\n // onClick events may not contain pointer events, and will fall through to here\n return lastInteractionType || (event.detail === 0 ? 'keyboard' : 'mouse');\n }\n return '';\n}\nconst LIST_LIMIT = 20;\nlet previouslyFocusedElements = [];\nfunction clearDisconnectedPreviouslyFocusedElements() {\n previouslyFocusedElements = previouslyFocusedElements.filter(el => el.isConnected);\n}\nfunction addPreviouslyFocusedElement(element) {\n clearDisconnectedPreviouslyFocusedElements();\n if (element && getNodeName(element) !== 'body') {\n previouslyFocusedElements.push(element);\n if (previouslyFocusedElements.length > LIST_LIMIT) {\n previouslyFocusedElements = previouslyFocusedElements.slice(-LIST_LIMIT);\n }\n }\n}\nfunction getPreviouslyFocusedElement() {\n clearDisconnectedPreviouslyFocusedElements();\n return previouslyFocusedElements[previouslyFocusedElements.length - 1];\n}\nfunction getFirstTabbableElement(container) {\n if (!container) {\n return null;\n }\n const tabbableOptions = getTabbableOptions();\n if (isTabbable(container, tabbableOptions)) {\n return container;\n }\n return tabbable(container, tabbableOptions)[0] || container;\n}\nfunction isFocusable(element) {\n if (!element || !element.isConnected) {\n return false;\n }\n if (typeof element.checkVisibility === 'function') {\n return element.checkVisibility();\n }\n return getComputedStyle(element).display !== 'none';\n}\nfunction handleTabIndex(floatingFocusElement, orderRef) {\n if (!orderRef.current.includes('floating') && !floatingFocusElement.getAttribute('role')?.includes('dialog')) {\n return;\n }\n const options = getTabbableOptions();\n const focusableElements = focusable(floatingFocusElement, options);\n const tabbableContent = focusableElements.filter(element => {\n const dataTabIndex = element.getAttribute('data-tabindex') || '';\n return isTabbable(element, options) || element.hasAttribute('data-tabindex') && !dataTabIndex.startsWith('-');\n });\n const tabIndex = floatingFocusElement.getAttribute('tabindex');\n if (orderRef.current.includes('floating') || tabbableContent.length === 0) {\n if (tabIndex !== '0') {\n floatingFocusElement.setAttribute('tabindex', '0');\n }\n } else if (tabIndex !== '-1' || floatingFocusElement.hasAttribute('data-tabindex') && floatingFocusElement.getAttribute('data-tabindex') !== '-1') {\n floatingFocusElement.setAttribute('tabindex', '-1');\n floatingFocusElement.setAttribute('data-tabindex', '-1');\n }\n}\n/**\n * Provides focus management for the floating element.\n * @see https://floating-ui.com/docs/FloatingFocusManager\n * @internal\n */\nexport function FloatingFocusManager(props) {\n const {\n context,\n children,\n disabled = false,\n order = ['content'],\n initialFocus = true,\n returnFocus = true,\n restoreFocus = false,\n modal = true,\n closeOnFocusOut = true,\n openInteractionType = '',\n getInsideElements: getInsideElementsProp = () => [],\n nextFocusableElement,\n previousFocusableElement,\n beforeContentFocusGuardRef,\n externalTree\n } = props;\n const store = 'rootStore' in context ? context.rootStore : context;\n const open = store.useState('open');\n const domReference = store.useState('domReferenceElement');\n const floating = store.useState('floatingElement');\n const {\n events,\n dataRef\n } = store.context;\n const getNodeId = useStableCallback(() => dataRef.current.floatingContext?.nodeId);\n const getInsideElements = useStableCallback(getInsideElementsProp);\n const ignoreInitialFocus = initialFocus === false;\n // If the reference is a combobox and is typeable (e.g. input/textarea),\n // there are different focus semantics. The guards should not be rendered, but\n // aria-hidden should be applied to all nodes still. Further, the visually\n // hidden dismiss button should only appear at the end of the list, not the\n // start.\n const isUntrappedTypeableCombobox = isTypeableCombobox(domReference) && ignoreInitialFocus;\n const orderRef = useValueAsRef(order);\n const initialFocusRef = useValueAsRef(initialFocus);\n const returnFocusRef = useValueAsRef(returnFocus);\n const openInteractionTypeRef = useValueAsRef(openInteractionType);\n const tree = useFloatingTree(externalTree);\n const portalContext = usePortalContext();\n const startDismissButtonRef = React.useRef(null);\n const endDismissButtonRef = React.useRef(null);\n const preventReturnFocusRef = React.useRef(false);\n const isPointerDownRef = React.useRef(false);\n const pointerDownOutsideRef = React.useRef(false);\n const tabbableIndexRef = React.useRef(-1);\n const closeTypeRef = React.useRef('');\n const lastInteractionTypeRef = React.useRef('');\n const blurTimeout = useTimeout();\n const pointerDownTimeout = useTimeout();\n const restoreFocusFrame = useAnimationFrame();\n const isInsidePortal = portalContext != null;\n const floatingFocusElement = getFloatingFocusElement(floating);\n const getTabbableContent = useStableCallback((container = floatingFocusElement) => {\n return container ? tabbable(container, getTabbableOptions()) : [];\n });\n const getTabbableElements = useStableCallback(container => {\n const content = getTabbableContent(container);\n return orderRef.current.map(() => content).filter(Boolean).flat();\n });\n React.useEffect(() => {\n if (disabled) {\n return undefined;\n }\n if (!modal) {\n return undefined;\n }\n function onKeyDown(event) {\n if (event.key === 'Tab') {\n // The focus guards have nothing to focus, so we need to stop the event.\n if (contains(floatingFocusElement, activeElement(getDocument(floatingFocusElement))) && getTabbableContent().length === 0 && !isUntrappedTypeableCombobox) {\n stopEvent(event);\n }\n }\n }\n const doc = getDocument(floatingFocusElement);\n doc.addEventListener('keydown', onKeyDown);\n return () => {\n doc.removeEventListener('keydown', onKeyDown);\n };\n }, [disabled, domReference, floatingFocusElement, modal, orderRef, isUntrappedTypeableCombobox, getTabbableContent, getTabbableElements]);\n React.useEffect(() => {\n if (disabled) {\n return undefined;\n }\n if (!floating) {\n return undefined;\n }\n function handleFocusIn(event) {\n const target = getTarget(event);\n const tabbableContent = getTabbableContent();\n const tabbableIndex = tabbableContent.indexOf(target);\n if (tabbableIndex !== -1) {\n tabbableIndexRef.current = tabbableIndex;\n }\n }\n floating.addEventListener('focusin', handleFocusIn);\n return () => {\n floating.removeEventListener('focusin', handleFocusIn);\n };\n }, [disabled, floating, getTabbableContent]);\n\n // Track the last interaction type at the document level to disambiguate focus events\n React.useEffect(() => {\n if (disabled || !open) {\n return undefined;\n }\n const doc = getDocument(floatingFocusElement);\n function clearPointerDownOutside() {\n pointerDownOutsideRef.current = false;\n }\n function onPointerDown(event) {\n const target = getTarget(event);\n const pointerTargetInside = contains(floating, target) || contains(domReference, target) || contains(portalContext?.portalNode, target);\n pointerDownOutsideRef.current = !pointerTargetInside;\n lastInteractionTypeRef.current = event.pointerType || 'keyboard';\n }\n function onKeyDown() {\n lastInteractionTypeRef.current = 'keyboard';\n }\n doc.addEventListener('pointerdown', onPointerDown, true);\n doc.addEventListener('pointerup', clearPointerDownOutside, true);\n doc.addEventListener('pointercancel', clearPointerDownOutside, true);\n doc.addEventListener('keydown', onKeyDown, true);\n return () => {\n doc.removeEventListener('pointerdown', onPointerDown, true);\n doc.removeEventListener('pointerup', clearPointerDownOutside, true);\n doc.removeEventListener('pointercancel', clearPointerDownOutside, true);\n doc.removeEventListener('keydown', onKeyDown, true);\n };\n }, [disabled, floating, domReference, floatingFocusElement, open, portalContext]);\n React.useEffect(() => {\n if (disabled) {\n return undefined;\n }\n if (!closeOnFocusOut) {\n return undefined;\n }\n\n // In Safari, buttons lose focus when pressing them.\n function handlePointerDown() {\n isPointerDownRef.current = true;\n pointerDownTimeout.start(0, () => {\n isPointerDownRef.current = false;\n });\n }\n function handleFocusOutside(event) {\n const relatedTarget = event.relatedTarget;\n const currentTarget = event.currentTarget;\n const target = getTarget(event);\n queueMicrotask(() => {\n const nodeId = getNodeId();\n const triggers = store.context.triggerElements;\n const movedToUnrelatedNode = !(contains(domReference, relatedTarget) || contains(floating, relatedTarget) || contains(relatedTarget, floating) || contains(portalContext?.portalNode, relatedTarget) || relatedTarget != null && triggers.hasElement(relatedTarget) || triggers.hasMatchingElement(trigger => contains(trigger, relatedTarget)) || relatedTarget?.hasAttribute(createAttribute('focus-guard')) || tree && (getNodeChildren(tree.nodesRef.current, nodeId).find(node => contains(node.context?.elements.floating, relatedTarget) || contains(node.context?.elements.domReference, relatedTarget)) || getNodeAncestors(tree.nodesRef.current, nodeId).find(node => [node.context?.elements.floating, getFloatingFocusElement(node.context?.elements.floating)].includes(relatedTarget) || node.context?.elements.domReference === relatedTarget)));\n if (currentTarget === domReference && floatingFocusElement) {\n handleTabIndex(floatingFocusElement, orderRef);\n }\n\n // Restore focus to the previous tabbable element index to prevent\n // focus from being lost outside the floating tree.\n if (restoreFocus && currentTarget !== domReference && !isFocusable(target) && activeElement(getDocument(floatingFocusElement)) === getDocument(floatingFocusElement).body) {\n // Let `FloatingPortal` effect knows that focus is still inside the\n // floating tree.\n if (isHTMLElement(floatingFocusElement)) {\n floatingFocusElement.focus();\n // If explicitly requested to restore focus to the popup container, do not search\n // for the next/previous tabbable element.\n if (restoreFocus === 'popup') {\n // If the element is removed on pointerdown, focus tries to move it,\n // but since it's removed at the same time, focus gets lost as it\n // happens after the .focus() call above.\n // In this case, focus needs to be moved asynchronously.\n restoreFocusFrame.request(() => {\n floatingFocusElement.focus();\n });\n return;\n }\n }\n const prevTabbableIndex = tabbableIndexRef.current;\n const tabbableContent = getTabbableContent();\n const nodeToFocus = tabbableContent[prevTabbableIndex] || tabbableContent[tabbableContent.length - 1] || floatingFocusElement;\n if (isHTMLElement(nodeToFocus)) {\n nodeToFocus.focus();\n }\n }\n\n // https://github.com/floating-ui/floating-ui/issues/3060\n if (dataRef.current.insideReactTree) {\n dataRef.current.insideReactTree = false;\n return;\n }\n\n // Focus did not move inside the floating tree, and there are no tabbable\n // portal guards to handle closing.\n if ((isUntrappedTypeableCombobox ? true : !modal) && relatedTarget && movedToUnrelatedNode && !isPointerDownRef.current && (\n // Fix React 18 Strict Mode returnFocus due to double rendering.\n // For an \"untrapped\" typeable combobox (input role=combobox with\n // initialFocus=false), re-opening the popup and tabbing out should still close it even\n // when the previously focused element (e.g. the next tabbable outside the popup) is\n // focused again. Otherwise, the popup remains open on the second Tab sequence:\n // click input -> Tab (closes) -> click input -> Tab.\n // Allow closing when `isUntrappedTypeableCombobox` regardless of the previously focused element.\n isUntrappedTypeableCombobox || relatedTarget !== getPreviouslyFocusedElement())) {\n preventReturnFocusRef.current = true;\n store.setOpen(false, createChangeEventDetails(REASONS.focusOut, event));\n }\n });\n }\n function markInsideReactTree() {\n if (pointerDownOutsideRef.current) {\n return;\n }\n dataRef.current.insideReactTree = true;\n blurTimeout.start(0, () => {\n dataRef.current.insideReactTree = false;\n });\n }\n const domReferenceElement = isHTMLElement(domReference) ? domReference : null;\n const cleanups = [];\n if (!floating && !domReferenceElement) {\n return undefined;\n }\n if (domReferenceElement) {\n domReferenceElement.addEventListener('focusout', handleFocusOutside);\n domReferenceElement.addEventListener('pointerdown', handlePointerDown);\n cleanups.push(() => {\n domReferenceElement.removeEventListener('focusout', handleFocusOutside);\n domReferenceElement.removeEventListener('pointerdown', handlePointerDown);\n });\n }\n if (floating) {\n floating.addEventListener('focusout', handleFocusOutside);\n if (portalContext) {\n floating.addEventListener('focusout', markInsideReactTree, true);\n cleanups.push(() => {\n floating.removeEventListener('focusout', markInsideReactTree, true);\n });\n }\n cleanups.push(() => {\n floating.removeEventListener('focusout', handleFocusOutside);\n });\n }\n return () => {\n cleanups.forEach(cleanup => {\n cleanup();\n });\n };\n }, [disabled, domReference, floating, floatingFocusElement, modal, tree, portalContext, store, closeOnFocusOut, restoreFocus, getTabbableContent, isUntrappedTypeableCombobox, getNodeId, orderRef, dataRef, blurTimeout, pointerDownTimeout, restoreFocusFrame]);\n const beforeGuardRef = React.useRef(null);\n const afterGuardRef = React.useRef(null);\n const mergedBeforeGuardRef = useMergedRefs(beforeGuardRef, beforeContentFocusGuardRef, portalContext?.beforeInsideRef);\n const mergedAfterGuardRef = useMergedRefs(afterGuardRef, portalContext?.afterInsideRef);\n React.useEffect(() => {\n if (disabled || !floating || !open) {\n return undefined;\n }\n\n // Don't hide portals nested within the parent portal.\n const portalNodes = Array.from(portalContext?.portalNode?.querySelectorAll(`[${createAttribute('portal')}]`) || []);\n const ancestors = tree ? getNodeAncestors(tree.nodesRef.current, getNodeId()) : [];\n const rootAncestorComboboxDomReference = ancestors.find(node => isTypeableCombobox(node.context?.elements.domReference || null))?.context?.elements.domReference;\n const insideElements = [floating, rootAncestorComboboxDomReference, ...portalNodes, ...getInsideElements(), startDismissButtonRef.current, endDismissButtonRef.current, beforeGuardRef.current, afterGuardRef.current, portalContext?.beforeOutsideRef.current, portalContext?.afterOutsideRef.current, resolveRef(previousFocusableElement), resolveRef(nextFocusableElement), isUntrappedTypeableCombobox ? domReference : null].filter(x => x != null);\n const cleanup = markOthers(insideElements, modal || isUntrappedTypeableCombobox);\n return () => {\n cleanup();\n };\n }, [open, disabled, domReference, floating, modal, orderRef, portalContext, isUntrappedTypeableCombobox, tree, getNodeId, getInsideElements, nextFocusableElement, previousFocusableElement]);\n useIsoLayoutEffect(() => {\n if (!open || disabled || !isHTMLElement(floatingFocusElement)) {\n return;\n }\n const doc = getDocument(floatingFocusElement);\n const previouslyFocusedElement = activeElement(doc);\n\n // Wait for any layout effect state setters to execute to set `tabIndex`.\n queueMicrotask(() => {\n const focusableElements = getTabbableElements(floatingFocusElement);\n const initialFocusValueOrFn = initialFocusRef.current;\n const resolvedInitialFocus = typeof initialFocusValueOrFn === 'function' ? initialFocusValueOrFn(openInteractionTypeRef.current || '') : initialFocusValueOrFn;\n\n // `null` should fallback to default behavior in case of an empty ref.\n if (resolvedInitialFocus === undefined || resolvedInitialFocus === false) {\n return;\n }\n let elToFocus;\n if (resolvedInitialFocus === true || resolvedInitialFocus === null) {\n elToFocus = focusableElements[0] || floatingFocusElement;\n } else {\n elToFocus = resolveRef(resolvedInitialFocus);\n }\n elToFocus = elToFocus || focusableElements[0] || floatingFocusElement;\n const focusAlreadyInsideFloatingEl = contains(floatingFocusElement, previouslyFocusedElement);\n if (focusAlreadyInsideFloatingEl) {\n return;\n }\n enqueueFocus(elToFocus, {\n preventScroll: elToFocus === floatingFocusElement\n });\n });\n }, [disabled, open, floatingFocusElement, ignoreInitialFocus, getTabbableElements, initialFocusRef, openInteractionTypeRef]);\n useIsoLayoutEffect(() => {\n if (disabled || !floatingFocusElement) {\n return undefined;\n }\n const doc = getDocument(floatingFocusElement);\n const previouslyFocusedElement = activeElement(doc);\n addPreviouslyFocusedElement(previouslyFocusedElement);\n\n // Dismissing via outside press should always ignore `returnFocus` to\n // prevent unwanted scrolling.\n function onOpenChangeLocal(details) {\n if (!details.open) {\n closeTypeRef.current = getEventType(details.nativeEvent, lastInteractionTypeRef.current);\n }\n if (details.reason === REASONS.triggerHover && details.nativeEvent.type === 'mouseleave') {\n preventReturnFocusRef.current = true;\n }\n if (details.reason !== REASONS.outsidePress) {\n return;\n }\n if (details.nested) {\n preventReturnFocusRef.current = false;\n } else if (isVirtualClick(details.nativeEvent) || isVirtualPointerEvent(details.nativeEvent)) {\n preventReturnFocusRef.current = false;\n } else {\n let isPreventScrollSupported = false;\n document.createElement('div').focus({\n get preventScroll() {\n isPreventScrollSupported = true;\n return false;\n }\n });\n if (isPreventScrollSupported) {\n preventReturnFocusRef.current = false;\n } else {\n preventReturnFocusRef.current = true;\n }\n }\n }\n events.on('openchange', onOpenChangeLocal);\n const fallbackEl = doc.createElement('span');\n fallbackEl.setAttribute('tabindex', '-1');\n fallbackEl.setAttribute('aria-hidden', 'true');\n Object.assign(fallbackEl.style, visuallyHidden);\n if (isInsidePortal && domReference) {\n domReference.insertAdjacentElement('afterend', fallbackEl);\n }\n function getReturnElement() {\n const returnFocusValueOrFn = returnFocusRef.current;\n let resolvedReturnFocusValue = typeof returnFocusValueOrFn === 'function' ? returnFocusValueOrFn(closeTypeRef.current) : returnFocusValueOrFn;\n\n // `null` should fallback to default behavior in case of an empty ref.\n if (resolvedReturnFocusValue === undefined || resolvedReturnFocusValue === false) {\n return null;\n }\n if (resolvedReturnFocusValue === null) {\n resolvedReturnFocusValue = true;\n }\n if (typeof resolvedReturnFocusValue === 'boolean') {\n const el = domReference || getPreviouslyFocusedElement();\n return el && el.isConnected ? el : fallbackEl;\n }\n const fallback = domReference || getPreviouslyFocusedElement() || fallbackEl;\n return resolveRef(resolvedReturnFocusValue) || fallback;\n }\n return () => {\n events.off('openchange', onOpenChangeLocal);\n const activeEl = activeElement(doc);\n const isFocusInsideFloatingTree = contains(floating, activeEl) || tree && getNodeChildren(tree.nodesRef.current, getNodeId(), false).some(node => contains(node.context?.elements.floating, activeEl));\n const returnElement = getReturnElement();\n queueMicrotask(() => {\n // This is `returnElement`, if it's tabbable, or its first tabbable child.\n const tabbableReturnElement = getFirstTabbableElement(returnElement);\n const hasExplicitReturnFocus = typeof returnFocusRef.current !== 'boolean';\n if (\n // eslint-disable-next-line react-hooks/exhaustive-deps\n returnFocusRef.current && !preventReturnFocusRef.current && isHTMLElement(tabbableReturnElement) && (\n // If the focus moved somewhere else after mount, avoid returning focus\n // since it likely entered a different element which should be\n // respected: https://github.com/floating-ui/floating-ui/issues/2607\n !hasExplicitReturnFocus && tabbableReturnElement !== activeEl && activeEl !== doc.body ? isFocusInsideFloatingTree : true)) {\n tabbableReturnElement.focus({\n preventScroll: true\n });\n }\n fallbackEl.remove();\n });\n };\n }, [disabled, floating, floatingFocusElement, returnFocusRef, dataRef, events, tree, isInsidePortal, domReference, getNodeId]);\n React.useEffect(() => {\n // The `returnFocus` cleanup behavior is inside a microtask; ensure we\n // wait for it to complete before resetting the flag.\n queueMicrotask(() => {\n preventReturnFocusRef.current = false;\n });\n }, [disabled]);\n React.useEffect(() => {\n if (disabled || !open) {\n return undefined;\n }\n function handlePointerDown(event) {\n const target = getTarget(event);\n if (target?.closest(`[${CLICK_TRIGGER_IDENTIFIER}]`)) {\n isPointerDownRef.current = true;\n }\n }\n const doc = getDocument(floatingFocusElement);\n doc.addEventListener('pointerdown', handlePointerDown, true);\n return () => {\n doc.removeEventListener('pointerdown', handlePointerDown, true);\n };\n }, [disabled, open, floatingFocusElement]);\n\n // Synchronize the `context` & `modal` value to the FloatingPortal context.\n // It will decide whether or not it needs to render its own guards.\n useIsoLayoutEffect(() => {\n if (disabled) {\n return undefined;\n }\n if (!portalContext) {\n return undefined;\n }\n portalContext.setFocusManagerState({\n modal,\n closeOnFocusOut,\n open,\n onOpenChange: store.setOpen,\n domReference\n });\n return () => {\n portalContext.setFocusManagerState(null);\n };\n }, [disabled, portalContext, modal, open, store, closeOnFocusOut, domReference]);\n useIsoLayoutEffect(() => {\n if (disabled || !floatingFocusElement) {\n return undefined;\n }\n handleTabIndex(floatingFocusElement, orderRef);\n return () => {\n queueMicrotask(clearDisconnectedPreviouslyFocusedElements);\n };\n }, [disabled, floatingFocusElement, orderRef]);\n const shouldRenderGuards = !disabled && (modal ? !isUntrappedTypeableCombobox : true) && (isInsidePortal || modal);\n return /*#__PURE__*/_jsxs(React.Fragment, {\n children: [shouldRenderGuards && /*#__PURE__*/_jsx(FocusGuard, {\n \"data-type\": \"inside\",\n ref: mergedBeforeGuardRef,\n onFocus: event => {\n if (modal) {\n const els = getTabbableElements();\n enqueueFocus(els[els.length - 1]);\n } else if (portalContext?.portalNode) {\n preventReturnFocusRef.current = false;\n if (isOutsideEvent(event, portalContext.portalNode)) {\n const nextTabbable = getNextTabbable(domReference);\n nextTabbable?.focus();\n } else {\n resolveRef(previousFocusableElement ?? portalContext.beforeOutsideRef)?.focus();\n }\n }\n }\n }), children, shouldRenderGuards && /*#__PURE__*/_jsx(FocusGuard, {\n \"data-type\": \"inside\",\n ref: mergedAfterGuardRef,\n onFocus: event => {\n if (modal) {\n enqueueFocus(getTabbableElements()[0]);\n } else if (portalContext?.portalNode) {\n if (closeOnFocusOut) {\n preventReturnFocusRef.current = true;\n }\n if (isOutsideEvent(event, portalContext.portalNode)) {\n const prevTabbable = getPreviousTabbable(domReference);\n prevTabbable?.focus();\n } else {\n resolveRef(nextFocusableElement ?? portalContext.afterOutsideRef)?.focus();\n }\n }\n }\n })]\n });\n}","import * as React from 'react';\nimport { getOverflowAncestors } from '@floating-ui/react-dom';\nimport { getComputedStyle, getParentNode, isElement, isHTMLElement, isLastTraversableNode, isWebKit } from '@floating-ui/utils/dom';\nimport { Timeout, useTimeout } from '@base-ui-components/utils/useTimeout';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { contains, getDocument, getTarget, isEventTargetWithin, isReactEvent, isRootElement, getNodeChildren } from \"../utils.js\";\n\n/* eslint-disable no-underscore-dangle */\n\nimport { useFloatingTree } from \"../components/FloatingTree.js\";\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { createAttribute } from \"../utils/createAttribute.js\";\nconst bubbleHandlerKeys = {\n intentional: 'onClick',\n sloppy: 'onPointerDown'\n};\nexport function normalizeProp(normalizable) {\n return {\n escapeKey: typeof normalizable === 'boolean' ? normalizable : normalizable?.escapeKey ?? false,\n outsidePress: typeof normalizable === 'boolean' ? normalizable : normalizable?.outsidePress ?? true\n };\n}\n/**\n * Closes the floating element when a dismissal is requested — by default, when\n * the user presses the `escape` key or outside of the floating element.\n * @see https://floating-ui.com/docs/useDismiss\n */\nexport function useDismiss(context, props = {}) {\n const store = 'rootStore' in context ? context.rootStore : context;\n const open = store.useState('open');\n const floatingElement = store.useState('floatingElement');\n const referenceElement = store.useState('referenceElement');\n const domReferenceElement = store.useState('domReferenceElement');\n const {\n onOpenChange,\n dataRef\n } = store.context;\n const {\n enabled = true,\n escapeKey = true,\n outsidePress: outsidePressProp = true,\n outsidePressEvent = 'sloppy',\n referencePress = false,\n referencePressEvent = 'sloppy',\n ancestorScroll = false,\n bubbles,\n externalTree\n } = props;\n const tree = useFloatingTree(externalTree);\n const outsidePressFn = useStableCallback(typeof outsidePressProp === 'function' ? outsidePressProp : () => false);\n const outsidePress = typeof outsidePressProp === 'function' ? outsidePressFn : outsidePressProp;\n const endedOrStartedInsideRef = React.useRef(false);\n const {\n escapeKey: escapeKeyBubbles,\n outsidePress: outsidePressBubbles\n } = normalizeProp(bubbles);\n const touchStateRef = React.useRef(null);\n const cancelDismissOnEndTimeout = useTimeout();\n const clearInsideReactTreeTimeout = useTimeout();\n const clearInsideReactTree = useStableCallback(() => {\n clearInsideReactTreeTimeout.clear();\n dataRef.current.insideReactTree = false;\n });\n const isComposingRef = React.useRef(false);\n const currentPointerTypeRef = React.useRef('');\n const trackPointerType = useStableCallback(event => {\n currentPointerTypeRef.current = event.pointerType;\n });\n const getOutsidePressEvent = useStableCallback(() => {\n const type = currentPointerTypeRef.current;\n const computedType = type === 'pen' || !type ? 'mouse' : type;\n const resolved = typeof outsidePressEvent === 'function' ? outsidePressEvent() : outsidePressEvent;\n if (typeof resolved === 'string') {\n return resolved;\n }\n return resolved[computedType];\n });\n const closeOnEscapeKeyDown = useStableCallback(event => {\n if (!open || !enabled || !escapeKey || event.key !== 'Escape') {\n return;\n }\n\n // Wait until IME is settled. Pressing `Escape` while composing should\n // close the compose menu, but not the floating element.\n if (isComposingRef.current) {\n return;\n }\n const nodeId = dataRef.current.floatingContext?.nodeId;\n const children = tree ? getNodeChildren(tree.nodesRef.current, nodeId) : [];\n if (!escapeKeyBubbles) {\n if (children.length > 0) {\n let shouldDismiss = true;\n children.forEach(child => {\n if (child.context?.open && !child.context.dataRef.current.__escapeKeyBubbles) {\n shouldDismiss = false;\n }\n });\n if (!shouldDismiss) {\n return;\n }\n }\n }\n const native = isReactEvent(event) ? event.nativeEvent : event;\n const eventDetails = createChangeEventDetails(REASONS.escapeKey, native);\n store.setOpen(false, eventDetails);\n if (!escapeKeyBubbles && !eventDetails.isPropagationAllowed) {\n event.stopPropagation();\n }\n });\n const shouldIgnoreEvent = useStableCallback(event => {\n const computedOutsidePressEvent = getOutsidePressEvent();\n return computedOutsidePressEvent === 'intentional' && event.type !== 'click' || computedOutsidePressEvent === 'sloppy' && event.type === 'click';\n });\n const markInsideReactTree = useStableCallback(() => {\n dataRef.current.insideReactTree = true;\n clearInsideReactTreeTimeout.start(0, clearInsideReactTree);\n });\n const closeOnPressOutside = useStableCallback((event, endedOrStartedInside = false) => {\n if (shouldIgnoreEvent(event)) {\n clearInsideReactTree();\n return;\n }\n if (dataRef.current.insideReactTree) {\n clearInsideReactTree();\n return;\n }\n if (getOutsidePressEvent() === 'intentional' && endedOrStartedInside) {\n return;\n }\n if (typeof outsidePress === 'function' && !outsidePress(event)) {\n return;\n }\n const target = getTarget(event);\n const inertSelector = `[${createAttribute('inert')}]`;\n const markers = getDocument(store.select('floatingElement')).querySelectorAll(inertSelector);\n const triggers = store.context.triggerElements;\n\n // If another trigger is clicked, don't close the floating element.\n if (target && (triggers.hasElement(target) || triggers.hasMatchingElement(trigger => contains(trigger, target)))) {\n return;\n }\n let targetRootAncestor = isElement(target) ? target : null;\n while (targetRootAncestor && !isLastTraversableNode(targetRootAncestor)) {\n const nextParent = getParentNode(targetRootAncestor);\n if (isLastTraversableNode(nextParent) || !isElement(nextParent)) {\n break;\n }\n targetRootAncestor = nextParent;\n }\n\n // Check if the click occurred on a third-party element injected after the\n // floating element rendered.\n if (markers.length && isElement(target) && !isRootElement(target) &&\n // Clicked on a direct ancestor (e.g. FloatingOverlay).\n !contains(target, store.select('floatingElement')) &&\n // If the target root element contains none of the markers, then the\n // element was injected after the floating element rendered.\n Array.from(markers).every(marker => !contains(targetRootAncestor, marker))) {\n return;\n }\n\n // Check if the click occurred on the scrollbar\n // Skip for touch events: scrollbars don't receive touch events on most platforms\n if (isHTMLElement(target) && !('touches' in event)) {\n const lastTraversableNode = isLastTraversableNode(target);\n const style = getComputedStyle(target);\n const scrollRe = /auto|scroll/;\n const isScrollableX = lastTraversableNode || scrollRe.test(style.overflowX);\n const isScrollableY = lastTraversableNode || scrollRe.test(style.overflowY);\n const canScrollX = isScrollableX && target.clientWidth > 0 && target.scrollWidth > target.clientWidth;\n const canScrollY = isScrollableY && target.clientHeight > 0 && target.scrollHeight > target.clientHeight;\n const isRTL = style.direction === 'rtl';\n\n // Check click position relative to scrollbar.\n // In some browsers it is possible to change the <body> (or window)\n // scrollbar to the left side, but is very rare and is difficult to\n // check for. Plus, for modal dialogs with backdrops, it is more\n // important that the backdrop is checked but not so much the window.\n const pressedVerticalScrollbar = canScrollY && (isRTL ? event.offsetX <= target.offsetWidth - target.clientWidth : event.offsetX > target.clientWidth);\n const pressedHorizontalScrollbar = canScrollX && event.offsetY > target.clientHeight;\n if (pressedVerticalScrollbar || pressedHorizontalScrollbar) {\n return;\n }\n }\n const nodeId = dataRef.current.floatingContext?.nodeId;\n const targetIsInsideChildren = tree && getNodeChildren(tree.nodesRef.current, nodeId).some(node => isEventTargetWithin(event, node.context?.elements.floating));\n if (isEventTargetWithin(event, store.select('floatingElement')) || isEventTargetWithin(event, store.select('domReferenceElement')) || targetIsInsideChildren) {\n return;\n }\n const children = tree ? getNodeChildren(tree.nodesRef.current, nodeId) : [];\n if (children.length > 0) {\n let shouldDismiss = true;\n children.forEach(child => {\n if (child.context?.open && !child.context.dataRef.current.__outsidePressBubbles) {\n shouldDismiss = false;\n }\n });\n if (!shouldDismiss) {\n return;\n }\n }\n store.setOpen(false, createChangeEventDetails(REASONS.outsidePress, event));\n clearInsideReactTree();\n });\n const handlePointerDown = useStableCallback(event => {\n if (getOutsidePressEvent() !== 'sloppy' || event.pointerType === 'touch' || !store.select('open') || !enabled || isEventTargetWithin(event, store.select('floatingElement')) || isEventTargetWithin(event, store.select('domReferenceElement'))) {\n return;\n }\n closeOnPressOutside(event);\n });\n const handleTouchStart = useStableCallback(event => {\n if (getOutsidePressEvent() !== 'sloppy' || !store.select('open') || !enabled || isEventTargetWithin(event, store.select('floatingElement')) || isEventTargetWithin(event, store.select('domReferenceElement'))) {\n return;\n }\n const touch = event.touches[0];\n if (touch) {\n touchStateRef.current = {\n startTime: Date.now(),\n startX: touch.clientX,\n startY: touch.clientY,\n dismissOnTouchEnd: false,\n dismissOnMouseDown: true\n };\n cancelDismissOnEndTimeout.start(1000, () => {\n if (touchStateRef.current) {\n touchStateRef.current.dismissOnTouchEnd = false;\n touchStateRef.current.dismissOnMouseDown = false;\n }\n });\n }\n });\n const handleTouchStartCapture = useStableCallback(event => {\n const target = getTarget(event);\n function callback() {\n handleTouchStart(event);\n target?.removeEventListener(event.type, callback);\n }\n target?.addEventListener(event.type, callback);\n });\n const closeOnPressOutsideCapture = useStableCallback(event => {\n // When click outside is lazy (`up` event), handle dragging.\n // Don't close if:\n // - The click started inside the floating element.\n // - The click ended inside the floating element.\n const endedOrStartedInside = endedOrStartedInsideRef.current;\n endedOrStartedInsideRef.current = false;\n cancelDismissOnEndTimeout.clear();\n if (event.type === 'mousedown' && touchStateRef.current && !touchStateRef.current.dismissOnMouseDown) {\n return;\n }\n const target = getTarget(event);\n function callback() {\n if (event.type === 'pointerdown') {\n handlePointerDown(event);\n } else {\n closeOnPressOutside(event, endedOrStartedInside);\n }\n target?.removeEventListener(event.type, callback);\n }\n target?.addEventListener(event.type, callback);\n });\n const handleTouchMove = useStableCallback(event => {\n if (getOutsidePressEvent() !== 'sloppy' || !touchStateRef.current || isEventTargetWithin(event, store.select('floatingElement')) || isEventTargetWithin(event, store.select('domReferenceElement'))) {\n return;\n }\n const touch = event.touches[0];\n if (!touch) {\n return;\n }\n const deltaX = Math.abs(touch.clientX - touchStateRef.current.startX);\n const deltaY = Math.abs(touch.clientY - touchStateRef.current.startY);\n const distance = Math.sqrt(deltaX * deltaX + deltaY * deltaY);\n if (distance > 5) {\n touchStateRef.current.dismissOnTouchEnd = true;\n }\n if (distance > 10) {\n closeOnPressOutside(event);\n cancelDismissOnEndTimeout.clear();\n touchStateRef.current = null;\n }\n });\n const handleTouchMoveCapture = useStableCallback(event => {\n const target = getTarget(event);\n function callback() {\n handleTouchMove(event);\n target?.removeEventListener(event.type, callback);\n }\n target?.addEventListener(event.type, callback);\n });\n const handleTouchEnd = useStableCallback(event => {\n if (getOutsidePressEvent() !== 'sloppy' || !touchStateRef.current || isEventTargetWithin(event, store.select('floatingElement')) || isEventTargetWithin(event, store.select('domReferenceElement'))) {\n return;\n }\n if (touchStateRef.current.dismissOnTouchEnd) {\n closeOnPressOutside(event);\n }\n cancelDismissOnEndTimeout.clear();\n touchStateRef.current = null;\n });\n const handleTouchEndCapture = useStableCallback(event => {\n const target = getTarget(event);\n function callback() {\n handleTouchEnd(event);\n target?.removeEventListener(event.type, callback);\n }\n target?.addEventListener(event.type, callback);\n });\n React.useEffect(() => {\n if (!open || !enabled) {\n return undefined;\n }\n dataRef.current.__escapeKeyBubbles = escapeKeyBubbles;\n dataRef.current.__outsidePressBubbles = outsidePressBubbles;\n const compositionTimeout = new Timeout();\n function onScroll(event) {\n store.setOpen(false, createChangeEventDetails(REASONS.none, event));\n }\n function handleCompositionStart() {\n compositionTimeout.clear();\n isComposingRef.current = true;\n }\n function handleCompositionEnd() {\n // Safari fires `compositionend` before `keydown`, so we need to wait\n // until the next tick to set `isComposing` to `false`.\n // https://bugs.webkit.org/show_bug.cgi?id=165004\n compositionTimeout.start(\n // 0ms or 1ms don't work in Safari. 5ms appears to consistently work.\n // Only apply to WebKit for the test to remain 0ms.\n isWebKit() ? 5 : 0, () => {\n isComposingRef.current = false;\n });\n }\n const doc = getDocument(floatingElement);\n doc.addEventListener('pointerdown', trackPointerType, true);\n if (escapeKey) {\n doc.addEventListener('keydown', closeOnEscapeKeyDown);\n doc.addEventListener('compositionstart', handleCompositionStart);\n doc.addEventListener('compositionend', handleCompositionEnd);\n }\n if (outsidePress) {\n doc.addEventListener('click', closeOnPressOutsideCapture, true);\n doc.addEventListener('pointerdown', closeOnPressOutsideCapture, true);\n doc.addEventListener('touchstart', handleTouchStartCapture, true);\n doc.addEventListener('touchmove', handleTouchMoveCapture, true);\n doc.addEventListener('touchend', handleTouchEndCapture, true);\n doc.addEventListener('mousedown', closeOnPressOutsideCapture, true);\n }\n let ancestors = [];\n if (ancestorScroll) {\n if (isElement(domReferenceElement)) {\n ancestors = getOverflowAncestors(domReferenceElement);\n }\n if (isElement(floatingElement)) {\n ancestors = ancestors.concat(getOverflowAncestors(floatingElement));\n }\n if (!isElement(referenceElement) && referenceElement && referenceElement.contextElement) {\n ancestors = ancestors.concat(getOverflowAncestors(referenceElement.contextElement));\n }\n }\n\n // Ignore the visual viewport for scrolling dismissal (allow pinch-zoom)\n ancestors = ancestors.filter(ancestor => ancestor !== doc.defaultView?.visualViewport);\n ancestors.forEach(ancestor => {\n ancestor.addEventListener('scroll', onScroll, {\n passive: true\n });\n });\n return () => {\n doc.removeEventListener('pointerdown', trackPointerType, true);\n if (escapeKey) {\n doc.removeEventListener('keydown', closeOnEscapeKeyDown);\n doc.removeEventListener('compositionstart', handleCompositionStart);\n doc.removeEventListener('compositionend', handleCompositionEnd);\n }\n if (outsidePress) {\n doc.removeEventListener('click', closeOnPressOutsideCapture, true);\n doc.removeEventListener('pointerdown', closeOnPressOutsideCapture, true);\n doc.removeEventListener('touchstart', handleTouchStartCapture, true);\n doc.removeEventListener('touchmove', handleTouchMoveCapture, true);\n doc.removeEventListener('touchend', handleTouchEndCapture, true);\n doc.removeEventListener('mousedown', closeOnPressOutsideCapture, true);\n }\n ancestors.forEach(ancestor => {\n ancestor.removeEventListener('scroll', onScroll);\n });\n compositionTimeout.clear();\n };\n }, [dataRef, floatingElement, referenceElement, domReferenceElement, escapeKey, outsidePress, open, onOpenChange, ancestorScroll, enabled, escapeKeyBubbles, outsidePressBubbles, closeOnEscapeKeyDown, closeOnPressOutside, closeOnPressOutsideCapture, handlePointerDown, handleTouchStartCapture, handleTouchMoveCapture, handleTouchEndCapture, trackPointerType, store]);\n React.useEffect(clearInsideReactTree, [outsidePress, clearInsideReactTree]);\n const reference = React.useMemo(() => ({\n onKeyDown: closeOnEscapeKeyDown,\n ...(referencePress && {\n [bubbleHandlerKeys[referencePressEvent]]: event => {\n store.setOpen(false, createChangeEventDetails(REASONS.triggerPress, event.nativeEvent));\n },\n ...(referencePressEvent !== 'intentional' && {\n onClick(event) {\n store.setOpen(false, createChangeEventDetails(REASONS.triggerPress, event.nativeEvent));\n }\n })\n })\n }), [closeOnEscapeKeyDown, store, referencePress, referencePressEvent]);\n const handlePressedInside = useStableCallback(event => {\n const target = getTarget(event.nativeEvent);\n if (!contains(store.select('floatingElement'), target) || event.button !== 0) {\n return;\n }\n endedOrStartedInsideRef.current = true;\n });\n const floating = React.useMemo(() => ({\n onKeyDown: closeOnEscapeKeyDown,\n // `onMouseDown` may be blocked if `event.preventDefault()` is called in\n // `onPointerDown`, such as with <NumberField.ScrubArea>.\n // See https://github.com/mui/base-ui/pull/3379\n onPointerDown: handlePressedInside,\n onMouseDown: handlePressedInside,\n onMouseUp: handlePressedInside,\n onClickCapture: markInsideReactTree,\n onMouseDownCapture: markInsideReactTree,\n onPointerDownCapture: markInsideReactTree,\n onMouseUpCapture: markInsideReactTree,\n onTouchEndCapture: markInsideReactTree,\n onTouchMoveCapture: markInsideReactTree\n }), [closeOnEscapeKeyDown, handlePressedInside, markInsideReactTree]);\n return React.useMemo(() => enabled ? {\n reference,\n floating,\n trigger: reference\n } : {}, [enabled, reference, floating]);\n}","// src/devModeChecks/identityFunctionCheck.ts\nvar runIdentityFunctionCheck = (resultFunc, inputSelectorsResults, outputSelectorResult) => {\n if (inputSelectorsResults.length === 1 && inputSelectorsResults[0] === outputSelectorResult) {\n let isInputSameAsOutput = false;\n try {\n const emptyObject = {};\n if (resultFunc(emptyObject) === emptyObject)\n isInputSameAsOutput = true;\n } catch {\n }\n if (isInputSameAsOutput) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"The result function returned its own inputs without modification. e.g\\n`createSelector([state => state.todos], todos => todos)`\\nThis could lead to inefficient memoization and unnecessary re-renders.\\nEnsure transformation logic is in the result function, and extraction logic is in the input selectors.\",\n { stack }\n );\n }\n }\n};\n\n// src/devModeChecks/inputStabilityCheck.ts\nvar runInputStabilityCheck = (inputSelectorResultsObject, options, inputSelectorArgs) => {\n const { memoize, memoizeOptions } = options;\n const { inputSelectorResults, inputSelectorResultsCopy } = inputSelectorResultsObject;\n const createAnEmptyObject = memoize(() => ({}), ...memoizeOptions);\n const areInputSelectorResultsEqual = createAnEmptyObject.apply(null, inputSelectorResults) === createAnEmptyObject.apply(null, inputSelectorResultsCopy);\n if (!areInputSelectorResultsEqual) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"An input selector returned a different result when passed same arguments.\\nThis means your output selector will likely run more frequently than intended.\\nAvoid returning a new reference inside your input selector, e.g.\\n`createSelector([state => state.todos.map(todo => todo.id)], todoIds => todoIds.length)`\",\n {\n arguments: inputSelectorArgs,\n firstInputs: inputSelectorResults,\n secondInputs: inputSelectorResultsCopy,\n stack\n }\n );\n }\n};\n\n// src/devModeChecks/setGlobalDevModeChecks.ts\nvar globalDevModeChecks = {\n inputStabilityCheck: \"once\",\n identityFunctionCheck: \"once\"\n};\nvar setGlobalDevModeChecks = (devModeChecks) => {\n Object.assign(globalDevModeChecks, devModeChecks);\n};\n\n// src/utils.ts\nvar NOT_FOUND = /* @__PURE__ */ Symbol(\"NOT_FOUND\");\nfunction assertIsFunction(func, errorMessage = `expected a function, instead received ${typeof func}`) {\n if (typeof func !== \"function\") {\n throw new TypeError(errorMessage);\n }\n}\nfunction assertIsObject(object, errorMessage = `expected an object, instead received ${typeof object}`) {\n if (typeof object !== \"object\") {\n throw new TypeError(errorMessage);\n }\n}\nfunction assertIsArrayOfFunctions(array, errorMessage = `expected all items to be functions, instead received the following types: `) {\n if (!array.every((item) => typeof item === \"function\")) {\n const itemTypes = array.map(\n (item) => typeof item === \"function\" ? `function ${item.name || \"unnamed\"}()` : typeof item\n ).join(\", \");\n throw new TypeError(`${errorMessage}[${itemTypes}]`);\n }\n}\nvar ensureIsArray = (item) => {\n return Array.isArray(item) ? item : [item];\n};\nfunction getDependencies(createSelectorArgs) {\n const dependencies = Array.isArray(createSelectorArgs[0]) ? createSelectorArgs[0] : createSelectorArgs;\n assertIsArrayOfFunctions(\n dependencies,\n `createSelector expects all input-selectors to be functions, but received the following types: `\n );\n return dependencies;\n}\nfunction collectInputSelectorResults(dependencies, inputSelectorArgs) {\n const inputSelectorResults = [];\n const { length } = dependencies;\n for (let i = 0; i < length; i++) {\n inputSelectorResults.push(dependencies[i].apply(null, inputSelectorArgs));\n }\n return inputSelectorResults;\n}\nvar getDevModeChecksExecutionInfo = (firstRun, devModeChecks) => {\n const { identityFunctionCheck, inputStabilityCheck } = {\n ...globalDevModeChecks,\n ...devModeChecks\n };\n return {\n identityFunctionCheck: {\n shouldRun: identityFunctionCheck === \"always\" || identityFunctionCheck === \"once\" && firstRun,\n run: runIdentityFunctionCheck\n },\n inputStabilityCheck: {\n shouldRun: inputStabilityCheck === \"always\" || inputStabilityCheck === \"once\" && firstRun,\n run: runInputStabilityCheck\n }\n };\n};\n\n// src/autotrackMemoize/autotracking.ts\nvar $REVISION = 0;\nvar CURRENT_TRACKER = null;\nvar Cell = class {\n revision = $REVISION;\n _value;\n _lastValue;\n _isEqual = tripleEq;\n constructor(initialValue, isEqual = tripleEq) {\n this._value = this._lastValue = initialValue;\n this._isEqual = isEqual;\n }\n // Whenever a storage value is read, it'll add itself to the current tracker if\n // one exists, entangling its state with that cache.\n get value() {\n CURRENT_TRACKER?.add(this);\n return this._value;\n }\n // Whenever a storage value is updated, we bump the global revision clock,\n // assign the revision for this storage to the new value, _and_ we schedule a\n // rerender. This is important, and it's what makes autotracking _pull_\n // based. We don't actively tell the caches which depend on the storage that\n // anything has happened. Instead, we recompute the caches when needed.\n set value(newValue) {\n if (this.value === newValue)\n return;\n this._value = newValue;\n this.revision = ++$REVISION;\n }\n};\nfunction tripleEq(a, b) {\n return a === b;\n}\nvar TrackingCache = class {\n _cachedValue;\n _cachedRevision = -1;\n _deps = [];\n hits = 0;\n fn;\n constructor(fn) {\n this.fn = fn;\n }\n clear() {\n this._cachedValue = void 0;\n this._cachedRevision = -1;\n this._deps = [];\n this.hits = 0;\n }\n get value() {\n if (this.revision > this._cachedRevision) {\n const { fn } = this;\n const currentTracker = /* @__PURE__ */ new Set();\n const prevTracker = CURRENT_TRACKER;\n CURRENT_TRACKER = currentTracker;\n this._cachedValue = fn();\n CURRENT_TRACKER = prevTracker;\n this.hits++;\n this._deps = Array.from(currentTracker);\n this._cachedRevision = this.revision;\n }\n CURRENT_TRACKER?.add(this);\n return this._cachedValue;\n }\n get revision() {\n return Math.max(...this._deps.map((d) => d.revision), 0);\n }\n};\nfunction getValue(cell) {\n if (!(cell instanceof Cell)) {\n console.warn(\"Not a valid cell! \", cell);\n }\n return cell.value;\n}\nfunction setValue(storage, value) {\n if (!(storage instanceof Cell)) {\n throw new TypeError(\n \"setValue must be passed a tracked store created with `createStorage`.\"\n );\n }\n storage.value = storage._lastValue = value;\n}\nfunction createCell(initialValue, isEqual = tripleEq) {\n return new Cell(initialValue, isEqual);\n}\nfunction createCache(fn) {\n assertIsFunction(\n fn,\n \"the first parameter to `createCache` must be a function\"\n );\n return new TrackingCache(fn);\n}\n\n// src/autotrackMemoize/tracking.ts\nvar neverEq = (a, b) => false;\nfunction createTag() {\n return createCell(null, neverEq);\n}\nfunction dirtyTag(tag, value) {\n setValue(tag, value);\n}\nvar consumeCollection = (node) => {\n let tag = node.collectionTag;\n if (tag === null) {\n tag = node.collectionTag = createTag();\n }\n getValue(tag);\n};\nvar dirtyCollection = (node) => {\n const tag = node.collectionTag;\n if (tag !== null) {\n dirtyTag(tag, null);\n }\n};\n\n// src/autotrackMemoize/proxy.ts\nvar REDUX_PROXY_LABEL = Symbol();\nvar nextId = 0;\nvar proto = Object.getPrototypeOf({});\nvar ObjectTreeNode = class {\n constructor(value) {\n this.value = value;\n this.value = value;\n this.tag.value = value;\n }\n proxy = new Proxy(this, objectProxyHandler);\n tag = createTag();\n tags = {};\n children = {};\n collectionTag = null;\n id = nextId++;\n};\nvar objectProxyHandler = {\n get(node, key) {\n function calculateResult() {\n const { value } = node;\n const childValue = Reflect.get(value, key);\n if (typeof key === \"symbol\") {\n return childValue;\n }\n if (key in proto) {\n return childValue;\n }\n if (typeof childValue === \"object\" && childValue !== null) {\n let childNode = node.children[key];\n if (childNode === void 0) {\n childNode = node.children[key] = createNode(childValue);\n }\n if (childNode.tag) {\n getValue(childNode.tag);\n }\n return childNode.proxy;\n } else {\n let tag = node.tags[key];\n if (tag === void 0) {\n tag = node.tags[key] = createTag();\n tag.value = childValue;\n }\n getValue(tag);\n return childValue;\n }\n }\n const res = calculateResult();\n return res;\n },\n ownKeys(node) {\n consumeCollection(node);\n return Reflect.ownKeys(node.value);\n },\n getOwnPropertyDescriptor(node, prop) {\n return Reflect.getOwnPropertyDescriptor(node.value, prop);\n },\n has(node, prop) {\n return Reflect.has(node.value, prop);\n }\n};\nvar ArrayTreeNode = class {\n constructor(value) {\n this.value = value;\n this.value = value;\n this.tag.value = value;\n }\n proxy = new Proxy([this], arrayProxyHandler);\n tag = createTag();\n tags = {};\n children = {};\n collectionTag = null;\n id = nextId++;\n};\nvar arrayProxyHandler = {\n get([node], key) {\n if (key === \"length\") {\n consumeCollection(node);\n }\n return objectProxyHandler.get(node, key);\n },\n ownKeys([node]) {\n return objectProxyHandler.ownKeys(node);\n },\n getOwnPropertyDescriptor([node], prop) {\n return objectProxyHandler.getOwnPropertyDescriptor(node, prop);\n },\n has([node], prop) {\n return objectProxyHandler.has(node, prop);\n }\n};\nfunction createNode(value) {\n if (Array.isArray(value)) {\n return new ArrayTreeNode(value);\n }\n return new ObjectTreeNode(value);\n}\nfunction updateNode(node, newValue) {\n const { value, tags, children } = node;\n node.value = newValue;\n if (Array.isArray(value) && Array.isArray(newValue) && value.length !== newValue.length) {\n dirtyCollection(node);\n } else {\n if (value !== newValue) {\n let oldKeysSize = 0;\n let newKeysSize = 0;\n let anyKeysAdded = false;\n for (const _key in value) {\n oldKeysSize++;\n }\n for (const key in newValue) {\n newKeysSize++;\n if (!(key in value)) {\n anyKeysAdded = true;\n break;\n }\n }\n const isDifferent = anyKeysAdded || oldKeysSize !== newKeysSize;\n if (isDifferent) {\n dirtyCollection(node);\n }\n }\n }\n for (const key in tags) {\n const childValue = value[key];\n const newChildValue = newValue[key];\n if (childValue !== newChildValue) {\n dirtyCollection(node);\n dirtyTag(tags[key], newChildValue);\n }\n if (typeof newChildValue === \"object\" && newChildValue !== null) {\n delete tags[key];\n }\n }\n for (const key in children) {\n const childNode = children[key];\n const newChildValue = newValue[key];\n const childValue = childNode.value;\n if (childValue === newChildValue) {\n continue;\n } else if (typeof newChildValue === \"object\" && newChildValue !== null) {\n updateNode(childNode, newChildValue);\n } else {\n deleteNode(childNode);\n delete children[key];\n }\n }\n}\nfunction deleteNode(node) {\n if (node.tag) {\n dirtyTag(node.tag, null);\n }\n dirtyCollection(node);\n for (const key in node.tags) {\n dirtyTag(node.tags[key], null);\n }\n for (const key in node.children) {\n deleteNode(node.children[key]);\n }\n}\n\n// src/lruMemoize.ts\nfunction createSingletonCache(equals) {\n let entry;\n return {\n get(key) {\n if (entry && equals(entry.key, key)) {\n return entry.value;\n }\n return NOT_FOUND;\n },\n put(key, value) {\n entry = { key, value };\n },\n getEntries() {\n return entry ? [entry] : [];\n },\n clear() {\n entry = void 0;\n }\n };\n}\nfunction createLruCache(maxSize, equals) {\n let entries = [];\n function get(key) {\n const cacheIndex = entries.findIndex((entry) => equals(key, entry.key));\n if (cacheIndex > -1) {\n const entry = entries[cacheIndex];\n if (cacheIndex > 0) {\n entries.splice(cacheIndex, 1);\n entries.unshift(entry);\n }\n return entry.value;\n }\n return NOT_FOUND;\n }\n function put(key, value) {\n if (get(key) === NOT_FOUND) {\n entries.unshift({ key, value });\n if (entries.length > maxSize) {\n entries.pop();\n }\n }\n }\n function getEntries() {\n return entries;\n }\n function clear() {\n entries = [];\n }\n return { get, put, getEntries, clear };\n}\nvar referenceEqualityCheck = (a, b) => a === b;\nfunction createCacheKeyComparator(equalityCheck) {\n return function areArgumentsShallowlyEqual(prev, next) {\n if (prev === null || next === null || prev.length !== next.length) {\n return false;\n }\n const { length } = prev;\n for (let i = 0; i < length; i++) {\n if (!equalityCheck(prev[i], next[i])) {\n return false;\n }\n }\n return true;\n };\n}\nfunction lruMemoize(func, equalityCheckOrOptions) {\n const providedOptions = typeof equalityCheckOrOptions === \"object\" ? equalityCheckOrOptions : { equalityCheck: equalityCheckOrOptions };\n const {\n equalityCheck = referenceEqualityCheck,\n maxSize = 1,\n resultEqualityCheck\n } = providedOptions;\n const comparator = createCacheKeyComparator(equalityCheck);\n let resultsCount = 0;\n const cache = maxSize <= 1 ? createSingletonCache(comparator) : createLruCache(maxSize, comparator);\n function memoized() {\n let value = cache.get(arguments);\n if (value === NOT_FOUND) {\n value = func.apply(null, arguments);\n resultsCount++;\n if (resultEqualityCheck) {\n const entries = cache.getEntries();\n const matchingEntry = entries.find(\n (entry) => resultEqualityCheck(entry.value, value)\n );\n if (matchingEntry) {\n value = matchingEntry.value;\n resultsCount !== 0 && resultsCount--;\n }\n }\n cache.put(arguments, value);\n }\n return value;\n }\n memoized.clearCache = () => {\n cache.clear();\n memoized.resetResultsCount();\n };\n memoized.resultsCount = () => resultsCount;\n memoized.resetResultsCount = () => {\n resultsCount = 0;\n };\n return memoized;\n}\n\n// src/autotrackMemoize/autotrackMemoize.ts\nfunction autotrackMemoize(func) {\n const node = createNode(\n []\n );\n let lastArgs = null;\n const shallowEqual = createCacheKeyComparator(referenceEqualityCheck);\n const cache = createCache(() => {\n const res = func.apply(null, node.proxy);\n return res;\n });\n function memoized() {\n if (!shallowEqual(lastArgs, arguments)) {\n updateNode(node, arguments);\n lastArgs = arguments;\n }\n return cache.value;\n }\n memoized.clearCache = () => {\n return cache.clear();\n };\n return memoized;\n}\n\n// src/weakMapMemoize.ts\nvar StrongRef = class {\n constructor(value) {\n this.value = value;\n }\n deref() {\n return this.value;\n }\n};\nvar Ref = typeof WeakRef !== \"undefined\" ? WeakRef : StrongRef;\nvar UNTERMINATED = 0;\nvar TERMINATED = 1;\nfunction createCacheNode() {\n return {\n s: UNTERMINATED,\n v: void 0,\n o: null,\n p: null\n };\n}\nfunction weakMapMemoize(func, options = {}) {\n let fnNode = createCacheNode();\n const { resultEqualityCheck } = options;\n let lastResult;\n let resultsCount = 0;\n function memoized() {\n let cacheNode = fnNode;\n const { length } = arguments;\n for (let i = 0, l = length; i < l; i++) {\n const arg = arguments[i];\n if (typeof arg === \"function\" || typeof arg === \"object\" && arg !== null) {\n let objectCache = cacheNode.o;\n if (objectCache === null) {\n cacheNode.o = objectCache = /* @__PURE__ */ new WeakMap();\n }\n const objectNode = objectCache.get(arg);\n if (objectNode === void 0) {\n cacheNode = createCacheNode();\n objectCache.set(arg, cacheNode);\n } else {\n cacheNode = objectNode;\n }\n } else {\n let primitiveCache = cacheNode.p;\n if (primitiveCache === null) {\n cacheNode.p = primitiveCache = /* @__PURE__ */ new Map();\n }\n const primitiveNode = primitiveCache.get(arg);\n if (primitiveNode === void 0) {\n cacheNode = createCacheNode();\n primitiveCache.set(arg, cacheNode);\n } else {\n cacheNode = primitiveNode;\n }\n }\n }\n const terminatedNode = cacheNode;\n let result;\n if (cacheNode.s === TERMINATED) {\n result = cacheNode.v;\n } else {\n result = func.apply(null, arguments);\n resultsCount++;\n if (resultEqualityCheck) {\n const lastResultValue = lastResult?.deref?.() ?? lastResult;\n if (lastResultValue != null && resultEqualityCheck(lastResultValue, result)) {\n result = lastResultValue;\n resultsCount !== 0 && resultsCount--;\n }\n const needsWeakRef = typeof result === \"object\" && result !== null || typeof result === \"function\";\n lastResult = needsWeakRef ? new Ref(result) : result;\n }\n }\n terminatedNode.s = TERMINATED;\n terminatedNode.v = result;\n return result;\n }\n memoized.clearCache = () => {\n fnNode = createCacheNode();\n memoized.resetResultsCount();\n };\n memoized.resultsCount = () => resultsCount;\n memoized.resetResultsCount = () => {\n resultsCount = 0;\n };\n return memoized;\n}\n\n// src/createSelectorCreator.ts\nfunction createSelectorCreator(memoizeOrOptions, ...memoizeOptionsFromArgs) {\n const createSelectorCreatorOptions = typeof memoizeOrOptions === \"function\" ? {\n memoize: memoizeOrOptions,\n memoizeOptions: memoizeOptionsFromArgs\n } : memoizeOrOptions;\n const createSelector2 = (...createSelectorArgs) => {\n let recomputations = 0;\n let dependencyRecomputations = 0;\n let lastResult;\n let directlyPassedOptions = {};\n let resultFunc = createSelectorArgs.pop();\n if (typeof resultFunc === \"object\") {\n directlyPassedOptions = resultFunc;\n resultFunc = createSelectorArgs.pop();\n }\n assertIsFunction(\n resultFunc,\n `createSelector expects an output function after the inputs, but received: [${typeof resultFunc}]`\n );\n const combinedOptions = {\n ...createSelectorCreatorOptions,\n ...directlyPassedOptions\n };\n const {\n memoize,\n memoizeOptions = [],\n argsMemoize = weakMapMemoize,\n argsMemoizeOptions = [],\n devModeChecks = {}\n } = combinedOptions;\n const finalMemoizeOptions = ensureIsArray(memoizeOptions);\n const finalArgsMemoizeOptions = ensureIsArray(argsMemoizeOptions);\n const dependencies = getDependencies(createSelectorArgs);\n const memoizedResultFunc = memoize(function recomputationWrapper() {\n recomputations++;\n return resultFunc.apply(\n null,\n arguments\n );\n }, ...finalMemoizeOptions);\n let firstRun = true;\n const selector = argsMemoize(function dependenciesChecker() {\n dependencyRecomputations++;\n const inputSelectorResults = collectInputSelectorResults(\n dependencies,\n arguments\n );\n lastResult = memoizedResultFunc.apply(null, inputSelectorResults);\n if (process.env.NODE_ENV !== \"production\") {\n const { identityFunctionCheck, inputStabilityCheck } = getDevModeChecksExecutionInfo(firstRun, devModeChecks);\n if (identityFunctionCheck.shouldRun) {\n identityFunctionCheck.run(\n resultFunc,\n inputSelectorResults,\n lastResult\n );\n }\n if (inputStabilityCheck.shouldRun) {\n const inputSelectorResultsCopy = collectInputSelectorResults(\n dependencies,\n arguments\n );\n inputStabilityCheck.run(\n { inputSelectorResults, inputSelectorResultsCopy },\n { memoize, memoizeOptions: finalMemoizeOptions },\n arguments\n );\n }\n if (firstRun)\n firstRun = false;\n }\n return lastResult;\n }, ...finalArgsMemoizeOptions);\n return Object.assign(selector, {\n resultFunc,\n memoizedResultFunc,\n dependencies,\n dependencyRecomputations: () => dependencyRecomputations,\n resetDependencyRecomputations: () => {\n dependencyRecomputations = 0;\n },\n lastResult: () => lastResult,\n recomputations: () => recomputations,\n resetRecomputations: () => {\n recomputations = 0;\n },\n memoize,\n argsMemoize\n });\n };\n Object.assign(createSelector2, {\n withTypes: () => createSelector2\n });\n return createSelector2;\n}\nvar createSelector = /* @__PURE__ */ createSelectorCreator(weakMapMemoize);\n\n// src/createStructuredSelector.ts\nvar createStructuredSelector = Object.assign(\n (inputSelectorsObject, selectorCreator = createSelector) => {\n assertIsObject(\n inputSelectorsObject,\n `createStructuredSelector expects first argument to be an object where each property is a selector, instead received a ${typeof inputSelectorsObject}`\n );\n const inputSelectorKeys = Object.keys(inputSelectorsObject);\n const dependencies = inputSelectorKeys.map(\n (key) => inputSelectorsObject[key]\n );\n const structuredSelector = selectorCreator(\n dependencies,\n (...inputSelectorResults) => {\n return inputSelectorResults.reduce((composition, value, index) => {\n composition[inputSelectorKeys[index]] = value;\n return composition;\n }, {});\n }\n );\n return structuredSelector;\n },\n { withTypes: () => createStructuredSelector }\n);\nexport {\n createSelector,\n createSelectorCreator,\n createStructuredSelector,\n lruMemoize,\n referenceEqualityCheck,\n setGlobalDevModeChecks,\n autotrackMemoize as unstable_autotrackMemoize,\n weakMapMemoize\n};\n//# sourceMappingURL=reselect.mjs.map","import _formatErrorMessage from \"../formatErrorMessage.js\";\nimport { lruMemoize, createSelectorCreator } from 'reselect';\n\n/* eslint-disable no-underscore-dangle */ // __cacheKey__\n\nconst reselectCreateSelector = createSelectorCreator({\n memoize: lruMemoize,\n memoizeOptions: {\n maxSize: 1,\n equalityCheck: Object.is\n }\n});\n/**\n * Creates a selector function that can be used to derive values from the store's state.\n * The selector can take up to three additional arguments that can be used in the selector logic.\n * This function accepts up to six functions and combines them into a single selector function.\n * The last parameter is the combiner function that combines the results of the previous selectors.\n *\n * @example\n * const selector = createSelector(\n * (state) => state.disabled\n * );\n *\n * @example\n * const selector = createSelector(\n * (state) => state.disabled,\n * (state) => state.open,\n * (disabled, open) => ({ disabled, open })\n * );\n *\n */\n/* eslint-disable id-denylist */\nexport const createSelector = (a, b, c, d, e, f, ...other) => {\n if (other.length > 0) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Unsupported number of selectors' : _formatErrorMessage(1));\n }\n let selector;\n if (a && b && c && d && e && f) {\n selector = (state, a1, a2, a3) => {\n const va = a(state, a1, a2, a3);\n const vb = b(state, a1, a2, a3);\n const vc = c(state, a1, a2, a3);\n const vd = d(state, a1, a2, a3);\n const ve = e(state, a1, a2, a3);\n return f(va, vb, vc, vd, ve, a1, a2, a3);\n };\n } else if (a && b && c && d && e) {\n selector = (state, a1, a2, a3) => {\n const va = a(state, a1, a2, a3);\n const vb = b(state, a1, a2, a3);\n const vc = c(state, a1, a2, a3);\n const vd = d(state, a1, a2, a3);\n return e(va, vb, vc, vd, a1, a2, a3);\n };\n } else if (a && b && c && d) {\n selector = (state, a1, a2, a3) => {\n const va = a(state, a1, a2, a3);\n const vb = b(state, a1, a2, a3);\n const vc = c(state, a1, a2, a3);\n return d(va, vb, vc, a1, a2, a3);\n };\n } else if (a && b && c) {\n selector = (state, a1, a2, a3) => {\n const va = a(state, a1, a2, a3);\n const vb = b(state, a1, a2, a3);\n return c(va, vb, a1, a2, a3);\n };\n } else if (a && b) {\n selector = (state, a1, a2, a3) => {\n const va = a(state, a1, a2, a3);\n return b(va, a1, a2, a3);\n };\n } else if (a) {\n selector = a;\n } else {\n throw new Error('Missing arguments');\n }\n return selector;\n};\n/* eslint-enable id-denylist */\n\nexport const createSelectorMemoized = (...selectors) => {\n const cache = new WeakMap();\n let nextCacheId = 1;\n const combiner = selectors[selectors.length - 1];\n const nSelectors = selectors.length - 1 || 1;\n // (s1, s2, ..., sN, a1, a2, a3) => { ... }\n const argsLength = combiner.length - nSelectors;\n if (argsLength > 3) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Unsupported number of arguments' : _formatErrorMessage(2));\n }\n const selector = (state, a1, a2, a3) => {\n let cacheKey = state.__cacheKey__;\n if (!cacheKey) {\n cacheKey = {\n id: nextCacheId\n };\n state.__cacheKey__ = cacheKey;\n nextCacheId += 1;\n }\n let fn = cache.get(cacheKey);\n if (!fn) {\n let reselectArgs = selectors;\n const selectorArgs = [undefined, undefined, undefined];\n switch (argsLength) {\n case 0:\n break;\n case 1:\n {\n reselectArgs = [...selectors.slice(0, -1), () => selectorArgs[0], combiner];\n break;\n }\n case 2:\n {\n reselectArgs = [...selectors.slice(0, -1), () => selectorArgs[0], () => selectorArgs[1], combiner];\n break;\n }\n case 3:\n {\n reselectArgs = [...selectors.slice(0, -1), () => selectorArgs[0], () => selectorArgs[1], () => selectorArgs[2], combiner];\n break;\n }\n default:\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Unsupported number of arguments' : _formatErrorMessage(2));\n }\n fn = reselectCreateSelector(...reselectArgs);\n fn.selectorArgs = selectorArgs;\n cache.set(cacheKey, fn);\n }\n fn.selectorArgs[0] = a1;\n fn.selectorArgs[1] = a2;\n fn.selectorArgs[2] = a3;\n\n // prettier-ignore\n switch (argsLength) {\n case 0:\n return fn(state);\n case 1:\n return fn(state, a1);\n case 2:\n return fn(state, a1, a2);\n case 3:\n return fn(state, a1, a2, a3);\n default:\n throw new Error('unreachable');\n }\n };\n return selector;\n};","/**\n * @license React\n * use-sync-external-store-shim.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar React = require(\"react\");\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useState = React.useState,\n useEffect = React.useEffect,\n useLayoutEffect = React.useLayoutEffect,\n useDebugValue = React.useDebugValue;\nfunction useSyncExternalStore$2(subscribe, getSnapshot) {\n var value = getSnapshot(),\n _useState = useState({ inst: { value: value, getSnapshot: getSnapshot } }),\n inst = _useState[0].inst,\n forceUpdate = _useState[1];\n useLayoutEffect(\n function () {\n inst.value = value;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n },\n [subscribe, value, getSnapshot]\n );\n useEffect(\n function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n return subscribe(function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n });\n },\n [subscribe]\n );\n useDebugValue(value);\n return value;\n}\nfunction checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n}\nfunction useSyncExternalStore$1(subscribe, getSnapshot) {\n return getSnapshot();\n}\nvar shim =\n \"undefined\" === typeof window ||\n \"undefined\" === typeof window.document ||\n \"undefined\" === typeof window.document.createElement\n ? useSyncExternalStore$1\n : useSyncExternalStore$2;\nexports.useSyncExternalStore =\n void 0 !== React.useSyncExternalStore ? React.useSyncExternalStore : shim;\n","/**\n * @license React\n * use-sync-external-store-shim.development.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\n\"production\" !== process.env.NODE_ENV &&\n (function () {\n function is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n }\n function useSyncExternalStore$2(subscribe, getSnapshot) {\n didWarnOld18Alpha ||\n void 0 === React.startTransition ||\n ((didWarnOld18Alpha = !0),\n console.error(\n \"You are using an outdated, pre-release alpha of React 18 that does not support useSyncExternalStore. The use-sync-external-store shim will not work correctly. Upgrade to a newer pre-release.\"\n ));\n var value = getSnapshot();\n if (!didWarnUncachedGetSnapshot) {\n var cachedValue = getSnapshot();\n objectIs(value, cachedValue) ||\n (console.error(\n \"The result of getSnapshot should be cached to avoid an infinite loop\"\n ),\n (didWarnUncachedGetSnapshot = !0));\n }\n cachedValue = useState({\n inst: { value: value, getSnapshot: getSnapshot }\n });\n var inst = cachedValue[0].inst,\n forceUpdate = cachedValue[1];\n useLayoutEffect(\n function () {\n inst.value = value;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n },\n [subscribe, value, getSnapshot]\n );\n useEffect(\n function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n return subscribe(function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n });\n },\n [subscribe]\n );\n useDebugValue(value);\n return value;\n }\n function checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n }\n function useSyncExternalStore$1(subscribe, getSnapshot) {\n return getSnapshot();\n }\n \"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ &&\n \"function\" ===\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart &&\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(Error());\n var React = require(\"react\"),\n objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useState = React.useState,\n useEffect = React.useEffect,\n useLayoutEffect = React.useLayoutEffect,\n useDebugValue = React.useDebugValue,\n didWarnOld18Alpha = !1,\n didWarnUncachedGetSnapshot = !1,\n shim =\n \"undefined\" === typeof window ||\n \"undefined\" === typeof window.document ||\n \"undefined\" === typeof window.document.createElement\n ? useSyncExternalStore$1\n : useSyncExternalStore$2;\n exports.useSyncExternalStore =\n void 0 !== React.useSyncExternalStore ? React.useSyncExternalStore : shim;\n \"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ &&\n \"function\" ===\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop &&\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop(Error());\n })();\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.production.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.development.js');\n}\n","/**\n * @license React\n * use-sync-external-store-shim/with-selector.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar React = require(\"react\"),\n shim = require(\"use-sync-external-store/shim\");\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useSyncExternalStore = shim.useSyncExternalStore,\n useRef = React.useRef,\n useEffect = React.useEffect,\n useMemo = React.useMemo,\n useDebugValue = React.useDebugValue;\nexports.useSyncExternalStoreWithSelector = function (\n subscribe,\n getSnapshot,\n getServerSnapshot,\n selector,\n isEqual\n) {\n var instRef = useRef(null);\n if (null === instRef.current) {\n var inst = { hasValue: !1, value: null };\n instRef.current = inst;\n } else inst = instRef.current;\n instRef = useMemo(\n function () {\n function memoizedSelector(nextSnapshot) {\n if (!hasMemo) {\n hasMemo = !0;\n memoizedSnapshot = nextSnapshot;\n nextSnapshot = selector(nextSnapshot);\n if (void 0 !== isEqual && inst.hasValue) {\n var currentSelection = inst.value;\n if (isEqual(currentSelection, nextSnapshot))\n return (memoizedSelection = currentSelection);\n }\n return (memoizedSelection = nextSnapshot);\n }\n currentSelection = memoizedSelection;\n if (objectIs(memoizedSnapshot, nextSnapshot)) return currentSelection;\n var nextSelection = selector(nextSnapshot);\n if (void 0 !== isEqual && isEqual(currentSelection, nextSelection))\n return (memoizedSnapshot = nextSnapshot), currentSelection;\n memoizedSnapshot = nextSnapshot;\n return (memoizedSelection = nextSelection);\n }\n var hasMemo = !1,\n memoizedSnapshot,\n memoizedSelection,\n maybeGetServerSnapshot =\n void 0 === getServerSnapshot ? null : getServerSnapshot;\n return [\n function () {\n return memoizedSelector(getSnapshot());\n },\n null === maybeGetServerSnapshot\n ? void 0\n : function () {\n return memoizedSelector(maybeGetServerSnapshot());\n }\n ];\n },\n [getSnapshot, getServerSnapshot, selector, isEqual]\n );\n var value = useSyncExternalStore(subscribe, instRef[0], instRef[1]);\n useEffect(\n function () {\n inst.hasValue = !0;\n inst.value = value;\n },\n [value]\n );\n useDebugValue(value);\n return value;\n};\n","/**\n * @license React\n * use-sync-external-store-shim/with-selector.development.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\n\"production\" !== process.env.NODE_ENV &&\n (function () {\n function is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n }\n \"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ &&\n \"function\" ===\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart &&\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(Error());\n var React = require(\"react\"),\n shim = require(\"use-sync-external-store/shim\"),\n objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useSyncExternalStore = shim.useSyncExternalStore,\n useRef = React.useRef,\n useEffect = React.useEffect,\n useMemo = React.useMemo,\n useDebugValue = React.useDebugValue;\n exports.useSyncExternalStoreWithSelector = function (\n subscribe,\n getSnapshot,\n getServerSnapshot,\n selector,\n isEqual\n ) {\n var instRef = useRef(null);\n if (null === instRef.current) {\n var inst = { hasValue: !1, value: null };\n instRef.current = inst;\n } else inst = instRef.current;\n instRef = useMemo(\n function () {\n function memoizedSelector(nextSnapshot) {\n if (!hasMemo) {\n hasMemo = !0;\n memoizedSnapshot = nextSnapshot;\n nextSnapshot = selector(nextSnapshot);\n if (void 0 !== isEqual && inst.hasValue) {\n var currentSelection = inst.value;\n if (isEqual(currentSelection, nextSnapshot))\n return (memoizedSelection = currentSelection);\n }\n return (memoizedSelection = nextSnapshot);\n }\n currentSelection = memoizedSelection;\n if (objectIs(memoizedSnapshot, nextSnapshot))\n return currentSelection;\n var nextSelection = selector(nextSnapshot);\n if (void 0 !== isEqual && isEqual(currentSelection, nextSelection))\n return (memoizedSnapshot = nextSnapshot), currentSelection;\n memoizedSnapshot = nextSnapshot;\n return (memoizedSelection = nextSelection);\n }\n var hasMemo = !1,\n memoizedSnapshot,\n memoizedSelection,\n maybeGetServerSnapshot =\n void 0 === getServerSnapshot ? null : getServerSnapshot;\n return [\n function () {\n return memoizedSelector(getSnapshot());\n },\n null === maybeGetServerSnapshot\n ? void 0\n : function () {\n return memoizedSelector(maybeGetServerSnapshot());\n }\n ];\n },\n [getSnapshot, getServerSnapshot, selector, isEqual]\n );\n var value = useSyncExternalStore(subscribe, instRef[0], instRef[1]);\n useEffect(\n function () {\n inst.hasValue = !0;\n inst.value = value;\n },\n [value]\n );\n useDebugValue(value);\n return value;\n };\n \"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ &&\n \"function\" ===\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop &&\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop(Error());\n })();\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.production.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.development.js');\n}\n","import * as React from 'react';\n/* We need to import the shim because React 17 does not support the `useSyncExternalStore` API.\n * More info: https://github.com/mui/mui-x/issues/18303#issuecomment-2958392341 */\nimport { useSyncExternalStore } from 'use-sync-external-store/shim';\nimport { useSyncExternalStoreWithSelector } from 'use-sync-external-store/shim/with-selector';\nimport { isReactVersionAtLeast } from \"../reactVersion.js\";\n/* Some tests fail in R18 with the raw useSyncExternalStore. It may be possible to make it work\n * but for now we only enable it for R19+. */\nconst canUseRawUseSyncExternalStore = isReactVersionAtLeast(19);\nconst useStoreImplementation = canUseRawUseSyncExternalStore ? useStoreR19 : useStoreLegacy;\nexport function useStore(store, selector, a1, a2, a3) {\n return useStoreImplementation(store, selector, a1, a2, a3);\n}\nfunction useStoreR19(store, selector, a1, a2, a3) {\n const getSelection = React.useCallback(() => selector(store.getSnapshot(), a1, a2, a3), [store, selector, a1, a2, a3]);\n return useSyncExternalStore(store.subscribe, getSelection, getSelection);\n}\nfunction useStoreLegacy(store, selector, a1, a2, a3) {\n return useSyncExternalStoreWithSelector(store.subscribe, store.getSnapshot, store.getSnapshot, state => selector(state, a1, a2, a3));\n}","/**\n * A data store implementation that allows subscribing to state changes and updating the state.\n * It uses an observer pattern to notify subscribers when the state changes.\n */\nexport class Store {\n /**\n * The current state of the store.\n * This property is updated immediately when the state changes as a result of calling {@link setState}, {@link update}, or {@link set}.\n * To subscribe to state changes, use the {@link useState} method. The value returned by {@link useState} is updated after the component renders (similarly to React's useState).\n * The values can be used directly (to avoid subscribing to the store) in effects or event handlers.\n *\n * Do not modify properties in state directly. Instead, use the provided methods to ensure proper state management and listener notification.\n */\n\n // Internal state to handle recursive `setState()` calls\n\n constructor(state) {\n this.state = state;\n this.listeners = new Set();\n this.updateTick = 0;\n }\n\n /**\n * Registers a listener that will be called whenever the store's state changes.\n *\n * @param fn The listener function to be called on state changes.\n * @returns A function to unsubscribe the listener.\n */\n subscribe = fn => {\n this.listeners.add(fn);\n return () => {\n this.listeners.delete(fn);\n };\n };\n\n /**\n * Returns the current state of the store.\n */\n getSnapshot = () => {\n return this.state;\n };\n\n /**\n * Updates the entire store's state and notifies all registered listeners.\n *\n * @param newState The new state to set for the store.\n */\n setState(newState) {\n if (this.state === newState) {\n return;\n }\n this.state = newState;\n this.updateTick += 1;\n const currentTick = this.updateTick;\n for (const listener of this.listeners) {\n if (currentTick !== this.updateTick) {\n // If the tick has changed, a recursive `setState` call has been made,\n // and it has already notified all listeners.\n return;\n }\n listener(newState);\n }\n }\n\n /**\n * Merges the provided changes into the current state and notifies listeners if there are changes.\n *\n * @param changes An object containing the changes to apply to the current state.\n */\n update(changes) {\n for (const key in changes) {\n if (!Object.is(this.state[key], changes[key])) {\n Store.prototype.setState.call(this, {\n ...this.state,\n ...changes\n });\n return;\n }\n }\n }\n\n /**\n * Sets a specific key in the store's state to a new value and notifies listeners if the value has changed.\n *\n * @param key The key in the store's state to update.\n * @param value The new value to set for the specified key.\n */\n set(key, value) {\n if (!Object.is(this.state[key], value)) {\n Store.prototype.setState.call(this, {\n ...this.state,\n [key]: value\n });\n }\n }\n\n /**\n * Gives the state a new reference and updates all registered listeners.\n */\n notifyAll() {\n const newState = {\n ...this.state\n };\n Store.prototype.setState.call(this, newState);\n }\n}","/* False positives - ESLint thinks we're calling a hook from a class component. */\n/* eslint-disable react-hooks/rules-of-hooks */\nimport * as React from 'react';\nimport { Store } from \"./Store.js\";\nimport { useStore } from \"./useStore.js\";\nimport { useStableCallback } from \"../useStableCallback.js\";\nimport { useIsoLayoutEffect } from \"../useIsoLayoutEffect.js\";\nimport { NOOP } from \"../empty.js\";\n\n/**\n * A Store that supports controlled state keys, non-reactive values and provides utility methods for React.\n */\nexport class ReactStore extends Store {\n /**\n * Creates a new ReactStore instance.\n *\n * @param state Initial state of the store.\n * @param context Non-reactive context values.\n * @param selectors Optional selectors for use with `useState`.\n */\n constructor(state, context = {}, selectors) {\n super(state);\n this.context = context;\n this.selectors = selectors;\n }\n\n /**\n * Non-reactive values such as refs, callbacks, etc.\n */\n\n /**\n * Keeps track of which properties are controlled.\n */\n controlledValues = new Map();\n /**\n * Synchronizes a single external value into the store.\n *\n * Note that the while the value in `state` is updated immediately, the value returned\n * by `useState` is updated before the next render (similarly to React's `useState`).\n */\n useSyncedValue(key, value) {\n React.useDebugValue(key);\n useIsoLayoutEffect(() => {\n if (this.state[key] !== value) {\n this.set(key, value);\n }\n }, [key, value]);\n }\n\n /**\n * Synchronizes a single external value into the store and\n * cleans it up (sets to `undefined`) on unmount.\n *\n * Note that the while the value in `state` is updated immediately, the value returned\n * by `useState` is updated before the next render (similarly to React's `useState`).\n */\n useSyncedValueWithCleanup(key, value) {\n useIsoLayoutEffect(() => {\n if (this.state[key] !== value) {\n this.set(key, value);\n }\n return () => {\n this.set(key, undefined);\n };\n }, [key, value]);\n }\n\n /**\n * Synchronizes multiple external values into the store.\n *\n * Note that the while the values in `state` are updated immediately, the values returned\n * by `useState` are updated before the next render (similarly to React's `useState`).\n */\n useSyncedValues(statePart) {\n if (process.env.NODE_ENV !== 'production') {\n // Check that an object with the same shape is passed on every render\n React.useDebugValue(statePart, p => Object.keys(p));\n const keys = React.useRef(Object.keys(statePart)).current;\n const nextKeys = Object.keys(statePart);\n if (keys.length !== nextKeys.length || keys.some((key, index) => key !== nextKeys[index])) {\n console.error('ReactStore.useSyncedValues expects the same prop keys on every render. Keys should be stable.');\n }\n }\n const dependencies = Object.values(statePart);\n useIsoLayoutEffect(() => {\n this.update(statePart);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, dependencies);\n }\n\n /**\n * Registers a controllable prop pair (`controlled`, `defaultValue`) for a specific key.\n * - If `controlled` is non-undefined, the key is marked as controlled and the store's\n * state at `key` is updated to match `controlled`. Local writes to that key are ignored.\n * - If `controlled` is undefined, the key is marked as uncontrolled. The store's state\n * is initialized to `defaultValue` on first render and can be updated with local writes.\n */\n useControlledProp(key, controlled, defaultValue) {\n React.useDebugValue(key);\n const isControlled = controlled !== undefined;\n if (process.env.NODE_ENV !== 'production') {\n const previouslyControlled = this.controlledValues.get(key);\n if (previouslyControlled !== undefined && previouslyControlled !== isControlled) {\n console.error(`A component is changing the ${isControlled ? '' : 'un'}controlled state of ${key.toString()} to be ${isControlled ? 'un' : ''}controlled. Elements should not switch from uncontrolled to controlled (or vice versa).`);\n }\n }\n if (!this.controlledValues.has(key)) {\n // First time initialization\n this.controlledValues.set(key, isControlled);\n if (!isControlled && !Object.is(this.state[key], defaultValue)) {\n super.setState({\n ...this.state,\n [key]: defaultValue\n });\n }\n }\n useIsoLayoutEffect(() => {\n if (isControlled && !Object.is(this.state[key], controlled)) {\n // Set the internal state to match the controlled value.\n super.setState({\n ...this.state,\n [key]: controlled\n });\n }\n }, [key, controlled, defaultValue, isControlled]);\n }\n\n /**\n * Sets a specific key in the store's state to a new value and notifies listeners if the value has changed.\n * If the key is controlled (registered via {@link useControlledProp} with a non-undefined value),\n * the update is ignored and no listeners are notified.\n *\n * @param key The state key to update.\n * @param value The new value to set for the specified key.\n */\n set(key, value) {\n if (this.controlledValues.get(key) === true) {\n // Ignore updates to controlled values\n return;\n }\n super.set(key, value);\n }\n\n /**\n * Merges the provided changes into the current state and notifies listeners if there are changes.\n * Controlled keys are filtered out and not updated.\n *\n * @param values An object containing the changes to apply to the current state.\n */\n update(values) {\n const newValues = {\n ...values\n };\n for (const key in newValues) {\n if (!Object.hasOwn(newValues, key)) {\n continue;\n }\n if (this.controlledValues.get(key) === true) {\n // Ignore updates to controlled values\n delete newValues[key];\n continue;\n }\n }\n super.update(newValues);\n }\n\n /**\n * Updates the entire store's state and notifies all registered listeners.\n * Controlled keys are left unchanged; only uncontrolled keys from `newState` are applied.\n *\n * @param newState The new state to set for the store.\n */\n setState(newState) {\n const newValues = {\n ...newState\n };\n for (const key in newValues) {\n if (!Object.hasOwn(newValues, key)) {\n continue;\n }\n if (this.controlledValues.get(key) === true) {\n // Ignore updates to controlled values\n delete newValues[key];\n continue;\n }\n }\n super.setState({\n ...this.state,\n ...newValues\n });\n }\n\n /** Gets the current value from the store using a selector with the provided key.\n *\n * @param key Key of the selector to use.\n */\n select = (key, a1, a2, a3) => {\n const selector = this.selectors[key];\n return selector(this.state, a1, a2, a3);\n };\n\n /**\n * Returns a value from the store's state using a selector function.\n * Used to subscribe to specific parts of the state.\n * This methods causes a rerender whenever the selected state changes.\n *\n * @param key Key of the selector to use.\n */\n useState = (key, a1, a2, a3) => {\n React.useDebugValue(key);\n const selector = this.selectors[key];\n const value = useStore(this, selector, a1, a2, a3);\n return value;\n };\n\n /**\n * Wraps a function with `useStableCallback` to ensure it has a stable reference\n * and assigns it to the context.\n *\n * @param key Key of the event callback. Must be a function in the context.\n * @param fn Function to assign.\n */\n useContextCallback(key, fn) {\n React.useDebugValue(key);\n const stableFunction = useStableCallback(fn ?? NOOP);\n this.context[key] = stableFunction;\n }\n\n /**\n * Returns a stable setter function for a specific key in the store's state.\n * It's commonly used to pass as a ref callback to React elements.\n *\n * @param key Key of the state to set.\n */\n useStateSetter(key) {\n const ref = React.useRef(undefined);\n if (ref.current === undefined) {\n ref.current = value => {\n this.set(key, value);\n };\n }\n return ref.current;\n }\n\n /**\n * Observes changes derived from the store's selectors and calls the listener when the selected value changes.\n *\n * @param key Key of the selector to observe.\n * @param listener Listener function called when the selector result changes.\n */\n\n observe(selector, listener) {\n let selectFn;\n if (typeof selector === 'function') {\n selectFn = selector;\n } else {\n selectFn = this.selectors[selector];\n }\n let prevValue = selectFn(this.state);\n listener(prevValue, prevValue, this);\n return this.subscribe(nextState => {\n const nextValue = selectFn(nextState);\n if (!Object.is(prevValue, nextValue)) {\n const oldValue = prevValue;\n prevValue = nextValue;\n listener(nextValue, oldValue, this);\n }\n });\n }\n}","import { createSelector, ReactStore } from '@base-ui-components/utils/store';\nimport { createEventEmitter } from \"../utils/createEventEmitter.js\";\nimport { isClickLikeEvent } from \"../utils.js\";\nconst selectors = {\n open: createSelector(state => state.open),\n domReferenceElement: createSelector(state => state.domReferenceElement),\n referenceElement: createSelector(state => state.positionReference ?? state.referenceElement),\n floatingElement: createSelector(state => state.floatingElement),\n floatingId: createSelector(state => state.floatingId)\n};\nexport class FloatingRootStore extends ReactStore {\n constructor(options) {\n const {\n nested,\n noEmit,\n onOpenChange,\n triggerElements,\n ...initialState\n } = options;\n super({\n ...initialState,\n positionReference: initialState.referenceElement,\n domReferenceElement: initialState.referenceElement\n }, {\n onOpenChange,\n dataRef: {\n current: {}\n },\n events: createEventEmitter(),\n nested,\n noEmit,\n triggerElements\n }, selectors);\n }\n\n /**\n * Emits the `openchange` event through the internal event emitter and calls the `onOpenChange` handler with the provided arguments.\n *\n * @param newOpen The new open state.\n * @param eventDetails Details about the event that triggered the open state change.\n */\n setOpen = (newOpen, eventDetails) => {\n if (!newOpen || !this.state.open ||\n // Prevent a pending hover-open from overwriting a click-open event, while allowing\n // click events to upgrade a hover-open.\n isClickLikeEvent(eventDetails.event)) {\n this.context.dataRef.current.openEvent = newOpen ? eventDetails.event : undefined;\n }\n if (!this.context.noEmit) {\n const details = {\n open: newOpen,\n reason: eventDetails.reason,\n nativeEvent: eventDetails.event,\n nested: this.context.nested,\n triggerElement: eventDetails.trigger\n };\n this.context.events.emit('openchange', details);\n }\n this.context.onOpenChange?.(newOpen, eventDetails);\n };\n}","import * as React from 'react';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { useTransitionStatus } from \"../useTransitionStatus.js\";\nimport { useOpenChangeComplete } from \"../useOpenChangeComplete.js\";\n/**\n * Returns a callback ref that registers/unregisters the trigger element in the store.\n *\n * @param store The Store instance where the trigger should be registered.\n */\nexport function useTriggerRegistration(id, store) {\n // Keep track of the currently registered element to unregister it on unmount or id change.\n const registeredElementId = React.useRef(null);\n return React.useCallback(element => {\n if (id === undefined) {\n return undefined;\n }\n if (registeredElementId.current !== null) {\n store.context.triggerElements.delete(registeredElementId.current);\n registeredElementId.current = null;\n }\n if (element !== null) {\n registeredElementId.current = id;\n store.context.triggerElements.add(id, element);\n return () => {\n if (registeredElementId.current !== null) {\n store.context.triggerElements.delete(registeredElementId.current);\n registeredElementId.current = null;\n }\n };\n }\n return undefined;\n }, [store, id]);\n}\n\n/**\n * Sets up trigger data forwarding to the store.\n *\n * @param triggerId Id of the trigger.\n * @param triggerElement The trigger DOM element.\n * @param store The Store instance managing the popup state.\n * @param stateUpdates An object with state updates to apply when the trigger is active.\n */\nexport function useTriggerDataForwarding(triggerId, triggerElementRef, store, stateUpdates) {\n const isMountedByThisTrigger = store.useState('isMountedByTrigger', triggerId);\n const baseRegisterTrigger = useTriggerRegistration(triggerId, store);\n const registerTrigger = useStableCallback(element => {\n const cleanup = baseRegisterTrigger(element);\n if (element !== null && store.select('open') && store.select('activeTriggerId') == null) {\n // This runs when popup is open, but no active trigger is set.\n // It can happen when using controlled mode and the trigger is mounted after opening or if `triggerId` prop is not set explicitly.\n // In such cases the first trigger to run this code becomes the active trigger (store.select('activeTriggerId') should not return null after that).\n // This is mostly for compatibility with contained triggers where no explicit `triggerId` was required in controlled mode.\n store.update({\n activeTriggerId: triggerId,\n activeTriggerElement: element,\n ...stateUpdates\n });\n }\n return cleanup;\n });\n useIsoLayoutEffect(() => {\n if (isMountedByThisTrigger) {\n store.update({\n activeTriggerElement: triggerElementRef.current,\n ...stateUpdates\n });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isMountedByThisTrigger, store, triggerElementRef, ...Object.values(stateUpdates)]);\n return {\n registerTrigger,\n isMountedByThisTrigger\n };\n}\n/**\n * Ensures that when there's only one trigger element registered, it is set as the active trigger.\n * This allows controlled popups to work correctly without an explicit triggerId, maintaining compatibility\n * with the contained triggers.\n *\n * This should be called on the Root part.\n *\n * @param open Whether the popup is open.\n * @param store The Store instance managing the popup state.\n */\nexport function useImplicitActiveTrigger(store) {\n const open = store.useState('open');\n useIsoLayoutEffect(() => {\n if (open && !store.select('activeTriggerId') && store.context.triggerElements.size === 1) {\n const iteratorResult = store.context.triggerElements.entries().next();\n if (!iteratorResult.done) {\n const [implicitTriggerId, implicitTriggerElement] = iteratorResult.value;\n store.update({\n activeTriggerId: implicitTriggerId,\n activeTriggerElement: implicitTriggerElement\n });\n }\n }\n }, [open, store]);\n}\n\n/**\n * Mangages the mounted state of the popup.\n * Sets up the transition status listeners and handles unmounting when needed.\n * Updates the `mounted` and `transitionStatus` states in the store.\n *\n * @param open Whether the popup is open.\n * @param store The Store instance managing the popup state.\n * @param onUnmount Optional callback to be called when the popup is unmounted.\n *\n * @returns A function to forcibly unmount the popup.\n */\nexport function useOpenStateTransitions(open, store, onUnmount) {\n const {\n mounted,\n setMounted,\n transitionStatus\n } = useTransitionStatus(open);\n store.useSyncedValues({\n mounted,\n transitionStatus\n });\n const forceUnmount = useStableCallback(() => {\n setMounted(false);\n store.update({\n activeTriggerId: null,\n activeTriggerElement: null,\n mounted: false\n });\n onUnmount?.();\n store.context.onOpenChangeComplete?.(false);\n });\n const preventUnmountingOnClose = store.useState('preventUnmountingOnClose');\n useOpenChangeComplete({\n enabled: !preventUnmountingOnClose,\n open,\n ref: store.context.popupRef,\n onComplete() {\n if (!open) {\n forceUnmount();\n }\n }\n });\n return {\n forceUnmount,\n transitionStatus\n };\n}","import _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\n/**\n * Data structure to keep track of popup trigger elements by their IDs.\n * Uses both a set of Elements and a map of IDs to Elements for efficient lookups.\n */\nexport class PopupTriggerMap {\n constructor() {\n this.elements = new Set();\n this.idMap = new Map();\n }\n\n /**\n * Adds a trigger element with the given ID.\n *\n * Note: The provided element is assumed to not be registered under multiple IDs.\n */\n add(id, element) {\n const existingElement = this.idMap.get(id);\n if (existingElement === element) {\n return;\n }\n if (existingElement !== undefined) {\n // We assume that the same element won't be registered under multiple ids.\n // This is safe considering how useTriggerRegistration is implemented.\n this.elements.delete(existingElement);\n }\n this.elements.add(element);\n this.idMap.set(id, element);\n if (process.env.NODE_ENV !== 'production') {\n if (this.elements.size !== this.idMap.size) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: A trigger element cannot be registered under multiple IDs in PopupTriggerMap.' : _formatErrorMessage(87));\n }\n }\n }\n\n /**\n * Removes the trigger element with the given ID.\n */\n delete(id) {\n const element = this.idMap.get(id);\n if (element) {\n this.elements.delete(element);\n this.idMap.delete(id);\n }\n }\n\n /**\n * Whether the given element is registered as a trigger.\n */\n hasElement(element) {\n return this.elements.has(element);\n }\n\n /**\n * Whether there is a registered trigger element matching the given predicate.\n */\n hasMatchingElement(predicate) {\n for (const element of this.elements) {\n if (predicate(element)) {\n return true;\n }\n }\n return false;\n }\n getById(id) {\n return this.idMap.get(id);\n }\n entries() {\n return this.idMap.entries();\n }\n get size() {\n return this.idMap.size;\n }\n}","import { PopupTriggerMap } from \"../../utils/popups/index.js\";\nimport { FloatingRootStore } from \"../components/FloatingRootStore.js\";\nexport function getEmptyRootContext() {\n return new FloatingRootStore({\n open: false,\n floatingElement: null,\n referenceElement: null,\n triggerElements: new PopupTriggerMap(),\n floatingId: '',\n nested: false,\n noEmit: false,\n onOpenChange: undefined\n });\n}","import { createSelector } from '@base-ui-components/utils/store';\nimport { getEmptyRootContext } from \"../../floating-ui-react/utils/getEmptyRootContext.js\";\nimport { EMPTY_OBJECT } from \"../constants.js\";\n\n/**\n * State common to all popup stores.\n */\n\nexport function createInitialPopupStoreState() {\n return {\n open: false,\n mounted: false,\n transitionStatus: 'idle',\n floatingRootContext: getEmptyRootContext(),\n preventUnmountingOnClose: false,\n payload: undefined,\n activeTriggerId: null,\n activeTriggerElement: null,\n popupElement: null,\n positionerElement: null,\n activeTriggerProps: EMPTY_OBJECT,\n inactiveTriggerProps: EMPTY_OBJECT,\n popupProps: EMPTY_OBJECT\n };\n}\nexport const popupStoreSelectors = {\n open: createSelector(state => state.open),\n mounted: createSelector(state => state.mounted),\n transitionStatus: createSelector(state => state.transitionStatus),\n floatingRootContext: createSelector(state => state.floatingRootContext),\n preventUnmountingOnClose: createSelector(state => state.preventUnmountingOnClose),\n payload: createSelector(state => state.payload),\n activeTriggerId: createSelector(state => state.activeTriggerId),\n activeTriggerElement: createSelector(state => state.mounted ? state.activeTriggerElement : null),\n /**\n * Whether the trigger with the given ID was used to open the popup.\n */\n isTriggerActive: createSelector((state, triggerId) => triggerId !== undefined && state.activeTriggerId === triggerId),\n /**\n * Whether the popup is open and was activated by a trigger with the given ID.\n */\n isOpenedByTrigger: createSelector((state, triggerId) => triggerId !== undefined && state.activeTriggerId === triggerId && state.open),\n /**\n * Whether the popup is mounted and was activated by a trigger with the given ID.\n */\n isMountedByTrigger: createSelector((state, triggerId) => triggerId !== undefined && state.activeTriggerId === triggerId && state.mounted),\n triggerProps: createSelector((state, isActive) => isActive ? state.activeTriggerProps : state.inactiveTriggerProps),\n popupProps: createSelector(state => state.popupProps),\n popupElement: createSelector(state => state.popupElement),\n positionerElement: createSelector(state => state.positionerElement)\n};","import { useId } from '@base-ui-components/utils/useId';\nimport { useRefWithInit } from '@base-ui-components/utils/useRefWithInit';\nimport { useIsoLayoutEffect } from '@base-ui-components/utils/useIsoLayoutEffect';\nimport { isElement } from '@floating-ui/utils/dom';\nimport { useFloatingParentNodeId } from \"../components/FloatingTree.js\";\nimport { FloatingRootStore } from \"../components/FloatingRootStore.js\";\n/**\n * Initializes a FloatingRootStore that is kept in sync with the provided PopupStore.\n * The new instance is created only once and updated on every render.\n */\nexport function useSyncedFloatingRootContext(options) {\n const {\n popupStore,\n noEmit = false,\n treatPopupAsFloatingElement = false,\n onOpenChange\n } = options;\n const floatingId = useId();\n const nested = useFloatingParentNodeId() != null;\n const open = popupStore.useState('open');\n const referenceElement = popupStore.useState('activeTriggerElement');\n const floatingElement = popupStore.useState(treatPopupAsFloatingElement ? 'popupElement' : 'positionerElement');\n const triggerElements = popupStore.context.triggerElements;\n const store = useRefWithInit(() => new FloatingRootStore({\n open,\n referenceElement,\n floatingElement,\n triggerElements,\n onOpenChange,\n floatingId,\n nested,\n noEmit\n })).current;\n useIsoLayoutEffect(() => {\n const valuesToSync = {\n open,\n floatingId,\n referenceElement,\n floatingElement\n };\n if (isElement(referenceElement)) {\n valuesToSync.domReferenceElement = referenceElement;\n }\n store.update(valuesToSync);\n }, [open, floatingId, referenceElement, floatingElement, store]);\n\n // TODO: When `setOpen` is a part of the PopupStore API, we don't need to sync it.\n store.context.onOpenChange = onOpenChange;\n store.context.nested = nested;\n store.context.noEmit = noEmit;\n return store;\n}","import * as React from 'react';\nimport { ACTIVE_KEY, FOCUSABLE_ATTRIBUTE, SELECTED_KEY } from \"../utils/constants.js\";\n/**\n * Merges an array of interaction hooks' props into prop getters, allowing\n * event handler functions to be composed together without overwriting one\n * another.\n * @see https://floating-ui.com/docs/useInteractions\n */\nexport function useInteractions(propsList = []) {\n const referenceDeps = propsList.map(key => key?.reference);\n const floatingDeps = propsList.map(key => key?.floating);\n const itemDeps = propsList.map(key => key?.item);\n const triggerDeps = propsList.map(key => key?.trigger);\n const getReferenceProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'reference'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n referenceDeps);\n const getFloatingProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'floating'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n floatingDeps);\n const getItemProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'item'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n itemDeps);\n const getTriggerProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'trigger'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n triggerDeps);\n return React.useMemo(() => ({\n getReferenceProps,\n getFloatingProps,\n getItemProps,\n getTriggerProps\n }), [getReferenceProps, getFloatingProps, getItemProps, getTriggerProps]);\n}\n\n/* eslint-disable guard-for-in */\n\nfunction mergeProps(userProps, propsList, elementKey) {\n const eventHandlers = new Map();\n const isItem = elementKey === 'item';\n const outputProps = {};\n if (elementKey === 'floating') {\n outputProps.tabIndex = -1;\n outputProps[FOCUSABLE_ATTRIBUTE] = '';\n }\n for (const key in userProps) {\n if (isItem && userProps) {\n if (key === ACTIVE_KEY || key === SELECTED_KEY) {\n continue;\n }\n }\n outputProps[key] = userProps[key];\n }\n for (let i = 0; i < propsList.length; i += 1) {\n let props;\n const propsOrGetProps = propsList[i]?.[elementKey];\n if (typeof propsOrGetProps === 'function') {\n props = userProps ? propsOrGetProps(userProps) : null;\n } else {\n props = propsOrGetProps;\n }\n if (!props) {\n continue;\n }\n mutablyMergeProps(outputProps, props, isItem, eventHandlers);\n }\n mutablyMergeProps(outputProps, userProps, isItem, eventHandlers);\n return outputProps;\n}\nfunction mutablyMergeProps(outputProps, props, isItem, eventHandlers) {\n for (const key in props) {\n const value = props[key];\n if (isItem && (key === ACTIVE_KEY || key === SELECTED_KEY)) {\n continue;\n }\n if (!key.startsWith('on')) {\n outputProps[key] = value;\n } else {\n if (!eventHandlers.has(key)) {\n eventHandlers.set(key, []);\n }\n if (typeof value === 'function') {\n eventHandlers.get(key)?.push(value);\n outputProps[key] = (...args) => {\n return eventHandlers.get(key)?.map(fn => fn(...args)).find(val => val !== undefined);\n };\n }\n }\n }\n}","import * as React from 'react';\nimport { useId } from '@base-ui-components/utils/useId';\nimport { getFloatingFocusElement } from \"../utils.js\";\nimport { useFloatingParentNodeId } from \"../components/FloatingTree.js\";\nimport { EMPTY_OBJECT } from \"../../utils/constants.js\";\nconst componentRoleToAriaRoleMap = new Map([['select', 'listbox'], ['combobox', 'listbox'], ['label', false]]);\n\n/**\n * Adds base screen reader props to the reference and floating elements for a\n * given floating element `role`.\n * @see https://floating-ui.com/docs/useRole\n */\nexport function useRole(context, props = {}) {\n const store = 'rootStore' in context ? context.rootStore : context;\n const open = store.useState('open');\n const defaultFloatingId = store.useState('floatingId');\n const domReference = store.useState('domReferenceElement');\n const floatingElement = store.useState('floatingElement');\n const {\n enabled = true,\n role = 'dialog'\n } = props;\n const defaultReferenceId = useId();\n const referenceId = domReference?.id || defaultReferenceId;\n const floatingId = React.useMemo(() => getFloatingFocusElement(floatingElement)?.id || defaultFloatingId, [floatingElement, defaultFloatingId]);\n const ariaRole = componentRoleToAriaRoleMap.get(role) ?? role;\n const parentId = useFloatingParentNodeId();\n const isNested = parentId != null;\n const trigger = React.useMemo(() => {\n if (ariaRole === 'tooltip' || role === 'label') {\n return EMPTY_OBJECT;\n }\n return {\n 'aria-haspopup': ariaRole === 'alertdialog' ? 'dialog' : ariaRole,\n 'aria-expanded': 'false',\n ...(ariaRole === 'listbox' && {\n role: 'combobox'\n }),\n ...(ariaRole === 'menu' && isNested && {\n role: 'menuitem'\n }),\n ...(role === 'select' && {\n 'aria-autocomplete': 'none'\n }),\n ...(role === 'combobox' && {\n 'aria-autocomplete': 'list'\n })\n };\n }, [ariaRole, isNested, role]);\n const reference = React.useMemo(() => {\n if (ariaRole === 'tooltip' || role === 'label') {\n return {\n [`aria-${role === 'label' ? 'labelledby' : 'describedby'}`]: open ? floatingId : undefined\n };\n }\n const triggerProps = trigger;\n return {\n ...triggerProps,\n 'aria-expanded': open ? 'true' : 'false',\n 'aria-controls': open ? floatingId : undefined,\n ...(ariaRole === 'menu' && {\n id: referenceId\n })\n };\n }, [ariaRole, floatingId, open, referenceId, role, trigger]);\n const floating = React.useMemo(() => {\n const floatingProps = {\n id: floatingId,\n ...(ariaRole && {\n role: ariaRole\n })\n };\n if (ariaRole === 'tooltip' || role === 'label') {\n return floatingProps;\n }\n return {\n ...floatingProps,\n ...(ariaRole === 'menu' && {\n 'aria-labelledby': referenceId\n })\n };\n }, [ariaRole, floatingId, referenceId, role]);\n const item = React.useCallback(({\n active,\n selected\n }) => {\n const commonProps = {\n role: 'option',\n ...(active && {\n id: `${floatingId}-fui-option`\n })\n };\n\n // For `menu`, we are unable to tell if the item is a `menuitemradio`\n // or `menuitemcheckbox`. For backwards-compatibility reasons, also\n // avoid defaulting to `menuitem` as it may overwrite custom role props.\n switch (role) {\n case 'select':\n case 'combobox':\n return {\n ...commonProps,\n 'aria-selected': selected\n };\n default:\n }\n return {};\n }, [floatingId, role]);\n return React.useMemo(() => enabled ? {\n reference,\n floating,\n item,\n trigger\n } : {}, [enabled, reference, floating, trigger, item]);\n}","export let DialogPopupCssVars = /*#__PURE__*/function (DialogPopupCssVars) {\n /**\n * Indicates how many dialogs are nested within.\n * @type {number}\n */\n DialogPopupCssVars[\"nestedDialogs\"] = \"--nested-dialogs\";\n return DialogPopupCssVars;\n}({});","import { CommonPopupDataAttributes } from \"../../utils/popupStateMapping.js\";\nexport let DialogPopupDataAttributes = function (DialogPopupDataAttributes) {\n /**\n * Present when the dialog is open.\n */\n DialogPopupDataAttributes[DialogPopupDataAttributes[\"open\"] = CommonPopupDataAttributes.open] = \"open\";\n /**\n * Present when the dialog is closed.\n */\n DialogPopupDataAttributes[DialogPopupDataAttributes[\"closed\"] = CommonPopupDataAttributes.closed] = \"closed\";\n /**\n * Present when the dialog is animating in.\n */\n DialogPopupDataAttributes[DialogPopupDataAttributes[\"startingStyle\"] = CommonPopupDataAttributes.startingStyle] = \"startingStyle\";\n /**\n * Present when the dialog is animating out.\n */\n DialogPopupDataAttributes[DialogPopupDataAttributes[\"endingStyle\"] = CommonPopupDataAttributes.endingStyle] = \"endingStyle\";\n /**\n * Present when the dialog is nested within another dialog.\n */\n DialogPopupDataAttributes[\"nested\"] = \"data-nested\";\n /**\n * Present when the dialog has other open dialogs nested within it.\n */\n DialogPopupDataAttributes[\"nestedDialogOpen\"] = \"data-nested-dialog-open\";\n return DialogPopupDataAttributes;\n}({});","import _formatErrorMessage from \"@base-ui-components/utils/formatErrorMessage\";\nimport * as React from 'react';\nexport const DialogPortalContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== \"production\") DialogPortalContext.displayName = \"DialogPortalContext\";\nexport function useDialogPortalContext() {\n const value = React.useContext(DialogPortalContext);\n if (value === undefined) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'Base UI: <Dialog.Portal> is missing.' : _formatErrorMessage(26));\n }\n return value;\n}","'use client';\n\nimport * as React from 'react';\nimport { FloatingFocusManager } from \"../../floating-ui-react/index.js\";\nimport { useDialogRootContext } from \"../root/DialogRootContext.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nimport { popupStateMapping as baseMapping } from \"../../utils/popupStateMapping.js\";\nimport { transitionStatusMapping } from \"../../utils/stateAttributesMapping.js\";\nimport { DialogPopupCssVars } from \"./DialogPopupCssVars.js\";\nimport { DialogPopupDataAttributes } from \"./DialogPopupDataAttributes.js\";\nimport { useDialogPortalContext } from \"../portal/DialogPortalContext.js\";\nimport { useOpenChangeComplete } from \"../../utils/useOpenChangeComplete.js\";\nimport { COMPOSITE_KEYS } from \"../../composite/composite.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst stateAttributesMapping = {\n ...baseMapping,\n ...transitionStatusMapping,\n nestedDialogOpen(value) {\n return value ? {\n [DialogPopupDataAttributes.nestedDialogOpen]: ''\n } : null;\n }\n};\n\n/**\n * A container for the dialog contents.\n * Renders a `<div>` element.\n *\n * Documentation: [Base UI Dialog](https://base-ui.com/react/components/dialog)\n */\nexport const DialogPopup = /*#__PURE__*/React.forwardRef(function DialogPopup(componentProps, forwardedRef) {\n const {\n className,\n finalFocus,\n initialFocus,\n render,\n ...elementProps\n } = componentProps;\n const {\n store\n } = useDialogRootContext();\n const descriptionElementId = store.useState('descriptionElementId');\n const disablePointerDismissal = store.useState('disablePointerDismissal');\n const floatingRootContext = store.useState('floatingRootContext');\n const rootPopupProps = store.useState('popupProps');\n const modal = store.useState('modal');\n const mounted = store.useState('mounted');\n const nested = store.useState('nested');\n const nestedOpenDialogCount = store.useState('nestedOpenDialogCount');\n const open = store.useState('open');\n const openMethod = store.useState('openMethod');\n const titleElementId = store.useState('titleElementId');\n const transitionStatus = store.useState('transitionStatus');\n const role = store.useState('role');\n useDialogPortalContext();\n useOpenChangeComplete({\n open,\n ref: store.context.popupRef,\n onComplete() {\n if (open) {\n store.context.onOpenChangeComplete?.(true);\n }\n }\n });\n\n // Default initial focus logic:\n // If opened by touch, focus the popup element to prevent the virtual keyboard from opening\n // (this is required for Android specifically as iOS handles this automatically).\n function defaultInitialFocus(interactionType) {\n if (interactionType === 'touch') {\n return store.context.popupRef.current;\n }\n return true;\n }\n const resolvedInitialFocus = initialFocus === undefined ? defaultInitialFocus : initialFocus;\n const nestedDialogOpen = nestedOpenDialogCount > 0;\n const state = React.useMemo(() => ({\n open,\n nested,\n transitionStatus,\n nestedDialogOpen\n }), [open, nested, transitionStatus, nestedDialogOpen]);\n const element = useRenderElement('div', componentProps, {\n state,\n props: [rootPopupProps, {\n 'aria-labelledby': titleElementId ?? undefined,\n 'aria-describedby': descriptionElementId ?? undefined,\n role,\n tabIndex: -1,\n hidden: !mounted,\n onKeyDown(event) {\n if (COMPOSITE_KEYS.has(event.key)) {\n event.stopPropagation();\n }\n },\n style: {\n [DialogPopupCssVars.nestedDialogs]: nestedOpenDialogCount\n }\n }, elementProps],\n ref: [forwardedRef, store.context.popupRef, store.useStateSetter('popupElement')],\n stateAttributesMapping\n });\n return /*#__PURE__*/_jsx(FloatingFocusManager, {\n context: floatingRootContext,\n openInteractionType: openMethod,\n disabled: !mounted,\n closeOnFocusOut: !disablePointerDismissal,\n initialFocus: resolvedInitialFocus,\n returnFocus: finalFocus,\n modal: modal !== false,\n restoreFocus: \"popup\",\n children: element\n });\n});\nif (process.env.NODE_ENV !== \"production\") DialogPopup.displayName = \"DialogPopup\";","import { isReactVersionAtLeast } from \"./reactVersion.js\";\nexport function inertValue(value) {\n if (isReactVersionAtLeast(19)) {\n return value;\n }\n // compatibility with React < 19\n return value ? 'true' : undefined;\n}","import * as React from 'react';\n\n/**\n * @internal\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport const InternalBackdrop = /*#__PURE__*/React.forwardRef(function InternalBackdrop(props, ref) {\n const {\n cutout,\n ...otherProps\n } = props;\n let clipPath;\n if (cutout) {\n const rect = cutout?.getBoundingClientRect();\n clipPath = `polygon(\n 0% 0%,\n 100% 0%,\n 100% 100%,\n 0% 100%,\n 0% 0%,\n ${rect.left}px ${rect.top}px,\n ${rect.left}px ${rect.bottom}px,\n ${rect.right}px ${rect.bottom}px,\n ${rect.right}px ${rect.top}px,\n ${rect.left}px ${rect.top}px\n )`;\n }\n return /*#__PURE__*/_jsx(\"div\", {\n ref: ref,\n role: \"presentation\"\n // Ensures Floating UI's outside press detection runs, as it considers\n // it an element that existed when the popup rendered.\n ,\n \"data-base-ui-inert\": \"\",\n ...otherProps,\n style: {\n position: 'fixed',\n inset: 0,\n userSelect: 'none',\n WebkitUserSelect: 'none',\n clipPath\n }\n });\n});\nif (process.env.NODE_ENV !== \"production\") InternalBackdrop.displayName = \"InternalBackdrop\";","'use client';\n\nimport * as React from 'react';\nimport { inertValue } from '@base-ui-components/utils/inertValue';\nimport { FloatingPortal } from \"../../floating-ui-react/index.js\";\nimport { useDialogRootContext } from \"../root/DialogRootContext.js\";\nimport { DialogPortalContext } from \"./DialogPortalContext.js\";\nimport { InternalBackdrop } from \"../../utils/InternalBackdrop.js\";\n\n/**\n * A portal element that moves the popup to a different part of the DOM.\n * By default, the portal element is appended to `<body>`.\n * Renders a `<div>` element.\n *\n * Documentation: [Base UI Dialog](https://base-ui.com/react/components/dialog)\n */\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nexport const DialogPortal = /*#__PURE__*/React.forwardRef(function DialogPortal(props, forwardedRef) {\n const {\n keepMounted = false,\n ...portalProps\n } = props;\n const {\n store\n } = useDialogRootContext();\n const mounted = store.useState('mounted');\n const modal = store.useState('modal');\n const shouldRender = mounted || keepMounted;\n if (!shouldRender) {\n return null;\n }\n return /*#__PURE__*/_jsx(DialogPortalContext.Provider, {\n value: keepMounted,\n children: /*#__PURE__*/_jsxs(FloatingPortal, {\n ref: forwardedRef,\n ...portalProps,\n children: [mounted && modal === true && /*#__PURE__*/_jsx(InternalBackdrop, {\n ref: store.context.internalBackdropRef,\n inert: inertValue(!open)\n }), props.children]\n })\n });\n});\nif (process.env.NODE_ENV !== \"production\") DialogPortal.displayName = \"DialogPortal\";","'use client';\n\nimport { isOverflowElement } from '@floating-ui/utils/dom';\nimport { isIOS, isWebKit } from \"./detectBrowser.js\";\nimport { ownerDocument, ownerWindow } from \"./owner.js\";\nimport { useIsoLayoutEffect } from \"./useIsoLayoutEffect.js\";\nimport { Timeout } from \"./useTimeout.js\";\nimport { AnimationFrame } from \"./useAnimationFrame.js\";\nimport { NOOP } from \"./empty.js\";\n\n/* eslint-disable lines-between-class-members */\n\nlet originalHtmlStyles = {};\nlet originalBodyStyles = {};\nlet originalHtmlScrollBehavior = '';\nfunction hasInsetScrollbars(referenceElement) {\n if (typeof document === 'undefined') {\n return false;\n }\n const doc = ownerDocument(referenceElement);\n const win = ownerWindow(doc);\n return win.innerWidth - doc.documentElement.clientWidth > 0;\n}\nfunction preventScrollOverlayScrollbars(referenceElement) {\n const doc = ownerDocument(referenceElement);\n const html = doc.documentElement;\n const body = doc.body;\n\n // If an `overflow` style is present on <html>, we need to lock it, because a lock on <body>\n // won't have any effect.\n // But if <body> has an `overflow` style (like `overflow-x: hidden`), we need to lock it\n // instead, as sticky elements shift otherwise.\n const elementToLock = isOverflowElement(html) ? html : body;\n const originalOverflow = elementToLock.style.overflow;\n elementToLock.style.overflow = 'hidden';\n return () => {\n elementToLock.style.overflow = originalOverflow;\n };\n}\nfunction preventScrollInsetScrollbars(referenceElement) {\n const doc = ownerDocument(referenceElement);\n const html = doc.documentElement;\n const body = doc.body;\n const win = ownerWindow(html);\n let scrollTop = 0;\n let scrollLeft = 0;\n const resizeFrame = AnimationFrame.create();\n\n // Handle `scrollbar-gutter` in Chrome when there is no scrollable content.\n const supportsStableScrollbarGutter = typeof CSS !== 'undefined' && CSS.supports?.('scrollbar-gutter', 'stable');\n\n // Pinch-zoom in Safari causes a shift. Just don't lock scroll if there's any pinch-zoom.\n if (isWebKit && (win.visualViewport?.scale ?? 1) !== 1) {\n return () => {};\n }\n function lockScroll() {\n /* DOM reads: */\n\n const htmlStyles = win.getComputedStyle(html);\n const bodyStyles = win.getComputedStyle(body);\n const htmlScrollbarGutterValue = htmlStyles.scrollbarGutter || '';\n const hasBothEdges = htmlScrollbarGutterValue.includes('both-edges');\n const scrollbarGutterValue = hasBothEdges ? 'stable both-edges' : 'stable';\n scrollTop = html.scrollTop;\n scrollLeft = html.scrollLeft;\n originalHtmlStyles = {\n scrollbarGutter: html.style.scrollbarGutter,\n overflowY: html.style.overflowY,\n overflowX: html.style.overflowX\n };\n originalHtmlScrollBehavior = html.style.scrollBehavior;\n originalBodyStyles = {\n position: body.style.position,\n height: body.style.height,\n width: body.style.width,\n boxSizing: body.style.boxSizing,\n overflowY: body.style.overflowY,\n overflowX: body.style.overflowX,\n scrollBehavior: body.style.scrollBehavior\n };\n const isScrollableY = html.scrollHeight > html.clientHeight;\n const isScrollableX = html.scrollWidth > html.clientWidth;\n const hasConstantOverflowY = htmlStyles.overflowY === 'scroll' || bodyStyles.overflowY === 'scroll';\n const hasConstantOverflowX = htmlStyles.overflowX === 'scroll' || bodyStyles.overflowX === 'scroll';\n\n // Values can be negative in Firefox\n const scrollbarWidth = Math.max(0, win.innerWidth - html.clientWidth);\n const scrollbarHeight = Math.max(0, win.innerHeight - html.clientHeight);\n\n // Avoid shift due to the default <body> margin. This does cause elements to be clipped\n // with whitespace. Warn if <body> has margins?\n const marginY = parseFloat(bodyStyles.marginTop) + parseFloat(bodyStyles.marginBottom);\n const marginX = parseFloat(bodyStyles.marginLeft) + parseFloat(bodyStyles.marginRight);\n const elementToLock = isOverflowElement(html) ? html : body;\n\n /*\n * DOM writes:\n * Do not read the DOM past this point!\n */\n\n if (supportsStableScrollbarGutter) {\n html.style.scrollbarGutter = scrollbarGutterValue;\n elementToLock.style.overflowY = 'hidden';\n elementToLock.style.overflowX = 'hidden';\n return;\n }\n Object.assign(html.style, {\n scrollbarGutter: scrollbarGutterValue,\n overflowY: 'hidden',\n overflowX: 'hidden'\n });\n if (isScrollableY || hasConstantOverflowY) {\n html.style.overflowY = 'scroll';\n }\n if (isScrollableX || hasConstantOverflowX) {\n html.style.overflowX = 'scroll';\n }\n Object.assign(body.style, {\n position: 'relative',\n height: marginY || scrollbarHeight ? `calc(100dvh - ${marginY + scrollbarHeight}px)` : '100dvh',\n width: marginX || scrollbarWidth ? `calc(100vw - ${marginX + scrollbarWidth}px)` : '100vw',\n boxSizing: 'border-box',\n overflow: 'hidden',\n scrollBehavior: 'unset'\n });\n body.scrollTop = scrollTop;\n body.scrollLeft = scrollLeft;\n html.setAttribute('data-base-ui-scroll-locked', '');\n html.style.scrollBehavior = 'unset';\n }\n function cleanup() {\n Object.assign(html.style, originalHtmlStyles);\n Object.assign(body.style, originalBodyStyles);\n if (!supportsStableScrollbarGutter) {\n html.scrollTop = scrollTop;\n html.scrollLeft = scrollLeft;\n html.removeAttribute('data-base-ui-scroll-locked');\n html.style.scrollBehavior = originalHtmlScrollBehavior;\n }\n }\n function handleResize() {\n cleanup();\n resizeFrame.request(lockScroll);\n }\n lockScroll();\n win.addEventListener('resize', handleResize);\n return () => {\n resizeFrame.cancel();\n cleanup();\n // Sometimes this cleanup can be run after test teardown\n // because it is called in a `setTimeout(fn, 0)`,\n // in which case `removeEventListener` wouldn't be available,\n // so we check for it to avoid test failures.\n if (typeof win.removeEventListener === 'function') {\n win.removeEventListener('resize', handleResize);\n }\n };\n}\nclass ScrollLocker {\n lockCount = 0;\n restore = null;\n timeoutLock = Timeout.create();\n timeoutUnlock = Timeout.create();\n acquire(referenceElement) {\n this.lockCount += 1;\n if (this.lockCount === 1 && this.restore === null) {\n this.timeoutLock.start(0, () => this.lock(referenceElement));\n }\n return this.release;\n }\n release = () => {\n this.lockCount -= 1;\n if (this.lockCount === 0 && this.restore) {\n this.timeoutUnlock.start(0, this.unlock);\n }\n };\n unlock = () => {\n if (this.lockCount === 0 && this.restore) {\n this.restore?.();\n this.restore = null;\n }\n };\n lock(referenceElement) {\n if (this.lockCount === 0 || this.restore !== null) {\n return;\n }\n const doc = ownerDocument(referenceElement);\n const html = doc.documentElement;\n const htmlOverflowY = ownerWindow(html).getComputedStyle(html).overflowY;\n\n // If the site author already hid overflow on <html>, respect it and bail out.\n if (htmlOverflowY === 'hidden' || htmlOverflowY === 'clip') {\n this.restore = NOOP;\n return;\n }\n const hasOverlayScrollbars = isIOS || !hasInsetScrollbars(referenceElement);\n\n // On iOS, scroll locking does not work if the navbar is collapsed. Due to numerous\n // side effects and bugs that arise on iOS, it must be researched extensively before\n // being enabled to ensure it doesn't cause the following issues:\n // - Textboxes must scroll into view when focused, nor cause a glitchy scroll animation.\n // - The navbar must not force itself into view and cause layout shift.\n // - Scroll containers must not flicker upon closing a popup when it has an exit animation.\n this.restore = hasOverlayScrollbars ? preventScrollOverlayScrollbars(referenceElement) : preventScrollInsetScrollbars(referenceElement);\n }\n}\nconst SCROLL_LOCKER = new ScrollLocker();\n\n/**\n * Locks the scroll of the document when enabled.\n *\n * @param enabled - Whether to enable the scroll lock.\n * @param referenceElement - Element to use as a reference for lock calculations.\n */\nexport function useScrollLock(enabled = true, referenceElement = null) {\n useIsoLayoutEffect(() => {\n if (!enabled) {\n return undefined;\n }\n return SCROLL_LOCKER.acquire(referenceElement);\n }, [enabled, referenceElement]);\n}","import * as React from 'react';\n/**\n * Provides a cross-browser way to determine the type of the pointer used to click.\n * Safari and Firefox do not provide the PointerEvent to the click handler (they use MouseEvent) yet.\n * Additionally, this implementation detects if the click was triggered by the keyboard.\n *\n * @param handler The function to be called when the button is clicked. The first parameter is the original event and the second parameter is the pointer type.\n */\nexport function useEnhancedClickHandler(handler) {\n const lastClickInteractionTypeRef = React.useRef('');\n const handlePointerDown = React.useCallback(event => {\n if (event.defaultPrevented) {\n return;\n }\n lastClickInteractionTypeRef.current = event.pointerType;\n handler(event, event.pointerType);\n }, [handler]);\n const handleClick = React.useCallback(event => {\n // event.detail has the number of clicks performed on the element. 0 means it was triggered by the keyboard.\n if (event.detail === 0) {\n handler(event, 'keyboard');\n return;\n }\n if ('pointerType' in event) {\n // Chrome and Edge correctly use PointerEvent\n handler(event, event.pointerType);\n }\n handler(event, lastClickInteractionTypeRef.current);\n lastClickInteractionTypeRef.current = '';\n }, [handler]);\n return {\n onClick: handleClick,\n onPointerDown: handlePointerDown\n };\n}","'use client';\n\nimport * as React from 'react';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useEnhancedClickHandler } from '@base-ui-components/utils/useEnhancedClickHandler';\n\n/**\n * Determines the interaction type (keyboard, mouse, touch, etc.) that opened the component.\n *\n * @param open The open state of the component.\n */\nexport function useOpenInteractionType(open) {\n const [openMethod, setOpenMethod] = React.useState(null);\n const handleTriggerClick = useStableCallback((_, interactionType) => {\n if (!open) {\n setOpenMethod(interactionType);\n }\n });\n const reset = React.useCallback(() => {\n setOpenMethod(null);\n }, []);\n const {\n onClick,\n onPointerDown\n } = useEnhancedClickHandler(handleTriggerClick);\n return React.useMemo(() => ({\n openMethod,\n reset,\n triggerProps: {\n onClick,\n onPointerDown\n }\n }), [openMethod, reset, onClick, onPointerDown]);\n}","'use client';\n\nimport * as React from 'react';\nimport { useStableCallback } from '@base-ui-components/utils/useStableCallback';\nimport { useScrollLock } from '@base-ui-components/utils/useScrollLock';\nimport { useDismiss, useInteractions, useRole, useSyncedFloatingRootContext } from \"../../floating-ui-react/index.js\";\nimport { contains, getTarget } from \"../../floating-ui-react/utils.js\";\nimport { useOpenInteractionType } from \"../../utils/useOpenInteractionType.js\";\nimport { createChangeEventDetails } from \"../../utils/createBaseUIEventDetails.js\";\nimport { REASONS } from \"../../utils/reasons.js\";\nimport { useImplicitActiveTrigger, useOpenStateTransitions } from \"../../utils/popups/index.js\";\nexport function useDialogRoot(params) {\n const {\n store,\n parentContext,\n actionsRef\n } = params;\n const open = store.useState('open');\n const disablePointerDismissal = store.useState('disablePointerDismissal');\n const modal = store.useState('modal');\n const popupElement = store.useState('popupElement');\n const {\n openMethod,\n triggerProps,\n reset: resetOpenInteractionType\n } = useOpenInteractionType(open);\n useImplicitActiveTrigger(store);\n const {\n forceUnmount\n } = useOpenStateTransitions(open, store, () => {\n resetOpenInteractionType();\n });\n const createDialogEventDetails = useStableCallback(reason => {\n const details = createChangeEventDetails(reason);\n details.preventUnmountOnClose = () => {\n store.set('preventUnmountingOnClose', true);\n };\n return details;\n });\n const handleImperativeClose = React.useCallback(() => {\n store.setOpen(false, createDialogEventDetails(REASONS.imperativeAction));\n }, [store, createDialogEventDetails]);\n React.useImperativeHandle(actionsRef, () => ({\n unmount: forceUnmount,\n close: handleImperativeClose\n }), [forceUnmount, handleImperativeClose]);\n const floatingRootContext = useSyncedFloatingRootContext({\n popupStore: store,\n onOpenChange: store.setOpen,\n treatPopupAsFloatingElement: true,\n noEmit: true\n });\n const [ownNestedOpenDialogs, setOwnNestedOpenDialogs] = React.useState(0);\n const isTopmost = ownNestedOpenDialogs === 0;\n const role = useRole(floatingRootContext);\n const dismiss = useDismiss(floatingRootContext, {\n outsidePressEvent() {\n if (store.context.internalBackdropRef.current || store.context.backdropRef.current) {\n return 'intentional';\n }\n // Ensure `aria-hidden` on outside elements is removed immediately\n // on outside press when trapping focus.\n return {\n mouse: modal === 'trap-focus' ? 'sloppy' : 'intentional',\n touch: 'sloppy'\n };\n },\n outsidePress(event) {\n // For mouse events, only accept left button (button 0)\n // For touch events, a single touch is equivalent to left button\n if ('button' in event && event.button !== 0) {\n return false;\n }\n if ('touches' in event && event.touches.length !== 1) {\n return false;\n }\n const target = getTarget(event);\n if (isTopmost && !disablePointerDismissal) {\n const eventTarget = target;\n // Only close if the click occurred on the dialog's owning backdrop.\n // This supports multiple modal dialogs that aren't nested in the React tree:\n // https://github.com/mui/base-ui/issues/1320\n if (modal) {\n return store.context.internalBackdropRef.current || store.context.backdropRef.current ? store.context.internalBackdropRef.current === eventTarget || store.context.backdropRef.current === eventTarget || contains(eventTarget, popupElement) && !eventTarget?.hasAttribute('data-base-ui-portal') : true;\n }\n return true;\n }\n return false;\n },\n escapeKey: isTopmost\n });\n useScrollLock(open && modal === true, popupElement);\n const {\n getReferenceProps,\n getFloatingProps,\n getTriggerProps\n } = useInteractions([role, dismiss]);\n\n // Listen for nested open/close events on this store to maintain the count\n store.useContextCallback('onNestedDialogOpen', ownChildrenCount => {\n setOwnNestedOpenDialogs(ownChildrenCount + 1);\n });\n store.useContextCallback('onNestedDialogClose', () => {\n setOwnNestedOpenDialogs(0);\n });\n\n // Notify parent of our open/close state using parent callbacks, if any\n React.useEffect(() => {\n if (parentContext?.onNestedDialogOpen && open) {\n parentContext.onNestedDialogOpen(ownNestedOpenDialogs);\n }\n if (parentContext?.onNestedDialogClose && !open) {\n parentContext.onNestedDialogClose();\n }\n return () => {\n if (parentContext?.onNestedDialogClose && open) {\n parentContext.onNestedDialogClose();\n }\n };\n }, [open, parentContext, ownNestedOpenDialogs]);\n const activeTriggerProps = React.useMemo(() => getReferenceProps(triggerProps), [getReferenceProps, triggerProps]);\n const inactiveTriggerProps = React.useMemo(() => getTriggerProps(triggerProps), [getTriggerProps, triggerProps]);\n const popupProps = React.useMemo(() => getFloatingProps(), [getFloatingProps]);\n store.useSyncedValues({\n openMethod,\n activeTriggerProps,\n inactiveTriggerProps,\n popupProps,\n floatingRootContext,\n nestedOpenDialogCount: ownNestedOpenDialogs\n });\n}","import * as React from 'react';\nimport { createSelector, ReactStore } from '@base-ui-components/utils/store';\nimport { createInitialPopupStoreState, popupStoreSelectors, PopupTriggerMap } from \"../../utils/popups/index.js\";\nconst selectors = {\n ...popupStoreSelectors,\n modal: createSelector(state => state.modal),\n nested: createSelector(state => state.nested),\n nestedOpenDialogCount: createSelector(state => state.nestedOpenDialogCount),\n disablePointerDismissal: createSelector(state => state.disablePointerDismissal),\n openMethod: createSelector(state => state.openMethod),\n descriptionElementId: createSelector(state => state.descriptionElementId),\n titleElementId: createSelector(state => state.titleElementId),\n viewportElement: createSelector(state => state.viewportElement),\n role: createSelector(state => state.role)\n};\nexport class DialogStore extends ReactStore {\n constructor(initialState) {\n super(createInitialState(initialState), {\n popupRef: /*#__PURE__*/React.createRef(),\n backdropRef: /*#__PURE__*/React.createRef(),\n internalBackdropRef: /*#__PURE__*/React.createRef(),\n triggerElements: new PopupTriggerMap(),\n onOpenChange: undefined,\n onOpenChangeComplete: undefined\n }, selectors);\n }\n setOpen = (nextOpen, eventDetails) => {\n eventDetails.preventUnmountOnClose = () => {\n this.set('preventUnmountingOnClose', true);\n };\n if (!nextOpen && eventDetails.trigger == null && this.state.activeTriggerId != null) {\n // When closing the dialog, pass the old trigger to the onOpenChange event\n // so it's not reset too early (potentially causing focus issues in controlled scenarios).\n eventDetails.trigger = this.state.activeTriggerElement ?? undefined;\n }\n this.context.onOpenChange?.(nextOpen, eventDetails);\n if (eventDetails.isCanceled) {\n return;\n }\n const details = {\n open: nextOpen,\n nativeEvent: eventDetails.event,\n reason: eventDetails.reason,\n nested: this.state.nested\n };\n this.state.floatingRootContext.context.events?.emit('openchange', details);\n const updatedState = {\n open: nextOpen\n };\n\n // If a popup is closing, the `trigger` may be null.\n // We want to keep the previous value so that exit animations are played and focus is returned correctly.\n const newTriggerId = eventDetails.trigger?.id ?? null;\n if (newTriggerId || nextOpen) {\n updatedState.activeTriggerId = newTriggerId;\n updatedState.activeTriggerElement = eventDetails.trigger ?? null;\n }\n this.update(updatedState);\n };\n}\nfunction createInitialState(initialState = {}) {\n return {\n ...createInitialPopupStoreState(),\n modal: true,\n disablePointerDismissal: false,\n popupElement: null,\n viewportElement: null,\n descriptionElementId: undefined,\n titleElementId: undefined,\n openMethod: null,\n nested: false,\n nestedOpenDialogCount: 0,\n role: 'dialog',\n ...initialState\n };\n}","'use client';\n\nimport * as React from 'react';\nimport { useRefWithInit } from '@base-ui-components/utils/useRefWithInit';\nimport { useDialogRoot } from \"./useDialogRoot.js\";\nimport { DialogRootContext, useDialogRootContext } from \"./DialogRootContext.js\";\nimport { DialogStore } from \"../store/DialogStore.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\n/**\n * Groups all parts of the dialog.\n * Doesn’t render its own HTML element.\n *\n * Documentation: [Base UI Dialog](https://base-ui.com/react/components/dialog)\n */\nexport function DialogRoot(props) {\n const {\n children,\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n onOpenChangeComplete,\n disablePointerDismissal = false,\n modal = true,\n actionsRef,\n handle,\n triggerId: triggerIdProp,\n defaultTriggerId: defaultTriggerIdProp = null\n } = props;\n const parentDialogRootContext = useDialogRootContext(true);\n const nested = Boolean(parentDialogRootContext);\n const store = useRefWithInit(() => {\n return handle?.store ?? new DialogStore({\n open: openProp ?? defaultOpen,\n activeTriggerId: triggerIdProp !== undefined ? triggerIdProp : defaultTriggerIdProp,\n modal,\n disablePointerDismissal,\n nested\n });\n }).current;\n store.useControlledProp('open', openProp, defaultOpen);\n store.useControlledProp('activeTriggerId', triggerIdProp, defaultTriggerIdProp);\n store.useSyncedValues({\n disablePointerDismissal,\n nested,\n modal\n });\n store.useContextCallback('onOpenChange', onOpenChange);\n store.useContextCallback('onOpenChangeComplete', onOpenChangeComplete);\n const payload = store.useState('payload');\n useDialogRoot({\n store,\n actionsRef,\n parentContext: parentDialogRootContext?.store.context,\n onOpenChange,\n triggerIdProp\n });\n const contextValue = React.useMemo(() => ({\n store\n }), [store]);\n return /*#__PURE__*/_jsx(DialogRootContext.Provider, {\n value: contextValue,\n children: typeof children === 'function' ? children({\n payload\n }) : children\n });\n}","'use client';\n\nimport * as React from 'react';\nimport { useDialogRootContext } from \"../root/DialogRootContext.js\";\nimport { useRenderElement } from \"../../utils/useRenderElement.js\";\nimport { useBaseUiId } from \"../../utils/useBaseUiId.js\";\n/**\n * A heading that labels the dialog.\n * Renders an `<h2>` element.\n *\n * Documentation: [Base UI Dialog](https://base-ui.com/react/components/dialog)\n */\nexport const DialogTitle = /*#__PURE__*/React.forwardRef(function DialogTitle(componentProps, forwardedRef) {\n const {\n render,\n className,\n id: idProp,\n ...elementProps\n } = componentProps;\n const {\n store\n } = useDialogRootContext();\n const id = useBaseUiId(idProp);\n store.useSyncedValueWithCleanup('titleElementId', id);\n return useRenderElement('h2', componentProps, {\n ref: forwardedRef,\n props: [{\n id\n }, elementProps]\n });\n});\nif (process.env.NODE_ENV !== \"production\") DialogTitle.displayName = \"DialogTitle\";","import { Dialog } from \"@base-ui-components/react/dialog\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n// Context for mobile menu state\nconst NavbarContext = React.createContext<{\n\tisMobileMenuOpen: boolean;\n\tsetIsMobileMenuOpen: (open: boolean) => void;\n}>({\n\tisMobileMenuOpen: false,\n\tsetIsMobileMenuOpen: () => {},\n});\n\nexport interface NavbarProps extends React.HTMLAttributes<HTMLElement> {}\n\n/**\n * Main navigation bar container.\n * Provides responsive layout for brand, links, and actions.\n */\nconst Navbar = React.forwardRef<HTMLElement, NavbarProps>(\n\t({ className, children, ...props }, ref) => {\n\t\tconst [isMobileMenuOpen, setIsMobileMenuOpen] = React.useState(false);\n\t\tconst navRef = React.useRef<HTMLElement>(null);\n\n\t\t// Set navbar height CSS variable for mobile menu positioning\n\t\tReact.useEffect(() => {\n\t\t\tconst updateHeight = () => {\n\t\t\t\tif (navRef.current) {\n\t\t\t\t\tconst height = navRef.current.offsetHeight;\n\t\t\t\t\tdocument.documentElement.style.setProperty(\n\t\t\t\t\t\t\"--navbar-height\",\n\t\t\t\t\t\t`${height}px`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tupdateHeight();\n\t\t\twindow.addEventListener(\"resize\", updateHeight);\n\t\t\treturn () => window.removeEventListener(\"resize\", updateHeight);\n\t\t}, []);\n\n\t\t// Merge refs\n\t\tconst mergedRef = React.useCallback(\n\t\t\t(node: HTMLElement | null) => {\n\t\t\t\t(navRef as React.MutableRefObject<HTMLElement | null>).current = node;\n\t\t\t\tif (typeof ref === \"function\") {\n\t\t\t\t\tref(node);\n\t\t\t\t} else if (ref) {\n\t\t\t\t\tref.current = node;\n\t\t\t\t}\n\t\t\t},\n\t\t\t[ref],\n\t\t);\n\n\t\treturn (\n\t\t\t<NavbarContext.Provider value={{ isMobileMenuOpen, setIsMobileMenuOpen }}>\n\t\t\t\t<nav\n\t\t\t\t\tref={mergedRef}\n\t\t\t\t\tclassName={cn(\"relative z-50 w-full bg-gray-50\", className)}\n\t\t\t\t\t{...props}\n\t\t\t\t>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\"flex w-full items-center justify-between\",\n\t\t\t\t\t\t\t// Mobile\n\t\t\t\t\t\t\t\"px-spacing-20 py-spacing-8\",\n\t\t\t\t\t\t\t// Tablet\n\t\t\t\t\t\t\t\"md:px-spacing-32 md:py-spacing-16\",\n\t\t\t\t\t\t\t// Desktop\n\t\t\t\t\t\t\t\"xl:px-spacing-32 xl:py-spacing-24\",\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t{children}\n\t\t\t\t\t</div>\n\t\t\t\t</nav>\n\t\t\t</NavbarContext.Provider>\n\t\t);\n\t},\n);\nNavbar.displayName = \"Navbar\";\n\nexport interface NavbarBrandProps extends React.HTMLAttributes<HTMLDivElement> {\n\tasChild?: boolean;\n}\n\n/**\n * Brand/logo area of the navbar.\n * Use asChild to render as a link.\n */\nconst NavbarBrand = React.forwardRef<HTMLDivElement, NavbarBrandProps>(\n\t({ className, asChild = false, ...props }, ref) => {\n\t\tconst Comp = asChild ? Slot : \"div\";\n\t\treturn <Comp ref={ref} className={cn(\"shrink-0\", className)} {...props} />;\n\t},\n);\nNavbarBrand.displayName = \"NavbarBrand\";\n\nexport interface NavbarLinksProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Container for navigation links.\n * Centers links on desktop, hidden on mobile (use NavbarMobileMenu instead).\n */\nconst NavbarLinks = React.forwardRef<HTMLDivElement, NavbarLinksProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"hidden items-center gap-spacing-40 md:flex\", className)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nNavbarLinks.displayName = \"NavbarLinks\";\n\nexport interface NavbarLinkProps\n\textends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n\tasChild?: boolean;\n\tactive?: boolean;\n}\n\n/**\n * Individual navigation link.\n * Use asChild to render with a router Link component.\n */\nconst NavbarLink = React.forwardRef<HTMLAnchorElement, NavbarLinkProps>(\n\t({ className, asChild = false, active, ...props }, ref) => {\n\t\tconst Comp = asChild ? Slot : \"a\";\n\t\treturn (\n\t\t\t<Comp\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"typography-brand-medium-link-small text-gray-900 transition-colors hover:text-gray-700\",\n\t\t\t\t\tactive && \"text-gray-1100\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nNavbarLink.displayName = \"NavbarLink\";\n\nexport interface NavbarActionsProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Container for navbar action items (search, menu button, etc).\n */\nconst NavbarActions = React.forwardRef<HTMLDivElement, NavbarActionsProps>(\n\t({ className, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\"flex items-center gap-spacing-8\", className)}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t},\n);\nNavbarActions.displayName = \"NavbarActions\";\n\nexport interface NavbarMobileMenuProps\n\textends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Mobile menu container that displays navigation links on mobile devices.\n * Hidden on desktop (md and above). Should be used with NavbarMobileMenuButton.\n * Built on Base UI Dialog for accessibility (focus trap, escape key, click-outside).\n */\nconst NavbarMobileMenu = React.forwardRef<\n\tHTMLDivElement,\n\tNavbarMobileMenuProps\n>(({ className, children, ...props }, ref) => {\n\tconst { isMobileMenuOpen, setIsMobileMenuOpen } =\n\t\tReact.useContext(NavbarContext);\n\n\treturn (\n\t\t<Dialog.Root open={isMobileMenuOpen} onOpenChange={setIsMobileMenuOpen}>\n\t\t\t<Dialog.Portal>\n\t\t\t\t<Dialog.Popup\n\t\t\t\t\tref={ref}\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"fixed inset-0 z-50 bg-gray-50 md:hidden\",\n\t\t\t\t\t\t// Position below navbar\n\t\t\t\t\t\t\"pt-[calc(var(--navbar-height,60px)+1px)]\",\n\t\t\t\t\t\t// Smooth transition\n\t\t\t\t\t\t\"transition-opacity duration-200\",\n\t\t\t\t\t\tclassName,\n\t\t\t\t\t)}\n\t\t\t\t\t{...props}\n\t\t\t\t>\n\t\t\t\t\t<Dialog.Title className=\"sr-only\">Navigation menu</Dialog.Title>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\"flex flex-col\",\n\t\t\t\t\t\t\t// Padding matching navbar\n\t\t\t\t\t\t\t\"px-spacing-20 py-spacing-16\",\n\t\t\t\t\t\t\t// Gap between links\n\t\t\t\t\t\t\t\"gap-spacing-8\",\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t{children}\n\t\t\t\t\t</div>\n\t\t\t\t</Dialog.Popup>\n\t\t\t</Dialog.Portal>\n\t\t</Dialog.Root>\n\t);\n});\nNavbarMobileMenu.displayName = \"NavbarMobileMenu\";\n\nexport interface NavbarMobileMenuButtonProps\n\textends React.ButtonHTMLAttributes<HTMLButtonElement> {\n\tasChild?: boolean;\n}\n\n/**\n * Button to toggle the mobile menu.\n * Should be placed in NavbarActions on mobile.\n * Use asChild to render as a custom button component (e.g., IconButton).\n */\nconst NavbarMobileMenuButton = React.forwardRef<\n\tHTMLButtonElement,\n\tNavbarMobileMenuButtonProps\n>(({ className, asChild = false, children, ...props }, ref) => {\n\tconst { isMobileMenuOpen, setIsMobileMenuOpen } =\n\t\tReact.useContext(NavbarContext);\n\n\tconst handleClick = () => {\n\t\tsetIsMobileMenuOpen(!isMobileMenuOpen);\n\t};\n\n\tif (asChild) {\n\t\treturn (\n\t\t\t<Slot\n\t\t\t\tref={ref}\n\t\t\t\taria-label=\"Toggle navigation menu\"\n\t\t\t\taria-expanded={isMobileMenuOpen}\n\t\t\t\taria-controls=\"navbar-mobile-menu\"\n\t\t\t\tonClick={handleClick}\n\t\t\t\tclassName={className}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</Slot>\n\t\t);\n\t}\n\n\treturn (\n\t\t<button\n\t\t\tref={ref}\n\t\t\ttype=\"button\"\n\t\t\taria-label=\"Toggle navigation menu\"\n\t\t\taria-expanded={isMobileMenuOpen}\n\t\t\taria-controls=\"navbar-mobile-menu\"\n\t\t\tonClick={handleClick}\n\t\t\tclassName={cn(\"transition-colors\", className)}\n\t\t\t{...props}\n\t\t>\n\t\t\t{children}\n\t\t</button>\n\t);\n});\nNavbarMobileMenuButton.displayName = \"NavbarMobileMenuButton\";\n\nexport interface NavbarMobileMenuLinkProps\n\textends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n\tasChild?: boolean;\n\tactive?: boolean;\n}\n\n/**\n * Navigation link for the mobile menu.\n * Automatically closes the mobile menu when clicked.\n * Use asChild to render with a router Link component.\n */\nconst NavbarMobileMenuLink = React.forwardRef<\n\tHTMLAnchorElement,\n\tNavbarMobileMenuLinkProps\n>(({ className, asChild = false, active, onClick, ...props }, ref) => {\n\tconst { setIsMobileMenuOpen } = React.useContext(NavbarContext);\n\tconst Comp = asChild ? Slot : \"a\";\n\n\tconst handleClick = (event: React.MouseEvent<HTMLAnchorElement>) => {\n\t\tsetIsMobileMenuOpen(false);\n\t\tonClick?.(event);\n\t};\n\n\treturn (\n\t\t<Comp\n\t\t\tref={ref}\n\t\t\tclassName={cn(\n\t\t\t\t\"typography-brand-medium-link-medium text-gray-900 transition-colors hover:text-gray-700\",\n\t\t\t\t\"py-spacing-8\",\n\t\t\t\tactive && \"text-gray-1100\",\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\tonClick={handleClick}\n\t\t\t{...props}\n\t\t/>\n\t);\n});\nNavbarMobileMenuLink.displayName = \"NavbarMobileMenuLink\";\n\nexport {\n\tNavbar,\n\tNavbarBrand,\n\tNavbarLinks,\n\tNavbarLink,\n\tNavbarActions,\n\tNavbarMobileMenu,\n\tNavbarMobileMenuButton,\n\tNavbarMobileMenuLink,\n};\n","import * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\nexport interface USGovBannerProps extends React.HTMLAttributes<HTMLDivElement> {\n\t/**\n\t * Custom flag icon element. Defaults to a US flag SVG.\n\t */\n\tflagIcon?: React.ReactNode;\n\t/**\n\t * Banner text content\n\t * @default \"An official website of the United States government\"\n\t */\n\ttext?: string;\n}\n\n/**\n * US Government official website banner.\n * Displays the official government website notice with flag icon.\n * Commonly placed at the very top of government websites.\n */\nconst USGovBanner = React.forwardRef<HTMLDivElement, USGovBannerProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\tflagIcon,\n\t\t\ttext = \"An official website of the United States government\",\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex w-full items-center justify-center bg-gray-50 py-spacing-12\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t<div className=\"flex items-center gap-spacing-8 opacity-70\">\n\t\t\t\t\t{flagIcon ?? <DefaultUSFlag />}\n\t\t\t\t\t<p className=\"text-[11px] leading-[13px] tracking-[0.17px] text-gray-900\">\n\t\t\t\t\t\t{text}\n\t\t\t\t\t</p>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t},\n);\nUSGovBanner.displayName = \"USGovBanner\";\n\nfunction DefaultUSFlag() {\n\treturn (\n\t\t<svg\n\t\t\twidth=\"16\"\n\t\t\theight=\"12\"\n\t\t\tviewBox=\"0 0 16 12\"\n\t\t\tfill=\"none\"\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\n\t\t\taria-hidden=\"true\"\n\t\t>\n\t\t\t<path d=\"M0 0H16V12H0V0Z\" fill=\"#212121\" fillOpacity=\"0.1\" />\n\t\t\t<path\n\t\t\t\td=\"M0 0H16V0.923077H0V0ZM0 1.84615H16V2.76923H0V1.84615ZM0 3.69231H16V4.61538H0V3.69231ZM0 5.53846H16V6.46154H0V5.53846ZM0 7.38462H16V8.30769H0V7.38462ZM0 9.23077H16V10.1538H0V9.23077ZM0 11.0769H16V12H0V11.0769Z\"\n\t\t\t\tfill=\"#BF0A30\"\n\t\t\t\tfillOpacity=\"0.8\"\n\t\t\t/>\n\t\t\t<path d=\"M0 0H8V6.46154H0V0Z\" fill=\"#002868\" fillOpacity=\"0.8\" />\n\t\t</svg>\n\t);\n}\n\nexport { USGovBanner };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * Banner component based on Figma BaseKit / Banners\n *\n * Used to surface short, important updates or a single key action\n * without disrupting the main page content.\n *\n * Responsive behavior using 24-column grid:\n * - Mobile (sm): Stacked layout, 20px horizontal / 32px vertical padding\n * - Tablet (md): Horizontal layout, 56px padding\n * - Desktop (lg): Horizontal layout, 72px padding\n *\n * Must be placed inside a `grid-container`. Uses `col-full` to span all columns.\n */\nconst bannerVariants = cva(\n\t[\n\t\t// Grid alignment - full width\n\t\t\"col-full\",\n\t\t// Responsive padding: mobile -> tablet -> desktop\n\t\t\"px-spacing-20 py-spacing-32\",\n\t\t\"md:p-spacing-56\",\n\t\t\"lg:px-spacing-72 lg:pb-spacing-72 lg:pt-0\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\ttheme: {\n\t\t\t\tlight: \"bg-gray-50\",\n\t\t\t\tdark: \"bg-gray-1200\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\ttheme: \"light\",\n\t\t},\n\t},\n);\n\nexport interface BannerProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof bannerVariants> {\n\t/**\n\t * The heading text displayed in the banner\n\t */\n\theading: string;\n\t/**\n\t * The description text displayed below the heading\n\t */\n\tdescription: string;\n\t/**\n\t * Optional action element (typically a Button component)\n\t */\n\taction?: React.ReactNode;\n}\n\n/**\n * Banner component for surfacing important updates or CTAs.\n *\n * Uses the 24-column grid system - must be placed inside a `grid-container`.\n * Spans full width with `col-full`.\n *\n * Responsive across breakpoints:\n * - Mobile: Stacked layout with smaller padding\n * - Tablet: Horizontal layout with medium padding\n * - Desktop: Horizontal layout with larger padding\n *\n * @example\n * ```tsx\n * <div className=\"grid-container\">\n * <Banner\n * heading=\"Important Update\"\n * description=\"Check out our new features.\"\n * action={<Button>Learn More</Button>}\n * />\n * </div>\n *\n * // Dark theme\n * <Banner\n * theme=\"dark\"\n * heading=\"Still Have Questions?\"\n * description=\"Contact us at support@example.com\"\n * action={<Button variant=\"secondary\">Email Us</Button>}\n * />\n * ```\n */\nconst Banner = React.forwardRef<HTMLElement, BannerProps>(\n\t({ className, theme, heading, description, action, ...props }, ref) => {\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(bannerVariants({ theme }), className)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Inner container with border-top for dark theme */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"flex flex-col md:flex-row gap-spacing-20 items-start md:items-center md:justify-between\",\n\t\t\t\t\t\ttheme === \"dark\" && \"border-t border-gray-700 py-spacing-36\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{/* Copy section */}\n\t\t\t\t\t<div className=\"flex flex-col gap-spacing-6 items-start\">\n\t\t\t\t\t\t<h2\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"typography-subheading-small\",\n\t\t\t\t\t\t\t\ttheme === \"dark\" ? \"text-gray-100\" : \"text-gray-900\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{heading}\n\t\t\t\t\t\t</h2>\n\t\t\t\t\t\t<p\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"typography-body-small\",\n\t\t\t\t\t\t\t\ttheme === \"dark\" ? \"text-gray-500\" : \"text-gray-800\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{description}\n\t\t\t\t\t\t</p>\n\t\t\t\t\t</div>\n\t\t\t\t\t{/* Action slot */}\n\t\t\t\t\t{action}\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nBanner.displayName = \"Banner\";\n\nexport { Banner, bannerVariants };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * CardGrid component for displaying cards in a responsive grid layout\n *\n * Variants:\n * - A: 3 columns on desktop, 2 on tablet, 1 on mobile\n * - B: 2 columns on desktop/tablet, 1 on mobile\n *\n * Uses the 24-column grid system with grid-container as root.\n */\nconst cardGridVariants = cva(\n\t// Base styles - grid-container for proper grid context\n\t[\n\t\t\"grid-container\",\n\t\t// Small (mobile): 72px y padding\n\t\t\"py-spacing-72\",\n\t\t// Large (desktop): 128px y padding\n\t\t\"lg:py-spacing-128\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\tA: \"\",\n\t\t\t\tB: \"\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"A\",\n\t\t},\n\t},\n);\n\nexport interface CardGridProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof cardGridVariants> {\n\t/**\n\t * The title text displayed above the cards\n\t */\n\ttitle: string;\n\t/**\n\t * The card elements to display in the grid\n\t */\n\tcards: React.ReactNode[];\n}\n\n/**\n * CardGrid component for displaying cards in a responsive grid layout.\n *\n * Uses the 24-column grid system with grid-container as root.\n *\n * Layout (Variant A):\n * - Mobile (sm): Single column, py-72\n * - Tablet (md): 2 columns, gap-56 between title and cards, gap-y-20 between cards\n * - Desktop (lg+): 3 columns, py-128, gap-64 between title and cards, gap-y-20 between cards\n *\n * Layout (Variant B):\n * - Mobile (sm): Single column, py-72\n * - Tablet (md): 2 columns, gap-56 between title and cards, gap-y-20 between cards\n * - Desktop (lg+): 2 columns, py-128, gap-64 between title and cards, gap-y-20 between cards\n *\n * @example\n * ```tsx\n * <CardGrid\n * variant=\"A\"\n * title=\"Featured Cards\"\n * cards={[\n * <Card key=\"1\">...</Card>,\n * <Card key=\"2\">...</Card>,\n * ]}\n * />\n * ```\n */\nconst CardGrid = React.forwardRef<HTMLElement, CardGridProps>(\n\t({ className, variant, title, cards, ...props }, ref) => {\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(cardGridVariants({ variant }), className)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Title - col-full within grid */}\n\t\t\t\t<h2\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"col-full\",\n\t\t\t\t\t\t\"typography-headline-small text-gray-900\",\n\t\t\t\t\t\t// Gap after title: mobile default, md: 56px, lg: 64px\n\t\t\t\t\t\t\"mb-spacing-36 md:mb-spacing-56 lg:mb-spacing-64\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{title}\n\t\t\t\t</h2>\n\n\t\t\t\t{/* Inner grid for cards */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"col-full\",\n\t\t\t\t\t\t// Mobile: single column\n\t\t\t\t\t\t\"grid grid-cols-1 gap-spacing-20\",\n\t\t\t\t\t\t// Tablet: 2 columns\n\t\t\t\t\t\t\"md:grid-cols-2\",\n\t\t\t\t\t\t// Desktop: 3 columns for variant A, 2 columns for variant B\n\t\t\t\t\t\tvariant === \"A\" && \"lg:grid-cols-3\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{React.Children.toArray(cards).map((card) => (\n\t\t\t\t\t\t<div key={(card as React.ReactElement).key}>{card}</div>\n\t\t\t\t\t))}\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nCardGrid.displayName = \"CardGrid\";\n\nexport { CardGrid, cardGridVariants };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * TwoColumnSection component for text-heavy content sections\n *\n * Layout:\n * - Desktop (lg+): Title left, content right with border-top divider\n * - Mobile/Tablet: Stacked vertically\n *\n * Uses the 24-column grid system.\n */\nconst twoColumnSectionVariants = cva(\n\t// Base styles - responsive padding\n\t[\n\t\t\"w-full\",\n\t\t// Small (mobile): 20px x, 56px top, 20px bottom\n\t\t\"px-spacing-20 pt-spacing-56 pb-spacing-20\",\n\t\t// Medium (tablet): 56px x, 56px y\n\t\t\"md:px-spacing-56 md:py-spacing-56\",\n\t\t// Large (desktop): 72px x, 72px top, 112px bottom\n\t\t\"lg:px-spacing-72 lg:pt-spacing-72 lg:pb-spacing-112\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\ttheme: {\n\t\t\t\tdark: \"bg-gray-1200\",\n\t\t\t\tlight: \"bg-white\",\n\t\t\t},\n\t\t\tlayout: {\n\t\t\t\t/** Default 24-column grid with asymmetric split (title: 9, content: 15) */\n\t\t\t\tasymmetric: \"\",\n\t\t\t\t/** Equal 2-column layout at md+ breakpoints */\n\t\t\t\tequal: \"\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\ttheme: \"dark\",\n\t\t\tlayout: \"asymmetric\",\n\t\t},\n\t},\n);\n\nexport interface TwoColumnSectionProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof twoColumnSectionVariants> {\n\t/**\n\t * The title text displayed in the left column\n\t */\n\ttitle: string;\n\t/**\n\t * Lead content - prominently styled (brighter text)\n\t * Can be a string or ReactNode for rich content\n\t */\n\tlead?: React.ReactNode;\n\t/**\n\t * Body content - secondary styled (muted text)\n\t * Can be a string or ReactNode for rich content\n\t */\n\tchildren: React.ReactNode;\n\t/**\n\t * Layout style for the columns\n\t * - \"asymmetric\" (default): Uses 24-column grid with ~40/60 split (title: 9, content: 15)\n\t * - \"equal\": Simple 2-column equal-width layout at md+ breakpoints\n\t */\n\tlayout?: \"asymmetric\" | \"equal\";\n}\n\n/**\n * TwoColumnSection component for text-heavy content with title/content split.\n *\n * Layout:\n * - Mobile/Tablet: Stacked (title above content)\n * - Desktop (lg+): Title left (~40%), Content right (~60%)\n *\n * @example\n * ```tsx\n * <TwoColumnSection\n * title=\"US Tech Force\"\n * lead=\"The US Tech Force is recruiting an elite corps of engineers...\"\n * theme=\"dark\"\n * >\n * <p>Through a two-year program, participants will work...</p>\n * <p>Upon completing the program, engineers can seek...</p>\n * </TwoColumnSection>\n * ```\n */\nconst TwoColumnSection = React.forwardRef<HTMLElement, TwoColumnSectionProps>(\n\t({ className, theme = \"dark\", layout, title, lead, children, ...props }, ref) => {\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(twoColumnSectionVariants({ theme, layout }), className)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Inner container with border-top */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"border-t pt-spacing-36\",\n\t\t\t\t\t\ttheme === \"dark\" ? \"border-gray-700\" : \"border-gray-300\",\n\t\t\t\t\t\t// Grid layout\n\t\t\t\t\t\t\"grid grid-cols-1 gap-spacing-56\",\n\t\t\t\t\t\tlayout === \"equal\"\n\t\t\t\t\t\t\t? \"md:grid-cols-2\"\n\t\t\t\t\t\t\t: \"lg:grid-cols-24 lg:gap-spacing-56\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{/* Title column */}\n\t\t\t\t\t<h2\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\"typography-subheading-medium\",\n\t\t\t\t\t\t\ttheme === \"dark\" ? \"text-gray-100\" : \"text-gray-900\",\n\t\t\t\t\t\t\t// Column span based on layout\n\t\t\t\t\t\t\tlayout !== \"equal\" && \"lg:col-span-9\",\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t{title}\n\t\t\t\t\t</h2>\n\n\t\t\t\t\t{/* Content column */}\n\t\t\t\t\t<div className={cn(\"flex flex-col gap-spacing-56\", layout !== \"equal\" && \"lg:col-span-15\")}>\n\t\t\t\t\t\t{/* Lead content - brighter/prominent */}\n\t\t\t\t\t\t{lead && (\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\t\"typography-body-large\",\n\t\t\t\t\t\t\t\t\ttheme === \"dark\" ? \"text-gray-100\" : \"text-gray-900\",\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{typeof lead === \"string\" ? <p>{lead}</p> : lead}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t)}\n\n\t\t\t\t\t\t{/* Body content - muted */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"typography-body-medium flex flex-col gap-[1em]\",\n\t\t\t\t\t\t\t\ttheme === \"dark\" ? \"text-gray-400\" : \"text-gray-600\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{children}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nTwoColumnSection.displayName = \"TwoColumnSection\";\n\nexport { TwoColumnSection, twoColumnSectionVariants };\n","import * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\nimport { TwoColumnSection } from \"../two-column-section\";\nimport type { VariantProps } from \"class-variance-authority\";\nimport { twoColumnSectionVariants } from \"../two-column-section/two-column-section\";\n\nexport interface FaqSectionProps\n\textends Omit<React.HTMLAttributes<HTMLElement>, \"title\">,\n\t\tVariantProps<typeof twoColumnSectionVariants> {\n\t/**\n\t * The title text displayed in the left column\n\t * @default \"Frequently Asked Questions\"\n\t */\n\ttitle?: string;\n\t/**\n\t * The FAQ content - typically an Accordion with AccordionItems\n\t */\n\tchildren: React.ReactNode;\n}\n\n/**\n * FaqSection component for displaying FAQ content in a two-column layout.\n *\n * Wraps TwoColumnSection with FAQ-specific defaults and typography.\n *\n * Layout:\n * - Mobile/Tablet: Stacked (title above content)\n * - Desktop (lg+): Title left (~40%), FAQ content right (~60%)\n *\n * @example\n * ```tsx\n * <FaqSection>\n * <Accordion defaultExpanded=\"faq-1\">\n * <AccordionItem id=\"faq-1\" title=\"What is the US Tech Force?\">\n * Tech Force will be an elite group of technology specialists...\n * </AccordionItem>\n * <AccordionItem id=\"faq-2\" title=\"What skills are required?\">\n * We're looking for expertise in software engineering...\n * </AccordionItem>\n * </Accordion>\n * </FaqSection>\n *\n * // With custom title\n * <FaqSection title=\"Common Questions\" theme=\"light\">\n * ...\n * </FaqSection>\n * ```\n */\nconst FaqSection = React.forwardRef<HTMLElement, FaqSectionProps>(\n\t(\n\t\t{ className, theme = \"dark\", title = \"Frequently Asked Questions\", children, layout, ...props },\n\t\tref,\n\t) => {\n\t\treturn (\n\t\t\t<TwoColumnSection\n\t\t\t\tref={ref}\n\t\t\t\ttheme={theme}\n\t\t\t\tlayout={layout ?? undefined}\n\t\t\t\ttitle={title}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t// Override title typography to be larger\n\t\t\t\t\t\"[&_h2]:typography-subheading-large\",\n\t\t\t\t\t// Accordion typography overrides\n\t\t\t\t\t\"[&_button]:typography-body-large [&_button]:md:typography-subheading-small\",\n\t\t\t\t\t\"[&_[data-accordion-panel]]:typography-body-medium [&_[data-accordion-panel]]:md:typography-body-large\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</TwoColumnSection>\n\t\t);\n\t},\n);\nFaqSection.displayName = \"FaqSection\";\n\nexport { FaqSection };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * Hero variants based on Figma BaseKit / Heros\n *\n * Variants:\n * - A1: Content aligned at bottom (default)\n * - A2: Content aligned at top\n * - A3: Content aligned at center\n *\n * Each variant is responsive across breakpoints:\n * - sm (Mobile): 500px height, 20px padding\n * - md (Tablet): 650px height, 56px padding\n * - lg (Desktop): 700-850px height, 64-72px padding\n */\nconst heroVariants = cva(\n\t[\n\t\t\"flex w-full bg-gray-1000\",\n\t\t// Mobile (sm)\n\t\t\"h-[500px] p-spacing-20\",\n\t\t// Tablet (md)\n\t\t\"md:h-[650px] md:p-spacing-56\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\t// A1: Content at bottom\n\t\t\t\tA1: [\n\t\t\t\t\t\"items-end\",\n\t\t\t\t\t// Desktop (lg) - 800px height, 72px padding\n\t\t\t\t\t\"xl:h-[800px] xl:p-spacing-72\",\n\t\t\t\t],\n\t\t\t\t// A2: Content at top\n\t\t\t\tA2: [\n\t\t\t\t\t\"items-start\",\n\t\t\t\t\t// Desktop (lg) - 700px height, 64px padding\n\t\t\t\t\t\"xl:h-[700px] xl:p-spacing-64\",\n\t\t\t\t],\n\t\t\t\t// A3: Content centered\n\t\t\t\tA3: [\n\t\t\t\t\t\"items-center\",\n\t\t\t\t\t// Desktop (lg) - 800px height, 64px padding\n\t\t\t\t\t\"xl:h-[800px] xl:p-spacing-64\",\n\t\t\t\t],\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"A1\",\n\t\t},\n\t},\n);\n\nexport interface HeroProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof heroVariants> {\n\t/**\n\t * The title text displayed in the hero\n\t */\n\ttitle: string;\n\t/**\n\t * URL for the background image\n\t */\n\tbackgroundImage?: string;\n\t/**\n\t * URL for a background video (takes precedence over backgroundImage)\n\t */\n\tbackgroundVideo?: string;\n\t/**\n\t * Opacity of the dark overlay (0-1, default: 0)\n\t */\n\toverlayOpacity?: number;\n\t/**\n\t * Color of the overlay (default: \"black\")\n\t */\n\toverlayColor?: string;\n\t/**\n\t * CSS background-position value (default: \"center\")\n\t */\n\tbackgroundPosition?: string;\n}\n\n/**\n * Hero component for page headers with large display typography.\n *\n * Features responsive sizing across three variants:\n * - A1: Content at bottom (default)\n * - A2: Content at top\n * - A3: Content centered\n *\n * Each variant responds to breakpoints:\n * - Mobile: 500px height, 20px padding, 64px typography\n * - Tablet (768px+): 650px height, 56px padding, 128-148px typography\n * - Desktop (1440px+): 700-800px height, 64-72px padding, 148-192px typography\n *\n * @example\n * ```tsx\n * // Simple hero\n * <Hero title=\"Welcome\" variant=\"A1\" />\n *\n * // With background image and overlay\n * <Hero\n * title=\"Welcome\"\n * variant=\"A1\"\n * backgroundImage=\"/hero.jpg\"\n * overlayOpacity={0.4}\n * />\n * ```\n */\nconst Hero = React.forwardRef<HTMLElement, HeroProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\ttitle,\n\t\t\tvariant,\n\t\t\tbackgroundImage,\n\t\t\tbackgroundVideo,\n\t\t\toverlayOpacity = 0,\n\t\t\toverlayColor = \"black\",\n\t\t\tbackgroundPosition = \"center\",\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\tconst hasBackground = backgroundImage || backgroundVideo;\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\theroVariants({ variant }),\n\t\t\t\t\thasBackground && \"relative overflow-hidden\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Background image */}\n\t\t\t\t{backgroundImage && !backgroundVideo && (\n\t\t\t\t\t<div\n\t\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\t\tclassName=\"absolute inset-0 bg-cover\"\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tbackgroundImage: `url(${backgroundImage})`,\n\t\t\t\t\t\t\tbackgroundPosition,\n\t\t\t\t\t\t}}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\n\t\t\t\t{/* Background video */}\n\t\t\t\t{backgroundVideo && (\n\t\t\t\t\t<video\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tloop\n\t\t\t\t\t\tmuted\n\t\t\t\t\t\tplaysInline\n\t\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\t\tclassName=\"absolute inset-0 h-full w-full object-cover\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={backgroundVideo} />\n\t\t\t\t\t</video>\n\t\t\t\t)}\n\n\t\t\t\t{/* Overlay */}\n\t\t\t\t{hasBackground && overlayOpacity > 0 && (\n\t\t\t\t\t<div\n\t\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\t\tclassName=\"absolute inset-0\"\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tbackgroundColor: overlayColor,\n\t\t\t\t\t\t\topacity: overlayOpacity,\n\t\t\t\t\t\t}}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\n\t\t\t\t{/* Content */}\n\t\t\t\t<h1\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"typography-display-large text-gray-50\",\n\t\t\t\t\t\thasBackground && \"relative z-10\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{title}\n\t\t\t\t</h1>\n\t\t\t</section>\n\t\t);\n\t},\n);\nHero.displayName = \"Hero\";\n\nexport { Hero, heroVariants };\n","import * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\nexport interface ProseProps extends React.HTMLAttributes<HTMLDivElement> {\n\tchildren: React.ReactNode;\n}\n\n/**\n * Prose container for long-form content with proper typography and spacing.\n *\n * Provides responsive spacing between content blocks:\n * - Desktop (1440px+): 96px gap\n * - Tablet (768px+): 72px gap\n * - Mobile: 56px gap\n *\n * Use with ProseSection components for proper content structure.\n */\nconst Prose = React.forwardRef<HTMLDivElement, ProseProps>(\n\t({ className, children, ...props }, ref) => {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex w-full max-w-[700px] flex-col overflow-hidden\",\n\t\t\t\t\t// Responsive gap between sections\n\t\t\t\t\t\"gap-spacing-56 md:gap-spacing-72 xl:gap-spacing-96\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</div>\n\t\t);\n\t},\n);\nProse.displayName = \"Prose\";\n\nexport interface ProseSectionProps extends React.HTMLAttributes<HTMLElement> {\n\t/**\n\t * The heading text for this section\n\t */\n\theading: string;\n\t/**\n\t * The heading level to render (h2 or h3)\n\t * @default \"h2\"\n\t */\n\tas?: \"h2\" | \"h3\";\n\tchildren: React.ReactNode;\n}\n\n/**\n * A section within Prose content, containing a heading and body text.\n *\n * Responsive typography:\n * - h2: Uses typography-headline-medium (42px mobile → 56px tablet → 72px desktop)\n * - h3: Uses typography-headline-small (32px mobile → 42px tablet → 56px desktop)\n * - Body: Uses typography-body-medium (16px mobile/tablet → 18px desktop)\n */\nconst ProseSection = React.forwardRef<HTMLElement, ProseSectionProps>(\n\t({ className, heading, as = \"h2\", children, ...props }, ref) => {\n\t\tconst Heading = as;\n\t\tconst headingClass =\n\t\t\tas === \"h2\" ? \"typography-headline-medium\" : \"typography-headline-small\";\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex w-full flex-col\",\n\t\t\t\t\t// Responsive gap between heading and body\n\t\t\t\t\t\"gap-spacing-24 md:gap-spacing-40\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t<Heading className={cn(headingClass, \"text-gray-900\")}>\n\t\t\t\t\t{heading}\n\t\t\t\t</Heading>\n\t\t\t\t<div className=\"typography-body-medium flex flex-col gap-[1em] text-gray-800 break-words\">\n\t\t\t\t\t{children}\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nProseSection.displayName = \"ProseSection\";\n\nexport { Prose, ProseSection };\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * River component for content sections with text and media\n *\n * Variants:\n * - A: Text on left (9 cols), media on right (15 cols) on desktop\n * - B: Media on left (15 cols), text on right (9 cols) on desktop\n *\n * Uses the 24-column grid system. Must be placed inside a `grid-container`.\n */\nconst riverVariants = cva(\n\t// Base styles - col-full within parent grid, responsive padding\n\t[\n\t\t\"col-full\",\n\t\t// Small (mobile): 20px x, 72px top, 20px bottom\n\t\t\"px-spacing-20 pt-spacing-72 pb-spacing-20\",\n\t\t// Medium (tablet): 56px x, 96px y\n\t\t\"md:px-spacing-56 md:py-spacing-96\",\n\t\t// Large (desktop): 72px x, 128px y\n\t\t\"lg:px-spacing-72 lg:py-spacing-128\",\n\t],\n\t{\n\t\tvariants: {\n\t\t\tvariant: {\n\t\t\t\tA: \"\",\n\t\t\t\tB: \"\",\n\t\t\t},\n\t\t},\n\t\tdefaultVariants: {\n\t\t\tvariant: \"A\",\n\t\t},\n\t},\n);\n\nexport interface RiverProps\n\textends React.HTMLAttributes<HTMLElement>,\n\t\tVariantProps<typeof riverVariants> {\n\t/**\n\t * The headline text\n\t */\n\theadline: string;\n\t/**\n\t * The body text\n\t */\n\tbody: string;\n\t/**\n\t * Primary action button (required)\n\t */\n\tprimaryAction: React.ReactNode;\n\t/**\n\t * Secondary action button (optional)\n\t */\n\tsecondaryAction?: React.ReactNode;\n\t/**\n\t * Media content (image, video, etc.)\n\t */\n\tmedia: React.ReactNode;\n}\n\n/**\n * River component for content sections with text and media.\n *\n * Uses the 24-column grid system - must be placed inside a `grid-container`.\n *\n * Layout:\n * - Mobile/Tablet: Stacked (text above media)\n * - Desktop (lg+):\n * - Variant A: Text (9 cols) | Media (15 cols)\n * - Variant B: Media (15 cols) | Text (9 cols)\n *\n * @example\n * ```tsx\n * <div className=\"grid-container\">\n * <River\n * variant=\"A\"\n * headline=\"Feature Headline\"\n * body=\"Description of the feature...\"\n * primaryAction={<Button>Primary</Button>}\n * secondaryAction={<Button variant=\"charcoalOutline\">Secondary</Button>}\n * media={<img src=\"...\" alt=\"Feature\" />}\n * />\n * </div>\n * ```\n */\nconst River = React.forwardRef<HTMLElement, RiverProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\tvariant,\n\t\t\theadline,\n\t\t\tbody,\n\t\t\tprimaryAction,\n\t\t\tsecondaryAction,\n\t\t\tmedia,\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\tconst contentColumn = (\n\t\t\t<div\n\t\t\t\tclassName={cn(\n\t\t\t\t\t\"flex flex-col\",\n\t\t\t\t\t// Full width on mobile/tablet, 9 cols on desktop\n\t\t\t\t\t\"lg:col-span-9\",\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t{/* Text content with 16px gap */}\n\t\t\t\t<div className=\"flex flex-col gap-spacing-16\">\n\t\t\t\t\t<h2 className=\"typography-headline-small text-gray-900\">\n\t\t\t\t\t\t{headline}\n\t\t\t\t\t</h2>\n\t\t\t\t\t<p className=\"typography-body-small text-gray-800\">{body}</p>\n\t\t\t\t</div>\n\n\t\t\t\t{/* Buttons with 36px gap from text, responsive sizes */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"flex flex-row gap-spacing-16 mt-spacing-36\",\n\t\t\t\t\t\t\"[&>*]:flex-shrink-0\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{primaryAction}\n\t\t\t\t\t{secondaryAction}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\n\t\tconst mediaColumn = (\n\t\t\t<div\n\t\t\t\tclassName={cn(\n\t\t\t\t\t// Full width on mobile/tablet, 15 cols on desktop\n\t\t\t\t\t\"lg:col-span-15\",\n\t\t\t\t\t// Ensure media fills the container\n\t\t\t\t\t\"[&>*]:w-full [&>*]:h-auto\",\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t{media}\n\t\t\t</div>\n\t\t);\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(riverVariants({ variant }), className)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Inner grid container for 24-col layout */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\"grid grid-cols-1 gap-spacing-36\",\n\t\t\t\t\t\t\"lg:grid-cols-24 lg:gap-spacing-36\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{variant === \"B\" ? (\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t{mediaColumn}\n\t\t\t\t\t\t\t{contentColumn}\n\t\t\t\t\t\t</>\n\t\t\t\t\t) : (\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t{contentColumn}\n\t\t\t\t\t\t\t{mediaColumn}\n\t\t\t\t\t\t</>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t</section>\n\t\t);\n\t},\n);\nRiver.displayName = \"River\";\n\nexport { River, riverVariants };\n","import * as React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\n/**\n * Tout component based on Figma BaseKit / Touts\n *\n * A full-bleed section with a background image and overlaid content.\n * Content can be positioned on the left side or centered.\n *\n * Responsive behavior:\n * - Mobile (sm): 600px height, 4 columns with gap-20, content spans all 4 cols\n * - Tablet (md): 750px height, 12 columns with gap-20, content spans 9 cols (left) or centered\n * - Desktop (lg): 900px height, 24 columns with gap-20, content spans 9 cols (left) or centered\n *\n * This component is self-contained - do NOT wrap in a grid-container.\n */\nexport interface ToutProps extends React.HTMLAttributes<HTMLElement> {\n\t/**\n\t * The headline displayed in the tout\n\t */\n\theadline: React.ReactNode;\n\t/**\n\t * The body text displayed below the headline (optional)\n\t */\n\tbody?: string;\n\t/**\n\t * Primary action button (required)\n\t */\n\tprimaryAction: React.ReactNode;\n\t/**\n\t * Secondary action button (optional)\n\t */\n\tsecondaryAction?: React.ReactNode;\n\t/**\n\t * Background media (image or video element)\n\t * Should be a full-bleed element that covers the entire section\n\t */\n\tbackgroundMedia: React.ReactNode;\n\t/**\n\t * Content alignment: left (default) or center\n\t */\n\talign?: \"left\" | \"center\";\n\t/**\n\t * Show National Design Studio footer link at the bottom of the section\n\t */\n\tndstudioFooter?: boolean;\n}\n\n/**\n * Tout component for hero-like sections with background media and overlaid content.\n *\n * This component is self-contained with its own grid.\n * Grid setup:\n * - Desktop (lg): 24 columns, gap-spacing-20, content spans 9 cols\n * - Tablet (md): 12 columns, gap-spacing-20, content spans 9 cols\n * - Mobile: 4 columns, gap-spacing-20, content spans all 4 cols\n *\n * @example\n * ```tsx\n * <Tout\n * headline=\"Feature Headline\"\n * body=\"Description of the feature...\"\n * primaryAction={<Button>Primary</Button>}\n * secondaryAction={<Button variant=\"charcoalOutline\">Secondary</Button>}\n * backgroundMedia={\n * <img\n * src=\"/background.jpg\"\n * alt=\"\"\n * className=\"absolute inset-0 w-full h-full object-cover\"\n * />\n * }\n * />\n * ```\n */\nconst Tout = React.forwardRef<HTMLElement, ToutProps>(\n\t(\n\t\t{\n\t\t\tclassName,\n\t\t\theadline,\n\t\t\tbody,\n\t\t\tprimaryAction,\n\t\t\tsecondaryAction,\n\t\t\tbackgroundMedia,\n\t\t\talign = \"left\",\n\t\t\tndstudioFooter,\n\t\t\t...props\n\t\t},\n\t\tref,\n\t) => {\n\t\tconst isCentered = align === \"center\";\n\n\t\treturn (\n\t\t\t<section\n\t\t\t\tref={ref}\n\t\t\t\tclassName={cn(\n\t\t\t\t\t// Full width\n\t\t\t\t\t\"w-full\",\n\t\t\t\t\t// Positioning context for background\n\t\t\t\t\t\"relative overflow-hidden\",\n\t\t\t\t\t// Responsive height: 600px mobile, 750px tablet, 900px desktop\n\t\t\t\t\t\"h-[600px] md:h-[750px] lg:h-[900px]\",\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\t{...props}\n\t\t\t>\n\t\t\t\t{/* Background layer - full bleed */}\n\t\t\t\t<div\n\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\tclassName=\"absolute inset-0 pointer-events-none\"\n\t\t\t\t>\n\t\t\t\t\t{/* Fallback background color */}\n\t\t\t\t\t<div className=\"absolute inset-0 bg-gray-500\" />\n\t\t\t\t\t{/* Background media */}\n\t\t\t\t\t{backgroundMedia}\n\t\t\t\t</div>\n\n\t\t\t\t{/* Inner grid for content alignment */}\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t// Position above background\n\t\t\t\t\t\t\"relative z-10\",\n\t\t\t\t\t\t// Grid setup with responsive columns\n\t\t\t\t\t\t\"grid w-full h-full\",\n\t\t\t\t\t\t// Mobile: 4 columns with gap-20\n\t\t\t\t\t\t\"grid-cols-4 gap-spacing-20\",\n\t\t\t\t\t\t// Tablet (md): 12 columns\n\t\t\t\t\t\t\"md:grid-cols-12\",\n\t\t\t\t\t\t// Desktop (lg): 24 columns\n\t\t\t\t\t\t\"lg:grid-cols-24\",\n\t\t\t\t\t\t// Max width and centering like grid-container\n\t\t\t\t\t\t\"max-w-[var(--breakpoint-lg)] mx-auto\",\n\t\t\t\t\t\t// Responsive margins matching grid-container\n\t\t\t\t\t\t\"px-spacing-20 md:px-spacing-56 lg:px-spacing-72\",\n\t\t\t\t\t\t// Vertical padding to position content at bottom\n\t\t\t\t\t\t\"py-spacing-36 md:py-spacing-56 lg:py-spacing-72\",\n\t\t\t\t\t)}\n\t\t\t\t>\n\t\t\t\t\t{/* Content column - aligned to grid */}\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t// Flex container for content\n\t\t\t\t\t\t\t\"flex flex-col\",\n\t\t\t\t\t\t\tisCentered ? \"justify-start items-center\" : \"justify-end\",\n\t\t\t\t\t\t\t// Responsive gap between text and buttons\n\t\t\t\t\t\t\t\"gap-spacing-28 md:gap-spacing-36\",\n\t\t\t\t\t\t\t// Mobile: all 4 cols\n\t\t\t\t\t\t\t\"col-span-4\",\n\t\t\t\t\t\t\t// Tablet & Desktop: 9 cols left-aligned, full width centered\n\t\t\t\t\t\t\tisCentered ? \"md:col-span-12 lg:col-span-24\" : \"md:col-span-9\",\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Text content stack */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"flex flex-col gap-spacing-16\",\n\t\t\t\t\t\t\t\tisCentered && \"items-center text-center\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<h2 className=\"typography-headline-small text-gray-900\">\n\t\t\t\t\t\t\t\t{headline}\n\t\t\t\t\t\t\t</h2>\n\t\t\t\t\t\t\t{body && (\n\t\t\t\t\t\t\t\t<p className=\"typography-body-small text-gray-800\">{body}</p>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* CTA buttons */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\"flex flex-row\",\n\t\t\t\t\t\t\t\tisCentered ? \"justify-center\" : \"items-start\",\n\t\t\t\t\t\t\t\t// Responsive gap between buttons\n\t\t\t\t\t\t\t\t\"gap-spacing-8 md:gap-spacing-12\",\n\t\t\t\t\t\t\t\t\"[&>*]:flex-shrink-0\",\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{primaryAction}\n\t\t\t\t\t\t\t{secondaryAction}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\n\t\t\t\t{/* National Design Studio footer */}\n\t\t\t\t{ndstudioFooter && (\n\t\t\t\t\t<div className=\"absolute bottom-6 md:bottom-8 left-0 right-0 z-10 text-center\">\n\t\t\t\t\t\t<p className=\"typography-label-large uppercase text-ivory-alpha-75\">\n\t\t\t\t\t\t\tDesigned and Engineered in DC by{\" \"}\n\t\t\t\t\t\t\t<a\n\t\t\t\t\t\t\t\thref=\"https://ndstudio.gov\"\n\t\t\t\t\t\t\t\ttarget=\"_blank\"\n\t\t\t\t\t\t\t\trel=\"noopener noreferrer\"\n\t\t\t\t\t\t\t\tclassName=\"hover:underline\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tNational Design Studio\n\t\t\t\t\t\t\t\t<span className=\"sr-only\"> (opens in new tab)</span>\n\t\t\t\t\t\t\t</a>\n\t\t\t\t\t\t</p>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</section>\n\t\t);\n\t},\n);\nTout.displayName = \"Tout\";\n\nexport { Tout };\n"],"names":["useControlled","controlled","defaultProp","name","state","isControlled","React","valueState","setValue","value","defaultValue","setValueIfUncontrolled","newValue","UNINITIALIZED","useRefWithInit","init","initArg","ref","useInsertionEffect","useSafeInsertionEffect","fn","useStableCallback","callback","stable","createStableCallback","assertNotCalled","args","noop","useIsoLayoutEffect","set","warn","messages","messageKey","CompositeListContext","useCompositeListContext","CompositeList","props","children","elementsRef","labelsRef","onMapChangeProp","onMapChange","nextIndexRef","listeners","createListeners","map","createMap","mapTick","setMapTick","lastTickRef","register","node","metadata","unregister","sortedMap","newMap","sortByDocumentPosition","index","mutationObserver","entries","diff","updateDiff","entry","_","subscribeMapChange","l","contextValue","_jsx","a","b","position","DirectionContext","useDirection","formatErrorMessage","code","url","arg","AccordionRootContext","useAccordionRootContext","context","_formatErrorMessage","useMergedRefs","c","d","forkRef","createForkRef","didChange","update","useMergedRefsN","refs","didChangeN","newRefs","instance","cleanupCallbacks","i","refCleanup","cleanupCallback","majorVersion","isReactVersionAtLeast","reactVersionToCheck","getReactElementRef","element","reactElement","propsWithRef","mergeObjects","getStateAttributesProps","customMapping","key","customProps","resolveClassName","className","resolveStyle","style","EMPTY_PROPS","mergeProps","e","merged","resolvePropsGetter","mergeOne","mergePropsN","inputProps","isPropsGetter","mutablyMergeInto","mergedProps","externalProps","propName","externalPropValue","mergeClassNames","isEventHandler","mergeEventHandlers","code0","code1","code2","previousProps","ourHandler","theirHandler","event","isSyntheticEvent","baseUIEvent","makeEventPreventable","result","ourClassName","theirClassName","NOOP","EMPTY_OBJECT","CLICK_TRIGGER_IDENTIFIER","ownerVisuallyHidden","useRenderElement","componentProps","params","renderProp","outProps","useRenderElementProps","evaluateRenderProp","classNameProp","styleProp","stateAttributesMapping","enabled","stateProps","render","renderTag","Tag","_createElement","none","triggerPress","triggerHover","outsidePress","focusOut","escapeKey","imperativeAction","createChangeEventDetails","reason","trigger","customProperties","canceled","allowPropagation","custom","rootStateAttributesMapping","AccordionRoot","forwardedRef","disabled","hiddenUntilFoundProp","keepMountedProp","loopFocus","onValueChangeProp","multiple","orientation","valueProp","defaultValueProp","elementProps","direction","onValueChange","accordionItemRefs","handleValueChange","nextOpen","details","REASONS.none","nextOpenValues","v","nextValue","SafeReact","globalId","useGlobalId","idOverride","prefix","defaultId","setDefaultId","id","maybeReactUseId","useId","reactId","useBaseUiId","EMPTY","useOnMount","LAST_RAF","Scheduler","timestamp","currentCallbacks","currentCallbacksCount","didRAFChange","scheduler","AnimationFrame","useAnimationFrame","timeout","resolveRef","maybeRef","useAnimationsFinished","elementOrRef","waitForNextTick","treatAbortedAsFinished","frame","fnToExecute","signal","exec","anim","ReactDOM","useTransitionStatus","open","enableIdleState","deferEndingState","transitionStatus","setTransitionStatus","mounted","setMounted","useCollapsibleRoot","parameters","openParam","defaultOpen","onOpenChange","setOpen","visible","setVisible","height","width","setDimensions","defaultPanelId","panelIdState","setPanelIdState","panelId","hiddenUntilFound","setHiddenUntilFound","keepMounted","setKeepMounted","abortControllerRef","animationTypeRef","transitionDimensionRef","panelRef","runOnceAnimationsFinish","handleTrigger","eventDetails","REASONS.triggerPress","panel","CollapsibleRootContext","useCollapsibleRootContext","IndexGuessBehavior","useCompositeListItem","label","textRef","indexGuessBehavior","externalIndex","indexRef","setIndex","newIndex","componentRef","isLabelDefined","AccordionItemContext","useAccordionItemContext","TransitionStatusDataAttributes","STARTING_HOOK","ENDING_HOOK","transitionStatusMapping","CollapsiblePanelDataAttributes","CollapsibleTriggerDataAttributes","PANEL_OPEN_HOOK","PANEL_CLOSED_HOOK","triggerOpenStateMapping","collapsibleOpenStateMapping","AccordionItemDataAttributes","accordionStateAttributesMapping","baseMapping","AccordionItem","disabledProp","onOpenChangeProp","listItemRef","mergedRef","contextDisabled","rootState","openValues","fallbackValue","isOpen","collapsible","collapsibleState","collapsibleContext","triggerId","setTriggerId","accordionItemContext","AccordionHeader","isElementDisabled","hasWindow","getNodeName","isNode","getWindow","_node$ownerDocument","getDocumentElement","_ref","isElement","isHTMLElement","isShadowRoot","invalidOverflowDisplayValues","isOverflowElement","overflow","overflowX","overflowY","display","getComputedStyle","isWebKit","lastTraversableNodeNames","isLastTraversableNode","getParentNode","getNearestOverflowAncestor","parentNode","getOverflowAncestors","list","traverseIframes","_node$ownerDocument2","scrollableAncestor","isBody","win","frameElement","getFrameElement","error","CompositeRootContext","useCompositeRootContext","optional","useFocusableWhenDisabled","focusableWhenDisabled","composite","tabIndexProp","isNativeButton","isFocusableComposite","isNonFocusableComposite","additionalProps","useButton","tabIndex","elementRef","isCompositeItem","isValidLink","focusableWhenDisabledProps","isButtonTag","updateDisabled","isButtonElement","getButtonProps","externalOnClick","externalOnMouseDown","externalOnKeyUp","externalOnKeyDown","externalOnPointerDown","otherExternalProps","shouldClick","isEnterKey","isSpaceKey","buttonRef","elem","hasNavigator","nav","getNavigatorData","platform","getPlatform","userAgent","getUserAgent","isIOS","isSafari","isAndroid","isJSDOM","uaData","brand","version","FOCUSABLE_ATTRIBUTE","ACTIVE_KEY","SELECTED_KEY","TYPEABLE_SELECTOR","activeElement","doc","contains","parent","child","rootNode","next","getTarget","isEventTargetWithin","eventAgain","isRootElement","getDocument","isTypeableElement","isTypeableCombobox","getFloatingFocusElement","floatingElement","getNodeChildren","nodes","onlyOpenChildren","getNodeAncestors","allAncestors","currentParentId","currentNode","stopEvent","isReactEvent","isVirtualClick","isVirtualPointerEvent","isClickLikeEvent","type","candidateSelectors","candidateSelector","NoElement","matches","getRootNode","_element$getRootNode","_isInert","lookUp","_node$getAttribute","inertAtt","inert","isContentEditable","_node$getAttribute2","attValue","getCandidates","el","includeContainer","filter","candidates","_getCandidatesIteratively","elements","options","elementsToCheck","assigned","content","nestedCandidates","validCandidate","shadowRoot","validShadowRoot","_nestedCandidates","hasTabIndex","getTabIndex","getSortOrderTabIndex","isScope","sortOrderedTabbables","isInput","isHiddenInput","isDetailsWithSummary","r","getCheckedRadio","form","isTabbableRadio","radioScope","queryRadios","radioSet","err","checked","isRadio","isNonTabbableRadio","isNodeAttached","_nodeRoot","nodeRoot","nodeRootHost","attached","_nodeRootHost","_nodeRootHost$ownerDo","_nodeRoot2","_nodeRootHost2","_nodeRootHost2$ownerD","isZeroArea","_node$getBoundingClie","isHidden","displayCheck","getShadowRoot","isDirectSummary","nodeUnderDetails","originalNode","parentElement","isDisabledFromFieldset","isNodeMatchingSelectorFocusable","isNodeMatchingSelectorTabbable","isShadowRootTabbable","shadowHostNode","_sortByOrder","regularTabbables","orderedTabbables","item","candidateTabindex","acc","sortable","tabbable","container","focusable","isTabbable","getTabbableOptions","getTabbableIn","dir","len","active","nextIndex","getNextTabbable","referenceElement","getPreviousTabbable","isOutsideEvent","containerElement","relatedTarget","disableFocusInside","enableFocusInside","tabindex","ARROW_UP","ARROW_DOWN","ARROW_LEFT","ARROW_RIGHT","HOME","END","HORIZONTAL_KEYS","VERTICAL_KEYS","ARROW_KEYS","COMPOSITE_KEYS","SUPPORTED_KEYS","getActiveTriggers","accordionItemElements","output","section","AccordionTrigger","idProp","nativeButton","isRtl","isHorizontal","triggers","lastIndex","thisIndex","toNext","toPrev","AccordionRootDataAttributes","useCollapsiblePanel","externalRef","idParam","isBeforeMatchRef","latestAnimationNameRef","shouldCancelInitialOpenAnimationRef","shouldCancelInitialOpenTransitionRef","endingStyleFrame","hidden","handlePanelRef","panelStyles","hasAnimation","hasTransition","nextFrame","mergedPanelRef","resizeFrame","originalLayoutStyles","abortController","attributeObserver","endingStyleAttribute","mutationList","mutation","handleBeforeMatch","AccordionPanelCssVars","useValueAsRef","latest","createLatestRef","useOpenChangeComplete","onCompleteParam","openRef","onComplete","AccordionPanel","contextHiddenUntilFound","contextKeepMounted","panelState","f","n","clsx","concatArrays","array1","array2","combinedArray","createClassValidatorObject","classGroupId","validator","createClassPartObject","nextPart","validators","CLASS_PART_SEPARATOR","EMPTY_CONFLICTS","ARBITRARY_PROPERTY_PREFIX","createClassGroupUtils","config","classMap","createClassMap","conflictingClassGroups","conflictingClassGroupModifiers","getGroupIdForArbitraryProperty","classParts","startIndex","getGroupRecursive","hasPostfixModifier","modifierConflicts","baseConflicts","classPartObject","currentClassPart","nextClassPartObject","classRest","validatorsLength","validatorObj","colonIndex","property","theme","classGroups","processClassGroups","group","processClassesRecursively","classGroup","classDefinition","processClassDefinition","processStringDefinition","processFunctionDefinition","processObjectDefinition","classPartObjectToEdit","getPart","isThemeGetter","path","current","parts","part","func","createLruCache","maxCacheSize","cacheSize","cache","previousCache","IMPORTANT_MODIFIER","MODIFIER_SEPARATOR","EMPTY_MODIFIERS","createResultObject","modifiers","hasImportantModifier","baseClassName","maybePostfixModifierPosition","isExternal","createParseClassName","experimentalParseClassName","parseClassName","bracketDepth","parenDepth","modifierStart","postfixModifierPosition","currentCharacter","baseClassNameWithImportantModifier","fullPrefix","parseClassNameOriginal","createSortModifiers","modifierWeights","mod","currentSegment","modifier","isArbitrary","isOrderSensitive","createConfigUtils","SPLIT_CLASSES_REGEX","mergeClassList","classList","configUtils","getClassGroupId","getConflictingClassGroupIds","sortModifiers","classGroupsInConflict","classNames","originalClassName","variantModifier","modifierId","classId","conflictGroups","twJoin","classLists","argument","resolvedValue","string","toValue","mix","k","createTailwindMerge","createConfigFirst","createConfigRest","cacheGet","cacheSet","functionToCall","initTailwindMerge","previousConfig","createConfigCurrent","tailwindMerge","cachedResult","fallbackThemeArr","fromTheme","themeGetter","arbitraryValueRegex","arbitraryVariableRegex","fractionRegex","tshirtUnitRegex","lengthUnitRegex","colorFunctionRegex","shadowRegex","imageRegex","isFraction","isNumber","isInteger","isPercent","isTshirtSize","isAny","isLengthOnly","isNever","isShadow","isImage","isAnyNonArbitrary","isArbitraryValue","isArbitraryVariable","isArbitrarySize","getIsArbitraryValue","isLabelSize","isArbitraryLength","isLabelLength","isArbitraryNumber","isLabelNumber","isArbitraryPosition","isLabelPosition","isArbitraryImage","isLabelImage","isArbitraryShadow","isLabelShadow","isArbitraryVariableLength","getIsArbitraryVariable","isArbitraryVariableFamilyName","isLabelFamilyName","isArbitraryVariablePosition","isArbitraryVariableSize","isArbitraryVariableImage","isArbitraryVariableShadow","testLabel","testValue","shouldMatchNoLabel","getDefaultConfig","themeColor","themeFont","themeText","themeFontWeight","themeTracking","themeLeading","themeBreakpoint","themeContainer","themeSpacing","themeRadius","themeShadow","themeInsetShadow","themeTextShadow","themeDropShadow","themeBlur","themePerspective","themeAspect","themeEase","themeAnimate","scaleBreak","scalePosition","scalePositionWithArbitrary","scaleOverflow","scaleOverscroll","scaleUnambiguousSpacing","scaleInset","scaleGridTemplateColsRows","scaleGridColRowStartAndEnd","scaleGridColRowStartOrEnd","scaleGridAutoColsRows","scaleAlignPrimaryAxis","scaleAlignSecondaryAxis","scaleMargin","scaleSizing","scaleColor","scaleBgPosition","scaleBgRepeat","scaleBgSize","scaleGradientStopPosition","scaleRadius","scaleBorderWidth","scaleLineStyle","scaleBlendMode","scaleMaskImagePosition","scaleBlur","scaleRotate","scaleScale","scaleSkew","scaleTranslate","twMerge","cn","inputs","Accordion","allowMultiple","defaultExpanded","jsx","BaseAccordion.Root","title","jsxs","BaseAccordion.Item","BaseAccordion.Header","BaseAccordion.Trigger","BaseAccordion.Panel","Button","falsyToString","cx","cva","base","_config_compoundVariants","variants","defaultVariants","getVariantClassNames","variant","variantProp","defaultVariantProp","variantKey","propsWithoutUndefined","param","getCompoundVariantClassNames","cvClass","cvClassName","compoundVariantOptions","buttonVariants","size","BaseButton","setRef","composeRefs","hasCleanup","cleanups","cleanup","REACT_LAZY_TYPE","use","isPromiseLike","isLazyComponent","createSlot","ownerName","SlotClone","createSlotClone","Slot2","slotProps","childrenArray","slottable","isSlottable","newElement","newChildren","Slot","childrenRef","getElementRef","props2","SLOTTABLE_IDENTIFIER","childProps","overrideProps","slotPropValue","childPropValue","getter","mayWarn","iconButtonVariants","IconButton","asChild","pagerControlVariants","dotBaseVariants","PagerControl","count","controlledIndex","duration","autoPlay","onChange","pauseOnHover","loop","internalIndex","setInternalIndex","isPaused","setIsPaused","progress","setProgress","activeIndex","animationFrameRef","startTimeRef","pausedProgressRef","goToNext","goToIndex","animate","elapsed","newProgress","handleMouseEnter","handleMouseLeave","getDotWidth","isActive","getInactiveClasses","getActiveTrackClass","getProgressFillClass","cardVariants","Card","layout","CardImage","src","alt","CardContent","CardEyebrow","CardTitle","Component","CardDescription","CardBody","CardActions","DialogRootContext","useDialogRootContext","dialogRootContext","CommonPopupDataAttributes","POPUP_OPEN_HOOK","POPUP_CLOSED_HOOK","ANCHOR_HIDDEN_HOOK","popupStateMapping","Timeout","delay","useTimeout","createEventEmitter","data","listener","FloatingNodeContext","FloatingTreeContext","useFloatingParentNodeId","useFloatingTree","externalTree","contextTree","createAttribute","visuallyHidden","ownerDocument","FocusGuard","role","setRole","rafId","enqueueFocus","preventScroll","cancelPrevious","sync","counters","getCounterMap","control","uncontrolledElementsSet","markerMap","lockCount","unwrapHost","correctElements","targets","target","correctedTarget","x","applyAttributeToOthers","uncorrectedAvoidElements","body","ariaHidden","markerName","controlAttribute","avoidElements","elementsToKeep","elementsToStop","hiddenElements","markerCounter","keep","deep","attr","alreadyHidden","counterMap","counterValue","markerValue","markOthers","PortalContext","usePortalContext","useFloatingPortalNode","containerProp","elementState","uniqueId","parentPortalNode","setContainerElement","portalNode","setPortalNode","containerRef","resolvedContainer","portalElement","FloatingPortal","renderGuards","portalSubtree","beforeOutsideRef","afterOutsideRef","beforeInsideRef","afterInsideRef","focusManagerState","setFocusManagerState","modal","shouldRenderGuards","onFocus","portalContextValue","_jsxs","domReference","REASONS.focusOut","getEventType","lastInteractionType","ownerWindow","LIST_LIMIT","previouslyFocusedElements","clearDisconnectedPreviouslyFocusedElements","addPreviouslyFocusedElement","getPreviouslyFocusedElement","getFirstTabbableElement","tabbableOptions","isFocusable","handleTabIndex","floatingFocusElement","orderRef","tabbableContent","dataTabIndex","FloatingFocusManager","order","initialFocus","returnFocus","restoreFocus","closeOnFocusOut","openInteractionType","getInsideElementsProp","nextFocusableElement","previousFocusableElement","beforeContentFocusGuardRef","store","floating","events","dataRef","getNodeId","getInsideElements","ignoreInitialFocus","isUntrappedTypeableCombobox","initialFocusRef","returnFocusRef","openInteractionTypeRef","tree","portalContext","startDismissButtonRef","endDismissButtonRef","preventReturnFocusRef","isPointerDownRef","pointerDownOutsideRef","tabbableIndexRef","closeTypeRef","lastInteractionTypeRef","blurTimeout","pointerDownTimeout","restoreFocusFrame","isInsidePortal","getTabbableContent","getTabbableElements","onKeyDown","handleFocusIn","tabbableIndex","clearPointerDownOutside","onPointerDown","pointerTargetInside","handlePointerDown","handleFocusOutside","currentTarget","nodeId","movedToUnrelatedNode","prevTabbableIndex","nodeToFocus","markInsideReactTree","domReferenceElement","beforeGuardRef","afterGuardRef","mergedBeforeGuardRef","mergedAfterGuardRef","portalNodes","rootAncestorComboboxDomReference","insideElements","previouslyFocusedElement","focusableElements","initialFocusValueOrFn","resolvedInitialFocus","elToFocus","onOpenChangeLocal","REASONS.triggerHover","REASONS.outsidePress","isPreventScrollSupported","fallbackEl","getReturnElement","returnFocusValueOrFn","resolvedReturnFocusValue","fallback","activeEl","isFocusInsideFloatingTree","returnElement","tabbableReturnElement","hasExplicitReturnFocus","els","bubbleHandlerKeys","normalizeProp","normalizable","useDismiss","outsidePressProp","outsidePressEvent","referencePress","referencePressEvent","ancestorScroll","bubbles","outsidePressFn","endedOrStartedInsideRef","escapeKeyBubbles","outsidePressBubbles","touchStateRef","cancelDismissOnEndTimeout","clearInsideReactTreeTimeout","clearInsideReactTree","isComposingRef","currentPointerTypeRef","trackPointerType","getOutsidePressEvent","computedType","resolved","closeOnEscapeKeyDown","shouldDismiss","native","REASONS.escapeKey","shouldIgnoreEvent","computedOutsidePressEvent","closeOnPressOutside","endedOrStartedInside","inertSelector","markers","targetRootAncestor","nextParent","marker","lastTraversableNode","scrollRe","isScrollableX","isScrollableY","canScrollX","canScrollY","isRTL","pressedVerticalScrollbar","pressedHorizontalScrollbar","targetIsInsideChildren","handleTouchStart","touch","handleTouchStartCapture","closeOnPressOutsideCapture","handleTouchMove","deltaX","deltaY","distance","handleTouchMoveCapture","handleTouchEnd","handleTouchEndCapture","compositionTimeout","onScroll","handleCompositionStart","handleCompositionEnd","ancestors","ancestor","reference","handlePressedInside","runIdentityFunctionCheck","resultFunc","inputSelectorsResults","outputSelectorResult","isInputSameAsOutput","emptyObject","stack","runInputStabilityCheck","inputSelectorResultsObject","inputSelectorArgs","memoize","memoizeOptions","inputSelectorResults","inputSelectorResultsCopy","createAnEmptyObject","globalDevModeChecks","NOT_FOUND","assertIsFunction","errorMessage","assertIsObject","object","assertIsArrayOfFunctions","array","itemTypes","ensureIsArray","getDependencies","createSelectorArgs","dependencies","collectInputSelectorResults","length","getDevModeChecksExecutionInfo","firstRun","devModeChecks","identityFunctionCheck","inputStabilityCheck","createSingletonCache","equals","maxSize","get","cacheIndex","put","getEntries","clear","referenceEqualityCheck","createCacheKeyComparator","equalityCheck","prev","lruMemoize","equalityCheckOrOptions","providedOptions","resultEqualityCheck","comparator","resultsCount","memoized","matchingEntry","StrongRef","Ref","UNTERMINATED","TERMINATED","createCacheNode","weakMapMemoize","fnNode","lastResult","cacheNode","objectCache","objectNode","primitiveCache","primitiveNode","terminatedNode","lastResultValue","createSelectorCreator","memoizeOrOptions","memoizeOptionsFromArgs","createSelectorCreatorOptions","createSelector2","recomputations","dependencyRecomputations","directlyPassedOptions","combinedOptions","argsMemoize","argsMemoizeOptions","finalMemoizeOptions","finalArgsMemoizeOptions","memoizedResultFunc","selector","createSelector","createStructuredSelector","inputSelectorsObject","selectorCreator","inputSelectorKeys","composition","other","require$$0","is","y","objectIs","useState","useEffect","useLayoutEffect","useDebugValue","useSyncExternalStore$2","subscribe","getSnapshot","_useState","inst","forceUpdate","checkIfSnapshotChanged","latestGetSnapshot","useSyncExternalStore$1","shim","useSyncExternalStoreShim_production","didWarnOld18Alpha","didWarnUncachedGetSnapshot","cachedValue","useSyncExternalStoreShim_development","shimModule","require$$1","useSyncExternalStore","useRef","useMemo","withSelector_production","getServerSnapshot","isEqual","instRef","memoizedSelector","nextSnapshot","hasMemo","memoizedSnapshot","currentSelection","memoizedSelection","nextSelection","maybeGetServerSnapshot","withSelector_development","withSelectorModule","canUseRawUseSyncExternalStore","useStoreImplementation","useStoreR19","useStoreLegacy","useStore","a1","a2","a3","getSelection","useSyncExternalStoreWithSelector","Store","newState","currentTick","changes","ReactStore","selectors","statePart","p","keys","nextKeys","previouslyControlled","values","newValues","stableFunction","selectFn","prevValue","nextState","oldValue","FloatingRootStore","nested","noEmit","triggerElements","initialState","newOpen","useImplicitActiveTrigger","iteratorResult","implicitTriggerId","implicitTriggerElement","useOpenStateTransitions","onUnmount","forceUnmount","preventUnmountingOnClose","PopupTriggerMap","existingElement","predicate","getEmptyRootContext","createInitialPopupStoreState","popupStoreSelectors","useSyncedFloatingRootContext","popupStore","treatPopupAsFloatingElement","floatingId","valuesToSync","useInteractions","propsList","referenceDeps","floatingDeps","itemDeps","triggerDeps","getReferenceProps","userProps","getFloatingProps","getItemProps","getTriggerProps","elementKey","eventHandlers","isItem","outputProps","propsOrGetProps","mutablyMergeProps","val","componentRoleToAriaRoleMap","useRole","defaultFloatingId","defaultReferenceId","referenceId","ariaRole","isNested","floatingProps","selected","commonProps","DialogPopupCssVars","DialogPopupDataAttributes","DialogPortalContext","useDialogPortalContext","DialogPopup","finalFocus","descriptionElementId","disablePointerDismissal","floatingRootContext","rootPopupProps","nestedOpenDialogCount","openMethod","titleElementId","defaultInitialFocus","interactionType","nestedDialogOpen","inertValue","InternalBackdrop","cutout","otherProps","clipPath","rect","DialogPortal","portalProps","originalHtmlStyles","originalBodyStyles","originalHtmlScrollBehavior","hasInsetScrollbars","preventScrollOverlayScrollbars","html","elementToLock","originalOverflow","preventScrollInsetScrollbars","scrollTop","scrollLeft","supportsStableScrollbarGutter","lockScroll","htmlStyles","bodyStyles","scrollbarGutterValue","hasConstantOverflowY","hasConstantOverflowX","scrollbarWidth","scrollbarHeight","marginY","marginX","handleResize","ScrollLocker","htmlOverflowY","hasOverlayScrollbars","SCROLL_LOCKER","useScrollLock","useEnhancedClickHandler","handler","lastClickInteractionTypeRef","useOpenInteractionType","setOpenMethod","handleTriggerClick","reset","onClick","useDialogRoot","parentContext","actionsRef","popupElement","triggerProps","resetOpenInteractionType","createDialogEventDetails","handleImperativeClose","REASONS.imperativeAction","ownNestedOpenDialogs","setOwnNestedOpenDialogs","isTopmost","dismiss","eventTarget","ownChildrenCount","activeTriggerProps","inactiveTriggerProps","popupProps","DialogStore","createInitialState","updatedState","newTriggerId","DialogRoot","openProp","onOpenChangeComplete","handle","triggerIdProp","defaultTriggerIdProp","parentDialogRootContext","payload","DialogTitle","NavbarContext","Navbar","isMobileMenuOpen","setIsMobileMenuOpen","navRef","updateHeight","NavbarBrand","NavbarLinks","NavbarLink","NavbarActions","NavbarMobileMenu","Dialog.Root","Dialog.Portal","Dialog.Popup","Dialog.Title","NavbarMobileMenuButton","handleClick","NavbarMobileMenuLink","Comp","USGovBanner","flagIcon","text","DefaultUSFlag","bannerVariants","Banner","heading","description","action","cardGridVariants","CardGrid","cards","card","twoColumnSectionVariants","TwoColumnSection","lead","FaqSection","heroVariants","Hero","backgroundImage","backgroundVideo","overlayOpacity","overlayColor","backgroundPosition","hasBackground","Prose","ProseSection","as","Heading","headingClass","riverVariants","River","headline","primaryAction","secondaryAction","media","contentColumn","mediaColumn","Fragment","Tout","backgroundMedia","align","ndstudioFooter","isCentered"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,69,70,72,73,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123]}
|