@duro-app/ui 0.8.6 → 0.9.0
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/Alert/Alert.d.ts +4 -1
- package/dist/components/Alert/Alert.d.ts.map +1 -1
- package/dist/components/Alert/styles.css.d.ts +15 -0
- package/dist/components/Alert/styles.css.d.ts.map +1 -1
- package/dist/components/Icon/Icon.d.ts +8 -0
- package/dist/components/Icon/Icon.d.ts.map +1 -0
- package/dist/components/Icon/index.d.ts +3 -0
- package/dist/components/Icon/index.d.ts.map +1 -0
- package/dist/components/StatusIcon/StatusIcon.d.ts +3 -2
- package/dist/components/StatusIcon/StatusIcon.d.ts.map +1 -1
- package/dist/components/StatusIcon/styles.css.d.ts +3 -0
- package/dist/components/StatusIcon/styles.css.d.ts.map +1 -1
- package/dist/index.css +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +901 -842
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../node_modules/.pnpm/react-strict-dom@0.0.55_postcss@8.5.6_react-dom@19.2.4_react@19.2.4__react-native@0.84._1278be21509893d955b57d0db9435779/node_modules/react-strict-dom/dist/web/runtime.js","../src/components/Alert/styles.css.ts","../src/components/Alert/Alert.tsx","../src/components/Badge/styles.css.ts","../src/components/Badge/Badge.tsx","../src/components/Button/styles.css.ts","../src/components/Button/Button.tsx","../src/components/Card/styles.css.ts","../src/components/Card/Card.tsx","../src/components/Checkbox/styles.css.ts","../src/components/Checkbox/Checkbox.tsx","../src/components/EmptyState/styles.css.ts","../src/components/EmptyState/EmptyState.tsx","../../tokens/src/tokens/type-presets.css.ts","../src/components/Heading/styles.css.ts","../src/components/Heading/Heading.tsx","../src/components/Field/FieldContext.ts","../src/components/Field/styles.css.ts","../src/components/Field/Field.tsx","../src/components/InputGroup/InputGroupContext.ts","../src/components/Input/styles.css.ts","../src/components/Input/Input.tsx","../src/components/InputGroup/styles.css.ts","../src/components/InputGroup/InputGroup.tsx","../src/components/LinkButton/styles.css.ts","../src/components/LinkButton/LinkButton.tsx","../src/components/Menu/styles.css.ts","../src/components/Menu/MenuContext.ts","../src/components/Menu/useMenuRoot.ts","../src/components/Menu/Menu.tsx","../src/components/ScrollArea/styles.css.ts","../src/components/ScrollArea/ScrollAreaContext.ts","../src/components/ScrollArea/useScrollAreaRoot.ts","../src/components/ScrollArea/ScrollArea.tsx","../src/components/Select/styles.css.ts","../src/components/Select/SelectContext.ts","../src/hooks/useControllableValue.ts","../src/components/Select/useSelectRoot.ts","../src/components/Select/Select.tsx","../src/components/SideNav/styles.css.ts","../src/components/SideNav/SideNavContext.ts","../src/components/SideNav/SideNav.tsx","../src/components/Spinner/styles.css.ts","../src/components/Spinner/Spinner.tsx","../src/components/StatusIcon/styles.css.ts","../src/components/StatusIcon/StatusIcon.tsx","../src/components/Table/styles.css.ts","../src/components/Table/Table.tsx","../src/components/Tabs/styles.css.ts","../src/components/Tabs/TabsContext.ts","../src/components/Tabs/useTabsRoot.ts","../src/components/Tabs/Tabs.tsx","../src/components/Textarea/styles.css.ts","../src/components/Textarea/Textarea.tsx","../../tokens/dist/index.js","../src/components/ThemeProvider/ThemeProvider.tsx","../src/components/Text/styles.css.ts","../src/components/Text/Text.tsx","../src/components/Tooltip/styles.css.ts","../src/components/Tooltip/Tooltip.tsx","../src/components/Stack/styles.css.ts","../src/components/Stack/Stack.tsx","../src/components/Inline/styles.css.ts","../src/components/Inline/Inline.tsx","../src/components/Cluster/styles.css.ts","../src/components/Cluster/Cluster.tsx","../src/components/Grid/styles.css.ts","../src/components/Grid/Grid.tsx","../src/hooks/useContainerQuery.ts"],"sourcesContent":["/**\n * @license react-strict-dom\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';\nimport * as stylex from '@stylexjs/stylex';\n\nvar styleq$1 = {};\n\nObject.defineProperty(styleq$1, \"__esModule\", {\n value: true\n});\nvar styleq_2 = styleq$1.styleq = void 0;\nvar cache = new WeakMap();\nvar compiledKey = '$$css';\nfunction createStyleq(options) {\n var disableCache;\n var disableMix;\n var transform;\n if (options != null) {\n disableCache = options.disableCache === true;\n disableMix = options.disableMix === true;\n transform = options.transform;\n }\n return function styleq() {\n var definedProperties = [];\n var className = '';\n var inlineStyle = null;\n var debugString = '';\n var nextCache = disableCache ? null : cache;\n var styles = new Array(arguments.length);\n for (var i = 0; i < arguments.length; i++) {\n styles[i] = arguments[i];\n }\n while (styles.length > 0) {\n var possibleStyle = styles.pop();\n if (possibleStyle == null || possibleStyle === false) {\n continue;\n }\n if (Array.isArray(possibleStyle)) {\n for (var _i = 0; _i < possibleStyle.length; _i++) {\n styles.push(possibleStyle[_i]);\n }\n continue;\n }\n var style = transform != null ? transform(possibleStyle) : possibleStyle;\n if (style.$$css != null) {\n var classNameChunk = '';\n if (nextCache != null && nextCache.has(style)) {\n var cacheEntry = nextCache.get(style);\n if (cacheEntry != null) {\n classNameChunk = cacheEntry[0];\n debugString = cacheEntry[2];\n definedProperties.push.apply(definedProperties, cacheEntry[1]);\n nextCache = cacheEntry[3];\n }\n } else {\n var definedPropertiesChunk = [];\n for (var prop in style) {\n var value = style[prop];\n if (prop === compiledKey) {\n var compiledKeyValue = style[prop];\n if (compiledKeyValue !== true) {\n debugString = debugString ? compiledKeyValue + '; ' + debugString : compiledKeyValue;\n }\n continue;\n }\n if (typeof value === 'string' || value === null) {\n if (!definedProperties.includes(prop)) {\n definedProperties.push(prop);\n if (nextCache != null) {\n definedPropertiesChunk.push(prop);\n }\n if (typeof value === 'string') {\n classNameChunk += classNameChunk ? ' ' + value : value;\n }\n }\n } else {\n console.error(\"styleq: \".concat(prop, \" typeof \").concat(String(value), \" is not \\\"string\\\" or \\\"null\\\".\"));\n }\n }\n if (nextCache != null) {\n var weakMap = new WeakMap();\n nextCache.set(style, [classNameChunk, definedPropertiesChunk, debugString, weakMap]);\n nextCache = weakMap;\n }\n }\n if (classNameChunk) {\n className = className ? classNameChunk + ' ' + className : classNameChunk;\n }\n } else {\n if (disableMix) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n inlineStyle = Object.assign({}, style, inlineStyle);\n } else {\n var subStyle = null;\n for (var _prop in style) {\n var _value = style[_prop];\n if (_value !== undefined) {\n if (!definedProperties.includes(_prop)) {\n if (_value != null) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n if (subStyle == null) {\n subStyle = {};\n }\n subStyle[_prop] = _value;\n }\n definedProperties.push(_prop);\n nextCache = null;\n }\n }\n }\n if (subStyle != null) {\n inlineStyle = Object.assign(subStyle, inlineStyle);\n }\n }\n }\n }\n var styleProps = [className, inlineStyle, debugString];\n return styleProps;\n };\n}\nvar styleq = styleq_2 = styleq$1.styleq = createStyleq();\nstyleq.factory = createStyleq;\n\nconst optimizedStyleq = styleq_2.factory({\n disableMix: true\n});\nfunction merge(...styles) {\n const [className, style, dataStyleSrc] = optimizedStyleq(styles);\n const result = {};\n if (className != null && className !== '') {\n result.className = className;\n }\n if (style != null) {\n result.style = style;\n }\n if (dataStyleSrc != null && dataStyleSrc !== '') {\n const chunks = dataStyleSrc.split(';');\n const pathsMap = {};\n for (const chunk of chunks) {\n const trimmed = chunk.trim();\n const [path, line] = trimmed.split(':');\n if (line != null) {\n pathsMap[path] = pathsMap[path] != null ? `${pathsMap[path]},${line}` : line;\n }\n }\n result['data-style-src'] = Object.keys(pathsMap).map(path => `${path}:${pathsMap[path]}`).join('; ');\n }\n return result;\n}\n\nconst styles = stylex.create({\n block: {\n margin: 0,\n padding: 0\n },\n inline: {\n margin: 0,\n padding: 0,\n textDecoration: 'none',\n textAlign: 'inherit',\n wordWrap: 'break-word'\n },\n inlineblock: {\n borderStyle: 'solid',\n margin: 0,\n padding: 0\n },\n button: {\n borderWidth: 1\n },\n codePre: {\n fontFamily: 'monospace, \"monospace\"',\n fontSize: '1em',\n overflow: 'auto'\n },\n heading: {\n fontSize: '1.5rem',\n wordWrap: 'break-word'\n },\n hr: {\n backgroundColor: 'black',\n borderStyle: 'none',\n borderWidth: 0,\n boxSizing: 'border-box',\n height: 1\n },\n img: {\n aspectRatio: 'attr(width) / attr(height)',\n height: 'auto',\n maxWidth: '100%'\n },\n input: {\n borderWidth: 1,\n borderStyle: 'solid'\n },\n list: {\n listStyle: 'none'\n },\n strong: {\n fontWeight: 'bold'\n },\n textarea: {\n borderWidth: 1,\n borderStyle: 'solid',\n resize: 'vertical'\n }\n});\nconst a = styles.inline;\nconst article = styles.block;\nconst aside = styles.block;\nconst b = styles.inline;\nconst bdi = styles.inline;\nconst bdo = styles.inline;\nconst blockquote = styles.block;\nconst br = null;\nconst button = [styles.inlineblock, styles.button];\nconst code = [styles.inline, styles.codePre];\nconst del = null;\nconst div = styles.block;\nconst em = styles.inline;\nconst fieldset = styles.block;\nconst footer = styles.block;\nconst form = styles.block;\nconst heading = [styles.block, styles.heading];\nconst header = styles.block;\nconst hr = [styles.block, styles.hr];\nconst i = styles.inline;\nconst img = styles.img;\nconst input = [styles.inlineblock, styles.input];\nconst ins = null;\nconst kbd = null;\nconst label = styles.inline;\nconst li = styles.block;\nconst main = styles.block;\nconst mark = styles.inline;\nconst nav = styles.block;\nconst ol = [styles.list, styles.block];\nconst optgroup = null;\nconst option = null;\nconst p = styles.block;\nconst pre = [styles.block, styles.codePre];\nconst s = null;\nconst section = styles.block;\nconst select = styles.inlineblock;\nconst span = styles.inline;\nconst strong = [styles.inline, styles.strong];\nconst sub = styles.inline;\nconst sup = styles.inline;\nconst textarea = [styles.inlineblock, styles.textarea];\nconst u = null;\nconst ul = [styles.list, styles.block];\nconst defaultStyles = {\n a: a,\n article: article,\n aside: aside,\n b: b,\n bdi: bdi,\n bdo: bdo,\n blockquote: blockquote,\n br: br,\n button: button,\n code: code,\n del: del,\n div: div,\n em: em,\n fieldset: fieldset,\n footer: footer,\n form: form,\n h1: heading,\n h2: heading,\n h3: heading,\n h4: heading,\n h5: heading,\n h6: heading,\n header: header,\n hr: hr,\n i: i,\n img: img,\n input: input,\n ins: ins,\n kbd: kbd,\n label: label,\n li: li,\n main: main,\n mark: mark,\n nav: nav,\n ol: ol,\n optgroup: optgroup,\n option: option,\n p: p,\n pre: pre,\n s: s,\n section: section,\n select: select,\n span: span,\n strong: strong,\n sub: sub,\n sup: sup,\n textarea: textarea,\n u: u,\n ul: ul\n};\n\nexport { defaultStyles, merge };\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n padding: spacing.md,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n },\n error: {\n backgroundColor: colors.errorBg,\n borderColor: colors.errorBorder,\n color: colors.errorText,\n },\n success: {\n backgroundColor: colors.successBg,\n borderColor: colors.successBorder,\n color: colors.successText,\n },\n warning: {\n backgroundColor: colors.warningBg,\n borderColor: colors.warningBorder,\n color: colors.warningText,\n },\n info: {\n backgroundColor: colors.infoBg,\n borderColor: colors.infoBorder,\n color: colors.infoText,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type AlertVariant = 'error' | 'success' | 'warning' | 'info'\n\ninterface AlertProps {\n variant?: AlertVariant\n children: ReactNode\n}\n\nexport function Alert({variant = 'info', children}: AlertProps) {\n return (\n <html.div role=\"alert\" style={[styles.base, styles[variant]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n fontFamily: typography.fontFamily,\n fontWeight: typography.fontWeightMedium,\n lineHeight: 1,\n borderRadius: radii.full,\n whiteSpace: 'nowrap',\n },\n sizeMd: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n sizeSm: {\n paddingTop: 2,\n paddingBottom: 2,\n paddingLeft: spacing.xs,\n paddingRight: spacing.xs,\n fontSize: '0.625rem',\n },\n default: {\n backgroundColor: colors.bgCardHover,\n color: colors.textMuted,\n },\n success: {\n backgroundColor: colors.successBg,\n color: colors.successText,\n },\n warning: {\n backgroundColor: colors.warningBg,\n color: colors.warningText,\n },\n error: {\n backgroundColor: colors.errorBg,\n color: colors.errorText,\n },\n info: {\n backgroundColor: colors.infoBg,\n color: colors.infoText,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type BadgeVariant = 'default' | 'success' | 'warning' | 'error' | 'info'\nexport type BadgeSize = 'sm' | 'md'\n\ninterface BadgeProps {\n variant?: BadgeVariant\n size?: BadgeSize\n children: ReactNode\n}\n\nconst sizeMap = {\n sm: styles.sizeSm,\n md: styles.sizeMd,\n} as const\n\nexport function Badge({variant = 'default', size = 'md', children}: BadgeProps) {\n return <html.span style={[styles.base, sizeMap[size], styles[variant]]}>{children}</html.span>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color, color, opacity',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n textDecoration: 'none',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 2,\n },\n },\n sizeDefault: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n },\n sizeSmall: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n primary: {\n backgroundColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n ':active': colors.accentHover,\n },\n borderColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n color: colors.accentContrast,\n },\n secondary: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderColor: colors.border,\n color: colors.textMuted,\n },\n link: {\n backgroundColor: 'transparent',\n borderColor: 'transparent',\n color: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n textDecoration: {\n default: 'none',\n ':hover': 'underline',\n },\n paddingLeft: 0,\n paddingRight: 0,\n },\n danger: {\n backgroundColor: {\n default: colors.error,\n ':hover': colors.errorHover,\n ':active': colors.errorHover,\n },\n borderColor: {\n default: colors.error,\n ':hover': colors.errorHover,\n },\n color: colors.errorContrast,\n },\n fullWidth: {\n width: '100%',\n },\n disabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type ButtonVariant = 'primary' | 'secondary' | 'link' | 'danger'\nexport type ButtonSize = 'default' | 'small'\n\ninterface ButtonProps {\n variant?: ButtonVariant\n size?: ButtonSize\n fullWidth?: boolean\n disabled?: boolean\n type?: 'button' | 'submit'\n onClick?: () => void\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n small: styles.sizeSmall,\n} as const\n\nexport function Button({\n variant = 'primary',\n size = 'default',\n fullWidth = false,\n disabled = false,\n type = 'button',\n onClick,\n children,\n}: ButtonProps) {\n return (\n <html.button\n type={type}\n disabled={disabled}\n onClick={onClick}\n style={[\n styles.base,\n sizeMap[size],\n styles[variant],\n fullWidth && styles.fullWidth,\n disabled && styles.disabled,\n ]}\n >\n {children}\n </html.button>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n base: {\n backgroundColor: colors.bgCard,\n color: colors.text,\n fontFamily: typography.fontFamily,\n },\n // Variants\n elevated: {\n borderRadius: radii.lg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n boxShadow: shadows.md,\n },\n outlined: {\n borderRadius: radii.md,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n },\n filled: {\n borderRadius: radii.md,\n },\n interactive: {\n borderRadius: radii.md,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':hover': colors.accent,\n },\n backgroundColor: {\n default: colors.bgCard,\n ':hover': colors.bgCardHover,\n },\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color, transform',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n transform: {\n default: 'translateY(0)',\n ':hover': 'translateY(-2px)',\n },\n },\n // Sizes (padding)\n sizeDefault: {\n padding: spacing.lg,\n },\n sizeCompact: {\n padding: spacing.md,\n },\n sizeFull: {\n padding: spacing.xl,\n },\n // Header\n header: {\n fontSize: typography.fontSizeLg,\n fontWeight: typography.fontWeightSemibold,\n marginBottom: spacing.md,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type CardVariant = 'elevated' | 'outlined' | 'filled' | 'interactive'\nexport type CardSize = 'default' | 'compact' | 'full'\n\ninterface CardProps {\n variant?: CardVariant\n size?: CardSize\n header?: string\n onClick?: () => void\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n compact: styles.sizeCompact,\n full: styles.sizeFull,\n} as const\n\nexport function Card({\n variant = 'outlined',\n size = 'default',\n header,\n onClick,\n children,\n}: CardProps) {\n return (\n <html.div onClick={onClick} style={[styles.base, styles[variant], sizeMap[size]]}>\n {header && <html.div style={styles.header}>{header}</html.div>}\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n gap: spacing.sm,\n cursor: 'pointer',\n fontSize: typography.fontSizeSm,\n color: colors.text,\n lineHeight: typography.lineHeight,\n },\n rootDisabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n },\n box: {\n width: 18,\n height: 18,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n transitionProperty: 'background-color, border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n boxUnchecked: {\n backgroundColor: colors.bg,\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n },\n },\n boxChecked: {\n backgroundColor: colors.accent,\n borderColor: colors.accent,\n },\n check: {\n width: 12,\n height: 12,\n color: colors.accentContrast,\n },\n input: {\n position: 'absolute',\n width: 1,\n height: 1,\n opacity: 0,\n overflow: 'hidden',\n },\n})\n","import {type ReactNode, useState, useCallback} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\ninterface CheckboxProps {\n name?: string\n value?: string\n checked?: boolean\n defaultChecked?: boolean\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void\n children?: ReactNode\n}\n\nexport function Checkbox({\n name,\n value,\n checked: controlledChecked,\n defaultChecked = false,\n disabled = false,\n onChange,\n children,\n}: CheckboxProps) {\n const isControlled = controlledChecked !== undefined\n const [internalChecked, setInternalChecked] = useState(defaultChecked)\n const isChecked = isControlled ? controlledChecked : internalChecked\n\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!isControlled) {\n setInternalChecked(e.target.checked)\n }\n onChange?.(e)\n },\n [isControlled, onChange],\n )\n\n return (\n <html.label style={[styles.root, disabled && styles.rootDisabled]}>\n <html.input\n type=\"checkbox\"\n name={name}\n value={value}\n checked={isControlled ? controlledChecked : undefined}\n defaultChecked={!isControlled ? defaultChecked : undefined}\n disabled={disabled}\n onChange={handleChange}\n style={styles.input}\n />\n <html.span\n style={[styles.box, isChecked ? styles.boxChecked : styles.boxUnchecked]}\n aria-hidden\n >\n <svg\n width={12}\n height={12}\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n style={{opacity: isChecked ? 1 : 0}}\n >\n <polyline\n points=\"2.5 6 5 8.5 9.5 3.5\"\n stroke=\"currentColor\"\n strokeWidth={1.5}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </html.span>\n {children && <html.span>{children}</html.span>}\n </html.label>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n paddingTop: spacing.xl,\n paddingBottom: spacing.xl,\n textAlign: 'center',\n },\n message: {\n fontSize: typography.fontSizeSm,\n color: colors.textMuted,\n lineHeight: typography.lineHeight,\n },\n action: {\n marginTop: spacing.sm,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\ninterface EmptyStateProps {\n message: string\n icon?: ReactNode\n action?: ReactNode\n}\n\nexport function EmptyState({message, icon, action}: EmptyStateProps) {\n return (\n <html.div style={styles.root}>\n {icon}\n <html.p style={styles.message}>{message}</html.p>\n {action && <html.div style={styles.action}>{action}</html.div>}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {typography, typeScale} from './typography.css'\n\nexport const typePresets = css.create({\n // Body\n bodySm: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize3,\n lineHeight: typeScale.lineHeight3,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n bodyMd: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize4,\n lineHeight: typeScale.lineHeight4,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n bodyLg: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize5,\n lineHeight: typeScale.lineHeight5,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n\n // UI\n caption: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize1,\n lineHeight: typeScale.lineHeight1,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingWide,\n },\n label: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize3,\n lineHeight: typeScale.lineHeight3,\n fontWeight: typography.fontWeightMedium,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n code: {\n fontFamily: typography.fontFamilyMono,\n fontSize: typeScale.fontSize3,\n lineHeight: typeScale.lineHeight3,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n overline: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize1,\n lineHeight: typeScale.lineHeight1,\n fontWeight: typography.fontWeightSemibold,\n letterSpacing: typeScale.letterSpacingWide,\n textTransform: 'uppercase' as const,\n },\n\n // Heading\n headingSm: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize6,\n lineHeight: typeScale.lineHeight6,\n fontWeight: typography.fontWeightSemibold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n headingMd: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize7,\n lineHeight: typeScale.lineHeight7,\n fontWeight: typography.fontWeightSemibold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n headingLg: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize8,\n lineHeight: typeScale.lineHeight8,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n headingXl: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize9,\n lineHeight: typeScale.lineHeight9,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n\n // Display (fluid)\n displaySm: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.displaySm,\n lineHeight: 1.2,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n displayMd: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.displayMd,\n lineHeight: 1.15,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n displayLg: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.displayLg,\n lineHeight: 1.1,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n})\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\n\nexport const styles = css.create({\n // Colors\n default: {\n color: colors.text,\n },\n muted: {\n color: colors.textMuted,\n },\n accent: {\n color: colors.accent,\n },\n\n // Alignment\n alignStart: {\n textAlign: 'start',\n },\n alignCenter: {\n textAlign: 'center',\n },\n alignEnd: {\n textAlign: 'end',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {typePresets} from '@duro-app/tokens/tokens/type-presets.css'\nimport {styles} from './styles.css'\n\nexport type HeadingVariant =\n | 'displayLg'\n | 'displayMd'\n | 'displaySm'\n | 'headingXl'\n | 'headingLg'\n | 'headingMd'\n | 'headingSm'\n\ninterface HeadingProps {\n level: 1 | 2 | 3 | 4 | 5 | 6\n variant?: HeadingVariant\n color?: 'default' | 'muted' | 'accent'\n align?: 'start' | 'center' | 'end'\n children: ReactNode\n}\n\nconst defaultVariantMap: Record<number, HeadingVariant> = {\n 1: 'headingXl',\n 2: 'headingLg',\n 3: 'headingMd',\n 4: 'headingSm',\n 5: 'headingSm',\n 6: 'headingSm',\n}\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n} as const\n\nexport function Heading({level, variant, color = 'default', align, children}: HeadingProps) {\n const resolvedVariant = variant ?? defaultVariantMap[level]\n const style = [typePresets[resolvedVariant], styles[color], align && alignMap[align]]\n\n if (level === 1) return <html.h1 style={style}>{children}</html.h1>\n if (level === 2) return <html.h2 style={style}>{children}</html.h2>\n if (level === 3) return <html.h3 style={style}>{children}</html.h3>\n if (level === 4) return <html.h4 style={style}>{children}</html.h4>\n if (level === 5) return <html.h5 style={style}>{children}</html.h5>\n return <html.h6 style={style}>{children}</html.h6>\n}\n","import {createContext, useContext} from 'react'\n\ninterface FieldContextValue {\n controlId: string\n descriptionId: string\n errorId: string\n invalid: boolean\n}\n\nexport const FieldContext = createContext<FieldContextValue | null>(null)\n\nexport function useFieldContext() {\n return useContext(FieldContext)\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n gap: spacing.xs,\n },\n label: {\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n color: colors.text,\n },\n description: {\n fontSize: typography.fontSizeXs,\n color: colors.textMuted,\n },\n error: {\n fontSize: typography.fontSizeXs,\n color: colors.error,\n },\n})\n","import {type ReactNode, useId, useMemo} from 'react'\nimport {html} from 'react-strict-dom'\nimport {FieldContext, useFieldContext} from './FieldContext'\nimport {styles} from './styles.css'\n\n// --- Root ---\ninterface RootProps {\n invalid?: boolean\n children: ReactNode\n}\n\nfunction Root({invalid = false, children}: RootProps) {\n const id = useId()\n const ctx = useMemo(\n () => ({\n controlId: `${id}-control`,\n descriptionId: `${id}-description`,\n errorId: `${id}-error`,\n invalid,\n }),\n [id, invalid],\n )\n\n return (\n <FieldContext.Provider value={ctx}>\n <html.div style={styles.root}>{children}</html.div>\n </FieldContext.Provider>\n )\n}\n\n// --- Label ---\ninterface LabelProps {\n children: ReactNode\n}\n\nfunction Label({children}: LabelProps) {\n const ctx = useFieldContext()\n return (\n <html.label for={ctx?.controlId} style={styles.label}>\n {children}\n </html.label>\n )\n}\n\n// --- Description ---\ninterface DescriptionProps {\n children: ReactNode\n}\n\nfunction Description({children}: DescriptionProps) {\n const ctx = useFieldContext()\n return (\n <html.span id={ctx?.descriptionId} style={styles.description}>\n {children}\n </html.span>\n )\n}\n\n// --- Error ---\ninterface ErrorProps {\n children?: ReactNode\n}\n\nfunction Error({children}: ErrorProps) {\n const ctx = useFieldContext()\n if (!ctx?.invalid && !children) return null\n\n return (\n <html.span id={ctx?.errorId} role=\"alert\" style={styles.error}>\n {children}\n </html.span>\n )\n}\n\nexport const Field = {\n Root,\n Label,\n Description,\n Error,\n}\n","import {createContext, useContext} from 'react'\n\ninterface InputGroupContextValue {\n inGroup: boolean\n}\n\nexport const InputGroupContext = createContext<InputGroupContextValue | null>(null)\n\nexport function useInputGroupContext() {\n return useContext(InputGroupContext)\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n width: '100%',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n color: colors.text,\n backgroundColor: colors.bg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 1,\n },\n },\n default: {\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n ':focus': colors.accent,\n },\n },\n error: {\n borderColor: {\n default: colors.error,\n ':focus': colors.error,\n },\n },\n inGroup: {\n borderWidth: 0,\n borderRadius: 0,\n outlineWidth: 0,\n },\n})\n","import {html} from 'react-strict-dom'\nimport {useFieldContext} from '../Field/FieldContext'\nimport {useInputGroupContext} from '../InputGroup/InputGroupContext'\nimport {styles} from './styles.css'\n\ntype StrictInputProps = React.ComponentProps<typeof html.input>\nexport type InputType = NonNullable<StrictInputProps['type']>\n\nexport type InputVariant = 'default' | 'error'\n\ninterface InputProps {\n variant?: InputVariant\n type?: InputType\n name?: string\n placeholder?: string\n required?: boolean\n minLength?: number\n pattern?: string\n autoComplete?:\n | 'on'\n | 'off'\n | 'email'\n | 'username'\n | 'current-password'\n | 'new-password'\n | 'name'\n | 'tel'\n | 'url'\n value?: string\n defaultValue?: string\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void\n}\n\nexport function Input({\n variant = 'default',\n type = 'text',\n name,\n placeholder,\n required,\n minLength,\n pattern,\n autoComplete,\n value,\n defaultValue,\n disabled,\n onChange,\n}: InputProps) {\n const ctx = useFieldContext()\n const groupCtx = useInputGroupContext()\n\n // react-strict-dom omits web-only `pattern` from its types, but the\n // underlying DOM element supports it. Type-assert to pass it through.\n const extraProps = pattern !== undefined ? {pattern} : undefined\n\n return (\n <html.input\n id={ctx?.controlId}\n type={type}\n name={name}\n placeholder={placeholder}\n required={required}\n minLength={minLength}\n autoComplete={autoComplete}\n value={value}\n defaultValue={defaultValue}\n disabled={disabled}\n aria-describedby={\n ctx ? `${ctx.descriptionId} ${ctx.invalid ? ctx.errorId : ''}`.trim() : undefined\n }\n aria-invalid={ctx?.invalid || variant === 'error' || undefined}\n onChange={onChange}\n style={[styles.base, styles[variant], groupCtx?.inGroup && styles.inGroup]}\n {...(extraProps as Record<string, unknown>)}\n />\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n wrapper: {\n display: 'flex',\n alignItems: 'stretch',\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':focus-within': colors.accent,\n },\n borderRadius: radii.sm,\n overflow: 'hidden',\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n addon: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n backgroundColor: colors.bgCardHover,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.textMuted,\n userSelect: 'none',\n borderWidth: 0,\n },\n addonStart: {\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n },\n addonEnd: {\n borderLeftWidth: 1,\n borderLeftStyle: 'solid',\n borderLeftColor: colors.border,\n },\n addonClickable: {\n cursor: 'pointer',\n backgroundColor: {\n default: colors.bgCardHover,\n ':hover': colors.bgCard,\n ':active': colors.bg,\n },\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n addonDisabled: {\n opacity: 0.4,\n cursor: 'not-allowed',\n },\n})\n","import type {ReactNode} from 'react'\nimport {useMemo} from 'react'\nimport {html} from 'react-strict-dom'\nimport {InputGroupContext} from './InputGroupContext'\nimport {styles} from './styles.css'\n\n// --- Root ---\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const ctx = useMemo(() => ({inGroup: true}), [])\n\n return (\n <InputGroupContext.Provider value={ctx}>\n <html.div style={styles.wrapper}>{children}</html.div>\n </InputGroupContext.Provider>\n )\n}\n\n// --- Addon ---\ninterface AddonProps {\n position?: 'start' | 'end'\n onClick?: () => void\n disabled?: boolean\n children: ReactNode\n}\n\nfunction Addon({position = 'end', onClick, disabled, children}: AddonProps) {\n const positionStyle = position === 'start' ? styles.addonStart : styles.addonEnd\n const style = [\n styles.addon,\n positionStyle,\n onClick && !disabled && styles.addonClickable,\n disabled && styles.addonDisabled,\n ]\n\n if (onClick) {\n return (\n <html.button type=\"button\" onClick={onClick} disabled={disabled} style={style}>\n {children}\n </html.button>\n )\n }\n\n return <html.span style={style}>{children}</html.span>\n}\n\nexport const InputGroup = {\n Root,\n Addon,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n cursor: 'pointer',\n textDecoration: 'none',\n transitionProperty: 'background-color, border-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n sizeDefault: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n },\n sizeSmall: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n primary: {\n backgroundColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n color: colors.accentContrast,\n },\n secondary: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n color: colors.textMuted,\n },\n fullWidth: {\n width: '100%',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type LinkButtonVariant = 'primary' | 'secondary'\nexport type LinkButtonSize = 'default' | 'small'\n\ninterface LinkButtonProps {\n href: string\n variant?: LinkButtonVariant\n size?: LinkButtonSize\n fullWidth?: boolean\n target?: '_blank' | '_self'\n rel?: string\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n small: styles.sizeSmall,\n} as const\n\nexport function LinkButton({\n href,\n variant = 'primary',\n size = 'default',\n fullWidth = false,\n target,\n rel,\n children,\n}: LinkButtonProps) {\n return (\n <html.a\n href={href}\n target={target}\n rel={rel}\n style={[styles.base, sizeMap[size], styles[variant], fullWidth && styles.fullWidth]}\n >\n {children}\n </html.a>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n trigger: {\n display: 'inline-flex',\n alignItems: 'center',\n gap: spacing.sm,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.text,\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color',\n transitionDuration: '150ms',\n },\n backdrop: {\n position: 'fixed',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n zIndex: 49,\n },\n popup: {\n position: 'absolute',\n top: '100%',\n left: 0,\n marginTop: spacing.xs,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n boxShadow: shadows.md,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n minWidth: 160,\n zIndex: 50,\n },\n popupEnd: {\n left: 'auto',\n right: 0,\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n fontFamily: typography.fontFamily,\n color: colors.text,\n borderRadius: radii.sm,\n cursor: 'pointer',\n backgroundColor: 'transparent',\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n itemHighlighted: {\n backgroundColor: colors.bgCardHover,\n },\n linkItem: {\n textDecoration: 'none',\n color: {\n default: colors.text,\n ':hover': colors.text,\n },\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface MenuContextValue {\n open: boolean\n toggle: () => void\n close: () => void\n menuId: string\n highlightedId: string | null\n setHighlightedId: (id: string | null) => void\n registerItem: (id: string, element: HTMLElement) => () => void\n triggerRef: React.RefObject<HTMLButtonElement | null>\n}\n\nexport const MenuContext = createContext<MenuContextValue | null>(null)\n\nexport function useMenu() {\n const ctx = useContext(MenuContext)\n if (!ctx) throw new Error('Menu compound components must be used within Menu.Root')\n return ctx\n}\n","import {useState, useCallback, useRef, useId, useEffect} from 'react'\nimport type {MenuContextValue} from './MenuContext'\n\nexport function useMenuRoot() {\n const [open, setOpen] = useState(false)\n const [highlightedId, setHighlightedId] = useState<string | null>(null)\n const menuId = useId()\n const rootRef = useRef<HTMLDivElement>(null)\n const triggerRef = useRef<HTMLButtonElement | null>(null)\n const itemsRef = useRef(new Map<string, HTMLElement>())\n const orderRef = useRef<string[]>([])\n const needsInitialHighlightRef = useRef(false)\n\n const close = useCallback(() => {\n setOpen(false)\n setHighlightedId(null)\n needsInitialHighlightRef.current = false\n triggerRef.current?.focus()\n }, [])\n\n const toggle = useCallback(() => {\n setOpen((prev) => {\n if (!prev) {\n needsInitialHighlightRef.current = true\n } else {\n setHighlightedId(null)\n needsInitialHighlightRef.current = false\n }\n return !prev\n })\n }, [])\n\n // Highlight the first item after items register on open.\n // Child effects (item registration) run before this parent effect,\n // so orderRef is populated by the time this runs.\n useEffect(() => {\n if (open && needsInitialHighlightRef.current) {\n needsInitialHighlightRef.current = false\n const order = orderRef.current\n if (order.length > 0) {\n setHighlightedId(order[0])\n }\n }\n }, [open])\n\n const registerItem = useCallback((id: string, element: HTMLElement) => {\n itemsRef.current.set(id, element)\n const map = itemsRef.current\n const ids = [...map.keys()]\n ids.sort((a, b) => {\n const elA = map.get(a)\n const elB = map.get(b)\n if (!elA || !elB) return 0\n return elA.compareDocumentPosition(elB) & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1\n })\n orderRef.current = ids\n return () => {\n itemsRef.current.delete(id)\n orderRef.current = orderRef.current.filter((i) => i !== id)\n }\n }, [])\n\n // Native keydown for full KeyboardEvent access (preventDefault)\n useEffect(() => {\n const root = rootRef.current\n if (!root || !open) return\n\n function handleKeyDown(e: KeyboardEvent) {\n const order = orderRef.current\n if (order.length === 0) return\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : -1\n return order[(idx + 1) % order.length]\n })\n break\n }\n case 'ArrowUp': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : 0\n return order[(idx - 1 + order.length) % order.length]\n })\n break\n }\n case 'Home': {\n e.preventDefault()\n setHighlightedId(order[0])\n break\n }\n case 'End': {\n e.preventDefault()\n setHighlightedId(order[order.length - 1])\n break\n }\n case 'Enter':\n case ' ': {\n e.preventDefault()\n const items = itemsRef.current\n setHighlightedId((prev) => {\n if (prev) {\n const el = items.get(prev)\n el?.click()\n }\n return prev\n })\n break\n }\n case 'Escape':\n case 'Tab': {\n close()\n break\n }\n }\n }\n\n root.addEventListener('keydown', handleKeyDown)\n return () => root.removeEventListener('keydown', handleKeyDown)\n }, [open, close])\n\n const ctx: MenuContextValue = {\n open,\n toggle,\n close,\n menuId,\n highlightedId,\n setHighlightedId,\n registerItem,\n triggerRef,\n }\n\n return {ctx, rootRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {MenuContext, useMenu} from './MenuContext'\nimport {useMenuRoot} from './useMenuRoot'\n\n// --- Root ---\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const {ctx, rootRef} = useMenuRoot()\n\n return (\n <MenuContext.Provider value={ctx}>\n <html.div ref={rootRef} style={styles.root}>\n {children}\n </html.div>\n </MenuContext.Provider>\n )\n}\n\n// --- Trigger ---\nfunction Trigger({children}: {children: ReactNode}) {\n const {open, toggle, menuId, triggerRef} = useMenu()\n const localRef = useRef<HTMLButtonElement>(null)\n\n // Sync local ref to context triggerRef\n useEffect(() => {\n triggerRef.current = localRef.current\n })\n\n return (\n <html.button\n ref={localRef}\n type=\"button\"\n onClick={toggle}\n aria-expanded={open}\n aria-haspopup=\"menu\"\n aria-controls={open ? menuId : undefined}\n style={styles.trigger}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Popup ---\ninterface PopupProps {\n children: ReactNode\n align?: 'start' | 'end'\n}\n\nfunction Popup({children, align = 'start'}: PopupProps) {\n const {open, close, menuId, highlightedId} = useMenu()\n\n if (!open) return null\n\n return (\n <>\n <html.div style={styles.backdrop} onClick={close} />\n <html.div\n id={menuId}\n role=\"menu\"\n aria-activedescendant={highlightedId ?? undefined}\n style={[styles.popup, align === 'end' && styles.popupEnd]}\n >\n {children}\n </html.div>\n </>\n )\n}\n\n// --- Item ---\ninterface ItemProps {\n onClick?: () => void\n children: ReactNode\n}\n\nfunction Item({onClick, children}: ItemProps) {\n const {close, highlightedId, setHighlightedId, registerItem} = useMenu()\n const id = useId()\n const ref = useRef<HTMLDivElement>(null)\n const isHighlighted = highlightedId === id\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, el)\n }, [id, registerItem])\n\n const handleClick = () => {\n onClick?.()\n close()\n }\n\n return (\n <html.div\n ref={ref}\n id={id}\n role=\"menuitem\"\n onClick={handleClick}\n onPointerEnter={() => setHighlightedId(id)}\n style={[styles.item, isHighlighted && styles.itemHighlighted]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- LinkItem ---\ninterface LinkItemProps {\n href: string\n children: ReactNode\n}\n\nfunction LinkItem({href, children}: LinkItemProps) {\n const {close, highlightedId, setHighlightedId, registerItem} = useMenu()\n const id = useId()\n const ref = useRef<HTMLAnchorElement>(null)\n const isHighlighted = highlightedId === id\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, el)\n }, [id, registerItem])\n\n return (\n <html.a\n ref={ref}\n id={id}\n href={href}\n onClick={close}\n role=\"menuitem\"\n onPointerEnter={() => setHighlightedId(id)}\n style={[styles.item, styles.linkItem, isHighlighted && styles.itemHighlighted]}\n >\n {children}\n </html.a>\n )\n}\n\nexport const Menu = {\n Root,\n Trigger,\n Popup,\n Item,\n LinkItem,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {radii} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n overflow: 'hidden',\n },\n viewport: {\n width: '100%',\n height: '100%',\n overflowX: 'auto',\n overflowY: 'auto',\n // Hide native scrollbar\n scrollbarWidth: 'none',\n },\n content: {\n minWidth: '100%',\n minHeight: '100%',\n },\n scrollbar: {\n position: 'absolute',\n zIndex: 1,\n display: 'flex',\n touchAction: 'none',\n userSelect: 'none',\n transitionProperty: 'opacity',\n transitionDuration: '200ms',\n transitionTimingFunction: 'ease',\n },\n scrollbarVertical: {\n top: 0,\n right: 0,\n bottom: 0,\n width: 8,\n flexDirection: 'column',\n paddingTop: 2,\n paddingBottom: 2,\n paddingRight: 2,\n },\n scrollbarHorizontal: {\n left: 0,\n right: 0,\n bottom: 0,\n height: 8,\n flexDirection: 'row',\n paddingLeft: 2,\n paddingRight: 2,\n paddingBottom: 2,\n },\n scrollbarHidden: {\n opacity: 0,\n },\n scrollbarVisible: {\n opacity: 1,\n },\n thumb: {\n position: 'relative',\n flex: 1,\n backgroundColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n },\n borderRadius: radii.full,\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n // Dynamic styles — simple identifier params only (StyleX constraint)\n viewportMaxHeight: (maxHeight: number | string) => ({\n maxHeight,\n }),\n thumbVertical: (height: string, transform: string) => ({\n height,\n transform,\n }),\n thumbHorizontal: (width: string, transform: string) => ({\n width,\n transform,\n }),\n})\n","import {createContext, useContext} from 'react'\n\nexport interface ScrollAreaContextValue {\n viewportRef: React.RefObject<HTMLDivElement | null>\n contentRef: React.RefObject<HTMLDivElement | null>\n scrollTop: number\n scrollLeft: number\n scrollHeight: number\n scrollWidth: number\n clientHeight: number\n clientWidth: number\n scrolling: boolean\n}\n\nexport const ScrollAreaContext = createContext<ScrollAreaContextValue | null>(null)\n\nexport function useScrollArea() {\n const ctx = useContext(ScrollAreaContext)\n if (!ctx) throw new Error('ScrollArea compound components must be used within ScrollArea.Root')\n return ctx\n}\n","import {useState, useCallback, useRef, useEffect} from 'react'\nimport type {ScrollAreaContextValue} from './ScrollAreaContext'\n\nexport function useScrollAreaRoot(): ScrollAreaContextValue {\n const viewportRef = useRef<HTMLDivElement | null>(null)\n const contentRef = useRef<HTMLDivElement | null>(null)\n const [scrollTop, setScrollTop] = useState(0)\n const [scrollLeft, setScrollLeft] = useState(0)\n const [scrollHeight, setScrollHeight] = useState(0)\n const [scrollWidth, setScrollWidth] = useState(0)\n const [clientHeight, setClientHeight] = useState(0)\n const [clientWidth, setClientWidth] = useState(0)\n const [scrolling, setScrolling] = useState(false)\n const scrollTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const handleScroll = useCallback(() => {\n const vp = viewportRef.current\n if (!vp) return\n\n setScrollTop(vp.scrollTop)\n setScrollLeft(vp.scrollLeft)\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n setScrolling(true)\n\n if (scrollTimerRef.current) clearTimeout(scrollTimerRef.current)\n scrollTimerRef.current = setTimeout(() => setScrolling(false), 1000)\n }, [])\n\n // Observe viewport size changes\n useEffect(() => {\n const vp = viewportRef.current\n if (!vp) return\n\n const observer = new ResizeObserver(() => {\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n })\n observer.observe(vp)\n // Initial measurement\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n\n return () => observer.disconnect()\n }, [])\n\n // Attach scroll listener directly to ensure we capture it\n useEffect(() => {\n const vp = viewportRef.current\n if (!vp) return\n vp.addEventListener('scroll', handleScroll, {passive: true})\n return () => vp.removeEventListener('scroll', handleScroll)\n }, [handleScroll])\n\n return {\n viewportRef,\n contentRef,\n scrollTop,\n scrollLeft,\n scrollHeight,\n scrollWidth,\n clientHeight,\n clientWidth,\n scrolling,\n }\n}\n","import {type ReactNode, useRef, useCallback} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {ScrollAreaContext, useScrollArea} from './ScrollAreaContext'\nimport {useScrollAreaRoot} from './useScrollAreaRoot'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const ctx = useScrollAreaRoot()\n\n return (\n <ScrollAreaContext.Provider value={ctx}>\n <html.div style={styles.root}>{children}</html.div>\n </ScrollAreaContext.Provider>\n )\n}\n\n// --- Viewport ---\n\ninterface ViewportProps {\n children: ReactNode\n maxHeight?: number | string\n}\n\nfunction Viewport({children, maxHeight}: ViewportProps) {\n const {viewportRef} = useScrollArea()\n\n return (\n <html.div\n ref={viewportRef}\n style={[styles.viewport, maxHeight != null && styles.viewportMaxHeight(maxHeight)]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Content ---\n\ninterface ContentProps {\n children: ReactNode\n}\n\nfunction Content({children}: ContentProps) {\n const {contentRef} = useScrollArea()\n return (\n <html.div ref={contentRef} style={styles.content}>\n {children}\n </html.div>\n )\n}\n\n// --- Scrollbar ---\n\ntype ScrollbarOrientation = 'vertical' | 'horizontal'\n\ninterface ScrollbarProps {\n orientation?: ScrollbarOrientation\n children: ReactNode\n}\n\nfunction Scrollbar({orientation = 'vertical', children}: ScrollbarProps) {\n const {scrolling, scrollHeight, scrollWidth, clientHeight, clientWidth} = useScrollArea()\n\n // Hide scrollbar when content fits\n const hasOverflow =\n orientation === 'vertical' ? scrollHeight > clientHeight : scrollWidth > clientWidth\n\n if (!hasOverflow) return null\n\n return (\n <html.div\n style={[\n styles.scrollbar,\n orientation === 'vertical' ? styles.scrollbarVertical : styles.scrollbarHorizontal,\n scrolling ? styles.scrollbarVisible : styles.scrollbarHidden,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Thumb ---\n\ninterface ThumbProps {\n orientation?: ScrollbarOrientation\n}\n\nfunction Thumb({orientation = 'vertical'}: ThumbProps) {\n const {viewportRef, scrollTop, scrollLeft, scrollHeight, scrollWidth, clientHeight, clientWidth} =\n useScrollArea()\n const draggingRef = useRef(false)\n const startPosRef = useRef(0)\n const startScrollRef = useRef(0)\n\n const isVertical = orientation === 'vertical'\n\n const thumbSizePercent = isVertical\n ? Math.max((clientHeight / scrollHeight) * 100, 10)\n : Math.max((clientWidth / scrollWidth) * 100, 10)\n\n const maxScroll = isVertical ? scrollHeight - clientHeight : scrollWidth - clientWidth\n const trackSize = isVertical ? clientHeight : clientWidth\n const thumbPixelSize = (thumbSizePercent / 100) * trackSize\n const scrollOffset = isVertical ? scrollTop : scrollLeft\n const thumbOffset = maxScroll > 0 ? (scrollOffset / maxScroll) * (trackSize - thumbPixelSize) : 0\n\n const thumbStyle = isVertical\n ? styles.thumbVertical(`${thumbSizePercent}%`, `translateY(${thumbOffset}px)`)\n : styles.thumbHorizontal(`${thumbSizePercent}%`, `translateX(${thumbOffset}px)`)\n\n const handlePointerDown = useCallback(\n (e: React.PointerEvent) => {\n e.preventDefault()\n draggingRef.current = true\n startPosRef.current = isVertical ? e.clientY : e.clientX\n startScrollRef.current = isVertical\n ? (viewportRef.current?.scrollTop ?? 0)\n : (viewportRef.current?.scrollLeft ?? 0)\n ;(e.target as HTMLElement).setPointerCapture(e.pointerId)\n },\n [isVertical, viewportRef],\n )\n\n const handlePointerMove = useCallback(\n (e: React.PointerEvent) => {\n if (!draggingRef.current) return\n const vp = viewportRef.current\n if (!vp) return\n\n const delta = (isVertical ? e.clientY : e.clientX) - startPosRef.current\n const scrollRatio = maxScroll / (trackSize - thumbPixelSize)\n const scrollDelta = delta * scrollRatio\n\n if (isVertical) {\n vp.scrollTop = startScrollRef.current + scrollDelta\n } else {\n vp.scrollLeft = startScrollRef.current + scrollDelta\n }\n },\n [isVertical, maxScroll, trackSize, thumbPixelSize, viewportRef],\n )\n\n const handlePointerUp = useCallback(() => {\n draggingRef.current = false\n }, [])\n\n return (\n <html.div\n onPointerDown={handlePointerDown}\n onPointerMove={handlePointerMove}\n onPointerUp={handlePointerUp}\n style={[styles.thumb, thumbStyle]}\n />\n )\n}\n\nexport const ScrollArea = {\n Root,\n Viewport,\n Content,\n Scrollbar,\n Thumb,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n trigger: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n gap: spacing.sm,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.text,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':hover': colors.accent,\n },\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n },\n value: {\n color: colors.text,\n },\n placeholder: {\n color: colors.textMuted,\n },\n icon: {\n display: 'flex',\n alignItems: 'center',\n color: colors.textMuted,\n },\n backdrop: {\n position: 'fixed',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n zIndex: 49,\n },\n popup: {\n position: 'absolute',\n top: '100%',\n left: 0,\n marginTop: spacing.xs,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n boxShadow: shadows.md,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n minWidth: 120,\n zIndex: 50,\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n fontFamily: typography.fontFamily,\n color: colors.text,\n borderRadius: radii.sm,\n cursor: 'pointer',\n backgroundColor: 'transparent',\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n itemSelected: {\n color: colors.accent,\n fontWeight: typography.fontWeightMedium,\n },\n itemHighlighted: {\n backgroundColor: colors.bgCardHover,\n },\n hidden: {\n display: 'none',\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface SelectContextValue {\n open: boolean\n toggle: () => void\n close: () => void\n value: string | null\n setValue: (value: string) => void\n labels: Record<string, string>\n registerLabel: (value: string, label: string) => void\n listboxId: string\n highlightedId: string | null\n setHighlightedId: (id: string | null) => void\n registerItem: (id: string, value: string, element: HTMLElement) => () => void\n triggerRef: React.RefObject<HTMLButtonElement | null>\n}\n\nexport const SelectContext = createContext<SelectContextValue | null>(null)\n\nexport function useSelect() {\n const ctx = useContext(SelectContext)\n if (!ctx) throw new Error('Select compound components must be used within Select.Root')\n return ctx\n}\n","import {useState, useCallback} from 'react'\n\nexport function useControllableValue<T>(\n controlledValue: T | undefined,\n defaultValue: T,\n onChange?: (value: T) => void,\n) {\n const [internal, setInternal] = useState(defaultValue)\n const value = controlledValue !== undefined ? controlledValue : internal\n const setValue = useCallback(\n (v: T) => {\n if (controlledValue === undefined) setInternal(v)\n onChange?.(v)\n },\n [controlledValue, onChange],\n )\n return [value, setValue] as const\n}\n","import {useState, useCallback, useMemo, useRef, useId, useEffect} from 'react'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport type {SelectContextValue} from './SelectContext'\n\ninterface UseSelectRootOptions {\n defaultValue?: string\n value?: string\n onValueChange?: (value: string | null) => void\n initialLabels?: Record<string, string>\n}\n\nexport function useSelectRoot({\n defaultValue,\n value: controlledValue,\n onValueChange,\n initialLabels,\n}: UseSelectRootOptions) {\n const [value, setValue] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange,\n )\n const [open, setOpen] = useState(false)\n const [labels, setLabels] = useState<Record<string, string>>(initialLabels ?? {})\n const [highlightedId, setHighlightedId] = useState<string | null>(null)\n const listboxId = useId()\n const rootRef = useRef<HTMLDivElement>(null)\n const triggerRef = useRef<HTMLButtonElement | null>(null)\n const itemsRef = useRef(new Map<string, {value: string; element: HTMLElement}>())\n const orderRef = useRef<string[]>([])\n\n const close = useCallback(() => {\n setOpen(false)\n setHighlightedId(null)\n triggerRef.current?.focus()\n }, [])\n\n const toggle = useCallback(() => {\n setOpen((prev) => {\n if (!prev) {\n const items = itemsRef.current\n const order = orderRef.current\n let found: string | null = null\n for (const id of order) {\n const item = items.get(id)\n if (item && item.value === value) {\n found = id\n break\n }\n }\n setHighlightedId(found ?? (order.length > 0 ? order[0] : null))\n } else {\n setHighlightedId(null)\n }\n return !prev\n })\n }, [value])\n\n const registerLabel = useCallback((v: string, label: string) => {\n setLabels((prev) => {\n if (prev[v] === label) return prev\n return {...prev, [v]: label}\n })\n }, [])\n\n const registerItem = useCallback((id: string, itemValue: string, element: HTMLElement) => {\n itemsRef.current.set(id, {value: itemValue, element})\n const map = itemsRef.current\n const ids = [...map.keys()]\n ids.sort((a, b) => {\n const elA = map.get(a)?.element\n const elB = map.get(b)?.element\n if (!elA || !elB) return 0\n return elA.compareDocumentPosition(elB) & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1\n })\n orderRef.current = ids\n return () => {\n itemsRef.current.delete(id)\n orderRef.current = orderRef.current.filter((i) => i !== id)\n }\n }, [])\n\n // Native keydown for full KeyboardEvent access (preventDefault)\n useEffect(() => {\n const root = rootRef.current\n if (!root || !open) return\n\n function handleKeyDown(e: KeyboardEvent) {\n const order = orderRef.current\n const items = itemsRef.current\n if (order.length === 0) return\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : -1\n return order[(idx + 1) % order.length]\n })\n break\n }\n case 'ArrowUp': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : 0\n return order[(idx - 1 + order.length) % order.length]\n })\n break\n }\n case 'Home': {\n e.preventDefault()\n setHighlightedId(order[0])\n break\n }\n case 'End': {\n e.preventDefault()\n setHighlightedId(order[order.length - 1])\n break\n }\n case 'Enter':\n case ' ': {\n e.preventDefault()\n setHighlightedId((prev) => {\n if (prev) {\n const item = items.get(prev)\n if (item) {\n setValue(item.value)\n close()\n }\n }\n return prev\n })\n break\n }\n case 'Escape':\n case 'Tab': {\n close()\n break\n }\n }\n }\n\n root.addEventListener('keydown', handleKeyDown)\n return () => root.removeEventListener('keydown', handleKeyDown)\n }, [open, close, setValue])\n\n const ctx: SelectContextValue = useMemo(\n () => ({\n open,\n toggle,\n close,\n value,\n setValue,\n labels,\n registerLabel,\n listboxId,\n highlightedId,\n setHighlightedId,\n registerItem,\n triggerRef,\n }),\n [\n open,\n toggle,\n close,\n value,\n setValue,\n labels,\n registerLabel,\n listboxId,\n highlightedId,\n setHighlightedId,\n registerItem,\n ],\n )\n\n return {ctx, rootRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {SelectContext, useSelect} from './SelectContext'\nimport {useSelectRoot} from './useSelectRoot'\n\n// --- Root ---\ninterface RootProps {\n name?: string\n defaultValue?: string\n value?: string\n onValueChange?: (value: string | null) => void\n initialLabels?: Record<string, string>\n children: ReactNode\n}\n\nfunction Root({name, defaultValue, value, onValueChange, initialLabels, children}: RootProps) {\n const {ctx, rootRef} = useSelectRoot({defaultValue, value, onValueChange, initialLabels})\n\n return (\n <SelectContext.Provider value={ctx}>\n <html.div ref={rootRef} style={styles.root}>\n {name && <html.input type=\"hidden\" name={name} value={ctx.value ?? ''} />}\n {children}\n </html.div>\n </SelectContext.Provider>\n )\n}\n\n// --- Trigger ---\nfunction Trigger({children}: {children: ReactNode}) {\n const {open, toggle, listboxId, highlightedId, triggerRef} = useSelect()\n const localRef = useRef<HTMLButtonElement>(null)\n\n // Sync local ref to context triggerRef\n useEffect(() => {\n triggerRef.current = localRef.current\n })\n\n return (\n <html.button\n ref={localRef}\n type=\"button\"\n role={'combobox' as 'listbox'}\n onClick={toggle}\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-controls={open ? listboxId : undefined}\n aria-activedescendant={highlightedId ?? undefined}\n style={styles.trigger}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Value ---\nfunction Value({placeholder}: {placeholder?: string}) {\n const {value, labels} = useSelect()\n const display = value ? (labels[value] ?? value) : null\n\n return (\n <html.span style={display ? styles.value : styles.placeholder}>\n {display ?? placeholder}\n </html.span>\n )\n}\n\n// --- Icon ---\nfunction Icon({children}: {children?: ReactNode}) {\n return (\n <html.span style={styles.icon}>\n {children ?? (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n aria-hidden=\"true\"\n >\n <path d=\"M6 9l6 6 6-6\" />\n </svg>\n )}\n </html.span>\n )\n}\n\n// --- Popup ---\nfunction Popup({children}: {children: ReactNode}) {\n const {open, close, listboxId} = useSelect()\n\n return (\n <>\n {open && <html.div style={styles.backdrop} onClick={close} />}\n <html.div\n id={listboxId}\n role=\"listbox\"\n aria-hidden={!open}\n style={[styles.popup, !open && styles.hidden]}\n >\n {children}\n </html.div>\n </>\n )\n}\n\n// --- Item ---\ninterface ItemProps {\n value: string\n children: ReactNode\n}\n\nfunction Item({value: itemValue, children}: ItemProps) {\n const {\n value: selectedValue,\n setValue,\n close,\n registerLabel,\n highlightedId,\n setHighlightedId,\n registerItem,\n } = useSelect()\n const id = useId()\n const ref = useRef<HTMLDivElement>(null)\n const isSelected = selectedValue === itemValue\n const isHighlighted = highlightedId === id\n\n // Register label from DOM text content (works with both string and JSX children)\n useEffect(() => {\n const el = ref.current\n if (!el) return\n const text = el.textContent\n if (text) registerLabel(itemValue, text)\n }, [itemValue, registerLabel])\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, itemValue, el)\n }, [id, itemValue, registerItem])\n\n const handleClick = () => {\n setValue(itemValue)\n close()\n }\n\n return (\n <html.div\n ref={ref}\n id={id}\n role=\"option\"\n aria-selected={isSelected}\n onClick={handleClick}\n onPointerEnter={() => setHighlightedId(id)}\n style={[\n styles.item,\n isSelected && styles.itemSelected,\n isHighlighted && styles.itemHighlighted,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- ItemText ---\nfunction ItemText({children}: {children: ReactNode}) {\n return <html.span>{children}</html.span>\n}\n\nexport const Select = {\n Root,\n Trigger,\n Value,\n Icon,\n Popup,\n Item,\n ItemText,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n gap: 0,\n },\n group: {\n display: 'flex',\n flexDirection: 'column',\n },\n groupTrigger: {\n display: 'flex',\n alignItems: 'center',\n gap: spacing.xs,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeXs,\n fontWeight: typography.fontWeightSemibold,\n textTransform: 'uppercase' as const,\n letterSpacing: '0.05em',\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: 'transparent',\n borderWidth: 0,\n cursor: 'pointer',\n transitionProperty: 'color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n groupTriggerActive: {\n color: colors.text,\n },\n chevron: {\n display: 'inline-flex',\n alignItems: 'center',\n transitionProperty: 'transform',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n chevronOpen: {\n transform: 'rotate(90deg)',\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: '6px',\n paddingBottom: '6px',\n paddingLeft: spacing.lg,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightNormal,\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 0,\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'color, background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n textAlign: 'left' as const,\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n },\n itemActive: {\n color: colors.accent,\n fontWeight: typography.fontWeightMedium,\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface SideNavContextValue {\n activeValue: string | null\n onSelect: (value: string) => void\n expandedGroups: Set<string>\n toggleGroup: (group: string) => void\n registerItem: (value: string) => () => void\n orderRef: React.RefObject<string[]>\n}\n\nexport const SideNavContext = createContext<SideNavContextValue | null>(null)\n\nexport function useSideNav() {\n const ctx = useContext(SideNavContext)\n if (!ctx) throw new Error('SideNav compound components must be used within SideNav.Root')\n return ctx\n}\n","import {type ReactNode, useState, useCallback, useRef, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport {SideNavContext, useSideNav} from './SideNavContext'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n}\n\nfunction Root({children, value: controlledValue, defaultValue, onValueChange}: RootProps) {\n const [activeValue, onSelect] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange\n ? (v) => {\n if (v !== null) onValueChange(v)\n }\n : undefined,\n )\n const [expandedGroups, setExpandedGroups] = useState<Set<string>>(new Set())\n const orderRef = useRef<string[]>([])\n\n const toggleGroup = useCallback((group: string) => {\n setExpandedGroups((prev) => {\n const next = new Set(prev)\n if (next.has(group)) {\n next.delete(group)\n } else {\n next.add(group)\n }\n return next\n })\n }, [])\n\n const registerItem = useCallback((value: string) => {\n if (!orderRef.current.includes(value)) {\n orderRef.current.push(value)\n }\n return () => {\n orderRef.current = orderRef.current.filter((v) => v !== value)\n }\n }, [])\n\n // Auto-expand group containing active value\n useEffect(() => {\n if (activeValue) {\n setExpandedGroups((prev) => {\n // We don't know which group it belongs to here — Group handles this\n return prev\n })\n }\n }, [activeValue])\n\n return (\n <SideNavContext.Provider\n value={{activeValue, onSelect, expandedGroups, toggleGroup, registerItem, orderRef}}\n >\n <html.nav role=\"navigation\" style={styles.root}>\n {children}\n </html.nav>\n </SideNavContext.Provider>\n )\n}\n\n// --- Group ---\n\ninterface GroupProps {\n children: ReactNode\n label: string\n groupKey?: string\n defaultExpanded?: boolean\n}\n\nfunction Group({children, label, groupKey, defaultExpanded}: GroupProps) {\n const key = groupKey ?? label\n const {expandedGroups, toggleGroup, activeValue} = useSideNav()\n const isExpanded = expandedGroups.has(key)\n const groupRef = useRef<HTMLDivElement>(null)\n\n // Auto-expand if this group contains the active item\n useEffect(() => {\n if (!activeValue || expandedGroups.has(key)) return\n const el = groupRef.current\n if (!el) return\n const activeBtn = el.querySelector(`[data-nav-value=\"${activeValue}\"]`)\n if (activeBtn) {\n toggleGroup(key)\n }\n }, [activeValue, key, expandedGroups, toggleGroup])\n\n // Expand on first render if defaultExpanded\n useEffect(() => {\n if (defaultExpanded && !expandedGroups.has(key)) {\n toggleGroup(key)\n }\n // Only run on mount\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [])\n\n const hasActiveChild = (() => {\n if (!activeValue || !groupRef.current) return false\n return !!groupRef.current.querySelector(`[data-nav-value=\"${activeValue}\"]`)\n })()\n\n return (\n <html.div ref={groupRef} style={styles.group}>\n <html.button\n type=\"button\"\n onClick={() => toggleGroup(key)}\n style={[styles.groupTrigger, hasActiveChild && styles.groupTriggerActive]}\n aria-expanded={isExpanded}\n >\n <html.span style={[styles.chevron, isExpanded && styles.chevronOpen]}>\n <svg\n width={10}\n height={10}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2.5}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"M9 18l6-6-6-6\" />\n </svg>\n </html.span>\n {label}\n </html.button>\n {isExpanded && children}\n </html.div>\n )\n}\n\n// --- Item ---\n\ninterface ItemProps {\n value: string\n children: ReactNode\n}\n\nfunction Item({value, children}: ItemProps) {\n const {activeValue, onSelect, registerItem} = useSideNav()\n const isActive = activeValue === value\n\n useEffect(() => {\n return registerItem(value)\n }, [value, registerItem])\n\n return (\n <html.button\n type=\"button\"\n data-nav-value={value}\n onClick={() => onSelect(value)}\n style={[styles.item, isActive && styles.itemActive]}\n aria-current={isActive ? 'page' : undefined}\n >\n {children}\n </html.button>\n )\n}\n\nexport const SideNav = {\n Root,\n Group,\n Item,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\n\nconst spin = css.keyframes({\n '0%': {transform: 'rotate(0deg)'},\n '100%': {transform: 'rotate(360deg)'},\n})\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n },\n spinner: {\n borderRadius: '50%',\n borderStyle: 'solid',\n borderColor: colors.border,\n borderTopColor: colors.accent,\n animationName: spin,\n animationDuration: '0.6s',\n animationTimingFunction: 'linear',\n animationIterationCount: 'infinite',\n },\n sm: {\n width: 16,\n height: 16,\n borderWidth: 2,\n },\n md: {\n width: 24,\n height: 24,\n borderWidth: 2,\n },\n lg: {\n width: 40,\n height: 40,\n borderWidth: 3,\n },\n srOnly: {\n position: 'absolute',\n width: 1,\n height: 1,\n overflow: 'hidden',\n clip: 'rect(0, 0, 0, 0)',\n },\n})\n","import {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type SpinnerSize = 'sm' | 'md' | 'lg'\n\ninterface SpinnerProps {\n size?: SpinnerSize\n label?: string\n}\n\nconst sizeMap = {\n sm: styles.sm,\n md: styles.md,\n lg: styles.lg,\n} as const\n\nexport function Spinner({size = 'md', label = 'Loading'}: SpinnerProps) {\n return (\n <html.div role=\"status\" style={styles.root}>\n <html.div style={[styles.spinner, sizeMap[size]]} aria-hidden />\n <html.span style={styles.srOnly}>{label}</html.span>\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n marginBottom: spacing.md,\n },\n error: {\n color: colors.error,\n },\n success: {\n color: colors.success,\n },\n warning: {\n color: colors.warning,\n },\n muted: {\n color: colors.textMuted,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type StatusIconName = 'x-circle' | 'check-circle' | 'check-done' | 'clock' | 'forbidden'\nexport type StatusIconVariant = 'error' | 'success' | 'warning' | 'muted'\n\nconst icons: Record<StatusIconName, ReactNode> = {\n 'x-circle': (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"15\" y1=\"9\" x2=\"9\" y2=\"15\" />\n <line x1=\"9\" y1=\"9\" x2=\"15\" y2=\"15\" />\n </>\n ),\n 'check-circle': (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <polyline points=\"16 10 11 15 8 12\" />\n </>\n ),\n 'check-done': (\n <>\n <path d=\"M22 11.08V12a10 10 0 1 1-5.93-9.14\" />\n <polyline points=\"22 4 12 14.01 9 11.01\" />\n </>\n ),\n clock: (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <polyline points=\"12 6 12 12 16 14\" />\n </>\n ),\n forbidden: (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"4.93\" y1=\"4.93\" x2=\"19.07\" y2=\"19.07\" />\n </>\n ),\n}\n\ninterface StatusIconProps {\n name: StatusIconName\n size?: number\n variant?: StatusIconVariant\n}\n\nexport function StatusIcon({name, size = 48, variant = 'muted'}: StatusIconProps) {\n return (\n <html.div style={[styles.root, styles[variant]]}>\n <svg\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n width={size}\n height={size}\n >\n {icons[name]}\n </svg>\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n // Root\n root: {\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.md,\n overflow: 'hidden',\n backgroundColor: colors.bgCard,\n fontFamily: typography.fontFamily,\n color: colors.text,\n },\n\n // Header group\n header: {\n backgroundColor: colors.bgCard,\n },\n\n // Row\n row: {\n display: 'grid',\n borderBottomWidth: 1,\n borderBottomStyle: 'solid',\n borderBottomColor: colors.border,\n },\n rowLastChild: {\n borderBottomWidth: 0,\n },\n bodyRow: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n\n // Header cell\n headerCell: {\n fontWeight: typography.fontWeightSemibold,\n color: colors.textMuted,\n textAlign: 'start',\n },\n\n // Body cell\n cell: {\n color: colors.text,\n display: 'flex',\n alignItems: 'center',\n },\n\n // Size: sm\n cellSm: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n // Size: md\n cellMd: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n },\n\n // Variant: striped (even body rows)\n stripedEven: {\n backgroundColor: {\n default: colors.bgCardHover,\n ':hover': colors.bgCardHover,\n },\n },\n\n // Variant: bordered (cells get side borders)\n borderedCell: {\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n },\n borderedCellLast: {\n borderRightWidth: 0,\n },\n\n // Dynamic styles — simple identifier params only (StyleX constraint)\n gridColumns: (columns: number) => ({\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n }),\n})\n","import {type ReactNode, createContext, useContext, Children} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\n// --- Types ---\n\nexport type TableVariant = 'default' | 'striped' | 'bordered'\nexport type TableSize = 'sm' | 'md'\n\n// --- Context ---\n\ninterface TableContextValue {\n variant: TableVariant\n size: TableSize\n columns: number\n isHeader: boolean\n}\n\nconst TableContext = createContext<TableContextValue | null>(null)\n\nfunction useTable() {\n const ctx = useContext(TableContext)\n if (!ctx) throw new Error('Table compound components must be used within Table.Root')\n return ctx\n}\n\n// --- HeaderContext (to distinguish header vs body rowgroup) ---\n\nconst HeaderContext = createContext(false)\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n variant?: TableVariant\n size?: TableSize\n columns: number\n}\n\nfunction Root({children, variant = 'default', size = 'md', columns}: RootProps) {\n return (\n <TableContext.Provider value={{variant, size, columns, isHeader: false}}>\n <html.div role=\"table\" style={styles.root}>\n {children}\n </html.div>\n </TableContext.Provider>\n )\n}\n\n// --- Header ---\n\nfunction Header({children}: {children: ReactNode}) {\n return (\n <HeaderContext.Provider value={true}>\n <html.div role=\"rowgroup\" style={styles.header}>\n {children}\n </html.div>\n </HeaderContext.Provider>\n )\n}\n\n// --- Body ---\n\nfunction Body({children}: {children: ReactNode}) {\n const {variant} = useTable()\n const childArray = Children.toArray(children)\n\n return (\n <HeaderContext.Provider value={false}>\n <html.div role=\"rowgroup\">\n {childArray.map((child, index) => {\n if (variant === 'striped') {\n return (\n <RowIndexContext.Provider key={index} value={index}>\n {child}\n </RowIndexContext.Provider>\n )\n }\n return child\n })}\n </html.div>\n </HeaderContext.Provider>\n )\n}\n\n// Row index context for striped variant\nconst RowIndexContext = createContext<number>(-1)\n\n// --- Row ---\n\nfunction Row({children}: {children: ReactNode}) {\n const {variant, columns} = useTable()\n const isHeader = useContext(HeaderContext)\n const rowIndex = useContext(RowIndexContext)\n const isEvenRow = rowIndex >= 0 && rowIndex % 2 === 1\n const childArray = Children.toArray(children)\n const isLastRow = false // handled by CSS or parent\n\n return (\n <html.div\n role=\"row\"\n style={[\n styles.row,\n styles.gridColumns(columns),\n !isHeader && styles.bodyRow,\n !isHeader && variant === 'striped' && isEvenRow && styles.stripedEven,\n ]}\n >\n {variant === 'bordered'\n ? childArray.map((child, index) => (\n <CellIndexContext.Provider key={index} value={{index, total: childArray.length}}>\n {child}\n </CellIndexContext.Provider>\n ))\n : children}\n </html.div>\n )\n}\n\n// Cell index context for bordered variant\nconst CellIndexContext = createContext<{index: number; total: number}>({\n index: 0,\n total: 0,\n})\n\n// --- HeaderCell ---\n\nfunction HeaderCell({children}: {children: ReactNode}) {\n const {size, variant} = useTable()\n const {index, total} = useContext(CellIndexContext)\n const isLast = variant === 'bordered' && index === total - 1\n\n return (\n <html.div\n role=\"columnheader\"\n style={[\n styles.headerCell,\n size === 'sm' ? styles.cellSm : styles.cellMd,\n variant === 'bordered' && styles.borderedCell,\n isLast && styles.borderedCellLast,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Cell ---\n\nfunction Cell({children}: {children: ReactNode}) {\n const {size, variant} = useTable()\n const {index, total} = useContext(CellIndexContext)\n const isLast = variant === 'bordered' && index === total - 1\n\n return (\n <html.div\n role=\"cell\"\n style={[\n styles.cell,\n size === 'sm' ? styles.cellSm : styles.cellMd,\n variant === 'bordered' && styles.borderedCell,\n isLast && styles.borderedCellLast,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Export ---\n\nexport const Table = {\n Root,\n Header,\n Body,\n Row,\n HeaderCell,\n Cell,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n },\n rootVertical: {\n flexDirection: 'row',\n },\n list: {\n display: 'flex',\n flexDirection: 'row',\n borderBottomWidth: 1,\n borderBottomStyle: 'solid',\n borderBottomColor: colors.border,\n gap: spacing.xs,\n },\n listVertical: {\n flexDirection: 'column',\n borderBottomWidth: 0,\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n gap: 0,\n },\n tab: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: 'transparent',\n borderWidth: 0,\n borderBottomWidth: 2,\n borderBottomStyle: 'solid',\n borderBottomColor: 'transparent',\n cursor: 'pointer',\n transitionProperty: 'color, border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': -2,\n },\n },\n tabVertical: {\n justifyContent: 'flex-start',\n borderBottomWidth: 0,\n borderRightWidth: 2,\n borderRightStyle: 'solid',\n borderRightColor: 'transparent',\n },\n tabActiveHorizontal: {\n color: colors.text,\n borderBottomColor: colors.accent,\n },\n tabActiveVertical: {\n color: colors.text,\n borderRightColor: colors.accent,\n },\n tabDisabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n color: colors.textMuted,\n },\n panel: {\n paddingTop: spacing.md,\n },\n panelVertical: {\n paddingTop: 0,\n paddingLeft: spacing.md,\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport type Orientation = 'horizontal' | 'vertical'\n\nexport interface TabsContextValue {\n activeValue: string | null\n onSelect: (value: string) => void\n orientation: Orientation\n registerTab: (value: string, disabled: boolean) => () => void\n tabsRef: React.RefObject<Map<string, boolean>>\n orderRef: React.RefObject<string[]>\n}\n\nexport const TabsContext = createContext<TabsContextValue | null>(null)\n\nexport function useTabs() {\n const ctx = useContext(TabsContext)\n if (!ctx) throw new Error('Tabs compound components must be used within Tabs.Root')\n return ctx\n}\n","import {useCallback, useRef} from 'react'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport type {Orientation, TabsContextValue} from './TabsContext'\n\ninterface UseTabsRootOptions {\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: Orientation\n}\n\nexport function useTabsRoot({\n value: controlledValue,\n defaultValue,\n onValueChange,\n orientation = 'horizontal',\n}: UseTabsRootOptions): TabsContextValue {\n const [activeValue, onSelect] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange\n ? (v) => {\n if (v !== null) onValueChange(v)\n }\n : undefined,\n )\n const tabsRef = useRef(new Map<string, boolean>())\n const orderRef = useRef<string[]>([])\n\n const registerTab = useCallback((value: string, disabled: boolean) => {\n tabsRef.current.set(value, disabled)\n if (!orderRef.current.includes(value)) {\n orderRef.current.push(value)\n }\n return () => {\n tabsRef.current.delete(value)\n orderRef.current = orderRef.current.filter((v) => v !== value)\n }\n }, [])\n\n return {activeValue, onSelect, orientation, registerTab, tabsRef, orderRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {TabsContext, useTabs} from './TabsContext'\nimport {useTabsRoot} from './useTabsRoot'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: 'horizontal' | 'vertical'\n}\n\nfunction Root({\n children,\n value,\n defaultValue,\n onValueChange,\n orientation = 'horizontal',\n}: RootProps) {\n const ctx = useTabsRoot({value, defaultValue, onValueChange, orientation})\n\n return (\n <TabsContext.Provider value={ctx}>\n <html.div style={[styles.root, orientation === 'vertical' && styles.rootVertical]}>\n {children}\n </html.div>\n </TabsContext.Provider>\n )\n}\n\n// --- List ---\n\ninterface ListProps {\n children: ReactNode\n}\n\nfunction List({children}: ListProps) {\n const {orientation, activeValue, onSelect, tabsRef, orderRef} = useTabs()\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n const el = listRef.current\n if (!el) return\n\n function handleKeyDown(this: HTMLElement, e: KeyboardEvent) {\n const order = orderRef.current\n const tabs = tabsRef.current\n if (order.length === 0) return\n const listEl = this\n\n const prevKey = orientation === 'horizontal' ? 'ArrowLeft' : 'ArrowUp'\n const nextKey = orientation === 'horizontal' ? 'ArrowRight' : 'ArrowDown'\n\n let targetValue: string | null = null\n\n switch (e.key) {\n case nextKey: {\n e.preventDefault()\n const currentIdx = activeValue ? order.indexOf(activeValue) : -1\n for (let i = 1; i <= order.length; i++) {\n const idx = (currentIdx + i) % order.length\n const val = order[idx]\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case prevKey: {\n e.preventDefault()\n const currentIdx = activeValue ? order.indexOf(activeValue) : 0\n for (let i = 1; i <= order.length; i++) {\n const idx = (currentIdx - i + order.length) % order.length\n const val = order[idx]\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case 'Home': {\n e.preventDefault()\n for (const val of order) {\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case 'End': {\n e.preventDefault()\n for (let i = order.length - 1; i >= 0; i--) {\n if (!tabs.get(order[i])) {\n targetValue = order[i]\n break\n }\n }\n break\n }\n }\n\n if (targetValue) {\n onSelect(targetValue)\n // Focus the newly activated tab button\n const tabEl = listEl.querySelector(\n `[data-tab-value=\"${targetValue}\"]`,\n ) as HTMLElement | null\n tabEl?.focus()\n }\n }\n\n el.addEventListener('keydown', handleKeyDown)\n return () => el.removeEventListener('keydown', handleKeyDown)\n }, [orientation, activeValue, onSelect, tabsRef, orderRef])\n\n return (\n <html.div\n ref={listRef}\n role=\"tablist\"\n aria-orientation={orientation}\n style={[styles.list, orientation === 'vertical' && styles.listVertical]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Tab ---\n\ninterface TabProps {\n value: string\n disabled?: boolean\n children: ReactNode\n}\n\nfunction Tab({value, disabled = false, children}: TabProps) {\n const {activeValue, onSelect, orientation, registerTab} = useTabs()\n const isActive = activeValue === value\n const tabId = useId()\n const panelId = `${tabId}-panel`\n\n useEffect(() => {\n return registerTab(value, disabled)\n }, [value, disabled, registerTab])\n\n const handleClick = () => {\n if (!disabled) {\n onSelect(value)\n }\n }\n\n return (\n <html.button\n type=\"button\"\n role=\"tab\"\n id={tabId}\n aria-selected={isActive}\n aria-controls={panelId}\n aria-disabled={disabled || undefined}\n data-tab-value={value}\n tabIndex={isActive ? 0 : -1}\n onClick={handleClick}\n style={[\n styles.tab,\n orientation === 'vertical' && styles.tabVertical,\n isActive &&\n (orientation === 'vertical' ? styles.tabActiveVertical : styles.tabActiveHorizontal),\n disabled && styles.tabDisabled,\n ]}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Panel ---\n\ninterface PanelProps {\n value: string\n children: ReactNode\n}\n\nfunction Panel({value, children}: PanelProps) {\n const {activeValue, orientation} = useTabs()\n\n if (activeValue !== value) return null\n\n return (\n <html.div\n role=\"tabpanel\"\n style={[styles.panel, orientation === 'vertical' && styles.panelVertical]}\n >\n {children}\n </html.div>\n )\n}\n\nexport const Tabs = {\n Root,\n List,\n Tab,\n Panel,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n width: '100%',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n color: colors.text,\n backgroundColor: colors.bg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n resize: 'vertical' as const,\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 1,\n },\n },\n default: {\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n ':focus': colors.accent,\n },\n },\n error: {\n borderColor: {\n default: colors.error,\n ':focus': colors.error,\n },\n },\n})\n","import {html} from 'react-strict-dom'\nimport {useFieldContext} from '../Field/FieldContext'\nimport {styles} from './styles.css'\n\nexport type TextareaVariant = 'default' | 'error'\n\ninterface TextareaProps {\n variant?: TextareaVariant\n name?: string\n placeholder?: string\n required?: boolean\n rows?: number\n value?: string\n defaultValue?: string\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void\n}\n\nexport function Textarea({\n variant = 'default',\n name,\n placeholder,\n required,\n rows = 3,\n value,\n defaultValue,\n disabled,\n onChange,\n}: TextareaProps) {\n const ctx = useFieldContext()\n\n return (\n <html.textarea\n id={ctx?.controlId}\n name={name}\n placeholder={placeholder}\n required={required}\n rows={rows}\n value={value}\n defaultValue={defaultValue}\n disabled={disabled}\n aria-describedby={\n ctx ? `${ctx.descriptionId} ${ctx.invalid ? ctx.errorId : ''}`.trim() : undefined\n }\n aria-invalid={ctx?.invalid || variant === 'error' || undefined}\n onChange={onChange}\n style={[styles.base, styles[variant]]}\n />\n )\n}\n","const e = {\n bg: \"var(--bg-xqkwqtp)\",\n bgCard: \"var(--bgCard-xj2l5r)\",\n bgCardHover: \"var(--bgCardHover-xlxk7vw)\",\n text: \"var(--text-xlpbogt)\",\n textMuted: \"var(--textMuted-x651nu9)\",\n accent: \"var(--accent-xw7wp3v)\",\n accentHover: \"var(--accentHover-x18fqoz)\",\n accentContrast: \"var(--accentContrast-x3gzxyp)\",\n border: \"var(--border-x1drj1pb)\",\n error: \"var(--error-x13gdhh0)\",\n errorHover: \"var(--errorHover-x7eyu03)\",\n errorBg: \"var(--errorBg-xrl8836)\",\n errorBorder: \"var(--errorBorder-x1a6pjl)\",\n errorText: \"var(--errorText-xf51nwe)\",\n errorContrast: \"var(--errorContrast-x1lvjkah)\",\n success: \"var(--success-x197pe5n)\",\n successBg: \"var(--successBg-xzjukav)\",\n successBorder: \"var(--successBorder-x1my3ygc)\",\n successText: \"var(--successText-x46dg9e)\",\n warning: \"var(--warning-x1gq0pyw)\",\n warningBg: \"var(--warningBg-xtnxqss)\",\n warningBorder: \"var(--warningBorder-x1ev2mr5)\",\n warningText: \"var(--warningText-x1lgjghx)\",\n infoBg: \"var(--infoBg-xho8jir)\",\n infoBorder: \"var(--infoBorder-xnevk3x)\",\n infoText: \"var(--infoText-x19pseus)\",\n __varGroupHash__: \"xjvd03b\"\n}, t = {\n xs: \"var(--xs-xxfyjsd)\",\n sm: \"var(--sm-xbh8y7f)\",\n ms: \"var(--ms-x13y09zs)\",\n md: \"var(--md-x3pkb85)\",\n lg: \"var(--lg-x34mutn)\",\n xl: \"var(--xl-xttpygj)\",\n xxl: \"var(--xxl-xbe9eha)\",\n xxxl: \"var(--xxxl-xroalp5)\",\n __varGroupHash__: \"x6uc9q\"\n}, n = {\n sm: \"var(--sm-x1bhtfs5)\",\n md: \"var(--md-xx2g89g)\",\n lg: \"var(--lg-xwd56yl)\",\n full: \"var(--full-x9vxdtd)\",\n __varGroupHash__: \"xw3ffwm\"\n}, i = {\n stackXs: \"var(--stackXs-x1qfrfo2)\",\n stackSm: \"var(--stackSm-x2rk1ut)\",\n stackMd: \"var(--stackMd-xhblkt4)\",\n stackLg: \"var(--stackLg-xeue779)\",\n stackXl: \"var(--stackXl-x7sbbgu)\",\n inlineXs: \"var(--inlineXs-xq4tp4f)\",\n inlineSm: \"var(--inlineSm-x2o8bbf)\",\n inlineMd: \"var(--inlineMd-x1oalkxi)\",\n inlineLg: \"var(--inlineLg-xz69o43)\",\n containerSm: \"var(--containerSm-x3nosus)\",\n containerMd: \"var(--containerMd-x170dvin)\",\n containerLg: \"var(--containerLg-x1n6aasq)\",\n __varGroupHash__: \"x16nfoyr\"\n}, r = {\n fontFamily: \"var(--fontFamily-xvrmnat)\",\n fontFamilyMono: \"var(--fontFamilyMono-x1bzqfky)\",\n fontSizeXs: \"var(--fontSizeXs-x1w5m325)\",\n fontSizeSm: \"var(--fontSizeSm-x1bjjs4u)\",\n fontSizeMd: \"var(--fontSizeMd-xq8d99q)\",\n fontSizeLg: \"var(--fontSizeLg-x18ngplw)\",\n fontSizeXl: \"var(--fontSizeXl-x1b1mqsu)\",\n fontSizeHeading: \"var(--fontSizeHeading-x1stydh2)\",\n fontWeightNormal: \"var(--fontWeightNormal-x1y1cayu)\",\n fontWeightMedium: \"var(--fontWeightMedium-xaw13ft)\",\n fontWeightSemibold: \"var(--fontWeightSemibold-xg6c7xe)\",\n fontWeightBold: \"var(--fontWeightBold-x1pjkvwg)\",\n lineHeight: \"var(--lineHeight-x1gubzd5)\",\n __varGroupHash__: \"xs62swl\"\n}, a = {\n fontSize1: \"var(--fontSize1-xx27tux)\",\n fontSize2: \"var(--fontSize2-x5hag8h)\",\n fontSize3: \"var(--fontSize3-x1mf6j39)\",\n fontSize4: \"var(--fontSize4-xh0hch2)\",\n fontSize5: \"var(--fontSize5-xcllv62)\",\n fontSize6: \"var(--fontSize6-xo5veds)\",\n fontSize7: \"var(--fontSize7-x1j85tz8)\",\n fontSize8: \"var(--fontSize8-x17zhits)\",\n fontSize9: \"var(--fontSize9-xveysf7)\",\n lineHeight1: \"var(--lineHeight1-x17o1wol)\",\n lineHeight2: \"var(--lineHeight2-xinpx5n)\",\n lineHeight3: \"var(--lineHeight3-x1163vpm)\",\n lineHeight4: \"var(--lineHeight4-x1y0jdbp)\",\n lineHeight5: \"var(--lineHeight5-xjln4cz)\",\n lineHeight6: \"var(--lineHeight6-x1h1b5wo)\",\n lineHeight7: \"var(--lineHeight7-xx3gx0p)\",\n lineHeight8: \"var(--lineHeight8-xk1f09j)\",\n lineHeight9: \"var(--lineHeight9-xshcxhh)\",\n displaySm: \"var(--displaySm-x5inqzv)\",\n displayMd: \"var(--displayMd-x1oektom)\",\n displayLg: \"var(--displayLg-x6qsr1u)\",\n letterSpacingTight: \"var(--letterSpacingTight-xmavxfk)\",\n letterSpacingNormal: \"var(--letterSpacingNormal-x1ih41v1)\",\n letterSpacingWide: \"var(--letterSpacingWide-xt8z9rj)\",\n __varGroupHash__: \"x4cj49w\"\n}, o = {\n bodySm: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1hn3ytp\",\n \"lineHeight-kLWn49\": \"lineHeight-xzs5d81\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:6\"\n },\n bodyMd: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xfzcsg9\",\n \"lineHeight-kLWn49\": \"lineHeight-x80sjjd\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:13\"\n },\n bodyLg: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1kws70c\",\n \"lineHeight-kLWn49\": \"lineHeight-x1487en2\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:20\"\n },\n caption: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x19zw8p8\",\n \"lineHeight-kLWn49\": \"lineHeight-xsnwo96\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x121swot\",\n $$css: \"tokens/type-presets.css.ts:29\"\n },\n label: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1hn3ytp\",\n \"lineHeight-kLWn49\": \"lineHeight-xzs5d81\",\n \"fontWeight-k63SB2\": \"fontWeight-x120ksxs\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:36\"\n },\n code: {\n \"fontFamily-kMv6JI\": \"fontFamily-x1kygxdj\",\n \"fontSize-kGuDYH\": \"fontSize-x1hn3ytp\",\n \"lineHeight-kLWn49\": \"lineHeight-xzs5d81\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:43\"\n },\n overline: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x19zw8p8\",\n \"lineHeight-kLWn49\": \"lineHeight-xsnwo96\",\n \"fontWeight-k63SB2\": \"fontWeight-x1x12jc5\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x121swot\",\n \"textTransform-kP9fke\": \"textTransform-xtvhhri\",\n $$css: \"tokens/type-presets.css.ts:50\"\n },\n headingSm: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xtv95mj\",\n \"lineHeight-kLWn49\": \"lineHeight-xyb71hx\",\n \"fontWeight-k63SB2\": \"fontWeight-x1x12jc5\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:60\"\n },\n headingMd: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1qndi8g\",\n \"lineHeight-kLWn49\": \"lineHeight-x17ovj3u\",\n \"fontWeight-k63SB2\": \"fontWeight-x1x12jc5\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:67\"\n },\n headingLg: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xo0rcgw\",\n \"lineHeight-kLWn49\": \"lineHeight-x18micsl\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:74\"\n },\n headingXl: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x6ugw34\",\n \"lineHeight-kLWn49\": \"lineHeight-x1f79cfb\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:81\"\n },\n displaySm: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1lwaixd\",\n \"lineHeight-kLWn49\": \"lineHeight-x1u7k74\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:90\"\n },\n displayMd: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xrqn33v\",\n \"lineHeight-kLWn49\": \"lineHeight-x1uo3zyz\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:97\"\n },\n displayLg: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1s08cw3\",\n \"lineHeight-kLWn49\": \"lineHeight-x1159mfc\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:104\"\n }\n}, s = {\n sm: \"var(--sm-x17hhtln)\",\n md: \"var(--md-x1oyt0aw)\",\n lg: \"var(--lg-x1mxd62i)\",\n __varGroupHash__: \"x13v825q\"\n}, x = {\n xjvd03b: \"x18itf25 xjvd03b\",\n $$css: !0\n}, l = {\n x13v825q: \"xv9ibj0 x13v825q\",\n $$css: !0\n}, g = {\n xjvd03b: \"x1qgt5a2 xjvd03b\",\n $$css: !0\n}, c = {\n x13v825q: \"x15e39jv x13v825q\",\n $$css: !0\n};\nexport {\n e as colors,\n c as highContrastShadows,\n g as highContrastTheme,\n i as layoutSpacing,\n l as lightShadows,\n x as lightTheme,\n n as radii,\n s as shadows,\n t as spacing,\n o as typePresets,\n a as typeScale,\n r as typography\n};\n//# sourceMappingURL=index.js.map\n","import type {ReactNode} from 'react'\nimport {css, html} from 'react-strict-dom'\nimport {lightTheme, lightShadows, highContrastTheme, highContrastShadows} from '@duro-app/tokens'\n\nexport type ThemeName = 'dark' | 'light' | 'high-contrast'\n\ninterface ThemeProviderProps {\n theme?: ThemeName\n children: ReactNode\n}\n\nconst themeMap: Partial<Record<ThemeName, readonly [typeof lightTheme, typeof lightShadows]>> = {\n light: [lightTheme, lightShadows],\n 'high-contrast': [highContrastTheme, highContrastShadows],\n}\n\nconst styles = css.create({\n root: {\n display: 'contents',\n },\n})\n\n// react-strict-dom's style prop rejects Theme<VarGroup<{named keys}>> because the\n// concrete VarGroup lacks the generic index signature. This is a known typing gap.\ntype DivStyle = Parameters<typeof html.div>[0]['style']\n\nexport function ThemeProvider({theme = 'dark', children}: ThemeProviderProps) {\n const overrides = themeMap[theme]\n const themeStyles = [overrides?.[0], overrides?.[1], styles.root] as DivStyle\n\n return <html.div style={themeStyles}>{children}</html.div>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n // Colors\n default: {\n color: colors.text,\n },\n muted: {\n color: colors.textMuted,\n },\n accent: {\n color: colors.accent,\n },\n error: {\n color: colors.errorText,\n },\n success: {\n color: colors.successText,\n },\n warning: {\n color: colors.warningText,\n },\n\n // Weight overrides\n weightNormal: {\n fontWeight: typography.fontWeightNormal,\n },\n weightMedium: {\n fontWeight: typography.fontWeightMedium,\n },\n weightSemibold: {\n fontWeight: typography.fontWeightSemibold,\n },\n weightBold: {\n fontWeight: typography.fontWeightBold,\n },\n\n // Alignment\n alignStart: {\n textAlign: 'start',\n },\n alignCenter: {\n textAlign: 'center',\n },\n alignEnd: {\n textAlign: 'end',\n },\n\n // Truncate\n truncate: {\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {typePresets} from '@duro-app/tokens/tokens/type-presets.css'\nimport {styles} from './styles.css'\n\nexport type TextVariant = 'bodySm' | 'bodyMd' | 'bodyLg' | 'caption' | 'label' | 'code' | 'overline'\nexport type TextColor = 'default' | 'muted' | 'accent' | 'error' | 'success' | 'warning'\n\ninterface TextProps {\n variant?: TextVariant\n color?: TextColor\n weight?: 'normal' | 'medium' | 'semibold' | 'bold'\n align?: 'start' | 'center' | 'end'\n truncate?: boolean\n as?: 'span' | 'p' | 'div'\n children: ReactNode\n}\n\nconst weightMap = {\n normal: styles.weightNormal,\n medium: styles.weightMedium,\n semibold: styles.weightSemibold,\n bold: styles.weightBold,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n} as const\n\nexport function Text({\n variant = 'bodyMd',\n color = 'default',\n weight,\n align,\n truncate,\n as = 'span',\n children,\n}: TextProps) {\n const style = [\n typePresets[variant],\n styles[color],\n weight && weightMap[weight],\n align && alignMap[align],\n truncate && styles.truncate,\n ]\n\n if (as === 'p') return <html.p style={style}>{children}</html.p>\n if (as === 'div') return <html.div style={style}>{children}</html.div>\n return <html.span style={style}>{children}</html.span>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n popup: {\n position: 'absolute',\n zIndex: 50,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n backgroundColor: colors.bgCard,\n color: colors.text,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeXs,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n boxShadow: shadows.md,\n whiteSpace: 'nowrap',\n pointerEvents: 'none',\n },\n top: {\n bottom: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginBottom: spacing.xs,\n },\n bottom: {\n top: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginTop: spacing.xs,\n },\n left: {\n right: '100%',\n top: '50%',\n transform: 'translateY(-50%)',\n marginRight: spacing.xs,\n },\n right: {\n left: '100%',\n top: '50%',\n transform: 'translateY(-50%)',\n marginLeft: spacing.xs,\n },\n})\n","import {\n type ReactNode,\n createContext,\n useContext,\n useState,\n useRef,\n useCallback,\n useId,\n} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\n// --- Context ---\n\ntype Placement = 'top' | 'bottom' | 'left' | 'right'\n\ninterface TooltipContextValue {\n open: boolean\n show: () => void\n hide: () => void\n tooltipId: string\n placement: Placement\n}\n\nconst TooltipContext = createContext<TooltipContextValue | null>(null)\n\nfunction useTooltip() {\n const ctx = useContext(TooltipContext)\n if (!ctx) throw new Error('Tooltip compound components must be used within Tooltip.Root')\n return ctx\n}\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n content: ReactNode\n placement?: Placement\n delay?: number\n}\n\nfunction Root({children, content, placement = 'top', delay = 300}: RootProps) {\n const [open, setOpen] = useState(false)\n const tooltipId = useId()\n const timerRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const show = useCallback(() => {\n if (timerRef.current) clearTimeout(timerRef.current)\n timerRef.current = setTimeout(() => setOpen(true), delay)\n }, [delay])\n\n const hide = useCallback(() => {\n if (timerRef.current) clearTimeout(timerRef.current)\n timerRef.current = null\n setOpen(false)\n }, [])\n\n return (\n <TooltipContext.Provider value={{open, show, hide, tooltipId, placement}}>\n <html.div style={styles.root}>\n {children}\n {open && (\n <html.div id={tooltipId} role=\"tooltip\" style={[styles.popup, styles[placement]]}>\n {content}\n </html.div>\n )}\n </html.div>\n </TooltipContext.Provider>\n )\n}\n\n// --- Trigger ---\n\ninterface TriggerProps {\n children: ReactNode\n}\n\nfunction Trigger({children}: TriggerProps) {\n const {open, show, hide, tooltipId} = useTooltip()\n\n return (\n <html.div\n onPointerEnter={show}\n onPointerLeave={hide}\n onFocus={show}\n onBlur={hide}\n aria-describedby={open ? tooltipId : undefined}\n >\n {children}\n </html.div>\n )\n}\n\nexport const Tooltip = {\n Root,\n Trigger,\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'column',\n },\n alignStart: {alignItems: 'flex-start'},\n alignCenter: {alignItems: 'center'},\n alignEnd: {alignItems: 'flex-end'},\n alignStretch: {alignItems: 'stretch'},\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type SpacingKey = 'xs' | 'sm' | 'ms' | 'md' | 'lg' | 'xl' | 'xxl' | 'xxxl'\n\ninterface StackProps {\n gap?: SpacingKey\n align?: 'start' | 'center' | 'end' | 'stretch'\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n stretch: styles.alignStretch,\n} as const\n\nexport function Stack({gap = 'md', align = 'stretch', children}: StackProps) {\n return <html.div style={[styles.base, gapMap[gap], alignMap[align]]}>{children}</html.div>\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'row',\n flexWrap: 'nowrap',\n },\n alignStart: {alignItems: 'flex-start'},\n alignCenter: {alignItems: 'center'},\n alignEnd: {alignItems: 'flex-end'},\n alignBaseline: {alignItems: 'baseline'},\n alignStretch: {alignItems: 'stretch'},\n justifyStart: {justifyContent: 'flex-start'},\n justifyCenter: {justifyContent: 'center'},\n justifyEnd: {justifyContent: 'flex-end'},\n justifyBetween: {justifyContent: 'space-between'},\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport type {SpacingKey} from '../Stack/Stack'\n\ninterface InlineProps {\n gap?: SpacingKey\n align?: 'start' | 'center' | 'end' | 'baseline' | 'stretch'\n justify?: 'start' | 'center' | 'end' | 'between'\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n baseline: styles.alignBaseline,\n stretch: styles.alignStretch,\n} as const\n\nconst justifyMap = {\n start: styles.justifyStart,\n center: styles.justifyCenter,\n end: styles.justifyEnd,\n between: styles.justifyBetween,\n} as const\n\nexport function Inline({gap = 'sm', align = 'center', justify = 'start', children}: InlineProps) {\n return (\n <html.div style={[styles.base, gapMap[gap], alignMap[align], justifyMap[justify]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n alignStart: {alignItems: 'flex-start'},\n alignCenter: {alignItems: 'center'},\n alignEnd: {alignItems: 'flex-end'},\n justifyStart: {justifyContent: 'flex-start'},\n justifyCenter: {justifyContent: 'center'},\n justifyEnd: {justifyContent: 'flex-end'},\n justifyBetween: {justifyContent: 'space-between'},\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport type {SpacingKey} from '../Stack/Stack'\n\ninterface ClusterProps {\n gap?: SpacingKey\n align?: 'start' | 'center' | 'end'\n justify?: 'start' | 'center' | 'end' | 'between'\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n} as const\n\nconst justifyMap = {\n start: styles.justifyStart,\n center: styles.justifyCenter,\n end: styles.justifyEnd,\n between: styles.justifyBetween,\n} as const\n\nexport function Cluster({gap = 'sm', align = 'start', justify = 'start', children}: ClusterProps) {\n return (\n <html.div style={[styles.base, gapMap[gap], alignMap[align], justifyMap[justify]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'grid',\n },\n col1: {gridTemplateColumns: '1fr'},\n col2: {gridTemplateColumns: 'repeat(2, 1fr)'},\n col3: {gridTemplateColumns: 'repeat(3, 1fr)'},\n col4: {gridTemplateColumns: 'repeat(4, 1fr)'},\n col5: {gridTemplateColumns: 'repeat(5, 1fr)'},\n col6: {gridTemplateColumns: 'repeat(6, 1fr)'},\n autoFit: (minWidth: string) => ({\n gridTemplateColumns: `repeat(auto-fit, minmax(${minWidth}, 1fr))`,\n }),\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport type {SpacingKey} from '../Stack/Stack'\n\ninterface GridProps {\n gap?: SpacingKey\n columns?: 1 | 2 | 3 | 4 | 5 | 6\n minColumnWidth?: string\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst columnsMap = {\n 1: styles.col1,\n 2: styles.col2,\n 3: styles.col3,\n 4: styles.col4,\n 5: styles.col5,\n 6: styles.col6,\n} as const\n\nexport function Grid({gap = 'md', columns, minColumnWidth, children}: GridProps) {\n const columnStyle = minColumnWidth\n ? styles.autoFit(minColumnWidth)\n : columns\n ? columnsMap[columns]\n : undefined\n\n return <html.div style={[styles.base, gapMap[gap], columnStyle]}>{children}</html.div>\n}\n","import {useRef, useState, useEffect} from 'react'\n\nexport type ContainerSize = 'compact' | 'default' | 'spacious'\n\ninterface UseContainerQueryOptions {\n compactBelow?: number\n spaciousAbove?: number\n}\n\nexport function useContainerQuery<T extends HTMLElement = HTMLElement>(\n options: UseContainerQueryOptions = {},\n): {\n ref: React.RefObject<T | null>\n size: ContainerSize\n} {\n const {compactBelow = 480, spaciousAbove = 768} = options\n const ref = useRef<T | null>(null)\n const [size, setSize] = useState<ContainerSize>('default')\n\n useEffect(() => {\n const element = ref.current\n if (!element) return\n\n let rafId: number | null = null\n\n const observer = new ResizeObserver((entries) => {\n if (rafId !== null) cancelAnimationFrame(rafId)\n\n rafId = requestAnimationFrame(() => {\n const entry = entries[0]\n if (!entry) return\n\n const width = entry.contentBoxSize?.[0]?.inlineSize ?? entry.contentRect.width\n\n if (width < compactBelow) {\n setSize('compact')\n } else if (width >= spaciousAbove) {\n setSize('spacious')\n } else {\n setSize('default')\n }\n })\n })\n\n observer.observe(element)\n\n return () => {\n observer.disconnect()\n if (rafId !== null) cancelAnimationFrame(rafId)\n }\n }, [compactBelow, spaciousAbove])\n\n return {ref, size}\n}\n"],"names":["styleq$1","styleq_2","cache","compiledKey","createStyleq","options","disableCache","disableMix","transform","definedProperties","className","inlineStyle","debugString","nextCache","styles","i","possibleStyle","_i","style","classNameChunk","cacheEntry","definedPropertiesChunk","prop","value","compiledKeyValue","weakMap","subStyle","_prop","_value","styleProps","styleq","optimizedStyleq","merge","dataStyleSrc","result","chunks","pathsMap","chunk","trimmed","path","line","a","button","div","heading","input","label","nav","p","span","textarea","defaultStyles","base","kmVPX3","kaIpWk","kMzoRj","ksu8eU","kGuDYH","kLWn49","$$css","error","kWkggS","kVAM5u","kMwMTN","success","warning","info","Alert","variant","children","jsx","_rsdMerge","_rsdDefaultStyles","k1xSpc","kGNEyG","kjj79g","kMv6JI","k63SB2","khDVqt","sizeMd","kLKAdn","kGO01o","kE3dHu","kpe85a","sizeSm","default","sizeMap","sm","md","Badge","size","kOIVth","kkrTdU","k1ekBW","kIyJzY","kAMwcw","kybGjl","kMeerF","k3XXqK","kjBf7l","kInvED","sizeDefault","sizeSmall","primary","secondary","link","danger","fullWidth","kzqmXN","disabled","kSiTet","small","Button","type","onClick","elevated","kGVxlE","outlined","filled","interactive","k3aq6I","sizeCompact","sizeFull","header","k1K539","compact","full","Card","jsxs","root","rootDisabled","box","kZKoxP","kmuXW","boxUnchecked","boxChecked","kVAEAm","kVQacm","Checkbox","name","checked","controlledChecked","defaultChecked","onChange","isControlled","undefined","internalChecked","setInternalChecked","useState","isChecked","handleChange","useCallback","e","target","opacity","kXwgrk","k9WMMc","message","action","keoZOQ","EmptyState","icon","typePresets","bodySm","kb6lSQ","bodyMd","bodyLg","caption","code","overline","kP9fke","headingSm","headingMd","headingLg","headingXl","displaySm","displayMd","displayLg","muted","accent","alignStart","alignCenter","alignEnd","defaultVariantMap","alignMap","start","center","end","Heading","level","color","align","resolvedVariant","h1","h2","h3","h4","h5","h6","FieldContext","createContext","useFieldContext","useContext","description","Root","invalid","id","useId","ctx","useMemo","controlId","descriptionId","errorId","Label","Description","Error","Field","InputGroupContext","useInputGroupContext","inGroup","Input","placeholder","required","minLength","pattern","autoComplete","defaultValue","groupCtx","extraProps","trim","wrapper","addon","kfSwDN","addonStart","kWqL5O","kSWEuD","k26BEO","addonEnd","kZ1KPB","k4WBpm","kaZRDh","addonClickable","addonDisabled","Addon","position","positionStyle","InputGroup","LinkButton","href","rel","trigger","backdrop","k87sOh","kbCHJM","kCIrl2","krVfgx","kY2c9j","popup","k7Eaqz","popupEnd","item","itemHighlighted","linkItem","MenuContext","useMenu","useMenuRoot","open","setOpen","highlightedId","setHighlightedId","menuId","rootRef","useRef","triggerRef","itemsRef","Map","orderRef","needsInitialHighlightRef","close","current","focus","toggle","prev","useEffect","order","length","registerItem","element","set","map","ids","keys","sort","b","elA","get","elB","compareDocumentPosition","Node","DOCUMENT_POSITION_FOLLOWING","delete","filter","handleKeyDown","key","preventDefault","idx","indexOf","items","click","addEventListener","removeEventListener","Trigger","localRef","Popup","Fragment","Item","ref","isHighlighted","el","handleClick","LinkItem","Menu","viewport","kXHlph","kORKVm","k5wCbM","content","kAzted","scrollbar","kFalU9","scrollbarVertical","scrollbarHorizontal","scrollbarHidden","scrollbarVisible","thumb","kUk6DE","viewportMaxHeight","maxHeight","kskxy","val","thumbVertical","height","thumbHorizontal","width","ScrollAreaContext","useScrollArea","useScrollAreaRoot","viewportRef","contentRef","scrollTop","setScrollTop","scrollLeft","setScrollLeft","scrollHeight","setScrollHeight","scrollWidth","setScrollWidth","clientHeight","setClientHeight","clientWidth","setClientWidth","scrolling","setScrolling","scrollTimerRef","handleScroll","vp","clearTimeout","setTimeout","observer","ResizeObserver","observe","disconnect","passive","Viewport","Content","Scrollbar","orientation","Thumb","draggingRef","startPosRef","startScrollRef","isVertical","thumbSizePercent","Math","max","maxScroll","trackSize","thumbPixelSize","scrollOffset","thumbOffset","thumbStyle","handlePointerDown","clientY","clientX","setPointerCapture","pointerId","handlePointerMove","delta","scrollRatio","scrollDelta","handlePointerUp","ScrollArea","itemSelected","hidden","SelectContext","useSelect","useControllableValue","controlledValue","internal","setInternal","setValue","v","useSelectRoot","onValueChange","initialLabels","labels","setLabels","listboxId","found","registerLabel","itemValue","Value","display","Icon","selectedValue","isSelected","text","textContent","ItemText","Select","group","groupTrigger","groupTriggerActive","chevron","chevronOpen","itemActive","SideNavContext","useSideNav","activeValue","onSelect","expandedGroups","setExpandedGroups","Set","toggleGroup","next","has","add","includes","push","Group","groupKey","defaultExpanded","isExpanded","groupRef","querySelector","hasActiveChild","isActive","SideNav","spinner","kLZC3w","kKVMdj","k44tkh","kyAemX","ko0y90","lg","srOnly","kMcinP","Spinner","icons","clock","forbidden","StatusIcon","_temp","kumcoG","row","kt9PQ7","kfdmCh","kL6WhQ","rowLastChild","bodyRow","headerCell","cell","cellSm","cellMd","stripedEven","borderedCell","borderedCellLast","gridColumns","columns","TableContext","useTable","HeaderContext","isHeader","Header","Body","childArray","Children","toArray","child","index","RowIndexContext","Row","rowIndex","isEvenRow","CellIndexContext","total","HeaderCell","isLast","Cell","Table","rootVertical","list","listVertical","tab","tabVertical","tabActiveHorizontal","tabActiveVertical","tabDisabled","panel","panelVertical","TabsContext","useTabs","useTabsRoot","tabsRef","registerTab","List","listRef","tabs","listEl","prevKey","nextKey","targetValue","currentIdx","Tab","tabId","panelId","Panel","Tabs","kHenm0","Textarea","rows","bg","bgCard","bgCardHover","textMuted","accentHover","accentContrast","border","errorHover","errorBg","errorBorder","errorText","errorContrast","successBg","successBorder","successText","warningBg","warningBorder","warningText","infoBg","infoBorder","infoText","__varGroupHash__","themeMap","light","lightTheme","lightShadows","highContrastTheme","highContrastShadows","ThemeProvider","theme","overrides","themeStyles","weightNormal","weightMedium","weightSemibold","weightBold","truncate","kg5iWk","weightMap","normal","medium","semibold","bold","Text","weight","as","kfzvcC","top","bottom","left","km5ZXQ","right","koQZXg","TooltipContext","useTooltip","placement","delay","tooltipId","timerRef","show","hide","Tooltip","alignStretch","gapXs","gapSm","gapMs","gapMd","gapLg","gapXl","gapXxl","gapXxxl","gapMap","xs","ms","xl","xxl","xxxl","stretch","Stack","gap","kwnvtZ","alignBaseline","justifyStart","justifyCenter","justifyEnd","justifyBetween","baseline","justifyMap","between","Inline","justify","Cluster","col1","col2","col3","col4","col5","col6","autoFit","minWidth","columnsMap","Grid","minColumnWidth","columnStyle","useContainerQuery","compactBelow","spaciousAbove","setSize","rafId","entries","cancelAnimationFrame","requestAnimationFrame","entry","contentBoxSize","inlineSize","contentRect"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../node_modules/.pnpm/react-strict-dom@0.0.55_postcss@8.5.6_react-dom@19.2.4_react@19.2.4__react-native@0.84._1278be21509893d955b57d0db9435779/node_modules/react-strict-dom/dist/web/runtime.js","../src/components/Icon/Icon.tsx","../src/components/Alert/styles.css.ts","../src/components/Alert/Alert.tsx","../src/components/Badge/styles.css.ts","../src/components/Badge/Badge.tsx","../src/components/Button/styles.css.ts","../src/components/Button/Button.tsx","../src/components/Card/styles.css.ts","../src/components/Card/Card.tsx","../src/components/Checkbox/styles.css.ts","../src/components/Checkbox/Checkbox.tsx","../src/components/EmptyState/styles.css.ts","../src/components/EmptyState/EmptyState.tsx","../../tokens/src/tokens/type-presets.css.ts","../src/components/Heading/styles.css.ts","../src/components/Heading/Heading.tsx","../src/components/Field/FieldContext.ts","../src/components/Field/styles.css.ts","../src/components/Field/Field.tsx","../src/components/InputGroup/InputGroupContext.ts","../src/components/Input/styles.css.ts","../src/components/Input/Input.tsx","../src/components/InputGroup/styles.css.ts","../src/components/InputGroup/InputGroup.tsx","../src/components/LinkButton/styles.css.ts","../src/components/LinkButton/LinkButton.tsx","../src/components/Menu/styles.css.ts","../src/components/Menu/MenuContext.ts","../src/components/Menu/useMenuRoot.ts","../src/components/Menu/Menu.tsx","../src/components/ScrollArea/styles.css.ts","../src/components/ScrollArea/ScrollAreaContext.ts","../src/components/ScrollArea/useScrollAreaRoot.ts","../src/components/ScrollArea/ScrollArea.tsx","../src/components/Select/styles.css.ts","../src/components/Select/SelectContext.ts","../src/hooks/useControllableValue.ts","../src/components/Select/useSelectRoot.ts","../src/components/Select/Select.tsx","../src/components/SideNav/styles.css.ts","../src/components/SideNav/SideNavContext.ts","../src/components/SideNav/SideNav.tsx","../src/components/Spinner/styles.css.ts","../src/components/Spinner/Spinner.tsx","../src/components/StatusIcon/styles.css.ts","../src/components/StatusIcon/StatusIcon.tsx","../src/components/Table/styles.css.ts","../src/components/Table/Table.tsx","../src/components/Tabs/styles.css.ts","../src/components/Tabs/TabsContext.ts","../src/components/Tabs/useTabsRoot.ts","../src/components/Tabs/Tabs.tsx","../src/components/Textarea/styles.css.ts","../src/components/Textarea/Textarea.tsx","../../tokens/dist/index.js","../src/components/ThemeProvider/ThemeProvider.tsx","../src/components/Text/styles.css.ts","../src/components/Text/Text.tsx","../src/components/Tooltip/styles.css.ts","../src/components/Tooltip/Tooltip.tsx","../src/components/Stack/styles.css.ts","../src/components/Stack/Stack.tsx","../src/components/Inline/styles.css.ts","../src/components/Inline/Inline.tsx","../src/components/Cluster/styles.css.ts","../src/components/Cluster/Cluster.tsx","../src/components/Grid/styles.css.ts","../src/components/Grid/Grid.tsx","../src/hooks/useContainerQuery.ts"],"sourcesContent":["/**\n * @license react-strict-dom\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';\nimport * as stylex from '@stylexjs/stylex';\n\nvar styleq$1 = {};\n\nObject.defineProperty(styleq$1, \"__esModule\", {\n value: true\n});\nvar styleq_2 = styleq$1.styleq = void 0;\nvar cache = new WeakMap();\nvar compiledKey = '$$css';\nfunction createStyleq(options) {\n var disableCache;\n var disableMix;\n var transform;\n if (options != null) {\n disableCache = options.disableCache === true;\n disableMix = options.disableMix === true;\n transform = options.transform;\n }\n return function styleq() {\n var definedProperties = [];\n var className = '';\n var inlineStyle = null;\n var debugString = '';\n var nextCache = disableCache ? null : cache;\n var styles = new Array(arguments.length);\n for (var i = 0; i < arguments.length; i++) {\n styles[i] = arguments[i];\n }\n while (styles.length > 0) {\n var possibleStyle = styles.pop();\n if (possibleStyle == null || possibleStyle === false) {\n continue;\n }\n if (Array.isArray(possibleStyle)) {\n for (var _i = 0; _i < possibleStyle.length; _i++) {\n styles.push(possibleStyle[_i]);\n }\n continue;\n }\n var style = transform != null ? transform(possibleStyle) : possibleStyle;\n if (style.$$css != null) {\n var classNameChunk = '';\n if (nextCache != null && nextCache.has(style)) {\n var cacheEntry = nextCache.get(style);\n if (cacheEntry != null) {\n classNameChunk = cacheEntry[0];\n debugString = cacheEntry[2];\n definedProperties.push.apply(definedProperties, cacheEntry[1]);\n nextCache = cacheEntry[3];\n }\n } else {\n var definedPropertiesChunk = [];\n for (var prop in style) {\n var value = style[prop];\n if (prop === compiledKey) {\n var compiledKeyValue = style[prop];\n if (compiledKeyValue !== true) {\n debugString = debugString ? compiledKeyValue + '; ' + debugString : compiledKeyValue;\n }\n continue;\n }\n if (typeof value === 'string' || value === null) {\n if (!definedProperties.includes(prop)) {\n definedProperties.push(prop);\n if (nextCache != null) {\n definedPropertiesChunk.push(prop);\n }\n if (typeof value === 'string') {\n classNameChunk += classNameChunk ? ' ' + value : value;\n }\n }\n } else {\n console.error(\"styleq: \".concat(prop, \" typeof \").concat(String(value), \" is not \\\"string\\\" or \\\"null\\\".\"));\n }\n }\n if (nextCache != null) {\n var weakMap = new WeakMap();\n nextCache.set(style, [classNameChunk, definedPropertiesChunk, debugString, weakMap]);\n nextCache = weakMap;\n }\n }\n if (classNameChunk) {\n className = className ? classNameChunk + ' ' + className : classNameChunk;\n }\n } else {\n if (disableMix) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n inlineStyle = Object.assign({}, style, inlineStyle);\n } else {\n var subStyle = null;\n for (var _prop in style) {\n var _value = style[_prop];\n if (_value !== undefined) {\n if (!definedProperties.includes(_prop)) {\n if (_value != null) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n if (subStyle == null) {\n subStyle = {};\n }\n subStyle[_prop] = _value;\n }\n definedProperties.push(_prop);\n nextCache = null;\n }\n }\n }\n if (subStyle != null) {\n inlineStyle = Object.assign(subStyle, inlineStyle);\n }\n }\n }\n }\n var styleProps = [className, inlineStyle, debugString];\n return styleProps;\n };\n}\nvar styleq = styleq_2 = styleq$1.styleq = createStyleq();\nstyleq.factory = createStyleq;\n\nconst optimizedStyleq = styleq_2.factory({\n disableMix: true\n});\nfunction merge(...styles) {\n const [className, style, dataStyleSrc] = optimizedStyleq(styles);\n const result = {};\n if (className != null && className !== '') {\n result.className = className;\n }\n if (style != null) {\n result.style = style;\n }\n if (dataStyleSrc != null && dataStyleSrc !== '') {\n const chunks = dataStyleSrc.split(';');\n const pathsMap = {};\n for (const chunk of chunks) {\n const trimmed = chunk.trim();\n const [path, line] = trimmed.split(':');\n if (line != null) {\n pathsMap[path] = pathsMap[path] != null ? `${pathsMap[path]},${line}` : line;\n }\n }\n result['data-style-src'] = Object.keys(pathsMap).map(path => `${path}:${pathsMap[path]}`).join('; ');\n }\n return result;\n}\n\nconst styles = stylex.create({\n block: {\n margin: 0,\n padding: 0\n },\n inline: {\n margin: 0,\n padding: 0,\n textDecoration: 'none',\n textAlign: 'inherit',\n wordWrap: 'break-word'\n },\n inlineblock: {\n borderStyle: 'solid',\n margin: 0,\n padding: 0\n },\n button: {\n borderWidth: 1\n },\n codePre: {\n fontFamily: 'monospace, \"monospace\"',\n fontSize: '1em',\n overflow: 'auto'\n },\n heading: {\n fontSize: '1.5rem',\n wordWrap: 'break-word'\n },\n hr: {\n backgroundColor: 'black',\n borderStyle: 'none',\n borderWidth: 0,\n boxSizing: 'border-box',\n height: 1\n },\n img: {\n aspectRatio: 'attr(width) / attr(height)',\n height: 'auto',\n maxWidth: '100%'\n },\n input: {\n borderWidth: 1,\n borderStyle: 'solid'\n },\n list: {\n listStyle: 'none'\n },\n strong: {\n fontWeight: 'bold'\n },\n textarea: {\n borderWidth: 1,\n borderStyle: 'solid',\n resize: 'vertical'\n }\n});\nconst a = styles.inline;\nconst article = styles.block;\nconst aside = styles.block;\nconst b = styles.inline;\nconst bdi = styles.inline;\nconst bdo = styles.inline;\nconst blockquote = styles.block;\nconst br = null;\nconst button = [styles.inlineblock, styles.button];\nconst code = [styles.inline, styles.codePre];\nconst del = null;\nconst div = styles.block;\nconst em = styles.inline;\nconst fieldset = styles.block;\nconst footer = styles.block;\nconst form = styles.block;\nconst heading = [styles.block, styles.heading];\nconst header = styles.block;\nconst hr = [styles.block, styles.hr];\nconst i = styles.inline;\nconst img = styles.img;\nconst input = [styles.inlineblock, styles.input];\nconst ins = null;\nconst kbd = null;\nconst label = styles.inline;\nconst li = styles.block;\nconst main = styles.block;\nconst mark = styles.inline;\nconst nav = styles.block;\nconst ol = [styles.list, styles.block];\nconst optgroup = null;\nconst option = null;\nconst p = styles.block;\nconst pre = [styles.block, styles.codePre];\nconst s = null;\nconst section = styles.block;\nconst select = styles.inlineblock;\nconst span = styles.inline;\nconst strong = [styles.inline, styles.strong];\nconst sub = styles.inline;\nconst sup = styles.inline;\nconst textarea = [styles.inlineblock, styles.textarea];\nconst u = null;\nconst ul = [styles.list, styles.block];\nconst defaultStyles = {\n a: a,\n article: article,\n aside: aside,\n b: b,\n bdi: bdi,\n bdo: bdo,\n blockquote: blockquote,\n br: br,\n button: button,\n code: code,\n del: del,\n div: div,\n em: em,\n fieldset: fieldset,\n footer: footer,\n form: form,\n h1: heading,\n h2: heading,\n h3: heading,\n h4: heading,\n h5: heading,\n h6: heading,\n header: header,\n hr: hr,\n i: i,\n img: img,\n input: input,\n ins: ins,\n kbd: kbd,\n label: label,\n li: li,\n main: main,\n mark: mark,\n nav: nav,\n ol: ol,\n optgroup: optgroup,\n option: option,\n p: p,\n pre: pre,\n s: s,\n section: section,\n select: select,\n span: span,\n strong: strong,\n sub: sub,\n sup: sup,\n textarea: textarea,\n u: u,\n ul: ul\n};\n\nexport { defaultStyles, merge };\n","import type {ReactNode} from 'react'\n\nexport type IconName =\n | 'x-circle'\n | 'check-circle'\n | 'check-done'\n | 'clock'\n | 'forbidden'\n | 'info-circle'\n | 'alert-triangle'\n | 'shield'\n | 'lock'\n | 'key'\n\nconst icons: Record<IconName, ReactNode> = {\n 'x-circle': (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"15\" y1=\"9\" x2=\"9\" y2=\"15\" />\n <line x1=\"9\" y1=\"9\" x2=\"15\" y2=\"15\" />\n </>\n ),\n 'check-circle': (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <polyline points=\"16 10 11 15 8 12\" />\n </>\n ),\n 'check-done': (\n <>\n <path d=\"M22 11.08V12a10 10 0 1 1-5.93-9.14\" />\n <polyline points=\"22 4 12 14.01 9 11.01\" />\n </>\n ),\n clock: (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <polyline points=\"12 6 12 12 16 14\" />\n </>\n ),\n forbidden: (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"4.93\" y1=\"4.93\" x2=\"19.07\" y2=\"19.07\" />\n </>\n ),\n 'info-circle': (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"12\" y1=\"16\" x2=\"12\" y2=\"12\" />\n <line x1=\"12\" y1=\"8\" x2=\"12.01\" y2=\"8\" />\n </>\n ),\n 'alert-triangle': (\n <>\n <path d=\"M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z\" />\n <line x1=\"12\" y1=\"9\" x2=\"12\" y2=\"13\" />\n <line x1=\"12\" y1=\"17\" x2=\"12.01\" y2=\"17\" />\n </>\n ),\n shield: (\n <path d=\"M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z\" />\n ),\n lock: (\n <>\n <rect x=\"3\" y=\"11\" width=\"18\" height=\"11\" rx=\"2\" ry=\"2\" />\n <path d=\"M7 11V7a5 5 0 0 1 10 0v4\" />\n </>\n ),\n key: (\n <>\n <path d=\"M21 2l-2 2m-7.61 7.61a5.5 5.5 0 1 1-7.78 7.78 5.5 5.5 0 0 1 7.78-7.78zm0 0L15.5 7.5m0 0l3 3L22 7l-3-3m-3.5 3.5L19 4\" />\n </>\n ),\n}\n\ninterface IconProps {\n name: IconName\n size?: number\n}\n\nexport function Icon({name, size = 24}: IconProps) {\n return (\n <svg\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n width={size}\n height={size}\n >\n {icons[name]}\n </svg>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'flex-start',\n gap: spacing.sm,\n padding: spacing.md,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n },\n iconWrap: {\n flexShrink: 0,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n paddingTop: 1,\n },\n content: {\n flex: 1,\n minWidth: 0,\n },\n error: {\n backgroundColor: colors.errorBg,\n borderColor: colors.errorBorder,\n color: colors.errorText,\n },\n success: {\n backgroundColor: colors.successBg,\n borderColor: colors.successBorder,\n color: colors.successText,\n },\n warning: {\n backgroundColor: colors.warningBg,\n borderColor: colors.warningBorder,\n color: colors.warningText,\n },\n info: {\n backgroundColor: colors.infoBg,\n borderColor: colors.infoBorder,\n color: colors.infoText,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {Icon} from '../Icon'\nimport type {IconName} from '../Icon'\nimport {styles} from './styles.css'\n\nexport type AlertVariant = 'error' | 'success' | 'warning' | 'info'\n\nconst defaultIcons: Record<AlertVariant, IconName> = {\n info: 'info-circle',\n warning: 'alert-triangle',\n success: 'check-circle',\n error: 'x-circle',\n}\n\ninterface AlertProps {\n variant?: AlertVariant\n /** Built-in icon name, custom ReactNode, or false to hide. Defaults to variant icon. */\n icon?: IconName | ReactNode | false\n children: ReactNode\n}\n\nfunction resolveIcon(\n icon: AlertProps['icon'],\n variant: AlertVariant,\n): ReactNode | null {\n if (icon === false) return null\n if (icon === undefined) return <Icon name={defaultIcons[variant]} size={18} />\n if (typeof icon === 'string') return <Icon name={icon as IconName} size={18} />\n return icon\n}\n\nexport function Alert({variant = 'info', icon, children}: AlertProps) {\n const resolvedIcon = resolveIcon(icon, variant)\n\n return (\n <html.div role=\"alert\" style={[styles.base, styles[variant]]}>\n {resolvedIcon ? (\n <>\n <html.div style={styles.iconWrap}>{resolvedIcon}</html.div>\n <html.div style={styles.content}>{children}</html.div>\n </>\n ) : (\n children\n )}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n fontFamily: typography.fontFamily,\n fontWeight: typography.fontWeightMedium,\n lineHeight: 1,\n borderRadius: radii.full,\n whiteSpace: 'nowrap',\n },\n sizeMd: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n sizeSm: {\n paddingTop: 2,\n paddingBottom: 2,\n paddingLeft: spacing.xs,\n paddingRight: spacing.xs,\n fontSize: '0.625rem',\n },\n default: {\n backgroundColor: colors.bgCardHover,\n color: colors.textMuted,\n },\n success: {\n backgroundColor: colors.successBg,\n color: colors.successText,\n },\n warning: {\n backgroundColor: colors.warningBg,\n color: colors.warningText,\n },\n error: {\n backgroundColor: colors.errorBg,\n color: colors.errorText,\n },\n info: {\n backgroundColor: colors.infoBg,\n color: colors.infoText,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type BadgeVariant = 'default' | 'success' | 'warning' | 'error' | 'info'\nexport type BadgeSize = 'sm' | 'md'\n\ninterface BadgeProps {\n variant?: BadgeVariant\n size?: BadgeSize\n children: ReactNode\n}\n\nconst sizeMap = {\n sm: styles.sizeSm,\n md: styles.sizeMd,\n} as const\n\nexport function Badge({variant = 'default', size = 'md', children}: BadgeProps) {\n return <html.span style={[styles.base, sizeMap[size], styles[variant]]}>{children}</html.span>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color, color, opacity',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n textDecoration: 'none',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 2,\n },\n },\n sizeDefault: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n },\n sizeSmall: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n primary: {\n backgroundColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n ':active': colors.accentHover,\n },\n borderColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n color: colors.accentContrast,\n },\n secondary: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderColor: colors.border,\n color: colors.textMuted,\n },\n link: {\n backgroundColor: 'transparent',\n borderColor: 'transparent',\n color: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n textDecoration: {\n default: 'none',\n ':hover': 'underline',\n },\n paddingLeft: 0,\n paddingRight: 0,\n },\n danger: {\n backgroundColor: {\n default: colors.error,\n ':hover': colors.errorHover,\n ':active': colors.errorHover,\n },\n borderColor: {\n default: colors.error,\n ':hover': colors.errorHover,\n },\n color: colors.errorContrast,\n },\n fullWidth: {\n width: '100%',\n },\n disabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type ButtonVariant = 'primary' | 'secondary' | 'link' | 'danger'\nexport type ButtonSize = 'default' | 'small'\n\ninterface ButtonProps {\n variant?: ButtonVariant\n size?: ButtonSize\n fullWidth?: boolean\n disabled?: boolean\n type?: 'button' | 'submit'\n onClick?: () => void\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n small: styles.sizeSmall,\n} as const\n\nexport function Button({\n variant = 'primary',\n size = 'default',\n fullWidth = false,\n disabled = false,\n type = 'button',\n onClick,\n children,\n}: ButtonProps) {\n return (\n <html.button\n type={type}\n disabled={disabled}\n onClick={onClick}\n style={[\n styles.base,\n sizeMap[size],\n styles[variant],\n fullWidth && styles.fullWidth,\n disabled && styles.disabled,\n ]}\n >\n {children}\n </html.button>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n base: {\n backgroundColor: colors.bgCard,\n color: colors.text,\n fontFamily: typography.fontFamily,\n },\n // Variants\n elevated: {\n borderRadius: radii.lg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n boxShadow: shadows.md,\n },\n outlined: {\n borderRadius: radii.md,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n },\n filled: {\n borderRadius: radii.md,\n },\n interactive: {\n borderRadius: radii.md,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':hover': colors.accent,\n },\n backgroundColor: {\n default: colors.bgCard,\n ':hover': colors.bgCardHover,\n },\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color, transform',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n transform: {\n default: 'translateY(0)',\n ':hover': 'translateY(-2px)',\n },\n },\n // Sizes (padding)\n sizeDefault: {\n padding: spacing.lg,\n },\n sizeCompact: {\n padding: spacing.md,\n },\n sizeFull: {\n padding: spacing.xl,\n },\n // Header\n header: {\n fontSize: typography.fontSizeLg,\n fontWeight: typography.fontWeightSemibold,\n marginBottom: spacing.md,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type CardVariant = 'elevated' | 'outlined' | 'filled' | 'interactive'\nexport type CardSize = 'default' | 'compact' | 'full'\n\ninterface CardProps {\n variant?: CardVariant\n size?: CardSize\n header?: string\n onClick?: () => void\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n compact: styles.sizeCompact,\n full: styles.sizeFull,\n} as const\n\nexport function Card({\n variant = 'outlined',\n size = 'default',\n header,\n onClick,\n children,\n}: CardProps) {\n return (\n <html.div onClick={onClick} style={[styles.base, styles[variant], sizeMap[size]]}>\n {header && <html.div style={styles.header}>{header}</html.div>}\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n gap: spacing.sm,\n cursor: 'pointer',\n fontSize: typography.fontSizeSm,\n color: colors.text,\n lineHeight: typography.lineHeight,\n },\n rootDisabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n },\n box: {\n width: 18,\n height: 18,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n transitionProperty: 'background-color, border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n boxUnchecked: {\n backgroundColor: colors.bg,\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n },\n },\n boxChecked: {\n backgroundColor: colors.accent,\n borderColor: colors.accent,\n },\n check: {\n width: 12,\n height: 12,\n color: colors.accentContrast,\n },\n input: {\n position: 'absolute',\n width: 1,\n height: 1,\n opacity: 0,\n overflow: 'hidden',\n },\n})\n","import {type ReactNode, useState, useCallback} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\ninterface CheckboxProps {\n name?: string\n value?: string\n checked?: boolean\n defaultChecked?: boolean\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void\n children?: ReactNode\n}\n\nexport function Checkbox({\n name,\n value,\n checked: controlledChecked,\n defaultChecked = false,\n disabled = false,\n onChange,\n children,\n}: CheckboxProps) {\n const isControlled = controlledChecked !== undefined\n const [internalChecked, setInternalChecked] = useState(defaultChecked)\n const isChecked = isControlled ? controlledChecked : internalChecked\n\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!isControlled) {\n setInternalChecked(e.target.checked)\n }\n onChange?.(e)\n },\n [isControlled, onChange],\n )\n\n return (\n <html.label style={[styles.root, disabled && styles.rootDisabled]}>\n <html.input\n type=\"checkbox\"\n name={name}\n value={value}\n checked={isControlled ? controlledChecked : undefined}\n defaultChecked={!isControlled ? defaultChecked : undefined}\n disabled={disabled}\n onChange={handleChange}\n style={styles.input}\n />\n <html.span\n style={[styles.box, isChecked ? styles.boxChecked : styles.boxUnchecked]}\n aria-hidden\n >\n <svg\n width={12}\n height={12}\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n style={{opacity: isChecked ? 1 : 0}}\n >\n <polyline\n points=\"2.5 6 5 8.5 9.5 3.5\"\n stroke=\"currentColor\"\n strokeWidth={1.5}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </html.span>\n {children && <html.span>{children}</html.span>}\n </html.label>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n paddingTop: spacing.xl,\n paddingBottom: spacing.xl,\n textAlign: 'center',\n },\n message: {\n fontSize: typography.fontSizeSm,\n color: colors.textMuted,\n lineHeight: typography.lineHeight,\n },\n action: {\n marginTop: spacing.sm,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\ninterface EmptyStateProps {\n message: string\n icon?: ReactNode\n action?: ReactNode\n}\n\nexport function EmptyState({message, icon, action}: EmptyStateProps) {\n return (\n <html.div style={styles.root}>\n {icon}\n <html.p style={styles.message}>{message}</html.p>\n {action && <html.div style={styles.action}>{action}</html.div>}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {typography, typeScale} from './typography.css'\n\nexport const typePresets = css.create({\n // Body\n bodySm: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize3,\n lineHeight: typeScale.lineHeight3,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n bodyMd: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize4,\n lineHeight: typeScale.lineHeight4,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n bodyLg: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize5,\n lineHeight: typeScale.lineHeight5,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n\n // UI\n caption: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize1,\n lineHeight: typeScale.lineHeight1,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingWide,\n },\n label: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize3,\n lineHeight: typeScale.lineHeight3,\n fontWeight: typography.fontWeightMedium,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n code: {\n fontFamily: typography.fontFamilyMono,\n fontSize: typeScale.fontSize3,\n lineHeight: typeScale.lineHeight3,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n overline: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize1,\n lineHeight: typeScale.lineHeight1,\n fontWeight: typography.fontWeightSemibold,\n letterSpacing: typeScale.letterSpacingWide,\n textTransform: 'uppercase' as const,\n },\n\n // Heading\n headingSm: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize6,\n lineHeight: typeScale.lineHeight6,\n fontWeight: typography.fontWeightSemibold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n headingMd: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize7,\n lineHeight: typeScale.lineHeight7,\n fontWeight: typography.fontWeightSemibold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n headingLg: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize8,\n lineHeight: typeScale.lineHeight8,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n headingXl: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize9,\n lineHeight: typeScale.lineHeight9,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n\n // Display (fluid)\n displaySm: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.displaySm,\n lineHeight: 1.2,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n displayMd: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.displayMd,\n lineHeight: 1.15,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n displayLg: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.displayLg,\n lineHeight: 1.1,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n})\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\n\nexport const styles = css.create({\n // Colors\n default: {\n color: colors.text,\n },\n muted: {\n color: colors.textMuted,\n },\n accent: {\n color: colors.accent,\n },\n\n // Alignment\n alignStart: {\n textAlign: 'start',\n },\n alignCenter: {\n textAlign: 'center',\n },\n alignEnd: {\n textAlign: 'end',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {typePresets} from '@duro-app/tokens/tokens/type-presets.css'\nimport {styles} from './styles.css'\n\nexport type HeadingVariant =\n | 'displayLg'\n | 'displayMd'\n | 'displaySm'\n | 'headingXl'\n | 'headingLg'\n | 'headingMd'\n | 'headingSm'\n\ninterface HeadingProps {\n level: 1 | 2 | 3 | 4 | 5 | 6\n variant?: HeadingVariant\n color?: 'default' | 'muted' | 'accent'\n align?: 'start' | 'center' | 'end'\n children: ReactNode\n}\n\nconst defaultVariantMap: Record<number, HeadingVariant> = {\n 1: 'headingXl',\n 2: 'headingLg',\n 3: 'headingMd',\n 4: 'headingSm',\n 5: 'headingSm',\n 6: 'headingSm',\n}\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n} as const\n\nexport function Heading({level, variant, color = 'default', align, children}: HeadingProps) {\n const resolvedVariant = variant ?? defaultVariantMap[level]\n const style = [typePresets[resolvedVariant], styles[color], align && alignMap[align]]\n\n if (level === 1) return <html.h1 style={style}>{children}</html.h1>\n if (level === 2) return <html.h2 style={style}>{children}</html.h2>\n if (level === 3) return <html.h3 style={style}>{children}</html.h3>\n if (level === 4) return <html.h4 style={style}>{children}</html.h4>\n if (level === 5) return <html.h5 style={style}>{children}</html.h5>\n return <html.h6 style={style}>{children}</html.h6>\n}\n","import {createContext, useContext} from 'react'\n\ninterface FieldContextValue {\n controlId: string\n descriptionId: string\n errorId: string\n invalid: boolean\n}\n\nexport const FieldContext = createContext<FieldContextValue | null>(null)\n\nexport function useFieldContext() {\n return useContext(FieldContext)\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n gap: spacing.xs,\n },\n label: {\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n color: colors.text,\n },\n description: {\n fontSize: typography.fontSizeXs,\n color: colors.textMuted,\n },\n error: {\n fontSize: typography.fontSizeXs,\n color: colors.error,\n },\n})\n","import {type ReactNode, useId, useMemo} from 'react'\nimport {html} from 'react-strict-dom'\nimport {FieldContext, useFieldContext} from './FieldContext'\nimport {styles} from './styles.css'\n\n// --- Root ---\ninterface RootProps {\n invalid?: boolean\n children: ReactNode\n}\n\nfunction Root({invalid = false, children}: RootProps) {\n const id = useId()\n const ctx = useMemo(\n () => ({\n controlId: `${id}-control`,\n descriptionId: `${id}-description`,\n errorId: `${id}-error`,\n invalid,\n }),\n [id, invalid],\n )\n\n return (\n <FieldContext.Provider value={ctx}>\n <html.div style={styles.root}>{children}</html.div>\n </FieldContext.Provider>\n )\n}\n\n// --- Label ---\ninterface LabelProps {\n children: ReactNode\n}\n\nfunction Label({children}: LabelProps) {\n const ctx = useFieldContext()\n return (\n <html.label for={ctx?.controlId} style={styles.label}>\n {children}\n </html.label>\n )\n}\n\n// --- Description ---\ninterface DescriptionProps {\n children: ReactNode\n}\n\nfunction Description({children}: DescriptionProps) {\n const ctx = useFieldContext()\n return (\n <html.span id={ctx?.descriptionId} style={styles.description}>\n {children}\n </html.span>\n )\n}\n\n// --- Error ---\ninterface ErrorProps {\n children?: ReactNode\n}\n\nfunction Error({children}: ErrorProps) {\n const ctx = useFieldContext()\n if (!ctx?.invalid && !children) return null\n\n return (\n <html.span id={ctx?.errorId} role=\"alert\" style={styles.error}>\n {children}\n </html.span>\n )\n}\n\nexport const Field = {\n Root,\n Label,\n Description,\n Error,\n}\n","import {createContext, useContext} from 'react'\n\ninterface InputGroupContextValue {\n inGroup: boolean\n}\n\nexport const InputGroupContext = createContext<InputGroupContextValue | null>(null)\n\nexport function useInputGroupContext() {\n return useContext(InputGroupContext)\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n width: '100%',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n color: colors.text,\n backgroundColor: colors.bg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 1,\n },\n },\n default: {\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n ':focus': colors.accent,\n },\n },\n error: {\n borderColor: {\n default: colors.error,\n ':focus': colors.error,\n },\n },\n inGroup: {\n borderWidth: 0,\n borderRadius: 0,\n outlineWidth: 0,\n },\n})\n","import {html} from 'react-strict-dom'\nimport {useFieldContext} from '../Field/FieldContext'\nimport {useInputGroupContext} from '../InputGroup/InputGroupContext'\nimport {styles} from './styles.css'\n\ntype StrictInputProps = React.ComponentProps<typeof html.input>\nexport type InputType = NonNullable<StrictInputProps['type']>\n\nexport type InputVariant = 'default' | 'error'\n\ninterface InputProps {\n variant?: InputVariant\n type?: InputType\n name?: string\n placeholder?: string\n required?: boolean\n minLength?: number\n pattern?: string\n autoComplete?:\n | 'on'\n | 'off'\n | 'email'\n | 'username'\n | 'current-password'\n | 'new-password'\n | 'name'\n | 'tel'\n | 'url'\n value?: string\n defaultValue?: string\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void\n}\n\nexport function Input({\n variant = 'default',\n type = 'text',\n name,\n placeholder,\n required,\n minLength,\n pattern,\n autoComplete,\n value,\n defaultValue,\n disabled,\n onChange,\n}: InputProps) {\n const ctx = useFieldContext()\n const groupCtx = useInputGroupContext()\n\n // react-strict-dom omits web-only `pattern` from its types, but the\n // underlying DOM element supports it. Type-assert to pass it through.\n const extraProps = pattern !== undefined ? {pattern} : undefined\n\n return (\n <html.input\n id={ctx?.controlId}\n type={type}\n name={name}\n placeholder={placeholder}\n required={required}\n minLength={minLength}\n autoComplete={autoComplete}\n value={value}\n defaultValue={defaultValue}\n disabled={disabled}\n aria-describedby={\n ctx ? `${ctx.descriptionId} ${ctx.invalid ? ctx.errorId : ''}`.trim() : undefined\n }\n aria-invalid={ctx?.invalid || variant === 'error' || undefined}\n onChange={onChange}\n style={[styles.base, styles[variant], groupCtx?.inGroup && styles.inGroup]}\n {...(extraProps as Record<string, unknown>)}\n />\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n wrapper: {\n display: 'flex',\n alignItems: 'stretch',\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':focus-within': colors.accent,\n },\n borderRadius: radii.sm,\n overflow: 'hidden',\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n addon: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n backgroundColor: colors.bgCardHover,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.textMuted,\n userSelect: 'none',\n borderWidth: 0,\n },\n addonStart: {\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n },\n addonEnd: {\n borderLeftWidth: 1,\n borderLeftStyle: 'solid',\n borderLeftColor: colors.border,\n },\n addonClickable: {\n cursor: 'pointer',\n backgroundColor: {\n default: colors.bgCardHover,\n ':hover': colors.bgCard,\n ':active': colors.bg,\n },\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n addonDisabled: {\n opacity: 0.4,\n cursor: 'not-allowed',\n },\n})\n","import type {ReactNode} from 'react'\nimport {useMemo} from 'react'\nimport {html} from 'react-strict-dom'\nimport {InputGroupContext} from './InputGroupContext'\nimport {styles} from './styles.css'\n\n// --- Root ---\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const ctx = useMemo(() => ({inGroup: true}), [])\n\n return (\n <InputGroupContext.Provider value={ctx}>\n <html.div style={styles.wrapper}>{children}</html.div>\n </InputGroupContext.Provider>\n )\n}\n\n// --- Addon ---\ninterface AddonProps {\n position?: 'start' | 'end'\n onClick?: () => void\n disabled?: boolean\n children: ReactNode\n}\n\nfunction Addon({position = 'end', onClick, disabled, children}: AddonProps) {\n const positionStyle = position === 'start' ? styles.addonStart : styles.addonEnd\n const style = [\n styles.addon,\n positionStyle,\n onClick && !disabled && styles.addonClickable,\n disabled && styles.addonDisabled,\n ]\n\n if (onClick) {\n return (\n <html.button type=\"button\" onClick={onClick} disabled={disabled} style={style}>\n {children}\n </html.button>\n )\n }\n\n return <html.span style={style}>{children}</html.span>\n}\n\nexport const InputGroup = {\n Root,\n Addon,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n cursor: 'pointer',\n textDecoration: 'none',\n transitionProperty: 'background-color, border-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n sizeDefault: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n },\n sizeSmall: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n primary: {\n backgroundColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n color: colors.accentContrast,\n },\n secondary: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n color: colors.textMuted,\n },\n fullWidth: {\n width: '100%',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type LinkButtonVariant = 'primary' | 'secondary'\nexport type LinkButtonSize = 'default' | 'small'\n\ninterface LinkButtonProps {\n href: string\n variant?: LinkButtonVariant\n size?: LinkButtonSize\n fullWidth?: boolean\n target?: '_blank' | '_self'\n rel?: string\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n small: styles.sizeSmall,\n} as const\n\nexport function LinkButton({\n href,\n variant = 'primary',\n size = 'default',\n fullWidth = false,\n target,\n rel,\n children,\n}: LinkButtonProps) {\n return (\n <html.a\n href={href}\n target={target}\n rel={rel}\n style={[styles.base, sizeMap[size], styles[variant], fullWidth && styles.fullWidth]}\n >\n {children}\n </html.a>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n trigger: {\n display: 'inline-flex',\n alignItems: 'center',\n gap: spacing.sm,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.text,\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color',\n transitionDuration: '150ms',\n },\n backdrop: {\n position: 'fixed',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n zIndex: 49,\n },\n popup: {\n position: 'absolute',\n top: '100%',\n left: 0,\n marginTop: spacing.xs,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n boxShadow: shadows.md,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n minWidth: 160,\n zIndex: 50,\n },\n popupEnd: {\n left: 'auto',\n right: 0,\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n fontFamily: typography.fontFamily,\n color: colors.text,\n borderRadius: radii.sm,\n cursor: 'pointer',\n backgroundColor: 'transparent',\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n itemHighlighted: {\n backgroundColor: colors.bgCardHover,\n },\n linkItem: {\n textDecoration: 'none',\n color: {\n default: colors.text,\n ':hover': colors.text,\n },\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface MenuContextValue {\n open: boolean\n toggle: () => void\n close: () => void\n menuId: string\n highlightedId: string | null\n setHighlightedId: (id: string | null) => void\n registerItem: (id: string, element: HTMLElement) => () => void\n triggerRef: React.RefObject<HTMLButtonElement | null>\n}\n\nexport const MenuContext = createContext<MenuContextValue | null>(null)\n\nexport function useMenu() {\n const ctx = useContext(MenuContext)\n if (!ctx) throw new Error('Menu compound components must be used within Menu.Root')\n return ctx\n}\n","import {useState, useCallback, useRef, useId, useEffect} from 'react'\nimport type {MenuContextValue} from './MenuContext'\n\nexport function useMenuRoot() {\n const [open, setOpen] = useState(false)\n const [highlightedId, setHighlightedId] = useState<string | null>(null)\n const menuId = useId()\n const rootRef = useRef<HTMLDivElement>(null)\n const triggerRef = useRef<HTMLButtonElement | null>(null)\n const itemsRef = useRef(new Map<string, HTMLElement>())\n const orderRef = useRef<string[]>([])\n const needsInitialHighlightRef = useRef(false)\n\n const close = useCallback(() => {\n setOpen(false)\n setHighlightedId(null)\n needsInitialHighlightRef.current = false\n triggerRef.current?.focus()\n }, [])\n\n const toggle = useCallback(() => {\n setOpen((prev) => {\n if (!prev) {\n needsInitialHighlightRef.current = true\n } else {\n setHighlightedId(null)\n needsInitialHighlightRef.current = false\n }\n return !prev\n })\n }, [])\n\n // Highlight the first item after items register on open.\n // Child effects (item registration) run before this parent effect,\n // so orderRef is populated by the time this runs.\n useEffect(() => {\n if (open && needsInitialHighlightRef.current) {\n needsInitialHighlightRef.current = false\n const order = orderRef.current\n if (order.length > 0) {\n setHighlightedId(order[0])\n }\n }\n }, [open])\n\n const registerItem = useCallback((id: string, element: HTMLElement) => {\n itemsRef.current.set(id, element)\n const map = itemsRef.current\n const ids = [...map.keys()]\n ids.sort((a, b) => {\n const elA = map.get(a)\n const elB = map.get(b)\n if (!elA || !elB) return 0\n return elA.compareDocumentPosition(elB) & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1\n })\n orderRef.current = ids\n return () => {\n itemsRef.current.delete(id)\n orderRef.current = orderRef.current.filter((i) => i !== id)\n }\n }, [])\n\n // Native keydown for full KeyboardEvent access (preventDefault)\n useEffect(() => {\n const root = rootRef.current\n if (!root || !open) return\n\n function handleKeyDown(e: KeyboardEvent) {\n const order = orderRef.current\n if (order.length === 0) return\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : -1\n return order[(idx + 1) % order.length]\n })\n break\n }\n case 'ArrowUp': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : 0\n return order[(idx - 1 + order.length) % order.length]\n })\n break\n }\n case 'Home': {\n e.preventDefault()\n setHighlightedId(order[0])\n break\n }\n case 'End': {\n e.preventDefault()\n setHighlightedId(order[order.length - 1])\n break\n }\n case 'Enter':\n case ' ': {\n e.preventDefault()\n const items = itemsRef.current\n setHighlightedId((prev) => {\n if (prev) {\n const el = items.get(prev)\n el?.click()\n }\n return prev\n })\n break\n }\n case 'Escape':\n case 'Tab': {\n close()\n break\n }\n }\n }\n\n root.addEventListener('keydown', handleKeyDown)\n return () => root.removeEventListener('keydown', handleKeyDown)\n }, [open, close])\n\n const ctx: MenuContextValue = {\n open,\n toggle,\n close,\n menuId,\n highlightedId,\n setHighlightedId,\n registerItem,\n triggerRef,\n }\n\n return {ctx, rootRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {MenuContext, useMenu} from './MenuContext'\nimport {useMenuRoot} from './useMenuRoot'\n\n// --- Root ---\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const {ctx, rootRef} = useMenuRoot()\n\n return (\n <MenuContext.Provider value={ctx}>\n <html.div ref={rootRef} style={styles.root}>\n {children}\n </html.div>\n </MenuContext.Provider>\n )\n}\n\n// --- Trigger ---\nfunction Trigger({children}: {children: ReactNode}) {\n const {open, toggle, menuId, triggerRef} = useMenu()\n const localRef = useRef<HTMLButtonElement>(null)\n\n // Sync local ref to context triggerRef\n useEffect(() => {\n triggerRef.current = localRef.current\n })\n\n return (\n <html.button\n ref={localRef}\n type=\"button\"\n onClick={toggle}\n aria-expanded={open}\n aria-haspopup=\"menu\"\n aria-controls={open ? menuId : undefined}\n style={styles.trigger}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Popup ---\ninterface PopupProps {\n children: ReactNode\n align?: 'start' | 'end'\n}\n\nfunction Popup({children, align = 'start'}: PopupProps) {\n const {open, close, menuId, highlightedId} = useMenu()\n\n if (!open) return null\n\n return (\n <>\n <html.div style={styles.backdrop} onClick={close} />\n <html.div\n id={menuId}\n role=\"menu\"\n aria-activedescendant={highlightedId ?? undefined}\n style={[styles.popup, align === 'end' && styles.popupEnd]}\n >\n {children}\n </html.div>\n </>\n )\n}\n\n// --- Item ---\ninterface ItemProps {\n onClick?: () => void\n children: ReactNode\n}\n\nfunction Item({onClick, children}: ItemProps) {\n const {close, highlightedId, setHighlightedId, registerItem} = useMenu()\n const id = useId()\n const ref = useRef<HTMLDivElement>(null)\n const isHighlighted = highlightedId === id\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, el)\n }, [id, registerItem])\n\n const handleClick = () => {\n onClick?.()\n close()\n }\n\n return (\n <html.div\n ref={ref}\n id={id}\n role=\"menuitem\"\n onClick={handleClick}\n onPointerEnter={() => setHighlightedId(id)}\n style={[styles.item, isHighlighted && styles.itemHighlighted]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- LinkItem ---\ninterface LinkItemProps {\n href: string\n children: ReactNode\n}\n\nfunction LinkItem({href, children}: LinkItemProps) {\n const {close, highlightedId, setHighlightedId, registerItem} = useMenu()\n const id = useId()\n const ref = useRef<HTMLAnchorElement>(null)\n const isHighlighted = highlightedId === id\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, el)\n }, [id, registerItem])\n\n return (\n <html.a\n ref={ref}\n id={id}\n href={href}\n onClick={close}\n role=\"menuitem\"\n onPointerEnter={() => setHighlightedId(id)}\n style={[styles.item, styles.linkItem, isHighlighted && styles.itemHighlighted]}\n >\n {children}\n </html.a>\n )\n}\n\nexport const Menu = {\n Root,\n Trigger,\n Popup,\n Item,\n LinkItem,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {radii} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n overflow: 'hidden',\n },\n viewport: {\n width: '100%',\n height: '100%',\n overflowX: 'auto',\n overflowY: 'auto',\n // Hide native scrollbar\n scrollbarWidth: 'none',\n },\n content: {\n minWidth: '100%',\n minHeight: '100%',\n },\n scrollbar: {\n position: 'absolute',\n zIndex: 1,\n display: 'flex',\n touchAction: 'none',\n userSelect: 'none',\n transitionProperty: 'opacity',\n transitionDuration: '200ms',\n transitionTimingFunction: 'ease',\n },\n scrollbarVertical: {\n top: 0,\n right: 0,\n bottom: 0,\n width: 8,\n flexDirection: 'column',\n paddingTop: 2,\n paddingBottom: 2,\n paddingRight: 2,\n },\n scrollbarHorizontal: {\n left: 0,\n right: 0,\n bottom: 0,\n height: 8,\n flexDirection: 'row',\n paddingLeft: 2,\n paddingRight: 2,\n paddingBottom: 2,\n },\n scrollbarHidden: {\n opacity: 0,\n },\n scrollbarVisible: {\n opacity: 1,\n },\n thumb: {\n position: 'relative',\n flex: 1,\n backgroundColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n },\n borderRadius: radii.full,\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n // Dynamic styles — simple identifier params only (StyleX constraint)\n viewportMaxHeight: (maxHeight: number | string) => ({\n maxHeight,\n }),\n thumbVertical: (height: string, transform: string) => ({\n height,\n transform,\n }),\n thumbHorizontal: (width: string, transform: string) => ({\n width,\n transform,\n }),\n})\n","import {createContext, useContext} from 'react'\n\nexport interface ScrollAreaContextValue {\n viewportRef: React.RefObject<HTMLDivElement | null>\n contentRef: React.RefObject<HTMLDivElement | null>\n scrollTop: number\n scrollLeft: number\n scrollHeight: number\n scrollWidth: number\n clientHeight: number\n clientWidth: number\n scrolling: boolean\n}\n\nexport const ScrollAreaContext = createContext<ScrollAreaContextValue | null>(null)\n\nexport function useScrollArea() {\n const ctx = useContext(ScrollAreaContext)\n if (!ctx) throw new Error('ScrollArea compound components must be used within ScrollArea.Root')\n return ctx\n}\n","import {useState, useCallback, useRef, useEffect} from 'react'\nimport type {ScrollAreaContextValue} from './ScrollAreaContext'\n\nexport function useScrollAreaRoot(): ScrollAreaContextValue {\n const viewportRef = useRef<HTMLDivElement | null>(null)\n const contentRef = useRef<HTMLDivElement | null>(null)\n const [scrollTop, setScrollTop] = useState(0)\n const [scrollLeft, setScrollLeft] = useState(0)\n const [scrollHeight, setScrollHeight] = useState(0)\n const [scrollWidth, setScrollWidth] = useState(0)\n const [clientHeight, setClientHeight] = useState(0)\n const [clientWidth, setClientWidth] = useState(0)\n const [scrolling, setScrolling] = useState(false)\n const scrollTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const handleScroll = useCallback(() => {\n const vp = viewportRef.current\n if (!vp) return\n\n setScrollTop(vp.scrollTop)\n setScrollLeft(vp.scrollLeft)\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n setScrolling(true)\n\n if (scrollTimerRef.current) clearTimeout(scrollTimerRef.current)\n scrollTimerRef.current = setTimeout(() => setScrolling(false), 1000)\n }, [])\n\n // Observe viewport size changes\n useEffect(() => {\n const vp = viewportRef.current\n if (!vp) return\n\n const observer = new ResizeObserver(() => {\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n })\n observer.observe(vp)\n // Initial measurement\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n\n return () => observer.disconnect()\n }, [])\n\n // Attach scroll listener directly to ensure we capture it\n useEffect(() => {\n const vp = viewportRef.current\n if (!vp) return\n vp.addEventListener('scroll', handleScroll, {passive: true})\n return () => vp.removeEventListener('scroll', handleScroll)\n }, [handleScroll])\n\n return {\n viewportRef,\n contentRef,\n scrollTop,\n scrollLeft,\n scrollHeight,\n scrollWidth,\n clientHeight,\n clientWidth,\n scrolling,\n }\n}\n","import {type ReactNode, useRef, useCallback} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {ScrollAreaContext, useScrollArea} from './ScrollAreaContext'\nimport {useScrollAreaRoot} from './useScrollAreaRoot'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const ctx = useScrollAreaRoot()\n\n return (\n <ScrollAreaContext.Provider value={ctx}>\n <html.div style={styles.root}>{children}</html.div>\n </ScrollAreaContext.Provider>\n )\n}\n\n// --- Viewport ---\n\ninterface ViewportProps {\n children: ReactNode\n maxHeight?: number | string\n}\n\nfunction Viewport({children, maxHeight}: ViewportProps) {\n const {viewportRef} = useScrollArea()\n\n return (\n <html.div\n ref={viewportRef}\n style={[styles.viewport, maxHeight != null && styles.viewportMaxHeight(maxHeight)]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Content ---\n\ninterface ContentProps {\n children: ReactNode\n}\n\nfunction Content({children}: ContentProps) {\n const {contentRef} = useScrollArea()\n return (\n <html.div ref={contentRef} style={styles.content}>\n {children}\n </html.div>\n )\n}\n\n// --- Scrollbar ---\n\ntype ScrollbarOrientation = 'vertical' | 'horizontal'\n\ninterface ScrollbarProps {\n orientation?: ScrollbarOrientation\n children: ReactNode\n}\n\nfunction Scrollbar({orientation = 'vertical', children}: ScrollbarProps) {\n const {scrolling, scrollHeight, scrollWidth, clientHeight, clientWidth} = useScrollArea()\n\n // Hide scrollbar when content fits\n const hasOverflow =\n orientation === 'vertical' ? scrollHeight > clientHeight : scrollWidth > clientWidth\n\n if (!hasOverflow) return null\n\n return (\n <html.div\n style={[\n styles.scrollbar,\n orientation === 'vertical' ? styles.scrollbarVertical : styles.scrollbarHorizontal,\n scrolling ? styles.scrollbarVisible : styles.scrollbarHidden,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Thumb ---\n\ninterface ThumbProps {\n orientation?: ScrollbarOrientation\n}\n\nfunction Thumb({orientation = 'vertical'}: ThumbProps) {\n const {viewportRef, scrollTop, scrollLeft, scrollHeight, scrollWidth, clientHeight, clientWidth} =\n useScrollArea()\n const draggingRef = useRef(false)\n const startPosRef = useRef(0)\n const startScrollRef = useRef(0)\n\n const isVertical = orientation === 'vertical'\n\n const thumbSizePercent = isVertical\n ? Math.max((clientHeight / scrollHeight) * 100, 10)\n : Math.max((clientWidth / scrollWidth) * 100, 10)\n\n const maxScroll = isVertical ? scrollHeight - clientHeight : scrollWidth - clientWidth\n const trackSize = isVertical ? clientHeight : clientWidth\n const thumbPixelSize = (thumbSizePercent / 100) * trackSize\n const scrollOffset = isVertical ? scrollTop : scrollLeft\n const thumbOffset = maxScroll > 0 ? (scrollOffset / maxScroll) * (trackSize - thumbPixelSize) : 0\n\n const thumbStyle = isVertical\n ? styles.thumbVertical(`${thumbSizePercent}%`, `translateY(${thumbOffset}px)`)\n : styles.thumbHorizontal(`${thumbSizePercent}%`, `translateX(${thumbOffset}px)`)\n\n const handlePointerDown = useCallback(\n (e: React.PointerEvent) => {\n e.preventDefault()\n draggingRef.current = true\n startPosRef.current = isVertical ? e.clientY : e.clientX\n startScrollRef.current = isVertical\n ? (viewportRef.current?.scrollTop ?? 0)\n : (viewportRef.current?.scrollLeft ?? 0)\n ;(e.target as HTMLElement).setPointerCapture(e.pointerId)\n },\n [isVertical, viewportRef],\n )\n\n const handlePointerMove = useCallback(\n (e: React.PointerEvent) => {\n if (!draggingRef.current) return\n const vp = viewportRef.current\n if (!vp) return\n\n const delta = (isVertical ? e.clientY : e.clientX) - startPosRef.current\n const scrollRatio = maxScroll / (trackSize - thumbPixelSize)\n const scrollDelta = delta * scrollRatio\n\n if (isVertical) {\n vp.scrollTop = startScrollRef.current + scrollDelta\n } else {\n vp.scrollLeft = startScrollRef.current + scrollDelta\n }\n },\n [isVertical, maxScroll, trackSize, thumbPixelSize, viewportRef],\n )\n\n const handlePointerUp = useCallback(() => {\n draggingRef.current = false\n }, [])\n\n return (\n <html.div\n onPointerDown={handlePointerDown}\n onPointerMove={handlePointerMove}\n onPointerUp={handlePointerUp}\n style={[styles.thumb, thumbStyle]}\n />\n )\n}\n\nexport const ScrollArea = {\n Root,\n Viewport,\n Content,\n Scrollbar,\n Thumb,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n trigger: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n gap: spacing.sm,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.text,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':hover': colors.accent,\n },\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n },\n value: {\n color: colors.text,\n },\n placeholder: {\n color: colors.textMuted,\n },\n icon: {\n display: 'flex',\n alignItems: 'center',\n color: colors.textMuted,\n },\n backdrop: {\n position: 'fixed',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n zIndex: 49,\n },\n popup: {\n position: 'absolute',\n top: '100%',\n left: 0,\n marginTop: spacing.xs,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n boxShadow: shadows.md,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n minWidth: 120,\n zIndex: 50,\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n fontFamily: typography.fontFamily,\n color: colors.text,\n borderRadius: radii.sm,\n cursor: 'pointer',\n backgroundColor: 'transparent',\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n itemSelected: {\n color: colors.accent,\n fontWeight: typography.fontWeightMedium,\n },\n itemHighlighted: {\n backgroundColor: colors.bgCardHover,\n },\n hidden: {\n display: 'none',\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface SelectContextValue {\n open: boolean\n toggle: () => void\n close: () => void\n value: string | null\n setValue: (value: string) => void\n labels: Record<string, string>\n registerLabel: (value: string, label: string) => void\n listboxId: string\n highlightedId: string | null\n setHighlightedId: (id: string | null) => void\n registerItem: (id: string, value: string, element: HTMLElement) => () => void\n triggerRef: React.RefObject<HTMLButtonElement | null>\n}\n\nexport const SelectContext = createContext<SelectContextValue | null>(null)\n\nexport function useSelect() {\n const ctx = useContext(SelectContext)\n if (!ctx) throw new Error('Select compound components must be used within Select.Root')\n return ctx\n}\n","import {useState, useCallback} from 'react'\n\nexport function useControllableValue<T>(\n controlledValue: T | undefined,\n defaultValue: T,\n onChange?: (value: T) => void,\n) {\n const [internal, setInternal] = useState(defaultValue)\n const value = controlledValue !== undefined ? controlledValue : internal\n const setValue = useCallback(\n (v: T) => {\n if (controlledValue === undefined) setInternal(v)\n onChange?.(v)\n },\n [controlledValue, onChange],\n )\n return [value, setValue] as const\n}\n","import {useState, useCallback, useMemo, useRef, useId, useEffect} from 'react'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport type {SelectContextValue} from './SelectContext'\n\ninterface UseSelectRootOptions {\n defaultValue?: string\n value?: string\n onValueChange?: (value: string | null) => void\n initialLabels?: Record<string, string>\n}\n\nexport function useSelectRoot({\n defaultValue,\n value: controlledValue,\n onValueChange,\n initialLabels,\n}: UseSelectRootOptions) {\n const [value, setValue] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange,\n )\n const [open, setOpen] = useState(false)\n const [labels, setLabels] = useState<Record<string, string>>(initialLabels ?? {})\n const [highlightedId, setHighlightedId] = useState<string | null>(null)\n const listboxId = useId()\n const rootRef = useRef<HTMLDivElement>(null)\n const triggerRef = useRef<HTMLButtonElement | null>(null)\n const itemsRef = useRef(new Map<string, {value: string; element: HTMLElement}>())\n const orderRef = useRef<string[]>([])\n\n const close = useCallback(() => {\n setOpen(false)\n setHighlightedId(null)\n triggerRef.current?.focus()\n }, [])\n\n const toggle = useCallback(() => {\n setOpen((prev) => {\n if (!prev) {\n const items = itemsRef.current\n const order = orderRef.current\n let found: string | null = null\n for (const id of order) {\n const item = items.get(id)\n if (item && item.value === value) {\n found = id\n break\n }\n }\n setHighlightedId(found ?? (order.length > 0 ? order[0] : null))\n } else {\n setHighlightedId(null)\n }\n return !prev\n })\n }, [value])\n\n const registerLabel = useCallback((v: string, label: string) => {\n setLabels((prev) => {\n if (prev[v] === label) return prev\n return {...prev, [v]: label}\n })\n }, [])\n\n const registerItem = useCallback((id: string, itemValue: string, element: HTMLElement) => {\n itemsRef.current.set(id, {value: itemValue, element})\n const map = itemsRef.current\n const ids = [...map.keys()]\n ids.sort((a, b) => {\n const elA = map.get(a)?.element\n const elB = map.get(b)?.element\n if (!elA || !elB) return 0\n return elA.compareDocumentPosition(elB) & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1\n })\n orderRef.current = ids\n return () => {\n itemsRef.current.delete(id)\n orderRef.current = orderRef.current.filter((i) => i !== id)\n }\n }, [])\n\n // Native keydown for full KeyboardEvent access (preventDefault)\n useEffect(() => {\n const root = rootRef.current\n if (!root || !open) return\n\n function handleKeyDown(e: KeyboardEvent) {\n const order = orderRef.current\n const items = itemsRef.current\n if (order.length === 0) return\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : -1\n return order[(idx + 1) % order.length]\n })\n break\n }\n case 'ArrowUp': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : 0\n return order[(idx - 1 + order.length) % order.length]\n })\n break\n }\n case 'Home': {\n e.preventDefault()\n setHighlightedId(order[0])\n break\n }\n case 'End': {\n e.preventDefault()\n setHighlightedId(order[order.length - 1])\n break\n }\n case 'Enter':\n case ' ': {\n e.preventDefault()\n setHighlightedId((prev) => {\n if (prev) {\n const item = items.get(prev)\n if (item) {\n setValue(item.value)\n close()\n }\n }\n return prev\n })\n break\n }\n case 'Escape':\n case 'Tab': {\n close()\n break\n }\n }\n }\n\n root.addEventListener('keydown', handleKeyDown)\n return () => root.removeEventListener('keydown', handleKeyDown)\n }, [open, close, setValue])\n\n const ctx: SelectContextValue = useMemo(\n () => ({\n open,\n toggle,\n close,\n value,\n setValue,\n labels,\n registerLabel,\n listboxId,\n highlightedId,\n setHighlightedId,\n registerItem,\n triggerRef,\n }),\n [\n open,\n toggle,\n close,\n value,\n setValue,\n labels,\n registerLabel,\n listboxId,\n highlightedId,\n setHighlightedId,\n registerItem,\n ],\n )\n\n return {ctx, rootRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {SelectContext, useSelect} from './SelectContext'\nimport {useSelectRoot} from './useSelectRoot'\n\n// --- Root ---\ninterface RootProps {\n name?: string\n defaultValue?: string\n value?: string\n onValueChange?: (value: string | null) => void\n initialLabels?: Record<string, string>\n children: ReactNode\n}\n\nfunction Root({name, defaultValue, value, onValueChange, initialLabels, children}: RootProps) {\n const {ctx, rootRef} = useSelectRoot({defaultValue, value, onValueChange, initialLabels})\n\n return (\n <SelectContext.Provider value={ctx}>\n <html.div ref={rootRef} style={styles.root}>\n {name && <html.input type=\"hidden\" name={name} value={ctx.value ?? ''} />}\n {children}\n </html.div>\n </SelectContext.Provider>\n )\n}\n\n// --- Trigger ---\nfunction Trigger({children}: {children: ReactNode}) {\n const {open, toggle, listboxId, highlightedId, triggerRef} = useSelect()\n const localRef = useRef<HTMLButtonElement>(null)\n\n // Sync local ref to context triggerRef\n useEffect(() => {\n triggerRef.current = localRef.current\n })\n\n return (\n <html.button\n ref={localRef}\n type=\"button\"\n role={'combobox' as 'listbox'}\n onClick={toggle}\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-controls={open ? listboxId : undefined}\n aria-activedescendant={highlightedId ?? undefined}\n style={styles.trigger}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Value ---\nfunction Value({placeholder}: {placeholder?: string}) {\n const {value, labels} = useSelect()\n const display = value ? (labels[value] ?? value) : null\n\n return (\n <html.span style={display ? styles.value : styles.placeholder}>\n {display ?? placeholder}\n </html.span>\n )\n}\n\n// --- Icon ---\nfunction Icon({children}: {children?: ReactNode}) {\n return (\n <html.span style={styles.icon}>\n {children ?? (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n aria-hidden=\"true\"\n >\n <path d=\"M6 9l6 6 6-6\" />\n </svg>\n )}\n </html.span>\n )\n}\n\n// --- Popup ---\nfunction Popup({children}: {children: ReactNode}) {\n const {open, close, listboxId} = useSelect()\n\n return (\n <>\n {open && <html.div style={styles.backdrop} onClick={close} />}\n <html.div\n id={listboxId}\n role=\"listbox\"\n aria-hidden={!open}\n style={[styles.popup, !open && styles.hidden]}\n >\n {children}\n </html.div>\n </>\n )\n}\n\n// --- Item ---\ninterface ItemProps {\n value: string\n children: ReactNode\n}\n\nfunction Item({value: itemValue, children}: ItemProps) {\n const {\n value: selectedValue,\n setValue,\n close,\n registerLabel,\n highlightedId,\n setHighlightedId,\n registerItem,\n } = useSelect()\n const id = useId()\n const ref = useRef<HTMLDivElement>(null)\n const isSelected = selectedValue === itemValue\n const isHighlighted = highlightedId === id\n\n // Register label from DOM text content (works with both string and JSX children)\n useEffect(() => {\n const el = ref.current\n if (!el) return\n const text = el.textContent\n if (text) registerLabel(itemValue, text)\n }, [itemValue, registerLabel])\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, itemValue, el)\n }, [id, itemValue, registerItem])\n\n const handleClick = () => {\n setValue(itemValue)\n close()\n }\n\n return (\n <html.div\n ref={ref}\n id={id}\n role=\"option\"\n aria-selected={isSelected}\n onClick={handleClick}\n onPointerEnter={() => setHighlightedId(id)}\n style={[\n styles.item,\n isSelected && styles.itemSelected,\n isHighlighted && styles.itemHighlighted,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- ItemText ---\nfunction ItemText({children}: {children: ReactNode}) {\n return <html.span>{children}</html.span>\n}\n\nexport const Select = {\n Root,\n Trigger,\n Value,\n Icon,\n Popup,\n Item,\n ItemText,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n gap: 0,\n },\n group: {\n display: 'flex',\n flexDirection: 'column',\n },\n groupTrigger: {\n display: 'flex',\n alignItems: 'center',\n gap: spacing.xs,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeXs,\n fontWeight: typography.fontWeightSemibold,\n textTransform: 'uppercase' as const,\n letterSpacing: '0.05em',\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: 'transparent',\n borderWidth: 0,\n cursor: 'pointer',\n transitionProperty: 'color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n groupTriggerActive: {\n color: colors.text,\n },\n chevron: {\n display: 'inline-flex',\n alignItems: 'center',\n transitionProperty: 'transform',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n chevronOpen: {\n transform: 'rotate(90deg)',\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: '6px',\n paddingBottom: '6px',\n paddingLeft: spacing.lg,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightNormal,\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 0,\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'color, background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n textAlign: 'left' as const,\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n },\n itemActive: {\n color: colors.accent,\n fontWeight: typography.fontWeightMedium,\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface SideNavContextValue {\n activeValue: string | null\n onSelect: (value: string) => void\n expandedGroups: Set<string>\n toggleGroup: (group: string) => void\n registerItem: (value: string) => () => void\n orderRef: React.RefObject<string[]>\n}\n\nexport const SideNavContext = createContext<SideNavContextValue | null>(null)\n\nexport function useSideNav() {\n const ctx = useContext(SideNavContext)\n if (!ctx) throw new Error('SideNav compound components must be used within SideNav.Root')\n return ctx\n}\n","import {type ReactNode, useState, useCallback, useRef, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport {SideNavContext, useSideNav} from './SideNavContext'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n}\n\nfunction Root({children, value: controlledValue, defaultValue, onValueChange}: RootProps) {\n const [activeValue, onSelect] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange\n ? (v) => {\n if (v !== null) onValueChange(v)\n }\n : undefined,\n )\n const [expandedGroups, setExpandedGroups] = useState<Set<string>>(new Set())\n const orderRef = useRef<string[]>([])\n\n const toggleGroup = useCallback((group: string) => {\n setExpandedGroups((prev) => {\n const next = new Set(prev)\n if (next.has(group)) {\n next.delete(group)\n } else {\n next.add(group)\n }\n return next\n })\n }, [])\n\n const registerItem = useCallback((value: string) => {\n if (!orderRef.current.includes(value)) {\n orderRef.current.push(value)\n }\n return () => {\n orderRef.current = orderRef.current.filter((v) => v !== value)\n }\n }, [])\n\n // Auto-expand group containing active value\n useEffect(() => {\n if (activeValue) {\n setExpandedGroups((prev) => {\n // We don't know which group it belongs to here — Group handles this\n return prev\n })\n }\n }, [activeValue])\n\n return (\n <SideNavContext.Provider\n value={{activeValue, onSelect, expandedGroups, toggleGroup, registerItem, orderRef}}\n >\n <html.nav role=\"navigation\" style={styles.root}>\n {children}\n </html.nav>\n </SideNavContext.Provider>\n )\n}\n\n// --- Group ---\n\ninterface GroupProps {\n children: ReactNode\n label: string\n groupKey?: string\n defaultExpanded?: boolean\n}\n\nfunction Group({children, label, groupKey, defaultExpanded}: GroupProps) {\n const key = groupKey ?? label\n const {expandedGroups, toggleGroup, activeValue} = useSideNav()\n const isExpanded = expandedGroups.has(key)\n const groupRef = useRef<HTMLDivElement>(null)\n\n // Auto-expand if this group contains the active item\n useEffect(() => {\n if (!activeValue || expandedGroups.has(key)) return\n const el = groupRef.current\n if (!el) return\n const activeBtn = el.querySelector(`[data-nav-value=\"${activeValue}\"]`)\n if (activeBtn) {\n toggleGroup(key)\n }\n }, [activeValue, key, expandedGroups, toggleGroup])\n\n // Expand on first render if defaultExpanded\n useEffect(() => {\n if (defaultExpanded && !expandedGroups.has(key)) {\n toggleGroup(key)\n }\n // Only run on mount\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [])\n\n const hasActiveChild = (() => {\n if (!activeValue || !groupRef.current) return false\n return !!groupRef.current.querySelector(`[data-nav-value=\"${activeValue}\"]`)\n })()\n\n return (\n <html.div ref={groupRef} style={styles.group}>\n <html.button\n type=\"button\"\n onClick={() => toggleGroup(key)}\n style={[styles.groupTrigger, hasActiveChild && styles.groupTriggerActive]}\n aria-expanded={isExpanded}\n >\n <html.span style={[styles.chevron, isExpanded && styles.chevronOpen]}>\n <svg\n width={10}\n height={10}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2.5}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"M9 18l6-6-6-6\" />\n </svg>\n </html.span>\n {label}\n </html.button>\n {isExpanded && children}\n </html.div>\n )\n}\n\n// --- Item ---\n\ninterface ItemProps {\n value: string\n children: ReactNode\n}\n\nfunction Item({value, children}: ItemProps) {\n const {activeValue, onSelect, registerItem} = useSideNav()\n const isActive = activeValue === value\n\n useEffect(() => {\n return registerItem(value)\n }, [value, registerItem])\n\n return (\n <html.button\n type=\"button\"\n data-nav-value={value}\n onClick={() => onSelect(value)}\n style={[styles.item, isActive && styles.itemActive]}\n aria-current={isActive ? 'page' : undefined}\n >\n {children}\n </html.button>\n )\n}\n\nexport const SideNav = {\n Root,\n Group,\n Item,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\n\nconst spin = css.keyframes({\n '0%': {transform: 'rotate(0deg)'},\n '100%': {transform: 'rotate(360deg)'},\n})\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n },\n spinner: {\n borderRadius: '50%',\n borderStyle: 'solid',\n borderColor: colors.border,\n borderTopColor: colors.accent,\n animationName: spin,\n animationDuration: '0.6s',\n animationTimingFunction: 'linear',\n animationIterationCount: 'infinite',\n },\n sm: {\n width: 16,\n height: 16,\n borderWidth: 2,\n },\n md: {\n width: 24,\n height: 24,\n borderWidth: 2,\n },\n lg: {\n width: 40,\n height: 40,\n borderWidth: 3,\n },\n srOnly: {\n position: 'absolute',\n width: 1,\n height: 1,\n overflow: 'hidden',\n clip: 'rect(0, 0, 0, 0)',\n },\n})\n","import {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type SpinnerSize = 'sm' | 'md' | 'lg'\n\ninterface SpinnerProps {\n size?: SpinnerSize\n label?: string\n}\n\nconst sizeMap = {\n sm: styles.sm,\n md: styles.md,\n lg: styles.lg,\n} as const\n\nexport function Spinner({size = 'md', label = 'Loading'}: SpinnerProps) {\n return (\n <html.div role=\"status\" style={styles.root}>\n <html.div style={[styles.spinner, sizeMap[size]]} aria-hidden />\n <html.span style={styles.srOnly}>{label}</html.span>\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n marginBottom: spacing.md,\n },\n error: {\n color: colors.error,\n },\n success: {\n color: colors.success,\n },\n warning: {\n color: colors.warning,\n },\n info: {\n color: colors.info,\n },\n muted: {\n color: colors.textMuted,\n },\n})\n","import {html} from 'react-strict-dom'\nimport {Icon} from '../Icon'\nimport type {IconName} from '../Icon'\nimport {styles} from './styles.css'\n\nexport type StatusIconName = Extract<\n IconName,\n 'x-circle' | 'check-circle' | 'check-done' | 'clock' | 'forbidden'\n>\nexport type StatusIconVariant = 'error' | 'success' | 'warning' | 'info' | 'muted'\n\ninterface StatusIconProps {\n name: StatusIconName\n size?: number\n variant?: StatusIconVariant\n}\n\nexport function StatusIcon({name, size = 48, variant = 'muted'}: StatusIconProps) {\n return (\n <html.div style={[styles.root, styles[variant]]}>\n <Icon name={name} size={size} />\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n // Root\n root: {\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.md,\n overflow: 'hidden',\n backgroundColor: colors.bgCard,\n fontFamily: typography.fontFamily,\n color: colors.text,\n },\n\n // Header group\n header: {\n backgroundColor: colors.bgCard,\n },\n\n // Row\n row: {\n display: 'grid',\n borderBottomWidth: 1,\n borderBottomStyle: 'solid',\n borderBottomColor: colors.border,\n },\n rowLastChild: {\n borderBottomWidth: 0,\n },\n bodyRow: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n\n // Header cell\n headerCell: {\n fontWeight: typography.fontWeightSemibold,\n color: colors.textMuted,\n textAlign: 'start',\n },\n\n // Body cell\n cell: {\n color: colors.text,\n display: 'flex',\n alignItems: 'center',\n },\n\n // Size: sm\n cellSm: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n // Size: md\n cellMd: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n },\n\n // Variant: striped (even body rows)\n stripedEven: {\n backgroundColor: {\n default: colors.bgCardHover,\n ':hover': colors.bgCardHover,\n },\n },\n\n // Variant: bordered (cells get side borders)\n borderedCell: {\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n },\n borderedCellLast: {\n borderRightWidth: 0,\n },\n\n // Dynamic styles — simple identifier params only (StyleX constraint)\n gridColumns: (columns: number) => ({\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n }),\n})\n","import {type ReactNode, createContext, useContext, Children} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\n// --- Types ---\n\nexport type TableVariant = 'default' | 'striped' | 'bordered'\nexport type TableSize = 'sm' | 'md'\n\n// --- Context ---\n\ninterface TableContextValue {\n variant: TableVariant\n size: TableSize\n columns: number\n isHeader: boolean\n}\n\nconst TableContext = createContext<TableContextValue | null>(null)\n\nfunction useTable() {\n const ctx = useContext(TableContext)\n if (!ctx) throw new Error('Table compound components must be used within Table.Root')\n return ctx\n}\n\n// --- HeaderContext (to distinguish header vs body rowgroup) ---\n\nconst HeaderContext = createContext(false)\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n variant?: TableVariant\n size?: TableSize\n columns: number\n}\n\nfunction Root({children, variant = 'default', size = 'md', columns}: RootProps) {\n return (\n <TableContext.Provider value={{variant, size, columns, isHeader: false}}>\n <html.div role=\"table\" style={styles.root}>\n {children}\n </html.div>\n </TableContext.Provider>\n )\n}\n\n// --- Header ---\n\nfunction Header({children}: {children: ReactNode}) {\n return (\n <HeaderContext.Provider value={true}>\n <html.div role=\"rowgroup\" style={styles.header}>\n {children}\n </html.div>\n </HeaderContext.Provider>\n )\n}\n\n// --- Body ---\n\nfunction Body({children}: {children: ReactNode}) {\n const {variant} = useTable()\n const childArray = Children.toArray(children)\n\n return (\n <HeaderContext.Provider value={false}>\n <html.div role=\"rowgroup\">\n {childArray.map((child, index) => {\n if (variant === 'striped') {\n return (\n <RowIndexContext.Provider key={index} value={index}>\n {child}\n </RowIndexContext.Provider>\n )\n }\n return child\n })}\n </html.div>\n </HeaderContext.Provider>\n )\n}\n\n// Row index context for striped variant\nconst RowIndexContext = createContext<number>(-1)\n\n// --- Row ---\n\nfunction Row({children}: {children: ReactNode}) {\n const {variant, columns} = useTable()\n const isHeader = useContext(HeaderContext)\n const rowIndex = useContext(RowIndexContext)\n const isEvenRow = rowIndex >= 0 && rowIndex % 2 === 1\n const childArray = Children.toArray(children)\n const isLastRow = false // handled by CSS or parent\n\n return (\n <html.div\n role=\"row\"\n style={[\n styles.row,\n styles.gridColumns(columns),\n !isHeader && styles.bodyRow,\n !isHeader && variant === 'striped' && isEvenRow && styles.stripedEven,\n ]}\n >\n {variant === 'bordered'\n ? childArray.map((child, index) => (\n <CellIndexContext.Provider key={index} value={{index, total: childArray.length}}>\n {child}\n </CellIndexContext.Provider>\n ))\n : children}\n </html.div>\n )\n}\n\n// Cell index context for bordered variant\nconst CellIndexContext = createContext<{index: number; total: number}>({\n index: 0,\n total: 0,\n})\n\n// --- HeaderCell ---\n\nfunction HeaderCell({children}: {children: ReactNode}) {\n const {size, variant} = useTable()\n const {index, total} = useContext(CellIndexContext)\n const isLast = variant === 'bordered' && index === total - 1\n\n return (\n <html.div\n role=\"columnheader\"\n style={[\n styles.headerCell,\n size === 'sm' ? styles.cellSm : styles.cellMd,\n variant === 'bordered' && styles.borderedCell,\n isLast && styles.borderedCellLast,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Cell ---\n\nfunction Cell({children}: {children: ReactNode}) {\n const {size, variant} = useTable()\n const {index, total} = useContext(CellIndexContext)\n const isLast = variant === 'bordered' && index === total - 1\n\n return (\n <html.div\n role=\"cell\"\n style={[\n styles.cell,\n size === 'sm' ? styles.cellSm : styles.cellMd,\n variant === 'bordered' && styles.borderedCell,\n isLast && styles.borderedCellLast,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Export ---\n\nexport const Table = {\n Root,\n Header,\n Body,\n Row,\n HeaderCell,\n Cell,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n },\n rootVertical: {\n flexDirection: 'row',\n },\n list: {\n display: 'flex',\n flexDirection: 'row',\n borderBottomWidth: 1,\n borderBottomStyle: 'solid',\n borderBottomColor: colors.border,\n gap: spacing.xs,\n },\n listVertical: {\n flexDirection: 'column',\n borderBottomWidth: 0,\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n gap: 0,\n },\n tab: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: 'transparent',\n borderWidth: 0,\n borderBottomWidth: 2,\n borderBottomStyle: 'solid',\n borderBottomColor: 'transparent',\n cursor: 'pointer',\n transitionProperty: 'color, border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': -2,\n },\n },\n tabVertical: {\n justifyContent: 'flex-start',\n borderBottomWidth: 0,\n borderRightWidth: 2,\n borderRightStyle: 'solid',\n borderRightColor: 'transparent',\n },\n tabActiveHorizontal: {\n color: colors.text,\n borderBottomColor: colors.accent,\n },\n tabActiveVertical: {\n color: colors.text,\n borderRightColor: colors.accent,\n },\n tabDisabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n color: colors.textMuted,\n },\n panel: {\n paddingTop: spacing.md,\n },\n panelVertical: {\n paddingTop: 0,\n paddingLeft: spacing.md,\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport type Orientation = 'horizontal' | 'vertical'\n\nexport interface TabsContextValue {\n activeValue: string | null\n onSelect: (value: string) => void\n orientation: Orientation\n registerTab: (value: string, disabled: boolean) => () => void\n tabsRef: React.RefObject<Map<string, boolean>>\n orderRef: React.RefObject<string[]>\n}\n\nexport const TabsContext = createContext<TabsContextValue | null>(null)\n\nexport function useTabs() {\n const ctx = useContext(TabsContext)\n if (!ctx) throw new Error('Tabs compound components must be used within Tabs.Root')\n return ctx\n}\n","import {useCallback, useRef} from 'react'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport type {Orientation, TabsContextValue} from './TabsContext'\n\ninterface UseTabsRootOptions {\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: Orientation\n}\n\nexport function useTabsRoot({\n value: controlledValue,\n defaultValue,\n onValueChange,\n orientation = 'horizontal',\n}: UseTabsRootOptions): TabsContextValue {\n const [activeValue, onSelect] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange\n ? (v) => {\n if (v !== null) onValueChange(v)\n }\n : undefined,\n )\n const tabsRef = useRef(new Map<string, boolean>())\n const orderRef = useRef<string[]>([])\n\n const registerTab = useCallback((value: string, disabled: boolean) => {\n tabsRef.current.set(value, disabled)\n if (!orderRef.current.includes(value)) {\n orderRef.current.push(value)\n }\n return () => {\n tabsRef.current.delete(value)\n orderRef.current = orderRef.current.filter((v) => v !== value)\n }\n }, [])\n\n return {activeValue, onSelect, orientation, registerTab, tabsRef, orderRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {TabsContext, useTabs} from './TabsContext'\nimport {useTabsRoot} from './useTabsRoot'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: 'horizontal' | 'vertical'\n}\n\nfunction Root({\n children,\n value,\n defaultValue,\n onValueChange,\n orientation = 'horizontal',\n}: RootProps) {\n const ctx = useTabsRoot({value, defaultValue, onValueChange, orientation})\n\n return (\n <TabsContext.Provider value={ctx}>\n <html.div style={[styles.root, orientation === 'vertical' && styles.rootVertical]}>\n {children}\n </html.div>\n </TabsContext.Provider>\n )\n}\n\n// --- List ---\n\ninterface ListProps {\n children: ReactNode\n}\n\nfunction List({children}: ListProps) {\n const {orientation, activeValue, onSelect, tabsRef, orderRef} = useTabs()\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n const el = listRef.current\n if (!el) return\n\n function handleKeyDown(this: HTMLElement, e: KeyboardEvent) {\n const order = orderRef.current\n const tabs = tabsRef.current\n if (order.length === 0) return\n const listEl = this\n\n const prevKey = orientation === 'horizontal' ? 'ArrowLeft' : 'ArrowUp'\n const nextKey = orientation === 'horizontal' ? 'ArrowRight' : 'ArrowDown'\n\n let targetValue: string | null = null\n\n switch (e.key) {\n case nextKey: {\n e.preventDefault()\n const currentIdx = activeValue ? order.indexOf(activeValue) : -1\n for (let i = 1; i <= order.length; i++) {\n const idx = (currentIdx + i) % order.length\n const val = order[idx]\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case prevKey: {\n e.preventDefault()\n const currentIdx = activeValue ? order.indexOf(activeValue) : 0\n for (let i = 1; i <= order.length; i++) {\n const idx = (currentIdx - i + order.length) % order.length\n const val = order[idx]\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case 'Home': {\n e.preventDefault()\n for (const val of order) {\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case 'End': {\n e.preventDefault()\n for (let i = order.length - 1; i >= 0; i--) {\n if (!tabs.get(order[i])) {\n targetValue = order[i]\n break\n }\n }\n break\n }\n }\n\n if (targetValue) {\n onSelect(targetValue)\n // Focus the newly activated tab button\n const tabEl = listEl.querySelector(\n `[data-tab-value=\"${targetValue}\"]`,\n ) as HTMLElement | null\n tabEl?.focus()\n }\n }\n\n el.addEventListener('keydown', handleKeyDown)\n return () => el.removeEventListener('keydown', handleKeyDown)\n }, [orientation, activeValue, onSelect, tabsRef, orderRef])\n\n return (\n <html.div\n ref={listRef}\n role=\"tablist\"\n aria-orientation={orientation}\n style={[styles.list, orientation === 'vertical' && styles.listVertical]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Tab ---\n\ninterface TabProps {\n value: string\n disabled?: boolean\n children: ReactNode\n}\n\nfunction Tab({value, disabled = false, children}: TabProps) {\n const {activeValue, onSelect, orientation, registerTab} = useTabs()\n const isActive = activeValue === value\n const tabId = useId()\n const panelId = `${tabId}-panel`\n\n useEffect(() => {\n return registerTab(value, disabled)\n }, [value, disabled, registerTab])\n\n const handleClick = () => {\n if (!disabled) {\n onSelect(value)\n }\n }\n\n return (\n <html.button\n type=\"button\"\n role=\"tab\"\n id={tabId}\n aria-selected={isActive}\n aria-controls={panelId}\n aria-disabled={disabled || undefined}\n data-tab-value={value}\n tabIndex={isActive ? 0 : -1}\n onClick={handleClick}\n style={[\n styles.tab,\n orientation === 'vertical' && styles.tabVertical,\n isActive &&\n (orientation === 'vertical' ? styles.tabActiveVertical : styles.tabActiveHorizontal),\n disabled && styles.tabDisabled,\n ]}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Panel ---\n\ninterface PanelProps {\n value: string\n children: ReactNode\n}\n\nfunction Panel({value, children}: PanelProps) {\n const {activeValue, orientation} = useTabs()\n\n if (activeValue !== value) return null\n\n return (\n <html.div\n role=\"tabpanel\"\n style={[styles.panel, orientation === 'vertical' && styles.panelVertical]}\n >\n {children}\n </html.div>\n )\n}\n\nexport const Tabs = {\n Root,\n List,\n Tab,\n Panel,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n width: '100%',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n color: colors.text,\n backgroundColor: colors.bg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n resize: 'vertical' as const,\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 1,\n },\n },\n default: {\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n ':focus': colors.accent,\n },\n },\n error: {\n borderColor: {\n default: colors.error,\n ':focus': colors.error,\n },\n },\n})\n","import {html} from 'react-strict-dom'\nimport {useFieldContext} from '../Field/FieldContext'\nimport {styles} from './styles.css'\n\nexport type TextareaVariant = 'default' | 'error'\n\ninterface TextareaProps {\n variant?: TextareaVariant\n name?: string\n placeholder?: string\n required?: boolean\n rows?: number\n value?: string\n defaultValue?: string\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void\n}\n\nexport function Textarea({\n variant = 'default',\n name,\n placeholder,\n required,\n rows = 3,\n value,\n defaultValue,\n disabled,\n onChange,\n}: TextareaProps) {\n const ctx = useFieldContext()\n\n return (\n <html.textarea\n id={ctx?.controlId}\n name={name}\n placeholder={placeholder}\n required={required}\n rows={rows}\n value={value}\n defaultValue={defaultValue}\n disabled={disabled}\n aria-describedby={\n ctx ? `${ctx.descriptionId} ${ctx.invalid ? ctx.errorId : ''}`.trim() : undefined\n }\n aria-invalid={ctx?.invalid || variant === 'error' || undefined}\n onChange={onChange}\n style={[styles.base, styles[variant]]}\n />\n )\n}\n","const e = {\n bg: \"var(--bg-xqkwqtp)\",\n bgCard: \"var(--bgCard-xj2l5r)\",\n bgCardHover: \"var(--bgCardHover-xlxk7vw)\",\n text: \"var(--text-xlpbogt)\",\n textMuted: \"var(--textMuted-x651nu9)\",\n accent: \"var(--accent-xw7wp3v)\",\n accentHover: \"var(--accentHover-x18fqoz)\",\n accentContrast: \"var(--accentContrast-x3gzxyp)\",\n border: \"var(--border-x1drj1pb)\",\n error: \"var(--error-x13gdhh0)\",\n errorHover: \"var(--errorHover-x7eyu03)\",\n errorBg: \"var(--errorBg-xrl8836)\",\n errorBorder: \"var(--errorBorder-x1a6pjl)\",\n errorText: \"var(--errorText-xf51nwe)\",\n errorContrast: \"var(--errorContrast-x1lvjkah)\",\n success: \"var(--success-x197pe5n)\",\n successBg: \"var(--successBg-xzjukav)\",\n successBorder: \"var(--successBorder-x1my3ygc)\",\n successText: \"var(--successText-x46dg9e)\",\n warning: \"var(--warning-x1gq0pyw)\",\n warningBg: \"var(--warningBg-xtnxqss)\",\n warningBorder: \"var(--warningBorder-x1ev2mr5)\",\n warningText: \"var(--warningText-x1lgjghx)\",\n info: \"var(--info-x97ho0r)\",\n infoBg: \"var(--infoBg-xho8jir)\",\n infoBorder: \"var(--infoBorder-xnevk3x)\",\n infoText: \"var(--infoText-x19pseus)\",\n __varGroupHash__: \"xjvd03b\"\n}, t = {\n xs: \"var(--xs-xxfyjsd)\",\n sm: \"var(--sm-xbh8y7f)\",\n ms: \"var(--ms-x13y09zs)\",\n md: \"var(--md-x3pkb85)\",\n lg: \"var(--lg-x34mutn)\",\n xl: \"var(--xl-xttpygj)\",\n xxl: \"var(--xxl-xbe9eha)\",\n xxxl: \"var(--xxxl-xroalp5)\",\n __varGroupHash__: \"x6uc9q\"\n}, n = {\n sm: \"var(--sm-x1bhtfs5)\",\n md: \"var(--md-xx2g89g)\",\n lg: \"var(--lg-xwd56yl)\",\n full: \"var(--full-x9vxdtd)\",\n __varGroupHash__: \"xw3ffwm\"\n}, i = {\n stackXs: \"var(--stackXs-x1qfrfo2)\",\n stackSm: \"var(--stackSm-x2rk1ut)\",\n stackMd: \"var(--stackMd-xhblkt4)\",\n stackLg: \"var(--stackLg-xeue779)\",\n stackXl: \"var(--stackXl-x7sbbgu)\",\n inlineXs: \"var(--inlineXs-xq4tp4f)\",\n inlineSm: \"var(--inlineSm-x2o8bbf)\",\n inlineMd: \"var(--inlineMd-x1oalkxi)\",\n inlineLg: \"var(--inlineLg-xz69o43)\",\n containerSm: \"var(--containerSm-x3nosus)\",\n containerMd: \"var(--containerMd-x170dvin)\",\n containerLg: \"var(--containerLg-x1n6aasq)\",\n __varGroupHash__: \"x16nfoyr\"\n}, r = {\n fontFamily: \"var(--fontFamily-xvrmnat)\",\n fontFamilyMono: \"var(--fontFamilyMono-x1bzqfky)\",\n fontSizeXs: \"var(--fontSizeXs-x1w5m325)\",\n fontSizeSm: \"var(--fontSizeSm-x1bjjs4u)\",\n fontSizeMd: \"var(--fontSizeMd-xq8d99q)\",\n fontSizeLg: \"var(--fontSizeLg-x18ngplw)\",\n fontSizeXl: \"var(--fontSizeXl-x1b1mqsu)\",\n fontSizeHeading: \"var(--fontSizeHeading-x1stydh2)\",\n fontWeightNormal: \"var(--fontWeightNormal-x1y1cayu)\",\n fontWeightMedium: \"var(--fontWeightMedium-xaw13ft)\",\n fontWeightSemibold: \"var(--fontWeightSemibold-xg6c7xe)\",\n fontWeightBold: \"var(--fontWeightBold-x1pjkvwg)\",\n lineHeight: \"var(--lineHeight-x1gubzd5)\",\n __varGroupHash__: \"xs62swl\"\n}, a = {\n fontSize1: \"var(--fontSize1-xx27tux)\",\n fontSize2: \"var(--fontSize2-x5hag8h)\",\n fontSize3: \"var(--fontSize3-x1mf6j39)\",\n fontSize4: \"var(--fontSize4-xh0hch2)\",\n fontSize5: \"var(--fontSize5-xcllv62)\",\n fontSize6: \"var(--fontSize6-xo5veds)\",\n fontSize7: \"var(--fontSize7-x1j85tz8)\",\n fontSize8: \"var(--fontSize8-x17zhits)\",\n fontSize9: \"var(--fontSize9-xveysf7)\",\n lineHeight1: \"var(--lineHeight1-x17o1wol)\",\n lineHeight2: \"var(--lineHeight2-xinpx5n)\",\n lineHeight3: \"var(--lineHeight3-x1163vpm)\",\n lineHeight4: \"var(--lineHeight4-x1y0jdbp)\",\n lineHeight5: \"var(--lineHeight5-xjln4cz)\",\n lineHeight6: \"var(--lineHeight6-x1h1b5wo)\",\n lineHeight7: \"var(--lineHeight7-xx3gx0p)\",\n lineHeight8: \"var(--lineHeight8-xk1f09j)\",\n lineHeight9: \"var(--lineHeight9-xshcxhh)\",\n displaySm: \"var(--displaySm-x5inqzv)\",\n displayMd: \"var(--displayMd-x1oektom)\",\n displayLg: \"var(--displayLg-x6qsr1u)\",\n letterSpacingTight: \"var(--letterSpacingTight-xmavxfk)\",\n letterSpacingNormal: \"var(--letterSpacingNormal-x1ih41v1)\",\n letterSpacingWide: \"var(--letterSpacingWide-xt8z9rj)\",\n __varGroupHash__: \"x4cj49w\"\n}, o = {\n bodySm: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1hn3ytp\",\n \"lineHeight-kLWn49\": \"lineHeight-xzs5d81\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:6\"\n },\n bodyMd: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xfzcsg9\",\n \"lineHeight-kLWn49\": \"lineHeight-x80sjjd\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:13\"\n },\n bodyLg: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1kws70c\",\n \"lineHeight-kLWn49\": \"lineHeight-x1487en2\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:20\"\n },\n caption: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x19zw8p8\",\n \"lineHeight-kLWn49\": \"lineHeight-xsnwo96\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x121swot\",\n $$css: \"tokens/type-presets.css.ts:29\"\n },\n label: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1hn3ytp\",\n \"lineHeight-kLWn49\": \"lineHeight-xzs5d81\",\n \"fontWeight-k63SB2\": \"fontWeight-x120ksxs\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:36\"\n },\n code: {\n \"fontFamily-kMv6JI\": \"fontFamily-x1kygxdj\",\n \"fontSize-kGuDYH\": \"fontSize-x1hn3ytp\",\n \"lineHeight-kLWn49\": \"lineHeight-xzs5d81\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:43\"\n },\n overline: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x19zw8p8\",\n \"lineHeight-kLWn49\": \"lineHeight-xsnwo96\",\n \"fontWeight-k63SB2\": \"fontWeight-x1x12jc5\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x121swot\",\n \"textTransform-kP9fke\": \"textTransform-xtvhhri\",\n $$css: \"tokens/type-presets.css.ts:50\"\n },\n headingSm: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xtv95mj\",\n \"lineHeight-kLWn49\": \"lineHeight-xyb71hx\",\n \"fontWeight-k63SB2\": \"fontWeight-x1x12jc5\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:60\"\n },\n headingMd: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1qndi8g\",\n \"lineHeight-kLWn49\": \"lineHeight-x17ovj3u\",\n \"fontWeight-k63SB2\": \"fontWeight-x1x12jc5\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:67\"\n },\n headingLg: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xo0rcgw\",\n \"lineHeight-kLWn49\": \"lineHeight-x18micsl\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:74\"\n },\n headingXl: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x6ugw34\",\n \"lineHeight-kLWn49\": \"lineHeight-x1f79cfb\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:81\"\n },\n displaySm: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1lwaixd\",\n \"lineHeight-kLWn49\": \"lineHeight-x1u7k74\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:90\"\n },\n displayMd: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xrqn33v\",\n \"lineHeight-kLWn49\": \"lineHeight-x1uo3zyz\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:97\"\n },\n displayLg: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1s08cw3\",\n \"lineHeight-kLWn49\": \"lineHeight-x1159mfc\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:104\"\n }\n}, s = {\n sm: \"var(--sm-x17hhtln)\",\n md: \"var(--md-x1oyt0aw)\",\n lg: \"var(--lg-x1mxd62i)\",\n __varGroupHash__: \"x13v825q\"\n}, x = {\n xjvd03b: \"xrtwk39 xjvd03b\",\n $$css: !0\n}, l = {\n x13v825q: \"xv9ibj0 x13v825q\",\n $$css: !0\n}, g = {\n xjvd03b: \"xaveibd xjvd03b\",\n $$css: !0\n}, c = {\n x13v825q: \"x15e39jv x13v825q\",\n $$css: !0\n};\nexport {\n e as colors,\n c as highContrastShadows,\n g as highContrastTheme,\n i as layoutSpacing,\n l as lightShadows,\n x as lightTheme,\n n as radii,\n s as shadows,\n t as spacing,\n o as typePresets,\n a as typeScale,\n r as typography\n};\n//# sourceMappingURL=index.js.map\n","import type {ReactNode} from 'react'\nimport {css, html} from 'react-strict-dom'\nimport {lightTheme, lightShadows, highContrastTheme, highContrastShadows} from '@duro-app/tokens'\n\nexport type ThemeName = 'dark' | 'light' | 'high-contrast'\n\ninterface ThemeProviderProps {\n theme?: ThemeName\n children: ReactNode\n}\n\nconst themeMap: Partial<Record<ThemeName, readonly [typeof lightTheme, typeof lightShadows]>> = {\n light: [lightTheme, lightShadows],\n 'high-contrast': [highContrastTheme, highContrastShadows],\n}\n\nconst styles = css.create({\n root: {\n display: 'contents',\n },\n})\n\n// react-strict-dom's style prop rejects Theme<VarGroup<{named keys}>> because the\n// concrete VarGroup lacks the generic index signature. This is a known typing gap.\ntype DivStyle = Parameters<typeof html.div>[0]['style']\n\nexport function ThemeProvider({theme = 'dark', children}: ThemeProviderProps) {\n const overrides = themeMap[theme]\n const themeStyles = [overrides?.[0], overrides?.[1], styles.root] as DivStyle\n\n return <html.div style={themeStyles}>{children}</html.div>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n // Colors\n default: {\n color: colors.text,\n },\n muted: {\n color: colors.textMuted,\n },\n accent: {\n color: colors.accent,\n },\n error: {\n color: colors.errorText,\n },\n success: {\n color: colors.successText,\n },\n warning: {\n color: colors.warningText,\n },\n\n // Weight overrides\n weightNormal: {\n fontWeight: typography.fontWeightNormal,\n },\n weightMedium: {\n fontWeight: typography.fontWeightMedium,\n },\n weightSemibold: {\n fontWeight: typography.fontWeightSemibold,\n },\n weightBold: {\n fontWeight: typography.fontWeightBold,\n },\n\n // Alignment\n alignStart: {\n textAlign: 'start',\n },\n alignCenter: {\n textAlign: 'center',\n },\n alignEnd: {\n textAlign: 'end',\n },\n\n // Truncate\n truncate: {\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {typePresets} from '@duro-app/tokens/tokens/type-presets.css'\nimport {styles} from './styles.css'\n\nexport type TextVariant = 'bodySm' | 'bodyMd' | 'bodyLg' | 'caption' | 'label' | 'code' | 'overline'\nexport type TextColor = 'default' | 'muted' | 'accent' | 'error' | 'success' | 'warning'\n\ninterface TextProps {\n variant?: TextVariant\n color?: TextColor\n weight?: 'normal' | 'medium' | 'semibold' | 'bold'\n align?: 'start' | 'center' | 'end'\n truncate?: boolean\n as?: 'span' | 'p' | 'div'\n children: ReactNode\n}\n\nconst weightMap = {\n normal: styles.weightNormal,\n medium: styles.weightMedium,\n semibold: styles.weightSemibold,\n bold: styles.weightBold,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n} as const\n\nexport function Text({\n variant = 'bodyMd',\n color = 'default',\n weight,\n align,\n truncate,\n as = 'span',\n children,\n}: TextProps) {\n const style = [\n typePresets[variant],\n styles[color],\n weight && weightMap[weight],\n align && alignMap[align],\n truncate && styles.truncate,\n ]\n\n if (as === 'p') return <html.p style={style}>{children}</html.p>\n if (as === 'div') return <html.div style={style}>{children}</html.div>\n return <html.span style={style}>{children}</html.span>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n popup: {\n position: 'absolute',\n zIndex: 50,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n backgroundColor: colors.bgCard,\n color: colors.text,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeXs,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n boxShadow: shadows.md,\n whiteSpace: 'nowrap',\n pointerEvents: 'none',\n },\n top: {\n bottom: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginBottom: spacing.xs,\n },\n bottom: {\n top: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginTop: spacing.xs,\n },\n left: {\n right: '100%',\n top: '50%',\n transform: 'translateY(-50%)',\n marginRight: spacing.xs,\n },\n right: {\n left: '100%',\n top: '50%',\n transform: 'translateY(-50%)',\n marginLeft: spacing.xs,\n },\n})\n","import {\n type ReactNode,\n createContext,\n useContext,\n useState,\n useRef,\n useCallback,\n useId,\n} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\n// --- Context ---\n\ntype Placement = 'top' | 'bottom' | 'left' | 'right'\n\ninterface TooltipContextValue {\n open: boolean\n show: () => void\n hide: () => void\n tooltipId: string\n placement: Placement\n}\n\nconst TooltipContext = createContext<TooltipContextValue | null>(null)\n\nfunction useTooltip() {\n const ctx = useContext(TooltipContext)\n if (!ctx) throw new Error('Tooltip compound components must be used within Tooltip.Root')\n return ctx\n}\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n content: ReactNode\n placement?: Placement\n delay?: number\n}\n\nfunction Root({children, content, placement = 'top', delay = 300}: RootProps) {\n const [open, setOpen] = useState(false)\n const tooltipId = useId()\n const timerRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const show = useCallback(() => {\n if (timerRef.current) clearTimeout(timerRef.current)\n timerRef.current = setTimeout(() => setOpen(true), delay)\n }, [delay])\n\n const hide = useCallback(() => {\n if (timerRef.current) clearTimeout(timerRef.current)\n timerRef.current = null\n setOpen(false)\n }, [])\n\n return (\n <TooltipContext.Provider value={{open, show, hide, tooltipId, placement}}>\n <html.div style={styles.root}>\n {children}\n {open && (\n <html.div id={tooltipId} role=\"tooltip\" style={[styles.popup, styles[placement]]}>\n {content}\n </html.div>\n )}\n </html.div>\n </TooltipContext.Provider>\n )\n}\n\n// --- Trigger ---\n\ninterface TriggerProps {\n children: ReactNode\n}\n\nfunction Trigger({children}: TriggerProps) {\n const {open, show, hide, tooltipId} = useTooltip()\n\n return (\n <html.div\n onPointerEnter={show}\n onPointerLeave={hide}\n onFocus={show}\n onBlur={hide}\n aria-describedby={open ? tooltipId : undefined}\n >\n {children}\n </html.div>\n )\n}\n\nexport const Tooltip = {\n Root,\n Trigger,\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'column',\n },\n alignStart: {alignItems: 'flex-start'},\n alignCenter: {alignItems: 'center'},\n alignEnd: {alignItems: 'flex-end'},\n alignStretch: {alignItems: 'stretch'},\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type SpacingKey = 'xs' | 'sm' | 'ms' | 'md' | 'lg' | 'xl' | 'xxl' | 'xxxl'\n\ninterface StackProps {\n gap?: SpacingKey\n align?: 'start' | 'center' | 'end' | 'stretch'\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n stretch: styles.alignStretch,\n} as const\n\nexport function Stack({gap = 'md', align = 'stretch', children}: StackProps) {\n return <html.div style={[styles.base, gapMap[gap], alignMap[align]]}>{children}</html.div>\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'row',\n flexWrap: 'nowrap',\n },\n alignStart: {alignItems: 'flex-start'},\n alignCenter: {alignItems: 'center'},\n alignEnd: {alignItems: 'flex-end'},\n alignBaseline: {alignItems: 'baseline'},\n alignStretch: {alignItems: 'stretch'},\n justifyStart: {justifyContent: 'flex-start'},\n justifyCenter: {justifyContent: 'center'},\n justifyEnd: {justifyContent: 'flex-end'},\n justifyBetween: {justifyContent: 'space-between'},\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport type {SpacingKey} from '../Stack/Stack'\n\ninterface InlineProps {\n gap?: SpacingKey\n align?: 'start' | 'center' | 'end' | 'baseline' | 'stretch'\n justify?: 'start' | 'center' | 'end' | 'between'\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n baseline: styles.alignBaseline,\n stretch: styles.alignStretch,\n} as const\n\nconst justifyMap = {\n start: styles.justifyStart,\n center: styles.justifyCenter,\n end: styles.justifyEnd,\n between: styles.justifyBetween,\n} as const\n\nexport function Inline({gap = 'sm', align = 'center', justify = 'start', children}: InlineProps) {\n return (\n <html.div style={[styles.base, gapMap[gap], alignMap[align], justifyMap[justify]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n alignStart: {alignItems: 'flex-start'},\n alignCenter: {alignItems: 'center'},\n alignEnd: {alignItems: 'flex-end'},\n justifyStart: {justifyContent: 'flex-start'},\n justifyCenter: {justifyContent: 'center'},\n justifyEnd: {justifyContent: 'flex-end'},\n justifyBetween: {justifyContent: 'space-between'},\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport type {SpacingKey} from '../Stack/Stack'\n\ninterface ClusterProps {\n gap?: SpacingKey\n align?: 'start' | 'center' | 'end'\n justify?: 'start' | 'center' | 'end' | 'between'\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n} as const\n\nconst justifyMap = {\n start: styles.justifyStart,\n center: styles.justifyCenter,\n end: styles.justifyEnd,\n between: styles.justifyBetween,\n} as const\n\nexport function Cluster({gap = 'sm', align = 'start', justify = 'start', children}: ClusterProps) {\n return (\n <html.div style={[styles.base, gapMap[gap], alignMap[align], justifyMap[justify]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'grid',\n },\n col1: {gridTemplateColumns: '1fr'},\n col2: {gridTemplateColumns: 'repeat(2, 1fr)'},\n col3: {gridTemplateColumns: 'repeat(3, 1fr)'},\n col4: {gridTemplateColumns: 'repeat(4, 1fr)'},\n col5: {gridTemplateColumns: 'repeat(5, 1fr)'},\n col6: {gridTemplateColumns: 'repeat(6, 1fr)'},\n autoFit: (minWidth: string) => ({\n gridTemplateColumns: `repeat(auto-fit, minmax(${minWidth}, 1fr))`,\n }),\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport type {SpacingKey} from '../Stack/Stack'\n\ninterface GridProps {\n gap?: SpacingKey\n columns?: 1 | 2 | 3 | 4 | 5 | 6\n minColumnWidth?: string\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst columnsMap = {\n 1: styles.col1,\n 2: styles.col2,\n 3: styles.col3,\n 4: styles.col4,\n 5: styles.col5,\n 6: styles.col6,\n} as const\n\nexport function Grid({gap = 'md', columns, minColumnWidth, children}: GridProps) {\n const columnStyle = minColumnWidth\n ? styles.autoFit(minColumnWidth)\n : columns\n ? columnsMap[columns]\n : undefined\n\n return <html.div style={[styles.base, gapMap[gap], columnStyle]}>{children}</html.div>\n}\n","import {useRef, useState, useEffect} from 'react'\n\nexport type ContainerSize = 'compact' | 'default' | 'spacious'\n\ninterface UseContainerQueryOptions {\n compactBelow?: number\n spaciousAbove?: number\n}\n\nexport function useContainerQuery<T extends HTMLElement = HTMLElement>(\n options: UseContainerQueryOptions = {},\n): {\n ref: React.RefObject<T | null>\n size: ContainerSize\n} {\n const {compactBelow = 480, spaciousAbove = 768} = options\n const ref = useRef<T | null>(null)\n const [size, setSize] = useState<ContainerSize>('default')\n\n useEffect(() => {\n const element = ref.current\n if (!element) return\n\n let rafId: number | null = null\n\n const observer = new ResizeObserver((entries) => {\n if (rafId !== null) cancelAnimationFrame(rafId)\n\n rafId = requestAnimationFrame(() => {\n const entry = entries[0]\n if (!entry) return\n\n const width = entry.contentBoxSize?.[0]?.inlineSize ?? entry.contentRect.width\n\n if (width < compactBelow) {\n setSize('compact')\n } else if (width >= spaciousAbove) {\n setSize('spacious')\n } else {\n setSize('default')\n }\n })\n })\n\n observer.observe(element)\n\n return () => {\n observer.disconnect()\n if (rafId !== null) cancelAnimationFrame(rafId)\n }\n }, [compactBelow, spaciousAbove])\n\n return {ref, size}\n}\n"],"names":["styleq$1","styleq_2","cache","compiledKey","createStyleq","options","disableCache","disableMix","transform","definedProperties","className","inlineStyle","debugString","nextCache","styles","i","possibleStyle","_i","style","classNameChunk","cacheEntry","definedPropertiesChunk","prop","value","compiledKeyValue","weakMap","subStyle","_prop","_value","styleProps","styleq","optimizedStyleq","merge","dataStyleSrc","result","chunks","pathsMap","chunk","trimmed","path","line","a","button","div","heading","input","label","nav","p","span","textarea","defaultStyles","icons","jsxs","Fragment","jsx","clock","forbidden","shield","lock","key","Icon","name","size","base","k1xSpc","kXwgrk","kGNEyG","kOIVth","kmVPX3","kaIpWk","kMzoRj","ksu8eU","kGuDYH","kLWn49","$$css","iconWrap","kmuXW","kjj79g","kLKAdn","content","kUk6DE","k7Eaqz","error","kWkggS","kVAM5u","kMwMTN","success","warning","info","defaultIcons","resolveIcon","icon","variant","undefined","Alert","children","resolvedIcon","_rsdMerge","_rsdDefaultStyles","kMv6JI","k63SB2","khDVqt","sizeMd","kGO01o","kE3dHu","kpe85a","sizeSm","default","sizeMap","sm","md","Badge","kkrTdU","k1ekBW","kIyJzY","kAMwcw","kybGjl","kMeerF","k3XXqK","kjBf7l","kInvED","sizeDefault","sizeSmall","primary","secondary","link","danger","fullWidth","kzqmXN","disabled","kSiTet","small","Button","type","onClick","elevated","kGVxlE","outlined","filled","interactive","k3aq6I","sizeCompact","sizeFull","header","k1K539","compact","full","Card","root","rootDisabled","box","kZKoxP","boxUnchecked","boxChecked","kVAEAm","kVQacm","Checkbox","checked","controlledChecked","defaultChecked","onChange","isControlled","internalChecked","setInternalChecked","useState","isChecked","handleChange","useCallback","e","target","opacity","k9WMMc","message","action","keoZOQ","EmptyState","typePresets","bodySm","kb6lSQ","bodyMd","bodyLg","caption","code","overline","kP9fke","headingSm","headingMd","headingLg","headingXl","displaySm","displayMd","displayLg","muted","accent","alignStart","alignCenter","alignEnd","defaultVariantMap","alignMap","start","center","end","Heading","level","color","align","resolvedVariant","h1","h2","h3","h4","h5","h6","FieldContext","createContext","useFieldContext","useContext","description","Root","invalid","id","useId","ctx","useMemo","controlId","descriptionId","errorId","Label","Description","Error","Field","InputGroupContext","useInputGroupContext","inGroup","Input","placeholder","required","minLength","pattern","autoComplete","defaultValue","groupCtx","extraProps","trim","wrapper","addon","kfSwDN","addonStart","kWqL5O","kSWEuD","k26BEO","addonEnd","kZ1KPB","k4WBpm","kaZRDh","addonClickable","addonDisabled","Addon","position","positionStyle","InputGroup","LinkButton","href","rel","trigger","backdrop","k87sOh","kbCHJM","kCIrl2","krVfgx","kY2c9j","popup","popupEnd","item","itemHighlighted","linkItem","MenuContext","useMenu","useMenuRoot","open","setOpen","highlightedId","setHighlightedId","menuId","rootRef","useRef","triggerRef","itemsRef","Map","orderRef","needsInitialHighlightRef","close","current","focus","toggle","prev","useEffect","order","length","registerItem","element","set","map","ids","keys","sort","b","elA","get","elB","compareDocumentPosition","Node","DOCUMENT_POSITION_FOLLOWING","delete","filter","handleKeyDown","preventDefault","idx","indexOf","items","click","addEventListener","removeEventListener","Trigger","localRef","Popup","Item","ref","isHighlighted","el","handleClick","LinkItem","Menu","viewport","kXHlph","kORKVm","k5wCbM","kAzted","scrollbar","kFalU9","scrollbarVertical","scrollbarHorizontal","scrollbarHidden","scrollbarVisible","thumb","viewportMaxHeight","maxHeight","kskxy","val","thumbVertical","height","thumbHorizontal","width","ScrollAreaContext","useScrollArea","useScrollAreaRoot","viewportRef","contentRef","scrollTop","setScrollTop","scrollLeft","setScrollLeft","scrollHeight","setScrollHeight","scrollWidth","setScrollWidth","clientHeight","setClientHeight","clientWidth","setClientWidth","scrolling","setScrolling","scrollTimerRef","handleScroll","vp","clearTimeout","setTimeout","observer","ResizeObserver","observe","disconnect","passive","Viewport","Content","Scrollbar","orientation","Thumb","draggingRef","startPosRef","startScrollRef","isVertical","thumbSizePercent","Math","max","maxScroll","trackSize","thumbPixelSize","scrollOffset","thumbOffset","thumbStyle","handlePointerDown","clientY","clientX","setPointerCapture","pointerId","handlePointerMove","delta","scrollRatio","scrollDelta","handlePointerUp","ScrollArea","itemSelected","hidden","SelectContext","useSelect","useControllableValue","controlledValue","internal","setInternal","setValue","v","useSelectRoot","onValueChange","initialLabels","labels","setLabels","listboxId","found","registerLabel","itemValue","Value","display","selectedValue","isSelected","text","textContent","ItemText","Select","group","groupTrigger","groupTriggerActive","chevron","chevronOpen","itemActive","SideNavContext","useSideNav","activeValue","onSelect","expandedGroups","setExpandedGroups","Set","toggleGroup","next","has","add","includes","push","Group","groupKey","defaultExpanded","isExpanded","groupRef","querySelector","hasActiveChild","isActive","SideNav","spinner","kLZC3w","kKVMdj","k44tkh","kyAemX","ko0y90","lg","srOnly","kMcinP","Spinner","StatusIcon","_temp","kumcoG","row","kt9PQ7","kfdmCh","kL6WhQ","rowLastChild","bodyRow","headerCell","cell","cellSm","cellMd","stripedEven","borderedCell","borderedCellLast","gridColumns","columns","TableContext","useTable","HeaderContext","isHeader","Header","Body","childArray","Children","toArray","child","index","RowIndexContext","Row","rowIndex","isEvenRow","CellIndexContext","total","HeaderCell","isLast","Cell","Table","rootVertical","list","listVertical","tab","tabVertical","tabActiveHorizontal","tabActiveVertical","tabDisabled","panel","panelVertical","TabsContext","useTabs","useTabsRoot","tabsRef","registerTab","List","listRef","tabs","listEl","prevKey","nextKey","targetValue","currentIdx","Tab","tabId","panelId","Panel","Tabs","kHenm0","Textarea","rows","bg","bgCard","bgCardHover","textMuted","accentHover","accentContrast","border","errorHover","errorBg","errorBorder","errorText","errorContrast","successBg","successBorder","successText","warningBg","warningBorder","warningText","infoBg","infoBorder","infoText","__varGroupHash__","themeMap","light","lightTheme","lightShadows","highContrastTheme","highContrastShadows","ThemeProvider","theme","overrides","themeStyles","weightNormal","weightMedium","weightSemibold","weightBold","truncate","kg5iWk","weightMap","normal","medium","semibold","bold","Text","weight","as","kfzvcC","top","bottom","left","km5ZXQ","right","koQZXg","TooltipContext","useTooltip","placement","delay","tooltipId","timerRef","show","hide","Tooltip","alignStretch","gapXs","gapSm","gapMs","gapMd","gapLg","gapXl","gapXxl","gapXxxl","gapMap","xs","ms","xl","xxl","xxxl","stretch","Stack","gap","kwnvtZ","alignBaseline","justifyStart","justifyCenter","justifyEnd","justifyBetween","baseline","justifyMap","between","Inline","justify","Cluster","col1","col2","col3","col4","col5","col6","autoFit","minWidth","columnsMap","Grid","minColumnWidth","columnStyle","useContainerQuery","compactBelow","spaciousAbove","setSize","rafId","entries","cancelAnimationFrame","requestAnimationFrame","entry","contentBoxSize","inlineSize","contentRect"],"mappings":";;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,IAAIA,KAAW,CAAA;AACf,OAAO,eAAeA,IAAU,cAAc;AAAA,EAC5C,OAAO;AACT,CAAC;AACD,IAAIC,KAAWD,GAAS,SAAS,QAC7BE,KAAQ,oBAAI,QAAO,GACnBC,KAAc;AAClB,SAASC,GAAaC,GAAS;AAC7B,MAAIC,GACAC,GACAC;AACJ,SAAIH,KAAW,SACbC,IAAeD,EAAQ,iBAAiB,IACxCE,IAAaF,EAAQ,eAAe,IACpCG,IAAYH,EAAQ,YAEf,WAAkB;AAOvB,aANII,IAAoB,CAAA,GACpBC,IAAY,IACZC,IAAc,MACdC,IAAc,IACdC,IAAYP,IAAe,OAAOJ,IAClCY,IAAS,IAAI,MAAM,UAAU,MAAM,GAC9BC,IAAI,GAAGA,IAAI,UAAU,QAAQA;AACpC,MAAAD,EAAOC,CAAC,IAAI,UAAUA,CAAC;AAEzB,WAAOD,EAAO,SAAS,KAAG;AACxB,UAAIE,IAAgBF,EAAO,IAAG;AAC9B,UAAI,EAAAE,KAAiB,QAAQA,MAAkB,KAG/C;AAAA,YAAI,MAAM,QAAQA,CAAa,GAAG;AAChC,mBAASC,IAAK,GAAGA,IAAKD,EAAc,QAAQC;AAC1C,YAAAH,EAAO,KAAKE,EAAcC,CAAE,CAAC;AAE/B;AAAA,QACF;AACA,YAAIC,IAAQV,KAAa,OAAOA,EAAUQ,CAAa,IAAIA;AAC3D,YAAIE,EAAM,SAAS,MAAM;AACvB,cAAIC,IAAiB;AACrB,cAAIN,KAAa,QAAQA,EAAU,IAAIK,CAAK,GAAG;AAC7C,gBAAIE,IAAaP,EAAU,IAAIK,CAAK;AACpC,YAAIE,KAAc,SAChBD,IAAiBC,EAAW,CAAC,GAC7BR,IAAcQ,EAAW,CAAC,GAC1BX,EAAkB,KAAK,MAAMA,GAAmBW,EAAW,CAAC,CAAC,GAC7DP,IAAYO,EAAW,CAAC;AAAA,UAE5B,OAAO;AACL,gBAAIC,IAAyB,CAAA;AAC7B,qBAASC,KAAQJ,GAAO;AACtB,kBAAIK,IAAQL,EAAMI,CAAI;AACtB,kBAAIA,MAASnB,IAAa;AACxB,oBAAIqB,IAAmBN,EAAMI,CAAI;AACjC,gBAAIE,MAAqB,OACvBZ,IAAcA,IAAcY,IAAmB,OAAOZ,IAAcY;AAEtE;AAAA,cACF;AACA,cAAI,OAAOD,KAAU,YAAYA,MAAU,OACpCd,EAAkB,SAASa,CAAI,MAClCb,EAAkB,KAAKa,CAAI,GACvBT,KAAa,QACfQ,EAAuB,KAAKC,CAAI,GAE9B,OAAOC,KAAU,aACnBJ,KAAkBA,IAAiB,MAAMI,IAAQA,MAIrD,QAAQ,MAAM,WAAW,OAAOD,GAAM,UAAU,EAAE,OAAO,OAAOC,CAAK,GAAG,6BAAiC,CAAC;AAAA,YAE9G;AACA,gBAAIV,KAAa,MAAM;AACrB,kBAAIY,IAAU,oBAAI,QAAO;AACzB,cAAAZ,EAAU,IAAIK,GAAO,CAACC,GAAgBE,GAAwBT,GAAaa,CAAO,CAAC,GACnFZ,IAAYY;AAAA,YACd;AAAA,UACF;AACA,UAAIN,MACFT,IAAYA,IAAYS,IAAiB,MAAMT,IAAYS;AAAA,QAE/D,WACMZ;AACF,UAAII,KAAe,SACjBA,IAAc,CAAA,IAEhBA,IAAc,OAAO,OAAO,CAAA,GAAIO,GAAOP,CAAW;AAAA,aAC7C;AACL,cAAIe,IAAW;AACf,mBAASC,KAAST,GAAO;AACvB,gBAAIU,IAASV,EAAMS,CAAK;AACxB,YAAIC,MAAW,WACRnB,EAAkB,SAASkB,CAAK,MAC/BC,KAAU,SACRjB,KAAe,SACjBA,IAAc,CAAA,IAEZe,KAAY,SACdA,IAAW,CAAA,IAEbA,EAASC,CAAK,IAAIC,IAEpBnB,EAAkB,KAAKkB,CAAK,GAC5Bd,IAAY;AAAA,UAGlB;AACA,UAAIa,KAAY,SACdf,IAAc,OAAO,OAAOe,GAAUf,CAAW;AAAA,QAErD;AAAA;AAAA,IAEJ;AACA,QAAIkB,IAAa,CAACnB,GAAWC,GAAaC,CAAW;AACrD,WAAOiB;AAAA,EACT;AACF;AACA,IAAIC,KAAS7B,KAAWD,GAAS,SAASI,GAAY;AACtD0B,GAAO,UAAU1B;AACjB,MAAM2B,KAAkB9B,GAAS,QAAQ;AAAA,EACvC,YAAY;AACd,CAAC;AACD,SAAS+B,KAASlB,GAAQ;AACxB,QAAM,CAACJ,GAAWQ,GAAOe,CAAY,IAAIF,GAAgBjB,CAAM,GACzDoB,IAAS,CAAA;AAOf,MANIxB,KAAa,QAAQA,MAAc,OACrCwB,EAAO,YAAYxB,IAEjBQ,KAAS,SACXgB,EAAO,QAAQhB,IAEbe,KAAgB,QAAQA,MAAiB,IAAI;AAC/C,UAAME,IAASF,EAAa,MAAM,GAAG,GAC/BG,IAAW,CAAA;AACjB,eAAWC,KAASF,GAAQ;AAC1B,YAAMG,IAAUD,EAAM,KAAI,GACpB,CAACE,GAAMC,CAAI,IAAIF,EAAQ,MAAM,GAAG;AACtC,MAAIE,KAAQ,SACVJ,EAASG,CAAI,IAAIH,EAASG,CAAI,KAAK,OAAO,GAAGH,EAASG,CAAI,CAAC,IAAIC,CAAI,KAAKA;AAAA,IAE5E;AACA,IAAAN,EAAO,gBAAgB,IAAI,OAAO,KAAKE,CAAQ,EAAE,IAAI,CAAAG,MAAQ,GAAGA,CAAI,IAAIH,EAASG,CAAI,CAAC,EAAE,EAAE,KAAK,IAAI;AAAA,EACrG;AACA,SAAOL;AACT;AACA,MAAMpB,IAAS;AAAA,EACb,OAAO;AAAA,IACL,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,OAAO;AAAA,EACX;AAAA,EACE,QAAQ;AAAA,IACN,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,OAAO;AAAA,EACX;AAAA,EACE,aAAa;AAAA,IACX,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,OAAO;AAAA,EACX;AAAA,EACE,QAAQ;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,EACX;AAAA,EAOE,SAAS;AAAA,IACP,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,OAAO;AAAA,EACX;AAAA,EAeE,OAAO;AAAA,IACL,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,OAAO;AAAA,EACX;AAAA,EASE,UAAU;AAAA,IACR,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,OAAO;AAAA,EACX;AACA,GACM2B,KAAI3B,EAAO,QAQX4B,KAAS,CAAC5B,EAAO,aAAaA,EAAO,MAAM,GAG3C6B,KAAM7B,EAAO,OAKb8B,IAAU,CAAC9B,EAAO,OAAOA,EAAO,OAAO,GAKvC+B,KAAQ,CAAC/B,EAAO,aAAaA,EAAO,KAAK,GAGzCgC,KAAQhC,EAAO,QAIfiC,KAAMjC,EAAO,OAIbkC,KAAIlC,EAAO,OAKXmC,KAAOnC,EAAO,QAIdoC,KAAW,CAACpC,EAAO,aAAaA,EAAO,QAAQ,GAG/CqC,IAAgB;AAAA,EACpB,GAAGV;AAAAA,EAQH,QAAQC;AAAA,EAGR,KAAKC;AAAA,EAKL,IAAIC;AAAA,EACJ,IAAIA;AAAA,EACJ,IAAIA;AAAA,EACJ,IAAIA;AAAA,EACJ,IAAIA;AAAA,EACJ,IAAIA;AAAA,EAKJ,OAAOC;AAAA,EAGP,OAAOC;AAAA,EAIP,KAAKC;AAAA,EAIL,GAAGC;AAAA,EAKH,MAAMC;AAAA,EAIN,UAAUC;AAGZ,GClTME,KAAqC;AAAA,EACzC,YACE,gBAAAC,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAC,YAAO,IAAG,MAAK,IAAG,MAAK,GAAE,MAAI;AAAA,IAC9B,gBAAAA,EAAC,UAAK,IAAG,MAAK,IAAG,KAAI,IAAG,KAAI,IAAG,KAAA,CAAI;AAAA,IACnC,gBAAAA,EAAC,UAAK,IAAG,KAAI,IAAG,KAAI,IAAG,MAAK,IAAG,KAAA,CAAI;AAAA,EAAA,GACrC;AAAA,EAEF,gBACE,gBAAAF,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAC,YAAO,IAAG,MAAK,IAAG,MAAK,GAAE,MAAI;AAAA,IAC9B,gBAAAA,EAAC,YAAA,EAAS,QAAO,mBAAA,CAAkB;AAAA,EAAA,GACrC;AAAA,EAEF,cACE,gBAAAF,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAC,QAAA,EAAK,GAAE,qCAAA,CAAoC;AAAA,IAC5C,gBAAAA,EAAC,YAAA,EAAS,QAAO,wBAAA,CAAuB;AAAA,EAAA,GAC1C;AAAA,EAEFC,OACE,gBAAAH,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAC,YAAO,IAAG,MAAK,IAAG,MAAK,GAAE,MAAI;AAAA,IAC9B,gBAAAA,EAAC,YAAA,EAAS,QAAO,mBAAA,CAAkB;AAAA,EAAA,GACrC;AAAA,EAEFE,WACE,gBAAAJ,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAC,YAAO,IAAG,MAAK,IAAG,MAAK,GAAE,MAAI;AAAA,IAC9B,gBAAAA,EAAC,UAAK,IAAG,QAAO,IAAG,QAAO,IAAG,SAAQ,IAAG,QAAA,CAAO;AAAA,EAAA,GACjD;AAAA,EAEF,eACE,gBAAAF,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAC,YAAO,IAAG,MAAK,IAAG,MAAK,GAAE,MAAI;AAAA,IAC9B,gBAAAA,EAAC,UAAK,IAAG,MAAK,IAAG,MAAK,IAAG,MAAK,IAAG,KAAA,CAAI;AAAA,IACrC,gBAAAA,EAAC,UAAK,IAAG,MAAK,IAAG,KAAI,IAAG,SAAQ,IAAG,IAAA,CAAG;AAAA,EAAA,GACxC;AAAA,EAEF,kBACE,gBAAAF,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAC,QAAA,EAAK,GAAE,2FAAA,CAA0F;AAAA,IAClG,gBAAAA,EAAC,UAAK,IAAG,MAAK,IAAG,KAAI,IAAG,MAAK,IAAG,KAAA,CAAI;AAAA,IACpC,gBAAAA,EAAC,UAAK,IAAG,MAAK,IAAG,MAAK,IAAG,SAAQ,IAAG,KAAA,CAAI;AAAA,EAAA,GAC1C;AAAA,EAEFG,QACE,gBAAAH,EAAC,QAAA,EAAK,GAAE,8CAAA,CAA6C;AAAA,EAEvDI,MACE,gBAAAN,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAC,QAAA,EAAK,GAAE,KAAI,GAAE,MAAK,OAAM,MAAK,QAAO,MAAK,IAAG,KAAI,IAAG,KAAG;AAAA,IACvD,gBAAAA,EAAC,QAAA,EAAK,GAAE,2BAAA,CAA0B;AAAA,EAAA,GACpC;AAAA,EAEFK,KACE,gBAAAL,EAAAD,GAAA,EACE,UAAA,gBAAAC,EAAC,QAAA,EAAK,GAAE,uHAAqH,EAAA,CAC/H;AAEJ;AAOO,SAASM,GAAK;AAAA,EAACC,MAAAA;AAAAA,EAAMC,MAAAA,IAAO;AAAa,GAAG;AACjD,SACE,gBAAAR,EAAC,SACC,SAAQ,aACR,MAAK,QACL,QAAO,gBACP,aAAa,GACb,eAAc,SACd,gBAAe,SACf,OAAOQ,GACP,QAAQA,GAEPX,UAAAA,GAAMU,CAAI,EAAA,CACb;AAEJ;AC3FO,MAAMhD,KAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,OAAA;AAAA,EAAA;AAAA,EAAAC,UAAA;AAAA,IAAAC,OAAA;AAAA,IAAAZ,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAJ,OAAA;AAAA,EAAA;AAAA,EAAAK,SAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAP,OAAA;AAAA,EAAA;AAAA,EAAAQ,OAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAY,SAAA;AAAA,IAAAH,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAa,SAAA;AAAA,IAAAJ,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAc,MAAA;AAAA,IAAAL,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,GCGbe,KAA+C;AAAA,EACnDD,MAAM;AAAA,EACND,SAAS;AAAA,EACTD,SAAS;AAAA,EACTJ,OAAO;AACT;AASA,SAASQ,GACPC,GACAC,GACkB;AAClB,SAAID,MAAS,KAAc,OACvBA,MAASE,SAAkB,gBAAAvC,EAACM,IAAA,EAAK,MAAM6B,GAAaG,CAAO,GAAG,MAAM,GAAA,CAAG,IACvE,OAAOD,KAAS,6BAAkB/B,IAAA,EAAK,MAAM+B,GAAkB,MAAM,IAAG,IACrEA;AACT;AAEO,SAASG,GAAM;AAAA,EAACF,SAAAA,IAAU;AAAA,EAAQD,MAAAA;AAAAA,EAAMI,UAAAA;AAAoB,GAAG;AACpE,QAAMC,IAAeN,GAAYC,GAAMC,CAAO;AAE9C,SACE,gBAAAtC,WAAU,MAAK,SAAO,GAAA2C,EAAAC,EAAAxD,KAAS7B,GAAOkD,MAAMlD,GAAO+E,CAAO,CAAC,GACxDI,cACC,gBAAA5C,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAA,OAAA,EAAA,GAAA2C,EAAAC,EAAAxD,KAAiB7B,GAAO8D,QAAQ,GAAGqB,UAAAA,EAAAA,CAAa;AAAA,IAChD,gBAAA1C,EAAA,SAAA,GAAA2C,EAAAC,EAAAxD,KAAiB7B,GAAOkE,OAAO,GAAGgB,UAAAA,EAAAA,CAAS;AAAA,EAAA,EAAA,CAC7C,IAEAA,GAEJ;AAEJ;AC1CO,MAAMlF,KAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAsB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAJ,QAAA;AAAA,IAAAgC,QAAA;AAAA,IAAA3B,OAAA;AAAA,EAAA;AAAA,EAAA4B,QAAA;AAAA,IAAAxB,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAjC,QAAA;AAAA,IAAAE,OAAA;AAAA,EAAA;AAAA,EAAAgC,QAAA;AAAA,IAAA5B,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAjC,QAAA;AAAA,IAAAE,OAAA;AAAA,EAAA;AAAA,EAAAiC,SAAA;AAAA,IAAAxB,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAY,SAAA;AAAA,IAAAH,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAa,SAAA;AAAA,IAAAJ,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAQ,OAAA;AAAA,IAAAC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAc,MAAA;AAAA,IAAAL,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,GCQbkC,KAAU;AAAA,EACdC,IAAIhG,GAAO6F;AAAAA,EACXI,IAAIjG,GAAOyF;AACb;AAEO,SAASS,GAAM;AAAA,EAACnB,SAAAA,IAAU;AAAA,EAAW9B,MAAAA,IAAO;AAAA,EAAMiC,UAAAA;AAAoB,GAAG;AAC9E,SAAO,gBAAAzC,EAAA,QAAA,EAAA,GAAA2C,EAAAC,EAAAlD,MAAmBnC,GAAOkD,MAAM6C,GAAQ9C,CAAI,GAAGjD,GAAO+E,CAAO,CAAC,GAAIG,UAAAA,GAAS;AACpF;ACfO,MAAMlF,KAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAV,QAAA;AAAA,IAAAgC,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAA4B,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAJ,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAyC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA9C,OAAA;AAAA,EAAA;AAAA,EAAA+C,aAAA;AAAA,IAAA3C,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA/B,OAAA;AAAA,EAAA;AAAA,EAAAgD,WAAA;AAAA,IAAA5C,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAjC,QAAA;AAAA,IAAAE,OAAA;AAAA,EAAA;AAAA,EAAAiD,SAAA;AAAA,IAAAxC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAkD,WAAA;AAAA,IAAAzC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAmD,MAAA;AAAA,IAAA1C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA+B,QAAA;AAAA,IAAAZ,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA/B,OAAA;AAAA,EAAA;AAAA,EAAAoD,QAAA;AAAA,IAAA3C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAqD,WAAA;AAAA,IAAAC,QAAA;AAAA,IAAAtD,OAAA;AAAA,EAAA;AAAA,EAAAuD,UAAA;AAAA,IAAAC,QAAA;AAAA,IAAAlB,QAAA;AAAA,IAAAtC,OAAA;AAAA,EAAA;AAAA,GCYbkC,KAAU;AAAA,EACdD,SAAS9F,GAAO4G;AAAAA,EAChBU,OAAOtH,GAAO6G;AAChB;AAEO,SAASU,GAAO;AAAA,EACrBxC,SAAAA,IAAU;AAAA,EACV9B,MAAAA,IAAO;AAAA,EACPiE,WAAAA,IAAY;AAAA,EACZE,UAAAA,IAAW;AAAA,EACXI,MAAAA,IAAO;AAAA,EACPC,SAAAA;AAAAA,EACAvC,UAAAA;AACW,GAAG;AACd,SACE,gBAAAzC,EAAA,UAAA,EACE,MAAA+E,GACA,UAAAJ,GACA,SAAAK,GAAiB,GAAArC,EAAAC,EAAAzD,QAEf5B,GAAOkD,MACP6C,GAAQ9C,CAAI,GACZjD,GAAO+E,CAAO,GACdmC,KAAalH,GAAOkH,WACpBE,KAAYpH,GAAOoH,QAAQ,GAG5BlC,UAAAA,EAAAA,CACH;AAEJ;ACzCO,MAAMlF,KAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAoB,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAc,QAAA;AAAA,IAAAzB,OAAA;AAAA,EAAA;AAAA,EAAA6D,UAAA;AAAA,IAAAlE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAoD,QAAA;AAAA,IAAA9D,OAAA;AAAA,EAAA;AAAA,EAAA+D,UAAA;AAAA,IAAApE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAV,OAAA;AAAA,EAAA;AAAA,EAAAgE,QAAA;AAAA,IAAArE,QAAA;AAAA,IAAAK,OAAA;AAAA,EAAA;AAAA,EAAAiE,aAAA;AAAA,IAAAtE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAD,QAAA;AAAA,IAAA6B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAlE,OAAA;AAAA,EAAA;AAAA,EAAA+C,aAAA;AAAA,IAAArD,QAAA;AAAA,IAAAM,OAAA;AAAA,EAAA;AAAA,EAAAmE,aAAA;AAAA,IAAAzE,QAAA;AAAA,IAAAM,OAAA;AAAA,EAAA;AAAA,EAAAoE,UAAA;AAAA,IAAA1E,QAAA;AAAA,IAAAM,OAAA;AAAA,EAAA;AAAA,EAAAqE,QAAA;AAAA,IAAAvE,QAAA;AAAA,IAAA4B,QAAA;AAAA,IAAA4C,QAAA;AAAA,IAAAtE,OAAA;AAAA,EAAA;AAAA,GCSbkC,KAAU;AAAA,EACdD,SAAS9F,GAAO4G;AAAAA,EAChBwB,SAASpI,GAAOgI;AAAAA,EAChBK,MAAMrI,GAAOiI;AACf;AAEO,SAASK,GAAK;AAAA,EACnBvD,SAAAA,IAAU;AAAA,EACV9B,MAAAA,IAAO;AAAA,EACPiF,QAAAA;AAAAA,EACAT,SAAAA;AAAAA,EACAvC,UAAAA;AACS,GAAG;AACZ,SACE,gBAAA3C,EAAA,OAAA,EAAU,SAAAkF,GAAiB,GAAArC,EAAAC,EAAAxD,KAAS7B,GAAOkD,MAAMlD,GAAO+E,CAAO,GAAGgB,GAAQ9C,CAAI,CAAC,GAC5EiF,UAAAA;AAAAA,IAAAA,KAAU,gBAAAzF,EAAA,SAAA,GAAA2C,EAAAC,EAAAxD,KAAiB7B,GAAOkI,MAAM,GAAGA,UAAAA,EAAAA,CAAO;AAAA,IAClDhD;AAAAA,EAAAA,GACH;AAEJ;AC7BO,MAAMlF,KAAM;AAAA,EAAAuI,MAAA;AAAA,IAAApF,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA6C,QAAA;AAAA,IAAAxC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAZ,QAAA;AAAA,IAAAC,OAAA;AAAA,EAAA;AAAA,EAAA2E,cAAA;AAAA,IAAAnB,QAAA;AAAA,IAAAlB,QAAA;AAAA,IAAAtC,OAAA;AAAA,EAAA;AAAA,EAAA4E,KAAA;AAAA,IAAAtB,QAAA;AAAA,IAAAuB,QAAA;AAAA,IAAAjF,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAAL,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAD,OAAA;AAAA,IAAAqC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAzC,OAAA;AAAA,EAAA;AAAA,EAAA8E,cAAA;AAAA,IAAArE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAV,OAAA;AAAA,EAAA;AAAA,EAAA+E,YAAA;AAAA,IAAAtE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAV,OAAA;AAAA,EAAA;AAAA,EAAA9B,OAAA;AAAA,IAAA8G,QAAA;AAAA,IAAA1B,QAAA;AAAA,IAAAuB,QAAA;AAAA,IAAArB,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAjF,OAAA;AAAA,EAAA;AAAA;ACSZ,SAASkF,GAAS;AAAA,EACvB/F,MAAAA;AAAAA,EACAvC,OAAAA;AAAAA,EACAuI,SAASC;AAAAA,EACTC,gBAAAA,IAAiB;AAAA,EACjB9B,UAAAA,IAAW;AAAA,EACX+B,UAAAA;AAAAA,EACAjE,UAAAA;AACa,GAAG;AAChB,QAAMkE,IAAeH,MAAsBjE,QACrC,CAACqE,GAAiBC,CAAkB,IAAIC,EAASL,CAAc,GAC/DM,IAAYJ,IAAeH,IAAoBI,GAE/CI,IAAeC,EACnB,CAACC,MAA2C;AAC1C,IAAKP,KACHE,EAAmBK,EAAEC,OAAOZ,OAAO,GAErCG,IAAWQ,CAAC;AAAA,EACd,GACA,CAACP,GAAcD,CAAQ,CACzB;AAEA,SACE,gBAAA5G,EAAA,SAAA,EAAA,GAAA6C,EAAAC,EAAArD,OAAoBhC,GAAOuI,MAAMnB,KAAYpH,GAAOwI,YAAY,GAC9D,UAAA;AAAA,IAAA,gBAAA/F,EAAA,SAAA,EACE,MAAK,YACL,MAAAO,GACA,OAAAvC,GACA,SAAS2I,IAAeH,IAAoBjE,QAC5C,gBAAiBoE,IAAgCpE,SAAjBkE,GAChC,UAAA9B,GACA,UAAUqC,GAAa,GAAArE,EAAAC,EAAAtD,OAChB/B,GAAO+B,KAAK,GAAA,KAAA,OAAA,CAAA;AAAA,IAErB,gBAAAU,EAAA,QAAA,EAAA,GAAA2C,EAAAC,EAAAlD,MACUnC,GAAOyI,KAAKe,IAAYxJ,GAAO4I,aAAa5I,GAAO2I,YAAY,GACvE,eAAW,IAEX,UAAA,gBAAAlG,EAAC,OAAA,EACC,OAAO,IACP,QAAQ,IACR,SAAQ,aACR,MAAK,QACL,OAAO;AAAA,MAACoH,SAASL,IAAY,IAAI;AAAA,IAAA,GAEjC,UAAA,gBAAA/G,EAAC,YAAA,EACC,QAAO,uBACP,QAAO,gBACP,aAAa,KACb,eAAc,SACd,gBAAe,QAAA,CAAO,GAE1B,GACF;AAAA,IACCyC,uBAAY,QAAA,EAAA,GAAAE,EAAAC,EAAAlD,IAAA,GAAY+C,UAAAA,EAAAA,CAAS;AAAA,EAAA,GACpC;AAEJ;ACnEO,MAAMlF,KAAM;AAAA,EAAAuI,MAAA;AAAA,IAAApF,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAV,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAoE,QAAA;AAAA,IAAAjG,OAAA;AAAA,EAAA;AAAA,EAAAkG,SAAA;AAAA,IAAApG,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAZ,QAAA;AAAA,IAAAC,OAAA;AAAA,EAAA;AAAA,EAAAmG,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAApG,OAAA;AAAA,EAAA;AAAA;ACKZ,SAASqG,GAAW;AAAA,EAACH,SAAAA;AAAAA,EAASjF,MAAAA;AAAAA,EAAMkF,QAAAA;AAAuB,GAAG;AACnE,SACE,gBAAAzH,EAAA,SAAA,GAAA6C,EAAAC,EAAAxD,KAAiB7B,GAAOuI,IAAI,GACzBzD,UAAAA;AAAAA,IAAAA;AAAAA,IACD,gBAAArC,EAAA,OAAA,GAAA2C,EAAAC,EAAAnD,GAAelC,GAAO+J,OAAO,GAAGA,UAAAA,EAAAA,CAAQ;AAAA,IACvCC,KAAU,gBAAAvH,EAAA,OAAA,EAAA,GAAA2C,EAAAC,EAAAxD,KAAiB7B,GAAOgK,MAAM,GAAGA,UAAAA,EAAAA,CAAO;AAAA,EAAA,GACrD;AAEJ;ACfO,MAAMG,KAAW;AAAA,EAAAC,QAAA;AAAA,IAAA9E,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAAyG,QAAA;AAAA,IAAAhF,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAA0G,QAAA;AAAA,IAAAjF,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAA2G,SAAA;AAAA,IAAAlF,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAA7B,OAAA;AAAA,IAAAsD,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAA4G,MAAA;AAAA,IAAAnF,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAA6G,UAAA;AAAA,IAAApF,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAM,QAAA;AAAA,IAAA9G,OAAA;AAAA,EAAA;AAAA,EAAA+G,WAAA;AAAA,IAAAtF,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAAgH,WAAA;AAAA,IAAAvF,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAAiH,WAAA;AAAA,IAAAxF,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAAkH,WAAA;AAAA,IAAAzF,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAAmH,WAAA;AAAA,IAAA1F,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAAoH,WAAA;AAAA,IAAA3F,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,EAAAqH,WAAA;AAAA,IAAA5F,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA8E,QAAA;AAAA,IAAAxG,OAAA;AAAA,EAAA;AAAA,GCAX7D,KAAM;AAAA,EAAA8F,SAAA;AAAA,IAAAtB,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAsH,OAAA;AAAA,IAAA3G,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAuH,QAAA;AAAA,IAAA5G,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAwH,YAAA;AAAA,IAAAvB,QAAA;AAAA,IAAAjG,OAAA;AAAA,EAAA;AAAA,EAAAyH,aAAA;AAAA,IAAAxB,QAAA;AAAA,IAAAjG,OAAA;AAAA,EAAA;AAAA,EAAA0H,UAAA;AAAA,IAAAzB,QAAA;AAAA,IAAAjG,OAAA;AAAA,EAAA;AAAA,GCmBb2H,KAAoD;AAAA,EACxD,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AACL,GAEMC,KAAW;AAAA,EACfC,OAAO1L,GAAOqL;AAAAA,EACdM,QAAQ3L,GAAOsL;AAAAA,EACfM,KAAK5L,GAAOuL;AACd;AAEO,SAASM,GAAQ;AAAA,EAACC,OAAAA;AAAAA,EAAO/G,SAAAA;AAAAA,EAASgH,OAAAA,IAAQ;AAAA,EAAWC,OAAAA;AAAAA,EAAO9G,UAAAA;AAAsB,GAAG;AAC1F,QAAM+G,IAAkBlH,KAAWyG,GAAkBM,CAAK,GACpD1L,IAAQ,CAAC+J,GAAY8B,CAAe,GAAGjM,GAAO+L,CAAK,GAAGC,KAASP,GAASO,CAAK,CAAC;AAEpF,SAAIF,MAAU,IAAU,gBAAArJ,aAAA2C,EAAAC,EAAA6G,IAAgB9L,CAAK,GAAG8E,UAAAA,EAAAA,CAAS,IACrD4G,MAAU,IAAU,gBAAArJ,aAAA2C,EAAAC,EAAA8G,IAAgB/L,CAAK,GAAG8E,UAAAA,EAAAA,CAAS,IACrD4G,MAAU,IAAU,gBAAArJ,aAAA2C,EAAAC,EAAA+G,IAAgBhM,CAAK,GAAG8E,UAAAA,EAAAA,CAAS,IACrD4G,MAAU,IAAU,gBAAArJ,aAAA2C,EAAAC,EAAAgH,IAAgBjM,CAAK,GAAG8E,UAAAA,EAAAA,CAAS,IACrD4G,MAAU,IAAU,gBAAArJ,aAAA2C,EAAAC,EAAAiH,IAAgBlM,CAAK,GAAG8E,UAAAA,EAAAA,CAAS,IAClD,gBAAAzC,EAAA,QAAA,GAAA2C,EAAAC,EAAAkH,IAAgBnM,CAAK,GAAG8E,UAAAA,GAAS;AAC1C;ACtCO,MAAMsH,KAAeC,EAAwC,IAAI;AAEjE,SAASC,KAAkB;AAChC,SAAOC,EAAWH,EAAY;AAChC;ACRO,MAAMxM,KAAM;AAAA,EAAAuI,MAAA;AAAA,IAAApF,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA7B,OAAA;AAAA,IAAA2B,QAAA;AAAA,IAAA4B,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAA+I,aAAA;AAAA,IAAAjJ,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAQ,OAAA;AAAA,IAAAV,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA;ACMnB,SAASgJ,GAAK;AAAA,EAACC,SAAAA,IAAU;AAAA,EAAO5H,UAAAA;AAAmB,GAAG;AACpD,QAAM6H,IAAKC,EAAAA,GACLC,IAAMC,GACV,OAAO;AAAA,IACLC,WAAW,GAAGJ,CAAE;AAAA,IAChBK,eAAe,GAAGL,CAAE;AAAA,IACpBM,SAAS,GAAGN,CAAE;AAAA,IACdD,SAAAA;AAAAA,EAAAA,IAEF,CAACC,GAAID,CAAO,CACd;AAEA,2BACGN,GAAa,UAAb,EAAsB,OAAOS,GAC5B,UAAA,gBAAAxK,EAAA,OAAA,EAAA,GAAA2C,EAAAC,EAAAxD,KAAiB7B,GAAOuI,IAAI,GAAGrD,UAAAA,GAAS,GAC1C;AAEJ;AAOA,SAASoI,GAAM;AAAA,EAACpI,UAAAA;AAAoB,GAAG;AACrC,QAAM+H,IAAMP,GAAAA;AACZ,SACE,gBAAAjK,aAAY,SAAKwK,GAAKE,WAAU,GAAA/H,EAAAC,EAAArD,OAAQhC,GAAOgC,KAAK,GACjDkD,UAAAA,EAAAA,CACH;AAEJ;AAOA,SAASqI,GAAY;AAAA,EAACrI,UAAAA;AAA0B,GAAG;AACjD,QAAM+H,IAAMP,GAAAA;AACZ,SACE,gBAAAjK,YAAW,IAAIwK,GAAKG,eAAc,GAAAhI,EAAAC,EAAAlD,MAAQnC,GAAO4M,WAAW,GACzD1H,UAAAA,EAAAA,CACH;AAEJ;AAOA,SAASsI,GAAM;AAAA,EAACtI,UAAAA;AAAoB,GAAG;AACrC,QAAM+H,IAAMP,GAAAA;AACZ,SAAI,CAACO,GAAKH,WAAW,CAAC5H,IAAiB,OAGrC,gBAAAzC,EAAA,QAAA,EAAW,IAAIwK,GAAKI,SAAS,MAAK,SAAO,GAAAjI,EAAAC,EAAAlD,MAAQnC,GAAOqE,KAAK,GAC1Da,UAAAA,GACH;AAEJ;AAEO,MAAMuI,KAAQ;AAAA,EAAA,MACnBZ;AAAAA,EACAS,OAAAA;AAAAA,EACAC,aAAAA;AAAAA,EAAAA,OACAC;AACF,GCzEaE,KAAoBjB,EAA6C,IAAI;AAE3E,SAASkB,KAAuB;AACrC,SAAOhB,EAAWe,EAAiB;AACrC;ACLO,MAAM1N,KAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAiE,QAAA;AAAA,IAAAlD,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAN,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAY,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAA4C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA9C,OAAA;AAAA,EAAA;AAAA,EAAAiC,SAAA;AAAA,IAAAvB,QAAA;AAAA,IAAAV,OAAA;AAAA,EAAA;AAAA,EAAAQ,OAAA;AAAA,IAAAE,QAAA;AAAA,IAAAV,OAAA;AAAA,EAAA;AAAA,EAAA+J,SAAA;AAAA,IAAAnK,QAAA;AAAA,IAAAD,QAAA;AAAA,IAAAgD,QAAA;AAAA,IAAA3C,OAAA;AAAA,EAAA;AAAA;AC6BZ,SAASgK,GAAM;AAAA,EACpB9I,SAAAA,IAAU;AAAA,EACVyC,MAAAA,IAAO;AAAA,EACPxE,MAAAA;AAAAA,EACA8K,aAAAA;AAAAA,EACAC,UAAAA;AAAAA,EACAC,WAAAA;AAAAA,EACAC,SAAAA;AAAAA,EACAC,cAAAA;AAAAA,EACAzN,OAAAA;AAAAA,EACA0N,cAAAA;AAAAA,EACA/G,UAAAA;AAAAA,EACA+B,UAAAA;AACU,GAAG;AACb,QAAM8D,IAAMP,GAAAA,GACN0B,IAAWT,GAAAA,GAIXU,IAAaJ,MAAYjJ,SAAY;AAAA,IAACiJ,SAAAA;AAAAA,EAAAA,IAAWjJ;AAEvD,SACE,gBAAAvC,EAAA,SAAA,EACE,IAAIwK,GAAKE,WACT,MAAA3F,GACA,MAAAxE,GACA,aAAA8K,GACA,UAAAC,GACA,WAAAC,GACA,cAAAE,GACA,OAAAzN,GACA,cAAA0N,GACA,UAAA/G,GACA,oBACE6F,IAAM,GAAGA,EAAIG,aAAa,IAAIH,EAAIH,UAAUG,EAAII,UAAU,EAAE,GAAGiB,SAAStJ,QAE1E,gBAAciI,GAAKH,WAAW/H,MAAY,WAAWC,QACrD,UAAAmE,GAAmB,GAAA/D,EAAAC,EAAAtD,OACX/B,GAAOkD,MAAMlD,GAAO+E,CAAO,GAAGqJ,GAAUR,WAAW5N,GAAO4N,OAAO,GACzE,GAAKS,GAAuC,KAAA,OAAA,CAAA;AAGlD;ACvEO,MAAMrO,KAAM;AAAA,EAAAuO,SAAA;AAAA,IAAApL,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAI,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAAsF,QAAA;AAAA,IAAA1C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAzC,OAAA;AAAA,EAAA;AAAA,EAAA2K,OAAA;AAAA,IAAArL,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAD,OAAA;AAAA,IAAA4B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAtB,QAAA;AAAA,IAAAgB,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAiK,QAAA;AAAA,IAAAhL,QAAA;AAAA,IAAAI,OAAA;AAAA,EAAA;AAAA,EAAA6K,YAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAhL,OAAA;AAAA,EAAA;AAAA,EAAAiL,UAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAApL,OAAA;AAAA,EAAA;AAAA,EAAAqL,gBAAA;AAAA,IAAA/I,QAAA;AAAA,IAAA7B,QAAA;AAAA,IAAA8B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAzC,OAAA;AAAA,EAAA;AAAA,EAAAsL,eAAA;AAAA,IAAA9H,QAAA;AAAA,IAAAlB,QAAA;AAAA,IAAAtC,OAAA;AAAA,EAAA;AAAA;ACMnB,SAASgJ,GAAK;AAAA,EAAC3H,UAAAA;AAAmB,GAAG;AACnC,QAAM+H,IAAMC,GAAQ,OAAO;AAAA,IAACU,SAAS;AAAA,EAAA,IAAQ,CAAA,CAAE;AAE/C,2BACGF,GAAkB,UAAlB,EAA2B,OAAOT,GACjC,UAAA,gBAAAxK,EAAA,OAAA,EAAA,GAAA2C,EAAAC,EAAAxD,KAAiB7B,GAAOuO,OAAO,GAAGrJ,UAAAA,GAAS,GAC7C;AAEJ;AAUA,SAASkK,GAAM;AAAA,EAACC,UAAAA,IAAW;AAAA,EAAO5H,SAAAA;AAAAA,EAASL,UAAAA;AAAAA,EAAUlC,UAAAA;AAAoB,GAAG;AAC1E,QAAMoK,IAAgBD,MAAa,UAAUrP,GAAO0O,aAAa1O,GAAO8O,UAClE1O,IAAQ,CACZJ,GAAOwO,OACPc,GACA7H,KAAW,CAACL,KAAYpH,GAAOkP,gBAC/B9H,KAAYpH,GAAOmP,aAAa;AAGlC,SAAI1H,IAEA,gBAAAhF,EAAA,UAAA,EAAa,MAAK,UAAS,SAAAgF,GAAkB,UAAAL,GAAmB,GAAAhC,EAAAC,EAAAzD,QAAQxB,CAAK,GAC1E8E,UAAAA,EAAAA,CACH,IAIG,gBAAAzC,EAAA,UAAA,GAAA2C,EAAAC,EAAAlD,MAAkB/B,CAAK,GAAG8E,UAAAA,GAAS;AAC5C;AAEO,MAAMqK,KAAa;AAAA,EAAA,MACxB1C;AAAAA,EACAuC,OAAAA;AACF,GC/CapP,KAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAV,QAAA;AAAA,IAAAgC,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAA4B,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAJ,QAAA;AAAA,IAAA2C,QAAA;AAAA,IAAAI,QAAA;AAAA,IAAAH,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAzC,OAAA;AAAA,EAAA;AAAA,EAAA+C,aAAA;AAAA,IAAA3C,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA/B,OAAA;AAAA,EAAA;AAAA,EAAAgD,WAAA;AAAA,IAAA5C,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAjC,QAAA;AAAA,IAAAE,OAAA;AAAA,EAAA;AAAA,EAAAiD,SAAA;AAAA,IAAAxC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAkD,WAAA;AAAA,IAAAzC,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAqD,WAAA;AAAA,IAAAC,QAAA;AAAA,IAAAtD,OAAA;AAAA,EAAA;AAAA,GCYbkC,KAAU;AAAA,EACdD,SAAS9F,GAAO4G;AAAAA,EAChBU,OAAOtH,GAAO6G;AAChB;AAEO,SAAS2I,GAAW;AAAA,EACzBC,MAAAA;AAAAA,EACA1K,SAAAA,IAAU;AAAA,EACV9B,MAAAA,IAAO;AAAA,EACPiE,WAAAA,IAAY;AAAA,EACZ0C,QAAAA;AAAAA,EACA8F,KAAAA;AAAAA,EACAxK,UAAAA;AACe,GAAG;AAClB,SACE,gBAAAzC,SACE,MAAAgN,GACA,QAAA7F,GACA,KAAA8F,MAAStK,EAAAC,EAAA1D,GACD3B,GAAOkD,MAAM6C,GAAQ9C,CAAI,GAAGjD,GAAO+E,CAAO,GAAGmC,KAAalH,GAAOkH,SAAS,GAEjFhC,UAAAA,GACH;AAEJ;ACnCO,MAAMlF,IAAM;AAAA,EAAAuI,MAAA;AAAA,IAAAM,QAAA;AAAA,IAAA1F,QAAA;AAAA,IAAAU,OAAA;AAAA,EAAA;AAAA,EAAA8L,SAAA;AAAA,IAAAxM,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAN,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAA2C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAxC,OAAA;AAAA,EAAA;AAAA,EAAA+L,UAAA;AAAA,IAAA/G,QAAA;AAAA,IAAAgH,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAApM,OAAA;AAAA,EAAA;AAAA,EAAAqM,OAAA;AAAA,IAAArH,QAAA;AAAA,IAAAgH,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA7F,QAAA;AAAA,IAAA3F,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAAmE,QAAA;AAAA,IAAA1D,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAtB,QAAA;AAAA,IAAA6L,QAAA;AAAA,IAAApM,OAAA;AAAA,EAAA;AAAA,EAAAsM,UAAA;AAAA,IAAAL,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAlM,OAAA;AAAA,EAAA;AAAA,EAAAuM,MAAA;AAAA,IAAAjN,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAY,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAjC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAAd,QAAA;AAAA,IAAAhB,QAAA;AAAA,IAAA2C,QAAA;AAAA,IAAA7B,QAAA;AAAA,IAAA8B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAxC,OAAA;AAAA,EAAA;AAAA,EAAAwM,iBAAA;AAAA,IAAA/L,QAAA;AAAA,IAAAT,OAAA;AAAA,EAAA;AAAA,EAAAyM,UAAA;AAAA,IAAA/J,QAAA;AAAA,IAAA/B,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,GCON0M,KAAc9D,EAAuC,IAAI;AAE/D,SAAS+D,KAAU;AACxB,QAAMvD,IAAMN,EAAW4D,EAAW;AAClC,MAAI,CAACtD,EAAK,OAAM,IAAIO,MAAM,wDAAwD;AAClF,SAAOP;AACT;AChBO,SAASwD,KAAc;AAC5B,QAAM,CAACC,GAAMC,CAAO,IAAIpH,EAAS,EAAK,GAChC,CAACqH,GAAeC,CAAgB,IAAItH,EAAwB,IAAI,GAChEuH,IAAS9D,EAAAA,GACT+D,IAAUC,EAAuB,IAAI,GACrCC,IAAaD,EAAiC,IAAI,GAClDE,IAAWF,EAAO,oBAAIG,KAA0B,GAChDC,IAAWJ,EAAiB,EAAE,GAC9BK,IAA2BL,EAAO,EAAK,GAEvCM,IAAQ5H,EAAY,MAAM;AAC9BiH,IAAAA,EAAQ,EAAK,GACbE,EAAiB,IAAI,GACrBQ,EAAyBE,UAAU,IACnCN,EAAWM,SAASC,MAAAA;AAAAA,EACtB,GAAG,CAAA,CAAE,GAECC,IAAS/H,EAAY,MAAM;AAC/BiH,IAAAA,EAASe,CAAAA,OACFA,KAGHb,EAAiB,IAAI,GACrBQ,EAAyBE,UAAU,MAHnCF,EAAyBE,UAAU,IAK9B,CAACG,EACT;AAAA,EACH,GAAG,CAAA,CAAE;AAKLC,EAAAA,EAAU,MAAM;AACd,QAAIjB,KAAQW,EAAyBE,SAAS;AAC5CF,MAAAA,EAAyBE,UAAU;AACnC,YAAMK,IAAQR,EAASG;AACvB,MAAIK,EAAMC,SAAS,KACjBhB,EAAiBe,EAAM,CAAC,CAAC;AAAA,IAE7B;AAAA,EACF,GAAG,CAAClB,CAAI,CAAC;AAET,QAAMoB,IAAepI,EAAY,CAACqD,GAAYgF,MAAyB;AACrEb,IAAAA,EAASK,QAAQS,IAAIjF,GAAIgF,CAAO;AAChC,UAAME,IAAMf,EAASK,SACfW,IAAM,CAAC,GAAGD,EAAIE,MAAM;AAC1BD,WAAAA,EAAIE,KAAK,CAACzQ,GAAG0Q,MAAM;AACjB,YAAMC,IAAML,EAAIM,IAAI5Q,CAAC,GACf6Q,IAAMP,EAAIM,IAAIF,CAAC;AACrB,aAAI,CAACC,KAAO,CAACE,IAAY,IAClBF,EAAIG,wBAAwBD,CAAG,IAAIE,KAAKC,8BAA8B,KAAK;AAAA,IACpF,CAAC,GACDvB,EAASG,UAAUW,GACZ,MAAM;AACXhB,MAAAA,EAASK,QAAQqB,OAAO7F,CAAE,GAC1BqE,EAASG,UAAUH,EAASG,QAAQsB,OAAQ5S,CAAAA,MAAMA,MAAM8M,CAAE;AAAA,IAC5D;AAAA,EACF,GAAG,CAAA,CAAE;AAGL4E,SAAAA,EAAU,MAAM;AACd,UAAMpJ,IAAOwI,EAAQQ;AACrB,QAAI,CAAChJ,KAAQ,CAACmI,EAAM;AAEpB,aAASoC,EAAcnJ,GAAkB;AACvC,YAAMiI,IAAQR,EAASG;AACvB,UAAIK,EAAMC,WAAW;AAErB,gBAAQlI,EAAE7G,KAAAA;AAAAA,UACR,KAAK,aAAa;AAChB6G,YAAAA,EAAEoJ,eAAAA,GACFlC,EAAkBa,CAAAA,MAAS;AACzB,oBAAMsB,IAAMtB,IAAOE,EAAMqB,QAAQvB,CAAI,IAAI;AACzC,qBAAOE,GAAOoB,IAAM,KAAKpB,EAAMC,MAAM;AAAA,YACvC,CAAC;AACD;AAAA,UACF;AAAA,UACA,KAAK,WAAW;AACdlI,YAAAA,EAAEoJ,eAAAA,GACFlC,EAAkBa,CAAAA,MAAS;AACzB,oBAAMsB,IAAMtB,IAAOE,EAAMqB,QAAQvB,CAAI,IAAI;AACzC,qBAAOE,GAAOoB,IAAM,IAAIpB,EAAMC,UAAUD,EAAMC,MAAM;AAAA,YACtD,CAAC;AACD;AAAA,UACF;AAAA,UACA,KAAK,QAAQ;AACXlI,YAAAA,EAAEoJ,eAAAA,GACFlC,EAAiBe,EAAM,CAAC,CAAC;AACzB;AAAA,UACF;AAAA,UACA,KAAK,OAAO;AACVjI,YAAAA,EAAEoJ,eAAAA,GACFlC,EAAiBe,EAAMA,EAAMC,SAAS,CAAC,CAAC;AACxC;AAAA,UACF;AAAA,UACA,KAAK;AAAA,UACL,KAAK,KAAK;AACRlI,YAAAA,EAAEoJ,eAAAA;AACF,kBAAMG,IAAQhC,EAASK;AACvBV,YAAAA,EAAkBa,CAAAA,OACZA,KACSwB,EAAMX,IAAIb,CAAI,GACrByB,MAAAA,GAECzB,EACR;AACD;AAAA,UACF;AAAA,UACA,KAAK;AAAA,UACL,KAAK,OAAO;AACVJ,YAAAA,EAAAA;AACA;AAAA,UACF;AAAA,QAAA;AAAA,IAEJ;AAEA/I,WAAAA,EAAK6K,iBAAiB,WAAWN,CAAa,GACvC,MAAMvK,EAAK8K,oBAAoB,WAAWP,CAAa;AAAA,EAChE,GAAG,CAACpC,GAAMY,CAAK,CAAC,GAaT;AAAA,IAACrE,KAXsB;AAAA,MAC5ByD,MAAAA;AAAAA,MACAe,QAAAA;AAAAA,MACAH,OAAAA;AAAAA,MACAR,QAAAA;AAAAA,MACAF,eAAAA;AAAAA,MACAC,kBAAAA;AAAAA,MACAiB,cAAAA;AAAAA,MACAb,YAAAA;AAAAA,IAAAA;AAAAA,IAGWF,SAAAA;AAAAA,EAAAA;AACf;AC5HA,SAASlE,GAAK;AAAA,EAAC3H,UAAAA;AAAmB,GAAG;AACnC,QAAM;AAAA,IAAC+H,KAAAA;AAAAA,IAAK8D,SAAAA;AAAAA,EAAAA,IAAWN,GAAAA;AAEvB,2BACGF,GAAY,UAAZ,EAAqB,OAAOtD,GAC3B,4BAAA,OAAA,EAAU,KAAK8D,GAAQ,GAAA3L,EAAAC,EAAAxD,KAAQ7B,EAAOuI,IAAI,GACvCrD,UAAAA,GACH,GACF;AAEJ;AAGA,SAASoO,GAAQ;AAAA,EAACpO,UAAAA;AAA+B,GAAG;AAClD,QAAM;AAAA,IAACwL,MAAAA;AAAAA,IAAMe,QAAAA;AAAAA,IAAQX,QAAAA;AAAAA,IAAQG,YAAAA;AAAAA,EAAAA,IAAcT,GAAAA,GACrC+C,IAAWvC,EAA0B,IAAI;AAG/CW,SAAAA,EAAU,MAAM;AACdV,IAAAA,EAAWM,UAAUgC,EAAShC;AAAAA,EAChC,CAAC,GAGC,gBAAA9O,EAAA,YACE,KAAK8Q,GACL,MAAK,UACL,SAAS9B,GACT,iBAAef,GACf,iBAAc,QACd,iBAAeA,IAAOI,IAAS9L,QAAU,GAAAI,EAAAC,EAAAzD,QAClC5B,EAAO2P,OAAO,GAEpBzK,UAAAA,EAAAA,CACH;AAEJ;AAQA,SAASsO,GAAM;AAAA,EAACtO,UAAAA;AAAAA,EAAU8G,OAAAA,IAAQ;AAAmB,GAAG;AACtD,QAAM;AAAA,IAAC0E,MAAAA;AAAAA,IAAMY,OAAAA;AAAAA,IAAOR,QAAAA;AAAAA,IAAQF,eAAAA;AAAAA,EAAAA,IAAiBJ,GAAAA;AAE7C,SAAKE,IAGH,gBAAAnO,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC,EAAA,OAAA,EAAA,GAAA2C,EAAAC,EAAAxD,KAAiB7B,EAAO4P,QAAQ,GAAE,SAAS0B,EAAAA,CAAM;AAAA,IACjD,gBAAA7O,EAAA,SACE,IAAIqO,GACJ,MAAK,QACL,yBAAuBF,KAAiB5L,QAAU,GAAAI,EAAAC,EAAAxD,KAC1C7B,EAAOkQ,OAAOlE,MAAU,SAAShM,EAAOmQ,QAAQ,GAEvDjL,UAAAA,EAAAA,CACH;AAAA,EAAA,GACF,IAbgB;AAepB;AAQA,SAASuO,GAAK;AAAA,EAAChM,SAAAA;AAAAA,EAASvC,UAAAA;AAAmB,GAAG;AAC5C,QAAM;AAAA,IAACoM,OAAAA;AAAAA,IAAOV,eAAAA;AAAAA,IAAeC,kBAAAA;AAAAA,IAAkBiB,cAAAA;AAAAA,EAAAA,IAAgBtB,GAAAA,GACzDzD,IAAKC,EAAAA,GACL0G,IAAM1C,EAAuB,IAAI,GACjC2C,IAAgB/C,MAAkB7D;AAExC4E,SAAAA,EAAU,MAAM;AACd,UAAMiC,IAAKF,EAAInC;AACf,QAAKqC;AACL,aAAO9B,EAAa/E,GAAI6G,CAAE;AAAA,EAC5B,GAAG,CAAC7G,GAAI+E,CAAY,CAAC,GAQnB,gBAAArP,EAAA,SACE,KAAAiR,GACA,IAAA3G,GACA,MAAK,YACL,SAVgB8G,MAAM;AACxBpM,IAAAA,IAAAA,GACA6J,EAAAA;AAAAA,EACF,GAQI,gBAAgB,MAAMT,EAAiB9D,CAAE,GAAE,GAAA3H,EAAAC,EAAAxD,KACnC7B,EAAOoQ,MAAMuD,KAAiB3T,EAAOqQ,eAAe,GAE3DnL,UAAAA,EAAAA,CACH;AAEJ;AAQA,SAAS4O,GAAS;AAAA,EAACrE,MAAAA;AAAAA,EAAMvK,UAAAA;AAAuB,GAAG;AACjD,QAAM;AAAA,IAACoM,OAAAA;AAAAA,IAAOV,eAAAA;AAAAA,IAAeC,kBAAAA;AAAAA,IAAkBiB,cAAAA;AAAAA,EAAAA,IAAgBtB,GAAAA,GACzDzD,IAAKC,EAAAA,GACL0G,IAAM1C,EAA0B,IAAI,GACpC2C,IAAgB/C,MAAkB7D;AAExC4E,SAAAA,EAAU,MAAM;AACd,UAAMiC,IAAKF,EAAInC;AACf,QAAKqC;AACL,aAAO9B,EAAa/E,GAAI6G,CAAE;AAAA,EAC5B,GAAG,CAAC7G,GAAI+E,CAAY,CAAC,GAGnB,gBAAArP,EAAA,KAAA,EACE,KAAAiR,GACA,IAAA3G,GACA,MAAA0C,GACA,SAAS6B,GACT,MAAK,YACL,gBAAgB,MAAMT,EAAiB9D,CAAE,GAAE,GAAA3H,EAAAC,EAAA1D,GACnC3B,EAAOoQ,MAAMpQ,EAAOsQ,UAAUqD,KAAiB3T,EAAOqQ,eAAe,GAE5EnL,UAAAA,EAAAA,CACH;AAEJ;AAEO,MAAM6O,KAAO;AAAA,EAAA,MAClBlH;AAAAA,EAAAA,SACAyG;AAAAA,EAAAA,OACAE;AAAAA,EAAAA,MACAC;AAAAA,EACAK,UAAAA;AACF,GClJa9T,IAAM;AAAA,EAAAuI,MAAA;AAAA,IAAAM,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAjF,OAAA;AAAA,EAAA;AAAA,EAAAmQ,UAAA;AAAA,IAAA7M,QAAA;AAAA,IAAAuB,QAAA;AAAA,IAAAuL,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAtQ,OAAA;AAAA,EAAA;AAAA,EAAAK,SAAA;AAAA,IAAAE,QAAA;AAAA,IAAAgQ,QAAA;AAAA,IAAAvQ,OAAA;AAAA,EAAA;AAAA,EAAAwQ,WAAA;AAAA,IAAAxL,QAAA;AAAA,IAAAoH,QAAA;AAAA,IAAA9M,QAAA;AAAA,IAAAmR,QAAA;AAAA,IAAA7F,QAAA;AAAA,IAAArI,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAzC,OAAA;AAAA,EAAA;AAAA,EAAA0Q,mBAAA;AAAA,IAAA1E,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA7I,QAAA;AAAA,IAAA/D,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAA/B,OAAA;AAAA,EAAA;AAAA,EAAA2Q,qBAAA;AAAA,IAAA1E,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAtH,QAAA;AAAA,IAAAtF,QAAA;AAAA,IAAAuC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAA7B,OAAA;AAAA,EAAA;AAAA,EAAA4Q,iBAAA;AAAA,IAAApN,QAAA;AAAA,IAAAxD,OAAA;AAAA,EAAA;AAAA,EAAA6Q,kBAAA;AAAA,IAAArN,QAAA;AAAA,IAAAxD,OAAA;AAAA,EAAA;AAAA,EAAA8Q,OAAA;AAAA,IAAA9L,QAAA;AAAA,IAAA1E,QAAA;AAAA,IAAAG,QAAA;AAAA,IAAAd,QAAA;AAAA,IAAA4C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAxC,OAAA;AAAA,EAAA;AAAA,EAAA+Q,mBAAAA,CAiEGC,MAA0B,CAAA;AAAA,IAAAC,OAC5CD,KAAS,OAAA,aAATA;AAAAA,IAAShR,OAAA;AAAA,EAAA,GAAA;AAAA,IAAA,kBAAAkR,CAAAA,MAAA,OAAAA,KAAA,WAAAA,IAAA,OAAAA,KAAA/P,QAAT6P,CAAS;AAAA,EAAA,CAAA;AAAA,EAAAG,eAAAA,CAEKC,GAAgBvV,MAAiB,CAAA;AAAA,IAAAgJ,QAC/CuM,KAAM,OAAA,aAANA;AAAAA,IAAMlN,QACNrI,KAAS,OAAA,YAATA;AAAAA,IAASmE,OAAA;AAAA,EAAA,GAAA;AAAA,IAAA,eAAAkR,CAAAA,MAAA,OAAAA,KAAA,WAAAA,IAAA,OAAAA,KAAA/P,QADTiQ,CAAM;AAAA,IAAA,iBACNvV,KAASsF;AAAAA,EAAAA,CAAA;AAAA,EAAAkQ,iBAAAA,CAEOC,GAAezV,MAAiB,CAAA;AAAA,IAAAyH,QAChDgO,KAAK,OAAA,YAALA;AAAAA,IAAKpN,QACLrI,KAAS,OAAA,YAATA;AAAAA,IAASmE,OAAA;AAAA,EAAA,GAAA;AAAA,IAAA,cAAAkR,CAAAA,MAAA,OAAAA,KAAA,WAAAA,IAAA,OAAAA,KAAA/P,QADTmQ,CAAK;AAAA,IAAA,iBACLzV,KAASsF;AAAAA,EAAAA,CAAA;AAAA,GChEAoQ,KAAoB3I,EAA6C,IAAI;AAE3E,SAAS4I,KAAgB;AAC9B,QAAMpI,IAAMN,EAAWyI,EAAiB;AACxC,MAAI,CAACnI,EAAK,OAAM,IAAIO,MAAM,oEAAoE;AAC9F,SAAOP;AACT;ACjBO,SAASqI,KAA4C;AAC1D,QAAMC,IAAcvE,EAA8B,IAAI,GAChDwE,IAAaxE,EAA8B,IAAI,GAC/C,CAACyE,GAAWC,CAAY,IAAInM,EAAS,CAAC,GACtC,CAACoM,GAAYC,CAAa,IAAIrM,EAAS,CAAC,GACxC,CAACsM,GAAcC,CAAe,IAAIvM,EAAS,CAAC,GAC5C,CAACwM,GAAaC,CAAc,IAAIzM,EAAS,CAAC,GAC1C,CAAC0M,GAAcC,CAAe,IAAI3M,EAAS,CAAC,GAC5C,CAAC4M,GAAaC,CAAc,IAAI7M,EAAS,CAAC,GAC1C,CAAC8M,GAAWC,CAAY,IAAI/M,EAAS,EAAK,GAC1CgN,IAAiBvF,EAA6C,IAAI,GAElEwF,IAAe9M,EAAY,MAAM;AACrC,UAAM+M,IAAKlB,EAAYhE;AACvB,IAAKkF,MAELf,EAAae,EAAGhB,SAAS,GACzBG,EAAca,EAAGd,UAAU,GAC3BG,EAAgBW,EAAGZ,YAAY,GAC/BG,EAAeS,EAAGV,WAAW,GAC7BG,EAAgBO,EAAGR,YAAY,GAC/BG,EAAeK,EAAGN,WAAW,GAC7BG,EAAa,EAAI,GAEbC,EAAehF,WAASmF,aAAaH,EAAehF,OAAO,GAC/DgF,EAAehF,UAAUoF,WAAW,MAAML,EAAa,EAAK,GAAG,GAAI;AAAA,EACrE,GAAG,CAAA,CAAE;AAGL3E,SAAAA,EAAU,MAAM;AACd,UAAM8E,IAAKlB,EAAYhE;AACvB,QAAI,CAACkF,EAAI;AAET,UAAMG,IAAW,IAAIC,eAAe,MAAM;AACxCf,MAAAA,EAAgBW,EAAGZ,YAAY,GAC/BG,EAAeS,EAAGV,WAAW,GAC7BG,EAAgBO,EAAGR,YAAY,GAC/BG,EAAeK,EAAGN,WAAW;AAAA,IAC/B,CAAC;AACDS,WAAAA,EAASE,QAAQL,CAAE,GAEnBX,EAAgBW,EAAGZ,YAAY,GAC/BG,EAAeS,EAAGV,WAAW,GAC7BG,EAAgBO,EAAGR,YAAY,GAC/BG,EAAeK,EAAGN,WAAW,GAEtB,MAAMS,EAASG,WAAAA;AAAAA,EACxB,GAAG,CAAA,CAAE,GAGLpF,EAAU,MAAM;AACd,UAAM8E,IAAKlB,EAAYhE;AACvB,QAAKkF;AACLA,aAAAA,EAAGrD,iBAAiB,UAAUoD,GAAc;AAAA,QAACQ,SAAS;AAAA,MAAA,CAAK,GACpD,MAAMP,EAAGpD,oBAAoB,UAAUmD,CAAY;AAAA,EAC5D,GAAG,CAACA,CAAY,CAAC,GAEV;AAAA,IACLjB,aAAAA;AAAAA,IACAC,YAAAA;AAAAA,IACAC,WAAAA;AAAAA,IACAE,YAAAA;AAAAA,IACAE,cAAAA;AAAAA,IACAE,aAAAA;AAAAA,IACAE,cAAAA;AAAAA,IACAE,aAAAA;AAAAA,IACAE,WAAAA;AAAAA,EAAAA;AAEJ;AC3DA,SAASxJ,GAAK;AAAA,EAAC3H,UAAAA;AAAmB,GAAG;AACnC,QAAM+H,IAAMqI,GAAAA;AAEZ,2BACGF,GAAkB,UAAlB,EAA2B,OAAOnI,GACjC,UAAA,gBAAAxK,EAAA,OAAA,EAAA,GAAA2C,EAAAC,EAAAxD,KAAiB7B,EAAOuI,IAAI,GAAGrD,UAAAA,GAAS,GAC1C;AAEJ;AASA,SAAS+R,GAAS;AAAA,EAAC/R,UAAAA;AAAAA,EAAU2P,WAAAA;AAAwB,GAAG;AACtD,QAAM;AAAA,IAACU,aAAAA;AAAAA,EAAAA,IAAeF,GAAAA;AAEtB,2BACE,OAAA,EACE,KAAKE,GAAY,GAAAnQ,EAAAC,EAAAxD,KACT7B,EAAOgU,UAAUa,KAAa,QAAQ7U,EAAO4U,kBAAkBC,CAAS,CAAC,GAEhF3P,UAAAA,GACH;AAEJ;AAQA,SAASgS,GAAQ;AAAA,EAAChS,UAAAA;AAAsB,GAAG;AACzC,QAAM;AAAA,IAACsQ,YAAAA;AAAAA,EAAAA,IAAcH,GAAAA;AACrB,SACE,gBAAA5S,EAAA,OAAA,EAAU,KAAK+S,GAAW,GAAApQ,EAAAC,EAAAxD,KAAQ7B,EAAOkE,OAAO,GAC7CgB,UAAAA,EAAAA,CACH;AAEJ;AAWA,SAASiS,GAAU;AAAA,EAACC,aAAAA,IAAc;AAAA,EAAYlS,UAAAA;AAAwB,GAAG;AACvE,QAAM;AAAA,IAACmR,WAAAA;AAAAA,IAAWR,cAAAA;AAAAA,IAAcE,aAAAA;AAAAA,IAAaE,cAAAA;AAAAA,IAAcE,aAAAA;AAAAA,EAAAA,IAAed,GAAAA;AAM1E,UAFE+B,MAAgB,aAAavB,IAAeI,IAAeF,IAAcI,KAKzE,gBAAA1T,EAAA,SAAA,GAAA2C,EAAAC,EAAAxD,KAEI7B,EAAOqU,WACP+C,MAAgB,aAAapX,EAAOuU,oBAAoBvU,EAAOwU,qBAC/D6B,IAAYrW,EAAO0U,mBAAmB1U,EAAOyU,eAAe,GAG7DvP,UAAAA,GACH,IAXuB;AAa3B;AAQA,SAASmS,GAAM;AAAA,EAACD,aAAAA,IAAc;AAAsB,GAAG;AACrD,QAAM;AAAA,IAAC7B,aAAAA;AAAAA,IAAaE,WAAAA;AAAAA,IAAWE,YAAAA;AAAAA,IAAYE,cAAAA;AAAAA,IAAcE,aAAAA;AAAAA,IAAaE,cAAAA;AAAAA,IAAcE,aAAAA;AAAAA,EAAAA,IAClFd,GAAAA,GACIiC,IAActG,EAAO,EAAK,GAC1BuG,IAAcvG,EAAO,CAAC,GACtBwG,IAAiBxG,EAAO,CAAC,GAEzByG,IAAaL,MAAgB,YAE7BM,IACFC,KAAKC,IADgBH,IACXxB,IAAeJ,IAAgB,MAC/BM,IAAcJ,IAAe,KADO,EAAE,GAG9C8B,IAAYJ,IAAa5B,IAAeI,IAAeF,IAAcI,GACrE2B,IAAYL,IAAaxB,IAAeE,GACxC4B,IAAkBL,IAAmB,MAAOI,GAC5CE,IAAeP,IAAahC,IAAYE,GACxCsC,IAAcJ,IAAY,IAAKG,IAAeH,KAAcC,IAAYC,KAAkB,GAE1FG,IAAaT,IACfzX,EAAOgV,cAAc,GAAG0C,CAAgB,KAAK,cAAcO,CAAW,KAAK,IAC3EjY,EAAOkV,gBAAgB,GAAGwC,CAAgB,KAAK,cAAcO,CAAW,KAAK,GAE3EE,IAAoBzO,EACxB,CAACC,MAA0B;AACzBA,IAAAA,EAAEoJ,eAAAA,GACFuE,EAAY/F,UAAU,IACtBgG,EAAYhG,UAAUkG,IAAa9N,EAAEyO,UAAUzO,EAAE0O,SACjDb,EAAejG,UAAUkG,IACpBlC,EAAYhE,SAASkE,aAAa,IAClCF,EAAYhE,SAASoE,cAAc,GACtChM,EAAEC,OAAuB0O,kBAAkB3O,EAAE4O,SAAS;AAAA,EAC1D,GACA,CAACd,GAAYlC,CAAW,CAC1B,GAEMiD,IAAoB9O,EACxB,CAACC,MAA0B;AACzB,QAAI,CAAC2N,EAAY/F,QAAS;AAC1B,UAAMkF,IAAKlB,EAAYhE;AACvB,QAAI,CAACkF,EAAI;AAET,UAAMgC,KAAShB,IAAa9N,EAAEyO,UAAUzO,EAAE0O,WAAWd,EAAYhG,SAC3DmH,IAAcb,KAAaC,IAAYC,IACvCY,IAAcF,IAAQC;AAE5B,IAAIjB,IACFhB,EAAGhB,YAAY+B,EAAejG,UAAUoH,IAExClC,EAAGd,aAAa6B,EAAejG,UAAUoH;AAAAA,EAE7C,GACA,CAAClB,GAAYI,GAAWC,GAAWC,GAAgBxC,CAAW,CAChE,GAEMqD,IAAkBlP,EAAY,MAAM;AACxC4N,IAAAA,EAAY/F,UAAU;AAAA,EACxB,GAAG,CAAA,CAAE;AAEL,SACE,gBAAA9O,EAAA,OAAA,EACE,eAAe0V,GACf,eAAeK,GACf,aAAaI,GAAgB,GAAAxT,EAAAC,EAAAxD,KACrB7B,EAAO2U,OAAOuD,CAAU,GAAA;AAGtC;AAEO,MAAMW,KAAa;AAAA,EAAA,MACxBhM;AAAAA,EACAoK,UAAAA;AAAAA,EACAC,SAAAA;AAAAA,EACAC,WAAAA;AAAAA,EACAE,OAAAA;AACF,GCnKarX,IAAM;AAAA,EAAAuI,MAAA;AAAA,IAAAM,QAAA;AAAA,IAAA1F,QAAA;AAAA,IAAAU,OAAA;AAAA,EAAA;AAAA,EAAA8L,SAAA;AAAA,IAAAxM,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAV,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAN,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAA2C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAxC,OAAA;AAAA,EAAA;AAAA,EAAApD,OAAA;AAAA,IAAA+D,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAiK,aAAA;AAAA,IAAAtJ,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAiB,MAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAmB,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAA+L,UAAA;AAAA,IAAA/G,QAAA;AAAA,IAAAgH,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAApM,OAAA;AAAA,EAAA;AAAA,EAAAqM,OAAA;AAAA,IAAArH,QAAA;AAAA,IAAAgH,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA7F,QAAA;AAAA,IAAA3F,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAAmE,QAAA;AAAA,IAAA1D,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAtB,QAAA;AAAA,IAAA6L,QAAA;AAAA,IAAApM,OAAA;AAAA,EAAA;AAAA,EAAAuM,MAAA;AAAA,IAAAjN,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAY,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAjC,QAAA;AAAA,IAAA2B,QAAA;AAAA,IAAAd,QAAA;AAAA,IAAAhB,QAAA;AAAA,IAAA2C,QAAA;AAAA,IAAA7B,QAAA;AAAA,IAAA8B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAxC,OAAA;AAAA,EAAA;AAAA,EAAAiV,cAAA;AAAA,IAAAtU,QAAA;AAAA,IAAAe,QAAA;AAAA,IAAA1B,OAAA;AAAA,EAAA;AAAA,EAAAwM,iBAAA;AAAA,IAAA/L,QAAA;AAAA,IAAAT,OAAA;AAAA,EAAA;AAAA,EAAAkV,QAAA;AAAA,IAAA5V,QAAA;AAAA,IAAAU,OAAA;AAAA,EAAA;AAAA,GCWNmV,KAAgBvM,EAAyC,IAAI;AAEnE,SAASwM,KAAY;AAC1B,QAAMhM,IAAMN,EAAWqM,EAAa;AACpC,MAAI,CAAC/L,EAAK,OAAM,IAAIO,MAAM,4DAA4D;AACtF,SAAOP;AACT;ACrBO,SAASiM,GACdC,GACAhL,GACAhF,GACA;AACA,QAAM,CAACiQ,GAAUC,CAAW,IAAI9P,EAAS4E,CAAY,GAC/C1N,IAAQ0Y,MAAoBnU,SAAYmU,IAAkBC,GAC1DE,IAAW5P,EACf,CAAC6P,MAAS;AACR,IAAIJ,MAAoBnU,UAAWqU,EAAYE,CAAC,GAChDpQ,IAAWoQ,CAAC;AAAA,EACd,GACA,CAACJ,GAAiBhQ,CAAQ,CAC5B;AACA,SAAO,CAAC1I,GAAO6Y,CAAQ;AACzB;ACNO,SAASE,GAAc;AAAA,EAC5BrL,cAAAA;AAAAA,EACA1N,OAAO0Y;AAAAA,EACPM,eAAAA;AAAAA,EACAC,eAAAA;AACoB,GAAG;AACvB,QAAM,CAACjZ,GAAO6Y,CAAQ,IAAIJ,GACxBC,GACAhL,KAAgB,MAChBsL,CACF,GACM,CAAC/I,GAAMC,CAAO,IAAIpH,EAAS,EAAK,GAChC,CAACoQ,GAAQC,CAAS,IAAIrQ,EAAiCmQ,KAAiB,CAAA,CAAE,GAC1E,CAAC9I,GAAeC,CAAgB,IAAItH,EAAwB,IAAI,GAChEsQ,IAAY7M,EAAAA,GACZ+D,IAAUC,EAAuB,IAAI,GACrCC,IAAaD,EAAiC,IAAI,GAClDE,IAAWF,EAAO,oBAAIG,KAAoD,GAC1EC,IAAWJ,EAAiB,EAAE,GAE9BM,IAAQ5H,EAAY,MAAM;AAC9BiH,IAAAA,EAAQ,EAAK,GACbE,EAAiB,IAAI,GACrBI,EAAWM,SAASC,MAAAA;AAAAA,EACtB,GAAG,CAAA,CAAE,GAECC,IAAS/H,EAAY,MAAM;AAC/BiH,IAAAA,EAASe,CAAAA,MAAS;AAChB,UAAKA;AAaHb,QAAAA,EAAiB,IAAI;AAAA,WAbZ;AACT,cAAMqC,IAAQhC,EAASK,SACjBK,IAAQR,EAASG;AACvB,YAAIuI,IAAuB;AAC3B,mBAAW/M,KAAM6E,GAAO;AACtB,gBAAMxB,IAAO8C,EAAMX,IAAIxF,CAAE;AACzB,cAAIqD,KAAQA,EAAK3P,UAAUA,GAAO;AAChCqZ,YAAAA,IAAQ/M;AACR;AAAA,UACF;AAAA,QACF;AACA8D,QAAAA,EAAiBiJ,MAAUlI,EAAMC,SAAS,IAAID,EAAM,CAAC,IAAI,KAAK;AAAA,MAChE;AAGA,aAAO,CAACF;AAAAA,IACV,CAAC;AAAA,EACH,GAAG,CAACjR,CAAK,CAAC,GAEJsZ,IAAgBrQ,EAAY,CAAC6P,GAAWvX,MAAkB;AAC9D4X,IAAAA,EAAWlI,CAAAA,MACLA,EAAK6H,CAAC,MAAMvX,IAAc0P,IACvB;AAAA,MAAC,GAAGA;AAAAA,MAAM,CAAC6H,CAAC,GAAGvX;AAAAA,IAAAA,CACvB;AAAA,EACH,GAAG,CAAA,CAAE,GAEC8P,IAAepI,EAAY,CAACqD,GAAYiN,GAAmBjI,MAAyB;AACxFb,IAAAA,EAASK,QAAQS,IAAIjF,GAAI;AAAA,MAACtM,OAAOuZ;AAAAA,MAAWjI,SAAAA;AAAAA,IAAAA,CAAQ;AACpD,UAAME,IAAMf,EAASK,SACfW,IAAM,CAAC,GAAGD,EAAIE,MAAM;AAC1BD,WAAAA,EAAIE,KAAK,CAACzQ,GAAG0Q,MAAM;AACjB,YAAMC,KAAML,EAAIM,IAAI5Q,CAAC,GAAGoQ,SAClBS,KAAMP,EAAIM,IAAIF,CAAC,GAAGN;AACxB,aAAI,CAACO,MAAO,CAACE,KAAY,IAClBF,GAAIG,wBAAwBD,EAAG,IAAIE,KAAKC,8BAA8B,KAAK;AAAA,IACpF,CAAC,GACDvB,EAASG,UAAUW,GACZ,MAAM;AACXhB,MAAAA,EAASK,QAAQqB,OAAO7F,CAAE,GAC1BqE,EAASG,UAAUH,EAASG,QAAQsB,OAAQ5S,CAAAA,MAAMA,MAAM8M,CAAE;AAAA,IAC5D;AAAA,EACF,GAAG,CAAA,CAAE;AAGL4E,SAAAA,EAAU,MAAM;AACd,UAAMpJ,IAAOwI,EAAQQ;AACrB,QAAI,CAAChJ,KAAQ,CAACmI,EAAM;AAEpB,aAASoC,EAAcnJ,GAAkB;AACvC,YAAMiI,IAAQR,EAASG,SACjB2B,IAAQhC,EAASK;AACvB,UAAIK,EAAMC,WAAW;AAErB,gBAAQlI,EAAE7G,KAAAA;AAAAA,UACR,KAAK,aAAa;AAChB6G,YAAAA,EAAEoJ,eAAAA,GACFlC,EAAkBa,CAAAA,MAAS;AACzB,oBAAMsB,IAAMtB,IAAOE,EAAMqB,QAAQvB,CAAI,IAAI;AACzC,qBAAOE,GAAOoB,IAAM,KAAKpB,EAAMC,MAAM;AAAA,YACvC,CAAC;AACD;AAAA,UACF;AAAA,UACA,KAAK,WAAW;AACdlI,YAAAA,EAAEoJ,eAAAA,GACFlC,EAAkBa,CAAAA,MAAS;AACzB,oBAAMsB,IAAMtB,IAAOE,EAAMqB,QAAQvB,CAAI,IAAI;AACzC,qBAAOE,GAAOoB,IAAM,IAAIpB,EAAMC,UAAUD,EAAMC,MAAM;AAAA,YACtD,CAAC;AACD;AAAA,UACF;AAAA,UACA,KAAK,QAAQ;AACXlI,YAAAA,EAAEoJ,eAAAA,GACFlC,EAAiBe,EAAM,CAAC,CAAC;AACzB;AAAA,UACF;AAAA,UACA,KAAK,OAAO;AACVjI,YAAAA,EAAEoJ,eAAAA,GACFlC,EAAiBe,EAAMA,EAAMC,SAAS,CAAC,CAAC;AACxC;AAAA,UACF;AAAA,UACA,KAAK;AAAA,UACL,KAAK,KAAK;AACRlI,YAAAA,EAAEoJ,eAAAA,GACFlC,EAAkBa,CAAAA,MAAS;AACzB,kBAAIA,GAAM;AACR,sBAAMtB,IAAO8C,EAAMX,IAAIb,CAAI;AAC3B,gBAAItB,MACFkJ,EAASlJ,EAAK3P,KAAK,GACnB6Q,EAAAA;AAAAA,cAEJ;AACA,qBAAOI;AAAAA,YACT,CAAC;AACD;AAAA,UACF;AAAA,UACA,KAAK;AAAA,UACL,KAAK,OAAO;AACVJ,YAAAA,EAAAA;AACA;AAAA,UACF;AAAA,QAAA;AAAA,IAEJ;AAEA/I,WAAAA,EAAK6K,iBAAiB,WAAWN,CAAa,GACvC,MAAMvK,EAAK8K,oBAAoB,WAAWP,CAAa;AAAA,EAChE,GAAG,CAACpC,GAAMY,GAAOgI,CAAQ,CAAC,GAgCnB;AAAA,IAACrM,KA9BwBC,GAC9B,OAAO;AAAA,MACLwD,MAAAA;AAAAA,MACAe,QAAAA;AAAAA,MACAH,OAAAA;AAAAA,MACA7Q,OAAAA;AAAAA,MACA6Y,UAAAA;AAAAA,MACAK,QAAAA;AAAAA,MACAI,eAAAA;AAAAA,MACAF,WAAAA;AAAAA,MACAjJ,eAAAA;AAAAA,MACAC,kBAAAA;AAAAA,MACAiB,cAAAA;AAAAA,MACAb,YAAAA;AAAAA,IAAAA,IAEF,CACEP,GACAe,GACAH,GACA7Q,GACA6Y,GACAK,GACAI,GACAF,GACAjJ,GACAC,GACAiB,CAAY,CAEhB;AAAA,IAEaf,SAAAA;AAAAA,EAAAA;AACf;ACjKA,SAASlE,GAAK;AAAA,EAAC7J,MAAAA;AAAAA,EAAMmL,cAAAA;AAAAA,EAAc1N,OAAAA;AAAAA,EAAOgZ,eAAAA;AAAAA,EAAeC,eAAAA;AAAAA,EAAexU,UAAAA;AAAmB,GAAG;AAC5F,QAAM;AAAA,IAAC+H,KAAAA;AAAAA,IAAK8D,SAAAA;AAAAA,EAAAA,IAAWyI,GAAc;AAAA,IAACrL,cAAAA;AAAAA,IAAc1N,OAAAA;AAAAA,IAAOgZ,eAAAA;AAAAA,IAAeC,eAAAA;AAAAA,EAAAA,CAAc;AAExF,2BACGV,GAAc,UAAd,EAAuB,OAAO/L,GAC7B,UAAA,gBAAA1K,EAAA,OAAA,EAAU,KAAKwO,GAAQ,GAAA3L,EAAAC,EAAAxD,KAAQ7B,EAAOuI,IAAI,GACvCvF,UAAAA;AAAAA,IAAAA,KAAQ,gBAAAP,EAAA,SAAA,EAAY,MAAK,UAAS,MAAAO,GAAY,OAAOiK,EAAIxM,SAAS,IAAG,KAAA,QAAA,GAAA2E,EAAAC,EAAAtD,KAAA,GAAA;AAAA,IACrEmD;AAAAA,EAAAA,EAAAA,CACH,EAAA,CACF;AAEJ;AAGA,SAASoO,GAAQ;AAAA,EAACpO,UAAAA;AAA+B,GAAG;AAClD,QAAM;AAAA,IAACwL,MAAAA;AAAAA,IAAMe,QAAAA;AAAAA,IAAQoI,WAAAA;AAAAA,IAAWjJ,eAAAA;AAAAA,IAAeK,YAAAA;AAAAA,EAAAA,IAAcgI,GAAAA,GACvD1F,IAAWvC,EAA0B,IAAI;AAG/CW,SAAAA,EAAU,MAAM;AACdV,IAAAA,EAAWM,UAAUgC,EAAShC;AAAAA,EAChC,CAAC,GAGC,gBAAA9O,EAAA,UAAA,EACE,KAAK8Q,GACL,MAAK,UACL,MAAM,YACN,SAAS9B,GACT,iBAAef,GACf,iBAAc,WACd,iBAAeA,IAAOmJ,IAAY7U,QAClC,yBAAuB4L,KAAiB5L,QAAU,GAAAI,EAAAC,EAAAzD,QAC3C5B,EAAO2P,OAAO,GAEpBzK,UAAAA,EAAAA,CACH;AAEJ;AAGA,SAAS+U,GAAM;AAAA,EAACnM,aAAAA;AAAmC,GAAG;AACpD,QAAM;AAAA,IAACrN,OAAAA;AAAAA,IAAOkZ,QAAAA;AAAAA,EAAAA,IAAUV,GAAAA,GAClBiB,IAAUzZ,IAASkZ,EAAOlZ,CAAK,KAAKA,IAAS;AAEnD,SACE,gBAAAgC,EAAA,QAAA,EAAA,GAAA2C,EAAAC,EAAAlD,MAAkB+X,IAAUla,EAAOS,QAAQT,EAAO8N,WAAW,GAC1DoM,eAAWpM,GACd;AAEJ;AAGA,SAAS/K,GAAK;AAAA,EAACmC,UAAAA;AAAgC,GAAG;AAChD,SACE,gBAAAzC,EAAA,QAAA,EAAA,GAAA2C,EAAAC,EAAAlD,MAAkBnC,EAAO8E,IAAI,GAC1BI,eACC,gBAAAzC,EAAC,OAAA,EACC,OAAM,MACN,QAAO,MACP,SAAQ,aACR,MAAK,QACL,QAAO,gBACP,aAAY,KACZ,eAAc,SACd,gBAAe,SACf,eAAY,QAEZ,UAAA,gBAAAA,EAAC,QAAA,EAAK,GAAE,eAAA,CAAc,GACxB,GAEJ;AAEJ;AAGA,SAAS+Q,GAAM;AAAA,EAACtO,UAAAA;AAA+B,GAAG;AAChD,QAAM;AAAA,IAACwL,MAAAA;AAAAA,IAAMY,OAAAA;AAAAA,IAAOuI,WAAAA;AAAAA,EAAAA,IAAaZ,GAAAA;AAEjC,SACE,gBAAA1W,EAAAC,GAAA,EACGkO,UAAAA;AAAAA,IAAAA,KAAQ,gBAAAjO,cAAA2C,EAAAC,EAAAxD,KAAiB7B,EAAO4P,QAAQ,GAAE,SAAS0B,EAAAA,CAAM;AAAA,IAC1D,gBAAA7O,EAAA,SACE,IAAIoX,GACJ,MAAK,WACL,eAAa,CAACnJ,GAAK,GAAAtL,EAAAC,EAAAxD,KACX7B,EAAOkQ,OAAO,CAACQ,KAAQ1Q,EAAO+Y,MAAM,GAE3C7T,UAAAA,EAAAA,CACH;AAAA,EAAA,GACF;AAEJ;AAQA,SAASuO,GAAK;AAAA,EAAChT,OAAOuZ;AAAAA,EAAW9U,UAAAA;AAAmB,GAAG;AACrD,QAAM;AAAA,IACJzE,OAAO0Z;AAAAA,IACPb,UAAAA;AAAAA,IACAhI,OAAAA;AAAAA,IACAyI,eAAAA;AAAAA,IACAnJ,eAAAA;AAAAA,IACAC,kBAAAA;AAAAA,IACAiB,cAAAA;AAAAA,EAAAA,IACEmH,GAAAA,GACElM,IAAKC,EAAAA,GACL0G,IAAM1C,EAAuB,IAAI,GACjCoJ,IAAaD,MAAkBH,GAC/BrG,IAAgB/C,MAAkB7D;AAGxC4E,SAAAA,EAAU,MAAM;AACd,UAAMiC,IAAKF,EAAInC;AACf,QAAI,CAACqC,EAAI;AACT,UAAMyG,IAAOzG,EAAG0G;AAChB,IAAID,KAAMN,EAAcC,GAAWK,CAAI;AAAA,EACzC,GAAG,CAACL,GAAWD,CAAa,CAAC,GAE7BpI,EAAU,MAAM;AACd,UAAMiC,IAAKF,EAAInC;AACf,QAAKqC;AACL,aAAO9B,EAAa/E,GAAIiN,GAAWpG,CAAE;AAAA,EACvC,GAAG,CAAC7G,GAAIiN,GAAWlI,CAAY,CAAC,GAQ9B,gBAAArP,EAAA,OAAA,EACE,KAAAiR,GACA,IAAA3G,GACA,MAAK,UACL,iBAAeqN,GACf,SAXgBvG,MAAM;AACxByF,IAAAA,EAASU,CAAS,GAClB1I,EAAAA;AAAAA,EACF,GASI,gBAAgB,MAAMT,EAAiB9D,CAAE,GAAE,GAAA3H,EAAAC,EAAAxD,KAEzC7B,EAAOoQ,MACPgK,KAAcpa,EAAO8Y,cACrBnF,KAAiB3T,EAAOqQ,eAAe,GAGxCnL,UAAAA,EAAAA,CACH;AAEJ;AAGA,SAASqV,GAAS;AAAA,EAACrV,UAAAA;AAA+B,GAAG;AACnD,2BAAO,QAAA,EAAA,GAAAE,EAAAC,EAAAlD,IAAA,GAAY+C,UAAAA,GAAS;AAC9B;AAEO,MAAMsV,KAAS;AAAA,EAAA,MACpB3N;AAAAA,EAAAA,SACAyG;AAAAA,EACA2G,OAAAA;AAAAA,EACAlX,MAAAA;AAAAA,EACAyQ,OAAAA;AAAAA,EAAAA,MACAC;AAAAA,EACA8G,UAAAA;AACF,GCjLava,IAAM;AAAA,EAAAuI,MAAA;AAAA,IAAApF,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA4W,OAAA;AAAA,IAAAtX,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAS,OAAA;AAAA,EAAA;AAAA,EAAA6W,cAAA;AAAA,IAAAvX,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAN,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAA4B,QAAA;AAAA,IAAAoF,QAAA;AAAA,IAAAN,QAAA;AAAA,IAAA7F,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAA0C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAzC,OAAA;AAAA,EAAA;AAAA,EAAA8W,oBAAA;AAAA,IAAAnW,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAA+W,SAAA;AAAA,IAAAzX,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAA+C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAzC,OAAA;AAAA,EAAA;AAAA,EAAAgX,aAAA;AAAA,IAAA9S,QAAA;AAAA,IAAAlE,OAAA;AAAA,EAAA;AAAA,EAAAuM,MAAA;AAAA,IAAAjN,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAY,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAN,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAA4B,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAAD,QAAA;AAAA,IAAA2C,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAwD,QAAA;AAAA,IAAAtD,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA7C,OAAA;AAAA,EAAA;AAAA,EAAAiX,YAAA;AAAA,IAAAtW,QAAA;AAAA,IAAAe,QAAA;AAAA,IAAA1B,OAAA;AAAA,EAAA;AAAA,GCMNkX,KAAiBtO,EAA0C,IAAI;AAErE,SAASuO,KAAa;AAC3B,QAAM/N,IAAMN,EAAWoO,EAAc;AACrC,MAAI,CAAC9N,EAAK,OAAM,IAAIO,MAAM,8DAA8D;AACxF,SAAOP;AACT;ACFA,SAASJ,GAAK;AAAA,EAAC3H,UAAAA;AAAAA,EAAUzE,OAAO0Y;AAAAA,EAAiBhL,cAAAA;AAAAA,EAAcsL,eAAAA;AAAwB,GAAG;AACxF,QAAM,CAACwB,GAAaC,CAAQ,IAAIhC,GAC9BC,GACAhL,KAAgB,MAChBsL,IACKF,CAAAA,MAAM;AACL,IAAIA,MAAM,QAAME,EAAcF,CAAC;AAAA,EACjC,IACAvU,MACN,GACM,CAACmW,GAAgBC,CAAiB,IAAI7R,EAAsB,oBAAI8R,KAAK,GACrEjK,IAAWJ,EAAiB,EAAE,GAE9BsK,IAAc5R,EAAY,CAAC+Q,MAAkB;AACjDW,IAAAA,EAAmB1J,CAAAA,MAAS;AAC1B,YAAM6J,IAAO,IAAIF,IAAI3J,CAAI;AACzB,aAAI6J,EAAKC,IAAIf,CAAK,IAChBc,EAAK3I,OAAO6H,CAAK,IAEjBc,EAAKE,IAAIhB,CAAK,GAETc;AAAAA,IACT,CAAC;AAAA,EACH,GAAG,CAAA,CAAE,GAECzJ,IAAepI,EAAY,CAACjJ,OAC3B2Q,EAASG,QAAQmK,SAASjb,CAAK,KAClC2Q,EAASG,QAAQoK,KAAKlb,CAAK,GAEtB,MAAM;AACX2Q,IAAAA,EAASG,UAAUH,EAASG,QAAQsB,OAAQ0G,CAAAA,MAAMA,MAAM9Y,CAAK;AAAA,EAC/D,IACC,CAAA,CAAE;AAGLkR,SAAAA,EAAU,MAAM;AACd,IAAIsJ,KACFG,EAAmB1J,CAAAA,MAEVA,CACR;AAAA,EAEL,GAAG,CAACuJ,CAAW,CAAC,GAGd,gBAAAxY,EAACsY,GAAe,UAAf,EACC,OAAO;AAAA,IAACE,aAAAA;AAAAA,IAAaC,UAAAA;AAAAA,IAAUC,gBAAAA;AAAAA,IAAgBG,aAAAA;AAAAA,IAAaxJ,cAAAA;AAAAA,IAAcV,UAAAA;AAAAA,EAAAA,GAE1E,UAAA,gBAAA3O,EAAA,OAAA,EAAU,MAAK,cAAY,GAAA2C,EAAAC,EAAApD,KAAQjC,EAAOuI,IAAI,GAC3CrD,UAAAA,GACH,EAAA,CACF;AAEJ;AAWA,SAAS0W,GAAM;AAAA,EAAC1W,UAAAA;AAAAA,EAAUlD,OAAAA;AAAAA,EAAO6Z,UAAAA;AAAAA,EAAUC,iBAAAA;AAA2B,GAAG;AACvE,QAAMhZ,IAAM+Y,KAAY7Z,GAClB;AAAA,IAACmZ,gBAAAA;AAAAA,IAAgBG,aAAAA;AAAAA,IAAaL,aAAAA;AAAAA,EAAAA,IAAeD,GAAAA,GAC7Ce,IAAaZ,EAAeK,IAAI1Y,CAAG,GACnCkZ,IAAWhL,EAAuB,IAAI;AAG5CW,EAAAA,EAAU,MAAM;AACd,QAAI,CAACsJ,KAAeE,EAAeK,IAAI1Y,CAAG,EAAG;AAC7C,UAAM8Q,IAAKoI,EAASzK;AACpB,QAAI,CAACqC,EAAI;AAET,IADkBA,EAAGqI,cAAc,oBAAoBhB,CAAW,IAAI,KAEpEK,EAAYxY,CAAG;AAAA,EAEnB,GAAG,CAACmY,GAAanY,GAAKqY,GAAgBG,CAAW,CAAC,GAGlD3J,EAAU,MAAM;AACd,IAAImK,KAAmB,CAACX,EAAeK,IAAI1Y,CAAG,KAC5CwY,EAAYxY,CAAG;AAAA,EAInB,GAAG,CAAA,CAAE;AAEL,QAAMoZ,IACA,CAACjB,KAAe,CAACe,EAASzK,UAAgB,KACvC,CAAC,CAACyK,EAASzK,QAAQ0K,cAAc,oBAAoBhB,CAAW,IAAI;AAG7E,SACE,gBAAA1Y,EAAA,OAAA,EAAU,KAAKyZ,GAAS,GAAA5W,EAAAC,EAAAxD,KAAQ7B,EAAOya,KAAK,GAC1C,UAAA;AAAA,IAAA,gBAAAlY,EAAA,YACE,MAAK,UACL,SAAS,MAAM+Y,EAAYxY,CAAG,MAAEsC,EAAAC,EAAAzD,QACxB5B,EAAO0a,cAAcwB,KAAkBlc,EAAO2a,kBAAkB,GACxE,iBAAeoB,GAEf,UAAA;AAAA,MAAA,gBAAAtZ,EAAA,QAAA,EAAA,GAAA2C,EAAAC,EAAAlD,MAAmBnC,EAAO4a,SAASmB,KAAc/b,EAAO6a,WAAW,GACjE,UAAA,gBAAApY,EAAC,OAAA,EACC,OAAO,IACP,QAAQ,IACR,SAAQ,aACR,MAAK,QACL,QAAO,gBACP,aAAa,KACb,eAAc,SACd,gBAAe,SAEf,UAAA,gBAAAA,EAAC,QAAA,EAAK,GAAE,gBAAA,CAAe,GACzB,GACF;AAAA,MACCT;AAAAA,IAAAA,GACH;AAAA,IACC+Z,KAAc7W;AAAAA,EAAAA,GACjB;AAEJ;AASA,SAASuO,GAAK;AAAA,EAAChT,OAAAA;AAAAA,EAAOyE,UAAAA;AAAmB,GAAG;AAC1C,QAAM;AAAA,IAAC+V,aAAAA;AAAAA,IAAaC,UAAAA;AAAAA,IAAUpJ,cAAAA;AAAAA,EAAAA,IAAgBkJ,GAAAA,GACxCmB,IAAWlB,MAAgBxa;AAEjCkR,SAAAA,EAAU,MACDG,EAAarR,CAAK,GACxB,CAACA,GAAOqR,CAAY,CAAC,GAGtB,gBAAArP,EAAA,UAAA,EACE,MAAK,UACL,kBAAgBhC,GAChB,SAAS,MAAMya,EAASza,CAAK,GAAE,GAAA2E,EAAAC,EAAAzD,QACvB5B,EAAOoQ,MAAM+L,KAAYnc,EAAO8a,UAAU,GAClD,gBAAcqB,IAAW,SAASnX,QAEjCE,UAAAA,EAAAA,CACH;AAEJ;AAEO,MAAMkX,KAAU;AAAA,EAAA,MACrBvP;AAAAA,EACA+O,OAAAA;AAAAA,EACAnI,MAAAA;AACF,GCnKazT,KAAM;AAAA,EAAAuI,MAAA;AAAA,IAAApF,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAH,OAAA;AAAA,EAAA;AAAA,EAAAwY,SAAA;AAAA,IAAA7Y,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAA+X,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA7Y,OAAA;AAAA,EAAA;AAAA,EAAAmC,IAAA;AAAA,IAAAmB,QAAA;AAAA,IAAAuB,QAAA;AAAA,IAAAjF,QAAA;AAAA,IAAAI,OAAA;AAAA,EAAA;AAAA,EAAAoC,IAAA;AAAA,IAAAkB,QAAA;AAAA,IAAAuB,QAAA;AAAA,IAAAjF,QAAA;AAAA,IAAAI,OAAA;AAAA,EAAA;AAAA,EAAA8Y,IAAA;AAAA,IAAAxV,QAAA;AAAA,IAAAuB,QAAA;AAAA,IAAAjF,QAAA;AAAA,IAAAI,OAAA;AAAA,EAAA;AAAA,EAAA+Y,QAAA;AAAA,IAAA/T,QAAA;AAAA,IAAA1B,QAAA;AAAA,IAAAuB,QAAA;AAAA,IAAAI,QAAA;AAAA,IAAA+T,QAAA;AAAA,IAAAhZ,OAAA;AAAA,EAAA;AAAA,GCEbkC,KAAU;AAAA,EACdC,IAAIhG,GAAOgG;AAAAA,EACXC,IAAIjG,GAAOiG;AAAAA,EACX0W,IAAI3c,GAAO2c;AACb;AAEO,SAASG,GAAQ;AAAA,EAAC7Z,MAAAA,IAAO;AAAA,EAAMjB,OAAAA,IAAQ;AAAuB,GAAG;AACtE,SACE,gBAAAO,EAAA,OAAA,EAAU,MAAK,UAAQ,GAAA6C,EAAAC,EAAAxD,KAAQ7B,GAAOuI,IAAI,GACxC,UAAA;AAAA,IAAA,gBAAA9F,cAAA2C,EAAAC,EAAAxD,KAAkB7B,GAAOqc,SAAStW,GAAQ9C,CAAI,CAAC,GAAG,eAAW,GAAA,CAAA;AAAA,IAC7D,gBAAAR,EAAA,UAAA,GAAA2C,EAAAC,EAAAlD,MAAkBnC,GAAO4c,MAAM,GAAG5a,UAAAA,EAAAA,CAAM;AAAA,EAAA,GAC1C;AAEJ;ACnBO,MAAMhC,KAAM;AAAA,EAAAuI,MAAA;AAAA,IAAApF,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAmE,QAAA;AAAA,IAAAtE,OAAA;AAAA,EAAA;AAAA,EAAAQ,OAAA;AAAA,IAAAG,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAY,SAAA;AAAA,IAAAD,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAa,SAAA;AAAA,IAAAF,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAc,MAAA;AAAA,IAAAH,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAsH,OAAA;AAAA,IAAA3G,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA;ACaZ,SAASkZ,GAAW;AAAA,EAAC/Z,MAAAA;AAAAA,EAAMC,MAAAA,IAAO;AAAA,EAAI8B,SAAAA,IAAU;AAAwB,GAAG;AAChF,2BACE,OAAA,EAAA,GAAAK,EAAAC,EAAAxD,KAAkB7B,GAAOuI,MAAMvI,GAAO+E,CAAO,CAAC,GAC5C,UAAA,gBAAAtC,EAACM,IAAA,EAAK,MAAAC,GAAY,MAAAC,GAAW,GAC/B;AAEJ;ACpBiE,MAAA+Z,KAAA;AAAA,EAAAC,QAAA;AAAA,EAAA,OAAA;AAAA,GAEpDjd,IAAM;AAAA,EAAAuI,MAAA;AAAA,IAAA9E,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAAsF,QAAA;AAAA,IAAAxE,QAAA;AAAA,IAAAgB,QAAA;AAAA,IAAAd,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAqE,QAAA;AAAA,IAAA5D,QAAA;AAAA,IAAAT,OAAA;AAAA,EAAA;AAAA,EAAAqZ,KAAA;AAAA,IAAA/Z,QAAA;AAAA,IAAAga,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAxZ,OAAA;AAAA,EAAA;AAAA,EAAAyZ,cAAA;AAAA,IAAAH,QAAA;AAAA,IAAAtZ,OAAA;AAAA,EAAA;AAAA,EAAA0Z,SAAA;AAAA,IAAAjZ,QAAA;AAAA,IAAA8B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAzC,OAAA;AAAA,EAAA;AAAA,EAAA2Z,YAAA;AAAA,IAAAjY,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAAsF,QAAA;AAAA,IAAAjG,OAAA;AAAA,EAAA;AAAA,EAAA4Z,MAAA;AAAA,IAAAjZ,QAAA;AAAA,IAAArB,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAA6Z,QAAA;AAAA,IAAAzZ,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAjC,QAAA;AAAA,IAAAE,OAAA;AAAA,EAAA;AAAA,EAAA8Z,QAAA;AAAA,IAAA1Z,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAjC,QAAA;AAAA,IAAAE,OAAA;AAAA,EAAA;AAAA,EAAA+Z,aAAA;AAAA,IAAAtZ,QAAA;AAAA,IAAAT,OAAA;AAAA,EAAA;AAAA,EAAAga,cAAA;AAAA,IAAAlP,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAhL,OAAA;AAAA,EAAA;AAAA,EAAAia,kBAAA;AAAA,IAAAnP,QAAA;AAAA,IAAA9K,OAAA;AAAA,EAAA;AAAA,EAAAka,aAAAA,CAwFHC,OAAehB,IAAA;AAAA,IAAA,2BACN,UAAUgB,CAAO,mBAAjB,UAAUA,CAAO,WAAQhZ;AAAAA,EAAAA,CAAA;AAAA,GC5E5CiZ,KAAexR,EAAwC,IAAI;AAEjE,SAASyR,KAAW;AAClB,QAAMjR,IAAMN,EAAWsR,EAAY;AACnC,MAAI,CAAChR,EAAK,OAAM,IAAIO,MAAM,0DAA0D;AACpF,SAAOP;AACT;AAIA,MAAMkR,KAAgB1R,EAAc,EAAK;AAWzC,SAASI,GAAK;AAAA,EAAC3H,UAAAA;AAAAA,EAAUH,SAAAA,IAAU;AAAA,EAAW9B,MAAAA,IAAO;AAAA,EAAM+a,SAAAA;AAAkB,GAAG;AAC9E,SACE,gBAAAvb,EAACwb,GAAa,UAAb,EAAsB,OAAO;AAAA,IAAClZ,SAAAA;AAAAA,IAAS9B,MAAAA;AAAAA,IAAM+a,SAAAA;AAAAA,IAASI,UAAU;AAAA,EAAA,GAC/D,UAAA,gBAAA3b,EAAA,OAAA,EAAU,MAAK,SAAO,GAAA2C,EAAAC,EAAAxD,KAAQ7B,EAAOuI,IAAI,GACtCrD,UAAAA,GACH,EAAA,CACF;AAEJ;AAIA,SAASmZ,GAAO;AAAA,EAACnZ,UAAAA;AAA+B,GAAG;AACjD,2BACGiZ,GAAc,UAAd,EAAuB,OAAO,IAC7B,4BAAA,OAAA,EAAU,MAAK,YAAU,GAAA/Y,EAAAC,EAAAxD,KAAQ7B,EAAOkI,MAAM,GAC3ChD,UAAAA,GACH,GACF;AAEJ;AAIA,SAASoZ,GAAK;AAAA,EAACpZ,UAAAA;AAA+B,GAAG;AAC/C,QAAM;AAAA,IAACH,SAAAA;AAAAA,EAAAA,IAAWmZ,GAAAA,GACZK,IAAaC,GAASC,QAAQvZ,CAAQ;AAE5C,2BACGiZ,GAAc,UAAd,EAAuB,OAAO,IAC7B,4BAAA,OAAA,EAAU,MAAK,eAAU/Y,EAAAC,EAAAxD,GAAA,GACtB0c,YAAWtM,IAAI,CAACyM,GAAOC,MAClB5Z,MAAY,8BAEX6Z,GAAgB,UAAhB,EAAqC,OAAOD,GAC1CD,eAD4BC,CAE/B,IAGGD,CACR,GACH,GACF;AAEJ;AAGA,MAAME,KAAkBnS,EAAsB,EAAE;AAIhD,SAASoS,GAAI;AAAA,EAAC3Z,UAAAA;AAA+B,GAAG;AAC9C,QAAM;AAAA,IAACH,SAAAA;AAAAA,IAASiZ,SAAAA;AAAAA,EAAAA,IAAWE,GAAAA,GACrBE,IAAWzR,EAAWwR,EAAa,GACnCW,IAAWnS,EAAWiS,EAAe,GACrCG,IAAYD,KAAY,KAAKA,IAAW,MAAM,GAC9CP,IAAaC,GAASC,QAAQvZ,CAAQ;AAG5C,oCAEI,MAAK,OAAK,GAAAE,EAAAC,EAAAxD,KAER7B,EAAOkd,KACPld,EAAO+d,YAAYC,CAAO,GAC1B,CAACI,KAAYpe,EAAOud,SACpB,CAACa,KAAYrZ,MAAY,aAAaga,KAAa/e,EAAO4d,WAAW,GAGtE7Y,UAAAA,MAAY,aACTwZ,EAAWtM,IAAI,CAACyM,GAAOC,wBACpBK,GAAiB,UAAjB,EAAsC,OAAO;AAAA,IAACL,OAAAA;AAAAA,IAAOM,OAAOV,EAAW1M;AAAAA,EAAAA,GACrE6M,UAAAA,EAAAA,GAD6BC,CAEhC,CACD,IACDzZ,EAAAA,CACN;AAEJ;AAGA,MAAM8Z,KAAmBvS,EAA8C;AAAA,EACrEkS,OAAO;AAAA,EACPM,OAAO;AACT,CAAC;AAID,SAASC,GAAW;AAAA,EAACha,UAAAA;AAA+B,GAAG;AACrD,QAAM;AAAA,IAACjC,MAAAA;AAAAA,IAAM8B,SAAAA;AAAAA,EAAAA,IAAWmZ,GAAAA,GAClB;AAAA,IAACS,OAAAA;AAAAA,IAAOM,OAAAA;AAAAA,EAAAA,IAAStS,EAAWqS,EAAgB,GAC5CG,IAASpa,MAAY,cAAc4Z,MAAUM,IAAQ;AAE3D,SACE,gBAAAxc,WACE,MAAK,gBAAc,GAAA2C,EAAAC,EAAAxD,KAEjB7B,EAAOwd,YACPva,MAAS,OAAOjD,EAAO0d,SAAS1d,EAAO2d,QACvC5Y,MAAY,cAAc/E,EAAO6d,cACjCsB,KAAUnf,EAAO8d,gBAAgB,GAGlC5Y,UAAAA,EAAAA,CACH;AAEJ;AAIA,SAASka,GAAK;AAAA,EAACla,UAAAA;AAA+B,GAAG;AAC/C,QAAM;AAAA,IAACjC,MAAAA;AAAAA,IAAM8B,SAAAA;AAAAA,EAAAA,IAAWmZ,GAAAA,GAClB;AAAA,IAACS,OAAAA;AAAAA,IAAOM,OAAAA;AAAAA,EAAAA,IAAStS,EAAWqS,EAAgB,GAC5CG,IAASpa,MAAY,cAAc4Z,MAAUM,IAAQ;AAE3D,SACE,gBAAAxc,WACE,MAAK,QAAM,GAAA2C,EAAAC,EAAAxD,KAET7B,EAAOyd,MACPxa,MAAS,OAAOjD,EAAO0d,SAAS1d,EAAO2d,QACvC5Y,MAAY,cAAc/E,EAAO6d,cACjCsB,KAAUnf,EAAO8d,gBAAgB,GAGlC5Y,UAAAA,EAAAA,CACH;AAEJ;AAIO,MAAMma,KAAQ;AAAA,EAAA,MACnBxS;AAAAA,EACAwR,QAAAA;AAAAA,EACAC,MAAAA;AAAAA,EACAO,KAAAA;AAAAA,EACAK,YAAAA;AAAAA,EACAE,MAAAA;AACF,GC7Kapf,IAAM;AAAA,EAAAuI,MAAA;AAAA,IAAApF,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAS,OAAA;AAAA,EAAA;AAAA,EAAAyb,cAAA;AAAA,IAAAlc,QAAA;AAAA,IAAAS,OAAA;AAAA,EAAA;AAAA,EAAA0b,MAAA;AAAA,IAAApc,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA+Z,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA/Z,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA2b,cAAA;AAAA,IAAApc,QAAA;AAAA,IAAA+Z,QAAA;AAAA,IAAAxO,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAvL,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA4b,KAAA;AAAA,IAAAtc,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAW,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAN,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAA4B,QAAA;AAAA,IAAAf,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAA0Z,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAlX,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA9C,OAAA;AAAA,EAAA;AAAA,EAAA6b,aAAA;AAAA,IAAA1b,QAAA;AAAA,IAAAmZ,QAAA;AAAA,IAAAxO,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAhL,OAAA;AAAA,EAAA;AAAA,EAAA8b,qBAAA;AAAA,IAAAnb,QAAA;AAAA,IAAA6Y,QAAA;AAAA,IAAAxZ,OAAA;AAAA,EAAA;AAAA,EAAA+b,mBAAA;AAAA,IAAApb,QAAA;AAAA,IAAAqK,QAAA;AAAA,IAAAhL,OAAA;AAAA,EAAA;AAAA,EAAAgc,aAAA;AAAA,IAAAxY,QAAA;AAAA,IAAAlB,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAic,OAAA;AAAA,IAAA7b,QAAA;AAAA,IAAAJ,OAAA;AAAA,EAAA;AAAA,EAAAkc,eAAA;AAAA,IAAA9b,QAAA;AAAA,IAAA0B,QAAA;AAAA,IAAA9B,OAAA;AAAA,EAAA;AAAA,GCQNmc,KAAcvT,EAAuC,IAAI;AAE/D,SAASwT,KAAU;AACxB,QAAMhT,IAAMN,EAAWqT,EAAW;AAClC,MAAI,CAAC/S,EAAK,OAAM,IAAIO,MAAM,wDAAwD;AAClF,SAAOP;AACT;ACRO,SAASiT,GAAY;AAAA,EAC1Bzf,OAAO0Y;AAAAA,EACPhL,cAAAA;AAAAA,EACAsL,eAAAA;AAAAA,EACArC,aAAAA,IAAc;AACI,GAAqB;AACvC,QAAM,CAAC6D,GAAaC,CAAQ,IAAIhC,GAC9BC,GACAhL,KAAgB,MAChBsL,IACKF,CAAAA,MAAM;AACL,IAAIA,MAAM,QAAME,EAAcF,CAAC;AAAA,EACjC,IACAvU,MACN,GACMmb,IAAUnP,EAAO,oBAAIG,KAAsB,GAC3CC,IAAWJ,EAAiB,EAAE,GAE9BoP,IAAc1W,EAAY,CAACjJ,GAAe2G,OAC9C+Y,EAAQ5O,QAAQS,IAAIvR,GAAO2G,CAAQ,GAC9BgK,EAASG,QAAQmK,SAASjb,CAAK,KAClC2Q,EAASG,QAAQoK,KAAKlb,CAAK,GAEtB,MAAM;AACX0f,IAAAA,EAAQ5O,QAAQqB,OAAOnS,CAAK,GAC5B2Q,EAASG,UAAUH,EAASG,QAAQsB,OAAQ0G,CAAAA,MAAMA,MAAM9Y,CAAK;AAAA,EAC/D,IACC,CAAA,CAAE;AAEL,SAAO;AAAA,IAACwa,aAAAA;AAAAA,IAAaC,UAAAA;AAAAA,IAAU9D,aAAAA;AAAAA,IAAagJ,aAAAA;AAAAA,IAAaD,SAAAA;AAAAA,IAAS/O,UAAAA;AAAAA,EAAAA;AACpE;ACzBA,SAASvE,GAAK;AAAA,EACZ3H,UAAAA;AAAAA,EACAzE,OAAAA;AAAAA,EACA0N,cAAAA;AAAAA,EACAsL,eAAAA;AAAAA,EACArC,aAAAA,IAAc;AACL,GAAG;AACZ,QAAMnK,IAAMiT,GAAY;AAAA,IAACzf,OAAAA;AAAAA,IAAO0N,cAAAA;AAAAA,IAAcsL,eAAAA;AAAAA,IAAerC,aAAAA;AAAAA,EAAAA,CAAY;AAEzE,SACE,gBAAA3U,EAACud,GAAY,UAAZ,EAAqB,OAAO/S,GAC3B,UAAA,gBAAAxK,cAAA2C,EAAAC,EAAAxD,KAAkB7B,EAAOuI,MAAM6O,MAAgB,cAAcpX,EAAOsf,YAAY,GAC7Epa,UAAAA,GACH,GACF;AAEJ;AAQA,SAASmb,GAAK;AAAA,EAACnb,UAAAA;AAAmB,GAAG;AACnC,QAAM;AAAA,IAACkS,aAAAA;AAAAA,IAAa6D,aAAAA;AAAAA,IAAaC,UAAAA;AAAAA,IAAUiF,SAAAA;AAAAA,IAAS/O,UAAAA;AAAAA,EAAAA,IAAY6O,GAAAA,GAC1DK,IAAUtP,EAAuB,IAAI;AAE3CW,SAAAA,EAAU,MAAM;AACd,UAAMiC,IAAK0M,EAAQ/O;AACnB,QAAI,CAACqC,EAAI;AAET,aAASd,EAAiCnJ,GAAkB;AAC1D,YAAMiI,IAAQR,EAASG,SACjBgP,IAAOJ,EAAQ5O;AACrB,UAAIK,EAAMC,WAAW,EAAG;AACxB,YAAM2O,IAAS,MAETC,IAAUrJ,MAAgB,eAAe,cAAc,WACvDsJ,IAAUtJ,MAAgB,eAAe,eAAe;AAE9D,UAAIuJ,IAA6B;AAEjC,cAAQhX,EAAE7G,KAAAA;AAAAA,QACR,KAAK4d,GAAS;AACZ/W,UAAAA,EAAEoJ,eAAAA;AACF,gBAAM6N,IAAa3F,IAAcrJ,EAAMqB,QAAQgI,CAAW,IAAI;AAC9D,mBAAShb,IAAI,GAAGA,KAAK2R,EAAMC,QAAQ5R,KAAK;AACtC,kBAAM+S,KAAO4N,IAAa3gB,KAAK2R,EAAMC,QAC/BkD,IAAMnD,EAAMoB,CAAG;AACrB,gBAAI,CAACuN,EAAKhO,IAAIwC,CAAG,GAAG;AAClB4L,cAAAA,IAAc5L;AACd;AAAA,YACF;AAAA,UACF;AACA;AAAA,QACF;AAAA,QACA,KAAK0L,GAAS;AACZ9W,UAAAA,EAAEoJ,eAAAA;AACF,gBAAM6N,IAAa3F,IAAcrJ,EAAMqB,QAAQgI,CAAW,IAAI;AAC9D,mBAAShb,IAAI,GAAGA,KAAK2R,EAAMC,QAAQ5R,KAAK;AACtC,kBAAM+S,KAAO4N,IAAa3gB,IAAI2R,EAAMC,UAAUD,EAAMC,QAC9CkD,IAAMnD,EAAMoB,CAAG;AACrB,gBAAI,CAACuN,EAAKhO,IAAIwC,CAAG,GAAG;AAClB4L,cAAAA,IAAc5L;AACd;AAAA,YACF;AAAA,UACF;AACA;AAAA,QACF;AAAA,QACA,KAAK,QAAQ;AACXpL,UAAAA,EAAEoJ,eAAAA;AACF,qBAAWgC,KAAOnD;AAChB,gBAAI,CAAC2O,EAAKhO,IAAIwC,CAAG,GAAG;AAClB4L,cAAAA,IAAc5L;AACd;AAAA,YACF;AAEF;AAAA,QACF;AAAA,QACA,KAAK,OAAO;AACVpL,UAAAA,EAAEoJ,eAAAA;AACF,mBAAS9S,IAAI2R,EAAMC,SAAS,GAAG5R,KAAK,GAAGA;AACrC,gBAAI,CAACsgB,EAAKhO,IAAIX,EAAM3R,CAAC,CAAC,GAAG;AACvB0gB,cAAAA,IAAc/O,EAAM3R,CAAC;AACrB;AAAA,YACF;AAEF;AAAA,QACF;AAAA,MAAA;AAGF,MAAI0gB,MACFzF,EAASyF,CAAW,GAENH,EAAOvE,cACnB,oBAAoB0E,CAAW,IACjC,GACOnP,MAAAA;AAAAA,IAEX;AAEAoC,WAAAA,EAAGR,iBAAiB,WAAWN,CAAa,GACrC,MAAMc,EAAGP,oBAAoB,WAAWP,CAAa;AAAA,EAC9D,GAAG,CAACsE,GAAa6D,GAAaC,GAAUiF,GAAS/O,CAAQ,CAAC,qBAGxD,OAAA,EACE,KAAKkP,GACL,MAAK,WACL,oBAAkBlJ,GAAY,GAAAhS,EAAAC,EAAAxD,KACtB7B,EAAOuf,MAAMnI,MAAgB,cAAcpX,EAAOwf,YAAY,GAErEta,UAAAA,GACH;AAEJ;AAUA,SAAS2b,GAAI;AAAA,EAACpgB,OAAAA;AAAAA,EAAO2G,UAAAA,IAAW;AAAA,EAAOlC,UAAAA;AAAkB,GAAG;AAC1D,QAAM;AAAA,IAAC+V,aAAAA;AAAAA,IAAaC,UAAAA;AAAAA,IAAU9D,aAAAA;AAAAA,IAAagJ,aAAAA;AAAAA,EAAAA,IAAeH,GAAAA,GACpD9D,IAAWlB,MAAgBxa,GAC3BqgB,IAAQ9T,EAAAA,GACR+T,IAAU,GAAGD,CAAK;AAExBnP,SAAAA,EAAU,MACDyO,EAAY3f,GAAO2G,CAAQ,GACjC,CAAC3G,GAAO2G,GAAUgZ,CAAW,CAAC,GAS/B,gBAAA3d,EAAA,YACE,MAAK,UACL,MAAK,OACL,IAAIqe,GACJ,iBAAe3E,GACf,iBAAe4E,GACf,iBAAe3Z,KAAYpC,QAC3B,kBAAgBvE,GAChB,UAAU0b,IAAW,IAAI,IACzB,SAhBgBtI,MAAM;AACxB,IAAKzM,KACH8T,EAASza,CAAK;AAAA,EAElB,GAYyB,GAAA2E,EAAAC,EAAAzD,QAEnB5B,EAAOyf,KACPrI,MAAgB,cAAcpX,EAAO0f,aACrCvD,MACG/E,MAAgB,aAAapX,EAAO4f,oBAAoB5f,EAAO2f,sBAClEvY,KAAYpH,EAAO6f,WAAW,GAG/B3a,UAAAA,GACH;AAEJ;AASA,SAAS8b,GAAM;AAAA,EAACvgB,OAAAA;AAAAA,EAAOyE,UAAAA;AAAoB,GAAG;AAC5C,QAAM;AAAA,IAAC+V,aAAAA;AAAAA,IAAa7D,aAAAA;AAAAA,EAAAA,IAAe6I,GAAAA;AAEnC,SAAIhF,MAAgBxa,IAAc,OAGhC,gBAAAgC,EAAA,OAAA,EACE,MAAK,eAAU2C,EAAAC,EAAAxD,KACP7B,EAAO8f,OAAO1I,MAAgB,cAAcpX,EAAO+f,aAAa,GAEvE7a,UAAAA,GACH;AAEJ;AAEO,MAAM+b,KAAO;AAAA,EAAA,MAClBpU;AAAAA,EACAwT,MAAAA;AAAAA,EACAQ,KAAAA;AAAAA,EACAG,OAAAA;AACF,GC5MahhB,KAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAiE,QAAA;AAAA,IAAAlD,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAN,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAY,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAAb,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAA0d,QAAA;AAAA,IAAA9a,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA9C,OAAA;AAAA,EAAA;AAAA,EAAAiC,SAAA;AAAA,IAAAvB,QAAA;AAAA,IAAAV,OAAA;AAAA,EAAA;AAAA,EAAAQ,OAAA;AAAA,IAAAE,QAAA;AAAA,IAAAV,OAAA;AAAA,EAAA;AAAA;ACaZ,SAASsd,GAAS;AAAA,EACvBpc,SAAAA,IAAU;AAAA,EACV/B,MAAAA;AAAAA,EACA8K,aAAAA;AAAAA,EACAC,UAAAA;AAAAA,EACAqT,MAAAA,IAAO;AAAA,EACP3gB,OAAAA;AAAAA,EACA0N,cAAAA;AAAAA,EACA/G,UAAAA;AAAAA,EACA+B,UAAAA;AACa,GAAG;AAChB,QAAM8D,IAAMP,GAAAA;AAEZ,SACE,gBAAAjK,EAAA,cACE,IAAIwK,GAAKE,WACT,MAAAnK,GACA,aAAA8K,GACA,UAAAC,GACA,MAAAqT,GACA,OAAA3gB,GACA,cAAA0N,GACA,UAAA/G,GACA,oBACE6F,IAAM,GAAGA,EAAIG,aAAa,IAAIH,EAAIH,UAAUG,EAAII,UAAU,EAAE,GAAGiB,KAAAA,IAAStJ,QAE1E,gBAAciI,GAAKH,WAAW/H,MAAY,WAAWC,QACrD,UAAAmE,GAAmB,GAAA/D,EAAAC,EAAAjD,UACXpC,GAAOkD,MAAMlD,GAAO+E,CAAO,CAAC,GAAA,KAAA,QAAA;AAG1C;AC/CO,MAAM4E,KAAS;AAAA,EACpB0X,IAAI;AAAA,EACJC,QAAQ;AAAA,EACRC,aAAa;AAAA,EACblH,MAAM;AAAA,EACNmH,WAAW;AAAA,EACXpW,QAAQ;AAAA,EACRqW,aAAa;AAAA,EACbC,gBAAgB;AAAA,EAChBC,QAAQ;AAAA,EACRtd,OAAO;AAAA,EACPud,YAAY;AAAA,EACZC,SAAS;AAAA,EACTC,aAAa;AAAA,EACbC,WAAW;AAAA,EACXC,eAAe;AAAA,EACfvd,SAAS;AAAA,EACTwd,WAAW;AAAA,EACXC,eAAe;AAAA,EACfC,aAAa;AAAA,EACbzd,SAAS;AAAA,EACT0d,WAAW;AAAA,EACXC,eAAe;AAAA,EACfC,aAAa;AAAA,EACb3d,MAAM;AAAA,EACN4d,QAAQ;AAAA,EACRC,YAAY;AAAA,EACZC,UAAU;AAAA,EACVC,kBAAkB;AACpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GCpBMC,KAA0F;AAAA,EAC9FC,OAAO,CAACC,IAAYC,EAAY;AAAA,EAChC,iBAAiB,CAACC,IAAmBC,EAAmB;AAC1D,GAEMhjB,KAAM;AAAA,EAAAuI,MAAA;AAAA,IAAApF,QAAA;AAAA,IAAAU,OAAA;AAAA,EAAA;AAAA;AAUL,SAASof,GAAc;AAAA,EAACC,OAAAA,IAAQ;AAAA,EAAQhe,UAAAA;AAA4B,GAAG;AAC5E,QAAMie,IAAYR,GAASO,CAAK,GAC1BE,IAAc,CAACD,IAAY,CAAC,GAAGA,IAAY,CAAC,GAAGnjB,GAAOuI,IAAI;AAEhE,SAAO,gBAAA9F,EAAA,SAAA,GAAA2C,EAAAC,EAAAxD,KAAiBuhB,CAAW,GAAGle,UAAAA,GAAS;AACjD;AC3BO,MAAMlF,IAAM;AAAA,EAAA8F,SAAA;AAAA,IAAAtB,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAsH,OAAA;AAAA,IAAA3G,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAuH,QAAA;AAAA,IAAA5G,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAQ,OAAA;AAAA,IAAAG,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAY,SAAA;AAAA,IAAAD,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAa,SAAA;AAAA,IAAAF,QAAA;AAAA,IAAAX,OAAA;AAAA,EAAA;AAAA,EAAAwf,cAAA;AAAA,IAAA9d,QAAA;AAAA,IAAA1B,OAAA;AAAA,EAAA;AAAA,EAAAyf,cAAA;AAAA,IAAA/d,QAAA;AAAA,IAAA1B,OAAA;AAAA,EAAA;AAAA,EAAA0f,gBAAA;AAAA,IAAAhe,QAAA;AAAA,IAAA1B,OAAA;AAAA,EAAA;AAAA,EAAA2f,YAAA;AAAA,IAAAje,QAAA;AAAA,IAAA1B,OAAA;AAAA,EAAA;AAAA,EAAAwH,YAAA;AAAA,IAAAvB,QAAA;AAAA,IAAAjG,OAAA;AAAA,EAAA;AAAA,EAAAyH,aAAA;AAAA,IAAAxB,QAAA;AAAA,IAAAjG,OAAA;AAAA,EAAA;AAAA,EAAA0H,UAAA;AAAA,IAAAzB,QAAA;AAAA,IAAAjG,OAAA;AAAA,EAAA;AAAA,EAAA4f,UAAA;AAAA,IAAA3a,QAAA;AAAA,IAAA4a,QAAA;AAAA,IAAAle,QAAA;AAAA,IAAA3B,OAAA;AAAA,EAAA;AAAA,GCcb8f,KAAY;AAAA,EAChBC,QAAQ5jB,EAAOqjB;AAAAA,EACfQ,QAAQ7jB,EAAOsjB;AAAAA,EACfQ,UAAU9jB,EAAOujB;AAAAA,EACjBQ,MAAM/jB,EAAOwjB;AACf,GAEM/X,KAAW;AAAA,EACfC,OAAO1L,EAAOqL;AAAAA,EACdM,QAAQ3L,EAAOsL;AAAAA,EACfM,KAAK5L,EAAOuL;AACd;AAEO,SAASyY,GAAK;AAAA,EACnBjf,SAAAA,IAAU;AAAA,EACVgH,OAAAA,IAAQ;AAAA,EACRkY,QAAAA;AAAAA,EACAjY,OAAAA;AAAAA,EACAyX,UAAAA;AAAAA,EACAS,IAAAA,IAAK;AAAA,EACLhf,UAAAA;AACS,GAAG;AACZ,QAAM9E,IAAQ,CACZ+J,GAAYpF,CAAO,GACnB/E,EAAO+L,CAAK,GACZkY,KAAUN,GAAUM,CAAM,GAC1BjY,KAASP,GAASO,CAAK,GACvByX,KAAYzjB,EAAOyjB,QAAQ;AAG7B,SAAIS,MAAO,MAAY,gBAAAzhB,YAAA2C,EAAAC,EAAAnD,GAAe9B,CAAK,GAAG8E,UAAAA,EAAAA,CAAS,IACnDgf,MAAO,QAAc,gBAAAzhB,cAAA2C,EAAAC,EAAAxD,KAAiBzB,CAAK,GAAG8E,UAAAA,EAAAA,CAAS,IACpD,gBAAAzC,EAAA,UAAA,GAAA2C,EAAAC,EAAAlD,MAAkB/B,CAAK,GAAG8E,UAAAA,GAAS;AAC5C;AC7CO,MAAMlF,KAAM;AAAA,EAAAuI,MAAA;AAAA,IAAAM,QAAA;AAAA,IAAA1F,QAAA;AAAA,IAAAU,OAAA;AAAA,EAAA;AAAA,EAAAqM,OAAA;AAAA,IAAArH,QAAA;AAAA,IAAAoH,QAAA;AAAA,IAAAhM,QAAA;AAAA,IAAAyB,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAtB,QAAA;AAAA,IAAAE,QAAA;AAAA,IAAAc,QAAA;AAAA,IAAA3B,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAJ,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAa,QAAA;AAAA,IAAAoD,QAAA;AAAA,IAAAnC,QAAA;AAAA,IAAA2e,QAAA;AAAA,IAAAtgB,OAAA;AAAA,EAAA;AAAA,EAAAugB,KAAA;AAAA,IAAApU,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAA/H,QAAA;AAAA,IAAAI,QAAA;AAAA,IAAAtE,OAAA;AAAA,EAAA;AAAA,EAAAwgB,QAAA;AAAA,IAAAxU,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAA/H,QAAA;AAAA,IAAAkC,QAAA;AAAA,IAAApG,OAAA;AAAA,EAAA;AAAA,EAAAygB,MAAA;AAAA,IAAAvU,QAAA;AAAA,IAAAF,QAAA;AAAA,IAAA9H,QAAA;AAAA,IAAAwc,QAAA;AAAA,IAAA1gB,OAAA;AAAA,EAAA;AAAA,EAAA2gB,OAAA;AAAA,IAAA1U,QAAA;AAAA,IAAAD,QAAA;AAAA,IAAA9H,QAAA;AAAA,IAAA0c,QAAA;AAAA,IAAA5gB,OAAA;AAAA,EAAA;AAAA,GCkBb6gB,KAAiBjY,EAA0C,IAAI;AAErE,SAASkY,KAAa;AACpB,QAAM1X,IAAMN,EAAW+X,EAAc;AACrC,MAAI,CAACzX,EAAK,OAAM,IAAIO,MAAM,8DAA8D;AACxF,SAAOP;AACT;AAWA,SAASJ,GAAK;AAAA,EAAC3H,UAAAA;AAAAA,EAAUhB,SAAAA;AAAAA,EAAS0gB,WAAAA,IAAY;AAAA,EAAOC,OAAAA,IAAQ;AAAc,GAAG;AAC5E,QAAM,CAACnU,GAAMC,CAAO,IAAIpH,EAAS,EAAK,GAChCub,IAAY9X,EAAAA,GACZ+X,IAAW/T,EAA6C,IAAI,GAE5DgU,IAAOtb,EAAY,MAAM;AAC7B,IAAIqb,EAASxT,WAASmF,aAAaqO,EAASxT,OAAO,GACnDwT,EAASxT,UAAUoF,WAAW,MAAMhG,EAAQ,EAAI,GAAGkU,CAAK;AAAA,EAC1D,GAAG,CAACA,CAAK,CAAC,GAEJI,IAAOvb,EAAY,MAAM;AAC7B,IAAIqb,EAASxT,WAASmF,aAAaqO,EAASxT,OAAO,GACnDwT,EAASxT,UAAU,MACnBZ,EAAQ,EAAK;AAAA,EACf,GAAG,CAAA,CAAE;AAEL,SACE,gBAAAlO,EAACiiB,GAAe,UAAf,EAAwB,OAAO;AAAA,IAAChU,MAAAA;AAAAA,IAAMsU,MAAAA;AAAAA,IAAMC,MAAAA;AAAAA,IAAMH,WAAAA;AAAAA,IAAWF,WAAAA;AAAAA,EAAAA,GAC5D,4BAAA,OAAA,EAAA,GAAAxf,EAAAC,EAAAxD,KAAiB7B,GAAOuI,IAAI,GACzBrD,UAAAA;AAAAA,IAAAA;AAAAA,IACAwL,KACC,gBAAAjO,EAAA,OAAA,EAAU,IAAIqiB,GAAW,MAAK,WAAS,GAAA1f,EAAAC,EAAAxD,KAAS7B,GAAOkQ,OAAOlQ,GAAO4kB,CAAS,CAAC,GAC5E1gB,UAAAA,EAAAA,CACH;AAAA,EAAA,EAAA,CAEJ,EAAA,CACF;AAEJ;AAQA,SAASoP,GAAQ;AAAA,EAACpO,UAAAA;AAAsB,GAAG;AACzC,QAAM;AAAA,IAACwL,MAAAA;AAAAA,IAAMsU,MAAAA;AAAAA,IAAMC,MAAAA;AAAAA,IAAMH,WAAAA;AAAAA,EAAAA,IAAaH,GAAAA;AAEtC,oCAEI,gBAAgBK,GAChB,gBAAgBC,GAChB,SAASD,GACT,QAAQC,GACR,oBAAkBvU,IAAOoU,IAAY9f,QAAU,GAAAI,EAAAC,EAAAxD,GAAA,GAE9CqD,UAAAA,GACH;AAEJ;AAEO,MAAMggB,KAAU;AAAA,EACrBrY,MAAAA;AAAAA,EACAyG,SAAAA;AACF,GC7FatT,IAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAS,OAAA;AAAA,EAAA;AAAA,EAAAwH,YAAA;AAAA,IAAAhI,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAAyH,aAAA;AAAA,IAAAjI,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAA0H,UAAA;AAAA,IAAAlI,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAAshB,cAAA;AAAA,IAAA9hB,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAAuhB,OAAA;AAAA,IAAA9hB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAAwhB,OAAA;AAAA,IAAA/hB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAAyhB,OAAA;AAAA,IAAAhiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA0hB,OAAA;AAAA,IAAAjiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA2hB,OAAA;AAAA,IAAAliB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA4hB,OAAA;AAAA,IAAAniB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA6hB,QAAA;AAAA,IAAApiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA8hB,SAAA;AAAA,IAAAriB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,GCSb+hB,KAAS;AAAA,EACbC,IAAI7lB,EAAOolB;AAAAA,EACXpf,IAAIhG,EAAOqlB;AAAAA,EACXS,IAAI9lB,EAAOslB;AAAAA,EACXrf,IAAIjG,EAAOulB;AAAAA,EACX5I,IAAI3c,EAAOwlB;AAAAA,EACXO,IAAI/lB,EAAOylB;AAAAA,EACXO,KAAKhmB,EAAO0lB;AAAAA,EACZO,MAAMjmB,EAAO2lB;AACf,GAEMla,KAAW;AAAA,EACfC,OAAO1L,EAAOqL;AAAAA,EACdM,QAAQ3L,EAAOsL;AAAAA,EACfM,KAAK5L,EAAOuL;AAAAA,EACZ2a,SAASlmB,EAAOmlB;AAClB;AAEO,SAASgB,GAAM;AAAA,EAACC,KAAAA,IAAM;AAAA,EAAMpa,OAAAA,IAAQ;AAAA,EAAW9G,UAAAA;AAAoB,GAAG;AAC3E,SAAO,gBAAAzC,EAAA,OAAA,EAAA,GAAA2C,EAAAC,EAAAxD,KAAkB7B,EAAOkD,MAAM0iB,GAAOQ,CAAG,GAAG3a,GAASO,CAAK,CAAC,GAAI9G,UAAAA,GAAS;AACjF;AC7BO,MAAMlF,IAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAijB,QAAA;AAAA,IAAAxiB,OAAA;AAAA,EAAA;AAAA,EAAAwH,YAAA;AAAA,IAAAhI,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAAyH,aAAA;AAAA,IAAAjI,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAA0H,UAAA;AAAA,IAAAlI,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAAyiB,eAAA;AAAA,IAAAjjB,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAAshB,cAAA;AAAA,IAAA9hB,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAA0iB,cAAA;AAAA,IAAAviB,QAAA;AAAA,IAAAH,OAAA;AAAA,EAAA;AAAA,EAAA2iB,eAAA;AAAA,IAAAxiB,QAAA;AAAA,IAAAH,OAAA;AAAA,EAAA;AAAA,EAAA4iB,YAAA;AAAA,IAAAziB,QAAA;AAAA,IAAAH,OAAA;AAAA,EAAA;AAAA,EAAA6iB,gBAAA;AAAA,IAAA1iB,QAAA;AAAA,IAAAH,OAAA;AAAA,EAAA;AAAA,EAAAuhB,OAAA;AAAA,IAAA9hB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAAwhB,OAAA;AAAA,IAAA/hB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAAyhB,OAAA;AAAA,IAAAhiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA0hB,OAAA;AAAA,IAAAjiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA2hB,OAAA;AAAA,IAAAliB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA4hB,OAAA;AAAA,IAAAniB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA6hB,QAAA;AAAA,IAAApiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA8hB,SAAA;AAAA,IAAAriB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,GCSb+hB,KAAS;AAAA,EACbC,IAAI7lB,EAAOolB;AAAAA,EACXpf,IAAIhG,EAAOqlB;AAAAA,EACXS,IAAI9lB,EAAOslB;AAAAA,EACXrf,IAAIjG,EAAOulB;AAAAA,EACX5I,IAAI3c,EAAOwlB;AAAAA,EACXO,IAAI/lB,EAAOylB;AAAAA,EACXO,KAAKhmB,EAAO0lB;AAAAA,EACZO,MAAMjmB,EAAO2lB;AACf,GAEMla,KAAW;AAAA,EACfC,OAAO1L,EAAOqL;AAAAA,EACdM,QAAQ3L,EAAOsL;AAAAA,EACfM,KAAK5L,EAAOuL;AAAAA,EACZob,UAAU3mB,EAAOsmB;AAAAA,EACjBJ,SAASlmB,EAAOmlB;AAClB,GAEMyB,KAAa;AAAA,EACjBlb,OAAO1L,EAAOumB;AAAAA,EACd5a,QAAQ3L,EAAOwmB;AAAAA,EACf5a,KAAK5L,EAAOymB;AAAAA,EACZI,SAAS7mB,EAAO0mB;AAClB;AAEO,SAASI,GAAO;AAAA,EAACV,KAAAA,IAAM;AAAA,EAAMpa,OAAAA,IAAQ;AAAA,EAAU+a,SAAAA,IAAU;AAAA,EAAS7hB,UAAAA;AAAqB,GAAG;AAC/F,2BACE,OAAA,EAAA,GAAAE,EAAAC,EAAAxD,KAAkB7B,EAAOkD,MAAM0iB,GAAOQ,CAAG,GAAG3a,GAASO,CAAK,GAAG4a,GAAWG,CAAO,CAAC,GAC7E7hB,UAAAA,GACH;AAEJ;ACzCO,MAAMlF,IAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAC,QAAA;AAAA,IAAAC,QAAA;AAAA,IAAAijB,QAAA;AAAA,IAAAxiB,OAAA;AAAA,EAAA;AAAA,EAAAwH,YAAA;AAAA,IAAAhI,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAAyH,aAAA;AAAA,IAAAjI,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAA0H,UAAA;AAAA,IAAAlI,QAAA;AAAA,IAAAQ,OAAA;AAAA,EAAA;AAAA,EAAA0iB,cAAA;AAAA,IAAAviB,QAAA;AAAA,IAAAH,OAAA;AAAA,EAAA;AAAA,EAAA2iB,eAAA;AAAA,IAAAxiB,QAAA;AAAA,IAAAH,OAAA;AAAA,EAAA;AAAA,EAAA4iB,YAAA;AAAA,IAAAziB,QAAA;AAAA,IAAAH,OAAA;AAAA,EAAA;AAAA,EAAA6iB,gBAAA;AAAA,IAAA1iB,QAAA;AAAA,IAAAH,OAAA;AAAA,EAAA;AAAA,EAAAuhB,OAAA;AAAA,IAAA9hB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAAwhB,OAAA;AAAA,IAAA/hB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAAyhB,OAAA;AAAA,IAAAhiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA0hB,OAAA;AAAA,IAAAjiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA2hB,OAAA;AAAA,IAAAliB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA4hB,OAAA;AAAA,IAAAniB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA6hB,QAAA;AAAA,IAAApiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA8hB,SAAA;AAAA,IAAAriB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,GCSb+hB,KAAS;AAAA,EACbC,IAAI7lB,EAAOolB;AAAAA,EACXpf,IAAIhG,EAAOqlB;AAAAA,EACXS,IAAI9lB,EAAOslB;AAAAA,EACXrf,IAAIjG,EAAOulB;AAAAA,EACX5I,IAAI3c,EAAOwlB;AAAAA,EACXO,IAAI/lB,EAAOylB;AAAAA,EACXO,KAAKhmB,EAAO0lB;AAAAA,EACZO,MAAMjmB,EAAO2lB;AACf,GAEMla,KAAW;AAAA,EACfC,OAAO1L,EAAOqL;AAAAA,EACdM,QAAQ3L,EAAOsL;AAAAA,EACfM,KAAK5L,EAAOuL;AACd,GAEMqb,KAAa;AAAA,EACjBlb,OAAO1L,EAAOumB;AAAAA,EACd5a,QAAQ3L,EAAOwmB;AAAAA,EACf5a,KAAK5L,EAAOymB;AAAAA,EACZI,SAAS7mB,EAAO0mB;AAClB;AAEO,SAASM,GAAQ;AAAA,EAACZ,KAAAA,IAAM;AAAA,EAAMpa,OAAAA,IAAQ;AAAA,EAAS+a,SAAAA,IAAU;AAAA,EAAS7hB,UAAAA;AAAsB,GAAG;AAChG,2BACE,OAAA,EAAA,GAAAE,EAAAC,EAAAxD,KAAkB7B,EAAOkD,MAAM0iB,GAAOQ,CAAG,GAAG3a,GAASO,CAAK,GAAG4a,GAAWG,CAAO,CAAC,GAC7E7hB,UAAAA,GACH;AAEJ;ACzC2D,MAAA8X,KAAA;AAAA,EAAAC,QAAA;AAAA,EAAA,OAAA;AAAA,GAE9Cjd,IAAM;AAAA,EAAAkD,MAAA;AAAA,IAAAC,QAAA;AAAA,IAAAU,OAAA;AAAA,EAAA;AAAA,EAAAojB,MAAA;AAAA,IAAAhK,QAAA;AAAA,IAAApZ,OAAA;AAAA,EAAA;AAAA,EAAAqjB,MAAA;AAAA,IAAAjK,QAAA;AAAA,IAAApZ,OAAA;AAAA,EAAA;AAAA,EAAAsjB,MAAA;AAAA,IAAAlK,QAAA;AAAA,IAAApZ,OAAA;AAAA,EAAA;AAAA,EAAAujB,MAAA;AAAA,IAAAnK,QAAA;AAAA,IAAApZ,OAAA;AAAA,EAAA;AAAA,EAAAwjB,MAAA;AAAA,IAAApK,QAAA;AAAA,IAAApZ,OAAA;AAAA,EAAA;AAAA,EAAAyjB,MAAA;AAAA,IAAArK,QAAA;AAAA,IAAApZ,OAAA;AAAA,EAAA;AAAA,EAAA0jB,SAAAA,CAUPC,OAAgBxK,IAAA;AAAA,IAAA,2BACH,2BAA2BwK,CAAQ,oBAAnC,2BAA2BA,CAAQ,YAASxiB;AAAAA,EAAAA,CAAA;AAAA,EAAAogB,OAAA;AAAA,IAAA9hB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAAwhB,OAAA;AAAA,IAAA/hB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAAyhB,OAAA;AAAA,IAAAhiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA0hB,OAAA;AAAA,IAAAjiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA2hB,OAAA;AAAA,IAAAliB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA4hB,OAAA;AAAA,IAAAniB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA6hB,QAAA;AAAA,IAAApiB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,EAAA8hB,SAAA;AAAA,IAAAriB,QAAA;AAAA,IAAAO,OAAA;AAAA,EAAA;AAAA,GCF/D+hB,KAAS;AAAA,EACbC,IAAI7lB,EAAOolB;AAAAA,EACXpf,IAAIhG,EAAOqlB;AAAAA,EACXS,IAAI9lB,EAAOslB;AAAAA,EACXrf,IAAIjG,EAAOulB;AAAAA,EACX5I,IAAI3c,EAAOwlB;AAAAA,EACXO,IAAI/lB,EAAOylB;AAAAA,EACXO,KAAKhmB,EAAO0lB;AAAAA,EACZO,MAAMjmB,EAAO2lB;AACf,GAEM8B,KAAa;AAAA,EACjB,GAAGznB,EAAOinB;AAAAA,EACV,GAAGjnB,EAAOknB;AAAAA,EACV,GAAGlnB,EAAOmnB;AAAAA,EACV,GAAGnnB,EAAOonB;AAAAA,EACV,GAAGpnB,EAAOqnB;AAAAA,EACV,GAAGrnB,EAAOsnB;AACZ;AAEO,SAASI,GAAK;AAAA,EAACtB,KAAAA,IAAM;AAAA,EAAMpI,SAAAA;AAAAA,EAAS2J,gBAAAA;AAAAA,EAAgBziB,UAAAA;AAAmB,GAAG;AAC/E,QAAM0iB,IAAcD,IAChB3nB,EAAOunB,QAAQI,CAAc,IAC7B3J,IACEyJ,GAAWzJ,CAAO,IAClBhZ;AAEN,SAAO,gBAAAvC,EAAA,OAAA,EAAA,GAAA2C,EAAAC,EAAAxD,KAAkB7B,EAAOkD,MAAM0iB,GAAOQ,CAAG,GAAGwB,CAAW,GAAI1iB,UAAAA,EAAAA,CAAS;AAC7E;AC/BO,SAAS2iB,GACdtoB,IAAoC,IAIpC;AACA,QAAM;AAAA,IAACuoB,cAAAA,IAAe;AAAA,IAAKC,eAAAA,IAAgB;AAAA,EAAA,IAAOxoB,GAC5CmU,IAAM1C,EAAiB,IAAI,GAC3B,CAAC/N,GAAM+kB,CAAO,IAAIze,EAAwB,SAAS;AAEzDoI,SAAAA,EAAU,MAAM;AACd,UAAMI,IAAU2B,EAAInC;AACpB,QAAI,CAACQ,EAAS;AAEd,QAAIkW,IAAuB;AAE3B,UAAMrR,IAAW,IAAIC,eAAgBqR,CAAAA,MAAY;AAC/C,MAAID,MAAU,QAAME,qBAAqBF,CAAK,GAE9CA,IAAQG,sBAAsB,MAAM;AAClC,cAAMC,IAAQH,EAAQ,CAAC;AACvB,YAAI,CAACG,EAAO;AAEZ,cAAMlT,IAAQkT,EAAMC,iBAAiB,CAAC,GAAGC,cAAcF,EAAMG,YAAYrT;AAEzE,QAAIA,IAAQ2S,IACVE,EAAQ,SAAS,IACR7S,KAAS4S,IAClBC,EAAQ,UAAU,IAElBA,EAAQ,SAAS;AAAA,MAErB,CAAC;AAAA,IACH,CAAC;AAEDpR,WAAAA,EAASE,QAAQ/E,CAAO,GAEjB,MAAM;AACX6E,MAAAA,EAASG,WAAAA,GACLkR,MAAU,QAAME,qBAAqBF,CAAK;AAAA,IAChD;AAAA,EACF,GAAG,CAACH,GAAcC,CAAa,CAAC,GAEzB;AAAA,IAACrU,KAAAA;AAAAA,IAAKzQ,MAAAA;AAAAA,EAAAA;AACf;","x_google_ignoreList":[0]}
|