@mkbabb/glass-ui 0.3.0 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (945) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +179 -70
  3. package/dist/CardFooter-Yi0xtLLd.js +129 -0
  4. package/dist/CollapsibleContent-DHRuXE3P.js +52 -0
  5. package/dist/CommandShortcut-_INFUMu6.js +285 -0
  6. package/dist/ContextMenuContent-CvXfU5qz.js +85 -0
  7. package/dist/ContextMenuSubContent-DCkweFW9.js +250 -0
  8. package/dist/DataTable-Ce00dbHD.js +460 -0
  9. package/dist/DialogContent-CmCijgX9.js +93 -0
  10. package/dist/DialogFooter-DRdaCok0.js +165 -0
  11. package/dist/DiscoGlyph-wRA02zAJ.js +132 -0
  12. package/dist/GlyphFace-BnPMUZ16.js +51 -0
  13. package/dist/HoverCardContent-4nN5-5bz.js +83 -0
  14. package/dist/HoverPopover-Btv4RQfv.js +80 -0
  15. package/dist/IconTooltip-ge_mBSWR.js +25 -0
  16. package/dist/Input-CbakTe3B.js +32 -0
  17. package/dist/InstrumentChassis-DOaVYyWq.js +65 -0
  18. package/dist/InstrumentRail-jHDqXj70.js +44 -0
  19. package/dist/Label-C8QMJSsf.js +32 -0
  20. package/dist/MetricBadge-DRBB18Xq.js +78 -0
  21. package/dist/ModalOverlay-DKLVY-cj.js +53 -0
  22. package/dist/Notification-DrI1DT2v.js +99 -0
  23. package/dist/PaperBackdrop-Bc2drCqJ.js +31 -0
  24. package/dist/PopoverContent-BCH4eYs8.js +121 -0
  25. package/dist/Progress-CCH-2UBR.js +126 -0
  26. package/dist/ScrollingText-7P8skg5W.js +40 -0
  27. package/dist/SelectGroup-O69GTQ77.js +31 -0
  28. package/dist/SelectScrollDownButton-yu8EYUnu.js +235 -0
  29. package/dist/SelectSeparator-GTHxKO0a.js +49 -0
  30. package/dist/Separator-_NCypg_C.js +37 -0
  31. package/dist/Switch-CL0uxu8F.js +41 -0
  32. package/dist/Toaster-DY8_jtHv.js +255 -0
  33. package/dist/ToggleGroupItem-BYG_8M9M.js +152 -0
  34. package/dist/TooltipProvider-C5QLSPto.js +104 -0
  35. package/dist/UnderlineTabs-BtrUcXn-.js +64 -0
  36. package/dist/_plugin-vue_export-helper-n-_DRHWS.js +8 -0
  37. package/dist/animated-digit.d.ts +1 -0
  38. package/dist/animated-digit.js +44 -0
  39. package/dist/api/index.d.ts +30 -0
  40. package/dist/api.js +2 -0
  41. package/dist/aurora.d.ts +1 -0
  42. package/dist/aurora.js +541 -0
  43. package/dist/badge-BbxVKZfw.js +49 -0
  44. package/dist/badge.d.ts +1 -0
  45. package/dist/badge.js +2 -0
  46. package/dist/button-BlOW34DT.js +70 -0
  47. package/dist/button.d.ts +1 -0
  48. package/dist/button.js +2 -0
  49. package/dist/card.d.ts +1 -0
  50. package/dist/card.js +2 -0
  51. package/dist/carousel.d.ts +2 -0
  52. package/dist/carousel.js +394 -0
  53. package/dist/check-dwgetki8.js +7 -0
  54. package/dist/chevron-down-DILQA1t6.js +7 -0
  55. package/dist/chevron-right-fS7fal2t.js +7 -0
  56. package/dist/chevron-up-BtYjYQOS.js +7 -0
  57. package/dist/cn-DJXf4yaB.js +97 -0
  58. package/dist/collapsible.d.ts +1 -0
  59. package/dist/collapsible.js +2 -0
  60. package/dist/command.d.ts +1 -0
  61. package/dist/command.js +2 -0
  62. package/dist/components/custom/animated-digit/AnimatedDigit.vue.d.ts +48 -0
  63. package/dist/components/custom/animated-digit/index.d.ts +2 -0
  64. package/dist/components/custom/aurora/Aurora.vue.d.ts +95 -0
  65. package/dist/components/custom/aurora/composables/color.d.ts +39 -0
  66. package/dist/components/custom/aurora/composables/configSource.d.ts +10 -0
  67. package/dist/components/custom/aurora/composables/runtime.d.ts +54 -0
  68. package/dist/components/custom/aurora/composables/useAurora.d.ts +67 -0
  69. package/dist/components/custom/aurora/composables/useCursorInteraction.d.ts +25 -0
  70. package/dist/components/custom/aurora/index.d.ts +9 -0
  71. package/dist/components/custom/aurora/presets.d.ts +121 -0
  72. package/dist/components/custom/aurora/renderMode.d.ts +30 -0
  73. package/dist/components/custom/aurora/shaders/aurora.frag.d.ts +1 -0
  74. package/dist/components/custom/aurora/shaders/aurora.vert.d.ts +1 -0
  75. package/dist/components/custom/configurator/Configurator.vue.d.ts +102 -0
  76. package/dist/components/custom/configurator/ConfiguratorLayer.vue.d.ts +68 -0
  77. package/dist/components/custom/configurator/ConfiguratorRow.vue.d.ts +63 -0
  78. package/dist/components/custom/configurator/density.d.ts +30 -0
  79. package/dist/components/custom/configurator/index.d.ts +6 -0
  80. package/dist/components/custom/configurator/useConfiguratorState.d.ts +45 -0
  81. package/dist/components/custom/confirm-dialog/ConfirmDialog.vue.d.ts +32 -0
  82. package/dist/components/custom/controls/DarkModeToggle.vue.d.ts +23 -0
  83. package/dist/components/custom/disco-glyph/DiscoGlyph.vue.d.ts +58 -0
  84. package/dist/components/custom/disco-glyph/index.d.ts +1 -0
  85. package/dist/components/custom/dock/DockDropdownTrigger.vue.d.ts +29 -0
  86. package/dist/components/custom/dock/DockIconButton.vue.d.ts +30 -0
  87. package/dist/components/custom/dock/DockLayer.vue.d.ts +34 -0
  88. package/dist/components/custom/dock/DockLayerGroup.vue.d.ts +43 -0
  89. package/dist/components/custom/dock/DockSelectTrigger.vue.d.ts +29 -0
  90. package/dist/components/custom/dock/DockTabButton.vue.d.ts +39 -0
  91. package/dist/components/custom/dock/GlassDock.vue.d.ts +96 -0
  92. package/dist/components/custom/dock/composables/dockContext.d.ts +40 -0
  93. package/dist/components/custom/dock/composables/dockLayerContext.d.ts +29 -0
  94. package/dist/components/custom/dock/composables/index.d.ts +7 -0
  95. package/dist/components/custom/dock/composables/isTeleportedTarget.d.ts +9 -0
  96. package/dist/components/custom/dock/composables/useDockState.d.ts +70 -0
  97. package/dist/components/custom/dock/composables/useLayerTransition.d.ts +34 -0
  98. package/dist/components/custom/dock/index.d.ts +9 -0
  99. package/dist/components/custom/expandable-container/ExpandableContainer.vue.d.ts +40 -0
  100. package/dist/components/custom/glass-carousel/GlassCarousel.vue.d.ts +36 -0
  101. package/dist/components/custom/glass-carousel/GlassCarouselItem.vue.d.ts +28 -0
  102. package/dist/components/custom/glass-carousel/index.d.ts +4 -0
  103. package/dist/components/custom/glass-carousel/useGlassCarousel.d.ts +30 -0
  104. package/dist/components/custom/glass-panel/GlassPanel.vue.d.ts +41 -0
  105. package/dist/components/custom/glass-panel/index.d.ts +2 -0
  106. package/dist/components/custom/glyph-face/GlyphFace.vue.d.ts +64 -0
  107. package/dist/components/custom/glyph-face/index.d.ts +2 -0
  108. package/dist/components/custom/glyph-face/keys.d.ts +35 -0
  109. package/dist/components/custom/header-ribbon/HeaderRibbon.vue.d.ts +31 -0
  110. package/dist/components/custom/header-ribbon/index.d.ts +2 -0
  111. package/dist/components/custom/header-ribbon/types.d.ts +7 -0
  112. package/dist/components/custom/hover-popover/HoverPopover.vue.d.ts +71 -0
  113. package/dist/components/custom/hover-popover/index.d.ts +1 -0
  114. package/dist/components/custom/icon-tooltip/IconTooltip.vue.d.ts +16 -0
  115. package/dist/components/custom/infinite-scroll/InfiniteScroll.vue.d.ts +33 -0
  116. package/dist/components/custom/infinite-scroll/composables/types.d.ts +21 -0
  117. package/dist/components/custom/infinite-scroll/composables/useInfiniteScroll.d.ts +9 -0
  118. package/dist/components/custom/instrument-chassis/ChassisDivider.vue.d.ts +30 -0
  119. package/dist/components/custom/instrument-chassis/InstrumentChassis.vue.d.ts +82 -0
  120. package/dist/components/custom/instrument-chassis/index.d.ts +3 -0
  121. package/dist/components/custom/instrument-rail/InstrumentRail.vue.d.ts +91 -0
  122. package/dist/components/custom/instrument-rail/index.d.ts +2 -0
  123. package/dist/components/custom/labeled-field/LabeledField.vue.d.ts +36 -0
  124. package/dist/components/custom/labeled-field/LabeledInput.vue.d.ts +15 -0
  125. package/dist/components/custom/labeled-field/LabeledSelect.vue.d.ts +18 -0
  126. package/dist/components/custom/labeled-field/LabeledSlider.vue.d.ts +16 -0
  127. package/dist/components/custom/labeled-field/LabeledSwitch.vue.d.ts +13 -0
  128. package/dist/components/custom/labeled-field/index.d.ts +5 -0
  129. package/dist/components/custom/metric-badge/MetricBadge.vue.d.ts +39 -0
  130. package/dist/components/custom/metric-badge/index.d.ts +1 -0
  131. package/dist/components/custom/metric-cell/MetricCell.vue.d.ts +97 -0
  132. package/dist/components/custom/metric-cell/index.d.ts +2 -0
  133. package/dist/components/custom/metric-stack/MetricRow.vue.d.ts +103 -0
  134. package/dist/components/custom/metric-stack/MetricStack.vue.d.ts +92 -0
  135. package/dist/components/custom/metric-stack/index.d.ts +4 -0
  136. package/dist/components/custom/paper-backdrop/PaperBackdrop.vue.d.ts +21 -0
  137. package/dist/components/custom/paper-backdrop/index.d.ts +2 -0
  138. package/dist/components/custom/pulse/Pulse.vue.d.ts +53 -0
  139. package/dist/components/custom/pulse/index.d.ts +1 -0
  140. package/dist/components/custom/responsive-tabs/ResponsiveTabs.vue.d.ts +67 -0
  141. package/dist/components/custom/responsive-tabs/index.d.ts +2 -0
  142. package/dist/components/custom/scrolling-text/ScrollingText.vue.d.ts +20 -0
  143. package/dist/components/custom/scrolling-text/index.d.ts +1 -0
  144. package/dist/components/custom/search/FuzzySearch.vue.d.ts +16 -0
  145. package/dist/components/custom/search/SearchBar.vue.d.ts +30 -0
  146. package/dist/components/custom/search/composables/fuzzySearchIndex.d.ts +42 -0
  147. package/dist/components/custom/search/composables/types.d.ts +31 -0
  148. package/dist/components/custom/search/composables/useFuzzySearch.d.ts +12 -0
  149. package/dist/components/custom/sortable-list/SortableHandle.vue.d.ts +32 -0
  150. package/dist/components/custom/sortable-list/SortableItem.vue.d.ts +38 -0
  151. package/dist/components/custom/sortable-list/SortableList.vue.d.ts +76 -0
  152. package/dist/components/custom/sortable-list/context.d.ts +26 -0
  153. package/dist/components/custom/sortable-list/index.d.ts +4 -0
  154. package/dist/components/custom/stacked-icons/StackedIconGroup.vue.d.ts +30 -0
  155. package/dist/components/custom/stacked-icons/index.d.ts +2 -0
  156. package/dist/components/custom/stacked-icons/types.d.ts +18 -0
  157. package/dist/components/custom/status-dot/StatusDot.vue.d.ts +18 -0
  158. package/dist/components/custom/status-dot/index.d.ts +1 -0
  159. package/dist/components/custom/tabs/BouncyTabs.vue.d.ts +24 -0
  160. package/dist/components/custom/tabs/BouncyToggle.vue.d.ts +56 -0
  161. package/dist/components/custom/tabs/UnderlineTabs.vue.d.ts +17 -0
  162. package/dist/components/custom/timeline/ContinuousTimeline.vue.d.ts +118 -0
  163. package/dist/components/custom/timeline/GlassTimeline.vue.d.ts +114 -0
  164. package/dist/components/custom/timeline/ScrubberTimeline.vue.d.ts +29 -0
  165. package/dist/components/custom/timeline/SegmentedTimeline.vue.d.ts +46 -0
  166. package/dist/components/custom/timeline/geometry.d.ts +100 -0
  167. package/dist/components/custom/timeline/index.d.ts +2 -0
  168. package/dist/components/custom/timeline/types.d.ts +57 -0
  169. package/dist/components/custom/toggle-chip/ToggleChip.vue.d.ts +39 -0
  170. package/dist/components/custom/toggle-chip/index.d.ts +17 -0
  171. package/dist/components/custom/typewriter/TypewriterText.vue.d.ts +85 -0
  172. package/dist/components/custom/typewriter/composables/useTypewriter.d.ts +22 -0
  173. package/dist/components/custom/typewriter/types.d.ts +137 -0
  174. package/dist/components/custom/typewriter/utils/keyboard.d.ts +15 -0
  175. package/dist/components/custom/typewriter/utils/pausePatterns.d.ts +28 -0
  176. package/dist/components/custom/typewriter/utils/timing.d.ts +17 -0
  177. package/dist/components/custom/typewriter/utils/typoStateMachine.d.ts +24 -0
  178. package/dist/components/ui/_shared/ModalOverlay.vue.d.ts +90 -0
  179. package/dist/components/ui/_shared/index.d.ts +2 -0
  180. package/dist/components/ui/_shared/menuItemVariants.d.ts +32 -0
  181. package/dist/components/ui/_shared/useStalePropWarning.d.ts +27 -0
  182. package/dist/components/ui/accordion/Accordion.vue.d.ts +19 -0
  183. package/dist/components/ui/accordion/AccordionContent.vue.d.ts +18 -0
  184. package/dist/components/ui/accordion/AccordionItem.vue.d.ts +18 -0
  185. package/dist/components/ui/accordion/AccordionTrigger.vue.d.ts +20 -0
  186. package/dist/components/ui/accordion/index.d.ts +4 -0
  187. package/dist/components/ui/alert/Alert.vue.d.ts +19 -0
  188. package/dist/components/ui/alert/AlertDescription.vue.d.ts +17 -0
  189. package/dist/components/ui/alert/AlertTitle.vue.d.ts +17 -0
  190. package/dist/components/ui/alert/index.d.ts +8 -0
  191. package/dist/components/ui/avatar/Avatar.vue.d.ts +23 -0
  192. package/dist/components/ui/avatar/AvatarFallback.vue.d.ts +14 -0
  193. package/dist/components/ui/avatar/AvatarImage.vue.d.ts +4 -0
  194. package/dist/components/ui/avatar/index.d.ts +9 -0
  195. package/dist/components/ui/badge/Badge.vue.d.ts +20 -0
  196. package/dist/components/ui/badge/index.d.ts +7 -0
  197. package/dist/components/ui/button/Button.vue.d.ts +23 -0
  198. package/dist/components/ui/button/index.d.ts +7 -0
  199. package/dist/components/ui/card/Card.vue.d.ts +56 -0
  200. package/dist/components/ui/card/CardContent.vue.d.ts +17 -0
  201. package/dist/components/ui/card/CardDescription.vue.d.ts +17 -0
  202. package/dist/components/ui/card/CardFooter.vue.d.ts +17 -0
  203. package/dist/components/ui/card/CardHeader.vue.d.ts +55 -0
  204. package/dist/components/ui/card/CardTitle.vue.d.ts +17 -0
  205. package/dist/components/ui/card/index.d.ts +6 -0
  206. package/dist/components/ui/carousel/Carousel.vue.d.ts +37 -0
  207. package/dist/components/ui/carousel/CarouselContent.vue.d.ts +16 -0
  208. package/dist/components/ui/carousel/CarouselDots.vue.d.ts +4 -0
  209. package/dist/components/ui/carousel/CarouselItem.vue.d.ts +14 -0
  210. package/dist/components/ui/carousel/CarouselNext.vue.d.ts +22 -0
  211. package/dist/components/ui/carousel/CarouselPager.vue.d.ts +10 -0
  212. package/dist/components/ui/carousel/CarouselPrevious.vue.d.ts +22 -0
  213. package/dist/components/ui/carousel/GlassCarouselPager.vue.d.ts +51 -0
  214. package/dist/components/ui/carousel/index.d.ts +10 -0
  215. package/dist/components/ui/carousel/interface.d.ts +20 -0
  216. package/dist/components/ui/carousel/useCarousel.d.ts +20 -0
  217. package/dist/components/ui/checkbox/Checkbox.vue.d.ts +22 -0
  218. package/dist/components/ui/checkbox/index.d.ts +1 -0
  219. package/dist/components/ui/collapsible/Collapsible.vue.d.ts +20 -0
  220. package/dist/components/ui/collapsible/CollapsibleContent.vue.d.ts +14 -0
  221. package/dist/components/ui/collapsible/CollapsibleTrigger.vue.d.ts +14 -0
  222. package/dist/components/ui/collapsible/index.d.ts +3 -0
  223. package/dist/components/ui/combobox/Combobox.vue.d.ts +29 -0
  224. package/dist/components/ui/combobox/ComboboxAnchor.vue.d.ts +18 -0
  225. package/dist/components/ui/combobox/ComboboxEmpty.vue.d.ts +18 -0
  226. package/dist/components/ui/combobox/ComboboxGroup.vue.d.ts +19 -0
  227. package/dist/components/ui/combobox/ComboboxInput.vue.d.ts +22 -0
  228. package/dist/components/ui/combobox/ComboboxItem.vue.d.ts +22 -0
  229. package/dist/components/ui/combobox/ComboboxItemIndicator.vue.d.ts +18 -0
  230. package/dist/components/ui/combobox/ComboboxList.vue.d.ts +32 -0
  231. package/dist/components/ui/combobox/ComboboxSeparator.vue.d.ts +18 -0
  232. package/dist/components/ui/combobox/ComboboxViewport.vue.d.ts +18 -0
  233. package/dist/components/ui/combobox/index.d.ts +11 -0
  234. package/dist/components/ui/command/Command.vue.d.ts +35 -0
  235. package/dist/components/ui/command/CommandDialog.vue.d.ts +18 -0
  236. package/dist/components/ui/command/CommandEmpty.vue.d.ts +18 -0
  237. package/dist/components/ui/command/CommandGroup.vue.d.ts +19 -0
  238. package/dist/components/ui/command/CommandInput.vue.d.ts +8 -0
  239. package/dist/components/ui/command/CommandItem.vue.d.ts +22 -0
  240. package/dist/components/ui/command/CommandList.vue.d.ts +30 -0
  241. package/dist/components/ui/command/CommandSeparator.vue.d.ts +18 -0
  242. package/dist/components/ui/command/CommandShortcut.vue.d.ts +17 -0
  243. package/dist/components/ui/command/index.d.ts +9 -0
  244. package/dist/components/ui/context-menu/ContextMenu.vue.d.ts +18 -0
  245. package/dist/components/ui/context-menu/ContextMenuCheckboxItem.vue.d.ts +24 -0
  246. package/dist/components/ui/context-menu/ContextMenuContent.vue.d.ts +30 -0
  247. package/dist/components/ui/context-menu/ContextMenuItem.vue.d.ts +23 -0
  248. package/dist/components/ui/context-menu/ContextMenuLabel.vue.d.ts +19 -0
  249. package/dist/components/ui/context-menu/ContextMenuRadioGroup.vue.d.ts +18 -0
  250. package/dist/components/ui/context-menu/ContextMenuRadioItem.vue.d.ts +22 -0
  251. package/dist/components/ui/context-menu/ContextMenuSeparator.vue.d.ts +8 -0
  252. package/dist/components/ui/context-menu/ContextMenuShortcut.vue.d.ts +17 -0
  253. package/dist/components/ui/context-menu/ContextMenuSubContent.vue.d.ts +34 -0
  254. package/dist/components/ui/context-menu/ContextMenuSubTrigger.vue.d.ts +19 -0
  255. package/dist/components/ui/context-menu/ContextMenuTrigger.vue.d.ts +14 -0
  256. package/dist/components/ui/context-menu/index.d.ts +12 -0
  257. package/dist/components/ui/data-table/DataTable.vue.d.ts +81 -0
  258. package/dist/components/ui/data-table/DataTablePagination.vue.d.ts +13 -0
  259. package/dist/components/ui/data-table/types.d.ts +56 -0
  260. package/dist/components/ui/dialog/Dialog.vue.d.ts +18 -0
  261. package/dist/components/ui/dialog/DialogClose.vue.d.ts +14 -0
  262. package/dist/components/ui/dialog/DialogContent.vue.d.ts +71 -0
  263. package/dist/components/ui/dialog/DialogDescription.vue.d.ts +18 -0
  264. package/dist/components/ui/dialog/DialogFooter.vue.d.ts +17 -0
  265. package/dist/components/ui/dialog/DialogHeader.vue.d.ts +17 -0
  266. package/dist/components/ui/dialog/DialogScrollContent.vue.d.ts +33 -0
  267. package/dist/components/ui/dialog/DialogTitle.vue.d.ts +18 -0
  268. package/dist/components/ui/dialog/DialogTrigger.vue.d.ts +14 -0
  269. package/dist/components/ui/dialog/index.d.ts +9 -0
  270. package/dist/components/ui/drawer/Drawer.vue.d.ts +53 -0
  271. package/dist/components/ui/drawer/DrawerContent.vue.d.ts +43 -0
  272. package/dist/components/ui/drawer/DrawerDescription.vue.d.ts +18 -0
  273. package/dist/components/ui/drawer/DrawerFooter.vue.d.ts +17 -0
  274. package/dist/components/ui/drawer/DrawerHeader.vue.d.ts +17 -0
  275. package/dist/components/ui/drawer/DrawerOverlay.vue.d.ts +8 -0
  276. package/dist/components/ui/drawer/DrawerTitle.vue.d.ts +18 -0
  277. package/dist/components/ui/drawer/index.d.ts +17 -0
  278. package/dist/components/ui/dropdown-menu/DropdownMenu.vue.d.ts +18 -0
  279. package/dist/components/ui/dropdown-menu/DropdownMenuCheckboxItem.vue.d.ts +24 -0
  280. package/dist/components/ui/dropdown-menu/DropdownMenuContent.vue.d.ts +32 -0
  281. package/dist/components/ui/dropdown-menu/DropdownMenuGroup.vue.d.ts +14 -0
  282. package/dist/components/ui/dropdown-menu/DropdownMenuItem.vue.d.ts +19 -0
  283. package/dist/components/ui/dropdown-menu/DropdownMenuLabel.vue.d.ts +19 -0
  284. package/dist/components/ui/dropdown-menu/DropdownMenuRadioGroup.vue.d.ts +18 -0
  285. package/dist/components/ui/dropdown-menu/DropdownMenuRadioItem.vue.d.ts +22 -0
  286. package/dist/components/ui/dropdown-menu/DropdownMenuSeparator.vue.d.ts +8 -0
  287. package/dist/components/ui/dropdown-menu/DropdownMenuShortcut.vue.d.ts +17 -0
  288. package/dist/components/ui/dropdown-menu/DropdownMenuSub.vue.d.ts +18 -0
  289. package/dist/components/ui/dropdown-menu/DropdownMenuSubContent.vue.d.ts +34 -0
  290. package/dist/components/ui/dropdown-menu/DropdownMenuSubTrigger.vue.d.ts +18 -0
  291. package/dist/components/ui/dropdown-menu/DropdownMenuTrigger.vue.d.ts +14 -0
  292. package/dist/components/ui/dropdown-menu/index.d.ts +15 -0
  293. package/dist/components/ui/hover-card/HoverCard.vue.d.ts +18 -0
  294. package/dist/components/ui/hover-card/HoverCardContent.vue.d.ts +20 -0
  295. package/dist/components/ui/hover-card/HoverCardTrigger.vue.d.ts +14 -0
  296. package/dist/components/ui/hover-card/index.d.ts +3 -0
  297. package/dist/components/ui/index.d.ts +41 -0
  298. package/dist/components/ui/input/Input.vue.d.ts +13 -0
  299. package/dist/components/ui/input/index.d.ts +1 -0
  300. package/dist/components/ui/label/Label.vue.d.ts +18 -0
  301. package/dist/components/ui/label/index.d.ts +1 -0
  302. package/dist/components/ui/metric-pill/MetricPill.vue.d.ts +43 -0
  303. package/dist/components/ui/metric-pill/index.d.ts +1 -0
  304. package/dist/components/ui/multi-select/MultiSelect.vue.d.ts +24 -0
  305. package/dist/components/ui/multi-select/index.d.ts +7 -0
  306. package/dist/components/ui/notification/Notification.vue.d.ts +16 -0
  307. package/dist/components/ui/notification/index.d.ts +1 -0
  308. package/dist/components/ui/number-field/NumberField.vue.d.ts +22 -0
  309. package/dist/components/ui/number-field/NumberFieldContent.vue.d.ts +17 -0
  310. package/dist/components/ui/number-field/NumberFieldDecrement.vue.d.ts +18 -0
  311. package/dist/components/ui/number-field/NumberFieldIncrement.vue.d.ts +18 -0
  312. package/dist/components/ui/number-field/NumberFieldInput.vue.d.ts +3 -0
  313. package/dist/components/ui/number-field/index.d.ts +5 -0
  314. package/dist/components/ui/popover/Popover.vue.d.ts +18 -0
  315. package/dist/components/ui/popover/PopoverContent.vue.d.ts +39 -0
  316. package/dist/components/ui/popover/PopoverTrigger.vue.d.ts +14 -0
  317. package/dist/components/ui/popover/index.d.ts +3 -0
  318. package/dist/components/ui/progress/Progress.vue.d.ts +111 -0
  319. package/dist/components/ui/progress/index.d.ts +2 -0
  320. package/dist/components/ui/radio-group/RadioGroup.vue.d.ts +22 -0
  321. package/dist/components/ui/radio-group/RadioGroupItem.vue.d.ts +8 -0
  322. package/dist/components/ui/radio-group/index.d.ts +2 -0
  323. package/dist/components/ui/section/Section.vue.d.ts +73 -0
  324. package/dist/components/ui/section/index.d.ts +1 -0
  325. package/dist/components/ui/select/Select.vue.d.ts +21 -0
  326. package/dist/components/ui/select/SelectContent.vue.d.ts +30 -0
  327. package/dist/components/ui/select/SelectGroup.vue.d.ts +18 -0
  328. package/dist/components/ui/select/SelectItem.vue.d.ts +21 -0
  329. package/dist/components/ui/select/SelectLabel.vue.d.ts +18 -0
  330. package/dist/components/ui/select/SelectScrollDownButton.vue.d.ts +18 -0
  331. package/dist/components/ui/select/SelectScrollUpButton.vue.d.ts +18 -0
  332. package/dist/components/ui/select/SelectSeparator.vue.d.ts +8 -0
  333. package/dist/components/ui/select/SelectTrigger.vue.d.ts +22 -0
  334. package/dist/components/ui/select/SelectValue.vue.d.ts +14 -0
  335. package/dist/components/ui/select/index.d.ts +10 -0
  336. package/dist/components/ui/separator/Separator.vue.d.ts +9 -0
  337. package/dist/components/ui/separator/index.d.ts +1 -0
  338. package/dist/components/ui/sheet/Sheet.vue.d.ts +18 -0
  339. package/dist/components/ui/sheet/SheetClose.vue.d.ts +14 -0
  340. package/dist/components/ui/sheet/SheetContent.vue.d.ts +53 -0
  341. package/dist/components/ui/sheet/SheetDescription.vue.d.ts +18 -0
  342. package/dist/components/ui/sheet/SheetFooter.vue.d.ts +17 -0
  343. package/dist/components/ui/sheet/SheetHeader.vue.d.ts +17 -0
  344. package/dist/components/ui/sheet/SheetTitle.vue.d.ts +18 -0
  345. package/dist/components/ui/sheet/SheetTrigger.vue.d.ts +14 -0
  346. package/dist/components/ui/sheet/index.d.ts +13 -0
  347. package/dist/components/ui/skeleton/Skeleton.vue.d.ts +32 -0
  348. package/dist/components/ui/skeleton/index.d.ts +1 -0
  349. package/dist/components/ui/slider/Slider.vue.d.ts +26 -0
  350. package/dist/components/ui/slider/index.d.ts +31 -0
  351. package/dist/components/ui/switch/Switch.vue.d.ts +12 -0
  352. package/dist/components/ui/switch/index.d.ts +1 -0
  353. package/dist/components/ui/table/Table.vue.d.ts +17 -0
  354. package/dist/components/ui/table/TableBody.vue.d.ts +17 -0
  355. package/dist/components/ui/table/TableCaption.vue.d.ts +17 -0
  356. package/dist/components/ui/table/TableCell.vue.d.ts +17 -0
  357. package/dist/components/ui/table/TableEmpty.vue.d.ts +20 -0
  358. package/dist/components/ui/table/TableHead.vue.d.ts +17 -0
  359. package/dist/components/ui/table/TableHeader.vue.d.ts +17 -0
  360. package/dist/components/ui/table/TableRow.vue.d.ts +17 -0
  361. package/dist/components/ui/table/index.d.ts +8 -0
  362. package/dist/components/ui/tabs/Tabs.vue.d.ts +19 -0
  363. package/dist/components/ui/tabs/TabsContent.vue.d.ts +18 -0
  364. package/dist/components/ui/tabs/TabsIndicator.vue.d.ts +8 -0
  365. package/dist/components/ui/tabs/TabsList.vue.d.ts +18 -0
  366. package/dist/components/ui/tabs/TabsTrigger.vue.d.ts +18 -0
  367. package/dist/components/ui/tabs/index.d.ts +5 -0
  368. package/dist/components/ui/tags-input/TagsInput.vue.d.ts +28 -0
  369. package/dist/components/ui/tags-input/TagsInputInput.vue.d.ts +8 -0
  370. package/dist/components/ui/tags-input/TagsInputItem.vue.d.ts +18 -0
  371. package/dist/components/ui/tags-input/TagsInputItemDelete.vue.d.ts +18 -0
  372. package/dist/components/ui/tags-input/TagsInputItemText.vue.d.ts +8 -0
  373. package/dist/components/ui/tags-input/index.d.ts +5 -0
  374. package/dist/components/ui/textarea/Textarea.vue.d.ts +13 -0
  375. package/dist/components/ui/textarea/index.d.ts +1 -0
  376. package/dist/components/ui/toast/Toast.vue.d.ts +104 -0
  377. package/dist/components/ui/toast/ToastAction.vue.d.ts +18 -0
  378. package/dist/components/ui/toast/ToastClose.vue.d.ts +8 -0
  379. package/dist/components/ui/toast/ToastDescription.vue.d.ts +18 -0
  380. package/dist/components/ui/toast/ToastTitle.vue.d.ts +18 -0
  381. package/dist/components/ui/toast/Toaster.vue.d.ts +3 -0
  382. package/dist/components/ui/toast/index.d.ts +8 -0
  383. package/dist/components/ui/toast/use-toast.d.ts +168 -0
  384. package/dist/components/ui/toggle/Toggle.vue.d.ts +29 -0
  385. package/dist/components/ui/toggle/index.d.ts +26 -0
  386. package/dist/components/ui/toggle-group/ToggleGroup.vue.d.ts +25 -0
  387. package/dist/components/ui/toggle-group/ToggleGroupItem.vue.d.ts +21 -0
  388. package/dist/components/ui/toggle-group/index.d.ts +2 -0
  389. package/dist/components/ui/toggle-group/toggleGroupContext.d.ts +21 -0
  390. package/dist/components/ui/tooltip/Tooltip.vue.d.ts +18 -0
  391. package/dist/components/ui/tooltip/TooltipContent.vue.d.ts +26 -0
  392. package/dist/components/ui/tooltip/TooltipProvider.vue.d.ts +14 -0
  393. package/dist/components/ui/tooltip/TooltipTrigger.vue.d.ts +14 -0
  394. package/dist/components/ui/tooltip/index.d.ts +4 -0
  395. package/dist/composables/dark/index.d.ts +1 -0
  396. package/dist/composables/dark/useGlobalDark.d.ts +7 -0
  397. package/dist/composables/dom/index.d.ts +6 -0
  398. package/dist/composables/dom/useBreakpoint.d.ts +38 -0
  399. package/dist/composables/dom/useClipboard.d.ts +45 -0
  400. package/dist/composables/dom/useResizeObserver.d.ts +50 -0
  401. package/dist/composables/dom/useTokenColor.d.ts +27 -0
  402. package/dist/composables/dom/useTouchGate.d.ts +18 -0
  403. package/dist/composables/dom/useViewportReady.d.ts +87 -0
  404. package/dist/composables/glass/index.d.ts +1 -0
  405. package/dist/composables/glass/useGlassRenderer.d.ts +37 -0
  406. package/dist/composables/glass/webgl/frostShader.d.ts +27 -0
  407. package/dist/composables/index.d.ts +9 -0
  408. package/dist/composables/keyboard/index.d.ts +1 -0
  409. package/dist/composables/keyboard/useKeyboardShortcuts.d.ts +33 -0
  410. package/dist/composables/motion/constants.d.ts +19 -0
  411. package/dist/composables/motion/index.d.ts +14 -0
  412. package/dist/composables/motion/installDarkModeSync.d.ts +1 -0
  413. package/dist/composables/motion/useAnimatedNumber.d.ts +40 -0
  414. package/dist/composables/motion/useAnimatedNumberMap.d.ts +29 -0
  415. package/dist/composables/motion/useIntersectionPause.d.ts +33 -0
  416. package/dist/composables/motion/useNumericTransition.d.ts +32 -0
  417. package/dist/composables/motion/useRAFLoop.d.ts +43 -0
  418. package/dist/composables/motion/useScrollProgress.d.ts +23 -0
  419. package/dist/composables/motion/useSpring.d.ts +66 -0
  420. package/dist/composables/motion/useSpringMount.d.ts +52 -0
  421. package/dist/composables/motion/useSpringOrchestrator.d.ts +15 -0
  422. package/dist/composables/motion/useSpringPress.d.ts +46 -0
  423. package/dist/composables/motion/useStagger.d.ts +50 -0
  424. package/dist/composables/motion/useStaggerReveal.d.ts +22 -0
  425. package/dist/composables/reactive/index.d.ts +2 -0
  426. package/dist/composables/reactive/useInterval.d.ts +24 -0
  427. package/dist/composables/reactive/useTimer.d.ts +24 -0
  428. package/dist/composables/sidebar/index.d.ts +7 -0
  429. package/dist/composables/sidebar/types.d.ts +44 -0
  430. package/dist/composables/sidebar/useScrollTracker.d.ts +12 -0
  431. package/dist/composables/sidebar/useSidebarFollow.d.ts +16 -0
  432. package/dist/composables/sidebar/useSidebarState.d.ts +39 -0
  433. package/dist/composables/sidebar/useTreeIndex.d.ts +37 -0
  434. package/dist/composables/sortable/index.d.ts +1 -0
  435. package/dist/composables/sortable/useSortable.d.ts +149 -0
  436. package/dist/configurator.d.ts +1 -0
  437. package/dist/configurator.js +2 -0
  438. package/dist/confirm-dialog.d.ts +1 -0
  439. package/dist/confirm-dialog.js +69 -0
  440. package/dist/context-menu.d.ts +1 -0
  441. package/dist/context-menu.js +3 -0
  442. package/dist/controls.d.ts +1 -0
  443. package/dist/controls.js +51 -0
  444. package/dist/createLucideIcon-Bn9a1b70.js +43 -0
  445. package/dist/dark.d.ts +1 -0
  446. package/dist/dark.js +2 -0
  447. package/dist/data-table.d.ts +1 -0
  448. package/dist/data-table.js +2 -0
  449. package/dist/dialog.d.ts +1 -0
  450. package/dist/dialog.js +3 -0
  451. package/dist/disco-glyph.d.ts +1 -0
  452. package/dist/disco-glyph.js +2 -0
  453. package/dist/dock.d.ts +1 -0
  454. package/dist/dock.js +548 -0
  455. package/dist/dockContext-BDGSrwsV.js +16 -0
  456. package/dist/dom.d.ts +1 -0
  457. package/dist/dom.js +4 -0
  458. package/dist/dropdown-menu-2K-SGkZU.js +363 -0
  459. package/dist/dropdown-menu.d.ts +1 -0
  460. package/dist/dropdown-menu.js +2 -0
  461. package/dist/expandable-container.d.ts +1 -0
  462. package/dist/expandable-container.js +64 -0
  463. package/dist/fonts/README.md +95 -0
  464. package/dist/fonts/fira-code/OFL.txt +93 -0
  465. package/dist/fonts/fira-code/fira-code-latin-ext.woff2 +0 -0
  466. package/dist/fonts/fira-code/fira-code-latin.woff2 +0 -0
  467. package/dist/fonts/plus-jakarta-sans/OFL.txt +93 -0
  468. package/dist/fonts/plus-jakarta-sans/plus-jakarta-sans-latin-ext.woff2 +0 -0
  469. package/dist/fonts/plus-jakarta-sans/plus-jakarta-sans-latin.woff2 +0 -0
  470. package/dist/forms.d.ts +3 -0
  471. package/dist/forms.js +311 -0
  472. package/dist/glass-carousel.d.ts +1 -0
  473. package/dist/glass-carousel.js +207 -0
  474. package/dist/glass-panel.d.ts +1 -0
  475. package/dist/glass-panel.js +44 -0
  476. package/dist/glass-ui.css +2 -1
  477. package/dist/glass-ui.js +1174 -10021
  478. package/dist/glyph-face.d.ts +1 -0
  479. package/dist/glyph-face.js +3 -0
  480. package/dist/header-ribbon.d.ts +1 -0
  481. package/dist/header-ribbon.js +63 -0
  482. package/dist/hover-card.d.ts +1 -0
  483. package/dist/hover-card.js +2 -0
  484. package/dist/hover-popover.d.ts +1 -0
  485. package/dist/hover-popover.js +2 -0
  486. package/dist/icon-tooltip.d.ts +1 -0
  487. package/dist/icon-tooltip.js +2 -0
  488. package/dist/index.d.ts +49 -6619
  489. package/dist/infinite-scroll.d.ts +2 -0
  490. package/dist/infinite-scroll.js +73 -0
  491. package/dist/instrument-chassis.d.ts +1 -0
  492. package/dist/instrument-chassis.js +2 -0
  493. package/dist/instrument-rail.d.ts +1 -0
  494. package/dist/instrument-rail.js +2 -0
  495. package/dist/keyboard.d.ts +1 -0
  496. package/dist/keyboard.js +2 -0
  497. package/dist/keys-DVkcUktU.js +11 -0
  498. package/dist/label.d.ts +1 -0
  499. package/dist/label.js +2 -0
  500. package/dist/labeled-field.d.ts +1 -0
  501. package/dist/labeled-field.js +194 -0
  502. package/dist/menuItemVariants-B2nDL7zH.js +30 -0
  503. package/dist/metric-badge.d.ts +1 -0
  504. package/dist/metric-badge.js +2 -0
  505. package/dist/metric-cell.d.ts +1 -0
  506. package/dist/metric-cell.js +54 -0
  507. package/dist/metric-stack.d.ts +1 -0
  508. package/dist/metric-stack.js +107 -0
  509. package/dist/minimize-2-LsCJ_eNt.js +38 -0
  510. package/dist/motion.d.ts +1 -0
  511. package/dist/motion.js +286 -0
  512. package/dist/notification.d.ts +1 -0
  513. package/dist/notification.js +2 -0
  514. package/dist/paper-backdrop.d.ts +1 -0
  515. package/dist/paper-backdrop.js +2 -0
  516. package/dist/popover.d.ts +1 -0
  517. package/dist/popover.js +2 -0
  518. package/dist/presets-BMzCDrmR.js +71 -0
  519. package/dist/progress.d.ts +1 -0
  520. package/dist/progress.js +2 -0
  521. package/dist/pulse.d.ts +1 -0
  522. package/dist/pulse.js +54 -0
  523. package/dist/reactive.d.ts +1 -0
  524. package/dist/reactive.js +3 -0
  525. package/dist/responsive-tabs.d.ts +1 -0
  526. package/dist/responsive-tabs.js +89 -0
  527. package/dist/scrolling-text.d.ts +1 -0
  528. package/dist/scrolling-text.js +2 -0
  529. package/dist/search-ocd8tmL9.js +12 -0
  530. package/dist/search.d.ts +1 -0
  531. package/dist/search.js +425 -0
  532. package/dist/select.d.ts +1 -0
  533. package/dist/select.js +4 -0
  534. package/dist/separator.d.ts +1 -0
  535. package/dist/separator.js +2 -0
  536. package/dist/sheet-CLVkb3AO.js +214 -0
  537. package/dist/sheet.d.ts +1 -0
  538. package/dist/sheet.js +2 -0
  539. package/dist/sidebar.d.ts +1 -0
  540. package/dist/sidebar.js +304 -0
  541. package/dist/slider-BQaLYFLh.js +133 -0
  542. package/dist/slider.d.ts +1 -0
  543. package/dist/slider.js +2 -0
  544. package/dist/sortable-list.d.ts +1 -0
  545. package/dist/sortable-list.js +85 -0
  546. package/dist/stacked-icons.d.ts +1 -0
  547. package/dist/stacked-icons.js +83 -0
  548. package/dist/status-dot.d.ts +1 -0
  549. package/dist/status-dot.js +58 -0
  550. package/dist/styles/animations.css +298 -0
  551. package/dist/styles/cards.css +44 -0
  552. package/dist/styles/disco-glyph.css +26 -0
  553. package/dist/styles/dock.css +1085 -0
  554. package/dist/styles/drawer.css +138 -0
  555. package/dist/styles/floating-panel.css +34 -0
  556. package/dist/styles/fonts.css +143 -0
  557. package/dist/styles/glass.css +277 -0
  558. package/dist/styles/glyph-face.css +92 -0
  559. package/dist/styles/hover-popover.css +44 -0
  560. package/dist/styles/index.css +112 -0
  561. package/dist/styles/instrument-chassis.css +313 -0
  562. package/dist/styles/instrument-rail.css +128 -0
  563. package/dist/styles/paper.css +68 -0
  564. package/dist/styles/theme.css +358 -0
  565. package/dist/styles/tokens.css +1495 -0
  566. package/dist/styles/transitions.css +245 -0
  567. package/dist/styles/typography.css +553 -0
  568. package/dist/styles/utilities.css +893 -0
  569. package/dist/tabs.d.ts +1 -0
  570. package/dist/tabs.js +206 -0
  571. package/dist/timeline.d.ts +1 -0
  572. package/dist/timeline.js +466 -0
  573. package/dist/toast.d.ts +1 -0
  574. package/dist/toast.js +2 -0
  575. package/dist/toggle-chip.d.ts +1 -0
  576. package/dist/toggle-chip.js +71 -0
  577. package/dist/toggle-group.d.ts +1 -0
  578. package/dist/toggle-group.js +2 -0
  579. package/dist/tokens.d.ts +53 -0
  580. package/dist/tokens.js +16 -0
  581. package/dist/tooltip.d.ts +1 -0
  582. package/dist/tooltip.js +2 -0
  583. package/dist/typewriter.d.ts +1 -0
  584. package/dist/typewriter.js +860 -0
  585. package/dist/useAnimatedNumber-DcvTR9B4.js +51 -0
  586. package/dist/useBreakpoint-BHlX-MhR.js +134 -0
  587. package/dist/useConfiguratorState-BlaevW0S.js +266 -0
  588. package/dist/useGlassRenderer-DMDdMH55.js +69 -0
  589. package/dist/useGlobalDark-PMiP5Jku.js +24 -0
  590. package/dist/useIntersectionPause-CXYfYg_C.js +39 -0
  591. package/dist/useInterval-COlTCeVa.js +18 -0
  592. package/dist/useKeyboardShortcuts-B1ev1YEC.js +99 -0
  593. package/dist/useResizeObserver-F4aRR4Cj.js +44 -0
  594. package/dist/useSortable-Ck0rBJ4g.js +175 -0
  595. package/dist/useSpringMount-BTRBNzXP.js +113 -0
  596. package/dist/useTimer-lp5NlH4w.js +20 -0
  597. package/dist/useTouchGate-BhhEMlwJ.js +84 -0
  598. package/dist/utils/cn.d.ts +27 -0
  599. package/dist/x-cdWAmO-q.js +10 -0
  600. package/package.json +514 -26
  601. package/src/fonts/README.md +95 -0
  602. package/src/fonts/fira-code/OFL.txt +93 -0
  603. package/src/fonts/fira-code/fira-code-latin-ext.woff2 +0 -0
  604. package/src/fonts/fira-code/fira-code-latin.woff2 +0 -0
  605. package/src/fonts/plus-jakarta-sans/OFL.txt +93 -0
  606. package/src/fonts/plus-jakarta-sans/plus-jakarta-sans-latin-ext.woff2 +0 -0
  607. package/src/fonts/plus-jakarta-sans/plus-jakarta-sans-latin.woff2 +0 -0
  608. package/src/styles/animations.css +172 -107
  609. package/src/styles/cards.css +30 -52
  610. package/src/styles/disco-glyph.css +26 -0
  611. package/src/styles/dock.css +991 -127
  612. package/src/styles/drawer.css +138 -0
  613. package/src/styles/floating-panel.css +22 -37
  614. package/src/styles/fonts.css +143 -0
  615. package/src/styles/glass.css +129 -126
  616. package/src/styles/glyph-face.css +92 -0
  617. package/src/styles/hover-popover.css +44 -0
  618. package/src/styles/index.css +85 -3
  619. package/src/styles/instrument-chassis.css +313 -0
  620. package/src/styles/instrument-rail.css +128 -0
  621. package/src/styles/paper.css +68 -0
  622. package/src/styles/theme.css +292 -72
  623. package/src/styles/tokens.css +1345 -183
  624. package/src/styles/transitions.css +227 -208
  625. package/src/styles/typography.css +498 -222
  626. package/src/styles/utilities.css +612 -437
  627. package/src/components/custom/aurora/Aurora.vue +0 -34
  628. package/src/components/custom/aurora/composables/color.ts +0 -122
  629. package/src/components/custom/aurora/composables/useAurora.ts +0 -352
  630. package/src/components/custom/aurora/index.ts +0 -8
  631. package/src/components/custom/confirm-dialog/ConfirmDialog.vue +0 -88
  632. package/src/components/custom/controls/DarkModeToggle.vue +0 -96
  633. package/src/components/custom/dock/DockLayerGroup.vue +0 -21
  634. package/src/components/custom/dock/DockPopover.vue +0 -263
  635. package/src/components/custom/dock/GlassDock.vue +0 -276
  636. package/src/components/custom/dock/composables/index.ts +0 -16
  637. package/src/components/custom/dock/composables/isTeleportedTarget.ts +0 -19
  638. package/src/components/custom/dock/composables/useDockActionBar.ts +0 -33
  639. package/src/components/custom/dock/composables/useDockState.ts +0 -314
  640. package/src/components/custom/dock/composables/useDockTransition.ts +0 -146
  641. package/src/components/custom/dock/composables/useLayerTransition.ts +0 -135
  642. package/src/components/custom/dock/composables/usePopupMutex.ts +0 -83
  643. package/src/components/custom/dock/index.ts +0 -9
  644. package/src/components/custom/expandable-container/ExpandableContainer.vue +0 -64
  645. package/src/components/custom/glass-panel/GlassPanel.vue +0 -98
  646. package/src/components/custom/glass-panel/index.ts +0 -2
  647. package/src/components/custom/icon-tooltip/IconTooltip.vue +0 -20
  648. package/src/components/custom/index.ts +0 -15
  649. package/src/components/custom/infinite-scroll/InfiniteScroll.vue +0 -55
  650. package/src/components/custom/infinite-scroll/composables/types.ts +0 -23
  651. package/src/components/custom/infinite-scroll/composables/useInfiniteScroll.ts +0 -73
  652. package/src/components/custom/labeled-field/LabeledInput.vue +0 -29
  653. package/src/components/custom/labeled-field/LabeledSelect.vue +0 -59
  654. package/src/components/custom/labeled-field/LabeledSlider.vue +0 -32
  655. package/src/components/custom/labeled-field/LabeledSwitch.vue +0 -27
  656. package/src/components/custom/labeled-field/index.ts +0 -4
  657. package/src/components/custom/metaballs/MetaballCanvas.vue +0 -23
  658. package/src/components/custom/metaballs/index.ts +0 -4
  659. package/src/components/custom/metaballs/shaders.ts +0 -63
  660. package/src/components/custom/metaballs/types.ts +0 -29
  661. package/src/components/custom/metaballs/useMetaballs.ts +0 -252
  662. package/src/components/custom/search/FuzzySearch.vue +0 -589
  663. package/src/components/custom/search/SearchBar.vue +0 -44
  664. package/src/components/custom/search/composables/fuzzySearchIndex.ts +0 -224
  665. package/src/components/custom/search/composables/types.ts +0 -34
  666. package/src/components/custom/search/composables/useFuzzySearch.ts +0 -115
  667. package/src/components/custom/sidebar/ProgressiveSidebar.vue +0 -256
  668. package/src/components/custom/sidebar/composables/index.ts +0 -6
  669. package/src/components/custom/sidebar/composables/useScrollTracker.ts +0 -242
  670. package/src/components/custom/sidebar/composables/useSidebarFollow.ts +0 -247
  671. package/src/components/custom/sidebar/composables/useSidebarState.ts +0 -72
  672. package/src/components/custom/sidebar/composables/useTreeIndex.ts +0 -152
  673. package/src/components/custom/sidebar/index.ts +0 -15
  674. package/src/components/custom/sidebar/types.ts +0 -50
  675. package/src/components/custom/tabs/BouncyTabs.vue +0 -39
  676. package/src/components/custom/tabs/BouncyToggle.vue +0 -352
  677. package/src/components/custom/tabs/UnderlineTabs.vue +0 -115
  678. package/src/components/custom/timeline/GlassTimeline.vue +0 -174
  679. package/src/components/custom/timeline/index.ts +0 -1
  680. package/src/components/custom/typewriter/TypewriterText.vue +0 -239
  681. package/src/components/custom/typewriter/composables/useTypewriter.ts +0 -413
  682. package/src/components/custom/typewriter/types.ts +0 -159
  683. package/src/components/custom/typewriter/utils/keyboard.ts +0 -213
  684. package/src/components/custom/typewriter/utils/pausePatterns.ts +0 -55
  685. package/src/components/custom/typewriter/utils/timing.ts +0 -104
  686. package/src/components/custom/typewriter/utils/typoStateMachine.ts +0 -197
  687. package/src/components/index.ts +0 -2
  688. package/src/components/ui/accordion/Accordion.vue +0 -19
  689. package/src/components/ui/accordion/AccordionContent.vue +0 -24
  690. package/src/components/ui/accordion/AccordionItem.vue +0 -24
  691. package/src/components/ui/accordion/AccordionTrigger.vue +0 -39
  692. package/src/components/ui/accordion/index.ts +0 -4
  693. package/src/components/ui/alert/Alert.vue +0 -20
  694. package/src/components/ui/alert/AlertDescription.vue +0 -17
  695. package/src/components/ui/alert/AlertTitle.vue +0 -17
  696. package/src/components/ui/alert/index.ts +0 -23
  697. package/src/components/ui/avatar/Avatar.vue +0 -21
  698. package/src/components/ui/avatar/AvatarFallback.vue +0 -11
  699. package/src/components/ui/avatar/AvatarImage.vue +0 -9
  700. package/src/components/ui/avatar/index.ts +0 -24
  701. package/src/components/ui/badge/Badge.vue +0 -16
  702. package/src/components/ui/badge/index.ts +0 -25
  703. package/src/components/ui/button/Button.vue +0 -26
  704. package/src/components/ui/button/index.ts +0 -43
  705. package/src/components/ui/card/Card.vue +0 -28
  706. package/src/components/ui/card/CardContent.vue +0 -14
  707. package/src/components/ui/card/CardDescription.vue +0 -14
  708. package/src/components/ui/card/CardFooter.vue +0 -14
  709. package/src/components/ui/card/CardHeader.vue +0 -14
  710. package/src/components/ui/card/CardTitle.vue +0 -21
  711. package/src/components/ui/card/index.ts +0 -6
  712. package/src/components/ui/carousel/Carousel.vue +0 -53
  713. package/src/components/ui/carousel/CarouselContent.vue +0 -35
  714. package/src/components/ui/carousel/CarouselItem.vue +0 -24
  715. package/src/components/ui/carousel/CarouselNext.vue +0 -40
  716. package/src/components/ui/carousel/CarouselPrevious.vue +0 -40
  717. package/src/components/ui/carousel/index.ts +0 -10
  718. package/src/components/ui/carousel/interface.ts +0 -26
  719. package/src/components/ui/carousel/useCarousel.ts +0 -56
  720. package/src/components/ui/checkbox/Checkbox.vue +0 -33
  721. package/src/components/ui/checkbox/index.ts +0 -1
  722. package/src/components/ui/collapsible/Collapsible.vue +0 -15
  723. package/src/components/ui/collapsible/CollapsibleContent.vue +0 -11
  724. package/src/components/ui/collapsible/CollapsibleTrigger.vue +0 -11
  725. package/src/components/ui/collapsible/index.ts +0 -3
  726. package/src/components/ui/combobox/Combobox.vue +0 -17
  727. package/src/components/ui/combobox/ComboboxAnchor.vue +0 -23
  728. package/src/components/ui/combobox/ComboboxEmpty.vue +0 -21
  729. package/src/components/ui/combobox/ComboboxGroup.vue +0 -27
  730. package/src/components/ui/combobox/ComboboxInput.vue +0 -41
  731. package/src/components/ui/combobox/ComboboxItem.vue +0 -24
  732. package/src/components/ui/combobox/ComboboxItemIndicator.vue +0 -23
  733. package/src/components/ui/combobox/ComboboxList.vue +0 -29
  734. package/src/components/ui/combobox/ComboboxSeparator.vue +0 -21
  735. package/src/components/ui/combobox/ComboboxViewport.vue +0 -23
  736. package/src/components/ui/combobox/index.ts +0 -12
  737. package/src/components/ui/command/Command.vue +0 -30
  738. package/src/components/ui/command/CommandDialog.vue +0 -21
  739. package/src/components/ui/command/CommandEmpty.vue +0 -20
  740. package/src/components/ui/command/CommandGroup.vue +0 -29
  741. package/src/components/ui/command/CommandInput.vue +0 -33
  742. package/src/components/ui/command/CommandItem.vue +0 -26
  743. package/src/components/ui/command/CommandList.vue +0 -27
  744. package/src/components/ui/command/CommandSeparator.vue +0 -23
  745. package/src/components/ui/command/CommandShortcut.vue +0 -14
  746. package/src/components/ui/command/index.ts +0 -9
  747. package/src/components/ui/context-menu/ContextMenu.vue +0 -15
  748. package/src/components/ui/context-menu/ContextMenuCheckboxItem.vue +0 -40
  749. package/src/components/ui/context-menu/ContextMenuContent.vue +0 -36
  750. package/src/components/ui/context-menu/ContextMenuGroup.vue +0 -11
  751. package/src/components/ui/context-menu/ContextMenuItem.vue +0 -34
  752. package/src/components/ui/context-menu/ContextMenuLabel.vue +0 -25
  753. package/src/components/ui/context-menu/ContextMenuPortal.vue +0 -11
  754. package/src/components/ui/context-menu/ContextMenuRadioGroup.vue +0 -19
  755. package/src/components/ui/context-menu/ContextMenuRadioItem.vue +0 -40
  756. package/src/components/ui/context-menu/ContextMenuSeparator.vue +0 -20
  757. package/src/components/ui/context-menu/ContextMenuShortcut.vue +0 -14
  758. package/src/components/ui/context-menu/ContextMenuSub.vue +0 -19
  759. package/src/components/ui/context-menu/ContextMenuSubContent.vue +0 -35
  760. package/src/components/ui/context-menu/ContextMenuSubTrigger.vue +0 -34
  761. package/src/components/ui/context-menu/ContextMenuTrigger.vue +0 -13
  762. package/src/components/ui/context-menu/index.ts +0 -14
  763. package/src/components/ui/data-table/DataTable.vue +0 -167
  764. package/src/components/ui/data-table/DataTablePagination.vue +0 -112
  765. package/src/components/ui/data-table/types.ts +0 -48
  766. package/src/components/ui/dialog/Dialog.vue +0 -14
  767. package/src/components/ui/dialog/DialogClose.vue +0 -11
  768. package/src/components/ui/dialog/DialogContent.vue +0 -61
  769. package/src/components/ui/dialog/DialogDescription.vue +0 -24
  770. package/src/components/ui/dialog/DialogFooter.vue +0 -19
  771. package/src/components/ui/dialog/DialogHeader.vue +0 -16
  772. package/src/components/ui/dialog/DialogScrollContent.vue +0 -65
  773. package/src/components/ui/dialog/DialogTitle.vue +0 -29
  774. package/src/components/ui/dialog/DialogTrigger.vue +0 -11
  775. package/src/components/ui/dialog/index.ts +0 -9
  776. package/src/components/ui/drawer/Drawer.vue +0 -19
  777. package/src/components/ui/drawer/DrawerContent.vue +0 -28
  778. package/src/components/ui/drawer/DrawerDescription.vue +0 -20
  779. package/src/components/ui/drawer/DrawerFooter.vue +0 -14
  780. package/src/components/ui/drawer/DrawerHeader.vue +0 -14
  781. package/src/components/ui/drawer/DrawerOverlay.vue +0 -18
  782. package/src/components/ui/drawer/DrawerTitle.vue +0 -20
  783. package/src/components/ui/drawer/index.ts +0 -8
  784. package/src/components/ui/dropdown-menu/DropdownMenu.vue +0 -14
  785. package/src/components/ui/dropdown-menu/DropdownMenuCheckboxItem.vue +0 -40
  786. package/src/components/ui/dropdown-menu/DropdownMenuContent.vue +0 -44
  787. package/src/components/ui/dropdown-menu/DropdownMenuGroup.vue +0 -11
  788. package/src/components/ui/dropdown-menu/DropdownMenuItem.vue +0 -28
  789. package/src/components/ui/dropdown-menu/DropdownMenuLabel.vue +0 -24
  790. package/src/components/ui/dropdown-menu/DropdownMenuRadioGroup.vue +0 -19
  791. package/src/components/ui/dropdown-menu/DropdownMenuRadioItem.vue +0 -40
  792. package/src/components/ui/dropdown-menu/DropdownMenuSeparator.vue +0 -22
  793. package/src/components/ui/dropdown-menu/DropdownMenuShortcut.vue +0 -14
  794. package/src/components/ui/dropdown-menu/DropdownMenuSub.vue +0 -19
  795. package/src/components/ui/dropdown-menu/DropdownMenuSubContent.vue +0 -36
  796. package/src/components/ui/dropdown-menu/DropdownMenuSubTrigger.vue +0 -33
  797. package/src/components/ui/dropdown-menu/DropdownMenuTrigger.vue +0 -13
  798. package/src/components/ui/dropdown-menu/index.ts +0 -16
  799. package/src/components/ui/hover-card/HoverCard.vue +0 -14
  800. package/src/components/ui/hover-card/HoverCardContent.vue +0 -41
  801. package/src/components/ui/hover-card/HoverCardTrigger.vue +0 -11
  802. package/src/components/ui/hover-card/index.ts +0 -3
  803. package/src/components/ui/index.ts +0 -41
  804. package/src/components/ui/input/Input.vue +0 -24
  805. package/src/components/ui/input/index.ts +0 -1
  806. package/src/components/ui/label/Label.vue +0 -27
  807. package/src/components/ui/label/index.ts +0 -1
  808. package/src/components/ui/multi-select/MultiSelect.vue +0 -141
  809. package/src/components/ui/multi-select/index.ts +0 -7
  810. package/src/components/ui/notification/Notification.vue +0 -85
  811. package/src/components/ui/notification/index.ts +0 -1
  812. package/src/components/ui/number-field/NumberField.vue +0 -23
  813. package/src/components/ui/number-field/NumberFieldContent.vue +0 -14
  814. package/src/components/ui/number-field/NumberFieldDecrement.vue +0 -25
  815. package/src/components/ui/number-field/NumberFieldIncrement.vue +0 -25
  816. package/src/components/ui/number-field/NumberFieldInput.vue +0 -8
  817. package/src/components/ui/number-field/index.ts +0 -5
  818. package/src/components/ui/popover/Popover.vue +0 -15
  819. package/src/components/ui/popover/PopoverContent.vue +0 -61
  820. package/src/components/ui/popover/PopoverTrigger.vue +0 -11
  821. package/src/components/ui/popover/index.ts +0 -3
  822. package/src/components/ui/progress/Progress.vue +0 -39
  823. package/src/components/ui/progress/index.ts +0 -1
  824. package/src/components/ui/radio-group/RadioGroup.vue +0 -25
  825. package/src/components/ui/radio-group/RadioGroupItem.vue +0 -39
  826. package/src/components/ui/radio-group/index.ts +0 -2
  827. package/src/components/ui/scroll-area/ScrollArea.vue +0 -29
  828. package/src/components/ui/scroll-area/ScrollBar.vue +0 -30
  829. package/src/components/ui/scroll-area/index.ts +0 -2
  830. package/src/components/ui/scroll-pane/ScrollPane.vue +0 -25
  831. package/src/components/ui/scroll-pane/ScrollPaneHeader.vue +0 -75
  832. package/src/components/ui/scroll-pane/index.ts +0 -2
  833. package/src/components/ui/select/Select.vue +0 -15
  834. package/src/components/ui/select/SelectContent.vue +0 -57
  835. package/src/components/ui/select/SelectGroup.vue +0 -19
  836. package/src/components/ui/select/SelectItem.vue +0 -47
  837. package/src/components/ui/select/SelectItemText.vue +0 -11
  838. package/src/components/ui/select/SelectLabel.vue +0 -13
  839. package/src/components/ui/select/SelectScrollDownButton.vue +0 -24
  840. package/src/components/ui/select/SelectScrollUpButton.vue +0 -24
  841. package/src/components/ui/select/SelectSeparator.vue +0 -17
  842. package/src/components/ui/select/SelectTrigger.vue +0 -45
  843. package/src/components/ui/select/SelectValue.vue +0 -11
  844. package/src/components/ui/select/index.ts +0 -11
  845. package/src/components/ui/separator/Separator.vue +0 -35
  846. package/src/components/ui/separator/index.ts +0 -1
  847. package/src/components/ui/sheet/Sheet.vue +0 -14
  848. package/src/components/ui/sheet/SheetClose.vue +0 -11
  849. package/src/components/ui/sheet/SheetContent.vue +0 -56
  850. package/src/components/ui/sheet/SheetDescription.vue +0 -22
  851. package/src/components/ui/sheet/SheetFooter.vue +0 -19
  852. package/src/components/ui/sheet/SheetHeader.vue +0 -16
  853. package/src/components/ui/sheet/SheetTitle.vue +0 -22
  854. package/src/components/ui/sheet/SheetTrigger.vue +0 -11
  855. package/src/components/ui/sheet/index.ts +0 -31
  856. package/src/components/ui/skeleton/Skeleton.vue +0 -14
  857. package/src/components/ui/skeleton/index.ts +0 -1
  858. package/src/components/ui/slider/Slider.vue +0 -67
  859. package/src/components/ui/slider/index.ts +0 -1
  860. package/src/components/ui/switch/Switch.vue +0 -37
  861. package/src/components/ui/switch/index.ts +0 -1
  862. package/src/components/ui/table/Table.vue +0 -16
  863. package/src/components/ui/table/TableBody.vue +0 -14
  864. package/src/components/ui/table/TableCaption.vue +0 -14
  865. package/src/components/ui/table/TableCell.vue +0 -14
  866. package/src/components/ui/table/TableEmpty.vue +0 -39
  867. package/src/components/ui/table/TableFooter.vue +0 -16
  868. package/src/components/ui/table/TableHead.vue +0 -21
  869. package/src/components/ui/table/TableHeader.vue +0 -14
  870. package/src/components/ui/table/TableRow.vue +0 -21
  871. package/src/components/ui/table/index.ts +0 -9
  872. package/src/components/ui/tabs/Tabs.vue +0 -15
  873. package/src/components/ui/tabs/TabsContent.vue +0 -22
  874. package/src/components/ui/tabs/TabsIndicator.vue +0 -22
  875. package/src/components/ui/tabs/TabsList.vue +0 -25
  876. package/src/components/ui/tabs/TabsTrigger.vue +0 -29
  877. package/src/components/ui/tabs/index.ts +0 -5
  878. package/src/components/ui/tags-input/TagsInput.vue +0 -22
  879. package/src/components/ui/tags-input/TagsInputInput.vue +0 -19
  880. package/src/components/ui/tags-input/TagsInputItem.vue +0 -22
  881. package/src/components/ui/tags-input/TagsInputItemDelete.vue +0 -24
  882. package/src/components/ui/tags-input/TagsInputItemText.vue +0 -19
  883. package/src/components/ui/tags-input/index.ts +0 -5
  884. package/src/components/ui/textarea/Textarea.vue +0 -24
  885. package/src/components/ui/textarea/index.ts +0 -1
  886. package/src/components/ui/toast/Toast.vue +0 -57
  887. package/src/components/ui/toast/ToastAction.vue +0 -30
  888. package/src/components/ui/toast/ToastClose.vue +0 -31
  889. package/src/components/ui/toast/ToastDescription.vue +0 -25
  890. package/src/components/ui/toast/ToastTitle.vue +0 -25
  891. package/src/components/ui/toast/Toaster.vue +0 -31
  892. package/src/components/ui/toast/index.ts +0 -8
  893. package/src/components/ui/toast/use-toast.ts +0 -136
  894. package/src/components/ui/toggle/Toggle.vue +0 -35
  895. package/src/components/ui/toggle/index.ts +0 -27
  896. package/src/components/ui/toggle-group/ToggleGroup.vue +0 -34
  897. package/src/components/ui/toggle-group/ToggleGroupItem.vue +0 -35
  898. package/src/components/ui/toggle-group/index.ts +0 -2
  899. package/src/components/ui/tooltip/Tooltip.vue +0 -14
  900. package/src/components/ui/tooltip/TooltipContent.vue +0 -31
  901. package/src/components/ui/tooltip/TooltipProvider.vue +0 -11
  902. package/src/components/ui/tooltip/TooltipTrigger.vue +0 -11
  903. package/src/components/ui/tooltip/index.ts +0 -4
  904. package/src/composables/glass/index.ts +0 -8
  905. package/src/composables/glass/useGlassRenderer.ts +0 -252
  906. package/src/composables/glass/webgl/frostShader.ts +0 -221
  907. package/src/composables/glass/webgpu/glassShader.wgsl +0 -173
  908. package/src/composables/index.ts +0 -32
  909. package/src/composables/infinite-scroll/index.ts +0 -2
  910. package/src/composables/infinite-scroll/types.ts +0 -25
  911. package/src/composables/infinite-scroll/useInfiniteScroll.ts +0 -101
  912. package/src/composables/interaction/index.ts +0 -5
  913. package/src/composables/interaction/useHeightTransition.ts +0 -82
  914. package/src/composables/interaction/useHoverPopover.ts +0 -64
  915. package/src/composables/interaction/useHoverToggle.ts +0 -103
  916. package/src/composables/interaction/useLeaveTimer.ts +0 -17
  917. package/src/composables/interaction/useTouchGate.ts +0 -207
  918. package/src/composables/pagination/index.ts +0 -2
  919. package/src/composables/pagination/useOffsetPagination.ts +0 -70
  920. package/src/composables/prng.ts +0 -32
  921. package/src/composables/useCharSplit.ts +0 -31
  922. package/src/composables/useClipboard.ts +0 -46
  923. package/src/composables/useGlobalDark.ts +0 -61
  924. package/src/composables/useKeyboardShortcuts.ts +0 -205
  925. package/src/composables/useWatercolorBlob.ts +0 -136
  926. package/src/composables/virtual/index.ts +0 -22
  927. package/src/composables/virtual/useVirtualSectionWindow.ts +0 -338
  928. package/src/composables/virtual/useWindowedStore.ts +0 -86
  929. package/src/composables/virtual/virtualSectionLayout.ts +0 -212
  930. package/src/index.ts +0 -9
  931. package/src/styles/scroll-pane.css +0 -10
  932. package/src/utils/cn.ts +0 -6
  933. /package/{src/components/custom/confirm-dialog/index.ts → dist/components/custom/confirm-dialog/index.d.ts} +0 -0
  934. /package/{src/components/custom/controls/index.ts → dist/components/custom/controls/index.d.ts} +0 -0
  935. /package/{src/components/custom/expandable-container/index.ts → dist/components/custom/expandable-container/index.d.ts} +0 -0
  936. /package/{src/components/custom/icon-tooltip/index.ts → dist/components/custom/icon-tooltip/index.d.ts} +0 -0
  937. /package/{src/components/custom/infinite-scroll/composables/index.ts → dist/components/custom/infinite-scroll/composables/index.d.ts} +0 -0
  938. /package/{src/components/custom/infinite-scroll/index.ts → dist/components/custom/infinite-scroll/index.d.ts} +0 -0
  939. /package/{src/components/custom/search/composables/index.ts → dist/components/custom/search/composables/index.d.ts} +0 -0
  940. /package/{src/components/custom/search/index.ts → dist/components/custom/search/index.d.ts} +0 -0
  941. /package/{src/components/custom/tabs/index.ts → dist/components/custom/tabs/index.d.ts} +0 -0
  942. /package/{src/components/custom/typewriter/composables/index.ts → dist/components/custom/typewriter/composables/index.d.ts} +0 -0
  943. /package/{src/components/custom/typewriter/index.ts → dist/components/custom/typewriter/index.d.ts} +0 -0
  944. /package/{src/components/ui/data-table/index.ts → dist/components/ui/data-table/index.d.ts} +0 -0
  945. /package/{src/utils/index.ts → dist/utils/index.d.ts} +0 -0
@@ -1,13 +1,67 @@
1
1
  /* Shared utility classes */
2
2
 
3
- @layer components {
4
- /* ── Popover/dropdown shared animation ── */
5
- .popover-animate {
6
- @apply data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95;
7
- }
3
+ /* ── Popover/dropdown shared animation ──
4
+ `@utility` form (V.W3.T8 / A5 §5.9 standardisation): data-state animation
5
+ pair for popover-class containers (Popover, DropdownMenu, ContextMenu,
6
+ Tooltip, HoverCard, Select). Composed alongside `.slide-in-from-side`
7
+ for direction-keyed entries. */
8
+ @utility popover-animate {
9
+ @apply data-[state=open]:animate-in data-[state=closed]:animate-out
10
+ data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0
11
+ data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95;
12
+ }
8
13
 
9
- .slide-in-from-side {
10
- @apply data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2;
14
+ /* ── Slide-in entry by side data-attr ──
15
+ `@utility` form (V.W3.T8). Side-keyed slide entry that pairs with
16
+ reka-ui's `data-side` (`top|right|bottom|left`). The animation
17
+ direction inverts each side so panels enter from outside the
18
+ anchor's edge. */
19
+ @utility slide-in-from-side {
20
+ @apply data-[side=bottom]:slide-in-from-top-2
21
+ data-[side=left]:slide-in-from-right-2
22
+ data-[side=right]:slide-in-from-left-2
23
+ data-[side=top]:slide-in-from-bottom-2;
24
+ }
25
+
26
+ @layer components {
27
+ /* ── Section description (V.W3.T7) ──────────────────────────────
28
+ Canonical recipe for the `<Section>` primitive's description
29
+ paragraph. Composes the body type + muted-foreground color in
30
+ one declaration so consumers don't fight twMerge's
31
+ typography-class collapse. */
32
+ .section-description {
33
+ font-size: var(--type-body);
34
+ color: var(--muted-foreground);
35
+ line-height: 1.5;
36
+ }
37
+
38
+ /* ── Labeled-field label (V.W3.T5 / A5 §5.5) ────────────────────
39
+ Canonical recipe for `<LabeledField>`'s tooltip-wrapped label
40
+ layer. Four sibling wrappers (LabeledInput, LabeledSelect,
41
+ LabeledSlider, LabeledSwitch) used to repeat this literal across
42
+ their templates; promoting it to a utility lets the parent SFC
43
+ own one canonical declaration. */
44
+ .labeled-field-label {
45
+ font-family: var(--font-display);
46
+ font-size: var(--type-body);
47
+ color: var(--muted-foreground);
48
+ cursor: help;
49
+ }
50
+
51
+ /* ── Popover-content recipe (V.W3.T3 / A5 §3.2) ─────────────────
52
+ Canonical recipe for floating-tier portal containers
53
+ (PopoverContent, DropdownMenuContent, SelectContent, etc.).
54
+ Covers radius + outline + popover-foreground; consumers compose
55
+ this with `.glass-floating` (bg + blur + border + shadow), with
56
+ `.popover-animate` (data-state animation), and with the per-host
57
+ z-rung. The floating-tier shadow comes from
58
+ `--glass-shadow-floating` via `.glass-floating`, replacing the
59
+ `shadow-md`/`shadow-lg` literals that bypassed the canonical
60
+ cascade. */
61
+ .popover-content {
62
+ border-radius: var(--radius-panel);
63
+ color: var(--popover-foreground);
64
+ outline: none;
11
65
  }
12
66
 
13
67
  /* ── Scrollbar ── */
@@ -30,34 +84,13 @@
30
84
  box-shadow: var(--focus-ring-shadow);
31
85
  }
32
86
 
33
- /* ── Button press/interactive states ── */
34
- .btn-press {
35
- transition: transform var(--duration-fast) var(--ease-standard);
36
- }
37
- .btn-press:active {
38
- transform: scale(var(--scale-press-btn));
39
- }
40
- .btn-press:disabled {
41
- opacity: 0.5;
42
- pointer-events: none;
43
- }
44
-
45
- .btn-interactive {
46
- transition: all var(--duration-fast) var(--ease-standard);
47
- }
48
- .btn-interactive:hover {
49
- transform: scale(var(--scale-hover));
50
- }
51
- .btn-interactive:active {
52
- transform: scale(var(--scale-press));
53
- }
54
- .btn-interactive:disabled {
55
- opacity: 0.5;
56
- pointer-events: none;
57
- }
58
- .btn-interactive:focus-visible {
59
- box-shadow: var(--focus-ring-shadow);
60
- outline: none;
87
+ /* ── Hairline-accent 0.5px catch-light + under-shadow pair ──
88
+ Composes the canonical `--border-hairline` token (tokens.css §
89
+ Glass-decorative). Adopt at any surface that wants the canonical
90
+ 2-stop hairline (dock surfaces, instrument-chassis). Auto-mirrors
91
+ in dark via the .dark token override. */
92
+ .hairline-accent {
93
+ box-shadow: var(--border-hairline);
61
94
  }
62
95
 
63
96
  /* ── Interactive item (hover bg + focus ring + active scale) ── */
@@ -81,9 +114,38 @@
81
114
  .interactive-item:active {
82
115
  transform: scale(0.98);
83
116
  }
84
- .interactive-item:disabled {
117
+ .interactive-item:disabled,
118
+ .interactive-item[data-disabled] {
85
119
  pointer-events: none;
86
- opacity: 0.5;
120
+ opacity: var(--opacity-disabled);
121
+ cursor: not-allowed;
122
+ }
123
+
124
+ /* ── Tap-squish — universal press-state choreography ──
125
+ AL-W10 SLIM (X6 §M-1 + Y7 §3 + DESIGN.md §L3). I compose this
126
+ class onto every interactive surface that wants the iOS tap-
127
+ squish idiom; the press scales to `--scale-press` (0.96, the
128
+ canonical iOS `.regular` control rung) and the spring carries
129
+ the return via `--spring-snappy` (the §L3 release-spring
130
+ contract). I keep this as a single canonical rung — NOT a
131
+ 3-rung ladder. The outliers I leave alone are button `0.97` and
132
+ dock control `0.92`, which consume their own scale tokens
133
+ directly.
134
+
135
+ Under PRM I retire the press transform entirely and lean on the
136
+ consumer's own hover/active bg-tint cascade to acknowledge the
137
+ press. */
138
+ .tap-squish {
139
+ transition: transform var(--duration-fast) var(--spring-snappy);
140
+ transform-origin: center center;
141
+ }
142
+ .tap-squish:active {
143
+ transform: scale(var(--scale-press));
144
+ }
145
+ @media (prefers-reduced-motion: reduce) {
146
+ .tap-squish:active {
147
+ transform: none;
148
+ }
87
149
  }
88
150
 
89
151
  /* ── Status dot indicator ── */
@@ -98,64 +160,6 @@
98
160
  background var(--duration-fast) var(--ease-standard),
99
161
  box-shadow var(--duration-fast) var(--ease-standard);
100
162
  }
101
- .status-dot--active {
102
- background: var(--color-status-active, hsl(142 71% 45%));
103
- }
104
- .status-dot--paused {
105
- background: var(--color-status-paused, hsl(48 96% 53%));
106
- }
107
- .status-dot--idle {
108
- background: var(--color-status-idle, var(--muted-foreground));
109
- }
110
-
111
- /* ── Paper texture backgrounds ── */
112
- .bg-paper-clean {
113
- background-image: var(--paper-clean-texture);
114
- background-repeat: repeat;
115
- background-size: var(--paper-texture-size);
116
- background-blend-mode: multiply;
117
- }
118
- .bg-paper-aged {
119
- background-image: var(--paper-aged-texture);
120
- background-repeat: repeat;
121
- background-size: var(--paper-texture-size);
122
- background-blend-mode: multiply;
123
- }
124
-
125
- /* ── Rainbow text ── */
126
- .rainbow-text {
127
- background: linear-gradient(
128
- 90deg,
129
- hsl(0 85% 70%),
130
- hsl(30 85% 65%),
131
- hsl(60 85% 60%),
132
- hsl(120 65% 55%),
133
- hsl(200 85% 60%),
134
- hsl(260 75% 65%),
135
- hsl(320 80% 65%)
136
- );
137
- background-clip: text;
138
- -webkit-text-fill-color: transparent;
139
- }
140
-
141
- /* ── Rainbow border ── */
142
- .rainbow-border {
143
- background:
144
- linear-gradient(var(--background), var(--background)) padding-box,
145
- linear-gradient(
146
- 135deg,
147
- hsl(0 85% 70%),
148
- hsl(60 85% 60%),
149
- hsl(120 65% 55%),
150
- hsl(200 85% 60%),
151
- hsl(260 75% 65%),
152
- hsl(320 80% 65%),
153
- hsl(0 85% 70%)
154
- )
155
- border-box;
156
- border: 2px solid transparent;
157
- }
158
-
159
163
  /* ── Depth text (layered shadow with customizable colors) ── */
160
164
  .depth-text {
161
165
  --depth-color-primary: var(--primary);
@@ -168,20 +172,10 @@
168
172
  3px 3px 0 var(--depth-color-shadow),
169
173
  4px 4px 0 var(--depth-color-shadow),
170
174
  5px 5px 0 var(--depth-color-shadow),
171
- 5px 5px 1px rgba(0, 0, 0, 0.1),
172
- 2px 2px 2px rgba(0, 0, 0, 0.2),
173
- 4px 4px 5px rgba(0, 0, 0, 0.25),
174
- 6px 6px 10px rgba(0, 0, 0, 0.15);
175
- }
176
-
177
- /* ── Touch gate (iOS Safari) ── */
178
- .touch-gate-target {
179
- outline: 2px solid transparent;
180
- outline-offset: -2px;
181
- transition: outline-color var(--duration-fast) var(--ease-standard);
182
- }
183
- .touch-gate-active {
184
- outline-color: color-mix(in srgb, var(--ring) 25%, transparent);
175
+ 5px 5px 1px color-mix(in srgb, var(--shadow-color) 10%, transparent),
176
+ 2px 2px 2px color-mix(in srgb, var(--shadow-color) 20%, transparent),
177
+ 4px 4px 5px color-mix(in srgb, var(--shadow-color) 25%, transparent),
178
+ 6px 6px 10px color-mix(in srgb, var(--shadow-color) 15%, transparent);
185
179
  }
186
180
 
187
181
  /* ── 3D preserve ── */
@@ -218,38 +212,42 @@
218
212
  -webkit-mask-image: linear-gradient(to bottom, transparent, black var(--mask-fade-width), black calc(100% - var(--mask-fade-width)), transparent);
219
213
  }
220
214
 
221
- /* ── Icon sizing ── */
222
- .icon-xs { @apply w-3 h-3 shrink-0; }
223
- .icon-sm { @apply w-3.5 h-3.5 shrink-0; }
224
- .icon-md { @apply w-4 h-4 shrink-0; }
225
- .icon-lg { @apply w-5 h-5 shrink-0; }
215
+ /* ── Card scroll-timeline host (AI.W1-α) ───────────────────────────────
216
+ Canonical scroll-overflow host that emits the `--card-scroll` named
217
+ scroll-timeline consumed by `<CardHeader shrink>`. Apply to the
218
+ scroll-overflow ancestor (typically the `<Card>` itself OR a wrapper
219
+ inside it that carries `overflow-y: auto`).
220
+
221
+ `contain: layout style paint` isolates the named timeline so child
222
+ animations respond to THIS host's scroll only — not to portal-
223
+ triggered layout shifts in ancestor containers (the load-bearing
224
+ isolation guarantee the value.js `PaneHeader.vue:18-29` comment
225
+ called out and the AI.W1 spec §1.2 ratified as canon).
226
226
 
227
- /* ── Shimmer text effects ── */
227
+ Disambiguated from `.scroll-fade-*` (mask-image fade gradient at
228
+ the container's leading/trailing edge) — `.card-scroll-host` does
229
+ NOT paint any visual; it only emits the timeline. */
230
+ .card-scroll-host {
231
+ contain: layout style paint;
232
+ scroll-timeline: --card-scroll block;
233
+ }
234
+
235
+ /* ── Shimmer text effects ──
236
+ The text-fill + background-clip composition is load-bearing visual
237
+ (the gold gradient itself); only the `animation:` line is wrapped in
238
+ the PRM no-preference bracket so PRM users see the static gradient
239
+ without the slide animation. */
228
240
  .gold-shimmer {
229
241
  background: linear-gradient(90deg, var(--color-gold-dark), var(--color-gold-light), var(--color-gold), var(--color-gold-light), var(--color-gold-dark));
230
242
  background-size: 250% 100%;
231
243
  background-clip: text;
232
244
  -webkit-background-clip: text;
233
245
  color: transparent;
234
- animation: shimmer 5s linear infinite;
235
- }
236
-
237
- .blue-shimmer {
238
- background: linear-gradient(90deg, #1e40af, #60a5fa, #3b82f6, #60a5fa, #1e40af);
239
- background-size: 200% 100%;
240
- background-clip: text;
241
- -webkit-background-clip: text;
242
- color: transparent;
243
- animation: shimmer 3s linear infinite;
244
246
  }
245
-
246
- .gold-shimmer-subtle {
247
- background: linear-gradient(90deg, var(--color-gold-dark), var(--color-gold-light), var(--color-gold-dark));
248
- background-size: 300% 100%;
249
- background-clip: text;
250
- -webkit-background-clip: text;
251
- color: transparent;
252
- animation: shimmer 8s linear infinite;
247
+ @media (prefers-reduced-motion: no-preference) {
248
+ .gold-shimmer {
249
+ animation: gold-shimmer-slide var(--duration-shimmer) linear infinite;
250
+ }
253
251
  }
254
252
 
255
253
  /* ── Keyboard key ── */
@@ -269,24 +267,172 @@
269
267
  line-height: 1;
270
268
  }
271
269
 
272
- /* ── Code badge ── */
273
- .code-badge {
274
- font-family: var(--font-mono, monospace);
275
- font-size: 0.75rem;
276
- border-radius: var(--radius-md);
277
- border: 1px solid var(--border);
278
- padding: 0.125rem 0.375rem;
270
+ /* ── Metric badge pill — compact glass label for numeric telemetry ── */
271
+ .metric-badge {
272
+ display: inline-flex;
273
+ align-items: center;
274
+ justify-content: center;
275
+ text-align: center;
276
+ gap: var(--metric-badge-gap, 0.125rem);
277
+ max-width: var(--metric-badge-max-width, 8rem);
278
+ min-height: var(--metric-badge-min-height, 1.5rem);
279
+ padding:
280
+ var(--metric-badge-padding-block, 0.125rem)
281
+ var(--metric-badge-padding-inline, 0.5rem);
282
+ overflow: hidden;
283
+ flex-shrink: 0;
284
+ line-height: 1;
285
+ /* Canonical 5-tier glass surface: the `quiet` rung paints the badge
286
+ plate at the `--glass-bg-quiet` α (0.50) with `--glass-blur-quiet`.
287
+ Reduced-transparency / no-backdrop-filter fallbacks propagate
288
+ through the lazy custom-property resolution that `glass.css`
289
+ sets up — the badge no longer bypasses the canon.
290
+ (Per audit U.W0.C-c §7.2.) */
291
+ border: 1px solid var(--metric-badge-border, var(--glass-border-quiet));
292
+ border-radius: var(--metric-badge-radius, var(--radius-badge, var(--radius-pill)));
293
+ background: var(--metric-badge-bg, var(--glass-bg-quiet));
294
+ backdrop-filter: var(--metric-badge-blur, var(--glass-blur-quiet));
295
+ box-shadow: var(--metric-badge-shadow, 0 1px 6px color-mix(in srgb, var(--shadow-color) 8%, transparent), var(--glass-highlight));
296
+ transition:
297
+ background var(--duration-fast) var(--ease-standard),
298
+ border-color var(--duration-fast) var(--ease-standard),
299
+ box-shadow var(--duration-fast) var(--ease-standard),
300
+ transform var(--duration-fast) var(--ease-standard);
301
+ }
302
+
303
+ .metric-badge > span {
304
+ line-height: 1;
305
+ }
306
+
307
+ .metric-badge:hover {
308
+ /* Hover lifts to the `resting` rung — one step up the canonical
309
+ ladder (audit U.W0.C-c §7.2). */
310
+ border-color: var(--metric-badge-hover-border, var(--glass-border-resting));
311
+ background: var(--metric-badge-hover-bg, var(--glass-bg-resting));
312
+ box-shadow: var(--metric-badge-hover-shadow, 0 2px 10px color-mix(in srgb, var(--shadow-color) 12%, transparent), var(--glass-highlight));
313
+ transform: scale(var(--metric-badge-hover-scale, 1.02));
314
+ }
315
+
316
+ .metric-badge:active {
317
+ transform: scale(var(--metric-badge-press-scale, 0.96));
318
+ }
319
+
320
+ .metric-badge:focus-visible {
321
+ outline: none;
322
+ box-shadow: var(--focus-ring-shadow);
323
+ }
324
+
325
+ /* Phase-finish catch-light — the quieter cousin of --glass-specular.
326
+ Speedtest toggles `data-just-resolved="true"` on a metric pill once
327
+ its phase completes; the badge briefly carries a 1px catch-light
328
+ streak at the top edge. Reads as the pill catching club lighting at
329
+ the moment its result resolves. */
330
+ .metric-badge[data-just-resolved="true"] {
331
+ box-shadow:
332
+ inset 0 1px 0 0 rgb(255 255 255 / 0.18),
333
+ var(--metric-badge-shadow,
334
+ 0 1px 6px color-mix(in srgb, var(--shadow-color) 8%, transparent),
335
+ var(--glass-highlight));
336
+ }
337
+
338
+ /* ── Label-bearing variants ───────────────────────────────────────────
339
+ When the badge carries a `labelPosition`, the prose-style annotation
340
+ slot precedes the amount. Inline keeps the row baseline-aligned;
341
+ stacked breaks to a column with items flush-left. The label slot
342
+ carries its own tracked uppercase rules; the badge's max-width
343
+ relaxes so the wider register fits. */
344
+ .metric-badge--label-inline {
345
+ flex-direction: row;
346
+ align-items: baseline;
347
+ justify-content: flex-start;
348
+ gap: var(--metric-badge-label-gap, 0.375rem);
349
+ max-width: var(--metric-badge-label-max-width, none);
350
+ text-align: left;
351
+ }
352
+
353
+ .metric-badge--label-stacked {
354
+ flex-direction: column;
355
+ align-items: flex-start;
356
+ justify-content: center;
357
+ gap: var(--metric-badge-label-gap-stacked, 0.0625rem);
358
+ max-width: var(--metric-badge-label-max-width, none);
359
+ text-align: left;
360
+ min-height: var(--metric-badge-min-height-stacked, 2.625rem);
361
+ padding-block: var(--metric-badge-padding-block-stacked, 0.375rem);
362
+ }
363
+
364
+ /* T.W2.T2 — stacked variant pairs amount + unit on a single row (row 2)
365
+ below the label (row 1). The `.metric-badge__row` wrapper baseline-
366
+ aligns the value and unit so the quantity reads as one phrase, not as
367
+ three siblings split across three rows (the pre-T behaviour the
368
+ audit B-spec §2.1 flagged). */
369
+ .metric-badge--label-stacked .metric-badge__row {
370
+ display: inline-flex;
371
+ align-items: baseline;
372
+ gap: var(--metric-badge-row-gap-stacked, 0.25rem);
373
+ }
374
+
375
+ /* T.W2.T3 — MetricPill density modifiers. The pill is a thin composition
376
+ over MetricBadge with `labelPosition="stacked"` defaults; the density
377
+ knob adjusts block padding + horizontal padding so the pill reads at
378
+ the right register for its dock host. `spacious` is the default
379
+ (chassis-strip rhythm), `comfortable` keeps the tighter compact
380
+ register for densely-packed dock clusters. The selectors compose with
381
+ `.metric-badge--label-stacked` so the inline ladder remains untouched
382
+ — these are stacked-only refinements. */
383
+ .metric-pill[data-density="spacious"].metric-badge--label-stacked {
384
+ --metric-badge-padding-block-stacked: 0.5rem;
385
+ --metric-badge-padding-inline: 0.75rem;
386
+ }
387
+
388
+ .metric-pill[data-density="comfortable"].metric-badge--label-stacked {
389
+ --metric-badge-padding-block-stacked: 0.25rem;
390
+ --metric-badge-padding-inline: 0.5rem;
391
+ }
392
+
393
+ .metric-badge__label {
394
+ letter-spacing: 0.18em;
395
+ line-height: 1;
396
+ }
397
+
398
+ /* Dual-slot default visibility (R2-spec):
399
+ The library renders both `--full` and `--abbr` siblings whenever both
400
+ props are passed. Default identity is the full label; the abbreviation
401
+ sits hidden until consumer container-query CSS flips it. The adjacent-
402
+ sibling selector preserves single-slot back-compat: when a consumer
403
+ passes only `abbreviation` (no `--full` sibling rendered), the abbr
404
+ reads at default visibility. */
405
+ .metric-badge__label--full + .metric-badge__label--abbr {
406
+ display: none;
407
+ }
408
+
409
+ /* sm-tier label tracking — tighter than the md/lg/xl 0.18em rung so the
410
+ compact register reads as a tighter annotation against the smaller
411
+ glyph rise. R2-spec D-Rec-2 (audit-D). */
412
+ .metric-badge[data-size="sm"] .metric-badge__label {
413
+ letter-spacing: 0.1em;
279
414
  }
280
415
 
281
- /* ── Input barglassmorphic inline input container ── */
416
+ /* Q.W3 Lane Athe `.glass-dock[data-density="…"]` density rungs that
417
+ set `--dock-tab-h` + `--dock-label-size` were consolidated into
418
+ `dock.css` (their canonical dock-styles home). They formerly lived
419
+ here and resolved only by the index.css import order (utilities.css
420
+ after dock.css); the cascade-order dependency is now gone. */
421
+
422
+ /* ── Input bar — glassmorphic inline input container ──
423
+ Composes the canonical `floating` glass rung (--glass-bg-floating
424
+ ≈ 80% α, --glass-blur-floating ≈ 24px) — same surface read as the
425
+ prior raw composition but routed through the canonical 5-tier
426
+ ladder so PRT / no-backdrop-filter fallbacks propagate cleanly.
427
+ (Per audit U.W0.C-c §7.2.) */
282
428
  .input-bar {
283
429
  display: flex;
284
430
  align-items: center;
285
431
  gap: 0.5rem;
286
432
  border-radius: var(--radius-2xl);
287
- border: 1px solid color-mix(in srgb, var(--border) 50%, transparent);
288
- background: color-mix(in srgb, var(--card) 80%, transparent);
289
- backdrop-filter: blur(24px);
433
+ border: 1px solid var(--glass-border-floating);
434
+ background: var(--glass-bg-floating);
435
+ backdrop-filter: var(--glass-blur-floating);
290
436
 
291
437
  padding: 0 0.75rem;
292
438
  height: 2.25rem;
@@ -297,7 +443,7 @@
297
443
  border-color var(--duration-fast) var(--ease-standard);
298
444
  }
299
445
  .input-bar:focus-within {
300
- box-shadow: 0 0 0 2px color-mix(in srgb, var(--ring) 40%, transparent);
446
+ box-shadow: var(--focus-ring-shadow);
301
447
  border-color: var(--border);
302
448
  }
303
449
 
@@ -314,24 +460,13 @@
314
460
  color: color-mix(in srgb, var(--muted-foreground) 50%, transparent);
315
461
  }
316
462
 
317
- /* ── Dashed well — muted container for adding/selecting items ── */
318
- .dashed-well {
319
- max-width: var(--max-width-input);
320
- border-radius: var(--radius-2xl);
321
- border: 2px dashed color-mix(in srgb, var(--primary) 30%, transparent);
322
- background: color-mix(in srgb, var(--primary) 5%, transparent);
323
- padding: 0.75rem;
324
- display: grid;
325
- gap: 0.5rem;
326
- }
327
-
328
463
  /* ── Hover lift — translate-y + shadow on hover (3 levels) ── */
329
464
  .hover-lift {
330
465
  transition-property: transform, box-shadow;
331
466
  transition-duration: var(--duration-normal);
332
- transition-timing-function: ease;
467
+ transition-timing-function: var(--ease-standard);
333
468
  }
334
- .hover-lift:hover {
469
+ .hover-lift:hover:not(:disabled):not([aria-disabled='true']) {
335
470
  transform: translateY(var(--lift-sm));
336
471
  box-shadow: var(--shadow-md);
337
472
  }
@@ -339,9 +474,9 @@
339
474
  .hover-lift-md {
340
475
  transition-property: transform, box-shadow;
341
476
  transition-duration: var(--duration-normal);
342
- transition-timing-function: ease;
477
+ transition-timing-function: var(--ease-standard);
343
478
  }
344
- .hover-lift-md:hover {
479
+ .hover-lift-md:hover:not(:disabled):not([aria-disabled='true']) {
345
480
  transform: translateY(var(--lift-md));
346
481
  box-shadow: var(--shadow-md);
347
482
  }
@@ -349,125 +484,41 @@
349
484
  .hover-lift-lg {
350
485
  transition-property: transform, box-shadow;
351
486
  transition-duration: var(--duration-normal);
352
- transition-timing-function: ease;
487
+ transition-timing-function: var(--ease-standard);
353
488
  }
354
- .hover-lift-lg:hover {
489
+ .hover-lift-lg:hover:not(:disabled):not([aria-disabled='true']) {
355
490
  transform: translateY(var(--lift-lg));
356
491
  box-shadow: var(--shadow-lg);
357
492
  }
358
493
 
359
- /* ── Hover shadow lift shadow-only hover ── */
360
- .hover-shadow-lift {
361
- transition-property: box-shadow;
362
- transition-duration: var(--duration-normal);
363
- transition-timing-function: var(--spring-smooth);
364
- }
365
- .hover-shadow-lift:hover {
366
- box-shadow: var(--shadow-xl);
367
- }
368
-
369
- /* ── Glass overlay — dark backdrop ── */
370
- .glass-overlay {
371
- background: rgb(0 0 0 / 0.6);
372
- backdrop-filter: blur(4px);
373
-
374
- }
375
-
376
- /* ── Cartoon shadows — multi-layer offset shadow + border + translateY ── */
494
+ /* ── Cartoon shadowstoken-driven box-shadow + bezel border + lift ──
495
+ The box-shadow stack reads from the canonical
496
+ `--shadow-cartoon-{sm,md,lg}` rungs declared at tokens.css:304-312.
497
+ Those rungs use `color-mix(in srgb, var(--shadow-color) N%, transparent)`
498
+ so dark-mode flips the cast through `--shadow-color` automatically.
499
+ The 2px bezel border + translateY are the cartoon-stamp geometry
500
+ atop the canonical depth — kept here so a single class delivers
501
+ the whole cartoon read.
502
+ (Per audit U.W0.C-c §1.3 / Union 1 — collapses the dual-system
503
+ drift onto the token-driven shadow.) */
377
504
  .shadow-cartoon-sm {
378
- box-shadow:
379
- -3px 2px 1px var(--shadow-cartoon-color),
380
- 0 3px 1px var(--shadow-cartoon-color),
381
- -3px 3px 1px var(--shadow-cartoon-color-soft);
505
+ box-shadow: var(--shadow-cartoon-sm);
382
506
  border: 2px solid var(--border);
383
507
  transform: translateY(-1px);
384
508
  }
385
509
 
386
510
  .shadow-cartoon-md {
387
- box-shadow:
388
- -4px 3px 1px var(--shadow-cartoon-color),
389
- 0 4px 1px var(--shadow-cartoon-color),
390
- -4px 4px 2px var(--shadow-cartoon-color-soft);
511
+ box-shadow: var(--shadow-cartoon-md);
391
512
  border: 2px solid var(--border);
392
513
  transform: translateY(-1px);
393
514
  }
394
515
 
395
516
  .shadow-cartoon-lg {
396
- box-shadow:
397
- -6px 4px 1px var(--shadow-cartoon-color),
398
- 0 6px 1px var(--shadow-cartoon-color),
399
- -6px 6px 2px var(--shadow-cartoon-color-soft);
400
- border: 2px solid var(--border);
401
- transform: translateY(-2px);
402
- }
403
-
404
- .shadow-cartoon-sm-hover {
405
- box-shadow:
406
- -4px 3px 1px var(--shadow-cartoon-color-hover),
407
- 0 4px 1px var(--shadow-cartoon-color-hover),
408
- -4px 4px 2px var(--shadow-cartoon-color-hover-soft);
517
+ box-shadow: var(--shadow-cartoon-lg);
409
518
  border: 2px solid var(--border);
410
519
  transform: translateY(-2px);
411
520
  }
412
521
 
413
- /* ── Shimmer text — background gradient sweep over text ── */
414
- .shimmer-text {
415
- background: linear-gradient(
416
- 90deg,
417
- currentColor 0%,
418
- currentColor 40%,
419
- rgba(255, 255, 255, 0.8) 50%,
420
- currentColor 60%,
421
- currentColor 100%
422
- );
423
- background-size: 200% 100%;
424
- background-clip: text;
425
- -webkit-background-clip: text;
426
- animation: shimmer-sweep var(--shimmer-duration, 2000ms) ease-in-out infinite;
427
- }
428
-
429
- .dark .shimmer-text {
430
- background: linear-gradient(
431
- 90deg,
432
- currentColor 0%,
433
- currentColor 40%,
434
- rgba(255, 255, 255, 0.9) 50%,
435
- currentColor 60%,
436
- currentColor 100%
437
- );
438
- background-size: 200% 100%;
439
- background-clip: text;
440
- -webkit-background-clip: text;
441
- animation: shimmer-sweep var(--shimmer-duration, 2000ms) ease-in-out infinite;
442
- }
443
-
444
- /* ── Rainbow gradients ── */
445
- .rainbow-pastel {
446
- background: linear-gradient(to right, var(--rainbow-pastel-red), var(--rainbow-pastel-orange), var(--rainbow-pastel-yellow), var(--rainbow-pastel-green), var(--rainbow-pastel-blue), var(--rainbow-pastel-indigo), var(--rainbow-pastel-violet));
447
- }
448
- .rainbow-vivid {
449
- background: linear-gradient(to right, var(--rainbow-red), var(--rainbow-orange), var(--rainbow-yellow), var(--rainbow-green), var(--rainbow-blue), var(--rainbow-indigo), var(--rainbow-violet));
450
- }
451
-
452
- /* ── Progress gradient (rainbow) ── */
453
- .progress-gradient {
454
- background: linear-gradient(90deg, #ef4444, #f97316, #eab308, #22c55e, #06b6d0, #3b82f6, #9333ea);
455
- }
456
-
457
- /* ── Glassmorphic checkbox ── */
458
- .checkbox-glass {
459
- height: 1.25rem;
460
- width: 1.25rem;
461
- border-radius: var(--radius-lg);
462
- border: 2px solid color-mix(in srgb, var(--border) 60%, transparent);
463
- backdrop-filter: blur(4px);
464
-
465
- box-shadow: var(--shadow-sm);
466
- transition-property: background-color, border-color, transform, box-shadow;
467
- transition-duration: var(--duration-normal);
468
- transition-timing-function: var(--spring-snappy);
469
- }
470
-
471
522
  /* ── Divider utilities ── */
472
523
  .divider-h {
473
524
  height: 2px;
@@ -491,208 +542,332 @@
491
542
  );
492
543
  }
493
544
 
494
- .divider-v {
495
- width: 2px;
496
- background: linear-gradient(
497
- to bottom,
498
- transparent 3%,
499
- var(--border) 15%,
500
- var(--border) 85%,
501
- transparent 97%
502
- );
545
+ }
546
+
547
+ /* ── Hover scale (O.W6 Lane C) ──
548
+ Canonical hover-transform utility consuming the `--scale-hover` token
549
+ (tokens.css §11). Promoted from consumer-side `hover:scale-105`
550
+ recipe — 13 sites in keyframes.js demo + 9 sites in words/frontend
551
+ per O11/d L3 + O11/a I4. Single-token recipe (no ladder); the dual
552
+ `--scale-press-{xs..lg}` ladder discussion is the press-axis cohort
553
+ (O-N-7), not hover. Consumers reach the utility via
554
+ `class="scale-on-hover"`; transition + easing bind to the canonical
555
+ `--duration-fast` + `--ease-standard` tokens. */
556
+ @utility scale-on-hover {
557
+ @apply transition-transform duration-fast ease-standard;
558
+
559
+ &:hover {
560
+ transform: scale(var(--scale-hover));
503
561
  }
562
+ }
563
+
564
+ /* ── Sheet/drawer slide-out animation grammar ──
565
+ Mirror of `.popover-animate` for sheet/drawer panels. Pairs with
566
+ `slide-in-from-{top,right,bottom,left}-N` to compose side-keyed entries.
567
+ The open path uses --duration-panel (slow, deliberate); the close path
568
+ uses --duration-fast so dismiss feels snappy. R5 vocab.γ gap row 6;
569
+ consumed by W2.A sheet/drawer migration. */
570
+ @utility sheet-animate {
571
+ @apply data-[state=open]:animate-in data-[state=closed]:animate-out
572
+ data-[state=open]:fade-in data-[state=closed]:fade-out
573
+ data-[state=open]:duration-[var(--duration-panel)]
574
+ data-[state=closed]:duration-[var(--duration-fast)];
575
+ }
504
576
 
505
- /* ── Shake error ── */
506
- .shake-error {
507
- animation: shake 0.5s ease-in-out;
577
+ /* ── Audacious primary CTA recipe (K.W6 HEADLINE) ────────────────────
578
+ Lifted from `dock.css` `.dock-tab-button[data-tier="primary"]` per
579
+ K.W6 spec §3 (Option B — drop phase-tinting from the canonical
580
+ variant; phase-tint stays as a dock-local extension). Composes three
581
+ at-rest marks (top-highlight via --glass-highlight, bottom under-shadow
582
+ via --border-hairline, baseline glass via --card surface) with three
583
+ disco accents on hover (specular swap via --glass-specular, sparkle
584
+ sweep via the ::after star, disco-grain via --paper-clean-texture
585
+ blended with a --primary radial). Reservation: disco fires on hover
586
+ only — at rest the button reads as a Vignelli-restrained composed
587
+ glass surface.
588
+
589
+ Pair with `bg-primary text-primary-foreground` for the canonical
590
+ Button variant; the utility owns the texture/highlight/sparkle
591
+ composition only. */
592
+ @utility btn-audacious {
593
+ position: relative;
594
+ isolation: isolate;
595
+ overflow: hidden;
596
+ border: 1px solid var(--glass-border-quiet);
597
+ box-shadow:
598
+ var(--border-hairline),
599
+ var(--glass-highlight);
600
+ transition:
601
+ background var(--duration-fast) var(--ease-standard),
602
+ color var(--duration-fast) var(--ease-standard),
603
+ transform var(--duration-fast) var(--ease-standard),
604
+ box-shadow var(--duration-fast) var(--ease-standard),
605
+ --ripple-radius var(--motion-duration-ripple, 340ms) var(--ease-out-expo);
606
+
607
+ /* Hover composition: paper-grain texture overlaid on a soft
608
+ --primary radial, with the specular catch-light replacing the
609
+ resting hairline highlight. The radial uses --primary at 18%
610
+ — same alpha rung the dock primary tier consumes for phase
611
+ tinting, just bound to the canonical CTA color instead. */
612
+ &:hover:not(:disabled) {
613
+ background-image:
614
+ var(--paper-clean-texture),
615
+ radial-gradient(
616
+ ellipse at 30% 30%,
617
+ color-mix(in srgb, var(--primary) 18%, transparent),
618
+ transparent 70%
619
+ );
620
+ background-blend-mode: overlay, normal;
621
+ background-size: var(--paper-texture-size), auto;
622
+ box-shadow:
623
+ var(--glass-specular),
624
+ 0 0.5px 0 0 rgb(0 0 0 / 0.06);
625
+ }
626
+
627
+ /* AI.W4-M.2 (Q5 — G-AI-D27 ratified) — press-ripple via a typed
628
+ `--ripple-radius` length custom property. The `::before`
629
+ element paints a radial gradient whose stop radius equals the
630
+ typed length; the `:active` rule sets the length to the cap
631
+ (`--ripple-radius-max`, 12rem), and the host's transition
632
+ (above) interpolates the radius via the @property registration
633
+ (tokens.css §18). Release returns the length to its 0px initial
634
+ value and the ripple retires. The ripple paints at z-index 0
635
+ (above the host's background, below the slot content which sits
636
+ in the default 0 stacking context but with text inheriting the
637
+ slot's foreground colour). */
638
+ &::before {
639
+ content: "";
640
+ position: absolute;
641
+ inset: 0;
642
+ pointer-events: none;
643
+ z-index: 0;
644
+ border-radius: inherit;
645
+ background: radial-gradient(
646
+ circle at center,
647
+ color-mix(in srgb, var(--primary-foreground, hsl(0 0% 100%)) 35%, transparent) 0,
648
+ color-mix(in srgb, var(--primary-foreground, hsl(0 0% 100%)) 18%, transparent)
649
+ calc(var(--ripple-radius, 0px) * 0.55),
650
+ transparent var(--ripple-radius, 0px)
651
+ );
652
+ transition: inherit;
653
+ will-change: background;
508
654
  }
509
655
 
510
- /* ── Input focus ring ── */
511
- .input-focus {
512
- outline: none;
513
- transition-property: box-shadow;
514
- transition-duration: var(--duration-normal);
515
- transition-timing-function: var(--spring-smooth);
656
+ &:active:not(:disabled) {
657
+ --ripple-radius: var(--ripple-radius-max, 12rem);
516
658
  }
517
- .input-focus:focus-visible {
518
- box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary) 40%, transparent);
519
- outline: none;
659
+
660
+ /* Sparkle glyph hidden at rest, animated on hover. The star
661
+ sweeps diagonally from top-left to bottom-right per the canonical
662
+ sparkle-sweep keyframe (animations.css). */
663
+ &::after {
664
+ content: "✦";
665
+ position: absolute;
666
+ top: 0.25rem;
667
+ left: 0.5rem;
668
+ color: hsl(0 0% 100% / 0.7);
669
+ font-size: 0.75rem;
670
+ line-height: 1;
671
+ pointer-events: none;
672
+ opacity: 0;
673
+ will-change: transform, opacity;
674
+ z-index: 1;
520
675
  }
521
676
 
522
- /* ── Active scale — press feedback ── */
523
- .active-scale:active {
524
- transform: scale(0.97);
525
- transition-property: transform;
526
- transition-duration: var(--duration-fast);
527
- }
528
-
529
- /* ── Stagger children — cascading entrance for list/grid items ── */
530
- .stagger-children > * {
531
- animation: fade-in var(--duration-normal) var(--spring-smooth, ease) backwards;
532
- animation-delay: calc(var(--stagger-index, 0) * 50ms);
533
- }
534
- .stagger-children > *:nth-child(1) { --stagger-index: 0; }
535
- .stagger-children > *:nth-child(2) { --stagger-index: 1; }
536
- .stagger-children > *:nth-child(3) { --stagger-index: 2; }
537
- .stagger-children > *:nth-child(4) { --stagger-index: 3; }
538
- .stagger-children > *:nth-child(5) { --stagger-index: 4; }
539
- .stagger-children > *:nth-child(6) { --stagger-index: 5; }
540
- .stagger-children > *:nth-child(7) { --stagger-index: 6; }
541
- .stagger-children > *:nth-child(8) { --stagger-index: 7; }
542
- .stagger-children > *:nth-child(9) { --stagger-index: 8; }
543
- .stagger-children > *:nth-child(10) { --stagger-index: 9; }
544
- .stagger-children > *:nth-child(11) { --stagger-index: 10; }
545
- .stagger-children > *:nth-child(12) { --stagger-index: 11; }
546
-
547
- /* ── Scroll reveal — animate on viewport entry (zero JS) ── */
548
- @supports (animation-timeline: view()) {
549
- /* One-shot: fades in during entry, stays visible */
550
- .scroll-reveal {
551
- animation: fade-in linear both;
552
- animation-timeline: view();
553
- animation-range: entry 0% entry 100%;
677
+ @media (prefers-reduced-motion: no-preference) {
678
+ &:hover::after {
679
+ animation: sparkle-sweep var(--duration-sparkle) var(--ease-out-expo);
554
680
  }
681
+ }
682
+
683
+ /* PRM bracket — the press-ripple retires; the press still reads
684
+ via the audacious recipe's transform/scale beat (the ripple is
685
+ affirmation atop affirmation). */
686
+ @media (prefers-reduced-motion: reduce) {
687
+ transition:
688
+ background var(--duration-fast) var(--ease-standard),
689
+ color var(--duration-fast) var(--ease-standard),
690
+ transform var(--duration-fast) var(--ease-standard),
691
+ box-shadow var(--duration-fast) var(--ease-standard);
555
692
 
556
- /* Reversible: fades in on scroll down, fades out on scroll back up */
557
- .scroll-reveal-reverse {
558
- animation: fade-in linear both;
559
- animation-timeline: view();
560
- animation-range: entry 0% cover 50%;
693
+ &:active:not(:disabled) {
694
+ --ripple-radius: 0px;
561
695
  }
562
696
  }
697
+ }
563
698
 
564
- /* ── Letter spacing hover spread ── */
565
- .text-hover-spread {
566
- letter-spacing: var(--tracking-tight);
567
- transition: letter-spacing var(--duration-normal) var(--spring-smooth, ease);
568
- }
569
- .text-hover-spread:hover {
570
- letter-spacing: var(--tracking-wide);
571
- }
699
+ /* ── Gold CTA shimmer modifier AN.R0 D9 ───────────────────────────────
700
+ `btn-audacious-gold` extends `btn-audacious` with a gold sweep shimmer
701
+ on hover. Pair as `btn-audacious btn-audacious-gold` (or use the Button
702
+ `variant="gold-audacious"` which composes both). The hover shimmer is a
703
+ translucent linear-gradient sweep (low alpha — tasteful, not garish)
704
+ that slides left-to-right via the existing `gold-shimmer-slide` keyframe
705
+ (animations.css). The gold gradient uses the canonical `--color-gold-*`
706
+ token triad (tokens.css §13).
707
+
708
+ Design register:
709
+ • PRM no-preference: shimmer sweeps continuously at `--duration-shimmer`
710
+ rate; the sparkle-sweep (from btn-audacious) coexists on hover.
711
+ • PRM reduce: static gold tint shows on hover; no animation.
712
+ • The gold shimmer is a background-image layer ABOVE the existing
713
+ btn-audacious paper-grain + primary-radial layers, blended with
714
+ `overlay` so the glass substrate reads through at partial opacity.
715
+ • The `::before` ripple and `::after` sparkle from btn-audacious are
716
+ unchanged; this modifier only retunes the hover background layers.
717
+ • Consumer applies: `<Button variant="gold-audacious">Next →</Button>` */
718
+ @utility btn-audacious-gold {
719
+ /* At rest: a faint warm gold tint over the glass surface reads as "warm
720
+ glass" without announcing the hover state prematurely. */
721
+ background-image:
722
+ linear-gradient(
723
+ 135deg,
724
+ color-mix(in srgb, var(--color-gold) 8%, transparent),
725
+ color-mix(in srgb, var(--color-gold-light) 5%, transparent) 50%,
726
+ color-mix(in srgb, var(--color-gold) 8%, transparent)
727
+ );
572
728
 
573
- /* ── Disabled base state ── */
574
- .disabled-base:disabled {
575
- pointer-events: none;
576
- cursor: not-allowed;
577
- opacity: 0.5;
729
+ /* Hover: replace the audacious primary-radial with a gold sweep shimmer.
730
+ The shimmer gradient rides above the paper-grain texture; the `overlay`
731
+ blend-mode concentrates the gold on bright grain facets and recedes on
732
+ dark ones — the same lens metaphor as the btn-audacious primary radial. */
733
+ &:hover:not(:disabled) {
734
+ background-image:
735
+ var(--paper-clean-texture),
736
+ linear-gradient(
737
+ 90deg,
738
+ transparent 0%,
739
+ color-mix(in srgb, var(--color-gold-dark) 22%, transparent) 25%,
740
+ color-mix(in srgb, var(--color-gold-light) 30%, transparent) 50%,
741
+ color-mix(in srgb, var(--color-gold-dark) 22%, transparent) 75%,
742
+ transparent 100%
743
+ );
744
+ background-blend-mode: overlay, normal;
745
+ background-size: var(--paper-texture-size), 250% 100%;
746
+ background-position: 0 0, 100% 0;
747
+ box-shadow:
748
+ var(--glass-specular),
749
+ 0 0 0 1px color-mix(in srgb, var(--color-gold) 30%, transparent),
750
+ 0 0.5px 0 0 rgb(0 0 0 / 0.06);
578
751
  }
579
752
 
580
- /* ── Card hover transitions ── */
581
- .card-hover {
582
- transition-property: color, background-color, border-color, box-shadow;
583
- transition-duration: var(--duration-normal);
584
- transition-timing-function: ease;
585
- }
586
- .card-hover:hover {
587
- border-color: color-mix(in srgb, var(--border) 50%, transparent);
588
- background-color: color-mix(in srgb, var(--muted) 30%, transparent);
753
+ @media (prefers-reduced-motion: no-preference) {
754
+ &:hover:not(:disabled) {
755
+ animation: btn-gold-bg-sweep var(--duration-shimmer) linear infinite;
756
+ }
589
757
  }
758
+ }
590
759
 
591
- .card-hover-interactive {
592
- transition-property: color, background-color, border-color, box-shadow;
593
- transition-duration: var(--duration-normal);
594
- transition-timing-function: ease;
595
- }
596
- .card-hover-interactive:hover {
597
- border-color: color-mix(in srgb, var(--primary) 30%, transparent);
598
- background-color: color-mix(in srgb, var(--primary) 5%, transparent);
599
- }
760
+ /* Background-position sweep for the gold CTA hover shimmer.
761
+ Distinct from `gold-shimmer-slide` (which animates background-position for
762
+ a text-clip gradient). This variant sweeps the `background-position` of the
763
+ 250% wide gradient across the button's bounding box. */
764
+ @keyframes btn-gold-bg-sweep {
765
+ 0% { background-position: 0 0, 100% 0; }
766
+ 100% { background-position: 0 0, -100% 0; }
767
+ }
600
768
 
601
- /* ── Sort button active state ── */
602
- .sort-button-active {
603
- background-color: color-mix(in srgb, var(--primary) 10%, transparent);
604
- color: var(--primary);
605
- border-color: color-mix(in srgb, var(--primary) 30%, transparent);
606
- }
769
+ /* ── Table density utilities AN.R0 ─────────────────────────────────────
770
+ `table-cell` and `table-head` replace the former Tailwind `p-4` / `h-12`
771
+ literals in TableCell.vue / TableHead.vue. Both read `--table-density`
772
+ (tokens.css §19) so a single CSS-var assignment on a wrapping element
773
+ scales all row padding + header height simultaneously. Default density=1
774
+ resolves to the identical geometry as the previous Tailwind literals. */
775
+ @utility table-cell {
776
+ padding-inline: var(--table-cell-px, 1rem);
777
+ padding-block: var(--table-cell-py, 1rem);
778
+ }
607
779
 
608
- /* ── Heatmap color scale (10 levels, light mode) ── */
609
- .heatmap-1 {
610
- background-color: rgb(254 226 226);
611
- color: rgb(127 29 29);
612
- }
613
- .heatmap-2 {
614
- background-color: rgb(254 202 202);
615
- color: rgb(127 29 29);
616
- }
617
- .heatmap-3 {
618
- background-color: rgb(252 165 165);
619
- color: rgb(127 29 29);
620
- }
621
- .heatmap-4 {
622
- background-color: rgb(248 113 113);
623
- color: rgb(127 29 29);
624
- }
625
- .heatmap-5 {
626
- background-color: rgb(239 68 68);
627
- color: rgb(220 38 38);
628
- }
629
- .heatmap-6 {
630
- background-color: rgb(220 38 38);
631
- color: rgb(254 226 226);
632
- }
633
- .heatmap-7 {
634
- background-color: rgb(185 28 28);
635
- color: rgb(254 226 226);
636
- }
637
- .heatmap-8 {
638
- background-color: rgb(153 27 27);
639
- color: rgb(254 226 226);
640
- }
641
- .heatmap-9 {
642
- background-color: rgb(127 29 29);
643
- color: rgb(254 226 226);
644
- }
645
- .heatmap-10 {
646
- background-color: rgb(69 10 10);
647
- color: rgb(254 226 226);
648
- }
780
+ @utility table-head {
781
+ height: var(--table-head-h, 3rem);
782
+ padding-inline: var(--table-head-px, 1rem);
783
+ }
649
784
 
650
- /* ── Heatmap color scale (dark mode) ── */
651
- .dark .heatmap-1 {
652
- background-color: rgb(30 10 10);
653
- color: rgb(156 163 175);
654
- }
655
- .dark .heatmap-2 {
656
- background-color: rgb(45 15 15);
657
- color: rgb(209 213 219);
658
- }
659
- .dark .heatmap-3 {
660
- background-color: rgb(69 10 10);
661
- color: rgb(229 231 235);
662
- }
663
- .dark .heatmap-4 {
664
- background-color: rgb(91 15 15);
665
- color: rgb(243 244 246);
666
- }
667
- .dark .heatmap-5 {
668
- background-color: rgb(127 29 29);
669
- color: rgb(249 250 251);
670
- }
671
- .dark .heatmap-6 {
672
- background-color: rgb(153 27 27);
673
- color: rgb(254 226 226);
674
- }
675
- .dark .heatmap-7 {
676
- background-color: rgb(185 28 28);
677
- color: rgb(254 242 242);
678
- }
679
- .dark .heatmap-8 {
680
- background-color: rgb(220 38 38);
681
- color: rgb(255 251 251);
785
+ /* ── Rainbow gradient backgrounds (Q.W3 Lane E re-promote) ──────────────
786
+ `.rainbow-vivid` + `.rainbow-pastel` paint a left-to-right 7-stop spectrum
787
+ from the canonical `--rainbow-*` / `--rainbow-pastel-*` token families
788
+ (tokens.css §14). They were retired at `b0debec` (D.W2.D, 2026-04-30)
789
+ under a zero-consumer audit that did not include keyframes.js in its
790
+ sweep corpus — keyframes.js's `AnimationMenuBar.vue` round play button
791
+ composes `rainbow-vivid` (playing) / `rainbow-pastel` (idle) and silently
792
+ lost its gradient when the recipes left the library. The `--rainbow-*`
793
+ color tokens survived the retiral; only the class recipes were dropped.
794
+
795
+ Re-promoted as `@utility` recipes — the token half is canonical, so the
796
+ class form that paints it belongs alongside it. Not a backwards-compat
797
+ alias: it is a substrate REVERT, the revert IS the consumer rediscovery
798
+ (≥ 1 consumer exists post-revert, satisfying L invariant 8). Faithful
799
+ to the pre-`b0debec` recipe bodies. */
800
+ @utility rainbow-vivid {
801
+ background: linear-gradient(
802
+ to right,
803
+ var(--rainbow-red),
804
+ var(--rainbow-orange),
805
+ var(--rainbow-yellow),
806
+ var(--rainbow-green),
807
+ var(--rainbow-blue),
808
+ var(--rainbow-indigo),
809
+ var(--rainbow-violet)
810
+ );
811
+ }
812
+
813
+ @utility rainbow-pastel {
814
+ background: linear-gradient(
815
+ to right,
816
+ var(--rainbow-pastel-red),
817
+ var(--rainbow-pastel-orange),
818
+ var(--rainbow-pastel-yellow),
819
+ var(--rainbow-pastel-green),
820
+ var(--rainbow-pastel-blue),
821
+ var(--rainbow-pastel-indigo),
822
+ var(--rainbow-pastel-violet)
823
+ );
824
+ }
825
+
826
+ /* ── Interactive-button four-state recipe (Q.W3 Lane E re-promote) ───────
827
+ `.btn-interactive` carries the canonical "Button-with-spring-hover"
828
+ four-state contract — transition + hover-scale (`--scale-hover`) +
829
+ active-press (`--scale-press`) + disabled-opacity (`--opacity-disabled`)
830
+ + focus-ring fade-in. Same shape as `.btn-audacious` (a composition-only
831
+ recipe a Button variant opts into). Retired at `b0debec` (D.W2.D)
832
+ alongside the rainbow recipes under the same incomplete audit corpus;
833
+ keyframes.js consumes it at 7 sites (CubeScene, EasingScene, demo/cube,
834
+ AnimationControlsGroup RIBBON_BUTTON_CLASS, PlaybackRibbon Reverse).
835
+
836
+ The Button primitive's own variants emit the four states except
837
+ `hover:scale-*` — `.btn-interactive` is the canonical opt-in that adds
838
+ the spring-hover lift. Faithful to the pre-`b0debec` recipe body. */
839
+ @utility btn-interactive {
840
+ transition:
841
+ background-color var(--duration-fast) var(--ease-standard),
842
+ color var(--duration-fast) var(--ease-standard),
843
+ transform var(--duration-fast) var(--ease-standard),
844
+ opacity var(--duration-fast) var(--ease-standard);
845
+
846
+ &:hover {
847
+ transform: scale(var(--scale-hover));
682
848
  }
683
- .dark .heatmap-9 {
684
- background-color: rgb(239 68 68);
685
- color: rgb(255 255 255);
849
+
850
+ &:active {
851
+ transform: scale(var(--scale-press));
686
852
  }
687
- .dark .heatmap-10 {
688
- background-color: rgb(248 113 113);
689
- color: rgb(255 255 255);
853
+
854
+ &:disabled {
855
+ opacity: var(--opacity-disabled);
856
+ pointer-events: none;
690
857
  }
691
- }
692
858
 
693
- @keyframes shimmer {
694
- 0% { background-position: 250% 0; }
695
- 100% { background-position: -250% 0; }
859
+ &:focus-visible {
860
+ box-shadow: var(--focus-ring-shadow);
861
+ outline: none;
862
+ /* Fade in; base state has no box-shadow transition → instant
863
+ removal */
864
+ transition:
865
+ background-color var(--duration-fast) var(--ease-standard),
866
+ color var(--duration-fast) var(--ease-standard),
867
+ transform var(--duration-fast) var(--ease-standard),
868
+ opacity var(--duration-fast) var(--ease-standard),
869
+ box-shadow var(--duration-fast) var(--ease-standard);
870
+ }
696
871
  }
697
872
 
698
873
  /* ── Reduced motion: nuanced — preserve opacity, remove spatial motion ── */