eglador-ui-react 0.1.0-alpha.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/components/accordion/accordion.tsx","../node_modules/clsx/dist/clsx.mjs","../node_modules/tailwind-merge/src/lib/utils.ts","../node_modules/tailwind-merge/src/lib/class-group-utils.ts","../node_modules/tailwind-merge/src/lib/lru-cache.ts","../node_modules/tailwind-merge/src/lib/parse-class-name.ts","../node_modules/tailwind-merge/src/lib/sort-modifiers.ts","../node_modules/tailwind-merge/src/lib/config-utils.ts","../node_modules/tailwind-merge/src/lib/merge-classlist.ts","../node_modules/tailwind-merge/src/lib/tw-join.ts","../node_modules/tailwind-merge/src/lib/create-tailwind-merge.ts","../node_modules/tailwind-merge/src/lib/from-theme.ts","../node_modules/tailwind-merge/src/lib/validators.ts","../node_modules/tailwind-merge/src/lib/default-config.ts","../node_modules/tailwind-merge/src/lib/merge-configs.ts","../node_modules/tailwind-merge/src/lib/extend-tailwind-merge.ts","../node_modules/tailwind-merge/src/lib/tw-merge.ts","../src/lib/utils.ts","../src/components/alert/alert.tsx","../src/components/badge/badge.tsx","../src/components/breadcrumb/breadcrumb.tsx","../src/components/button/button.tsx","../src/components/carousel/carousel.tsx","../src/components/button-group/button-group.tsx","../src/components/checkbox/checkbox.tsx","../src/components/drawer/drawer.tsx","../src/components/checkbox-group/checkbox-group.tsx","../src/components/dropdown/dropdown.tsx","../src/components/input/input.tsx","../src/components/input-group/input-group.tsx","../src/components/link/link.tsx","../src/components/media-image/media-image.tsx","../src/components/media-video/media-video.tsx","../src/components/modal/modal.tsx","../src/components/multi-select/multi-select.tsx","../src/components/notification/notification.tsx","../src/components/radio/radio.tsx","../src/components/radio-group/radio-group.tsx","../src/components/select/select.tsx","../src/components/switch/switch.tsx","../src/components/table/table.tsx","../src/components/tabs/tabs.tsx","../src/components/tooltip/tooltip.tsx","../src/components/typewriter/typewriter.tsx"],"sourcesContent":["export * from \"./components/accordion\";\nexport * from \"./components/alert\";\nexport * from \"./components/badge\";\nexport * from \"./components/breadcrumb\";\nexport * from \"./components/button\";\nexport * from \"./components/carousel\";\nexport * from \"./components/button-group\";\nexport * from \"./components/checkbox\";\nexport * from \"./components/drawer\";\nexport * from \"./components/checkbox-group\";\nexport * from \"./components/dropdown\";\nexport * from \"./components/input\";\nexport * from \"./components/input-group\";\nexport * from \"./components/link\";\nexport * from \"./components/media-image\";\nexport * from \"./components/media-video\";\nexport * from \"./components/modal\";\nexport * from \"./components/multi-select\";\nexport * from \"./components/notification\";\nexport * from \"./components/radio\";\nexport * from \"./components/radio-group\";\nexport * from \"./components/select\";\nexport * from \"./components/switch\";\nexport * from \"./components/table\";\nexport * from \"./components/tabs\";\nexport * from \"./components/tooltip\";\nexport * from \"./components/typewriter\";\nexport * from \"./lib/utils\";\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type AccordionVariant = \"default\" | \"bordered\" | \"filled\";\nexport type AccordionSize = \"xs\" | \"sm\" | \"md\";\n\nexport interface AccordionProps {\n title: React.ReactNode;\n icon?: React.ReactNode;\n extra?: React.ReactNode;\n defaultOpen?: boolean;\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n variant?: AccordionVariant;\n size?: AccordionSize;\n disabled?: boolean;\n hideChevron?: boolean;\n children: React.ReactNode;\n className?: string;\n}\n\n// ── ChevronDown Icon ─────────────────────────\n\nfunction ChevronDownIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<AccordionSize, {\n trigger: string;\n triggerCompact: string;\n gap: string;\n font: string;\n chevronSize: string;\n contentPadding: string;\n}> = {\n xs: { trigger: \"px-2 py-1.5\", triggerCompact: \"px-1 py-0.5\", gap: \"gap-1\", font: \"text-xs\", chevronSize: \"size-4\", contentPadding: \"px-2 pb-2\" },\n sm: { trigger: \"px-3 py-2\", triggerCompact: \"px-1 py-0.5\", gap: \"gap-1.5\", font: \"text-sm\", chevronSize: \"size-5\", contentPadding: \"px-3 pb-3\" },\n md: { trigger: \"px-4 py-3\", triggerCompact: \"px-1 py-0.5\", gap: \"gap-2\", font: \"text-base\", chevronSize: \"size-6\", contentPadding: \"px-4 pb-4\" },\n};\n\n// ── Component ────────────────────────────────\n\nexport function Accordion({\n title,\n icon,\n extra,\n defaultOpen = true,\n open,\n onOpenChange,\n variant = \"default\",\n size = \"sm\",\n disabled = false,\n hideChevron = false,\n children,\n className,\n}: AccordionProps) {\n const [internalOpen, setInternalOpen] = React.useState(defaultOpen);\n const id = React.useId();\n const s = SIZES[size];\n\n const isControlled = open !== undefined;\n const isOpen = isControlled ? open : internalOpen;\n\n const toggle = () => {\n if (disabled) return;\n const next = !isOpen;\n if (!isControlled) setInternalOpen(next);\n onOpenChange?.(next);\n };\n\n const isBoxed = variant === \"bordered\" || variant === \"filled\";\n\n return (\n <div\n className={cn(\n \"flex flex-col\",\n variant === \"bordered\" && \"border border-zinc-200 rounded-lg\",\n variant === \"filled\" && \"bg-zinc-50 rounded-lg\",\n disabled && \"opacity-50\",\n className,\n )}\n >\n <button\n type=\"button\"\n aria-expanded={isOpen}\n aria-controls={id}\n disabled={disabled}\n onClick={toggle}\n className={cn(\n \"flex items-center w-full text-left group transition-colors\",\n s.gap,\n !disabled && \"cursor-pointer\",\n isBoxed ? s.trigger : s.triggerCompact,\n !disabled && isBoxed && \"hover:bg-zinc-100/50 rounded-lg\",\n )}\n >\n {icon && (\n <span className=\"shrink-0 text-zinc-400\">\n {icon}\n </span>\n )}\n <span className={cn(\n \"flex-1 font-bold text-zinc-400 uppercase tracking-wider\",\n s.font,\n )}>\n {title}\n </span>\n {extra && <span className=\"shrink-0\">{extra}</span>}\n {!hideChevron && (\n <ChevronDownIcon\n className={cn(\n \"shrink-0 text-zinc-400 transition-transform duration-200\",\n s.chevronSize,\n isOpen ? \"rotate-0\" : \"-rotate-90\",\n )}\n />\n )}\n </button>\n\n <div\n id={id}\n className={cn(\n \"grid transition-all duration-200 ease-in-out\",\n isOpen ? \"grid-rows-[1fr] opacity-100 mt-2\" : \"grid-rows-[0fr] opacity-0 mt-0\",\n )}\n >\n <div className={cn(\n isOpen ? \"overflow-visible\" : \"overflow-hidden\",\n isBoxed && s.contentPadding,\n )}>\n {children}\n </div>\n </div>\n </div>\n );\n}\n","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","/**\n * Concatenates two arrays faster than the array spread operator.\n */\nexport const concatArrays = <T, U>(\n array1: readonly T[],\n array2: readonly U[],\n): readonly (T | U)[] => {\n // Pre-allocate for better V8 optimization\n const combinedArray: (T | U)[] = new Array(array1.length + array2.length)\n for (let i = 0; i < array1.length; i++) {\n combinedArray[i] = array1[i]!\n }\n for (let i = 0; i < array2.length; i++) {\n combinedArray[array1.length + i] = array2[i]!\n }\n return combinedArray\n}\n","import {\n AnyClassGroupIds,\n AnyConfig,\n AnyThemeGroupIds,\n ClassGroup,\n ClassValidator,\n Config,\n ThemeGetter,\n ThemeObject,\n} from './types'\nimport { concatArrays } from './utils'\n\nexport interface ClassPartObject {\n nextPart: Map<string, ClassPartObject>\n validators: ClassValidatorObject[] | null\n classGroupId: AnyClassGroupIds | undefined // Always define optional props for consistent shape\n}\n\ninterface ClassValidatorObject {\n classGroupId: AnyClassGroupIds\n validator: ClassValidator\n}\n\n// Factory function ensures consistent object shapes\nconst createClassValidatorObject = (\n classGroupId: AnyClassGroupIds,\n validator: ClassValidator,\n): ClassValidatorObject => ({\n classGroupId,\n validator,\n})\n\n// Factory ensures consistent ClassPartObject shape\nconst createClassPartObject = (\n nextPart: Map<string, ClassPartObject> = new Map(),\n validators: ClassValidatorObject[] | null = null,\n classGroupId?: AnyClassGroupIds,\n): ClassPartObject => ({\n nextPart,\n validators,\n classGroupId,\n})\n\nconst CLASS_PART_SEPARATOR = '-'\n\nconst EMPTY_CONFLICTS: readonly AnyClassGroupIds[] = []\n// I use two dots here because one dot is used as prefix for class groups in plugins\nconst ARBITRARY_PROPERTY_PREFIX = 'arbitrary..'\n\nexport const createClassGroupUtils = (config: AnyConfig) => {\n const classMap = createClassMap(config)\n const { conflictingClassGroups, conflictingClassGroupModifiers } = config\n\n const getClassGroupId = (className: string) => {\n if (className.startsWith('[') && className.endsWith(']')) {\n return getGroupIdForArbitraryProperty(className)\n }\n\n const classParts = className.split(CLASS_PART_SEPARATOR)\n // Classes like `-inset-1` produce an empty string as first classPart. We assume that classes for negative values are used correctly and skip it.\n const startIndex = classParts[0] === '' && classParts.length > 1 ? 1 : 0\n return getGroupRecursive(classParts, startIndex, classMap)\n }\n\n const getConflictingClassGroupIds = (\n classGroupId: AnyClassGroupIds,\n hasPostfixModifier: boolean,\n ): readonly AnyClassGroupIds[] => {\n if (hasPostfixModifier) {\n const modifierConflicts = conflictingClassGroupModifiers[classGroupId]\n const baseConflicts = conflictingClassGroups[classGroupId]\n\n if (modifierConflicts) {\n if (baseConflicts) {\n // Merge base conflicts with modifier conflicts\n return concatArrays(baseConflicts, modifierConflicts)\n }\n // Only modifier conflicts\n return modifierConflicts\n }\n // Fall back to without postfix if no modifier conflicts\n return baseConflicts || EMPTY_CONFLICTS\n }\n\n return conflictingClassGroups[classGroupId] || EMPTY_CONFLICTS\n }\n\n return {\n getClassGroupId,\n getConflictingClassGroupIds,\n }\n}\n\nconst getGroupRecursive = (\n classParts: string[],\n startIndex: number,\n classPartObject: ClassPartObject,\n): AnyClassGroupIds | undefined => {\n const classPathsLength = classParts.length - startIndex\n if (classPathsLength === 0) {\n return classPartObject.classGroupId\n }\n\n const currentClassPart = classParts[startIndex]!\n const nextClassPartObject = classPartObject.nextPart.get(currentClassPart)\n\n if (nextClassPartObject) {\n const result = getGroupRecursive(classParts, startIndex + 1, nextClassPartObject)\n if (result) return result\n }\n\n const validators = classPartObject.validators\n if (validators === null) {\n return undefined\n }\n\n // Build classRest string efficiently by joining from startIndex onwards\n const classRest =\n startIndex === 0\n ? classParts.join(CLASS_PART_SEPARATOR)\n : classParts.slice(startIndex).join(CLASS_PART_SEPARATOR)\n const validatorsLength = validators.length\n\n for (let i = 0; i < validatorsLength; i++) {\n const validatorObj = validators[i]!\n if (validatorObj.validator(classRest)) {\n return validatorObj.classGroupId\n }\n }\n\n return undefined\n}\n\n/**\n * Get the class group ID for an arbitrary property.\n *\n * @param className - The class name to get the group ID for. Is expected to be string starting with `[` and ending with `]`.\n */\nconst getGroupIdForArbitraryProperty = (className: string): AnyClassGroupIds | undefined =>\n className.slice(1, -1).indexOf(':') === -1\n ? undefined\n : (() => {\n const content = className.slice(1, -1)\n const colonIndex = content.indexOf(':')\n const property = content.slice(0, colonIndex)\n return property ? ARBITRARY_PROPERTY_PREFIX + property : undefined\n })()\n\n/**\n * Exported for testing only\n */\nexport const createClassMap = (config: Config<AnyClassGroupIds, AnyThemeGroupIds>) => {\n const { theme, classGroups } = config\n return processClassGroups(classGroups, theme)\n}\n\n// Split into separate functions to maintain monomorphic call sites\nconst processClassGroups = (\n classGroups: Record<AnyClassGroupIds, ClassGroup<AnyThemeGroupIds>>,\n theme: ThemeObject<AnyThemeGroupIds>,\n): ClassPartObject => {\n const classMap = createClassPartObject()\n\n for (const classGroupId in classGroups) {\n const group = classGroups[classGroupId]!\n processClassesRecursively(group, classMap, classGroupId, theme)\n }\n\n return classMap\n}\n\nconst processClassesRecursively = (\n classGroup: ClassGroup<AnyThemeGroupIds>,\n classPartObject: ClassPartObject,\n classGroupId: AnyClassGroupIds,\n theme: ThemeObject<AnyThemeGroupIds>,\n) => {\n const len = classGroup.length\n for (let i = 0; i < len; i++) {\n const classDefinition = classGroup[i]!\n processClassDefinition(classDefinition, classPartObject, classGroupId, theme)\n }\n}\n\n// Split into separate functions for each type to maintain monomorphic call sites\nconst processClassDefinition = (\n classDefinition: ClassGroup<AnyThemeGroupIds>[number],\n classPartObject: ClassPartObject,\n classGroupId: AnyClassGroupIds,\n theme: ThemeObject<AnyThemeGroupIds>,\n) => {\n if (typeof classDefinition === 'string') {\n processStringDefinition(classDefinition, classPartObject, classGroupId)\n return\n }\n\n if (typeof classDefinition === 'function') {\n processFunctionDefinition(classDefinition, classPartObject, classGroupId, theme)\n return\n }\n\n processObjectDefinition(\n classDefinition as Record<string, ClassGroup<AnyThemeGroupIds>>,\n classPartObject,\n classGroupId,\n theme,\n )\n}\n\nconst processStringDefinition = (\n classDefinition: string,\n classPartObject: ClassPartObject,\n classGroupId: AnyClassGroupIds,\n) => {\n const classPartObjectToEdit =\n classDefinition === '' ? classPartObject : getPart(classPartObject, classDefinition)\n classPartObjectToEdit.classGroupId = classGroupId\n}\n\nconst processFunctionDefinition = (\n classDefinition: Function,\n classPartObject: ClassPartObject,\n classGroupId: AnyClassGroupIds,\n theme: ThemeObject<AnyThemeGroupIds>,\n) => {\n if (isThemeGetter(classDefinition)) {\n processClassesRecursively(classDefinition(theme), classPartObject, classGroupId, theme)\n return\n }\n\n if (classPartObject.validators === null) {\n classPartObject.validators = []\n }\n classPartObject.validators.push(\n createClassValidatorObject(classGroupId, classDefinition as ClassValidator),\n )\n}\n\nconst processObjectDefinition = (\n classDefinition: Record<string, ClassGroup<AnyThemeGroupIds>>,\n classPartObject: ClassPartObject,\n classGroupId: AnyClassGroupIds,\n theme: ThemeObject<AnyThemeGroupIds>,\n) => {\n const entries = Object.entries(classDefinition)\n const len = entries.length\n for (let i = 0; i < len; i++) {\n const [key, value] = entries[i]!\n processClassesRecursively(value, getPart(classPartObject, key), classGroupId, theme)\n }\n}\n\nconst getPart = (classPartObject: ClassPartObject, path: string): ClassPartObject => {\n let current = classPartObject\n const parts = path.split(CLASS_PART_SEPARATOR)\n const len = parts.length\n\n for (let i = 0; i < len; i++) {\n const part = parts[i]!\n\n let next = current.nextPart.get(part)\n if (!next) {\n next = createClassPartObject()\n current.nextPart.set(part, next)\n }\n current = next\n }\n\n return current\n}\n\n// Type guard maintains monomorphic check\nconst isThemeGetter = (func: Function): func is ThemeGetter =>\n 'isThemeGetter' in func && (func as ThemeGetter).isThemeGetter === true\n","// Export is needed because TypeScript complains about an error otherwise:\n// Error: …/tailwind-merge/src/config-utils.ts(8,17): semantic error TS4058: Return type of exported function has or is using name 'LruCache' from external module \"…/tailwind-merge/src/lru-cache\" but cannot be named.\nexport interface LruCache<Key extends string, Value> {\n get(key: Key): Value | undefined\n set(key: Key, value: Value): void\n}\n\n// LRU cache implementation using plain objects for simplicity\nexport const createLruCache = <Key extends string, Value>(\n maxCacheSize: number,\n): LruCache<Key, Value> => {\n if (maxCacheSize < 1) {\n return {\n get: () => undefined,\n set: () => {},\n }\n }\n\n let cacheSize = 0\n let cache: Record<Key, Value> = Object.create(null)\n let previousCache: Record<Key, Value> = Object.create(null)\n\n const update = (key: Key, value: Value) => {\n cache[key] = value\n cacheSize++\n\n if (cacheSize > maxCacheSize) {\n cacheSize = 0\n previousCache = cache\n cache = Object.create(null)\n }\n }\n\n return {\n get(key) {\n let value = cache[key]\n\n if (value !== undefined) {\n return value\n }\n if ((value = previousCache[key]) !== undefined) {\n update(key, value)\n return value\n }\n },\n set(key, value) {\n if (key in cache) {\n cache[key] = value\n } else {\n update(key, value)\n }\n },\n }\n}\n","import { AnyConfig, ParsedClassName } from './types'\n\nexport const IMPORTANT_MODIFIER = '!'\n\nconst MODIFIER_SEPARATOR = ':'\nconst EMPTY_MODIFIERS: string[] = []\n\n// Pre-allocated result object shape for consistency\nconst createResultObject = (\n modifiers: string[],\n hasImportantModifier: boolean,\n baseClassName: string,\n maybePostfixModifierPosition?: number,\n isExternal?: boolean,\n): ParsedClassName => ({\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition,\n isExternal,\n})\n\nexport const createParseClassName = (config: AnyConfig) => {\n const { prefix, experimentalParseClassName } = config\n\n /**\n * Parse class name into parts.\n *\n * Inspired by `splitAtTopLevelOnly` used in Tailwind CSS\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v3.2.2/src/util/splitAtTopLevelOnly.js\n */\n let parseClassName = (className: string): ParsedClassName => {\n // Use simple array with push for better performance\n const modifiers: string[] = []\n\n let bracketDepth = 0\n let parenDepth = 0\n let modifierStart = 0\n let postfixModifierPosition: number | undefined\n\n const len = className.length\n for (let index = 0; index < len; index++) {\n const currentCharacter = className[index]!\n\n if (bracketDepth === 0 && parenDepth === 0) {\n if (currentCharacter === MODIFIER_SEPARATOR) {\n modifiers.push(className.slice(modifierStart, index))\n modifierStart = index + 1\n continue\n }\n\n if (currentCharacter === '/') {\n postfixModifierPosition = index\n continue\n }\n }\n\n if (currentCharacter === '[') bracketDepth++\n else if (currentCharacter === ']') bracketDepth--\n else if (currentCharacter === '(') parenDepth++\n else if (currentCharacter === ')') parenDepth--\n }\n\n const baseClassNameWithImportantModifier =\n modifiers.length === 0 ? className : className.slice(modifierStart)\n\n // Inline important modifier check\n let baseClassName = baseClassNameWithImportantModifier\n let hasImportantModifier = false\n\n if (baseClassNameWithImportantModifier.endsWith(IMPORTANT_MODIFIER)) {\n baseClassName = baseClassNameWithImportantModifier.slice(0, -1)\n hasImportantModifier = true\n } else if (\n /**\n * In Tailwind CSS v3 the important modifier was at the start of the base class name. This is still supported for legacy reasons.\n * @see https://github.com/dcastil/tailwind-merge/issues/513#issuecomment-2614029864\n */\n baseClassNameWithImportantModifier.startsWith(IMPORTANT_MODIFIER)\n ) {\n baseClassName = baseClassNameWithImportantModifier.slice(1)\n hasImportantModifier = true\n }\n\n const maybePostfixModifierPosition =\n postfixModifierPosition && postfixModifierPosition > modifierStart\n ? postfixModifierPosition - modifierStart\n : undefined\n\n return createResultObject(\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition,\n )\n }\n\n if (prefix) {\n const fullPrefix = prefix + MODIFIER_SEPARATOR\n const parseClassNameOriginal = parseClassName\n parseClassName = (className: string) =>\n className.startsWith(fullPrefix)\n ? parseClassNameOriginal(className.slice(fullPrefix.length))\n : createResultObject(EMPTY_MODIFIERS, false, className, undefined, true)\n }\n\n if (experimentalParseClassName) {\n const parseClassNameOriginal = parseClassName\n parseClassName = (className: string) =>\n experimentalParseClassName({ className, parseClassName: parseClassNameOriginal })\n }\n\n return parseClassName\n}\n","import { AnyConfig } from './types'\n\n/**\n * Sorts modifiers according to following schema:\n * - Predefined modifiers are sorted alphabetically\n * - When an arbitrary variant appears, it must be preserved which modifiers are before and after it\n */\nexport const createSortModifiers = (config: AnyConfig) => {\n // Pre-compute weights for all known modifiers for O(1) comparison\n const modifierWeights = new Map<string, number>()\n\n // Assign weights to sensitive modifiers (highest priority, but preserve order)\n config.orderSensitiveModifiers.forEach((mod, index) => {\n modifierWeights.set(mod, 1000000 + index) // High weights for sensitive mods\n })\n\n return (modifiers: readonly string[]): string[] => {\n const result: string[] = []\n let currentSegment: string[] = []\n\n // Process modifiers in one pass\n for (let i = 0; i < modifiers.length; i++) {\n const modifier = modifiers[i]!\n\n // Check if modifier is sensitive (starts with '[' or in orderSensitiveModifiers)\n const isArbitrary = modifier[0] === '['\n const isOrderSensitive = modifierWeights.has(modifier)\n\n if (isArbitrary || isOrderSensitive) {\n // Sort and flush current segment alphabetically\n if (currentSegment.length > 0) {\n currentSegment.sort()\n result.push(...currentSegment)\n currentSegment = []\n }\n result.push(modifier)\n } else {\n // Regular modifier - add to current segment for batch sorting\n currentSegment.push(modifier)\n }\n }\n\n // Sort and add any remaining segment items\n if (currentSegment.length > 0) {\n currentSegment.sort()\n result.push(...currentSegment)\n }\n\n return result\n }\n}\n","import { createClassGroupUtils } from './class-group-utils'\nimport { createLruCache } from './lru-cache'\nimport { createParseClassName } from './parse-class-name'\nimport { createSortModifiers } from './sort-modifiers'\nimport { AnyConfig } from './types'\n\nexport type ConfigUtils = ReturnType<typeof createConfigUtils>\n\nexport const createConfigUtils = (config: AnyConfig) => ({\n cache: createLruCache<string, string>(config.cacheSize),\n parseClassName: createParseClassName(config),\n sortModifiers: createSortModifiers(config),\n ...createClassGroupUtils(config),\n})\n","import { ConfigUtils } from './config-utils'\nimport { IMPORTANT_MODIFIER } from './parse-class-name'\n\nconst SPLIT_CLASSES_REGEX = /\\s+/\n\nexport const mergeClassList = (classList: string, configUtils: ConfigUtils) => {\n const { parseClassName, getClassGroupId, getConflictingClassGroupIds, sortModifiers } =\n configUtils\n\n /**\n * Set of classGroupIds in following format:\n * `{importantModifier}{variantModifiers}{classGroupId}`\n * @example 'float'\n * @example 'hover:focus:bg-color'\n * @example 'md:!pr'\n */\n const classGroupsInConflict: string[] = []\n const classNames = classList.trim().split(SPLIT_CLASSES_REGEX)\n\n let result = ''\n\n for (let index = classNames.length - 1; index >= 0; index -= 1) {\n const originalClassName = classNames[index]!\n\n const {\n isExternal,\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition,\n } = parseClassName(originalClassName)\n\n if (isExternal) {\n result = originalClassName + (result.length > 0 ? ' ' + result : result)\n continue\n }\n\n let hasPostfixModifier = !!maybePostfixModifierPosition\n let classGroupId = getClassGroupId(\n hasPostfixModifier\n ? baseClassName.substring(0, maybePostfixModifierPosition)\n : baseClassName,\n )\n\n if (!classGroupId) {\n if (!hasPostfixModifier) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result)\n continue\n }\n\n classGroupId = getClassGroupId(baseClassName)\n\n if (!classGroupId) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result)\n continue\n }\n\n hasPostfixModifier = false\n }\n\n // Fast path: skip sorting for empty or single modifier\n const variantModifier =\n modifiers.length === 0\n ? ''\n : modifiers.length === 1\n ? modifiers[0]!\n : sortModifiers(modifiers).join(':')\n\n const modifierId = hasImportantModifier\n ? variantModifier + IMPORTANT_MODIFIER\n : variantModifier\n\n const classId = modifierId + classGroupId\n\n if (classGroupsInConflict.indexOf(classId) > -1) {\n // Tailwind class omitted due to conflict\n continue\n }\n\n classGroupsInConflict.push(classId)\n\n const conflictGroups = getConflictingClassGroupIds(classGroupId, hasPostfixModifier)\n for (let i = 0; i < conflictGroups.length; ++i) {\n const group = conflictGroups[i]!\n classGroupsInConflict.push(modifierId + group)\n }\n\n // Tailwind class not in conflict\n result = originalClassName + (result.length > 0 ? ' ' + result : result)\n }\n\n return result\n}\n","/**\n * The code in this file is copied from https://github.com/lukeed/clsx and modified to suit the needs of tailwind-merge better.\n *\n * Specifically:\n * - Runtime code from https://github.com/lukeed/clsx/blob/v1.2.1/src/index.js\n * - TypeScript types from https://github.com/lukeed/clsx/blob/v1.2.1/clsx.d.ts\n *\n * Original code has MIT license: Copyright (c) Luke Edwards <luke.edwards05@gmail.com> (lukeed.com)\n */\n\nexport type ClassNameValue = ClassNameArray | string | null | undefined | 0 | 0n | false\ntype ClassNameArray = ClassNameValue[]\n\nexport const twJoin = (...classLists: ClassNameValue[]): string => {\n let index = 0\n let argument: ClassNameValue\n let resolvedValue: string\n let string = ''\n\n while (index < classLists.length) {\n if ((argument = classLists[index++])) {\n if ((resolvedValue = toValue(argument))) {\n string && (string += ' ')\n string += resolvedValue\n }\n }\n }\n return string\n}\n\nconst toValue = (mix: ClassNameArray | string): string => {\n // Fast path for strings\n if (typeof mix === 'string') {\n return mix\n }\n\n let resolvedValue: string\n let string = ''\n\n for (let k = 0; k < mix.length; k++) {\n if (mix[k]) {\n if ((resolvedValue = toValue(mix[k] as ClassNameArray | string))) {\n string && (string += ' ')\n string += resolvedValue\n }\n }\n }\n\n return string\n}\n","import { createConfigUtils } from './config-utils'\nimport { mergeClassList } from './merge-classlist'\nimport { ClassNameValue, twJoin } from './tw-join'\nimport { AnyConfig } from './types'\n\ntype CreateConfigFirst = () => AnyConfig\ntype CreateConfigSubsequent = (config: AnyConfig) => AnyConfig\ntype TailwindMerge = (...classLists: ClassNameValue[]) => string\ntype ConfigUtils = ReturnType<typeof createConfigUtils>\n\nexport const createTailwindMerge = (\n createConfigFirst: CreateConfigFirst,\n ...createConfigRest: CreateConfigSubsequent[]\n): TailwindMerge => {\n let configUtils: ConfigUtils\n let cacheGet: ConfigUtils['cache']['get']\n let cacheSet: ConfigUtils['cache']['set']\n let functionToCall: (classList: string) => string\n\n const initTailwindMerge = (classList: string) => {\n const config = createConfigRest.reduce(\n (previousConfig, createConfigCurrent) => createConfigCurrent(previousConfig),\n createConfigFirst() as AnyConfig,\n )\n\n configUtils = createConfigUtils(config)\n cacheGet = configUtils.cache.get\n cacheSet = configUtils.cache.set\n functionToCall = tailwindMerge\n\n return tailwindMerge(classList)\n }\n\n const tailwindMerge = (classList: string) => {\n const cachedResult = cacheGet(classList)\n\n if (cachedResult) {\n return cachedResult\n }\n\n const result = mergeClassList(classList, configUtils)\n cacheSet(classList, result)\n\n return result\n }\n\n functionToCall = initTailwindMerge\n\n return (...args: ClassNameValue[]) => functionToCall(twJoin(...args))\n}\n","import { DefaultThemeGroupIds, NoInfer, ThemeGetter, ThemeObject } from './types'\n\nconst fallbackThemeArr: ThemeObject<DefaultThemeGroupIds>[DefaultThemeGroupIds] = []\n\nexport const fromTheme = <\n AdditionalThemeGroupIds extends string = never,\n DefaultThemeGroupIdsInner extends string = DefaultThemeGroupIds,\n>(\n key: NoInfer<DefaultThemeGroupIdsInner | AdditionalThemeGroupIds>,\n): ThemeGetter => {\n const themeGetter = (theme: ThemeObject<DefaultThemeGroupIdsInner | AdditionalThemeGroupIds>) =>\n theme[key] || fallbackThemeArr\n\n themeGetter.isThemeGetter = true as const\n\n return themeGetter\n}\n","const arbitraryValueRegex = /^\\[(?:(\\w[\\w-]*):)?(.+)\\]$/i\nconst arbitraryVariableRegex = /^\\((?:(\\w[\\w-]*):)?(.+)\\)$/i\nconst fractionRegex = /^\\d+(?:\\.\\d+)?\\/\\d+(?:\\.\\d+)?$/\nconst tshirtUnitRegex = /^(\\d+(\\.\\d+)?)?(xs|sm|md|lg|xl)$/\nconst lengthUnitRegex =\n /\\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\\b(calc|min|max|clamp)\\(.+\\)|^0$/\nconst colorFunctionRegex = /^(rgba?|hsla?|hwb|(ok)?(lab|lch)|color-mix)\\(.+\\)$/\n// Shadow always begins with x and y offset separated by underscore optionally prepended by inset\nconst shadowRegex = /^(inset_)?-?((\\d+)?\\.?(\\d+)[a-z]+|0)_-?((\\d+)?\\.?(\\d+)[a-z]+|0)/\nconst imageRegex =\n /^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\\(.+\\)$/\n\nexport const isFraction = (value: string) => fractionRegex.test(value)\n\nexport const isNumber = (value: string) => !!value && !Number.isNaN(Number(value))\n\nexport const isInteger = (value: string) => !!value && Number.isInteger(Number(value))\n\nexport const isPercent = (value: string) => value.endsWith('%') && isNumber(value.slice(0, -1))\n\nexport const isTshirtSize = (value: string) => tshirtUnitRegex.test(value)\n\nexport const isAny = () => true\n\nconst isLengthOnly = (value: string) =>\n // `colorFunctionRegex` check is necessary because color functions can have percentages in them which which would be incorrectly classified as lengths.\n // For example, `hsl(0 0% 0%)` would be classified as a length without this check.\n // I could also use lookbehind assertion in `lengthUnitRegex` but that isn't supported widely enough.\n lengthUnitRegex.test(value) && !colorFunctionRegex.test(value)\n\nconst isNever = () => false\n\nconst isShadow = (value: string) => shadowRegex.test(value)\n\nconst isImage = (value: string) => imageRegex.test(value)\n\nexport const isAnyNonArbitrary = (value: string) =>\n !isArbitraryValue(value) && !isArbitraryVariable(value)\n\nexport const isArbitrarySize = (value: string) => getIsArbitraryValue(value, isLabelSize, isNever)\n\nexport const isArbitraryValue = (value: string) => arbitraryValueRegex.test(value)\n\nexport const isArbitraryLength = (value: string) =>\n getIsArbitraryValue(value, isLabelLength, isLengthOnly)\n\nexport const isArbitraryNumber = (value: string) =>\n getIsArbitraryValue(value, isLabelNumber, isNumber)\n\nexport const isArbitraryWeight = (value: string) => getIsArbitraryValue(value, isLabelWeight, isAny)\n\nexport const isArbitraryFamilyName = (value: string) =>\n getIsArbitraryValue(value, isLabelFamilyName, isNever)\n\nexport const isArbitraryPosition = (value: string) =>\n getIsArbitraryValue(value, isLabelPosition, isNever)\n\nexport const isArbitraryImage = (value: string) => getIsArbitraryValue(value, isLabelImage, isImage)\n\nexport const isArbitraryShadow = (value: string) =>\n getIsArbitraryValue(value, isLabelShadow, isShadow)\n\nexport const isArbitraryVariable = (value: string) => arbitraryVariableRegex.test(value)\n\nexport const isArbitraryVariableLength = (value: string) =>\n getIsArbitraryVariable(value, isLabelLength)\n\nexport const isArbitraryVariableFamilyName = (value: string) =>\n getIsArbitraryVariable(value, isLabelFamilyName)\n\nexport const isArbitraryVariablePosition = (value: string) =>\n getIsArbitraryVariable(value, isLabelPosition)\n\nexport const isArbitraryVariableSize = (value: string) => getIsArbitraryVariable(value, isLabelSize)\n\nexport const isArbitraryVariableImage = (value: string) =>\n getIsArbitraryVariable(value, isLabelImage)\n\nexport const isArbitraryVariableShadow = (value: string) =>\n getIsArbitraryVariable(value, isLabelShadow, true)\n\nexport const isArbitraryVariableWeight = (value: string) =>\n getIsArbitraryVariable(value, isLabelWeight, true)\n\n// Helpers\n\nconst getIsArbitraryValue = (\n value: string,\n testLabel: (label: string) => boolean,\n testValue: (value: string) => boolean,\n) => {\n const result = arbitraryValueRegex.exec(value)\n\n if (result) {\n if (result[1]) {\n return testLabel(result[1])\n }\n\n return testValue(result[2]!)\n }\n\n return false\n}\n\nconst getIsArbitraryVariable = (\n value: string,\n testLabel: (label: string) => boolean,\n shouldMatchNoLabel = false,\n) => {\n const result = arbitraryVariableRegex.exec(value)\n\n if (result) {\n if (result[1]) {\n return testLabel(result[1])\n }\n return shouldMatchNoLabel\n }\n\n return false\n}\n\n// Labels\n\nconst isLabelPosition = (label: string) => label === 'position' || label === 'percentage'\n\nconst isLabelImage = (label: string) => label === 'image' || label === 'url'\n\nconst isLabelSize = (label: string) => label === 'length' || label === 'size' || label === 'bg-size'\n\nconst isLabelLength = (label: string) => label === 'length'\n\nconst isLabelNumber = (label: string) => label === 'number'\n\nconst isLabelFamilyName = (label: string) => label === 'family-name'\n\nconst isLabelWeight = (label: string) => label === 'number' || label === 'weight'\n\nconst isLabelShadow = (label: string) => label === 'shadow'\n","import { fromTheme } from './from-theme'\nimport { Config, DefaultClassGroupIds, DefaultThemeGroupIds } from './types'\nimport {\n isAny,\n isAnyNonArbitrary,\n isArbitraryFamilyName,\n isArbitraryImage,\n isArbitraryLength,\n isArbitraryNumber,\n isArbitraryPosition,\n isArbitraryShadow,\n isArbitrarySize,\n isArbitraryValue,\n isArbitraryVariable,\n isArbitraryVariableFamilyName,\n isArbitraryVariableImage,\n isArbitraryVariableLength,\n isArbitraryVariablePosition,\n isArbitraryVariableShadow,\n isArbitraryVariableSize,\n isArbitraryVariableWeight,\n isArbitraryWeight,\n isFraction,\n isInteger,\n isNumber,\n isPercent,\n isTshirtSize,\n} from './validators'\n\nexport const getDefaultConfig = () => {\n /**\n * Theme getters for theme variable namespaces\n * @see https://tailwindcss.com/docs/theme#theme-variable-namespaces\n */\n /***/\n\n const themeColor = fromTheme('color')\n const themeFont = fromTheme('font')\n const themeText = fromTheme('text')\n const themeFontWeight = fromTheme('font-weight')\n const themeTracking = fromTheme('tracking')\n const themeLeading = fromTheme('leading')\n const themeBreakpoint = fromTheme('breakpoint')\n const themeContainer = fromTheme('container')\n const themeSpacing = fromTheme('spacing')\n const themeRadius = fromTheme('radius')\n const themeShadow = fromTheme('shadow')\n const themeInsetShadow = fromTheme('inset-shadow')\n const themeTextShadow = fromTheme('text-shadow')\n const themeDropShadow = fromTheme('drop-shadow')\n const themeBlur = fromTheme('blur')\n const themePerspective = fromTheme('perspective')\n const themeAspect = fromTheme('aspect')\n const themeEase = fromTheme('ease')\n const themeAnimate = fromTheme('animate')\n\n /**\n * Helpers to avoid repeating the same scales\n *\n * We use functions that create a new array every time they're called instead of static arrays.\n * This ensures that users who modify any scale by mutating the array (e.g. with `array.push(element)`) don't accidentally mutate arrays in other parts of the config.\n */\n /***/\n\n const scaleBreak = () =>\n ['auto', 'avoid', 'all', 'avoid-page', 'page', 'left', 'right', 'column'] as const\n const scalePosition = () =>\n [\n 'center',\n 'top',\n 'bottom',\n 'left',\n 'right',\n 'top-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-top',\n 'top-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-top',\n 'bottom-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-bottom',\n 'bottom-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-bottom',\n ] as const\n const scalePositionWithArbitrary = () =>\n [...scalePosition(), isArbitraryVariable, isArbitraryValue] as const\n const scaleOverflow = () => ['auto', 'hidden', 'clip', 'visible', 'scroll'] as const\n const scaleOverscroll = () => ['auto', 'contain', 'none'] as const\n const scaleUnambiguousSpacing = () =>\n [isArbitraryVariable, isArbitraryValue, themeSpacing] as const\n const scaleInset = () => [isFraction, 'full', 'auto', ...scaleUnambiguousSpacing()] as const\n const scaleGridTemplateColsRows = () =>\n [isInteger, 'none', 'subgrid', isArbitraryVariable, isArbitraryValue] as const\n const scaleGridColRowStartAndEnd = () =>\n [\n 'auto',\n { span: ['full', isInteger, isArbitraryVariable, isArbitraryValue] },\n isInteger,\n isArbitraryVariable,\n isArbitraryValue,\n ] as const\n const scaleGridColRowStartOrEnd = () =>\n [isInteger, 'auto', isArbitraryVariable, isArbitraryValue] as const\n const scaleGridAutoColsRows = () =>\n ['auto', 'min', 'max', 'fr', isArbitraryVariable, isArbitraryValue] as const\n const scaleAlignPrimaryAxis = () =>\n [\n 'start',\n 'end',\n 'center',\n 'between',\n 'around',\n 'evenly',\n 'stretch',\n 'baseline',\n 'center-safe',\n 'end-safe',\n ] as const\n const scaleAlignSecondaryAxis = () =>\n ['start', 'end', 'center', 'stretch', 'center-safe', 'end-safe'] as const\n const scaleMargin = () => ['auto', ...scaleUnambiguousSpacing()] as const\n const scaleSizing = () =>\n [\n isFraction,\n 'auto',\n 'full',\n 'dvw',\n 'dvh',\n 'lvw',\n 'lvh',\n 'svw',\n 'svh',\n 'min',\n 'max',\n 'fit',\n ...scaleUnambiguousSpacing(),\n ] as const\n const scaleSizingInline = () =>\n [\n isFraction,\n 'screen',\n 'full',\n 'dvw',\n 'lvw',\n 'svw',\n 'min',\n 'max',\n 'fit',\n ...scaleUnambiguousSpacing(),\n ] as const\n const scaleSizingBlock = () =>\n [\n isFraction,\n 'screen',\n 'full',\n 'lh',\n 'dvh',\n 'lvh',\n 'svh',\n 'min',\n 'max',\n 'fit',\n ...scaleUnambiguousSpacing(),\n ] as const\n const scaleColor = () => [themeColor, isArbitraryVariable, isArbitraryValue] as const\n const scaleBgPosition = () =>\n [\n ...scalePosition(),\n isArbitraryVariablePosition,\n isArbitraryPosition,\n { position: [isArbitraryVariable, isArbitraryValue] },\n ] as const\n const scaleBgRepeat = () => ['no-repeat', { repeat: ['', 'x', 'y', 'space', 'round'] }] as const\n const scaleBgSize = () =>\n [\n 'auto',\n 'cover',\n 'contain',\n isArbitraryVariableSize,\n isArbitrarySize,\n { size: [isArbitraryVariable, isArbitraryValue] },\n ] as const\n const scaleGradientStopPosition = () =>\n [isPercent, isArbitraryVariableLength, isArbitraryLength] as const\n const scaleRadius = () =>\n [\n // Deprecated since Tailwind CSS v4.0.0\n '',\n 'none',\n 'full',\n themeRadius,\n isArbitraryVariable,\n isArbitraryValue,\n ] as const\n const scaleBorderWidth = () =>\n ['', isNumber, isArbitraryVariableLength, isArbitraryLength] as const\n const scaleLineStyle = () => ['solid', 'dashed', 'dotted', 'double'] as const\n const scaleBlendMode = () =>\n [\n 'normal',\n 'multiply',\n 'screen',\n 'overlay',\n 'darken',\n 'lighten',\n 'color-dodge',\n 'color-burn',\n 'hard-light',\n 'soft-light',\n 'difference',\n 'exclusion',\n 'hue',\n 'saturation',\n 'color',\n 'luminosity',\n ] as const\n const scaleMaskImagePosition = () =>\n [isNumber, isPercent, isArbitraryVariablePosition, isArbitraryPosition] as const\n const scaleBlur = () =>\n [\n // Deprecated since Tailwind CSS v4.0.0\n '',\n 'none',\n themeBlur,\n isArbitraryVariable,\n isArbitraryValue,\n ] as const\n const scaleRotate = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue] as const\n const scaleScale = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue] as const\n const scaleSkew = () => [isNumber, isArbitraryVariable, isArbitraryValue] as const\n const scaleTranslate = () => [isFraction, 'full', ...scaleUnambiguousSpacing()] as const\n\n return {\n cacheSize: 500,\n theme: {\n animate: ['spin', 'ping', 'pulse', 'bounce'],\n aspect: ['video'],\n blur: [isTshirtSize],\n breakpoint: [isTshirtSize],\n color: [isAny],\n container: [isTshirtSize],\n 'drop-shadow': [isTshirtSize],\n ease: ['in', 'out', 'in-out'],\n font: [isAnyNonArbitrary],\n 'font-weight': [\n 'thin',\n 'extralight',\n 'light',\n 'normal',\n 'medium',\n 'semibold',\n 'bold',\n 'extrabold',\n 'black',\n ],\n 'inset-shadow': [isTshirtSize],\n leading: ['none', 'tight', 'snug', 'normal', 'relaxed', 'loose'],\n perspective: ['dramatic', 'near', 'normal', 'midrange', 'distant', 'none'],\n radius: [isTshirtSize],\n shadow: [isTshirtSize],\n spacing: ['px', isNumber],\n text: [isTshirtSize],\n 'text-shadow': [isTshirtSize],\n tracking: ['tighter', 'tight', 'normal', 'wide', 'wider', 'widest'],\n },\n classGroups: {\n // --------------\n // --- Layout ---\n // --------------\n\n /**\n * Aspect Ratio\n * @see https://tailwindcss.com/docs/aspect-ratio\n */\n aspect: [\n {\n aspect: [\n 'auto',\n 'square',\n isFraction,\n isArbitraryValue,\n isArbitraryVariable,\n themeAspect,\n ],\n },\n ],\n /**\n * Container\n * @see https://tailwindcss.com/docs/container\n * @deprecated since Tailwind CSS v4.0.0\n */\n container: ['container'],\n /**\n * Columns\n * @see https://tailwindcss.com/docs/columns\n */\n columns: [\n { columns: [isNumber, isArbitraryValue, isArbitraryVariable, themeContainer] },\n ],\n /**\n * Break After\n * @see https://tailwindcss.com/docs/break-after\n */\n 'break-after': [{ 'break-after': scaleBreak() }],\n /**\n * Break Before\n * @see https://tailwindcss.com/docs/break-before\n */\n 'break-before': [{ 'break-before': scaleBreak() }],\n /**\n * Break Inside\n * @see https://tailwindcss.com/docs/break-inside\n */\n 'break-inside': [{ 'break-inside': ['auto', 'avoid', 'avoid-page', 'avoid-column'] }],\n /**\n * Box Decoration Break\n * @see https://tailwindcss.com/docs/box-decoration-break\n */\n 'box-decoration': [{ 'box-decoration': ['slice', 'clone'] }],\n /**\n * Box Sizing\n * @see https://tailwindcss.com/docs/box-sizing\n */\n box: [{ box: ['border', 'content'] }],\n /**\n * Display\n * @see https://tailwindcss.com/docs/display\n */\n display: [\n 'block',\n 'inline-block',\n 'inline',\n 'flex',\n 'inline-flex',\n 'table',\n 'inline-table',\n 'table-caption',\n 'table-cell',\n 'table-column',\n 'table-column-group',\n 'table-footer-group',\n 'table-header-group',\n 'table-row-group',\n 'table-row',\n 'flow-root',\n 'grid',\n 'inline-grid',\n 'contents',\n 'list-item',\n 'hidden',\n ],\n /**\n * Screen Reader Only\n * @see https://tailwindcss.com/docs/display#screen-reader-only\n */\n sr: ['sr-only', 'not-sr-only'],\n /**\n * Floats\n * @see https://tailwindcss.com/docs/float\n */\n float: [{ float: ['right', 'left', 'none', 'start', 'end'] }],\n /**\n * Clear\n * @see https://tailwindcss.com/docs/clear\n */\n clear: [{ clear: ['left', 'right', 'both', 'none', 'start', 'end'] }],\n /**\n * Isolation\n * @see https://tailwindcss.com/docs/isolation\n */\n isolation: ['isolate', 'isolation-auto'],\n /**\n * Object Fit\n * @see https://tailwindcss.com/docs/object-fit\n */\n 'object-fit': [{ object: ['contain', 'cover', 'fill', 'none', 'scale-down'] }],\n /**\n * Object Position\n * @see https://tailwindcss.com/docs/object-position\n */\n 'object-position': [{ object: scalePositionWithArbitrary() }],\n /**\n * Overflow\n * @see https://tailwindcss.com/docs/overflow\n */\n overflow: [{ overflow: scaleOverflow() }],\n /**\n * Overflow X\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-x': [{ 'overflow-x': scaleOverflow() }],\n /**\n * Overflow Y\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-y': [{ 'overflow-y': scaleOverflow() }],\n /**\n * Overscroll Behavior\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n overscroll: [{ overscroll: scaleOverscroll() }],\n /**\n * Overscroll Behavior X\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-x': [{ 'overscroll-x': scaleOverscroll() }],\n /**\n * Overscroll Behavior Y\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-y': [{ 'overscroll-y': scaleOverscroll() }],\n /**\n * Position\n * @see https://tailwindcss.com/docs/position\n */\n position: ['static', 'fixed', 'absolute', 'relative', 'sticky'],\n /**\n * Inset\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n inset: [{ inset: scaleInset() }],\n /**\n * Inset Inline\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-x': [{ 'inset-x': scaleInset() }],\n /**\n * Inset Block\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-y': [{ 'inset-y': scaleInset() }],\n /**\n * Inset Inline Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n * @todo class group will be renamed to `inset-s` in next major release\n */\n start: [\n {\n 'inset-s': scaleInset(),\n /**\n * @deprecated since Tailwind CSS v4.2.0 in favor of `inset-s-*` utilities.\n * @see https://github.com/tailwindlabs/tailwindcss/pull/19613\n */\n start: scaleInset(),\n },\n ],\n /**\n * Inset Inline End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n * @todo class group will be renamed to `inset-e` in next major release\n */\n end: [\n {\n 'inset-e': scaleInset(),\n /**\n * @deprecated since Tailwind CSS v4.2.0 in favor of `inset-e-*` utilities.\n * @see https://github.com/tailwindlabs/tailwindcss/pull/19613\n */\n end: scaleInset(),\n },\n ],\n /**\n * Inset Block Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-bs': [{ 'inset-bs': scaleInset() }],\n /**\n * Inset Block End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-be': [{ 'inset-be': scaleInset() }],\n /**\n * Top\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n top: [{ top: scaleInset() }],\n /**\n * Right\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n right: [{ right: scaleInset() }],\n /**\n * Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n bottom: [{ bottom: scaleInset() }],\n /**\n * Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n left: [{ left: scaleInset() }],\n /**\n * Visibility\n * @see https://tailwindcss.com/docs/visibility\n */\n visibility: ['visible', 'invisible', 'collapse'],\n /**\n * Z-Index\n * @see https://tailwindcss.com/docs/z-index\n */\n z: [{ z: [isInteger, 'auto', isArbitraryVariable, isArbitraryValue] }],\n\n // ------------------------\n // --- Flexbox and Grid ---\n // ------------------------\n\n /**\n * Flex Basis\n * @see https://tailwindcss.com/docs/flex-basis\n */\n basis: [\n {\n basis: [\n isFraction,\n 'full',\n 'auto',\n themeContainer,\n ...scaleUnambiguousSpacing(),\n ],\n },\n ],\n /**\n * Flex Direction\n * @see https://tailwindcss.com/docs/flex-direction\n */\n 'flex-direction': [{ flex: ['row', 'row-reverse', 'col', 'col-reverse'] }],\n /**\n * Flex Wrap\n * @see https://tailwindcss.com/docs/flex-wrap\n */\n 'flex-wrap': [{ flex: ['nowrap', 'wrap', 'wrap-reverse'] }],\n /**\n * Flex\n * @see https://tailwindcss.com/docs/flex\n */\n flex: [{ flex: [isNumber, isFraction, 'auto', 'initial', 'none', isArbitraryValue] }],\n /**\n * Flex Grow\n * @see https://tailwindcss.com/docs/flex-grow\n */\n grow: [{ grow: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Flex Shrink\n * @see https://tailwindcss.com/docs/flex-shrink\n */\n shrink: [{ shrink: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Order\n * @see https://tailwindcss.com/docs/order\n */\n order: [\n {\n order: [\n isInteger,\n 'first',\n 'last',\n 'none',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Grid Template Columns\n * @see https://tailwindcss.com/docs/grid-template-columns\n */\n 'grid-cols': [{ 'grid-cols': scaleGridTemplateColsRows() }],\n /**\n * Grid Column Start / End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start-end': [{ col: scaleGridColRowStartAndEnd() }],\n /**\n * Grid Column Start\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start': [{ 'col-start': scaleGridColRowStartOrEnd() }],\n /**\n * Grid Column End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-end': [{ 'col-end': scaleGridColRowStartOrEnd() }],\n /**\n * Grid Template Rows\n * @see https://tailwindcss.com/docs/grid-template-rows\n */\n 'grid-rows': [{ 'grid-rows': scaleGridTemplateColsRows() }],\n /**\n * Grid Row Start / End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start-end': [{ row: scaleGridColRowStartAndEnd() }],\n /**\n * Grid Row Start\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start': [{ 'row-start': scaleGridColRowStartOrEnd() }],\n /**\n * Grid Row End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-end': [{ 'row-end': scaleGridColRowStartOrEnd() }],\n /**\n * Grid Auto Flow\n * @see https://tailwindcss.com/docs/grid-auto-flow\n */\n 'grid-flow': [{ 'grid-flow': ['row', 'col', 'dense', 'row-dense', 'col-dense'] }],\n /**\n * Grid Auto Columns\n * @see https://tailwindcss.com/docs/grid-auto-columns\n */\n 'auto-cols': [{ 'auto-cols': scaleGridAutoColsRows() }],\n /**\n * Grid Auto Rows\n * @see https://tailwindcss.com/docs/grid-auto-rows\n */\n 'auto-rows': [{ 'auto-rows': scaleGridAutoColsRows() }],\n /**\n * Gap\n * @see https://tailwindcss.com/docs/gap\n */\n gap: [{ gap: scaleUnambiguousSpacing() }],\n /**\n * Gap X\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-x': [{ 'gap-x': scaleUnambiguousSpacing() }],\n /**\n * Gap Y\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-y': [{ 'gap-y': scaleUnambiguousSpacing() }],\n /**\n * Justify Content\n * @see https://tailwindcss.com/docs/justify-content\n */\n 'justify-content': [{ justify: [...scaleAlignPrimaryAxis(), 'normal'] }],\n /**\n * Justify Items\n * @see https://tailwindcss.com/docs/justify-items\n */\n 'justify-items': [{ 'justify-items': [...scaleAlignSecondaryAxis(), 'normal'] }],\n /**\n * Justify Self\n * @see https://tailwindcss.com/docs/justify-self\n */\n 'justify-self': [{ 'justify-self': ['auto', ...scaleAlignSecondaryAxis()] }],\n /**\n * Align Content\n * @see https://tailwindcss.com/docs/align-content\n */\n 'align-content': [{ content: ['normal', ...scaleAlignPrimaryAxis()] }],\n /**\n * Align Items\n * @see https://tailwindcss.com/docs/align-items\n */\n 'align-items': [{ items: [...scaleAlignSecondaryAxis(), { baseline: ['', 'last'] }] }],\n /**\n * Align Self\n * @see https://tailwindcss.com/docs/align-self\n */\n 'align-self': [\n { self: ['auto', ...scaleAlignSecondaryAxis(), { baseline: ['', 'last'] }] },\n ],\n /**\n * Place Content\n * @see https://tailwindcss.com/docs/place-content\n */\n 'place-content': [{ 'place-content': scaleAlignPrimaryAxis() }],\n /**\n * Place Items\n * @see https://tailwindcss.com/docs/place-items\n */\n 'place-items': [{ 'place-items': [...scaleAlignSecondaryAxis(), 'baseline'] }],\n /**\n * Place Self\n * @see https://tailwindcss.com/docs/place-self\n */\n 'place-self': [{ 'place-self': ['auto', ...scaleAlignSecondaryAxis()] }],\n // Spacing\n /**\n * Padding\n * @see https://tailwindcss.com/docs/padding\n */\n p: [{ p: scaleUnambiguousSpacing() }],\n /**\n * Padding Inline\n * @see https://tailwindcss.com/docs/padding\n */\n px: [{ px: scaleUnambiguousSpacing() }],\n /**\n * Padding Block\n * @see https://tailwindcss.com/docs/padding\n */\n py: [{ py: scaleUnambiguousSpacing() }],\n /**\n * Padding Inline Start\n * @see https://tailwindcss.com/docs/padding\n */\n ps: [{ ps: scaleUnambiguousSpacing() }],\n /**\n * Padding Inline End\n * @see https://tailwindcss.com/docs/padding\n */\n pe: [{ pe: scaleUnambiguousSpacing() }],\n /**\n * Padding Block Start\n * @see https://tailwindcss.com/docs/padding\n */\n pbs: [{ pbs: scaleUnambiguousSpacing() }],\n /**\n * Padding Block End\n * @see https://tailwindcss.com/docs/padding\n */\n pbe: [{ pbe: scaleUnambiguousSpacing() }],\n /**\n * Padding Top\n * @see https://tailwindcss.com/docs/padding\n */\n pt: [{ pt: scaleUnambiguousSpacing() }],\n /**\n * Padding Right\n * @see https://tailwindcss.com/docs/padding\n */\n pr: [{ pr: scaleUnambiguousSpacing() }],\n /**\n * Padding Bottom\n * @see https://tailwindcss.com/docs/padding\n */\n pb: [{ pb: scaleUnambiguousSpacing() }],\n /**\n * Padding Left\n * @see https://tailwindcss.com/docs/padding\n */\n pl: [{ pl: scaleUnambiguousSpacing() }],\n /**\n * Margin\n * @see https://tailwindcss.com/docs/margin\n */\n m: [{ m: scaleMargin() }],\n /**\n * Margin Inline\n * @see https://tailwindcss.com/docs/margin\n */\n mx: [{ mx: scaleMargin() }],\n /**\n * Margin Block\n * @see https://tailwindcss.com/docs/margin\n */\n my: [{ my: scaleMargin() }],\n /**\n * Margin Inline Start\n * @see https://tailwindcss.com/docs/margin\n */\n ms: [{ ms: scaleMargin() }],\n /**\n * Margin Inline End\n * @see https://tailwindcss.com/docs/margin\n */\n me: [{ me: scaleMargin() }],\n /**\n * Margin Block Start\n * @see https://tailwindcss.com/docs/margin\n */\n mbs: [{ mbs: scaleMargin() }],\n /**\n * Margin Block End\n * @see https://tailwindcss.com/docs/margin\n */\n mbe: [{ mbe: scaleMargin() }],\n /**\n * Margin Top\n * @see https://tailwindcss.com/docs/margin\n */\n mt: [{ mt: scaleMargin() }],\n /**\n * Margin Right\n * @see https://tailwindcss.com/docs/margin\n */\n mr: [{ mr: scaleMargin() }],\n /**\n * Margin Bottom\n * @see https://tailwindcss.com/docs/margin\n */\n mb: [{ mb: scaleMargin() }],\n /**\n * Margin Left\n * @see https://tailwindcss.com/docs/margin\n */\n ml: [{ ml: scaleMargin() }],\n /**\n * Space Between X\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x': [{ 'space-x': scaleUnambiguousSpacing() }],\n /**\n * Space Between X Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x-reverse': ['space-x-reverse'],\n /**\n * Space Between Y\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y': [{ 'space-y': scaleUnambiguousSpacing() }],\n /**\n * Space Between Y Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y-reverse': ['space-y-reverse'],\n\n // --------------\n // --- Sizing ---\n // --------------\n\n /**\n * Size\n * @see https://tailwindcss.com/docs/width#setting-both-width-and-height\n */\n size: [{ size: scaleSizing() }],\n /**\n * Inline Size\n * @see https://tailwindcss.com/docs/width\n */\n 'inline-size': [{ inline: ['auto', ...scaleSizingInline()] }],\n /**\n * Min-Inline Size\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-inline-size': [{ 'min-inline': ['auto', ...scaleSizingInline()] }],\n /**\n * Max-Inline Size\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-inline-size': [{ 'max-inline': ['none', ...scaleSizingInline()] }],\n /**\n * Block Size\n * @see https://tailwindcss.com/docs/height\n */\n 'block-size': [{ block: ['auto', ...scaleSizingBlock()] }],\n /**\n * Min-Block Size\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-block-size': [{ 'min-block': ['auto', ...scaleSizingBlock()] }],\n /**\n * Max-Block Size\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-block-size': [{ 'max-block': ['none', ...scaleSizingBlock()] }],\n /**\n * Width\n * @see https://tailwindcss.com/docs/width\n */\n w: [{ w: [themeContainer, 'screen', ...scaleSizing()] }],\n /**\n * Min-Width\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-w': [\n {\n 'min-w': [\n themeContainer,\n 'screen',\n /** Deprecated. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'none',\n ...scaleSizing(),\n ],\n },\n ],\n /**\n * Max-Width\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-w': [\n {\n 'max-w': [\n themeContainer,\n 'screen',\n 'none',\n /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'prose',\n /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n { screen: [themeBreakpoint] },\n ...scaleSizing(),\n ],\n },\n ],\n /**\n * Height\n * @see https://tailwindcss.com/docs/height\n */\n h: [{ h: ['screen', 'lh', ...scaleSizing()] }],\n /**\n * Min-Height\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-h': [{ 'min-h': ['screen', 'lh', 'none', ...scaleSizing()] }],\n /**\n * Max-Height\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-h': [{ 'max-h': ['screen', 'lh', ...scaleSizing()] }],\n\n // ------------------\n // --- Typography ---\n // ------------------\n\n /**\n * Font Size\n * @see https://tailwindcss.com/docs/font-size\n */\n 'font-size': [\n { text: ['base', themeText, isArbitraryVariableLength, isArbitraryLength] },\n ],\n /**\n * Font Smoothing\n * @see https://tailwindcss.com/docs/font-smoothing\n */\n 'font-smoothing': ['antialiased', 'subpixel-antialiased'],\n /**\n * Font Style\n * @see https://tailwindcss.com/docs/font-style\n */\n 'font-style': ['italic', 'not-italic'],\n /**\n * Font Weight\n * @see https://tailwindcss.com/docs/font-weight\n */\n 'font-weight': [\n {\n font: [themeFontWeight, isArbitraryVariableWeight, isArbitraryWeight],\n },\n ],\n /**\n * Font Stretch\n * @see https://tailwindcss.com/docs/font-stretch\n */\n 'font-stretch': [\n {\n 'font-stretch': [\n 'ultra-condensed',\n 'extra-condensed',\n 'condensed',\n 'semi-condensed',\n 'normal',\n 'semi-expanded',\n 'expanded',\n 'extra-expanded',\n 'ultra-expanded',\n isPercent,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Font Family\n * @see https://tailwindcss.com/docs/font-family\n */\n 'font-family': [\n { font: [isArbitraryVariableFamilyName, isArbitraryFamilyName, themeFont] },\n ],\n /**\n * Font Feature Settings\n * @see https://tailwindcss.com/docs/font-feature-settings\n */\n 'font-features': [{ 'font-features': [isArbitraryValue] }],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-normal': ['normal-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-ordinal': ['ordinal'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-slashed-zero': ['slashed-zero'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-figure': ['lining-nums', 'oldstyle-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-spacing': ['proportional-nums', 'tabular-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-fraction': ['diagonal-fractions', 'stacked-fractions'],\n /**\n * Letter Spacing\n * @see https://tailwindcss.com/docs/letter-spacing\n */\n tracking: [{ tracking: [themeTracking, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Line Clamp\n * @see https://tailwindcss.com/docs/line-clamp\n */\n 'line-clamp': [\n { 'line-clamp': [isNumber, 'none', isArbitraryVariable, isArbitraryNumber] },\n ],\n /**\n * Line Height\n * @see https://tailwindcss.com/docs/line-height\n */\n leading: [\n {\n leading: [\n /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n themeLeading,\n ...scaleUnambiguousSpacing(),\n ],\n },\n ],\n /**\n * List Style Image\n * @see https://tailwindcss.com/docs/list-style-image\n */\n 'list-image': [{ 'list-image': ['none', isArbitraryVariable, isArbitraryValue] }],\n /**\n * List Style Position\n * @see https://tailwindcss.com/docs/list-style-position\n */\n 'list-style-position': [{ list: ['inside', 'outside'] }],\n /**\n * List Style Type\n * @see https://tailwindcss.com/docs/list-style-type\n */\n 'list-style-type': [\n { list: ['disc', 'decimal', 'none', isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Text Alignment\n * @see https://tailwindcss.com/docs/text-align\n */\n 'text-alignment': [{ text: ['left', 'center', 'right', 'justify', 'start', 'end'] }],\n /**\n * Placeholder Color\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://v3.tailwindcss.com/docs/placeholder-color\n */\n 'placeholder-color': [{ placeholder: scaleColor() }],\n /**\n * Text Color\n * @see https://tailwindcss.com/docs/text-color\n */\n 'text-color': [{ text: scaleColor() }],\n /**\n * Text Decoration\n * @see https://tailwindcss.com/docs/text-decoration\n */\n 'text-decoration': ['underline', 'overline', 'line-through', 'no-underline'],\n /**\n * Text Decoration Style\n * @see https://tailwindcss.com/docs/text-decoration-style\n */\n 'text-decoration-style': [{ decoration: [...scaleLineStyle(), 'wavy'] }],\n /**\n * Text Decoration Thickness\n * @see https://tailwindcss.com/docs/text-decoration-thickness\n */\n 'text-decoration-thickness': [\n {\n decoration: [\n isNumber,\n 'from-font',\n 'auto',\n isArbitraryVariable,\n isArbitraryLength,\n ],\n },\n ],\n /**\n * Text Decoration Color\n * @see https://tailwindcss.com/docs/text-decoration-color\n */\n 'text-decoration-color': [{ decoration: scaleColor() }],\n /**\n * Text Underline Offset\n * @see https://tailwindcss.com/docs/text-underline-offset\n */\n 'underline-offset': [\n { 'underline-offset': [isNumber, 'auto', isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Text Transform\n * @see https://tailwindcss.com/docs/text-transform\n */\n 'text-transform': ['uppercase', 'lowercase', 'capitalize', 'normal-case'],\n /**\n * Text Overflow\n * @see https://tailwindcss.com/docs/text-overflow\n */\n 'text-overflow': ['truncate', 'text-ellipsis', 'text-clip'],\n /**\n * Text Wrap\n * @see https://tailwindcss.com/docs/text-wrap\n */\n 'text-wrap': [{ text: ['wrap', 'nowrap', 'balance', 'pretty'] }],\n /**\n * Text Indent\n * @see https://tailwindcss.com/docs/text-indent\n */\n indent: [{ indent: scaleUnambiguousSpacing() }],\n /**\n * Vertical Alignment\n * @see https://tailwindcss.com/docs/vertical-align\n */\n 'vertical-align': [\n {\n align: [\n 'baseline',\n 'top',\n 'middle',\n 'bottom',\n 'text-top',\n 'text-bottom',\n 'sub',\n 'super',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Whitespace\n * @see https://tailwindcss.com/docs/whitespace\n */\n whitespace: [\n { whitespace: ['normal', 'nowrap', 'pre', 'pre-line', 'pre-wrap', 'break-spaces'] },\n ],\n /**\n * Word Break\n * @see https://tailwindcss.com/docs/word-break\n */\n break: [{ break: ['normal', 'words', 'all', 'keep'] }],\n /**\n * Overflow Wrap\n * @see https://tailwindcss.com/docs/overflow-wrap\n */\n wrap: [{ wrap: ['break-word', 'anywhere', 'normal'] }],\n /**\n * Hyphens\n * @see https://tailwindcss.com/docs/hyphens\n */\n hyphens: [{ hyphens: ['none', 'manual', 'auto'] }],\n /**\n * Content\n * @see https://tailwindcss.com/docs/content\n */\n content: [{ content: ['none', isArbitraryVariable, isArbitraryValue] }],\n\n // -------------------\n // --- Backgrounds ---\n // -------------------\n\n /**\n * Background Attachment\n * @see https://tailwindcss.com/docs/background-attachment\n */\n 'bg-attachment': [{ bg: ['fixed', 'local', 'scroll'] }],\n /**\n * Background Clip\n * @see https://tailwindcss.com/docs/background-clip\n */\n 'bg-clip': [{ 'bg-clip': ['border', 'padding', 'content', 'text'] }],\n /**\n * Background Origin\n * @see https://tailwindcss.com/docs/background-origin\n */\n 'bg-origin': [{ 'bg-origin': ['border', 'padding', 'content'] }],\n /**\n * Background Position\n * @see https://tailwindcss.com/docs/background-position\n */\n 'bg-position': [{ bg: scaleBgPosition() }],\n /**\n * Background Repeat\n * @see https://tailwindcss.com/docs/background-repeat\n */\n 'bg-repeat': [{ bg: scaleBgRepeat() }],\n /**\n * Background Size\n * @see https://tailwindcss.com/docs/background-size\n */\n 'bg-size': [{ bg: scaleBgSize() }],\n /**\n * Background Image\n * @see https://tailwindcss.com/docs/background-image\n */\n 'bg-image': [\n {\n bg: [\n 'none',\n {\n linear: [\n { to: ['t', 'tr', 'r', 'br', 'b', 'bl', 'l', 'tl'] },\n isInteger,\n isArbitraryVariable,\n isArbitraryValue,\n ],\n radial: ['', isArbitraryVariable, isArbitraryValue],\n conic: [isInteger, isArbitraryVariable, isArbitraryValue],\n },\n isArbitraryVariableImage,\n isArbitraryImage,\n ],\n },\n ],\n /**\n * Background Color\n * @see https://tailwindcss.com/docs/background-color\n */\n 'bg-color': [{ bg: scaleColor() }],\n /**\n * Gradient Color Stops From Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from-pos': [{ from: scaleGradientStopPosition() }],\n /**\n * Gradient Color Stops Via Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via-pos': [{ via: scaleGradientStopPosition() }],\n /**\n * Gradient Color Stops To Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to-pos': [{ to: scaleGradientStopPosition() }],\n /**\n * Gradient Color Stops From\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from': [{ from: scaleColor() }],\n /**\n * Gradient Color Stops Via\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via': [{ via: scaleColor() }],\n /**\n * Gradient Color Stops To\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to': [{ to: scaleColor() }],\n\n // ---------------\n // --- Borders ---\n // ---------------\n\n /**\n * Border Radius\n * @see https://tailwindcss.com/docs/border-radius\n */\n rounded: [{ rounded: scaleRadius() }],\n /**\n * Border Radius Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-s': [{ 'rounded-s': scaleRadius() }],\n /**\n * Border Radius End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-e': [{ 'rounded-e': scaleRadius() }],\n /**\n * Border Radius Top\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-t': [{ 'rounded-t': scaleRadius() }],\n /**\n * Border Radius Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-r': [{ 'rounded-r': scaleRadius() }],\n /**\n * Border Radius Bottom\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-b': [{ 'rounded-b': scaleRadius() }],\n /**\n * Border Radius Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-l': [{ 'rounded-l': scaleRadius() }],\n /**\n * Border Radius Start Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ss': [{ 'rounded-ss': scaleRadius() }],\n /**\n * Border Radius Start End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-se': [{ 'rounded-se': scaleRadius() }],\n /**\n * Border Radius End End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ee': [{ 'rounded-ee': scaleRadius() }],\n /**\n * Border Radius End Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-es': [{ 'rounded-es': scaleRadius() }],\n /**\n * Border Radius Top Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tl': [{ 'rounded-tl': scaleRadius() }],\n /**\n * Border Radius Top Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tr': [{ 'rounded-tr': scaleRadius() }],\n /**\n * Border Radius Bottom Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-br': [{ 'rounded-br': scaleRadius() }],\n /**\n * Border Radius Bottom Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-bl': [{ 'rounded-bl': scaleRadius() }],\n /**\n * Border Width\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w': [{ border: scaleBorderWidth() }],\n /**\n * Border Width Inline\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-x': [{ 'border-x': scaleBorderWidth() }],\n /**\n * Border Width Block\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-y': [{ 'border-y': scaleBorderWidth() }],\n /**\n * Border Width Inline Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-s': [{ 'border-s': scaleBorderWidth() }],\n /**\n * Border Width Inline End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-e': [{ 'border-e': scaleBorderWidth() }],\n /**\n * Border Width Block Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-bs': [{ 'border-bs': scaleBorderWidth() }],\n /**\n * Border Width Block End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-be': [{ 'border-be': scaleBorderWidth() }],\n /**\n * Border Width Top\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-t': [{ 'border-t': scaleBorderWidth() }],\n /**\n * Border Width Right\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-r': [{ 'border-r': scaleBorderWidth() }],\n /**\n * Border Width Bottom\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-b': [{ 'border-b': scaleBorderWidth() }],\n /**\n * Border Width Left\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-l': [{ 'border-l': scaleBorderWidth() }],\n /**\n * Divide Width X\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x': [{ 'divide-x': scaleBorderWidth() }],\n /**\n * Divide Width X Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x-reverse': ['divide-x-reverse'],\n /**\n * Divide Width Y\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y': [{ 'divide-y': scaleBorderWidth() }],\n /**\n * Divide Width Y Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y-reverse': ['divide-y-reverse'],\n /**\n * Border Style\n * @see https://tailwindcss.com/docs/border-style\n */\n 'border-style': [{ border: [...scaleLineStyle(), 'hidden', 'none'] }],\n /**\n * Divide Style\n * @see https://tailwindcss.com/docs/border-style#setting-the-divider-style\n */\n 'divide-style': [{ divide: [...scaleLineStyle(), 'hidden', 'none'] }],\n /**\n * Border Color\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color': [{ border: scaleColor() }],\n /**\n * Border Color Inline\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-x': [{ 'border-x': scaleColor() }],\n /**\n * Border Color Block\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-y': [{ 'border-y': scaleColor() }],\n /**\n * Border Color Inline Start\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-s': [{ 'border-s': scaleColor() }],\n /**\n * Border Color Inline End\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-e': [{ 'border-e': scaleColor() }],\n /**\n * Border Color Block Start\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-bs': [{ 'border-bs': scaleColor() }],\n /**\n * Border Color Block End\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-be': [{ 'border-be': scaleColor() }],\n /**\n * Border Color Top\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-t': [{ 'border-t': scaleColor() }],\n /**\n * Border Color Right\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-r': [{ 'border-r': scaleColor() }],\n /**\n * Border Color Bottom\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-b': [{ 'border-b': scaleColor() }],\n /**\n * Border Color Left\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-l': [{ 'border-l': scaleColor() }],\n /**\n * Divide Color\n * @see https://tailwindcss.com/docs/divide-color\n */\n 'divide-color': [{ divide: scaleColor() }],\n /**\n * Outline Style\n * @see https://tailwindcss.com/docs/outline-style\n */\n 'outline-style': [{ outline: [...scaleLineStyle(), 'none', 'hidden'] }],\n /**\n * Outline Offset\n * @see https://tailwindcss.com/docs/outline-offset\n */\n 'outline-offset': [\n { 'outline-offset': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Outline Width\n * @see https://tailwindcss.com/docs/outline-width\n */\n 'outline-w': [\n { outline: ['', isNumber, isArbitraryVariableLength, isArbitraryLength] },\n ],\n /**\n * Outline Color\n * @see https://tailwindcss.com/docs/outline-color\n */\n 'outline-color': [{ outline: scaleColor() }],\n\n // ---------------\n // --- Effects ---\n // ---------------\n\n /**\n * Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow\n */\n shadow: [\n {\n shadow: [\n // Deprecated since Tailwind CSS v4.0.0\n '',\n 'none',\n themeShadow,\n isArbitraryVariableShadow,\n isArbitraryShadow,\n ],\n },\n ],\n /**\n * Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-shadow-color\n */\n 'shadow-color': [{ shadow: scaleColor() }],\n /**\n * Inset Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-shadow\n */\n 'inset-shadow': [\n {\n 'inset-shadow': [\n 'none',\n themeInsetShadow,\n isArbitraryVariableShadow,\n isArbitraryShadow,\n ],\n },\n ],\n /**\n * Inset Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-shadow-color\n */\n 'inset-shadow-color': [{ 'inset-shadow': scaleColor() }],\n /**\n * Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-a-ring\n */\n 'ring-w': [{ ring: scaleBorderWidth() }],\n /**\n * Ring Width Inset\n * @see https://v3.tailwindcss.com/docs/ring-width#inset-rings\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-w-inset': ['ring-inset'],\n /**\n * Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-ring-color\n */\n 'ring-color': [{ ring: scaleColor() }],\n /**\n * Ring Offset Width\n * @see https://v3.tailwindcss.com/docs/ring-offset-width\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-w': [{ 'ring-offset': [isNumber, isArbitraryLength] }],\n /**\n * Ring Offset Color\n * @see https://v3.tailwindcss.com/docs/ring-offset-color\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-color': [{ 'ring-offset': scaleColor() }],\n /**\n * Inset Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-ring\n */\n 'inset-ring-w': [{ 'inset-ring': scaleBorderWidth() }],\n /**\n * Inset Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-ring-color\n */\n 'inset-ring-color': [{ 'inset-ring': scaleColor() }],\n /**\n * Text Shadow\n * @see https://tailwindcss.com/docs/text-shadow\n */\n 'text-shadow': [\n {\n 'text-shadow': [\n 'none',\n themeTextShadow,\n isArbitraryVariableShadow,\n isArbitraryShadow,\n ],\n },\n ],\n /**\n * Text Shadow Color\n * @see https://tailwindcss.com/docs/text-shadow#setting-the-shadow-color\n */\n 'text-shadow-color': [{ 'text-shadow': scaleColor() }],\n /**\n * Opacity\n * @see https://tailwindcss.com/docs/opacity\n */\n opacity: [{ opacity: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Mix Blend Mode\n * @see https://tailwindcss.com/docs/mix-blend-mode\n */\n 'mix-blend': [{ 'mix-blend': [...scaleBlendMode(), 'plus-darker', 'plus-lighter'] }],\n /**\n * Background Blend Mode\n * @see https://tailwindcss.com/docs/background-blend-mode\n */\n 'bg-blend': [{ 'bg-blend': scaleBlendMode() }],\n /**\n * Mask Clip\n * @see https://tailwindcss.com/docs/mask-clip\n */\n 'mask-clip': [\n { 'mask-clip': ['border', 'padding', 'content', 'fill', 'stroke', 'view'] },\n 'mask-no-clip',\n ],\n /**\n * Mask Composite\n * @see https://tailwindcss.com/docs/mask-composite\n */\n 'mask-composite': [{ mask: ['add', 'subtract', 'intersect', 'exclude'] }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image-linear-pos': [{ 'mask-linear': [isNumber] }],\n 'mask-image-linear-from-pos': [{ 'mask-linear-from': scaleMaskImagePosition() }],\n 'mask-image-linear-to-pos': [{ 'mask-linear-to': scaleMaskImagePosition() }],\n 'mask-image-linear-from-color': [{ 'mask-linear-from': scaleColor() }],\n 'mask-image-linear-to-color': [{ 'mask-linear-to': scaleColor() }],\n 'mask-image-t-from-pos': [{ 'mask-t-from': scaleMaskImagePosition() }],\n 'mask-image-t-to-pos': [{ 'mask-t-to': scaleMaskImagePosition() }],\n 'mask-image-t-from-color': [{ 'mask-t-from': scaleColor() }],\n 'mask-image-t-to-color': [{ 'mask-t-to': scaleColor() }],\n 'mask-image-r-from-pos': [{ 'mask-r-from': scaleMaskImagePosition() }],\n 'mask-image-r-to-pos': [{ 'mask-r-to': scaleMaskImagePosition() }],\n 'mask-image-r-from-color': [{ 'mask-r-from': scaleColor() }],\n 'mask-image-r-to-color': [{ 'mask-r-to': scaleColor() }],\n 'mask-image-b-from-pos': [{ 'mask-b-from': scaleMaskImagePosition() }],\n 'mask-image-b-to-pos': [{ 'mask-b-to': scaleMaskImagePosition() }],\n 'mask-image-b-from-color': [{ 'mask-b-from': scaleColor() }],\n 'mask-image-b-to-color': [{ 'mask-b-to': scaleColor() }],\n 'mask-image-l-from-pos': [{ 'mask-l-from': scaleMaskImagePosition() }],\n 'mask-image-l-to-pos': [{ 'mask-l-to': scaleMaskImagePosition() }],\n 'mask-image-l-from-color': [{ 'mask-l-from': scaleColor() }],\n 'mask-image-l-to-color': [{ 'mask-l-to': scaleColor() }],\n 'mask-image-x-from-pos': [{ 'mask-x-from': scaleMaskImagePosition() }],\n 'mask-image-x-to-pos': [{ 'mask-x-to': scaleMaskImagePosition() }],\n 'mask-image-x-from-color': [{ 'mask-x-from': scaleColor() }],\n 'mask-image-x-to-color': [{ 'mask-x-to': scaleColor() }],\n 'mask-image-y-from-pos': [{ 'mask-y-from': scaleMaskImagePosition() }],\n 'mask-image-y-to-pos': [{ 'mask-y-to': scaleMaskImagePosition() }],\n 'mask-image-y-from-color': [{ 'mask-y-from': scaleColor() }],\n 'mask-image-y-to-color': [{ 'mask-y-to': scaleColor() }],\n 'mask-image-radial': [{ 'mask-radial': [isArbitraryVariable, isArbitraryValue] }],\n 'mask-image-radial-from-pos': [{ 'mask-radial-from': scaleMaskImagePosition() }],\n 'mask-image-radial-to-pos': [{ 'mask-radial-to': scaleMaskImagePosition() }],\n 'mask-image-radial-from-color': [{ 'mask-radial-from': scaleColor() }],\n 'mask-image-radial-to-color': [{ 'mask-radial-to': scaleColor() }],\n 'mask-image-radial-shape': [{ 'mask-radial': ['circle', 'ellipse'] }],\n 'mask-image-radial-size': [\n { 'mask-radial': [{ closest: ['side', 'corner'], farthest: ['side', 'corner'] }] },\n ],\n 'mask-image-radial-pos': [{ 'mask-radial-at': scalePosition() }],\n 'mask-image-conic-pos': [{ 'mask-conic': [isNumber] }],\n 'mask-image-conic-from-pos': [{ 'mask-conic-from': scaleMaskImagePosition() }],\n 'mask-image-conic-to-pos': [{ 'mask-conic-to': scaleMaskImagePosition() }],\n 'mask-image-conic-from-color': [{ 'mask-conic-from': scaleColor() }],\n 'mask-image-conic-to-color': [{ 'mask-conic-to': scaleColor() }],\n /**\n * Mask Mode\n * @see https://tailwindcss.com/docs/mask-mode\n */\n 'mask-mode': [{ mask: ['alpha', 'luminance', 'match'] }],\n /**\n * Mask Origin\n * @see https://tailwindcss.com/docs/mask-origin\n */\n 'mask-origin': [\n { 'mask-origin': ['border', 'padding', 'content', 'fill', 'stroke', 'view'] },\n ],\n /**\n * Mask Position\n * @see https://tailwindcss.com/docs/mask-position\n */\n 'mask-position': [{ mask: scaleBgPosition() }],\n /**\n * Mask Repeat\n * @see https://tailwindcss.com/docs/mask-repeat\n */\n 'mask-repeat': [{ mask: scaleBgRepeat() }],\n /**\n * Mask Size\n * @see https://tailwindcss.com/docs/mask-size\n */\n 'mask-size': [{ mask: scaleBgSize() }],\n /**\n * Mask Type\n * @see https://tailwindcss.com/docs/mask-type\n */\n 'mask-type': [{ 'mask-type': ['alpha', 'luminance'] }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image': [{ mask: ['none', isArbitraryVariable, isArbitraryValue] }],\n\n // ---------------\n // --- Filters ---\n // ---------------\n\n /**\n * Filter\n * @see https://tailwindcss.com/docs/filter\n */\n filter: [\n {\n filter: [\n // Deprecated since Tailwind CSS v3.0.0\n '',\n 'none',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Blur\n * @see https://tailwindcss.com/docs/blur\n */\n blur: [{ blur: scaleBlur() }],\n /**\n * Brightness\n * @see https://tailwindcss.com/docs/brightness\n */\n brightness: [{ brightness: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Contrast\n * @see https://tailwindcss.com/docs/contrast\n */\n contrast: [{ contrast: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Drop Shadow\n * @see https://tailwindcss.com/docs/drop-shadow\n */\n 'drop-shadow': [\n {\n 'drop-shadow': [\n // Deprecated since Tailwind CSS v4.0.0\n '',\n 'none',\n themeDropShadow,\n isArbitraryVariableShadow,\n isArbitraryShadow,\n ],\n },\n ],\n /**\n * Drop Shadow Color\n * @see https://tailwindcss.com/docs/filter-drop-shadow#setting-the-shadow-color\n */\n 'drop-shadow-color': [{ 'drop-shadow': scaleColor() }],\n /**\n * Grayscale\n * @see https://tailwindcss.com/docs/grayscale\n */\n grayscale: [{ grayscale: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Hue Rotate\n * @see https://tailwindcss.com/docs/hue-rotate\n */\n 'hue-rotate': [{ 'hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Invert\n * @see https://tailwindcss.com/docs/invert\n */\n invert: [{ invert: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Saturate\n * @see https://tailwindcss.com/docs/saturate\n */\n saturate: [{ saturate: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Sepia\n * @see https://tailwindcss.com/docs/sepia\n */\n sepia: [{ sepia: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Backdrop Filter\n * @see https://tailwindcss.com/docs/backdrop-filter\n */\n 'backdrop-filter': [\n {\n 'backdrop-filter': [\n // Deprecated since Tailwind CSS v3.0.0\n '',\n 'none',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Backdrop Blur\n * @see https://tailwindcss.com/docs/backdrop-blur\n */\n 'backdrop-blur': [{ 'backdrop-blur': scaleBlur() }],\n /**\n * Backdrop Brightness\n * @see https://tailwindcss.com/docs/backdrop-brightness\n */\n 'backdrop-brightness': [\n { 'backdrop-brightness': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Contrast\n * @see https://tailwindcss.com/docs/backdrop-contrast\n */\n 'backdrop-contrast': [\n { 'backdrop-contrast': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Grayscale\n * @see https://tailwindcss.com/docs/backdrop-grayscale\n */\n 'backdrop-grayscale': [\n { 'backdrop-grayscale': ['', isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Hue Rotate\n * @see https://tailwindcss.com/docs/backdrop-hue-rotate\n */\n 'backdrop-hue-rotate': [\n { 'backdrop-hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Invert\n * @see https://tailwindcss.com/docs/backdrop-invert\n */\n 'backdrop-invert': [\n { 'backdrop-invert': ['', isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Opacity\n * @see https://tailwindcss.com/docs/backdrop-opacity\n */\n 'backdrop-opacity': [\n { 'backdrop-opacity': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Saturate\n * @see https://tailwindcss.com/docs/backdrop-saturate\n */\n 'backdrop-saturate': [\n { 'backdrop-saturate': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Sepia\n * @see https://tailwindcss.com/docs/backdrop-sepia\n */\n 'backdrop-sepia': [\n { 'backdrop-sepia': ['', isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n\n // --------------\n // --- Tables ---\n // --------------\n\n /**\n * Border Collapse\n * @see https://tailwindcss.com/docs/border-collapse\n */\n 'border-collapse': [{ border: ['collapse', 'separate'] }],\n /**\n * Border Spacing\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing': [{ 'border-spacing': scaleUnambiguousSpacing() }],\n /**\n * Border Spacing X\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-x': [{ 'border-spacing-x': scaleUnambiguousSpacing() }],\n /**\n * Border Spacing Y\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-y': [{ 'border-spacing-y': scaleUnambiguousSpacing() }],\n /**\n * Table Layout\n * @see https://tailwindcss.com/docs/table-layout\n */\n 'table-layout': [{ table: ['auto', 'fixed'] }],\n /**\n * Caption Side\n * @see https://tailwindcss.com/docs/caption-side\n */\n caption: [{ caption: ['top', 'bottom'] }],\n\n // ---------------------------------\n // --- Transitions and Animation ---\n // ---------------------------------\n\n /**\n * Transition Property\n * @see https://tailwindcss.com/docs/transition-property\n */\n transition: [\n {\n transition: [\n '',\n 'all',\n 'colors',\n 'opacity',\n 'shadow',\n 'transform',\n 'none',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Transition Behavior\n * @see https://tailwindcss.com/docs/transition-behavior\n */\n 'transition-behavior': [{ transition: ['normal', 'discrete'] }],\n /**\n * Transition Duration\n * @see https://tailwindcss.com/docs/transition-duration\n */\n duration: [{ duration: [isNumber, 'initial', isArbitraryVariable, isArbitraryValue] }],\n /**\n * Transition Timing Function\n * @see https://tailwindcss.com/docs/transition-timing-function\n */\n ease: [\n { ease: ['linear', 'initial', themeEase, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Transition Delay\n * @see https://tailwindcss.com/docs/transition-delay\n */\n delay: [{ delay: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Animation\n * @see https://tailwindcss.com/docs/animation\n */\n animate: [{ animate: ['none', themeAnimate, isArbitraryVariable, isArbitraryValue] }],\n\n // ------------------\n // --- Transforms ---\n // ------------------\n\n /**\n * Backface Visibility\n * @see https://tailwindcss.com/docs/backface-visibility\n */\n backface: [{ backface: ['hidden', 'visible'] }],\n /**\n * Perspective\n * @see https://tailwindcss.com/docs/perspective\n */\n perspective: [\n { perspective: [themePerspective, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Perspective Origin\n * @see https://tailwindcss.com/docs/perspective-origin\n */\n 'perspective-origin': [{ 'perspective-origin': scalePositionWithArbitrary() }],\n /**\n * Rotate\n * @see https://tailwindcss.com/docs/rotate\n */\n rotate: [{ rotate: scaleRotate() }],\n /**\n * Rotate X\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-x': [{ 'rotate-x': scaleRotate() }],\n /**\n * Rotate Y\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-y': [{ 'rotate-y': scaleRotate() }],\n /**\n * Rotate Z\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-z': [{ 'rotate-z': scaleRotate() }],\n /**\n * Scale\n * @see https://tailwindcss.com/docs/scale\n */\n scale: [{ scale: scaleScale() }],\n /**\n * Scale X\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-x': [{ 'scale-x': scaleScale() }],\n /**\n * Scale Y\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-y': [{ 'scale-y': scaleScale() }],\n /**\n * Scale Z\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-z': [{ 'scale-z': scaleScale() }],\n /**\n * Scale 3D\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-3d': ['scale-3d'],\n /**\n * Skew\n * @see https://tailwindcss.com/docs/skew\n */\n skew: [{ skew: scaleSkew() }],\n /**\n * Skew X\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-x': [{ 'skew-x': scaleSkew() }],\n /**\n * Skew Y\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-y': [{ 'skew-y': scaleSkew() }],\n /**\n * Transform\n * @see https://tailwindcss.com/docs/transform\n */\n transform: [\n { transform: [isArbitraryVariable, isArbitraryValue, '', 'none', 'gpu', 'cpu'] },\n ],\n /**\n * Transform Origin\n * @see https://tailwindcss.com/docs/transform-origin\n */\n 'transform-origin': [{ origin: scalePositionWithArbitrary() }],\n /**\n * Transform Style\n * @see https://tailwindcss.com/docs/transform-style\n */\n 'transform-style': [{ transform: ['3d', 'flat'] }],\n /**\n * Translate\n * @see https://tailwindcss.com/docs/translate\n */\n translate: [{ translate: scaleTranslate() }],\n /**\n * Translate X\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-x': [{ 'translate-x': scaleTranslate() }],\n /**\n * Translate Y\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-y': [{ 'translate-y': scaleTranslate() }],\n /**\n * Translate Z\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-z': [{ 'translate-z': scaleTranslate() }],\n /**\n * Translate None\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-none': ['translate-none'],\n\n // ---------------------\n // --- Interactivity ---\n // ---------------------\n\n /**\n * Accent Color\n * @see https://tailwindcss.com/docs/accent-color\n */\n accent: [{ accent: scaleColor() }],\n /**\n * Appearance\n * @see https://tailwindcss.com/docs/appearance\n */\n appearance: [{ appearance: ['none', 'auto'] }],\n /**\n * Caret Color\n * @see https://tailwindcss.com/docs/just-in-time-mode#caret-color-utilities\n */\n 'caret-color': [{ caret: scaleColor() }],\n /**\n * Color Scheme\n * @see https://tailwindcss.com/docs/color-scheme\n */\n 'color-scheme': [\n { scheme: ['normal', 'dark', 'light', 'light-dark', 'only-dark', 'only-light'] },\n ],\n /**\n * Cursor\n * @see https://tailwindcss.com/docs/cursor\n */\n cursor: [\n {\n cursor: [\n 'auto',\n 'default',\n 'pointer',\n 'wait',\n 'text',\n 'move',\n 'help',\n 'not-allowed',\n 'none',\n 'context-menu',\n 'progress',\n 'cell',\n 'crosshair',\n 'vertical-text',\n 'alias',\n 'copy',\n 'no-drop',\n 'grab',\n 'grabbing',\n 'all-scroll',\n 'col-resize',\n 'row-resize',\n 'n-resize',\n 'e-resize',\n 's-resize',\n 'w-resize',\n 'ne-resize',\n 'nw-resize',\n 'se-resize',\n 'sw-resize',\n 'ew-resize',\n 'ns-resize',\n 'nesw-resize',\n 'nwse-resize',\n 'zoom-in',\n 'zoom-out',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Field Sizing\n * @see https://tailwindcss.com/docs/field-sizing\n */\n 'field-sizing': [{ 'field-sizing': ['fixed', 'content'] }],\n /**\n * Pointer Events\n * @see https://tailwindcss.com/docs/pointer-events\n */\n 'pointer-events': [{ 'pointer-events': ['auto', 'none'] }],\n /**\n * Resize\n * @see https://tailwindcss.com/docs/resize\n */\n resize: [{ resize: ['none', '', 'y', 'x'] }],\n /**\n * Scroll Behavior\n * @see https://tailwindcss.com/docs/scroll-behavior\n */\n 'scroll-behavior': [{ scroll: ['auto', 'smooth'] }],\n /**\n * Scroll Margin\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-m': [{ 'scroll-m': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Inline\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mx': [{ 'scroll-mx': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Block\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-my': [{ 'scroll-my': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Inline Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ms': [{ 'scroll-ms': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Inline End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-me': [{ 'scroll-me': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Block Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mbs': [{ 'scroll-mbs': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Block End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mbe': [{ 'scroll-mbe': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Top\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mt': [{ 'scroll-mt': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Right\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mr': [{ 'scroll-mr': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Bottom\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mb': [{ 'scroll-mb': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Left\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ml': [{ 'scroll-ml': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-p': [{ 'scroll-p': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Inline\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-px': [{ 'scroll-px': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Block\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-py': [{ 'scroll-py': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Inline Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-ps': [{ 'scroll-ps': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Inline End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pe': [{ 'scroll-pe': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Block Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pbs': [{ 'scroll-pbs': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Block End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pbe': [{ 'scroll-pbe': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Top\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pt': [{ 'scroll-pt': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Right\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pr': [{ 'scroll-pr': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Bottom\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pb': [{ 'scroll-pb': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Left\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pl': [{ 'scroll-pl': scaleUnambiguousSpacing() }],\n /**\n * Scroll Snap Align\n * @see https://tailwindcss.com/docs/scroll-snap-align\n */\n 'snap-align': [{ snap: ['start', 'end', 'center', 'align-none'] }],\n /**\n * Scroll Snap Stop\n * @see https://tailwindcss.com/docs/scroll-snap-stop\n */\n 'snap-stop': [{ snap: ['normal', 'always'] }],\n /**\n * Scroll Snap Type\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-type': [{ snap: ['none', 'x', 'y', 'both'] }],\n /**\n * Scroll Snap Type Strictness\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-strictness': [{ snap: ['mandatory', 'proximity'] }],\n /**\n * Touch Action\n * @see https://tailwindcss.com/docs/touch-action\n */\n touch: [{ touch: ['auto', 'none', 'manipulation'] }],\n /**\n * Touch Action X\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-x': [{ 'touch-pan': ['x', 'left', 'right'] }],\n /**\n * Touch Action Y\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-y': [{ 'touch-pan': ['y', 'up', 'down'] }],\n /**\n * Touch Action Pinch Zoom\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-pz': ['touch-pinch-zoom'],\n /**\n * User Select\n * @see https://tailwindcss.com/docs/user-select\n */\n select: [{ select: ['none', 'text', 'all', 'auto'] }],\n /**\n * Will Change\n * @see https://tailwindcss.com/docs/will-change\n */\n 'will-change': [\n {\n 'will-change': [\n 'auto',\n 'scroll',\n 'contents',\n 'transform',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n\n // -----------\n // --- SVG ---\n // -----------\n\n /**\n * Fill\n * @see https://tailwindcss.com/docs/fill\n */\n fill: [{ fill: ['none', ...scaleColor()] }],\n /**\n * Stroke Width\n * @see https://tailwindcss.com/docs/stroke-width\n */\n 'stroke-w': [\n {\n stroke: [\n isNumber,\n isArbitraryVariableLength,\n isArbitraryLength,\n isArbitraryNumber,\n ],\n },\n ],\n /**\n * Stroke\n * @see https://tailwindcss.com/docs/stroke\n */\n stroke: [{ stroke: ['none', ...scaleColor()] }],\n\n // ---------------------\n // --- Accessibility ---\n // ---------------------\n\n /**\n * Forced Color Adjust\n * @see https://tailwindcss.com/docs/forced-color-adjust\n */\n 'forced-color-adjust': [{ 'forced-color-adjust': ['auto', 'none'] }],\n },\n conflictingClassGroups: {\n overflow: ['overflow-x', 'overflow-y'],\n overscroll: ['overscroll-x', 'overscroll-y'],\n inset: [\n 'inset-x',\n 'inset-y',\n 'inset-bs',\n 'inset-be',\n 'start',\n 'end',\n 'top',\n 'right',\n 'bottom',\n 'left',\n ],\n 'inset-x': ['right', 'left'],\n 'inset-y': ['top', 'bottom'],\n flex: ['basis', 'grow', 'shrink'],\n gap: ['gap-x', 'gap-y'],\n p: ['px', 'py', 'ps', 'pe', 'pbs', 'pbe', 'pt', 'pr', 'pb', 'pl'],\n px: ['pr', 'pl'],\n py: ['pt', 'pb'],\n m: ['mx', 'my', 'ms', 'me', 'mbs', 'mbe', 'mt', 'mr', 'mb', 'ml'],\n mx: ['mr', 'ml'],\n my: ['mt', 'mb'],\n size: ['w', 'h'],\n 'font-size': ['leading'],\n 'fvn-normal': [\n 'fvn-ordinal',\n 'fvn-slashed-zero',\n 'fvn-figure',\n 'fvn-spacing',\n 'fvn-fraction',\n ],\n 'fvn-ordinal': ['fvn-normal'],\n 'fvn-slashed-zero': ['fvn-normal'],\n 'fvn-figure': ['fvn-normal'],\n 'fvn-spacing': ['fvn-normal'],\n 'fvn-fraction': ['fvn-normal'],\n 'line-clamp': ['display', 'overflow'],\n rounded: [\n 'rounded-s',\n 'rounded-e',\n 'rounded-t',\n 'rounded-r',\n 'rounded-b',\n 'rounded-l',\n 'rounded-ss',\n 'rounded-se',\n 'rounded-ee',\n 'rounded-es',\n 'rounded-tl',\n 'rounded-tr',\n 'rounded-br',\n 'rounded-bl',\n ],\n 'rounded-s': ['rounded-ss', 'rounded-es'],\n 'rounded-e': ['rounded-se', 'rounded-ee'],\n 'rounded-t': ['rounded-tl', 'rounded-tr'],\n 'rounded-r': ['rounded-tr', 'rounded-br'],\n 'rounded-b': ['rounded-br', 'rounded-bl'],\n 'rounded-l': ['rounded-tl', 'rounded-bl'],\n 'border-spacing': ['border-spacing-x', 'border-spacing-y'],\n 'border-w': [\n 'border-w-x',\n 'border-w-y',\n 'border-w-s',\n 'border-w-e',\n 'border-w-bs',\n 'border-w-be',\n 'border-w-t',\n 'border-w-r',\n 'border-w-b',\n 'border-w-l',\n ],\n 'border-w-x': ['border-w-r', 'border-w-l'],\n 'border-w-y': ['border-w-t', 'border-w-b'],\n 'border-color': [\n 'border-color-x',\n 'border-color-y',\n 'border-color-s',\n 'border-color-e',\n 'border-color-bs',\n 'border-color-be',\n 'border-color-t',\n 'border-color-r',\n 'border-color-b',\n 'border-color-l',\n ],\n 'border-color-x': ['border-color-r', 'border-color-l'],\n 'border-color-y': ['border-color-t', 'border-color-b'],\n translate: ['translate-x', 'translate-y', 'translate-none'],\n 'translate-none': ['translate', 'translate-x', 'translate-y', 'translate-z'],\n 'scroll-m': [\n 'scroll-mx',\n 'scroll-my',\n 'scroll-ms',\n 'scroll-me',\n 'scroll-mbs',\n 'scroll-mbe',\n 'scroll-mt',\n 'scroll-mr',\n 'scroll-mb',\n 'scroll-ml',\n ],\n 'scroll-mx': ['scroll-mr', 'scroll-ml'],\n 'scroll-my': ['scroll-mt', 'scroll-mb'],\n 'scroll-p': [\n 'scroll-px',\n 'scroll-py',\n 'scroll-ps',\n 'scroll-pe',\n 'scroll-pbs',\n 'scroll-pbe',\n 'scroll-pt',\n 'scroll-pr',\n 'scroll-pb',\n 'scroll-pl',\n ],\n 'scroll-px': ['scroll-pr', 'scroll-pl'],\n 'scroll-py': ['scroll-pt', 'scroll-pb'],\n touch: ['touch-x', 'touch-y', 'touch-pz'],\n 'touch-x': ['touch'],\n 'touch-y': ['touch'],\n 'touch-pz': ['touch'],\n },\n conflictingClassGroupModifiers: {\n 'font-size': ['leading'],\n },\n orderSensitiveModifiers: [\n '*',\n '**',\n 'after',\n 'backdrop',\n 'before',\n 'details-content',\n 'file',\n 'first-letter',\n 'first-line',\n 'marker',\n 'placeholder',\n 'selection',\n ],\n } as const satisfies Config<DefaultClassGroupIds, DefaultThemeGroupIds>\n}\n","import { AnyConfig, ConfigExtension, NoInfer } from './types'\n\n/**\n * @param baseConfig Config where other config will be merged into. This object will be mutated.\n * @param configExtension Partial config to merge into the `baseConfig`.\n */\nexport const mergeConfigs = <ClassGroupIds extends string, ThemeGroupIds extends string = never>(\n baseConfig: AnyConfig,\n {\n cacheSize,\n prefix,\n experimentalParseClassName,\n extend = {},\n override = {},\n }: ConfigExtension<ClassGroupIds, ThemeGroupIds>,\n) => {\n overrideProperty(baseConfig, 'cacheSize', cacheSize)\n overrideProperty(baseConfig, 'prefix', prefix)\n overrideProperty(baseConfig, 'experimentalParseClassName', experimentalParseClassName)\n\n overrideConfigProperties(baseConfig.theme, override.theme)\n overrideConfigProperties(baseConfig.classGroups, override.classGroups)\n overrideConfigProperties(baseConfig.conflictingClassGroups, override.conflictingClassGroups)\n overrideConfigProperties(\n baseConfig.conflictingClassGroupModifiers,\n override.conflictingClassGroupModifiers,\n )\n overrideProperty(baseConfig, 'orderSensitiveModifiers', override.orderSensitiveModifiers)\n\n mergeConfigProperties(baseConfig.theme, extend.theme)\n mergeConfigProperties(baseConfig.classGroups, extend.classGroups)\n mergeConfigProperties(baseConfig.conflictingClassGroups, extend.conflictingClassGroups)\n mergeConfigProperties(\n baseConfig.conflictingClassGroupModifiers,\n extend.conflictingClassGroupModifiers,\n )\n mergeArrayProperties(baseConfig, extend, 'orderSensitiveModifiers')\n\n return baseConfig\n}\n\nconst overrideProperty = <T extends object, K extends keyof T>(\n baseObject: T,\n overrideKey: K,\n overrideValue: T[K] | undefined,\n) => {\n if (overrideValue !== undefined) {\n baseObject[overrideKey] = overrideValue\n }\n}\n\nconst overrideConfigProperties = (\n baseObject: Partial<Record<string, readonly unknown[]>>,\n overrideObject: Partial<Record<string, readonly unknown[]>> | undefined,\n) => {\n if (overrideObject) {\n for (const key in overrideObject) {\n overrideProperty(baseObject, key, overrideObject[key])\n }\n }\n}\n\nconst mergeConfigProperties = (\n baseObject: Partial<Record<string, readonly unknown[]>>,\n mergeObject: Partial<Record<string, readonly unknown[]>> | undefined,\n) => {\n if (mergeObject) {\n for (const key in mergeObject) {\n mergeArrayProperties(baseObject, mergeObject, key)\n }\n }\n}\n\nconst mergeArrayProperties = <Key extends string>(\n baseObject: Partial<Record<NoInfer<Key>, readonly unknown[]>>,\n mergeObject: Partial<Record<NoInfer<Key>, readonly unknown[]>>,\n key: Key,\n) => {\n const mergeValue = mergeObject[key]\n\n if (mergeValue !== undefined) {\n baseObject[key] = baseObject[key] ? baseObject[key].concat(mergeValue) : mergeValue\n }\n}\n","import { createTailwindMerge } from './create-tailwind-merge'\nimport { getDefaultConfig } from './default-config'\nimport { mergeConfigs } from './merge-configs'\nimport { AnyConfig, ConfigExtension, DefaultClassGroupIds, DefaultThemeGroupIds } from './types'\n\ntype CreateConfigSubsequent = (config: AnyConfig) => AnyConfig\n\nexport const extendTailwindMerge = <\n AdditionalClassGroupIds extends string = never,\n AdditionalThemeGroupIds extends string = never,\n>(\n configExtension:\n | ConfigExtension<\n DefaultClassGroupIds | AdditionalClassGroupIds,\n DefaultThemeGroupIds | AdditionalThemeGroupIds\n >\n | CreateConfigSubsequent,\n ...createConfig: CreateConfigSubsequent[]\n) =>\n typeof configExtension === 'function'\n ? createTailwindMerge(getDefaultConfig, configExtension, ...createConfig)\n : createTailwindMerge(\n () => mergeConfigs(getDefaultConfig(), configExtension),\n ...createConfig,\n )\n","import { createTailwindMerge } from './create-tailwind-merge'\nimport { getDefaultConfig } from './default-config'\n\nexport const twMerge = createTailwindMerge(getDefaultConfig)\n","import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type AlertVariant = \"soft\" | \"outline\" | \"filled\";\nexport type AlertColor = \"default\" | \"primary\" | \"danger\" | \"success\" | \"warning\" | \"info\";\nexport type AlertSize = \"sm\" | \"md\";\n\nexport interface AlertProps {\n variant?: AlertVariant;\n color?: AlertColor;\n size?: AlertSize;\n icon?: React.ReactNode;\n title?: React.ReactNode;\n dismissible?: boolean;\n onDismiss?: () => void;\n className?: string;\n children?: React.ReactNode;\n}\n\n// ── Icons ────────────────────────────────────\n\nfunction XIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<AlertSize, { padding: string; font: string; titleFont: string; iconSize: string; gap: string }> = {\n sm: { padding: \"px-3 py-2.5\", font: \"text-xs\", titleFont: \"text-sm\", iconSize: \"size-4\", gap: \"gap-2.5\" },\n md: { padding: \"px-4 py-3.5\", font: \"text-sm\", titleFont: \"text-base\", iconSize: \"size-5\", gap: \"gap-3\" },\n};\n\n// ── Color definitions ────────────────────────\n\ninterface AlertColorDef {\n soft: string;\n outline: string;\n filled: string;\n icon: string;\n filledIcon: string;\n dismissHover: string;\n filledDismissHover: string;\n}\n\nconst COLORS: Record<AlertColor, AlertColorDef> = {\n default: {\n soft: \"bg-zinc-50 text-zinc-700 border border-zinc-200\",\n outline: \"bg-transparent text-zinc-700 border border-zinc-300\",\n filled: \"bg-zinc-900 text-zinc-100 border border-zinc-900\",\n icon: \"text-zinc-500\",\n filledIcon: \"text-zinc-300\",\n dismissHover: \"hover:bg-zinc-200 hover:text-zinc-900\",\n filledDismissHover: \"hover:bg-zinc-700 hover:text-white\",\n },\n primary: {\n soft: \"bg-blue-50 text-blue-800 border border-blue-100\",\n outline: \"bg-transparent text-blue-700 border border-blue-300\",\n filled: \"bg-blue-600 text-white border border-blue-600\",\n icon: \"text-blue-500\",\n filledIcon: \"text-blue-200\",\n dismissHover: \"hover:bg-blue-100 hover:text-blue-900\",\n filledDismissHover: \"hover:bg-blue-500 hover:text-white\",\n },\n danger: {\n soft: \"bg-red-50 text-red-800 border border-red-100\",\n outline: \"bg-transparent text-red-700 border border-red-300\",\n filled: \"bg-red-600 text-white border border-red-600\",\n icon: \"text-red-500\",\n filledIcon: \"text-red-200\",\n dismissHover: \"hover:bg-red-100 hover:text-red-900\",\n filledDismissHover: \"hover:bg-red-500 hover:text-white\",\n },\n success: {\n soft: \"bg-green-50 text-green-800 border border-green-100\",\n outline: \"bg-transparent text-green-700 border border-green-300\",\n filled: \"bg-green-600 text-white border border-green-600\",\n icon: \"text-green-500\",\n filledIcon: \"text-green-200\",\n dismissHover: \"hover:bg-green-100 hover:text-green-900\",\n filledDismissHover: \"hover:bg-green-500 hover:text-white\",\n },\n warning: {\n soft: \"bg-yellow-50 text-yellow-800 border border-yellow-100\",\n outline: \"bg-transparent text-yellow-700 border border-yellow-300\",\n filled: \"bg-yellow-500 text-white border border-yellow-500\",\n icon: \"text-yellow-500\",\n filledIcon: \"text-yellow-200\",\n dismissHover: \"hover:bg-yellow-100 hover:text-yellow-900\",\n filledDismissHover: \"hover:bg-yellow-400 hover:text-white\",\n },\n info: {\n soft: \"bg-indigo-50 text-indigo-800 border border-indigo-100\",\n outline: \"bg-transparent text-indigo-700 border border-indigo-300\",\n filled: \"bg-indigo-600 text-white border border-indigo-600\",\n icon: \"text-indigo-500\",\n filledIcon: \"text-indigo-200\",\n dismissHover: \"hover:bg-indigo-100 hover:text-indigo-900\",\n filledDismissHover: \"hover:bg-indigo-500 hover:text-white\",\n },\n};\n\n// ── Component ────────────────────────────────\n\nexport function Alert({\n variant = \"soft\",\n color = \"default\",\n size = \"md\",\n icon,\n title,\n dismissible = false,\n onDismiss,\n className,\n children,\n}: AlertProps) {\n const [dismissed, setDismissed] = React.useState(false);\n\n if (dismissed) return null;\n\n const s = SIZES[size];\n const c = COLORS[color];\n const isFilled = variant === \"filled\";\n\n const handleDismiss = () => {\n setDismissed(true);\n onDismiss?.();\n };\n\n return (\n <div\n role=\"alert\"\n className={cn(\n \"relative flex rounded-lg\",\n s.padding,\n s.gap,\n c[variant],\n className,\n )}\n >\n {icon && (\n <span className={cn(\"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full mt-0.5\", s.iconSize, isFilled ? c.filledIcon : c.icon)}>\n {icon}\n </span>\n )}\n\n <div className=\"flex-1 min-w-0\">\n {title && (\n <div className={cn(\"font-semibold leading-snug\", s.titleFont)}>\n {title}\n </div>\n )}\n {children && (\n <div className={cn(\"leading-relaxed\", s.font, title && \"mt-1\")}>\n {children}\n </div>\n )}\n </div>\n\n {dismissible && (\n <button\n type=\"button\"\n onClick={handleDismiss}\n className={cn(\n \"shrink-0 flex items-center justify-center size-5 rounded transition-colors cursor-pointer\",\n isFilled ? c.filledDismissHover : c.dismissHover,\n )}\n >\n <XIcon className=\"size-3.5\" />\n </button>\n )}\n </div>\n );\n}\n","import * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type BadgeVariant = \"solid\" | \"soft\" | \"outline\";\nexport type BadgeColor = \"default\" | \"black\" | \"primary\" | \"danger\" | \"success\" | \"warning\" | \"info\";\nexport type BadgeSize = \"xs\" | \"sm\" | \"md\";\nexport type BadgeShape = \"square\" | \"rounded\" | \"pill\";\n\nexport interface BadgeProps {\n variant?: BadgeVariant;\n color?: BadgeColor;\n size?: BadgeSize;\n shape?: BadgeShape;\n icon?: React.ReactNode;\n iconRight?: React.ReactNode;\n removable?: boolean;\n onRemove?: () => void;\n className?: string;\n children: React.ReactNode;\n}\n\n// ── X Icon ───────────────────────────────────\n\nfunction XIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<BadgeSize, { padding: string; font: string; iconSize: string; gap: string }> = {\n xs: { padding: \"px-1.5 py-0.5\", font: \"text-[10px]\", iconSize: \"size-2.5\", gap: \"gap-0.5\" },\n sm: { padding: \"px-2 py-0.5\", font: \"text-xs\", iconSize: \"size-3\", gap: \"gap-1\" },\n md: { padding: \"px-2.5 py-1\", font: \"text-sm\", iconSize: \"size-3.5\", gap: \"gap-1\" },\n};\n\n// ── Shape definitions ────────────────────────\n\nconst SHAPES: Record<BadgeShape, string> = {\n square: \"rounded\",\n rounded: \"rounded-md\",\n pill: \"rounded-full\",\n};\n\n// ── Color definitions ────────────────────────\n\ninterface BadgeColorDef {\n solid: string;\n soft: string;\n outline: string;\n removeHover: string;\n}\n\nconst COLORS: Record<BadgeColor, BadgeColorDef> = {\n default: {\n solid: \"bg-zinc-100 text-zinc-700 border border-zinc-200\",\n soft: \"bg-zinc-50 text-zinc-600 border border-zinc-100\",\n outline: \"bg-transparent text-zinc-600 border border-zinc-300\",\n removeHover: \"hover:text-zinc-900 hover:bg-zinc-200\",\n },\n black: {\n solid: \"bg-zinc-900 text-white border border-zinc-900\",\n soft: \"bg-zinc-100 text-zinc-800 border border-zinc-200\",\n outline: \"bg-transparent text-zinc-800 border border-zinc-300\",\n removeHover: \"hover:text-zinc-900 hover:bg-zinc-200\",\n },\n primary: {\n solid: \"bg-blue-500 text-white border border-blue-500\",\n soft: \"bg-blue-50 text-blue-700 border border-blue-100\",\n outline: \"bg-transparent text-blue-600 border border-blue-300\",\n removeHover: \"hover:text-blue-900 hover:bg-blue-100\",\n },\n danger: {\n solid: \"bg-red-500 text-white border border-red-500\",\n soft: \"bg-red-50 text-red-700 border border-red-100\",\n outline: \"bg-transparent text-red-600 border border-red-300\",\n removeHover: \"hover:text-red-900 hover:bg-red-100\",\n },\n success: {\n solid: \"bg-green-500 text-white border border-green-500\",\n soft: \"bg-green-50 text-green-700 border border-green-100\",\n outline: \"bg-transparent text-green-600 border border-green-300\",\n removeHover: \"hover:text-green-900 hover:bg-green-100\",\n },\n warning: {\n solid: \"bg-yellow-500 text-white border border-yellow-500\",\n soft: \"bg-yellow-50 text-yellow-700 border border-yellow-100\",\n outline: \"bg-transparent text-yellow-600 border border-yellow-300\",\n removeHover: \"hover:text-yellow-900 hover:bg-yellow-100\",\n },\n info: {\n solid: \"bg-indigo-500 text-white border border-indigo-500\",\n soft: \"bg-indigo-50 text-indigo-700 border border-indigo-100\",\n outline: \"bg-transparent text-indigo-600 border border-indigo-300\",\n removeHover: \"hover:text-indigo-900 hover:bg-indigo-100\",\n },\n};\n\n// ── Component ────────────────────────────────\n\nexport function Badge({\n variant = \"soft\",\n color = \"default\",\n size = \"sm\",\n shape = \"rounded\",\n icon,\n iconRight,\n removable = false,\n onRemove,\n className,\n children,\n}: BadgeProps) {\n const s = SIZES[size];\n const c = COLORS[color];\n\n return (\n <span\n className={cn(\n \"inline-flex items-center font-medium whitespace-nowrap\",\n s.padding,\n s.font,\n s.gap,\n SHAPES[shape],\n c[variant],\n className,\n )}\n >\n {icon && (\n <span className={cn(\"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full\", s.iconSize)}>\n {icon}\n </span>\n )}\n\n {children}\n\n {iconRight && !removable && (\n <span className={cn(\"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full\", s.iconSize)}>\n {iconRight}\n </span>\n )}\n\n {removable && (\n <button\n type=\"button\"\n onClick={onRemove}\n className={cn(\n \"shrink-0 flex items-center justify-center rounded-full transition-colors cursor-pointer -mr-0.5\",\n s.iconSize,\n c.removeHover,\n )}\n >\n <XIcon className=\"size-full\" />\n </button>\n )}\n </span>\n );\n}\n","import * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport interface BreadcrumbProps {\n children: React.ReactNode;\n className?: string;\n separator?: React.ReactNode;\n}\n\nexport interface BreadcrumbItemProps {\n children: React.ReactNode;\n href?: string;\n className?: string;\n isActive?: boolean;\n}\n\n// ── ChevronRight Icon ────────────────────────\n\nfunction ChevronRightIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n );\n}\n\n// ── Breadcrumb Root ──────────────────────────\n\nfunction BreadcrumbRoot({ children, className, separator }: BreadcrumbProps) {\n const items = React.Children.toArray(children);\n const defaultSeparator = <ChevronRightIcon className=\"size-3.5 text-zinc-400\" />;\n\n return (\n <nav aria-label=\"Breadcrumb\" className={cn(\"flex\", className)}>\n <ol className=\"flex flex-wrap items-center gap-1.5 text-sm text-zinc-500\">\n {items.map((child, index) => {\n const isLast = index === items.length - 1;\n return (\n <li key={index} className=\"flex items-center gap-1.5\">\n {child}\n {!isLast && (\n <span aria-hidden=\"true\" className=\"flex items-center justify-center\">\n {separator || defaultSeparator}\n </span>\n )}\n </li>\n );\n })}\n </ol>\n </nav>\n );\n}\n\n// ── Breadcrumb Item ──────────────────────────\n\nfunction BreadcrumbItem({ children, href, className, isActive }: BreadcrumbItemProps) {\n const baseClass = \"inline-flex items-center gap-1.5 font-medium transition-colors\";\n\n if (href && !isActive) {\n return (\n <a\n href={href}\n className={cn(baseClass, \"text-zinc-500 hover:text-zinc-900\", className)}\n >\n {children}\n </a>\n );\n }\n\n return (\n <span\n aria-current={isActive ? \"page\" : undefined}\n className={cn(baseClass, \"text-zinc-900\", className)}\n >\n {children}\n </span>\n );\n}\n\n// ── Export ────────────────────────────────────\n\nexport const Breadcrumb = Object.assign(BreadcrumbRoot, {\n Item: BreadcrumbItem,\n});\n","import * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type ButtonColor = \"default\" | \"black\" | \"primary\" | \"danger\" | \"success\" | \"warning\" | \"info\";\nexport type ButtonSize = \"xs\" | \"sm\" | \"md\";\nexport type ButtonShape = \"square\" | \"rounded\" | \"circle\";\nexport type ButtonVariant = \"solid\" | \"outline\" | \"ghost\";\n\nexport interface ButtonProps extends Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, \"active\"> {\n variant?: ButtonVariant;\n color?: ButtonColor;\n soft?: boolean;\n size?: ButtonSize;\n shape?: ButtonShape;\n icon?: React.ReactNode;\n iconRight?: React.ReactNode;\n loading?: boolean;\n active?: boolean;\n className?: string;\n}\n\n// ── Spinner ──────────────────────────────────\n\nfunction Spinner({ className }: { className?: string }) {\n return (\n <svg\n className={cn(\"animate-spin\", className)}\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n >\n <circle className=\"opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" />\n <path\n className=\"opacity-75\"\n fill=\"currentColor\"\n d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\"\n />\n </svg>\n );\n}\n\n// ── Boyut tanimlari ──────────────────────────\n\nconst SIZES: Record<ButtonSize, { height: string; square: string; padding: string; gap: string; font: string; iconSize: string }> = {\n xs: { height: \"h-8\", square: \"w-8\", padding: \"px-2\", gap: \"gap-1\", font: \"text-xs\", iconSize: \"size-3\" },\n sm: { height: \"h-10\", square: \"w-10\", padding: \"px-3\", gap: \"gap-1.5\", font: \"text-sm\", iconSize: \"size-3.5\" },\n md: { height: \"h-12\", square: \"w-12\", padding: \"px-4\", gap: \"gap-2\", font: \"text-base\", iconSize: \"size-4\" },\n};\n\n// ── Sekil tanimlari ──────────────────────────\n\nconst SHAPES: Record<ButtonShape, string> = {\n square: \"\",\n rounded: \"rounded-lg\",\n circle: \"rounded-full\",\n};\n\n// ── Renk tanimlari ───────────────────────────\n\ninterface ColorDef {\n base: string;\n hover: string;\n text: string;\n iconColor: string;\n}\n\nconst COLOR_DEFAULT_SOLID: ColorDef = {\n base: \"bg-white border border-zinc-100\",\n hover: \"hover:bg-zinc-100\",\n text: \"text-zinc-700\",\n iconColor: \"text-zinc-500\",\n};\n\nconst COLORS: Record<Exclude<ButtonColor, \"default\">, { solid: ColorDef; soft: ColorDef }> = {\n black: {\n solid: { base: \"bg-zinc-900 border border-zinc-900\", hover: \"hover:bg-zinc-800\", text: \"text-zinc-50\", iconColor: \"text-zinc-50\" },\n soft: { base: \"bg-zinc-100 border border-zinc-200\", hover: \"hover:bg-zinc-200\", text: \"text-zinc-800\", iconColor: \"text-zinc-600\" },\n },\n primary: {\n solid: { base: \"bg-blue-500 border border-blue-500\", hover: \"hover:bg-blue-600\", text: \"text-white\", iconColor: \"text-white\" },\n soft: { base: \"bg-blue-50 border border-blue-100\", hover: \"hover:bg-blue-100\", text: \"text-blue-600\", iconColor: \"text-blue-500\" },\n },\n danger: {\n solid: { base: \"bg-red-500 border border-red-500\", hover: \"hover:bg-red-600\", text: \"text-white\", iconColor: \"text-white\" },\n soft: { base: \"bg-red-100 border border-red-200\", hover: \"hover:bg-red-200\", text: \"text-red-600\", iconColor: \"text-red-500\" },\n },\n success: {\n solid: { base: \"bg-green-500 border border-green-500\", hover: \"hover:bg-green-600\", text: \"text-white\", iconColor: \"text-white\" },\n soft: { base: \"bg-green-50 border border-green-100\", hover: \"hover:bg-green-100\", text: \"text-green-600\", iconColor: \"text-green-500\" },\n },\n warning: {\n solid: { base: \"bg-yellow-500 border border-yellow-500\", hover: \"hover:bg-yellow-600\", text: \"text-white\", iconColor: \"text-white\" },\n soft: { base: \"bg-yellow-50 border border-yellow-100\", hover: \"hover:bg-yellow-100\", text: \"text-yellow-700\", iconColor: \"text-yellow-600\" },\n },\n info: {\n solid: { base: \"bg-indigo-500 border border-indigo-500\", hover: \"hover:bg-indigo-600\", text: \"text-white\", iconColor: \"text-white\" },\n soft: { base: \"bg-indigo-50 border border-indigo-100\", hover: \"hover:bg-indigo-100\", text: \"text-indigo-600\", iconColor: \"text-indigo-500\" },\n },\n};\n\nconst COLOR_DEFAULT_OUTLINE: ColorDef = {\n base: \"bg-transparent border border-zinc-200\",\n hover: \"hover:bg-zinc-50\",\n text: \"text-zinc-700\",\n iconColor: \"text-zinc-500\",\n};\n\nconst OUTLINE_COLORS: Record<Exclude<ButtonColor, \"default\">, ColorDef> = {\n black: { base: \"bg-transparent border border-zinc-300\", hover: \"hover:bg-zinc-50\", text: \"text-zinc-800\", iconColor: \"text-zinc-600\" },\n primary: { base: \"bg-transparent border border-blue-200\", hover: \"hover:bg-blue-50\", text: \"text-blue-600\", iconColor: \"text-blue-500\" },\n danger: { base: \"bg-transparent border border-red-200\", hover: \"hover:bg-red-50\", text: \"text-red-600\", iconColor: \"text-red-500\" },\n success: { base: \"bg-transparent border border-green-200\", hover: \"hover:bg-green-50\", text: \"text-green-600\", iconColor: \"text-green-500\" },\n warning: { base: \"bg-transparent border border-yellow-200\", hover: \"hover:bg-yellow-50\", text: \"text-yellow-700\", iconColor: \"text-yellow-600\" },\n info: { base: \"bg-transparent border border-indigo-200\", hover: \"hover:bg-indigo-50\", text: \"text-indigo-600\", iconColor: \"text-indigo-500\" },\n};\n\nconst COLOR_DEFAULT_GHOST: ColorDef = {\n base: \"bg-transparent\",\n hover: \"hover:bg-zinc-100\",\n text: \"text-zinc-500\",\n iconColor: \"text-zinc-500\",\n};\n\nconst GHOST_COLORS: Record<Exclude<ButtonColor, \"default\">, ColorDef> = {\n black: { base: \"bg-transparent\", hover: \"hover:bg-zinc-100\", text: \"text-zinc-800\", iconColor: \"text-zinc-600\" },\n primary: { base: \"bg-transparent\", hover: \"hover:bg-blue-50\", text: \"text-blue-600\", iconColor: \"text-blue-500\" },\n danger: { base: \"bg-transparent\", hover: \"hover:bg-red-50\", text: \"text-red-600\", iconColor: \"text-red-500\" },\n success: { base: \"bg-transparent\", hover: \"hover:bg-green-50\", text: \"text-green-600\", iconColor: \"text-green-500\" },\n warning: { base: \"bg-transparent\", hover: \"hover:bg-yellow-50\", text: \"text-yellow-700\", iconColor: \"text-yellow-600\" },\n info: { base: \"bg-transparent\", hover: \"hover:bg-indigo-50\", text: \"text-indigo-600\", iconColor: \"text-indigo-500\" },\n};\n\nconst ACTIVE_DEFAULT = \"bg-zinc-50 border border-zinc-300\";\n\n// ── Yardimci: renk stillerini resolve et ─────\n\nfunction resolveColor(color: ButtonColor, soft: boolean, active: boolean, variant: ButtonVariant): ColorDef {\n if (active && color === \"default\") {\n return { ...COLOR_DEFAULT_SOLID, base: ACTIVE_DEFAULT };\n }\n\n if (color === \"default\") {\n if (variant === \"ghost\") return COLOR_DEFAULT_GHOST;\n if (variant === \"outline\") return COLOR_DEFAULT_OUTLINE;\n return COLOR_DEFAULT_SOLID;\n }\n\n if (variant === \"ghost\") return GHOST_COLORS[color];\n if (variant === \"outline\") return OUTLINE_COLORS[color];\n\n return soft ? COLORS[color].soft : COLORS[color].solid;\n}\n\n// ── Bilesen ──────────────────────────────────\n\nexport const Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n (\n {\n variant = \"solid\",\n color = \"default\",\n soft = false,\n size = \"sm\",\n shape = \"rounded\",\n icon,\n iconRight,\n loading = false,\n active = false,\n disabled = false,\n className,\n children,\n type = \"button\",\n ...rest\n },\n ref,\n ) => {\n const s = SIZES[size];\n const isIconOnly = !children && (!!icon || loading);\n const colorDef = resolveColor(color, soft, active, variant);\n\n return (\n <button\n ref={ref}\n type={type}\n disabled={disabled || loading}\n className={cn(\n \"group inline-flex items-center justify-center\",\n \"font-medium transition-all duration-200\",\n \"cursor-pointer select-none\",\n \"disabled:opacity-50 disabled:pointer-events-none\",\n SHAPES[shape],\n s.height,\n isIconOnly ? s.square : [s.padding, s.gap],\n !isIconOnly && s.font,\n colorDef.base,\n colorDef.hover,\n colorDef.text,\n className,\n )}\n {...rest}\n >\n {loading ? (\n <Spinner className={cn(s.iconSize, colorDef.iconColor)} />\n ) : icon ? (\n <span className={cn(\"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full\", s.iconSize, colorDef.iconColor)}>\n {icon}\n </span>\n ) : null}\n\n {children}\n\n {iconRight && !loading && (\n <span className={cn(\"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full\", s.iconSize, colorDef.iconColor)}>\n {iconRight}\n </span>\n )}\n </button>\n );\n },\n);\n\nButton.displayName = \"Button\";\n","\"use client\";\n\nimport * as React from \"react\";\nimport useEmblaCarousel from \"embla-carousel-react\";\nimport type { EmblaOptionsType, EmblaCarouselType, EmblaPluginType } from \"embla-carousel\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Dynamic plugin imports ───────────────────\n\nasync function loadPlugin(name: string, opts: Record<string, unknown> = {}) {\n try {\n const mod = await import(/* @vite-ignore */ name);\n const factory = mod.default || mod;\n return factory(opts);\n } catch {\n return null;\n }\n}\n\n// ── Types ────────────────────────────────────\n\nexport type CarouselBreakpointOptions = EmblaOptionsType & {\n slidesPerView?: number | \"auto\";\n};\n\nexport interface CarouselProps {\n slides: React.ReactNode[];\n\n // Core\n slidesPerView?: number | \"auto\";\n align?: EmblaOptionsType[\"align\"];\n containScroll?: EmblaOptionsType[\"containScroll\"];\n dragFree?: boolean;\n loop?: boolean;\n axis?: \"x\" | \"y\";\n direction?: \"ltr\" | \"rtl\";\n\n // Plugins\n autoplay?: boolean | Record<string, unknown>;\n autoScroll?: boolean | Record<string, unknown>;\n autoHeight?: boolean | Record<string, unknown>;\n fade?: boolean | Record<string, unknown>;\n wheelGestures?: boolean | Record<string, unknown>;\n classNames?: boolean | Record<string, unknown>;\n\n // Effects\n parallax?: boolean;\n opacity?: boolean;\n lazyLoad?: boolean;\n\n // Controls\n showNavigation?: boolean;\n showPagination?: boolean;\n scrollToIndex?: number;\n\n // Responsive\n breakpoints?: Record<string, CarouselBreakpointOptions>;\n\n // Styling\n className?: string;\n viewportClassName?: string;\n containerClassName?: string;\n slideClassName?: string;\n styles?: {\n controls?: string;\n navigation?: string;\n pagination?: string;\n prevButton?: string;\n nextButton?: string;\n dot?: string;\n };\n}\n\n// ── Icons ────────────────────────────────────\n\nfunction ChevronLeftIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"m15 18-6-6 6-6\" />\n </svg>\n );\n}\n\nfunction ChevronRightIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n );\n}\n\n// ── Internal Hooks ───────────────────────────\n\nfunction useDotButton(emblaApi: EmblaCarouselType | undefined) {\n const [selectedIndex, setSelectedIndex] = React.useState(0);\n const [scrollSnaps, setScrollSnaps] = React.useState<number[]>([]);\n\n const onDotButtonClick = React.useCallback((index: number) => {\n emblaApi?.scrollTo(index);\n }, [emblaApi]);\n\n const onInit = React.useCallback((api: EmblaCarouselType) => {\n setScrollSnaps(api.scrollSnapList());\n }, []);\n\n const onSelect = React.useCallback((api: EmblaCarouselType) => {\n setSelectedIndex(api.selectedScrollSnap());\n }, []);\n\n React.useEffect(() => {\n if (!emblaApi) return;\n const id = setTimeout(() => { onInit(emblaApi); onSelect(emblaApi); }, 0);\n emblaApi.on(\"reInit\", onInit).on(\"reInit\", onSelect).on(\"select\", onSelect);\n return () => clearTimeout(id);\n }, [emblaApi, onInit, onSelect]);\n\n return { selectedIndex, scrollSnaps, onDotButtonClick };\n}\n\nfunction usePrevNextButtons(emblaApi: EmblaCarouselType | undefined) {\n const [prevBtnDisabled, setPrevBtnDisabled] = React.useState(true);\n const [nextBtnDisabled, setNextBtnDisabled] = React.useState(true);\n\n const onPrevButtonClick = React.useCallback(() => emblaApi?.scrollPrev(), [emblaApi]);\n const onNextButtonClick = React.useCallback(() => emblaApi?.scrollNext(), [emblaApi]);\n\n const onSelect = React.useCallback((api: EmblaCarouselType) => {\n setPrevBtnDisabled(!api.canScrollPrev());\n setNextBtnDisabled(!api.canScrollNext());\n }, []);\n\n React.useEffect(() => {\n if (!emblaApi) return;\n const id = setTimeout(() => onSelect(emblaApi), 0);\n emblaApi.on(\"reInit\", onSelect).on(\"select\", onSelect);\n return () => clearTimeout(id);\n }, [emblaApi, onSelect]);\n\n return { prevBtnDisabled, nextBtnDisabled, onPrevButtonClick, onNextButtonClick };\n}\n\n// ── Nav Buttons ──────────────────────────────\n\ntype NavButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement> & { className?: string };\n\nfunction PrevButton({ className, ...restProps }: NavButtonProps) {\n return (\n <button\n type=\"button\"\n className={cn(\n \"inline-flex items-center justify-center size-8 rounded-full border bg-white/50 border-zinc-200/80 hover:bg-white hover:border-zinc-300 disabled:opacity-40 transition-colors cursor-pointer\",\n className,\n )}\n {...restProps}\n >\n <ChevronLeftIcon className=\"size-4\" />\n </button>\n );\n}\n\nfunction NextButton({ className, ...restProps }: NavButtonProps) {\n return (\n <button\n type=\"button\"\n className={cn(\n \"inline-flex items-center justify-center size-8 rounded-full border bg-white/50 border-zinc-200/80 hover:bg-white hover:border-zinc-300 disabled:opacity-40 transition-colors cursor-pointer\",\n className,\n )}\n {...restProps}\n >\n <ChevronRightIcon className=\"size-4\" />\n </button>\n );\n}\n\n// ── Component ────────────────────────────────\n\nexport function Carousel({\n slides,\n slidesPerView,\n align,\n containScroll,\n dragFree = false,\n loop = false,\n axis = \"x\",\n direction = \"ltr\",\n autoplay = false,\n autoScroll = false,\n autoHeight = false,\n fade: fadeProp = false,\n wheelGestures: wheelGesturesProp = true,\n classNames: classNamesProp = false,\n parallax = false,\n opacity = false,\n lazyLoad = false,\n showNavigation = false,\n showPagination = false,\n scrollToIndex,\n breakpoints,\n className,\n viewportClassName,\n containerClassName,\n slideClassName,\n styles,\n}: CarouselProps) {\n const [plugins, setPlugins] = React.useState<EmblaPluginType[]>([]);\n const [pluginsReady, setPluginsReady] = React.useState(false);\n\n // Build plugins async\n React.useEffect(() => {\n let cancelled = false;\n\n async function buildPlugins() {\n const active: (EmblaPluginType | null)[] = [];\n\n if (autoplay) {\n const opts = typeof autoplay === \"object\" ? autoplay : { delay: 4000 };\n active.push(await loadPlugin(\"embla-carousel-autoplay\", opts));\n }\n if (autoScroll) {\n const opts = typeof autoScroll === \"object\" ? autoScroll : { speed: 2 };\n active.push(await loadPlugin(\"embla-carousel-auto-scroll\", opts));\n }\n if (autoHeight) {\n const opts = typeof autoHeight === \"object\" ? autoHeight : {};\n active.push(await loadPlugin(\"embla-carousel-auto-height\", opts));\n }\n if (fadeProp) {\n const opts = typeof fadeProp === \"object\" ? fadeProp : {};\n active.push(await loadPlugin(\"embla-carousel-fade\", opts));\n }\n if (wheelGesturesProp) {\n const opts = typeof wheelGesturesProp === \"object\" ? wheelGesturesProp : {};\n active.push(await loadPlugin(\"embla-carousel-wheel-gestures\", opts));\n }\n if (classNamesProp) {\n const opts = typeof classNamesProp === \"object\" ? classNamesProp : {};\n active.push(await loadPlugin(\"embla-carousel-class-names\", opts));\n }\n\n if (!cancelled) {\n setPlugins(active.filter(Boolean) as EmblaPluginType[]);\n setPluginsReady(true);\n }\n }\n\n buildPlugins();\n return () => { cancelled = true; };\n }, [autoplay, autoScroll, autoHeight, fadeProp, wheelGesturesProp, classNamesProp]);\n\n // Core options\n const coreOptions: EmblaOptionsType = React.useMemo(() => {\n const opts: Record<string, unknown> = { dragFree, loop, axis, direction };\n if (align !== undefined) opts.align = align;\n if (containScroll !== undefined) opts.containScroll = containScroll;\n if (breakpoints !== undefined) opts.breakpoints = breakpoints;\n return opts as EmblaOptionsType;\n }, [align, containScroll, dragFree, loop, axis, direction, breakpoints]);\n\n // Resolved slidesPerView\n const [resolvedSlidesPerView, setResolvedSlidesPerView] = React.useState<number | \"auto\" | undefined>(slidesPerView);\n\n const slideStyle = React.useMemo(() => {\n if (typeof resolvedSlidesPerView === \"number\") {\n return { flex: `0 0 ${100 / resolvedSlidesPerView}%`, minWidth: 0 };\n }\n return undefined;\n }, [resolvedSlidesPerView]);\n\n // Initialize Embla\n const [emblaRef, emblaApi] = useEmblaCarousel(coreOptions, plugins);\n\n // scrollToIndex\n React.useEffect(() => {\n if (emblaApi && scrollToIndex !== undefined) {\n emblaApi.scrollTo(scrollToIndex);\n }\n }, [emblaApi, scrollToIndex]);\n\n // autoHeight: ensure correct height after images load\n React.useEffect(() => {\n if (!emblaApi || !autoHeight) return;\n\n const slideNodes = emblaApi.slideNodes();\n const handleLoad = () => emblaApi.reInit();\n\n slideNodes.forEach((slide, i) => {\n const images = slide.querySelectorAll(\"img\");\n images.forEach((img) => {\n if (i === 0 && img.loading === \"lazy\") img.loading = \"eager\";\n if (!img.complete) {\n img.addEventListener(\"load\", handleLoad, { once: true });\n img.addEventListener(\"error\", handleLoad, { once: true });\n }\n });\n });\n\n const raf = requestAnimationFrame(() => emblaApi.reInit());\n\n return () => {\n cancelAnimationFrame(raf);\n slideNodes.forEach((slide) => {\n slide.querySelectorAll(\"img\").forEach((img) => {\n img.removeEventListener(\"load\", handleLoad);\n img.removeEventListener(\"error\", handleLoad);\n });\n });\n };\n }, [emblaApi, autoHeight]);\n\n // Breakpoint-responsive slidesPerView\n React.useEffect(() => {\n if (!emblaApi) return;\n\n const onReInit = () => {\n const engine = emblaApi.internalEngine();\n if (!engine) return;\n\n const engineOptions = engine.options as CarouselBreakpointOptions;\n if (engineOptions.slidesPerView !== undefined) {\n setResolvedSlidesPerView(engineOptions.slidesPerView);\n } else {\n setResolvedSlidesPerView(slidesPerView);\n }\n };\n\n emblaApi.on(\"reInit\", onReInit);\n emblaApi.on(\"init\", onReInit);\n onReInit();\n\n return () => {\n emblaApi.off(\"reInit\", onReInit);\n emblaApi.off(\"init\", onReInit);\n };\n }, [emblaApi, slidesPerView]);\n\n // Lazy load tracking\n const [slidesInView, setSlidesInView] = React.useState<number[]>([]);\n\n const updateSlidesInView = React.useCallback((api: EmblaCarouselType) => {\n setSlidesInView((prev) => {\n if (prev.length === api.slideNodes().length) return prev;\n const inView = api.slidesInView();\n const merged = new Set([...prev, ...inView]);\n if (merged.size === prev.length) return prev;\n return Array.from(merged);\n });\n }, []);\n\n React.useEffect(() => {\n if (!emblaApi || !lazyLoad) return;\n updateSlidesInView(emblaApi);\n emblaApi.on(\"slidesInView\", updateSlidesInView);\n emblaApi.on(\"reInit\", updateSlidesInView);\n return () => {\n emblaApi.off(\"slidesInView\", updateSlidesInView);\n emblaApi.off(\"reInit\", updateSlidesInView);\n };\n }, [emblaApi, lazyLoad, updateSlidesInView]);\n\n // Parallax & opacity tween\n const simpleTween = React.useCallback((api: EmblaCarouselType) => {\n const engine = api.internalEngine();\n const scrollProgress = api.scrollProgress();\n const slideNodes = api.slideNodes();\n const locations = api.scrollSnapList();\n\n slideNodes.forEach((slide, index) => {\n const targetNode = slide.querySelector(\".carousel__parallax-layer\") as HTMLElement || slide;\n if (!targetNode) return;\n\n let distance = locations[index] - scrollProgress;\n\n if (engine.options.loop) {\n if (distance < -0.5) distance += 1;\n if (distance > 0.5) distance -= 1;\n }\n\n if (parallax) {\n const factor = 15;\n const x = distance * factor * 100;\n targetNode.style.transform = axis === \"y\"\n ? `translate3d(0, ${x}%, 0)`\n : `translate3d(${x}%, 0, 0)`;\n }\n\n if (opacity) {\n const factor = 2.5;\n const opacityValue = Math.max(0, 1 - Math.abs(distance * factor));\n slide.style.opacity = (0.3 + opacityValue * 0.7).toString();\n }\n });\n }, [parallax, opacity, axis]);\n\n React.useEffect(() => {\n if (!emblaApi || (!parallax && !opacity)) return;\n\n const onScroll = () => simpleTween(emblaApi);\n emblaApi.on(\"scroll\", onScroll);\n emblaApi.on(\"reInit\", onScroll);\n emblaApi.on(\"resize\", onScroll);\n simpleTween(emblaApi);\n\n return () => {\n emblaApi.off(\"scroll\", onScroll);\n emblaApi.off(\"reInit\", onScroll);\n emblaApi.off(\"resize\", onScroll);\n };\n }, [emblaApi, simpleTween, parallax, opacity]);\n\n // Hooks\n const { selectedIndex, scrollSnaps, onDotButtonClick } = useDotButton(emblaApi);\n const { prevBtnDisabled, nextBtnDisabled, onPrevButtonClick, onNextButtonClick } = usePrevNextButtons(emblaApi);\n\n const isVertical = axis === \"y\";\n const isRTL = direction === \"rtl\";\n\n if (!pluginsReady && (autoplay || autoScroll || autoHeight || fadeProp || classNamesProp)) {\n return null;\n }\n\n return (\n <div className={cn(isRTL && \"direction-rtl\", className)} dir={isRTL ? \"rtl\" : undefined}>\n <div\n className={cn(\"overflow-hidden\", isVertical && \"h-125\", autoHeight && \"transition-[height] duration-200\", viewportClassName)}\n ref={emblaRef}\n >\n <div className={cn(\n \"flex\",\n isVertical ? \"flex-col h-full\" : \"touch-pan-y touch-pinch-zoom\",\n autoHeight && \"items-start\",\n containerClassName,\n )}>\n {slides.map((slide, index) => {\n const isLoaded = !lazyLoad || slidesInView.includes(index);\n return (\n <div\n className={cn(\"flex-none min-w-0 relative\", slideClassName)}\n key={index}\n style={slideStyle}\n >\n <div className={cn(\"carousel__parallax-layer w-full\", !autoHeight && \"h-full\")}>\n {isLoaded ? slide : (\n <div className=\"w-full h-full bg-zinc-100/10 animate-pulse rounded-lg min-h-50\" />\n )}\n </div>\n </div>\n );\n })}\n </div>\n </div>\n\n {(showNavigation || showPagination) && (\n <div className={cn(styles?.controls || \"flex justify-between items-center gap-5 mt-4 px-1\")}>\n {showNavigation && (\n <div className={cn(styles?.navigation || \"flex gap-2 items-center\")}>\n <PrevButton onClick={onPrevButtonClick} disabled={prevBtnDisabled} className={styles?.prevButton} />\n <NextButton onClick={onNextButtonClick} disabled={nextBtnDisabled} className={styles?.nextButton} />\n </div>\n )}\n\n {showPagination && (\n <div className={cn(styles?.pagination || \"flex flex-wrap justify-end items-center gap-2.5 leading-none\")}>\n {scrollSnaps.map((_, index) => (\n <button\n type=\"button\"\n key={index}\n onClick={() => onDotButtonClick(index)}\n className={cn(\n styles?.dot\n ? cn(styles.dot, index === selectedIndex ? \"opacity-100 bg-current scale-110 border-current!\" : \"opacity-40\")\n : cn(\n \"w-2.5 h-2.5 rounded-full border bg-transparent flex items-center justify-center cursor-pointer touch-manipulation transition-all duration-300\",\n index === selectedIndex\n ? \"border-zinc-800 border-[2.5px] scale-110\"\n : \"border-zinc-300 hover:border-zinc-400 border-[1.5px]\",\n ),\n )}\n />\n ))}\n </div>\n )}\n </div>\n )}\n </div>\n );\n}\n","import * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\nexport type ButtonGroupVariant = \"bordered\" | \"segmented\";\n\nexport interface ButtonGroupProps {\n variant?: ButtonGroupVariant;\n className?: string;\n children: React.ReactNode;\n}\n\nexport function ButtonGroup({\n variant = \"bordered\",\n className,\n children,\n}: ButtonGroupProps) {\n const items = React.Children.toArray(children).filter(React.isValidElement);\n\n return (\n <div\n className={cn(\n \"inline-flex items-center rounded-lg\",\n variant === \"bordered\"\n ? \"bg-white border border-zinc-200\"\n : \"bg-zinc-100 p-1 gap-px\",\n className,\n )}\n >\n {items.map((child, index) => {\n const childProps = child.props as { className?: string; active?: boolean };\n const isActive = !!childProps.active;\n\n return (\n <React.Fragment key={index}>\n {React.cloneElement(child as React.ReactElement<{ className?: string }>, {\n className: cn(\n childProps.className,\n \"border-0\",\n variant === \"segmented\" && !isActive && \"bg-transparent hover:bg-white/80\",\n variant === \"segmented\" && isActive && \"bg-white shadow-sm text-zinc-900\",\n ),\n })}\n\n {variant === \"bordered\" && index < items.length - 1 && (\n <div className=\"w-px self-stretch my-2 bg-zinc-200 shrink-0\" />\n )}\n </React.Fragment>\n );\n })}\n </div>\n );\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type CheckboxSize = \"xs\" | \"sm\" | \"md\";\nexport type CheckboxColor = \"default\" | \"black\" | \"primary\" | \"danger\" | \"success\" | \"warning\" | \"info\";\nexport type CheckboxVariant = \"default\" | \"card\" | \"list\";\n\nexport interface CheckboxProps {\n variant?: CheckboxVariant;\n checked?: boolean;\n onChange?: (checked: boolean) => void;\n indeterminate?: boolean;\n size?: CheckboxSize;\n color?: CheckboxColor;\n label?: React.ReactNode;\n description?: React.ReactNode;\n disabled?: boolean;\n className?: string;\n name?: string;\n value?: string;\n id?: string;\n}\n\n// ── Icons ────────────────────────────────────\n\nfunction CheckIcon({ className, strokeWidth }: { className?: string; strokeWidth?: number }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth={strokeWidth} strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M20 6 9 17l-5-5\" />\n </svg>\n );\n}\n\nfunction MinusIcon({ className, strokeWidth }: { className?: string; strokeWidth?: number }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth={strokeWidth} strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M5 12h14\" />\n </svg>\n );\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<CheckboxSize, {\n box: string;\n iconSize: string;\n iconStroke: number;\n labelFont: string;\n descFont: string;\n gap: string;\n cardPadding: string;\n}> = {\n xs: {\n box: \"size-3.5\",\n iconSize: \"size-2.5\",\n iconStroke: 3,\n labelFont: \"text-xs\",\n descFont: \"text-[10px]\",\n gap: \"gap-1.5\",\n cardPadding: \"p-2\",\n },\n sm: {\n box: \"size-4\",\n iconSize: \"size-3\",\n iconStroke: 3,\n labelFont: \"text-sm\",\n descFont: \"text-xs\",\n gap: \"gap-2\",\n cardPadding: \"p-2.5\",\n },\n md: {\n box: \"size-5\",\n iconSize: \"size-3.5\",\n iconStroke: 2.5,\n labelFont: \"text-base\",\n descFont: \"text-sm\",\n gap: \"gap-2.5\",\n cardPadding: \"p-3\",\n },\n};\n\n// ── Color definitions ────────────────────────\n\ninterface CheckboxColorDef {\n checked: string;\n hover: string;\n}\n\nconst COLORS: Record<CheckboxColor, CheckboxColorDef> = {\n default: {\n checked: \"bg-zinc-900 border-zinc-900\",\n hover: \"group-hover/cb:border-zinc-400\",\n },\n black: {\n checked: \"bg-zinc-900 border-zinc-900\",\n hover: \"group-hover/cb:border-zinc-400\",\n },\n primary: {\n checked: \"bg-blue-600 border-blue-600\",\n hover: \"group-hover/cb:border-blue-300\",\n },\n danger: {\n checked: \"bg-red-500 border-red-500\",\n hover: \"group-hover/cb:border-red-300\",\n },\n success: {\n checked: \"bg-green-500 border-green-500\",\n hover: \"group-hover/cb:border-green-300\",\n },\n warning: {\n checked: \"bg-yellow-500 border-yellow-500\",\n hover: \"group-hover/cb:border-yellow-300\",\n },\n info: {\n checked: \"bg-indigo-500 border-indigo-500\",\n hover: \"group-hover/cb:border-indigo-300\",\n },\n};\n\n// ── Card variant colors ──────────────────────\n\ninterface CardColorDef {\n checked: string;\n unchecked: string;\n}\n\nconst CARD_COLORS: Record<CheckboxColor, CardColorDef> = {\n default: {\n checked: \"bg-zinc-50 border-zinc-300 text-zinc-800\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n black: {\n checked: \"bg-zinc-100 border-zinc-300 text-zinc-900\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n primary: {\n checked: \"bg-blue-50/50 border-blue-200 text-blue-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n danger: {\n checked: \"bg-red-50/50 border-red-200 text-red-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n success: {\n checked: \"bg-green-50/50 border-green-200 text-green-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n warning: {\n checked: \"bg-yellow-50/50 border-yellow-200 text-yellow-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n info: {\n checked: \"bg-indigo-50/50 border-indigo-200 text-indigo-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n};\n\n// ── Component ────────────────────────────────\n\nexport const Checkbox = React.forwardRef<HTMLInputElement, CheckboxProps>(\n (\n {\n variant = \"default\",\n checked = false,\n onChange,\n indeterminate = false,\n size = \"sm\",\n color = \"default\",\n label,\n description,\n disabled = false,\n className,\n name,\n value,\n id: idProp,\n },\n ref,\n ) => {\n const autoId = React.useId();\n const id = idProp || autoId;\n\n const s = SIZES[size];\n const c = COLORS[color];\n const isActive = checked || indeterminate;\n\n const handleChange = () => {\n if (disabled) return;\n onChange?.(!checked);\n };\n\n const variantClasses = (() => {\n switch (variant) {\n case \"card\": {\n const cc = CARD_COLORS[color];\n return cn(\n \"rounded-xl border font-medium transition-colors\",\n s.cardPadding,\n isActive ? cc.checked : cc.unchecked,\n );\n }\n case \"list\":\n return \"p-2 rounded-lg hover:bg-zinc-50 transition-colors\";\n default:\n return \"\";\n }\n })();\n\n return (\n <label\n htmlFor={id}\n className={cn(\n \"group/cb inline-flex items-start select-none\",\n s.gap,\n disabled ? \"opacity-50 cursor-not-allowed\" : \"cursor-pointer\",\n variantClasses,\n className,\n )}\n >\n <input\n ref={ref}\n id={id}\n type=\"checkbox\"\n className=\"sr-only\"\n checked={checked}\n onChange={handleChange}\n disabled={disabled}\n name={name}\n value={value}\n />\n\n <div\n className={cn(\n \"shrink-0 flex items-center justify-center rounded transition-all duration-150 mt-0.5\",\n s.box,\n isActive\n ? cn(c.checked, \"text-white\")\n : cn(\"border border-zinc-300 bg-white\", !disabled && c.hover),\n )}\n >\n {checked && !indeterminate && (\n <CheckIcon className={s.iconSize} strokeWidth={s.iconStroke} />\n )}\n {indeterminate && (\n <MinusIcon className={s.iconSize} strokeWidth={s.iconStroke} />\n )}\n </div>\n\n {(label || description) && (\n <div className=\"flex flex-col min-w-0\">\n {label && (\n <span className={cn(\"font-medium\", s.labelFont, variant === \"default\" && \"text-zinc-700\")}>\n {label}\n </span>\n )}\n {description && (\n <span className={cn(\"text-zinc-400 mt-0.5\", s.descFont)}>\n {description}\n </span>\n )}\n </div>\n )}\n </label>\n );\n },\n);\n\nCheckbox.displayName = \"Checkbox\";\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type DrawerSide = \"left\" | \"right\" | \"top\" | \"bottom\";\nexport type DrawerSize = \"sm\" | \"md\" | \"lg\" | \"full\";\n\nexport interface DrawerProps {\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n side?: DrawerSide;\n size?: DrawerSize;\n closeOnBackdrop?: boolean;\n closeOnEscape?: boolean;\n children: React.ReactNode;\n}\n\nexport interface DrawerTriggerProps {\n asChild?: boolean;\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface DrawerContentProps {\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface DrawerHeaderProps {\n hideClose?: boolean;\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface DrawerBodyProps {\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface DrawerFooterProps {\n className?: string;\n children: React.ReactNode;\n}\n\n// ── X Icon ───────────────────────────────────\n\nfunction XIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n}\n\n// ── Context ──────────────────────────────────\n\ninterface DrawerContextValue {\n isOpen: boolean;\n open: () => void;\n close: () => void;\n side: DrawerSide;\n size: DrawerSize;\n closeOnBackdrop: boolean;\n titleId: string;\n descriptionId: string;\n}\n\nconst DrawerContext = React.createContext<DrawerContextValue | null>(null);\n\nfunction useDrawer(): DrawerContextValue {\n const ctx = React.useContext(DrawerContext);\n if (!ctx) throw new Error(\"Drawer sub-components must be used within <Drawer>\");\n return ctx;\n}\n\n// ── Sizes ────────────────────────────────────\n\nconst HORIZONTAL_SIZES: Record<DrawerSize, string> = {\n sm: \"max-w-xs\",\n md: \"max-w-md\",\n lg: \"max-w-lg\",\n full: \"max-w-full\",\n};\n\nconst VERTICAL_SIZES: Record<DrawerSize, string> = {\n sm: \"max-h-48\",\n md: \"max-h-80\",\n lg: \"max-h-[32rem]\",\n full: \"max-h-full\",\n};\n\n// ── Slide animations ─────────────────────────\n\nconst SLIDE_IN: Record<DrawerSide, string> = {\n left: \"animate-[slide-in-left_200ms_ease-out]\",\n right: \"animate-[slide-in-right_200ms_ease-out]\",\n top: \"animate-[slide-in-top_200ms_ease-out]\",\n bottom: \"animate-[slide-in-bottom_200ms_ease-out]\",\n};\n\nconst PANEL_POSITION: Record<DrawerSide, string> = {\n left: \"inset-y-0 left-0\",\n right: \"inset-y-0 right-0\",\n top: \"inset-x-0 top-0\",\n bottom: \"inset-x-0 bottom-0\",\n};\n\n// ── Drawer (root) ────────────────────────────\n\nfunction DrawerRoot({\n open,\n defaultOpen = false,\n onOpenChange,\n side = \"right\",\n size = \"md\",\n closeOnBackdrop = true,\n closeOnEscape = true,\n children,\n}: DrawerProps) {\n const [internalOpen, setInternalOpen] = React.useState(defaultOpen);\n const isControlled = open !== undefined;\n const isOpen = isControlled ? open : internalOpen;\n\n const autoId = React.useId();\n const titleId = `drawer-title-${autoId}`;\n const descriptionId = `drawer-desc-${autoId}`;\n\n const setOpen = React.useCallback((next: boolean) => {\n if (!isControlled) setInternalOpen(next);\n onOpenChange?.(next);\n }, [isControlled, onOpenChange]);\n\n const openDrawer = React.useCallback(() => setOpen(true), [setOpen]);\n const closeDrawer = React.useCallback(() => setOpen(false), [setOpen]);\n\n React.useEffect(() => {\n if (!isOpen || !closeOnEscape) return;\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") closeDrawer();\n };\n document.addEventListener(\"keydown\", handleKeyDown);\n return () => document.removeEventListener(\"keydown\", handleKeyDown);\n }, [isOpen, closeOnEscape, closeDrawer]);\n\n React.useEffect(() => {\n if (!isOpen) return;\n const prev = document.body.style.overflow;\n document.body.style.overflow = \"hidden\";\n return () => { document.body.style.overflow = prev; };\n }, [isOpen]);\n\n return (\n <DrawerContext.Provider value={{ isOpen, open: openDrawer, close: closeDrawer, side, size, closeOnBackdrop, titleId, descriptionId }}>\n {children}\n </DrawerContext.Provider>\n );\n}\nDrawerRoot.displayName = \"Drawer\";\n\n// ── Trigger ──────────────────────────────────\n\nfunction DrawerTrigger({ asChild = false, className, children }: DrawerTriggerProps) {\n const { isOpen, open: openDrawer, titleId } = useDrawer();\n\n const handleClick = React.useCallback((e: React.MouseEvent) => {\n if (asChild && React.isValidElement(children)) {\n const originalOnClick = (children.props as Record<string, unknown>).onClick as ((e: React.MouseEvent) => void) | undefined;\n originalOnClick?.(e);\n }\n openDrawer();\n }, [asChild, children, openDrawer]);\n\n const triggerProps = {\n \"aria-haspopup\": \"dialog\" as const,\n \"aria-expanded\": isOpen,\n \"aria-controls\": isOpen ? titleId : undefined,\n onClick: handleClick,\n };\n\n if (asChild && React.isValidElement(children)) {\n const ChildType = children.type as React.ElementType;\n const childProps = children.props as Record<string, unknown>;\n return (\n <ChildType\n {...childProps}\n {...triggerProps}\n className={cn(childProps.className as string | undefined, className)}\n />\n );\n }\n\n return (\n <button type=\"button\" {...triggerProps} className={cn(\"cursor-pointer\", className)}>\n {children}\n </button>\n );\n}\nDrawerTrigger.displayName = \"DrawerTrigger\";\n\n// ── Content ──────────────────────────────────\n\nfunction DrawerContent({ className, children }: DrawerContentProps) {\n const { isOpen, close, side, size, closeOnBackdrop, titleId, descriptionId } = useDrawer();\n\n if (!isOpen) return null;\n\n const handleBackdropClick = closeOnBackdrop ? close : undefined;\n const isHorizontal = side === \"left\" || side === \"right\";\n const sizeClass = isHorizontal ? HORIZONTAL_SIZES[size] : VERTICAL_SIZES[size];\n\n return ReactDOM.createPortal(\n <div\n className=\"fixed inset-0 z-9999 flex bg-black/40 backdrop-blur-sm\"\n onClick={handleBackdropClick}\n aria-hidden=\"true\"\n >\n <div\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={titleId}\n aria-describedby={descriptionId}\n onClick={(e) => e.stopPropagation()}\n className={cn(\n \"fixed bg-white shadow-2xl flex flex-col\",\n PANEL_POSITION[side],\n isHorizontal ? \"w-full h-full\" : \"w-full\",\n sizeClass,\n SLIDE_IN[side],\n className,\n )}\n >\n {children}\n </div>\n </div>,\n document.body,\n );\n}\nDrawerContent.displayName = \"DrawerContent\";\n\n// ── Header ───────────────────────────────────\n\nfunction DrawerHeader({ hideClose = false, className, children }: DrawerHeaderProps) {\n const { titleId, close } = useDrawer();\n\n return (\n <div className={cn(\"flex items-center justify-between px-6 pt-6 pb-0\", className)}>\n <h2 id={titleId} className=\"text-base font-bold text-zinc-900 leading-snug\">\n {children}\n </h2>\n {!hideClose && (\n <button\n type=\"button\"\n aria-label=\"Close\"\n onClick={close}\n className=\"size-7 flex items-center justify-center rounded-lg text-zinc-400 hover:bg-zinc-100 hover:text-zinc-900 transition-colors cursor-pointer\"\n >\n <XIcon className=\"size-4\" />\n </button>\n )}\n </div>\n );\n}\nDrawerHeader.displayName = \"DrawerHeader\";\n\n// ── Body ─────────────────────────────────────\n\nfunction DrawerBody({ className, children }: DrawerBodyProps) {\n const { descriptionId } = useDrawer();\n\n return (\n <div id={descriptionId} className={cn(\"flex-1 overflow-y-auto px-6 py-4 text-sm text-zinc-600 leading-relaxed\", className)}>\n {children}\n </div>\n );\n}\nDrawerBody.displayName = \"DrawerBody\";\n\n// ── Footer ───────────────────────────────────\n\nfunction DrawerFooter({ className, children }: DrawerFooterProps) {\n return (\n <div className={cn(\"flex flex-wrap gap-3 px-6 pb-6 pt-2\", className)}>\n {children}\n </div>\n );\n}\nDrawerFooter.displayName = \"DrawerFooter\";\n\n// ── Export ────────────────────────────────────\n\nexport const Drawer = Object.assign(DrawerRoot, {\n Trigger: DrawerTrigger,\n Content: DrawerContent,\n Header: DrawerHeader,\n Body: DrawerBody,\n Footer: DrawerFooter,\n});\n","import * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type CheckboxGroupVariant = \"bordered\" | \"segmented\";\n\nexport interface CheckboxGroupProps {\n variant?: CheckboxGroupVariant;\n className?: string;\n children: React.ReactNode;\n}\n\n// ── Component ────────────────────────────────\n\nexport function CheckboxGroup({\n variant = \"bordered\",\n className,\n children,\n}: CheckboxGroupProps) {\n const items = React.Children.toArray(children).filter(React.isValidElement);\n\n return (\n <div\n className={cn(\n \"inline-flex items-center rounded-lg\",\n variant === \"bordered\"\n ? \"bg-white border border-zinc-200\"\n : \"bg-zinc-100 p-1 gap-px\",\n className,\n )}\n >\n {items.map((child, index) => {\n const childProps = child.props as { className?: string; checked?: boolean };\n const isChecked = !!childProps.checked;\n\n return (\n <React.Fragment key={index}>\n {React.cloneElement(child as React.ReactElement<{ className?: string }>, {\n className: cn(\n childProps.className,\n \"border-0\",\n variant === \"segmented\" && !isChecked && \"bg-transparent hover:bg-white/80\",\n variant === \"segmented\" && isChecked && \"bg-white shadow-sm text-zinc-900\",\n ),\n })}\n\n {variant === \"bordered\" && index < items.length - 1 && (\n <div className=\"w-px self-stretch my-2 bg-zinc-200 shrink-0\" />\n )}\n </React.Fragment>\n );\n })}\n </div>\n );\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\nimport { Button } from \"../button\";\n\n// ── Types ────────────────────────────────────\n\nexport type DropdownSide = \"bottom\" | \"top\" | \"right\" | \"left\";\nexport type DropdownAlign = \"left\" | \"right\" | \"top\" | \"bottom\" | \"start\" | \"center\" | \"end\";\nexport type DropdownWidth = number | \"trigger\" | \"auto\";\n\nexport interface DropdownProps {\n side?: DropdownSide;\n align?: DropdownAlign;\n width?: DropdownWidth;\n maxHeight?: number;\n scroll?: boolean;\n autoFlip?: boolean;\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface DropdownTriggerProps {\n className?: string;\n children?: React.ReactNode;\n asChild?: boolean;\n}\n\nexport interface DropdownContentProps {\n className?: string;\n children: React.ReactNode;\n}\n\n// ── Ellipsis Icon ────────────────────────────\n\nfunction EllipsisIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <circle cx=\"12\" cy=\"12\" r=\"1\" />\n <circle cx=\"19\" cy=\"12\" r=\"1\" />\n <circle cx=\"5\" cy=\"12\" r=\"1\" />\n </svg>\n );\n}\n\n// ── Context ──────────────────────────────────\n\ninterface DropdownContextValue {\n isOpen: boolean;\n toggle: () => void;\n close: () => void;\n side: DropdownSide;\n align: DropdownAlign;\n width: DropdownWidth;\n maxHeight?: number;\n scroll: boolean;\n autoFlip: boolean;\n triggerId: string;\n contentId: string;\n triggerRef: React.RefObject<HTMLElement | null>;\n setTriggerNode: (node: HTMLElement | null) => void;\n}\n\nconst DropdownContext = React.createContext<DropdownContextValue | null>(null);\n\nfunction useDropdown(): DropdownContextValue {\n const ctx = React.useContext(DropdownContext);\n if (!ctx) throw new Error(\"Dropdown sub-components must be used within <Dropdown>\");\n return ctx;\n}\n\n// ── Dropdown (root) ──────────────────────────\n\nconst DropdownRoot = React.forwardRef<HTMLDivElement, DropdownProps>(\n ({ side = \"bottom\", align = \"right\", width = \"auto\", maxHeight, scroll = true, autoFlip = false, open, onOpenChange, className, children }, ref) => {\n const [internalOpen, setInternalOpen] = React.useState(false);\n const isControlled = open !== undefined;\n const isOpen = isControlled ? open : internalOpen;\n\n const containerRef = React.useRef<HTMLDivElement | null>(null);\n const triggerRef = React.useRef<HTMLElement | null>(null);\n\n const autoId = React.useId();\n const triggerId = `dropdown-trigger-${autoId}`;\n const contentId = `dropdown-content-${autoId}`;\n\n const setOpen = React.useCallback((next: boolean) => {\n if (!isControlled) setInternalOpen(next);\n onOpenChange?.(next);\n }, [isControlled, onOpenChange]);\n\n const toggle = React.useCallback(() => setOpen(!isOpen), [isOpen, setOpen]);\n const close = React.useCallback(() => setOpen(false), [setOpen]);\n\n React.useEffect(() => {\n if (!isOpen) return;\n const handleMouseDown = (e: MouseEvent) => {\n if (containerRef.current && !containerRef.current.contains(e.target as Node)) {\n close();\n }\n };\n document.addEventListener(\"mousedown\", handleMouseDown);\n return () => document.removeEventListener(\"mousedown\", handleMouseDown);\n }, [isOpen, close]);\n\n React.useEffect(() => {\n if (!isOpen) return;\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") close();\n };\n document.addEventListener(\"keydown\", handleKeyDown);\n return () => document.removeEventListener(\"keydown\", handleKeyDown);\n }, [isOpen, close]);\n\n const childArray = React.Children.toArray(children);\n const hasTrigger = childArray.some(\n (child) => React.isValidElement(child) && child.type === DropdownTrigger,\n );\n\n const setTriggerNode = React.useCallback((node: HTMLElement | null) => {\n triggerRef.current = node;\n }, []);\n\n const mergedRef = React.useCallback(\n (node: HTMLDivElement | null) => {\n containerRef.current = node;\n if (typeof ref === \"function\") ref(node);\n else if (ref) ref.current = node;\n },\n [ref],\n );\n\n return (\n <DropdownContext.Provider value={{ isOpen, toggle, close, side, align, width, maxHeight, scroll, autoFlip, triggerId, contentId, triggerRef, setTriggerNode }}>\n <div ref={mergedRef} className={cn(\"relative inline-flex\", className)}>\n {!hasTrigger && <DropdownTrigger />}\n {children}\n </div>\n </DropdownContext.Provider>\n );\n },\n);\nDropdownRoot.displayName = \"Dropdown\";\n\n// ── Trigger ──────────────────────────────────\n\nfunction DropdownTrigger({ className, children, asChild = false }: DropdownTriggerProps) {\n const { isOpen, toggle, triggerId, contentId, setTriggerNode } = useDropdown();\n\n const handleClick = React.useCallback((e: React.MouseEvent) => {\n if (asChild && React.isValidElement(children)) {\n const originalOnClick = (children.props as Record<string, unknown>).onClick as ((e: React.MouseEvent) => void) | undefined;\n originalOnClick?.(e);\n }\n toggle();\n }, [asChild, children, toggle]);\n\n const triggerProps = {\n id: triggerId,\n \"aria-expanded\": isOpen,\n \"aria-haspopup\": true as const,\n \"aria-controls\": isOpen ? contentId : undefined,\n onClick: handleClick,\n };\n\n if (!children) {\n return (\n <Button\n ref={setTriggerNode as React.Ref<HTMLButtonElement>}\n variant=\"ghost\"\n size=\"xs\"\n shape=\"circle\"\n icon={<EllipsisIcon />}\n active={isOpen}\n className={className}\n {...triggerProps}\n />\n );\n }\n\n if (asChild && React.isValidElement(children)) {\n const ChildType = children.type as React.ElementType;\n const childProps = children.props as Record<string, unknown>;\n const isComponent = typeof ChildType !== \"string\";\n return (\n <ChildType\n {...childProps}\n ref={setTriggerNode}\n {...triggerProps}\n {...(isComponent ? { active: isOpen } : { \"data-active\": isOpen || undefined })}\n className={cn(childProps.className as string | undefined, className)}\n />\n );\n }\n\n return (\n <div ref={setTriggerNode as React.Ref<HTMLDivElement>} {...triggerProps} className={cn(\"cursor-pointer\", className)}>\n {children}\n </div>\n );\n}\nDropdownTrigger.displayName = \"DropdownTrigger\";\n\n// ── Content ──────────────────────────────────\n\nfunction DropdownContent({ className, children }: DropdownContentProps) {\n const { isOpen, side, align, width, maxHeight, scroll, autoFlip, triggerId, contentId, triggerRef } = useDropdown();\n const [triggerWidth, setTriggerWidth] = React.useState<number | null>(null);\n const [currentSide, setCurrentSide] = React.useState(side);\n const contentRef = React.useRef<HTMLDivElement>(null);\n\n const [prevSide, setPrevSide] = React.useState(side);\n const [prevIsOpen, setPrevIsOpen] = React.useState(isOpen);\n if (side !== prevSide || isOpen !== prevIsOpen) {\n setPrevSide(side);\n setPrevIsOpen(isOpen);\n setCurrentSide(side);\n }\n\n React.useEffect(() => {\n if (!isOpen || !autoFlip || !contentRef.current || !triggerRef.current) return;\n\n const measure = () => {\n if (!contentRef.current || !triggerRef.current) return;\n const triggerRect = triggerRef.current.getBoundingClientRect();\n const contentRect = contentRef.current.getBoundingClientRect();\n const { height, width: w } = contentRect;\n const { innerHeight, innerWidth } = window;\n\n let newSide = side;\n\n if (side === \"bottom\") {\n if (triggerRect.bottom + height > innerHeight && triggerRect.top > height) newSide = \"top\";\n } else if (side === \"top\") {\n if (triggerRect.top - height < 0 && innerHeight - triggerRect.bottom > height) newSide = \"bottom\";\n } else if (side === \"right\") {\n if (triggerRect.right + w > innerWidth && triggerRect.left > w) newSide = \"left\";\n } else if (side === \"left\") {\n if (triggerRect.left - w < 0 && innerWidth - triggerRect.right > w) newSide = \"right\";\n }\n\n setCurrentSide(newSide);\n };\n\n const timer = requestAnimationFrame(measure);\n window.addEventListener(\"scroll\", measure, { passive: true });\n window.addEventListener(\"resize\", measure);\n\n return () => {\n cancelAnimationFrame(timer);\n window.removeEventListener(\"scroll\", measure);\n window.removeEventListener(\"resize\", measure);\n };\n }, [isOpen, autoFlip, side, triggerRef]);\n\n React.useEffect(() => {\n if (!isOpen || width !== \"trigger\") return;\n if (triggerRef.current) {\n setTriggerWidth(triggerRef.current.offsetWidth);\n }\n }, [isOpen, width, triggerRef]);\n\n if (!isOpen) return null;\n\n const widthStyle: React.CSSProperties = {};\n if (typeof width === \"number\") {\n widthStyle.width = `${width}px`;\n } else if (width === \"trigger\" && triggerWidth) {\n widthStyle.width = `${triggerWidth}px`;\n }\n\n const heightStyle: React.CSSProperties = {};\n if (maxHeight) {\n heightStyle.maxHeight = `${maxHeight}px`;\n if (scroll) {\n heightStyle.overflowY = \"auto\";\n } else {\n heightStyle.overflow = \"hidden\";\n }\n }\n\n return (\n <div\n ref={contentRef}\n id={contentId}\n aria-labelledby={triggerId}\n style={{ ...widthStyle, ...heightStyle }}\n className={cn(\n \"absolute z-50\",\n currentSide === \"bottom\" ? \"top-full mt-2\" : \"\",\n currentSide === \"top\" ? \"bottom-full mb-2\" : \"\",\n currentSide === \"right\" ? \"left-full ml-2\" : \"\",\n currentSide === \"left\" ? \"right-full mr-2\" : \"\",\n (currentSide === \"bottom\" || currentSide === \"top\") && (align === \"left\" || align === \"start\") ? \"left-0\" : \"\",\n (currentSide === \"bottom\" || currentSide === \"top\") && (align === \"right\" || align === \"end\") ? \"right-0\" : \"\",\n (currentSide === \"bottom\" || currentSide === \"top\") && align === \"center\" ? \"left-1/2 -translate-x-1/2\" : \"\",\n (currentSide === \"left\" || currentSide === \"right\") && (align === \"top\" || align === \"start\") ? \"top-0\" : \"\",\n (currentSide === \"left\" || currentSide === \"right\") && (align === \"bottom\" || align === \"end\") ? \"bottom-0\" : \"\",\n (currentSide === \"left\" || currentSide === \"right\") && align === \"center\" ? \"top-1/2 -translate-y-1/2\" : \"\",\n \"bg-white border border-zinc-200 rounded-xl\",\n \"shadow-[0_8px_30px_rgb(0,0,0,0.12)]\",\n className,\n )}\n >\n {children}\n </div>\n );\n}\nDropdownContent.displayName = \"DropdownContent\";\n\n// ── Export ────────────────────────────────────\n\nexport const Dropdown = Object.assign(DropdownRoot, {\n Trigger: DropdownTrigger,\n Content: DropdownContent,\n});\n","import * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type InputSize = \"xs\" | \"sm\" | \"md\";\nexport type InputShape = \"square\" | \"rounded\";\nexport type InputVariant = \"default\" | \"outline\" | \"ghost\";\nexport type InputColor = \"default\" | \"black\" | \"primary\" | \"danger\" | \"success\" | \"warning\" | \"info\";\nexport type InputState = \"idle\" | \"error\" | \"success\";\n\nexport interface InputProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, \"size\"> {\n variant?: InputVariant;\n size?: InputSize;\n shape?: InputShape;\n color?: InputColor;\n state?: InputState;\n icon?: React.ReactNode;\n iconRight?: React.ReactNode;\n loading?: boolean;\n label?: string;\n errorMessage?: string;\n successMessage?: string;\n wrapperClassName?: string;\n className?: string;\n}\n\n// ── Spinner ──────────────────────────────────\n\nfunction Spinner({ className }: { className?: string }) {\n return (\n <svg\n className={cn(\"animate-spin\", className)}\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n >\n <circle className=\"opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" />\n <path\n className=\"opacity-75\"\n fill=\"currentColor\"\n d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\"\n />\n </svg>\n );\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<InputSize, {\n height: string;\n font: string;\n iconSize: string;\n paddingX: string;\n paddingWithLeftIcon: string;\n paddingWithRightIcon: string;\n paddingWithBothIcons: string;\n iconLeft: string;\n iconRight: string;\n labelFont: string;\n}> = {\n xs: {\n height: \"h-8\",\n font: \"text-xs\",\n iconSize: \"size-3.5\",\n paddingX: \"px-2.5\",\n paddingWithLeftIcon: \"pl-8 pr-2.5\",\n paddingWithRightIcon: \"pl-2.5 pr-8\",\n paddingWithBothIcons: \"pl-8 pr-8\",\n iconLeft: \"left-2.5\",\n iconRight: \"right-2.5\",\n labelFont: \"text-xs\",\n },\n sm: {\n height: \"h-10\",\n font: \"text-sm\",\n iconSize: \"size-4\",\n paddingX: \"px-3\",\n paddingWithLeftIcon: \"pl-9 pr-3\",\n paddingWithRightIcon: \"pl-3 pr-9\",\n paddingWithBothIcons: \"pl-9 pr-9\",\n iconLeft: \"left-3\",\n iconRight: \"right-3\",\n labelFont: \"text-sm\",\n },\n md: {\n height: \"h-12\",\n font: \"text-base\",\n iconSize: \"size-4\",\n paddingX: \"px-4\",\n paddingWithLeftIcon: \"pl-10 pr-4\",\n paddingWithRightIcon: \"pl-4 pr-10\",\n paddingWithBothIcons: \"pl-10 pr-10\",\n iconLeft: \"left-3.5\",\n iconRight: \"right-3.5\",\n labelFont: \"text-sm\",\n },\n};\n\n// ── Shape definitions ────────────────────────\n\nconst SHAPES: Record<InputShape, string> = {\n square: \"\",\n rounded: \"rounded-lg\",\n};\n\n// ── Color definitions ────────────────────────\n\ninterface InputColorDef {\n bg: string;\n border: string;\n focusRing: string;\n iconColor: string;\n}\n\nconst INPUT_COLORS: Record<InputColor, InputColorDef> = {\n default: {\n bg: \"bg-zinc-50\",\n border: \"border border-zinc-200\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-black/5 focus:border-black/10\",\n iconColor: \"text-zinc-400\",\n },\n black: {\n bg: \"bg-zinc-50\",\n border: \"border border-zinc-300\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-zinc-200 focus:border-zinc-400\",\n iconColor: \"text-zinc-600\",\n },\n primary: {\n bg: \"bg-blue-50/30\",\n border: \"border border-blue-200\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-blue-100 focus:border-blue-400\",\n iconColor: \"text-blue-500\",\n },\n danger: {\n bg: \"bg-red-50/30\",\n border: \"border border-red-200\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-red-100 focus:border-red-400\",\n iconColor: \"text-red-500\",\n },\n success: {\n bg: \"bg-green-50/30\",\n border: \"border border-green-200\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-green-100 focus:border-green-400\",\n iconColor: \"text-green-500\",\n },\n warning: {\n bg: \"bg-yellow-50/30\",\n border: \"border border-yellow-200\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-yellow-100 focus:border-yellow-400\",\n iconColor: \"text-yellow-600\",\n },\n info: {\n bg: \"bg-indigo-50/30\",\n border: \"border border-indigo-200\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-indigo-100 focus:border-indigo-400\",\n iconColor: \"text-indigo-500\",\n },\n};\n\n// ── Variant styles ───────────────────────────\n\ninterface InputVariantDef {\n bg: string;\n border: string;\n focusRing: string;\n}\n\nconst VARIANT_STYLES: Record<InputVariant, InputVariantDef> = {\n default: { bg: \"\", border: \"\", focusRing: \"\" },\n outline: { bg: \"bg-transparent\", border: \"\", focusRing: \"\" },\n ghost: {\n bg: \"bg-transparent\",\n border: \"border border-transparent\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-black/5 focus:border-zinc-200\",\n },\n};\n\n// ── State overrides ──────────────────────────\n\ninterface InputStateOverride {\n border: string;\n focusRing: string;\n iconColor: string;\n messageColor: string;\n}\n\nconst STATE_OVERRIDES: Record<Exclude<InputState, \"idle\">, InputStateOverride> = {\n error: {\n border: \"border border-red-300\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-red-100 focus:border-red-400\",\n iconColor: \"text-red-400\",\n messageColor: \"text-red-500\",\n },\n success: {\n border: \"border border-green-300\",\n focusRing: \"focus:outline-none focus:ring-2 focus:ring-green-100 focus:border-green-400\",\n iconColor: \"text-green-500\",\n messageColor: \"text-green-600\",\n },\n};\n\n// ── Style resolver ───────────────────────────\n\nfunction resolveStyles(variant: InputVariant, color: InputColor, state: InputState) {\n const colorDef = INPUT_COLORS[color];\n const variantDef = VARIANT_STYLES[variant];\n\n if (state !== \"idle\") {\n const override = STATE_OVERRIDES[state];\n return {\n bg: variantDef.bg || colorDef.bg,\n border: override.border,\n focusRing: override.focusRing,\n iconColor: override.iconColor,\n messageColor: override.messageColor,\n };\n }\n\n return {\n bg: variantDef.bg || colorDef.bg,\n border: variantDef.border || colorDef.border,\n focusRing: variantDef.focusRing || colorDef.focusRing,\n iconColor: colorDef.iconColor,\n messageColor: \"\",\n };\n}\n\n// ── Padding resolver ─────────────────────────\n\nfunction resolvePadding(\n s: (typeof SIZES)[InputSize],\n hasLeftIcon: boolean,\n hasRightIcon: boolean,\n): string {\n if (hasLeftIcon && hasRightIcon) return s.paddingWithBothIcons;\n if (hasLeftIcon) return s.paddingWithLeftIcon;\n if (hasRightIcon) return s.paddingWithRightIcon;\n return s.paddingX;\n}\n\n// ── Component ────────────────────────────────\n\nexport const Input = React.forwardRef<HTMLInputElement, InputProps>(\n (\n {\n variant = \"default\",\n size = \"sm\",\n shape = \"rounded\",\n color = \"default\",\n state = \"idle\",\n icon,\n iconRight,\n loading = false,\n label,\n errorMessage,\n successMessage,\n wrapperClassName,\n className,\n disabled = false,\n id: idProp,\n ...rest\n },\n ref,\n ) => {\n const autoId = React.useId();\n const id = idProp || autoId;\n\n const s = SIZES[size];\n const styles = resolveStyles(variant, color, state);\n const hasLeftIcon = !!icon;\n const hasRightIcon = !!iconRight || loading;\n const padding = resolvePadding(s, hasLeftIcon, hasRightIcon);\n\n const message =\n state === \"error\" ? errorMessage\n : state === \"success\" ? successMessage\n : undefined;\n\n return (\n <div className={cn(\"flex flex-col\", wrapperClassName)}>\n {label && (\n <label\n htmlFor={id}\n className={cn(\"mb-1.5 font-medium text-zinc-700\", s.labelFont)}\n >\n {label}\n </label>\n )}\n\n <div className=\"relative\">\n {hasLeftIcon && (\n <span\n className={cn(\n \"absolute top-1/2 -translate-y-1/2 flex items-center justify-center pointer-events-none\",\n s.iconLeft,\n )}\n >\n <span className={cn(\n \"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full\",\n s.iconSize,\n styles.iconColor,\n )}>\n {icon}\n </span>\n </span>\n )}\n\n <input\n ref={ref}\n id={id}\n disabled={disabled || loading}\n className={cn(\n \"w-full transition-shadow duration-200\",\n \"text-zinc-900 placeholder:text-zinc-400\",\n \"disabled:opacity-50 disabled:cursor-not-allowed\",\n SHAPES[shape],\n s.height,\n s.font,\n padding,\n styles.bg,\n styles.border,\n styles.focusRing,\n className,\n )}\n {...rest}\n />\n\n {hasRightIcon && (\n <span\n className={cn(\n \"absolute top-1/2 -translate-y-1/2 flex items-center justify-center pointer-events-none\",\n s.iconRight,\n )}\n >\n {loading ? (\n <Spinner className={cn(s.iconSize, styles.iconColor)} />\n ) : (\n <span className={cn(\n \"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full\",\n s.iconSize,\n styles.iconColor,\n )}>\n {iconRight}\n </span>\n )}\n </span>\n )}\n </div>\n\n {message && (\n <p className={cn(\"mt-1.5 text-xs\", styles.messageColor)}>\n {message}\n </p>\n )}\n </div>\n );\n },\n);\n\nInput.displayName = \"Input\";\n","import * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type InputGroupVariant = \"bordered\" | \"stacked\";\n\nexport interface InputGroupProps {\n variant?: InputGroupVariant;\n className?: string;\n children: React.ReactNode;\n}\n\n// ── Component ────────────────────────────────\n\nexport function InputGroup({\n variant = \"bordered\",\n className,\n children,\n}: InputGroupProps) {\n const items = React.Children.toArray(children).filter(React.isValidElement);\n\n if (variant === \"stacked\") {\n return (\n <div\n className={cn(\n \"flex flex-col rounded-lg border border-zinc-200 overflow-hidden\",\n className,\n )}\n >\n {items.map((child, index) => (\n <React.Fragment key={index}>\n {React.cloneElement(child as React.ReactElement<{ className?: string; wrapperClassName?: string }>, {\n className: cn(\n (child.props as { className?: string }).className,\n \"rounded-none border-0 focus:ring-0 focus:border-0 focus:outline-none focus:ring-offset-0\",\n \"focus:relative focus:z-10 focus:ring-2 focus:ring-black/5\",\n ),\n wrapperClassName: \"\",\n })}\n\n {index < items.length - 1 && (\n <div className=\"h-px bg-zinc-200 shrink-0\" />\n )}\n </React.Fragment>\n ))}\n </div>\n );\n }\n\n return (\n <div\n className={cn(\n \"inline-flex items-center rounded-lg border border-zinc-200 overflow-hidden\",\n className,\n )}\n >\n {items.map((child, index) => (\n <React.Fragment key={index}>\n {React.cloneElement(child as React.ReactElement<{ className?: string; wrapperClassName?: string }>, {\n className: cn(\n (child.props as { className?: string }).className,\n \"rounded-none border-0 focus:ring-0 focus:border-0 focus:outline-none focus:ring-offset-0\",\n \"focus:relative focus:z-10 focus:ring-2 focus:ring-black/5\",\n ),\n wrapperClassName: \"\",\n })}\n\n {index < items.length - 1 && (\n <div className=\"w-px self-stretch bg-zinc-200 shrink-0\" />\n )}\n </React.Fragment>\n ))}\n </div>\n );\n}\n","import * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type LinkVariant = \"default\" | \"underline\" | \"ghost\";\nexport type LinkColor = \"default\" | \"black\" | \"primary\" | \"danger\" | \"success\" | \"warning\" | \"info\";\nexport type LinkSize = \"xs\" | \"sm\" | \"md\";\n\nexport interface LinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n variant?: LinkVariant;\n color?: LinkColor;\n size?: LinkSize;\n icon?: React.ReactNode;\n iconRight?: React.ReactNode;\n external?: boolean;\n disabled?: boolean;\n className?: string;\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<LinkSize, { font: string; iconSize: string; gap: string }> = {\n xs: { font: \"text-xs\", iconSize: \"size-3\", gap: \"gap-1\" },\n sm: { font: \"text-sm\", iconSize: \"size-3.5\", gap: \"gap-1.5\" },\n md: { font: \"text-base\", iconSize: \"size-4\", gap: \"gap-2\" },\n};\n\n// ── Color definitions ────────────────────────\n\ninterface LinkColorDef {\n text: string;\n hover: string;\n iconColor: string;\n}\n\nconst COLORS: Record<LinkColor, LinkColorDef> = {\n default: {\n text: \"text-zinc-700\",\n hover: \"hover:text-zinc-900\",\n iconColor: \"text-zinc-400\",\n },\n black: {\n text: \"text-zinc-900\",\n hover: \"hover:text-black\",\n iconColor: \"text-zinc-600\",\n },\n primary: {\n text: \"text-blue-600\",\n hover: \"hover:text-blue-700\",\n iconColor: \"text-blue-500\",\n },\n danger: {\n text: \"text-red-600\",\n hover: \"hover:text-red-700\",\n iconColor: \"text-red-500\",\n },\n success: {\n text: \"text-green-600\",\n hover: \"hover:text-green-700\",\n iconColor: \"text-green-500\",\n },\n warning: {\n text: \"text-yellow-600\",\n hover: \"hover:text-yellow-700\",\n iconColor: \"text-yellow-500\",\n },\n info: {\n text: \"text-indigo-600\",\n hover: \"hover:text-indigo-700\",\n iconColor: \"text-indigo-500\",\n },\n};\n\n// ── Variant styles ───────────────────────────\n\nconst VARIANT_STYLES: Record<LinkVariant, string> = {\n default: \"\",\n underline: \"underline underline-offset-4\",\n ghost: \"no-underline hover:bg-zinc-100 px-2 py-1 rounded-md -mx-2 -my-1\",\n};\n\n// ── External Icon ────────────────────────────\n\nfunction ExternalLinkIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M15 3h6v6\" />\n <path d=\"M10 14 21 3\" />\n <path d=\"M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6\" />\n </svg>\n );\n}\n\n// ── Component ────────────────────────────────\n\nexport const Link = React.forwardRef<HTMLAnchorElement, LinkProps>(\n (\n {\n variant = \"default\",\n color = \"primary\",\n size = \"sm\",\n icon,\n iconRight,\n external = false,\n disabled = false,\n className,\n children,\n ...rest\n },\n ref,\n ) => {\n const s = SIZES[size];\n const c = COLORS[color];\n\n const externalProps = external\n ? { target: \"_blank\", rel: \"noopener noreferrer\" }\n : {};\n\n return (\n <a\n ref={ref}\n className={cn(\n \"inline-flex items-center font-medium transition-colors\",\n s.font,\n s.gap,\n c.text,\n !disabled && c.hover,\n VARIANT_STYLES[variant],\n disabled && \"opacity-50 pointer-events-none cursor-not-allowed\",\n className,\n )}\n {...externalProps}\n {...rest}\n >\n {icon && (\n <span className={cn(\"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full\", s.iconSize, c.iconColor)}>\n {icon}\n </span>\n )}\n\n {children}\n\n {external && !iconRight && (\n <ExternalLinkIcon className={cn(s.iconSize, c.iconColor)} />\n )}\n\n {iconRight && (\n <span className={cn(\"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full\", s.iconSize, c.iconColor)}>\n {iconRight}\n </span>\n )}\n </a>\n );\n },\n);\n\nLink.displayName = \"Link\";\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type MediaImageRatio = \"1:1\" | \"16:9\" | \"4:3\" | \"1:2\" | \"free\";\nexport type MediaImageSize = \"xs\" | \"sm\" | \"md\" | \"lg\";\nexport type MediaImageShape = \"square\" | \"rounded\" | \"circle\";\n\nexport interface MediaImageProps {\n src: string;\n alt: string;\n caption?: string;\n ratio?: MediaImageRatio;\n size?: MediaImageSize;\n shape?: MediaImageShape;\n children?: React.ReactNode;\n hideCaption?: boolean;\n objectFit?: \"cover\" | \"contain\" | \"fill\" | \"none\";\n loading?: \"lazy\" | \"eager\";\n onError?: () => void;\n className?: string;\n}\n\n// ── Icons ────────────────────────────────────\n\nfunction CameraIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M14.5 4h-5L7 7H4a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2h-3l-2.5-3z\" />\n <circle cx=\"12\" cy=\"13\" r=\"3\" />\n </svg>\n );\n}\n\n// ── Shape definitions ────────────────────────\n\nconst SHAPES: Record<MediaImageShape, string | null> = {\n square: \"\",\n rounded: null,\n circle: \"rounded-full\",\n};\n\n// ── Ratio definitions ────────────────────────\n\nconst RATIOS: Record<MediaImageRatio, string> = {\n \"1:1\": \"aspect-square\",\n \"16:9\": \"aspect-video\",\n \"4:3\": \"aspect-[4/3]\",\n \"1:2\": \"aspect-[1/2]\",\n \"free\": \"\",\n};\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<MediaImageSize, {\n rounded: string;\n captionFont: string;\n errorIconSize: string;\n errorFont: string;\n}> = {\n xs: { rounded: \"rounded-lg\", captionFont: \"text-xs\", errorIconSize: \"size-6\", errorFont: \"text-[10px]\" },\n sm: { rounded: \"rounded-xl\", captionFont: \"text-sm\", errorIconSize: \"size-8\", errorFont: \"text-xs\" },\n md: { rounded: \"rounded-2xl\", captionFont: \"text-base\", errorIconSize: \"size-10\", errorFont: \"text-sm\" },\n lg: { rounded: \"rounded-2xl\", captionFont: \"text-base\", errorIconSize: \"size-10\", errorFont: \"text-sm\" },\n};\n\n// ── Object fit ───────────────────────────────\n\nconst OBJECT_FIT: Record<string, string> = {\n cover: \"object-cover\",\n contain: \"object-contain\",\n fill: \"object-fill\",\n none: \"object-none\",\n};\n\n// ── Component ────────────────────────────────\n\nexport function MediaImage({\n src,\n alt,\n caption,\n ratio = \"16:9\",\n size = \"sm\",\n shape = \"rounded\",\n children,\n hideCaption = false,\n objectFit = \"cover\",\n loading = \"lazy\",\n onError,\n className,\n}: MediaImageProps) {\n const [hasError, setHasError] = React.useState(false);\n const s = SIZES[size];\n const ratioClass = RATIOS[ratio];\n const shapeClass = SHAPES[shape] ?? s.rounded;\n\n if (hasError || !src) {\n return (\n <div className=\"flex flex-col\">\n <div className={cn(\n \"relative overflow-hidden bg-zinc-100 flex flex-col items-center justify-center gap-2 group\",\n ratioClass, shapeClass, className,\n )}>\n <div className=\"flex flex-col justify-center items-center gap-2 p-4 text-center\">\n <CameraIcon className={cn(s.errorIconSize, \"text-zinc-300\")} />\n <span className={cn(s.errorFont, \"text-zinc-400\")}>Image could not be loaded</span>\n </div>\n {children}\n </div>\n {caption && !hideCaption && (\n <p className={cn(\"text-zinc-500 line-clamp-2 mt-1.5\", s.captionFont)}>{caption}</p>\n )}\n </div>\n );\n }\n\n return (\n <div className=\"flex flex-col\">\n <div className={cn(\n \"relative overflow-hidden group bg-zinc-100 flex flex-col\",\n ratioClass, shapeClass, className,\n )}>\n <img\n src={src}\n alt={alt}\n className={cn(\"w-full\", ratio !== \"free\" && \"h-full\", OBJECT_FIT[objectFit])}\n loading={loading}\n onError={() => { setHasError(true); onError?.(); }}\n />\n {children}\n </div>\n {caption && !hideCaption && (\n <p className={cn(\"text-zinc-500 line-clamp-2 mt-1.5\", s.captionFont)}>{caption}</p>\n )}\n </div>\n );\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type MediaVideoRatio = \"1:1\" | \"16:9\" | \"4:3\" | \"1:2\" | \"free\";\nexport type MediaVideoSize = \"xs\" | \"sm\" | \"md\";\nexport type MediaVideoShape = \"square\" | \"rounded\" | \"circle\";\n\nexport interface MediaVideoProps {\n src: string;\n caption?: string;\n ratio?: MediaVideoRatio;\n size?: MediaVideoSize;\n shape?: MediaVideoShape;\n children?: React.ReactNode;\n hideCaption?: boolean;\n controls?: boolean;\n preload?: \"none\" | \"metadata\" | \"auto\";\n autoPlay?: boolean;\n muted?: boolean;\n loop?: boolean;\n poster?: string;\n onError?: () => void;\n className?: string;\n}\n\n// ── Icons ────────────────────────────────────\n\nfunction VideoIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"m16 13 5.223 3.482a.5.5 0 0 0 .777-.416V7.87a.5.5 0 0 0-.752-.432L16 10.5\" />\n <rect x=\"2\" y=\"6\" width=\"14\" height=\"12\" rx=\"2\" />\n </svg>\n );\n}\n\n// ── Shape definitions ────────────────────────\n\nconst SHAPES: Record<MediaVideoShape, string | null> = {\n square: \"\",\n rounded: null,\n circle: \"rounded-full\",\n};\n\n// ── Ratio definitions ────────────────────────\n\nconst RATIOS: Record<MediaVideoRatio, string> = {\n \"1:1\": \"aspect-square\",\n \"16:9\": \"aspect-video\",\n \"4:3\": \"aspect-[4/3]\",\n \"1:2\": \"aspect-[1/2]\",\n \"free\": \"\",\n};\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<MediaVideoSize, {\n rounded: string;\n captionFont: string;\n errorIconSize: string;\n errorFont: string;\n}> = {\n xs: { rounded: \"rounded-lg\", captionFont: \"text-xs\", errorIconSize: \"size-6\", errorFont: \"text-[10px]\" },\n sm: { rounded: \"rounded-xl\", captionFont: \"text-sm\", errorIconSize: \"size-8\", errorFont: \"text-xs\" },\n md: { rounded: \"rounded-2xl\", captionFont: \"text-base\", errorIconSize: \"size-10\", errorFont: \"text-sm\" },\n};\n\n// ── Component ────────────────────────────────\n\nexport function MediaVideo({\n src,\n caption,\n ratio = \"16:9\",\n size = \"sm\",\n shape = \"rounded\",\n children,\n hideCaption = false,\n controls = true,\n preload = \"metadata\",\n autoPlay = false,\n muted = false,\n loop = false,\n poster,\n onError,\n className,\n}: MediaVideoProps) {\n const [hasError, setHasError] = React.useState(false);\n const s = SIZES[size];\n const ratioClass = RATIOS[ratio];\n const shapeClass = SHAPES[shape] ?? s.rounded;\n\n if (hasError || !src) {\n return (\n <div className=\"flex flex-col\">\n <div className={cn(\"overflow-hidden flex flex-col\", shapeClass, className)}>\n <div className={cn(\n \"relative bg-zinc-900 flex flex-col items-center justify-center\",\n ratioClass,\n )}>\n <div className=\"flex flex-col justify-center items-center gap-2 p-4 text-center\">\n <VideoIcon className={cn(s.errorIconSize, \"text-zinc-500\")} />\n <span className={cn(s.errorFont, \"text-zinc-500\")}>Video could not be loaded</span>\n </div>\n </div>\n {children}\n </div>\n {caption && !hideCaption && (\n <p className={cn(\"text-zinc-500 line-clamp-2 mt-1.5\", s.captionFont)}>{caption}</p>\n )}\n </div>\n );\n }\n\n return (\n <div className=\"flex flex-col\">\n <div className={cn(\"overflow-hidden flex flex-col\", shapeClass, className)}>\n <div className={cn(\"relative bg-black\", ratioClass)}>\n <video\n src={src}\n controls={controls}\n preload={preload}\n autoPlay={autoPlay}\n muted={muted}\n loop={loop}\n poster={poster}\n className=\"w-full h-full object-contain\"\n onError={() => { setHasError(true); onError?.(); }}\n />\n </div>\n {children}\n </div>\n {caption && !hideCaption && (\n <p className={cn(\"text-zinc-500 line-clamp-2 mt-1.5\", s.captionFont)}>{caption}</p>\n )}\n </div>\n );\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type ModalSize = \"sm\" | \"md\" | \"lg\";\n\nexport interface ModalProps {\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n size?: ModalSize;\n closeOnBackdrop?: boolean;\n closeOnEscape?: boolean;\n children: React.ReactNode;\n}\n\nexport interface ModalTriggerProps {\n asChild?: boolean;\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface ModalContentProps {\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface ModalHeaderProps {\n icon?: React.ReactNode;\n hideClose?: boolean;\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface ModalBodyProps {\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface ModalFooterProps {\n className?: string;\n children: React.ReactNode;\n}\n\n// ── X Icon ───────────────────────────────────\n\nfunction XIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n}\n\n// ── Context ──────────────────────────────────\n\ninterface ModalContextValue {\n isOpen: boolean;\n open: () => void;\n close: () => void;\n size: ModalSize;\n closeOnBackdrop: boolean;\n titleId: string;\n descriptionId: string;\n}\n\nconst ModalContext = React.createContext<ModalContextValue | null>(null);\n\nfunction useModal(): ModalContextValue {\n const ctx = React.useContext(ModalContext);\n if (!ctx) throw new Error(\"Modal sub-components must be used within <Modal>\");\n return ctx;\n}\n\n// ── Sizes ────────────────────────────────────\n\nconst SIZES: Record<ModalSize, string> = {\n sm: \"max-w-sm\",\n md: \"max-w-md\",\n lg: \"max-w-lg\",\n};\n\n// ── Modal (root) ─────────────────────────────\n\nfunction ModalRoot({\n open,\n defaultOpen = false,\n onOpenChange,\n size = \"md\",\n closeOnBackdrop = true,\n closeOnEscape = true,\n children,\n}: ModalProps) {\n const [internalOpen, setInternalOpen] = React.useState(defaultOpen);\n const isControlled = open !== undefined;\n const isOpen = isControlled ? open : internalOpen;\n\n const autoId = React.useId();\n const titleId = `modal-title-${autoId}`;\n const descriptionId = `modal-desc-${autoId}`;\n\n const setOpen = React.useCallback((next: boolean) => {\n if (!isControlled) setInternalOpen(next);\n onOpenChange?.(next);\n }, [isControlled, onOpenChange]);\n\n const openModal = React.useCallback(() => setOpen(true), [setOpen]);\n const closeModal = React.useCallback(() => setOpen(false), [setOpen]);\n\n React.useEffect(() => {\n if (!isOpen || !closeOnEscape) return;\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") closeModal();\n };\n document.addEventListener(\"keydown\", handleKeyDown);\n return () => document.removeEventListener(\"keydown\", handleKeyDown);\n }, [isOpen, closeOnEscape, closeModal]);\n\n React.useEffect(() => {\n if (!isOpen) return;\n const prev = document.body.style.overflow;\n document.body.style.overflow = \"hidden\";\n return () => { document.body.style.overflow = prev; };\n }, [isOpen]);\n\n return (\n <ModalContext.Provider value={{ isOpen, open: openModal, close: closeModal, size, closeOnBackdrop, titleId, descriptionId }}>\n {children}\n </ModalContext.Provider>\n );\n}\nModalRoot.displayName = \"Modal\";\n\n// ── Trigger ──────────────────────────────────\n\nfunction ModalTrigger({ asChild = false, className, children }: ModalTriggerProps) {\n const { isOpen, open: openModal, titleId } = useModal();\n\n const handleClick = React.useCallback((e: React.MouseEvent) => {\n if (asChild && React.isValidElement(children)) {\n const originalOnClick = (children.props as Record<string, unknown>).onClick as ((e: React.MouseEvent) => void) | undefined;\n originalOnClick?.(e);\n }\n openModal();\n }, [asChild, children, openModal]);\n\n const triggerProps = {\n \"aria-haspopup\": \"dialog\" as const,\n \"aria-expanded\": isOpen,\n \"aria-controls\": isOpen ? titleId : undefined,\n onClick: handleClick,\n };\n\n if (asChild && React.isValidElement(children)) {\n const ChildType = children.type as React.ElementType;\n const childProps = children.props as Record<string, unknown>;\n return (\n <ChildType\n {...childProps}\n {...triggerProps}\n className={cn(childProps.className as string | undefined, className)}\n />\n );\n }\n\n return (\n <button type=\"button\" {...triggerProps} className={cn(\"cursor-pointer\", className)}>\n {children}\n </button>\n );\n}\nModalTrigger.displayName = \"ModalTrigger\";\n\n// ── Content ──────────────────────────────────\n\nfunction ModalContent({ className, children }: ModalContentProps) {\n const { isOpen, close, size, closeOnBackdrop, titleId, descriptionId } = useModal();\n\n if (!isOpen) return null;\n\n const handleBackdropClick = closeOnBackdrop ? close : undefined;\n\n return ReactDOM.createPortal(\n <div\n className=\"fixed inset-0 z-9999 flex items-center justify-center bg-black/40 backdrop-blur-sm\"\n onClick={handleBackdropClick}\n aria-hidden=\"true\"\n >\n <div\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={titleId}\n aria-describedby={descriptionId}\n onClick={(e) => e.stopPropagation()}\n className={cn(\n \"relative bg-white rounded-2xl shadow-2xl\",\n \"w-full mx-4 overflow-hidden\",\n SIZES[size],\n className,\n )}\n >\n {children}\n </div>\n </div>,\n document.body,\n );\n}\nModalContent.displayName = \"ModalContent\";\n\n// ── Header ───────────────────────────────────\n\nfunction ModalHeader({ icon, hideClose = false, className, children }: ModalHeaderProps) {\n const { titleId, close } = useModal();\n\n return (\n <div className={cn(\"flex flex-col gap-3 px-6 pt-6 pb-0\", className)}>\n {icon && (\n <div className=\"shrink-0 size-10 rounded-xl bg-zinc-100 flex items-center justify-center text-zinc-600\">\n {icon}\n </div>\n )}\n <div className=\"flex-1 flex flex-col gap-0.5\">\n <h2 id={titleId} className=\"text-base font-bold text-zinc-900 leading-snug\">\n {children}\n </h2>\n </div>\n {!hideClose && (\n <button\n type=\"button\"\n aria-label=\"Close\"\n onClick={close}\n className=\"absolute top-4 right-4 size-7 flex items-center justify-center rounded-lg text-zinc-400 hover:bg-zinc-100 hover:text-zinc-900 transition-colors cursor-pointer\"\n >\n <XIcon className=\"size-4\" />\n </button>\n )}\n </div>\n );\n}\nModalHeader.displayName = \"ModalHeader\";\n\n// ── Body ─────────────────────────────────────\n\nfunction ModalBody({ className, children }: ModalBodyProps) {\n const { descriptionId } = useModal();\n\n return (\n <div id={descriptionId} className={cn(\"px-6 py-4 text-sm text-zinc-600 leading-relaxed\", className)}>\n {children}\n </div>\n );\n}\nModalBody.displayName = \"ModalBody\";\n\n// ── Footer ───────────────────────────────────\n\nfunction ModalFooter({ className, children }: ModalFooterProps) {\n return (\n <div className={cn(\"flex flex-wrap gap-3 px-6 pb-6 pt-2\", className)}>\n {children}\n </div>\n );\n}\nModalFooter.displayName = \"ModalFooter\";\n\n// ── Export ────────────────────────────────────\n\nexport const Modal = Object.assign(ModalRoot, {\n Trigger: ModalTrigger,\n Content: ModalContent,\n Header: ModalHeader,\n Body: ModalBody,\n Footer: ModalFooter,\n});\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport interface MultiSelectOption {\n label: string;\n value: string;\n [key: string]: unknown;\n}\n\nexport interface MultiSelectProps {\n value?: string[];\n onChange?: (values: string[], options?: MultiSelectOption[]) => void;\n options?: MultiSelectOption[];\n placeholder?: string;\n className?: string;\n disabled?: boolean;\n autoFlip?: boolean;\n maxHeight?: number;\n searchable?: boolean;\n searchPlaceholder?: string;\n maxSelected?: number;\n maxVisibleChips?: number;\n clearLabel?: string;\n selectedLabel?: string;\n noResultsLabel?: string;\n noOptionsLabel?: string;\n}\n\n// ── Icons ────────────────────────────────────\n\nfunction ChevronDownIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n\nfunction CheckIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M20 6 9 17l-5-5\" />\n </svg>\n );\n}\n\nfunction XIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n}\n\nfunction SearchIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <circle cx=\"11\" cy=\"11\" r=\"8\" />\n <path d=\"m21 21-4.3-4.3\" />\n </svg>\n );\n}\n\n// ── Component ────────────────────────────────\n\nexport function MultiSelect({\n value = [],\n onChange,\n options = [],\n placeholder = \"Select...\",\n className,\n disabled = false,\n autoFlip = true,\n maxHeight = 240,\n searchable = false,\n searchPlaceholder = \"Search...\",\n maxSelected,\n maxVisibleChips = 3,\n clearLabel = \"Clear\",\n selectedLabel = \"selected\",\n noResultsLabel = \"No results found\",\n noOptionsLabel = \"No options\",\n}: MultiSelectProps) {\n const [isOpen, setIsOpen] = React.useState(false);\n const [openDirection, setOpenDirection] = React.useState<\"bottom\" | \"top\">(\"bottom\");\n const [search, setSearch] = React.useState(\"\");\n\n const containerRef = React.useRef<HTMLDivElement>(null);\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const dropdownRef = React.useRef<HTMLDivElement>(null);\n const searchInputRef = React.useRef<HTMLInputElement>(null);\n\n const selectedOptions = React.useMemo(\n () => options.filter((opt) => value.includes(opt.value)),\n [options, value],\n );\n\n const filteredOptions = React.useMemo(() => {\n if (!search.trim()) return options;\n const q = search.toLowerCase();\n return options.filter((opt) => opt.label.toLowerCase().includes(q));\n }, [options, search]);\n\n React.useEffect(() => {\n if (!isOpen) return;\n const handleClickOutside = (event: MouseEvent) => {\n if (containerRef.current && !containerRef.current.contains(event.target as Node)) {\n setIsOpen(false);\n setSearch(\"\");\n }\n };\n document.addEventListener(\"mousedown\", handleClickOutside);\n return () => document.removeEventListener(\"mousedown\", handleClickOutside);\n }, [isOpen]);\n\n React.useEffect(() => {\n if (!isOpen) return;\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") {\n setIsOpen(false);\n setSearch(\"\");\n }\n };\n document.addEventListener(\"keydown\", handleEscape);\n return () => document.removeEventListener(\"keydown\", handleEscape);\n }, [isOpen]);\n\n React.useEffect(() => {\n if (!isOpen || !autoFlip || !triggerRef.current || !dropdownRef.current) return;\n\n const measure = () => {\n if (!triggerRef.current || !dropdownRef.current) return;\n const triggerRect = triggerRef.current.getBoundingClientRect();\n const contentRect = dropdownRef.current.getBoundingClientRect();\n const { innerHeight } = window;\n\n if (triggerRect.bottom + contentRect.height > innerHeight && triggerRect.top > contentRect.height) {\n setOpenDirection(\"top\");\n } else {\n setOpenDirection(\"bottom\");\n }\n };\n\n const timer = requestAnimationFrame(measure);\n window.addEventListener(\"scroll\", measure, { passive: true });\n window.addEventListener(\"resize\", measure);\n\n return () => {\n cancelAnimationFrame(timer);\n window.removeEventListener(\"scroll\", measure);\n window.removeEventListener(\"resize\", measure);\n };\n }, [isOpen, autoFlip]);\n\n React.useEffect(() => {\n if (isOpen && searchable) {\n requestAnimationFrame(() => searchInputRef.current?.focus());\n }\n }, [isOpen, searchable]);\n\n const toggleOption = (option: MultiSelectOption) => {\n const isSelected = value.includes(option.value);\n\n let nextValues: string[];\n if (isSelected) {\n nextValues = value.filter((v) => v !== option.value);\n } else {\n if (maxSelected && value.length >= maxSelected) return;\n nextValues = [...value, option.value];\n }\n\n const nextOptions = options.filter((opt) => nextValues.includes(opt.value));\n onChange?.(nextValues, nextOptions);\n };\n\n const removeOption = (optionValue: string, e: React.MouseEvent) => {\n e.stopPropagation();\n const nextValues = value.filter((v) => v !== optionValue);\n const nextOptions = options.filter((opt) => nextValues.includes(opt.value));\n onChange?.(nextValues, nextOptions);\n };\n\n const hasSelection = selectedOptions.length > 0;\n const visibleChips = selectedOptions.slice(0, maxVisibleChips);\n const overflowCount = selectedOptions.length - maxVisibleChips;\n const isAtMax = maxSelected !== undefined && value.length >= maxSelected;\n\n return (\n <div ref={containerRef} className={cn(\"relative w-full\", className)}>\n <button\n ref={triggerRef}\n type=\"button\"\n disabled={disabled}\n onClick={() => !disabled && setIsOpen((prev) => !prev)}\n className={cn(\n \"flex w-full items-center justify-between rounded-lg border bg-white px-3 py-2 text-[13px] font-medium transition-all duration-200 outline-none min-h-9.5\",\n disabled ? \"opacity-50 cursor-not-allowed border-zinc-200 text-zinc-400\" : \"cursor-pointer\",\n isOpen ? \"border-zinc-400 ring-2 ring-zinc-50 text-zinc-900\" : \"border-zinc-200 text-zinc-700 hover:border-zinc-300 hover:bg-zinc-50\",\n )}\n >\n <div className=\"flex-1 flex items-center gap-1 flex-wrap min-w-0 mr-1\">\n {hasSelection ? (\n <>\n {visibleChips.map((opt) => (\n <span\n key={opt.value}\n className=\"inline-flex items-center gap-1 bg-zinc-100 text-zinc-700 rounded-md px-1.5 py-0.5 text-xs font-medium max-w-30\"\n >\n <span className=\"truncate\">{opt.label}</span>\n {!disabled && (\n <span\n role=\"button\"\n tabIndex={0}\n onClick={(e) => removeOption(opt.value, e)}\n onKeyDown={(e) => {\n if (e.key === \"Enter\" || e.key === \" \") removeOption(opt.value, e as unknown as React.MouseEvent);\n }}\n className=\"shrink-0 hover:text-zinc-900 transition-colors cursor-pointer\"\n >\n <XIcon className=\"size-3\" />\n </span>\n )}\n </span>\n ))}\n {overflowCount > 0 && (\n <span className=\"text-xs text-zinc-400 font-medium px-1\">\n +{overflowCount}\n </span>\n )}\n </>\n ) : (\n <span className=\"text-zinc-400 truncate\">{placeholder}</span>\n )}\n </div>\n <ChevronDownIcon\n className={cn(\n \"size-4 shrink-0 transition-transform duration-200\",\n isOpen && openDirection === \"bottom\" ? \"rotate-180 text-zinc-900\" : isOpen && openDirection === \"top\" ? \"text-zinc-900\" : \"text-zinc-400\",\n )}\n />\n </button>\n\n {isOpen && (\n <div\n ref={dropdownRef}\n className={cn(\n \"absolute left-0 z-50 w-full rounded-xl border border-zinc-200 bg-white shadow-[0_8px_30px_rgb(0,0,0,0.12)]\",\n openDirection === \"bottom\" ? \"top-[calc(100%+4px)]\" : \"bottom-[calc(100%+4px)]\",\n )}\n >\n {searchable && (\n <div className=\"p-1.5 pb-0\">\n <div className=\"relative\">\n <SearchIcon className=\"absolute left-2.5 top-1/2 -translate-y-1/2 size-3.5 text-zinc-400\" />\n <input\n ref={searchInputRef}\n type=\"text\"\n value={search}\n onChange={(e) => setSearch(e.target.value)}\n placeholder={searchPlaceholder}\n className=\"w-full pl-8 pr-3 py-2 text-[13px] border border-zinc-200 rounded-lg outline-none focus:border-zinc-400 transition-colors bg-zinc-50\"\n />\n </div>\n </div>\n )}\n\n <div\n className=\"overflow-y-auto p-1.5\"\n style={{ maxHeight: `${maxHeight}px` }}\n >\n {filteredOptions.length === 0 ? (\n <div className=\"py-2.5 px-3 text-[13px] text-zinc-500 text-center font-medium\">\n {search ? noResultsLabel : noOptionsLabel}\n </div>\n ) : (\n <div className=\"flex flex-col gap-0.5\">\n {filteredOptions.map((option) => {\n const isSelected = value.includes(option.value);\n const isDisabledOption = !isSelected && isAtMax;\n return (\n <button\n key={option.value}\n type=\"button\"\n disabled={isDisabledOption}\n onClick={() => toggleOption(option)}\n className={cn(\n \"relative flex w-full select-none items-center rounded-md py-2 pl-9 pr-3 text-[13px] outline-none transition-colors\",\n isDisabledOption ? \"opacity-40 cursor-not-allowed\" : \"cursor-pointer\",\n isSelected ? \"bg-zinc-50 text-zinc-900 font-semibold\" : \"text-zinc-600 hover:bg-zinc-50 hover:text-zinc-900\",\n )}\n >\n <span className=\"absolute left-3 flex h-full items-center justify-center\">\n {isSelected ? (\n <CheckIcon className=\"size-4 text-zinc-900\" />\n ) : (\n <div className=\"size-4 rounded border border-zinc-300\" />\n )}\n </span>\n <span className=\"truncate\">{option.label}</span>\n </button>\n );\n })}\n </div>\n )}\n </div>\n\n {hasSelection && (\n <div className=\"border-t border-zinc-100 px-3 py-2 flex items-center justify-between\">\n <span className=\"text-xs text-zinc-400 font-medium\">\n {selectedOptions.length} {selectedLabel}\n {maxSelected && <span> / {maxSelected}</span>}\n </span>\n <button\n type=\"button\"\n onClick={() => onChange?.([], [])}\n className=\"text-xs text-zinc-400 hover:text-zinc-700 font-medium transition-colors cursor-pointer\"\n >\n {clearLabel}\n </button>\n </div>\n )}\n </div>\n )}\n </div>\n );\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type NotificationColor = \"default\" | \"primary\" | \"danger\" | \"success\" | \"warning\" | \"info\";\nexport type NotificationPosition = \"top-right\" | \"top-left\" | \"bottom-right\" | \"bottom-left\" | \"top-center\" | \"bottom-center\";\n\nexport interface NotificationAction {\n label: string;\n onClick: () => void;\n variant?: \"default\" | \"primary\";\n}\n\nexport interface NotificationItem {\n id: string;\n title?: React.ReactNode;\n message?: React.ReactNode;\n icon?: React.ReactNode;\n color?: NotificationColor;\n /** Auto-dismiss duration in ms (0 = persistent, default: 5000) */\n duration?: number;\n /** Show close button (default: true) */\n dismissible?: boolean;\n /** Show progress bar for auto-dismiss countdown */\n showProgress?: boolean;\n /** Action buttons */\n actions?: NotificationAction[];\n /** Pause auto-dismiss on hover (default: true) */\n pauseOnHover?: boolean;\n /** Callback when notification is dismissed */\n onDismiss?: () => void;\n /** Timestamp for \"time ago\" display */\n timestamp?: Date;\n}\n\nexport interface NotificationProps {\n item: NotificationItem;\n onDismiss: (id: string) => void;\n}\n\nexport interface NotificationContainerProps {\n position?: NotificationPosition;\n /** Max visible notifications (older ones hidden, default: 5) */\n maxVisible?: number;\n className?: string;\n children: React.ReactNode;\n}\n\n// ── Icons ────────────────────────────────────\n\nfunction XIcon({ className }: { className?: string }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n}\n\n// ── Color definitions ────────────────────────\n\ninterface NotificationColorDef {\n border: string;\n icon: string;\n dismissHover: string;\n progressBar: string;\n actionPrimary: string;\n}\n\nconst COLORS: Record<NotificationColor, NotificationColorDef> = {\n default: {\n border: \"border-l-zinc-400\",\n icon: \"text-zinc-500\",\n dismissHover: \"hover:bg-zinc-100 hover:text-zinc-900\",\n progressBar: \"bg-zinc-400\",\n actionPrimary: \"text-zinc-700 hover:text-zinc-900\",\n },\n primary: {\n border: \"border-l-blue-500\",\n icon: \"text-blue-500\",\n dismissHover: \"hover:bg-blue-50 hover:text-blue-900\",\n progressBar: \"bg-blue-500\",\n actionPrimary: \"text-blue-600 hover:text-blue-800\",\n },\n danger: {\n border: \"border-l-red-500\",\n icon: \"text-red-500\",\n dismissHover: \"hover:bg-red-50 hover:text-red-900\",\n progressBar: \"bg-red-500\",\n actionPrimary: \"text-red-600 hover:text-red-800\",\n },\n success: {\n border: \"border-l-green-500\",\n icon: \"text-green-500\",\n dismissHover: \"hover:bg-green-50 hover:text-green-900\",\n progressBar: \"bg-green-500\",\n actionPrimary: \"text-green-600 hover:text-green-800\",\n },\n warning: {\n border: \"border-l-yellow-500\",\n icon: \"text-yellow-500\",\n dismissHover: \"hover:bg-yellow-50 hover:text-yellow-900\",\n progressBar: \"bg-yellow-500\",\n actionPrimary: \"text-yellow-600 hover:text-yellow-800\",\n },\n info: {\n border: \"border-l-indigo-500\",\n icon: \"text-indigo-500\",\n dismissHover: \"hover:bg-indigo-50 hover:text-indigo-900\",\n progressBar: \"bg-indigo-500\",\n actionPrimary: \"text-indigo-600 hover:text-indigo-800\",\n },\n};\n\n// ── Position definitions ─────────────────────\n\nconst POSITIONS: Record<NotificationPosition, string> = {\n \"top-right\": \"top-4 right-4 items-end\",\n \"top-left\": \"top-4 left-4 items-start\",\n \"bottom-right\": \"bottom-4 right-4 items-end\",\n \"bottom-left\": \"bottom-4 left-4 items-start\",\n \"top-center\": \"top-4 left-1/2 -translate-x-1/2 items-center\",\n \"bottom-center\": \"bottom-4 left-1/2 -translate-x-1/2 items-center\",\n};\n\n// ── Time ago helper ──────────────────────────\n\nfunction timeAgo(date: Date): string {\n const seconds = Math.floor((Date.now() - date.getTime()) / 1000);\n if (seconds < 5) return \"just now\";\n if (seconds < 60) return `${seconds}s ago`;\n const minutes = Math.floor(seconds / 60);\n if (minutes < 60) return `${minutes}m ago`;\n const hours = Math.floor(minutes / 60);\n if (hours < 24) return `${hours}h ago`;\n return `${Math.floor(hours / 24)}d ago`;\n}\n\n// ── Notification Item ────────────────────────\n\nexport function Notification({ item, onDismiss }: NotificationProps) {\n const {\n id,\n title,\n message,\n icon,\n color = \"default\",\n duration = 5000,\n dismissible = true,\n showProgress = false,\n actions,\n pauseOnHover = true,\n onDismiss: onItemDismiss,\n timestamp,\n } = item;\n\n const c = COLORS[color];\n const [paused, setPaused] = React.useState(false);\n const [progress, setProgress] = React.useState(100);\n const [timeLabel, setTimeLabel] = React.useState(timestamp ? timeAgo(timestamp) : \"\");\n const startTimeRef = React.useRef(Date.now());\n const remainingRef = React.useRef(duration);\n\n // Auto-dismiss with pause support\n React.useEffect(() => {\n if (duration <= 0) return;\n\n if (paused) return;\n\n const start = Date.now();\n const remaining = remainingRef.current;\n\n const timer = setTimeout(() => {\n onItemDismiss?.();\n onDismiss(id);\n }, remaining);\n\n const progressInterval = showProgress\n ? setInterval(() => {\n const elapsed = Date.now() - start;\n const newProgress = Math.max(0, ((remaining - elapsed) / duration) * 100);\n setProgress(newProgress);\n }, 50)\n : undefined;\n\n return () => {\n clearTimeout(timer);\n if (progressInterval) clearInterval(progressInterval);\n remainingRef.current = Math.max(0, remaining - (Date.now() - start));\n };\n }, [id, duration, paused, onDismiss, onItemDismiss, showProgress]);\n\n // Update time ago label\n React.useEffect(() => {\n if (!timestamp) return;\n const interval = setInterval(() => setTimeLabel(timeAgo(timestamp)), 10000);\n return () => clearInterval(interval);\n }, [timestamp]);\n\n const handleMouseEnter = () => {\n if (pauseOnHover && duration > 0) setPaused(true);\n };\n\n const handleMouseLeave = () => {\n if (pauseOnHover && duration > 0) setPaused(false);\n };\n\n const handleDismiss = () => {\n onItemDismiss?.();\n onDismiss(id);\n };\n\n return (\n <div\n role=\"status\"\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n className={cn(\n \"relative flex flex-col w-80 bg-white border border-zinc-200 border-l-4 rounded-lg shadow-lg overflow-hidden\",\n c.border,\n )}\n >\n <div className=\"flex gap-3 p-4\">\n {icon && (\n <span className={cn(\"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full size-5 mt-0.5\", c.icon)}>\n {icon}\n </span>\n )}\n\n <div className=\"flex-1 min-w-0\">\n <div className=\"flex items-start justify-between gap-2\">\n <div className=\"flex-1 min-w-0\">\n {title && (\n <div className=\"text-sm font-semibold text-zinc-900 leading-snug\">\n {title}\n </div>\n )}\n {message && (\n <div className={cn(\"text-xs text-zinc-500 leading-relaxed\", title && \"mt-1\")}>\n {message}\n </div>\n )}\n </div>\n\n <div className=\"flex items-center gap-1 shrink-0\">\n {timestamp && (\n <span className=\"text-[10px] text-zinc-400\">{timeLabel}</span>\n )}\n {dismissible && (\n <button\n type=\"button\"\n onClick={handleDismiss}\n className={cn(\n \"flex items-center justify-center size-5 rounded text-zinc-400 transition-colors cursor-pointer\",\n c.dismissHover,\n )}\n >\n <XIcon className=\"size-3.5\" />\n </button>\n )}\n </div>\n </div>\n\n {actions && actions.length > 0 && (\n <div className=\"flex gap-3 mt-2.5\">\n {actions.map((action) => (\n <button\n key={action.label}\n type=\"button\"\n onClick={action.onClick}\n className={cn(\n \"text-xs font-semibold transition-colors cursor-pointer\",\n action.variant === \"primary\" ? c.actionPrimary : \"text-zinc-500 hover:text-zinc-700\",\n )}\n >\n {action.label}\n </button>\n ))}\n </div>\n )}\n </div>\n </div>\n\n {showProgress && duration > 0 && (\n <div className=\"h-0.5 w-full bg-zinc-100\">\n <div\n className={cn(\"h-full transition-all duration-100 ease-linear\", c.progressBar)}\n style={{ width: `${progress}%` }}\n />\n </div>\n )}\n </div>\n );\n}\n\n// ── Notification Container ───────────────────\n\nexport function NotificationContainer({\n position = \"top-right\",\n maxVisible = 5,\n className,\n children,\n}: NotificationContainerProps) {\n const childArray = React.Children.toArray(children);\n const visibleChildren = childArray.slice(-maxVisible);\n const hiddenCount = childArray.length - visibleChildren.length;\n\n return ReactDOM.createPortal(\n <div\n className={cn(\n \"fixed z-9999 flex flex-col gap-3 pointer-events-none\",\n POSITIONS[position],\n className,\n )}\n >\n <div className=\"flex flex-col gap-3 pointer-events-auto\">\n {hiddenCount > 0 && (\n <div className=\"text-[10px] text-zinc-400 text-center font-medium\">\n +{hiddenCount} more\n </div>\n )}\n {visibleChildren}\n </div>\n </div>,\n document.body,\n );\n}\n\n// ── useNotification Hook ─────────────────────\n\nlet notificationCounter = 0;\n\nexport function useNotification() {\n const [notifications, setNotifications] = React.useState<NotificationItem[]>([]);\n\n const push = React.useCallback((item: Omit<NotificationItem, \"id\"> & { id?: string }) => {\n const id = item.id || `notification-${++notificationCounter}`;\n setNotifications((prev) => [...prev, { ...item, id }]);\n return id;\n }, []);\n\n const dismiss = React.useCallback((id: string) => {\n setNotifications((prev) => prev.filter((n) => n.id !== id));\n }, []);\n\n const dismissAll = React.useCallback(() => {\n setNotifications([]);\n }, []);\n\n const update = React.useCallback((id: string, updates: Partial<Omit<NotificationItem, \"id\">>) => {\n setNotifications((prev) => prev.map((n) => n.id === id ? { ...n, ...updates } : n));\n }, []);\n\n return { notifications, push, dismiss, dismissAll, update };\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type RadioSize = \"xs\" | \"sm\" | \"md\";\nexport type RadioColor = \"default\" | \"black\" | \"primary\" | \"danger\" | \"success\" | \"warning\" | \"info\";\nexport type RadioVariant = \"default\" | \"card\" | \"list\";\n\nexport interface RadioProps {\n variant?: RadioVariant;\n checked?: boolean;\n onChange?: (checked: boolean) => void;\n size?: RadioSize;\n color?: RadioColor;\n label?: React.ReactNode;\n description?: React.ReactNode;\n disabled?: boolean;\n className?: string;\n name?: string;\n value?: string;\n id?: string;\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<RadioSize, {\n box: string;\n dotSize: string;\n labelFont: string;\n descFont: string;\n gap: string;\n cardPadding: string;\n}> = {\n xs: {\n box: \"size-3.5\",\n dotSize: \"size-1.5\",\n labelFont: \"text-xs\",\n descFont: \"text-[10px]\",\n gap: \"gap-1.5\",\n cardPadding: \"p-2\",\n },\n sm: {\n box: \"size-4\",\n dotSize: \"size-2\",\n labelFont: \"text-sm\",\n descFont: \"text-xs\",\n gap: \"gap-2\",\n cardPadding: \"p-2.5\",\n },\n md: {\n box: \"size-5\",\n dotSize: \"size-2.5\",\n labelFont: \"text-base\",\n descFont: \"text-sm\",\n gap: \"gap-2.5\",\n cardPadding: \"p-3\",\n },\n};\n\n// ── Color definitions ────────────────────────\n\ninterface RadioColorDef {\n checked: string;\n hover: string;\n}\n\nconst COLORS: Record<RadioColor, RadioColorDef> = {\n default: {\n checked: \"border-zinc-900 bg-zinc-900\",\n hover: \"group-hover/radio:border-zinc-400\",\n },\n black: {\n checked: \"border-zinc-900 bg-zinc-900\",\n hover: \"group-hover/radio:border-zinc-400\",\n },\n primary: {\n checked: \"border-blue-600 bg-blue-600\",\n hover: \"group-hover/radio:border-blue-300\",\n },\n danger: {\n checked: \"border-red-500 bg-red-500\",\n hover: \"group-hover/radio:border-red-300\",\n },\n success: {\n checked: \"border-green-500 bg-green-500\",\n hover: \"group-hover/radio:border-green-300\",\n },\n warning: {\n checked: \"border-yellow-500 bg-yellow-500\",\n hover: \"group-hover/radio:border-yellow-300\",\n },\n info: {\n checked: \"border-indigo-500 bg-indigo-500\",\n hover: \"group-hover/radio:border-indigo-300\",\n },\n};\n\n// ── Card variant colors ──────────────────────\n\ninterface CardColorDef {\n checked: string;\n unchecked: string;\n}\n\nconst CARD_COLORS: Record<RadioColor, CardColorDef> = {\n default: {\n checked: \"bg-zinc-50 border-zinc-300 text-zinc-800\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n black: {\n checked: \"bg-zinc-100 border-zinc-300 text-zinc-900\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n primary: {\n checked: \"bg-blue-50/50 border-blue-200 text-blue-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n danger: {\n checked: \"bg-red-50/50 border-red-200 text-red-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n success: {\n checked: \"bg-green-50/50 border-green-200 text-green-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n warning: {\n checked: \"bg-yellow-50/50 border-yellow-200 text-yellow-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n info: {\n checked: \"bg-indigo-50/50 border-indigo-200 text-indigo-700\",\n unchecked: \"bg-white border-zinc-200 text-zinc-600 hover:bg-zinc-50 hover:border-zinc-300\",\n },\n};\n\n// ── Component ────────────────────────────────\n\nexport const Radio = React.forwardRef<HTMLInputElement, RadioProps>(\n (\n {\n variant = \"default\",\n checked = false,\n onChange,\n size = \"sm\",\n color = \"default\",\n label,\n description,\n disabled = false,\n className,\n name,\n value,\n id: idProp,\n },\n ref,\n ) => {\n const autoId = React.useId();\n const id = idProp || autoId;\n\n const s = SIZES[size];\n const c = COLORS[color];\n\n const handleChange = () => {\n if (disabled) return;\n onChange?.(!checked);\n };\n\n const variantClasses = (() => {\n switch (variant) {\n case \"card\": {\n const cc = CARD_COLORS[color];\n return cn(\n \"rounded-xl border font-medium transition-colors\",\n s.cardPadding,\n checked ? cc.checked : cc.unchecked,\n );\n }\n case \"list\":\n return \"p-2 rounded-lg hover:bg-zinc-50 transition-colors\";\n default:\n return \"\";\n }\n })();\n\n return (\n <label\n htmlFor={id}\n className={cn(\n \"group/radio inline-flex items-start select-none\",\n s.gap,\n disabled ? \"opacity-50 cursor-not-allowed\" : \"cursor-pointer\",\n variantClasses,\n className,\n )}\n >\n <input\n ref={ref}\n id={id}\n type=\"radio\"\n className=\"sr-only\"\n checked={checked}\n onChange={handleChange}\n disabled={disabled}\n name={name}\n value={value}\n />\n\n <div\n className={cn(\n \"shrink-0 flex items-center justify-center rounded-full transition-all duration-150 mt-0.5\",\n s.box,\n checked\n ? cn(c.checked, \"text-white\")\n : cn(\"border border-zinc-300 bg-white\", !disabled && c.hover),\n )}\n >\n {checked && (\n <div className={cn(\"rounded-full bg-white\", s.dotSize)} />\n )}\n </div>\n\n {(label || description) && (\n <div className=\"flex flex-col min-w-0\">\n {label && (\n <span className={cn(\"font-medium\", s.labelFont, variant === \"default\" && \"text-zinc-700\")}>\n {label}\n </span>\n )}\n {description && (\n <span className={cn(\"text-zinc-400 mt-0.5\", s.descFont)}>\n {description}\n </span>\n )}\n </div>\n )}\n </label>\n );\n },\n);\n\nRadio.displayName = \"Radio\";\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type RadioGroupVariant = \"bordered\" | \"segmented\";\n\nexport interface RadioGroupProps {\n variant?: RadioGroupVariant;\n className?: string;\n children: React.ReactNode;\n}\n\n// ── Component ────────────────────────────────\n\nexport function RadioGroup({\n variant = \"bordered\",\n className,\n children,\n}: RadioGroupProps) {\n const items = React.Children.toArray(children).filter(React.isValidElement);\n\n return (\n <div\n className={cn(\n \"inline-flex items-center rounded-lg\",\n variant === \"bordered\"\n ? \"bg-white border border-zinc-200\"\n : \"bg-zinc-100 p-1 gap-px\",\n className,\n )}\n >\n {items.map((child, index) => {\n const childProps = child.props as { className?: string; checked?: boolean };\n const isChecked = !!childProps.checked;\n\n return (\n <React.Fragment key={index}>\n {React.cloneElement(child as React.ReactElement<{ className?: string }>, {\n className: cn(\n childProps.className,\n \"border-0\",\n variant === \"segmented\" && !isChecked && \"bg-transparent hover:bg-white/80\",\n variant === \"segmented\" && isChecked && \"bg-white shadow-sm text-zinc-900\",\n ),\n })}\n\n {variant === \"bordered\" && index < items.length - 1 && (\n <div className=\"w-px self-stretch my-2 bg-zinc-200 shrink-0\" />\n )}\n </React.Fragment>\n );\n })}\n </div>\n );\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport interface SelectOption {\n label: string;\n value: string;\n [key: string]: unknown;\n}\n\nexport interface SelectProps {\n value?: string;\n onChange?: (value: string, option?: SelectOption) => void;\n options?: SelectOption[];\n placeholder?: string;\n className?: string;\n disabled?: boolean;\n autoFlip?: boolean;\n maxHeight?: number;\n}\n\n// ── Icons ────────────────────────────────────\n\nfunction ChevronDownIcon({ className, strokeWidth = 2 }: { className?: string; strokeWidth?: number }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth={strokeWidth} strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n\nfunction CheckIcon({ className, strokeWidth = 2.5 }: { className?: string; strokeWidth?: number }) {\n return (\n <svg className={className} xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth={strokeWidth} strokeLinecap=\"round\" strokeLinejoin=\"round\">\n <path d=\"M20 6 9 17l-5-5\" />\n </svg>\n );\n}\n\n// ── Component ────────────────────────────────\n\nexport function Select({\n value,\n onChange,\n options = [],\n placeholder = \"Select...\",\n className,\n disabled = false,\n autoFlip = true,\n maxHeight = 240,\n}: SelectProps) {\n const [isOpen, setIsOpen] = React.useState(false);\n const [openDirection, setOpenDirection] = React.useState<\"bottom\" | \"top\">(\"bottom\");\n\n const containerRef = React.useRef<HTMLDivElement>(null);\n const buttonRef = React.useRef<HTMLButtonElement>(null);\n const dropdownRef = React.useRef<HTMLDivElement>(null);\n\n const selectedOption = options.find((opt) => opt.value === value);\n\n React.useEffect(() => {\n if (!isOpen) return;\n const handleClickOutside = (event: MouseEvent) => {\n if (containerRef.current && !containerRef.current.contains(event.target as Node)) {\n setIsOpen(false);\n }\n };\n document.addEventListener(\"mousedown\", handleClickOutside);\n return () => document.removeEventListener(\"mousedown\", handleClickOutside);\n }, [isOpen]);\n\n React.useEffect(() => {\n if (!isOpen) return;\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") setIsOpen(false);\n };\n document.addEventListener(\"keydown\", handleEscape);\n return () => document.removeEventListener(\"keydown\", handleEscape);\n }, [isOpen]);\n\n React.useEffect(() => {\n if (!isOpen || !autoFlip || !buttonRef.current || !dropdownRef.current) return;\n\n const measure = () => {\n if (!buttonRef.current || !dropdownRef.current) return;\n const triggerRect = buttonRef.current.getBoundingClientRect();\n const contentRect = dropdownRef.current.getBoundingClientRect();\n const { innerHeight } = window;\n\n if (triggerRect.bottom + contentRect.height > innerHeight && triggerRect.top > contentRect.height) {\n setOpenDirection(\"top\");\n } else {\n setOpenDirection(\"bottom\");\n }\n };\n\n const timer = requestAnimationFrame(measure);\n window.addEventListener(\"scroll\", measure, { passive: true });\n window.addEventListener(\"resize\", measure);\n\n return () => {\n cancelAnimationFrame(timer);\n window.removeEventListener(\"scroll\", measure);\n window.removeEventListener(\"resize\", measure);\n };\n }, [isOpen, autoFlip]);\n\n const handleSelect = (option: SelectOption) => {\n onChange?.(option.value, option);\n setIsOpen(false);\n };\n\n return (\n <div ref={containerRef} className={cn(\"relative w-full\", className)}>\n <button\n ref={buttonRef}\n type=\"button\"\n disabled={disabled}\n onClick={() => !disabled && setIsOpen((prev) => !prev)}\n className={cn(\n \"flex w-full items-center justify-between rounded-lg border bg-white px-3 py-2 text-[13px] font-medium transition-all duration-200 outline-none\",\n disabled ? \"opacity-50 cursor-not-allowed border-zinc-200 text-zinc-400\" : \"cursor-pointer\",\n isOpen ? \"border-zinc-400 ring-2 ring-zinc-50 text-zinc-900\" : \"border-zinc-200 text-zinc-700 hover:border-zinc-300 hover:bg-zinc-50\",\n )}\n >\n <span className=\"truncate\">\n {selectedOption ? selectedOption.label : <span className=\"text-zinc-400\">{placeholder}</span>}\n </span>\n <ChevronDownIcon\n className={cn(\n \"size-4 shrink-0 transition-transform duration-200\",\n isOpen && openDirection === \"bottom\" ? \"rotate-180 text-zinc-900\" : isOpen && openDirection === \"top\" ? \"text-zinc-900\" : \"text-zinc-400\",\n )}\n />\n </button>\n\n {isOpen && (\n <div\n ref={dropdownRef}\n className={cn(\n \"absolute left-0 z-50 w-full rounded-xl border border-zinc-200 bg-white p-1.5 shadow-[0_8px_30px_rgb(0,0,0,0.12)]\",\n openDirection === \"bottom\" ? \"top-[calc(100%+4px)]\" : \"bottom-[calc(100%+4px)]\",\n )}\n >\n <div\n className=\"overflow-y-auto\"\n style={{ maxHeight: `${maxHeight}px` }}\n >\n {options.length === 0 ? (\n <div className=\"py-2.5 px-3 text-[13px] text-zinc-500 text-center font-medium\">No options</div>\n ) : (\n <div className=\"flex flex-col gap-0.5\">\n {options.map((option) => {\n const isSelected = value === option.value;\n return (\n <button\n key={option.value}\n type=\"button\"\n onClick={() => handleSelect(option)}\n className={cn(\n \"relative flex w-full cursor-pointer select-none items-center rounded-md py-2 pl-9 pr-3 text-[13px] outline-none transition-colors\",\n isSelected ? \"bg-zinc-50 text-zinc-900 font-semibold\" : \"text-zinc-600 hover:bg-zinc-50 hover:text-zinc-900\",\n )}\n >\n {isSelected && (\n <span className=\"absolute left-3 flex h-full items-center justify-center\">\n <CheckIcon className=\"size-4 text-zinc-900\" />\n </span>\n )}\n <span className=\"truncate\">{option.label}</span>\n </button>\n );\n })}\n </div>\n )}\n </div>\n </div>\n )}\n </div>\n );\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type SwitchSize = \"xs\" | \"sm\" | \"md\";\nexport type SwitchColor = \"default\" | \"black\" | \"primary\" | \"danger\" | \"success\" | \"warning\" | \"info\";\n\nexport interface SwitchProps {\n checked?: boolean;\n onChange?: (checked: boolean) => void;\n size?: SwitchSize;\n color?: SwitchColor;\n label?: React.ReactNode;\n description?: React.ReactNode;\n disabled?: boolean;\n className?: string;\n name?: string;\n value?: string;\n id?: string;\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<SwitchSize, {\n track: string;\n thumb: string;\n thumbTranslate: string;\n labelFont: string;\n descFont: string;\n gap: string;\n}> = {\n xs: {\n track: \"w-7 h-4\",\n thumb: \"size-3\",\n thumbTranslate: \"translate-x-3\",\n labelFont: \"text-xs\",\n descFont: \"text-[10px]\",\n gap: \"gap-1.5\",\n },\n sm: {\n track: \"w-9 h-5\",\n thumb: \"size-3.5\",\n thumbTranslate: \"translate-x-4\",\n labelFont: \"text-sm\",\n descFont: \"text-xs\",\n gap: \"gap-2\",\n },\n md: {\n track: \"w-11 h-6\",\n thumb: \"size-4.5\",\n thumbTranslate: \"translate-x-5\",\n labelFont: \"text-base\",\n descFont: \"text-sm\",\n gap: \"gap-2.5\",\n },\n};\n\n// ── Color definitions ────────────────────────\n\ninterface SwitchColorDef {\n checked: string;\n hover: string;\n}\n\nconst COLORS: Record<SwitchColor, SwitchColorDef> = {\n default: {\n checked: \"bg-zinc-900\",\n hover: \"group-hover/switch:bg-zinc-300\",\n },\n black: {\n checked: \"bg-zinc-900\",\n hover: \"group-hover/switch:bg-zinc-300\",\n },\n primary: {\n checked: \"bg-blue-600\",\n hover: \"group-hover/switch:bg-blue-200\",\n },\n danger: {\n checked: \"bg-red-500\",\n hover: \"group-hover/switch:bg-red-200\",\n },\n success: {\n checked: \"bg-green-500\",\n hover: \"group-hover/switch:bg-green-200\",\n },\n warning: {\n checked: \"bg-yellow-500\",\n hover: \"group-hover/switch:bg-yellow-200\",\n },\n info: {\n checked: \"bg-indigo-500\",\n hover: \"group-hover/switch:bg-indigo-200\",\n },\n};\n\n// ── Component ────────────────────────────────\n\nexport const Switch = React.forwardRef<HTMLInputElement, SwitchProps>(\n (\n {\n checked = false,\n onChange,\n size = \"sm\",\n color = \"default\",\n label,\n description,\n disabled = false,\n className,\n name,\n value,\n id: idProp,\n },\n ref,\n ) => {\n const autoId = React.useId();\n const id = idProp || autoId;\n\n const s = SIZES[size];\n const c = COLORS[color];\n\n const handleChange = () => {\n if (disabled) return;\n onChange?.(!checked);\n };\n\n return (\n <label\n htmlFor={id}\n className={cn(\n \"group/switch inline-flex items-start select-none\",\n s.gap,\n disabled ? \"opacity-50 cursor-not-allowed\" : \"cursor-pointer\",\n className,\n )}\n >\n <input\n ref={ref}\n id={id}\n type=\"checkbox\"\n role=\"switch\"\n aria-checked={checked}\n className=\"sr-only\"\n checked={checked}\n onChange={handleChange}\n disabled={disabled}\n name={name}\n value={value}\n />\n\n <div\n className={cn(\n \"shrink-0 relative rounded-full transition-colors duration-200 mt-0.5\",\n s.track,\n checked\n ? c.checked\n : cn(\"bg-zinc-200\", !disabled && c.hover),\n )}\n >\n <div\n className={cn(\n \"absolute top-1/2 -translate-y-1/2 left-0.5 rounded-full bg-white shadow-sm transition-transform duration-200\",\n s.thumb,\n checked && s.thumbTranslate,\n )}\n />\n </div>\n\n {(label || description) && (\n <div className=\"flex flex-col min-w-0\">\n {label && (\n <span className={cn(\"font-medium text-zinc-700\", s.labelFont)}>\n {label}\n </span>\n )}\n {description && (\n <span className={cn(\"text-zinc-400 mt-0.5\", s.descFont)}>\n {description}\n </span>\n )}\n </div>\n )}\n </label>\n );\n },\n);\n\nSwitch.displayName = \"Switch\";\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type TableSize = \"xs\" | \"sm\" | \"md\";\nexport type TableVariant = \"default\" | \"bordered\" | \"striped\";\nexport type TableShape = \"square\" | \"rounded\";\n\nexport interface TableProps {\n size?: TableSize;\n variant?: TableVariant;\n shape?: TableShape;\n fullWidth?: boolean;\n scrollX?: boolean;\n scrollY?: boolean;\n maxHeight?: string;\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface TableHeadProps {\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface TableBodyProps {\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface TableRowProps {\n onClick?: () => void;\n isActive?: boolean;\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface TableHeaderProps {\n align?: \"left\" | \"center\" | \"right\";\n width?: string;\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TableCellProps {\n align?: \"left\" | \"center\" | \"right\";\n truncate?: boolean;\n className?: string;\n children?: React.ReactNode;\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<TableSize, { cell: string; header: string; text: string }> = {\n xs: { cell: \"px-3 py-1.5\", header: \"px-3 py-1.5\", text: \"text-xs\" },\n sm: { cell: \"px-4 py-2.5\", header: \"px-4 py-2.5\", text: \"text-sm\" },\n md: { cell: \"px-5 py-3.5\", header: \"px-5 py-3.5\", text: \"text-base\" },\n};\n\n// ── Shape definitions ────────────────────────\n\nconst SHAPES: Record<TableShape, string> = {\n square: \"\",\n rounded: \"rounded-lg overflow-hidden\",\n};\n\n// ── Variant styles ───────────────────────────\n\nconst TABLE_VARIANTS: Record<TableVariant, string> = {\n default: \"\",\n bordered: \"border border-zinc-200\",\n striped: \"\",\n};\n\nconst ROW_VARIANTS: Record<TableVariant, { base: string; active: string }> = {\n default: {\n base: \"border-b border-zinc-100 last:border-0\",\n active: \"bg-zinc-50\",\n },\n bordered: {\n base: \"border-b border-zinc-100 last:border-0\",\n active: \"bg-zinc-50\",\n },\n striped: {\n base: \"border-b border-zinc-100 last:border-0 even:bg-zinc-50/50\",\n active: \"bg-zinc-100\",\n },\n};\n\n// ── Context ──────────────────────────────────\n\ninterface TableContextValue {\n size: TableSize;\n variant: TableVariant;\n}\n\nconst TableContext = React.createContext<TableContextValue>({ size: \"sm\", variant: \"default\" });\n\nfunction useTable() {\n return React.useContext(TableContext);\n}\n\n// ── Align map ────────────────────────────────\n\nconst ALIGN_MAP = {\n left: \"text-left\",\n center: \"text-center\",\n right: \"text-right\",\n};\n\n// ── Table Root ───────────────────────────────\n\nfunction TableRoot({\n size = \"sm\",\n variant = \"default\",\n shape = \"rounded\",\n fullWidth = true,\n scrollX = false,\n scrollY = false,\n maxHeight,\n className,\n children,\n}: TableProps) {\n return (\n <TableContext.Provider value={{ size, variant }}>\n <div\n className={cn(\n TABLE_VARIANTS[variant],\n SHAPES[shape],\n scrollX && \"overflow-x-auto\",\n scrollY && \"overflow-y-auto\",\n className,\n )}\n style={scrollY && maxHeight ? { maxHeight } : undefined}\n >\n <table className={cn(\"border-collapse\", fullWidth && \"w-full\")}>\n {children}\n </table>\n </div>\n </TableContext.Provider>\n );\n}\n\n// ── Table Head ───────────────────────────────\n\nfunction TableHead({ className, children }: TableHeadProps) {\n return (\n <thead className={cn(\"bg-zinc-50 border-b border-zinc-200 sticky top-0 z-10\", className)}>\n {children}\n </thead>\n );\n}\n\n// ── Table Body ───────────────────────────────\n\nfunction TableBody({ className, children }: TableBodyProps) {\n return (\n <tbody className={cn(\"bg-white\", className)}>\n {children}\n </tbody>\n );\n}\n\n// ── Table Row ────────────────────────────────\n\nfunction TableRow({ onClick, isActive, className, children }: TableRowProps) {\n const { variant } = useTable();\n const v = ROW_VARIANTS[variant];\n\n return (\n <tr\n onClick={onClick}\n className={cn(\n v.base,\n isActive && v.active,\n onClick && \"cursor-pointer hover:bg-zinc-50 transition-colors\",\n className,\n )}\n >\n {children}\n </tr>\n );\n}\n\n// ── Table Header Cell ────────────────────────\n\nfunction TableHeader({ align = \"left\", width, className, children }: TableHeaderProps) {\n const { size } = useTable();\n const s = SIZES[size];\n\n return (\n <th\n style={width ? { width } : undefined}\n className={cn(\n \"font-semibold text-zinc-500 uppercase tracking-wider whitespace-nowrap\",\n s.header,\n s.text,\n ALIGN_MAP[align],\n className,\n )}\n >\n {children}\n </th>\n );\n}\n\n// ── Table Cell ───────────────────────────────\n\nfunction TableCell({ align = \"left\", truncate, className, children }: TableCellProps) {\n const { size } = useTable();\n const s = SIZES[size];\n\n return (\n <td\n className={cn(\n \"text-zinc-700\",\n s.cell,\n s.text,\n ALIGN_MAP[align],\n truncate && \"max-w-0 truncate\",\n className,\n )}\n >\n {children}\n </td>\n );\n}\n\n// ── Export ────────────────────────────────────\n\nexport const Table = Object.assign(TableRoot, {\n Head: TableHead,\n Body: TableBody,\n Row: TableRow,\n Header: TableHeader,\n Cell: TableCell,\n});\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type TabsVariant = \"default\" | \"bordered\" | \"segmented\";\nexport type TabsSize = \"xs\" | \"sm\" | \"md\";\n\nexport interface TabsProps {\n value?: string;\n defaultValue?: string;\n onValueChange?: (value: string) => void;\n variant?: TabsVariant;\n size?: TabsSize;\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface TabsListProps {\n className?: string;\n children: React.ReactNode;\n}\n\nexport interface TabsTriggerProps {\n value: string;\n icon?: React.ReactNode;\n activeClassName?: string;\n disabled?: boolean;\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TabsContentProps {\n value: string;\n className?: string;\n children: React.ReactNode;\n}\n\n// ── Context ──────────────────────────────────\n\ninterface TabsContextValue {\n activeValue: string;\n onSelect: (value: string) => void;\n variant: TabsVariant;\n size: TabsSize;\n baseId: string;\n}\n\nconst TabsContext = React.createContext<TabsContextValue | null>(null);\n\nfunction useTabs(): TabsContextValue {\n const ctx = React.useContext(TabsContext);\n if (!ctx) throw new Error(\"Tabs sub-components must be used within <Tabs>\");\n return ctx;\n}\n\n// ── Size definitions ─────────────────────────\n\nconst SIZES: Record<TabsSize, { list: string; trigger: string; font: string; iconSize: string }> = {\n xs: { list: \"h-9\", trigger: \"px-3 gap-1\", font: \"text-xs\", iconSize: \"size-3\" },\n sm: { list: \"h-10\", trigger: \"px-4 gap-1.5\", font: \"text-sm\", iconSize: \"size-3.5\" },\n md: { list: \"h-12\", trigger: \"px-5 gap-2\", font: \"text-base\", iconSize: \"size-4\" },\n};\n\n// ── Variant styles ───────────────────────────\n\nconst LIST_VARIANTS: Record<TabsVariant, string> = {\n default: \"border-b border-zinc-200\",\n bordered: \"border border-zinc-200 rounded-lg bg-white p-1 gap-1\",\n segmented: \"bg-zinc-100 rounded-lg p-1 gap-px\",\n};\n\nconst TRIGGER_VARIANTS: Record<TabsVariant, { active: string; inactive: string }> = {\n default: {\n active: \"text-zinc-900 border-b-2 border-zinc-900\",\n inactive: \"text-zinc-400 hover:text-zinc-600\",\n },\n bordered: {\n active: \"bg-zinc-50 text-zinc-900 rounded-md shadow-sm\",\n inactive: \"text-zinc-400 hover:text-zinc-600 hover:bg-zinc-50/50 rounded-md\",\n },\n segmented: {\n active: \"bg-white text-zinc-900 rounded-md shadow-sm\",\n inactive: \"text-zinc-500 hover:text-zinc-700 hover:bg-white/50 rounded-md\",\n },\n};\n\n// ── Tabs Root ────────────────────────────────\n\nfunction TabsRoot({\n value,\n defaultValue = \"\",\n onValueChange,\n variant = \"default\",\n size = \"sm\",\n className,\n children,\n}: TabsProps) {\n const [internalValue, setInternalValue] = React.useState(defaultValue);\n const baseId = React.useId();\n\n const isControlled = value !== undefined;\n const activeValue = isControlled ? value : internalValue;\n\n const onSelect = (val: string) => {\n if (!isControlled) setInternalValue(val);\n onValueChange?.(val);\n };\n\n return (\n <TabsContext.Provider value={{ activeValue, onSelect, variant, size, baseId }}>\n <div className={cn(\"flex flex-col\", className)}>\n {children}\n </div>\n </TabsContext.Provider>\n );\n}\n\n// ── Tabs List ────────────────────────────────\n\nfunction TabsList({ className, children }: TabsListProps) {\n const { variant, size } = useTabs();\n const s = SIZES[size];\n\n return (\n <div\n role=\"tablist\"\n className={cn(\n \"shrink-0 flex items-center\",\n s.list,\n LIST_VARIANTS[variant],\n className,\n )}\n >\n {children}\n </div>\n );\n}\n\n// ── Tabs Trigger ─────────────────────────────\n\nfunction TabsTrigger({ value, icon, activeClassName, disabled = false, className, children }: TabsTriggerProps) {\n const { activeValue, onSelect, variant, size, baseId } = useTabs();\n const isActive = activeValue === value;\n const s = SIZES[size];\n const v = TRIGGER_VARIANTS[variant];\n\n return (\n <button\n type=\"button\"\n role=\"tab\"\n aria-selected={isActive}\n aria-controls={`${baseId}-panel-${value}`}\n id={`${baseId}-tab-${value}`}\n tabIndex={isActive ? 0 : -1}\n disabled={disabled}\n onClick={() => { if (!disabled) onSelect(value); }}\n className={cn(\n \"flex-1 flex items-center justify-center h-full font-semibold transition-colors cursor-pointer\",\n s.trigger,\n s.font,\n isActive ? (activeClassName ?? v.active) : v.inactive,\n disabled && \"opacity-50 cursor-not-allowed\",\n className,\n )}\n >\n {icon && <span className={cn(\"shrink-0 flex items-center justify-center [&>svg]:w-full [&>svg]:h-full\", s.iconSize)}>{icon}</span>}\n {children}\n </button>\n );\n}\n\n// ── Tabs Content ─────────────────────────────\n\nfunction TabsContent({ value, className, children }: TabsContentProps) {\n const { activeValue, baseId } = useTabs();\n\n if (activeValue !== value) return null;\n\n return (\n <div\n role=\"tabpanel\"\n id={`${baseId}-panel-${value}`}\n aria-labelledby={`${baseId}-tab-${value}`}\n className={className}\n >\n {children}\n </div>\n );\n}\n\n// ── Export ────────────────────────────────────\n\nexport const Tabs = Object.assign(TabsRoot, {\n List: TabsList,\n Trigger: TabsTrigger,\n Content: TabsContent,\n});\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport type TooltipPosition = \"top\" | \"bottom\" | \"left\" | \"right\";\n\nexport interface TooltipProps {\n content: React.ReactNode;\n position?: TooltipPosition;\n delay?: number;\n children: React.ReactElement;\n className?: string;\n}\n\n// ── Position styles ──────────────────────────\n\nconst POSITIONS: Record<TooltipPosition, {\n tooltip: string;\n arrow: string;\n}> = {\n top: {\n tooltip: \"bottom-full left-1/2 -translate-x-1/2 mb-2\",\n arrow: \"top-full left-1/2 -translate-x-1/2 border-t-zinc-800 border-x-transparent border-b-transparent border-4\",\n },\n bottom: {\n tooltip: \"top-full left-1/2 -translate-x-1/2 mt-2\",\n arrow: \"bottom-full left-1/2 -translate-x-1/2 border-b-zinc-800 border-x-transparent border-t-transparent border-4\",\n },\n left: {\n tooltip: \"right-full top-1/2 -translate-y-1/2 mr-2\",\n arrow: \"left-full top-1/2 -translate-y-1/2 border-l-zinc-800 border-y-transparent border-r-transparent border-4\",\n },\n right: {\n tooltip: \"left-full top-1/2 -translate-y-1/2 ml-2\",\n arrow: \"right-full top-1/2 -translate-y-1/2 border-r-zinc-800 border-y-transparent border-l-transparent border-4\",\n },\n};\n\n// ── Component ────────────────────────────────\n\nexport function Tooltip({\n content,\n position = \"top\",\n delay = 300,\n children,\n className,\n}: TooltipProps) {\n const [visible, setVisible] = React.useState(false);\n const timerRef = React.useRef<ReturnType<typeof setTimeout> | null>(null);\n const pos = POSITIONS[position];\n\n const show = React.useCallback(() => {\n timerRef.current = setTimeout(() => setVisible(true), delay);\n }, [delay]);\n\n const hide = React.useCallback(() => {\n if (timerRef.current) clearTimeout(timerRef.current);\n setVisible(false);\n }, []);\n\n return (\n <div className=\"relative inline-flex\" onMouseEnter={show} onMouseLeave={hide}>\n {children}\n {visible && (\n <div\n className={cn(\n \"absolute z-50 pointer-events-none\",\n \"px-2 py-1 rounded-md bg-zinc-800 text-white text-xs font-medium whitespace-nowrap shadow-lg\",\n pos.tooltip,\n className,\n )}\n >\n {content}\n <span className={cn(\"absolute w-0 h-0\", pos.arrow)} />\n </div>\n )}\n </div>\n );\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\n// ── Types ────────────────────────────────────\n\nexport interface TypewriterProps {\n texts: string[];\n typingSpeed?: number;\n deletingSpeed?: number;\n pauseDuration?: number;\n deleteMode?: \"backspace\" | \"clear\";\n loop?: boolean;\n startDelay?: number;\n cursor?: boolean;\n cursorStyle?: \"line\" | \"block\" | \"underscore\";\n onComplete?: () => void;\n className?: string;\n}\n\n// ── Component ────────────────────────────────\n\nexport function Typewriter({\n texts,\n typingSpeed = 40,\n deletingSpeed = 25,\n pauseDuration = 3000,\n deleteMode = \"backspace\",\n loop = true,\n startDelay = 0,\n cursor = true,\n cursorStyle = \"line\",\n onComplete,\n className,\n}: TypewriterProps) {\n const [displayText, setDisplayText] = React.useState(\"\");\n const [textIndex, setTextIndex] = React.useState(0);\n const [phase, setPhase] = React.useState<\"waiting\" | \"typing\" | \"pausing\" | \"deleting\" | \"done\">(\n startDelay > 0 ? \"waiting\" : \"typing\",\n );\n\n React.useEffect(() => {\n if (phase !== \"waiting\") return;\n const timeout = setTimeout(() => setPhase(\"typing\"), startDelay);\n return () => clearTimeout(timeout);\n }, [phase, startDelay]);\n\n const getDelay = React.useCallback(() => {\n switch (phase) {\n case \"typing\": return typingSpeed;\n case \"pausing\": return pauseDuration;\n case \"deleting\": return deleteMode === \"clear\" ? 0 : deletingSpeed;\n default: return 0;\n }\n }, [phase, typingSpeed, pauseDuration, deletingSpeed, deleteMode]);\n\n React.useEffect(() => {\n if (phase === \"waiting\" || phase === \"done\" || !texts.length) return;\n\n const currentFullText = texts[textIndex];\n\n const timeout = setTimeout(() => {\n switch (phase) {\n case \"typing\":\n if (displayText.length < currentFullText.length) {\n setDisplayText(currentFullText.slice(0, displayText.length + 1));\n } else {\n if (!loop && textIndex === texts.length - 1) {\n setPhase(\"done\");\n onComplete?.();\n } else {\n setPhase(\"pausing\");\n }\n }\n break;\n\n case \"pausing\":\n setPhase(\"deleting\");\n break;\n\n case \"deleting\":\n if (deleteMode === \"clear\") {\n setDisplayText(\"\");\n setTextIndex((prev) => (prev + 1) % texts.length);\n setPhase(\"typing\");\n } else {\n if (displayText.length > 0) {\n setDisplayText(displayText.slice(0, -1));\n } else {\n setTextIndex((prev) => (prev + 1) % texts.length);\n setPhase(\"typing\");\n }\n }\n break;\n }\n }, getDelay());\n\n return () => clearTimeout(timeout);\n }, [displayText, textIndex, phase, texts, deleteMode, getDelay, loop, onComplete]);\n\n const cursorElement = cursor && phase !== \"done\" && (\n <span\n className={cn(\n \"inline-block bg-current animate-pulse align-baseline ml-0.5\",\n cursorStyle === \"line\" && \"w-px h-[1em]\",\n cursorStyle === \"block\" && \"w-[0.6em] h-[1.1em] opacity-70\",\n cursorStyle === \"underscore\" && \"w-[0.6em] h-px translate-y-[0.1em]\",\n )}\n />\n );\n\n return (\n <span className={cn(className)}>\n {displayText}\n {cursorElement}\n </span>\n );\n}\n"],"mappings":"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","names":["concatArrays","array1","array2","combinedArray","Array","length","i","createClassValidatorObject","classGroupId","validator","createClassPartObject","nextPart","Map","validators","CLASS_PART_SEPARATOR","EMPTY_CONFLICTS","ARBITRARY_PROPERTY_PREFIX","createClassGroupUtils","config","classMap","createClassMap","conflictingClassGroups","conflictingClassGroupModifiers","getClassGroupId","className","startsWith","endsWith","getGroupIdForArbitraryProperty","classParts","split","startIndex","getGroupRecursive","getConflictingClassGroupIds","hasPostfixModifier","modifierConflicts","baseConflicts","classPartObject","classPathsLength","currentClassPart","nextClassPartObject","get","result","undefined","classRest","join","slice","validatorsLength","validatorObj","indexOf","content","colonIndex","property","theme","classGroups","processClassGroups","group","processClassesRecursively","classGroup","len","classDefinition","processClassDefinition","processStringDefinition","processFunctionDefinition","processObjectDefinition","classPartObjectToEdit","getPart","isThemeGetter","push","entries","Object","key","value","path","current","parts","part","next","set","func","createLruCache","maxCacheSize","cacheSize","cache","create","previousCache","update","IMPORTANT_MODIFIER","MODIFIER_SEPARATOR","EMPTY_MODIFIERS","createResultObject","modifiers","hasImportantModifier","baseClassName","maybePostfixModifierPosition","isExternal","createParseClassName","prefix","experimentalParseClassName","parseClassName","bracketDepth","parenDepth","modifierStart","postfixModifierPosition","index","currentCharacter","baseClassNameWithImportantModifier","fullPrefix","parseClassNameOriginal","createSortModifiers","modifierWeights","orderSensitiveModifiers","forEach","mod","currentSegment","modifier","isArbitrary","isOrderSensitive","has","sort","createConfigUtils","sortModifiers","SPLIT_CLASSES_REGEX","mergeClassList","classList","configUtils","classGroupsInConflict","classNames","trim","originalClassName","substring","variantModifier","modifierId","classId","conflictGroups","twJoin","classLists","argument","resolvedValue","string","toValue","mix","k","createTailwindMerge","createConfigFirst","createConfigRest","cacheGet","cacheSet","functionToCall","initTailwindMerge","reduce","previousConfig","createConfigCurrent","tailwindMerge","cachedResult","args","fallbackThemeArr","fromTheme","themeGetter","arbitraryValueRegex","arbitraryVariableRegex","fractionRegex","tshirtUnitRegex","lengthUnitRegex","colorFunctionRegex","shadowRegex","imageRegex","isFraction","test","isNumber","Number","isNaN","isInteger","isPercent","isTshirtSize","isAny","isLengthOnly","isNever","isShadow","isImage","isAnyNonArbitrary","isArbitraryValue","isArbitraryVariable","isArbitrarySize","getIsArbitraryValue","isLabelSize","isArbitraryLength","isLabelLength","isArbitraryNumber","isLabelNumber","isArbitraryWeight","isLabelWeight","isArbitraryFamilyName","isLabelFamilyName","isArbitraryPosition","isLabelPosition","isArbitraryImage","isLabelImage","isArbitraryShadow","isLabelShadow","isArbitraryVariableLength","getIsArbitraryVariable","isArbitraryVariableFamilyName","isArbitraryVariablePosition","isArbitraryVariableSize","isArbitraryVariableImage","isArbitraryVariableShadow","isArbitraryVariableWeight","testLabel","testValue","exec","shouldMatchNoLabel","label","getDefaultConfig","themeColor","fromTheme","themeFont","themeText","themeFontWeight","themeTracking","themeLeading","themeBreakpoint","themeContainer","themeSpacing","themeRadius","themeShadow","themeInsetShadow","themeTextShadow","themeDropShadow","themeBlur","themePerspective","themeAspect","themeEase","themeAnimate","scaleBreak","scalePosition","scalePositionWithArbitrary","isArbitraryVariable","isArbitraryValue","scaleOverflow","scaleOverscroll","scaleUnambiguousSpacing","scaleInset","isFraction","scaleGridTemplateColsRows","isInteger","scaleGridColRowStartAndEnd","span","scaleGridColRowStartOrEnd","scaleGridAutoColsRows","scaleAlignPrimaryAxis","scaleAlignSecondaryAxis","scaleMargin","scaleSizing","scaleSizingInline","scaleSizingBlock","scaleColor","scaleBgPosition","isArbitraryVariablePosition","isArbitraryPosition","position","scaleBgRepeat","repeat","scaleBgSize","isArbitraryVariableSize","isArbitrarySize","size","scaleGradientStopPosition","isPercent","isArbitraryVariableLength","isArbitraryLength","scaleRadius","scaleBorderWidth","isNumber","scaleLineStyle","scaleBlendMode","scaleMaskImagePosition","scaleBlur","scaleRotate","scaleScale","scaleSkew","scaleTranslate","cacheSize","theme","animate","aspect","blur","isTshirtSize","breakpoint","color","isAny","container","ease","font","isAnyNonArbitrary","leading","perspective","radius","shadow","spacing","text","tracking","classGroups","columns","box","display","sr","float","clear","isolation","object","overflow","overscroll","inset","start","end","top","right","bottom","left","visibility","z","basis","flex","grow","shrink","order","col","row","gap","justify","content","items","baseline","self","p","px","py","ps","pe","pbs","pbe","pt","pr","pb","pl","m","mx","my","ms","me","mbs","mbe","mt","mr","mb","ml","inline","block","w","screen","h","isArbitraryVariableWeight","isArbitraryWeight","isArbitraryVariableFamilyName","isArbitraryFamilyName","isArbitraryNumber","list","placeholder","decoration","indent","align","whitespace","break","wrap","hyphens","bg","linear","to","radial","conic","isArbitraryVariableImage","isArbitraryImage","from","via","rounded","border","divide","outline","isArbitraryVariableShadow","isArbitraryShadow","ring","opacity","mask","closest","farthest","filter","brightness","contrast","grayscale","invert","saturate","sepia","table","caption","transition","duration","delay","backface","rotate","scale","skew","transform","origin","translate","accent","appearance","caret","scheme","cursor","resize","scroll","snap","touch","select","fill","stroke","conflictingClassGroups","conflictingClassGroupModifiers","orderSensitiveModifiers","twMerge","createTailwindMerge","getDefaultConfig","React","import_jsx_runtime","SIZES","import_jsx_runtime","XIcon","SIZES","COLORS","React","import_jsx_runtime","React","import_jsx_runtime","SIZES","SHAPES","COLORS","React","import_jsx_runtime","ChevronRightIcon","useEmblaCarousel","React","import_jsx_runtime","React","import_jsx_runtime","SIZES","COLORS","React","import_jsx_runtime","XIcon","React","import_jsx_runtime","React","import_jsx_runtime","React","import_jsx_runtime","Spinner","SIZES","SHAPES","React","import_jsx_runtime","React","import_jsx_runtime","SIZES","COLORS","VARIANT_STYLES","React","import_jsx_runtime","SHAPES","SIZES","React","import_jsx_runtime","SHAPES","RATIOS","SIZES","React","ReactDOM","import_jsx_runtime","XIcon","SIZES","React","import_jsx_runtime","ChevronDownIcon","CheckIcon","XIcon","React","ReactDOM","import_jsx_runtime","XIcon","COLORS","React","import_jsx_runtime","SIZES","COLORS","CARD_COLORS","React","import_jsx_runtime","React","import_jsx_runtime","ChevronDownIcon","CheckIcon","React","import_jsx_runtime","SIZES","COLORS","React","import_jsx_runtime","SIZES","SHAPES","React","import_jsx_runtime","SIZES","React","import_jsx_runtime","POSITIONS","React","import_jsx_runtime"]}